mirror of
https://github.com/home-assistant/iOS.git
synced 2026-02-04 02:46:35 -06:00
<!-- Thank you for submitting a Pull Request and helping to improve Home Assistant. Please complete the following sections to help the processing and review of your changes. Please do not delete anything from this template. --> ## Summary <!-- Provide a brief summary of the changes you have made and most importantly what they aim to achieve --> ## Screenshots <!-- If this is a user-facing change not in the frontend, please include screenshots in light and dark mode. --> ## Link to pull request in Documentation repository <!-- Pull requests that add, change or remove functionality must have a corresponding pull request in the Companion App Documentation repository (https://github.com/home-assistant/companion.home-assistant). Please add the number of this pull request after the "#" --> Documentation: home-assistant/companion.home-assistant# ## Any other notes <!-- If there is any other information of note, like if this Pull Request is part of a bigger change, please include it here. -->
34 lines
1.2 KiB
Swift
34 lines
1.2 KiB
Swift
import PromiseKit
|
|
import Shared
|
|
import UserNotifications
|
|
|
|
final class NotificationService: UNNotificationServiceExtension {
|
|
override func didReceive(
|
|
_ request: UNNotificationRequest,
|
|
withContentHandler contentHandler: @escaping (UNNotificationContent) -> Void
|
|
) {
|
|
Current.Log.info("didReceive \(request), user info \(request.content.userInfo)")
|
|
|
|
guard let server = Current.servers.server(for: request.content), let api = Current.api(for: server) else {
|
|
contentHandler(request.content)
|
|
return
|
|
}
|
|
|
|
firstly {
|
|
Current.notificationAttachmentManager.content(from: request.content, api: api)
|
|
}.recover { error in
|
|
Current.Log.error("failed to get content, giving default: \(error)")
|
|
return .value(request.content)
|
|
}.done {
|
|
contentHandler($0)
|
|
}
|
|
}
|
|
|
|
override func serviceExtensionTimeWillExpire() {
|
|
// Called just before the extension will be terminated by the system.
|
|
// Use this as an opportunity to deliver your "best attempt" at modified content,
|
|
// otherwise the original push payload will be used.
|
|
Current.Log.warning("serviceExtensionTimeWillExpire")
|
|
}
|
|
}
|