Updated on 2024-06-12 GMT+08:00

Agencies and Dependencies

Function Dependency

Function Dependency Policies

When using ModelArts to develop algorithms or manage training jobs, you are required to use other Cloud services. For example, before submitting a training job, select an OBS path for storing the dataset and logs, respectively. Therefore, when configuring fine-grained authorization policies for a user, the administrator must configure dependent permissions so that the user can use required functions.

If you use ModelArts as the root user (default IAM user with the same name as the account), the root user has all permissions by default.

Table 1 Basic configuration

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Global configuration

IAM

iam:users:listUsers

Obtain a user list. This action is required by the administrator only.

Basic function

IAM

iam:tokens:assume

(Mandatory) Use an agency to obtain temporary authentication credentials.

Table 2 Managing workspaces

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Workspace

IAM

iam:users:listUsers

Authorize an IAM user to use a workspace.

ModelArts

modelarts:*:*delete*

Clear resources in a workspace when deleting it.

Table 3 Managing notebook instances

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Lifecycle management of development environment instances

ModelArts

modelarts:notebook:create

modelarts:notebook:list

modelarts:notebook:get

modelarts:notebook:update

modelarts:notebook:delete

modelarts:notebook:start

modelarts:notebook:stop

modelarts:notebook:updateStopPolicy

modelarts:image:delete

modelarts:image:list

modelarts:image:create

modelarts:image:get

modelarts:pool:list

modelarts:tag:list

modelarts:network:get

aom:metric:get

aom:metric:list

aom:alarm:list

Start, stop, create, delete, and update an instance.

Dynamically mounting storage

ModelArts

modelarts:notebook:listMountedStorages

modelarts:notebook:mountStorage

modelarts:notebook:getMountedStorage

modelarts:notebook:umountStorage

Dynamically mount storage.

OBS

obs:bucket:ListAllMyBuckets

obs:bucket:ListBucket

Image management

ModelArts

modelarts:image:register

modelarts:image:listGroup

Register and view an image on the Image Management page.

Saving an image

SWR

SWR Admin

The SWR Admin policy contains the maximum scope of SWR permissions, which can be used to:

  • Save a running development environment instance as an image.
  • Create a notebook instance using a custom image.

Using the SSH function

ECS

ecs:serverKeypairs:list

ecs:serverKeypairs:get

ecs:serverKeypairs:delete

ecs:serverKeypairs:create

Configure a login key for a notebook instance.

Mounting an SFS Turbo file system

SFS Turbo

SFS Turbo FullAccess

Read and write an SFS directory as an IAM user. Mount an SFS file system that is not created by you to a notebook instance using a dedicated resource pool.

Viewing all Instances

ModelArts

modelarts:notebook:listAllNotebooks

View development environment instances of all users on the ModelArts management console. This action is required by the development environment instance administrator.

IAM

iam:users:listUsers

Local VS Code plug-in or PyCharm Toolkit

ModelArts

modelarts:notebook:listAllNotebooks

modelarts:trainJob:create

modelarts:trainJob:list

modelarts:trainJob:update

modelarts:trainJobVersion:delete

modelarts:trainJob:get

modelarts:trainJob:logExport

modelarts:workspace:getQuotas (This policy is required if the workspace function is enabled.)

Access a notebook instance from local VS Code and submit training jobs.

OBS

obs:bucket:ListAllMybuckets

obs:bucket:HeadBucket

obs:bucket:ListBucket

obs:bucket:GetBucketLocation

obs:object:GetObject

obs:object:GetObjectVersion

obs:object:PutObject

obs:object:DeleteObject

obs:object:DeleteObjectVersion

obs:object:ListMultipartUploadParts

obs:object:AbortMultipartUpload

obs:object:GetObjectAcl

obs:object:GetObjectVersionAcl

obs:bucket:PutBucketAcl

obs:object:PutObjectAcl

obs:object:ModifyObjectMetaData

IAM

iam:projects:listProjects

Obtain an IAM project list through local PyCharm for access configurations.

Table 4 Managing training jobs

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Training management

ModelArts

modelarts:trainJob:*

modelarts:trainJobLog:*

modelarts:aiAlgorithm:*

modelarts:image:list

Create a training job and view training logs.

modelarts:workspace:getQuotas

Obtain a workspace quota. This policy is required if the workspace function is enabled.

modelarts:tag:list

Use Tag Management Service (TMS) in a training job.

IAM

iam:credentials:listCredentials

