역할 끝점

마지막 업데이트: 2023-10-05
  • 작성 대상:
  • Developer
    User
    Admin
    Leader
노트

사용자 토큰이 전달되는 경우 토큰의 사용자는 요청된 조직에 대한 "조직 관리자" 역할이 있어야 합니다.

역할은 관리자, 전문가 또는 최종 사용자가 조직의 리소스에 액세스할 수 있는 권한을 정의합니다. 역할 기반 액세스 제어 환경에서 사용자 액세스 프로비저닝은 일반적인 책임과 요구 사항을 통해 그룹화됩니다. 역할에는 주어진 권한 집합이 있으며, 조직의 멤버들은 필요한 보기 또는 쓰기 액세스 범위에 따라 하나 이상의 역할에 할당될 수 있습니다.

다음 /roles 속성 기반 액세스 제어 API의 끝점을 사용하면 조직의 역할을 프로그래밍 방식으로 관리할 수 있습니다.

시작하기

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

역할 목록 검색

에 GET 요청을 하여 조직에 속한 기존 역할을 모두 나열할 수 있습니다. /roles 엔드포인트.

API 형식

GET /roles/

요청

다음 요청은 조직에 속한 역할 목록을 검색합니다.

curl -X GET \
  https://platform.adobe.io/data/foundation/access-control/administration/roles \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}' \

응답

성공적인 응답은 각 역할 유형, 권한 집합 및 제목 속성에 대한 정보를 포함하여 조직의 역할 목록을 반환합니다.

{
  "roles": [
    {
      "id": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
      "name": "Administrator Role",
      "description": "Role for administrator type of responsibilities and access",
      "roleType": "user-defined",
      "permissionSets": [
        "manage-datasets",
        "manage-schemas"
      ],
      "sandboxes": [
        "prod"
      ],
      "subjectAttributes": {
        "labels": [
          "core/S1"
        ]
      },
      "createdBy": "{CREATED_BY}",
      "createdAt": 1648153201825,
      "modifiedBy": "{MODIFIED_BY}",
      "modifiedAt": 1648153201825,
      "etag": null
    }
  ],
  "_page": {
    "limit": 1,
    "count": 1
  },
  "_links": {
    "next": {
      "href": "https://platform.adobe.io:443/data/foundation/access-control/administration/roles/3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
      "templated": true
    },
    "page": {
      "href": "https://platform.adobe.io:443/data/foundation/access-control/administration/roles/3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
      "templated": true
    },
    "subjects": {
      "href": "https://platform.adobe.io:443/data/foundation/access-control/administration/roles/3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
      "templated": true
    }
  }
}
속성 설명
id 역할에 해당하는 ID입니다. 이 ID는 자동으로 생성됩니다.
name 역할의 이름입니다.
description description 속성은 역할에 대한 추가 정보를 제공합니다.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.
permissionSets 권한 집합은 관리자가 역할에 적용할 수 있는 권한 그룹을 나타냅니다. 관리자는 개별 권한을 할당하는 대신 역할에 권한 집합을 할당할 수 있습니다. 이를 통해 권한 그룹을 포함하는 사전 정의된 역할에서 사용자 정의 역할을 만들 수 있습니다.
sandboxes 이 속성은 특정 역할에 대해 프로비저닝된 조직 내의 샌드박스를 표시합니다.
subjectAttributes 주체와 주체가 액세스할 수 있는 Platform 리소스 간의 상관 관계를 나타내는 특성입니다.
subjectAttributes.labels 쿼리된 역할에 적용되는 데이터 사용 레이블을 표시합니다.

역할 조회

해당하는 역할을 포함하는 GET 요청을 만들어 개별 역할을 조회할 수 있습니다 roleId 요청 경로에서.

API 형식

GET /roles/{ROLE_ID}
매개변수 설명
조회할 역할의 ID입니다.

요청

다음 요청은 다음에 대한 정보를 검색합니다. {ROLE_ID}.

curl -X GET \
  https://platform.adobe.io/data/foundation/access-control/administration/roles/3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809 \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}' \

응답

성공한 응답은 역할 유형, 권한 집합 및 주체 특성에 대한 정보를 포함하여 쿼리된 역할 ID에 대한 세부 정보를 반환합니다.

