Skip to main content
Release: CX-Io (preview)

CX-0012 Business Partner Data Pool API v4.1.0

FOR WHOM IS THE STANDARD DESIGNED

This document is mainly targeted to technical individuals involved in integrating and developing against this API, as well as business individuals who are involved in compliance process of this API.

COMPARISON WITH THE PREVIOUS VERSION OF THE STANDARD

VersionPublishing DateAuthorDescription of Change
1.1.02022-11-30Initial version by Catena-X Association
1.1.12023-06-03Addendum for Conformity Assessment added
2.0.02023-09-26Included new API and terminology chapter
2.1.02024-01-10Small additions to the terminology and API specification chapters: added “business partner type” in changelog entry; added “administrative area (level 1)” as sub-object; added ISO 6709 and WGS 84 for geographic coordinates; added GET/sites; linked OpenAPI document in release branch instead of main
3.0.02024-03-22Added additional street attributes; removed boolean attributes in favor of enum for address types, like in the Gate API; switched to the new document structure
4.0.02024-06-07Added footnote to indicate that the term "site main address" is subject to change; added the CX-0018 version; changed and added the detailed asset structure; added footnote to clarify role distribution; removed terms Company Data and Sharing Member, as they are not used here; removed classification sub-object, to reintroduce it in a presumably new form in one of the next non-breaking versions of this standard; added "is Catena-X Member data" attribute; removed "api/catena/" from the endpoint definitions; added data sovereignty chapters as additional requirements; fix changelog controller endpoint for business-partners to match the reference implementation.
4.1.02024-12-02Added tax jurisdiction code

ABSTRACT

The Business Partner Data Management (BPDM) is a distributed service-based system, composed of a set of dedicated services, that simultaneously serve multiple stakeholders. It is based on a central data pool of business partners, which is consistent with the overall design principles of Catena-X. The main target is to create business partner data records (such as customer/supplier) with a high quality and currentness, to provide other processes with these data. This results in less rework and adjustment due to better master data quality which ultimately leads to an overall cost reduction for participating companies. Additionally, Value Added Services shall be offered to enrich those business partner data sets even further and give additional information or warnings about the business partners. Getting a 360° view on your business partners also helps with reducing costs and achieving process excellence because better decisions can be made.

The Business Partner Pool collects business partner data records which are cleansed and enriched, so-called Golden Records, and makes them available. It is a main component of the architecture framework at Catena-X, as it enables the Catena-X Members to leverage accurate, complete, and consistent business partner data for Catena-X applications and shared services.

The Business Partner Pool can be accessed via the standardized API described in this standard.

1 INTRODUCTION

1.1 AUDIENCE & SCOPE

This section is non-normative

This standard is relevant for the following audience:

  • Core Service Provider
  • Onboarding Service Provider
  • Business Application Provider
  • Data Provider and Consumer

This document focuses on the Business Partner Pool API (short: Pool API) that is part of the Business Partner Data Management (BPDM) described on the BPDM Catena-X Website. It is relevant for Core Service Providers who want to provide services for retrieving a cleansed, high-quality business partner data record (Golden Record) for a given business partner number (BPN). It is also relevant for onboarding service providers, business application providers as well as data providers and consumers who want to use such services.

Not in scope are the structure and logic of the business partner number itself and the mechanism on how the business partner number is issued. There is a separate standard for this: CX-0010 Business Partner Number 2.1.0.

Not in scope is the way of how business partner data records can be shared to create a Golden Record. There is a separate standard for this: CX-0074 Business Partner Data Gate API 3.1.0.

Not in scope are the requirements of cleansing and enriching the business partner data records with the aim to create a Golden Record. There is a separate standard for this: CX-0076 Golden Record End to End Requirement Standards 1.3.0.

You can find the other standards in the Catena-X standard library.

1.2 CONTEXT AND ARCHITECTURE FIT

This section is non-normative

