element-ios/Riot/Managers/PushNotification/PushNotificationStore.swift
Stefan Ceriu f7a8163947
Adopt consolidated logging mechanism (#4370)
* Adopted the new MXLog and replaced NSLog throughout the application - vector-im/element-ios/issues/4351
* Replaced NSLog() and print() usages with MXLog.debug()
* Added swiftlint rules for NSLog(), print(), println() and os_log()
* Escape paths used to run script build phases for swiftlint and swiftgen
2021-06-03 11:30:07 +03:00

80 lines
2.5 KiB
Swift

//
// Copyright 2020 Vector Creations Ltd
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
import Foundation
import KeychainAccess
import MatrixSDK
@objcMembers
final class PushNotificationStore: NSObject {
// MARK: - Constants
private struct PushNotificationConstants {
static let pushNotificationKeychainService: String = BuildSettings.baseBundleIdentifier + ".pushnotification-service"
}
private struct StoreKeys {
static let pushToken: String = "pushtoken"
}
/// Store. Defaults to `KeychainStore`
private let store: KeyValueStore
override init() {
store = KeychainStore(withKeychain: Keychain(service: PushNotificationConstants.pushNotificationKeychainService,
accessGroup: BuildSettings.keychainAccessGroup))
super.init()
}
/// Saved PushKit token
var pushKitToken: Data? {
get {
do {
return try store.data(forKey: StoreKeys.pushToken)
} catch let error {
MXLog.debug("[PinCodePreferences] Error when reading push token from store: \(error)")
return nil
}
} set {
do {
try store.set(newValue, forKey: StoreKeys.pushToken)
} catch let error {
MXLog.debug("[PinCodePreferences] Error when storing push token to the store: \(error)")
}
}
}
func callInvite(forEventId eventId: String) -> MXEvent? {
guard let data = try? store.data(forKey: eventId) else {
return nil
}
return NSKeyedUnarchiver.unarchiveObject(with: data) as? MXEvent
}
func storeCallInvite(_ event: MXEvent) {
let data = NSKeyedArchiver.archivedData(withRootObject: event)
try? store.set(data, forKey: event.eventId)
}
func removeCallInvite(withEventId eventId: String) {
try? store.removeObject(forKey: eventId)
}
func reset() {
try? store.removeAll()
}
}