From f7e6761609ae76998839396adfbf5c801038bbdf Mon Sep 17 00:00:00 2001 From: Britta Stallknecht <146106656+britsta@users.noreply.github.com> Date: Tue, 5 Mar 2024 14:38:38 +0100 Subject: [PATCH] Feature/add create own identity attribute description (#164) * feat: create own identityattribute init (cherry picked from commit 2a36b68539878c197824bda90ed3008cf8859fea) * feat: create own identityattribute (cherry picked from commit f820de93668c61b3f42c97fa8e675aefc5ec2ec6) * feat: create own identityattribute (cherry picked from commit 188fb6d8c02ff312a5050104935912911b3b05ee) * feat: create own identityattribute (cherry picked from commit 6b294bf564ba78055a1f7e0c15448f7f76ded11b) * fix: adjust size of diagramm (cherry picked from commit 7fa0ed94f0fe6cdada8733c0fcfdc76021e56479) * fix: adjust size of diagramm (cherry picked from commit 486d542ecde1196c42fe7e5f6639911e6f07b205) * fix: remove dependent link temporarly * fix: remove api excerpt on create attribute page (cherry picked from commit 5686ce648d44c25d10224dd598e2b765b0d58cec) * fix: make text more readable, embed new diagram * fix: change terminology for requests, add usecases * fix: replace http request payloads with tables * fix: simplifying property notation * fix: synchronize table with other documentations * fix: remove comments on RelationshipAttributes * fix: synchronize tables with other documentations * fix: remove comments * refactor: incorporate some review comments * refactor: replace example tables with JSON payloads * feat: replace input table with JSON payload * feat: remove table of success response * feat: adjust scenario because "Create an Attribute" use case will change * refactor: add whitespaces in JSON comments * refactor: renaming use cases * refactor: renaming of scenario * refactor: use new nomenclature for Attributes part 1 * refactor: use new nomenclature for Attributes part 2 * refactor: use new nomenclatur for Attributes part 3 * feat: add "Create RelationshipAttribute for yourself" part * feat: add structure for "Create a RelationshipAttribute for yourself" section * feat: add RelationshipAttribute creation with Read/Create/ProposeAttributeRequestItem * feat: add RelationshipAttribute creation with ShareAttributeRequestItem * feat: incorporate review comments * feat: mention consumption.attributeCreated event * feat: incorporate review comments --------- Co-authored-by: Vinzent Lange --- _data/navigation.yml | 2 + ...te.md => create-attribute-for-yourself.md} | 10 +- .../identityattribute-introduction.md | 2 +- .../test-your-requests-validity.md | 2 +- .../create-attribute-for-yourself.md | 99 +++++++++++++++++++ .../integrate/share-own-attribute-to-peer.md | 4 +- 6 files changed, 109 insertions(+), 10 deletions(-) rename _docs_integrate/{create-own-identityattribute.md => create-attribute-for-yourself.md} (67%) create mode 100644 _includes/scenarios/integrate/create-attribute-for-yourself.md diff --git a/_data/navigation.yml b/_data/navigation.yml index 71f62a828..3fa2c55f5 100644 --- a/_data/navigation.yml +++ b/_data/navigation.yml @@ -95,6 +95,8 @@ docs_integrate: url: /integrate/requests-over-messages - title: Manage attributes of yourself children: + - title: "Create Attribute for yourself" + url: /integrate/create-attribute-for-yourself - title: "Share own Attribute to peer" url: /integrate/share-own-attribute-to-peer - title: "Succeeding Attributes to update their values" diff --git a/_docs_integrate/create-own-identityattribute.md b/_docs_integrate/create-attribute-for-yourself.md similarity index 67% rename from _docs_integrate/create-own-identityattribute.md rename to _docs_integrate/create-attribute-for-yourself.md index 263ac9740..a5cc553cf 100644 --- a/_docs_integrate/create-own-identityattribute.md +++ b/_docs_integrate/create-attribute-for-yourself.md @@ -1,8 +1,8 @@ --- # !!! Warning: Do not edit this file; any changes must be replicated in Excel !!! -permalink: integrate/create-own-identityattribute -published: false -title: "Create own IdentityAttribute" +permalink: integrate/create-attribute-for-yourself +published: true +title: "Create Attribute for yourself" type: scenario toc: true properties: @@ -15,11 +15,11 @@ properties: - implementation status: DONE - documentation status: OPEN - published: - - link: integrate/create-own-identityattribute + - link: integrate/create-attribute-for-yourself require: - integrate/identityattribute-introduction required_by: - integrate/test-your-requests-validity --- -{% include scenarios/integrate/create-own-identityattribute.md %} +{% include scenarios/integrate/create-attribute-for-yourself.md %} diff --git a/_docs_integrate/identityattribute-introduction.md b/_docs_integrate/identityattribute-introduction.md index 42c77d2ba..ad4ad9d02 100644 --- a/_docs_integrate/identityattribute-introduction.md +++ b/_docs_integrate/identityattribute-introduction.md @@ -18,7 +18,7 @@ properties: - link: integrate/identityattribute-introduction require: required_by: - - integrate/create-own-identityattribute + - integrate/create-attribute-for-yourself --- {% include scenarios/integrate/identityattribute-introduction.md %} diff --git a/_docs_integrate/test-your-requests-validity.md b/_docs_integrate/test-your-requests-validity.md index 26c4373b6..086029e66 100644 --- a/_docs_integrate/test-your-requests-validity.md +++ b/_docs_integrate/test-your-requests-validity.md @@ -17,7 +17,7 @@ properties: - published: - link: integrate/test-your-requests-validity require: - - integrate/create-own-identityattribute + - integrate/create-attribute-for-yourself required_by: --- diff --git a/_includes/scenarios/integrate/create-attribute-for-yourself.md b/_includes/scenarios/integrate/create-attribute-for-yourself.md new file mode 100644 index 000000000..d54d3d4f0 --- /dev/null +++ b/_includes/scenarios/integrate/create-attribute-for-yourself.md @@ -0,0 +1,99 @@ +This guide explains the end to end flow of creating an [Attribute]({% link _docs_integrate/data-model-overview.md %}#attributes) for your own Connector as its Integrator. As there are two types of Attributes, [IdentityAttributes]({% link _docs_integrate/data-model-overview.md %}#identityattribute) and [RelationshipAttributes]({% link _docs_integrate/data-model-overview.md %}#relationshipattribute), a distinction must be made between them when creating an Attribute for yourself. + +## Create an IdentityAttribute for yourself + +This section is about how to create an [IdentityAttribute]({% link _docs_integrate/data-model-overview.md %}#identityattribute) for your own Connector that is not initially shared with any other Identity. From a technical point of view, this corresponds to the creation of a [LocalAttribute]({% link _docs_integrate/data-model-overview.md %}#localattribute) whose `content` is given by the IdentityAttribute that is intended to be created and whose `shareInfo` is undefined. Such a LocalAttribute is referred to as a RepositoryAttribute. + +Since knowledge about IdentityAttributes is required in the following, you should take a look at our IdentityAttribute introduction before you continue reading this guide. In particular, a description of the two kinds of IdentityAttributes, the simple IdentityAttributes and the complex IdentityAttributes, can be found there. +{: .notice--info} + + + +### Input for creating a RepositoryAttribute + +To create a RepositoryAttribute, proceed as described in the [Create a RepositoryAttribute]({% link _docs_use-cases/use-case-consumption-create-a-repositoryattribute.md %}) use case documentation. As input for the creation of a RepositoryAttribute, the following `content` must be used: + +```jsonc +{ + "content": { + "validFrom": "", + "validTo": "", + "value": { + // IdentityAttributeValue + ... + }, + "tags": ["", ..., ""] + } +} +``` + +You need to replace the placeholders marked with `<...>` appropriately. Also, it is necessary that you insert one of the available [IdentityAttributeValues]({% link _docs_integrate/attribute-values.md %}#identity-attributes) into the `value` property. Note that the properties `validFrom`, `validTo` and `tags` are optional, so you can omit them. + +### Process of creating a RepositoryAttribute + +As you can see from the diagram below, after you have entered the [input for creating a RepositoryAttribute]({% link _docs_integrate/create-attribute-for-yourself.md %}#input-for-creating-a-repositoryattribute), a check is performed whether the input values for the properties of the specified [IdentityAttributeValue]({% link _docs_integrate/attribute-values.md %}#identity-attributes) meet the validation criteria documented on the [Attribute Values]({% link _docs_integrate/attribute-values.md %}) page. If the validation is not successful, an [error message]({% link _docs_integrate/error-codes.md %}) is sent in response. Otherwise, a RepositoryAttribute is created that contains the IdentityAttribute in its `content` property. If it is a simple IdentityAttribute, a success response is sent directly. In the case of a complex IdentityAttribute, on the other hand, another RepositoryAttribute is created beforehand for each of its appropriate properties. These RepositoryAttributes for the properties are also referred to as children of the RepositoryAttribute belonging to the complex IdentityAttribute. The `id` of their parent is contained within their `parentId` property. Note that the successful creation of a LocalAttribute, and therefore in particular the creation of a RepositoryAttribute, triggers the `consumption.attributeCreated` [Connector event]({% link _docs_integrate/connector-events.md %}). + +
+ +### Example of creating a simple IdentityAttribute + +An example of a simple IdentityAttribute is one of type [DisplayName]({% link _docs_integrate/attribute-values.md %}#displayname). To create one for your own Connector without specifying optional parameters, the following `content` must be used: + +```jsonc +{ + "content": { + "value": { + "@type": "DisplayName", + "value": "" + } + } +} +``` + +Assuming that the input value for the Connector's display name specified in the `value.value` property meets the [validation criterion]({% link _docs_integrate/attribute-values.md %}#displayname), which means that the entered name does not have more than 100 characters, the IdentityAttribute is saved as a RepositoryAttribute and a success response is sent. + +### Example of creating a complex IdentityAttribute + +An example of a complex IdentityAttribute is one of type [BirthDate]({% link _docs_integrate/attribute-values.md %}#birthdate). To create one for your own Connector without specifying optional parameters, the following `content` must be used: + +```jsonc +{ + "content": { + "value": { + "@type": "BirthDate", + "day": , + "month": , + "year": + } + } +} +``` + +Assuming that the input values ​​for the properties `value.day`, `value.month` and `value.year` meet the [validation criteria]({% link _docs_integrate/attribute-values.md %}#birthdate), which means, for example, that the input value for `value.month` is an integer between 1 and 12, the IdentityAttribute is saved as a RepositoryAttribute. The properties `value.day`, `value.month` and `value.year` can each be understood as an additional simple IdentityAttribute of type [BirthDay]({% link _docs_integrate/attribute-values.md %}#birthday), [BirthMonth]({% link _docs_integrate/attribute-values.md %}#birthmonth) and [BirthYear]({% link _docs_integrate/attribute-values.md %}#birthyear), respectively. For this reason, another RepositoryAttribute is created internally for each of these properties before a success response is sent. So for the RepositoryAttribute, which belongs to the complex IdentityAttribute of type BirthDate, a total of three children are created. + +### What's next? + +When you have successfully created an IdentityAttribute for your own Connector, you will receive a success response. From the result, you can get the `id` of the corresponding RepositoryAttribute belonging to the IdentityAttribute. You will need this `id`, for example, if you want to share the underlying IdentityAttribute with other Identities later, as in the [Share own Attribute to peer]({% link _docs_integrate/share-own-attribute-to-peer.md %}) scenario. + +## Create a RelationshipAttribute for yourself + +If you want to create a [RelationshipAttribute]({% link _docs_integrate/data-model-overview.md %}#relationshipattribute), you must proceed differently than when [creating an IdentityAttribute for yourself]({% link _docs_integrate/create-attribute-for-yourself.md %}#create-an-identityattribute-for-yourself). This is because a RelationshipAttribute can only exist in the context of a [Relationship]({% link _docs_integrate/data-model-overview.md %}#relationship) with a peer, which means that they must also agree to the creation of it. This is achieved by sending a [Request]({% link _docs_integrate/data-model-overview.md %}#request) whose `items` property contains an appropriate [RequestItem]({% link _docs_integrate/data-model-overview.md %}#requestitems), which must be accepted by the peer. Depending on whether you or your peer should set the [RelationshipAttributeValue]({% link _docs_integrate/attribute-values.md %}#relationship-attributes) and depending on other factors, a [CreateAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#createattributerequestitem), [ReadAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#readattributerequestitem), [ProposeAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#proposeattributerequestitem) or [ShareAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#shareattributerequestitem) should be used for this. + +From a technical point of view, the creation of a RelationshipAttribute corresponds to the creation of one [LocalAttribute]({% link _docs_integrate/data-model-overview.md %}#localattribute) for yourself and one LocalAttribute for your peer, whereby their `content` is given by the RelationshipAttribute that is intended to be created and the `shareInfo` of both LocalAttributes contains a correspondingly suitable [LocalAttributeShareInfo]({% link _docs_integrate/data-model-overview.md %}#localattributeshareinfo). +{: .notice--info} + +### Utilization of a CreateAttributeRequestItem + +You can use a [CreateAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#createattributerequestitem) to create a RelationshipAttribute in the context of a Relationship between you and your peer if you want the RelationshipAttributeValue to be set by yourself. Your peer can only accept or reject the creation of the RelationshipAttribute, but cannot modify the RelationshipAttributeValue. A RelationshipAttribute that you want to create using a CreateAttributeRequestItem can be owned by yourself or by your peer. For full details on how to create a RelationshipAttribute using a CreateAttributeRequestItem, please refer to the [Create Attribute for peer]({% link _docs_integrate/create-attribute-for-peer.md %}) guide. + +### Utilization of a ReadAttributeRequestItem + +You can use a [ReadAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#readattributerequestitem) to create a RelationshipAttribute in the context of a Relationship between you and your peer if you want the RelationshipAttributeValue to be set by your peer. Even if it seems misleading to use a ReadAttributeRequestItem to create a RelationshipAttribute, this terminology makes sense insofar as the RelationshipAttributeValue should be read from the peer in order to be able to create the RelationshipAttribute. A RelationshipAttribute that you want to create using a ReadAttributeRequestItem can be owned by yourself, your peer or even a third party. For full details on how to create a RelationshipAttribute using a ReadAttributeRequestItem, please refer to the [Read Attribute from peer]({% link _docs_integrate/read-attribute-from-peer.md %}) guide. + +### Utilization of a ProposeAttributeRequestItem + +You can use a [ProposeAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#proposeattributerequestitem) to create a RelationshipAttribute in the context of a Relationship between you and your peer if you want to propose a potentially suitable RelationshipAttributeValue to your peer, but your peer has the option to modify it before the RelationshipAttribute is created. A RelationshipAttribute that you want to create using a ProposeAttributeRequestItem must be owned by your peer. All details on how to create a RelationshipAttribute using a ProposeAttributeRequestItem can be found in the [Propose Attribute to peer]({% link _docs_integrate/propose-attribute-to-peer.md %}) guide. + +### Utilization of a ShareAttributeRequestItem + +You can use a [ShareAttributeRequestItem]({% link _docs_integrate/data-model-overview.md %}#shareattributerequestitem) to create a RelationshipAttribute in the context of a Relationship between you and your peer if you want to use an existing RelationshipAttribute between you and a third party as the source for creating the new RelationshipAttribute. Your peer can only accept or reject the creation of it, but cannot modify it. A RelationshipAttribute that you want to create using a ShareAttributeRequestItem can be owned by yourself or the third party, but not by your peer. All details on how to create a RelationshipAttribute using a ShareAttributeRequestItem can be found in the [Share own Attribute to peer]({% link _docs_integrate/share-own-attribute-to-peer.md %}) guide. diff --git a/_includes/scenarios/integrate/share-own-attribute-to-peer.md b/_includes/scenarios/integrate/share-own-attribute-to-peer.md index 575ade537..cef19e6a9 100644 --- a/_includes/scenarios/integrate/share-own-attribute-to-peer.md +++ b/_includes/scenarios/integrate/share-own-attribute-to-peer.md @@ -37,9 +37,7 @@ The following table provides an overview of the possible kinds of Attributes tha ### Example of sharing an own IdentityAttribute -We assume that the Integrator of the Sender has created an own IdentityAttribute of type [BirthDate]({% link _docs_integrate/attribute-values.md %}#birthdate) for the Sender by following the instructions of our Create own IdentityAttribute scenario documentation. This IdentityAttribute is stored locally within the `content` property of a corresponding [LocalAttribute]({% link _docs_integrate/data-model-overview.md %}#localattribute) of the Sender. - - +We assume that the Integrator of the Sender has created an own IdentityAttribute of type [BirthDate]({% link _docs_integrate/attribute-values.md %}#birthdate) for the Sender by following the instructions of our [Create Attribute for yourself]({% link _docs_integrate/create-attribute-for-yourself.md %}) scenario documentation. This IdentityAttribute is stored locally within the `content` property of a corresponding [LocalAttribute]({% link _docs_integrate/data-model-overview.md %}#localattribute) of the Sender. ```jsonc {