NCDatabase.swift 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. //
  2. // NCDatabase.swift
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 06/05/17.
  6. // Copyright © 2017 Marino Faggiana. All rights reserved.
  7. //
  8. // Author Marino Faggiana <marino.faggiana@nextcloud.com>
  9. // Author Henrik Storch <henrik.storch@nextcloud.com>
  10. //
  11. // This program is free software: you can redistribute it and/or modify
  12. // it under the terms of the GNU General Public License as published by
  13. // the Free Software Foundation, either version 3 of the License, or
  14. // (at your option) any later version.
  15. //
  16. // This program is distributed in the hope that it will be useful,
  17. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  19. // GNU General Public License for more details.
  20. //
  21. // You should have received a copy of the GNU General Public License
  22. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  23. //
  24. import UIKit
  25. import RealmSwift
  26. import NextcloudKit
  27. protocol DateCompareable {
  28. var dateKey: Date { get }
  29. }
  30. class tableAccount: Object, NCUserBaseUrl {
  31. @objc dynamic var account = ""
  32. @objc dynamic var active: Bool = false
  33. @objc dynamic var address = ""
  34. @objc dynamic var alias = ""
  35. @objc dynamic var autoUpload: Bool = false
  36. @objc dynamic var autoUploadCreateSubfolder: Bool = false
  37. @objc dynamic var autoUploadDirectory = ""
  38. @objc dynamic var autoUploadFileName = ""
  39. @objc dynamic var autoUploadFull: Bool = false
  40. @objc dynamic var autoUploadImage: Bool = false
  41. @objc dynamic var autoUploadVideo: Bool = false
  42. @objc dynamic var autoUploadWWAnPhoto: Bool = false
  43. @objc dynamic var autoUploadWWAnVideo: Bool = false
  44. @objc dynamic var backend = ""
  45. @objc dynamic var backendCapabilitiesSetDisplayName: Bool = false
  46. @objc dynamic var backendCapabilitiesSetPassword: Bool = false
  47. @objc dynamic var businessSize: String = ""
  48. @objc dynamic var businessType = ""
  49. @objc dynamic var city = ""
  50. @objc dynamic var country = ""
  51. @objc dynamic var displayName = ""
  52. @objc dynamic var email = ""
  53. @objc dynamic var enabled: Bool = false
  54. @objc dynamic var groups = ""
  55. @objc dynamic var language = ""
  56. @objc dynamic var lastLogin: Int64 = 0
  57. @objc dynamic var locale = ""
  58. @objc dynamic var mediaPath = ""
  59. @objc dynamic var organisation = ""
  60. @objc dynamic var password = ""
  61. @objc dynamic var phone = ""
  62. @objc dynamic var quota: Int64 = 0
  63. @objc dynamic var quotaFree: Int64 = 0
  64. @objc dynamic var quotaRelative: Double = 0
  65. @objc dynamic var quotaTotal: Int64 = 0
  66. @objc dynamic var quotaUsed: Int64 = 0
  67. @objc dynamic var role = ""
  68. @objc dynamic var storageLocation = ""
  69. @objc dynamic var subadmin = ""
  70. @objc dynamic var twitter = ""
  71. @objc dynamic var urlBase = ""
  72. @objc dynamic var user = ""
  73. @objc dynamic var userId = ""
  74. @objc dynamic var userStatusClearAt: NSDate?
  75. @objc dynamic var userStatusIcon: String?
  76. @objc dynamic var userStatusMessage: String?
  77. @objc dynamic var userStatusMessageId: String?
  78. @objc dynamic var userStatusMessageIsPredefined: Bool = false
  79. @objc dynamic var userStatusStatus: String?
  80. @objc dynamic var userStatusStatusIsUserDefined: Bool = false
  81. @objc dynamic var website = ""
  82. @objc dynamic var zip = ""
  83. // HC
  84. @objc dynamic var hcIsTrial: Bool = false
  85. @objc dynamic var hcTrialExpired: Bool = false
  86. @objc dynamic var hcTrialRemainingSec: Int64 = 0
  87. @objc dynamic var hcTrialEndTime: NSDate?
  88. @objc dynamic var hcAccountRemoveExpired: Bool = false
  89. @objc dynamic var hcAccountRemoveRemainingSec: Int64 = 0
  90. @objc dynamic var hcAccountRemoveTime: NSDate?
  91. @objc dynamic var hcNextGroupExpirationGroup = ""
  92. @objc dynamic var hcNextGroupExpirationGroupExpired: Bool = false
  93. @objc dynamic var hcNextGroupExpirationExpiresTime: NSDate?
  94. @objc dynamic var hcNextGroupExpirationExpires = ""
  95. override static func primaryKey() -> String {
  96. return "account"
  97. }
  98. }
  99. class tableActivity: Object, DateCompareable {
  100. var dateKey: Date { date as Date }
  101. @objc dynamic var account = ""
  102. @objc dynamic var idPrimaryKey = ""
  103. @objc dynamic var action = "Activity"
  104. @objc dynamic var date = NSDate()
  105. @objc dynamic var idActivity: Int = 0
  106. @objc dynamic var app = ""
  107. @objc dynamic var type = ""
  108. @objc dynamic var user = ""
  109. @objc dynamic var subject = ""
  110. @objc dynamic var subjectRich = ""
  111. let subjectRichItem = List<tableActivitySubjectRich>()
  112. @objc dynamic var icon = ""
  113. @objc dynamic var link = ""
  114. @objc dynamic var message = ""
  115. @objc dynamic var objectType = ""
  116. @objc dynamic var objectId: Int = 0
  117. @objc dynamic var objectName = ""
  118. @objc dynamic var note = ""
  119. @objc dynamic var selector = ""
  120. @objc dynamic var verbose: Bool = false
  121. override static func primaryKey() -> String {
  122. return "idPrimaryKey"
  123. }
  124. }
  125. class tableActivityLatestId: Object {
  126. @objc dynamic var account = ""
  127. @objc dynamic var activityFirstKnown: Int = 0
  128. @objc dynamic var activityLastGiven: Int = 0
  129. override static func primaryKey() -> String {
  130. return "account"
  131. }
  132. }
  133. class tableActivityPreview: Object {
  134. @objc dynamic var account = ""
  135. @objc dynamic var filename = ""
  136. @objc dynamic var idPrimaryKey = ""
  137. @objc dynamic var idActivity: Int = 0
  138. @objc dynamic var source = ""
  139. @objc dynamic var link = ""
  140. @objc dynamic var mimeType = ""
  141. @objc dynamic var fileId: Int = 0
  142. @objc dynamic var view = ""
  143. @objc dynamic var isMimeTypeIcon: Bool = false
  144. override static func primaryKey() -> String {
  145. return "idPrimaryKey"
  146. }
  147. }
  148. class tableActivitySubjectRich: Object {
  149. @objc dynamic var account = ""
  150. @objc dynamic var idActivity: Int = 0
  151. @objc dynamic var idPrimaryKey = ""
  152. @objc dynamic var id = ""
  153. @objc dynamic var key = ""
  154. @objc dynamic var link = ""
  155. @objc dynamic var name = ""
  156. @objc dynamic var path = ""
  157. @objc dynamic var type = ""
  158. override static func primaryKey() -> String {
  159. return "idPrimaryKey"
  160. }
  161. }
  162. class tableAvatar: Object {
  163. @objc dynamic var date = NSDate()
  164. @objc dynamic var etag = ""
  165. @objc dynamic var fileName = ""
  166. @objc dynamic var loaded: Bool = false
  167. override static func primaryKey() -> String {
  168. return "fileName"
  169. }
  170. }
  171. class tableCapabilities: Object {
  172. @objc dynamic var account = ""
  173. @objc dynamic var jsondata: Data?
  174. override static func primaryKey() -> String {
  175. return "account"
  176. }
  177. }
  178. class tableChunk: Object {
  179. @objc dynamic var account = ""
  180. @objc dynamic var chunkFolder = ""
  181. @objc dynamic var fileName = ""
  182. @objc dynamic var index = ""
  183. @objc dynamic var ocId = ""
  184. @objc dynamic var size: Int64 = 0
  185. override static func primaryKey() -> String {
  186. return "index"
  187. }
  188. }
  189. class tableComments: Object, DateCompareable {
  190. var dateKey: Date { creationDateTime as Date }
  191. @objc dynamic var account = ""
  192. @objc dynamic var actorDisplayName = ""
  193. @objc dynamic var actorId = ""
  194. @objc dynamic var actorType = ""
  195. @objc dynamic var creationDateTime = NSDate()
  196. @objc dynamic var isUnread: Bool = false
  197. @objc dynamic var message = ""
  198. @objc dynamic var messageId = ""
  199. @objc dynamic var objectId = ""
  200. @objc dynamic var objectType = ""
  201. @objc dynamic var path = ""
  202. @objc dynamic var verb = ""
  203. override static func primaryKey() -> String {
  204. return "messageId"
  205. }
  206. }
  207. class tableDirectEditingCreators: Object {
  208. @objc dynamic var account = ""
  209. @objc dynamic var editor = ""
  210. @objc dynamic var ext = ""
  211. @objc dynamic var identifier = ""
  212. @objc dynamic var mimetype = ""
  213. @objc dynamic var name = ""
  214. @objc dynamic var templates: Int = 0
  215. }
  216. class tableDashboardWidget: Object {
  217. @Persisted var account = ""
  218. @Persisted var id = ""
  219. @Persisted var title = ""
  220. @Persisted var order: Int = 0
  221. @Persisted var iconClass: String?
  222. @Persisted var iconUrl: String?
  223. @Persisted var widgetUrl: String?
  224. let button = List<tableDashboardWidgetButton>()
  225. @Persisted var index = ""
  226. override static func primaryKey() -> String {
  227. return "index"
  228. }
  229. }
  230. class tableDashboardWidgetButton: Object {
  231. @Persisted var account = ""
  232. @Persisted var id = ""
  233. @Persisted var type = ""
  234. @Persisted var text = ""
  235. @Persisted var link = ""
  236. @Persisted var index = ""
  237. override static func primaryKey() -> String {
  238. return "index"
  239. }
  240. }
  241. class tableDirectEditingEditors: Object {
  242. @objc dynamic var account = ""
  243. @objc dynamic var editor = ""
  244. let mimetypes = List<String>()
  245. @objc dynamic var name = ""
  246. let optionalMimetypes = List<String>()
  247. @objc dynamic var secure: Int = 0
  248. }
  249. class tableDirectory: Object {
  250. @objc dynamic var account = ""
  251. @objc dynamic var colorFolder: String?
  252. @objc dynamic var e2eEncrypted: Bool = false
  253. @objc dynamic var etag = ""
  254. @objc dynamic var favorite: Bool = false
  255. @objc dynamic var fileId = ""
  256. @objc dynamic var ocId = ""
  257. @objc dynamic var offline: Bool = false
  258. @objc dynamic var permissions = ""
  259. @objc dynamic var richWorkspace: String?
  260. @objc dynamic var serverUrl = ""
  261. override static func primaryKey() -> String {
  262. return "ocId"
  263. }
  264. }
  265. class tableE2eEncryption: Object {
  266. @objc dynamic var account = ""
  267. @objc dynamic var authenticationTag: String?
  268. @objc dynamic var fileName = ""
  269. @objc dynamic var fileNameIdentifier = ""
  270. @objc dynamic var fileNamePath = ""
  271. @objc dynamic var key = ""
  272. @objc dynamic var initializationVector = ""
  273. @objc dynamic var metadataKey = ""
  274. @objc dynamic var metadataKeyIndex: Int = 0
  275. @objc dynamic var mimeType = ""
  276. @objc dynamic var serverUrl = ""
  277. @objc dynamic var version: Int = 1
  278. override static func primaryKey() -> String {
  279. return "fileNamePath"
  280. }
  281. }
  282. class tableE2eEncryptionLock: Object {
  283. @objc dynamic var account = ""
  284. @objc dynamic var date = NSDate()
  285. @objc dynamic var fileId = ""
  286. @objc dynamic var serverUrl = ""
  287. @objc dynamic var e2eToken = ""
  288. override static func primaryKey() -> String {
  289. return "fileId"
  290. }
  291. }
  292. class tableExternalSites: Object {
  293. @objc dynamic var account = ""
  294. @objc dynamic var icon = ""
  295. @objc dynamic var idExternalSite: Int = 0
  296. @objc dynamic var lang = ""
  297. @objc dynamic var name = ""
  298. @objc dynamic var type = ""
  299. @objc dynamic var url = ""
  300. }
  301. class tableGPS: Object {
  302. @objc dynamic var latitude = ""
  303. @objc dynamic var location = ""
  304. @objc dynamic var longitude = ""
  305. @objc dynamic var placemarkAdministrativeArea = ""
  306. @objc dynamic var placemarkCountry = ""
  307. @objc dynamic var placemarkLocality = ""
  308. @objc dynamic var placemarkPostalCode = ""
  309. @objc dynamic var placemarkThoroughfare = ""
  310. }
  311. class tableLocalFile: Object {
  312. @objc dynamic var account = ""
  313. @objc dynamic var etag = ""
  314. @objc dynamic var exifDate: NSDate?
  315. @objc dynamic var exifLatitude = ""
  316. @objc dynamic var exifLongitude = ""
  317. @objc dynamic var exifLensModel: String?
  318. @objc dynamic var favorite: Bool = false
  319. @objc dynamic var fileName = ""
  320. @objc dynamic var ocId = ""
  321. @objc dynamic var offline: Bool = false
  322. override static func primaryKey() -> String {
  323. return "ocId"
  324. }
  325. }
  326. class tableMetadata: Object, NCUserBaseUrl {
  327. override func isEqual(_ object: Any?) -> Bool {
  328. if let object = object as? tableMetadata {
  329. return self.fileId == object.fileId && self.account == object.account
  330. && self.path == object.path && self.fileName == object.fileName
  331. } else {
  332. return false
  333. }
  334. }
  335. @objc dynamic var account = ""
  336. @objc dynamic var assetLocalIdentifier = ""
  337. @objc dynamic var checksums = ""
  338. @objc dynamic var chunk: Bool = false
  339. @objc dynamic var classFile = ""
  340. @objc dynamic var commentsUnread: Bool = false
  341. @objc dynamic var contentType = ""
  342. @objc dynamic var creationDate = NSDate()
  343. @objc dynamic var dataFingerprint = ""
  344. @objc dynamic var date = NSDate()
  345. @objc dynamic var directory: Bool = false
  346. @objc dynamic var deleteAssetLocalIdentifier: Bool = false
  347. @objc dynamic var downloadURL = ""
  348. @objc dynamic var e2eEncrypted: Bool = false
  349. @objc dynamic var edited: Bool = false
  350. @objc dynamic var etag = ""
  351. @objc dynamic var etagResource = ""
  352. @objc dynamic var ext = ""
  353. @objc dynamic var favorite: Bool = false
  354. @objc dynamic var fileId = ""
  355. @objc dynamic var fileName = ""
  356. @objc dynamic var fileNameView = ""
  357. @objc dynamic var fileNameWithoutExt = ""
  358. @objc dynamic var hasPreview: Bool = false
  359. @objc dynamic var iconName = ""
  360. @objc dynamic var iconUrl = ""
  361. @objc dynamic var isExtractFile: Bool = false
  362. @objc dynamic var livePhoto: Bool = false
  363. @objc dynamic var mountType = ""
  364. @objc dynamic var name = "" // for unifiedSearch is the provider.id
  365. @objc dynamic var note = ""
  366. @objc dynamic var ocId = ""
  367. @objc dynamic var ownerId = ""
  368. @objc dynamic var ownerDisplayName = ""
  369. @objc public var lock = false
  370. @objc public var lockOwner = ""
  371. @objc public var lockOwnerEditor = ""
  372. @objc public var lockOwnerType = 0
  373. @objc public var lockOwnerDisplayName = ""
  374. @objc public var lockTime: Date?
  375. @objc public var lockTimeOut: Date?
  376. @objc dynamic var path = ""
  377. @objc dynamic var permissions = ""
  378. @objc dynamic var quotaUsedBytes: Int64 = 0
  379. @objc dynamic var quotaAvailableBytes: Int64 = 0
  380. @objc dynamic var resourceType = ""
  381. @objc dynamic var richWorkspace: String?
  382. @objc dynamic var serverUrl = ""
  383. @objc dynamic var session = ""
  384. @objc dynamic var sessionError = ""
  385. @objc dynamic var sessionSelector = ""
  386. @objc dynamic var sessionTaskIdentifier: Int = 0
  387. @objc dynamic var sharePermissionsCollaborationServices: Int = 0
  388. let sharePermissionsCloudMesh = List<String>()
  389. let shareType = List<Int>()
  390. @objc dynamic var size: Int64 = 0
  391. @objc dynamic var status: Int = 0
  392. @objc dynamic var subline: String?
  393. @objc dynamic var trashbinFileName = ""
  394. @objc dynamic var trashbinOriginalLocation = ""
  395. @objc dynamic var trashbinDeletionTime = NSDate()
  396. @objc dynamic var uploadDate = NSDate()
  397. @objc dynamic var url = ""
  398. @objc dynamic var urlBase = ""
  399. @objc dynamic var user = ""
  400. @objc dynamic var userId = ""
  401. override static func primaryKey() -> String {
  402. return "ocId"
  403. }
  404. }
  405. extension tableMetadata {
  406. var fileExtension: String { (fileNameView as NSString).pathExtension }
  407. var isPrintable: Bool {
  408. classFile == NKCommon.typeClassFile.image.rawValue || ["application/pdf", "com.adobe.pdf"].contains(contentType) || contentType.hasPrefix("text/")
  409. }
  410. /// Returns false if the user is lokced out of the file. I.e. The file is locked but by somone else
  411. func canUnlock(as user: String) -> Bool {
  412. return !lock || (lockOwner == user && lockOwnerType == 0)
  413. }
  414. }
  415. class tablePhotoLibrary: Object {
  416. @objc dynamic var account = ""
  417. @objc dynamic var assetLocalIdentifier = ""
  418. @objc dynamic var creationDate: NSDate?
  419. @objc dynamic var idAsset = ""
  420. @objc dynamic var modificationDate: NSDate?
  421. @objc dynamic var mediaType: Int = 0
  422. override static func primaryKey() -> String {
  423. return "idAsset"
  424. }
  425. }
  426. class tableShare: Object {
  427. @objc dynamic var account = ""
  428. @objc dynamic var canEdit: Bool = false
  429. @objc dynamic var canDelete: Bool = false
  430. @objc dynamic var date: NSDate?
  431. @objc dynamic var displaynameFileOwner = ""
  432. @objc dynamic var displaynameOwner = ""
  433. @objc dynamic var expirationDate: NSDate?
  434. @objc dynamic var fileName = ""
  435. @objc dynamic var fileParent: Int = 0
  436. @objc dynamic var fileSource: Int = 0
  437. @objc dynamic var fileTarget = ""
  438. @objc dynamic var hideDownload: Bool = false
  439. @objc dynamic var idShare: Int = 0
  440. @objc dynamic var itemSource: Int = 0
  441. @objc dynamic var itemType = ""
  442. @objc dynamic var label = ""
  443. @objc dynamic var mailSend: Bool = false
  444. @objc dynamic var mimeType = ""
  445. @objc dynamic var note = ""
  446. @objc dynamic var parent: String = ""
  447. @objc dynamic var password: String = ""
  448. @objc dynamic var path = ""
  449. @objc dynamic var permissions: Int = 0
  450. @objc dynamic var sendPasswordByTalk: Bool = false
  451. @objc dynamic var serverUrl = ""
  452. @objc dynamic var shareType: Int = 0
  453. @objc dynamic var shareWith = ""
  454. @objc dynamic var shareWithDisplayname = ""
  455. @objc dynamic var storage: Int = 0
  456. @objc dynamic var storageId = ""
  457. @objc dynamic var token = ""
  458. @objc dynamic var uidFileOwner = ""
  459. @objc dynamic var uidOwner = ""
  460. @objc dynamic var url = ""
  461. @objc dynamic var userClearAt: NSDate?
  462. @objc dynamic var userIcon = ""
  463. @objc dynamic var userMessage = ""
  464. @objc dynamic var userStatus = ""
  465. override static func primaryKey() -> String {
  466. return "idShare"
  467. }
  468. }
  469. class tableTag: Object {
  470. @objc dynamic var account = ""
  471. @objc dynamic var ocId = ""
  472. @objc dynamic var tagIOS: Data?
  473. override static func primaryKey() -> String {
  474. return "ocId"
  475. }
  476. }
  477. class tableTip: Object {
  478. @Persisted(primaryKey: true) var tipName = ""
  479. }
  480. class tableTrash: Object {
  481. @objc dynamic var account = ""
  482. @objc dynamic var classFile = ""
  483. @objc dynamic var contentType = ""
  484. @objc dynamic var date = NSDate()
  485. @objc dynamic var directory: Bool = false
  486. @objc dynamic var fileId = ""
  487. @objc dynamic var fileName = ""
  488. @objc dynamic var filePath = ""
  489. @objc dynamic var hasPreview: Bool = false
  490. @objc dynamic var iconName = ""
  491. @objc dynamic var size: Int64 = 0
  492. @objc dynamic var trashbinFileName = ""
  493. @objc dynamic var trashbinOriginalLocation = ""
  494. @objc dynamic var trashbinDeletionTime = NSDate()
  495. override static func primaryKey() -> String {
  496. return "fileId"
  497. }
  498. }
  499. class tableUserStatus: Object {
  500. @objc dynamic var account = ""
  501. @objc dynamic var clearAt: NSDate?
  502. @objc dynamic var clearAtTime: String?
  503. @objc dynamic var clearAtType: String?
  504. @objc dynamic var icon: String?
  505. @objc dynamic var id: String?
  506. @objc dynamic var message: String?
  507. @objc dynamic var predefined: Bool = false
  508. @objc dynamic var status: String?
  509. @objc dynamic var userId: String?
  510. }
  511. class tableVideo: Object {
  512. @objc dynamic var account = ""
  513. @objc dynamic var duration: Int64 = 0
  514. @objc dynamic var ocId = ""
  515. @objc dynamic var time: Int64 = 0
  516. @objc dynamic var codecNameVideo: String?
  517. @objc dynamic var codecNameAudio: String?
  518. @objc dynamic var codecAudioChannelLayout: String?
  519. @objc dynamic var codecAudioLanguage: String?
  520. @objc dynamic var codecMaxCompatibility: Bool = false
  521. @objc dynamic var codecQuality: String?
  522. override static func primaryKey() -> String {
  523. return "ocId"
  524. }
  525. }