Skip to main content

Create consent record and signature

POST 

/service/individual/record/consent-record

This endpoint is used to create a consent record and signature object. This returns the same objects with the PK defined.

Request

Header Parameters

    X-ConsentBB-IndividualId stringrequired

    Individual ID

Body

    consentRecord objectrequired

    A consent record expresses consent (as defined in this building block's specification) to a single DataAgreement. There must be a UNIQUE constraint on (data agreement revision, individual)

    id stringrequired

    Objects may be passed back by some API endpoints without an ID (PK), denoting that they are a "draft", i.e. a ConsentRecord that is not yet stored in the database and only exist in transit. Draft ConsentRecords do not have a Revision, but if paired up with a Signature, a valid Revision should be generated.

    dataAgreementId string

    The DataAgreement to which consent has been given

    dataAgreementRevisionId string

    The Revision of the data agreement which consent has been given to

    dataAgreementRevisionHash string

    Copy of the revision hash. The hash is the included in the signature and ensures against tampering with the original agreement.

    individualId string

    The Individual who has signed this consent record

    optIn boolean

    True: The individual has positively opted in. False: The individual has explicitly said no (or withdrawn a previous consent).

    state stringrequired

    Possible values: [unsigned, signed]

    The state field is used to record state changes after-the-fact. It is maintained by the Consent BB itself. Valid states: unsigned/pending more signatures/signed

    signatureId string

    A signature that hashes all the values of the consent record and has signed it with the key of the Invidiual, making it verifiable and tamper-proof. TBD: Relation to a Signature schema?

    sectorPreferences object[]
  • Array [
  • sector stringrequired

    Name of the sector

    optIn boolean

    Defines sector is opted in or not

    isLastUpdated boolean

    Defines consent record for this sector is last updated

  • ]
  • signature objectrequired

    A generic signature contains a cryptographic hash of some value, together with a signature created by some private key in another system. Required signing methods: Revision object or another Signature object.

    id string

    Objects may be passed back by some API endpoints without an id (PK), denoting that they are a "draft", i.e. a Signature that is not yet stored in the database and only exists in transit.

    payload stringrequired

    The final payload that is signed, constructed as a JSON serialisation of fields {verificationPayload: ..., verificationPayloadHash: ..., verificationMethod: ..., verificationArtifact: ..., verificationSignedBy: ..., verificationJwsHeader, timestamp: ..., signedWithoutObjectReference: ..., objectType: ..., objectReference: ...}. Serialised as a JSON dict. If the signature is generated before anything is stored in the database (and has a PK), then the objectReference should be omitted from the payload but filled in afterwards.

    signature stringrequired

    Signature of payload hash, the format of the signature should be specified by either verificationMethod or verificationJwsHeader

    verificationMethod stringrequired

    A well-known string denoting which method is used. Valid values: TBD. This might be expanded with supported verification methods. There may be a minimal set of supported methods necessary.

    verificationPayload stringrequired

    Internally generated serialised version of the data referenced by objectType and objectReference - by extracting and serialising their data as JSON

    verificationPayloadHash stringrequired

    Internally generated cryptographic hash of the value to be signed, i.e. the value of verificationPayload

    verificationArtifact string

    A verification artifact in the form of a scanned object, image, signature etc

    verificationSignedBy stringrequired

    Because an identifier's information may change over time, there is a need to store that information at the time of signing. In the case of a cryptographic signature, this field should contain some identifier for looking up or verifying the public key of the signing party. In the case of a non-cryptographic signature, this field could contain a natural individual's names, personal number, email addresses - store a snapshot that binds to the signature at the time of signing. In the case of a cryptographic signature, this may be the fingerprint of the individual's public key or in some cases, a token from the user's ID session.

    verificationSignedAs string

    DRAFT FIELD: Specifies the relationship between the authorising signature and the invidual which the payload concerns. This is relevant for Consent Records. Possible values: "individual" / "delegate".

    verificationJwsHeader string

    Alternative to the verificationMethod, verificationHash and verificationSignature, give a JWS serialised object (RFC7515)

    timestamp stringrequired

    Timestamp of signature, currently this field isn't part of the payload so it's not tamper-proof

    signedWithoutObjectReference boolean

    Indicates that objectReference was left blank in the serialised version that was signed

    objectType string

    Possible values: [revision, signature]

    Name of the schema model that objectReference points to. Values: "signature" or "revision"

    objectReference string

    A symmetric relation / back reference to the objectType that was signed. We are currently just modelling signing another signature (a chain) or signing a Revision (which can be a revision of a consent record, an agreement, policy etc).

Responses

Response Headers
    Schema
      consentRecord object

      A consent record expresses consent (as defined in this building block's specification) to a single DataAgreement. There must be a UNIQUE constraint on (data agreement revision, individual)

      id stringrequired

      Objects may be passed back by some API endpoints without an ID (PK), denoting that they are a "draft", i.e. a ConsentRecord that is not yet stored in the database and only exist in transit. Draft ConsentRecords do not have a Revision, but if paired up with a Signature, a valid Revision should be generated.

      dataAgreementId string

      The DataAgreement to which consent has been given

      dataAgreementRevisionId string

      The Revision of the data agreement which consent has been given to

      dataAgreementRevisionHash string

      Copy of the revision hash. The hash is the included in the signature and ensures against tampering with the original agreement.

      individualId string

      The Individual who has signed this consent record

      optIn boolean

      True: The individual has positively opted in. False: The individual has explicitly said no (or withdrawn a previous consent).

      state stringrequired

      Possible values: [unsigned, signed]

      The state field is used to record state changes after-the-fact. It is maintained by the Consent BB itself. Valid states: unsigned/pending more signatures/signed

      signatureId string

      A signature that hashes all the values of the consent record and has signed it with the key of the Invidiual, making it verifiable and tamper-proof. TBD: Relation to a Signature schema?

      sectorPreferences object[]
    • Array [
    • sector stringrequired

      Name of the sector

      optIn boolean

      Defines sector is opted in or not

      isLastUpdated boolean

      Defines consent record for this sector is last updated

    • ]
    • revision object

      A generic revision model captures the serialised contents of any schema's single row. This is then subject to 1) cryptographic signature and 2) auditing.

      Aside from the "successor" column, a revision should be considered locked.

      id stringrequired

      Revision ID

      schemaName stringrequired

      Possible values: [dataAgreement, policy, dataAgreementRecord]

      Previously "schema" but for technical reasons should be called "schemaName"

      objectId stringrequired

      The PK of the object that was serialised

      objectData stringrequired

      The object that is serialised

      signedWithoutObjectId boolean

      Indicates that objectId was left blank in serizalizedSnapshot when calculating serializedHash. objectId may subsequently be filled in.

      serizalizedSnapshot stringrequired

      Revisioned data (sed as JSON) as a dict. Apply JSON Canonicalization Scheme as per IETF RFC 8785. It contains all the fields of the schema except sucessorId, serializedHash, serializedSnapshot.

      serializedHash stringrequired

      Hash of serizalizedSnapshot (SHA-1)

      timestamp stringrequired

      Timestamp of when revisioning happened. It should be ISO 8601 UTC date time

      authorizedByIndividualId string

      Individual ID

      authorizedByOtherId string

      Reference to an admin user that has created this revision

      successorId string

      If this revision is no longer the latest revision, refer to its successor

      predecessorHash string

      Tamper-resistent artifact from previous record, copied from serializedHash

      predecessorSignature string

      Tamper-resistent artifact from previous record (we don't know if the previous record was signed or not)

      signature object

      A generic signature contains a cryptographic hash of some value, together with a signature created by some private key in another system. Required signing methods: Revision object or another Signature object.

      id string

      Objects may be passed back by some API endpoints without an id (PK), denoting that they are a "draft", i.e. a Signature that is not yet stored in the database and only exists in transit.

      payload stringrequired

      The final payload that is signed, constructed as a JSON serialisation of fields {verificationPayload: ..., verificationPayloadHash: ..., verificationMethod: ..., verificationArtifact: ..., verificationSignedBy: ..., verificationJwsHeader, timestamp: ..., signedWithoutObjectReference: ..., objectType: ..., objectReference: ...}. Serialised as a JSON dict. If the signature is generated before anything is stored in the database (and has a PK), then the objectReference should be omitted from the payload but filled in afterwards.

      signature stringrequired

      Signature of payload hash, the format of the signature should be specified by either verificationMethod or verificationJwsHeader

      verificationMethod stringrequired

      A well-known string denoting which method is used. Valid values: TBD. This might be expanded with supported verification methods. There may be a minimal set of supported methods necessary.

      verificationPayload stringrequired

      Internally generated serialised version of the data referenced by objectType and objectReference - by extracting and serialising their data as JSON

      verificationPayloadHash stringrequired

      Internally generated cryptographic hash of the value to be signed, i.e. the value of verificationPayload

      verificationArtifact string

      A verification artifact in the form of a scanned object, image, signature etc

      verificationSignedBy stringrequired

      Because an identifier's information may change over time, there is a need to store that information at the time of signing. In the case of a cryptographic signature, this field should contain some identifier for looking up or verifying the public key of the signing party. In the case of a non-cryptographic signature, this field could contain a natural individual's names, personal number, email addresses - store a snapshot that binds to the signature at the time of signing. In the case of a cryptographic signature, this may be the fingerprint of the individual's public key or in some cases, a token from the user's ID session.

      verificationSignedAs string

      DRAFT FIELD: Specifies the relationship between the authorising signature and the invidual which the payload concerns. This is relevant for Consent Records. Possible values: "individual" / "delegate".

      verificationJwsHeader string

      Alternative to the verificationMethod, verificationHash and verificationSignature, give a JWS serialised object (RFC7515)

      timestamp stringrequired

      Timestamp of signature, currently this field isn't part of the payload so it's not tamper-proof

      signedWithoutObjectReference boolean

      Indicates that objectReference was left blank in the serialised version that was signed

      objectType string

      Possible values: [revision, signature]

      Name of the schema model that objectReference points to. Values: "signature" or "revision"

      objectReference string

      A symmetric relation / back reference to the objectType that was signed. We are currently just modelling signing another signature (a chain) or signing a Revision (which can be a revision of a consent record, an agreement, policy etc).

    Loading...