AWS Lambda 的操作、资源和条件键
AWS Lambda(服务前缀:lambda)提供以下服务特定的资源、操作和条件上下文键以在 IAM 权限策略中使用。
参考:
AWS Lambda 定义的操作
您可以在 IAM 策略语句的 Action 元素中指定以下操作。可以使用策略授予在 AWS 中执行操作的权限。您在策略中使用一项操作时,通常使用相同的名称允许或拒绝对 API 操作或 CLI 命令的访问。但在某些情况下,单一动作可控制对多项操作的访问。还有某些操作需要多种不同的动作。
操作表的访问级别列描述如何对操作进行分类(列出、读取、权限管理或标记)。此分类可以帮助您了解当您在策略中使用操作时,相应操作授予的访问级别。有关访问级别的更多信息,请参阅策略摘要中的访问级别。
操作表的资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource 元素中指定策略应用的所有资源(“*”)。通过在 IAM policy 中使用条件来筛选访问权限,以控制是否可以在资源或请求中使用特定标签键。如果操作具有一个或多个必需资源,则调用方必须具有使用这些资源来使用该操作的权限。必需资源在表中以星号 (*) 表示。如果您在 IAM policy 中使用 Resource 元素限制资源访问权限,则必须为每种必需的资源类型添加 ARN 或模式。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种可选资源类型。
操作表的条件键列包括可以在策略语句的 Condition 元素中指定的键。有关与服务资源关联的条件键的更多信息,请参阅资源类型表的条件键列。
操作表的依赖操作列显示成功调用操作可能需要的其他权限。除了操作本身的权限以外,可能还需要这些权限。若某个操作指定依赖操作,则这些依赖关系可能适用于为该操作定义的其他资源,而不仅仅是表中列出的第一个资源。
注意
资源条件键在资源类型表中列出。您可以在操作表的资源类型(* 为必需)列中找到应用于某项操作的资源类型的链接。资源类型表中的资源类型包括条件密钥列,这是应用于操作表中操作的资源条件键。
有关下表中各列的详细信息,请参阅操作表。
| 操作 | 描述 | 访问级别 | 资源类型(* 为必需) | 条件键 | 相关操作 |
|---|---|---|---|---|---|
| AddLayerVersionPermission | 授予权限以向 AWS Lambda 层版本的基于资源的策略添加权限 | Permissions management | |||
| AddPermission | 授予权限以向AWS服务或其他账户提供使用 AWS Lambda 函数的权限 | Permissions management | |||
| CreateAlias | 授予权限以创建 Lambda 函数版本的别名 | Write | |||
| CreateCodeSigningConfig | 授予创建 AWS Lambda 代码签名配置的权限 | Write | |||
| CreateEventSourceMapping | 授予权限以在事件源和 AWS Lambda 函数之间创建映射 | Write | |||
| CreateFunction | 授予权限以创建 AWS Lambda 函数 | 写入 |
iam:PassRole |
||
| CreateFunctionUrlConfig | 授予权限以创建 Lambda 函数的函数 url 配置 | 写入 | |||
| DeleteAlias | 授予权限以删除 AWS Lambda 函数别名 | Write | |||
| DeleteCodeSigningConfig | 授予删除 AWS Lambda 代码签名配置的权限 | Write | |||
| DeleteEventSourceMapping | 授予权限以删除 AWS Lambda 事件源映射 | Write | |||
| DeleteFunction | 授予权限以删除 AWS Lambda 函数 | Write | |||
| DeleteFunctionCodeSigningConfig | 授予从 AWS Lambda 函数中分离代码签名配置的权限 | Write | |||
| DeleteFunctionConcurrency | 授予权限以从 AWS Lambda 函数中删除并发执行限制 | Write | |||
| DeleteFunctionEventInvokeConfig | 授予权限以删除 AWS Lambda 函数、版本或别名的异步调用配置 | 写入 | |||
| DeleteFunctionUrlConfig | 授予权限以删除 Lambda 函数的函数 url 配置 | 写入 | |||
| DeleteLayerVersion | 授予权限以删除 AWS Lambda 层版本 | Write | |||
| DeleteProvisionedConcurrencyConfig | 授予权限以删除 AWS Lambda 函数的预置并发配置 | Write | |||
| DisableReplication [仅权限] | 授予权限以禁用 Lambda@Edge 函数复制 | Permissions management | |||
| EnableReplication [仅权限] | 授予权限以启用 Lambda@Edge 函数复制 | Permissions management | |||
| GetAccountSettings | 授予权限以查看有关 AWS 区域 中账户限制和使用情况的详细信息 | Read | |||
| GetAlias | 授予权限以查看有关 AWS Lambda 函数别名的详细信息 | Read | |||
| GetCodeSigningConfig | 授予查看有关 AWS Lambda 代码签名配置详细信息的权限 | Read | |||
| GetEventSourceMapping | 授予权限以查看有关 AWS Lambda 事件源映射的详细信息 | Read | |||
| GetFunction | 授予权限以查看有关 AWS Lambda 函数的详细信息 | Read | |||
| GetFunctionCodeSigningConfig | 授予查看附加到 AWS Lambda 函数的代码签名配置 arn 的权限 | Read | |||
| GetFunctionConcurrency | 授予权限以查看有关函数的保留并发配置的详细信息 | Read | |||
| GetFunctionConfiguration | 授予权限以查看有关 AWS Lambda 函数或版本的版本特定设置的详细信息 | Read | |||
| GetFunctionEventInvokeConfig | 授予权限以查看函数、版本或别名的异步调用配置 | 读取 | |||
| GetFunctionRecursionConfig | 授予权限以查看 AWS Lambda 函数的递归配置 | 读取 | |||
| GetFunctionUrlConfig | 授予权限以读取 Lambda 函数的函数 url 配置 | 读取 | |||
| GetLayerVersion | 授予权限以查看有关 AWS Lambda 层版本的详细信息 请注意,此操作还支持 GetLayerVersionByArn API | Read | |||
| GetLayerVersionPolicy | 授予权限以查看 AWS Lambda 层版本的基于资源的策略 | Read | |||
| GetPolicy | 授予权限以查看 AWS Lambda 函数、版本或别名的基于资源的策略 | Read | |||
| GetProvisionedConcurrencyConfig | 授予权限以查看 AWS Lambda 函数别名或版本的预置并发配置 | 读取 | |||
| GetRuntimeManagementConfig | 授予查看 AWS Lambda 函数的运行时管理配置的权限 | 读取 | |||
| InvokeAsync | 授予权限以异步调用函数(已弃用) | 写入 | |||
| InvokeFunction | 授予权限以调用 AWS Lambda 函数 | 写入 | |||
| InvokeFunctionUrl [仅权限] | 授予权限以通过 url 调用 AWS Lambda 函数 | 写入 | |||
| ListAliases | 授予权限以检索 AWS Lambda 函数别名列表 | List | |||
| ListCodeSigningConfigs | 授予检索 AWS Lambda 代码签名配置列表的权限 | List | |||
| ListEventSourceMappings | 授予权限以检索 AWS Lambda 事件源映射列表 | List | |||
| ListFunctionEventInvokeConfigs | 授予权限以检索函数异步调用的配置列表 | 列表 | |||
| ListFunctionUrlConfigs | 授予权限以读取函数的函数 url 配置 | 列表 | |||
| ListFunctions | 授予权限以检索 AWS Lambda 函数以及每个函数的版本特定配置的列表 | List | |||
| ListFunctionsByCodeSigningConfig | 授予通过分配的代码签名配置检索 AWS Lambda 函数列表的权限 | List | |||
| ListLayerVersions | 授予权限以检索 AWS Lambda 层版本列表 | List | |||
| ListLayers | 授予权限以检索 AWS Lambda 层以及有关每个层的最新版本的详细信息的列表 | List | |||
| ListProvisionedConcurrencyConfigs | 授予权限以检索 AWS Lambda 函数的预置并发配置列表 | 列表 | |||
| ListTags | 授予权限以检索 AWS Lambda 函数、事件源映射或代码签名配置资源的标签列表 | 读取 | |||
| ListVersionsByFunction | 授予权限以检索 AWS Lambda 函数版本列表 | List | |||
| PublishLayerVersion | 授予权限以创建 AWS Lambda 层 | Write | |||
| PublishVersion | 授予权限以创建 AWS Lambda 函数版本 | Write | |||
| PutFunctionCodeSigningConfig | 授予将代码签名配置附加到 AWS Lambda 函数的权限 | Write | |||
| PutFunctionConcurrency | 授予权限以配置 AWS Lambda 函数的预留并发性 | Write | |||
| PutFunctionEventInvokeConfig | 授予权限以配置 AWS Lambda 函数、版本或别名的异步调用选项 | 写入 | |||
| PutFunctionRecursionConfig | 授予权限以更新 AWS Lambda 函数的递归配置 | 写入 | |||
| PutProvisionedConcurrencyConfig | 授予权限以配置 AWS Lambda 函数别名或版本的预置并发性 | 写入 | |||
| PutRuntimeManagementConfig | 授予更新 AWS Lambda 函数的运行时管理配置的权限 | 写入 | |||
| RemoveLayerVersionPermission | 授予权限以从 AWS Lambda 层版本的权限策略中删除语句 | Permissions management | |||
| RemovePermission | 授予权限以从AWS服务或其他账户中撤销函数使用权限 | 权限管理 | |||
| TagResource | 授予权限以向 AWS Lambda 函数、事件源映射或代码签名配置资源添加标签 | 标记 | |||
| UntagResource | 授予权限以从 AWS Lambda 函数、事件源映射或代码签名配置资源中删除标签 | 标记 | |||
| UpdateAlias | 授予权限以更新 AWS Lambda 函数别名的配置 | Write | |||
| UpdateCodeSigningConfig | 授予更新 AWS Lambda 代码签名配置的权限 | Write | |||
| UpdateEventSourceMapping | 授予权限以更新 AWS Lambda 事件源映射的配置 | Write | |||
| UpdateFunctionCode | 授予权限以更新 AWS Lambda 函数代码 | Write | |||
| UpdateFunctionCodeSigningConfig | 授予更新 AWS Lambda 函数代码签名配置的权限 | Write | |||
| UpdateFunctionConfiguration | 授予权限以修改 AWS Lambda 函数的版本特定设置 | Write | |||
| UpdateFunctionEventInvokeConfig | 授予权限以修改 AWS Lambda 函数、版本或别名的异步调用的配置 | 写入 | |||
| UpdateFunctionUrlConfig | 授予权限以更新 Lambda 函数的函数 url 配置 | 写入 | |||
AWS Lambda 定义的资源类型
以下资源类型是由该服务定义的,可以在 IAM 权限策略语句的 Resource 元素中使用这些资源类型。操作表中的每个操作指定了可以使用该操作指定的资源类型。您也可以在策略中包含条件键,从而定义资源类型。这些键显示在资源类型表的最后一列。有关下表中各列的详细信息,请参阅资源类型表。
| 资源类型 | ARN | 条件键 |
|---|---|---|
| code signing config |
arn:${Partition}:lambda:${Region}:${Account}:code-signing-config:${CodeSigningConfigId}
|
|
| eventSourceMapping |
arn:${Partition}:lambda:${Region}:${Account}:event-source-mapping:${UUID}
|
|
| function |
arn:${Partition}:lambda:${Region}:${Account}:function:${FunctionName}
|
|
| function alias |
arn:${Partition}:lambda:${Region}:${Account}:function:${FunctionName}:${Alias}
|
|
| function version |
arn:${Partition}:lambda:${Region}:${Account}:function:${FunctionName}:${Version}
|
|
| layer |
arn:${Partition}:lambda:${Region}:${Account}:layer:${LayerName}
|
|
| layerVersion |
arn:${Partition}:lambda:${Region}:${Account}:layer:${LayerName}:${LayerVersion}
|
AWS Lambda 的条件键
AWS Lambda 定义以下可以在 IAM policy 的 Condition 元素中使用的条件键。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表。
要查看适用于所有服务的全局条件键,请参阅 AWS 全局条件上下文键。
| 条件键 | 描述 | 类型 |
|---|---|---|
| aws:RequestTag/${TagKey} | 按请求中传递的标签筛选访问权限 | 字符串 |
| aws:ResourceTag/${TagKey} | 按与资源关联的标签筛选访问权限 | 字符串 |
| aws:TagKeys | 按请求中传递的标签键筛选访问权限 | 字符串数组 |
| lambda:CodeSigningConfigArn | 按 AWS Lambda 代码签名配置的 ARN 筛选访问 | ARN |
| lambda:EventSourceToken | 按来自为 AWS Lambda 函数配置的非 AWS 事件源的 ID 筛选访问权限 | 字符串 |
| lambda:FunctionArn | 按 AWS Lambda 函数的 ARN 筛选访问 | ARN |
| lambda:FunctionUrlAuthType | 按请求中指定的授权类型筛选访问。在 CreateFunctionUrlConfig、UpdateFunctionUrlConfig、DeleteFunctionUrlConfig、GetFunctionUrlConfig、ListFunctionUrlConfig、AddPermission 和 RemovePermission 操作期间可用 | 字符串 |
| lambda:Layer | 按 AWS Lambda 层的版本的 ARN 筛选访问 | 字符串数组 |
| lambda:Principal | 通过限制可调用函数的AWS服务或账户来筛选访问 | 字符串 |
| lambda:SecurityGroupIds | 按为 AWS Lambda 函数配置的安全组的 ID 筛选访问 | 字符串数组 |
| lambda:SourceFunctionArn | 按发起请求的 AWS Lambda 函数的 ARN 筛选访问 | ARN |
| lambda:SubnetIds | 按为 AWS Lambda 函数配置的子网的 ID 筛选访问 | 字符串数组 |
| lambda:VpcIds | 按为 AWS Lambda 函数配置的 VPC 的 ID 筛选访问 | 字符串 |