Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Traceability KIT 24.12] Block Notification #1028

Merged
Show file tree
Hide file tree
Changes from 62 commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
6819e84
Update page_architecture-view.mdx
johannsvarela Sep 9, 2024
605b54f
Update DEPENDENCIES
johannsvarela Sep 10, 2024
443e415
Update page_architecture-view.mdx
johannsvarela Sep 10, 2024
8a0da5e
Update page_architecture-view.mdx
johannsvarela Sep 10, 2024
34fe2be
Update page_changelog.mdx
johannsvarela Sep 10, 2024
5a1d16a
Update page_architecture-view.mdx
johannsvarela Sep 10, 2024
653f781
Update page_changelog.mdx
johannsvarela Sep 10, 2024
3d9613c
Update page_architecture-view.mdx
johannsvarela Sep 10, 2024
bcabb82
Update page_app-provider_software-development-view.mdx
johannsvarela Sep 10, 2024
fe241cf
Update page_changelog.mdx
johannsvarela Sep 10, 2024
f56361c
Delete docs-kits/kits/Traceability Kit/assets/architecture_level_1.png
johannsvarela Sep 10, 2024
62fc3ae
Add files via upload
johannsvarela Sep 10, 2024
df56749
Update page_architecture-view.mdx
johannsvarela Sep 10, 2024
616070e
Update page_changelog.mdx
johannsvarela Sep 10, 2024
5393b54
Update page_architecture-view.mdx
johannsvarela Sep 11, 2024
c147c27
Update page_changelog.mdx
johannsvarela Sep 11, 2024
bbcb73f
Update page_architecture-view.mdx
johannsvarela Sep 11, 2024
6a7bb86
Update page_architecture-view.mdx
johannsvarela Sep 11, 2024
b8464c4
Update page_changelog.mdx
johannsvarela Sep 11, 2024
16955a7
Add files via upload
johannsvarela Sep 18, 2024
d6b6e2c
Update page_architecture-view.mdx
johannsvarela Sep 18, 2024
e434c53
Update page_changelog.mdx
johannsvarela Sep 18, 2024
a10682d
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Sep 18, 2024
1aeb48a
Add files via upload
johannsvarela Sep 18, 2024
4d8e1b2
Add files via upload
johannsvarela Sep 18, 2024
e111fc7
Update page_architecture-view.mdx
johannsvarela Sep 18, 2024
a82e4d7
Add files via upload
johannsvarela Sep 18, 2024
268e2e5
Add files via upload
johannsvarela Sep 18, 2024
8df9e8b
Update page_architecture-view.mdx
johannsvarela Sep 18, 2024
98e814e
Update page_architecture-view.mdx
johannsvarela Sep 18, 2024
4f9e1c8
Add files via upload
johannsvarela Sep 20, 2024
163b4eb
Update page_business_view.mdx
johannsvarela Sep 20, 2024
5c4f4a0
Update page_changelog.mdx
johannsvarela Sep 20, 2024
9f65c27
Update page_app-provider_software-development-view.mdx
johannsvarela Sep 20, 2024
f64325d
Update page_changelog.mdx
johannsvarela Sep 20, 2024
7e91615
Update DEPENDENCIES
johannsvarela Sep 25, 2024
a68eba7
Update page_business_view.mdx
johannsvarela Sep 25, 2024
57e6d4a
Add files via upload
johannsvarela Sep 25, 2024
b9f376d
Add files via upload
johannsvarela Oct 7, 2024
d5a7910
Add files via upload
johannsvarela Oct 14, 2024
090d164
Update page_architecture-view.mdx
johannsvarela Oct 14, 2024
a0d4f85
Add files via upload
johannsvarela Oct 14, 2024
a4aefe7
Update page_changelog.mdx
johannsvarela Oct 14, 2024
ce41d2d
Update page_app-provider_software-development-view.mdx
johannsvarela Oct 14, 2024
5cd93b0
Add files via upload
johannsvarela Oct 14, 2024
3cfabda
Update page_app-provider_software-development-view.mdx
johannsvarela Oct 15, 2024
64526f5
Update page_changelog.mdx
johannsvarela Oct 15, 2024
2ec8099
Update page_changelog.mdx
johannsvarela Oct 15, 2024
c80d242
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Oct 15, 2024
67b1aa6
Update page_changelog.mdx
johannsvarela Oct 15, 2024
79e34b8
Update page_changelog.mdx
johannsvarela Oct 16, 2024
4fa627f
Update block-notifications-1-0-0.yaml
johannsvarela Oct 23, 2024
fa81dea
Update page_app-provider_software-development-view.mdx
johannsvarela Oct 23, 2024
769d5a0
Update page_architecture-view.mdx
johannsvarela Oct 23, 2024
7d16f72
Update page_app-provider_software-development-view.mdx
johannsvarela Oct 24, 2024
317c39c
Update page_app-provider_software-development-view.mdx
johannsvarela Oct 24, 2024
dc4b327
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Oct 24, 2024
04ba181
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Oct 25, 2024
26ae4c9
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Nov 20, 2024
f21c729
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Nov 25, 2024
02a628c
Add files via upload
johannsvarela Nov 26, 2024
0e1f18f
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Nov 26, 2024
89aa730
Update block-notifications-1-0-0.yaml
johannsvarela Dec 2, 2024
1f52494
Rename architecture_level_1.png.license to architecture_level_1.svg.l…
johannsvarela Dec 2, 2024
628bcbf
Create block-notification-state-model-interaction.svg.license
johannsvarela Dec 2, 2024
129b923
Create block-notification-state-model.svg.license
johannsvarela Dec 2, 2024
5cf1674
Create block_notifications.svg.license
johannsvarela Dec 2, 2024
b8ea5fc
Create block-notification-send-receive.svg.license
johannsvarela Dec 2, 2024
067a970
Create block-notification-update-status.svg.license
johannsvarela Dec 2, 2024
419992e
Update page_app-provider_software-development-view.mdx
johannsvarela Dec 2, 2024
aafd242
Update page_architecture-view.mdx
johannsvarela Dec 2, 2024
ea3d905
Merge branch 'eclipse-tractusx:main' into docs-kits/trace-block-notif…
johannsvarela Dec 2, 2024
4748a53
Merge branch 'main' into docs-kits/trace-block-notification-release-2…
stephanbcbauer Dec 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,8 @@ The traceability app providers are supposed to implement the capabilities to ena
This feature will enable the whole industry to exchange and act upon quality issues in a more standardized, integrated, accelerated and precise manner in order to streamline claim management, avoid general and inaccurate recalls as well as reduce cost and safeguard brand reputation.

