NCGlobal.swift 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475
  1. //
  2. // NCGlobal.swift
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 22/02/21.
  6. // Copyright © 2021 Marino Faggiana. All rights reserved.
  7. //
  8. // Author Marino Faggiana <marino.faggiana@nextcloud.com>
  9. //
  10. // This program is free software: you can redistribute it and/or modify
  11. // it under the terms of the GNU General Public License as published by
  12. // the Free Software Foundation, either version 3 of the License, or
  13. // (at your option) any later version.
  14. //
  15. // This program is distributed in the hope that it will be useful,
  16. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. // GNU General Public License for more details.
  19. //
  20. // You should have received a copy of the GNU General Public License
  21. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. //
  23. import UIKit
  24. class NCGlobal: NSObject {
  25. @objc static let shared: NCGlobal = {
  26. let instance = NCGlobal()
  27. return instance
  28. }()
  29. func usernameToColor(_ username: String) -> CGColor {
  30. // Normalize hash
  31. let lowerUsername = username.lowercased()
  32. var hash: String
  33. let regex = try! NSRegularExpression(pattern: "^([0-9a-f]{4}-?){8}$")
  34. let matches = regex.matches(
  35. in: username,
  36. range: NSRange(username.startIndex..., in: username))
  37. if !matches.isEmpty {
  38. // Already a md5 hash?
  39. // done, use as is.
  40. hash = lowerUsername
  41. } else {
  42. hash = lowerUsername.md5()
  43. }
  44. hash = hash.replacingOccurrences(of: "[^0-9a-f]", with: "", options: .regularExpression)
  45. // userColors has 18 colors by default
  46. let userColorIx = NCGlobal.hashToInt(hash: hash, maximum: 18)
  47. return NCBrandColor.shared.userColors[userColorIx]
  48. }
  49. // Convert a string to an integer evenly
  50. // hash is hex string
  51. static func hashToInt(hash: String, maximum: Int) -> Int {
  52. let result = hash.compactMap(\.hexDigitValue)
  53. return result.reduce(0, { $0 + $1 }) % maximum
  54. }
  55. // Directory on Group
  56. //
  57. @objc let directoryProviderStorage = "File Provider Storage"
  58. @objc let appApplicationSupport = "Library/Application Support"
  59. @objc let appCertificates = "Library/Application Support/Certificates"
  60. @objc let appDatabaseNextcloud = "Library/Application Support/Nextcloud"
  61. @objc let appScan = "Library/Application Support/Scan"
  62. @objc let appUserData = "Library/Application Support/UserData"
  63. // Service
  64. //
  65. @objc let serviceShareKeyChain = "Crypto Cloud"
  66. let metadataKeyedUnarchiver = "it.twsweb.nextcloud.metadata"
  67. let refreshTask = "com.nextcloud.refreshTask"
  68. let processingTask = "com.nextcloud.processingTask"
  69. // App
  70. //
  71. let appName = "files"
  72. let appScheme = "nextcloud"
  73. let talkName = "talk-message"
  74. let spreedName = "spreed"
  75. let twoFactorNotificatioName = "twofactor_nextcloud_notification"
  76. // Nextcloud version
  77. //
  78. let nextcloudVersion12: Int = 12
  79. let nextcloudVersion15: Int = 15
  80. let nextcloudVersion17: Int = 17
  81. let nextcloudVersion18: Int = 18
  82. let nextcloudVersion20: Int = 20
  83. let nextcloudVersion23: Int = 23
  84. let nextcloudVersion24: Int = 24
  85. let nextcloudVersion25: Int = 25
  86. let nextcloudVersion26: Int = 26
  87. let nextcloudVersion27: Int = 27
  88. // Nextcloud unsupported
  89. //
  90. let nextcloud_unsupported_version: Int = 16
  91. // Intro selector
  92. //
  93. @objc let introLogin: Int = 0
  94. let introSignup: Int = 1
  95. // Varie size GUI
  96. //
  97. @objc let heightCellSettings: CGFloat = 50
  98. // Avatar & Preview size
  99. //
  100. let avatarSize: Int = 128 * Int(UIScreen.main.scale)
  101. let avatarSizeRounded: Int = 128
  102. let sizePreview: Int = 1024
  103. let sizeIcon: Int = 512
  104. // E2EE
  105. //
  106. let e2eePassphraseTest = "more over television factory tendency independence international intellectual impress interest sentence pony"
  107. @objc let e2eeVersions = ["1.1", "1.2", "2.0"]
  108. let e2eeVersionV11 = "1.1"
  109. let e2eeVersionV12 = "1.2"
  110. let e2eeVersionV20 = "2.0"
  111. // CHUNK
  112. let chunkSizeMBCellular = 10000000
  113. let chunkSizeMBEthernetOrWiFi = 100000000
  114. // Video
  115. //
  116. let maxHTTPCache: Int64 = 10000000000 // 10 GB
  117. let fileNameVideoEncoded: String = "video_encoded.mp4"
  118. // NCViewerProviderContextMenu
  119. //
  120. let maxAutoDownload: UInt64 = 50000000 // 50MB
  121. let maxAutoDownloadCellular: UInt64 = 10000000 // 10MB
  122. // Layout
  123. //
  124. let layoutList = "typeLayoutList"
  125. let layoutGrid = "typeLayoutGrid"
  126. let layoutViewTrash = "LayoutTrash"
  127. let layoutViewOffline = "LayoutOffline"
  128. let layoutViewFavorite = "LayoutFavorite"
  129. let layoutViewFiles = "LayoutFiles"
  130. let layoutViewTransfers = "LayoutTransfers"
  131. let layoutViewRecent = "LayoutRecent"
  132. let layoutViewShares = "LayoutShares"
  133. let layoutViewShareExtension = "LayoutShareExtension"
  134. let layoutViewGroupfolders = "LayoutGroupfolders"
  135. // Button Type in Cell list/grid
  136. //
  137. let buttonMoreMore = "more"
  138. let buttonMoreStop = "stop"
  139. let buttonMoreLock = "moreLock"
  140. // Standard height sections header/footer
  141. //
  142. let heightButtonsView: CGFloat = 50
  143. let heightHeaderTransfer: CGFloat = 50
  144. let heightSection: CGFloat = 30
  145. let heightFooter: CGFloat = 1
  146. let heightFooterButton: CGFloat = 30
  147. let endHeightFooter: CGFloat = 85
  148. // Text - OnlyOffice - Collabora - QuickLook
  149. //
  150. let editorText = "text"
  151. let editorOnlyoffice = "onlyoffice"
  152. let editorCollabora = "collabora"
  153. let editorQuickLook = "quicklook"
  154. let onlyofficeDocx = "onlyoffice_docx"
  155. let onlyofficeXlsx = "onlyoffice_xlsx"
  156. let onlyofficePptx = "onlyoffice_pptx"
  157. // Template
  158. //
  159. let templateDocument = "document"
  160. let templateSpreadsheet = "spreadsheet"
  161. let templatePresentation = "presentation"
  162. // Rich Workspace
  163. //
  164. let fileNameRichWorkspace = "Readme.md"
  165. // Extension
  166. //
  167. @objc let extensionPreview = "ico"
  168. // ContentPresenter
  169. //
  170. @objc let dismissAfterSecond: TimeInterval = 4
  171. @objc let dismissAfterSecondLong: TimeInterval = 10
  172. // Error
  173. //
  174. @objc let errorRequestExplicityCancelled: Int = 15
  175. @objc let errorNotModified: Int = 304
  176. @objc let errorBadRequest: Int = 400
  177. @objc let errorUnauthorized401: Int = 401
  178. @objc let errorForbidden: Int = 403
  179. @objc let errorResourceNotFound: Int = 404
  180. @objc let errorMethodNotSupported: Int = 405
  181. @objc let errorConflict: Int = 409
  182. @objc let errorPreconditionFailed: Int = 412
  183. @objc let errorQuota: Int = 507
  184. @objc let errorUnauthorized997: Int = 997
  185. @objc let errorConnectionLost: Int = -1005
  186. @objc let errorNetworkNotAvailable: Int = -1009
  187. @objc let errorBadServerResponse: Int = -1011
  188. @objc let errorInternalError: Int = -99999
  189. @objc let errorFileNotSaved: Int = -99998
  190. @objc let errorOffline: Int = -99997
  191. @objc let errorCharactersForbidden: Int = -99996
  192. @objc let errorCreationFile: Int = -99995
  193. @objc let errorReadFile: Int = -99994
  194. @objc let errorUnauthorizedFilesPasscode: Int = -99993
  195. @objc let errorDisableFilesApp: Int = -99992
  196. @objc let errorUnexpectedResponseFromDB: Int = -99991
  197. // E2EE
  198. @objc let errorE2EENotEnabled: Int = -98000
  199. @objc let errorE2EEVersion: Int = -98001
  200. @objc let errorE2EEKeyChecksums: Int = -98002
  201. @objc let errorE2EEKeyEncodeMetadata: Int = -98003
  202. @objc let errorE2EEKeyDecodeMetadata: Int = -98004
  203. @objc let errorE2EEKeyVerifySignature: Int = -98005
  204. @objc let errorE2EEKeyCiphertext: Int = -98006
  205. @objc let errorE2EEKeyFiledropCiphertext: Int = -98007
  206. @objc let errorE2EEJSon: Int = -98008
  207. @objc let errorE2EELock: Int = -98009
  208. @objc let errorE2EEEncryptFile: Int = -98010
  209. @objc let errorE2EEEncryptPayloadFile: Int = -98011
  210. @objc let errorE2EECounter: Int = -98012
  211. @objc let errorE2EEGenerateKey: Int = -98013
  212. @objc let errorE2EEEncodedKey: Int = -98014
  213. @objc let errorE2EENoUserFound: Int = -98015
  214. @objc let errorE2EEUploadInProgress: Int = -98016
  215. // Constants to identify the different permissions of a file
  216. //
  217. @objc let permissionShared = "S"
  218. @objc let permissionCanShare = "R"
  219. @objc let permissionMounted = "M"
  220. @objc let permissionFileCanWrite = "W"
  221. @objc let permissionCanCreateFile = "C"
  222. @objc let permissionCanCreateFolder = "K"
  223. @objc let permissionCanDelete = "D"
  224. @objc let permissionCanRename = "N"
  225. @objc let permissionCanMove = "V"
  226. // Share permission
  227. // permissions - (int) 1 = read; 2 = update; 4 = create; 8 = delete; 16 = share; 31 = all
  228. //
  229. @objc let permissionReadShare: Int = 1
  230. @objc let permissionUpdateShare: Int = 2
  231. @objc let permissionCreateShare: Int = 4
  232. @objc let permissionDeleteShare: Int = 8
  233. @objc let permissionShareShare: Int = 16
  234. @objc let permissionMinFileShare: Int = 1
  235. @objc let permissionMaxFileShare: Int = 19
  236. @objc let permissionMinFolderShare: Int = 1
  237. @objc let permissionMaxFolderShare: Int = 31
  238. @objc let permissionDefaultFileRemoteShareNoSupportShareOption: Int = 3
  239. @objc let permissionDefaultFolderRemoteShareNoSupportShareOption: Int = 15
  240. // ATTRIBUTES
  241. @objc let permissionDownloadShare: Int = 0
  242. // Filename Mask and Type
  243. //
  244. let keyFileNameMask = "fileNameMask"
  245. let keyFileNameType = "fileNameType"
  246. let keyFileNameAutoUploadMask = "fileNameAutoUploadMask"
  247. let keyFileNameAutoUploadType = "fileNameAutoUploadType"
  248. let keyFileNameOriginal = "fileNameOriginal"
  249. let keyFileNameOriginalAutoUpload = "fileNameOriginalAutoUpload"
  250. // Selector
  251. //
  252. let selectorDownloadFile = "downloadFile"
  253. let selectorDownloadAllFile = "downloadAllFile"
  254. let selectorReadFile = "readFile"
  255. let selectorListingFavorite = "listingFavorite"
  256. let selectorLoadFileView = "loadFileView"
  257. let selectorLoadFileQuickLook = "loadFileQuickLook"
  258. let selectorLoadOffline = "loadOffline"
  259. let selectorOpenIn = "openIn"
  260. let selectorPrint = "print"
  261. let selectorUploadAutoUpload = "uploadAutoUpload"
  262. let selectorUploadAutoUploadAll = "uploadAutoUploadAll"
  263. let selectorUploadFile = "uploadFile"
  264. let selectorUploadFileNODelete = "UploadFileNODelete"
  265. let selectorUploadFileShareExtension = "uploadFileShareExtension"
  266. let selectorSaveAlbum = "saveAlbum"
  267. let selectorSaveAlbumLivePhotoIMG = "saveAlbumLivePhotoIMG"
  268. let selectorSaveAlbumLivePhotoMOV = "saveAlbumLivePhotoMOV"
  269. let selectorSaveAsScan = "saveAsScan"
  270. let selectorOpenDetail = "openDetail"
  271. // Metadata : Status
  272. //
  273. // 1) wait download/upload
  274. // 2) in download/upload
  275. // 3) downloading/uploading
  276. // 4) done or error
  277. //
  278. let metadataStatusNormal: Int = 0
  279. let metadataStatusWaitDownload: Int = -1
  280. let metadataStatusInDownload: Int = -2
  281. let metadataStatusDownloading: Int = -3
  282. let metadataStatusDownloadError: Int = -4
  283. let metadataStatusWaitUpload: Int = 1
  284. let metadataStatusInUpload: Int = 2
  285. let metadataStatusUploading: Int = 3
  286. let metadataStatusUploadError: Int = 4
  287. // Hidden files included in the read
  288. //
  289. let includeHiddenFiles: [String] = [".LivePhoto"]
  290. // Auto upload subfolder granularity
  291. //
  292. @objc let subfolderGranularityDaily = 2
  293. @objc let subfolderGranularityMonthly = 1
  294. @objc let subfolderGranularityYearly = 0
  295. // Notification Center
  296. //
  297. @objc let notificationCenterApplicationDidEnterBackground = "applicationDidEnterBackground"
  298. @objc let notificationCenterApplicationDidBecomeActive = "applicationDidBecomeActive"
  299. @objc let notificationCenterApplicationWillResignActive = "applicationWillResignActive"
  300. @objc let notificationCenterChangeUser = "changeUser"
  301. @objc let notificationCenterChangeTheming = "changeTheming"
  302. let notificationCenterRichdocumentGrabFocus = "richdocumentGrabFocus"
  303. let notificationCenterReloadDataNCShare = "reloadDataNCShare"
  304. let notificationCenterCloseRichWorkspaceWebView = "closeRichWorkspaceWebView"
  305. let notificationCenterUpdateBadgeNumber = "updateBadgeNumber" // userInfo: counter
  306. let notificationCenterReloadAvatar = "reloadAvatar"
  307. @objc let notificationCenterReloadDataSource = "reloadDataSource"
  308. let notificationCenterReloadDataSourceNetwork = "reloadDataSourceNetwork"
  309. let notificationCenterReloadDataSourceNetworkForced = "reloadDataSourceNetworkForced"
  310. let notificationCenterChangeStatusFolderE2EE = "changeStatusFolderE2EE" // userInfo: serverUrl
  311. let notificationCenterDownloadStartFile = "downloadStartFile" // userInfo: ocId, serverUrl, account
  312. let notificationCenterDownloadedFile = "downloadedFile" // userInfo: ocId, serverUrl, account, selector, error
  313. let notificationCenterDownloadCancelFile = "downloadCancelFile" // userInfo: ocId, serverUrl, account
  314. let notificationCenterUploadStartFile = "uploadStartFile" // userInfo: ocId, serverUrl, account, fileName, sessionSelector
  315. @objc let notificationCenterUploadedFile = "uploadedFile" // userInfo: ocId, serverUrl, account, fileName, ocIdTemp, error
  316. let notificationCenterUploadCancelFile = "uploadCancelFile" // userInfo: ocId, serverUrl, account
  317. let notificationCenterProgressTask = "progressTask" // userInfo: account, ocId, serverUrl, status, chunk, e2eEncrypted, progress, totalBytes, totalBytesExpected
  318. let notificationCenterCreateFolder = "createFolder" // userInfo: ocId, serverUrl, account, withPush
  319. let notificationCenterDeleteFile = "deleteFile" // userInfo: [ocId], [indexPath], onlyLocalCache, error, hud?
  320. let notificationCenterMoveFile = "moveFile" // userInfo: [ocId], [indexPath], error, hud?
  321. let notificationCenterCopyFile = "copyFile" // userInfo: [ocId], [indexPath], error, hud?
  322. let notificationCenterRenameFile = "renameFile" // userInfo: ocId, account, indexPath
  323. let notificationCenterFavoriteFile = "favoriteFile" // userInfo: ocId, serverUrl
  324. let notificationCenterOperationReadFile = "operationReadFile" // userInfo: ocId
  325. let notificationCenterMenuSearchTextPDF = "menuSearchTextPDF"
  326. let notificationCenterMenuGotToPageInPDF = "menuGotToPageInPDF"
  327. let notificationCenterDownloadedThumbnail = "DownloadedThumbnail" // userInfo: ocId
  328. let notificationCenterOpenMediaDetail = "openMediaDetail" // userInfo: ocId
  329. let notificationCenterDismissScanDocument = "dismissScanDocument"
  330. let notificationCenterDismissUploadAssets = "dismissUploadAssets"
  331. let notificationCenterEnableSwipeGesture = "enableSwipeGesture"
  332. let notificationCenterDisableSwipeGesture = "disableSwipeGesture"
  333. // TIP
  334. //
  335. let tipNCViewerPDFThumbnail = "tipncviewerpdfthumbnail"
  336. let tipNCCollectionViewCommonAccountRequest = "tipnccollectionviewcommonaccountrequest"
  337. let tipNCScanAddImage = "tipncscanaddimage"
  338. let tipNCViewerMediaDetailView = "tipncviewermediadetailview"
  339. // ACTION
  340. //
  341. let actionNoAction = "no-action"
  342. let actionUploadAsset = "upload-asset"
  343. let actionScanDocument = "add-scan-document"
  344. let actionTextDocument = "create-text-document"
  345. let actionVoiceMemo = "create-voice-memo"
  346. // WIDGET ACTION
  347. //
  348. let widgetActionNoAction = "nextcloud://open-action?action=no-action"
  349. let widgetActionUploadAsset = "nextcloud://open-action?action=upload-asset"
  350. let widgetActionScanDocument = "nextcloud://open-action?action=add-scan-document"
  351. let widgetActionTextDocument = "nextcloud://open-action?action=create-text-document"
  352. let widgetActionVoiceMemo = "nextcloud://open-action?action=create-voice-memo"
  353. // APPCONFIG
  354. //
  355. let configuration_brand = "brand"
  356. let configuration_serverUrl = "serverUrl"
  357. let configuration_username = "username"
  358. let configuration_password = "password"
  359. let configuration_apppassword = "apppassword"
  360. let configuration_disable_intro = "disable_intro"
  361. let configuration_disable_multiaccount = "disable_multiaccount"
  362. let configuration_disable_crash_service = "disable_crash_service"
  363. let configuration_disable_log = "disable_log"
  364. let configuration_disable_manage_account = "disable_manage_account"
  365. let configuration_disable_more_external_site = "disable_more_external_site"
  366. let configuration_disable_openin_file = "disable_openin_file"
  367. // CAPABILITIES
  368. //
  369. var capabilityServerVersionMajor: Int = 0
  370. @objc var capabilityServerVersion: String = ""
  371. var capabilityFileSharingApiEnabled: Bool = false
  372. var capabilityFileSharingPubPasswdEnforced: Bool = false
  373. var capabilityFileSharingPubExpireDateEnforced: Bool = false
  374. var capabilityFileSharingPubExpireDateDays: Int = 0
  375. var capabilityFileSharingInternalExpireDateEnforced: Bool = false
  376. var capabilityFileSharingInternalExpireDateDays: Int = 0
  377. var capabilityFileSharingRemoteExpireDateEnforced: Bool = false
  378. var capabilityFileSharingRemoteExpireDateDays: Int = 0
  379. var capabilityFileSharingDefaultPermission: Int = 0
  380. var capabilityThemingColor: String = ""
  381. var capabilityThemingColorElement: String = ""
  382. var capabilityThemingColorText: String = ""
  383. @objc var capabilityThemingName: String = ""
  384. @objc var capabilityThemingSlogan: String = ""
  385. @objc var capabilityE2EEEnabled: Bool = false
  386. @objc var capabilityE2EEApiVersion: String = ""
  387. var capabilityRichdocumentsMimetypes: [String] = []
  388. var capabilityActivity: [String] = []
  389. var capabilityNotification: [String] = []
  390. var capabilityFilesUndelete: Bool = false
  391. var capabilityFilesLockVersion: String = "" // NC 24
  392. var capabilityFilesComments: Bool = false // NC 20
  393. @objc var capabilityUserStatusEnabled: Bool = false
  394. var capabilityExternalSites: Bool = false
  395. var capabilityGroupfoldersEnabled: Bool = false // NC27
  396. // MORE NEXTCLOUD APPS
  397. let talkSchemeUrl = "nextcloudtalk://"
  398. let notesSchemeUrl = "nextcloudnotes://"
  399. let talkAppStoreUrl = "https://apps.apple.com/de/app/nextcloud-talk/id1296825574"
  400. let notesAppStoreUrl = "https://apps.apple.com/de/app/nextcloud-notes/id813973264"
  401. let moreAppsUrl = "https://www.apple.com/us/search/nextcloud?src=globalnav"
  402. // SNAPSHOT PREVIEW
  403. let defaultSnapshotConfiguration = "DefaultPreviewConfiguration"
  404. }