설명자 엔드포인트

스키마는 데이터 엔티티의 정적 보기를 정의하지만 이러한 스키마를 기반으로 하는 데이터(예: 데이터 세트)가 서로 관련될 수 있는 방법에 대한 특정 세부 정보는 제공하지 않습니다. Adobe Experience Platform에서는 설명자를 사용하여 스키마에 대한 이러한 관계와 기타 해석적인 메타데이터를 설명할 수 있습니다.

스키마 설명자는 테넌트 수준의 메타데이터입니다. 즉, 조직에 고유하며 모든 설명자 작업이 테넌트 컨테이너에서 수행됩니다.

각 스키마에는 하나 이상의 스키마 설명자 엔티티가 적용될 수 있습니다. 각 스키마 디스크립터 엔티티는 디스크립터를 포함한다 @typesourceSchema 적용 대상. 이 설명자가 적용되면 스키마를 사용하여 만든 모든 데이터 세트에 적용됩니다.

다음 /descriptors 의 엔드포인트 Schema Registry API를 사용하면 경험 애플리케이션 내의 설명자를 프로그래밍 방식으로 관리할 수 있습니다.

시작하기

이 안내서에 사용된 끝점은 Schema Registry API. 계속하기 전에 다음을 검토하십시오. 시작 안내서 관련 설명서에 대한 링크, 이 문서의 샘플 API 호출 읽기에 대한 안내서 및 Experience Platform API를 성공적으로 호출하는 데 필요한 필수 헤더에 대한 중요 정보입니다.

설명자 목록 검색 list

에 GET 요청을 하여 조직에서 정의한 모든 설명자를 나열할 수 있습니다. /tenant/descriptors.

API 형식

GET /tenant/descriptors

요청

curl -X GET \
  https://platform.adobe.io/data/foundation/schemaregistry/tenant/descriptors \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}' \
  -H 'Accept: application/vnd.adobe.xdm-link+json'

응답 형식은 다음에 따라 다릅니다. Accept 헤더가 요청에서 전송되었습니다. 다음 사항에 주목하십시오. /descriptors 엔드포인트 사용 Accept 의 다른 모든 끝점과 다른 헤더 Schema Registry API.

IMPORTANT
설명자는 고유해야 합니다. Accept 대체할 헤더 xed 포함 xdm, 및 link 설명자에 고유한 옵션입니다. 더 프로퍼트 Accept 아래 예제 호출에 헤더가 포함되었지만 설명자를 사용하여 작업할 때 올바른 헤더가 사용되고 있는지 각별히 주의하십시오.
Accept 머리글
설명
application/vnd.adobe.xdm-id+json
설명자 ID 배열 반환
application/vnd.adobe.xdm-link+json
설명자 API 경로 배열 반환
application/vnd.adobe.xdm+json
확장된 설명자 개체의 배열을 반환합니다.
application/vnd.adobe.xdm-v2+json
Accept 페이징 기능을 사용하려면 헤더를 사용해야 합니다.

응답

응답에는 설명자가 정의된 각 설명자 유형에 대한 배열이 포함됩니다. 즉, 특정 항목의 설명자가 없는 경우 @type 정의된 경우 레지스트리는 해당 설명자 유형에 대해 빈 배열을 반환하지 않습니다.

사용 시 link Accept 헤더, 각 설명자는 형식으로 배열 항목으로 표시됨 /{CONTAINER}/descriptors/{DESCRIPTOR_ID}

{
  "xdm:alternateDisplayInfo": [
    "/tenant/descriptors/85dc1bc8b91516ac41163365318e38a9f1e4f351",
    "/tenant/descriptors/49bd5abb5a1310ee80ebc1848eb508d383a462cf",
    "/tenant/descriptors/b3b3e548f1c653326bcf5459ceac4140fc0b9e08"
  ],
  "xdm:descriptorIdentity": [
    "/tenant/descriptors/f7a4bc25429496c4740f8f9a7a49ba96862c5379"
  ],
  "xdm:descriptorOneToOne": [
    "/tenant/descriptors/cb509fd6f8ab6304e346905441a34b58a0cd481a"
  ]
}

설명자 조회 lookup

특정 설명자의 세부 정보를 보려면 해당 설명자를 사용하여 개별 설명자를 조회(GET)할 수 있습니다 @id.

API 형식

