Foo foo = ...; Any any; any.PackFrom(foo); ... if (any.UnpackTo(&foo)) { ... }
GET /v1/signatureintegrations
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
代码 |
整数 |
int32 |
|||
消息 |
字符串 |
||||
细节 |
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
。示例
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" }
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
@type |
字符串 |
一个 URL/资源名称,用于唯一标识序列化协议缓冲区消息的类型。此字符串必须包含至少一个“/”字符。URL 路径的最后一部分必须表示类型的完全限定名称(例如, |
包含用于验证附加到 cosign 签名的证书的所有验证数据。如果仅给出证书,则将假定 Fulcio 受信任的根链并对其进行验证。如果仅给出链,则在验证时将使用此链而不是 Fulcio 受信任的根链。如果没有给出证书或链,则将假定 Fulcio 受信任的根链并对其进行验证。
字段名称 | 必填 | 可空 | 类型 | 描述 | 格式 |
---|---|---|---|---|---|
certificatePemEnc |
字符串 |
用于验证的 PEM 编码证书。 |
|||
certificateChainPemEnc |
字符串 |
用于验证的 PEM 编码证书链。 |
|||
certificateOidcIssuer |
字符串 |
用于验证的证书 OIDC 发行者。这支持遵循 RE2 语法的正则表达式:https://github.com/google/re2/wiki/Syntax。如果证书未指定 OIDC 发行者,则可以使用 '.*' 作为 OIDC 发行者。但是,建议根据规范使用与 Fulcio 兼容的证书:https://github.com/sigstore/fulcio/blob/main/docs/certificate-specification.md。 |
|||
certificateIdentity |
字符串 |
用于验证的证书标识。这支持遵循 RE2 语法的正则表达式:https://github.com/google/re2/wiki/Syntax。如果证书未指定标识,则可以使用 '.*' 作为标识。但是,建议根据规范使用与 Fulcio 兼容的证书:https://github.com/sigstore/fulcio/blob/main/docs/certificate-specification.md。 |