570 lines
21 KiB
Go
570 lines
21 KiB
Go
// Code generated by protoc-gen-go. DO NOT EDIT.
|
|
// source: google/iam/v1/policy.proto
|
|
|
|
package iam
|
|
|
|
import (
|
|
fmt "fmt"
|
|
math "math"
|
|
|
|
proto "github.com/golang/protobuf/proto"
|
|
_ "google.golang.org/genproto/googleapis/api/annotations"
|
|
expr "google.golang.org/genproto/googleapis/type/expr"
|
|
)
|
|
|
|
// Reference imports to suppress errors if they are not otherwise used.
|
|
var _ = proto.Marshal
|
|
var _ = fmt.Errorf
|
|
var _ = math.Inf
|
|
|
|
// This is a compile-time assertion to ensure that this generated file
|
|
// is compatible with the proto package it is being compiled against.
|
|
// A compilation error at this line likely means your copy of the
|
|
// proto package needs to be updated.
|
|
const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
|
|
|
|
// The type of action performed on a Binding in a policy.
|
|
type BindingDelta_Action int32
|
|
|
|
const (
|
|
// Unspecified.
|
|
BindingDelta_ACTION_UNSPECIFIED BindingDelta_Action = 0
|
|
// Addition of a Binding.
|
|
BindingDelta_ADD BindingDelta_Action = 1
|
|
// Removal of a Binding.
|
|
BindingDelta_REMOVE BindingDelta_Action = 2
|
|
)
|
|
|
|
var BindingDelta_Action_name = map[int32]string{
|
|
0: "ACTION_UNSPECIFIED",
|
|
1: "ADD",
|
|
2: "REMOVE",
|
|
}
|
|
|
|
var BindingDelta_Action_value = map[string]int32{
|
|
"ACTION_UNSPECIFIED": 0,
|
|
"ADD": 1,
|
|
"REMOVE": 2,
|
|
}
|
|
|
|
func (x BindingDelta_Action) String() string {
|
|
return proto.EnumName(BindingDelta_Action_name, int32(x))
|
|
}
|
|
|
|
func (BindingDelta_Action) EnumDescriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{3, 0}
|
|
}
|
|
|
|
// The type of action performed on an audit configuration in a policy.
|
|
type AuditConfigDelta_Action int32
|
|
|
|
const (
|
|
// Unspecified.
|
|
AuditConfigDelta_ACTION_UNSPECIFIED AuditConfigDelta_Action = 0
|
|
// Addition of an audit configuration.
|
|
AuditConfigDelta_ADD AuditConfigDelta_Action = 1
|
|
// Removal of an audit configuration.
|
|
AuditConfigDelta_REMOVE AuditConfigDelta_Action = 2
|
|
)
|
|
|
|
var AuditConfigDelta_Action_name = map[int32]string{
|
|
0: "ACTION_UNSPECIFIED",
|
|
1: "ADD",
|
|
2: "REMOVE",
|
|
}
|
|
|
|
var AuditConfigDelta_Action_value = map[string]int32{
|
|
"ACTION_UNSPECIFIED": 0,
|
|
"ADD": 1,
|
|
"REMOVE": 2,
|
|
}
|
|
|
|
func (x AuditConfigDelta_Action) String() string {
|
|
return proto.EnumName(AuditConfigDelta_Action_name, int32(x))
|
|
}
|
|
|
|
func (AuditConfigDelta_Action) EnumDescriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{4, 0}
|
|
}
|
|
|
|
// Defines an Identity and Access Management (IAM) policy. It is used to
|
|
// specify access control policies for Cloud Platform resources.
|
|
//
|
|
//
|
|
// A `Policy` is a collection of `bindings`. A `binding` binds one or more
|
|
// `members` to a single `role`. Members can be user accounts, service accounts,
|
|
// Google groups, and domains (such as G Suite). A `role` is a named list of
|
|
// permissions (defined by IAM or configured by users). A `binding` can
|
|
// optionally specify a `condition`, which is a logic expression that further
|
|
// constrains the role binding based on attributes about the request and/or
|
|
// target resource.
|
|
//
|
|
// **JSON Example**
|
|
//
|
|
// {
|
|
// "bindings": [
|
|
// {
|
|
// "role": "roles/resourcemanager.organizationAdmin",
|
|
// "members": [
|
|
// "user:mike@example.com",
|
|
// "group:admins@example.com",
|
|
// "domain:google.com",
|
|
// "serviceAccount:my-project-id@appspot.gserviceaccount.com"
|
|
// ]
|
|
// },
|
|
// {
|
|
// "role": "roles/resourcemanager.organizationViewer",
|
|
// "members": ["user:eve@example.com"],
|
|
// "condition": {
|
|
// "title": "expirable access",
|
|
// "description": "Does not grant access after Sep 2020",
|
|
// "expression": "request.time <
|
|
// timestamp('2020-10-01T00:00:00.000Z')",
|
|
// }
|
|
// }
|
|
// ]
|
|
// }
|
|
//
|
|
// **YAML Example**
|
|
//
|
|
// bindings:
|
|
// - members:
|
|
// - user:mike@example.com
|
|
// - group:admins@example.com
|
|
// - domain:google.com
|
|
// - serviceAccount:my-project-id@appspot.gserviceaccount.com
|
|
// role: roles/resourcemanager.organizationAdmin
|
|
// - members:
|
|
// - user:eve@example.com
|
|
// role: roles/resourcemanager.organizationViewer
|
|
// condition:
|
|
// title: expirable access
|
|
// description: Does not grant access after Sep 2020
|
|
// expression: request.time < timestamp('2020-10-01T00:00:00.000Z')
|
|
//
|
|
// For a description of IAM and its features, see the
|
|
// [IAM developer's guide](https://cloud.google.com/iam/docs).
|
|
type Policy struct {
|
|
// Specifies the format of the policy.
|
|
//
|
|
// Valid values are 0, 1, and 3. Requests specifying an invalid value will be
|
|
// rejected.
|
|
//
|
|
// Operations affecting conditional bindings must specify version 3. This can
|
|
// be either setting a conditional policy, modifying a conditional binding,
|
|
// or removing a binding (conditional or unconditional) from the stored
|
|
// conditional policy.
|
|
// Operations on non-conditional policies may specify any valid value or
|
|
// leave the field unset.
|
|
//
|
|
// If no etag is provided in the call to `setIamPolicy`, version compliance
|
|
// checks against the stored policy is skipped.
|
|
Version int32 `protobuf:"varint,1,opt,name=version,proto3" json:"version,omitempty"`
|
|
// Associates a list of `members` to a `role`. Optionally may specify a
|
|
// `condition` that determines when binding is in effect.
|
|
// `bindings` with no members will result in an error.
|
|
Bindings []*Binding `protobuf:"bytes,4,rep,name=bindings,proto3" json:"bindings,omitempty"`
|
|
// `etag` is used for optimistic concurrency control as a way to help
|
|
// prevent simultaneous updates of a policy from overwriting each other.
|
|
// It is strongly suggested that systems make use of the `etag` in the
|
|
// read-modify-write cycle to perform policy updates in order to avoid race
|
|
// conditions: An `etag` is returned in the response to `getIamPolicy`, and
|
|
// systems are expected to put that etag in the request to `setIamPolicy` to
|
|
// ensure that their change will be applied to the same version of the policy.
|
|
//
|
|
// If no `etag` is provided in the call to `setIamPolicy`, then the existing
|
|
// policy is overwritten. Due to blind-set semantics of an etag-less policy,
|
|
// 'setIamPolicy' will not fail even if the incoming policy version does not
|
|
// meet the requirements for modifying the stored policy.
|
|
Etag []byte `protobuf:"bytes,3,opt,name=etag,proto3" json:"etag,omitempty"`
|
|
XXX_NoUnkeyedLiteral struct{} `json:"-"`
|
|
XXX_unrecognized []byte `json:"-"`
|
|
XXX_sizecache int32 `json:"-"`
|
|
}
|
|
|
|
func (m *Policy) Reset() { *m = Policy{} }
|
|
func (m *Policy) String() string { return proto.CompactTextString(m) }
|
|
func (*Policy) ProtoMessage() {}
|
|
func (*Policy) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{0}
|
|
}
|
|
|
|
func (m *Policy) XXX_Unmarshal(b []byte) error {
|
|
return xxx_messageInfo_Policy.Unmarshal(m, b)
|
|
}
|
|
func (m *Policy) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
|
|
return xxx_messageInfo_Policy.Marshal(b, m, deterministic)
|
|
}
|
|
func (m *Policy) XXX_Merge(src proto.Message) {
|
|
xxx_messageInfo_Policy.Merge(m, src)
|
|
}
|
|
func (m *Policy) XXX_Size() int {
|
|
return xxx_messageInfo_Policy.Size(m)
|
|
}
|
|
func (m *Policy) XXX_DiscardUnknown() {
|
|
xxx_messageInfo_Policy.DiscardUnknown(m)
|
|
}
|
|
|
|
var xxx_messageInfo_Policy proto.InternalMessageInfo
|
|
|
|
func (m *Policy) GetVersion() int32 {
|
|
if m != nil {
|
|
return m.Version
|
|
}
|
|
return 0
|
|
}
|
|
|
|
func (m *Policy) GetBindings() []*Binding {
|
|
if m != nil {
|
|
return m.Bindings
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *Policy) GetEtag() []byte {
|
|
if m != nil {
|
|
return m.Etag
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Associates `members` with a `role`.
|
|
type Binding struct {
|
|
// Role that is assigned to `members`.
|
|
// For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
|
|
Role string `protobuf:"bytes,1,opt,name=role,proto3" json:"role,omitempty"`
|
|
// Specifies the identities requesting access for a Cloud Platform resource.
|
|
// `members` can have the following values:
|
|
//
|
|
// * `allUsers`: A special identifier that represents anyone who is
|
|
// on the internet; with or without a Google account.
|
|
//
|
|
// * `allAuthenticatedUsers`: A special identifier that represents anyone
|
|
// who is authenticated with a Google account or a service account.
|
|
//
|
|
// * `user:{emailid}`: An email address that represents a specific Google
|
|
// account. For example, `alice@example.com` .
|
|
//
|
|
//
|
|
// * `serviceAccount:{emailid}`: An email address that represents a service
|
|
// account. For example, `my-other-app@appspot.gserviceaccount.com`.
|
|
//
|
|
// * `group:{emailid}`: An email address that represents a Google group.
|
|
// For example, `admins@example.com`.
|
|
//
|
|
//
|
|
// * `domain:{domain}`: The G Suite domain (primary) that represents all the
|
|
// users of that domain. For example, `google.com` or `example.com`.
|
|
//
|
|
//
|
|
Members []string `protobuf:"bytes,2,rep,name=members,proto3" json:"members,omitempty"`
|
|
// The condition that is associated with this binding.
|
|
// NOTE: An unsatisfied condition will not allow user access via current
|
|
// binding. Different bindings, including their conditions, are examined
|
|
// independently.
|
|
Condition *expr.Expr `protobuf:"bytes,3,opt,name=condition,proto3" json:"condition,omitempty"`
|
|
XXX_NoUnkeyedLiteral struct{} `json:"-"`
|
|
XXX_unrecognized []byte `json:"-"`
|
|
XXX_sizecache int32 `json:"-"`
|
|
}
|
|
|
|
func (m *Binding) Reset() { *m = Binding{} }
|
|
func (m *Binding) String() string { return proto.CompactTextString(m) }
|
|
func (*Binding) ProtoMessage() {}
|
|
func (*Binding) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{1}
|
|
}
|
|
|
|
func (m *Binding) XXX_Unmarshal(b []byte) error {
|
|
return xxx_messageInfo_Binding.Unmarshal(m, b)
|
|
}
|
|
func (m *Binding) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
|
|
return xxx_messageInfo_Binding.Marshal(b, m, deterministic)
|
|
}
|
|
func (m *Binding) XXX_Merge(src proto.Message) {
|
|
xxx_messageInfo_Binding.Merge(m, src)
|
|
}
|
|
func (m *Binding) XXX_Size() int {
|
|
return xxx_messageInfo_Binding.Size(m)
|
|
}
|
|
func (m *Binding) XXX_DiscardUnknown() {
|
|
xxx_messageInfo_Binding.DiscardUnknown(m)
|
|
}
|
|
|
|
var xxx_messageInfo_Binding proto.InternalMessageInfo
|
|
|
|
func (m *Binding) GetRole() string {
|
|
if m != nil {
|
|
return m.Role
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Binding) GetMembers() []string {
|
|
if m != nil {
|
|
return m.Members
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *Binding) GetCondition() *expr.Expr {
|
|
if m != nil {
|
|
return m.Condition
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// The difference delta between two policies.
|
|
type PolicyDelta struct {
|
|
// The delta for Bindings between two policies.
|
|
BindingDeltas []*BindingDelta `protobuf:"bytes,1,rep,name=binding_deltas,json=bindingDeltas,proto3" json:"binding_deltas,omitempty"`
|
|
// The delta for AuditConfigs between two policies.
|
|
AuditConfigDeltas []*AuditConfigDelta `protobuf:"bytes,2,rep,name=audit_config_deltas,json=auditConfigDeltas,proto3" json:"audit_config_deltas,omitempty"`
|
|
XXX_NoUnkeyedLiteral struct{} `json:"-"`
|
|
XXX_unrecognized []byte `json:"-"`
|
|
XXX_sizecache int32 `json:"-"`
|
|
}
|
|
|
|
func (m *PolicyDelta) Reset() { *m = PolicyDelta{} }
|
|
func (m *PolicyDelta) String() string { return proto.CompactTextString(m) }
|
|
func (*PolicyDelta) ProtoMessage() {}
|
|
func (*PolicyDelta) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{2}
|
|
}
|
|
|
|
func (m *PolicyDelta) XXX_Unmarshal(b []byte) error {
|
|
return xxx_messageInfo_PolicyDelta.Unmarshal(m, b)
|
|
}
|
|
func (m *PolicyDelta) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
|
|
return xxx_messageInfo_PolicyDelta.Marshal(b, m, deterministic)
|
|
}
|
|
func (m *PolicyDelta) XXX_Merge(src proto.Message) {
|
|
xxx_messageInfo_PolicyDelta.Merge(m, src)
|
|
}
|
|
func (m *PolicyDelta) XXX_Size() int {
|
|
return xxx_messageInfo_PolicyDelta.Size(m)
|
|
}
|
|
func (m *PolicyDelta) XXX_DiscardUnknown() {
|
|
xxx_messageInfo_PolicyDelta.DiscardUnknown(m)
|
|
}
|
|
|
|
var xxx_messageInfo_PolicyDelta proto.InternalMessageInfo
|
|
|
|
func (m *PolicyDelta) GetBindingDeltas() []*BindingDelta {
|
|
if m != nil {
|
|
return m.BindingDeltas
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *PolicyDelta) GetAuditConfigDeltas() []*AuditConfigDelta {
|
|
if m != nil {
|
|
return m.AuditConfigDeltas
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// One delta entry for Binding. Each individual change (only one member in each
|
|
// entry) to a binding will be a separate entry.
|
|
type BindingDelta struct {
|
|
// The action that was performed on a Binding.
|
|
// Required
|
|
Action BindingDelta_Action `protobuf:"varint,1,opt,name=action,proto3,enum=google.iam.v1.BindingDelta_Action" json:"action,omitempty"`
|
|
// Role that is assigned to `members`.
|
|
// For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
|
|
// Required
|
|
Role string `protobuf:"bytes,2,opt,name=role,proto3" json:"role,omitempty"`
|
|
// A single identity requesting access for a Cloud Platform resource.
|
|
// Follows the same format of Binding.members.
|
|
// Required
|
|
Member string `protobuf:"bytes,3,opt,name=member,proto3" json:"member,omitempty"`
|
|
// The condition that is associated with this binding.
|
|
Condition *expr.Expr `protobuf:"bytes,4,opt,name=condition,proto3" json:"condition,omitempty"`
|
|
XXX_NoUnkeyedLiteral struct{} `json:"-"`
|
|
XXX_unrecognized []byte `json:"-"`
|
|
XXX_sizecache int32 `json:"-"`
|
|
}
|
|
|
|
func (m *BindingDelta) Reset() { *m = BindingDelta{} }
|
|
func (m *BindingDelta) String() string { return proto.CompactTextString(m) }
|
|
func (*BindingDelta) ProtoMessage() {}
|
|
func (*BindingDelta) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{3}
|
|
}
|
|
|
|
func (m *BindingDelta) XXX_Unmarshal(b []byte) error {
|
|
return xxx_messageInfo_BindingDelta.Unmarshal(m, b)
|
|
}
|
|
func (m *BindingDelta) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
|
|
return xxx_messageInfo_BindingDelta.Marshal(b, m, deterministic)
|
|
}
|
|
func (m *BindingDelta) XXX_Merge(src proto.Message) {
|
|
xxx_messageInfo_BindingDelta.Merge(m, src)
|
|
}
|
|
func (m *BindingDelta) XXX_Size() int {
|
|
return xxx_messageInfo_BindingDelta.Size(m)
|
|
}
|
|
func (m *BindingDelta) XXX_DiscardUnknown() {
|
|
xxx_messageInfo_BindingDelta.DiscardUnknown(m)
|
|
}
|
|
|
|
var xxx_messageInfo_BindingDelta proto.InternalMessageInfo
|
|
|
|
func (m *BindingDelta) GetAction() BindingDelta_Action {
|
|
if m != nil {
|
|
return m.Action
|
|
}
|
|
return BindingDelta_ACTION_UNSPECIFIED
|
|
}
|
|
|
|
func (m *BindingDelta) GetRole() string {
|
|
if m != nil {
|
|
return m.Role
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *BindingDelta) GetMember() string {
|
|
if m != nil {
|
|
return m.Member
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *BindingDelta) GetCondition() *expr.Expr {
|
|
if m != nil {
|
|
return m.Condition
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// One delta entry for AuditConfig. Each individual change (only one
|
|
// exempted_member in each entry) to a AuditConfig will be a separate entry.
|
|
type AuditConfigDelta struct {
|
|
// The action that was performed on an audit configuration in a policy.
|
|
// Required
|
|
Action AuditConfigDelta_Action `protobuf:"varint,1,opt,name=action,proto3,enum=google.iam.v1.AuditConfigDelta_Action" json:"action,omitempty"`
|
|
// Specifies a service that was configured for Cloud Audit Logging.
|
|
// For example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
|
|
// `allServices` is a special value that covers all services.
|
|
// Required
|
|
Service string `protobuf:"bytes,2,opt,name=service,proto3" json:"service,omitempty"`
|
|
// A single identity that is exempted from "data access" audit
|
|
// logging for the `service` specified above.
|
|
// Follows the same format of Binding.members.
|
|
ExemptedMember string `protobuf:"bytes,3,opt,name=exempted_member,json=exemptedMember,proto3" json:"exempted_member,omitempty"`
|
|
// Specifies the log_type that was be enabled. ADMIN_ACTIVITY is always
|
|
// enabled, and cannot be configured.
|
|
// Required
|
|
LogType string `protobuf:"bytes,4,opt,name=log_type,json=logType,proto3" json:"log_type,omitempty"`
|
|
XXX_NoUnkeyedLiteral struct{} `json:"-"`
|
|
XXX_unrecognized []byte `json:"-"`
|
|
XXX_sizecache int32 `json:"-"`
|
|
}
|
|
|
|
func (m *AuditConfigDelta) Reset() { *m = AuditConfigDelta{} }
|
|
func (m *AuditConfigDelta) String() string { return proto.CompactTextString(m) }
|
|
func (*AuditConfigDelta) ProtoMessage() {}
|
|
func (*AuditConfigDelta) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor_a3cd40b8a66b2a99, []int{4}
|
|
}
|
|
|
|
func (m *AuditConfigDelta) XXX_Unmarshal(b []byte) error {
|
|
return xxx_messageInfo_AuditConfigDelta.Unmarshal(m, b)
|
|
}
|
|
func (m *AuditConfigDelta) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
|
|
return xxx_messageInfo_AuditConfigDelta.Marshal(b, m, deterministic)
|
|
}
|
|
func (m *AuditConfigDelta) XXX_Merge(src proto.Message) {
|
|
xxx_messageInfo_AuditConfigDelta.Merge(m, src)
|
|
}
|
|
func (m *AuditConfigDelta) XXX_Size() int {
|
|
return xxx_messageInfo_AuditConfigDelta.Size(m)
|
|
}
|
|
func (m *AuditConfigDelta) XXX_DiscardUnknown() {
|
|
xxx_messageInfo_AuditConfigDelta.DiscardUnknown(m)
|
|
}
|
|
|
|
var xxx_messageInfo_AuditConfigDelta proto.InternalMessageInfo
|
|
|
|
func (m *AuditConfigDelta) GetAction() AuditConfigDelta_Action {
|
|
if m != nil {
|
|
return m.Action
|
|
}
|
|
return AuditConfigDelta_ACTION_UNSPECIFIED
|
|
}
|
|
|
|
func (m *AuditConfigDelta) GetService() string {
|
|
if m != nil {
|
|
return m.Service
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *AuditConfigDelta) GetExemptedMember() string {
|
|
if m != nil {
|
|
return m.ExemptedMember
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *AuditConfigDelta) GetLogType() string {
|
|
if m != nil {
|
|
return m.LogType
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func init() {
|
|
proto.RegisterEnum("google.iam.v1.BindingDelta_Action", BindingDelta_Action_name, BindingDelta_Action_value)
|
|
proto.RegisterEnum("google.iam.v1.AuditConfigDelta_Action", AuditConfigDelta_Action_name, AuditConfigDelta_Action_value)
|
|
proto.RegisterType((*Policy)(nil), "google.iam.v1.Policy")
|
|
proto.RegisterType((*Binding)(nil), "google.iam.v1.Binding")
|
|
proto.RegisterType((*PolicyDelta)(nil), "google.iam.v1.PolicyDelta")
|
|
proto.RegisterType((*BindingDelta)(nil), "google.iam.v1.BindingDelta")
|
|
proto.RegisterType((*AuditConfigDelta)(nil), "google.iam.v1.AuditConfigDelta")
|
|
}
|
|
|
|
func init() {
|
|
proto.RegisterFile("google/iam/v1/policy.proto", fileDescriptor_a3cd40b8a66b2a99)
|
|
}
|
|
|
|
var fileDescriptor_a3cd40b8a66b2a99 = []byte{
|
|
// 550 bytes of a gzipped FileDescriptorProto
|
|
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x93, 0xcf, 0xae, 0xd2, 0x4e,
|
|
0x14, 0xc7, 0x7f, 0x03, 0xfc, 0xca, 0xe5, 0x70, 0x2f, 0xc2, 0xdc, 0x84, 0x54, 0x34, 0x91, 0x74,
|
|
0xa1, 0xac, 0x5a, 0xc1, 0xb8, 0xd1, 0xc4, 0x84, 0x7f, 0x1a, 0x16, 0xf7, 0x42, 0xc6, 0x2b, 0x0b,
|
|
0x43, 0x42, 0x86, 0x76, 0xac, 0x63, 0xda, 0x4e, 0xd3, 0xf6, 0x12, 0x58, 0xfb, 0x26, 0x2e, 0x7d,
|
|
0x14, 0x1f, 0xc2, 0xad, 0xaf, 0xe0, 0xd2, 0x74, 0xa6, 0x45, 0x68, 0x8c, 0x1a, 0x77, 0x73, 0xce,
|
|
0xf9, 0xce, 0x39, 0xe7, 0xf3, 0x6d, 0x07, 0x3a, 0xae, 0x10, 0xae, 0xc7, 0x2c, 0x4e, 0x7d, 0x6b,
|
|
0xdb, 0xb7, 0x42, 0xe1, 0x71, 0x7b, 0x6f, 0x86, 0x91, 0x48, 0x04, 0xbe, 0x50, 0x35, 0x93, 0x53,
|
|
0xdf, 0xdc, 0xf6, 0x3b, 0xed, 0x4c, 0x9a, 0xec, 0x43, 0x66, 0xb1, 0x5d, 0x18, 0x29, 0x59, 0xe7,
|
|
0x7e, 0x96, 0xa7, 0x21, 0xb7, 0x68, 0x10, 0x88, 0x84, 0x26, 0x5c, 0x04, 0xb1, 0xaa, 0x1a, 0x1f,
|
|
0x40, 0x5b, 0xc8, 0xa6, 0x58, 0x87, 0xea, 0x96, 0x45, 0x31, 0x17, 0x81, 0x8e, 0xba, 0xa8, 0xf7,
|
|
0x3f, 0xc9, 0x43, 0x3c, 0x80, 0xb3, 0x0d, 0x0f, 0x1c, 0x1e, 0xb8, 0xb1, 0x5e, 0xe9, 0x96, 0x7b,
|
|
0xf5, 0x41, 0xdb, 0x3c, 0x99, 0x6d, 0x8e, 0x54, 0x99, 0x1c, 0x74, 0x18, 0x43, 0x85, 0x25, 0xd4,
|
|
0xd5, 0xcb, 0x5d, 0xd4, 0x3b, 0x27, 0xf2, 0x6c, 0xbc, 0x87, 0x6a, 0x26, 0x4c, 0xcb, 0x91, 0xf0,
|
|
0x98, 0x9c, 0x54, 0x23, 0xf2, 0x9c, 0x2e, 0xe0, 0x33, 0x7f, 0xc3, 0xa2, 0x58, 0x2f, 0x75, 0xcb,
|
|
0xbd, 0x1a, 0xc9, 0x43, 0x6c, 0x41, 0xcd, 0x16, 0x81, 0xc3, 0xd3, 0xc5, 0x65, 0xc7, 0xfa, 0xa0,
|
|
0x95, 0x6f, 0x90, 0xe2, 0x9a, 0xd3, 0x5d, 0x18, 0x91, 0x9f, 0x1a, 0xe3, 0x13, 0x82, 0xba, 0xc2,
|
|
0x9a, 0x30, 0x2f, 0xa1, 0x78, 0x04, 0x8d, 0x6c, 0xb3, 0xb5, 0x93, 0x26, 0x62, 0x1d, 0x49, 0x8e,
|
|
0x7b, 0xbf, 0xe6, 0x90, 0x97, 0xc8, 0xc5, 0xe6, 0x28, 0x8a, 0xf1, 0x1c, 0x2e, 0xe9, 0xad, 0xc3,
|
|
0x93, 0xb5, 0x2d, 0x82, 0x77, 0xfc, 0xd0, 0xa8, 0x24, 0x1b, 0x3d, 0x28, 0x34, 0x1a, 0xa6, 0xca,
|
|
0xb1, 0x14, 0xaa, 0x66, 0x2d, 0x5a, 0xc8, 0xc4, 0xc6, 0x57, 0x04, 0xe7, 0xc7, 0x03, 0xf1, 0x33,
|
|
0xd0, 0xa8, 0x9d, 0xe4, 0x1f, 0xa0, 0x31, 0x30, 0x7e, 0xb3, 0x9d, 0x39, 0x94, 0x4a, 0x92, 0xdd,
|
|
0x38, 0x18, 0x5a, 0x3a, 0x32, 0xb4, 0x0d, 0x9a, 0x72, 0x50, 0x7a, 0x56, 0x23, 0x59, 0x74, 0x6a,
|
|
0x67, 0xe5, 0x2f, 0xec, 0x7c, 0x0a, 0x9a, 0x1a, 0x87, 0xdb, 0x80, 0x87, 0xe3, 0x9b, 0xd9, 0xfc,
|
|
0x7a, 0xfd, 0xe6, 0xfa, 0xf5, 0x62, 0x3a, 0x9e, 0xbd, 0x9c, 0x4d, 0x27, 0xcd, 0xff, 0x70, 0x15,
|
|
0xca, 0xc3, 0xc9, 0xa4, 0x89, 0x30, 0x80, 0x46, 0xa6, 0x57, 0xf3, 0xe5, 0xb4, 0x59, 0x32, 0xbe,
|
|
0x21, 0x68, 0x16, 0x8d, 0xc0, 0x2f, 0x0a, 0x90, 0x0f, 0xff, 0xe0, 0x5c, 0x11, 0x54, 0x87, 0x6a,
|
|
0xcc, 0xa2, 0x2d, 0xb7, 0x73, 0xd6, 0x3c, 0xc4, 0x8f, 0xe0, 0x0e, 0xdb, 0x31, 0x3f, 0x4c, 0x98,
|
|
0xb3, 0x3e, 0xe1, 0x6e, 0xe4, 0xe9, 0x2b, 0xc5, 0x7f, 0x17, 0xce, 0x3c, 0xe1, 0xae, 0x53, 0x54,
|
|
0x89, 0x5f, 0x23, 0x55, 0x4f, 0xb8, 0x37, 0xfb, 0x90, 0xfd, 0x23, 0xe9, 0xe8, 0x23, 0x82, 0x96,
|
|
0x2d, 0xfc, 0x53, 0x94, 0x51, 0xf6, 0x0b, 0x2e, 0xd2, 0x87, 0xb6, 0x40, 0x6f, 0x1f, 0x67, 0x55,
|
|
0x57, 0x78, 0x34, 0x70, 0x4d, 0x11, 0xb9, 0x96, 0xcb, 0x02, 0xf9, 0x0c, 0x2d, 0x55, 0xa2, 0x21,
|
|
0x8f, 0xb3, 0xa7, 0xfe, 0x9c, 0x53, 0xff, 0x3b, 0x42, 0x9f, 0x4b, 0x97, 0xaf, 0xd4, 0xad, 0xb1,
|
|
0x27, 0x6e, 0x1d, 0x73, 0x46, 0x7d, 0x73, 0xd9, 0xff, 0x92, 0x67, 0x57, 0x32, 0xbb, 0x9a, 0x51,
|
|
0x7f, 0xb5, 0xec, 0x6f, 0x34, 0xd9, 0xeb, 0xc9, 0x8f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x29, 0x86,
|
|
0x8f, 0x3e, 0x35, 0x04, 0x00, 0x00,
|
|
}
|