Skip to content
Snippets Groups Projects
api.pb.go 35.4 KiB
Newer Older
  • Learn to ignore specific revisions
  • Eric Chiang's avatar
    Eric Chiang committed
    // Code generated by protoc-gen-go. DO NOT EDIT.
    
    Eric Chiang's avatar
    Eric Chiang committed
    // source: api/api.proto
    
    /*
    Package api is a generated protocol buffer package.
    
    It is generated from these files:
    	api/api.proto
    
    It has these top-level messages:
    	Client
    	CreateClientReq
    	CreateClientResp
    	DeleteClientReq
    	DeleteClientResp
    
    	Password
    	CreatePasswordReq
    	CreatePasswordResp
    	UpdatePasswordReq
    	UpdatePasswordResp
    	DeletePasswordReq
    	DeletePasswordResp
    
    	ListPasswordReq
    	ListPasswordResp
    
    	VersionReq
    	VersionResp
    
    	RefreshTokenRef
    	ListRefreshReq
    	ListRefreshResp
    
    	RevokeRefreshReq
    	RevokeRefreshResp
    
    Eric Chiang's avatar
    Eric Chiang committed
    */
    package api
    
    import proto "github.com/golang/protobuf/proto"
    import fmt "fmt"
    import math "math"
    
    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
    
    // Client represents an OAuth2 client.
    type Client struct {
    	Id           string   `protobuf:"bytes,1,opt,name=id" json:"id,omitempty"`
    	Secret       string   `protobuf:"bytes,2,opt,name=secret" json:"secret,omitempty"`
    	RedirectUris []string `protobuf:"bytes,3,rep,name=redirect_uris,json=redirectUris" json:"redirect_uris,omitempty"`
    	TrustedPeers []string `protobuf:"bytes,4,rep,name=trusted_peers,json=trustedPeers" json:"trusted_peers,omitempty"`
    	Public       bool     `protobuf:"varint,5,opt,name=public" json:"public,omitempty"`
    	Name         string   `protobuf:"bytes,6,opt,name=name" json:"name,omitempty"`
    	LogoUrl      string   `protobuf:"bytes,7,opt,name=logo_url,json=logoUrl" json:"logo_url,omitempty"`
    }
    
    func (m *Client) Reset()                    { *m = Client{} }
    func (m *Client) String() string            { return proto.CompactTextString(m) }
    func (*Client) ProtoMessage()               {}
    func (*Client) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *Client) GetId() string {
    	if m != nil {
    		return m.Id
    	}
    	return ""
    }
    
    func (m *Client) GetSecret() string {
    	if m != nil {
    		return m.Secret
    	}
    	return ""
    }
    
    func (m *Client) GetRedirectUris() []string {
    	if m != nil {
    		return m.RedirectUris
    	}
    	return nil
    }
    
    func (m *Client) GetTrustedPeers() []string {
    	if m != nil {
    		return m.TrustedPeers
    	}
    	return nil
    }
    
    func (m *Client) GetPublic() bool {
    	if m != nil {
    		return m.Public
    	}
    	return false
    }
    
    func (m *Client) GetName() string {
    	if m != nil {
    		return m.Name
    	}
    	return ""
    }
    
    func (m *Client) GetLogoUrl() string {
    	if m != nil {
    		return m.LogoUrl
    	}
    	return ""
    }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    // CreateClientReq is a request to make a client.
    type CreateClientReq struct {
    	Client *Client `protobuf:"bytes,1,opt,name=client" json:"client,omitempty"`
    }
    
    func (m *CreateClientReq) Reset()                    { *m = CreateClientReq{} }
    func (m *CreateClientReq) String() string            { return proto.CompactTextString(m) }
    func (*CreateClientReq) ProtoMessage()               {}
    func (*CreateClientReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{1} }
    
    func (m *CreateClientReq) GetClient() *Client {
    	if m != nil {
    		return m.Client
    	}
    	return nil
    }
    
    // CreateClientResp returns the response from creating a client.
    type CreateClientResp struct {
    	AlreadyExists bool    `protobuf:"varint,1,opt,name=already_exists,json=alreadyExists" json:"already_exists,omitempty"`
    	Client        *Client `protobuf:"bytes,2,opt,name=client" json:"client,omitempty"`
    }
    
    func (m *CreateClientResp) Reset()                    { *m = CreateClientResp{} }
    func (m *CreateClientResp) String() string            { return proto.CompactTextString(m) }
    func (*CreateClientResp) ProtoMessage()               {}
    func (*CreateClientResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{2} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *CreateClientResp) GetAlreadyExists() bool {
    	if m != nil {
    		return m.AlreadyExists
    	}
    	return false
    }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *CreateClientResp) GetClient() *Client {
    	if m != nil {
    		return m.Client
    	}
    	return nil
    }
    
    // DeleteClientReq is a request to delete a client.
    type DeleteClientReq struct {
    	// The ID of the client.
    	Id string `protobuf:"bytes,1,opt,name=id" json:"id,omitempty"`
    }
    
    func (m *DeleteClientReq) Reset()                    { *m = DeleteClientReq{} }
    func (m *DeleteClientReq) String() string            { return proto.CompactTextString(m) }
    func (*DeleteClientReq) ProtoMessage()               {}
    func (*DeleteClientReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{3} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *DeleteClientReq) GetId() string {
    	if m != nil {
    		return m.Id
    	}
    	return ""
    }
    
    
    // DeleteClientResp determines if the client is deleted successfully.
    
    Eric Chiang's avatar
    Eric Chiang committed
    type DeleteClientResp struct {
    	NotFound bool `protobuf:"varint,1,opt,name=not_found,json=notFound" json:"not_found,omitempty"`
    }
    
    func (m *DeleteClientResp) Reset()                    { *m = DeleteClientResp{} }
    func (m *DeleteClientResp) String() string            { return proto.CompactTextString(m) }
    func (*DeleteClientResp) ProtoMessage()               {}
    func (*DeleteClientResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{4} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *DeleteClientResp) GetNotFound() bool {
    	if m != nil {
    		return m.NotFound
    	}
    	return false
    }
    
    
    // Password is an email for password mapping managed by the storage.
    type Password struct {
    	Email string `protobuf:"bytes,1,opt,name=email" json:"email,omitempty"`
    	// Currently we do not accept plain text passwords. Could be an option in the future.
    	Hash     []byte `protobuf:"bytes,2,opt,name=hash,proto3" json:"hash,omitempty"`
    	Username string `protobuf:"bytes,3,opt,name=username" json:"username,omitempty"`
    	UserId   string `protobuf:"bytes,4,opt,name=user_id,json=userId" json:"user_id,omitempty"`
    }
    
    func (m *Password) Reset()                    { *m = Password{} }
    func (m *Password) String() string            { return proto.CompactTextString(m) }
    func (*Password) ProtoMessage()               {}
    func (*Password) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{5} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *Password) GetEmail() string {
    	if m != nil {
    		return m.Email
    	}
    	return ""
    }
    
    func (m *Password) GetHash() []byte {
    	if m != nil {
    		return m.Hash
    	}
    	return nil
    }
    
    func (m *Password) GetUsername() string {
    	if m != nil {
    		return m.Username
    	}
    	return ""
    }
    
    func (m *Password) GetUserId() string {
    	if m != nil {
    		return m.UserId
    	}
    	return ""
    }
    
    
    // CreatePasswordReq is a request to make a password.
    type CreatePasswordReq struct {
    	Password *Password `protobuf:"bytes,1,opt,name=password" json:"password,omitempty"`
    }
    
    func (m *CreatePasswordReq) Reset()                    { *m = CreatePasswordReq{} }
    func (m *CreatePasswordReq) String() string            { return proto.CompactTextString(m) }
    func (*CreatePasswordReq) ProtoMessage()               {}
    func (*CreatePasswordReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{6} }
    
    func (m *CreatePasswordReq) GetPassword() *Password {
    	if m != nil {
    		return m.Password
    	}
    	return nil
    }
    
    // CreatePasswordResp returns the response from creating a password.
    type CreatePasswordResp struct {
    	AlreadyExists bool `protobuf:"varint,1,opt,name=already_exists,json=alreadyExists" json:"already_exists,omitempty"`
    }
    
    func (m *CreatePasswordResp) Reset()                    { *m = CreatePasswordResp{} }
    func (m *CreatePasswordResp) String() string            { return proto.CompactTextString(m) }
    func (*CreatePasswordResp) ProtoMessage()               {}
    func (*CreatePasswordResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{7} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *CreatePasswordResp) GetAlreadyExists() bool {
    	if m != nil {
    		return m.AlreadyExists
    	}
    	return false
    }
    
    
    // UpdatePasswordReq is a request to modify an existing password.
    type UpdatePasswordReq struct {
    	// The email used to lookup the password. This field cannot be modified
    	Email       string `protobuf:"bytes,1,opt,name=email" json:"email,omitempty"`
    	NewHash     []byte `protobuf:"bytes,2,opt,name=new_hash,json=newHash,proto3" json:"new_hash,omitempty"`
    	NewUsername string `protobuf:"bytes,3,opt,name=new_username,json=newUsername" json:"new_username,omitempty"`
    }
    
    func (m *UpdatePasswordReq) Reset()                    { *m = UpdatePasswordReq{} }
    func (m *UpdatePasswordReq) String() string            { return proto.CompactTextString(m) }
    func (*UpdatePasswordReq) ProtoMessage()               {}
    func (*UpdatePasswordReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{8} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *UpdatePasswordReq) GetEmail() string {
    	if m != nil {
    		return m.Email
    	}
    	return ""
    }
    
    func (m *UpdatePasswordReq) GetNewHash() []byte {
    	if m != nil {
    		return m.NewHash
    	}
    	return nil
    }
    
    func (m *UpdatePasswordReq) GetNewUsername() string {
    	if m != nil {
    		return m.NewUsername
    	}
    	return ""
    }
    
    
    // UpdatePasswordResp returns the response from modifying an existing password.
    type UpdatePasswordResp struct {
    	NotFound bool `protobuf:"varint,1,opt,name=not_found,json=notFound" json:"not_found,omitempty"`
    }
    
    func (m *UpdatePasswordResp) Reset()                    { *m = UpdatePasswordResp{} }
    func (m *UpdatePasswordResp) String() string            { return proto.CompactTextString(m) }
    func (*UpdatePasswordResp) ProtoMessage()               {}
    func (*UpdatePasswordResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{9} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *UpdatePasswordResp) GetNotFound() bool {
    	if m != nil {
    		return m.NotFound
    	}
    	return false
    }
    
    
    // DeletePasswordReq is a request to delete a password.
    type DeletePasswordReq struct {
    	Email string `protobuf:"bytes,1,opt,name=email" json:"email,omitempty"`
    }
    
    func (m *DeletePasswordReq) Reset()                    { *m = DeletePasswordReq{} }
    func (m *DeletePasswordReq) String() string            { return proto.CompactTextString(m) }
    func (*DeletePasswordReq) ProtoMessage()               {}
    func (*DeletePasswordReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{10} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *DeletePasswordReq) GetEmail() string {
    	if m != nil {
    		return m.Email
    	}
    	return ""
    }
    
    
    // DeletePasswordResp returns the response from deleting a password.
    type DeletePasswordResp struct {
    	NotFound bool `protobuf:"varint,1,opt,name=not_found,json=notFound" json:"not_found,omitempty"`
    }
    
    func (m *DeletePasswordResp) Reset()                    { *m = DeletePasswordResp{} }
    func (m *DeletePasswordResp) String() string            { return proto.CompactTextString(m) }
    func (*DeletePasswordResp) ProtoMessage()               {}
    func (*DeletePasswordResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{11} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *DeletePasswordResp) GetNotFound() bool {
    	if m != nil {
    		return m.NotFound
    	}
    	return false
    }
    
    
    // ListPasswordReq is a request to enumerate passwords.
    type ListPasswordReq struct {
    }
    
    func (m *ListPasswordReq) Reset()                    { *m = ListPasswordReq{} }
    func (m *ListPasswordReq) String() string            { return proto.CompactTextString(m) }
    func (*ListPasswordReq) ProtoMessage()               {}
    func (*ListPasswordReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{12} }
    
    
    // ListPasswordResp returns a list of passwords.
    
    type ListPasswordResp struct {
    	Passwords []*Password `protobuf:"bytes,1,rep,name=passwords" json:"passwords,omitempty"`
    }
    
    func (m *ListPasswordResp) Reset()                    { *m = ListPasswordResp{} }
    func (m *ListPasswordResp) String() string            { return proto.CompactTextString(m) }
    func (*ListPasswordResp) ProtoMessage()               {}
    func (*ListPasswordResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{13} }
    
    func (m *ListPasswordResp) GetPasswords() []*Password {
    	if m != nil {
    		return m.Passwords
    	}
    	return nil
    }
    
    
    // VersionReq is a request to fetch version info.
    type VersionReq struct {
    }
    
    func (m *VersionReq) Reset()                    { *m = VersionReq{} }
    func (m *VersionReq) String() string            { return proto.CompactTextString(m) }
    func (*VersionReq) ProtoMessage()               {}
    
    func (*VersionReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{14} }
    
    
    // VersionResp holds the version info of components.
    type VersionResp struct {
    	// Semantic version of the server.
    	Server string `protobuf:"bytes,1,opt,name=server" json:"server,omitempty"`
    	// Numeric version of the API. It increases everytime a new call is added to the API.
    	// Clients should use this info to determine if the server supports specific features.
    	Api int32 `protobuf:"varint,2,opt,name=api" json:"api,omitempty"`
    }
    
    func (m *VersionResp) Reset()                    { *m = VersionResp{} }
    func (m *VersionResp) String() string            { return proto.CompactTextString(m) }
    func (*VersionResp) ProtoMessage()               {}
    
    func (*VersionResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{15} }
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *VersionResp) GetServer() string {
    	if m != nil {
    		return m.Server
    	}
    	return ""
    }
    
    func (m *VersionResp) GetApi() int32 {
    	if m != nil {
    		return m.Api
    	}
    	return 0
    }
    
    
    // RefreshTokenRef contains the metadata for a refresh token that is managed by the storage.
    type RefreshTokenRef struct {
    	// ID of the refresh token.
    	Id        string `protobuf:"bytes,1,opt,name=id" json:"id,omitempty"`
    	ClientId  string `protobuf:"bytes,2,opt,name=client_id,json=clientId" json:"client_id,omitempty"`
    
    	CreatedAt int64  `protobuf:"varint,5,opt,name=created_at,json=createdAt" json:"created_at,omitempty"`
    	LastUsed  int64  `protobuf:"varint,6,opt,name=last_used,json=lastUsed" json:"last_used,omitempty"`
    
    }
    
    func (m *RefreshTokenRef) Reset()                    { *m = RefreshTokenRef{} }
    func (m *RefreshTokenRef) String() string            { return proto.CompactTextString(m) }
    func (*RefreshTokenRef) ProtoMessage()               {}
    func (*RefreshTokenRef) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{16} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *RefreshTokenRef) GetId() string {
    	if m != nil {
    		return m.Id
    	}
    	return ""
    }
    
    func (m *RefreshTokenRef) GetClientId() string {
    	if m != nil {
    		return m.ClientId
    	}
    	return ""
    }
    
    func (m *RefreshTokenRef) GetCreatedAt() int64 {
    	if m != nil {
    		return m.CreatedAt
    	}
    	return 0
    }
    
    func (m *RefreshTokenRef) GetLastUsed() int64 {
    	if m != nil {
    		return m.LastUsed
    	}
    	return 0
    }
    
    
    // ListRefreshReq is a request to enumerate the refresh tokens of a user.
    type ListRefreshReq struct {
    	// The "sub" claim returned in the ID Token.
    	UserId string `protobuf:"bytes,1,opt,name=user_id,json=userId" json:"user_id,omitempty"`
    }
    
    func (m *ListRefreshReq) Reset()                    { *m = ListRefreshReq{} }
    func (m *ListRefreshReq) String() string            { return proto.CompactTextString(m) }
    func (*ListRefreshReq) ProtoMessage()               {}
    func (*ListRefreshReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{17} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *ListRefreshReq) GetUserId() string {
    	if m != nil {
    		return m.UserId
    	}
    	return ""
    }
    
    
    // ListRefreshResp returns a list of refresh tokens for a user.
    type ListRefreshResp struct {
    	RefreshTokens []*RefreshTokenRef `protobuf:"bytes,1,rep,name=refresh_tokens,json=refreshTokens" json:"refresh_tokens,omitempty"`
    }
    
    func (m *ListRefreshResp) Reset()                    { *m = ListRefreshResp{} }
    func (m *ListRefreshResp) String() string            { return proto.CompactTextString(m) }
    func (*ListRefreshResp) ProtoMessage()               {}
    func (*ListRefreshResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{18} }
    
    func (m *ListRefreshResp) GetRefreshTokens() []*RefreshTokenRef {
    	if m != nil {
    		return m.RefreshTokens
    	}
    	return nil
    }
    
    
    // RevokeRefreshReq is a request to revoke the refresh token of the user-client pair.
    
    type RevokeRefreshReq struct {
    	// The "sub" claim returned in the ID Token.
    	UserId   string `protobuf:"bytes,1,opt,name=user_id,json=userId" json:"user_id,omitempty"`
    	ClientId string `protobuf:"bytes,2,opt,name=client_id,json=clientId" json:"client_id,omitempty"`
    }
    
    func (m *RevokeRefreshReq) Reset()                    { *m = RevokeRefreshReq{} }
    func (m *RevokeRefreshReq) String() string            { return proto.CompactTextString(m) }
    func (*RevokeRefreshReq) ProtoMessage()               {}
    func (*RevokeRefreshReq) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{19} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *RevokeRefreshReq) GetUserId() string {
    	if m != nil {
    		return m.UserId
    	}
    	return ""
    }
    
    func (m *RevokeRefreshReq) GetClientId() string {
    	if m != nil {
    		return m.ClientId
    	}
    	return ""
    }
    
    
    // RevokeRefreshResp determines if the refresh token is revoked successfully.
    
    type RevokeRefreshResp struct {
    
    	// Set to true is refresh token was not found and token could not be revoked.
    
    	NotFound bool `protobuf:"varint,1,opt,name=not_found,json=notFound" json:"not_found,omitempty"`
    }
    
    func (m *RevokeRefreshResp) Reset()                    { *m = RevokeRefreshResp{} }
    func (m *RevokeRefreshResp) String() string            { return proto.CompactTextString(m) }
    func (*RevokeRefreshResp) ProtoMessage()               {}
    func (*RevokeRefreshResp) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{20} }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func (m *RevokeRefreshResp) GetNotFound() bool {
    	if m != nil {
    		return m.NotFound
    	}
    	return false
    }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    func init() {
    	proto.RegisterType((*Client)(nil), "api.Client")
    	proto.RegisterType((*CreateClientReq)(nil), "api.CreateClientReq")
    	proto.RegisterType((*CreateClientResp)(nil), "api.CreateClientResp")
    	proto.RegisterType((*DeleteClientReq)(nil), "api.DeleteClientReq")
    	proto.RegisterType((*DeleteClientResp)(nil), "api.DeleteClientResp")
    
    	proto.RegisterType((*Password)(nil), "api.Password")
    	proto.RegisterType((*CreatePasswordReq)(nil), "api.CreatePasswordReq")
    	proto.RegisterType((*CreatePasswordResp)(nil), "api.CreatePasswordResp")
    	proto.RegisterType((*UpdatePasswordReq)(nil), "api.UpdatePasswordReq")
    	proto.RegisterType((*UpdatePasswordResp)(nil), "api.UpdatePasswordResp")
    	proto.RegisterType((*DeletePasswordReq)(nil), "api.DeletePasswordReq")
    	proto.RegisterType((*DeletePasswordResp)(nil), "api.DeletePasswordResp")
    
    	proto.RegisterType((*ListPasswordReq)(nil), "api.ListPasswordReq")
    	proto.RegisterType((*ListPasswordResp)(nil), "api.ListPasswordResp")
    
    	proto.RegisterType((*VersionReq)(nil), "api.VersionReq")
    	proto.RegisterType((*VersionResp)(nil), "api.VersionResp")
    
    	proto.RegisterType((*RefreshTokenRef)(nil), "api.RefreshTokenRef")
    	proto.RegisterType((*ListRefreshReq)(nil), "api.ListRefreshReq")
    	proto.RegisterType((*ListRefreshResp)(nil), "api.ListRefreshResp")
    
    	proto.RegisterType((*RevokeRefreshReq)(nil), "api.RevokeRefreshReq")
    	proto.RegisterType((*RevokeRefreshResp)(nil), "api.RevokeRefreshResp")
    
    Eric Chiang's avatar
    Eric Chiang committed
    }
    
    // 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
    
    Eric Chiang's avatar
    Eric Chiang committed
    
    // Client API for Dex service
    
    type DexClient interface {
    
    	// CreateClient creates a client.
    
    Eric Chiang's avatar
    Eric Chiang committed
    	CreateClient(ctx context.Context, in *CreateClientReq, opts ...grpc.CallOption) (*CreateClientResp, error)
    
    	// DeleteClient deletes the provided client.
    
    Eric Chiang's avatar
    Eric Chiang committed
    	DeleteClient(ctx context.Context, in *DeleteClientReq, opts ...grpc.CallOption) (*DeleteClientResp, error)
    
    	// CreatePassword creates a password.
    
    	CreatePassword(ctx context.Context, in *CreatePasswordReq, opts ...grpc.CallOption) (*CreatePasswordResp, error)
    
    	// UpdatePassword modifies existing password.
    
    	UpdatePassword(ctx context.Context, in *UpdatePasswordReq, opts ...grpc.CallOption) (*UpdatePasswordResp, error)
    
    	// DeletePassword deletes the password.
    
    	DeletePassword(ctx context.Context, in *DeletePasswordReq, opts ...grpc.CallOption) (*DeletePasswordResp, error)
    
    	// ListPassword lists all password entries.
    	ListPasswords(ctx context.Context, in *ListPasswordReq, opts ...grpc.CallOption) (*ListPasswordResp, error)
    
    	// GetVersion returns version information of the server.
    	GetVersion(ctx context.Context, in *VersionReq, opts ...grpc.CallOption) (*VersionResp, error)
    
    	// ListRefresh lists all the refresh token entries for a particular user.
    	ListRefresh(ctx context.Context, in *ListRefreshReq, opts ...grpc.CallOption) (*ListRefreshResp, error)
    
    	// RevokeRefresh revokes the refresh token for the provided user-client pair.
    
    	// Note that each user-client pair can have only one refresh token at a time.
    	RevokeRefresh(ctx context.Context, in *RevokeRefreshReq, opts ...grpc.CallOption) (*RevokeRefreshResp, error)
    
    Eric Chiang's avatar
    Eric Chiang committed
    }
    
    type dexClient struct {
    	cc *grpc.ClientConn
    }
    
    func NewDexClient(cc *grpc.ClientConn) DexClient {
    	return &dexClient{cc}
    }
    
    func (c *dexClient) CreateClient(ctx context.Context, in *CreateClientReq, opts ...grpc.CallOption) (*CreateClientResp, error) {
    	out := new(CreateClientResp)
    	err := grpc.Invoke(ctx, "/api.Dex/CreateClient", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    func (c *dexClient) DeleteClient(ctx context.Context, in *DeleteClientReq, opts ...grpc.CallOption) (*DeleteClientResp, error) {
    	out := new(DeleteClientResp)
    	err := grpc.Invoke(ctx, "/api.Dex/DeleteClient", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    
    func (c *dexClient) CreatePassword(ctx context.Context, in *CreatePasswordReq, opts ...grpc.CallOption) (*CreatePasswordResp, error) {
    	out := new(CreatePasswordResp)
    	err := grpc.Invoke(ctx, "/api.Dex/CreatePassword", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    func (c *dexClient) UpdatePassword(ctx context.Context, in *UpdatePasswordReq, opts ...grpc.CallOption) (*UpdatePasswordResp, error) {
    	out := new(UpdatePasswordResp)
    	err := grpc.Invoke(ctx, "/api.Dex/UpdatePassword", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    func (c *dexClient) DeletePassword(ctx context.Context, in *DeletePasswordReq, opts ...grpc.CallOption) (*DeletePasswordResp, error) {
    	out := new(DeletePasswordResp)
    	err := grpc.Invoke(ctx, "/api.Dex/DeletePassword", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    
    func (c *dexClient) ListPasswords(ctx context.Context, in *ListPasswordReq, opts ...grpc.CallOption) (*ListPasswordResp, error) {
    	out := new(ListPasswordResp)
    	err := grpc.Invoke(ctx, "/api.Dex/ListPasswords", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    
    func (c *dexClient) GetVersion(ctx context.Context, in *VersionReq, opts ...grpc.CallOption) (*VersionResp, error) {
    	out := new(VersionResp)
    	err := grpc.Invoke(ctx, "/api.Dex/GetVersion", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    
    func (c *dexClient) ListRefresh(ctx context.Context, in *ListRefreshReq, opts ...grpc.CallOption) (*ListRefreshResp, error) {
    	out := new(ListRefreshResp)
    	err := grpc.Invoke(ctx, "/api.Dex/ListRefresh", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    
    func (c *dexClient) RevokeRefresh(ctx context.Context, in *RevokeRefreshReq, opts ...grpc.CallOption) (*RevokeRefreshResp, error) {
    	out := new(RevokeRefreshResp)
    	err := grpc.Invoke(ctx, "/api.Dex/RevokeRefresh", in, out, c.cc, opts...)
    	if err != nil {
    		return nil, err
    	}
    	return out, nil
    }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    // Server API for Dex service
    
    type DexServer interface {
    
    	// CreateClient creates a client.
    
    Eric Chiang's avatar
    Eric Chiang committed
    	CreateClient(context.Context, *CreateClientReq) (*CreateClientResp, error)
    
    	// DeleteClient deletes the provided client.
    
    Eric Chiang's avatar
    Eric Chiang committed
    	DeleteClient(context.Context, *DeleteClientReq) (*DeleteClientResp, error)
    
    	// CreatePassword creates a password.
    
    	CreatePassword(context.Context, *CreatePasswordReq) (*CreatePasswordResp, error)
    
    	// UpdatePassword modifies existing password.
    
    	UpdatePassword(context.Context, *UpdatePasswordReq) (*UpdatePasswordResp, error)
    
    	// DeletePassword deletes the password.
    
    	DeletePassword(context.Context, *DeletePasswordReq) (*DeletePasswordResp, error)
    
    	// ListPassword lists all password entries.
    	ListPasswords(context.Context, *ListPasswordReq) (*ListPasswordResp, error)
    
    	// GetVersion returns version information of the server.
    	GetVersion(context.Context, *VersionReq) (*VersionResp, error)
    
    	// ListRefresh lists all the refresh token entries for a particular user.
    	ListRefresh(context.Context, *ListRefreshReq) (*ListRefreshResp, error)
    
    	// RevokeRefresh revokes the refresh token for the provided user-client pair.
    
    	// Note that each user-client pair can have only one refresh token at a time.
    	RevokeRefresh(context.Context, *RevokeRefreshReq) (*RevokeRefreshResp, error)
    
    Eric Chiang's avatar
    Eric Chiang committed
    }
    
    func RegisterDexServer(s *grpc.Server, srv DexServer) {
    	s.RegisterService(&_Dex_serviceDesc, srv)
    }
    
    func _Dex_CreateClient_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(CreateClientReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).CreateClient(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/CreateClient",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).CreateClient(ctx, req.(*CreateClientReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    func _Dex_DeleteClient_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(DeleteClientReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).DeleteClient(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/DeleteClient",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).DeleteClient(ctx, req.(*DeleteClientReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    
    func _Dex_CreatePassword_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(CreatePasswordReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).CreatePassword(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/CreatePassword",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).CreatePassword(ctx, req.(*CreatePasswordReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    func _Dex_UpdatePassword_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(UpdatePasswordReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).UpdatePassword(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/UpdatePassword",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).UpdatePassword(ctx, req.(*UpdatePasswordReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    func _Dex_DeletePassword_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(DeletePasswordReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).DeletePassword(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/DeletePassword",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).DeletePassword(ctx, req.(*DeletePasswordReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    
    func _Dex_ListPasswords_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(ListPasswordReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).ListPasswords(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/ListPasswords",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).ListPasswords(ctx, req.(*ListPasswordReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    
    func _Dex_GetVersion_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(VersionReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).GetVersion(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/GetVersion",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).GetVersion(ctx, req.(*VersionReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    
    func _Dex_ListRefresh_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(ListRefreshReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).ListRefresh(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/ListRefresh",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).ListRefresh(ctx, req.(*ListRefreshReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    
    func _Dex_RevokeRefresh_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
    	in := new(RevokeRefreshReq)
    	if err := dec(in); err != nil {
    		return nil, err
    	}
    	if interceptor == nil {
    		return srv.(DexServer).RevokeRefresh(ctx, in)
    	}
    	info := &grpc.UnaryServerInfo{
    		Server:     srv,
    		FullMethod: "/api.Dex/RevokeRefresh",
    	}
    	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
    		return srv.(DexServer).RevokeRefresh(ctx, req.(*RevokeRefreshReq))
    	}
    	return interceptor(ctx, in, info, handler)
    }
    
    
    Eric Chiang's avatar
    Eric Chiang committed
    var _Dex_serviceDesc = grpc.ServiceDesc{
    	ServiceName: "api.Dex",
    	HandlerType: (*DexServer)(nil),
    	Methods: []grpc.MethodDesc{
    		{
    			MethodName: "CreateClient",
    			Handler:    _Dex_CreateClient_Handler,
    		},
    		{
    			MethodName: "DeleteClient",
    			Handler:    _Dex_DeleteClient_Handler,
    		},
    
    		{
    			MethodName: "CreatePassword",
    			Handler:    _Dex_CreatePassword_Handler,
    		},
    		{
    			MethodName: "UpdatePassword",
    			Handler:    _Dex_UpdatePassword_Handler,
    		},
    		{
    			MethodName: "DeletePassword",
    			Handler:    _Dex_DeletePassword_Handler,
    		},
    
    		{
    			MethodName: "ListPasswords",
    			Handler:    _Dex_ListPasswords_Handler,
    		},
    
    		{
    			MethodName: "GetVersion",
    			Handler:    _Dex_GetVersion_Handler,
    		},
    
    		{
    			MethodName: "ListRefresh",
    			Handler:    _Dex_ListRefresh_Handler,
    		},
    
    		{
    			MethodName: "RevokeRefresh",
    			Handler:    _Dex_RevokeRefresh_Handler,
    		},
    
    Eric Chiang's avatar
    Eric Chiang committed
    	},
    	Streams:  []grpc.StreamDesc{},
    
    	Metadata: "api/api.proto",
    
    Eric Chiang's avatar
    Eric Chiang committed
    }
    
    func init() { proto.RegisterFile("api/api.proto", fileDescriptor0) }
    
    var fileDescriptor0 = []byte{
    
    Eric Chiang's avatar
    Eric Chiang committed
    	// 801 bytes of a gzipped FileDescriptorProto
    	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x56, 0x6d, 0x4f, 0xe3, 0x46,
    	0x10, 0x4e, 0xe2, 0x90, 0x38, 0x93, 0xf7, 0x6d, 0x00, 0x13, 0x54, 0x09, 0x16, 0x55, 0x02, 0x55,
    	0x0a, 0x85, 0x4a, 0xad, 0x54, 0x54, 0xfa, 0x02, 0x6d, 0x41, 0xaa, 0x2a, 0x64, 0x35, 0xfd, 0x58,
    	0xcb, 0xc4, 0x03, 0xac, 0x30, 0xb6, 0xbb, 0xbb, 0x21, 0xf4, 0xfe, 0xdd, 0xe9, 0xfe, 0xd8, 0x69,
    	0xd7, 0x9b, 0x60, 0x3b, 0xb9, 0x0b, 0xdf, 0x3c, 0xcf, 0xce, 0x3c, 0xb3, 0xf3, 0xec, 0xcc, 0xc8,
    	0xd0, 0xf6, 0x13, 0x76, 0xec, 0x27, 0x6c, 0x94, 0xf0, 0x58, 0xc6, 0xc4, 0xf2, 0x13, 0x46, 0xdf,
    	0x97, 0xa1, 0x76, 0x11, 0x32, 0x8c, 0x24, 0xe9, 0x40, 0x85, 0x05, 0x4e, 0x79, 0xaf, 0x7c, 0xd8,
    	0x70, 0x2b, 0x2c, 0x20, 0x5b, 0x50, 0x13, 0x38, 0xe1, 0x28, 0x9d, 0x8a, 0xc6, 0x8c, 0x45, 0x0e,
    	0xa0, 0xcd, 0x31, 0x60, 0x1c, 0x27, 0xd2, 0x9b, 0x72, 0x26, 0x1c, 0x6b, 0xcf, 0x3a, 0x6c, 0xb8,
    	0xad, 0x39, 0x38, 0xe6, 0x4c, 0x28, 0x27, 0xc9, 0xa7, 0x42, 0x62, 0xe0, 0x25, 0x88, 0x5c, 0x38,
    	0xd5, 0xd4, 0xc9, 0x80, 0x37, 0x0a, 0x53, 0x19, 0x92, 0xe9, 0x6d, 0xc8, 0x26, 0xce, 0xc6, 0x5e,
    	0xf9, 0xd0, 0x76, 0x8d, 0x45, 0x08, 0x54, 0x23, 0xff, 0x09, 0x9d, 0x9a, 0xce, 0xab, 0xbf, 0xc9,
    	0x0e, 0xd8, 0x61, 0x7c, 0x1f, 0x7b, 0x53, 0x1e, 0x3a, 0x75, 0x8d, 0xd7, 0x95, 0x3d, 0xe6, 0x21,
    	0xfd, 0x0e, 0xba, 0x17, 0x1c, 0x7d, 0x89, 0x69, 0x21, 0x2e, 0xfe, 0x47, 0x0e, 0xa0, 0x36, 0xd1,
    	0x86, 0xae, 0xa7, 0x79, 0xda, 0x1c, 0xa9, 0xba, 0xcd, 0xb9, 0x39, 0xa2, 0xff, 0x42, 0x2f, 0x1f,
    	0x27, 0x12, 0xf2, 0x15, 0x74, 0xfc, 0x90, 0xa3, 0x1f, 0xfc, 0xef, 0xe1, 0x0b, 0x13, 0x52, 0x68,
    	0x02, 0xdb, 0x6d, 0x1b, 0xf4, 0x37, 0x0d, 0x66, 0xf8, 0x2b, 0x9f, 0xe6, 0xdf, 0x87, 0xee, 0x25,
    	0x86, 0x98, 0xbd, 0x57, 0x41, 0x63, 0x7a, 0x0c, 0xbd, 0xbc, 0x8b, 0x48, 0xc8, 0x2e, 0x34, 0xa2,
    	0x58, 0x7a, 0x77, 0xf1, 0x34, 0x0a, 0x4c, 0x76, 0x3b, 0x8a, 0xe5, 0xef, 0xca, 0xa6, 0x0c, 0xec,
    	0x1b, 0x5f, 0x88, 0x59, 0xcc, 0x03, 0x32, 0x80, 0x0d, 0x7c, 0xf2, 0x59, 0x68, 0xf8, 0x52, 0x43,
    	0x89, 0xf7, 0xe0, 0x8b, 0x07, 0x7d, 0xb1, 0x96, 0xab, 0xbf, 0xc9, 0x10, 0xec, 0xa9, 0x40, 0xae,
    	0x45, 0xb5, 0xb4, 0xf3, 0xc2, 0x26, 0xdb, 0x50, 0x57, 0xdf, 0x1e, 0x0b, 0x9c, 0x6a, 0xfa, 0xce,
    	0xca, 0xbc, 0x0e, 0xe8, 0x39, 0xf4, 0x53, 0x79, 0xe6, 0x09, 0x55, 0x01, 0x47, 0x60, 0x27, 0xc6,
    	0x34, 0xd2, 0xb6, 0x75, 0xe9, 0x0b, 0x9f, 0xc5, 0x31, 0x3d, 0x03, 0x52, 0x8c, 0x7f, 0xb3, 0xc0,
    	0xf4, 0x1e, 0xfa, 0xe3, 0x24, 0x28, 0x24, 0x5f, 0x5d, 0xf0, 0x0e, 0xd8, 0x11, 0xce, 0xbc, 0x4c,
    	0xd1, 0xf5, 0x08, 0x67, 0x57, 0xaa, 0xee, 0x7d, 0x68, 0xa9, 0xa3, 0x42, 0xed, 0xcd, 0x08, 0x67,
    	0x63, 0x03, 0xd1, 0x13, 0x20, 0xc5, 0x44, 0xeb, 0xde, 0xe0, 0x08, 0xfa, 0xe9, 0xa3, 0xad, 0xbd,
    	0x9b, 0x62, 0x2f, 0xba, 0xae, 0x63, 0xef, 0x43, 0xf7, 0x4f, 0x26, 0x64, 0x86, 0x9b, 0xfe, 0x04,
    	0xbd, 0x3c, 0x24, 0x12, 0xf2, 0x35, 0x34, 0xe6, 0x4a, 0x2b, 0x09, 0xad, 0xe5, 0x97, 0x78, 0x3d,
    	0xa7, 0x2d, 0x80, 0x7f, 0x90, 0x0b, 0x16, 0x47, 0x8a, 0xee, 0x7b, 0x68, 0x2e, 0x2c, 0x91, 0xa4,
    	0x73, 0xce, 0x9f, 0x91, 0x9b, 0xab, 0x1b, 0x8b, 0xf4, 0x40, 0x6d, 0x08, 0x2d, 0xe9, 0x86, 0xab,
    	0x97, 0xc5, 0x3b, 0xe8, 0xba, 0x78, 0xc7, 0x51, 0x3c, 0xfc, 0x1d, 0x3f, 0x62, 0xe4, 0xe2, 0xdd,
    	0xd2, 0xd2, 0xd8, 0x85, 0x46, 0xda, 0xfd, 0xaa, 0x9f, 0xd2, 0xbd, 0x61, 0xa7, 0xc0, 0x75, 0x40,
    	0xbe, 0x04, 0x98, 0xe8, 0x8e, 0x08, 0x3c, 0x5f, 0xea, 0x99, 0xb7, 0xdc, 0x86, 0x41, 0x7e, 0x91,
    	0x2a, 0x36, 0xf4, 0x85, 0x54, 0xcf, 0x15, 0xe8, 0xd9, 0xb7, 0x5c, 0x5b, 0x01, 0x63, 0x81, 0x4a,
    	0xf4, 0x8e, 0xd2, 0xc0, 0xe4, 0x57, 0x8a, 0x67, 0x1a, 0xb7, 0x9c, 0x6b, 0xdc, 0xbf, 0x52, 0x05,
    	0x17, 0xae, 0x22, 0x21, 0x67, 0xd0, 0xe1, 0xa9, 0xe9, 0x49, 0x75, 0xf5, 0xb9, 0x64, 0x03, 0x2d,
    	0x59, 0xa1, 0x28, 0xb7, 0xcd, 0x33, 0x80, 0xa0, 0x57, 0xd0, 0x73, 0xf1, 0x39, 0x7e, 0xc4, 0x37,
    	0x24, 0xff, 0xac, 0x00, 0xf4, 0x1b, 0xe8, 0x17, 0x98, 0xd6, 0x74, 0xc3, 0xe9, 0x87, 0x2a, 0x58,
    	0x97, 0xf8, 0x42, 0x7e, 0x84, 0x56, 0x76, 0x57, 0x91, 0xf4, 0xe2, 0x85, 0xb5, 0x37, 0xdc, 0x5c,
    	0x81, 0x8a, 0x84, 0x96, 0x54, 0x78, 0x76, 0xcf, 0x98, 0xf0, 0xc2, 0x76, 0x32, 0xe1, 0xc5, 0x85,
    	0x44, 0x4b, 0xe4, 0x02, 0x3a, 0xf9, 0x51, 0x26, 0x5b, 0x99, 0x4c, 0x99, 0x56, 0x1d, 0x6e, 0xaf,
    	0xc4, 0xe7, 0x24, 0xf9, 0x49, 0x33, 0x24, 0x4b, 0x73, 0x6e, 0x48, 0x96, 0xc7, 0x32, 0x25, 0xc9,
    	0x0f, 0x94, 0x21, 0x59, 0x1a, 0x48, 0x43, 0xb2, 0x3c, 0x7d, 0xb4, 0x44, 0xce, 0xa1, 0x9d, 0x9d,
    	0x27, 0x61, 0xe4, 0x28, 0x8c, 0x9d, 0x91, 0xa3, 0x38, 0x79, 0xb4, 0x44, 0x4e, 0x00, 0xfe, 0x40,
    	0x69, 0x66, 0x88, 0x74, 0xb5, 0xdb, 0xeb, 0x7c, 0x0d, 0x7b, 0x79, 0x40, 0x87, 0xfc, 0x00, 0xcd,
    	0x4c, 0x4f, 0x92, 0x2f, 0x16, 0xd4, 0xaf, 0x3d, 0x35, 0x1c, 0x2c, 0x83, 0x3a, 0xf6, 0x67, 0x68,
    	0xe7, 0xba, 0x86, 0x6c, 0x9a, 0xae, 0xcd, 0xf7, 0xe4, 0x70, 0x6b, 0x15, 0xac, 0x18, 0x7e, 0x1d,
    	0x00, 0x99, 0xc4, 0x4f, 0xa3, 0x49, 0xcc, 0x31, 0x16, 0xa3, 0x00, 0x5f, 0x94, 0xe7, 0x6d, 0x4d,
    	0xff, 0x07, 0x7c, 0xfb, 0x31, 0x00, 0x00, 0xff, 0xff, 0xbd, 0x6a, 0x64, 0xe2, 0x18, 0x08, 0x00,
    	0x00,