Skip to content

Commit

Permalink
GIN-341: support for gateway certificate api
Browse files Browse the repository at this point in the history
  • Loading branch information
alyssamw committed Jul 17, 2024
1 parent 44f6e82 commit f88bbe9
Show file tree
Hide file tree
Showing 4 changed files with 389 additions and 2 deletions.
2 changes: 1 addition & 1 deletion .changelog/2748.txt → .changelog/2754.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
```release-note:breaking-change
teams: gateway: rename TeamsCertificate in TeamsAccountConfiguration to TeamsCertificateSetting
teams: gateway: rename TeamsCertificate in TeamsAccountConfiguration to TeamsCertificateSetting, add TeamsCertificate resource to manage gateway certificates
```
2 changes: 1 addition & 1 deletion teams_accounts.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ type TeamsAccountSettings struct {
BodyScanning *TeamsBodyScanning `json:"body_scanning,omitempty"`
ExtendedEmailMatching *TeamsExtendedEmailMatching `json:"extended_email_matching,omitempty"`
CustomCertificate *TeamsCustomCertificate `json:"custom_certificate,omitempty"`
Certificate *TeamsCertificateSetting `json:"certificate,omitempty"`
Certificate *TeamsCertificateSetting `json:"certificate,omitempty"`
}

type BrowserIsolation struct {
Expand Down
158 changes: 158 additions & 0 deletions teams_certificates.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,158 @@
package cloudflare

import (
"context"
"fmt"
"net/http"
"time"

"github.com/goccy/go-json"
)

type TeamsCertificate struct {
Enabled *bool `json:"enabled"`
ID string `json:"id"`
BindingStatus string `json:"binding_status"`
QsPackId string `json:"qs_pack_id"`
Type string `json:"type"`
UpdatedAt *time.Time `json:"updated_at"`
UploadedOn *time.Time `json:"uploaded_on"`
CreatedAt *time.Time `json:"created_at"`
ExpiresOn *time.Time `json:"expires_on"`
}

type TeamsCertificateCreateRequest struct {
ValidityPeriodDays int `json:"validity_period_days,omitempty"`
}

const DEFAULT_VALIDITY_PERIOD_DAYS = 1826

// TeamsCertificateResponse is the API response, containing a single certificate.
type TeamsCertificateResponse struct {
Response
Result TeamsCertificate `json:"result"`
}

// TeamsCertificatesResponse is the API response, containing an array of certificates.
type TeamsCertificatesResponse struct {
Response
Result []TeamsCertificate `json:"result"`
}

// TeamsCertificates returns all certificates in an account
//
// API reference: https://developers.cloudflare.com/api/operations/zero-trust-certificates-list-zero-trust-certificates
func (api *API) TeamsCertificates(ctx context.Context, accountID string) ([]TeamsCertificate, error) {
uri := fmt.Sprintf("/accounts/%s/gateway/certificates", accountID)

res, err := api.makeRequestContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return []TeamsCertificate{}, err
}

var teamsCertificatesResponse TeamsCertificatesResponse
err = json.Unmarshal(res, &teamsCertificatesResponse)
if err != nil {
return []TeamsCertificate{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}

return teamsCertificatesResponse.Result, nil
}

// TeamsCertificate returns teams account certificate.
//
// API reference: https://developers.cloudflare.com/api/operations/zero-trust-certificates-zero-trust-certificate-details
func (api *API) TeamsCertificate(ctx context.Context, accountID string, certificateId string) (TeamsCertificate, error) {
uri := fmt.Sprintf("/accounts/%s/gateway/certificates/%s", accountID, certificateId)

res, err := api.makeRequestContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return TeamsCertificate{}, err
}

var teamsCertificateResponse TeamsCertificateResponse
err = json.Unmarshal(res, &teamsCertificateResponse)
if err != nil {
return TeamsCertificate{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}

return teamsCertificateResponse.Result, nil
}

// TeamsGenerateCertificate generates a new gateway managed certificate
//
// API reference: https://developers.cloudflare.com/api/operations/zero-trust-certificates-create-zero-trust-certificate
func (api *API) TeamsGenerateCertificate(ctx context.Context, accountID string, certificateRequest TeamsCertificateCreateRequest) (TeamsCertificate, error) {
uri := fmt.Sprintf("/accounts/%s/gateway/certificates", accountID)

if certificateRequest.ValidityPeriodDays == 0 {
certificateRequest.ValidityPeriodDays = DEFAULT_VALIDITY_PERIOD_DAYS
}

res, err := api.makeRequestContext(ctx, http.MethodPost, uri, certificateRequest)
if err != nil {
return TeamsCertificate{}, err
}

var teamsCertResponse TeamsCertificateResponse
err = json.Unmarshal(res, &teamsCertResponse)
if err != nil {
return TeamsCertificate{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}

return teamsCertResponse.Result, nil
}

// TeamsActivateCertificate activates a certificate
//
// API reference: https://developers.cloudflare.com/api/operations/zero-trust-certificates-activate-zero-trust-certificate
func (api *API) TeamsActivateCertificate(ctx context.Context, accountID string, certificateId string) (TeamsCertificate, error) {
uri := fmt.Sprintf("/accounts/%s/gateway/certificates/%s/activate", accountID, certificateId)

res, err := api.makeRequestContext(ctx, http.MethodPost, uri, nil)
if err != nil {
return TeamsCertificate{}, err
}

var teamsCertResponse TeamsCertificateResponse
err = json.Unmarshal(res, &teamsCertResponse)
if err != nil {
return TeamsCertificate{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}

return teamsCertResponse.Result, nil
}

// TeamsDectivateCertificate deactivates a certificate
//
// API reference: https://developers.cloudflare.com/api/operations/zero-trust-certificates-deactivate-zero-trust-certificate
func (api *API) TeamsDeactivateCertificate(ctx context.Context, accountID string, certificateId string) (TeamsCertificate, error) {
uri := fmt.Sprintf("/accounts/%s/gateway/certificates/%s/deactivate", accountID, certificateId)

res, err := api.makeRequestContext(ctx, http.MethodPost, uri, nil)
if err != nil {
return TeamsCertificate{}, err
}

var teamsCertResponse TeamsCertificateResponse
err = json.Unmarshal(res, &teamsCertResponse)
if err != nil {
return TeamsCertificate{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}

return teamsCertResponse.Result, nil
}

// TeamsDeleteCertificate deletes a certificate.
//
// API reference: https://developers.cloudflare.com/api/operations/zero-trust-certificates-delete-zero-trust-certificate
func (api *API) TeamsDeleteCertificate(ctx context.Context, accountID string, certificateId string) error {
uri := fmt.Sprintf("/accounts/%s/gateway/certificates/%s", accountID, certificateId)

_, err := api.makeRequestContext(ctx, http.MethodDelete, uri, nil)
if err != nil {
return err
}

return nil
}
Loading

0 comments on commit f88bbe9

Please sign in to comment.