The Pool API is a crucial core component in Catena-X and its platform capability BPDM because it contributes to the following functions:

  1. Data Consistency: The Pool API ensures that all data related to business partners is consistent and up-to-date and can be accessed by all consumers of the API. This helps to reduce the risk of errors and inconsistencies in business partner information.
  2. Centralized Data Management: The Pool API provides a centralized repository for business partner data, making it easier to manage, maintain, and update information.
  3. Data Governance: The Pool API is the basis for a data governance framework and helps to enforce data quality standards, such as data completeness, accuracy, and consistency. This helps to ensure that business partner data is of high quality and can be trusted for use in various business processes.
  4. Interoperability: The Pool API provides an interoperable and standardized way to access business partner data, ensuring both Core Service Provider interchangeability and streamlined data accessibility for all consumers of the API.

There is a reference implementation for the Business Partner Data Pool API (6.1.x) on GitHub. It is part of a Spring Boot Kotlin open-source software project under the hood of the Eclipse Foundation and follows the Apache 2.0 licenses.

For the complete and up-to-date BPDM setup refer to the Eclipse Tractus-X BPDM GitHub repository (6.1.x).

For an architecture overview refer to the BPDM ARC42 documentation (6.1.x).

To use the Pool API in the BPDM use case apart from this standard, the following other standards should be considered by all participants for which this standard is relevant:

  • CX-0018 Dataspace Connectivity 3.1.0

1.3 CONFORMANCE AND PROOF OF CONFORMITY

This section is non-normative

If sections are marked as non-normative, all authoring guidelines, diagrams, examples, and notes in these sections are non-normative. Everything else in this specification is normative.

The key words MAY, MUST, MUST NOT, OPTIONAL, RECOMMENDED, REQUIRED, SHOULD and SHOULD NOT in this document are to be interpreted as described in BCP 14, RFC2119, RFC8174 when, and only when, they appear in all capitals, as shown here.

All participants and their solutions will need to prove, that they are conform with the Catena-X standards. To validate that the standards are applied correctly, Catena-X employs Conformity Assessment Bodies (CABs).

When implementing the API defined in this standard, proof of conformity must be provided by the following deliverables:

  • An OpenAPI specification defining the relevant resources for this standard
  • Examples of data assets

1.4 EXAMPLES

Intentionally left blank.

1.5 TERMINOLOGY

This section is non-normative

1.5.1 GENERAL

Golden Record: Golden Record defines a business partner data record which successfully passed a set of predefined quality rules. These rules qualified the data record into a harmonized, standardized, and semantically unified data structure which is defined by Catena-X. The Golden Record status is a prerequisite for each BP data record to receive a valid BPN.

1.5.2 DATA MODEL

This chapter explains the data model1 from a conceptual / terminology point of view. It does not include technical details of the API data model, such as:

  • differences in response and request
  • differences in data stages (like input or output)
  • attributes for pagination
  • singular query parameters, which are not already attributes of the entities
1.5.2.1 BUSINESS PARTNER

Business Partner

In general, a business partner is any entity (such as a customer, a supplier, an employee, or a service provider) that does business with another entity.

In Catena-X, a business partner is an organization (such as an enterprise or company, university, association, etc., and not a natural person) or one of its substructures that acts as unique partner within the automotive supply chain - either in the role of a direct participant, or a consultant, or a non-production-material (NPM) supplier.

BPDM distinguishes between three business partner types to represent an organization or one of its substructures relevant for the automotive supply chain (see detailed definitions): legal entity, site, and address2.

Legal Entity

In general, a legal entity is a juridical person that has legal rights and duties related to contracts, agreements, and obligations. The term especially applies to any kind of organization (such as an enterprise or company, university, association, etc.) established under the law applicable to a country.

In Catena-X, a legal entity is a type of business partner representing a legally registered organization with its official registration information, such as legal name (including legal form, if registered), legal address and tax number.

A legal entity has exactly one legal address, but it is possible to specify additional addresses that a legal entity owns. Thus, at least one address is assigned to a legal entity. A legal entity can own sites. Thus, many or no sites are assigned to a legal entity. A legal entity is uniquely identified by the BPNL.

AttributeDescription(Data) Type / Code List / Enumeration
BPNLA BPNL represents and uniquely identifies a legal entity, which is defined by its legal name (including legal form, if registered), legal address and tax number.String
Legal NameThe name of the legal entity according to official registers.String
Short NameThe abbreviated name of the legal entity.String
Legal FormThe legal form of the legal entity.Legal Form
StatesThe list of (temporary) states of the legal entity.List of Legal Entity State
IdentifiersThe list of identifiers of the legal entity.List of Legal Entity Identifier
Is Catena-X Member DataIndicates whether the legal entity is owned and thus provided by a Catena-X Member.Boolean
Created AtThe date and time when the legal entity data record has been created.Date / Time
Updated AtThe date and time when the legal entity data record has been last updated.Date / Time
Legal AddressThe official, legal correspondence address to be provided to government and tax authorities and used in all legal or court documents.Address