{
  "id": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
  "name": "Administrator Role",
  "description": "Role for administrator type of responsibilities and access",
  "roleType": "user-defined",
  "permissionSets": [
    "manage-datasets",
    "manage-schemas"
  ],
  "sandboxes": [
    "prod"
  ],
  "subjectAttributes": {
    "labels": [
      "core/S1"
    ]
  },
  "createdBy": "{CREATED_BY}",
  "createdAt": 1648153201825,
  "modifiedBy": "{MODIFIED_BY}",
  "modifiedAt": 1648153201825,
  "etag": null
}
속성 설명
id 역할에 해당하는 ID입니다. 이 ID는 자동으로 생성됩니다.
name 역할의 이름입니다.
description description 속성은 역할에 대한 추가 정보를 제공합니다.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.
permissionSets 권한 집합은 관리자가 역할에 적용할 수 있는 권한 그룹을 나타냅니다. 관리자는 개별 권한을 할당하는 대신 역할에 권한 집합을 할당할 수 있습니다. 이를 통해 권한 그룹을 포함하는 사전 정의된 역할에서 사용자 정의 역할을 만들 수 있습니다.
sandboxes 이 속성은 특정 역할에 대해 프로비저닝된 조직 내의 샌드박스를 표시합니다.
subjectAttributes 주체와 주체가 액세스할 수 있는 Platform 리소스 간의 상관 관계를 나타내는 특성입니다.
subjectAttributes.labels 쿼리된 역할에 적용되는 데이터 사용 레이블을 표시합니다.

역할 ID로 주제 조회

에 GET 요청을 하여 제목을 검색할 수도 있습니다. /roles 를 제공하는 동안 엔드포인트 {ROLE_ID}.

API 형식

GET /roles/{ROLE_ID}/subjects
매개변수 설명
조회할 주체와 연관된 역할의 ID입니다.

요청

다음 요청은 과 연관된 주제를 검색합니다. 3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809.

curl -X GET \
  https://platform.adobe.io/data/foundation/access-control/administration/roles/3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809/subjects \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}' \

응답

성공적인 응답은 해당 주체 ID 및 주체 유형을 포함하여 쿼리된 역할 ID와 연관된 주제를 반환합니다.

{
  "items": [
      {
          "roleId": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
          "subjectType": "user",
          "subjectId": "03Z07HFQCCUF3TUHAX274206@AdobeID"
      },
      {
          "roleId": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
          "subjectType": "user",
          "subjectId": "PIRJ7WE5T3QT9Z4TCLVH86DE@AdobeID"
      },
      {
          "roleId": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
          "subjectType": "user",
          "subjectId": "WHPWE00MC26SHZ7AKBFG403D@AdobeID"
      },
  ]
  "_page": {
    "limit": 0,
    "count": 0
  },
  "_links": {
      "self": {
          "href": "/roles/{ROLE_ID}/subjects",
          "templated": false,
          "type": null,
          "method": null
      },
      "page": {
          "href": "/roles/{ROLE_ID}/subjects?limit={limit}&start={start}&orderBy={orderBy}&property={property}",
          "templated": true,
          "type": null,
          "method": null
      }
  }
}
속성 설명
roleId 쿼리된 제목과 연결된 역할 ID입니다.
subjectType 쿼리된 제목의 유형입니다.
subjectId 쿼리된 제목에 해당하는 ID입니다.

역할 만들기

새 역할을 만들려면 POST 요청을에 /roles 역할의 이름, 설명 및 역할 유형에 대한 값을 제공하는 동안 끝점이 발생했습니다.

API 형식

POST /roles/

요청

curl -X POST \
  https://platform.adobe.io/data/foundation/access-control/administration/roles \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}'
  -d'{
    "name": "Administrator Role",
    "description": "Role for administrator type of responsibilities and access",
    "roleType": "user-defined"
  }'
속성 설명
name 역할의 이름입니다. 이 기능을 사용하여 역할에 대한 정보를 조회할 수 있으므로 역할 이름이 설명적인지 확인하십시오.
description (선택 사항) 역할에 대한 자세한 정보를 제공하기 위해 포함할 수 있는 설명 값입니다.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.

응답

성공적인 응답은 해당 역할 ID는 물론, 역할 유형, 권한 집합 및 주체 특성에 대한 정보와 함께 새로 만든 역할을 반환합니다.

