pulumi/sdk/proto/go/resource.pb.go
Pat Gavlin 137fd54f1c
Propagate inputs to outputs during preview. (#3327)
These changes restore a more-correct version of the behavior that was
disabled with #3014. The original implementation of this behavior was
done in the SDKs, which do not have access to the complete inputs for a
resource (in particular, default values filled in by the provider during
`Check` are not exposed to the SDK). This lack of information meant that
the resolved output values could disagree with the typings present in
a provider SDK. Exacerbating this problem was the fact that unknown
values were dropped entirely, causing `undefined` values to appear in
unexpected places.

By doing this in the engine and allowing unknown values to be
represented in a first-class manner in the SDK, we can attack both of
these issues.

Although this behavior is not _strictly_ consistent with respect to the
resource model--in an update, a resource's output properties will come
from its provider and may differ from its input properties--this
behavior was present in the product for a fairly long time without
significant issues. In the future, we may be able to improve the
accuracy of resource outputs during a preview by allowing the provider
to dry-run CRUD operations and return partially-known values where
possible.

These changes also introduce new APIs in the Node and Python SDKs
that work with unknown values in a first-class fashion:
- A new parameter to the `apply` function that indicates that the
  callback should be run even if the result of the apply contains
  unknown values
- `containsUnknowns` and `isUnknown`, which return true if a value
  either contains nested unknown values or is exactly an unknown value
- The `Unknown` type, which represents unknown values

The primary use case for these APIs is to allow nested, properties with
known values to be accessed via the lifted property accessor even when
the containing property is not fully know. A common example of this
pattern is the `metadata.name` property of a Kubernetes `Namespace`
object: while other properties of the `metadata` bag may be unknown,
`name` is often known. These APIs allow `ns.metadata.name` to return a
known value in this case.

In order to avoid exposing downlevel SDKs to unknown values--a change
which could break user code by exposing it to unexpected values--a
language SDK must indicate whether or not it supports first-class
unknown values as part of each `RegisterResourceRequest`.

These changes also allow us to avoid breaking user code with the new
behavior introduced by the prior commit.

Fixes #3190.
2019-11-11 12:09:34 -08:00

1011 lines
40 KiB
Go

// Code generated by protoc-gen-go. DO NOT EDIT.
// source: resource.proto
package pulumirpc
import proto "github.com/golang/protobuf/proto"
import fmt "fmt"
import math "math"
import empty "github.com/golang/protobuf/ptypes/empty"
import _struct "github.com/golang/protobuf/ptypes/struct"
import (
context "golang.org/x/net/context"
grpc "google.golang.org/grpc"
)
// 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.ProtoPackageIsVersion2 // please upgrade the proto package
// SupportsFeatureRequest allows a client to test if the resource monitor supports a certain feature, which it may use
// to control the format or types of messages it sends.
type SupportsFeatureRequest struct {
Id string `protobuf:"bytes,1,opt,name=id" json:"id,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *SupportsFeatureRequest) Reset() { *m = SupportsFeatureRequest{} }
func (m *SupportsFeatureRequest) String() string { return proto.CompactTextString(m) }
func (*SupportsFeatureRequest) ProtoMessage() {}
func (*SupportsFeatureRequest) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{0}
}
func (m *SupportsFeatureRequest) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_SupportsFeatureRequest.Unmarshal(m, b)
}
func (m *SupportsFeatureRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_SupportsFeatureRequest.Marshal(b, m, deterministic)
}
func (dst *SupportsFeatureRequest) XXX_Merge(src proto.Message) {
xxx_messageInfo_SupportsFeatureRequest.Merge(dst, src)
}
func (m *SupportsFeatureRequest) XXX_Size() int {
return xxx_messageInfo_SupportsFeatureRequest.Size(m)
}
func (m *SupportsFeatureRequest) XXX_DiscardUnknown() {
xxx_messageInfo_SupportsFeatureRequest.DiscardUnknown(m)
}
var xxx_messageInfo_SupportsFeatureRequest proto.InternalMessageInfo
func (m *SupportsFeatureRequest) GetId() string {
if m != nil {
return m.Id
}
return ""
}
type SupportsFeatureResponse struct {
HasSupport bool `protobuf:"varint,1,opt,name=hasSupport" json:"hasSupport,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *SupportsFeatureResponse) Reset() { *m = SupportsFeatureResponse{} }
func (m *SupportsFeatureResponse) String() string { return proto.CompactTextString(m) }
func (*SupportsFeatureResponse) ProtoMessage() {}
func (*SupportsFeatureResponse) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{1}
}
func (m *SupportsFeatureResponse) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_SupportsFeatureResponse.Unmarshal(m, b)
}
func (m *SupportsFeatureResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_SupportsFeatureResponse.Marshal(b, m, deterministic)
}
func (dst *SupportsFeatureResponse) XXX_Merge(src proto.Message) {
xxx_messageInfo_SupportsFeatureResponse.Merge(dst, src)
}
func (m *SupportsFeatureResponse) XXX_Size() int {
return xxx_messageInfo_SupportsFeatureResponse.Size(m)
}
func (m *SupportsFeatureResponse) XXX_DiscardUnknown() {
xxx_messageInfo_SupportsFeatureResponse.DiscardUnknown(m)
}
var xxx_messageInfo_SupportsFeatureResponse proto.InternalMessageInfo
func (m *SupportsFeatureResponse) GetHasSupport() bool {
if m != nil {
return m.HasSupport
}
return false
}
// ReadResourceRequest contains enough information to uniquely qualify and read a resource's state.
type ReadResourceRequest struct {
Id string `protobuf:"bytes,1,opt,name=id" json:"id,omitempty"`
Type string `protobuf:"bytes,2,opt,name=type" json:"type,omitempty"`
Name string `protobuf:"bytes,3,opt,name=name" json:"name,omitempty"`
Parent string `protobuf:"bytes,4,opt,name=parent" json:"parent,omitempty"`
Properties *_struct.Struct `protobuf:"bytes,5,opt,name=properties" json:"properties,omitempty"`
Dependencies []string `protobuf:"bytes,6,rep,name=dependencies" json:"dependencies,omitempty"`
Provider string `protobuf:"bytes,7,opt,name=provider" json:"provider,omitempty"`
Version string `protobuf:"bytes,8,opt,name=version" json:"version,omitempty"`
AcceptSecrets bool `protobuf:"varint,9,opt,name=acceptSecrets" json:"acceptSecrets,omitempty"`
AdditionalSecretOutputs []string `protobuf:"bytes,10,rep,name=additionalSecretOutputs" json:"additionalSecretOutputs,omitempty"`
Aliases []string `protobuf:"bytes,11,rep,name=aliases" json:"aliases,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ReadResourceRequest) Reset() { *m = ReadResourceRequest{} }
func (m *ReadResourceRequest) String() string { return proto.CompactTextString(m) }
func (*ReadResourceRequest) ProtoMessage() {}
func (*ReadResourceRequest) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{2}
}
func (m *ReadResourceRequest) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ReadResourceRequest.Unmarshal(m, b)
}
func (m *ReadResourceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ReadResourceRequest.Marshal(b, m, deterministic)
}
func (dst *ReadResourceRequest) XXX_Merge(src proto.Message) {
xxx_messageInfo_ReadResourceRequest.Merge(dst, src)
}
func (m *ReadResourceRequest) XXX_Size() int {
return xxx_messageInfo_ReadResourceRequest.Size(m)
}
func (m *ReadResourceRequest) XXX_DiscardUnknown() {
xxx_messageInfo_ReadResourceRequest.DiscardUnknown(m)
}
var xxx_messageInfo_ReadResourceRequest proto.InternalMessageInfo
func (m *ReadResourceRequest) GetId() string {
if m != nil {
return m.Id
}
return ""
}
func (m *ReadResourceRequest) GetType() string {
if m != nil {
return m.Type
}
return ""
}
func (m *ReadResourceRequest) GetName() string {
if m != nil {
return m.Name
}
return ""
}
func (m *ReadResourceRequest) GetParent() string {
if m != nil {
return m.Parent
}
return ""
}
func (m *ReadResourceRequest) GetProperties() *_struct.Struct {
if m != nil {
return m.Properties
}
return nil
}
func (m *ReadResourceRequest) GetDependencies() []string {
if m != nil {
return m.Dependencies
}
return nil
}
func (m *ReadResourceRequest) GetProvider() string {
if m != nil {
return m.Provider
}
return ""
}
func (m *ReadResourceRequest) GetVersion() string {
if m != nil {
return m.Version
}
return ""
}
func (m *ReadResourceRequest) GetAcceptSecrets() bool {
if m != nil {
return m.AcceptSecrets
}
return false
}
func (m *ReadResourceRequest) GetAdditionalSecretOutputs() []string {
if m != nil {
return m.AdditionalSecretOutputs
}
return nil
}
func (m *ReadResourceRequest) GetAliases() []string {
if m != nil {
return m.Aliases
}
return nil
}
// ReadResourceResponse contains the result of reading a resource's state.
type ReadResourceResponse struct {
Urn string `protobuf:"bytes,1,opt,name=urn" json:"urn,omitempty"`
Properties *_struct.Struct `protobuf:"bytes,2,opt,name=properties" json:"properties,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ReadResourceResponse) Reset() { *m = ReadResourceResponse{} }
func (m *ReadResourceResponse) String() string { return proto.CompactTextString(m) }
func (*ReadResourceResponse) ProtoMessage() {}
func (*ReadResourceResponse) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{3}
}
func (m *ReadResourceResponse) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ReadResourceResponse.Unmarshal(m, b)
}
func (m *ReadResourceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ReadResourceResponse.Marshal(b, m, deterministic)
}
func (dst *ReadResourceResponse) XXX_Merge(src proto.Message) {
xxx_messageInfo_ReadResourceResponse.Merge(dst, src)
}
func (m *ReadResourceResponse) XXX_Size() int {
return xxx_messageInfo_ReadResourceResponse.Size(m)
}
func (m *ReadResourceResponse) XXX_DiscardUnknown() {
xxx_messageInfo_ReadResourceResponse.DiscardUnknown(m)
}
var xxx_messageInfo_ReadResourceResponse proto.InternalMessageInfo
func (m *ReadResourceResponse) GetUrn() string {
if m != nil {
return m.Urn
}
return ""
}
func (m *ReadResourceResponse) GetProperties() *_struct.Struct {
if m != nil {
return m.Properties
}
return nil
}
// RegisterResourceRequest contains information about a resource object that was newly allocated.
type RegisterResourceRequest struct {
Type string `protobuf:"bytes,1,opt,name=type" json:"type,omitempty"`
Name string `protobuf:"bytes,2,opt,name=name" json:"name,omitempty"`
Parent string `protobuf:"bytes,3,opt,name=parent" json:"parent,omitempty"`
Custom bool `protobuf:"varint,4,opt,name=custom" json:"custom,omitempty"`
Object *_struct.Struct `protobuf:"bytes,5,opt,name=object" json:"object,omitempty"`
Protect bool `protobuf:"varint,6,opt,name=protect" json:"protect,omitempty"`
Dependencies []string `protobuf:"bytes,7,rep,name=dependencies" json:"dependencies,omitempty"`
Provider string `protobuf:"bytes,8,opt,name=provider" json:"provider,omitempty"`
PropertyDependencies map[string]*RegisterResourceRequest_PropertyDependencies `protobuf:"bytes,9,rep,name=propertyDependencies" json:"propertyDependencies,omitempty" protobuf_key:"bytes,1,opt,name=key" protobuf_val:"bytes,2,opt,name=value"`
DeleteBeforeReplace bool `protobuf:"varint,10,opt,name=deleteBeforeReplace" json:"deleteBeforeReplace,omitempty"`
Version string `protobuf:"bytes,11,opt,name=version" json:"version,omitempty"`
IgnoreChanges []string `protobuf:"bytes,12,rep,name=ignoreChanges" json:"ignoreChanges,omitempty"`
AcceptSecrets bool `protobuf:"varint,13,opt,name=acceptSecrets" json:"acceptSecrets,omitempty"`
AdditionalSecretOutputs []string `protobuf:"bytes,14,rep,name=additionalSecretOutputs" json:"additionalSecretOutputs,omitempty"`
Aliases []string `protobuf:"bytes,15,rep,name=aliases" json:"aliases,omitempty"`
ImportId string `protobuf:"bytes,16,opt,name=importId" json:"importId,omitempty"`
CustomTimeouts *RegisterResourceRequest_CustomTimeouts `protobuf:"bytes,17,opt,name=customTimeouts" json:"customTimeouts,omitempty"`
DeleteBeforeReplaceDefined bool `protobuf:"varint,18,opt,name=deleteBeforeReplaceDefined" json:"deleteBeforeReplaceDefined,omitempty"`
SupportsPartialValues bool `protobuf:"varint,19,opt,name=supportsPartialValues" json:"supportsPartialValues,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *RegisterResourceRequest) Reset() { *m = RegisterResourceRequest{} }
func (m *RegisterResourceRequest) String() string { return proto.CompactTextString(m) }
func (*RegisterResourceRequest) ProtoMessage() {}
func (*RegisterResourceRequest) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{4}
}
func (m *RegisterResourceRequest) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_RegisterResourceRequest.Unmarshal(m, b)
}
func (m *RegisterResourceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_RegisterResourceRequest.Marshal(b, m, deterministic)
}
func (dst *RegisterResourceRequest) XXX_Merge(src proto.Message) {
xxx_messageInfo_RegisterResourceRequest.Merge(dst, src)
}
func (m *RegisterResourceRequest) XXX_Size() int {
return xxx_messageInfo_RegisterResourceRequest.Size(m)
}
func (m *RegisterResourceRequest) XXX_DiscardUnknown() {
xxx_messageInfo_RegisterResourceRequest.DiscardUnknown(m)
}
var xxx_messageInfo_RegisterResourceRequest proto.InternalMessageInfo
func (m *RegisterResourceRequest) GetType() string {
if m != nil {
return m.Type
}
return ""
}
func (m *RegisterResourceRequest) GetName() string {
if m != nil {
return m.Name
}
return ""
}
func (m *RegisterResourceRequest) GetParent() string {
if m != nil {
return m.Parent
}
return ""
}
func (m *RegisterResourceRequest) GetCustom() bool {
if m != nil {
return m.Custom
}
return false
}
func (m *RegisterResourceRequest) GetObject() *_struct.Struct {
if m != nil {
return m.Object
}
return nil
}
func (m *RegisterResourceRequest) GetProtect() bool {
if m != nil {
return m.Protect
}
return false
}
func (m *RegisterResourceRequest) GetDependencies() []string {
if m != nil {
return m.Dependencies
}
return nil
}
func (m *RegisterResourceRequest) GetProvider() string {
if m != nil {
return m.Provider
}
return ""
}
func (m *RegisterResourceRequest) GetPropertyDependencies() map[string]*RegisterResourceRequest_PropertyDependencies {
if m != nil {
return m.PropertyDependencies
}
return nil
}
func (m *RegisterResourceRequest) GetDeleteBeforeReplace() bool {
if m != nil {
return m.DeleteBeforeReplace
}
return false
}
func (m *RegisterResourceRequest) GetVersion() string {
if m != nil {
return m.Version
}
return ""
}
func (m *RegisterResourceRequest) GetIgnoreChanges() []string {
if m != nil {
return m.IgnoreChanges
}
return nil
}
func (m *RegisterResourceRequest) GetAcceptSecrets() bool {
if m != nil {
return m.AcceptSecrets
}
return false
}
func (m *RegisterResourceRequest) GetAdditionalSecretOutputs() []string {
if m != nil {
return m.AdditionalSecretOutputs
}
return nil
}
func (m *RegisterResourceRequest) GetAliases() []string {
if m != nil {
return m.Aliases
}
return nil
}
func (m *RegisterResourceRequest) GetImportId() string {
if m != nil {
return m.ImportId
}
return ""
}
func (m *RegisterResourceRequest) GetCustomTimeouts() *RegisterResourceRequest_CustomTimeouts {
if m != nil {
return m.CustomTimeouts
}
return nil
}
func (m *RegisterResourceRequest) GetDeleteBeforeReplaceDefined() bool {
if m != nil {
return m.DeleteBeforeReplaceDefined
}
return false
}
func (m *RegisterResourceRequest) GetSupportsPartialValues() bool {
if m != nil {
return m.SupportsPartialValues
}
return false
}
// PropertyDependencies describes the resources that a particular property depends on.
type RegisterResourceRequest_PropertyDependencies struct {
Urns []string `protobuf:"bytes,1,rep,name=urns" json:"urns,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *RegisterResourceRequest_PropertyDependencies) Reset() {
*m = RegisterResourceRequest_PropertyDependencies{}
}
func (m *RegisterResourceRequest_PropertyDependencies) String() string {
return proto.CompactTextString(m)
}
func (*RegisterResourceRequest_PropertyDependencies) ProtoMessage() {}
func (*RegisterResourceRequest_PropertyDependencies) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{4, 0}
}
func (m *RegisterResourceRequest_PropertyDependencies) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_RegisterResourceRequest_PropertyDependencies.Unmarshal(m, b)
}
func (m *RegisterResourceRequest_PropertyDependencies) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_RegisterResourceRequest_PropertyDependencies.Marshal(b, m, deterministic)
}
func (dst *RegisterResourceRequest_PropertyDependencies) XXX_Merge(src proto.Message) {
xxx_messageInfo_RegisterResourceRequest_PropertyDependencies.Merge(dst, src)
}
func (m *RegisterResourceRequest_PropertyDependencies) XXX_Size() int {
return xxx_messageInfo_RegisterResourceRequest_PropertyDependencies.Size(m)
}
func (m *RegisterResourceRequest_PropertyDependencies) XXX_DiscardUnknown() {
xxx_messageInfo_RegisterResourceRequest_PropertyDependencies.DiscardUnknown(m)
}
var xxx_messageInfo_RegisterResourceRequest_PropertyDependencies proto.InternalMessageInfo
func (m *RegisterResourceRequest_PropertyDependencies) GetUrns() []string {
if m != nil {
return m.Urns
}
return nil
}
// CustomTimeouts allows a user to be able to create a set of custom timeout parameters.
type RegisterResourceRequest_CustomTimeouts struct {
Create string `protobuf:"bytes,1,opt,name=create" json:"create,omitempty"`
Update string `protobuf:"bytes,2,opt,name=update" json:"update,omitempty"`
Delete string `protobuf:"bytes,3,opt,name=delete" json:"delete,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *RegisterResourceRequest_CustomTimeouts) Reset() {
*m = RegisterResourceRequest_CustomTimeouts{}
}
func (m *RegisterResourceRequest_CustomTimeouts) String() string { return proto.CompactTextString(m) }
func (*RegisterResourceRequest_CustomTimeouts) ProtoMessage() {}
func (*RegisterResourceRequest_CustomTimeouts) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{4, 1}
}
func (m *RegisterResourceRequest_CustomTimeouts) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_RegisterResourceRequest_CustomTimeouts.Unmarshal(m, b)
}
func (m *RegisterResourceRequest_CustomTimeouts) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_RegisterResourceRequest_CustomTimeouts.Marshal(b, m, deterministic)
}
func (dst *RegisterResourceRequest_CustomTimeouts) XXX_Merge(src proto.Message) {
xxx_messageInfo_RegisterResourceRequest_CustomTimeouts.Merge(dst, src)
}
func (m *RegisterResourceRequest_CustomTimeouts) XXX_Size() int {
return xxx_messageInfo_RegisterResourceRequest_CustomTimeouts.Size(m)
}
func (m *RegisterResourceRequest_CustomTimeouts) XXX_DiscardUnknown() {
xxx_messageInfo_RegisterResourceRequest_CustomTimeouts.DiscardUnknown(m)
}
var xxx_messageInfo_RegisterResourceRequest_CustomTimeouts proto.InternalMessageInfo
func (m *RegisterResourceRequest_CustomTimeouts) GetCreate() string {
if m != nil {
return m.Create
}
return ""
}
func (m *RegisterResourceRequest_CustomTimeouts) GetUpdate() string {
if m != nil {
return m.Update
}
return ""
}
func (m *RegisterResourceRequest_CustomTimeouts) GetDelete() string {
if m != nil {
return m.Delete
}
return ""
}
// RegisterResourceResponse is returned by the engine after a resource has finished being initialized. It includes the
// auto-assigned URN, the provider-assigned ID, and any other properties initialized by the engine.
type RegisterResourceResponse struct {
Urn string `protobuf:"bytes,1,opt,name=urn" json:"urn,omitempty"`
Id string `protobuf:"bytes,2,opt,name=id" json:"id,omitempty"`
Object *_struct.Struct `protobuf:"bytes,3,opt,name=object" json:"object,omitempty"`
Stable bool `protobuf:"varint,4,opt,name=stable" json:"stable,omitempty"`
Stables []string `protobuf:"bytes,5,rep,name=stables" json:"stables,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *RegisterResourceResponse) Reset() { *m = RegisterResourceResponse{} }
func (m *RegisterResourceResponse) String() string { return proto.CompactTextString(m) }
func (*RegisterResourceResponse) ProtoMessage() {}
func (*RegisterResourceResponse) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{5}
}
func (m *RegisterResourceResponse) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_RegisterResourceResponse.Unmarshal(m, b)
}
func (m *RegisterResourceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_RegisterResourceResponse.Marshal(b, m, deterministic)
}
func (dst *RegisterResourceResponse) XXX_Merge(src proto.Message) {
xxx_messageInfo_RegisterResourceResponse.Merge(dst, src)
}
func (m *RegisterResourceResponse) XXX_Size() int {
return xxx_messageInfo_RegisterResourceResponse.Size(m)
}
func (m *RegisterResourceResponse) XXX_DiscardUnknown() {
xxx_messageInfo_RegisterResourceResponse.DiscardUnknown(m)
}
var xxx_messageInfo_RegisterResourceResponse proto.InternalMessageInfo
func (m *RegisterResourceResponse) GetUrn() string {
if m != nil {
return m.Urn
}
return ""
}
func (m *RegisterResourceResponse) GetId() string {
if m != nil {
return m.Id
}
return ""
}
func (m *RegisterResourceResponse) GetObject() *_struct.Struct {
if m != nil {
return m.Object
}
return nil
}
func (m *RegisterResourceResponse) GetStable() bool {
if m != nil {
return m.Stable
}
return false
}
func (m *RegisterResourceResponse) GetStables() []string {
if m != nil {
return m.Stables
}
return nil
}
// RegisterResourceOutputsRequest adds extra resource outputs created by the program after registration has occurred.
type RegisterResourceOutputsRequest struct {
Urn string `protobuf:"bytes,1,opt,name=urn" json:"urn,omitempty"`
Outputs *_struct.Struct `protobuf:"bytes,2,opt,name=outputs" json:"outputs,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *RegisterResourceOutputsRequest) Reset() { *m = RegisterResourceOutputsRequest{} }
func (m *RegisterResourceOutputsRequest) String() string { return proto.CompactTextString(m) }
func (*RegisterResourceOutputsRequest) ProtoMessage() {}
func (*RegisterResourceOutputsRequest) Descriptor() ([]byte, []int) {
return fileDescriptor_resource_beee7c3faa8096b0, []int{6}
}
func (m *RegisterResourceOutputsRequest) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_RegisterResourceOutputsRequest.Unmarshal(m, b)
}
func (m *RegisterResourceOutputsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_RegisterResourceOutputsRequest.Marshal(b, m, deterministic)
}
func (dst *RegisterResourceOutputsRequest) XXX_Merge(src proto.Message) {
xxx_messageInfo_RegisterResourceOutputsRequest.Merge(dst, src)
}
func (m *RegisterResourceOutputsRequest) XXX_Size() int {
return xxx_messageInfo_RegisterResourceOutputsRequest.Size(m)
}
func (m *RegisterResourceOutputsRequest) XXX_DiscardUnknown() {
xxx_messageInfo_RegisterResourceOutputsRequest.DiscardUnknown(m)
}
var xxx_messageInfo_RegisterResourceOutputsRequest proto.InternalMessageInfo
func (m *RegisterResourceOutputsRequest) GetUrn() string {
if m != nil {
return m.Urn
}
return ""
}
func (m *RegisterResourceOutputsRequest) GetOutputs() *_struct.Struct {
if m != nil {
return m.Outputs
}
return nil
}
func init() {
proto.RegisterType((*SupportsFeatureRequest)(nil), "pulumirpc.SupportsFeatureRequest")
proto.RegisterType((*SupportsFeatureResponse)(nil), "pulumirpc.SupportsFeatureResponse")
proto.RegisterType((*ReadResourceRequest)(nil), "pulumirpc.ReadResourceRequest")
proto.RegisterType((*ReadResourceResponse)(nil), "pulumirpc.ReadResourceResponse")
proto.RegisterType((*RegisterResourceRequest)(nil), "pulumirpc.RegisterResourceRequest")
proto.RegisterMapType((map[string]*RegisterResourceRequest_PropertyDependencies)(nil), "pulumirpc.RegisterResourceRequest.PropertyDependenciesEntry")
proto.RegisterType((*RegisterResourceRequest_PropertyDependencies)(nil), "pulumirpc.RegisterResourceRequest.PropertyDependencies")
proto.RegisterType((*RegisterResourceRequest_CustomTimeouts)(nil), "pulumirpc.RegisterResourceRequest.CustomTimeouts")
proto.RegisterType((*RegisterResourceResponse)(nil), "pulumirpc.RegisterResourceResponse")
proto.RegisterType((*RegisterResourceOutputsRequest)(nil), "pulumirpc.RegisterResourceOutputsRequest")
}
// Reference imports to suppress errors if they are not otherwise used.
var _ context.Context
var _ grpc.ClientConn
// This is a compile-time assertion to ensure that this generated file
// is compatible with the grpc package it is being compiled against.
const _ = grpc.SupportPackageIsVersion4
// Client API for ResourceMonitor service
type ResourceMonitorClient interface {
SupportsFeature(ctx context.Context, in *SupportsFeatureRequest, opts ...grpc.CallOption) (*SupportsFeatureResponse, error)
Invoke(ctx context.Context, in *InvokeRequest, opts ...grpc.CallOption) (*InvokeResponse, error)
StreamInvoke(ctx context.Context, in *InvokeRequest, opts ...grpc.CallOption) (ResourceMonitor_StreamInvokeClient, error)
ReadResource(ctx context.Context, in *ReadResourceRequest, opts ...grpc.CallOption) (*ReadResourceResponse, error)
RegisterResource(ctx context.Context, in *RegisterResourceRequest, opts ...grpc.CallOption) (*RegisterResourceResponse, error)
RegisterResourceOutputs(ctx context.Context, in *RegisterResourceOutputsRequest, opts ...grpc.CallOption) (*empty.Empty, error)
}
type resourceMonitorClient struct {
cc *grpc.ClientConn
}
func NewResourceMonitorClient(cc *grpc.ClientConn) ResourceMonitorClient {
return &resourceMonitorClient{cc}
}
func (c *resourceMonitorClient) SupportsFeature(ctx context.Context, in *SupportsFeatureRequest, opts ...grpc.CallOption) (*SupportsFeatureResponse, error) {
out := new(SupportsFeatureResponse)
err := grpc.Invoke(ctx, "/pulumirpc.ResourceMonitor/SupportsFeature", in, out, c.cc, opts...)
if err != nil {
return nil, err
}
return out, nil
}
func (c *resourceMonitorClient) Invoke(ctx context.Context, in *InvokeRequest, opts ...grpc.CallOption) (*InvokeResponse, error) {
out := new(InvokeResponse)
err := grpc.Invoke(ctx, "/pulumirpc.ResourceMonitor/Invoke", in, out, c.cc, opts...)
if err != nil {
return nil, err
}
return out, nil
}
func (c *resourceMonitorClient) StreamInvoke(ctx context.Context, in *InvokeRequest, opts ...grpc.CallOption) (ResourceMonitor_StreamInvokeClient, error) {
stream, err := grpc.NewClientStream(ctx, &_ResourceMonitor_serviceDesc.Streams[0], c.cc, "/pulumirpc.ResourceMonitor/StreamInvoke", opts...)
if err != nil {
return nil, err
}
x := &resourceMonitorStreamInvokeClient{stream}
if err := x.ClientStream.SendMsg(in); err != nil {
return nil, err
}
if err := x.ClientStream.CloseSend(); err != nil {
return nil, err
}
return x, nil
}
type ResourceMonitor_StreamInvokeClient interface {
Recv() (*InvokeResponse, error)
grpc.ClientStream
}
type resourceMonitorStreamInvokeClient struct {
grpc.ClientStream
}
func (x *resourceMonitorStreamInvokeClient) Recv() (*InvokeResponse, error) {
m := new(InvokeResponse)
if err := x.ClientStream.RecvMsg(m); err != nil {
return nil, err
}
return m, nil
}
func (c *resourceMonitorClient) ReadResource(ctx context.Context, in *ReadResourceRequest, opts ...grpc.CallOption) (*ReadResourceResponse, error) {
out := new(ReadResourceResponse)
err := grpc.Invoke(ctx, "/pulumirpc.ResourceMonitor/ReadResource", in, out, c.cc, opts...)
if err != nil {
return nil, err
}
return out, nil
}
func (c *resourceMonitorClient) RegisterResource(ctx context.Context, in *RegisterResourceRequest, opts ...grpc.CallOption) (*RegisterResourceResponse, error) {
out := new(RegisterResourceResponse)
err := grpc.Invoke(ctx, "/pulumirpc.ResourceMonitor/RegisterResource", in, out, c.cc, opts...)
if err != nil {
return nil, err
}
return out, nil
}
func (c *resourceMonitorClient) RegisterResourceOutputs(ctx context.Context, in *RegisterResourceOutputsRequest, opts ...grpc.CallOption) (*empty.Empty, error) {
out := new(empty.Empty)
err := grpc.Invoke(ctx, "/pulumirpc.ResourceMonitor/RegisterResourceOutputs", in, out, c.cc, opts...)
if err != nil {
return nil, err
}
return out, nil
}
// Server API for ResourceMonitor service
type ResourceMonitorServer interface {
SupportsFeature(context.Context, *SupportsFeatureRequest) (*SupportsFeatureResponse, error)
Invoke(context.Context, *InvokeRequest) (*InvokeResponse, error)
StreamInvoke(*InvokeRequest, ResourceMonitor_StreamInvokeServer) error
ReadResource(context.Context, *ReadResourceRequest) (*ReadResourceResponse, error)
RegisterResource(context.Context, *RegisterResourceRequest) (*RegisterResourceResponse, error)
RegisterResourceOutputs(context.Context, *RegisterResourceOutputsRequest) (*empty.Empty, error)
}
func RegisterResourceMonitorServer(s *grpc.Server, srv ResourceMonitorServer) {
s.RegisterService(&_ResourceMonitor_serviceDesc, srv)
}
func _ResourceMonitor_SupportsFeature_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(SupportsFeatureRequest)
if err := dec(in); err != nil {
return nil, err
}
if interceptor == nil {
return srv.(ResourceMonitorServer).SupportsFeature(ctx, in)
}
info := &grpc.UnaryServerInfo{
Server: srv,
FullMethod: "/pulumirpc.ResourceMonitor/SupportsFeature",
}
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(ResourceMonitorServer).SupportsFeature(ctx, req.(*SupportsFeatureRequest))
}
return interceptor(ctx, in, info, handler)
}
func _ResourceMonitor_Invoke_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(InvokeRequest)
if err := dec(in); err != nil {
return nil, err
}
if interceptor == nil {
return srv.(ResourceMonitorServer).Invoke(ctx, in)
}
info := &grpc.UnaryServerInfo{
Server: srv,
FullMethod: "/pulumirpc.ResourceMonitor/Invoke",
}
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(ResourceMonitorServer).Invoke(ctx, req.(*InvokeRequest))
}
return interceptor(ctx, in, info, handler)
}
func _ResourceMonitor_StreamInvoke_Handler(srv interface{}, stream grpc.ServerStream) error {
m := new(InvokeRequest)
if err := stream.RecvMsg(m); err != nil {
return err
}
return srv.(ResourceMonitorServer).StreamInvoke(m, &resourceMonitorStreamInvokeServer{stream})
}
type ResourceMonitor_StreamInvokeServer interface {
Send(*InvokeResponse) error
grpc.ServerStream
}
type resourceMonitorStreamInvokeServer struct {
grpc.ServerStream
}
func (x *resourceMonitorStreamInvokeServer) Send(m *InvokeResponse) error {
return x.ServerStream.SendMsg(m)
}
func _ResourceMonitor_ReadResource_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(ReadResourceRequest)
if err := dec(in); err != nil {
return nil, err
}
if interceptor == nil {
return srv.(ResourceMonitorServer).ReadResource(ctx, in)
}
info := &grpc.UnaryServerInfo{
Server: srv,
FullMethod: "/pulumirpc.ResourceMonitor/ReadResource",
}
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(ResourceMonitorServer).ReadResource(ctx, req.(*ReadResourceRequest))
}
return interceptor(ctx, in, info, handler)
}
func _ResourceMonitor_RegisterResource_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(RegisterResourceRequest)
if err := dec(in); err != nil {
return nil, err
}
if interceptor == nil {
return srv.(ResourceMonitorServer).RegisterResource(ctx, in)
}
info := &grpc.UnaryServerInfo{
Server: srv,
FullMethod: "/pulumirpc.ResourceMonitor/RegisterResource",
}
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(ResourceMonitorServer).RegisterResource(ctx, req.(*RegisterResourceRequest))
}
return interceptor(ctx, in, info, handler)
}
func _ResourceMonitor_RegisterResourceOutputs_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(RegisterResourceOutputsRequest)
if err := dec(in); err != nil {
return nil, err
}
if interceptor == nil {
return srv.(ResourceMonitorServer).RegisterResourceOutputs(ctx, in)
}
info := &grpc.UnaryServerInfo{
Server: srv,
FullMethod: "/pulumirpc.ResourceMonitor/RegisterResourceOutputs",
}
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(ResourceMonitorServer).RegisterResourceOutputs(ctx, req.(*RegisterResourceOutputsRequest))
}
return interceptor(ctx, in, info, handler)
}
var _ResourceMonitor_serviceDesc = grpc.ServiceDesc{
ServiceName: "pulumirpc.ResourceMonitor",
HandlerType: (*ResourceMonitorServer)(nil),
Methods: []grpc.MethodDesc{
{
MethodName: "SupportsFeature",
Handler: _ResourceMonitor_SupportsFeature_Handler,
},
{
MethodName: "Invoke",
Handler: _ResourceMonitor_Invoke_Handler,
},
{
MethodName: "ReadResource",
Handler: _ResourceMonitor_ReadResource_Handler,
},
{
MethodName: "RegisterResource",
Handler: _ResourceMonitor_RegisterResource_Handler,
},
{
MethodName: "RegisterResourceOutputs",
Handler: _ResourceMonitor_RegisterResourceOutputs_Handler,
},
},
Streams: []grpc.StreamDesc{
{
StreamName: "StreamInvoke",
Handler: _ResourceMonitor_StreamInvoke_Handler,
ServerStreams: true,
},
},
Metadata: "resource.proto",
}
func init() { proto.RegisterFile("resource.proto", fileDescriptor_resource_beee7c3faa8096b0) }
var fileDescriptor_resource_beee7c3faa8096b0 = []byte{
// 878 bytes of a gzipped FileDescriptorProto
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xa4, 0x56, 0xdd, 0x6e, 0x1b, 0x45,
0x14, 0xae, 0xed, 0xd4, 0x71, 0x4e, 0x52, 0x27, 0x4c, 0x42, 0xb2, 0x5d, 0x50, 0x28, 0x0b, 0x17,
0x85, 0x0b, 0xa7, 0x0d, 0x48, 0x2d, 0x08, 0x81, 0x44, 0x5b, 0x50, 0x2f, 0x2a, 0xca, 0x06, 0x21,
0x40, 0x02, 0x69, 0xb2, 0x7b, 0xe2, 0x2e, 0x59, 0xef, 0x0e, 0x33, 0xb3, 0x91, 0x7c, 0xc7, 0x2d,
0x4f, 0xc1, 0x2b, 0xf1, 0x2c, 0x3c, 0x01, 0xf3, 0x6b, 0xbc, 0x3f, 0x4e, 0x0c, 0xbd, 0xf2, 0x9c,
0xdf, 0x9d, 0xf3, 0x9d, 0xef, 0x9c, 0x31, 0x8c, 0x39, 0x8a, 0xb2, 0xe2, 0x09, 0x4e, 0x18, 0x2f,
0x65, 0x49, 0xb6, 0x58, 0x95, 0x57, 0xb3, 0x8c, 0xb3, 0x24, 0x7c, 0x6b, 0x5a, 0x96, 0xd3, 0x1c,
0x4f, 0x8c, 0xe1, 0xbc, 0xba, 0x38, 0xc1, 0x19, 0x93, 0x73, 0xeb, 0x17, 0xbe, 0xdd, 0x34, 0x0a,
0xc9, 0xab, 0x44, 0x3a, 0xeb, 0x58, 0xfd, 0x5c, 0x65, 0x29, 0x72, 0x2b, 0x47, 0xf7, 0xe1, 0xf0,
0xac, 0x62, 0xac, 0xe4, 0x52, 0x7c, 0x85, 0x54, 0x56, 0x1c, 0x63, 0xfc, 0xad, 0x42, 0x21, 0xc9,
0x18, 0xfa, 0x59, 0x1a, 0xf4, 0xee, 0xf5, 0xee, 0x6f, 0xc5, 0xea, 0x14, 0x7d, 0x02, 0x47, 0x2d,
0x4f, 0xc1, 0xca, 0x42, 0x20, 0x39, 0x06, 0x78, 0x45, 0x85, 0xb3, 0x9a, 0x90, 0x51, 0xbc, 0xa4,
0x89, 0xfe, 0xee, 0xc3, 0x7e, 0x8c, 0x34, 0x8d, 0x5d, 0x45, 0x2b, 0x3e, 0x41, 0x08, 0x6c, 0xc8,
0x39, 0xc3, 0xa0, 0x6f, 0x34, 0xe6, 0xac, 0x75, 0x05, 0x9d, 0x61, 0x30, 0xb0, 0x3a, 0x7d, 0x26,
0x87, 0x30, 0x64, 0x94, 0x63, 0x21, 0x83, 0x0d, 0xa3, 0x75, 0x12, 0x79, 0x04, 0xa0, 0xaa, 0x62,
0xc8, 0x65, 0x86, 0x22, 0xb8, 0xad, 0x6c, 0xdb, 0xa7, 0x47, 0x13, 0x8b, 0xc7, 0xc4, 0xe3, 0x31,
0x39, 0x33, 0x78, 0xc4, 0x4b, 0xae, 0x24, 0x82, 0x9d, 0x14, 0x19, 0x16, 0x29, 0x16, 0x89, 0x0e,
0x1d, 0xde, 0x1b, 0xa8, 0xb4, 0x35, 0x1d, 0x09, 0x61, 0xe4, 0xb1, 0x0b, 0x36, 0xcd, 0x67, 0x17,
0x32, 0x09, 0x60, 0xf3, 0x0a, 0xb9, 0xc8, 0xca, 0x22, 0x18, 0x19, 0x93, 0x17, 0xc9, 0xfb, 0x70,
0x87, 0x26, 0x09, 0x32, 0x79, 0x86, 0x09, 0x47, 0x29, 0x82, 0x2d, 0x83, 0x4e, 0x5d, 0x49, 0x1e,
0xc3, 0x11, 0x4d, 0xd3, 0x4c, 0xaa, 0x08, 0x9a, 0x5b, 0xe5, 0x37, 0x95, 0x64, 0x95, 0xf2, 0x07,
0x73, 0x95, 0x55, 0x66, 0xfd, 0x65, 0x9a, 0x67, 0x54, 0xa8, 0x4b, 0x6f, 0x1b, 0x4f, 0x2f, 0x46,
0x14, 0x0e, 0xea, 0x98, 0xbb, 0x66, 0xed, 0xc1, 0xa0, 0xe2, 0x85, 0x43, 0x5d, 0x1f, 0x1b, 0xb0,
0xf5, 0xd7, 0x86, 0x2d, 0xfa, 0x6b, 0x04, 0x47, 0x31, 0x4e, 0x33, 0x21, 0x91, 0x37, 0x7b, 0xeb,
0x7b, 0xd9, 0xeb, 0xe8, 0x65, 0xbf, 0xb3, 0x97, 0x83, 0x5a, 0x2f, 0x95, 0x3e, 0xa9, 0x84, 0x2c,
0x67, 0xa6, 0xc7, 0xa3, 0xd8, 0x49, 0xe4, 0x04, 0x86, 0xe5, 0xf9, 0xaf, 0x98, 0xc8, 0x9b, 0xfa,
0xeb, 0xdc, 0x34, 0x42, 0xda, 0xa4, 0x23, 0x86, 0x26, 0x93, 0x17, 0x5b, 0x5d, 0xdf, 0xbc, 0xa1,
0xeb, 0xa3, 0x46, 0xd7, 0x19, 0x1c, 0x38, 0x30, 0xe6, 0x4f, 0x97, 0xf3, 0x6c, 0xa9, 0x3c, 0xdb,
0xa7, 0x9f, 0x4d, 0x16, 0x03, 0x3b, 0x59, 0x01, 0xd2, 0xe4, 0x65, 0x47, 0xf8, 0xb3, 0x42, 0xf2,
0x79, 0xdc, 0x99, 0x99, 0x3c, 0x80, 0xfd, 0x14, 0x73, 0x94, 0xf8, 0x25, 0x5e, 0x94, 0x7a, 0x00,
0x59, 0x4e, 0x13, 0x54, 0x1c, 0xd1, 0x75, 0x75, 0x99, 0x96, 0x99, 0xb9, 0xdd, 0x62, 0x66, 0x36,
0x2d, 0x94, 0xeb, 0x93, 0x57, 0xb4, 0x98, 0xaa, 0x6b, 0xef, 0x98, 0xf2, 0xeb, 0xca, 0x36, 0x7f,
0xef, 0xfc, 0x47, 0xfe, 0x8e, 0xd7, 0xe6, 0xef, 0x6e, 0x8d, 0xbf, 0x1a, 0xf9, 0x6c, 0xa6, 0xd7,
0xc7, 0xf3, 0x34, 0xd8, 0xb3, 0xc8, 0x7b, 0x99, 0xfc, 0x08, 0x63, 0x4b, 0x87, 0xef, 0xb2, 0x19,
0x96, 0xfa, 0x33, 0x6f, 0x18, 0x32, 0x3c, 0x5c, 0x03, 0xf3, 0x27, 0xb5, 0xc0, 0xb8, 0x91, 0x88,
0x7c, 0x0e, 0x61, 0x07, 0x8e, 0x4f, 0xf1, 0x22, 0x2b, 0x30, 0x0d, 0x88, 0xa9, 0xfe, 0x1a, 0x0f,
0xf2, 0x31, 0xbc, 0x29, 0xdc, 0x9a, 0x7c, 0x49, 0xd5, 0x98, 0xd0, 0xfc, 0x7b, 0x9a, 0xab, 0x0f,
0x07, 0xfb, 0x26, 0xb4, 0xdb, 0x18, 0x7e, 0x08, 0x07, 0x5d, 0x5c, 0xd0, 0x13, 0xa3, 0x26, 0x54,
0xa8, 0x29, 0xd2, 0xd8, 0x98, 0x73, 0xf8, 0x03, 0x8c, 0xeb, 0x35, 0x98, 0x59, 0xe1, 0x6a, 0x27,
0xfb, 0x69, 0x73, 0x92, 0xd6, 0x57, 0x2c, 0xd5, 0x7a, 0x3b, 0x71, 0x4e, 0xd2, 0x7a, 0x5b, 0x81,
0x9f, 0x39, 0x2b, 0x85, 0xbf, 0xf7, 0xe0, 0xee, 0x4a, 0x4a, 0xea, 0xc5, 0x71, 0x89, 0x73, 0xbf,
0x38, 0xd4, 0x91, 0xbc, 0x80, 0xdb, 0x57, 0xfa, 0xfe, 0x6e, 0x67, 0x3c, 0xfa, 0x9f, 0x8c, 0x8f,
0x6d, 0x96, 0x4f, 0xfb, 0x8f, 0x7b, 0xd1, 0x9f, 0x3d, 0x08, 0xda, 0xb1, 0x2b, 0x57, 0x97, 0x7d,
0x41, 0xfa, 0x8b, 0x17, 0xe4, 0xdf, 0xed, 0x30, 0x58, 0x6f, 0x3b, 0x28, 0x28, 0x84, 0xa4, 0xe7,
0x39, 0xfa, 0x35, 0x63, 0x25, 0xcd, 0x4b, 0x7b, 0xd2, 0xef, 0x88, 0xe1, 0xa5, 0x13, 0x23, 0x84,
0xe3, 0xe6, 0x05, 0x1d, 0x99, 0xfd, 0xea, 0x6b, 0x5f, 0xf3, 0x21, 0x6c, 0x96, 0x6e, 0x1e, 0x6e,
0x58, 0xaf, 0xde, 0xef, 0xf4, 0x8f, 0x0d, 0xd8, 0xf5, 0xf9, 0x5f, 0x94, 0x45, 0x26, 0x4b, 0x4e,
0x7e, 0x82, 0xdd, 0xc6, 0x13, 0x4c, 0xde, 0x5d, 0xc2, 0xbc, 0xfb, 0x21, 0x0f, 0xa3, 0xeb, 0x5c,
0x2c, 0xb2, 0xd1, 0x2d, 0xf2, 0x05, 0x0c, 0x9f, 0x17, 0x57, 0xe5, 0xa5, 0x2a, 0x7d, 0xc9, 0xdf,
0xaa, 0x7c, 0xa6, 0xbb, 0x1d, 0x96, 0x45, 0x82, 0xaf, 0x61, 0x47, 0xd5, 0x80, 0x74, 0xf6, 0x5a,
0x69, 0x1e, 0xf4, 0xc8, 0xb7, 0xb0, 0xb3, 0xfc, 0x70, 0x91, 0xe3, 0x1a, 0xad, 0x5a, 0xff, 0x22,
0xc2, 0x77, 0x56, 0xda, 0x17, 0x77, 0xfb, 0x19, 0xf6, 0x9a, 0x3d, 0x23, 0xd1, 0xcd, 0x6c, 0x0d,
0xdf, 0xbb, 0xd6, 0x67, 0x91, 0xfe, 0x97, 0xf6, 0x33, 0xe8, 0xf7, 0xdb, 0x07, 0xd7, 0x64, 0xa8,
0xd3, 0x26, 0x3c, 0x6c, 0x71, 0xe2, 0x99, 0xfe, 0x5b, 0x17, 0xdd, 0x3a, 0x1f, 0x1a, 0xcd, 0x47,
0xff, 0x04, 0x00, 0x00, 0xff, 0xff, 0x00, 0xa9, 0x5c, 0x60, 0x13, 0x0a, 0x00, 0x00,
}