85 lines
2.5 KiB
Swift
85 lines
2.5 KiB
Swift
//
|
|
// LoginState.swift
|
|
// punchnet
|
|
//
|
|
// Created by 安礼成 on 2026/1/16.
|
|
//
|
|
|
|
import Foundation
|
|
import Observation
|
|
|
|
@Observable
|
|
class AppContext {
|
|
var noticePort: Int
|
|
|
|
// 调用 "/connect" 之后的网络信息
|
|
var networkContext: SDLAPIClient.NetworkContext?
|
|
|
|
var loginCredit: Credit?
|
|
var networkSession: SDLAPIClient.NetworkSession?
|
|
|
|
// 当前app所处的场景
|
|
var appScene: AppScene = .login(username: nil)
|
|
|
|
enum Credit {
|
|
case token(token: String, accessToken: String)
|
|
case accountAndPasword(account: String, password: String, accessToken: String)
|
|
}
|
|
|
|
// 当前的场景
|
|
enum AppScene: Equatable {
|
|
case login(username: String?)
|
|
case logined
|
|
case register
|
|
case resetPassword
|
|
}
|
|
|
|
init(noticePort: Int) {
|
|
self.noticePort = noticePort
|
|
}
|
|
|
|
func loginWith(token: String) async throws {
|
|
let networkSession = try await SDLAPIClient.loginWithToken(token: token)
|
|
self.loginCredit = .token(token: token, accessToken: networkSession.accessToken)
|
|
self.networkSession = networkSession
|
|
|
|
// 将数据缓存到keychain
|
|
if let data = token.data(using: .utf8) {
|
|
try KeychainStore.shared.save(data, account: "token")
|
|
}
|
|
}
|
|
|
|
func loginWith(username: String, password: String) async throws {
|
|
let networkSession = try await SDLAPIClient.loginWithAccountAndPassword(username: username, password: password)
|
|
self.loginCredit = .accountAndPasword(account: username, password: password, accessToken: networkSession.accessToken)
|
|
// 将数据缓存到keychain
|
|
if let data = "\(username):\(password)".data(using: .utf8) {
|
|
try KeychainStore.shared.save(data, account: "accountAndPasword")
|
|
}
|
|
}
|
|
|
|
func loadCacheToken() -> String? {
|
|
if let data = try? KeychainStore.shared.load(account: "token") {
|
|
return String(data: data, encoding: .utf8)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func loadCacheUsernameAndPassword() -> (String, String)? {
|
|
if let data = try? KeychainStore.shared.load(account: "accountAndPasword"),
|
|
let str = String(data: data, encoding: .utf8) {
|
|
let parts = str.split(separator: ":")
|
|
if parts.count == 2 {
|
|
return (String(parts[0]), String(parts[1]))
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// 退出登陆
|
|
func logout() async throws {
|
|
try await VPNManager.shared.disableVpn()
|
|
}
|
|
|
|
}
|