A legal entity identifier (uniquely) identifies the legal entity, such as the German Handelsregisternummer, a VAT number, etc.

AttributeDescription(Data) Type / Code List / Enumeration
ValueThe value of the identifier like “DE123465789”String
TypeThe type of the identifier.Identifier Type
Issuing BodyThe name of the official register, where the identifier is registered. For example, a Handelsregisternummer in Germany is only valid with its corresponding Registergericht and Registerart.String

A legal entity state indicates if the legal entity is active or inactive3. This does not describe the relation between a Catena-X Member and a business partner and whether they have active business, but it describes whether the legal entity is still operating.

AttributeDescription(Data) Type / Code List / Enumeration
Valid FromThe date and time from which the state is valid.Date / Time
Valid ToThe date and time until the state is valid.Date / Time
TypeOne of the state types: active, inactive.Enum
1.5.2.3 SITE

Site

In general, a site is a delimited geographical area in which an organization (such as an enterprise or company, university, association, etc.) conducts business.

In Catena-X, a site is a type of business partner representing a physical location or area owned by a legal entity, where a production plant, a warehouse, or an office building is located.

A site is owned by a legal entity. Thus, exactly one legal entity is assigned to a site. A site has exactly one main address4, but it is possible to specify additional addresses (such as different gates), that belong to a site. Thus, at least one address is assigned to a site. A site can only be uploaded and modified by the owner (the legal entity), because only the owner knows which addresses belong to which site. A site is uniquely identified by the BPNS.

AttributeDescription(Data) Type / Code List / Enumeration
BPNSA BPNS represents and uniquely identifies a site, which is where for example a production plant, a warehouse, or an office building is located.String
NameThe name of the site. This is not according to official registers but according to the name the owner chooses.String
StatesThe list of the (temporary) states of the site.List of Site State
Legal Entity BPNThe BPNL of the legal entity owning the site.String
Is Catena-X Member DataIndicates whether the site is owned and thus provided by a Catena-X Member.Boolean
Created AtThe date and time when the site data record has been created.Date / Time
Updated AtThe date and time the site data record has been last updated.Date / Time
Main Address4The address, where typically the main entrance or the reception is located, or where the mail is delivered to.Address
1.5.2.3.1 SITE STATE

A site state indicates if the site is active or inactive5. This does not describe the relation between a Catena-X Member and a business partner and whether they have active business, but it describes whether the site is still operating.

AttributeDescription(Data) Type / Code List / Enumeration
Valid FromThe date from which the state is valid.String
Valid ToThe date until the state is valid.String
TypeOne of the state types: active, inactive.Enum
1.5.2.4 ADDRESS

Address

In general, an address is a collection of information to describe a physical location, using a street name with a house number and/or a post office box as reference. In addition, an address consists of several postal attributes, such as country, region (state), county, township, city, district, or postal code, which help deliver mail.

In Catena-X, an address is a type of business partner representing the legal address of a legal entity, and/or the main address4 of a site, or any additional address of a legal entity or site (such as different gates).

An address is owned by a legal entity. Thus, exactly one legal entity is assigned to an address. An address can belong to a site. Thus, one or no site is assigned to an address. An address is uniquely identified by the BPNA.

