Documentation ¶
Index ¶
- func ZTSSchema() *rdl.Schema
- type AWSCertificateRequest
- type AWSInstanceInformation
- type AWSTemporaryCredentials
- type Access
- type ActionName
- type Assertion
- type AssertionEffect
- type AuthorityName
- type CompoundName
- type DomainMetric
- type DomainMetricType
- type DomainMetrics
- type DomainName
- type DomainSignedPolicyData
- type EntityName
- type HostServices
- type Identity
- type InstanceInformation
- type InstanceRefreshRequest
- type LocationName
- type Policy
- type PolicyData
- type PublicKeyEntry
- type ResourceName
- type RoleAccess
- type RoleCertificateRequest
- type RoleToken
- type ServiceIdentity
- type ServiceIdentityList
- type ServiceName
- type SignedPolicyData
- type SignedToken
- type SimpleName
- type TenantDomains
- type YBase64
- type YEncoded
- type YRN
- type ZTSClient
- func (client *ZTSClient) AddCredentials(header string, token string)
- func (client ZTSClient) GetAWSTemporaryCredentials(domainName DomainName, role CompoundName) (*AWSTemporaryCredentials, error)
- func (client ZTSClient) GetAccess(domainName DomainName, roleName EntityName, principal EntityName) (*Access, error)
- func (client ZTSClient) GetDomainSignedPolicyData(domainName DomainName, matchingTag string) (*DomainSignedPolicyData, string, error)
- func (client ZTSClient) GetHostServices(host string) (*HostServices, error)
- func (client ZTSClient) GetPublicKeyEntry(domainName DomainName, serviceName SimpleName, keyId string) (*PublicKeyEntry, error)
- func (client ZTSClient) GetRoleAccess(domainName DomainName, principal EntityName) (*RoleAccess, error)
- func (client ZTSClient) GetRoleToken(domainName DomainName, role EntityName, minExpiryTime *int32, ...) (*RoleToken, error)
- func (client ZTSClient) GetServiceIdentity(domainName DomainName, serviceName ServiceName) (*ServiceIdentity, error)
- func (client ZTSClient) GetServiceIdentityList(domainName DomainName) (*ServiceIdentityList, error)
- func (client ZTSClient) GetTenantDomains(providerDomainName DomainName, userName EntityName, roleName EntityName, ...) (*TenantDomains, error)
- func (client ZTSClient) PostAWSCertificateRequest(domain CompoundName, service SimpleName, req *AWSCertificateRequest) (*Identity, error)
- func (client ZTSClient) PostAWSInstanceInformation(info *AWSInstanceInformation) (*Identity, error)
- func (client ZTSClient) PostDomainMetrics(domainName DomainName, req *DomainMetrics) (*DomainMetrics, error)
- func (client ZTSClient) PostInstanceInformation(info *InstanceInformation) (*Identity, error)
- func (client ZTSClient) PostInstanceRefreshRequest(domain CompoundName, service SimpleName, req *InstanceRefreshRequest) (*Identity, error)
- func (client ZTSClient) PostRoleCertificateRequest(domainName DomainName, roleName EntityName, req *RoleCertificateRequest) (*RoleToken, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type AWSCertificateRequest ¶
type AWSCertificateRequest struct {
Csr string `json:"csr"`
}
AWSCertificateRequest - AWSCertificateRequest - a certificate signing request
func NewAWSCertificateRequest ¶
func NewAWSCertificateRequest(init ...*AWSCertificateRequest) *AWSCertificateRequest
NewAWSCertificateRequest - creates an initialized AWSCertificateRequest instance, returns a pointer to it
func (*AWSCertificateRequest) UnmarshalJSON ¶
func (pTypeDef *AWSCertificateRequest) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a AWSCertificateRequest
func (*AWSCertificateRequest) Validate ¶
func (pTypeDef *AWSCertificateRequest) Validate() error
Validate - checks for missing required fields, etc
type AWSInstanceInformation ¶
type AWSInstanceInformation struct { // // signed document containing attributes like IP address, instance-id, // account#, etc. // Document string `json:"document"` // // the signature for the document // Signature string `json:"signature"` // // the domain of the instance // Domain CompoundName `json:"domain"` // // the service this instance is supposed to run // Service SimpleName `json:"service"` // // return a certificate in the response // Csr string `json:"csr"` // // the full service identity name (same as the EC2 instance profile name) // Name CompoundName `json:"name"` // // the account id (as a string) for the instance. parsed from the instance // profile ARN // Account SimpleName `json:"account"` // // the name of the cloud (namespace) within the account, parsed from the name // Cloud SimpleName `json:"cloud,omitempty" rdl:"optional"` // // the name of the subnet this instance is expected to be running in, parsed // from the name // Subnet SimpleName `json:"subnet"` // // the AWS Access Key Id for the role // Access string `json:"access"` // // the AWS Secret Access Key for the role // Secret string `json:"secret"` // // the AWS STS Token for the role // Token string `json:"token"` // // the expiration time of the access keys // Expires rdl.Timestamp `json:"expires"` // // the modified time of the access keys // Modified rdl.Timestamp `json:"modified"` // // the 'flavor' of the access keys, i.e. "AWS-HMAC" // Flavor string `json:"flavor"` }
AWSInstanceInformation - AWSInstanceInformation - the information a booting EC2 instance must provide to ZTS to authenticate.
func NewAWSInstanceInformation ¶
func NewAWSInstanceInformation(init ...*AWSInstanceInformation) *AWSInstanceInformation
NewAWSInstanceInformation - creates an initialized AWSInstanceInformation instance, returns a pointer to it
func (*AWSInstanceInformation) UnmarshalJSON ¶
func (pTypeDef *AWSInstanceInformation) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a AWSInstanceInformation
func (*AWSInstanceInformation) Validate ¶
func (pTypeDef *AWSInstanceInformation) Validate() error
Validate - checks for missing required fields, etc
type AWSTemporaryCredentials ¶
type AWSTemporaryCredentials struct { AccessKeyId string `json:"accessKeyId"` SecretAccessKey string `json:"secretAccessKey"` SessionToken string `json:"sessionToken"` Expiration rdl.Timestamp `json:"expiration"` }
AWSTemporaryCredentials -
func NewAWSTemporaryCredentials ¶
func NewAWSTemporaryCredentials(init ...*AWSTemporaryCredentials) *AWSTemporaryCredentials
NewAWSTemporaryCredentials - creates an initialized AWSTemporaryCredentials instance, returns a pointer to it
func (*AWSTemporaryCredentials) UnmarshalJSON ¶
func (pTypeDef *AWSTemporaryCredentials) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a AWSTemporaryCredentials
func (*AWSTemporaryCredentials) Validate ¶
func (pTypeDef *AWSTemporaryCredentials) Validate() error
Validate - checks for missing required fields, etc
type Access ¶
type Access struct { // // true (allowed) or false (denied) // Granted bool `json:"granted"` }
Access - Access can be checked and returned as this resource.
func (*Access) UnmarshalJSON ¶
UnmarshalJSON is defined for proper JSON decoding of a Access
type Assertion ¶
type Assertion struct { // // the subject of the assertion, a role // Role string `json:"role"` // // the object of the assertion. Must be in the local namespace. Can contain // wildcards // Resource string `json:"resource"` // // the predicate of the assertion. Can contain wildcards // Action string `json:"action"` // // the effect of the assertion in the policy language // Effect *AssertionEffect `json:"effect,omitempty" rdl:"optional"` // // assertion id - auto generated by server // Id *int64 `json:"id,omitempty" rdl:"optional"` }
Assertion - A representation for the encapsulation of an action to be performed on a resource by a principal.
func NewAssertion ¶
NewAssertion - creates an initialized Assertion instance, returns a pointer to it
func (*Assertion) UnmarshalJSON ¶
UnmarshalJSON is defined for proper JSON decoding of a Assertion
type AssertionEffect ¶
type AssertionEffect int
AssertionEffect - Every assertion can have the effect of ALLOW or DENY.
const ( ALLOW AssertionEffect DENY )
AssertionEffect constants
func NewAssertionEffect ¶
func NewAssertionEffect(init ...interface{}) AssertionEffect
NewAssertionEffect - return a string representation of the enum
func (AssertionEffect) MarshalJSON ¶
func (e AssertionEffect) MarshalJSON() ([]byte, error)
MarshalJSON is defined for proper JSON encoding of a AssertionEffect
func (AssertionEffect) String ¶
func (e AssertionEffect) String() string
String - return a string representation of the enum
func (AssertionEffect) SymbolSet ¶
func (e AssertionEffect) SymbolSet() []string
SymbolSet - return an array of all valid string representations (symbols) of the enum
func (*AssertionEffect) UnmarshalJSON ¶
func (e *AssertionEffect) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a AssertionEffect
type AuthorityName ¶
type AuthorityName string
AuthorityName - Used as the prefix in a signed assertion. This uniquely identifies a signing authority.
type CompoundName ¶
type CompoundName string
CompoundName - A compound name. Most names in this API are compound names.
type DomainMetric ¶
type DomainMetric struct { MetricType DomainMetricType `json:"metricType"` MetricVal int32 `json:"metricVal"` }
DomainMetric -
func NewDomainMetric ¶
func NewDomainMetric(init ...*DomainMetric) *DomainMetric
NewDomainMetric - creates an initialized DomainMetric instance, returns a pointer to it
func (*DomainMetric) UnmarshalJSON ¶
func (pTypeDef *DomainMetric) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a DomainMetric
func (*DomainMetric) Validate ¶
func (pTypeDef *DomainMetric) Validate() error
Validate - checks for missing required fields, etc
type DomainMetricType ¶
type DomainMetricType int
DomainMetricType - zpe metric attributes
const ( ACCESS_ALLOWED DomainMetricType ACCESS_ALLOWED_DENY ACCESS_ALLOWED_DENY_NO_MATCH ACCESS_ALLOWED_ALLOW ACCESS_ALLOWED_ERROR ACCESS_ALLOWED_TOKEN_INVALID ACCESS_Allowed_TOKEN_EXPIRED ACCESS_ALLOWED_DOMAIN_NOT_FOUND ACCESS_ALLOWED_DOMAIN_MISMATCH ACCESS_ALLOWED_DOMAIN_EXPIRED ACCESS_ALLOWED_DOMAIN_EMPTY ACCESS_ALLOWED_TOKEN_CACHE_FAILURE ACCESS_ALLOWED_TOKEN_CACHE_NOT_FOUND ACCESS_ALLOWED_TOKEN_CACHE_SUCCESS ACCESS_ALLOWED_TOKEN_VALIDATE LOAD_FILE_FAIL LOAD_FILE_GOOD LOAD_DOMAIN_GOOD )
DomainMetricType constants
func NewDomainMetricType ¶
func NewDomainMetricType(init ...interface{}) DomainMetricType
NewDomainMetricType - return a string representation of the enum
func (DomainMetricType) MarshalJSON ¶
func (e DomainMetricType) MarshalJSON() ([]byte, error)
MarshalJSON is defined for proper JSON encoding of a DomainMetricType
func (DomainMetricType) String ¶
func (e DomainMetricType) String() string
String - return a string representation of the enum
func (DomainMetricType) SymbolSet ¶
func (e DomainMetricType) SymbolSet() []string
SymbolSet - return an array of all valid string representations (symbols) of the enum
func (*DomainMetricType) UnmarshalJSON ¶
func (e *DomainMetricType) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a DomainMetricType
type DomainMetrics ¶
type DomainMetrics struct { // // name of the domain the metrics pertain to // DomainName DomainName `json:"domainName"` // // list of the domains metrics // MetricList []*DomainMetric `json:"metricList"` }
DomainMetrics -
func NewDomainMetrics ¶
func NewDomainMetrics(init ...*DomainMetrics) *DomainMetrics
NewDomainMetrics - creates an initialized DomainMetrics instance, returns a pointer to it
func (*DomainMetrics) Init ¶
func (pTypeDef *DomainMetrics) Init() *DomainMetrics
Init - sets up the instance according to its default field values, if any
func (*DomainMetrics) UnmarshalJSON ¶
func (pTypeDef *DomainMetrics) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a DomainMetrics
func (*DomainMetrics) Validate ¶
func (pTypeDef *DomainMetrics) Validate() error
Validate - checks for missing required fields, etc
type DomainName ¶
type DomainName string
DomainName - A domain name is the general qualifier prefix, as its uniqueness is managed.
type DomainSignedPolicyData ¶
type DomainSignedPolicyData struct { // // policy data signed by ZMS // SignedPolicyData *SignedPolicyData `json:"signedPolicyData"` // // signature generated based on the domain policies object // Signature string `json:"signature"` // // the identifier of the key used to generate the signature // KeyId string `json:"keyId"` }
DomainSignedPolicyData - A signed bulk transfer of policies. The data is signed with server's private key.
func NewDomainSignedPolicyData ¶
func NewDomainSignedPolicyData(init ...*DomainSignedPolicyData) *DomainSignedPolicyData
NewDomainSignedPolicyData - creates an initialized DomainSignedPolicyData instance, returns a pointer to it
func (*DomainSignedPolicyData) Init ¶
func (pTypeDef *DomainSignedPolicyData) Init() *DomainSignedPolicyData
Init - sets up the instance according to its default field values, if any
func (*DomainSignedPolicyData) UnmarshalJSON ¶
func (pTypeDef *DomainSignedPolicyData) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a DomainSignedPolicyData
func (*DomainSignedPolicyData) Validate ¶
func (pTypeDef *DomainSignedPolicyData) Validate() error
Validate - checks for missing required fields, etc
type EntityName ¶
type EntityName string
EntityName - An entity name is a short form of a resource name, including only the domain and entity.
type HostServices ¶
type HostServices struct { // // name of the host // Host string `json:"host"` // // list of service names authorized to run on this host // Names []EntityName `json:"names"` }
HostServices - The representation for an enumeration of services authorized to run on a specific host.
func NewHostServices ¶
func NewHostServices(init ...*HostServices) *HostServices
NewHostServices - creates an initialized HostServices instance, returns a pointer to it
func (*HostServices) Init ¶
func (pTypeDef *HostServices) Init() *HostServices
Init - sets up the instance according to its default field values, if any
func (*HostServices) UnmarshalJSON ¶
func (pTypeDef *HostServices) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a HostServices
func (*HostServices) Validate ¶
func (pTypeDef *HostServices) Validate() error
Validate - checks for missing required fields, etc
type Identity ¶
type Identity struct { // // name of the identity, fully qualified, i.e. my.domain.service1, or // aws.1232321321312.myusername // Name CompoundName `json:"name"` // // a certificate usable for both client and server in TLS connections // Certificate string `json:"certificate,omitempty" rdl:"optional"` // // the CA certificate chain to use with all IMS-generated certs // CaCertBundle string `json:"caCertBundle,omitempty" rdl:"optional"` // // the SSH server cert, signed by the CA // SshServerCert string `json:"sshServerCert,omitempty" rdl:"optional"` // // service token instead of TLS certificate // ServiceToken SignedToken `json:"serviceToken,omitempty" rdl:"optional"` // // other config-like attributes determined at boot time // Attributes map[string]string `json:"attributes,omitempty" rdl:"optional"` }
Identity - Identity - a signed assertion of service or human identity, the response could be either a client certificate or just a regular NToken (depending if the request contained a csr or not).
func NewIdentity ¶
NewIdentity - creates an initialized Identity instance, returns a pointer to it
func (*Identity) UnmarshalJSON ¶
UnmarshalJSON is defined for proper JSON decoding of a Identity
type InstanceInformation ¶
type InstanceInformation struct { // // signed document containing attributes like IP address, instance-id, // account#, etc. // Document string `json:"document"` // // the signature for the document // Signature string `json:"signature"` // // the keyid used to sign the document // KeyId string `json:"keyId"` // // the domain of the instance // Domain CompoundName `json:"domain"` // // the service this instance is supposed to run // Service SimpleName `json:"service"` // // return a certificate in the response // Csr string `json:"csr"` }
InstanceInformation - Instance object that includes requested service details plus host document that is signed by provider as part of the host bootstrap process
func NewInstanceInformation ¶
func NewInstanceInformation(init ...*InstanceInformation) *InstanceInformation
NewInstanceInformation - creates an initialized InstanceInformation instance, returns a pointer to it
func (*InstanceInformation) UnmarshalJSON ¶
func (pTypeDef *InstanceInformation) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a InstanceInformation
func (*InstanceInformation) Validate ¶
func (pTypeDef *InstanceInformation) Validate() error
Validate - checks for missing required fields, etc
type InstanceRefreshRequest ¶
type InstanceRefreshRequest struct { // // Cert CSR if requesting TLS certificate // Csr string `json:"csr"` // // in seconds how long token should be valid for // ExpiryTime *int32 `json:"expiryTime,omitempty" rdl:"optional"` }
InstanceRefreshRequest - InstanceRefreshRequest - a certificate refresh request
func NewInstanceRefreshRequest ¶
func NewInstanceRefreshRequest(init ...*InstanceRefreshRequest) *InstanceRefreshRequest
NewInstanceRefreshRequest - creates an initialized InstanceRefreshRequest instance, returns a pointer to it
func (*InstanceRefreshRequest) UnmarshalJSON ¶
func (pTypeDef *InstanceRefreshRequest) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a InstanceRefreshRequest
func (*InstanceRefreshRequest) Validate ¶
func (pTypeDef *InstanceRefreshRequest) Validate() error
Validate - checks for missing required fields, etc
type LocationName ¶
type LocationName string
LocationName - A location name is not yet defined, but will be a dotted name like everything else.
type Policy ¶
type Policy struct { // // name of the policy // Name ResourceName `json:"name"` // // last modification timestamp of this policy // Modified *rdl.Timestamp `json:"modified,omitempty" rdl:"optional"` // // list of defined assertions for this policy // Assertions []*Assertion `json:"assertions"` }
Policy - The representation for a Policy with set of assertions.
func (*Policy) UnmarshalJSON ¶
UnmarshalJSON is defined for proper JSON decoding of a Policy
type PolicyData ¶
type PolicyData struct { // // name of the domain // Domain DomainName `json:"domain"` // // list of policies defined in this server // Policies []*Policy `json:"policies"` }
PolicyData -
func NewPolicyData ¶
func NewPolicyData(init ...*PolicyData) *PolicyData
NewPolicyData - creates an initialized PolicyData instance, returns a pointer to it
func (*PolicyData) Init ¶
func (pTypeDef *PolicyData) Init() *PolicyData
Init - sets up the instance according to its default field values, if any
func (*PolicyData) UnmarshalJSON ¶
func (pTypeDef *PolicyData) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a PolicyData
func (*PolicyData) Validate ¶
func (pTypeDef *PolicyData) Validate() error
Validate - checks for missing required fields, etc
type PublicKeyEntry ¶
type PublicKeyEntry struct { // // the public key for the service // Key string `json:"key"` // // the key identifier (version or zone name) // Id string `json:"id"` }
PublicKeyEntry - The representation of the public key in a service identity object.
func NewPublicKeyEntry ¶
func NewPublicKeyEntry(init ...*PublicKeyEntry) *PublicKeyEntry
NewPublicKeyEntry - creates an initialized PublicKeyEntry instance, returns a pointer to it
func (*PublicKeyEntry) UnmarshalJSON ¶
func (pTypeDef *PublicKeyEntry) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a PublicKeyEntry
func (*PublicKeyEntry) Validate ¶
func (pTypeDef *PublicKeyEntry) Validate() error
Validate - checks for missing required fields, etc
type ResourceName ¶
type ResourceName string
ResourceName - A shorthand for a YRN with no service or location. The 'tail' of a YRN, just the domain:entity. Note that the EntityName part is optional, that is, a domain name followed by a colon is valid resource name.
type RoleAccess ¶
type RoleAccess struct {
Roles []EntityName `json:"roles"`
}
RoleAccess -
func NewRoleAccess ¶
func NewRoleAccess(init ...*RoleAccess) *RoleAccess
NewRoleAccess - creates an initialized RoleAccess instance, returns a pointer to it
func (*RoleAccess) Init ¶
func (pTypeDef *RoleAccess) Init() *RoleAccess
Init - sets up the instance according to its default field values, if any
func (*RoleAccess) UnmarshalJSON ¶
func (pTypeDef *RoleAccess) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a RoleAccess
func (*RoleAccess) Validate ¶
func (pTypeDef *RoleAccess) Validate() error
Validate - checks for missing required fields, etc
type RoleCertificateRequest ¶
RoleCertificateRequest - RoleCertificateRequest - a certificate signing request
func NewRoleCertificateRequest ¶
func NewRoleCertificateRequest(init ...*RoleCertificateRequest) *RoleCertificateRequest
NewRoleCertificateRequest - creates an initialized RoleCertificateRequest instance, returns a pointer to it
func (*RoleCertificateRequest) UnmarshalJSON ¶
func (pTypeDef *RoleCertificateRequest) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a RoleCertificateRequest
func (*RoleCertificateRequest) Validate ¶
func (pTypeDef *RoleCertificateRequest) Validate() error
Validate - checks for missing required fields, etc
type RoleToken ¶
RoleToken - A representation of a signed RoleToken
func NewRoleToken ¶
NewRoleToken - creates an initialized RoleToken instance, returns a pointer to it
func (*RoleToken) UnmarshalJSON ¶
UnmarshalJSON is defined for proper JSON decoding of a RoleToken
type ServiceIdentity ¶
type ServiceIdentity struct { // // the full name of the service, i.e. "sports.storage" // Name ServiceName `json:"name"` // // array of public keys for key rotation // PublicKeys []*PublicKeyEntry `json:"publicKeys,omitempty" rdl:"optional"` // // if present, then this service can provision tenants via this endpoint. // ProviderEndpoint string `json:"providerEndpoint,omitempty" rdl:"optional"` // // the timestamp when this entry was last modified // Modified *rdl.Timestamp `json:"modified,omitempty" rdl:"optional"` // // the path of the executable that runs the service // Executable string `json:"executable,omitempty" rdl:"optional"` // // list of host names that this service can run on // Hosts []string `json:"hosts,omitempty" rdl:"optional"` // // local (unix) user name this service can run as // User string `json:"user,omitempty" rdl:"optional"` // // local (unix) group name this service can run as // Group string `json:"group,omitempty" rdl:"optional"` }
ServiceIdentity - The representation of the service identity object.
func NewServiceIdentity ¶
func NewServiceIdentity(init ...*ServiceIdentity) *ServiceIdentity
NewServiceIdentity - creates an initialized ServiceIdentity instance, returns a pointer to it
func (*ServiceIdentity) UnmarshalJSON ¶
func (pTypeDef *ServiceIdentity) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a ServiceIdentity
func (*ServiceIdentity) Validate ¶
func (pTypeDef *ServiceIdentity) Validate() error
Validate - checks for missing required fields, etc
type ServiceIdentityList ¶
type ServiceIdentityList struct { // // list of service names // Names []EntityName `json:"names"` }
ServiceIdentityList - The representation for an enumeration of services in the namespace.
func NewServiceIdentityList ¶
func NewServiceIdentityList(init ...*ServiceIdentityList) *ServiceIdentityList
NewServiceIdentityList - creates an initialized ServiceIdentityList instance, returns a pointer to it
func (*ServiceIdentityList) Init ¶
func (pTypeDef *ServiceIdentityList) Init() *ServiceIdentityList
Init - sets up the instance according to its default field values, if any
func (*ServiceIdentityList) UnmarshalJSON ¶
func (pTypeDef *ServiceIdentityList) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a ServiceIdentityList
func (*ServiceIdentityList) Validate ¶
func (pTypeDef *ServiceIdentityList) Validate() error
Validate - checks for missing required fields, etc
type ServiceName ¶
type ServiceName string
ServiceName - A service name will generally be a unique subdomain.
type SignedPolicyData ¶
type SignedPolicyData struct { // // list of policies defined in a domain // PolicyData *PolicyData `json:"policyData"` // // zms signature generated based on the domain policies object // ZmsSignature string `json:"zmsSignature"` // // the identifier of the zms key used to generate the signature // ZmsKeyId string `json:"zmsKeyId"` // // when the domain itself was last modified // Modified rdl.Timestamp `json:"modified"` // // timestamp specifying the expiration time for using this set of policies // Expires rdl.Timestamp `json:"expires"` }
SignedPolicyData - A representation of policies object defined in a given server.
func NewSignedPolicyData ¶
func NewSignedPolicyData(init ...*SignedPolicyData) *SignedPolicyData
NewSignedPolicyData - creates an initialized SignedPolicyData instance, returns a pointer to it
func (*SignedPolicyData) Init ¶
func (pTypeDef *SignedPolicyData) Init() *SignedPolicyData
Init - sets up the instance according to its default field values, if any
func (*SignedPolicyData) UnmarshalJSON ¶
func (pTypeDef *SignedPolicyData) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a SignedPolicyData
func (*SignedPolicyData) Validate ¶
func (pTypeDef *SignedPolicyData) Validate() error
Validate - checks for missing required fields, etc
type SignedToken ¶
type SignedToken string
SignedToken - A signed assertion if identity. i.e. the user cookie value. This token will only make sense to the authority that generated it, so it is beneficial to have something in the value that is cheaply recognized to quickly reject if it belongs to another authority. In addition to the YEncoded set our token includes ; to separate components and , to separate roles
type SimpleName ¶
type SimpleName string
SimpleName - Copyright 2016 Yahoo Inc. Licensed under the terms of the Apache version 2.0 license. See LICENSE file for terms. Common name types used by several API definitions A simple identifier, an element of compound name.
type TenantDomains ¶
type TenantDomains struct {
TenantDomainNames []DomainName `json:"tenantDomainNames"`
}
TenantDomains -
func NewTenantDomains ¶
func NewTenantDomains(init ...*TenantDomains) *TenantDomains
NewTenantDomains - creates an initialized TenantDomains instance, returns a pointer to it
func (*TenantDomains) Init ¶
func (pTypeDef *TenantDomains) Init() *TenantDomains
Init - sets up the instance according to its default field values, if any
func (*TenantDomains) UnmarshalJSON ¶
func (pTypeDef *TenantDomains) UnmarshalJSON(b []byte) error
UnmarshalJSON is defined for proper JSON decoding of a TenantDomains
func (*TenantDomains) Validate ¶
func (pTypeDef *TenantDomains) Validate() error
Validate - checks for missing required fields, etc
type YEncoded ¶
type YEncoded string
YEncoded - YEncoded includes ybase64 chars, as well as = and %. This can represent a user cookie and URL-encoded values.
type ZTSClient ¶
type ZTSClient struct { URL string Transport http.RoundTripper CredsHeader *string CredsToken *string Timeout time.Duration }
func NewClient ¶
func NewClient(url string, transport http.RoundTripper) ZTSClient
NewClient creates and returns a new HTTP client object for the ZTS service
func (*ZTSClient) AddCredentials ¶
AddCredentials adds the credentials to the client for subsequent requests.
func (ZTSClient) GetAWSTemporaryCredentials ¶
func (client ZTSClient) GetAWSTemporaryCredentials(domainName DomainName, role CompoundName) (*AWSTemporaryCredentials, error)
func (ZTSClient) GetAccess ¶
func (client ZTSClient) GetAccess(domainName DomainName, roleName EntityName, principal EntityName) (*Access, error)
func (ZTSClient) GetDomainSignedPolicyData ¶
func (client ZTSClient) GetDomainSignedPolicyData(domainName DomainName, matchingTag string) (*DomainSignedPolicyData, string, error)
func (ZTSClient) GetHostServices ¶
func (client ZTSClient) GetHostServices(host string) (*HostServices, error)
func (ZTSClient) GetPublicKeyEntry ¶
func (client ZTSClient) GetPublicKeyEntry(domainName DomainName, serviceName SimpleName, keyId string) (*PublicKeyEntry, error)
func (ZTSClient) GetRoleAccess ¶
func (client ZTSClient) GetRoleAccess(domainName DomainName, principal EntityName) (*RoleAccess, error)
func (ZTSClient) GetRoleToken ¶
func (client ZTSClient) GetRoleToken(domainName DomainName, role EntityName, minExpiryTime *int32, maxExpiryTime *int32, proxyForPrincipal EntityName) (*RoleToken, error)
func (ZTSClient) GetServiceIdentity ¶
func (client ZTSClient) GetServiceIdentity(domainName DomainName, serviceName ServiceName) (*ServiceIdentity, error)
func (ZTSClient) GetServiceIdentityList ¶
func (client ZTSClient) GetServiceIdentityList(domainName DomainName) (*ServiceIdentityList, error)
func (ZTSClient) GetTenantDomains ¶
func (client ZTSClient) GetTenantDomains(providerDomainName DomainName, userName EntityName, roleName EntityName, serviceName ServiceName) (*TenantDomains, error)
func (ZTSClient) PostAWSCertificateRequest ¶
func (client ZTSClient) PostAWSCertificateRequest(domain CompoundName, service SimpleName, req *AWSCertificateRequest) (*Identity, error)
func (ZTSClient) PostAWSInstanceInformation ¶
func (client ZTSClient) PostAWSInstanceInformation(info *AWSInstanceInformation) (*Identity, error)
func (ZTSClient) PostDomainMetrics ¶
func (client ZTSClient) PostDomainMetrics(domainName DomainName, req *DomainMetrics) (*DomainMetrics, error)
func (ZTSClient) PostInstanceInformation ¶
func (client ZTSClient) PostInstanceInformation(info *InstanceInformation) (*Identity, error)
func (ZTSClient) PostInstanceRefreshRequest ¶
func (client ZTSClient) PostInstanceRefreshRequest(domain CompoundName, service SimpleName, req *InstanceRefreshRequest) (*Identity, error)
func (ZTSClient) PostRoleCertificateRequest ¶
func (client ZTSClient) PostRoleCertificateRequest(domainName DomainName, roleName EntityName, req *RoleCertificateRequest) (*RoleToken, error)