mirror of https://github.com/oxen-io/session-ios
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
153 lines
6.9 KiB
Swift
153 lines
6.9 KiB
Swift
// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
|
|
|
|
import UIKit
|
|
import Photos
|
|
import PhotosUI
|
|
import AVFAudio
|
|
import SessionUIKit
|
|
import SessionUtilitiesKit
|
|
import SessionMessagingKit
|
|
|
|
public enum Permissions {
|
|
@discardableResult public static func requestCameraPermissionIfNeeded(
|
|
presentingViewController: UIViewController? = nil,
|
|
onAuthorized: (() -> Void)? = nil
|
|
) -> Bool {
|
|
switch AVCaptureDevice.authorizationStatus(for: .video) {
|
|
case .authorized:
|
|
onAuthorized?()
|
|
return true
|
|
|
|
case .denied, .restricted:
|
|
guard
|
|
Singleton.hasAppContext,
|
|
let presentingViewController: UIViewController = (presentingViewController ?? Singleton.appContext.frontmostViewController)
|
|
else { return false }
|
|
|
|
let confirmationModal: ConfirmationModal = ConfirmationModal(
|
|
info: ConfirmationModal.Info(
|
|
title: "permissionsRequired".localized(),
|
|
body: .text(
|
|
"cameraGrantAccessDenied"
|
|
.put(key: "app_name", value: Constants.app_name)
|
|
.localized()
|
|
),
|
|
confirmTitle: "sessionSettings".localized(),
|
|
dismissOnConfirm: false
|
|
) { [weak presentingViewController] _ in
|
|
presentingViewController?.dismiss(animated: true, completion: {
|
|
UIApplication.shared.open(URL(string: UIApplication.openSettingsURLString)!)
|
|
})
|
|
}
|
|
)
|
|
presentingViewController.present(confirmationModal, animated: true, completion: nil)
|
|
return false
|
|
|
|
case .notDetermined:
|
|
AVCaptureDevice.requestAccess(for: .video, completionHandler: { _ in
|
|
onAuthorized?()
|
|
})
|
|
return false
|
|
|
|
default: return false
|
|
}
|
|
}
|
|
|
|
public static func requestMicrophonePermissionIfNeeded(
|
|
presentingViewController: UIViewController? = nil,
|
|
onNotGranted: (() -> Void)? = nil
|
|
) {
|
|
switch AVAudioSession.sharedInstance().recordPermission {
|
|
case .granted: break
|
|
case .denied:
|
|
guard
|
|
Singleton.hasAppContext,
|
|
let presentingViewController: UIViewController = (presentingViewController ?? Singleton.appContext.frontmostViewController)
|
|
else { return }
|
|
onNotGranted?()
|
|
|
|
let confirmationModal: ConfirmationModal = ConfirmationModal(
|
|
info: ConfirmationModal.Info(
|
|
title: "permissionsRequired".localized(),
|
|
body: .text(
|
|
"permissionsMicrophoneAccessRequiredIos"
|
|
.put(key: "app_name", value: Constants.app_name)
|
|
.localized()
|
|
),
|
|
confirmTitle: "sessionSettings".localized(),
|
|
dismissOnConfirm: false,
|
|
onConfirm: { [weak presentingViewController] _ in
|
|
presentingViewController?.dismiss(animated: true, completion: {
|
|
UIApplication.shared.open(URL(string: UIApplication.openSettingsURLString)!)
|
|
})
|
|
},
|
|
afterClosed: { onNotGranted?() }
|
|
)
|
|
)
|
|
presentingViewController.present(confirmationModal, animated: true, completion: nil)
|
|
|
|
case .undetermined:
|
|
onNotGranted?()
|
|
AVAudioSession.sharedInstance().requestRecordPermission { _ in }
|
|
|
|
default: break
|
|
}
|
|
}
|
|
|
|
public static func requestLibraryPermissionIfNeeded(
|
|
isSavingMedia: Bool,
|
|
presentingViewController: UIViewController? = nil,
|
|
onAuthorized: @escaping () -> Void
|
|
) {
|
|
let targetPermission: PHAccessLevel = (isSavingMedia ? .addOnly : .readWrite)
|
|
let authorizationStatus = PHPhotoLibrary.authorizationStatus(for: .readWrite)
|
|
if authorizationStatus == .notDetermined {
|
|
// When the user chooses to select photos (which is the .limit status),
|
|
// the PHPhotoUI will present the picker view on the top of the front view.
|
|
// Since we have the ScreenLockUI showing when we request premissions,
|
|
// the picker view will be presented on the top of the ScreenLockUI.
|
|
// However, the ScreenLockUI will dismiss with the permission request alert view, so
|
|
// the picker view then will dismiss, too. The selection process cannot be finished
|
|
// this way. So we add a flag (isRequestingPermission) to prevent the ScreenLockUI
|
|
// from showing when we request the photo library permission.
|
|
SessionEnvironment.shared?.isRequestingPermission = true
|
|
|
|
PHPhotoLibrary.requestAuthorization(for: targetPermission) { status in
|
|
SessionEnvironment.shared?.isRequestingPermission = false
|
|
if [ PHAuthorizationStatus.authorized, PHAuthorizationStatus.limited ].contains(status) {
|
|
onAuthorized()
|
|
}
|
|
}
|
|
}
|
|
|
|
switch authorizationStatus {
|
|
case .authorized, .limited: onAuthorized()
|
|
case .denied, .restricted:
|
|
guard
|
|
Singleton.hasAppContext,
|
|
let presentingViewController: UIViewController = (presentingViewController ?? Singleton.appContext.frontmostViewController)
|
|
else { return }
|
|
|
|
let confirmationModal: ConfirmationModal = ConfirmationModal(
|
|
info: ConfirmationModal.Info(
|
|
title: "permissionsRequired".localized(),
|
|
body: .text(
|
|
"permissionsLibrary"
|
|
.put(key: "app_name", value: Constants.app_name)
|
|
.localized()
|
|
),
|
|
confirmTitle: "sessionSettings".localized(),
|
|
dismissOnConfirm: false
|
|
) { [weak presentingViewController] _ in
|
|
presentingViewController?.dismiss(animated: true, completion: {
|
|
UIApplication.shared.open(URL(string: UIApplication.openSettingsURLString)!)
|
|
})
|
|
}
|
|
)
|
|
presentingViewController.present(confirmationModal, animated: true, completion: nil)
|
|
|
|
default: return
|
|
}
|
|
}
|
|
}
|