GET /tenant/descriptors/{DESCRIPTOR_ID}
매개변수
설명
{DESCRIPTOR_ID}
다음 @id 조회하려는 설명자.

요청

다음 요청은 설명자를 로 검색합니다. @id 값. 설명자에 버전이 없으므로 Accept 조회 요청에는 헤더가 필요합니다.

curl -X GET \
  https://platform.adobe.io/data/foundation/schemaregistry/tenant/descriptors/f3a1dfa38a4871cf4442a33074c1f9406a593407 \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}'

응답

성공적인 응답은 해당 정보를 포함한 설명자의 세부 정보를 반환합니다 @typesourceSchema설명자 유형에 따라 달라지는 추가 정보도 포함됩니다. 반환된 @id 은(는) 설명자와 일치해야 합니다 @id 요청에 제공됩니다.

{
  "@type": "xdm:descriptorIdentity",
  "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/fbc52b243d04b5d4f41eaa72a8ba58be",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/personalEmail/address",
  "xdm:namespace": "Email",
  "xdm:property": "xdm:code",
  "xdm:isPrimary": false,
  "createdUser": "{CREATED_USER}",
  "imsOrg": "{ORG_ID}",
  "createdClient": "{CREATED_CLIENT}",
  "updatedUser": "{UPDATED_USER}",
  "created": 1548899346989,
  "updated": 1548899346989,
  "meta:containerId": "tenant",
  "@id": "f3a1dfa38a4871cf4442a33074c1f9406a593407"
}

설명자 만들기 create

에 POST 요청을 하여 새 설명자를 만들 수 있습니다. /tenant/descriptors 엔드포인트.

IMPORTANT
다음 Schema Registry 여러 다른 설명자 유형을 정의할 수 있습니다. 각 설명자 유형은 요청 본문에 보낼 고유한 필드를 필요로 합니다. 다음을 참조하십시오. 부록 설명자의 전체 목록과 설명자를 정의하는 데 필요한 필드를 보려면 여기를 클릭하십시오.

API 형식

POST /tenant/descriptors

요청

다음 요청은 샘플 스키마의 "이메일 주소" 필드에 ID 설명자를 정의합니다. 이는 다음을 말해줍니다. Experience Platform 개인에 대한 정보를 결합하는 데 도움이 되는 식별자로 이메일 주소를 사용합니다.

curl -X POST \
  https://platform.adobe.io/data/foundation/schemaregistry/tenant/descriptors \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'Content-Type: application/json' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}' \
  -d '
      {
        "@type": "xdm:descriptorIdentity",
        "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/fbc52b243d04b5d4f41eaa72a8ba58be",
        "xdm:sourceVersion": 1,
        "xdm:sourceProperty": "/personalEmail/address",
        "xdm:namespace": "Email",
        "xdm:property": "xdm:code",
        "xdm:isPrimary": false
      }'

응답

성공적인 응답은 HTTP 상태 201(생성됨)과, 해당 값을 포함하여 새로 생성된 설명자의 세부 정보를 반환합니다 @id. 다음 @id 은(는) 다음에 의해 할당된 읽기 전용 필드입니다. Schema Registry API의 설명자를 참조하는 데 사용됩니다.

{
  "@type": "xdm:descriptorIdentity",
  "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/fbc52b243d04b5d4f41eaa72a8ba58be",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/personalEmail/address",
  "xdm:namespace": "Email",
  "xdm:property": "xdm:code",
  "xdm:isPrimary": false,
  "meta:containerId": "tenant",
  "@id": "f3a1dfa38a4871cf4442a33074c1f9406a593407"
}

설명자 업데이트 put

다음을 포함하여 설명자를 업데이트할 수 있습니다. @id PUT 요청의 경로에 있습니다.

API 형식

PUT /tenant/descriptors/{DESCRIPTOR_ID}
매개변수
설명
{DESCRIPTOR_ID}
다음 @id 업데이트하려는 설명자.

요청

이 요청은 본질적으로 설명자를 재작성하므로 요청 본문에는 해당 유형의 설명자를 정의하는 데 필요한 모든 필드가 포함되어야 합니다. 즉, 설명자를 업데이트(PUT)하기 위한 요청 페이로드는 페이로드와 동일합니다 설명자 만들기(POST) 같은 종류의

