// // Copyright 2022 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 Combine import Foundation import MatrixRustSDK class MockAuthenticationServiceProxy: AuthenticationServiceProtocol { let validCredentials = (username: "alice", password: "12345678") private let homeserverSubject: CurrentValueSubject var homeserver: CurrentValuePublisher { homeserverSubject.asCurrentValuePublisher() } init(homeserver: LoginHomeserver = .mockMatrixDotOrg) { homeserverSubject = .init(homeserver) } func configure(for homeserverAddress: String) async -> Result { // Map the address to the mock homeservers if LoginHomeserver.mockMatrixDotOrg.address.contains(homeserverAddress) { homeserverSubject.send(.mockMatrixDotOrg) return .success(()) } else if LoginHomeserver.mockOIDC.address.contains(homeserverAddress) { homeserverSubject.send(.mockOIDC) return .success(()) } else if LoginHomeserver.mockBasicServer.address.contains(homeserverAddress) { homeserverSubject.send(.mockBasicServer) return .success(()) } else if LoginHomeserver.mockUnsupported.address.contains(homeserverAddress) { homeserverSubject.send(.mockUnsupported) return .success(()) } else { // Otherwise fail with an invalid server. return .failure(.invalidServer) } } func urlForOIDCLogin() async -> Result { .failure(.oidcError(.notSupported)) } func abortOIDCLogin(data: OIDCAuthorizationDataProxy) async { } func loginWithOIDCCallback(_ callbackURL: URL, data: OIDCAuthorizationDataProxy) async -> Result { .failure(.oidcError(.notSupported)) } func login(username: String, password: String, initialDeviceName: String?, deviceID: String?) async -> Result { // Login only succeeds if the username and password match the valid credentials property guard username == validCredentials.username, password == validCredentials.password else { return .failure(.invalidCredentials) } let userSession = UserSessionMock(.init(clientProxy: ClientProxyMock(.init(userID: username)))) return .success(userSession) } }