AttributeDescription(Data) Type / Code List / Enumeration
BPNAA BPNA represents and uniquely identifies an address, which can be the legal address of a legal entity, and/or the main address4 of a site, or any additional address of a legal entity or site (such as different gates). It is important to note that only the BPNL must be used to uniquely identify a legal entity. Even in the case that the BPNA represents the legal address of the legal entity, it shall not be used to uniquely identify the legal entity.String
NameThe name of the address. This is not according to official registers but according to the name the sharing members agree on, such as the name of a gate or any other additional names that designate the address in common parlance.String
StatesThe list of (temporary) states of the address.List of Address State
IdentifiersThe list of identifiers of the address.List of Address Identifier
Physical Postal AddressThe physical postal address of the address, such as an office, warehouse, gate, etc.Physical Postal Address
Alternative Postal AddressThe alternative postal address of the address, for example if the goods are to be picked up somewhere else.Alternative Postal Address
Legal Entity BPNThe BPNL of the legal entity owning the address.String
TypeOne of the address types: Legal Address, Site Main Address4, Legal and Site Main Address4, Additional Address.Enum
Site BPNThe BPNS of the site the address belongs to.String
Is Catena-X Member DataIndicates whether the address is owned and thus provided by a Catena-X Member.Boolean
Created AtThe date and time when the address data record has been created.Date / Time
Updated AtThe date and time when the address data record has been last updated.Date / Time
1.5.2.4.1 ADDRESS IDENTIFIER

An address identifier (uniquely) identifies the address, such as the Global Location Number (GLN).

AttributeDescription(Data) Type / Code List / Enumeration
ValueThe value of the identifier like "0847976000005"String
TypeThe type of the identifier.Identifier Type
1.5.2.4.2 ADDRESS STATE

An address state indicates if the address is active or inactive6. This does not describe the relation between a Catena-X Member and a business partner and whether they have active business, but it describes whether the business partner is still operating at that address.

AttributeDescription(Data) Type / Code List / Enumeration
Valid FromThe date from which the state is valid.String
Valid ToThe date until the state is valid.String
TypeOne of the state types: active, inactive.Enum

A legal form is a mandatory corporate legal framework by which companies can conduct business, charitable or other permissible activities.

AttributeDescription(Data) Type / Code List / Enumeration
Technical KeyThe technical identifier of the legal form according to ISO 20275:2017.String
NameThe name of legal form according to ISO 20275:2017.String
AbbreviationThe abbreviated name of the legal form according to ISO 20275:2017, such as AG for German Aktiengesellschaft.String
1.5.2.6 PHYSICAL POSTAL ADDRESS

A physical postal address describes the physical location of an office, warehouse, gate, etc.

AttributeDescription(Data) Type / Code List / Enumeration
Geographic CoordinatesThe exact location of the physical postal address in latitude, longitude, and altitude.Geographic Coordinates
CountryThe two-letter country code of the physical postal address according to ISO 3166-1:2020.String
Administrative Area Level 1The administrative area of the physical postal address, such as a region within a country.Administrative Area (Level 1)
Administrative Area Level 2The name of the locally regulated secondary country subdivision of the physical postal address, such as county within a country.String
Administrative Area Level 3The name of the locally regulated tertiary country subdivision of the physical address, such as townships within a country.String
Postal CodeThe alphanumeric identifier (sometimes including spaces or punctuation) of the physical postal address for the purpose of sorting mail, synonyms: postcode, post code, PIN or ZIP code.String
CityThe name of the city of the physical postal address, synonyms: town, village, municipality.String
DistrictThe name of the district of the physical postal address which divides the city into several smaller areas.String
StreetThe street of the physical postal address, synonyms: road, avenue, lane, boulevard, highwayStreet
Company Postal CodeThe company postal code of the physical postal address, which is sometimes required for large companies.String
Tax Jurisdiction CodeThe identifier of the particular geographic or governmental area to which the physical mailing address belongs and which is responsible for administering tax laws and collecting taxes from individuals and businesses.String
Industrial ZoneThe industrial zone of the physical postal address, designating an area for industrial development, synonym: industrial area.String
BuildingThe alphanumeric identifier of the building addressed by the physical postal address.String
FloorThe number of a floor in the building addressed by the physical postal address, synonym: level.String
DoorThe number of a door in the building on the respective floor addressed by the physical postal address, synonyms: room, suite.String
1.5.2.6.1 STREET

A street is a public road in a city, town, or village, typically with houses and buildings on one or both sides, synonyms: road, avenue, lane, boulevard, highway.

