mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-23 10:02:46 +02:00
Extended device info (PSG-772) (#6766)
This commit is contained in:
+20
-6
@@ -41,21 +41,35 @@ enum MockUserSessionDetailsScreenState: MockScreenState, CaseIterable {
|
||||
let session: UserSessionInfo
|
||||
switch self {
|
||||
case .allSections:
|
||||
session = UserSessionInfo(id: "session",
|
||||
session = UserSessionInfo(id: "alice",
|
||||
name: "iOS",
|
||||
deviceType: .mobile,
|
||||
isVerified: false,
|
||||
lastSeenIP: "10.0.0.10",
|
||||
lastSeenTimestamp: Date().timeIntervalSince1970 - 100,
|
||||
lastSeenTimestamp: nil,
|
||||
applicationName: "Element iOS",
|
||||
applicationVersion: "1.0.0",
|
||||
applicationURL: nil,
|
||||
deviceModel: nil,
|
||||
deviceOS: "iOS 15.5",
|
||||
lastSeenIPLocation: nil,
|
||||
deviceName: "My iPhone",
|
||||
isActive: true,
|
||||
isCurrent: true)
|
||||
case .sessionSectionOnly:
|
||||
session = UserSessionInfo(id: "session",
|
||||
name: "iOS",
|
||||
session = UserSessionInfo(id: "3",
|
||||
name: "Android",
|
||||
deviceType: .mobile,
|
||||
isVerified: false,
|
||||
lastSeenIP: nil,
|
||||
lastSeenTimestamp: Date().timeIntervalSince1970 - 100,
|
||||
lastSeenIP: "3.0.0.3",
|
||||
lastSeenTimestamp: Date().timeIntervalSince1970 - 10,
|
||||
applicationName: "Element Android",
|
||||
applicationVersion: "1.0.0",
|
||||
applicationURL: nil,
|
||||
deviceModel: nil,
|
||||
deviceOS: "Android 4.0",
|
||||
lastSeenIPLocation: nil,
|
||||
deviceName: "My Phone",
|
||||
isActive: true,
|
||||
isCurrent: false)
|
||||
}
|
||||
|
||||
+96
-49
@@ -20,17 +20,20 @@ import XCTest
|
||||
|
||||
class UserSessionDetailsViewModelTests: XCTestCase {
|
||||
func test_whenSessionNameAndLastSeenIPNil_viewStateCorrect() {
|
||||
let userSessionInfo = createUserSessionInfo(sessionId: "session",
|
||||
sessionName: nil,
|
||||
let userSessionInfo = createUserSessionInfo(id: "session",
|
||||
name: nil,
|
||||
lastSeenIP: nil)
|
||||
|
||||
let sessionItems = [
|
||||
sessionIdItem(sessionId: "session")
|
||||
]
|
||||
|
||||
var sessionItems = [UserSessionDetailsSectionItemViewData]()
|
||||
sessionItems.append(sessionIdItem(sessionId: userSessionInfo.id))
|
||||
|
||||
var sections = [UserSessionDetailsSectionViewData]()
|
||||
sections.append(UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems))
|
||||
let sections = [
|
||||
UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems)
|
||||
]
|
||||
|
||||
let expectedModel = UserSessionDetailsViewState(sections: sections)
|
||||
let sut = UserSessionDetailsViewModel(session: userSessionInfo)
|
||||
|
||||
@@ -38,18 +41,20 @@ class UserSessionDetailsViewModelTests: XCTestCase {
|
||||
}
|
||||
|
||||
func test_whenSessionNameNotNilLastSeenIPNil_viewStateCorrect() {
|
||||
let userSessionInfo = createUserSessionInfo(sessionId: "session",
|
||||
sessionName: "session name",
|
||||
let userSessionInfo = createUserSessionInfo(id: "session",
|
||||
name: "session name",
|
||||
lastSeenIP: nil)
|
||||
|
||||
var sessionItems = [UserSessionDetailsSectionItemViewData]()
|
||||
sessionItems.append(sessionNameItem(sessionName: "session name"))
|
||||
sessionItems.append(sessionIdItem(sessionId: userSessionInfo.id))
|
||||
|
||||
var sections = [UserSessionDetailsSectionViewData]()
|
||||
sections.append(UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems))
|
||||
|
||||
let sessionItems = [
|
||||
sessionNameItem(sessionName: "session name"),
|
||||
sessionIdItem(sessionId: "session")
|
||||
]
|
||||
|
||||
let sections = [
|
||||
UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems)
|
||||
]
|
||||
|
||||
let expectedModel = UserSessionDetailsViewState(sections: sections)
|
||||
let sut = UserSessionDetailsViewModel(session: userSessionInfo)
|
||||
@@ -58,56 +63,98 @@ class UserSessionDetailsViewModelTests: XCTestCase {
|
||||
}
|
||||
|
||||
func test_whenUserSessionInfoContainsAllValues_viewStateCorrect() {
|
||||
let userSessionInfo = createUserSessionInfo(sessionId: "session",
|
||||
sessionName: "session name",
|
||||
lastSeenIP: "0.0.0.0")
|
||||
let userSessionInfo = createUserSessionInfo(id: "session",
|
||||
name: "session name",
|
||||
lastSeenIP: "0.0.0.0",
|
||||
applicationName: "Element iOS",
|
||||
applicationVersion: "1.0.0")
|
||||
|
||||
var sessionItems = [UserSessionDetailsSectionItemViewData]()
|
||||
sessionItems.append(sessionNameItem(sessionName: "session name"))
|
||||
sessionItems.append(sessionIdItem(sessionId: userSessionInfo.id))
|
||||
|
||||
var sections = [UserSessionDetailsSectionViewData]()
|
||||
sections.append(UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems))
|
||||
|
||||
var deviceSectionItems = [UserSessionDetailsSectionItemViewData]()
|
||||
deviceSectionItems.append(UserSessionDetailsSectionItemViewData(title: VectorL10n.userSessionDetailsDeviceIpAddress,
|
||||
value: "0.0.0.0"))
|
||||
sections.append(UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsDeviceSectionHeader.uppercased(),
|
||||
footer: nil,
|
||||
items: deviceSectionItems))
|
||||
let sessionItems = [
|
||||
sessionNameItem(sessionName: "session name"),
|
||||
sessionIdItem(sessionId: "session")
|
||||
]
|
||||
let appItems = [
|
||||
appNameItem(appName: "Element iOS"),
|
||||
appVersionItem(appVersion: "1.0.0")
|
||||
]
|
||||
let deviceItems = [
|
||||
ipAddressItem(ipAddress: "0.0.0.0")
|
||||
]
|
||||
|
||||
let sections = [
|
||||
UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems),
|
||||
UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsApplicationSectionHeader.uppercased(),
|
||||
footer: nil,
|
||||
items: appItems),
|
||||
UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsDeviceSectionHeader.uppercased(),
|
||||
footer: nil,
|
||||
items: deviceItems)
|
||||
]
|
||||
|
||||
let expectedModel = UserSessionDetailsViewState(sections: sections)
|
||||
let sut = UserSessionDetailsViewModel(session: userSessionInfo)
|
||||
|
||||
XCTAssertEqual(sut.state, expectedModel)
|
||||
}
|
||||
|
||||
// MARK: - Private
|
||||
|
||||
private func createUserSessionInfo(sessionId: String,
|
||||
sessionName: String?,
|
||||
private func createUserSessionInfo(id: String,
|
||||
name: String?,
|
||||
deviceType: DeviceType = .mobile,
|
||||
isVerified: Bool = false,
|
||||
lastSeenIP: String?,
|
||||
lastSeenTimestamp: TimeInterval = Date().timeIntervalSince1970,
|
||||
isCurrentSession: Bool = true) -> UserSessionInfo {
|
||||
UserSessionInfo(id: sessionId,
|
||||
name: sessionName,
|
||||
applicationName: String? = nil,
|
||||
applicationVersion: String? = nil,
|
||||
applicationURL: String? = nil,
|
||||
deviceModel: String? = nil,
|
||||
deviceOS: String? = nil,
|
||||
lastSeenIPLocation: String? = nil,
|
||||
deviceName: String? = nil,
|
||||
isActive: Bool = true,
|
||||
isCurrent: Bool = true) -> UserSessionInfo {
|
||||
UserSessionInfo(id: id,
|
||||
name: name,
|
||||
deviceType: deviceType,
|
||||
isVerified: isVerified,
|
||||
lastSeenIP: lastSeenIP,
|
||||
lastSeenTimestamp: lastSeenTimestamp,
|
||||
isActive: true,
|
||||
isCurrent: isCurrentSession)
|
||||
applicationName: applicationName,
|
||||
applicationVersion: applicationVersion,
|
||||
applicationURL: applicationURL,
|
||||
deviceModel: deviceModel,
|
||||
deviceOS: deviceOS,
|
||||
lastSeenIPLocation: lastSeenIPLocation,
|
||||
deviceName: deviceName,
|
||||
isActive: isActive,
|
||||
isCurrent: isCurrent)
|
||||
}
|
||||
|
||||
private func sessionNameItem(sessionName: String) -> UserSessionDetailsSectionItemViewData {
|
||||
UserSessionDetailsSectionItemViewData(title: VectorL10n.userSessionDetailsSessionName,
|
||||
value: sessionName)
|
||||
.init(title: VectorL10n.userSessionDetailsSessionName,
|
||||
value: sessionName)
|
||||
}
|
||||
|
||||
private func sessionIdItem(sessionId: String) -> UserSessionDetailsSectionItemViewData {
|
||||
UserSessionDetailsSectionItemViewData(title: VectorL10n.keyVerificationManuallyVerifyDeviceIdTitle,
|
||||
value: sessionId)
|
||||
.init(title: VectorL10n.keyVerificationManuallyVerifyDeviceIdTitle,
|
||||
value: sessionId)
|
||||
}
|
||||
|
||||
private func appNameItem(appName: String) -> UserSessionDetailsSectionItemViewData {
|
||||
.init(title: VectorL10n.userSessionDetailsApplicationName,
|
||||
value: appName)
|
||||
}
|
||||
|
||||
private func appVersionItem(appVersion: String) -> UserSessionDetailsSectionItemViewData {
|
||||
.init(title: VectorL10n.userSessionDetailsApplicationVersion,
|
||||
value: appVersion)
|
||||
}
|
||||
|
||||
private func ipAddressItem(ipAddress: String) -> UserSessionDetailsSectionItemViewData {
|
||||
.init(title: VectorL10n.userSessionDetailsDeviceIpAddress,
|
||||
value: ipAddress)
|
||||
}
|
||||
}
|
||||
|
||||
+56
-15
@@ -32,8 +32,12 @@ class UserSessionDetailsViewModel: UserSessionDetailsViewModelType, UserSessionD
|
||||
|
||||
private func updateViewState(session: UserSessionInfo) {
|
||||
var sections = [UserSessionDetailsSectionViewData]()
|
||||
|
||||
|
||||
sections.append(sessionSection(session: session))
|
||||
|
||||
if let applicationSection = applicationSection(session: session) {
|
||||
sections.append(applicationSection)
|
||||
}
|
||||
|
||||
if let deviceSection = deviceSection(session: session) {
|
||||
sections.append(deviceSection)
|
||||
@@ -43,31 +47,68 @@ class UserSessionDetailsViewModel: UserSessionDetailsViewModelType, UserSessionD
|
||||
}
|
||||
|
||||
private func sessionSection(session: UserSessionInfo) -> UserSessionDetailsSectionViewData {
|
||||
var sessionItems = [UserSessionDetailsSectionItemViewData]()
|
||||
|
||||
var sessionItems: [UserSessionDetailsSectionItemViewData] = []
|
||||
|
||||
if let sessionName = session.name {
|
||||
sessionItems.append(UserSessionDetailsSectionItemViewData(title: VectorL10n.userSessionDetailsSessionName,
|
||||
value: sessionName))
|
||||
sessionItems.append(.init(title: VectorL10n.userSessionDetailsSessionName,
|
||||
value: sessionName))
|
||||
}
|
||||
|
||||
sessionItems.append(UserSessionDetailsSectionItemViewData(title: VectorL10n.keyVerificationManuallyVerifyDeviceIdTitle,
|
||||
value: session.id))
|
||||
sessionItems.append(.init(title: VectorL10n.keyVerificationManuallyVerifyDeviceIdTitle,
|
||||
value: session.id))
|
||||
|
||||
return UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems)
|
||||
return .init(header: VectorL10n.userSessionDetailsSessionSectionHeader.uppercased(),
|
||||
footer: VectorL10n.userSessionDetailsSessionSectionFooter,
|
||||
items: sessionItems)
|
||||
}
|
||||
|
||||
private func applicationSection(session: UserSessionInfo) -> UserSessionDetailsSectionViewData? {
|
||||
var sessionItems: [UserSessionDetailsSectionItemViewData] = []
|
||||
|
||||
if let name = session.applicationName {
|
||||
sessionItems.append(.init(title: VectorL10n.userSessionDetailsApplicationName,
|
||||
value: name))
|
||||
}
|
||||
if let version = session.applicationVersion {
|
||||
sessionItems.append(.init(title: VectorL10n.userSessionDetailsApplicationVersion,
|
||||
value: version))
|
||||
}
|
||||
if let url = session.applicationURL {
|
||||
sessionItems.append(.init(title: VectorL10n.userSessionDetailsApplicationUrl,
|
||||
value: url))
|
||||
}
|
||||
|
||||
guard !sessionItems.isEmpty else {
|
||||
return nil
|
||||
}
|
||||
return .init(header: VectorL10n.userSessionDetailsApplicationSectionHeader.uppercased(),
|
||||
footer: nil,
|
||||
items: sessionItems)
|
||||
}
|
||||
|
||||
private func deviceSection(session: UserSessionInfo) -> UserSessionDetailsSectionViewData? {
|
||||
var deviceSectionItems = [UserSessionDetailsSectionItemViewData]()
|
||||
|
||||
if let model = session.deviceModel {
|
||||
deviceSectionItems.append(.init(title: VectorL10n.userSessionDetailsDeviceModel,
|
||||
value: model))
|
||||
}
|
||||
if let deviceOS = session.deviceOS {
|
||||
deviceSectionItems.append(.init(title: VectorL10n.userSessionDetailsDeviceOs,
|
||||
value: deviceOS))
|
||||
}
|
||||
if let lastSeenIP = session.lastSeenIP {
|
||||
deviceSectionItems.append(UserSessionDetailsSectionItemViewData(title: VectorL10n.userSessionDetailsDeviceIpAddress,
|
||||
value: lastSeenIP))
|
||||
deviceSectionItems.append(.init(title: VectorL10n.userSessionDetailsDeviceIpAddress,
|
||||
value: lastSeenIP))
|
||||
}
|
||||
if let lastSeenIPLocation = session.lastSeenIPLocation {
|
||||
deviceSectionItems.append(.init(title: VectorL10n.userSessionDetailsDeviceIpLocation,
|
||||
value: lastSeenIPLocation))
|
||||
}
|
||||
if deviceSectionItems.count > 0 {
|
||||
return UserSessionDetailsSectionViewData(header: VectorL10n.userSessionDetailsDeviceSectionHeader.uppercased(),
|
||||
footer: nil,
|
||||
items: deviceSectionItems)
|
||||
return .init(header: VectorL10n.userSessionDetailsDeviceSectionHeader.uppercased(),
|
||||
footer: nil,
|
||||
items: deviceSectionItems)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user