element-ios/Riot/Modules/Camera/CameraAccessManager.swift
ismailgulek 19afad1f18
Login with QR UI components (#6790)
* Display QR button on login screen if HS supports

* Create start screen

* Add build flag

* Connect start screen to the login

* QR display screen

* Move `LabelledDividerView` into separate file

* Show display QR screen on button tap

* Add swift concurreny to CameraAccessManager

* Introduce `QRLoginServiceProtocol`

* Use new service in screens

* Introduce scan QR code screen

* Remove hardcoded service availability

* Remove unnecessary import

* Add confirmation screen

* Add loading screen

* Fix ZXingObjc targets

* Add failure screen

* Add strings

* Various UI tweaks, navigation according to the service state

* Fix tests

* Add string for invalid QR error

* Add QR login service mode
2022-10-06 18:05:46 +03:00

77 lines
2.3 KiB
Swift

/*
Copyright 2020 New Vector 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
/// CameraAccessManager handles camera availability and authorization.
final class CameraAccessManager {
// MARK: - Properties
var isCameraAvailable: Bool {
return UIImagePickerController.isSourceTypeAvailable(.camera)
}
var isCameraAccessGranted: Bool {
return AVCaptureDevice.authorizationStatus(for: .video) == .authorized
}
// MARK: - Public
func askAndRequestCameraAccessIfNeeded(completion: @escaping (_ granted: Bool) -> Void) {
let authorizationStatus = AVCaptureDevice.authorizationStatus(for: .video)
switch authorizationStatus {
case .authorized:
completion(true)
case .notDetermined:
self.requestCameraAccess(completion: { (granted) in
completion(granted)
})
case .denied, .restricted:
completion(false)
@unknown default:
break
}
}
/// Checks and requests the camera access if needed. Returns `true` if granted, otherwise `false`.
func requestCameraAccessIfNeeded() async -> Bool {
let authStatus = AVCaptureDevice.authorizationStatus(for: .video)
switch authStatus {
case .authorized:
return true
case .notDetermined:
return await AVCaptureDevice.requestAccess(for: .video)
case .denied, .restricted:
return false
@unknown default:
return false
}
}
// MARK: - Private
private func requestCameraAccess(completion: @escaping (_ granted: Bool) -> Void) {
AVCaptureDevice.requestAccess(for: .video) { granted in
DispatchQueue.main.async {
completion(granted)
}
}
}
}