-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathClient.swift
More file actions
77 lines (65 loc) · 2.13 KB
/
Client.swift
File metadata and controls
77 lines (65 loc) · 2.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*
* Copyright (c) 2023 European Commission
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import Foundation
import JOSESwift
public enum Client {
/// Represents a Public client
case `public`(id: ClientId)
/// Represents an Attested client
case attested(attestationJWT: ClientAttestationJWT, popJwtSpec: ClientAttestationPoPJWTSpec)
// Computed property for 'id' (common property for both cases)
public var id: ClientId {
switch self {
case .public(let id):
return id
case .attested(let attestationJWT, _):
return attestationJWT.clientId
}
}
// MARK: - Validation
public init(public id: ClientId) {
self = .public(id: id)
}
public init(attestationJWT: ClientAttestationJWT, popJwtSpec: ClientAttestationPoPJWTSpec) throws {
// Validate clientId
let clientId = attestationJWT.clientId
guard !clientId.isEmpty && !clientId.trimmingCharacters(in: .whitespaces).isEmpty else {
throw ClientAttestationError.invalidClientId
}
// Validate public key
guard (attestationJWT.pubKey?.isPublicKey ?? false) else {
throw ClientAttestationError.missingJwkClaim
}
self = .attested(attestationJWT: attestationJWT, popJwtSpec: popJwtSpec)
}
}
extension JWK {
/// Determines if the JWK is a private key
var isPrivateKey: Bool {
switch self {
case let rsaKey as RSAPrivateKey:
return !rsaKey.privateExponent.isEmpty
case let ecKey as ECPrivateKey:
return !ecKey.privateKey.isEmpty
default:
return false
}
}
/// Determines if the JWK is a public key
var isPublicKey: Bool {
return !isPrivateKey
}
}