123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- import UIKit
- class fileProviderUtility: NSObject {
- static let shared: fileProviderUtility = {
- let instance = fileProviderUtility()
- return instance
- }()
- var fileManager = FileManager()
- func getAccountFromItemIdentifier(_ itemIdentifier: NSFileProviderItemIdentifier) -> String? {
- let ocId = itemIdentifier.rawValue
- return NCManageDatabase.shared.getMetadataFromOcId(ocId)?.account
- }
- func getTableMetadataFromItemIdentifier(_ itemIdentifier: NSFileProviderItemIdentifier) -> tableMetadata? {
- let ocId = itemIdentifier.rawValue
- return NCManageDatabase.shared.getMetadataFromOcId(ocId)
- }
- func getItemIdentifier(metadata: tableMetadata) -> NSFileProviderItemIdentifier {
- return NSFileProviderItemIdentifier(metadata.ocId)
- }
- func createocIdentifierOnFileSystem(metadata: tableMetadata) {
- let itemIdentifier = getItemIdentifier(metadata: metadata)
- if metadata.directory {
- CCUtility.getDirectoryProviderStorageOcId(itemIdentifier.rawValue)
- } else {
- CCUtility.getDirectoryProviderStorageOcId(itemIdentifier.rawValue, fileNameView: metadata.fileNameView)
- }
- }
- func getParentItemIdentifier(metadata: tableMetadata) -> NSFileProviderItemIdentifier? {
- let homeServerUrl = NCUtilityFileSystem.shared.getHomeServer(urlBase: metadata.urlBase, userId: metadata.userId)
- if let directory = NCManageDatabase.shared.getTableDirectory(predicate: NSPredicate(format: "account == %@ AND serverUrl == %@", metadata.account, metadata.serverUrl)) {
- if directory.serverUrl == homeServerUrl {
- return NSFileProviderItemIdentifier(NSFileProviderItemIdentifier.rootContainer.rawValue)
- } else {
-
- if let metadata = NCManageDatabase.shared.getMetadataFromOcId(directory.ocId) {
- let identifier = getItemIdentifier(metadata: metadata)
- return identifier
- }
- }
- }
- return nil
- }
- func getTableDirectoryFromParentItemIdentifier(_ parentItemIdentifier: NSFileProviderItemIdentifier, account: String, homeServerUrl: String) -> tableDirectory? {
- var predicate: NSPredicate
- if parentItemIdentifier == .rootContainer {
- predicate = NSPredicate(format: "account == %@ AND serverUrl == %@", account, homeServerUrl)
- } else {
- guard let metadata = getTableMetadataFromItemIdentifier(parentItemIdentifier) else { return nil }
- predicate = NSPredicate(format: "ocId == %@", metadata.ocId)
- }
- guard let directory = NCManageDatabase.shared.getTableDirectory(predicate: predicate) else { return nil }
- return directory
- }
-
- func copyFile(_ atPath: String, toPath: String) -> Error? {
- var errorResult: Error?
- if !fileManager.fileExists(atPath: atPath) { return NSError(domain: NSCocoaErrorDomain, code: NSFileNoSuchFileError, userInfo: [:]) }
- do {
- try fileManager.removeItem(atPath: toPath)
- } catch let error {
- print("error: \(error)")
- }
- do {
- try fileManager.copyItem(atPath: atPath, toPath: toPath)
- } catch let error {
- errorResult = error
- }
- return errorResult
- }
- func moveFile(_ atPath: String, toPath: String) -> Error? {
- var errorResult: Error?
- if atPath == toPath { return nil }
- if !fileManager.fileExists(atPath: atPath) { return NSError(domain: NSCocoaErrorDomain, code: NSFileNoSuchFileError, userInfo: [:]) }
- do {
- try fileManager.removeItem(atPath: toPath)
- } catch let error {
- print("error: \(error)")
- }
- do {
- try fileManager.moveItem(atPath: atPath, toPath: toPath)
- } catch let error {
- errorResult = error
- }
- return errorResult
- }
- func deleteFile(_ atPath: String) -> Error? {
- var errorResult: Error?
- do {
- try fileManager.removeItem(atPath: atPath)
- } catch let error {
- errorResult = error
- }
- return errorResult
- }
- func fileExists(atPath: String) -> Bool {
- return fileManager.fileExists(atPath: atPath)
- }
- }
|