iam:agencies:listAgencies

Use the configured agency authorization.

SFS Turbo

sfsturbo:shares:getShare

sfsturbo:shares:getAllShares

Use SFS Turbo in a training job.

SWR

swr:repository:listTags

swr:repository:getRepository

swr:repository:listRepositories

Use a custom image to create a training job.

SMN

smn:topic:publish

smn:topic:list

Notify training job status changes through SMN.

OBS

obs:bucket:ListAllMybuckets

obs:bucket:HeadBucket

obs:bucket:ListBucket

obs:bucket:GetBucketLocation

obs:object:GetObject

obs:object:GetObjectVersion

obs:object:PutObject

obs:object:DeleteObject

obs:object:DeleteObjectVersion

obs:object:ListMultipartUploadParts

obs:object:AbortMultipartUpload

obs:object:GetObjectAcl

obs:object:GetObjectVersionAcl

obs:bucket:PutBucketAcl

obs:object:PutObjectAcl

obs:object:ModifyObjectMetaData

Run a training job using a dataset in an OBS bucket.

Table 5 Using workflows

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Using a dataset

ModelArts

modelarts:dataset:getDataset

modelarts:dataset:createDataset

modelarts:dataset:createDatasetVersion

modelarts:dataset:createImportTask

modelarts:dataset:updateDataset

modelarts:processTask:createProcessTask

modelarts:processTask:getProcessTask

modelarts:dataset:listDatasets

Use ModelArts datasets in a workflow.

Managing AI applications

ModelArts

modelarts:model:list

modelarts:model:get

modelarts:model:create

modelarts:model:delete

modelarts:model:update

Manage ModelArts AI applications in a workflow.

Deploying a service

ModelArts

modelarts:service:get

modelarts:service:create

modelarts:service:update

modelarts:service:delete

modelarts:service:getLogs

Manage ModelArts real-time services in a workflow.

Training jobs

ModelArts

modelarts:trainJob:get

modelarts:trainJob:create

modelarts:trainJob:list

modelarts:trainJobVersion:list

modelarts:trainJobVersion:create

modelarts:trainJob:delete

modelarts:trainJobVersion:delete

modelarts:trainJobVersion:stop

Manage ModelArts training jobs in a workflow.

Workspace

ModelArts

modelarts:workspace:get

modelarts:workspace:getQuotas

Use ModelArts workspaces in a workflow.

Managing data

OBS

obs:bucket:ListAllMybuckets (Obtaining a bucket list)

obs:bucket:HeadBucket (Obtaining bucket metadata)

obs:bucket:ListBucket (Listing objects in a bucket)

obs:bucket:GetBucketLocation (Obtaining the bucket location)

obs:object:GetObject (Obtaining object content and metadata)

obs:object:GetObjectVersion (Obtaining object content and metadata)

obs:object:PutObject (Uploading objects using PUT method, uploading objects using POST method, copying objects, appending an object, initializing a multipart task, uploading parts, and merging parts)

obs:object:DeleteObject (Deleting an object or batch deleting objects)

obs:object:DeleteObjectVersion (Deleting an object or batch deleting objects)

obs:object:ListMultipartUploadParts (Listing uploaded parts)

obs:object:AbortMultipartUpload (Aborting multipart uploads)

obs:object:GetObjectAcl (Obtaining an object ACL)

obs:object:GetObjectVersionAcl (Obtaining an object ACL)

obs:bucket:PutBucketAcl (Configuring a bucket ACL)

obs:object:PutObjectAcl (Configuring an object ACL)

Use OBS data in a workflow.

Executing a workflow

IAM

iam:users:listUsers (Obtaining users)

iam:agencies:getAgency (Obtaining details about a specified agency)

iam:tokens:assume (Obtaining an agency token)

Call other ModelArts services when the workflow is running.

Integrating DLI

DLI

dli:jobs:get (Obtaining job details)

dli:jobs:list_all (Viewing a job list)

dli:jobs:create (Creating a job)

Integrate DLI into a workflow.

Integrating MRS

MRS

mrs:job:get (Obtaining job details)

mrs:job:submit (Creating and executing a job)

mrs:job:list (Viewing a job list)

mrs:job:stop (Stopping a job)

mrs:job:batchDelete (Batch deleting jobs)

mrs:file:list (Viewing a file list)

Integrate MRS into a workflow.

Table 6 Managing AI applications

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Managing AI applications

SWR

swr:repository:deleteRepository

swr:repository:deleteTag

