Zum Hauptinhalt springen

iOS SDK Verwendung

Initialisierung

Das SDK wird als KMP-Framework unter iOS genutzt. Verwenden Sie das Builder-Muster, um eine Instanz zu erstellen. Die Funktion build() ist asynchron und fuehrt die DPoP-Schluesselpaargenerierung (Secure Enclave), Token-Aktivierung und Berechtigungsueberpruefung durch.

import VitaleraSdkCore

let sdk = try await VitaleraSdk.companion.builder()
.clientId(clientId: "your-org-license-key")
.addProvider(providerName: "omron")
.addProvider(providerName: "polar")
.addProvider(providerName: "standard-ble")
.connectedMode(enabled: true)
.build()

Behandlung von Authentifizierungsfehlern:

do {
let sdk = try await VitaleraSdk.companion.builder()
.clientId(clientId: "your-org-license-key")
.build()
} catch let error as SdkAuthException {
switch error.errorCode {
case "activation_failed":
showInvalidLicenseError()
case "entitlements_expired":
showConnectToInternetPrompt()
case "no_cache":
showFirstLaunchOfflineError()
default:
showGenericError(error.message)
}
}

Berechtigungen

Fuegen Sie die erforderlichen Berechtigungen zu Ihrer Info.plist hinzu:

<key>NSBluetoothAlwaysUsageDescription</key>
<string>This app uses Bluetooth to connect with medical devices.</string>
<key>NSBluetoothPeripheralUsageDescription</key>
<string>This app uses Bluetooth to communicate with devices.</string>

Fuer HealthKit:

<key>NSHealthShareUsageDescription</key>
<string>This app reads health data for monitoring.</string>

Geraeteerkennung

Die Erkennung verwendet Swift AsyncSequence. Jedes erkannte Geraet wird als DeviceDescriptor zurueckgegeben.

let filter = DiscoveryFilter(
providers: nil,
capabilities: [DeviceCapability.bloodPressure],
namePrefix: nil
)

for try await descriptor in sdk.devices.discover(filter: filter, timeoutMs: 15_000) {
print("Found: \(descriptor.name) (\(descriptor.provider))")
}

Filteroptionen

// Nur Polar-Geraete
let polarFilter = DiscoveryFilter(
providers: ["polar"],
capabilities: nil,
namePrefix: nil
)

// Nur Herzfrequenzmessgeraete
let hrFilter = DiscoveryFilter(
providers: nil,
capabilities: [DeviceCapability.heartRate],
namePrefix: nil
)

Geraeteverbindung

Erstellen Sie ein Geraet aus einem Deskriptor und verbinden Sie sich. Die Funktion connect() ist asynchron mit einem konfigurierbaren Timeout.

let device = sdk.devices.createDevice(descriptor: descriptor)

// Verbinden (asynchron, mit Timeout)
try await device.connect(timeoutMs: 10_000)

Datenerfassung

Die Methode collect() gibt eine AsyncSequence typisierter Beobachtungsklassen zurueck.

for try await observation in device.collect() {
if let bp = observation as? BloodPressureObservation {
print("BP: \(bp.systolic)/\(bp.diastolic) mmHg")
if let pulse = bp.pulseRate {
print("Pulse: \(pulse) bpm")
}
} else if let hr = observation as? HeartRateObservation {
print("HR: \(hr.heartRate) bpm")
} else if let temp = observation as? TemperatureObservation {
print("Temp: \(temp.temperature) C")
} else if let weight = observation as? WeightObservation {
print("Weight: \(weight.weight) kg")
} else if let spo2 = observation as? OxygenSaturationObservation {
print("SpO2: \(spo2.spo2)%")
}
}

// Nach Abschluss trennen
try await device.disconnect()

Verbundener Modus

Wenn der verbundene Modus aktiviert ist, koennen Sie Patienten aufloesen und Beobachtungen senden:

let patient = try await sdk.connected().resolveMonitored(externalId: "patient-ext-id")

try await sdk.connected().postObservation(
monitoredId: patient.id,
observation: BaseObservation(
observationType: "blood-pressure",
issued: ISO8601DateFormatter().string(from: Date()),
components: [
ObservationComponent(name: "systolic", value: "120", valueUnit: "mmHg"),
ObservationComponent(name: "diastolic", value: "80", valueUnit: "mmHg"),
]
)
)

Fehlerbehandlung

do {
try await device.connect(timeoutMs: 10_000)
for try await obs in device.collect() {
// Beobachtung verarbeiten
}
} catch let error as SdkError {
switch error {
case is SdkError.ConnectionTimeout:
showError("Connection timed out. Move closer to the device.")
case is SdkError.BluetoothDisabled:
showError("Please enable Bluetooth.")
case is SdkError.BluetoothPermissionDenied:
showError("Bluetooth permissions required.")
default:
showError("Device error: \(error.localizedDescription)")
}
}

HealthKit

Lesen von Apple HealthKit (kein BLE-Scan erforderlich):

let descriptor = try await sdk.devices.discover(
filter: DiscoveryFilter(providers: ["apple-healthkit"], capabilities: nil, namePrefix: nil),
timeoutMs: 5_000
).first { _ in true }!

let store = sdk.devices.createDevice(descriptor: descriptor)
try await store.connect()
for try await observation in store.collect() {
// HealthKit-Beobachtungen verarbeiten
}
try await store.disconnect()

Ressourcenbereinigung

Rufen Sie immer close() auf, wenn das SDK nicht mehr benoetigt wird:

sdk.close()