123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- import FileProvider
- class FileProviderEnumerator: NSObject, NSFileProviderEnumerator {
-
- var enumeratedItemIdentifier: NSFileProviderItemIdentifier
- let recordForPage = 10
- var serverUrl: String?
-
- init(enumeratedItemIdentifier: NSFileProviderItemIdentifier) {
-
- self.enumeratedItemIdentifier = enumeratedItemIdentifier
-
-
- if #available(iOSApplicationExtension 11.0, *) {
- if (enumeratedItemIdentifier == .rootContainer) {
- serverUrl = homeServerUrl
- } else {
- if let metadata = NCManageDatabase.sharedInstance.getMetadata(predicate: NSPredicate(format: "account = %@ AND fileID = %@", account, enumeratedItemIdentifier.rawValue)) {
- if let directorySource = NCManageDatabase.sharedInstance.getTableDirectory(predicate: NSPredicate(format: "account = %@ AND directoryID = %@", account, metadata.directoryID)) {
- serverUrl = directorySource.serverUrl + "/" + metadata.fileName
- }
- }
- }
- }
-
- super.init()
- }
- func invalidate() {
-
- }
- func enumerateItems(for observer: NSFileProviderEnumerationObserver, startingAt page: NSFileProviderPage) {
-
- var items: [NSFileProviderItemProtocol] = []
- var metadatas: [tableMetadata]?
- if #available(iOSApplicationExtension 11.0, *) {
-
- guard let serverUrl = serverUrl else {
- observer.finishEnumerating(upTo: nil)
- return
- }
-
-
- if let directory = NCManageDatabase.sharedInstance.getTableDirectory(predicate: NSPredicate(format: "account = %@ AND serverUrl = %@", account, serverUrl)) {
- metadatas = NCManageDatabase.sharedInstance.getMetadatas(predicate: NSPredicate(format: "account = %@ AND directoryID = %@", account, directory.directoryID), sorted: "fileName", ascending: true)
- }
-
-
- if (page != NSFileProviderPage.initialPageSortedByDate as NSFileProviderPage && page != NSFileProviderPage.initialPageSortedByName as NSFileProviderPage) {
-
- var numPage = Int(String(data: page.rawValue, encoding: .utf8)!)!
-
- if (metadatas != nil) {
- items = self.selectItems(numPage: numPage, account: account, serverUrl: serverUrl, metadatas: metadatas!)
- observer.didEnumerate(items)
- }
- if (items.count == self.recordForPage) {
- numPage += 1
- let providerPage = NSFileProviderPage("\(numPage)".data(using: .utf8)!)
- observer.finishEnumerating(upTo: providerPage)
- } else {
- observer.finishEnumerating(upTo: nil)
- }
- return
- }
-
-
- ocNetworking?.readFolder(withServerUrl: serverUrl, depth: "1", account: account, success: { (metadatas, metadataFolder, directoryID) in
-
- if (metadatas != nil) {
- NCManageDatabase.sharedInstance.deleteMetadata(predicate: NSPredicate(format: "account = %@ AND directoryID = %@ AND session = ''", account, directoryID!), clearDateReadDirectoryID: directoryID!)
- if let metadataDB = NCManageDatabase.sharedInstance.addMetadatas(metadatas as! [tableMetadata], serverUrl: serverUrl) {
- items = self.selectItems(numPage: 0, account: account, serverUrl: serverUrl, metadatas: metadataDB)
- observer.didEnumerate(items)
- }
- }
- if (items.count == self.recordForPage) {
- let providerPage = NSFileProviderPage("1".data(using: .utf8)!)
- observer.finishEnumerating(upTo: providerPage)
- } else {
- observer.finishEnumerating(upTo: nil)
- }
-
- }, failure: { (message, errorCode) in
-
-
- if (metadatas != nil) {
- items = self.selectItems(numPage: 0, account: account, serverUrl: serverUrl, metadatas: metadatas!)
- observer.didEnumerate(items)
- }
- if (items.count == self.recordForPage) {
- let providerPage = NSFileProviderPage("1".data(using: .utf8)!)
- observer.finishEnumerating(upTo: providerPage)
- } else {
- observer.finishEnumerating(upTo: nil)
- }
- })
-
- } else {
-
- observer.finishEnumerating(upTo: nil)
- }
- }
-
- func selectItems(numPage: Int, account: String, serverUrl: String, metadatas: [tableMetadata]) -> [NSFileProviderItemProtocol] {
-
- var items: [NSFileProviderItemProtocol] = []
- let start = numPage * self.recordForPage + 1
- let stop = start + (self.recordForPage - 1)
- var counter = 0
- for metadata in metadatas {
- counter += 1
- if (counter >= start && counter <= stop) {
- let item = FileProviderItem(metadata: metadata, serverUrl: serverUrl)
- items.append(item)
- }
- }
-
- return items
- }
-
- func enumerateChanges(for observer: NSFileProviderChangeObserver, from anchor: NSFileProviderSyncAnchor) {
-
-
- observer.finishEnumeratingChanges(upTo: anchor, moreComing: false)
- }
-
- func currentSyncAnchor(completionHandler: @escaping (NSFileProviderSyncAnchor?) -> Void) {
-
- guard let serverUrl = serverUrl else {
- return
- }
-
- let anchor = NSFileProviderSyncAnchor(serverUrl.data(using: .utf8)!)
- completionHandler(anchor)
- }
- }
|