swr:repository:getRepository

swr:repository:listTags

Import a model from a custom image.

Use a custom engine when importing a model from OBS.

OBS

obs:bucket:ListAllMybuckets (Obtaining a bucket list)

obs:bucket:HeadBucket (Obtaining bucket metadata)

obs:bucket:ListBucket (Listing objects in a bucket)

obs:bucket:GetBucketLocation (Obtaining the bucket location)

obs:object:GetObject (Obtaining object content and metadata)

obs:object:GetObjectVersion (Obtaining object content and metadata)

obs:object:PutObject (Uploading objects using PUT method, uploading objects using POST method, copying objects, appending an object, initializing a multipart task, uploading parts, and merging parts)

obs:object:DeleteObject (Deleting an object or batch deleting objects)

obs:object:DeleteObjectVersion (Deleting an object or batch deleting objects)

obs:object:ListMultipartUploadParts (Listing uploaded parts)

obs:object:AbortMultipartUpload (Aborting multipart uploads)

obs:object:GetObjectAcl (Obtaining an object ACL)

obs:object:GetObjectVersionAcl (Obtaining an object ACL)

obs:bucket:PutBucketAcl (Configuring a bucket ACL)

obs:object:PutObjectAcl (Configuring an object ACL)

Import a model from a template.

Specify an OBS path for model conversion.

Table 7 Managing service deployment

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Real-time services

LTS

lts:logs:list (Obtaining the log list)

Show LTS logs.

OBS

obs:bucket:GetBucketPolicy (Obtaining a bucket policy)

obs:bucket:HeadBucket (Obtaining bucket metadata)

obs:bucket:ListAllMyBuckets (Obtaining a bucket list)

obs:bucket:PutBucketPolicy (Configuring a bucket policy)

obs:bucket:DeleteBucketPolicy (Deleting a bucket policy)

Mount external volumes to a container when services are running.

Batch services

OBS

obs:object:GetObject (Obtaining object content and metadata)

obs:object:PutObject (Uploading objects using PUT method, uploading objects using POST method, copying objects, appending an object, initializing a multipart task, uploading parts, and merging parts)

obs:bucket:CreateBucket (Creating a bucket)

obs:bucket:ListBucket (Listing objects in a bucket)

obs:bucket:ListAllMyBuckets (Obtaining a bucket list)

Create batch services and perform batch inference.

Edge services

CES

ces:metricData:list: (Obtaining metric data)

View monitoring metrics.

IEF

ief:deployment:delete (Deleting a deployment)

Manage edge services.

Table 8 Managing datasets

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Managing datasets and labels

OBS

obs:bucket:ListBucket (Listing objects in a bucket)

obs:object:GetObject (Obtaining object content and metadata)

obs:object:PutObject (Uploading objects using PUT method, uploading objects using POST method, copying objects, appending an object, initializing a multipart task, uploading parts, and merging parts)

obs:object:DeleteObject (Deleting an object or batch deleting objects)

obs:bucket:HeadBucket (Obtaining bucket metadata)

obs:bucket:GetBucketAcl (Obtaining a bucket ACL)

obs:bucket:PutBucketAcl (Configuring a bucket ACL)

obs:bucket:GetBucketPolicy (Obtaining a bucket policy)

obs:bucket:PutBucketPolicy (Configuring a bucket policy)

obs:bucket:DeleteBucketPolicy (Deleting a bucket policy)

obs:bucket:PutBucketCORS (Configuring or deleting CORS rules of a bucket)

obs:bucket:GetBucketCORS (Obtaining the CORS rules of a bucket)

obs:object:PutObjectAcl (Configuring an object ACL)

Manage datasets in OBS.

Label OBS data.

Create a data management job.

Managing table datasets

DLI

dli:database:displayAllDatabases

dli:database:displayAllTables

dli:table:describe_table

Manage DLI data in a dataset.

Managing table datasets

DWS

dws:openAPICluster:list

dws:openAPICluster:getDetail

Manage DWS data in a dataset.

Managing table datasets

MRS

mrs:job:submit

mrs:job:list

mrs:cluster:list

mrs:cluster:get

Manage MRS data in a dataset.

Auto labeling

ModelArts

modelarts:service:list

modelarts:model:list

modelarts:model:get

modelarts:model:create

modelarts:trainJobInnerModel:list

modelarts:workspace:get

modelarts:workspace:list

Enable auto labeling.

Team labeling

IAM

