Skip to content

Commit

Permalink
Add app attestation and assertion api documentation.
Browse files Browse the repository at this point in the history
This adds attestation and assertion documentation. Attestation is the verifying
an app is a valid instance of an iOS app and assertion is requesting a secret
of some kind after attestation is verified, in this case X.509 certificates
that can be used for client authentication.

Add response to successful assertion.
  • Loading branch information
Jimmy Phan authored and lostlevels committed Jul 24, 2023
1 parent 0dcc826 commit fae9ab7
Show file tree
Hide file tree
Showing 11 changed files with 302 additions and 2,484 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
.dccache
.idea/
.DS_Store
114 changes: 114 additions & 0 deletions reference/auth.v1.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,10 @@ tags:
description: >-
List and manage users.
- name: Attestation
description: >-
Attest and assert an app is a valid instance of an iOS app.
paths:
'/auth/login':
post:
Expand Down Expand Up @@ -698,6 +702,98 @@ paths:
security:
- serverToken: []

'/v1/attestations/challenges':
post:
operationId: CreateAttestationChallenge
summary: Create an attestation challenge.
description: >-
Starts the attestation flow by requesting an attestation challenge that the client will later use in an Apple API call and to verify an attestation.
requestBody:
content:
'application/json':
schema:
$ref: './auth/models/newappchallenge.v1.yaml'
responses:
'201':
$ref: '#/components/responses/AppChallenge'
'400':
$ref: './common/responses/badrequest.v1.yaml'
'401':
$ref: './common/responses/unauthorized.v1.yaml'
'403':
$ref: './common/responses/forbidden.v1.yaml'
tags:
- Attestation

'/v1/attestations/verifications':
post:
operationId: VerifyAttestation
summary: Verify an attestation.
description: >-
This confirms the app is a valid instance of an iOS app. It must use the previously generated challenge.
requestBody:
content:
'application/json':
schema:
$ref: './auth/models/attestationverify.v1.yaml'
responses:
'204':
description: The attestation was verified successfully.
'400':
$ref: './common/responses/badrequest.v1.yaml'
'401':
$ref: './common/responses/unauthorized.v1.yaml'
'403':
$ref: './common/responses/forbidden.v1.yaml'
tags:
- Attestation

'/v1/assertions/challenges':
post:
operationId: CreateAssertionChallenge
summary: Create an assertion challenge.
description: >-
Requests an assertion challenge be generated. This can only happen after attestation has been verified.
requestBody:
content:
'application/json':
schema:
$ref: './auth/models/newappchallenge.v1.yaml'
responses:
'201':
$ref: '#/components/responses/AppChallenge'
'400':
$ref: './common/responses/badrequest.v1.yaml'
'401':
$ref: './common/responses/unauthorized.v1.yaml'
'403':
$ref: './common/responses/forbidden.v1.yaml'
tags:
- Attestation

'/v1/assertions/verifications':
post:
operationId: VerifyAssertion
summary: Verify an assertion.
description: >-
This verifies an assertion and returns X.509 certficates.
requestBody:
content:
'application/json':
schema:
$ref: './auth/models/assertionverify.v1.yaml'
responses:
'200':
$ref: '#/components/responses/Assertion'
'400':
$ref: './common/responses/badrequest.v1.yaml'
'401':
$ref: './common/responses/unauthorized.v1.yaml'
'403':
$ref: './common/responses/forbidden.v1.yaml'
tags:
- Attestation

components:
securitySchemes:
basicAuth:
Expand Down Expand Up @@ -977,3 +1073,21 @@ components:
required:
- code
- reason
AppChallenge:
description: 'Challenge generated by server and which client should use in later operations.'
headers:
'X-Tidepool-Session-Token':
$ref: './common/headers/tidepoolsessiontoken.v1.yaml'
content:
'application/json':
schema:
$ref: './auth/models/appchallenge.v1.yaml'
Assertion:
description: 'Certificates returned upon successful assertion.'
headers:
'X-Tidepool-Session-Token':
$ref: './common/headers/tidepoolsessiontoken.v1.yaml'
content:
'application/json':
schema:
$ref: './auth/models/assertionsecret.v1.yaml'
7 changes: 7 additions & 0 deletions reference/auth/models/appchallenge.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
title: Challenge
description: Challenge generated by server.
type: object
properties:
challenge:
type: string
minLength: 1
20 changes: 20 additions & 0 deletions reference/auth/models/assertionsecret.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
title: AssertionSecret
description: Data sent back upon successful app assertion. This will include X.509 certificates.
type: object
properties:
certificates:
description: X.509 certificates to be used for client authentication.
type: array
items:
type: object
properties:
content:
type: string
description: base64 encoded X.509 certificate in DER format.
ttlInDays:
type: integer
type:
type: string
oneOf:
- CONSTRAINED
- WILDCARD
30 changes: 30 additions & 0 deletions reference/auth/models/assertionverify.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
title: Assertion Verify
description: Request body for verifying an assertion.
type: object
properties:
assertion:
$ref: '../../common/models/base64.v1.yaml'
description: Base64 encoded data received from Apple App Attest API. User must base64 encode the binary data received from Apple.
clientData:
type: object
properties:
challenge:
type: string
minLength: 1
partner:
description: Code name of partner to retrieve certificate from.
type: string
minLength: 1
enum:
- Coastal
partnerData:
description: Actual data to send to partner API.
$ref: './coastaldata.v1.yaml'
description: Actual data requested by client. Must include the previously requested challenge.
keyId:
$ref: './keyid.v1.yaml'
description: Base64 encoded key Id received from Apple App Attest API.
required:
- attestation
- clientData
- keyId
18 changes: 18 additions & 0 deletions reference/auth/models/attestationverify.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
title: Attestation Verify
description: Request body for verifying an attestation.
type: object
properties:
attestation:
$ref: '../../common/models/base64.v1.yaml'
description: Base64 encoded data received from Apple App Attest API. User must base64 encode the binary data received from Apple.
challenge:
type: string
minLength: 1
description: Challenge string returned from the Tidepool platform API.
keyId:
$ref: './keyid.v1.yaml'
description: Base64 encoded key Id received from Apple App Attest API.
required:
- attestation
- challenge
- keyId
24 changes: 24 additions & 0 deletions reference/auth/models/coastaldata.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
title: CoastalData
description: Data to send to Coastal's API.
type: object
properties:
rcTypeId:
type: string
rcInstanceId:
type: string
rcHWVersions:
type: array
items:
type: string
rcSWVersions:
type: array
items:
type: string
phdTypeId:
type: string
phdInstanceId:
type: string
csr:
type: string
rcbMac:
type: string
3 changes: 3 additions & 0 deletions reference/auth/models/keyid.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
title: Key Id
description: Base64 encoded key identifier received from apple. The Key Id is some shortened data, usually a hash, used to identify the longer actual key.
$ref: '../../common/models/base64.v1.yaml'
9 changes: 9 additions & 0 deletions reference/auth/models/newappchallenge.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
title: New App Challenge
description: Information needed when generating an attestation or assertion challenge.
type: object
properties:
keyId:
$ref: '../../common/models/base64.v1.yaml'
description: Base64 encoded key Id received from Apple App Attest API.
required:
- keyId
4 changes: 4 additions & 0 deletions reference/common/models/base64.v1.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
title: Base64
type: string
description: Base64 encoded data.
pattern: '^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$'
Loading

0 comments on commit fae9ab7

Please sign in to comment.