AttributeDescription(Data) Type / Code List / Enumeration
Name PrefixThe street related information, which is usually printed before the official street name on an address label.String
Additional Name PrefixThe additional street related information, which is usually printed before the official street name on an address label.String
NameThe name of the street.String
Name SuffixThe street related information, which is usually printed after the official street name on an address label.String
Additional Name SuffixThe additional street related information, which is usually printed after the official street name on an address label.String
House NumberThe alphanumeric identifier representing the exact location of a building within the street.String
House Number SupplementThe alphanumeric identifier representing the exact location of a business partner in a building. Note this information might be further detailed semantically in the building, floor, and door attributes. However, this attribute is the only relevant for addressing the business partner.String
MilestoneThe alphanumeric identifier representing the exact location of an addressed object within a street without house numbers, such as within long roads.String
DirectionThe cardinal direction describing where the exit to the location of the addressed object on large highways / motorways is located, such as Highway 101 South.String
1.5.2.7 ALTERNATIVE POSTAL ADDRESS

An alternative postal address describes an alternative way of delivery for example if the goods are to be picked up somewhere else.

AttributeDescription(Data) Type / Code List / Enumeration
Geographic CoordinatesThe exact location of the alternative postal address in latitude, longitude, and altitude.Geographic Coordinates
CountryThe two-letter country code of the postal address according to ISO 3166-1:2020..String
Administrative Area Level 1The administrative area of the alternative postal address, such as a region within a country.Administrative Area (Level 1)
Postal CodeThe alphanumeric identifier (sometimes including spaces or punctuation) of the alternative postal address for the purpose of sorting mail, synonyms: postcode, post code, PIN or ZIP code.String
CityThe name of the city of the alternative postal address, synonyms: town, village, municipality.String
Delivery Service TypeOne of the alternative postal address types: P.O. box, private bag, boite postale.Enum
Delivery Service QualifierThe qualifier uniquely identifying the delivery service endpoint of the alternative postal address in conjunction with the delivery service number. In some countries for example, entering a P.O. box number, postal code and city is not sufficient to uniquely identify a P.O. box, because the same P.O. box number is assigned multiple times in some cities.String
Delivery Service NumberThe number indicating the delivery service endpoint of the alternative postal address to which the delivery is to be delivered, such as a P.O. box number or a private bag number.String
1.5.2.8 ADMINISTRATIVE AREA (LEVEL 1)

An administrative area (level 1) is the country subdivision according to ISO 3166-2:2020, such as regions within a country.

AttributeDescription(Data) Type / Code List / Enumeration
NameThe name of the country subdivision according to ISO 3166-2:2020.String
CodeThe six-character alphanumeric code according to ISO 3166-2:2020, consisting of the two-letter ISO 3166-1:2020 country code and a three-character alphanumeric code for the subdivision in that country, separated by a hyphen.String
1.5.2.9 GEOGRAPHIC COORDINATES

Geographic coordinates describe an exact location in latitude, longitude, and altitude, according to ISO 6709:2022 with WGS 84 (NGA STND 0036 1.0.0) as the currently only supported coordinate reference system.

AttributeDescription(Data) Type / Code List / Enumeration
LongitudeThe geographic coordinate of a place indicating the distance to the west or east of the line passing through Greenwich, in decimal degrees (DD).Float
LatitudeThe geographic coordinate of a place indicating its distance to the north or south of the equator, in decimal degrees (DD).Float
AltitudeThe geographic coordinate of a place indicating its height above mean sea level, in meters.Float
1.5.2.10 IDENTIFIER TYPE

Identifier Type

An identifier type defines the name or category of an identifier, such as the German Handelsregisternummer, VAT number, Global Location Number (GLN), etc. The identifier type is valid for a business partner type and used in a specific country.

AttributeDescription(Data) Type / Code List / Enumeration
Technical KeyThe technical identifier of the identifier type.String
NameThe name of the identifier type.String
Business Partner TypeOne of the types of business partners for which the identifier is valid: legal entity, addressEnum
1.5.2.11 CHANGELOG ENTRY

Changelog Entry

An entry of the changelog, which is created each time a business partner is modified and contains data about the change. The actual new state of the business partner is not included.

AttributeDescription(Data) Type / Code List / Enumeration
BPNThe business partner number for which the changelog entry was created. Can be either a BPNL, BPNS or BPNA.String
Business Partner TypeOne of the types of business partners for which the changelog entry was created: legal entity, site, address.Enum
Changelog TypeOne of the actions for which the changelog entry was created: create, update.Enum
TimestampThe date and time when the changelog entry was created.Date / Time
1.5.2.12 IDENTIFIER MAPPING ENTRY

Identifier Mapping Entry

