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
|
package solver
import (
"github.com/kong/deck/crud"
"github.com/kong/deck/diff"
"github.com/kong/deck/state"
"github.com/kong/go-kong/kong"
)
// certificateCRUD implements crud.Actions interface.
type certificateCRUD struct {
client *kong.Client
}
func certificateFromStuct(arg diff.Event) *state.Certificate {
certificate, ok := arg.Obj.(*state.Certificate)
if !ok {
panic("unexpected type, expected *state.certificate")
}
return certificate
}
// Create creates a Certificate 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.Certificate.
func (s *certificateCRUD) Create(arg ...crud.Arg) (crud.Arg, error) {
event := eventFromArg(arg[0])
certificate := certificateFromStuct(event)
createdCertificate, err := s.client.Certificates.Create(nil, &certificate.Certificate)
if err != nil {
return nil, err
}
return &state.Certificate{Certificate: *createdCertificate}, nil
}
// Delete deletes a Certificate 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.Certificate.
func (s *certificateCRUD) Delete(arg ...crud.Arg) (crud.Arg, error) {
event := eventFromArg(arg[0])
certificate := certificateFromStuct(event)
err := s.client.Certificates.Delete(nil, certificate.ID)
if err != nil {
return nil, err
}
return certificate, nil
}
// Update updates a Certificate 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.Certificate.
func (s *certificateCRUD) Update(arg ...crud.Arg) (crud.Arg, error) {
event := eventFromArg(arg[0])
certificate := certificateFromStuct(event)
updatedCertificate, err := s.client.Certificates.Create(nil, &certificate.Certificate)
if err != nil {
return nil, err
}
return &state.Certificate{Certificate: *updatedCertificate}, nil
}
|