如果我的客户将 SQLite 数据库放在托管文件夹中,我经常会遇到麻烦。对于托管文件夹,我的意思是:
- 挂载的卷
- Dropbox 文件夹
- iCloud 云盘文件夹
- 保险丝等
是否有一种安全的方法来识别此类位置以警告用户?
如果我的客户将 SQLite 数据库放在托管文件夹中,我经常会遇到麻烦。对于托管文件夹,我的意思是:
是否有一种安全的方法来识别此类位置以警告用户?
Dropbox 确实提供了一种以编程方式获取本地 Dropbox 文件夹(如果有)的路径的方法:
https://help.dropbox.com/installs-integrations/desktop/locate-dropbox-folder#programmatically
根据@Greg 的提示,我使用一些私人助手在 ObjC 中提出了一个解决方案,但我想这个想法应该变得清晰:
- (BOOL)isDropbox:(NSURL *)url {
// https://help.dropbox.com/de-de/installs-integrations/desktop/locate-dropbox-folder#programmatically
id json = [[NSData dataWithContentsOfURL:hxFileURL(@"~/.dropbox/info.json".stringByExpandingTildeInPath)] fromJSON];
NSString *ppath = json[@"personal"][@"path"];
NSString *bpath = json[@"business"][@"path"];
NSString *path = hxFilePath(url);
return (ppath && [path hasPrefix:ppath]) || (bpath && [path hasPrefix:bpath]);
}
- (BOOL)hoIsLocal:(NSURL *)url {
@try {
if (![FS hoIsDir:url]) {
url = [url URLByDeletingLastPathComponent];
}
// Is it local in general?
ERROR_DEF;
NSNumber *state;
[url getResourceValue:&state forKey:NSURLVolumeIsLocalKey error:&error];
XLogInfo(@"state=%@ url=%@", state, url);
// If so it could be stored in iCloud Drive
if (state.boolValue) {
BOOL ubiq = [FS isUbiquitousItemAtURL:url];
XLogInfo(@"ubiq=%@ url=%@", @(ubiq), url);
// Or on Dropbox
if (!ubiq) {
BOOL dbx = [FS isDropbox:url];
XLogInfo(@"dbx=%@ url=%@", @(dbx), url);
return !dbx;
}
}
}
@catch (id ex) {
XLogException(ex);
}
return NO;
}