mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
199 lines
9.3 KiB
Swift
199 lines
9.3 KiB
Swift
import Foundation
|
|
import Postbox
|
|
import TelegramApi
|
|
|
|
|
|
func parsedTelegramProfilePhoto(_ photo: Api.UserProfilePhoto) -> [TelegramMediaImageRepresentation] {
|
|
var representations: [TelegramMediaImageRepresentation] = []
|
|
switch photo {
|
|
case let .userProfilePhoto(flags, id, strippedThumb, dcId):
|
|
let _ = (flags & (1 << 0)) != 0
|
|
|
|
let smallResource: TelegramMediaResource
|
|
let fullSizeResource: TelegramMediaResource
|
|
|
|
smallResource = CloudPeerPhotoSizeMediaResource(datacenterId: dcId, photoId: id, sizeSpec: .small, volumeId: nil, localId: nil)
|
|
fullSizeResource = CloudPeerPhotoSizeMediaResource(datacenterId: dcId, photoId: id, sizeSpec: .fullSize, volumeId: nil, localId: nil)
|
|
|
|
representations.append(TelegramMediaImageRepresentation(dimensions: PixelDimensions(width: 80, height: 80), resource: smallResource, progressiveSizes: [], immediateThumbnailData: strippedThumb?.makeData()))
|
|
representations.append(TelegramMediaImageRepresentation(dimensions: PixelDimensions(width: 640, height: 640), resource: fullSizeResource, progressiveSizes: [], immediateThumbnailData: strippedThumb?.makeData()))
|
|
case .userProfilePhotoEmpty:
|
|
break
|
|
}
|
|
return representations
|
|
}
|
|
|
|
extension TelegramUser {
|
|
convenience init(user: Api.User) {
|
|
switch user {
|
|
case let .user(flags, id, accessHash, firstName, lastName, username, phone, photo, _, _, restrictionReason, botInlinePlaceholder, _):
|
|
let representations: [TelegramMediaImageRepresentation] = photo.flatMap(parsedTelegramProfilePhoto) ?? []
|
|
|
|
let isMin = (flags & (1 << 20)) != 0
|
|
let accessHashValue = accessHash.flatMap { value -> TelegramPeerAccessHash in
|
|
if isMin {
|
|
return .genericPublic(value)
|
|
} else {
|
|
return .personal(value)
|
|
}
|
|
}
|
|
|
|
var userFlags: UserInfoFlags = []
|
|
if (flags & (1 << 17)) != 0 {
|
|
userFlags.insert(.isVerified)
|
|
}
|
|
if (flags & (1 << 23)) != 0 {
|
|
userFlags.insert(.isSupport)
|
|
}
|
|
if (flags & (1 << 24)) != 0 {
|
|
userFlags.insert(.isScam)
|
|
}
|
|
if (flags & (1 << 26)) != 0 {
|
|
userFlags.insert(.isFake)
|
|
}
|
|
|
|
var botInfo: BotUserInfo?
|
|
if (flags & (1 << 14)) != 0 {
|
|
var botFlags = BotUserInfoFlags()
|
|
if (flags & (1 << 15)) != 0 {
|
|
botFlags.insert(.hasAccessToChatHistory)
|
|
}
|
|
if (flags & (1 << 16)) == 0 {
|
|
botFlags.insert(.worksWithGroups)
|
|
}
|
|
if (flags & (1 << 21)) != 0 {
|
|
botFlags.insert(.requiresGeolocationForInlineRequests)
|
|
}
|
|
if (flags & (1 << 27)) != 0 {
|
|
botFlags.insert(.canBeAddedToAttachMenu)
|
|
}
|
|
if (flags & (1 << 28)) != 0 {
|
|
botFlags.insert(.menuStartsWebView)
|
|
}
|
|
botInfo = BotUserInfo(flags: botFlags, inlinePlaceholder: botInlinePlaceholder)
|
|
}
|
|
|
|
let restrictionInfo: PeerAccessRestrictionInfo? = restrictionReason.flatMap(PeerAccessRestrictionInfo.init(apiReasons:))
|
|
|
|
self.init(id: PeerId(namespace: Namespaces.Peer.CloudUser, id: PeerId.Id._internalFromInt64Value(id)), accessHash: accessHashValue, firstName: firstName, lastName: lastName, username: username, phone: phone, photo: representations, botInfo: botInfo, restrictionInfo: restrictionInfo, flags: userFlags)
|
|
case let .userEmpty(id):
|
|
self.init(id: PeerId(namespace: Namespaces.Peer.CloudUser, id: PeerId.Id._internalFromInt64Value(id)), accessHash: nil, firstName: nil, lastName: nil, username: nil, phone: nil, photo: [], botInfo: nil, restrictionInfo: nil, flags: [])
|
|
}
|
|
}
|
|
|
|
static func merge(_ lhs: TelegramUser?, rhs: Api.User) -> TelegramUser? {
|
|
switch rhs {
|
|
case let .user(flags, _, rhsAccessHash, _, _, username, _, photo, _, _, restrictionReason, botInlinePlaceholder, _):
|
|
let isMin = (flags & (1 << 20)) != 0
|
|
if !isMin {
|
|
return TelegramUser(user: rhs)
|
|
} else {
|
|
let telegramPhoto: [TelegramMediaImageRepresentation]
|
|
if let photo = photo {
|
|
telegramPhoto = parsedTelegramProfilePhoto(photo)
|
|
} else if let currentPhoto = lhs?.photo {
|
|
telegramPhoto = currentPhoto
|
|
} else {
|
|
telegramPhoto = []
|
|
}
|
|
|
|
if let lhs = lhs {
|
|
var userFlags: UserInfoFlags = []
|
|
if (flags & (1 << 17)) != 0 {
|
|
userFlags.insert(.isVerified)
|
|
}
|
|
if (flags & (1 << 23)) != 0 {
|
|
userFlags.insert(.isSupport)
|
|
}
|
|
if (flags & (1 << 24)) != 0 {
|
|
userFlags.insert(.isScam)
|
|
}
|
|
if (flags & Int32(1 << 26)) != 0 {
|
|
userFlags.insert(.isFake)
|
|
}
|
|
|
|
var botInfo: BotUserInfo?
|
|
if (flags & (1 << 14)) != 0 {
|
|
var botFlags = BotUserInfoFlags()
|
|
if (flags & (1 << 15)) != 0 {
|
|
botFlags.insert(.hasAccessToChatHistory)
|
|
}
|
|
if (flags & (1 << 16)) == 0 {
|
|
botFlags.insert(.worksWithGroups)
|
|
}
|
|
if (flags & (1 << 21)) != 0 {
|
|
botFlags.insert(.requiresGeolocationForInlineRequests)
|
|
}
|
|
if (flags & (1 << 27)) != 0 {
|
|
botFlags.insert(.canBeAddedToAttachMenu)
|
|
}
|
|
if (flags & (1 << 28)) != 0 {
|
|
botFlags.insert(.menuStartsWebView)
|
|
}
|
|
botInfo = BotUserInfo(flags: botFlags, inlinePlaceholder: botInlinePlaceholder)
|
|
}
|
|
|
|
let restrictionInfo: PeerAccessRestrictionInfo? = restrictionReason.flatMap(PeerAccessRestrictionInfo.init)
|
|
|
|
let rhsAccessHashValue = rhsAccessHash.flatMap { value -> TelegramPeerAccessHash in
|
|
if isMin {
|
|
return .genericPublic(value)
|
|
} else {
|
|
return .personal(value)
|
|
}
|
|
}
|
|
|
|
let accessHash: TelegramPeerAccessHash?
|
|
if let rhsAccessHashValue = rhsAccessHashValue, case .personal = rhsAccessHashValue {
|
|
accessHash = rhsAccessHashValue
|
|
} else {
|
|
accessHash = lhs.accessHash ?? rhsAccessHashValue
|
|
}
|
|
|
|
return TelegramUser(id: lhs.id, accessHash: accessHash, firstName: lhs.firstName, lastName: lhs.lastName, username: username, phone: lhs.phone, photo: telegramPhoto, botInfo: botInfo, restrictionInfo: restrictionInfo, flags: userFlags)
|
|
} else {
|
|
return TelegramUser(user: rhs)
|
|
}
|
|
}
|
|
case .userEmpty:
|
|
return TelegramUser(user: rhs)
|
|
}
|
|
}
|
|
|
|
static func merge(lhs: TelegramUser?, rhs: TelegramUser) -> TelegramUser {
|
|
guard let lhs = lhs else {
|
|
return rhs
|
|
}
|
|
if let rhsAccessHash = rhs.accessHash, case .personal = rhsAccessHash {
|
|
return rhs
|
|
} else {
|
|
var userFlags: UserInfoFlags = []
|
|
if rhs.flags.contains(.isVerified) {
|
|
userFlags.insert(.isVerified)
|
|
}
|
|
if rhs.flags.contains(.isSupport) {
|
|
userFlags.insert(.isSupport)
|
|
}
|
|
if rhs.flags.contains(.isScam) {
|
|
userFlags.insert(.isScam)
|
|
}
|
|
if rhs.flags.contains(.isFake) {
|
|
userFlags.insert(.isFake)
|
|
}
|
|
|
|
let botInfo: BotUserInfo? = rhs.botInfo
|
|
|
|
let restrictionInfo: PeerAccessRestrictionInfo? = rhs.restrictionInfo
|
|
|
|
let accessHash: TelegramPeerAccessHash?
|
|
if let rhsAccessHashValue = lhs.accessHash, case .personal = rhsAccessHashValue {
|
|
accessHash = rhsAccessHashValue
|
|
} else {
|
|
accessHash = lhs.accessHash ?? rhs.accessHash
|
|
}
|
|
|
|
return TelegramUser(id: lhs.id, accessHash: accessHash, firstName: lhs.firstName, lastName: lhs.lastName, username: rhs.username, phone: lhs.phone, photo: rhs.photo.isEmpty ? lhs.photo : rhs.photo, botInfo: botInfo, restrictionInfo: restrictionInfo, flags: userFlags)
|
|
}
|
|
}
|
|
}
|