1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
package solver
import (
"github.com/kong/deck/crud"
"github.com/kong/deck/diff"
"github.com/kong/deck/state"
"github.com/kong/go-kong/kong"
)
// caCertificateCRUD implements crud.Actions interface.
type caCertificateCRUD struct {
client *kong.Client
}
func caCertFromStuct(arg diff.Event) *state.CACertificate {
caCert, ok := arg.Obj.(*state.CACertificate)
if !ok {
panic("unexpected type, expected *state.CACertificate")
}
return caCert
}
// Create creates a CACertificate in Kong.
// The arg should be of type diff.Event, containing the certificate to be created,
// else the function will panic.
// It returns a the created *state.CACertificate.
func (s *caCertificateCRUD) Create(arg ...crud.Arg) (crud.Arg, error) {
event := eventFromArg(arg[0])
certificate := caCertFromStuct(event)
createdCertificate, err := s.client.CACertificates.Create(nil,
&certificate.CACertificate)
if err != nil {
return nil, err
}
return &state.CACertificate{CACertificate: *createdCertificate}, nil
}
// Delete deletes a CACertificate in Kong.
// The arg should be of type diff.Event, containing the certificate to be deleted,
// else the function will panic.
// It returns a the deleted *state.CACertificate.
func (s *caCertificateCRUD) Delete(arg ...crud.Arg) (crud.Arg, error) {
event := eventFromArg(arg[0])
certificate := caCertFromStuct(event)
err := s.client.CACertificates.Delete(nil, certificate.ID)
if err != nil {
return nil, err
}
return certificate, nil
}
// Update updates a CACertificate in Kong.
// The arg should be of type diff.Event, containing the certificate to be updated,
// else the function will panic.
// It returns a the updated *state.CACertificate.
func (s *caCertificateCRUD) Update(arg ...crud.Arg) (crud.Arg, error) {
event := eventFromArg(arg[0])
certificate := caCertFromStuct(event)
updatedCertificate, err := s.client.CACertificates.Create(nil,
&certificate.CACertificate)
if err != nil {
return nil, err
}
return &state.CACertificate{CACertificate: *updatedCertificate}, nil
}
|