1.6. AuthService
1.6.1. UpdateAuthMachineToMachineConfig
PUT /v1/auth/m2m/{config.id}
UpdateAuthMachineToMachineConfig 将现有的 auth 机器更新为机器配置。如果 auth 机器到机器配置不存在,则会创建一个新机器。
1.6.1.1. 描述
1.6.1.2. 参数
1.6.1.2.1. 路径参数
Name | 描述 | 必填 | default | pattern |
---|---|---|---|---|
config.id | 配置的 UUID。请注意,在将机器添加到机器配置时,不应设置此字段。 | X | null |
1.6.1.2.2. 正文参数
Name | 描述 | 必填 | default | pattern |
---|---|---|---|---|
正文(body) | X |
1.6.1.3. 返回类型
对象
1.6.1.4. 内容类型
- application/json
1.6.1.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 |
|
0 | 意外错误响应。 |
1.6.1.6. Samples
1.6.1.7. 常规对象参考
1.6.1.7.1. AuthMachineToMachineConfigMapping
映射将身份令牌的声明值映射到 Central 中的特定角色。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
key | 字符串 | 要使用的身份令牌声明值中的键。 | |||
valueExpression | 字符串 | 一个正则表达式,它将针对指定键标识的身份令牌声明的值进行评估。这个正则表达式采用 RE2 格式,更多详情: https://github.com/google/re2/wiki/Syntax。 | |||
role | 字符串 | 当一个特定身份令牌的键和值匹配时,应发出的角色。 |
1.6.1.7.2. AuthServiceUpdateAuthMachineToMachineConfigBody
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
config |
1.6.1.7.3. AuthServiceUpdateAuthMachineToMachineConfigBodyConfig
AuthMachineToMachineConfig 决定从带有 Central 访问令牌的第三方交换身份令牌的规则。M2M 代表机器,因为这是配置的预期用例。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
type | GENERIC, GITHUB_ACTIONS, KUBE_SERVICE_ACCOUNT, | ||||
tokenExpirationDuration | 字符串 | 设置从 ExchangeAuthMachineToMachineToken API 调用返回的令牌的过期时间。可能的有效时间单位为:s、m、h。允许的最大过期时间为 24h。例如: 2h45m。有关验证持续时间的更多信息,请参阅: https://pkg.go.dev/time#ParseDuration。 | |||
映射 | 至少需要一个映射才能成功生成访问令牌的有效角色。 | ||||
Issuer | 字符串 | 相关 OIDC 供应商发布 ID 令牌来交换的签发者。当类型为 GENERIC 时,必须是包含 URL 的非空字符串。如果是 GitHub 操作,则必须为空,或设置为 https://token.actions.githubusercontent.com。issuer 是一个唯一的密钥,因此最多可能有一个 GITHUB_ACTIONS 配置,每个 GENERIC 配置必须具有不同的签发者。 |
1.6.1.7.4. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.1.7.5. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.1.7.5.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.1.7.6. V1AuthMachineToMachineConfigType
机器配置的 auth 机器的类型。目前支持 GitHub 操作或其他通用 OIDC 供应商来验证和交换令牌。
Enum 值 |
---|
GENERIC |
GITHUB_ACTIONS |
KUBE_SERVICE_ACCOUNT |
1.6.2. ExchangeAuthMachineToMachineToken
POST /v1/auth/m2m/exchange
ExchangeAuthMachineToMachineToken 根据配置的 auth 机器与机器配置交换中央访问令牌的给定身份令牌。
1.6.2.1. 描述
1.6.2.2. 参数
1.6.2.2.1. 正文参数
Name | 描述 | 必填 | default | pattern |
---|---|---|---|---|
正文(body) | X |
1.6.2.3. 返回类型
1.6.2.4. 内容类型
- application/json
1.6.2.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 | |
0 | 意外错误响应。 |
1.6.2.6. Samples
1.6.2.7. 常规对象参考
1.6.2.7.1. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.2.7.2. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.2.7.2.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.2.7.3. V1ExchangeAuthMachineToMachineTokenRequest
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
idToken | 字符串 | 应该交换的身份令牌。 |
1.6.2.7.4. V1ExchangeAuthMachineToMachineTokenResponse
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
accessToken | 字符串 | 交换访问令牌。 |
1.6.3. ListAuthMachineToMachineConfigs
GET /v1/auth/m2m
ListAuthMachineToMachineConfigs 列出到机器配置的可用 auth 机器。
1.6.3.1. 描述
1.6.3.2. 参数
1.6.3.3. 返回类型
1.6.3.4. 内容类型
- application/json
1.6.3.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 | |
0 | 意外错误响应。 |
1.6.3.6. Samples
1.6.3.7. 常规对象参考
1.6.3.7.1. AuthMachineToMachineConfigMapping
映射将身份令牌的声明值映射到 Central 中的特定角色。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
key | 字符串 | 要使用的身份令牌声明值中的键。 | |||
valueExpression | 字符串 | 一个正则表达式,它将针对指定键标识的身份令牌声明的值进行评估。这个正则表达式采用 RE2 格式,更多详情: https://github.com/google/re2/wiki/Syntax。 | |||
role | 字符串 | 当一个特定身份令牌的键和值匹配时,应发出的角色。 |
1.6.3.7.2. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.3.7.3. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.3.7.3.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.3.7.4. V1AuthMachineToMachineConfig
AuthMachineToMachineConfig 决定从带有 Central 访问令牌的第三方交换身份令牌的规则。M2M 代表机器,因为这是配置的预期用例。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
id | 字符串 | 配置的 UUID。请注意,在将机器添加到机器配置时,不应设置此字段。 | |||
type | GENERIC, GITHUB_ACTIONS, KUBE_SERVICE_ACCOUNT, | ||||
tokenExpirationDuration | 字符串 | 设置从 ExchangeAuthMachineToMachineToken API 调用返回的令牌的过期时间。可能的有效时间单位为:s、m、h。允许的最大过期时间为 24h。例如: 2h45m。有关验证持续时间的更多信息,请参阅: https://pkg.go.dev/time#ParseDuration。 | |||
映射 | 至少需要一个映射才能成功生成访问令牌的有效角色。 | ||||
Issuer | 字符串 | 相关 OIDC 供应商发布 ID 令牌来交换的签发者。当类型为 GENERIC 时,必须是包含 URL 的非空字符串。如果是 GitHub 操作,则必须为空,或设置为 https://token.actions.githubusercontent.com。issuer 是一个唯一的密钥,因此最多可能有一个 GITHUB_ACTIONS 配置,每个 GENERIC 配置必须具有不同的签发者。 |
1.6.3.7.5. V1AuthMachineToMachineConfigType
机器配置的 auth 机器的类型。目前支持 GitHub 操作或其他通用 OIDC 供应商来验证和交换令牌。
Enum 值 |
---|
GENERIC |
GITHUB_ACTIONS |
KUBE_SERVICE_ACCOUNT |
1.6.3.7.6. V1ListAuthMachineToMachineConfigResponse
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
配置 |
1.6.4. DeleteAuthMachineToMachineConfig
DELETE /v1/auth/m2m/{id}
DeleteAuthMachineToMachineConfig 将特定的 auth 机器删除到机器配置。如果一个指定的 auth 机器到机器配置不存在,则不会返回任何错误。
1.6.4.1. 描述
1.6.4.2. 参数
1.6.4.2.1. 路径参数
Name | 描述 | 必填 | default | pattern |
---|---|---|---|---|
id | X | null |
1.6.4.3. 返回类型
对象
1.6.4.4. 内容类型
- application/json
1.6.4.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 |
|
0 | 意外错误响应。 |
1.6.4.6. Samples
1.6.4.7. 常规对象参考
1.6.4.7.1. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.4.7.2. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.4.7.2.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.5. GetAuthMachineToMachineConfig
GET /v1/auth/m2m/{id}
GetAuthMachineToMachineConfig 将特定的 auth 机器检索到机器配置。
1.6.5.1. 描述
1.6.5.2. 参数
1.6.5.2.1. 路径参数
Name | 描述 | 必填 | default | pattern |
---|---|---|---|---|
id | X | null |
1.6.5.3. 返回类型
1.6.5.4. 内容类型
- application/json
1.6.5.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 | |
0 | 意外错误响应。 |
1.6.5.6. Samples
1.6.5.7. 常规对象参考
1.6.5.7.1. AuthMachineToMachineConfigMapping
映射将身份令牌的声明值映射到 Central 中的特定角色。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
key | 字符串 | 要使用的身份令牌声明值中的键。 | |||
valueExpression | 字符串 | 一个正则表达式,它将针对指定键标识的身份令牌声明的值进行评估。这个正则表达式采用 RE2 格式,更多详情: https://github.com/google/re2/wiki/Syntax。 | |||
role | 字符串 | 当一个特定身份令牌的键和值匹配时,应发出的角色。 |
1.6.5.7.2. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.5.7.3. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.5.7.3.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.5.7.4. V1AuthMachineToMachineConfig
AuthMachineToMachineConfig 决定从带有 Central 访问令牌的第三方交换身份令牌的规则。M2M 代表机器,因为这是配置的预期用例。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
id | 字符串 | 配置的 UUID。请注意,在将机器添加到机器配置时,不应设置此字段。 | |||
type | GENERIC, GITHUB_ACTIONS, KUBE_SERVICE_ACCOUNT, | ||||
tokenExpirationDuration | 字符串 | 设置从 ExchangeAuthMachineToMachineToken API 调用返回的令牌的过期时间。可能的有效时间单位为:s、m、h。允许的最大过期时间为 24h。例如: 2h45m。有关验证持续时间的更多信息,请参阅: https://pkg.go.dev/time#ParseDuration。 | |||
映射 | 至少需要一个映射才能成功生成访问令牌的有效角色。 | ||||
Issuer | 字符串 | 相关 OIDC 供应商发布 ID 令牌来交换的签发者。当类型为 GENERIC 时,必须是包含 URL 的非空字符串。如果是 GitHub 操作,则必须为空,或设置为 https://token.actions.githubusercontent.com。issuer 是一个唯一的密钥,因此最多可能有一个 GITHUB_ACTIONS 配置,每个 GENERIC 配置必须具有不同的签发者。 |
1.6.5.7.5. V1AuthMachineToMachineConfigType
机器配置的 auth 机器的类型。目前支持 GitHub 操作或其他通用 OIDC 供应商来验证和交换令牌。
Enum 值 |
---|
GENERIC |
GITHUB_ACTIONS |
KUBE_SERVICE_ACCOUNT |
1.6.5.7.6. V1GetAuthMachineToMachineConfigResponse
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
config |
1.6.6. AddAuthMachineToMachineConfig
POST /v1/auth/m2m
AddAuthMachineToMachineConfig 创建一个新的 auth 机器到机器配置。
1.6.6.1. 描述
1.6.6.2. 参数
1.6.6.2.1. 正文参数
Name | 描述 | 必填 | default | pattern |
---|---|---|---|---|
正文(body) | X |
1.6.6.3. 返回类型
1.6.6.4. 内容类型
- application/json
1.6.6.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 | |
0 | 意外错误响应。 |
1.6.6.6. Samples
1.6.6.7. 常规对象参考
1.6.6.7.1. AuthMachineToMachineConfigMapping
映射将身份令牌的声明值映射到 Central 中的特定角色。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
key | 字符串 | 要使用的身份令牌声明值中的键。 | |||
valueExpression | 字符串 | 一个正则表达式,它将针对指定键标识的身份令牌声明的值进行评估。这个正则表达式采用 RE2 格式,更多详情: https://github.com/google/re2/wiki/Syntax。 | |||
role | 字符串 | 当一个特定身份令牌的键和值匹配时,应发出的角色。 |
1.6.6.7.2. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.6.7.3. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.6.7.3.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.6.7.4. V1AddAuthMachineToMachineConfigRequest
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
config |
1.6.6.7.5. V1AddAuthMachineToMachineConfigResponse
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
config |
1.6.6.7.6. V1AuthMachineToMachineConfig
AuthMachineToMachineConfig 决定从带有 Central 访问令牌的第三方交换身份令牌的规则。M2M 代表机器,因为这是配置的预期用例。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
id | 字符串 | 配置的 UUID。请注意,在将机器添加到机器配置时,不应设置此字段。 | |||
type | GENERIC, GITHUB_ACTIONS, KUBE_SERVICE_ACCOUNT, | ||||
tokenExpirationDuration | 字符串 | 设置从 ExchangeAuthMachineToMachineToken API 调用返回的令牌的过期时间。可能的有效时间单位为:s、m、h。允许的最大过期时间为 24h。例如: 2h45m。有关验证持续时间的更多信息,请参阅: https://pkg.go.dev/time#ParseDuration。 | |||
映射 | 至少需要一个映射才能成功生成访问令牌的有效角色。 | ||||
Issuer | 字符串 | 相关 OIDC 供应商发布 ID 令牌来交换的签发者。当类型为 GENERIC 时,必须是包含 URL 的非空字符串。如果是 GitHub 操作,则必须为空,或设置为 https://token.actions.githubusercontent.com。issuer 是一个唯一的密钥,因此最多可能有一个 GITHUB_ACTIONS 配置,每个 GENERIC 配置必须具有不同的签发者。 |
1.6.6.7.7. V1AuthMachineToMachineConfigType
机器配置的 auth 机器的类型。目前支持 GitHub 操作或其他通用 OIDC 供应商来验证和交换令牌。
Enum 值 |
---|
GENERIC |
GITHUB_ACTIONS |
KUBE_SERVICE_ACCOUNT |
1.6.7. GetAuthStatus
GET /v1/auth/status
GetAuthStatus 返回当前客户端的状态。
1.6.7.1. 描述
1.6.7.2. 参数
1.6.7.3. 返回类型
1.6.7.4. 内容类型
- application/json
1.6.7.5. 响应
代码 | 消息 | datatype |
---|---|---|
200 | 成功响应。 | |
0 | 意外错误响应。 |
1.6.7.6. Samples
1.6.7.7. 常规对象参考
1.6.7.7.1. AuthProviderRequiredAttribute
RequiredAttribute 允许指定 auth 供应商需要返回 ALL 的一组属性。如果在 Central 发布的令牌的外部声明中缺少任何属性,则对此 IdP 的身份验证请求被视为失败。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
attributeKey | 字符串 | ||||
attributeValue | 字符串 |
1.6.7.7.2. GooglerpcStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
code | 整数 | int32 | |||
message | 字符串 | ||||
详情 |
1.6.7.7.3. ProtobufAny
any
包含任意序列化协议缓冲区消息,以及一个描述序列化消息的类型的 URL。
protobuf 库以实用程序函数形式提供对 pack/unpack Any 值的支持,或者对 Any 类型的其他生成的方法提供其他生成的方法。
示例 1: Pack 并在 C++ 中解包信息。
Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
示例 2:打包并解压缩 Java 消息。
Foo foo = ...; Any any = Any.pack(foo); ... if (any.is(Foo.class)) { foo = any.unpack(Foo.class); } // or ... if (any.isSameTypeAs(Foo.getDefaultInstance())) { foo = any.unpack(Foo.getDefaultInstance()); }
Example 3: Pack and unpack a message in Python.
foo = Foo(...) any = Any() any.Pack(foo) ... if any.Is(Foo.DESCRIPTOR): any.Unpack(foo) ...
Example 4: Pack and unpack a message in Go
foo := &pb.Foo{...} any, err := anypb.New(foo) if err != nil { ... } ... foo := &pb.Foo{} if err := any.UnmarshalTo(foo); err != nil { ... }
默认情况下,protobuf 库提供的软件包方法将使用 'type.googleapis.com/full.type.name' 作为类型 URL,解包方法只使用类型 URL 中的完全限定类型名称,如 "foo.bar.com/x/x/y.z"。
1.6.7.7.3.1. JSON 表示
any 值的 JSON 表示使用反序列化的、嵌入式消息的常规表示,以及包含类型 URL 的附加字段 @type
。Example:
package google.profile; message Person { string first_name = 1; string last_name = 2; }
{ "@type": "type.googleapis.com/google.profile.Person", "firstName": <string>, "lastName": <string> }
如果嵌入式消息类型是知名且具有自定义 JSON 表示法,则该表示将被嵌入一个字段值,该值
除 @type
字段外还包含自定义 JSON。示例(用于消息 [google.protobuf.Duration][]):
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type | 字符串 |
唯一标识序列化协议缓冲消息的 URL/资源名称。此字符串必须至少包含一个 \"/\" 字符。URL 路径的最后一部分必须代表类型的完全限定名称(如 |
1.6.7.7.4. StorageAccess
Enum 值 |
---|
NO_ACCESS |
READ_ACCESS |
READ_WRITE_ACCESS |
1.6.7.7.5. StorageAuthProvider
下一标签:15.
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
id | 字符串 | ||||
name | 字符串 | ||||
type | 字符串 | ||||
uiEndpoint | 字符串 | ||||
enabled | 布尔值 | ||||
config |
| config 包含特定于 auth 供应商的配置。每个配置选项都根据给定的 auth 供应商类型而有所不同。OIDC: - \"issuer\":根据 https://openid.net/specs/openid-connect-core-1_0.html#IssuerIdentifier. - \"client_id\": 客户端 ID,根据 https://www.rfc-editor.org/rfc/rfc6749.html#section-2.2. - \"client_secret\":客户端 secret,根据 https://www.rfc-editor.org/rfc/rfc6749.html#section-2.3.1. - \"do_not_use_client_secret\": 设置为 \"true\"。从 \"fragment\", \"post\", 或 \"query\". - \"disable_offline_access_scope\": 设置为 \"true\":如果未发布离线令牌,则设为 \"extra_scopes\": 一个空格分隔的额外范围字符串,以请求,除了 针对 https://www.rfc-editor.org/rfc/rfc6749.html#section-3.3 的 \"openid 配置集 email\" 外。OpenShift Auth:不支持额外的配置选项。User PKI: - \"keys\":可信证书 PEM 编码。SAML: - \"sp_issuer\": 根据 https://datatracker.ietf.org/doc/html/rfc7522#section-3. - \"idp_metadata_url\": 元数据 URL,根据 https://docs.oasis-open.org/security/saml/v2.0/saml-metadata-2.0-os.pdf. - \"idp_issuer\": IdP issuer. - \"idp_cert_pem\": cert PEM 编码 for the IdP 端点。- \"idp_sso_url\": IdP SSO URL. - \"idp_name_id\":IAP: - \"audience\":要使用的受众。 | |||
loginUrl | 字符串 | 登录 URL 将由后端提供,且可能不会在请求中指定。 | |||
验证 | 布尔值 | ||||
extraUiEndpoints |
|
除了 | |||
active | 布尔值 | ||||
requiredAttributes | |||||
遍历 | |||||
claimMappings |
| 指定将复制到 Rox 令牌属性的 IdP 令牌中的声明。此映射中的每个密钥包含我们要映射的 IdP 令牌的路径。路径用 \".\" 符号分隔。例如,如果 IdP 令牌有效负载类似:{ \"a\": { \"b\" : \"c\" : \"c\", \"d\": true, \"e\": [ \"val2\", \"val3\" ], \"f\": [ true, false, false ], \"g\": 123.0, \"h\": [ 1, 2, 3] } } then \"a.b\" 是一个有效的键,\"a.z\" 则不行。我们支持以下声明类型:* 字符串(path \"a.b\")* bool (path \"a.d\")* 字符串数组(path \"a.e\")* bool 数组(path \"a.f.\")我们不支持以下声明类型:{ complex claims (path \"a\"a\")* float/integer claims (path \"a.g\")* float/integer 数组声明(path \"a.h\") every value 包含一个 Rox 令牌属性名称,我们要向其添加声明。例如,如果 value 是 \"groups\",则声明可以在令牌中的 \"external_user.Attributes.groups\" 中找到。注: 我们只支持 OIDC 身份验证供应商。 | |||
lastUpdated | Date | 最后更新表示 auth 提供程序最后一次更新的时间。如果在此时间戳之前由身份验证提供程序发出了令牌,则它们被视为无效。因此,所有客户端都必须重新发布其令牌(通过刷新或额外的登录尝试)。 | date-time |
1.6.7.7.6. StorageServiceIdentity
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
serialStr | 字符串 | ||||
serial | 字符串 | int64 | |||
id | 字符串 | ||||
type | UNKNOWN_SERVICE, SENSOR_SERVICE, CENTRAL_SERVICE, CENTRAL_DB_SERVICE, REMOTE_SERVICE, COLLECTOR_SERVICE, MONITORING_UI_SERVICE, MONITORING_DB_SERVICE, MONITORING_CLIENT_SERVICE, BENCHMARK_SERVICE, SCANNER_SERVICE, SCANER_DB_SERVICE, ADMISSION_CONTROL_SERVICE, SCANNER_V4_INDEXER_SERVICE, SCANNER_V4_MATCHER_SERVICE, SCANNER_V4_DB_SERVICE, SCANNER_V4_SERVICE, REGISTRANT_SERVICE, | ||||
initBundleId | 字符串 |
1.6.7.7.7. StorageServiceType
Next available tag: 18
- SCANNER_V4_SERVICE :当 Scanner V4 以组合模式运行时使用。
Enum 值 |
---|
UNKNOWN_SERVICE |
SENSOR_SERVICE |
CENTRAL_SERVICE |
CENTRAL_DB_SERVICE |
REMOTE_SERVICE |
COLLECTOR_SERVICE |
监控_UI_SERVICE |
监控_DB_SERVICE |
监控_CLIENT_SERVICE |
BENCHMARK_SERVICE |
SCANNER_SERVICE |
SCANNER_DB_SERVICE |
ADMISSION_CONTROL_SERVICE |
SCANNER_V4_INDEXER_SERVICE |
SCANNER_V4_MATCHER_SERVICE |
SCANNER_V4_DB_SERVICE |
SCANNER_V4_SERVICE |
REGISTRANT_SERVICE |
1.6.7.7.8. StorageTraits
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
mutabilityMode | ALLOW_MUTATE, ALLOW_MUTATE_FORCED, | ||||
可见性 | 可见、隐藏、 | ||||
origin | IMPERATIVE, DEFAULT, DECLARATIVE, DECLARATIVE_ORPHANED, |
1.6.7.7.9. StorageUserInfo
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
username | 字符串 | ||||
friendlyName | 字符串 | ||||
权限 | |||||
roles |
1.6.7.7.10. StorageUserInfoRole
角色与旧格式 storage.Role 兼容,因此仅包含角色名称和关联的权限。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
name | 字符串 | ||||
resourceToAccess |
1.6.7.7.11. TraitsMutabilityMode
实验性。注意:请参考在时间使用 MutabilityMode 时。它将在以后被替换(ROX-14276)。MutabilityMode 指定是否以及如何修改对象。默认为 ALLOW_MUTATE,意味着没有修改限制,这等同于没有 MutabilityMode 规格。ALLOW_MUTATE_FORCED forbids 所有修改操作,除了删除强制位的对象。
更改此字段的状态时要小心。例如,将对象从 ALLOW_MUTATE 修改为 ALLOW_MUTATE_FORCED,但会禁止以后更改它,包括将其修改回 ALLOW_MUTATE。
Enum 值 |
---|
EXTETE_MUTATE |
ALLOW_MUTATE_FORCED |
1.6.7.7.12. TraitsOrigin
origin 指定对象的起源。对象可以有四个不同的来源: - IMPERATIVE:对象是通过 API 创建的。默认情况下会假设这个对象。- DEFAULT:对象是默认对象,如默认角色、访问范围等。- DECLARATIVE:对象通过声明性配置创建。- DECLARATIVE_ORPHANED:对象通过声明性配置创建,然后成功删除(例如,它被声明配置引用)创建。- DECLARATIVE_ORPHANED:对象通过声明性配置创建,然后取消删除(例如,它被另一个对象引用),它基于原始对象,应用到对象。不允许使用 DECLARATIVE 原始对象通过 API 修改,只能通过声明性配置进行修改。另外,它们可能无法引用带有 IMPERATIVE 原始卷的对象。不允许使用 DEFAULT origin 的对象通过 API 或声明性配置进行修改。它们可以被所有其他对象引用。允许通过 API 修改具有 IMPERATIVE 来源的对象,而不是通过声明性配置进行修改。它们可能会引用所有其他对象。不允许使用 DECLARATIVE_ORPHANED 原始对象通过 API 或声明性配置进行修改。如果资源在声明配置中重新定义,则 DECLARATIVE_ORPHANED 资源可能会再次变为 DECLARATIVE。使用此源的对象将在不再被其他资源引用后立即从系统中清理。它们可以被所有其他对象引用。
Enum 值 |
---|
IMPERATIVE |
DEFAULT |
DECLARATIVE |
DECLARATIVE_ORPHANED |
1.6.7.7.13. TraitsVisibility
EXPERIMENTAL. visibility 允许指定对象是否应该对某些 API 可见。
Enum 值 |
---|
VISIBLE |
HIDDEN |
1.6.7.7.14. UserInfoResourceToAccess
ResourceToAccess 代表一个权限集合。它与旧的 storage.Role 格式兼容,并在只需要聚合权限的地方替换它。
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
resourceToAccess |
1.6.7.7.15. V1AuthStatus
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
userId | 字符串 | ||||
serviceId | |||||
过期 | Date | date-time | |||
refreshUrl | 字符串 | ||||
authProvider | |||||
userInfo | |||||
userAttributes | |||||
idpToken | 字符串 | 由底层身份提供程序返回到 ACS 的令牌。此字段只在几个特定上下文中设置。不要依赖响应中的此字段。 |
1.6.7.7.16. V1UserAttribute
字段名称 | 必填 | nullable | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
key | 字符串 | ||||
values |
|