In order to uniquely reference the affected parts across the network in the context of a quality incident, the exchange of quality notifications uses Catena-X Unique ID, which are the network-wide unique identifiers for a serialized part or batch, for which a digital twin has been created. Therefore, an app provider should also deliver capabilities for standardized creation of digital twins of vehicles, parts and materials as described in the [Industry Core KIT](../../../category/industry-core-kit) and [Digital Twin KIT](../../../category/digital-twin-kit).
![Quality Notifications](../assets/quality_notifications.png)

![Quality Notifications](../assets/quality_notifications.svg)

### Quality Notification Process
The notification process takes place between traceability applications or application stacks, and the focus is on minimal interaction, which must be supported by all applications participating in a quality notification or quality investigation scenario. This minimal interaction includes sending and receiving of quality notification as well as updating of the notification state. Application internals like user journeys, process steps or workflows for notification creation and management in an application are not standardized within Catena-X, and therefore omitted.
Expand All @@ -46,7 +47,32 @@ The notification states and their cycle are described in the following figure.
### Quality Notification API
A standardized set of APIs and payloads are specified to enable partners to send quality notifications in a standardized way while already knowing which parts (i.e., serialized parts or batches) and which direct customers or suppliers are affected. Notifications are - in contrast to classical data offers in Catena-X which is created for consumption by external stakeholders - a way to push notification related data from a sender to a receiver. For now, this notification API is limited to the sending and receiving of quality notifications as well as the update of the notification status following a state model.
It is important to mention that the notification API shall be implemented into each participant's traceability solution or solution stack in order to be able to receive information related to quality issues. The implemented endpoints shall be able to process the defined request body and respond with the HTTP status codes and - if required - reply with the defined response body.
Meanwhile, this notification API shall only be accessible after successful contract negotiation via Connector based on [Dataspace Protocol (DSP)](https://docs.internationaldataspaces.org/dataspace-protocol/), since the API is made available as part of an EDC data asset with usage policy attached. Please refer to the Notification API ([v1.2.1](../openapi/notifications_1-2-1.yaml), [v2.0.0](../openapi/notifications_2-0-0.yaml)) for more details.
Meanwhile, this notification API shall only be accessible after successful contract negotiation via Connector based on [Dataspace Protocol (DSP)](https://docs.internationaldataspaces.org/dataspace-protocol/), since the API is made available as part of an EDC data asset with usage policy attached. Please refer to the corresponding Notification API specifications for more details:
- [Notification API (v1.2.1)](../openapi/notifications_1-2-1.yaml)
- [Notification API (v2.0.0)](../openapi/notifications_2-0-0.yaml)

> :raised_hand: For the current release, **version 1.2.1 is mandatory** and must be supported by every App provider. The newer version 2.0.0 can be supported optionally.

## Block Notifications
While quality notifications are primarily aimed at (first) contact between business partners, block notifications represent an extended form of data exchange in order to actively initiate an immediate measure to block or sort out the produced parts at the customer's production or logistics. As the quality notifications, block notifications take place between traceability applications or other application stacks, so that this functionality must be implemented by both business partners application.

In this case, block notifications include a **notification status similar to quality notifications** to track communication, but **also include a new status model** for each individual part of the block notification to provide additional information. For example, whether the part was blocked or whether the process to block a part was canceled.

> :raised_hand: Since the Catena-x unique ID is used for the individually listed (damaged) parts in the block notification, the app provider should also provide functions for the standardized creation of digital twins of vehicles, parts and materials, as already mentioned in the quality notifications section.

### Block Status Model
In order to track the blocking process in the Catena X network, a defined status model is used for each part of the block notification:
![Block Status Model](../assets/block-notification-state-model.svg)

- ACTIVE means that the part has been identified as a damaged and safety-critical part and must therefore be blocked on the customer side.
- PART_BLOCKED is used when the recipient has received the block notification and actually blocks / sorts out the damaged parts as a measure.
- CANCELED serves as the update status of the component originally identified to be blocked if the supplier subsequently determines that the original part does meet safety requirements, is not damaged or that the information was sent by mistake. This status can also be set by the manufacturer if, after an (initial) analysis, the part does not require a block.

### Block Notification API
A standardized API and corresponding payloads are specified for block notification to enable and ensure the exchange of information that is critical to the blocking process in a standardized way. At this point, the notification API is focused on sending and receiving notifications with a full stack of block information and on updating a previously sent notification by changing the block status. The implemented endpoints shall be able to process the defined request body and respond with the HTTP status codes and - if required - reply with the defined response body. Meanwhile, the Block Notification API shall only be accessible after successful contract negotiation via Connector based on [Dataspace Protocol (DSP)](https://docs.internationaldataspaces.org/dataspace-protocol/), since the API is made available as part of an EDC data asset with usage policy attached. Please refer to the corresponding Block Notification API specification for more details:
- [Block Notification API (v1.0.0)](../openapi/block-notifications-1-0-0.yaml)

> :raised_hand: For the current release, **version 1.0.0 is optional** and MUST be supported by every App provider from the next (major) release.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved

## Asset Registration via Connector
Since the notification APIs are published towards the network using a data asset/contract definition in terms of the dataspace protocol (DSP), there are general guidelines defined for registering a notification receiving endpoint within a data asset. The traceability solutions are supposed to implement a similar data asset with the same structure and provisioning towards Catena-X.
Expand All @@ -57,9 +83,11 @@ The notification endpoint providers must set properties `dct:type` and `cx-commo

In general, during EDC asset creation, the notification API version needs to provided for `cx-common:version` as specified in OpenAPI documentation. For `dct:type` the following asset typizations should be used during implementation:
- ReceiveQualityInvestigationNotification
- ReceiveQualityAlertNotification
- ReceiveQualityAlertNotification
- UpdateQualityInvestigationNotification
- ReceiveQualityAlertNotification
- UpdateQualityAlertNotification
- ReceiveBlockNotification
- UpdateBlockNotification

Please refer to the [Digital Twin KIT](../../../category/digital-twin-kit) for more details.

Expand Down Expand Up @@ -100,7 +128,9 @@ For general guidelines for policy creation, please refer to [Industry Core KIT](
It is possible to restrict visibility of data offer for notification API with access policy either for members of Catena-X (“Membership”) and one or several Data Consumers identified by a specific business partner number ("BusinessPartnerNumber").
As for usage policy, participants and related services must restrict the data usage for notification endpoints by using the following policy rules:
- Data Exchange Governance (leftOperand: “FrameworkAgreement”) – The official "Data Exchange Governance" is published on [Catena-X website](https://catena-x.net/en/catena-x-introduce-implement/governance-framework-for-data-space-operations)
- at least one use case purpose (“UsagePurpose”) from the [ODRL policy repository](https://github.com/catenax-eV/cx-odrl-profile).
- at least one use case purpose (“UsagePurpose”) from the [ODRL policy repository](https://github.com/catenax-eV/cx-odrl-profile)
- for quality notifications, the corresponding usage policy MUST be used (leftOperand: “qualityNotifications”)
- for block notifications, the same usage policy as quality notifications MUST be used (leftOperand: “qualityNotifications”)

Additionally, respective usage policies MAY include the following policy rule:
- Reference Contract (“ContractReference”).
Expand Down
Binary file not shown.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please add the corresponding licence-file.

Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
johannsvarela marked this conversation as resolved.
Show resolved Hide resolved
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading