Files
GLEGram-iOS/submodules/TelegramCore/Sources/State/UnauthorizedAccountStateManager.swift
T
Leeksov 4647310322 GLEGram 12.5 — Initial public release
Based on Swiftgram 12.5 (Telegram iOS 12.5).
All GLEGram features ported and organized in GLEGram/ folder.

Features: Ghost Mode, Saved Deleted Messages, Content Protection Bypass,
Font Replacement, Fake Profile, Chat Export, Plugin System, and more.

See CHANGELOG_12.5.md for full details.
2026-04-06 09:48:12 +03:00

115 lines
4.0 KiB
Swift

import Foundation
import Postbox
import SwiftSignalKit
import TelegramApi
import MtProtoKit
private final class UnauthorizedUpdateMessageService: NSObject, MTMessageService {
let pipe: ValuePipe<[Api.Update]> = ValuePipe()
var mtProto: MTProto?
override init() {
super.init()
}
func mtProtoWillAdd(_ mtProto: MTProto!) {
self.mtProto = mtProto
}
func mtProtoDidChangeSession(_ mtProto: MTProto!) {
}
func mtProtoServerDidChangeSession(_ mtProto: MTProto!, firstValidMessageId: Int64, otherValidMessageIds: [Any]!) {
}
func putNext(_ updates: [Api.Update]) {
self.pipe.putNext(updates)
}
func mtProto(_ mtProto: MTProto!, receivedMessage message: MTIncomingMessage!, authInfoSelector: MTDatacenterAuthInfoSelector, networkType: Int32) {
if let updates = (message.body as? BoxedMessage)?.body as? Api.Updates {
self.addUpdates(updates)
}
}
func addUpdates(_ updates: Api.Updates) {
switch updates {
case let .updates(updatesData):
let updates = updatesData.updates
self.putNext(updates)
case let .updatesCombined(updatesCombinedData):
let updates = updatesCombinedData.updates
self.putNext(updates)
case let .updateShort(updateShortData):
let update = updateShortData.update
self.putNext([update])
case .updateShortChatMessage, .updateShortMessage, .updatesTooLong, .updateShortSentMessage:
break
}
}
}
final class UnauthorizedAccountStateManager {
private let queue = Queue()
private let network: Network
private var updateService: UnauthorizedUpdateMessageService?
private let updateServiceDisposable = MetaDisposable()
private let updateLoginToken: () -> Void
private let updateSentCode: (Api.auth.SentCode) -> Void
private let displayServiceNotification: (String) -> Void
init(
network: Network,
updateLoginToken: @escaping () -> Void,
updateSentCode: @escaping (Api.auth.SentCode) -> Void,
displayServiceNotification: @escaping (String) -> Void
) {
self.network = network
self.updateLoginToken = updateLoginToken
self.updateSentCode = updateSentCode
self.displayServiceNotification = displayServiceNotification
}
deinit {
self.updateServiceDisposable.dispose()
}
func addUpdates(_ updates: Api.Updates) {
self.queue.async {
self.updateService?.addUpdates(updates)
}
}
func reset() {
self.queue.async {
if self.updateService == nil {
self.updateService = UnauthorizedUpdateMessageService()
let updateLoginToken = self.updateLoginToken
let updateSentCode = self.updateSentCode
let displayServiceNotification = self.displayServiceNotification
self.updateServiceDisposable.set(self.updateService!.pipe.signal().start(next: { updates in
for update in updates {
switch update {
case .updateLoginToken:
updateLoginToken()
case let .updateServiceNotification(updateServiceNotificationData):
let (flags, message) = (updateServiceNotificationData.flags, updateServiceNotificationData.message)
let popup = (flags & (1 << 0)) != 0
if popup {
displayServiceNotification(message)
}
case let .updateSentPhoneCode(updateSentPhoneCodeData):
let sentCode = updateSentPhoneCodeData.sentCode
updateSentCode(sentCode)
default:
break
}
}
}))
self.network.mtProto.add(self.updateService)
}
}
}
}