mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-26 15:06:08 +03:00
ada4b98a93
Signed-off-by: Claudio Cambra <claudio.cambra@nextcloud.com>
86 lines
4.7 KiB
Swift
86 lines
4.7 KiB
Swift
/*
|
|
* Copyright (C) 2022 by Claudio Cambra <claudio.cambra@nextcloud.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*/
|
|
|
|
import FileProvider
|
|
import OSLog
|
|
import NCDesktopClientSocketKit
|
|
|
|
class FileProviderExtension: NSObject, NSFileProviderReplicatedExtension {
|
|
let domain: NSFileProviderDomain
|
|
let socketClient: LocalSocketClient
|
|
|
|
required init(domain: NSFileProviderDomain) {
|
|
self.domain = domain
|
|
// The containing application must create a domain using `NSFileProviderManager.add(_:, completionHandler:)`. The system will then launch the application extension process, call `FileProviderExtension.init(domain:)` to instantiate the extension for that domain, and call methods on the instance.
|
|
|
|
let bundle = Bundle(for: type(of: self))
|
|
guard let fileProviderSocketApiPrefix = bundle.object(forInfoDictionaryKey: "SocketApiPrefix") as? String else {
|
|
NSLog("Could not start file provider socket client properly as SocketApiPrefix is missing")
|
|
self.socketClient = LocalSocketClient()
|
|
super.init()
|
|
return;
|
|
}
|
|
|
|
let containerUrl = FileManager.default.containerURL(forSecurityApplicationGroupIdentifier: fileProviderSocketApiPrefix)
|
|
let socketPath = containerUrl?.appendingPathComponent(".fileprovidersocket", conformingTo: .archive)
|
|
self.socketClient = LocalSocketClient(socketPath: socketPath?.path, lineProcessor: nil)
|
|
self.socketClient.start();
|
|
super.init()
|
|
}
|
|
|
|
func invalidate() {
|
|
// TODO: cleanup any resources
|
|
}
|
|
|
|
func item(for identifier: NSFileProviderItemIdentifier, request: NSFileProviderRequest, completionHandler: @escaping (NSFileProviderItem?, Error?) -> Void) -> Progress {
|
|
// resolve the given identifier to a record in the model
|
|
|
|
// TODO: implement the actual lookup
|
|
|
|
completionHandler(FileProviderItem(identifier: identifier), nil)
|
|
return Progress()
|
|
}
|
|
|
|
func fetchContents(for itemIdentifier: NSFileProviderItemIdentifier, version requestedVersion: NSFileProviderItemVersion?, request: NSFileProviderRequest, completionHandler: @escaping (URL?, NSFileProviderItem?, Error?) -> Void) -> Progress {
|
|
// TODO: implement fetching of the contents for the itemIdentifier at the specified version
|
|
|
|
completionHandler(nil, nil, NSError(domain: NSCocoaErrorDomain, code: NSFeatureUnsupportedError, userInfo:[:]))
|
|
return Progress()
|
|
}
|
|
|
|
func createItem(basedOn itemTemplate: NSFileProviderItem, fields: NSFileProviderItemFields, contents url: URL?, options: NSFileProviderCreateItemOptions = [], request: NSFileProviderRequest, completionHandler: @escaping (NSFileProviderItem?, NSFileProviderItemFields, Bool, Error?) -> Void) -> Progress {
|
|
// TODO: a new item was created on disk, process the item's creation
|
|
|
|
completionHandler(itemTemplate, [], false, nil)
|
|
return Progress()
|
|
}
|
|
|
|
func modifyItem(_ item: NSFileProviderItem, baseVersion version: NSFileProviderItemVersion, changedFields: NSFileProviderItemFields, contents newContents: URL?, options: NSFileProviderModifyItemOptions = [], request: NSFileProviderRequest, completionHandler: @escaping (NSFileProviderItem?, NSFileProviderItemFields, Bool, Error?) -> Void) -> Progress {
|
|
// TODO: an item was modified on disk, process the item's modification
|
|
|
|
completionHandler(nil, [], false, NSError(domain: NSCocoaErrorDomain, code: NSFeatureUnsupportedError, userInfo:[:]))
|
|
return Progress()
|
|
}
|
|
|
|
func deleteItem(identifier: NSFileProviderItemIdentifier, baseVersion version: NSFileProviderItemVersion, options: NSFileProviderDeleteItemOptions = [], request: NSFileProviderRequest, completionHandler: @escaping (Error?) -> Void) -> Progress {
|
|
// TODO: an item was deleted on disk, process the item's deletion
|
|
|
|
completionHandler(NSError(domain: NSCocoaErrorDomain, code: NSFeatureUnsupportedError, userInfo:[:]))
|
|
return Progress()
|
|
}
|
|
|
|
func enumerator(for containerItemIdentifier: NSFileProviderItemIdentifier, request: NSFileProviderRequest) throws -> NSFileProviderEnumerator {
|
|
return FileProviderEnumerator(enumeratedItemIdentifier: containerItemIdentifier)
|
|
}
|
|
}
|