FileProviderItem.swift 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. //
  2. // FileProviderItem.swift
  3. // Files
  4. //
  5. // Created by Marino Faggiana on 26/03/18.
  6. // Copyright © 2018 TWS. All rights reserved.
  7. //
  8. import FileProvider
  9. class FileProviderItem: NSObject, NSFileProviderItem {
  10. // TODO: implement an initializer to create an item from your extension's backing model
  11. // TODO: implement the accessors to return the values from your extension's backing model
  12. // Providing Required Properties
  13. var itemIdentifier: NSFileProviderItemIdentifier // The item's persistent identifier
  14. var filename: String = "" // The item's filename
  15. var typeIdentifier: String = "" // The item's uniform type identifiers
  16. var capabilities: NSFileProviderItemCapabilities { // The item's capabilities
  17. if (self.isDirectory) {
  18. return [ .allowsAddingSubItems, .allowsContentEnumerating, .allowsReading ]
  19. } else {
  20. return [ .allowsReading ]
  21. }
  22. }
  23. // Managing Content
  24. var childItemCount: NSNumber? // The number of items contained by this item
  25. var documentSize: NSNumber? // The document's size, in bytes
  26. // Specifying Content Location
  27. var parentItemIdentifier: NSFileProviderItemIdentifier // The persistent identifier of the item's parent folder
  28. var isTrashed: Bool = false // A Boolean value that indicates whether an item is in the trash
  29. // Tracking Usage
  30. var contentModificationDate: Date? // The date the item was last modified
  31. var creationDate: Date? // The date the item was created
  32. //var lastUsedDate: Date? // The date the item was last used
  33. // Tracking Versions
  34. var versionIdentifier: Data? // A data value used to determine when the item changes
  35. var isMostRecentVersionDownloaded: Bool = false // A Boolean value that indicates whether the item is the most recent version downloaded from the server
  36. // Monitoring File Transfers
  37. var isUploading: Bool = false // A Boolean value that indicates whether the item is currently uploading to your remote server
  38. var isUploaded: Bool = true // A Boolean value that indicates whether the item has been uploaded to your remote server
  39. var uploadingError: Error? // An error that occurred while uploading to your remote server
  40. var isDownloading: Bool = false // A Boolean value that indicates whether the item is currently downloading from your remote server
  41. var isDownloaded: Bool = true // A Boolean value that indicates whether the item has been downloaded from your remote server
  42. var downloadingError: Error? // An error that occurred while downloading the item
  43. var isDirectory = false;
  44. init(metadata: tableMetadata, serverUrl: String) {
  45. self.contentModificationDate = metadata.date as Date
  46. self.creationDate = metadata.date as Date
  47. self.documentSize = NSNumber(value: metadata.size)
  48. self.filename = metadata.fileNameView
  49. self.itemIdentifier = NSFileProviderItemIdentifier("\(metadata.fileID)")
  50. self.isDirectory = metadata.directory
  51. // parentItemIdentifier
  52. if #available(iOSApplicationExtension 11.0, *) {
  53. self.parentItemIdentifier = NSFileProviderItemIdentifier.rootContainer
  54. // NOT .rootContainer
  55. if (serverUrl != homeServerUrl) {
  56. if let directoryParent = NCManageDatabase.sharedInstance.getTableDirectory(predicate: NSPredicate(format: "account = %@ AND directoryID = %@", metadata.account, metadata.directoryID)) {
  57. if let metadataParent = NCManageDatabase.sharedInstance.getMetadata(predicate: NSPredicate(format: "account = %@ AND fileID = %@", metadata.account, directoryParent.fileID)) {
  58. self.parentItemIdentifier = NSFileProviderItemIdentifier(metadataParent.fileID)
  59. }
  60. }
  61. }
  62. } else {
  63. // < iOS 11
  64. self.parentItemIdentifier = NSFileProviderItemIdentifier("")
  65. }
  66. // typeIdentifier
  67. if let fileType = CCUtility.insertTypeFileIconName(metadata.fileNameView, metadata: metadata) {
  68. self.typeIdentifier = fileType
  69. }
  70. self.versionIdentifier = metadata.etag.data(using: .utf8)
  71. // Verify file exists on cache
  72. if (!metadata.directory) {
  73. let filePath = "\(directoryUser)/\(metadata.fileID)"
  74. if FileManager().fileExists(atPath: filePath) {
  75. self.isDownloaded = true
  76. self.isMostRecentVersionDownloaded = true;
  77. } else {
  78. self.isDownloaded = false
  79. self.isMostRecentVersionDownloaded = false;
  80. }
  81. }
  82. }
  83. }