{
  "id": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
  "name": "Administrator Role",
  "description": "Role for administrator type of responsibilities and access",
  "roleType": "user-defined",
  "permissionSets": [
    "manage-datasets",
    "manage-schemas"
  ],
  "sandboxes": [
    "prod"
  ],
  "subjectAttributes": {
    "labels": [
      "core/S1"
    ]
  },
  "createdBy": "{CREATED_BY}",
  "createdAt": 1648153201825,
  "modifiedBy": "{MODIFIED_BY}",
  "modifiedAt": 1648153201825,
  "etag": null
}
속성 설명
id 역할에 해당하는 ID입니다. 이 ID는 자동으로 생성됩니다.
name 역할의 이름입니다.
description description 속성은 역할에 대한 추가 정보를 제공합니다.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.
permissionSets 권한 집합은 관리자가 역할에 적용할 수 있는 권한 그룹을 나타냅니다. 관리자는 개별 권한을 할당하는 대신 역할에 권한 집합을 할당할 수 있습니다. 이를 통해 권한 그룹을 포함하는 사전 정의된 역할에서 사용자 정의 역할을 만들 수 있습니다.
sandboxes 이 속성은 특정 역할에 대해 프로비저닝된 조직 내의 샌드박스를 표시합니다.
subjectAttributes 주체와 주체가 액세스할 수 있는 Platform 리소스 간의 상관 관계를 나타내는 특성입니다.
subjectAttributes.labels 쿼리된 역할에 적용되는 데이터 사용 레이블을 표시합니다.

역할 업데이트

에 PATCH 요청을 하여 역할의 속성을 업데이트할 수 있습니다. /roles 적용할 작업에 해당 역할 ID 및 값을 제공하는 동안 끝점이 발생했습니다.

API 형식

PATCH /roles/{ROLE_ID}
매개변수 설명
업데이트할 역할의 ID입니다.

요청

curl -X PATCH \
  https://platform.adobe.io/data/foundation/access-control/administration/roles/{ROLE_ID} \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}'
  -d'{
    "operations": [
      {
        "op": "add",
        "path": "/description",
        "value": "Role with permission sets for admin type of access"
      }
    ]
  }'
작업 설명
op 역할을 업데이트하는 데 필요한 작업을 정의하는 데 사용되는 작업 호출입니다. 작업에는 다음이 포함됩니다. add, replace, 및 remove.
path 업데이트할 매개 변수의 경로입니다.
value 매개 변수를 업데이트할 새 값입니다.

응답

성공한 응답은 업데이트하도록 선택한 속성에 대한 새 값을 포함하여 업데이트된 역할을 반환합니다.

{
  "id": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
  "name": "Administrator Role",
  "description": "Role with permission sets for admin type of access",
  "roleType": "user-defined",
  "permissionSets": [
    "manage-datasets",
    "manage-schemas"
  ],
  "sandboxes": [
    "prod"
  ],
  "subjectAttributes": {
    "labels": [
      "core/S1"
    ]
  },
  "createdBy": "{CREATED_BY}",
  "createdAt": 1648153201825,
  "modifiedBy": "{MODIFIED_BY}",
  "modifiedAt": 1648153201825,
  "etag": null
}
속성 설명
id 역할에 해당하는 ID입니다. 이 ID는 자동으로 생성됩니다.
name 역할의 이름입니다.
description description 속성은 역할에 대한 추가 정보를 제공합니다.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.
permissionSets 권한 집합은 관리자가 역할에 적용할 수 있는 권한 그룹을 나타냅니다. 관리자는 개별 권한을 할당하는 대신 역할에 권한 집합을 할당할 수 있습니다. 이를 통해 권한 그룹을 포함하는 사전 정의된 역할에서 사용자 정의 역할을 만들 수 있습니다.
sandboxes 이 속성은 특정 역할에 대해 프로비저닝된 조직 내의 샌드박스를 표시합니다.
subjectAttributes 주체와 주체가 액세스할 수 있는 Platform 리소스 간의 상관 관계를 나타내는 특성입니다.
subjectAttributes.labels 쿼리된 역할에 적용되는 데이터 사용 레이블을 표시합니다.

역할 ID로 역할 업데이트

에 PUT 요청을 하여 역할을 업데이트할 수 있습니다. /roles 끝점을 지정하고 업데이트할 역할에 해당하는 역할 ID를 지정합니다.

API 형식

PUT /roles/{ROLE_ID}

요청

다음 요청은 역할 ID에 대한 이름, 설명 및 역할 유형을 업데이트합니다. 3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809.

curl -X PUT \
  https://platform.adobe.io/data/foundation/access-control/administration/roles/3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809 \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}'
  -d'{
    "name": "Administrator role for ACME",
    "description": "New administrator role for ACME",
    "roleType": "user-defined"
  }'
매개변수 설명
name 업데이트된 역할 이름.
description 역할에 대한 업데이트된 설명.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.

응답

성공하면 이름, 설명 및 역할 유형에 대한 새 값을 포함하여 업데이트된 역할이 반환됩니다.

