0

如果我的客户将 SQLite 数据库放在托管文件夹中,我经常会遇到麻烦。对于托管文件夹,我的意思是:

  • 挂载的卷
  • Dropbox 文件夹
  • iCloud 云盘文件夹
  • 保险丝等

是否有一种安全的方法来识别此类位置以警告用户?

4

2 回答 2

1

Dropbox 确实提供了一种以编程方式获取本地 Dropbox 文件夹(如果有)的路径的方法:

https://help.dropbox.com/installs-integrations/desktop/locate-dropbox-folder#programmatically

于 2020-07-21T15:44:08.533 回答
0

根据@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;
}
于 2020-07-21T19:12:39.590 回答