mirror of
https://github.com/immich-app/immich.git
synced 2025-05-24 01:12:58 -04:00
447 lines
15 KiB
Swift
447 lines
15 KiB
Swift
// Autogenerated from Pigeon (v25.3.2), do not edit directly.
|
|
// See also: https://pub.dev/packages/pigeon
|
|
|
|
import Foundation
|
|
|
|
#if os(iOS)
|
|
import Flutter
|
|
#elseif os(macOS)
|
|
import FlutterMacOS
|
|
#else
|
|
#error("Unsupported platform.")
|
|
#endif
|
|
|
|
/// Error class for passing custom error details to Dart side.
|
|
final class PigeonError: Error {
|
|
let code: String
|
|
let message: String?
|
|
let details: Sendable?
|
|
|
|
init(code: String, message: String?, details: Sendable?) {
|
|
self.code = code
|
|
self.message = message
|
|
self.details = details
|
|
}
|
|
|
|
var localizedDescription: String {
|
|
return
|
|
"PigeonError(code: \(code), message: \(message ?? "<nil>"), details: \(details ?? "<nil>")"
|
|
}
|
|
}
|
|
|
|
private func wrapResult(_ result: Any?) -> [Any?] {
|
|
return [result]
|
|
}
|
|
|
|
private func wrapError(_ error: Any) -> [Any?] {
|
|
if let pigeonError = error as? PigeonError {
|
|
return [
|
|
pigeonError.code,
|
|
pigeonError.message,
|
|
pigeonError.details,
|
|
]
|
|
}
|
|
if let flutterError = error as? FlutterError {
|
|
return [
|
|
flutterError.code,
|
|
flutterError.message,
|
|
flutterError.details,
|
|
]
|
|
}
|
|
return [
|
|
"\(error)",
|
|
"\(type(of: error))",
|
|
"Stacktrace: \(Thread.callStackSymbols)",
|
|
]
|
|
}
|
|
|
|
private func isNullish(_ value: Any?) -> Bool {
|
|
return value is NSNull || value == nil
|
|
}
|
|
|
|
private func nilOrValue<T>(_ value: Any?) -> T? {
|
|
if value is NSNull { return nil }
|
|
return value as! T?
|
|
}
|
|
|
|
func deepEqualsMessages(_ lhs: Any?, _ rhs: Any?) -> Bool {
|
|
let cleanLhs = nilOrValue(lhs) as Any?
|
|
let cleanRhs = nilOrValue(rhs) as Any?
|
|
switch (cleanLhs, cleanRhs) {
|
|
case (nil, nil):
|
|
return true
|
|
|
|
case (nil, _), (_, nil):
|
|
return false
|
|
|
|
case is (Void, Void):
|
|
return true
|
|
|
|
case let (cleanLhsHashable, cleanRhsHashable) as (AnyHashable, AnyHashable):
|
|
return cleanLhsHashable == cleanRhsHashable
|
|
|
|
case let (cleanLhsArray, cleanRhsArray) as ([Any?], [Any?]):
|
|
guard cleanLhsArray.count == cleanRhsArray.count else { return false }
|
|
for (index, element) in cleanLhsArray.enumerated() {
|
|
if !deepEqualsMessages(element, cleanRhsArray[index]) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
|
|
case let (cleanLhsDictionary, cleanRhsDictionary) as ([AnyHashable: Any?], [AnyHashable: Any?]):
|
|
guard cleanLhsDictionary.count == cleanRhsDictionary.count else { return false }
|
|
for (key, cleanLhsValue) in cleanLhsDictionary {
|
|
guard cleanRhsDictionary.index(forKey: key) != nil else { return false }
|
|
if !deepEqualsMessages(cleanLhsValue, cleanRhsDictionary[key]!) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
|
|
default:
|
|
// Any other type shouldn't be able to be used with pigeon. File an issue if you find this to be untrue.
|
|
return false
|
|
}
|
|
}
|
|
|
|
func deepHashMessages(value: Any?, hasher: inout Hasher) {
|
|
if let valueList = value as? [AnyHashable] {
|
|
for item in valueList { deepHashMessages(value: item, hasher: &hasher) }
|
|
return
|
|
}
|
|
|
|
if let valueDict = value as? [AnyHashable: AnyHashable] {
|
|
for key in valueDict.keys {
|
|
hasher.combine(key)
|
|
deepHashMessages(value: valueDict[key]!, hasher: &hasher)
|
|
}
|
|
return
|
|
}
|
|
|
|
if let hashableValue = value as? AnyHashable {
|
|
hasher.combine(hashableValue.hashValue)
|
|
}
|
|
|
|
return hasher.combine(String(describing: value))
|
|
}
|
|
|
|
|
|
|
|
/// Generated class from Pigeon that represents data sent in messages.
|
|
struct ImAsset: Hashable {
|
|
var id: String
|
|
var name: String
|
|
var type: Int64
|
|
var createdAt: Int64? = nil
|
|
var updatedAt: Int64? = nil
|
|
var durationInSeconds: Int64
|
|
|
|
|
|
// swift-format-ignore: AlwaysUseLowerCamelCase
|
|
static func fromList(_ pigeonVar_list: [Any?]) -> ImAsset? {
|
|
let id = pigeonVar_list[0] as! String
|
|
let name = pigeonVar_list[1] as! String
|
|
let type = pigeonVar_list[2] as! Int64
|
|
let createdAt: Int64? = nilOrValue(pigeonVar_list[3])
|
|
let updatedAt: Int64? = nilOrValue(pigeonVar_list[4])
|
|
let durationInSeconds = pigeonVar_list[5] as! Int64
|
|
|
|
return ImAsset(
|
|
id: id,
|
|
name: name,
|
|
type: type,
|
|
createdAt: createdAt,
|
|
updatedAt: updatedAt,
|
|
durationInSeconds: durationInSeconds
|
|
)
|
|
}
|
|
func toList() -> [Any?] {
|
|
return [
|
|
id,
|
|
name,
|
|
type,
|
|
createdAt,
|
|
updatedAt,
|
|
durationInSeconds,
|
|
]
|
|
}
|
|
static func == (lhs: ImAsset, rhs: ImAsset) -> Bool {
|
|
return deepEqualsMessages(lhs.toList(), rhs.toList()) }
|
|
func hash(into hasher: inout Hasher) {
|
|
deepHashMessages(value: toList(), hasher: &hasher)
|
|
}
|
|
}
|
|
|
|
/// Generated class from Pigeon that represents data sent in messages.
|
|
struct ImAlbum: Hashable {
|
|
var id: String
|
|
var name: String
|
|
var updatedAt: Int64? = nil
|
|
var isCloud: Bool
|
|
var assetCount: Int64
|
|
|
|
|
|
// swift-format-ignore: AlwaysUseLowerCamelCase
|
|
static func fromList(_ pigeonVar_list: [Any?]) -> ImAlbum? {
|
|
let id = pigeonVar_list[0] as! String
|
|
let name = pigeonVar_list[1] as! String
|
|
let updatedAt: Int64? = nilOrValue(pigeonVar_list[2])
|
|
let isCloud = pigeonVar_list[3] as! Bool
|
|
let assetCount = pigeonVar_list[4] as! Int64
|
|
|
|
return ImAlbum(
|
|
id: id,
|
|
name: name,
|
|
updatedAt: updatedAt,
|
|
isCloud: isCloud,
|
|
assetCount: assetCount
|
|
)
|
|
}
|
|
func toList() -> [Any?] {
|
|
return [
|
|
id,
|
|
name,
|
|
updatedAt,
|
|
isCloud,
|
|
assetCount,
|
|
]
|
|
}
|
|
static func == (lhs: ImAlbum, rhs: ImAlbum) -> Bool {
|
|
return deepEqualsMessages(lhs.toList(), rhs.toList()) }
|
|
func hash(into hasher: inout Hasher) {
|
|
deepHashMessages(value: toList(), hasher: &hasher)
|
|
}
|
|
}
|
|
|
|
/// Generated class from Pigeon that represents data sent in messages.
|
|
struct SyncDelta: Hashable {
|
|
var hasChanges: Bool
|
|
var updates: [ImAsset]
|
|
var deletes: [String]
|
|
var assetAlbums: [String: [String]]
|
|
|
|
|
|
// swift-format-ignore: AlwaysUseLowerCamelCase
|
|
static func fromList(_ pigeonVar_list: [Any?]) -> SyncDelta? {
|
|
let hasChanges = pigeonVar_list[0] as! Bool
|
|
let updates = pigeonVar_list[1] as! [ImAsset]
|
|
let deletes = pigeonVar_list[2] as! [String]
|
|
let assetAlbums = pigeonVar_list[3] as! [String: [String]]
|
|
|
|
return SyncDelta(
|
|
hasChanges: hasChanges,
|
|
updates: updates,
|
|
deletes: deletes,
|
|
assetAlbums: assetAlbums
|
|
)
|
|
}
|
|
func toList() -> [Any?] {
|
|
return [
|
|
hasChanges,
|
|
updates,
|
|
deletes,
|
|
assetAlbums,
|
|
]
|
|
}
|
|
static func == (lhs: SyncDelta, rhs: SyncDelta) -> Bool {
|
|
return deepEqualsMessages(lhs.toList(), rhs.toList()) }
|
|
func hash(into hasher: inout Hasher) {
|
|
deepHashMessages(value: toList(), hasher: &hasher)
|
|
}
|
|
}
|
|
|
|
private class MessagesPigeonCodecReader: FlutterStandardReader {
|
|
override func readValue(ofType type: UInt8) -> Any? {
|
|
switch type {
|
|
case 129:
|
|
return ImAsset.fromList(self.readValue() as! [Any?])
|
|
case 130:
|
|
return ImAlbum.fromList(self.readValue() as! [Any?])
|
|
case 131:
|
|
return SyncDelta.fromList(self.readValue() as! [Any?])
|
|
default:
|
|
return super.readValue(ofType: type)
|
|
}
|
|
}
|
|
}
|
|
|
|
private class MessagesPigeonCodecWriter: FlutterStandardWriter {
|
|
override func writeValue(_ value: Any) {
|
|
if let value = value as? ImAsset {
|
|
super.writeByte(129)
|
|
super.writeValue(value.toList())
|
|
} else if let value = value as? ImAlbum {
|
|
super.writeByte(130)
|
|
super.writeValue(value.toList())
|
|
} else if let value = value as? SyncDelta {
|
|
super.writeByte(131)
|
|
super.writeValue(value.toList())
|
|
} else {
|
|
super.writeValue(value)
|
|
}
|
|
}
|
|
}
|
|
|
|
private class MessagesPigeonCodecReaderWriter: FlutterStandardReaderWriter {
|
|
override func reader(with data: Data) -> FlutterStandardReader {
|
|
return MessagesPigeonCodecReader(data: data)
|
|
}
|
|
|
|
override func writer(with data: NSMutableData) -> FlutterStandardWriter {
|
|
return MessagesPigeonCodecWriter(data: data)
|
|
}
|
|
}
|
|
|
|
class MessagesPigeonCodec: FlutterStandardMessageCodec, @unchecked Sendable {
|
|
static let shared = MessagesPigeonCodec(readerWriter: MessagesPigeonCodecReaderWriter())
|
|
}
|
|
|
|
/// Generated protocol from Pigeon that represents a handler of messages from Flutter.
|
|
protocol NativeSyncApi {
|
|
func shouldFullSync() throws -> Bool
|
|
func getMediaChanges() throws -> SyncDelta
|
|
func checkpointSync() throws
|
|
func clearSyncCheckpoint() throws
|
|
func getAssetIdsForAlbum(albumId: String) throws -> [String]
|
|
func getAlbums() throws -> [ImAlbum]
|
|
func getAssetsCountSince(albumId: String, timestamp: Int64) throws -> Int64
|
|
func getAssetsForAlbum(albumId: String, updatedTimeCond: Int64?) throws -> [ImAsset]
|
|
}
|
|
|
|
/// Generated setup class from Pigeon to handle messages through the `binaryMessenger`.
|
|
class NativeSyncApiSetup {
|
|
static var codec: FlutterStandardMessageCodec { MessagesPigeonCodec.shared }
|
|
/// Sets up an instance of `NativeSyncApi` to handle messages through the `binaryMessenger`.
|
|
static func setUp(binaryMessenger: FlutterBinaryMessenger, api: NativeSyncApi?, messageChannelSuffix: String = "") {
|
|
let channelSuffix = messageChannelSuffix.count > 0 ? ".\(messageChannelSuffix)" : ""
|
|
#if os(iOS)
|
|
let taskQueue = binaryMessenger.makeBackgroundTaskQueue?()
|
|
#else
|
|
let taskQueue: FlutterTaskQueue? = nil
|
|
#endif
|
|
let shouldFullSyncChannel = FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.shouldFullSync\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
if let api = api {
|
|
shouldFullSyncChannel.setMessageHandler { _, reply in
|
|
do {
|
|
let result = try api.shouldFullSync()
|
|
reply(wrapResult(result))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
shouldFullSyncChannel.setMessageHandler(nil)
|
|
}
|
|
let getMediaChangesChannel = taskQueue == nil
|
|
? FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getMediaChanges\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
: FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getMediaChanges\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec, taskQueue: taskQueue)
|
|
if let api = api {
|
|
getMediaChangesChannel.setMessageHandler { _, reply in
|
|
do {
|
|
let result = try api.getMediaChanges()
|
|
reply(wrapResult(result))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
getMediaChangesChannel.setMessageHandler(nil)
|
|
}
|
|
let checkpointSyncChannel = FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.checkpointSync\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
if let api = api {
|
|
checkpointSyncChannel.setMessageHandler { _, reply in
|
|
do {
|
|
try api.checkpointSync()
|
|
reply(wrapResult(nil))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
checkpointSyncChannel.setMessageHandler(nil)
|
|
}
|
|
let clearSyncCheckpointChannel = FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.clearSyncCheckpoint\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
if let api = api {
|
|
clearSyncCheckpointChannel.setMessageHandler { _, reply in
|
|
do {
|
|
try api.clearSyncCheckpoint()
|
|
reply(wrapResult(nil))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
clearSyncCheckpointChannel.setMessageHandler(nil)
|
|
}
|
|
let getAssetIdsForAlbumChannel = taskQueue == nil
|
|
? FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAssetIdsForAlbum\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
: FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAssetIdsForAlbum\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec, taskQueue: taskQueue)
|
|
if let api = api {
|
|
getAssetIdsForAlbumChannel.setMessageHandler { message, reply in
|
|
let args = message as! [Any?]
|
|
let albumIdArg = args[0] as! String
|
|
do {
|
|
let result = try api.getAssetIdsForAlbum(albumId: albumIdArg)
|
|
reply(wrapResult(result))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
getAssetIdsForAlbumChannel.setMessageHandler(nil)
|
|
}
|
|
let getAlbumsChannel = taskQueue == nil
|
|
? FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAlbums\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
: FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAlbums\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec, taskQueue: taskQueue)
|
|
if let api = api {
|
|
getAlbumsChannel.setMessageHandler { _, reply in
|
|
do {
|
|
let result = try api.getAlbums()
|
|
reply(wrapResult(result))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
getAlbumsChannel.setMessageHandler(nil)
|
|
}
|
|
let getAssetsCountSinceChannel = taskQueue == nil
|
|
? FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAssetsCountSince\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
: FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAssetsCountSince\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec, taskQueue: taskQueue)
|
|
if let api = api {
|
|
getAssetsCountSinceChannel.setMessageHandler { message, reply in
|
|
let args = message as! [Any?]
|
|
let albumIdArg = args[0] as! String
|
|
let timestampArg = args[1] as! Int64
|
|
do {
|
|
let result = try api.getAssetsCountSince(albumId: albumIdArg, timestamp: timestampArg)
|
|
reply(wrapResult(result))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
getAssetsCountSinceChannel.setMessageHandler(nil)
|
|
}
|
|
let getAssetsForAlbumChannel = taskQueue == nil
|
|
? FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAssetsForAlbum\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec)
|
|
: FlutterBasicMessageChannel(name: "dev.flutter.pigeon.immich_mobile.NativeSyncApi.getAssetsForAlbum\(channelSuffix)", binaryMessenger: binaryMessenger, codec: codec, taskQueue: taskQueue)
|
|
if let api = api {
|
|
getAssetsForAlbumChannel.setMessageHandler { message, reply in
|
|
let args = message as! [Any?]
|
|
let albumIdArg = args[0] as! String
|
|
let updatedTimeCondArg: Int64? = nilOrValue(args[1])
|
|
do {
|
|
let result = try api.getAssetsForAlbum(albumId: albumIdArg, updatedTimeCond: updatedTimeCondArg)
|
|
reply(wrapResult(result))
|
|
} catch {
|
|
reply(wrapError(error))
|
|
}
|
|
}
|
|
} else {
|
|
getAssetsForAlbumChannel.setMessageHandler(nil)
|
|
}
|
|
}
|
|
}
|