mirror of
https://github.com/vector-im/element-ios.git
synced 2024-10-02 01:02:41 +00:00
19afad1f18
* 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
117 lines
3.7 KiB
Swift
117 lines
3.7 KiB
Swift
//
|
|
// Copyright 2021 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
|
|
|
|
// MARK: View model
|
|
|
|
enum AuthenticationLoginViewModelResult: CustomStringConvertible {
|
|
/// The user would like to select another server.
|
|
case selectServer
|
|
/// Parse the username and update the homeserver if included.
|
|
case parseUsername(String)
|
|
/// The user would like to reset their password.
|
|
case forgotPassword
|
|
/// Login using the supplied credentials.
|
|
case login(username: String, password: String)
|
|
/// Continue using the supplied SSO provider.
|
|
case continueWithSSO(SSOIdentityProvider)
|
|
/// Continue using the fallback page
|
|
case fallback
|
|
/// Continue with QR login
|
|
case qrLogin
|
|
|
|
/// A string representation of the result, ignoring any associated values that could leak PII.
|
|
var description: String {
|
|
switch self {
|
|
case .selectServer:
|
|
return "selectServer"
|
|
case .parseUsername:
|
|
return "parseUsername"
|
|
case .forgotPassword:
|
|
return "forgotPassword"
|
|
case .login:
|
|
return "login"
|
|
case .continueWithSSO(let provider):
|
|
return "continueWithSSO: \(provider)"
|
|
case .fallback:
|
|
return "fallback"
|
|
case .qrLogin:
|
|
return "qrLogin"
|
|
}
|
|
}
|
|
}
|
|
|
|
// MARK: View
|
|
|
|
struct AuthenticationLoginViewState: BindableState {
|
|
/// Data about the selected homeserver.
|
|
var homeserver: AuthenticationHomeserverViewData
|
|
/// Whether a new homeserver is currently being loaded.
|
|
var isLoading = false
|
|
/// View state that can be bound to from SwiftUI.
|
|
var bindings: AuthenticationLoginBindings
|
|
|
|
/// Whether to show any SSO buttons.
|
|
var showSSOButtons: Bool {
|
|
!homeserver.ssoIdentityProviders.isEmpty
|
|
}
|
|
|
|
/// `true` if the username and password are ready to be submitted.
|
|
var hasValidCredentials: Bool {
|
|
!bindings.username.isEmpty && !bindings.password.isEmpty
|
|
}
|
|
|
|
/// `true` if valid credentials have been entered and the homeserver is loaded.
|
|
var canSubmit: Bool {
|
|
hasValidCredentials && !isLoading
|
|
}
|
|
}
|
|
|
|
struct AuthenticationLoginBindings {
|
|
/// The username input by the user.
|
|
var username = ""
|
|
/// The password input by the user.
|
|
var password = ""
|
|
/// Information describing the currently displayed alert.
|
|
var alertInfo: AlertInfo<AuthenticationLoginErrorType>?
|
|
}
|
|
|
|
enum AuthenticationLoginViewAction {
|
|
/// The user would like to select another server.
|
|
case selectServer
|
|
/// Parse the username to detect if a homeserver is included.
|
|
case parseUsername
|
|
/// The user would like to reset their password.
|
|
case forgotPassword
|
|
/// Continue using the input username and password.
|
|
case next
|
|
/// Continue using the fallback page
|
|
case fallback
|
|
/// Continue using the supplied SSO provider.
|
|
case continueWithSSO(SSOIdentityProvider)
|
|
/// Continue using QR login
|
|
case qrLogin
|
|
}
|
|
|
|
enum AuthenticationLoginErrorType: Hashable {
|
|
/// An error response from the homeserver.
|
|
case mxError(String)
|
|
/// The current homeserver address isn't valid.
|
|
case invalidHomeserver
|
|
/// The response from the homeserver was unexpected.
|
|
case unknown
|
|
}
|