An identifier mapping entry of a specific identifier (of a specific identifier type) to a BPNL, BPNS or BPNA.

AttributeDescription(Data) Type / Code List / Enumeration
Identifier ValueThe value of a specific identifier type for which the mapping was returned.String
BPNThe business partner number for which the mapping was returned. Can be either a BPNL, BPNS or BPNA.String

2 BUSINESS PARTNER POOL API [NORMATIVE]

The Business Partner Gate API allows to upload and download business partner data records to improve their quality and enrich them with additional information. The Gate API MUST be implemented based on the OpenAPI specification (3.0.1).

2.1 PRECONDITIONS AND DEPENDENCIES

To run the API, the technical components described in the Eclipse Tractus-X BPDM GitHub repository (6.1.x) SHOULD be set up.

2.2 API SPECIFICATION

2.2.1 API ENDPOINTS & RESOURCES

The Gate API MUST be implemented as defined in the following OpenAPI document: Business Partner Data Pool OpenAPI specification (6.1.x)

The resources MUST use the well-known HTTP request methods for CRU(D) operations:

  • POST method MUST be used for create requests
  • PUT7 method MUST be used for update requests
  • GET method MUST be used for read requests

The POST method MAY also be used for read requests, if input is not given by parameters but rather by an HTTP body to bypass maximum URL length. The PUT method MAY also be used for upsert requests (create or update) if this is required. A state (active / inactive) at each entity MUST be used for a soft delete, so that the DELETE method SHALL NOT be used. Other HTTP request methods SHALL NOT be used, including PATCH.

To facilitate the compliance assessment, this chapter additionally lists and describes the API resources of the Gate API per API controller.

The following API controllers of the OpenAPI document MUST be implemented:

  • Legal entity controller
  • Site controller
  • Address controller
  • Metadata controller (code lists)
  • Changelog controller
  • BPN controller (identifier mappings)

Note that all resources of the OpenAPI document described in the following are REQUIRED. Conversely, all resources not described in the following are OPTIONAL.

The legal entity controller MUST allow to create, update, or read business partners of type legal entity (having a BPNL). It also MUST allow to read sites and addresses of a legal entity. It MUST have the following resources:

Legal Entity Controller ResourcesDescription
POST/legal-entitiesCreates a new legal entity.
PUT/legal-entitiesUpdates an existing legal entity.
GET/legal-entitiesReturns legal entities by different search parameters.
GET/legal-entities/{idValue}Returns a legal entity by an identifier, like BPNL, DUNS or EU VAT ID, specified by the identifier type.
POST/legal-entities/searchReturns legal entities by an array of BPNL.
POST/members/legal-entities/searchReturns only legal entities by an array of BPNL, which are owned by Catena-X Members.
GET/legal-entities/{bpnl}/sitesReturns all sites of a legal entity with a specific BPNL.
GET/legal-entities/{bpnl}/addressesReturns all addresses of a legal entity with a specific BPNL.
2.2.1.2 SITE CONTROLLER

The site controller MUST allow to create, update, or read business partners of type site (having a BPNS). It also MUST allow to read addresses of a site. It MUST have the following resources:

Site Controller ResourcesDescription
POST/sitesCreates a new site.
PUT/sitesUpdates an existing site.
GET/sitesReturns sites by different search parameters.
GET/sites/{bpns}Returns a site by its BPNS.
POST/sites/searchReturns sites by an array of BPNS and/or an array of corresponding BPNL.
POST/members/sites/searchReturns only sites by an array of BPNS and/or an array of corresponding BPNL, which are owned by Catena-X Members.
2.2.1.3 ADDRESS CONTROLLER

The address controller MUST allow to create, update, or read business partners of type address (having a BPNA). It MUST have the following resources:

Address Controller ResourcesDescription
POST/addressesCreates a new address.
PUT/addressesUpdates an existing address.
GET/addressesReturns addresses by different search parameters.
GET/addresses/{bpna}Returns an address by its BPNA.
POST/addresses/searchReturns addresses by an array of BPNA and/or an array of corresponding BPNS and/or an array of corresponding BPNL.
POST/members/addresses/searchReturns only addresses by an array of BPNA and/or an array of corresponding BPNS and/or an array of corresponding BPNL, which are owned by Catena-X Members.
2.2.1.4 METADATA CONTROLLER (CODE LISTS)

