Skip to content

Commit

Permalink
Merge pull request #1276 from piperswe/piper/wr-1279
Browse files Browse the repository at this point in the history
WR-1279 add waiting room zone-level settings
  • Loading branch information
jacobbednarz committed May 8, 2023
2 parents 1633ac1 + 3508050 commit 03d8ad1
Show file tree
Hide file tree
Showing 3 changed files with 181 additions and 0 deletions.
3 changes: 3 additions & 0 deletions .changelog/1276.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:enhancement
waiting_room: add support for zone-level settings
```
85 changes: 85 additions & 0 deletions waiting_room.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,12 @@ type WaitingRoomRule struct {
Enabled *bool `json:"enabled"`
}

// WaitingRoomSettings describes zone-level waiting room settings.
type WaitingRoomSettings struct {
// Whether to allow verified search engine crawlers to bypass all waiting rooms on this zone
SearchEngineCrawlerBypass bool `json:"search_engine_crawler_bypass"`
}

// WaitingRoomPagePreviewURL describes a WaitingRoomPagePreviewURL object.
type WaitingRoomPagePreviewURL struct {
PreviewURL string `json:"preview_url"`
Expand All @@ -98,6 +104,12 @@ type WaitingRoomsResponse struct {
Result []WaitingRoom `json:"result"`
}

// WaitingRoomSettingsResponse is the API response, containing zone-level Waiting Room settings.
type WaitingRoomSettingsResponse struct {
Response
Result WaitingRoomSettings `json:"result"`
}

// WaitingRoomStatusResponse is the API response, containing the status of a waiting room.
type WaitingRoomStatusResponse struct {
Response
Expand Down Expand Up @@ -532,3 +544,76 @@ func (api *API) DeleteWaitingRoomRule(ctx context.Context, rc *ResourceContainer

return r.Result, nil
}

// GetWaitingRoomSettings fetches the Waiting Room zone-level settings for a zone.
//
// API reference: https://api.cloudflare.com/#waiting-room-get-zone-settings
func (api *API) GetWaitingRoomSettings(ctx context.Context, rc *ResourceContainer) (WaitingRoomSettings, error) {
if rc.Level != ZoneRouteLevel {
return WaitingRoomSettings{}, fmt.Errorf(errInvalidResourceContainerAccess, rc.Level)
}

uri := fmt.Sprintf("/zones/%s/waiting_rooms/settings", rc.Identifier)
res, err := api.makeRequestContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return WaitingRoomSettings{}, err
}
var r WaitingRoomSettingsResponse
err = json.Unmarshal(res, &r)
if err != nil {
return WaitingRoomSettings{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}
return r.Result, nil
}

type PatchWaitingRoomSettingsParams struct {
SearchEngineCrawlerBypass *bool `json:"search_engine_crawler_bypass,omitempty"`
}

// PatchWaitingRoomSettings lets you change individual zone-level Waiting Room settings. This is
// in contrast to UpdateWaitingRoomSettings which replaces all settings.
//
// API reference: https://api.cloudflare.com/#waiting-room-patch-zone-settings
func (api *API) PatchWaitingRoomSettings(ctx context.Context, rc *ResourceContainer, params PatchWaitingRoomSettingsParams) (WaitingRoomSettings, error) {
if rc.Level != ZoneRouteLevel {
return WaitingRoomSettings{}, fmt.Errorf(errInvalidResourceContainerAccess, rc.Level)
}

uri := fmt.Sprintf("/zones/%s/waiting_rooms/settings", rc.Identifier)
res, err := api.makeRequestContext(ctx, http.MethodPatch, uri, params)
if err != nil {
return WaitingRoomSettings{}, err
}
var r WaitingRoomSettingsResponse
err = json.Unmarshal(res, &r)
if err != nil {
return WaitingRoomSettings{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}
return r.Result, nil
}

type UpdateWaitingRoomSettingsParams struct {
SearchEngineCrawlerBypass *bool `json:"search_engine_crawler_bypass,omitempty"`
}

// UpdateWaitingRoomSettings lets you replace all zone-level Waiting Room settings. This is in contrast to
// PatchWaitingRoomSettings which lets you change individual settings.
//
// API reference: https://api.cloudflare.com/#waiting-room-update-zone-settings
func (api *API) UpdateWaitingRoomSettings(ctx context.Context, rc *ResourceContainer, params UpdateWaitingRoomSettingsParams) (WaitingRoomSettings, error) {
if rc.Level != ZoneRouteLevel {
return WaitingRoomSettings{}, fmt.Errorf(errInvalidResourceContainerAccess, rc.Level)
}

uri := fmt.Sprintf("/zones/%s/waiting_rooms/settings", rc.Identifier)
res, err := api.makeRequestContext(ctx, http.MethodPut, uri, params)
if err != nil {
return WaitingRoomSettings{}, err
}
var r WaitingRoomSettingsResponse
err = json.Unmarshal(res, &r)
if err != nil {
return WaitingRoomSettings{}, fmt.Errorf("%s: %w", errUnmarshalError, err)
}
return r.Result, nil
}
93 changes: 93 additions & 0 deletions waiting_room_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,12 @@ var waitingRoomPagePreviewJSON = `
}
`

var waitingRoomSettingsJSON = `
{
"search_engine_crawler_bypass": true
}
`

var waitingRoom = WaitingRoom{
ID: waitingRoomID,
CreatedOn: testTimestampWaitingRoom,
Expand Down Expand Up @@ -160,6 +166,18 @@ var waitingRoomRule = WaitingRoomRule{
LastUpdated: &testTimestampWaitingRoom,
}

var waitingRoomSettings = WaitingRoomSettings{
SearchEngineCrawlerBypass: true,
}

var waitingRoomSettingsUpdate = UpdateWaitingRoomSettingsParams{
SearchEngineCrawlerBypass: BoolPtr(true),
}

var waitingRoomSettingsPatch = PatchWaitingRoomSettingsParams{
SearchEngineCrawlerBypass: BoolPtr(true),
}

func TestListWaitingRooms(t *testing.T) {
setup()
defer teardown()
Expand Down Expand Up @@ -785,3 +803,78 @@ func TestReplaceWaitingRoomRules(t *testing.T) {
assert.Equal(t, want, actual)
}
}

func TestWaitingRoomSettings(t *testing.T) {
setup()
defer teardown()

handler := func(w http.ResponseWriter, r *http.Request) {
assert.Equal(t, http.MethodGet, r.Method, "Expected method 'GET', got %s", r.Method)
w.Header().Set("content-type", "application/json")
fmt.Fprintf(w, `{
"success": true,
"errors": [],
"messages": [],
"result": %s
}
`, waitingRoomSettingsJSON)
}

mux.HandleFunc("/zones/"+testZoneID+"/waiting_rooms/settings", handler)
want := waitingRoomSettings

actual, err := client.GetWaitingRoomSettings(context.Background(), ZoneIdentifier(testZoneID))
if assert.NoError(t, err) {
assert.Equal(t, want, actual)
}
}

func TestUpdateWaitingRoomSettings(t *testing.T) {
setup()
defer teardown()

handler := func(w http.ResponseWriter, r *http.Request) {
assert.Equal(t, http.MethodPut, r.Method, "Expected method 'PUT', got %s", r.Method)
w.Header().Set("content-type", "application/json")
fmt.Fprintf(w, `{
"success": true,
"errors": [],
"messages": [],
"result": %s
}
`, waitingRoomSettingsJSON)
}

mux.HandleFunc("/zones/"+testZoneID+"/waiting_rooms/settings", handler)
want := waitingRoomSettings

actual, err := client.UpdateWaitingRoomSettings(context.Background(), ZoneIdentifier(testZoneID), waitingRoomSettingsUpdate)
if assert.NoError(t, err) {
assert.Equal(t, want, actual)
}
}

func TestChangeWaitingRoomSettings(t *testing.T) {
setup()
defer teardown()

handler := func(w http.ResponseWriter, r *http.Request) {
assert.Equal(t, http.MethodPatch, r.Method, "Expected method 'PATCH', got %s", r.Method)
w.Header().Set("content-type", "application/json")
fmt.Fprintf(w, `{
"success": true,
"errors": [],
"messages": [],
"result": %s
}
`, waitingRoomSettingsJSON)
}

mux.HandleFunc("/zones/"+testZoneID+"/waiting_rooms/settings", handler)
want := waitingRoomSettings

actual, err := client.PatchWaitingRoomSettings(context.Background(), ZoneIdentifier(testZoneID), waitingRoomSettingsPatch)
if assert.NoError(t, err) {
assert.Equal(t, want, actual)
}
}

0 comments on commit 03d8ad1

Please sign in to comment.