CCUtility.m 40 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049
  1. //
  2. // CCUtility.m
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 02/02/16.
  6. // Copyright (c) 2016 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 "CCUtility.h"
  24. #import "NCBridgeSwift.h"
  25. #import "NSNotificationCenter+MainThread.h"
  26. #import <OpenSSL/OpenSSL.h>
  27. #import <CoreLocation/CoreLocation.h>
  28. #include <sys/stat.h>
  29. #define INTRO_MessageType @"MessageType_"
  30. #define E2E_certificate @"EndToEndCertificate_"
  31. #define E2E_PrivateKey @"EndToEndPrivateKey_"
  32. #define E2E_Passphrase @"EndToEndPassphrase_"
  33. #define E2E_PublicKey @"EndToEndPublicKeyServer_"
  34. @implementation CCUtility
  35. #pragma --------------------------------------------------------------------------------------------
  36. #pragma mark ======================= KeyChainStore ==================================
  37. #pragma --------------------------------------------------------------------------------------------
  38. + (void)deleteAllChainStore
  39. {
  40. [UICKeyChainStore removeAllItems];
  41. [UICKeyChainStore removeAllItemsForService:NCGlobal.shared.serviceShareKeyChain];
  42. }
  43. #pragma ------------------------------ GET/SET
  44. + (BOOL)getDisableFilesApp
  45. {
  46. return [[UICKeyChainStore stringForKey:@"disablefilesapp" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  47. }
  48. + (void)setDisableFilesApp:(BOOL)disable
  49. {
  50. NSString *sDisable = (disable) ? @"true" : @"false";
  51. [UICKeyChainStore setString:sDisable forKey:@"disablefilesapp" service:NCGlobal.shared.serviceShareKeyChain];
  52. }
  53. + (void)setPushNotificationPublicKey:(NSString *)account data:(NSData *)data
  54. {
  55. NSString *key = [@"PNPublicKey" stringByAppendingString:account];
  56. [UICKeyChainStore setData:data forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  57. }
  58. + (NSData *)getPushNotificationPublicKey:(NSString *)account
  59. {
  60. NSString *key = [@"PNPublicKey" stringByAppendingString:account];
  61. return [UICKeyChainStore dataForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  62. }
  63. + (void)setPushNotificationSubscribingPublicKey:(NSString *)account publicKey:(NSString *)publicKey
  64. {
  65. NSString *key = [@"PNSubscribingPublicKey" stringByAppendingString:account];
  66. [UICKeyChainStore setString:publicKey forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  67. }
  68. + (NSString *)getPushNotificationSubscribingPublicKey:(NSString *)account
  69. {
  70. NSString *key = [@"PNSubscribingPublicKey" stringByAppendingString:account];
  71. return [UICKeyChainStore stringForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  72. }
  73. + (void)setPushNotificationPrivateKey:(NSString *)account data:(NSData *)data
  74. {
  75. NSString *key = [@"PNPrivateKey" stringByAppendingString:account];
  76. [UICKeyChainStore setData:data forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  77. }
  78. + (NSData *)getPushNotificationPrivateKey:(NSString *)account
  79. {
  80. NSString *key = [@"PNPrivateKey" stringByAppendingString:account];
  81. return [UICKeyChainStore dataForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  82. }
  83. + (void)setPushNotificationToken:(NSString *)account token:(NSString *)token
  84. {
  85. NSString *key = [@"PNToken" stringByAppendingString:account];
  86. [UICKeyChainStore setString:token forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  87. }
  88. + (NSString *)getPushNotificationToken:(NSString *)account
  89. {
  90. NSString *key = [@"PNToken" stringByAppendingString:account];
  91. return [UICKeyChainStore stringForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  92. }
  93. + (void)setPushNotificationDeviceIdentifier:(NSString *)account deviceIdentifier:(NSString *)deviceIdentifier
  94. {
  95. NSString *key = [@"PNDeviceIdentifier" stringByAppendingString:account];
  96. [UICKeyChainStore setString:deviceIdentifier forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  97. }
  98. + (NSString *)getPushNotificationDeviceIdentifier:(NSString *)account
  99. {
  100. NSString *key = [@"PNDeviceIdentifier" stringByAppendingString:account];
  101. return [UICKeyChainStore stringForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  102. }
  103. + (void)setPushNotificationDeviceIdentifierSignature:(NSString *)account deviceIdentifierSignature:(NSString *)deviceIdentifierSignature
  104. {
  105. NSString *key = [@"PNDeviceIdentifierSignature" stringByAppendingString:account];
  106. [UICKeyChainStore setString:deviceIdentifierSignature forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  107. }
  108. + (NSString *)getPushNotificationDeviceIdentifierSignature:(NSString *)account
  109. {
  110. NSString *key = [@"PNDeviceIdentifierSignature" stringByAppendingString:account];
  111. return [UICKeyChainStore stringForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  112. }
  113. + (void)clearAllKeysPushNotification:(NSString *)account
  114. {
  115. [self setPushNotificationPublicKey:account data:nil];
  116. [self setPushNotificationSubscribingPublicKey:account publicKey:nil];
  117. [self setPushNotificationPrivateKey:account data:nil];
  118. [self setPushNotificationToken:account token:nil];
  119. [self setPushNotificationDeviceIdentifier:account deviceIdentifier:nil];
  120. [self setPushNotificationDeviceIdentifierSignature:account deviceIdentifierSignature:nil];
  121. }
  122. + (NSInteger)getMediaWidthImage
  123. {
  124. NSString *width = [UICKeyChainStore stringForKey:@"mediaWidthImage" service:NCGlobal.shared.serviceShareKeyChain];
  125. if (width == nil) {
  126. return 80;
  127. } else {
  128. return [width integerValue];
  129. }
  130. }
  131. + (void)setMediaWidthImage:(NSInteger)width
  132. {
  133. NSString *widthString = [@(width) stringValue];
  134. [UICKeyChainStore setString:widthString forKey:@"mediaWidthImage" service:NCGlobal.shared.serviceShareKeyChain];
  135. }
  136. + (BOOL)getDisableCrashservice
  137. {
  138. return [[UICKeyChainStore stringForKey:@"crashservice" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  139. }
  140. + (void)setDisableCrashservice:(BOOL)disable
  141. {
  142. NSString *sDisable = (disable) ? @"true" : @"false";
  143. [UICKeyChainStore setString:sDisable forKey:@"crashservice" service:NCGlobal.shared.serviceShareKeyChain];
  144. }
  145. + (void)setPassword:(NSString *)account password:(NSString *)password
  146. {
  147. NSString *key = [@"password" stringByAppendingString:account];
  148. [UICKeyChainStore setString:password forKey:key service:NCGlobal.shared.serviceShareKeyChain];
  149. }
  150. + (NSString *)getPassword:(NSString *)account
  151. {
  152. NSString *key = [@"password" stringByAppendingString:account];
  153. NSString *result = [UICKeyChainStore stringForKey:key service:NCGlobal.shared.serviceShareKeyChain];
  154. if (result == nil) { result = @""; }
  155. return result;
  156. }
  157. + (void)setHCBusinessType:(NSString *)professions
  158. {
  159. [UICKeyChainStore setString:professions forKey:@"businessType" service:NCGlobal.shared.serviceShareKeyChain];
  160. }
  161. + (NSString *)getHCBusinessType
  162. {
  163. return [UICKeyChainStore stringForKey:@"businessType" service:NCGlobal.shared.serviceShareKeyChain];
  164. }
  165. + (NSData *)getDatabaseEncryptionKey
  166. {
  167. NSData *key = [UICKeyChainStore dataForKey:@"databaseEncryptionKey" service:NCGlobal.shared.serviceShareKeyChain];
  168. if (key == nil) {
  169. NSMutableData *key = [NSMutableData dataWithLength:64];
  170. (void)SecRandomCopyBytes(kSecRandomDefault, key.length, (uint8_t *)key.mutableBytes);
  171. [UICKeyChainStore setData:key forKey:@"databaseEncryptionKey" service:NCGlobal.shared.serviceShareKeyChain];
  172. return key;
  173. } else {
  174. return key;
  175. }
  176. }
  177. + (void)setDatabaseEncryptionKey:(NSData *)data
  178. {
  179. [UICKeyChainStore setData:data forKey:@"databaseEncryptionKey" service:NCGlobal.shared.serviceShareKeyChain];
  180. }
  181. + (BOOL)getLivePhoto
  182. {
  183. NSString *valueString = [UICKeyChainStore stringForKey:@"livePhoto" service:NCGlobal.shared.serviceShareKeyChain];
  184. // Default TRUE
  185. if (valueString == nil) {
  186. [self setLivePhoto:YES];
  187. return true;
  188. }
  189. return [valueString boolValue];
  190. }
  191. + (void)setLivePhoto:(BOOL)set
  192. {
  193. NSString *sSet = (set) ? @"true" : @"false";
  194. [UICKeyChainStore setString:sSet forKey:@"livePhoto" service:NCGlobal.shared.serviceShareKeyChain];
  195. }
  196. + (NSString *)getMediaSortDate
  197. {
  198. NSString *valueString = [UICKeyChainStore stringForKey:@"mediaSortDate" service:NCGlobal.shared.serviceShareKeyChain];
  199. // Default TRUE
  200. if (valueString == nil) {
  201. [self setMediaSortDate:@"date"];
  202. return @"date";
  203. }
  204. return valueString;
  205. }
  206. + (void)setMediaSortDate:(NSString *)value
  207. {
  208. [UICKeyChainStore setString:value forKey:@"mediaSortDate" service:NCGlobal.shared.serviceShareKeyChain];
  209. }
  210. + (BOOL)getTextRecognitionStatus
  211. {
  212. return [[UICKeyChainStore stringForKey:@"textRecognitionStatus" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  213. }
  214. + (void)setTextRecognitionStatus:(BOOL)value
  215. {
  216. NSString *valueString = (value) ? @"true" : @"false";
  217. [UICKeyChainStore setString:valueString forKey:@"textRecognitionStatus" service:NCGlobal.shared.serviceShareKeyChain];
  218. }
  219. + (BOOL)getDeleteAllScanImages
  220. {
  221. return [[UICKeyChainStore stringForKey:@"deleteAllScanImages" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  222. }
  223. + (void)setDeleteAllScanImages:(BOOL)value
  224. {
  225. NSString *valueString = (value) ? @"true" : @"false";
  226. [UICKeyChainStore setString:valueString forKey:@"deleteAllScanImages" service:NCGlobal.shared.serviceShareKeyChain];
  227. }
  228. + (NSString *)getDirectoryScanDocument
  229. {
  230. return [UICKeyChainStore stringForKey:@"directoryScanDocuments" service:NCGlobal.shared.serviceShareKeyChain];
  231. }
  232. + (void)setDirectoryScanDocument:(NSString *)value
  233. {
  234. [UICKeyChainStore setString:value forKey:@"directoryScanDocuments" service:NCGlobal.shared.serviceShareKeyChain];
  235. }
  236. + (double)getQualityScanDocument
  237. {
  238. NSString *value = [UICKeyChainStore stringForKey:@"qualityScanDocument" service:NCGlobal.shared.serviceShareKeyChain];
  239. if (value == nil) {
  240. return 2;
  241. } else {
  242. return [value doubleValue];
  243. }
  244. }
  245. + (void)setQualityScanDocument:(double)value
  246. {
  247. NSString *valueString = [@(value) stringValue];
  248. [UICKeyChainStore setString:valueString forKey:@"qualityScanDocument" service:NCGlobal.shared.serviceShareKeyChain];
  249. }
  250. + (NSInteger)getLogLevel
  251. {
  252. NSString *value = [UICKeyChainStore stringForKey:@"logLevel" service:NCGlobal.shared.serviceShareKeyChain];
  253. if (value == nil) {
  254. return 1;
  255. } else {
  256. return [value integerValue];
  257. }
  258. }
  259. + (void)setLogLevel:(NSInteger)value
  260. {
  261. NSString *valueString = [@(value) stringValue];
  262. [UICKeyChainStore setString:valueString forKey:@"logLevel" service:NCGlobal.shared.serviceShareKeyChain];
  263. }
  264. + (BOOL)getAccountRequest
  265. {
  266. return [[UICKeyChainStore stringForKey:@"accountRequest" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  267. }
  268. + (void)setAccountRequest:(BOOL)set
  269. {
  270. NSString *sSet = (set) ? @"true" : @"false";
  271. [UICKeyChainStore setString:sSet forKey:@"accountRequest" service:NCGlobal.shared.serviceShareKeyChain];
  272. }
  273. + (NSInteger)getCleanUpDay
  274. {
  275. NSString *size = [UICKeyChainStore stringForKey:@"cleanUpDay" service:NCGlobal.shared.serviceShareKeyChain];
  276. if (size == nil) {
  277. NSInteger days = [[NCBrandOptions shared] cleanUpDay];
  278. return days;
  279. } else {
  280. return [size integerValue];
  281. }
  282. }
  283. + (void)setCleanUpDay:(NSInteger)days
  284. {
  285. NSString *daysString = [@(days) stringValue];
  286. [UICKeyChainStore setString:daysString forKey:@"cleanUpDay" service:NCGlobal.shared.serviceShareKeyChain];
  287. }
  288. + (BOOL)getPrivacyScreenEnabled
  289. {
  290. return [[UICKeyChainStore stringForKey:@"privacyScreen" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  291. }
  292. + (void)setPrivacyScreenEnabled:(BOOL)set
  293. {
  294. NSString *sSet = (set) ? @"true" : @"false";
  295. [UICKeyChainStore setString:sSet forKey:@"privacyScreen" service:NCGlobal.shared.serviceShareKeyChain];
  296. }
  297. + (BOOL)getRemovePhotoCameraRoll
  298. {
  299. return [[UICKeyChainStore stringForKey:@"removePhotoCameraRoll" service:NCGlobal.shared.serviceShareKeyChain] boolValue];
  300. }
  301. + (void)setRemovePhotoCameraRoll:(BOOL)set
  302. {
  303. NSString *sSet = (set) ? @"true" : @"false";
  304. [UICKeyChainStore setString:sSet forKey:@"removePhotoCameraRoll" service:NCGlobal.shared.serviceShareKeyChain];
  305. }
  306. #pragma --------------------------------------------------------------------------------------------
  307. #pragma mark ===== Various =====
  308. #pragma --------------------------------------------------------------------------------------------
  309. + (BOOL)addSkipBackupAttributeToItemAtURL:(NSURL *)URL
  310. {
  311. NSError *error = nil;
  312. BOOL success = [URL setResourceValue:[NSNumber numberWithBool: YES] forKey: NSURLIsExcludedFromBackupKey error: &error];
  313. if(success) {
  314. NSLog(@"Excluding %@ from backup", [URL lastPathComponent]);
  315. } else {
  316. NSLog(@"Error excluding %@ from backup %@", [URL lastPathComponent], error);
  317. }
  318. return success;
  319. }
  320. + (NSString *)dateDiff:(NSDate *) convertedDate
  321. {
  322. NSDate *todayDate = [NSDate date];
  323. double ti = [convertedDate timeIntervalSinceDate:todayDate];
  324. ti = ti * -1;
  325. if (ti < 60) {
  326. return NSLocalizedString(@"_less_a_minute_", nil);
  327. } else if (ti < 3600) {
  328. int diff = round(ti / 60);
  329. if (diff == 1) {
  330. return NSLocalizedString(@"_a_minute_ago_", nil);
  331. } else {
  332. return [NSString stringWithFormat:NSLocalizedString(@"_minutes_ago_", nil), diff];
  333. }
  334. } else if (ti < 86400) {
  335. int diff = round(ti / 60 / 60);
  336. if (diff == 1) {
  337. return NSLocalizedString(@"_an_hour_ago_", nil);
  338. } else {
  339. return[NSString stringWithFormat:NSLocalizedString(@"_hours_ago_", nil), diff];
  340. }
  341. } else if (ti < 86400 * 30) {
  342. int diff = round(ti / 60 / 60 / 24);
  343. if (diff == 1) {
  344. return NSLocalizedString(@"_a_day_ago_", nil);
  345. } else {
  346. return[NSString stringWithFormat:NSLocalizedString(@"_days_ago_", nil), diff];
  347. }
  348. } else {
  349. // Older than one month
  350. NSDateFormatter *df = [[NSDateFormatter alloc] init];
  351. [df setFormatterBehavior:NSDateFormatterBehavior10_4];
  352. [df setDateStyle:NSDateFormatterMediumStyle];
  353. return [df stringFromDate:convertedDate];
  354. }
  355. }
  356. + (NSString *)transformedSize:(int64_t)value
  357. {
  358. NSString *string = [NSByteCountFormatter stringFromByteCount:value countStyle:NSByteCountFormatterCountStyleBinary];
  359. return string;
  360. }
  361. // Remove do not forbidden characters for Nextcloud Server
  362. + (NSString *)removeForbiddenCharactersServer:(NSString *)fileName
  363. {
  364. NSArray *arrayForbiddenCharacters = [NSArray arrayWithObjects:@"/", nil];
  365. for (NSString *currentCharacter in arrayForbiddenCharacters) {
  366. fileName = [fileName stringByReplacingOccurrencesOfString:currentCharacter withString:@""];
  367. }
  368. return fileName;
  369. }
  370. // Remove do not forbidden characters for File System Server
  371. + (NSString *)removeForbiddenCharactersFileSystem:(NSString *)fileName
  372. {
  373. NSArray *arrayForbiddenCharacters = [NSArray arrayWithObjects:@"\\",@"<",@">",@":",@"\"",@"|",@"?",@"*",@"/", nil];
  374. for (NSString *currentCharacter in arrayForbiddenCharacters) {
  375. fileName = [fileName stringByReplacingOccurrencesOfString:currentCharacter withString:@""];
  376. }
  377. return fileName;
  378. }
  379. + (NSString*)stringAppendServerUrl:(NSString *)serverUrl addFileName:(NSString *)addFileName
  380. {
  381. NSString *result;
  382. if (serverUrl == nil || addFileName == nil) return nil;
  383. if ([addFileName isEqualToString:@""]) return serverUrl;
  384. if ([serverUrl isEqualToString:@"/"]) result = [serverUrl stringByAppendingString:addFileName];
  385. else result = [NSString stringWithFormat:@"%@/%@", serverUrl, addFileName];
  386. return result;
  387. }
  388. + (NSString *)createFileNameDate:(NSString *)fileName extension:(NSString *)extension
  389. {
  390. NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
  391. [formatter setDateFormat:@"yy-MM-dd HH-mm-ss"];
  392. NSString *fileNameDate = [formatter stringFromDate:[NSDate date]];
  393. NSString *returnFileName;
  394. if ([fileName isEqualToString:@""] && ![extension isEqualToString:@""]) {
  395. returnFileName = [NSString stringWithFormat:@"%@.%@", fileNameDate, extension];
  396. }
  397. if (![fileName isEqualToString:@""] && [extension isEqualToString:@""]) {
  398. returnFileName = [NSString stringWithFormat:@"%@ %@", fileName, fileNameDate];
  399. }
  400. if ([fileName isEqualToString:@""] && [extension isEqualToString:@""]) {
  401. returnFileName = fileNameDate;
  402. }
  403. if (![fileName isEqualToString:@""] && ![extension isEqualToString:@""]) {
  404. returnFileName = [NSString stringWithFormat:@"%@ %@.%@", fileName, fileNameDate, extension];
  405. }
  406. return returnFileName;
  407. }
  408. + (NSString *)createFileName:(NSString *)fileName fileDate:(NSDate *)fileDate fileType:(PHAssetMediaType)fileType keyFileName:(NSString *)keyFileName keyFileNameType:(NSString *)keyFileNameType keyFileNameOriginal:(NSString *)keyFileNameOriginal forcedNewFileName:(BOOL)forcedNewFileName
  409. {
  410. BOOL addFileNameType = NO;
  411. // Original FileName ?
  412. if ([[[NCKeychain alloc] init] getOriginalFileNameWithKey:keyFileNameOriginal] && !forcedNewFileName) {
  413. return fileName;
  414. }
  415. NSString *numberFileName;
  416. if ([fileName length] > 8) numberFileName = [fileName substringWithRange:NSMakeRange(04, 04)];
  417. else numberFileName = [NCKeychain alloc].incrementalNumber;
  418. NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
  419. [formatter setLocale:[[NSLocale alloc] initWithLocaleIdentifier:@"en_US_POSIX"]];
  420. [formatter setDateFormat:@"yy-MM-dd HH-mm-ss"];
  421. NSString *fileNameDate = [formatter stringFromDate:fileDate];
  422. NSString *fileNameType = @"";
  423. if (fileType == PHAssetMediaTypeImage)
  424. fileNameType = NSLocalizedString(@"_photo_", nil);
  425. if (fileType == PHAssetMediaTypeVideo)
  426. fileNameType = NSLocalizedString(@"_video_", nil);
  427. if (fileType == PHAssetMediaTypeAudio)
  428. fileNameType = NSLocalizedString(@"_audio_", nil);
  429. if (fileType == PHAssetMediaTypeUnknown)
  430. fileNameType = NSLocalizedString(@"_unknown_", nil);
  431. // Use File Name Type
  432. if (keyFileNameType)
  433. addFileNameType = [[[NCKeychain alloc] init] getFileNameTypeWithKey:keyFileNameType];
  434. NSString *fileNameExt = [[fileName pathExtension] lowercaseString];
  435. if (keyFileName) {
  436. fileName = [[[NCKeychain alloc] init] getFileNameMaskWithKey:keyFileName];
  437. if ([fileName length] > 0) {
  438. [formatter setDateFormat:@"dd"];
  439. NSString *dayNumber = [formatter stringFromDate:fileDate];
  440. [formatter setDateFormat:@"MMM"];
  441. NSString *month = [formatter stringFromDate:fileDate];
  442. [formatter setDateFormat:@"MM"];
  443. NSString *monthNumber = [formatter stringFromDate:fileDate];
  444. [formatter setDateFormat:@"yyyy"];
  445. NSString *year = [formatter stringFromDate:fileDate];
  446. [formatter setDateFormat:@"yy"];
  447. NSString *yearNumber = [formatter stringFromDate:fileDate];
  448. [formatter setDateFormat:@"HH"];
  449. NSString *hour24 = [formatter stringFromDate:fileDate];
  450. [formatter setDateFormat:@"hh"];
  451. NSString *hour12 = [formatter stringFromDate:fileDate];
  452. [formatter setDateFormat:@"mm"];
  453. NSString *minute = [formatter stringFromDate:fileDate];
  454. [formatter setDateFormat:@"ss"];
  455. NSString *second = [formatter stringFromDate:fileDate];
  456. [formatter setDateFormat:@"a"];
  457. NSString *ampm = [formatter stringFromDate:fileDate];
  458. // Replace string with date
  459. fileName = [fileName stringByReplacingOccurrencesOfString:@"DD" withString:dayNumber];
  460. fileName = [fileName stringByReplacingOccurrencesOfString:@"MMM" withString:month];
  461. fileName = [fileName stringByReplacingOccurrencesOfString:@"MM" withString:monthNumber];
  462. fileName = [fileName stringByReplacingOccurrencesOfString:@"YYYY" withString:year];
  463. fileName = [fileName stringByReplacingOccurrencesOfString:@"YY" withString:yearNumber];
  464. fileName = [fileName stringByReplacingOccurrencesOfString:@"HH" withString:hour24];
  465. fileName = [fileName stringByReplacingOccurrencesOfString:@"hh" withString:hour12];
  466. fileName = [fileName stringByReplacingOccurrencesOfString:@"mm" withString:minute];
  467. fileName = [fileName stringByReplacingOccurrencesOfString:@"ss" withString:second];
  468. fileName = [fileName stringByReplacingOccurrencesOfString:@"ampm" withString:ampm];
  469. if (addFileNameType)
  470. fileName = [NSString stringWithFormat:@"%@%@%@.%@", fileNameType, fileName, numberFileName, fileNameExt];
  471. else
  472. fileName = [NSString stringWithFormat:@"%@%@.%@", fileName, numberFileName, fileNameExt];
  473. fileName = [fileName stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];
  474. } else {
  475. if (addFileNameType)
  476. fileName = [NSString stringWithFormat:@"%@ %@ %@.%@", fileNameType, fileNameDate, numberFileName, fileNameExt];
  477. else
  478. fileName = [NSString stringWithFormat:@"%@ %@.%@", fileNameDate, numberFileName, fileNameExt];
  479. }
  480. } else {
  481. if (addFileNameType)
  482. fileName = [NSString stringWithFormat:@"%@ %@ %@.%@", fileNameType, fileNameDate, numberFileName, fileNameExt];
  483. else
  484. fileName = [NSString stringWithFormat:@"%@ %@.%@", fileNameDate, numberFileName, fileNameExt];
  485. }
  486. return fileName;
  487. }
  488. + (void)createDirectoryStandard
  489. {
  490. NSString *path;
  491. NSURL *dirGroup = [CCUtility getDirectoryGroup];
  492. NSLog(@"[LOG] Dir Group");
  493. NSLog(@"%@", [dirGroup path]);
  494. NSLog(@"[LOG] Program application ");
  495. NSLog(@"%@", [[CCUtility getDirectoryDocuments] stringByDeletingLastPathComponent]);
  496. // create Directory Documents
  497. path = [CCUtility getDirectoryDocuments];
  498. if (![[NSFileManager defaultManager] fileExistsAtPath: path])
  499. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  500. // create Directory audio => Library, Application Support, audio
  501. path = [CCUtility getDirectoryAudio];
  502. if (![[NSFileManager defaultManager] fileExistsAtPath: path])
  503. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  504. // create Directory database Nextcloud
  505. path = [[dirGroup URLByAppendingPathComponent:[[NCGlobal shared] appDatabaseNextcloud]] path];
  506. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  507. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  508. // create Directory User Data
  509. path = [[dirGroup URLByAppendingPathComponent:NCGlobal.shared.appUserData] path];
  510. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  511. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  512. // create Directory Provider Storage
  513. path = [CCUtility getDirectoryProviderStorage];
  514. if (![[NSFileManager defaultManager] fileExistsAtPath: path])
  515. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  516. // create Directory Scan
  517. path = [[dirGroup URLByAppendingPathComponent:NCGlobal.shared.appScan] path];
  518. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  519. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  520. // create Directory Temp
  521. path = NSTemporaryDirectory();
  522. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  523. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  524. // Directory Excluded From Backup
  525. [CCUtility addSkipBackupAttributeToItemAtURL:[[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject]];
  526. [CCUtility addSkipBackupAttributeToItemAtURL:[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.directoryProviderStorage]];
  527. [CCUtility addSkipBackupAttributeToItemAtURL:[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appApplicationSupport]];
  528. [CCUtility addSkipBackupAttributeToItemAtURL:[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appCertificates]];
  529. [CCUtility addSkipBackupAttributeToItemAtURL:[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appDatabaseNextcloud]];
  530. [CCUtility addSkipBackupAttributeToItemAtURL:[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appScan]];
  531. [CCUtility addSkipBackupAttributeToItemAtURL:[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appUserData]];
  532. }
  533. + (NSURL *)getDirectoryGroup
  534. {
  535. NSURL *path = [[NSFileManager defaultManager] containerURLForSecurityApplicationGroupIdentifier:[NCBrandOptions shared].capabilitiesGroups];
  536. return path;
  537. }
  538. // Return the path of directory Documents -> NSDocumentDirectory
  539. + (NSString *)getDirectoryDocuments
  540. {
  541. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
  542. return [paths objectAtIndex:0];
  543. }
  544. + (NSString *)getDirectoryReaderMetadata
  545. {
  546. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSApplicationSupportDirectory, NSUserDomainMask, YES);
  547. return [NSString stringWithFormat:@"%@/Reader Metadata", [paths objectAtIndex:0]];
  548. }
  549. // Return the path of directory Audio
  550. + (NSString *)getDirectoryAudio
  551. {
  552. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSApplicationSupportDirectory, NSUserDomainMask, YES);
  553. return [NSString stringWithFormat:@"%@/%@", [paths objectAtIndex:0], @"audio"];
  554. }
  555. // Return the path of directory Cetificates
  556. + (NSString *)getDirectoryCerificates
  557. {
  558. NSString *path = [[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appCertificates] path];
  559. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  560. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  561. return path;
  562. }
  563. + (NSString *)getDirectoryUserData
  564. {
  565. NSString *path = [[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appUserData] path];
  566. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  567. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  568. return path;
  569. }
  570. + (NSString *)getDirectoryProviderStorage
  571. {
  572. NSString *path = [[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.directoryProviderStorage] path];
  573. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  574. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  575. return path;
  576. }
  577. + (NSString *)getDirectoryProviderStorageOcId:(NSString *)ocId
  578. {
  579. NSString *path = [NSString stringWithFormat:@"%@/%@", [self getDirectoryProviderStorage], ocId];
  580. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  581. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  582. return path;
  583. }
  584. + (NSString *)getDirectoryProviderStorageOcId:(NSString *)ocId fileNameView:(NSString *)fileNameView
  585. {
  586. NSString *fileNamePath = [NSString stringWithFormat:@"%@/%@", [self getDirectoryProviderStorageOcId:ocId], fileNameView];
  587. // if do not exists create file 0 length
  588. // causes files with lenth 0 to never be downloaded, because already exist
  589. // also makes it impossible to delete any file with length 0 (from cache)
  590. if ([[NSFileManager defaultManager] fileExistsAtPath:fileNamePath] == NO) {
  591. [[NSFileManager defaultManager] createFileAtPath:fileNamePath contents:nil attributes:nil];
  592. }
  593. return fileNamePath;
  594. }
  595. + (NSString *)getDirectoryProviderStorageIconOcId:(NSString *)ocId etag:(NSString *)etag
  596. {
  597. return [NSString stringWithFormat:@"%@/%@.small.%@", [self getDirectoryProviderStorageOcId:ocId], etag, [NCGlobal shared].extensionPreview];
  598. }
  599. + (NSString *)getDirectoryProviderStoragePreviewOcId:(NSString *)ocId etag:(NSString *)etag
  600. {
  601. return [NSString stringWithFormat:@"%@/%@.preview.%@", [self getDirectoryProviderStorageOcId:ocId], etag, [NCGlobal shared].extensionPreview];
  602. }
  603. + (BOOL)fileProviderStorageExists:(tableMetadata *)metadata
  604. {
  605. NSString *fileNameViewPath = [self getDirectoryProviderStorageOcId:metadata.ocId fileNameView:metadata.fileNameView];
  606. NSString *fileNamePath = [self getDirectoryProviderStorageOcId:metadata.ocId fileNameView:metadata.fileName];
  607. unsigned long long fileNameViewSize = [[[NSFileManager defaultManager] attributesOfItemAtPath:fileNameViewPath error:nil] fileSize];
  608. unsigned long long fileNameSize = [[[NSFileManager defaultManager] attributesOfItemAtPath:fileNamePath error:nil] fileSize];
  609. if (metadata.isDirectoryE2EE == true) {
  610. if ((fileNameSize == metadata.size || fileNameViewSize == metadata.size) && fileNameViewSize > 0) {
  611. return true;
  612. } else {
  613. return false;
  614. }
  615. } else {
  616. return fileNameViewSize == metadata.size;
  617. }
  618. }
  619. + (int64_t)fileProviderStorageSize:(NSString *)ocId fileNameView:(NSString *)fileNameView
  620. {
  621. NSString *fileNamePath = [self getDirectoryProviderStorageOcId:ocId fileNameView:fileNameView];
  622. int64_t fileSize = [[[NSFileManager defaultManager] attributesOfItemAtPath:fileNamePath error:nil] fileSize];
  623. return fileSize;
  624. }
  625. + (BOOL)fileProviderStoragePreviewIconExists:(NSString *)ocId etag:(NSString *)etag
  626. {
  627. NSString *fileNamePathPreview = [self getDirectoryProviderStoragePreviewOcId:ocId etag:etag];
  628. NSString *fileNamePathIcon = [self getDirectoryProviderStorageIconOcId:ocId etag:etag];
  629. unsigned long long fileSizePreview = [[[NSFileManager defaultManager] attributesOfItemAtPath:fileNamePathPreview error:nil] fileSize];
  630. unsigned long long fileSizeIcon = [[[NSFileManager defaultManager] attributesOfItemAtPath:fileNamePathIcon error:nil] fileSize];
  631. if (fileSizePreview > 0 && fileSizeIcon > 0) return true;
  632. else return false;
  633. }
  634. + (void)removeGroupApplicationSupport
  635. {
  636. NSURL *dirGroup = [CCUtility getDirectoryGroup];
  637. NSString *path = [[dirGroup URLByAppendingPathComponent:NCGlobal.shared.appApplicationSupport] path];
  638. [[NSFileManager defaultManager] removeItemAtPath:path error:nil];
  639. }
  640. + (void)removeGroupLibraryDirectory
  641. {
  642. [[NSFileManager defaultManager] removeItemAtPath:[CCUtility getDirectoryScan] error:nil];
  643. [[NSFileManager defaultManager] removeItemAtPath:[CCUtility getDirectoryUserData] error:nil];
  644. }
  645. + (void)removeGroupDirectoryProviderStorage
  646. {
  647. [[NSFileManager defaultManager] removeItemAtPath:[CCUtility getDirectoryProviderStorage] error:nil];
  648. }
  649. + (void)removeDocumentsDirectory
  650. {
  651. [[NSFileManager defaultManager] removeItemAtPath:[CCUtility getDirectoryDocuments] error:nil];
  652. }
  653. + (void)removeTemporaryDirectory
  654. {
  655. [[NSFileManager defaultManager] removeItemAtPath:NSTemporaryDirectory() error:nil];
  656. }
  657. + (void)emptyTemporaryDirectory
  658. {
  659. NSArray* tmpDirectory = [[NSFileManager defaultManager] contentsOfDirectoryAtPath:NSTemporaryDirectory() error:NULL];
  660. for (NSString *file in tmpDirectory) {
  661. [[NSFileManager defaultManager] removeItemAtPath:[NSString stringWithFormat:@"%@%@", NSTemporaryDirectory(), file] error:NULL];
  662. }
  663. }
  664. + (NSString *)getTitleSectionDate:(NSDate *)date
  665. {
  666. NSString *title;
  667. NSDate *today = [NSDate date];
  668. NSDate *yesterday = [today dateByAddingTimeInterval: -86400.0];
  669. if ([date isEqualToDate:[CCUtility datetimeWithOutTime:[NSDate distantPast]]]) {
  670. title = NSLocalizedString(@"_no_date_", nil);
  671. } else {
  672. title = [NSDateFormatter localizedStringFromDate:date dateStyle:NSDateFormatterLongStyle timeStyle:0];
  673. if ([date isEqualToDate:[CCUtility datetimeWithOutTime:today]])
  674. title = [NSString stringWithFormat:NSLocalizedString(@"_today_", nil)];
  675. if ([date isEqualToDate:[CCUtility datetimeWithOutTime:yesterday]])
  676. title = [NSString stringWithFormat:NSLocalizedString(@"_yesterday_", nil)];
  677. }
  678. return title;
  679. }
  680. + (void)moveFileAtPath:(NSString *)atPath toPath:(NSString *)toPath
  681. {
  682. [[NSFileManager defaultManager] removeItemAtPath:toPath error:nil];
  683. [[NSFileManager defaultManager] copyItemAtPath:atPath toPath:toPath error:nil];
  684. [[NSFileManager defaultManager] removeItemAtPath:atPath error:nil];
  685. }
  686. + (void)copyFileAtPath:(NSString *)atPath toPath:(NSString *)toPath
  687. {
  688. [[NSFileManager defaultManager] removeItemAtPath:toPath error:nil];
  689. [[NSFileManager defaultManager] copyItemAtPath:atPath toPath:toPath error:nil];
  690. }
  691. + (void)removeFileAtPath:(NSString *)atPath
  692. {
  693. [[NSFileManager defaultManager] removeItemAtPath:atPath error:nil];
  694. }
  695. + (void)createDirectoryAtPath:(NSString *)atPath
  696. {
  697. [[NSFileManager defaultManager] createDirectoryAtPath:atPath withIntermediateDirectories:true attributes:nil error:nil];
  698. }
  699. + (NSString *)returnPathfromServerUrl:(NSString *)serverUrl urlBase:(NSString *)urlBase userId:(NSString *)userId account:(NSString *)account
  700. {
  701. NSString *homeServer = [[NCUtilityFileSystem shared] getHomeServerWithUrlBase:urlBase userId:userId];
  702. NSString *path = [serverUrl stringByReplacingOccurrencesOfString:homeServer withString:@""];
  703. return path;
  704. }
  705. + (NSString *)returnFileNamePathFromFileName:(NSString *)metadataFileName serverUrl:(NSString *)serverUrl urlBase:(NSString *)urlBase userId:(NSString *)userId account:(NSString *)account
  706. {
  707. if (metadataFileName == nil || serverUrl == nil || urlBase == nil) {
  708. return @"";
  709. }
  710. NSString *homeServer = [[NCUtilityFileSystem shared] getHomeServerWithUrlBase:urlBase userId:userId];
  711. NSString *fileName = [NSString stringWithFormat:@"%@/%@", [serverUrl stringByReplacingOccurrencesOfString:homeServer withString:@""], metadataFileName];
  712. if ([fileName hasPrefix:@"/"]) fileName = [fileName substringFromIndex:1];
  713. return fileName;
  714. }
  715. + (NSString *)getMimeType:(NSString *)fileNameView
  716. {
  717. CFStringRef fileUTI = nil;
  718. NSString *returnFileUTI = nil;
  719. if ([fileNameView isEqualToString:@"."]) {
  720. return returnFileUTI;
  721. } else {
  722. CFStringRef fileExtension = (__bridge CFStringRef)[fileNameView pathExtension];
  723. NSString *ext = (__bridge NSString *)fileExtension;
  724. ext = ext.uppercaseString;
  725. fileUTI = UTTypeCreatePreferredIdentifierForTag(kUTTagClassFilenameExtension, fileExtension, NULL);
  726. if (fileUTI != nil) {
  727. returnFileUTI = (__bridge NSString *)fileUTI;
  728. CFRelease(fileUTI);
  729. }
  730. }
  731. return returnFileUTI;
  732. }
  733. + (NSString *)getDirectoryScan
  734. {
  735. NSString *path = [[[CCUtility getDirectoryGroup] URLByAppendingPathComponent:NCGlobal.shared.appScan] path];
  736. if (![[NSFileManager defaultManager] fileExistsAtPath:path])
  737. [[NSFileManager defaultManager] createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];
  738. return path;
  739. }
  740. #pragma --------------------------------------------------------------------------------------------
  741. #pragma mark ===== Share Permissions =====
  742. #pragma --------------------------------------------------------------------------------------------
  743. + (NSInteger) getPermissionsValueByCanEdit:(BOOL)canEdit andCanCreate:(BOOL)canCreate andCanChange:(BOOL)canChange andCanDelete:(BOOL)canDelete andCanShare:(BOOL)canShare andIsFolder:(BOOL) isFolder
  744. {
  745. NSInteger permissionsValue = NCGlobal.shared.permissionReadShare;
  746. if (canEdit && !isFolder) {
  747. permissionsValue = permissionsValue + NCGlobal.shared.permissionUpdateShare;
  748. }
  749. if (canCreate & isFolder) {
  750. permissionsValue = permissionsValue + NCGlobal.shared.permissionCreateShare;
  751. }
  752. if (canChange && isFolder) {
  753. permissionsValue = permissionsValue + NCGlobal.shared.permissionUpdateShare;
  754. }
  755. if (canDelete & isFolder) {
  756. permissionsValue = permissionsValue + NCGlobal.shared.permissionDeleteShare;
  757. }
  758. if (canShare) {
  759. permissionsValue = permissionsValue + NCGlobal.shared.permissionShareShare;
  760. }
  761. return permissionsValue;
  762. }
  763. + (BOOL) isPermissionToCanCreate:(NSInteger) permissionValue {
  764. BOOL canCreate = ((permissionValue & NCGlobal.shared.permissionCreateShare) > 0);
  765. return canCreate;
  766. }
  767. + (BOOL) isPermissionToCanChange:(NSInteger) permissionValue {
  768. BOOL canChange = ((permissionValue & NCGlobal.shared.permissionUpdateShare) > 0);
  769. return canChange;
  770. }
  771. + (BOOL) isPermissionToCanDelete:(NSInteger) permissionValue {
  772. BOOL canDelete = ((permissionValue & NCGlobal.shared.permissionDeleteShare) > 0);
  773. return canDelete;
  774. }
  775. + (BOOL) isPermissionToCanShare:(NSInteger) permissionValue {
  776. BOOL canShare = ((permissionValue & NCGlobal.shared.permissionShareShare) > 0);
  777. return canShare;
  778. }
  779. + (BOOL) isAnyPermissionToEdit:(NSInteger) permissionValue {
  780. BOOL canCreate = [self isPermissionToCanCreate:permissionValue];
  781. BOOL canChange = [self isPermissionToCanChange:permissionValue];
  782. BOOL canDelete = [self isPermissionToCanDelete:permissionValue];
  783. BOOL canEdit = (canCreate || canChange || canDelete);
  784. return canEdit;
  785. }
  786. + (BOOL) isPermissionToRead:(NSInteger) permissionValue {
  787. BOOL canRead = ((permissionValue & NCGlobal.shared.permissionReadShare) > 0);
  788. return canRead;
  789. }
  790. + (BOOL) isPermissionToReadCreateUpdate:(NSInteger) permissionValue {
  791. BOOL canRead = [self isPermissionToRead:permissionValue];
  792. BOOL canCreate = [self isPermissionToCanCreate:permissionValue];
  793. BOOL canChange = [self isPermissionToCanChange:permissionValue];
  794. BOOL canEdit = (canCreate && canChange && canRead);
  795. return canEdit;
  796. }
  797. #pragma --------------------------------------------------------------------------------------------
  798. #pragma mark ===== Third parts =====
  799. #pragma --------------------------------------------------------------------------------------------
  800. + (NSString *)getExtension:(NSString*)fileName
  801. {
  802. NSMutableArray *fileNameArray =[[NSMutableArray alloc] initWithArray: [fileName componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@"."]]];
  803. NSString *extension = [NSString stringWithFormat:@"%@",[fileNameArray lastObject]];
  804. extension = [extension uppercaseString];
  805. //If the file has a ZIP extension obtain the previous one for check if it is a .pages.zip / .numbers.zip / .key.zip extension
  806. if ([extension isEqualToString:@"ZIP"]) {
  807. [fileNameArray removeLastObject];
  808. NSString *secondExtension = [NSString stringWithFormat:@"%@",[fileNameArray lastObject]];
  809. secondExtension = [secondExtension uppercaseString];
  810. if ([secondExtension isEqualToString:@"PAGES"] || [secondExtension isEqualToString:@"NUMBERS"] || [secondExtension isEqualToString:@"KEY"]) {
  811. extension = [NSString stringWithFormat:@"%@.%@",secondExtension,extension];
  812. return extension;
  813. }
  814. }
  815. return extension;
  816. }
  817. + (NSDate *)datetimeWithOutTime:(NSDate *)datDate
  818. {
  819. if (datDate == nil) return nil;
  820. NSDateComponents* comps = [[NSCalendar currentCalendar] components:NSCalendarUnitYear|NSCalendarUnitMonth|NSCalendarUnitDay fromDate:datDate];
  821. datDate = [[NSCalendar currentCalendar] dateFromComponents:comps];
  822. return datDate;
  823. }
  824. + (NSString *)valueForKey:(NSString *)key fromQueryItems:(NSArray *)queryItems
  825. {
  826. NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name=%@", key];
  827. NSURLQueryItem *queryItem = [[queryItems filteredArrayUsingPredicate:predicate] firstObject];
  828. return queryItem.value;
  829. }
  830. + (NSDate *)getATime:(const char *)path
  831. {
  832. struct stat st;
  833. stat(path, &st);
  834. time_t accessed = st.st_atime;
  835. NSDate *date = [NSDate dateWithTimeIntervalSince1970:accessed];
  836. return date;
  837. }
  838. @end