IMPORTANT
POST 요청을 사용하여 설명자를 만드는 경우와 마찬가지로, 각 설명자 유형에는 고유한 필드가 PUT 요청 페이로드에서 전송되어야 합니다. 다음을 참조하십시오. 부록 설명자의 전체 목록과 설명자를 정의하는 데 필요한 필드를 보려면 여기를 클릭하십시오.

다음 예제에서는 다른 ID 설명자를 참조하도록 ID 설명자를 업데이트합니다 xdm:sourceProperty (mobile phone) 및 변경 xdm:namespacePhone.

curl -X PUT \
  https://platform.adobe.io/data/foundation/schemaregistry/tenant/descriptors/f3a1dfa38a4871cf4442a33074c1f9406a593407 \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'Content-Type: application/json' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}' \
  -d '{
        "@type": "xdm:descriptorIdentity",
        "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/fbc52b243d04b5d4f41eaa72a8ba58be",
        "xdm:sourceVersion": 1,
        "xdm:sourceProperty": "/mobilePhone/number",
        "xdm:namespace": "Phone",
        "xdm:property": "xdm:code",
        "xdm:isPrimary": false
      }'

응답

성공적인 응답은 HTTP 상태 201(생성됨) 및 @id 업데이트된 설명자의 (과 일치해야 함) @id (요청에서 전송됨).

{
    "@id": "f3a1dfa38a4871cf4442a33074c1f9406a593407"
}

수행 조회(GET) 요청 설명자를 보려면 PUT 요청에서 전송된 변경 사항을 반영하도록 필드가 업데이트되었음을 보여 줍니다.

설명자 삭제 delete

간혹 정의한 설명자를 다음에서 제거해야 할 수 있습니다. Schema Registry. 이 작업은 를 참조하는 DELETE 요청을 통해 수행됩니다. @id 제거할 설명자의 이름입니다.

API 형식

DELETE /tenant/descriptors/{DESCRIPTOR_ID}
매개변수
설명
{DESCRIPTOR_ID}
다음 @id / 삭제하려는 설명자.

요청

curl -X DELETE \
  https://platform.adobe.io/data/foundation/schemaregistry/tenant/descriptors/ca921946fb5281cbdb8ba5e07087486ce531a1f2  \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {ORG_ID}' \
  -H 'x-sandbox-name: {SANDBOX_NAME}'

응답

성공적인 응답은 HTTP 상태 204(콘텐츠 없음) 및 빈 본문을 반환합니다.

설명자가 삭제되었는지 확인하기 위해 다음을 수행할 수 있습니다. 조회 요청 설명자에 대해 @id. 설명자가 다음에서 제거되었으므로 응답에서 HTTP 상태 404(찾을 수 없음)를 반환합니다. Schema Registry.

부록

다음 단원에서는 설명자 작업에 대한 추가 정보를 제공합니다 Schema Registry API.

설명자 정의 defining-descriptors

다음 섹션에서는 각 유형의 설명자를 정의하는 데 필요한 필드를 포함하여 사용 가능한 설명자 유형에 대한 개요를 제공합니다.

IMPORTANT
시스템이 해당 샌드박스의 모든 사용자 정의 필드에 해당 레이블을 적용하므로 테넌트 네임스페이스 개체에 레이블을 지정할 수 없습니다. 대신 레이블을 지정해야 하는 개체 아래에 리프 노드를 지정해야 합니다.

ID 설명자

ID 설명자는 "라는 신호를 보냅니다.sourceProperty의 "source스키마"은(는) Identity 다음에 의해 설명된 필드 Adobe Experience Platform ID 서비스.

{
  "@type": "xdm:descriptorIdentity",
  "xdm:sourceSchema":
    "https://ns.adobe.com/{TENANT_ID}/schemas/fbc52b243d04b5d4f41eaa72a8ba58be",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/personalEmail/address",
  "xdm:namespace": "Email",
  "xdm:property": "xdm:code",
  "xdm:isPrimary": false
}
속성
설명
@type
정의 중인 설명자 유형. ID 설명자의 경우 이 값을 로 설정해야 합니다. xdm:descriptorIdentity.
xdm:sourceSchema
다음 $id 설명자가 정의되는 스키마의 URI입니다.
xdm:sourceVersion
소스 스키마의 주 버전.
xdm:sourceProperty
ID가 될 특정 속성에 대한 경로입니다. 경로는 "/"로 시작하고 1로 끝나지 않아야 합니다. 경로에 "속성"을 포함하지 마십시오(예: "/properties/personalEmail/properties/address" 대신 "/personalEmail/address" 사용).
xdm:namespace
다음 id 또는 code id 네임스페이스 값입니다. 네임스페이스 목록은 Identity Service API.
xdm:property
다음 중 하나 xdm:id 또는 xdm:code, 다음에 따라 xdm:namespace 사용됨.
xdm:isPrimary
선택적 부울 값입니다. true인 경우 는 필드를 기본 ID로 나타냅니다. 스키마에는 기본 ID가 하나만 포함될 수 있습니다.

