162 lines
4.8 KiB
Go
162 lines
4.8 KiB
Go
package client
|
|
|
|
const (
|
|
CERTIFICATE_TYPE = "certificate"
|
|
)
|
|
|
|
type Certificate struct {
|
|
Resource
|
|
|
|
AccountId string `json:"accountId,omitempty" yaml:"account_id,omitempty"`
|
|
|
|
Algorithm string `json:"algorithm,omitempty" yaml:"algorithm,omitempty"`
|
|
|
|
CN string `json:"cN,omitempty" yaml:"cn,omitempty"`
|
|
|
|
Cert string `json:"cert,omitempty" yaml:"cert,omitempty"`
|
|
|
|
CertChain string `json:"certChain,omitempty" yaml:"cert_chain,omitempty"`
|
|
|
|
CertFingerprint string `json:"certFingerprint,omitempty" yaml:"cert_fingerprint,omitempty"`
|
|
|
|
Created string `json:"created,omitempty" yaml:"created,omitempty"`
|
|
|
|
Data map[string]interface{} `json:"data,omitempty" yaml:"data,omitempty"`
|
|
|
|
Description string `json:"description,omitempty" yaml:"description,omitempty"`
|
|
|
|
ExpiresAt string `json:"expiresAt,omitempty" yaml:"expires_at,omitempty"`
|
|
|
|
IssuedAt string `json:"issuedAt,omitempty" yaml:"issued_at,omitempty"`
|
|
|
|
Issuer string `json:"issuer,omitempty" yaml:"issuer,omitempty"`
|
|
|
|
Key string `json:"key,omitempty" yaml:"key,omitempty"`
|
|
|
|
KeySize int64 `json:"keySize,omitempty" yaml:"key_size,omitempty"`
|
|
|
|
Kind string `json:"kind,omitempty" yaml:"kind,omitempty"`
|
|
|
|
Name string `json:"name,omitempty" yaml:"name,omitempty"`
|
|
|
|
RemoveTime string `json:"removeTime,omitempty" yaml:"remove_time,omitempty"`
|
|
|
|
Removed string `json:"removed,omitempty" yaml:"removed,omitempty"`
|
|
|
|
SerialNumber string `json:"serialNumber,omitempty" yaml:"serial_number,omitempty"`
|
|
|
|
State string `json:"state,omitempty" yaml:"state,omitempty"`
|
|
|
|
SubjectAlternativeNames []string `json:"subjectAlternativeNames,omitempty" yaml:"subject_alternative_names,omitempty"`
|
|
|
|
Transitioning string `json:"transitioning,omitempty" yaml:"transitioning,omitempty"`
|
|
|
|
TransitioningMessage string `json:"transitioningMessage,omitempty" yaml:"transitioning_message,omitempty"`
|
|
|
|
TransitioningProgress int64 `json:"transitioningProgress,omitempty" yaml:"transitioning_progress,omitempty"`
|
|
|
|
Uuid string `json:"uuid,omitempty" yaml:"uuid,omitempty"`
|
|
|
|
Version string `json:"version,omitempty" yaml:"version,omitempty"`
|
|
}
|
|
|
|
type CertificateCollection struct {
|
|
Collection
|
|
Data []Certificate `json:"data,omitempty"`
|
|
client *CertificateClient
|
|
}
|
|
|
|
type CertificateClient struct {
|
|
rancherClient *RancherClient
|
|
}
|
|
|
|
type CertificateOperations interface {
|
|
List(opts *ListOpts) (*CertificateCollection, error)
|
|
Create(opts *Certificate) (*Certificate, error)
|
|
Update(existing *Certificate, updates interface{}) (*Certificate, error)
|
|
ById(id string) (*Certificate, error)
|
|
Delete(container *Certificate) error
|
|
|
|
ActionCreate(*Certificate) (*Certificate, error)
|
|
|
|
ActionRemove(*Certificate) (*Certificate, error)
|
|
|
|
ActionUpdate(*Certificate) (*Certificate, error)
|
|
}
|
|
|
|
func newCertificateClient(rancherClient *RancherClient) *CertificateClient {
|
|
return &CertificateClient{
|
|
rancherClient: rancherClient,
|
|
}
|
|
}
|
|
|
|
func (c *CertificateClient) Create(container *Certificate) (*Certificate, error) {
|
|
resp := &Certificate{}
|
|
err := c.rancherClient.doCreate(CERTIFICATE_TYPE, container, resp)
|
|
return resp, err
|
|
}
|
|
|
|
func (c *CertificateClient) Update(existing *Certificate, updates interface{}) (*Certificate, error) {
|
|
resp := &Certificate{}
|
|
err := c.rancherClient.doUpdate(CERTIFICATE_TYPE, &existing.Resource, updates, resp)
|
|
return resp, err
|
|
}
|
|
|
|
func (c *CertificateClient) List(opts *ListOpts) (*CertificateCollection, error) {
|
|
resp := &CertificateCollection{}
|
|
err := c.rancherClient.doList(CERTIFICATE_TYPE, opts, resp)
|
|
resp.client = c
|
|
return resp, err
|
|
}
|
|
|
|
func (cc *CertificateCollection) Next() (*CertificateCollection, error) {
|
|
if cc != nil && cc.Pagination != nil && cc.Pagination.Next != "" {
|
|
resp := &CertificateCollection{}
|
|
err := cc.client.rancherClient.doNext(cc.Pagination.Next, resp)
|
|
resp.client = cc.client
|
|
return resp, err
|
|
}
|
|
return nil, nil
|
|
}
|
|
|
|
func (c *CertificateClient) ById(id string) (*Certificate, error) {
|
|
resp := &Certificate{}
|
|
err := c.rancherClient.doById(CERTIFICATE_TYPE, id, resp)
|
|
if apiError, ok := err.(*ApiError); ok {
|
|
if apiError.StatusCode == 404 {
|
|
return nil, nil
|
|
}
|
|
}
|
|
return resp, err
|
|
}
|
|
|
|
func (c *CertificateClient) Delete(container *Certificate) error {
|
|
return c.rancherClient.doResourceDelete(CERTIFICATE_TYPE, &container.Resource)
|
|
}
|
|
|
|
func (c *CertificateClient) ActionCreate(resource *Certificate) (*Certificate, error) {
|
|
|
|
resp := &Certificate{}
|
|
|
|
err := c.rancherClient.doAction(CERTIFICATE_TYPE, "create", &resource.Resource, nil, resp)
|
|
|
|
return resp, err
|
|
}
|
|
|
|
func (c *CertificateClient) ActionRemove(resource *Certificate) (*Certificate, error) {
|
|
|
|
resp := &Certificate{}
|
|
|
|
err := c.rancherClient.doAction(CERTIFICATE_TYPE, "remove", &resource.Resource, nil, resp)
|
|
|
|
return resp, err
|
|
}
|
|
|
|
func (c *CertificateClient) ActionUpdate(resource *Certificate) (*Certificate, error) {
|
|
|
|
resp := &Certificate{}
|
|
|
|
err := c.rancherClient.doAction(CERTIFICATE_TYPE, "update", &resource.Resource, nil, resp)
|
|
|
|
return resp, err
|
|
}
|