iam:projects:listProjects (Obtaining tenant projects)

iam:users:listUsers (Obtaining users)

iam:agencies:createAgency (Creating an agency)

iam:quotas:listQuotasForProject (Obtaining the quotas of a project)

Manage labeling teams.

Table 9 Managing resources

Application Scenario

Dependent Service

Dependent Policy

Supported Function

Managing resource pools

BSS

bss:coupon:view

bss:order:view

bss:balance:view

bss:discount:view

bss:renewal:view

bss:bill:view

bss:contract:update

bss:order:pay

bss:unsubscribe:update

bss:renewal:update

bss:order:update

Create, renew, and unsubscribe from a resource pool. Dependent permissions must be configured in the IAM project view.

ECS

ecs:availabilityZones:list

Show AZs. Dependent permissions must be configured in the IAM project view.

Network management

VPC

vpc:routes:create

vpc:routes:list

vpc:routes:get

vpc:routes:delete

vpc:peerings:create

vpc:peerings:accept

vpc:peerings:get

vpc:peerings:delete

vpc:routeTables:update

vpc:routeTables:get

vpc:routeTables:list

vpc:vpcs:create

vpc:vpcs:list

vpc:vpcs:get

vpc:vpcs:delete

vpc:subnets:create

vpc:subnets:get

vpc:subnets:delete

vpcep:endpoints:list

vpcep:endpoints:create

vpcep:endpoints:delete

vpcep:endpoints:get

vpc:ports:create

vpc:ports:get

vpc:ports:update

vpc:ports:delete

vpc:networks:create

vpc:networks:get

vpc:networks:update

vpc:networks:delete

Create and delete ModelArts networks, and interconnect VPCs. Dependent permissions must be configured in the IAM project view.

SFS Turbo

sfsturbo:shares:addShareNic

sfsturbo:shares:deleteShareNic

sfsturbo:shares:showShareNic

sfsturbo:shares:listShareNics

Interconnect your network with SFS Turbo. Dependent permissions must be configured in the IAM project view.

Edge resource pool

IEF

ief:node:list

ief:group:get

ief:application:list

ief:application:get

ief:node:listNodeCert

ief:node:get

ief:IEFInstance:get

ief:deployment:list

ief:group:listGroupInstanceState

ief:IEFInstance:list

ief:deployment:get

ief:group:list

Add, delete, modify, and search for edge pools

Agency authorization

To simplify operations when you use ModelArts to run jobs, certain operations are automatically performed on the ModelArts backend, for example, downloading the datasets in an OBS bucket to a workspace before a training job is started and dumping training job logs to the OBS bucket.

ModelArts does not save your token authentication credentials. Before performing operations on your resources (such as OBS buckets) in a backend asynchronous job, you are required to explicitly authorize ModelArts through an IAM agency. ModelArts will use the agency to obtain a temporary authentication credential for performing operations on your resources. For details, see Adding Authorization.

Figure 1 Agency authorization

As shown in Figure 1, after authorization is configured on ModelArts, ModelArts uses the temporary credential to access and operate your resources, relieving you from some complex and time-consuming operations. The agency credential will also be synchronized to your jobs (including notebook instances and training jobs). You can use the agency credential to access your resources in the jobs.

You can use either of the following methods to authorize ModelArts using an agency:

One-click authorization

ModelArts provides one-click automatic authorization. You can quickly configure agency authorization on the Global Configuration page of ModelArts. Then, ModelArts will automatically create an agency for you and configure it in ModelArts.

In this mode, the authorization scope is specified based on the preset system policies of dependent services to ensure sufficient permissions for using services. The created agency has almost all permissions of dependent services. If you want to precisely control the scope of permissions granted to an agency, use the second method.

Custom authorization

The administrator creates different agency authorization policies for different users in IAM, and configures the created agency for ModelArts users. When creating an agency for an IAM user, the administrator specifies the minimum permissions for the agency based on the user's permissions to control the resources that the user can access when they use ModelArts.

Risks in Unauthorized Operations

The agency authorization of a user is independent. Theoretically, the agency authorization scope of a user can be beyond the authorization scope of the authorization policy configured for the user group. Any improper configuration will result in unauthorized operations.

To prevent unauthorized operations, only a tenant administrator is allowed to configure agencies for users in the ModelArts global configuration to ensure the security of agency authorization.

Minimal Agency Authorization

When configuring agency authorization, an administrator must strictly control the authorization scope.