설명자에 대한 알기 쉬운 이름 friendly-name

사용자는 친숙한 이름 설명자를 사용하여 title, description, 및 meta:enum 코어 라이브러리 스키마 필드의 값. 특히 조직에 관련된 정보를 포함하는 것으로 레이블을 지정하려는 "eVar" 및 기타 "일반" 필드로 작업할 때 유용합니다. UI는 이러한 매개 변수를 사용하여 보다 친숙한 이름을 표시하거나 친숙한 이름이 있는 필드만 표시할 수 있습니다.

{
  "@type": "xdm:alternateDisplayInfo",
  "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/274f17bc5807ff307a046bab1489fb18",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/xdm:eventType",
  "xdm:title": {
    "en_us": "Event Type"
  },
  "xdm:description": {
    "en_us": "The type of experience event detected by the system."
  },
  "meta:enum": {
    "click": "Mouse Click",
    "addCart": "Add to Cart",
    "checkout": "Cart Checkout"
  },
  "xdm:excludeMetaEnum": {
    "web.formFilledOut": "Web Form Filled Out",
    "media.ping": "Media ping"
  }
}
속성
설명
@type
정의 중인 설명자 유형. 친숙한 이름 설명자의 경우 이 값을 로 설정해야 합니다. xdm:alternateDisplayInfo.
xdm:sourceSchema
다음 $id 설명자가 정의되는 스키마의 URI입니다.
xdm:sourceVersion
소스 스키마의 주 버전.
xdm:sourceProperty
세부 정보를 수정할 특정 속성의 경로입니다. 경로는 슬래시(/) 로 끝나지 않습니다. 포함하지 않음 properties 경로(예: /personalEmail/address 대신 /properties/personalEmail/properties/address).
xdm:title
이 필드에 표시할 새 제목(제목 대/소문자로 작성됨)입니다.
xdm:description
제목과 함께 선택적 설명을 추가할 수 있습니다.
meta:enum
필드가 로 표시되는 경우 xdm:sourceProperty 은(는) 문자열 필드입니다. meta:enum 는 세분화 UI의 필드에 대해 제안된 값을 추가하는 데 사용할 수 있습니다. 주의할 점은 다음과 같습니다 meta:enum 는 열거형을 선언하거나 XDM 필드에 대한 데이터 유효성 검사를 제공하지 않습니다.

Adobe으로 정의된 코어 XDM 필드에만 사용해야 합니다. 소스 속성이 조직에서 정의한 사용자 정의 필드인 경우 대신 의 필드를 편집해야 합니다 meta:enum 필드의 상위 리소스에 대한 PATCH 요청을 통해 직접 속성을 작성합니다.
meta:excludeMetaEnum
필드가 로 표시되는 경우 xdm:sourceProperty 는 아래에 제공된 기존 제안 값이 있는 문자열 필드입니다. meta:enum 필드에서는 친숙한 이름 설명자에 이 객체를 포함하여 이러한 값의 일부 또는 모두를 세그먼테이션에서 제외할 수 있습니다. 각 항목의 키 및 값은 원본에 포함된 키와 일치해야 합니다 meta:enum : 항목을 제외하기 위한 필드입니다.

관계 설명자

관계 설명자는에 설명된 속성을 기준으로 두 개의 서로 다른 스키마 간의 관계를 설명합니다. sourcePropertydestinationProperty. 다음 튜토리얼 참조: 두 스키마 간의 관계 정의 추가 정보.

