@sphereon/ssi-sdk.sd-jwt 0.32.1-feature.IATAB2B.52.189 → 0.32.1-feature.MWALL.715.120
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/action-handler.d.ts.map +1 -1
- package/dist/action-handler.js +34 -4
- package/dist/action-handler.js.map +1 -1
- package/dist/defaultCallbacks.d.ts +2 -2
- package/dist/defaultCallbacks.d.ts.map +1 -1
- package/dist/defaultCallbacks.js.map +1 -1
- package/dist/types.d.ts +5 -4
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/utils.d.ts +15 -2
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +29 -4
- package/dist/utils.js.map +1 -1
- package/package.json +14 -14
- package/src/__tests__/resources/BoardingPassCredential-vct.json +196 -0
- package/src/__tests__/resources/LoyaltyProgram Account VC Schema V0.1 sd-jwt-schema.json +97 -0
- package/src/__tests__/resources/LoyaltyProgramAccountCredential-vct.json +126 -0
- package/src/__tests__/resources/boarding Pass VC Schema V1.0 sd-jwt.json +156 -0
- package/src/__tests__/resources/boardingpass-logo.png +0 -0
- package/src/__tests__/resources/boardingpass.svg +1 -0
- package/src/__tests__/resources/e-passport.svg +1 -0
- package/src/__tests__/resources/ePassport VC Schema V1.0.sd-jwt.json +197 -0
- package/src/__tests__/resources/ePassportCredential-vct.json +226 -0
- package/src/__tests__/resources/epassport-logo.png +0 -0
- package/src/__tests__/resources/loyaltyprogramaccount-icon.png +0 -0
- package/src/__tests__/resources/loyaltyprogramaccount.png +0 -0
- package/src/__tests__/resources/loyaltyprogramaccount.svg +1 -0
- package/src/__tests__/resources/travel-agency VC Employee v0.1 sd-jwt-schema.json +115 -0
- package/src/__tests__/resources/travel-agency-EmployeeAgencyCredential-vct.json +146 -0
- package/src/__tests__/resources/travel-agency-vc-employee-logo.png +0 -0
- package/src/__tests__/resources/travel-agency-vc-employee.svg +1 -0
- package/src/__tests__/sd-jwt-integrity.test.ts +100 -0
- package/src/__tests__/sd-jwt.test.ts +2 -3
- package/src/action-handler.ts +48 -14
- package/src/defaultCallbacks.ts +2 -3
- package/src/types.ts +5 -4
- package/src/utils.ts +48 -4
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://json-schema.org/draft/2020-12/schema",
|
|
3
|
+
"$id": "https://schemas.prod.digitalcredentials.iata.org/epassport.json",
|
|
4
|
+
"title": "ePassport",
|
|
5
|
+
"description": "Verifiable Credential for an ePassport.",
|
|
6
|
+
"type": "object",
|
|
7
|
+
"required": ["electronicPassport", "iss", "iat", "vct", "cnf"],
|
|
8
|
+
"properties": {
|
|
9
|
+
"electronicPassport": {
|
|
10
|
+
"title": "Electronic Passport",
|
|
11
|
+
"description": "A passport that has an embedded electronic microprocessor chip, which contains biometric information that can be used to authenticate the identity of the passport holder. Also known as an e-passport, biometric passport, or a digital passport. Note filler characters are not required.",
|
|
12
|
+
"type": "object",
|
|
13
|
+
"required": ["dataGroup1", "dataGroup2EncodedFaceBiometrics", "docSecurityObject"],
|
|
14
|
+
"properties": {
|
|
15
|
+
"dataGroup1": {
|
|
16
|
+
"title": "Data Group 1",
|
|
17
|
+
"description": "Data Group 1 (DG1) of the machine readable zone (MRZ). Reference: Section 4.7.1 of Doc 9303 Machine Readable Travel Documents, Eighth Edition 2021, Part 10: Logical Data Structure (LDS) for Storage of Biometrics and Other Data in the Contactless Integrated Circuit (IC).",
|
|
18
|
+
"type": "object",
|
|
19
|
+
"required": ["birthdate", "docTypeCode", "expiryDate", "sexCode", "holdersName", "issuerCode", "natlCode", "passportNumberIdentifier"],
|
|
20
|
+
"properties": {
|
|
21
|
+
"birthdate": {
|
|
22
|
+
"title": "Data Group 1 Birthdate",
|
|
23
|
+
"description": "Date of birth of the passport holder as recorded by the issuing State or organization.",
|
|
24
|
+
"type": "string",
|
|
25
|
+
"pattern": "^[0-9<]{2}([0<][1-9<]|[1<][0-2<])([0<][1-9<]|[12<][0-9<]|[3<][01<])$"
|
|
26
|
+
},
|
|
27
|
+
"docTypeCode": {
|
|
28
|
+
"title": "Data Group 1 Document Type Code",
|
|
29
|
+
"description": "Capital letter P to designate an ePassport. One additional capital letter may be used, in the character position after the letter P and at the discretion of the issuing State or organization, to designate other types of passports such as MRP issued to diplomatic staff.",
|
|
30
|
+
"type": "string",
|
|
31
|
+
"pattern": "^P.$"
|
|
32
|
+
},
|
|
33
|
+
"expiryDate": {
|
|
34
|
+
"title": "Data Group 1 Expiry Date",
|
|
35
|
+
"description": "Date of expiry of the ePassport.",
|
|
36
|
+
"type": "string",
|
|
37
|
+
"pattern": "^[0-9]{2}([0][1-9]|[1][0-2])([0][1-9]|[12][0-9]|[3][01])$"
|
|
38
|
+
},
|
|
39
|
+
"sexCode": {
|
|
40
|
+
"title": "Sex Code",
|
|
41
|
+
"description": "Sex of the passport holder; typically, F for Female, M for Male or < for non-specified.",
|
|
42
|
+
"type": "string",
|
|
43
|
+
"enum": ["F", "M", "<"]
|
|
44
|
+
},
|
|
45
|
+
"holdersName": {
|
|
46
|
+
"title": "Data Group 1 Holders Name",
|
|
47
|
+
"description": "Full name of the holder, as identified by the issuing State or organization.",
|
|
48
|
+
"type": "string",
|
|
49
|
+
"minLength": 1,
|
|
50
|
+
"maxLength": 39
|
|
51
|
+
},
|
|
52
|
+
"issuerCode": {
|
|
53
|
+
"title": "Data Group 1 Issuer Code",
|
|
54
|
+
"description": "Code of the State or Organization responsible for the issuance of the ePassport.",
|
|
55
|
+
"type": "string",
|
|
56
|
+
"maxLength": 13
|
|
57
|
+
},
|
|
58
|
+
"natlCode": {
|
|
59
|
+
"title": "Data Group 1 Nationality Text",
|
|
60
|
+
"description": "The code for the nationality of the holder of the ePassport.",
|
|
61
|
+
"type": "string",
|
|
62
|
+
"minLength": 3,
|
|
63
|
+
"maxLength": 3
|
|
64
|
+
},
|
|
65
|
+
"passportNumberIdentifier": {
|
|
66
|
+
"title": "Data Group 1 Passport Number Identifier",
|
|
67
|
+
"description": "As given by the issuing State or organization to uniquely identify the document from all other MRTDs issued by the State or organization.",
|
|
68
|
+
"type": "string",
|
|
69
|
+
"maxLength": 9
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
"dataGroup15": {
|
|
74
|
+
"title": "Data Group 15",
|
|
75
|
+
"description": "Data group 15 defined by ICAO for ePassport. Reference: Section 4.7.15.1 of Doc 9303 Machine Readable Travel Documents, Eighth Edition 2021, Part 10: Logical Data Structure (LDS) for Storage of Biometrics and Other Data in the Contactless Integrated Circuit (IC).",
|
|
76
|
+
"type": "object",
|
|
77
|
+
"required": ["activeAuthentication"],
|
|
78
|
+
"properties": {
|
|
79
|
+
"activeAuthentication": {
|
|
80
|
+
"title": "Active Authentication",
|
|
81
|
+
"description": "Active Authentication authenticates the contactless IC by signing a challenge sent by the IFD (inspection system) with a private key known only to the IC. For this purpose the contactless IC contains its own Active Authentication Key pair (KPrAA and KPuAA). A hash representation of Data Group 15 (Public Key (KPuAA) info) is stored in the Document Security Object (SOD) and therefore authenticated by the issuer's digital signature. The corresponding Private Key (KPrAA) is stored in the contactless IC's secure memory. By authenticating the visual MRZ (through the hashed MRZ in the Document Security Object (SOD)) in combination with the challenge response, using the eMRTD's Active Authentication Key Pair (KPrAA and KPuAA), the inspection system verifies that the Document Security Object (SOD) has been read from the genuine contactless IC stored in the genuine eMRTD.",
|
|
82
|
+
"type": "object",
|
|
83
|
+
"required": ["publicKeyBinaryObject"],
|
|
84
|
+
"properties": {
|
|
85
|
+
"publicKeyBinaryObject": {
|
|
86
|
+
"title": "Active Authentication Public Key Binary Object",
|
|
87
|
+
"description": "Public key for use in active authentication. Example uri format data:application/octet-stream;base64,...",
|
|
88
|
+
"type": "string",
|
|
89
|
+
"format": "uri"
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
},
|
|
95
|
+
"dataGroup2EncodedFaceBiometrics": {
|
|
96
|
+
"title": "Data Group 2 Encoded Face Biometrics",
|
|
97
|
+
"description": "First, most recent, face biometric image from data group 2. Reference: Section 4.7.2 of Doc 9303 Machine Readable Travel Documents, Eighth Edition 2021, Part 10: Logical Data Structure (LDS) for Storage of Biometrics and Other Data in the Contactless Integrated Circuit (IC).",
|
|
98
|
+
"type": "object",
|
|
99
|
+
"required": ["faceBiometricDataEncodedPicture"],
|
|
100
|
+
"properties": {
|
|
101
|
+
"faceBiometricDataEncodedPicture": {
|
|
102
|
+
"title": "Data Group 2 Encoded Face Biometrics Face Biometric Data Encoded Picture",
|
|
103
|
+
"description": "First, most recent, face biometric image from data group 2. Example uri, data:image/jpeg;base64,...",
|
|
104
|
+
"type": "string",
|
|
105
|
+
"format": "uri"
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
"digitalTravelCredential": {
|
|
110
|
+
"title": "Digital Travel Credential",
|
|
111
|
+
"description": "Travel credentials in a digital format that are meant to temporarily or permanently substitute a conventional passport by a digital representation of the traveler's identity. Reference: Section 2.1.3 of Machine Readable Travel Documents, Digital Travel Credentials (DTC), Virtual Component Data Structure and PKI Mechanisms, Technical Report, Version 1.2 October 2020.",
|
|
112
|
+
"type": "object",
|
|
113
|
+
"required": ["dTCContentInfo"],
|
|
114
|
+
"properties": {
|
|
115
|
+
"dTCContentInfo": {
|
|
116
|
+
"title": "DTC-VC as DTCContentInfo encoded Structure",
|
|
117
|
+
"description": "DER encoded DTC-VC. Example uri format data:application/octet-stream;base64,...",
|
|
118
|
+
"type": "string",
|
|
119
|
+
"format": "uri"
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
"docSecurityObject": {
|
|
124
|
+
"title": "Document Security Object",
|
|
125
|
+
"description": "Document Security Object which contains the hashing information including hashed ePassport data. Reference: Section 4.6.2 of Doc 9303 Machine Readable Travel Documents, Eighth Edition 2021, Part 10: Logical Data Structure (LDS) for Storage of Biometrics and Other Data in the Contactless Integrated Circuit (IC).",
|
|
126
|
+
"type": "object",
|
|
127
|
+
"required": ["dataGroupHash", "digestHashAlgorithmIdentifier", "versionNumber"],
|
|
128
|
+
"properties": {
|
|
129
|
+
"digestHashAlgorithmIdentifier": {
|
|
130
|
+
"title": "Document Security Object Digest Hash Algorithm Identifier",
|
|
131
|
+
"description": "Digest Algorithm Identifier used to perform hashing on the data groups.",
|
|
132
|
+
"type": "string",
|
|
133
|
+
"maxLength": 35
|
|
134
|
+
},
|
|
135
|
+
"versionNumber": {
|
|
136
|
+
"title": "Document Security Object Version Number",
|
|
137
|
+
"description": "Security object version.",
|
|
138
|
+
"type": "number"
|
|
139
|
+
},
|
|
140
|
+
"dataGroupHash": {
|
|
141
|
+
"title": "Data Group Hash",
|
|
142
|
+
"description": "Data group with corresponding hash value.",
|
|
143
|
+
"type": "array",
|
|
144
|
+
"items": {
|
|
145
|
+
"type": "object",
|
|
146
|
+
"title": "Data Group Hash",
|
|
147
|
+
"description": "Data group with corresponding hash value.",
|
|
148
|
+
"required": ["dataGroupNumber", "valueBinaryObject"],
|
|
149
|
+
"properties": {
|
|
150
|
+
"dataGroupNumber": {
|
|
151
|
+
"title": "Data Group Hash Data Group Number",
|
|
152
|
+
"description": "Data group number.",
|
|
153
|
+
"type": "integer",
|
|
154
|
+
"minimum": 1,
|
|
155
|
+
"maximum": 16
|
|
156
|
+
},
|
|
157
|
+
"valueBinaryObject": {
|
|
158
|
+
"title": "Data Group Hash Value Binary Object",
|
|
159
|
+
"description": "Hash value for the corresponding data group. Example uri format data:application/octet-stream;base64,...",
|
|
160
|
+
"type": "string",
|
|
161
|
+
"format": "uri"
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
},
|
|
170
|
+
"iss": {
|
|
171
|
+
"title": "Issuer",
|
|
172
|
+
"description": "URI identifying the issuer of the credential.",
|
|
173
|
+
"type": "string",
|
|
174
|
+
"format": "uri"
|
|
175
|
+
},
|
|
176
|
+
"iat": {
|
|
177
|
+
"title": "Issued At",
|
|
178
|
+
"description": "The time at which the credential was issued (Unix timestamp).",
|
|
179
|
+
"type": "integer"
|
|
180
|
+
},
|
|
181
|
+
"exp": {
|
|
182
|
+
"title": "Expiration",
|
|
183
|
+
"description": "The time at which the credential expires (Unix timestamp).",
|
|
184
|
+
"type": "integer"
|
|
185
|
+
},
|
|
186
|
+
"vct": {
|
|
187
|
+
"title": "Verifiable Credential Type",
|
|
188
|
+
"description": "A URI or string identifying the type or context of this credential.",
|
|
189
|
+
"type": "string"
|
|
190
|
+
},
|
|
191
|
+
"cnf": {
|
|
192
|
+
"title": "Confirmation",
|
|
193
|
+
"description": "Proof-of-possession key information used to bind the credential to a specific holder.",
|
|
194
|
+
"type": "object"
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "ePassport Verifiable Credential",
|
|
3
|
+
"schema_uri": "https://iata.trustregistry.nborbit.ca/.well-known/schema/epassport.json",
|
|
4
|
+
"schema_uri#integrity": "sha256-MvSlwJxOreBIWTotPQlcOSzsd9gNSiGMltshUKL8TFI",
|
|
5
|
+
"vct": "https://iata.trustregistry.nborbit.ca/.well-known/vct/epassport.json",
|
|
6
|
+
"description": "A Verifiable Credential for an ePassport.",
|
|
7
|
+
"display": [
|
|
8
|
+
{
|
|
9
|
+
"description": "A Verifiable Credential for an ePassport.",
|
|
10
|
+
"lang": "en-US",
|
|
11
|
+
"name": "ePassport Verifiable Credential",
|
|
12
|
+
"rendering": {
|
|
13
|
+
"simple": {
|
|
14
|
+
"background_color": "#CB2210",
|
|
15
|
+
"logo": {
|
|
16
|
+
"alt_text": "ePassport Verifiable Credential Logo",
|
|
17
|
+
"uri": "https://iata.trustregistry.nborbit.ca/logo/epassport-logo.png",
|
|
18
|
+
"uri#integrity": "sha256-SSp0p9SBIotc7FIi/pkqbMthx4Gmx+g+IXnMdOOQXl4"
|
|
19
|
+
},
|
|
20
|
+
"text_color": "#F9F9F9"
|
|
21
|
+
},
|
|
22
|
+
"svg_template": {
|
|
23
|
+
"properties": {
|
|
24
|
+
"color_scheme": "light",
|
|
25
|
+
"contrast": "high",
|
|
26
|
+
"orientation": "landscape"
|
|
27
|
+
},
|
|
28
|
+
"uri": "https://iata.trustregistry.nborbit.ca/svg/epassport.svg",
|
|
29
|
+
"uri#integrity": "sha256-+2b8yT2jzbRuoHh5KnI6RzorWNTN/eL67ZvEV+abEfA"
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
],
|
|
34
|
+
"claims": [
|
|
35
|
+
{
|
|
36
|
+
"display": [
|
|
37
|
+
{
|
|
38
|
+
"description": "Information about the electronic passport.",
|
|
39
|
+
"label": "Electronic Passport",
|
|
40
|
+
"lang": "en-US"
|
|
41
|
+
}
|
|
42
|
+
],
|
|
43
|
+
"path": ["electronicPassport"]
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
"display": [
|
|
47
|
+
{
|
|
48
|
+
"description": "Data Group 1 of the electronic passport.",
|
|
49
|
+
"label": "Data Group 1",
|
|
50
|
+
"lang": "en-US"
|
|
51
|
+
}
|
|
52
|
+
],
|
|
53
|
+
"path": ["electronicPassport", "dataGroup1"]
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
"display": [
|
|
57
|
+
{
|
|
58
|
+
"description": "Date of birth of the passport holder.",
|
|
59
|
+
"label": "Birthdate",
|
|
60
|
+
"lang": "en-US"
|
|
61
|
+
}
|
|
62
|
+
],
|
|
63
|
+
"path": ["electronicPassport", "dataGroup1", "birthdate"]
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
"display": [
|
|
67
|
+
{
|
|
68
|
+
"description": "Document type code, such as 'P' for an ePassport.",
|
|
69
|
+
"label": "Document Type Code",
|
|
70
|
+
"lang": "en-US"
|
|
71
|
+
}
|
|
72
|
+
],
|
|
73
|
+
"path": ["electronicPassport", "dataGroup1", "docTypeCode"]
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
"display": [
|
|
77
|
+
{
|
|
78
|
+
"description": "Expiry date of the ePassport.",
|
|
79
|
+
"label": "Expiry Date",
|
|
80
|
+
"lang": "en-US"
|
|
81
|
+
}
|
|
82
|
+
],
|
|
83
|
+
"path": ["electronicPassport", "dataGroup1", "expiryDate"]
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
"display": [
|
|
87
|
+
{
|
|
88
|
+
"description": "Sex of the passport holder.",
|
|
89
|
+
"label": "Sex Code",
|
|
90
|
+
"lang": "en-US"
|
|
91
|
+
}
|
|
92
|
+
],
|
|
93
|
+
"path": ["electronicPassport", "dataGroup1", "sexCode"]
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
"display": [
|
|
97
|
+
{
|
|
98
|
+
"description": "Full name of the passport holder.",
|
|
99
|
+
"label": "Holder's Name",
|
|
100
|
+
"lang": "en-US"
|
|
101
|
+
}
|
|
102
|
+
],
|
|
103
|
+
"path": ["electronicPassport", "dataGroup1", "holdersName"]
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
"display": [
|
|
107
|
+
{
|
|
108
|
+
"description": "Issuer code of the ePassport.",
|
|
109
|
+
"label": "Issuer Code",
|
|
110
|
+
"lang": "en-US"
|
|
111
|
+
}
|
|
112
|
+
],
|
|
113
|
+
"path": ["electronicPassport", "dataGroup1", "issuerCode"]
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
"display": [
|
|
117
|
+
{
|
|
118
|
+
"description": "Nationality code of the passport holder.",
|
|
119
|
+
"label": "Nationality Code",
|
|
120
|
+
"lang": "en-US"
|
|
121
|
+
}
|
|
122
|
+
],
|
|
123
|
+
"path": ["electronicPassport", "dataGroup1", "natlCode"]
|
|
124
|
+
},
|
|
125
|
+
{
|
|
126
|
+
"display": [
|
|
127
|
+
{
|
|
128
|
+
"description": "Unique identifier for the passport.",
|
|
129
|
+
"label": "Passport Number",
|
|
130
|
+
"lang": "en-US"
|
|
131
|
+
}
|
|
132
|
+
],
|
|
133
|
+
"path": ["electronicPassport", "dataGroup1", "passportNumberIdentifier"]
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
"display": [
|
|
137
|
+
{
|
|
138
|
+
"description": "Encoded face biometric data from Data Group 2.",
|
|
139
|
+
"label": "Encoded Face Biometrics",
|
|
140
|
+
"lang": "en-US"
|
|
141
|
+
}
|
|
142
|
+
],
|
|
143
|
+
"path": ["electronicPassport", "dataGroup2EncodedFaceBiometrics", "faceBiometricDataEncodedPicture"]
|
|
144
|
+
},
|
|
145
|
+
{
|
|
146
|
+
"display": [
|
|
147
|
+
{
|
|
148
|
+
"description": "Data group 15 containing the public key for active authentication.",
|
|
149
|
+
"label": "Data Group 15",
|
|
150
|
+
"lang": "en-US"
|
|
151
|
+
}
|
|
152
|
+
],
|
|
153
|
+
"path": ["electronicPassport", "dataGroup15"]
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
"display": [
|
|
157
|
+
{
|
|
158
|
+
"description": "Public key for active authentication.",
|
|
159
|
+
"label": "Active Authentication Public Key",
|
|
160
|
+
"lang": "en-US"
|
|
161
|
+
}
|
|
162
|
+
],
|
|
163
|
+
"path": ["electronicPassport", "dataGroup15", "activeAuthentication", "publicKeyBinaryObject"]
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
"display": [
|
|
167
|
+
{
|
|
168
|
+
"description": "Document security object containing hashing information.",
|
|
169
|
+
"label": "Document Security Object",
|
|
170
|
+
"lang": "en-US"
|
|
171
|
+
}
|
|
172
|
+
],
|
|
173
|
+
"path": ["electronicPassport", "docSecurityObject"]
|
|
174
|
+
},
|
|
175
|
+
{
|
|
176
|
+
"display": [
|
|
177
|
+
{
|
|
178
|
+
"description": "Digest hash algorithm used for the document security object.",
|
|
179
|
+
"label": "Digest Hash Algorithm",
|
|
180
|
+
"lang": "en-US"
|
|
181
|
+
}
|
|
182
|
+
],
|
|
183
|
+
"path": ["electronicPassport", "docSecurityObject", "digestHashAlgorithmIdentifier"]
|
|
184
|
+
},
|
|
185
|
+
{
|
|
186
|
+
"display": [
|
|
187
|
+
{
|
|
188
|
+
"description": "Version number of the document security object.",
|
|
189
|
+
"label": "Version Number",
|
|
190
|
+
"lang": "en-US"
|
|
191
|
+
}
|
|
192
|
+
],
|
|
193
|
+
"path": ["electronicPassport", "docSecurityObject", "versionNumber"]
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
"display": [
|
|
197
|
+
{
|
|
198
|
+
"description": "Data group hash values within the document security object.",
|
|
199
|
+
"label": "Data Group Hash",
|
|
200
|
+
"lang": "en-US"
|
|
201
|
+
}
|
|
202
|
+
],
|
|
203
|
+
"path": ["electronicPassport", "docSecurityObject", "dataGroupHash", null]
|
|
204
|
+
},
|
|
205
|
+
{
|
|
206
|
+
"display": [
|
|
207
|
+
{
|
|
208
|
+
"description": "Data group number for the hash.",
|
|
209
|
+
"label": "Data Group Number",
|
|
210
|
+
"lang": "en-US"
|
|
211
|
+
}
|
|
212
|
+
],
|
|
213
|
+
"path": ["electronicPassport", "docSecurityObject", "dataGroupHash", null, "dataGroupNumber"]
|
|
214
|
+
},
|
|
215
|
+
{
|
|
216
|
+
"display": [
|
|
217
|
+
{
|
|
218
|
+
"description": "Hash value for the data group.",
|
|
219
|
+
"label": "Hash Value",
|
|
220
|
+
"lang": "en-US"
|
|
221
|
+
}
|
|
222
|
+
],
|
|
223
|
+
"path": ["electronicPassport", "docSecurityObject", "dataGroupHash", null, "valueBinaryObject"]
|
|
224
|
+
}
|
|
225
|
+
]
|
|
226
|
+
}
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg width="2058" height="1173" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" overflow="hidden"><defs><image width="600" height="573" xlink:href="" preserveAspectRatio="none" id="img0"></image><clipPath id="clip1"><rect x="0" y="0" width="559724" height="534536"/></clipPath></defs><g transform="translate(-430 -944)"><g><path d="M436.5 1003.59C436.5 972.61 461.611 947.5 492.586 947.5L2426.41 947.5C2457.39 947.5 2482.5 972.61 2482.5 1003.59L2482.5 2058.41C2482.5 2089.39 2457.39 2114.5 2426.41 2114.5L492.586 2114.5C461.611 2114.5 436.5 2089.39 436.5 2058.41Z" stroke="#060F6A" stroke-width="4.58333" stroke-linecap="butt" stroke-linejoin="miter" stroke-miterlimit="8" stroke-opacity="1" fill="#9C4FE9" fill-rule="evenodd" fill-opacity="1"/><text fill="#FFFFFF" fill-opacity="1" font-family="61,61_MSFontService,sans-serif" font-style="normal" font-variant="normal" font-weight="400" font-stretch="normal" font-size="165" text-anchor="start" direction="ltr" writing-mode="lr-tb" unicode-bidi="normal" text-decoration="none" transform="matrix(1 0 0 1 1130.03 1165)">Loyalty program</text><g transform="matrix(0.000360892 0 0 0.000360892 526 1028)"><g clip-path="url(#clip1)" transform="matrix(1 0 0 1.00047 -0.0690252 -0.0260121)"><use width="100%" height="100%" xlink:href="#img0" opacity="1" transform="scale(932.873 932.873)"></use></g></g></g></g></svg>
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://json-schema.org/draft/2020-12/schema",
|
|
3
|
+
"$id": "EmployeeAgencyCredential",
|
|
4
|
+
"title": "Employee Agency Verifiable Credential",
|
|
5
|
+
"description": "A Verifiable Credential for employees working at a travel agency.",
|
|
6
|
+
"type": "object",
|
|
7
|
+
"required": ["employee", "iss", "iat", "vct", "cnf"],
|
|
8
|
+
"properties": {
|
|
9
|
+
"employee": {
|
|
10
|
+
"title": "Employee",
|
|
11
|
+
"description": "An individual employed by a travel agency.",
|
|
12
|
+
"type": "object",
|
|
13
|
+
"required": ["salutation", "givenName", "surname", "phoneNumber", "employeeID", "email", "jobTitle"],
|
|
14
|
+
"properties": {
|
|
15
|
+
"salutation": {
|
|
16
|
+
"title": "Credential Subject Salutation",
|
|
17
|
+
"description": "Honorific or title prefix (e.g., Mr., Mrs., Ms.).",
|
|
18
|
+
"type": "string",
|
|
19
|
+
"minLength": 1,
|
|
20
|
+
"maxLength": 10
|
|
21
|
+
},
|
|
22
|
+
"givenName": {
|
|
23
|
+
"title": "Credential Subject Given Name",
|
|
24
|
+
"type": "string",
|
|
25
|
+
"minLength": 1,
|
|
26
|
+
"maxLength": 64
|
|
27
|
+
},
|
|
28
|
+
"surname": {
|
|
29
|
+
"title": "Credential Subject Surname",
|
|
30
|
+
"type": "string",
|
|
31
|
+
"minLength": 1,
|
|
32
|
+
"maxLength": 64
|
|
33
|
+
},
|
|
34
|
+
"phoneNumber": {
|
|
35
|
+
"title": "Credential Subject Phone Number",
|
|
36
|
+
"description": "Employee's phone number, separated into country code and local number.",
|
|
37
|
+
"type": "object",
|
|
38
|
+
"required": ["countryCode", "localNumber"],
|
|
39
|
+
"properties": {
|
|
40
|
+
"countryCode": {
|
|
41
|
+
"title": "Country Code",
|
|
42
|
+
"description": "Phone number country code in E.164 format (e.g., +1, +44).",
|
|
43
|
+
"type": "string",
|
|
44
|
+
"minLength": 2,
|
|
45
|
+
"maxLength": 4
|
|
46
|
+
},
|
|
47
|
+
"localNumber": {
|
|
48
|
+
"title": "Local Number",
|
|
49
|
+
"description": "The local portion of the phone number (area code + number).",
|
|
50
|
+
"type": "string",
|
|
51
|
+
"minLength": 6,
|
|
52
|
+
"maxLength": 20
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
"employeeID": {
|
|
57
|
+
"title": "Credential Subject Employee ID",
|
|
58
|
+
"description": "Unique identifier for the employee within the organization.",
|
|
59
|
+
"type": "string",
|
|
60
|
+
"maxLength": 35
|
|
61
|
+
},
|
|
62
|
+
"email": {
|
|
63
|
+
"title": "Credential Subject Email",
|
|
64
|
+
"type": "string",
|
|
65
|
+
"format": "email",
|
|
66
|
+
"maxLength": 254
|
|
67
|
+
},
|
|
68
|
+
"jobTitle": {
|
|
69
|
+
"title": "Credential Subject Job Title",
|
|
70
|
+
"description": "Official title or role of the employee within the travel agency.",
|
|
71
|
+
"type": "string",
|
|
72
|
+
"minLength": 2,
|
|
73
|
+
"maxLength": 88
|
|
74
|
+
},
|
|
75
|
+
"pcc": {
|
|
76
|
+
"title": "Credential Subject PCC Codes",
|
|
77
|
+
"description": "An array of Pseudo City Codes (PCCs) associated with the employee.",
|
|
78
|
+
"type": "array",
|
|
79
|
+
"items": {
|
|
80
|
+
"type": "string",
|
|
81
|
+
"description": "Pseudo City Code for a branch or agency."
|
|
82
|
+
},
|
|
83
|
+
"minItems": 0,
|
|
84
|
+
"uniqueItems": true
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
"iss": {
|
|
89
|
+
"title": "Issuer",
|
|
90
|
+
"description": "URI identifying the issuer of the credential.",
|
|
91
|
+
"type": "string",
|
|
92
|
+
"format": "uri"
|
|
93
|
+
},
|
|
94
|
+
"iat": {
|
|
95
|
+
"title": "Issued At",
|
|
96
|
+
"description": "The time at which the credential was issued (Unix timestamp).",
|
|
97
|
+
"type": "integer"
|
|
98
|
+
},
|
|
99
|
+
"exp": {
|
|
100
|
+
"title": "Expiration",
|
|
101
|
+
"description": "The time at which the credential expires (Unix timestamp).",
|
|
102
|
+
"type": "integer"
|
|
103
|
+
},
|
|
104
|
+
"vct": {
|
|
105
|
+
"title": "Verifiable Credential Type",
|
|
106
|
+
"description": "A URI or string identifying the type or context of this credential.",
|
|
107
|
+
"type": "string"
|
|
108
|
+
},
|
|
109
|
+
"cnf": {
|
|
110
|
+
"title": "Confirmation",
|
|
111
|
+
"description": "Proof-of-possession key information used to bind the credential to a specific holder.",
|
|
112
|
+
"type": "object"
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|