2019-02-08 11:59:06 +01:00
|
|
|
package clientconfig
|
|
|
|
|
|
|
|
// PublicClouds represents a collection of PublicCloud entries in clouds-public.yaml file.
|
|
|
|
// The format of the clouds-public.yml is documented at
|
|
|
|
// https://docs.openstack.org/python-openstackclient/latest/configuration/
|
|
|
|
type PublicClouds struct {
|
|
|
|
Clouds map[string]Cloud `yaml:"public-clouds" json:"public-clouds"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clouds represents a collection of Cloud entries in a clouds.yaml file.
|
|
|
|
// The format of clouds.yaml is documented at
|
|
|
|
// https://docs.openstack.org/os-client-config/latest/user/configuration.html.
|
|
|
|
type Clouds struct {
|
|
|
|
Clouds map[string]Cloud `yaml:"clouds" json:"clouds"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Cloud represents an entry in a clouds.yaml/public-clouds.yaml/secure.yaml file.
|
|
|
|
type Cloud struct {
|
2020-04-25 08:41:54 +02:00
|
|
|
Cloud string `yaml:"cloud,omitempty" json:"cloud,omitempty"`
|
|
|
|
Profile string `yaml:"profile,omitempty" json:"profile,omitempty"`
|
|
|
|
AuthInfo *AuthInfo `yaml:"auth,omitempty" json:"auth,omitempty"`
|
|
|
|
AuthType AuthType `yaml:"auth_type,omitempty" json:"auth_type,omitempty"`
|
|
|
|
RegionName string `yaml:"region_name,omitempty" json:"region_name,omitempty"`
|
|
|
|
Regions []interface{} `yaml:"regions,omitempty" json:"regions,omitempty"`
|
|
|
|
|
|
|
|
// EndpointType and Interface both specify whether to use the public, internal,
|
|
|
|
// or admin interface of a service. They should be considered synonymous, but
|
|
|
|
// EndpointType will take precedence when both are specified.
|
|
|
|
EndpointType string `yaml:"endpoint_type,omitempty" json:"endpoint_type,omitempty"`
|
|
|
|
Interface string `yaml:"interface,omitempty" json:"interface,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// API Version overrides.
|
2020-04-25 08:41:54 +02:00
|
|
|
IdentityAPIVersion string `yaml:"identity_api_version,omitempty" json:"identity_api_version,omitempty"`
|
|
|
|
VolumeAPIVersion string `yaml:"volume_api_version,omitempty" json:"volume_api_version,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Verify whether or not SSL API requests should be verified.
|
2020-04-25 08:41:54 +02:00
|
|
|
Verify *bool `yaml:"verify,omitempty" json:"verify,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// CACertFile a path to a CA Cert bundle that can be used as part of
|
|
|
|
// verifying SSL API requests.
|
2020-04-25 08:41:54 +02:00
|
|
|
CACertFile string `yaml:"cacert,omitempty" json:"cacert,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// ClientCertFile a path to a client certificate to use as part of the SSL
|
|
|
|
// transaction.
|
2020-04-25 08:41:54 +02:00
|
|
|
ClientCertFile string `yaml:"cert,omitempty" json:"cert,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// ClientKeyFile a path to a client key to use as part of the SSL
|
|
|
|
// transaction.
|
2020-04-25 08:41:54 +02:00
|
|
|
ClientKeyFile string `yaml:"key,omitempty" json:"key,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// AuthInfo represents the auth section of a cloud entry or
|
|
|
|
// auth options entered explicitly in ClientOpts.
|
|
|
|
type AuthInfo struct {
|
|
|
|
// AuthURL is the keystone/identity endpoint URL.
|
2020-04-25 08:41:54 +02:00
|
|
|
AuthURL string `yaml:"auth_url,omitempty" json:"auth_url,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Token is a pre-generated authentication token.
|
2020-04-25 08:41:54 +02:00
|
|
|
Token string `yaml:"token,omitempty" json:"token,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Username is the username of the user.
|
2020-04-25 08:41:54 +02:00
|
|
|
Username string `yaml:"username,omitempty" json:"username,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// UserID is the unique ID of a user.
|
2020-04-25 08:41:54 +02:00
|
|
|
UserID string `yaml:"user_id,omitempty" json:"user_id,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Password is the password of the user.
|
2020-04-25 08:41:54 +02:00
|
|
|
Password string `yaml:"password,omitempty" json:"password,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Application Credential ID to login with.
|
2020-04-25 08:41:54 +02:00
|
|
|
ApplicationCredentialID string `yaml:"application_credential_id,omitempty" json:"application_credential_id,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Application Credential name to login with.
|
2020-04-25 08:41:54 +02:00
|
|
|
ApplicationCredentialName string `yaml:"application_credential_name,omitempty" json:"application_credential_name,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// Application Credential secret to login with.
|
2020-04-25 08:41:54 +02:00
|
|
|
ApplicationCredentialSecret string `yaml:"application_credential_secret,omitempty" json:"application_credential_secret,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// ProjectName is the common/human-readable name of a project.
|
|
|
|
// Users can be scoped to a project.
|
|
|
|
// ProjectName on its own is not enough to ensure a unique scope. It must
|
|
|
|
// also be combined with either a ProjectDomainName or ProjectDomainID.
|
|
|
|
// ProjectName cannot be combined with ProjectID in a scope.
|
2020-04-25 08:41:54 +02:00
|
|
|
ProjectName string `yaml:"project_name,omitempty" json:"project_name,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// ProjectID is the unique ID of a project.
|
|
|
|
// It can be used to scope a user to a specific project.
|
2020-04-25 08:41:54 +02:00
|
|
|
ProjectID string `yaml:"project_id,omitempty" json:"project_id,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// UserDomainName is the name of the domain where a user resides.
|
|
|
|
// It is used to identify the source domain of a user.
|
2020-04-25 08:41:54 +02:00
|
|
|
UserDomainName string `yaml:"user_domain_name,omitempty" json:"user_domain_name,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// UserDomainID is the unique ID of the domain where a user resides.
|
|
|
|
// It is used to identify the source domain of a user.
|
2020-04-25 08:41:54 +02:00
|
|
|
UserDomainID string `yaml:"user_domain_id,omitempty" json:"user_domain_id,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// ProjectDomainName is the name of the domain where a project resides.
|
|
|
|
// It is used to identify the source domain of a project.
|
|
|
|
// ProjectDomainName can be used in addition to a ProjectName when scoping
|
|
|
|
// a user to a specific project.
|
2020-04-25 08:41:54 +02:00
|
|
|
ProjectDomainName string `yaml:"project_domain_name,omitempty" json:"project_domain_name,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// ProjectDomainID is the name of the domain where a project resides.
|
|
|
|
// It is used to identify the source domain of a project.
|
|
|
|
// ProjectDomainID can be used in addition to a ProjectName when scoping
|
|
|
|
// a user to a specific project.
|
2020-04-25 08:41:54 +02:00
|
|
|
ProjectDomainID string `yaml:"project_domain_id,omitempty" json:"project_domain_id,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// DomainName is the name of a domain which can be used to identify the
|
|
|
|
// source domain of either a user or a project.
|
|
|
|
// If UserDomainName and ProjectDomainName are not specified, then DomainName
|
|
|
|
// is used as a default choice.
|
|
|
|
// It can also be used be used to specify a domain-only scope.
|
2020-04-25 08:41:54 +02:00
|
|
|
DomainName string `yaml:"domain_name,omitempty" json:"domain_name,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// DomainID is the unique ID of a domain which can be used to identify the
|
|
|
|
// source domain of eitehr a user or a project.
|
|
|
|
// If UserDomainID and ProjectDomainID are not specified, then DomainID is
|
|
|
|
// used as a default choice.
|
|
|
|
// It can also be used be used to specify a domain-only scope.
|
2020-04-25 08:41:54 +02:00
|
|
|
DomainID string `yaml:"domain_id,omitempty" json:"domain_id,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
|
|
|
|
// DefaultDomain is the domain ID to fall back on if no other domain has
|
|
|
|
// been specified and a domain is required for scope.
|
2020-04-25 08:41:54 +02:00
|
|
|
DefaultDomain string `yaml:"default_domain,omitempty" json:"default_domain,omitempty"`
|
2019-02-08 11:59:06 +01:00
|
|
|
}
|