{
  "@type": "xdm:descriptorOneToOne",
  "xdm:sourceSchema":
    "https://ns.adobe.com/{TENANT_ID}/schemas/fbc52b243d04b5d4f41eaa72a8ba58be",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/parentField/subField",
  "xdm:destinationSchema":
    "https://ns.adobe.com/{TENANT_ID}/schemas/78bab6346b9c5102b60591e15e75d254",
  "xdm:destinationVersion": 1,
  "xdm:destinationProperty": "/parentField/subField"
}
속성
설명
@type
정의 중인 설명자 유형. 관계 설명자의 경우 이 값을 로 설정해야 합니다. xdm:descriptorOneToOne.
xdm:sourceSchema
다음 $id 설명자가 정의되는 스키마의 URI입니다.
xdm:sourceVersion
소스 스키마의 주 버전.
xdm:sourceProperty
관계가 정의되는 소스 스키마의 필드 경로. "/"로 시작하고 1로 끝나지 않아야 합니다. 경로에 "속성"을 포함하지 마십시오(예: "/properties/personalEmail/properties/address" 대신 "/personalEmail/address").
xdm:destinationSchema
다음 $id 해당 설명자가 관계를 정의하는 참조 스키마의 URI입니다.
xdm:destinationVersion
참조 스키마의 주 버전.
xdm:destinationProperty
참조 스키마 내의 대상 필드에 대한 선택적 경로입니다. 이 속성을 생략하면 일치하는 참조 ID 설명자가 포함된 모든 필드에서 대상 필드를 유추합니다(아래 참조).

참조 ID 설명자

참조 ID 설명자는 스키마 필드의 기본 ID에 대한 참조 컨텍스트를 제공하여 다른 스키마의 필드에서 참조할 수 있도록 합니다. 참조 스키마에는 이미 기본 ID 필드가 정의되어 있어야 해당 설명자를 통해 다른 스키마에서 참조할 수 있습니다.

{
  "@type": "xdm:descriptorReferenceIdentity",
  "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/78bab6346b9c5102b60591e15e75d254",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/parentField/subField",
  "xdm:identityNamespace": "Email"
}
속성
설명
@type
정의 중인 설명자 유형. 참조 ID 설명자의 경우 이 값을 로 설정해야 합니다. xdm:descriptorReferenceIdentity.
xdm:sourceSchema
다음 $id 설명자가 정의되는 스키마의 URI입니다.
xdm:sourceVersion
소스 스키마의 주 버전.
xdm:sourceProperty
참조 스키마를 참조하는 데 사용할 소스 스키마의 필드 경로입니다. "/"로 시작하고 1로 끝나지 않아야 합니다. 경로에 "속성"을 포함하지 마십시오(예: /personalEmail/address 대신 /properties/personalEmail/properties/address).
xdm:identityNamespace
소스 속성에 대한 ID 네임스페이스 코드.

사용되지 않는 필드 설명자

다음을 수행할 수 있습니다. 사용자 지정 XDM 리소스 내의 필드 사용 중단 를 추가하여 meta:status 속성이 로 설정됨 deprecated 을(를) 해당 필드에 보냅니다. 그러나 스키마의 표준 XDM 리소스에서 제공하는 필드를 사용하지 않으려면 해당 스키마에 더 이상 사용되지 않는 필드 설명자를 할당하여 동일한 효과를 얻을 수 있습니다. 사용 정답 Accept 머리글그런 다음 API에서 조회할 때 스키마에 대해 더 이상 사용되지 않는 표준 필드를 확인할 수 있습니다.

{
  "@type": "xdm:descriptorDeprecated",
  "xdm:sourceSchema": "https://ns.adobe.com/{TENANT_ID}/schemas/c65ddf08cf2d4a2fe94bd06113bf4bc4c855e12a936410d5",
  "xdm:sourceVersion": 1,
  "xdm:sourceProperty": "/faxPhone"
}
속성
설명
@type
설명자 유형. 필드 사용 중단 설명자의 경우 이 값을 로 설정해야 합니다. xdm:descriptorDeprecated.
xdm:sourceSchema
URI $id 설명자를 적용 중인 스키마 의 입니다.
xdm:sourceVersion
설명자를 적용 중인 스키마 버전입니다. 을(를) (으)로 설정해야 함 1.
xdm:sourceProperty
설명자를 적용하는 스키마 내의 속성에 대한 경로입니다. 설명자를 여러 속성에 적용하려면 경로 목록을 배열 형식으로 제공할 수 있습니다(예: ["/firstName", "/lastName"]).
recommendation-more-help
62e9ffd9-1c74-4cef-8f47-0d00af32fc07