The metadata controller MUST allow to create or read legal forms, identifier types, and administrative areas on level 1. It MUST have the following resources:

Metadata Controller ResourcesDescription
POST/legal-formsCreates a new legal form.
POST/identifier-typesCreates a new identifier type.
POST/administrative-areas-level1Creates a new administrative area on level 1.
GET/legal-formsReturns all legal forms.
GET/identifier-typesReturns all identifier types filtered by business partner type and country.
GET/administrative-areas-level1Returns all administrative areas on level 1.
2.2.1.5 BPN CONTROLLER (IDENTIFIER MAPPINGS)

The BPN controller MUST allow to read identifier mappings between identifiers (such as DUNS, EU VAT ID, CX Member Identifier, etc.) on one side and BPNL, BPNS, BPNA on the other side. It MUST have the following resources:

BPN Controller ResourcesDescription
POST/bpn/searchReturns a list of identifier mappings of an identifier to a BPNL, BPNA or BPNS, specified by a business partner type, identifier type and identifier values.
2.2.1.6 CHANGELOG CONTROLLER

The changelog controller MUST allow to read change log entries of legal entities, sites and addresses. It MUST have the following resources:

Changelog Controller ResourcesDescription
POST/business-partners/changelog/searchReturns changelog entries of legal entities, sites and addresses as of a specified timestamp, optionally filtered by a list of BPNL, BPNS and BPNA, or business partner types.
POST/members/changelog/searchReturns only changelog entries of legal entities, sites and addresses, which are owned by Catena-X Members, as of a specified timestamp, optionally filtered by a list of BPNL, BPNS and BPNA, or business partner types.

2.2.2 AVAILABLE DATA TYPES

The API MUST use JSON as the payload format transported via HTTP. Other formats MAY be added. These are then, however, OPTIONAL.

2.2.3 DATA ASSET STRUCTURE

The following data assets MUST be registered at the Core Service Provider so that the Catena-X Member can negotiate an API usage contract with the Core Service Provider and access the BPDM Pool (hosted by the Core Service Provider) through these assets 8:

TypeSubjectVersionDescription
BPDMPoolReadAccessPoolForCatenaXMember6.1Grants the Catena-X Member read access to the Pool API. This can be used to read legal entity, site, address, legal form, identifier type and administrative area level 1 data. To that end, it also grants read access to the respective changelog and identifier mappings, as well as relational data.

Read access for legal entities, sites and address MUST be restricted to Catena-X Member data (see the corresponding attribute for legal entity, site and address), because the Pool may also contain legal entities, sites and address, which are not owned by Catena-X Members.

Write resources (create and update) of the Pool API MUST NOT be called from outside of the Catena-X operating environment. Consequently, data assets for them are NOT REQUIRED.

Example data asset (dct:type for asset type, dct:subject for asset subject, dct:description for asset description and cx-common:version for asset version from the table above):

{
"@context": {
"dct": "https://purl.org/dc/terms/",
"cx-taxo": "https://w3id.org/catenax/taxonomy#",
"cx-common": "https://w3id.org/catenax/ontology/common#",
},
"@type": "Asset",
"@id": "e94272b1-9831-458f-8986-c63c4973ea60",
"properties": {
"dct:type": {
"@id": "cx-taxo:BPDMPool"
},
"dct:subject": {
"@id": "cx-taxo:ReadAccessPoolForCatenaXMember"
},
"dct:description": "Grants the Catena-X Member read access to the Pool API. This can be used to read legal entity, site, address, legal form, identifier type and administrative area level 1 data. To that end, it also grants read access to the respective changelog entries and identifier mappings, as well as relational data.",
"cx-common:version": "6.1"
},
"dataAddress": {
"@type": "DataAddress",
"type": "HttpData",
"baseUrl": "https://<host>/pool/api/v6/members",
"oauth2:tokenUrl": "https://<host>/auth/realms/<realm>/protocol/openid-connect/token",
"oauth2:clientId": "<technical user>",
"oauth2:clientSecretKey": "<key to the secret of the technical user in the vault>",
"proxyMethod": true,
"proxyPath": true,
"proxyQueryParams": true,
"proxyBody": true
}
}