{
  "id": "3dfa045d-de58-4dfd-8ea9-e4e2c1b6d809",
  "name": "Administrator Role",
  "description": "Role with permission sets for admin type of access",
  "roleType": "user-defined",
  "permissionSets": [
    "manage-datasets",
    "manage-schemas"
  ],
  "sandboxes": [
    "prod"
  ],
  "subjectAttributes": {
    "labels": [
      "core/S1"
    ]
  },
  "createdBy": "{CREATED_BY}",
  "createdAt": 1648153201825,
  "modifiedBy": "{MODIFIED_BY}",
  "modifiedAt": 1648153201825,
  "etag": null
}
속성 설명
id 역할에 해당하는 ID입니다. 이 ID는 자동으로 생성됩니다.
name 역할의 이름입니다.
description description 속성은 역할에 대한 추가 정보를 제공합니다.
roleType 역할의 지정된 유형입니다. 역할 유형에 사용할 수 있는 값은 다음과 같습니다. user-definedsystem-defined.
permissionSets 권한 집합은 관리자가 역할에 적용할 수 있는 권한 그룹을 나타냅니다. 관리자는 개별 권한을 할당하는 대신 역할에 권한 집합을 할당할 수 있습니다. 이를 통해 권한 그룹을 포함하는 사전 정의된 역할에서 사용자 정의 역할을 만들 수 있습니다.
sandboxes 이 속성은 특정 역할에 대해 프로비저닝된 조직 내의 샌드박스를 표시합니다.
subjectAttributes 주체와 주체가 액세스할 수 있는 Platform 리소스 간의 상관 관계를 나타내는 특성입니다.
subjectAttributes.labels 쿼리된 역할에 적용되는 데이터 사용 레이블을 표시합니다.

역할 ID로 제목 업데이트

역할과 연결된 주제를 업데이트하려면 PATCH에 /roles 업데이트할 주체의 역할 ID를 제공하는 동안 끝점이 발생했습니다.

API 형식

PATCH /roles/{ROLE_ID}
매개변수 설명
업데이트할 주체와 연결된 역할의 ID입니다.

요청

다음 요청은 과 연관된 주제를 업데이트합니다. {ROLE_ID}.

curl --location --request PATCH 'https://platform.adobe.io/data/foundation/access-control/administration/roles/<ROLE_ID>/subjects' \
--header 'Authorization: Bearer {ACCESS_TOKEN}' \
--header 'x-api-key: {API_KEY}' \
--header 'x-gw-ims-org-id: {IMS_ORG}' \
--header 'Content-Type: application/json' \
--data-raw '[
    {
        "op": "add",
        "path": "/user",
        "value": "{USER ID}"
    }
]'
작업 설명
op 역할을 업데이트하는 데 필요한 작업을 정의하는 데 사용되는 작업 호출입니다. 작업에는 다음이 포함됩니다. add, replace, 및 remove.
path 업데이트할 매개 변수의 경로입니다.
value 매개 변수를 업데이트할 새 값입니다.

응답

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

역할 삭제

역할을 삭제하려면 다음에 대한 DELETE 요청을 /roles 삭제할 역할의 ID를 지정하는 동안 끝점이 발생했습니다.

API 형식

DELETE /roles/{ROLE_ID}
매개변수 설명
삭제할 역할의 ID입니다.

요청

다음 요청은 ID가 인 역할을 삭제합니다. {ROLE_ID}.

curl -X DELETE \
  https://platform.adobe.io/data/foundation/access-control/administration/roles/{ROLE_ID} \
  -H 'Authorization: Bearer {ACCESS_TOKEN}' \
  -H 'x-api-key: {API_KEY}' \
  -H 'x-gw-ims-org-id: {IMS_ORG}' \

응답

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

역할에 대한 조회(GET) 요청을 시도하여 삭제를 확인할 수 있습니다. 역할이 관리에서 제거되었으므로 HTTP 상태 404(찾을 수 없음)를 받게 됩니다.

API 자격 증명 추가

API 자격 증명을 추가하려면 PATCH 요청을에 /roles 주체의 역할 ID를 제공하는 동안 끝점이 발생했습니다.

API 형식

curl --location --request PATCH 'https://platform.adobe.io/data/foundation/access-control/administration/roles/<ROLE_ID>/subjects' \
--header 'Authorization: Bearer {ACCESS_TOKEN}' \
--header 'x-api-key: {API_KEY}' \
--header 'x-gw-ims-org-id: {IMS_ORG}' \
--header 'Content-Type: application/json' \
--data-raw '[
    {
        "op": "add",
        "path": "/api-integration",
        "value": "{TECHNICAL ACCOUNT ID}"
    }
]'
작업 설명
op 역할을 업데이트하는 데 필요한 작업을 정의하는 데 사용되는 작업 호출입니다. 작업에는 다음이 포함됩니다. add, replace, 및 remove.
path 추가할 매개 변수의 경로입니다.
value 매개 변수를 추가할 값입니다.

응답

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

이 페이지의