Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
GET /v1/rbac/bindings/{id}
代码 (Code) | 消息 (Message) | 数据类型 (Datatype) |
---|---|---|
200 |
成功响应。(A successful response.) |
|
0 |
意外错误响应。(An unexpected error response.) |
字段名称 (Field Name) | 必填 (Required) | 可空 (Nullable) | 类型 (Type) | 描述 (Description) | 格式 (Format) |
---|---|---|---|---|---|
code |
整数 (Integer) |
int32 |
|||
message |
字符串 (String) |
||||
details |
ProtobufAny 列表 (List of ProtobufAny) |
Any
包含任意序列化的协议缓冲区消息以及描述序列化消息类型的 URL。
Protobuf 库提供支持,以实用程序函数或 Any 类型的附加生成方法的形式打包/解包 Any 值。
示例 1:在 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/y.z”将产生类型名称“y.z”。
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 表示,则该表示将被嵌入,添加一个字段value
,该字段除了@type
字段外还保存自定义 JSON。示例(对于消息 [google.protobuf.Duration][])
{ "@type": "type.googleapis.com/google.protobuf.Duration", "value": "1.212s" }
字段名称 (Field Name) | 必填 (Required) | 可空 (Nullable) | 类型 (Type) | 描述 (Description) | 格式 (Format) |
---|---|---|---|---|---|
@type |
字符串 (String) |
一个 URL/资源名称,唯一标识序列化 Protocol Buffer 消息的类型。此字符串必须包含至少一个“/”字符。URL 路径的最后一部分必须表示类型的完全限定名称(例如,`path/google.protobuf.Duration`)。名称应采用规范形式(例如,不接受开头的“.”)。实际上,团队通常会预编译其在 Any 上下文中预期使用的所有类型到二进制文件中。但是,对于使用方案 `http`、`https` 或无方案的 URL,可以选择设置一个类型服务器,用于将类型 URL 映射到消息定义,如下所示:* 如果没有提供方案,则假定为 `https`。* 对 URL 的 HTTP GET 请求必须产生二进制格式的 [google.protobuf.Type][] 值,否则会产生错误。* 应用程序允许根据 URL 缓存查找结果,或将其预编译到二进制文件中以避免任何查找。因此,需要在类型更改时保留二进制兼容性。(使用版本化的类型名称来管理重大更改。)注意:此功能当前在官方 protobuf 版本中不可用,并且不适用于以 type.googleapis.com 开头的类型 URL。截至 2023 年 5 月,没有广泛使用的类型服务器实现,也没有计划实现一个。除了 `http`、`https`(或空方案)之外的其他方案可能会与实现相关的语义一起使用。 |
Properties of an individual k8s RoleBinding or ClusterRoleBinding. ////////////////////////////////////////
字段名称 (Field Name) | 必填 (Required) | 可空 (Nullable) | 类型 (Type) | 描述 (Description) | 格式 (Format) |
---|---|---|---|---|---|
id |
字符串 (String) |
||||
名称 |
字符串 (String) |
||||
命名空间 |
字符串 (String) |
||||
集群 ID |
字符串 (String) |
||||
集群名称 |
字符串 (String) |
||||
集群角色 |
布尔值 |
ClusterRole 指定绑定是否绑定集群角色。但是,它不能用于确定绑定是否是集群角色绑定。这可以与命名空间结合使用。如果命名空间为空并且集群角色为真,则绑定是集群角色绑定。 |
|||
标签 |
|
||||
注释 |
|
||||
创建时间 |
日期 |
日期时间 |
|||
主体 |
|||||
角色 ID |
字符串 (String) |
Properties of an individual subjects who are granted roles via role bindings. ////////////////////////////////////////
字段名称 (Field Name) | 必填 (Required) | 可空 (Nullable) | 类型 (Type) | 描述 (Description) | 格式 (Format) |
---|---|---|---|---|---|
id |
字符串 (String) |
||||
类型 |
UNSET_KIND, SERVICE_ACCOUNT, USER, GROUP, |
||||
名称 |
字符串 (String) |
||||
命名空间 |
字符串 (String) |
||||
集群 ID |
字符串 (String) |
||||
集群名称 |
字符串 (String) |