The OAuth2 client permissions MUST be configured to solely allow access to the API resources defined in the corresponding asset, checking HTTP method, path, query parameters and body of the HTTP request sent to the data plane public API which acts as a proxy for the BPDM Pool API9.

2.2.4 ERROR HANDLING

The following http response codes MUST be defined for all resources:

  • 200 - OK
  • 400 - Bad Request
  • 401 - Unauthorized
  • 403 - Forbidden
  • 404 - Not Found
  • 500 - Internal Server Error

The IANA HTTP Status Code Registry MUST be adhered to for the decision on when to use which error code.

2.2.5 ADDITIONAL REQUIREMENTS

2.2.5.1 CONVENTIONS FOR USE CASE POLICY IN CONTEXT OF DATA EXCHANGE

In alignment with our commitment to data sovereignty, a specific framework governing the utilization of data within the Catena-X use cases has been outlined. A set of specific policies on data offering and data usage level detail the conditions under which data may be accessed, shared, and used, ensuring compliance with legal standards.

For a comprehensive understanding of the rights, restrictions, and obligations associated with data usage in the Catena-X ecosystem, we refer users to

  • the detailed ODRL policy repository. This document provides in-depth explanations of the terms and conditions applied to data access and utilization, ensuring that all engagement with our data is conducted responsibly and in accordance with established guidelines.
  • the ODRL schema template. This defines how policies used for data sharing/usage should get defined. Those schemas MUST be followed when providing services or apps for data sharing/consuming.
2.2.5.2 ADDITIONAL DETAILS REGARDING ACCESS POLICIES

A Data Provider may tie certain access authorizations ("Access Policies") to its data offers for members of Catena-X and one or several Data Consumers. By limiting access to certain Participants, Data Provider maintains control over its anti-trust obligations when sharing certain data. In particular, Data Provider may apply Access Policies to restrict access to a particular data offer for only one Participant identified by a specific business partner number.

  • Membership
  • BPNL
2.2.5.3 ADDITIONAL DETAILS REGARDING USAGE POLICIES

In the context of data usage policies (“Usage Policies”), Participants and related services MUST use the following policy rules:

  • Use Case Framework (“FrameworkAgreement”)
  • at least one use case purpose (“UsagePurpose”) from the above mentioned ODRL policy repository.

Additionally, respective usage policies MAY include the following policy rule:

  • Reference Contract (“ContractReference”).

Details on namespaces and ODRL policy rule values to be used for the above-mentioned types are provided via the ODRL policy repository.

3 REFERENCES

3.1 NORMATIVE REFERENCES

3.2 NON-NORMATIVE REFERENCES

This section is non-normative

3.3 REFERENCE IMPLEMENTATIONS

This section is non-normative

ANNEXES

FIGURES

This section is non-normative

Intentionally left blank.

TABLES

This section is non-normative

Intentionally left blank.

Copyright © 2024 Catena-X Automotive Network e.V. All rights reserved. For more information, please visit here.

Footnotes

  1. Note that PlantUml is used for the conceptual UML diagrams in this document (A = abstract class; green E = entity; C = class; red E = enumeration). An abstract class has no actual representation in the OpenAPI implementation. An entity is usually implemented by an own OpenAPI controller with resources and usually is the root in a payload, while a class is a sub node in the payload. An enumeration is a set of predefined values.

  2. These types always imply a business partner which means that legal entity, site, and address are types of business partners.

  3. Note that this a currently a soft-delete approach and not a business state. However, this can be adapted in the next version of this standard.

  4. Note that there is currently a debate as to whether a site is only a consolidation of addresses (BPNA), with all addresses being equally ranked, since a "main" address can't always be defined at this point in time. This may lead to changes in the next update of this standard. 2 3 4 5 6

  5. Note that this a currently a soft-delete approach and not a business state. However, this can be adapted in the next version of this standard.

  6. Note that this a currently a soft-delete approach and not a business state. However, this can be adapted in the next version of this standard.

  7. Note that in case of a PUT the corresponding resources expect to receive the full updated record, including values that did not change.

  8. Note that further assets will most probably be introduced in one of the next versions of this standard.

  9. Note that the definition of the data assets depends on the current implementation state of the reference implementation (Tractus-X Eclipse Dataspace Connector). Therefore the data assets represent permissions on APIs, whereas they should actually only represent APIs.