ModelArts asynchronously and automatically performs operations such as job preparation and clearing. The required agency authorization is within the basic authorization scope. If you use only some functions of ModelArts, the administrator can filter out the basic permissions that are not used according to the agency authorization configuration. Conversely, if you need to obtain resource permissions beyond the basic authorization scope in a job, the administrator can add new permissions to the agency authorization configuration. In a word, the agency authorization scope must be minimized and customized based on service requirements.

Basic Agency Authorization Scope

To customize the permissions for an agency, select permissions based on your service requirements.

Table 10 Basic agency authorization for a development environment

Application Scenario

Dependent Service

Agency Authorization

Description

Configuration Suggestion

JupyterLab

OBS

obs:object:DeleteObject

obs:object:GetObject

obs:object:GetObjectVersion

obs:bucket:CreateBucket

obs:bucket:ListBucket

obs:bucket:ListAllMyBuckets

obs:object:PutObject

obs:bucket:GetBucketAcl

obs:bucket:PutBucketAcl

obs:bucket:PutBucketCORS

Use OBS to upload and download data in JupyterLab through ModelArts notebook.

Recommended

Development environment monitoring

AOM

aom:alarm:put

Call the AOM API to obtain monitoring data and events of notebook instances and display them in ModelArts notebook.

Recommended

Table 11 Basic agency authorization for training jobs

Application Scenario

Dependent Service

Agency Authorization

Description

Training jobs

OBS

obs:bucket:ListBucket

obs:object:GetObject

obs:object:PutObject

Download data, models, and code before starting a training job.

Upload logs and models when a training job is running.

Table 12 Basic agency authorization for deploying services

Application Scenario

Dependent Service

Agency Authorization

Description

Real-time services

LTS

lts:groups:create

lts:groups:list

lts:topics:create

lts:topics:delete

lts:topics:list

Configure LTS for reporting logs of real-time services.

Batch services

OBS

obs:bucket:ListBucket

obs:object:GetObject

obs:object:PutObject

Run a batch service.

Edge services

IEF

ief:deployment:list

ief:deployment:create

ief:deployment:update

ief:deployment:delete

ief:node:createNodeCert

ief:iefInstance:list

ief:node:list

Deploy an edge service using IEF.

Table 13 Basic agency authorization for managing data

Application Scenario

Dependent Service

Agency Authorization

Description

Dataset and data labeling

OBS

obs:object:GetObject

obs:object:PutObject

obs:object:DeleteObject

obs:object:PutObjectAcl

obs:bucket:ListBucket

obs:bucket:HeadBucket

obs:bucket:GetBucketAcl

obs:bucket:PutBucketAcl

obs:bucket:GetBucketPolicy

obs:bucket:PutBucketPolicy

obs:bucket:DeleteBucketPolicy

obs:bucket:PutBucketCORS

obs:bucket:GetBucketCORS

Manage datasets in an OBS bucket.

Labeling data

ModelArts inference

modelarts:service:get

modelarts:service:create

modelarts:service:update

Perform auto labeling based on ModelArts inference.

Table 14 Basic agency authorization for managing dedicated resource pools

Application Scenario

Dependent Service

Agency Authorization

Description

Network management (New version)

VPC

vpc:routes:create

vpc:routes:list

vpc:routes:get

vpc:routes:delete

vpc:peerings:create

vpc:peerings:accept

vpc:peerings:get

vpc:peerings:delete

vpc:routeTables:update

vpc:routeTables:get

vpc:routeTables:list

vpc:vpcs:create

vpc:vpcs:list

vpc:vpcs:get

vpc:vpcs:delete

vpc:subnets:create

vpc:subnets:get

vpc:subnets:delete

vpcep:endpoints:list

vpcep:endpoints:create

vpcep:endpoints:delete

vpcep:endpoints:get

vpc:ports:create

vpc:ports:get

vpc:ports:update

vpc:ports:delete

vpc:networks:create

vpc:networks:get

vpc:networks:update

vpc:networks:delete

Create and delete ModelArts networks, and interconnect VPCs. Dependent permissions must be configured in the IAM project view.

SFS Turbo

sfsturbo:shares:addShareNic

sfsturbo:shares:deleteShareNic

sfsturbo:shares:showShareNic

sfsturbo:shares:listShareNics

Interconnect your network with SFS Turbo. Dependent permissions must be configured in the IAM project view.

Managing resource pools

ECS

ecs:availabilityZones:list

Show AZs. Dependent permissions must be configured in the IAM project view.