services/google/monitoring/uptime_check_config_internal.go (2,515 lines of code) (raw):
// Copyright 2025 Google LLC. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package monitoring
import (
"bytes"
"context"
"encoding/json"
"fmt"
"io/ioutil"
"strings"
"github.com/GoogleCloudPlatform/declarative-resource-client-library/dcl"
)
func (r *UptimeCheckConfig) validate() error {
if err := dcl.ValidateExactlyOneOfFieldsSet([]string{"MonitoredResource", "ResourceGroup"}, r.MonitoredResource, r.ResourceGroup); err != nil {
return err
}
if err := dcl.ValidateAtMostOneOfFieldsSet([]string{"HttpCheck", "TcpCheck"}, r.HttpCheck, r.TcpCheck); err != nil {
return err
}
if err := dcl.Required(r, "displayName"); err != nil {
return err
}
if err := dcl.Required(r, "timeout"); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(r.MonitoredResource) {
if err := r.MonitoredResource.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.ResourceGroup) {
if err := r.ResourceGroup.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.HttpCheck) {
if err := r.HttpCheck.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.TcpCheck) {
if err := r.TcpCheck.validate(); err != nil {
return err
}
}
return nil
}
func (r *UptimeCheckConfigMonitoredResource) validate() error {
if err := dcl.Required(r, "type"); err != nil {
return err
}
if err := dcl.Required(r, "filterLabels"); err != nil {
return err
}
return nil
}
func (r *UptimeCheckConfigResourceGroup) validate() error {
return nil
}
func (r *UptimeCheckConfigHttpCheck) validate() error {
if !dcl.IsEmptyValueIndirect(r.AuthInfo) {
if err := r.AuthInfo.validate(); err != nil {
return err
}
}
return nil
}
func (r *UptimeCheckConfigHttpCheckAuthInfo) validate() error {
if err := dcl.Required(r, "username"); err != nil {
return err
}
if err := dcl.Required(r, "password"); err != nil {
return err
}
return nil
}
func (r *UptimeCheckConfigTcpCheck) validate() error {
if err := dcl.Required(r, "port"); err != nil {
return err
}
return nil
}
func (r *UptimeCheckConfigContentMatchers) validate() error {
if err := dcl.Required(r, "content"); err != nil {
return err
}
return nil
}
func (r *UptimeCheckConfig) basePath() string {
params := map[string]interface{}{}
return dcl.Nprintf("https://monitoring.googleapis.com/v3/", params)
}
func (r *UptimeCheckConfig) getURL(userBasePath string) (string, error) {
nr := r.urlNormalized()
params := map[string]interface{}{
"project": dcl.ValueOrEmptyString(nr.Project),
"name": dcl.ValueOrEmptyString(nr.Name),
}
return dcl.URL("projects/{{project}}/uptimeCheckConfigs/{{name}}", nr.basePath(), userBasePath, params), nil
}
func (r *UptimeCheckConfig) listURL(userBasePath string) (string, error) {
nr := r.urlNormalized()
params := map[string]interface{}{
"project": dcl.ValueOrEmptyString(nr.Project),
}
return dcl.URL("projects/{{project}}/uptimeCheckConfigs", nr.basePath(), userBasePath, params), nil
}
func (r *UptimeCheckConfig) createURL(userBasePath string) (string, error) {
nr := r.urlNormalized()
params := map[string]interface{}{
"project": dcl.ValueOrEmptyString(nr.Project),
}
return dcl.URL("projects/{{project}}/uptimeCheckConfigs", nr.basePath(), userBasePath, params), nil
}
func (r *UptimeCheckConfig) deleteURL(userBasePath string) (string, error) {
nr := r.urlNormalized()
params := map[string]interface{}{
"project": dcl.ValueOrEmptyString(nr.Project),
"name": dcl.ValueOrEmptyString(nr.Name),
}
return dcl.URL("projects/{{project}}/uptimeCheckConfigs/{{name}}", nr.basePath(), userBasePath, params), nil
}
// uptimeCheckConfigApiOperation represents a mutable operation in the underlying REST
// API such as Create, Update, or Delete.
type uptimeCheckConfigApiOperation interface {
do(context.Context, *UptimeCheckConfig, *Client) error
}
// newUpdateUptimeCheckConfigUpdateUptimeCheckConfigRequest creates a request for an
// UptimeCheckConfig resource's UpdateUptimeCheckConfig update type by filling in the update
// fields based on the intended state of the resource.
func newUpdateUptimeCheckConfigUpdateUptimeCheckConfigRequest(ctx context.Context, f *UptimeCheckConfig, c *Client) (map[string]interface{}, error) {
req := map[string]interface{}{}
res := f
_ = res
if v := f.DisplayName; !dcl.IsEmptyValueIndirect(v) {
req["displayName"] = v
}
if v, err := expandUptimeCheckConfigHttpCheck(c, f.HttpCheck, res); err != nil {
return nil, fmt.Errorf("error expanding HttpCheck into httpCheck: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
req["httpCheck"] = v
}
if v, err := expandUptimeCheckConfigTcpCheck(c, f.TcpCheck, res); err != nil {
return nil, fmt.Errorf("error expanding TcpCheck into tcpCheck: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
req["tcpCheck"] = v
}
if v := f.Period; !dcl.IsEmptyValueIndirect(v) {
req["period"] = v
}
if v := f.Timeout; !dcl.IsEmptyValueIndirect(v) {
req["timeout"] = v
}
if v, err := expandUptimeCheckConfigContentMatchersSlice(c, f.ContentMatchers, res); err != nil {
return nil, fmt.Errorf("error expanding ContentMatchers into contentMatchers: %w", err)
} else if v != nil {
req["contentMatchers"] = v
}
if v := f.SelectedRegions; v != nil {
req["selectedRegions"] = v
}
req["name"] = fmt.Sprintf("projects/%s/uptimeCheckConfigs/%s", *f.Project, *f.Name)
return req, nil
}
// marshalUpdateUptimeCheckConfigUpdateUptimeCheckConfigRequest converts the update into
// the final JSON request body.
func marshalUpdateUptimeCheckConfigUpdateUptimeCheckConfigRequest(c *Client, m map[string]interface{}) ([]byte, error) {
return json.Marshal(m)
}
type updateUptimeCheckConfigUpdateUptimeCheckConfigOperation struct {
// If the update operation has the REQUIRES_APPLY_OPTIONS trait, this will be populated.
// Usually it will be nil - this is to prevent us from accidentally depending on apply
// options, which should usually be unnecessary.
ApplyOptions []dcl.ApplyOption
FieldDiffs []*dcl.FieldDiff
}
// do creates a request and sends it to the appropriate URL. In most operations,
// do will transcribe a subset of the resource into a request object and send a
// PUT request to a single URL.
func (op *updateUptimeCheckConfigUpdateUptimeCheckConfigOperation) do(ctx context.Context, r *UptimeCheckConfig, c *Client) error {
_, err := c.GetUptimeCheckConfig(ctx, r)
if err != nil {
return err
}
u, err := r.updateURL(c.Config.BasePath, "UpdateUptimeCheckConfig")
if err != nil {
return err
}
mask := dcl.UpdateMask(op.FieldDiffs)
u, err = dcl.AddQueryParams(u, map[string]string{"updateMask": mask})
if err != nil {
return err
}
req, err := newUpdateUptimeCheckConfigUpdateUptimeCheckConfigRequest(ctx, r, c)
if err != nil {
return err
}
c.Config.Logger.InfoWithContextf(ctx, "Created update: %#v", req)
body, err := marshalUpdateUptimeCheckConfigUpdateUptimeCheckConfigRequest(c, req)
if err != nil {
return err
}
_, err = dcl.SendRequest(ctx, c.Config, "PATCH", u, bytes.NewBuffer(body), c.Config.RetryProvider)
if err != nil {
return err
}
return nil
}
func (c *Client) listUptimeCheckConfigRaw(ctx context.Context, r *UptimeCheckConfig, pageToken string, pageSize int32) ([]byte, error) {
u, err := r.urlNormalized().listURL(c.Config.BasePath)
if err != nil {
return nil, err
}
m := make(map[string]string)
if pageToken != "" {
m["pageToken"] = pageToken
}
if pageSize != UptimeCheckConfigMaxPage {
m["pageSize"] = fmt.Sprintf("%v", pageSize)
}
u, err = dcl.AddQueryParams(u, m)
if err != nil {
return nil, err
}
resp, err := dcl.SendRequest(ctx, c.Config, "GET", u, &bytes.Buffer{}, c.Config.RetryProvider)
if err != nil {
return nil, err
}
defer resp.Response.Body.Close()
return ioutil.ReadAll(resp.Response.Body)
}
type listUptimeCheckConfigOperation struct {
UptimeCheckConfigs []map[string]interface{} `json:"uptimeCheckConfigs"`
Token string `json:"nextPageToken"`
}
func (c *Client) listUptimeCheckConfig(ctx context.Context, r *UptimeCheckConfig, pageToken string, pageSize int32) ([]*UptimeCheckConfig, string, error) {
b, err := c.listUptimeCheckConfigRaw(ctx, r, pageToken, pageSize)
if err != nil {
return nil, "", err
}
var m listUptimeCheckConfigOperation
if err := json.Unmarshal(b, &m); err != nil {
return nil, "", err
}
var l []*UptimeCheckConfig
for _, v := range m.UptimeCheckConfigs {
res, err := unmarshalMapUptimeCheckConfig(v, c, r)
if err != nil {
return nil, m.Token, err
}
res.Project = r.Project
l = append(l, res)
}
return l, m.Token, nil
}
func (c *Client) deleteAllUptimeCheckConfig(ctx context.Context, f func(*UptimeCheckConfig) bool, resources []*UptimeCheckConfig) error {
var errors []string
for _, res := range resources {
if f(res) {
// We do not want deleteAll to fail on a deletion or else it will stop deleting other resources.
err := c.DeleteUptimeCheckConfig(ctx, res)
if err != nil {
errors = append(errors, err.Error())
}
}
}
if len(errors) > 0 {
return fmt.Errorf("%v", strings.Join(errors, "\n"))
} else {
return nil
}
}
type deleteUptimeCheckConfigOperation struct{}
func (op *deleteUptimeCheckConfigOperation) do(ctx context.Context, r *UptimeCheckConfig, c *Client) error {
r, err := c.GetUptimeCheckConfig(ctx, r)
if err != nil {
if dcl.IsNotFound(err) {
c.Config.Logger.InfoWithContextf(ctx, "UptimeCheckConfig not found, returning. Original error: %v", err)
return nil
}
c.Config.Logger.WarningWithContextf(ctx, "GetUptimeCheckConfig checking for existence. error: %v", err)
return err
}
u, err := r.deleteURL(c.Config.BasePath)
if err != nil {
return err
}
// Delete should never have a body
body := &bytes.Buffer{}
_, err = dcl.SendRequest(ctx, c.Config, "DELETE", u, body, c.Config.RetryProvider)
if err != nil {
return fmt.Errorf("failed to delete UptimeCheckConfig: %w", err)
}
// We saw a race condition where for some successful delete operation, the Get calls returned resources for a short duration.
// This is the reason we are adding retry to handle that case.
retriesRemaining := 10
dcl.Do(ctx, func(ctx context.Context) (*dcl.RetryDetails, error) {
_, err := c.GetUptimeCheckConfig(ctx, r)
if dcl.IsNotFound(err) {
return nil, nil
}
if retriesRemaining > 0 {
retriesRemaining--
return &dcl.RetryDetails{}, dcl.OperationNotDone{}
}
return nil, dcl.NotDeletedError{ExistingResource: r}
}, c.Config.RetryProvider)
return nil
}
// Create operations are similar to Update operations, although they do not have
// specific request objects. The Create request object is the json encoding of
// the resource, which is modified by res.marshal to form the base request body.
type createUptimeCheckConfigOperation struct {
response map[string]interface{}
}
func (op *createUptimeCheckConfigOperation) FirstResponse() (map[string]interface{}, bool) {
return op.response, len(op.response) > 0
}
func (op *createUptimeCheckConfigOperation) do(ctx context.Context, r *UptimeCheckConfig, c *Client) error {
c.Config.Logger.InfoWithContextf(ctx, "Attempting to create %v", r)
u, err := r.createURL(c.Config.BasePath)
if err != nil {
return err
}
req, err := r.marshal(c)
if err != nil {
return err
}
if r.Name != nil {
// Allowing creation to continue with Name set could result in a UptimeCheckConfig with the wrong Name.
return fmt.Errorf("server-generated parameter Name was specified by user as %v, should be unspecified", dcl.ValueOrEmptyString(r.Name))
}
resp, err := dcl.SendRequest(ctx, c.Config, "POST", u, bytes.NewBuffer(req), c.Config.RetryProvider)
if err != nil {
return err
}
o, err := dcl.ResponseBodyAsJSON(resp)
if err != nil {
return fmt.Errorf("error decoding response body into JSON: %w", err)
}
op.response = o
// Include Name in URL substitution for initial GET request.
m := op.response
r.Name = dcl.SelfLinkToName(dcl.FlattenString(m["name"]))
if _, err := c.GetUptimeCheckConfig(ctx, r); err != nil {
c.Config.Logger.WarningWithContextf(ctx, "get returned error: %v", err)
return err
}
return nil
}
func (c *Client) getUptimeCheckConfigRaw(ctx context.Context, r *UptimeCheckConfig) ([]byte, error) {
if dcl.IsZeroValue(r.Period) {
r.Period = dcl.String("60s")
}
u, err := r.getURL(c.Config.BasePath)
if err != nil {
return nil, err
}
resp, err := dcl.SendRequest(ctx, c.Config, "GET", u, &bytes.Buffer{}, c.Config.RetryProvider)
if err != nil {
return nil, err
}
defer resp.Response.Body.Close()
b, err := ioutil.ReadAll(resp.Response.Body)
if err != nil {
return nil, err
}
return b, nil
}
func (c *Client) uptimeCheckConfigDiffsForRawDesired(ctx context.Context, rawDesired *UptimeCheckConfig, opts ...dcl.ApplyOption) (initial, desired *UptimeCheckConfig, diffs []*dcl.FieldDiff, err error) {
c.Config.Logger.InfoWithContext(ctx, "Fetching initial state...")
// First, let us see if the user provided a state hint. If they did, we will start fetching based on that.
var fetchState *UptimeCheckConfig
if sh := dcl.FetchStateHint(opts); sh != nil {
if r, ok := sh.(*UptimeCheckConfig); !ok {
c.Config.Logger.WarningWithContextf(ctx, "Initial state hint was of the wrong type; expected UptimeCheckConfig, got %T", sh)
} else {
fetchState = r
}
}
if fetchState == nil {
fetchState = rawDesired
}
if fetchState.Name == nil {
// We cannot perform a get because of lack of information. We have to assume
// that this is being created for the first time.
desired, err := canonicalizeUptimeCheckConfigDesiredState(rawDesired, nil)
return nil, desired, nil, err
}
// 1.2: Retrieval of raw initial state from API
rawInitial, err := c.GetUptimeCheckConfig(ctx, fetchState)
if rawInitial == nil {
if !dcl.IsNotFound(err) {
c.Config.Logger.WarningWithContextf(ctx, "Failed to retrieve whether a UptimeCheckConfig resource already exists: %s", err)
return nil, nil, nil, fmt.Errorf("failed to retrieve UptimeCheckConfig resource: %v", err)
}
c.Config.Logger.InfoWithContext(ctx, "Found that UptimeCheckConfig resource did not exist.")
// Perform canonicalization to pick up defaults.
desired, err = canonicalizeUptimeCheckConfigDesiredState(rawDesired, rawInitial)
return nil, desired, nil, err
}
c.Config.Logger.InfoWithContextf(ctx, "Found initial state for UptimeCheckConfig: %v", rawInitial)
c.Config.Logger.InfoWithContextf(ctx, "Initial desired state for UptimeCheckConfig: %v", rawDesired)
// The Get call applies postReadExtract and so the result may contain fields that are not part of API version.
if err := extractUptimeCheckConfigFields(rawInitial); err != nil {
return nil, nil, nil, err
}
// 1.3: Canonicalize raw initial state into initial state.
initial, err = canonicalizeUptimeCheckConfigInitialState(rawInitial, rawDesired)
if err != nil {
return nil, nil, nil, err
}
c.Config.Logger.InfoWithContextf(ctx, "Canonicalized initial state for UptimeCheckConfig: %v", initial)
// 1.4: Canonicalize raw desired state into desired state.
desired, err = canonicalizeUptimeCheckConfigDesiredState(rawDesired, rawInitial, opts...)
if err != nil {
return nil, nil, nil, err
}
c.Config.Logger.InfoWithContextf(ctx, "Canonicalized desired state for UptimeCheckConfig: %v", desired)
// 2.1: Comparison of initial and desired state.
diffs, err = diffUptimeCheckConfig(c, desired, initial, opts...)
return initial, desired, diffs, err
}
func canonicalizeUptimeCheckConfigInitialState(rawInitial, rawDesired *UptimeCheckConfig) (*UptimeCheckConfig, error) {
// TODO(magic-modules-eng): write canonicalizer once relevant traits are added.
if !dcl.IsZeroValue(rawInitial.MonitoredResource) {
// Check if anything else is set.
if dcl.AnySet(rawInitial.ResourceGroup) {
rawInitial.MonitoredResource = EmptyUptimeCheckConfigMonitoredResource
}
}
if !dcl.IsZeroValue(rawInitial.ResourceGroup) {
// Check if anything else is set.
if dcl.AnySet(rawInitial.MonitoredResource) {
rawInitial.ResourceGroup = EmptyUptimeCheckConfigResourceGroup
}
}
if !dcl.IsZeroValue(rawInitial.HttpCheck) {
// Check if anything else is set.
if dcl.AnySet(rawInitial.TcpCheck) {
rawInitial.HttpCheck = EmptyUptimeCheckConfigHttpCheck
}
}
if !dcl.IsZeroValue(rawInitial.TcpCheck) {
// Check if anything else is set.
if dcl.AnySet(rawInitial.HttpCheck) {
rawInitial.TcpCheck = EmptyUptimeCheckConfigTcpCheck
}
}
return rawInitial, nil
}
/*
* Canonicalizers
*
* These are responsible for converting either a user-specified config or a
* GCP API response to a standard format that can be used for difference checking.
* */
func canonicalizeUptimeCheckConfigDesiredState(rawDesired, rawInitial *UptimeCheckConfig, opts ...dcl.ApplyOption) (*UptimeCheckConfig, error) {
if dcl.IsZeroValue(rawDesired.Period) {
rawDesired.Period = dcl.String("60s")
}
if rawInitial == nil {
// Since the initial state is empty, the desired state is all we have.
// We canonicalize the remaining nested objects with nil to pick up defaults.
rawDesired.MonitoredResource = canonicalizeUptimeCheckConfigMonitoredResource(rawDesired.MonitoredResource, nil, opts...)
rawDesired.ResourceGroup = canonicalizeUptimeCheckConfigResourceGroup(rawDesired.ResourceGroup, nil, opts...)
rawDesired.HttpCheck = canonicalizeUptimeCheckConfigHttpCheck(rawDesired.HttpCheck, nil, opts...)
rawDesired.TcpCheck = canonicalizeUptimeCheckConfigTcpCheck(rawDesired.TcpCheck, nil, opts...)
return rawDesired, nil
}
canonicalDesired := &UptimeCheckConfig{}
if dcl.IsZeroValue(rawDesired.Name) || (dcl.IsEmptyValueIndirect(rawDesired.Name) && dcl.IsEmptyValueIndirect(rawInitial.Name)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
canonicalDesired.Name = rawInitial.Name
} else {
canonicalDesired.Name = rawDesired.Name
}
if dcl.StringCanonicalize(rawDesired.DisplayName, rawInitial.DisplayName) {
canonicalDesired.DisplayName = rawInitial.DisplayName
} else {
canonicalDesired.DisplayName = rawDesired.DisplayName
}
canonicalDesired.MonitoredResource = canonicalizeUptimeCheckConfigMonitoredResource(rawDesired.MonitoredResource, rawInitial.MonitoredResource, opts...)
canonicalDesired.ResourceGroup = canonicalizeUptimeCheckConfigResourceGroup(rawDesired.ResourceGroup, rawInitial.ResourceGroup, opts...)
canonicalDesired.HttpCheck = canonicalizeUptimeCheckConfigHttpCheck(rawDesired.HttpCheck, rawInitial.HttpCheck, opts...)
canonicalDesired.TcpCheck = canonicalizeUptimeCheckConfigTcpCheck(rawDesired.TcpCheck, rawInitial.TcpCheck, opts...)
if dcl.StringCanonicalize(rawDesired.Period, rawInitial.Period) {
canonicalDesired.Period = rawInitial.Period
} else {
canonicalDesired.Period = rawDesired.Period
}
if dcl.StringCanonicalize(rawDesired.Timeout, rawInitial.Timeout) {
canonicalDesired.Timeout = rawInitial.Timeout
} else {
canonicalDesired.Timeout = rawDesired.Timeout
}
canonicalDesired.ContentMatchers = canonicalizeUptimeCheckConfigContentMatchersSlice(rawDesired.ContentMatchers, rawInitial.ContentMatchers, opts...)
if dcl.StringArrayCanonicalize(rawDesired.SelectedRegions, rawInitial.SelectedRegions) {
canonicalDesired.SelectedRegions = rawInitial.SelectedRegions
} else {
canonicalDesired.SelectedRegions = rawDesired.SelectedRegions
}
if dcl.NameToSelfLink(rawDesired.Project, rawInitial.Project) {
canonicalDesired.Project = rawInitial.Project
} else {
canonicalDesired.Project = rawDesired.Project
}
if canonicalDesired.MonitoredResource != nil {
// Check if anything else is set.
if dcl.AnySet(rawDesired.ResourceGroup) {
canonicalDesired.MonitoredResource = EmptyUptimeCheckConfigMonitoredResource
}
}
if canonicalDesired.ResourceGroup != nil {
// Check if anything else is set.
if dcl.AnySet(rawDesired.MonitoredResource) {
canonicalDesired.ResourceGroup = EmptyUptimeCheckConfigResourceGroup
}
}
if canonicalDesired.HttpCheck != nil {
// Check if anything else is set.
if dcl.AnySet(rawDesired.TcpCheck) {
canonicalDesired.HttpCheck = EmptyUptimeCheckConfigHttpCheck
}
}
if canonicalDesired.TcpCheck != nil {
// Check if anything else is set.
if dcl.AnySet(rawDesired.HttpCheck) {
canonicalDesired.TcpCheck = EmptyUptimeCheckConfigTcpCheck
}
}
return canonicalDesired, nil
}
func canonicalizeUptimeCheckConfigNewState(c *Client, rawNew, rawDesired *UptimeCheckConfig) (*UptimeCheckConfig, error) {
if dcl.IsEmptyValueIndirect(rawNew.Name) && dcl.IsEmptyValueIndirect(rawDesired.Name) {
rawNew.Name = rawDesired.Name
} else {
}
if dcl.IsEmptyValueIndirect(rawNew.DisplayName) && dcl.IsEmptyValueIndirect(rawDesired.DisplayName) {
rawNew.DisplayName = rawDesired.DisplayName
} else {
if dcl.StringCanonicalize(rawDesired.DisplayName, rawNew.DisplayName) {
rawNew.DisplayName = rawDesired.DisplayName
}
}
if dcl.IsEmptyValueIndirect(rawNew.MonitoredResource) && dcl.IsEmptyValueIndirect(rawDesired.MonitoredResource) {
rawNew.MonitoredResource = rawDesired.MonitoredResource
} else {
rawNew.MonitoredResource = canonicalizeNewUptimeCheckConfigMonitoredResource(c, rawDesired.MonitoredResource, rawNew.MonitoredResource)
}
if dcl.IsEmptyValueIndirect(rawNew.ResourceGroup) && dcl.IsEmptyValueIndirect(rawDesired.ResourceGroup) {
rawNew.ResourceGroup = rawDesired.ResourceGroup
} else {
rawNew.ResourceGroup = canonicalizeNewUptimeCheckConfigResourceGroup(c, rawDesired.ResourceGroup, rawNew.ResourceGroup)
}
if dcl.IsEmptyValueIndirect(rawNew.HttpCheck) && dcl.IsEmptyValueIndirect(rawDesired.HttpCheck) {
rawNew.HttpCheck = rawDesired.HttpCheck
} else {
rawNew.HttpCheck = canonicalizeNewUptimeCheckConfigHttpCheck(c, rawDesired.HttpCheck, rawNew.HttpCheck)
}
if dcl.IsEmptyValueIndirect(rawNew.TcpCheck) && dcl.IsEmptyValueIndirect(rawDesired.TcpCheck) {
rawNew.TcpCheck = rawDesired.TcpCheck
} else {
rawNew.TcpCheck = canonicalizeNewUptimeCheckConfigTcpCheck(c, rawDesired.TcpCheck, rawNew.TcpCheck)
}
if dcl.IsEmptyValueIndirect(rawNew.Period) && dcl.IsEmptyValueIndirect(rawDesired.Period) {
rawNew.Period = rawDesired.Period
} else {
if dcl.StringCanonicalize(rawDesired.Period, rawNew.Period) {
rawNew.Period = rawDesired.Period
}
}
if dcl.IsEmptyValueIndirect(rawNew.Timeout) && dcl.IsEmptyValueIndirect(rawDesired.Timeout) {
rawNew.Timeout = rawDesired.Timeout
} else {
if dcl.StringCanonicalize(rawDesired.Timeout, rawNew.Timeout) {
rawNew.Timeout = rawDesired.Timeout
}
}
if dcl.IsEmptyValueIndirect(rawNew.ContentMatchers) && dcl.IsEmptyValueIndirect(rawDesired.ContentMatchers) {
rawNew.ContentMatchers = rawDesired.ContentMatchers
} else {
rawNew.ContentMatchers = canonicalizeNewUptimeCheckConfigContentMatchersSlice(c, rawDesired.ContentMatchers, rawNew.ContentMatchers)
}
if dcl.IsEmptyValueIndirect(rawNew.SelectedRegions) && dcl.IsEmptyValueIndirect(rawDesired.SelectedRegions) {
rawNew.SelectedRegions = rawDesired.SelectedRegions
} else {
if dcl.StringArrayCanonicalize(rawDesired.SelectedRegions, rawNew.SelectedRegions) {
rawNew.SelectedRegions = rawDesired.SelectedRegions
}
}
rawNew.Project = rawDesired.Project
return rawNew, nil
}
func canonicalizeUptimeCheckConfigMonitoredResource(des, initial *UptimeCheckConfigMonitoredResource, opts ...dcl.ApplyOption) *UptimeCheckConfigMonitoredResource {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &UptimeCheckConfigMonitoredResource{}
if dcl.StringCanonicalize(des.Type, initial.Type) || dcl.IsZeroValue(des.Type) {
cDes.Type = initial.Type
} else {
cDes.Type = des.Type
}
if dcl.IsZeroValue(des.FilterLabels) || (dcl.IsEmptyValueIndirect(des.FilterLabels) && dcl.IsEmptyValueIndirect(initial.FilterLabels)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.FilterLabels = initial.FilterLabels
} else {
cDes.FilterLabels = des.FilterLabels
}
return cDes
}
func canonicalizeUptimeCheckConfigMonitoredResourceSlice(des, initial []UptimeCheckConfigMonitoredResource, opts ...dcl.ApplyOption) []UptimeCheckConfigMonitoredResource {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]UptimeCheckConfigMonitoredResource, 0, len(des))
for _, d := range des {
cd := canonicalizeUptimeCheckConfigMonitoredResource(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]UptimeCheckConfigMonitoredResource, 0, len(des))
for i, d := range des {
cd := canonicalizeUptimeCheckConfigMonitoredResource(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewUptimeCheckConfigMonitoredResource(c *Client, des, nw *UptimeCheckConfigMonitoredResource) *UptimeCheckConfigMonitoredResource {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for UptimeCheckConfigMonitoredResource while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
if dcl.StringCanonicalize(des.Type, nw.Type) {
nw.Type = des.Type
}
return nw
}
func canonicalizeNewUptimeCheckConfigMonitoredResourceSet(c *Client, des, nw []UptimeCheckConfigMonitoredResource) []UptimeCheckConfigMonitoredResource {
if des == nil {
return nw
}
// Find the elements in des that are also in nw and canonicalize them. Remove matched elements from nw.
var items []UptimeCheckConfigMonitoredResource
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareUptimeCheckConfigMonitoredResourceNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewUptimeCheckConfigMonitoredResource(c, &d, &nw[matchedIndex]))
nw = append(nw[:matchedIndex], nw[matchedIndex+1:]...)
}
}
// Also include elements in nw that are not matched in des.
items = append(items, nw...)
return items
}
func canonicalizeNewUptimeCheckConfigMonitoredResourceSlice(c *Client, des, nw []UptimeCheckConfigMonitoredResource) []UptimeCheckConfigMonitoredResource {
if des == nil {
return nw
}
// Lengths are unequal. A diff will occur later, so we shouldn't canonicalize.
// Return the original array.
if len(des) != len(nw) {
return nw
}
var items []UptimeCheckConfigMonitoredResource
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewUptimeCheckConfigMonitoredResource(c, &d, &n))
}
return items
}
func canonicalizeUptimeCheckConfigResourceGroup(des, initial *UptimeCheckConfigResourceGroup, opts ...dcl.ApplyOption) *UptimeCheckConfigResourceGroup {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &UptimeCheckConfigResourceGroup{}
if dcl.IsZeroValue(des.GroupId) || (dcl.IsEmptyValueIndirect(des.GroupId) && dcl.IsEmptyValueIndirect(initial.GroupId)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.GroupId = initial.GroupId
} else {
cDes.GroupId = des.GroupId
}
if dcl.IsZeroValue(des.ResourceType) || (dcl.IsEmptyValueIndirect(des.ResourceType) && dcl.IsEmptyValueIndirect(initial.ResourceType)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.ResourceType = initial.ResourceType
} else {
cDes.ResourceType = des.ResourceType
}
return cDes
}
func canonicalizeUptimeCheckConfigResourceGroupSlice(des, initial []UptimeCheckConfigResourceGroup, opts ...dcl.ApplyOption) []UptimeCheckConfigResourceGroup {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]UptimeCheckConfigResourceGroup, 0, len(des))
for _, d := range des {
cd := canonicalizeUptimeCheckConfigResourceGroup(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]UptimeCheckConfigResourceGroup, 0, len(des))
for i, d := range des {
cd := canonicalizeUptimeCheckConfigResourceGroup(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewUptimeCheckConfigResourceGroup(c *Client, des, nw *UptimeCheckConfigResourceGroup) *UptimeCheckConfigResourceGroup {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for UptimeCheckConfigResourceGroup while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
return nw
}
func canonicalizeNewUptimeCheckConfigResourceGroupSet(c *Client, des, nw []UptimeCheckConfigResourceGroup) []UptimeCheckConfigResourceGroup {
if des == nil {
return nw
}
// Find the elements in des that are also in nw and canonicalize them. Remove matched elements from nw.
var items []UptimeCheckConfigResourceGroup
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareUptimeCheckConfigResourceGroupNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewUptimeCheckConfigResourceGroup(c, &d, &nw[matchedIndex]))
nw = append(nw[:matchedIndex], nw[matchedIndex+1:]...)
}
}
// Also include elements in nw that are not matched in des.
items = append(items, nw...)
return items
}
func canonicalizeNewUptimeCheckConfigResourceGroupSlice(c *Client, des, nw []UptimeCheckConfigResourceGroup) []UptimeCheckConfigResourceGroup {
if des == nil {
return nw
}
// Lengths are unequal. A diff will occur later, so we shouldn't canonicalize.
// Return the original array.
if len(des) != len(nw) {
return nw
}
var items []UptimeCheckConfigResourceGroup
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewUptimeCheckConfigResourceGroup(c, &d, &n))
}
return items
}
func canonicalizeUptimeCheckConfigHttpCheck(des, initial *UptimeCheckConfigHttpCheck, opts ...dcl.ApplyOption) *UptimeCheckConfigHttpCheck {
if des == nil {
return initial
}
if des.empty {
return des
}
if dcl.IsZeroValue(des.RequestMethod) {
des.RequestMethod = UptimeCheckConfigHttpCheckRequestMethodEnumRef("GET")
}
if dcl.IsZeroValue(des.Path) {
des.Path = dcl.String("/")
}
if initial == nil {
return des
}
cDes := &UptimeCheckConfigHttpCheck{}
if dcl.IsZeroValue(des.RequestMethod) || (dcl.IsEmptyValueIndirect(des.RequestMethod) && dcl.IsEmptyValueIndirect(initial.RequestMethod)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.RequestMethod = initial.RequestMethod
} else {
cDes.RequestMethod = des.RequestMethod
}
if dcl.BoolCanonicalize(des.UseSsl, initial.UseSsl) || dcl.IsZeroValue(des.UseSsl) {
cDes.UseSsl = initial.UseSsl
} else {
cDes.UseSsl = des.UseSsl
}
if dcl.StringCanonicalize(des.Path, initial.Path) || dcl.IsZeroValue(des.Path) {
cDes.Path = initial.Path
} else {
cDes.Path = des.Path
}
if dcl.IsZeroValue(des.Port) || (dcl.IsEmptyValueIndirect(des.Port) && dcl.IsEmptyValueIndirect(initial.Port)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.Port = initial.Port
} else {
cDes.Port = des.Port
}
cDes.AuthInfo = canonicalizeUptimeCheckConfigHttpCheckAuthInfo(des.AuthInfo, initial.AuthInfo, opts...)
if dcl.BoolCanonicalize(des.MaskHeaders, initial.MaskHeaders) || dcl.IsZeroValue(des.MaskHeaders) {
cDes.MaskHeaders = initial.MaskHeaders
} else {
cDes.MaskHeaders = des.MaskHeaders
}
if dcl.IsZeroValue(des.Headers) || (dcl.IsEmptyValueIndirect(des.Headers) && dcl.IsEmptyValueIndirect(initial.Headers)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.Headers = initial.Headers
} else {
cDes.Headers = des.Headers
}
if dcl.IsZeroValue(des.ContentType) || (dcl.IsEmptyValueIndirect(des.ContentType) && dcl.IsEmptyValueIndirect(initial.ContentType)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.ContentType = initial.ContentType
} else {
cDes.ContentType = des.ContentType
}
if dcl.BoolCanonicalize(des.ValidateSsl, initial.ValidateSsl) || dcl.IsZeroValue(des.ValidateSsl) {
cDes.ValidateSsl = initial.ValidateSsl
} else {
cDes.ValidateSsl = des.ValidateSsl
}
if dcl.StringCanonicalize(des.Body, initial.Body) || dcl.IsZeroValue(des.Body) {
cDes.Body = initial.Body
} else {
cDes.Body = des.Body
}
return cDes
}
func canonicalizeUptimeCheckConfigHttpCheckSlice(des, initial []UptimeCheckConfigHttpCheck, opts ...dcl.ApplyOption) []UptimeCheckConfigHttpCheck {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]UptimeCheckConfigHttpCheck, 0, len(des))
for _, d := range des {
cd := canonicalizeUptimeCheckConfigHttpCheck(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]UptimeCheckConfigHttpCheck, 0, len(des))
for i, d := range des {
cd := canonicalizeUptimeCheckConfigHttpCheck(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewUptimeCheckConfigHttpCheck(c *Client, des, nw *UptimeCheckConfigHttpCheck) *UptimeCheckConfigHttpCheck {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for UptimeCheckConfigHttpCheck while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
if dcl.IsZeroValue(nw.RequestMethod) {
nw.RequestMethod = UptimeCheckConfigHttpCheckRequestMethodEnumRef("GET")
}
if dcl.IsZeroValue(nw.Path) {
nw.Path = dcl.String("/")
}
if dcl.BoolCanonicalize(des.UseSsl, nw.UseSsl) {
nw.UseSsl = des.UseSsl
}
if dcl.StringCanonicalize(des.Path, nw.Path) {
nw.Path = des.Path
}
nw.AuthInfo = canonicalizeNewUptimeCheckConfigHttpCheckAuthInfo(c, des.AuthInfo, nw.AuthInfo)
if dcl.BoolCanonicalize(des.MaskHeaders, nw.MaskHeaders) {
nw.MaskHeaders = des.MaskHeaders
}
nw.Headers = des.Headers
if dcl.BoolCanonicalize(des.ValidateSsl, nw.ValidateSsl) {
nw.ValidateSsl = des.ValidateSsl
}
if dcl.StringCanonicalize(des.Body, nw.Body) {
nw.Body = des.Body
}
return nw
}
func canonicalizeNewUptimeCheckConfigHttpCheckSet(c *Client, des, nw []UptimeCheckConfigHttpCheck) []UptimeCheckConfigHttpCheck {
if des == nil {
return nw
}
// Find the elements in des that are also in nw and canonicalize them. Remove matched elements from nw.
var items []UptimeCheckConfigHttpCheck
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareUptimeCheckConfigHttpCheckNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewUptimeCheckConfigHttpCheck(c, &d, &nw[matchedIndex]))
nw = append(nw[:matchedIndex], nw[matchedIndex+1:]...)
}
}
// Also include elements in nw that are not matched in des.
items = append(items, nw...)
return items
}
func canonicalizeNewUptimeCheckConfigHttpCheckSlice(c *Client, des, nw []UptimeCheckConfigHttpCheck) []UptimeCheckConfigHttpCheck {
if des == nil {
return nw
}
// Lengths are unequal. A diff will occur later, so we shouldn't canonicalize.
// Return the original array.
if len(des) != len(nw) {
return nw
}
var items []UptimeCheckConfigHttpCheck
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewUptimeCheckConfigHttpCheck(c, &d, &n))
}
return items
}
func canonicalizeUptimeCheckConfigHttpCheckAuthInfo(des, initial *UptimeCheckConfigHttpCheckAuthInfo, opts ...dcl.ApplyOption) *UptimeCheckConfigHttpCheckAuthInfo {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &UptimeCheckConfigHttpCheckAuthInfo{}
if dcl.StringCanonicalize(des.Username, initial.Username) || dcl.IsZeroValue(des.Username) {
cDes.Username = initial.Username
} else {
cDes.Username = des.Username
}
if dcl.StringCanonicalize(des.Password, initial.Password) || dcl.IsZeroValue(des.Password) {
cDes.Password = initial.Password
} else {
cDes.Password = des.Password
}
return cDes
}
func canonicalizeUptimeCheckConfigHttpCheckAuthInfoSlice(des, initial []UptimeCheckConfigHttpCheckAuthInfo, opts ...dcl.ApplyOption) []UptimeCheckConfigHttpCheckAuthInfo {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]UptimeCheckConfigHttpCheckAuthInfo, 0, len(des))
for _, d := range des {
cd := canonicalizeUptimeCheckConfigHttpCheckAuthInfo(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]UptimeCheckConfigHttpCheckAuthInfo, 0, len(des))
for i, d := range des {
cd := canonicalizeUptimeCheckConfigHttpCheckAuthInfo(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewUptimeCheckConfigHttpCheckAuthInfo(c *Client, des, nw *UptimeCheckConfigHttpCheckAuthInfo) *UptimeCheckConfigHttpCheckAuthInfo {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for UptimeCheckConfigHttpCheckAuthInfo while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
if dcl.StringCanonicalize(des.Username, nw.Username) {
nw.Username = des.Username
}
nw.Password = des.Password
return nw
}
func canonicalizeNewUptimeCheckConfigHttpCheckAuthInfoSet(c *Client, des, nw []UptimeCheckConfigHttpCheckAuthInfo) []UptimeCheckConfigHttpCheckAuthInfo {
if des == nil {
return nw
}
// Find the elements in des that are also in nw and canonicalize them. Remove matched elements from nw.
var items []UptimeCheckConfigHttpCheckAuthInfo
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareUptimeCheckConfigHttpCheckAuthInfoNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewUptimeCheckConfigHttpCheckAuthInfo(c, &d, &nw[matchedIndex]))
nw = append(nw[:matchedIndex], nw[matchedIndex+1:]...)
}
}
// Also include elements in nw that are not matched in des.
items = append(items, nw...)
return items
}
func canonicalizeNewUptimeCheckConfigHttpCheckAuthInfoSlice(c *Client, des, nw []UptimeCheckConfigHttpCheckAuthInfo) []UptimeCheckConfigHttpCheckAuthInfo {
if des == nil {
return nw
}
// Lengths are unequal. A diff will occur later, so we shouldn't canonicalize.
// Return the original array.
if len(des) != len(nw) {
return nw
}
var items []UptimeCheckConfigHttpCheckAuthInfo
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewUptimeCheckConfigHttpCheckAuthInfo(c, &d, &n))
}
return items
}
func canonicalizeUptimeCheckConfigTcpCheck(des, initial *UptimeCheckConfigTcpCheck, opts ...dcl.ApplyOption) *UptimeCheckConfigTcpCheck {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &UptimeCheckConfigTcpCheck{}
if dcl.IsZeroValue(des.Port) || (dcl.IsEmptyValueIndirect(des.Port) && dcl.IsEmptyValueIndirect(initial.Port)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.Port = initial.Port
} else {
cDes.Port = des.Port
}
return cDes
}
func canonicalizeUptimeCheckConfigTcpCheckSlice(des, initial []UptimeCheckConfigTcpCheck, opts ...dcl.ApplyOption) []UptimeCheckConfigTcpCheck {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]UptimeCheckConfigTcpCheck, 0, len(des))
for _, d := range des {
cd := canonicalizeUptimeCheckConfigTcpCheck(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]UptimeCheckConfigTcpCheck, 0, len(des))
for i, d := range des {
cd := canonicalizeUptimeCheckConfigTcpCheck(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewUptimeCheckConfigTcpCheck(c *Client, des, nw *UptimeCheckConfigTcpCheck) *UptimeCheckConfigTcpCheck {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for UptimeCheckConfigTcpCheck while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
return nw
}
func canonicalizeNewUptimeCheckConfigTcpCheckSet(c *Client, des, nw []UptimeCheckConfigTcpCheck) []UptimeCheckConfigTcpCheck {
if des == nil {
return nw
}
// Find the elements in des that are also in nw and canonicalize them. Remove matched elements from nw.
var items []UptimeCheckConfigTcpCheck
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareUptimeCheckConfigTcpCheckNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewUptimeCheckConfigTcpCheck(c, &d, &nw[matchedIndex]))
nw = append(nw[:matchedIndex], nw[matchedIndex+1:]...)
}
}
// Also include elements in nw that are not matched in des.
items = append(items, nw...)
return items
}
func canonicalizeNewUptimeCheckConfigTcpCheckSlice(c *Client, des, nw []UptimeCheckConfigTcpCheck) []UptimeCheckConfigTcpCheck {
if des == nil {
return nw
}
// Lengths are unequal. A diff will occur later, so we shouldn't canonicalize.
// Return the original array.
if len(des) != len(nw) {
return nw
}
var items []UptimeCheckConfigTcpCheck
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewUptimeCheckConfigTcpCheck(c, &d, &n))
}
return items
}
func canonicalizeUptimeCheckConfigContentMatchers(des, initial *UptimeCheckConfigContentMatchers, opts ...dcl.ApplyOption) *UptimeCheckConfigContentMatchers {
if des == nil {
return initial
}
if des.empty {
return des
}
if dcl.IsZeroValue(des.Matcher) {
des.Matcher = UptimeCheckConfigContentMatchersMatcherEnumRef("CONTAINS_STRING")
}
if initial == nil {
return des
}
cDes := &UptimeCheckConfigContentMatchers{}
if dcl.StringCanonicalize(des.Content, initial.Content) || dcl.IsZeroValue(des.Content) {
cDes.Content = initial.Content
} else {
cDes.Content = des.Content
}
if dcl.IsZeroValue(des.Matcher) || (dcl.IsEmptyValueIndirect(des.Matcher) && dcl.IsEmptyValueIndirect(initial.Matcher)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.Matcher = initial.Matcher
} else {
cDes.Matcher = des.Matcher
}
return cDes
}
func canonicalizeUptimeCheckConfigContentMatchersSlice(des, initial []UptimeCheckConfigContentMatchers, opts ...dcl.ApplyOption) []UptimeCheckConfigContentMatchers {
if des == nil {
return initial
}
if len(des) != len(initial) {
items := make([]UptimeCheckConfigContentMatchers, 0, len(des))
for _, d := range des {
cd := canonicalizeUptimeCheckConfigContentMatchers(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]UptimeCheckConfigContentMatchers, 0, len(des))
for i, d := range des {
cd := canonicalizeUptimeCheckConfigContentMatchers(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewUptimeCheckConfigContentMatchers(c *Client, des, nw *UptimeCheckConfigContentMatchers) *UptimeCheckConfigContentMatchers {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for UptimeCheckConfigContentMatchers while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
if dcl.IsZeroValue(nw.Matcher) {
nw.Matcher = UptimeCheckConfigContentMatchersMatcherEnumRef("CONTAINS_STRING")
}
if dcl.StringCanonicalize(des.Content, nw.Content) {
nw.Content = des.Content
}
return nw
}
func canonicalizeNewUptimeCheckConfigContentMatchersSet(c *Client, des, nw []UptimeCheckConfigContentMatchers) []UptimeCheckConfigContentMatchers {
if des == nil {
return nw
}
// Find the elements in des that are also in nw and canonicalize them. Remove matched elements from nw.
var items []UptimeCheckConfigContentMatchers
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareUptimeCheckConfigContentMatchersNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewUptimeCheckConfigContentMatchers(c, &d, &nw[matchedIndex]))
nw = append(nw[:matchedIndex], nw[matchedIndex+1:]...)
}
}
// Also include elements in nw that are not matched in des.
items = append(items, nw...)
return items
}
func canonicalizeNewUptimeCheckConfigContentMatchersSlice(c *Client, des, nw []UptimeCheckConfigContentMatchers) []UptimeCheckConfigContentMatchers {
if des == nil {
return nw
}
// Lengths are unequal. A diff will occur later, so we shouldn't canonicalize.
// Return the original array.
if len(des) != len(nw) {
return nw
}
var items []UptimeCheckConfigContentMatchers
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewUptimeCheckConfigContentMatchers(c, &d, &n))
}
return items
}
// The differ returns a list of diffs, along with a list of operations that should be taken
// to remedy them. Right now, it does not attempt to consolidate operations - if several
// fields can be fixed with a patch update, it will perform the patch several times.
// Diffs on some fields will be ignored if the `desired` state has an empty (nil)
// value. This empty value indicates that the user does not care about the state for
// the field. Empty fields on the actual object will cause diffs.
// TODO(magic-modules-eng): for efficiency in some resources, add batching.
func diffUptimeCheckConfig(c *Client, desired, actual *UptimeCheckConfig, opts ...dcl.ApplyOption) ([]*dcl.FieldDiff, error) {
if desired == nil || actual == nil {
return nil, fmt.Errorf("nil resource passed to diff - always a programming error: %#v, %#v", desired, actual)
}
c.Config.Logger.Infof("Diff function called with desired state: %v", desired)
c.Config.Logger.Infof("Diff function called with actual state: %v", actual)
var fn dcl.FieldName
var newDiffs []*dcl.FieldDiff
// New style diffs.
if ds, err := dcl.Diff(desired.Name, actual.Name, dcl.DiffInfo{Type: "ReferenceType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Name")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.DisplayName, actual.DisplayName, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("DisplayName")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.MonitoredResource, actual.MonitoredResource, dcl.DiffInfo{ObjectFunction: compareUptimeCheckConfigMonitoredResourceNewStyle, EmptyObject: EmptyUptimeCheckConfigMonitoredResource, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("MonitoredResource")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.ResourceGroup, actual.ResourceGroup, dcl.DiffInfo{ObjectFunction: compareUptimeCheckConfigResourceGroupNewStyle, EmptyObject: EmptyUptimeCheckConfigResourceGroup, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("ResourceGroup")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.HttpCheck, actual.HttpCheck, dcl.DiffInfo{ObjectFunction: compareUptimeCheckConfigHttpCheckNewStyle, EmptyObject: EmptyUptimeCheckConfigHttpCheck, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("HttpCheck")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.TcpCheck, actual.TcpCheck, dcl.DiffInfo{ObjectFunction: compareUptimeCheckConfigTcpCheckNewStyle, EmptyObject: EmptyUptimeCheckConfigTcpCheck, OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("TcpCheck")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.Period, actual.Period, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Period")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.Timeout, actual.Timeout, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Timeout")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.ContentMatchers, actual.ContentMatchers, dcl.DiffInfo{ObjectFunction: compareUptimeCheckConfigContentMatchersNewStyle, EmptyObject: EmptyUptimeCheckConfigContentMatchers, OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("ContentMatchers")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.SelectedRegions, actual.SelectedRegions, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("SelectedRegions")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.Project, actual.Project, dcl.DiffInfo{Type: "ReferenceType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Project")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if len(newDiffs) > 0 {
c.Config.Logger.Infof("Diff function found diffs: %v", newDiffs)
}
return newDiffs, nil
}
func compareUptimeCheckConfigMonitoredResourceNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*UptimeCheckConfigMonitoredResource)
if !ok {
desiredNotPointer, ok := d.(UptimeCheckConfigMonitoredResource)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigMonitoredResource or *UptimeCheckConfigMonitoredResource", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*UptimeCheckConfigMonitoredResource)
if !ok {
actualNotPointer, ok := a.(UptimeCheckConfigMonitoredResource)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigMonitoredResource", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Type, actual.Type, dcl.DiffInfo{OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Type")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.FilterLabels, actual.FilterLabels, dcl.DiffInfo{OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Labels")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareUptimeCheckConfigResourceGroupNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*UptimeCheckConfigResourceGroup)
if !ok {
desiredNotPointer, ok := d.(UptimeCheckConfigResourceGroup)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigResourceGroup or *UptimeCheckConfigResourceGroup", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*UptimeCheckConfigResourceGroup)
if !ok {
actualNotPointer, ok := a.(UptimeCheckConfigResourceGroup)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigResourceGroup", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.GroupId, actual.GroupId, dcl.DiffInfo{Type: "ReferenceType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("GroupId")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.ResourceType, actual.ResourceType, dcl.DiffInfo{Type: "EnumType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("ResourceType")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareUptimeCheckConfigHttpCheckNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*UptimeCheckConfigHttpCheck)
if !ok {
desiredNotPointer, ok := d.(UptimeCheckConfigHttpCheck)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigHttpCheck or *UptimeCheckConfigHttpCheck", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*UptimeCheckConfigHttpCheck)
if !ok {
actualNotPointer, ok := a.(UptimeCheckConfigHttpCheck)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigHttpCheck", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.RequestMethod, actual.RequestMethod, dcl.DiffInfo{Type: "EnumType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("RequestMethod")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.UseSsl, actual.UseSsl, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("UseSsl")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Path, actual.Path, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Path")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Port, actual.Port, dcl.DiffInfo{ServerDefault: true, OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Port")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.AuthInfo, actual.AuthInfo, dcl.DiffInfo{ObjectFunction: compareUptimeCheckConfigHttpCheckAuthInfoNewStyle, EmptyObject: EmptyUptimeCheckConfigHttpCheckAuthInfo, OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("AuthInfo")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.MaskHeaders, actual.MaskHeaders, dcl.DiffInfo{OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("MaskHeaders")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Headers, actual.Headers, dcl.DiffInfo{ServerDefault: true, OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Headers")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.ContentType, actual.ContentType, dcl.DiffInfo{Type: "EnumType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("ContentType")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.ValidateSsl, actual.ValidateSsl, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("ValidateSsl")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Body, actual.Body, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Body")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareUptimeCheckConfigHttpCheckAuthInfoNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*UptimeCheckConfigHttpCheckAuthInfo)
if !ok {
desiredNotPointer, ok := d.(UptimeCheckConfigHttpCheckAuthInfo)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigHttpCheckAuthInfo or *UptimeCheckConfigHttpCheckAuthInfo", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*UptimeCheckConfigHttpCheckAuthInfo)
if !ok {
actualNotPointer, ok := a.(UptimeCheckConfigHttpCheckAuthInfo)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigHttpCheckAuthInfo", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Username, actual.Username, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Username")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Password, actual.Password, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateUptimeCheckConfigUpdateUptimeCheckConfigOperation")}, fn.AddNest("Password")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareUptimeCheckConfigTcpCheckNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*UptimeCheckConfigTcpCheck)
if !ok {
desiredNotPointer, ok := d.(UptimeCheckConfigTcpCheck)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigTcpCheck or *UptimeCheckConfigTcpCheck", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*UptimeCheckConfigTcpCheck)
if !ok {
actualNotPointer, ok := a.(UptimeCheckConfigTcpCheck)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigTcpCheck", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Port, actual.Port, dcl.DiffInfo{OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Port")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareUptimeCheckConfigContentMatchersNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*UptimeCheckConfigContentMatchers)
if !ok {
desiredNotPointer, ok := d.(UptimeCheckConfigContentMatchers)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigContentMatchers or *UptimeCheckConfigContentMatchers", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*UptimeCheckConfigContentMatchers)
if !ok {
actualNotPointer, ok := a.(UptimeCheckConfigContentMatchers)
if !ok {
return nil, fmt.Errorf("obj %v is not a UptimeCheckConfigContentMatchers", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Content, actual.Content, dcl.DiffInfo{OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Content")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Matcher, actual.Matcher, dcl.DiffInfo{Type: "EnumType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Matcher")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
// urlNormalized returns a copy of the resource struct with values normalized
// for URL substitutions. For instance, it converts long-form self-links to
// short-form so they can be substituted in.
func (r *UptimeCheckConfig) urlNormalized() *UptimeCheckConfig {
normalized := dcl.Copy(*r).(UptimeCheckConfig)
normalized.Name = dcl.SelfLinkToName(r.Name)
normalized.DisplayName = dcl.SelfLinkToName(r.DisplayName)
normalized.Period = dcl.SelfLinkToName(r.Period)
normalized.Timeout = dcl.SelfLinkToName(r.Timeout)
normalized.Project = dcl.SelfLinkToName(r.Project)
return &normalized
}
func (r *UptimeCheckConfig) updateURL(userBasePath, updateName string) (string, error) {
nr := r.urlNormalized()
if updateName == "UpdateUptimeCheckConfig" {
fields := map[string]interface{}{
"project": dcl.ValueOrEmptyString(nr.Project),
"name": dcl.ValueOrEmptyString(nr.Name),
}
return dcl.URL("projects/{{project}}/uptimeCheckConfigs/{{name}}", nr.basePath(), userBasePath, fields), nil
}
return "", fmt.Errorf("unknown update name: %s", updateName)
}
// marshal encodes the UptimeCheckConfig resource into JSON for a Create request, and
// performs transformations from the resource schema to the API schema if
// necessary.
func (r *UptimeCheckConfig) marshal(c *Client) ([]byte, error) {
m, err := expandUptimeCheckConfig(c, r)
if err != nil {
return nil, fmt.Errorf("error marshalling UptimeCheckConfig: %w", err)
}
return json.Marshal(m)
}
// unmarshalUptimeCheckConfig decodes JSON responses into the UptimeCheckConfig resource schema.
func unmarshalUptimeCheckConfig(b []byte, c *Client, res *UptimeCheckConfig) (*UptimeCheckConfig, error) {
var m map[string]interface{}
if err := json.Unmarshal(b, &m); err != nil {
return nil, err
}
return unmarshalMapUptimeCheckConfig(m, c, res)
}
func unmarshalMapUptimeCheckConfig(m map[string]interface{}, c *Client, res *UptimeCheckConfig) (*UptimeCheckConfig, error) {
flattened := flattenUptimeCheckConfig(c, m, res)
if flattened == nil {
return nil, fmt.Errorf("attempted to flatten empty json object")
}
return flattened, nil
}
// expandUptimeCheckConfig expands UptimeCheckConfig into a JSON request object.
func expandUptimeCheckConfig(c *Client, f *UptimeCheckConfig) (map[string]interface{}, error) {
m := make(map[string]interface{})
res := f
_ = res
if v := f.Name; dcl.ValueShouldBeSent(v) {
m["name"] = v
}
if v := f.DisplayName; dcl.ValueShouldBeSent(v) {
m["displayName"] = v
}
if v, err := expandUptimeCheckConfigMonitoredResource(c, f.MonitoredResource, res); err != nil {
return nil, fmt.Errorf("error expanding MonitoredResource into monitoredResource: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["monitoredResource"] = v
}
if v, err := expandUptimeCheckConfigResourceGroup(c, f.ResourceGroup, res); err != nil {
return nil, fmt.Errorf("error expanding ResourceGroup into resourceGroup: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["resourceGroup"] = v
}
if v, err := expandUptimeCheckConfigHttpCheck(c, f.HttpCheck, res); err != nil {
return nil, fmt.Errorf("error expanding HttpCheck into httpCheck: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["httpCheck"] = v
}
if v, err := expandUptimeCheckConfigTcpCheck(c, f.TcpCheck, res); err != nil {
return nil, fmt.Errorf("error expanding TcpCheck into tcpCheck: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["tcpCheck"] = v
}
if v := f.Period; dcl.ValueShouldBeSent(v) {
m["period"] = v
}
if v := f.Timeout; dcl.ValueShouldBeSent(v) {
m["timeout"] = v
}
if v, err := expandUptimeCheckConfigContentMatchersSlice(c, f.ContentMatchers, res); err != nil {
return nil, fmt.Errorf("error expanding ContentMatchers into contentMatchers: %w", err)
} else if v != nil {
m["contentMatchers"] = v
}
if v := f.SelectedRegions; v != nil {
m["selectedRegions"] = v
}
if v, err := dcl.EmptyValue(); err != nil {
return nil, fmt.Errorf("error expanding Project into project: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["project"] = v
}
return m, nil
}
// flattenUptimeCheckConfig flattens UptimeCheckConfig from a JSON request object into the
// UptimeCheckConfig type.
func flattenUptimeCheckConfig(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfig {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
if len(m) == 0 {
return nil
}
resultRes := &UptimeCheckConfig{}
resultRes.Name = dcl.SelfLinkToName(dcl.FlattenString(m["name"]))
resultRes.DisplayName = dcl.FlattenString(m["displayName"])
resultRes.MonitoredResource = flattenUptimeCheckConfigMonitoredResource(c, m["monitoredResource"], res)
resultRes.ResourceGroup = flattenUptimeCheckConfigResourceGroup(c, m["resourceGroup"], res)
resultRes.HttpCheck = flattenUptimeCheckConfigHttpCheck(c, m["httpCheck"], res)
resultRes.TcpCheck = flattenUptimeCheckConfigTcpCheck(c, m["tcpCheck"], res)
resultRes.Period = dcl.FlattenString(m["period"])
if _, ok := m["period"]; !ok {
c.Config.Logger.Info("Using default value for period")
resultRes.Period = dcl.String("60s")
}
resultRes.Timeout = dcl.FlattenString(m["timeout"])
resultRes.ContentMatchers = flattenUptimeCheckConfigContentMatchersSlice(c, m["contentMatchers"], res)
resultRes.SelectedRegions = dcl.FlattenStringSlice(m["selectedRegions"])
resultRes.Project = dcl.FlattenString(m["project"])
return resultRes
}
// expandUptimeCheckConfigMonitoredResourceMap expands the contents of UptimeCheckConfigMonitoredResource into a JSON
// request object.
func expandUptimeCheckConfigMonitoredResourceMap(c *Client, f map[string]UptimeCheckConfigMonitoredResource, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandUptimeCheckConfigMonitoredResource(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandUptimeCheckConfigMonitoredResourceSlice expands the contents of UptimeCheckConfigMonitoredResource into a JSON
// request object.
func expandUptimeCheckConfigMonitoredResourceSlice(c *Client, f []UptimeCheckConfigMonitoredResource, res *UptimeCheckConfig) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandUptimeCheckConfigMonitoredResource(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenUptimeCheckConfigMonitoredResourceMap flattens the contents of UptimeCheckConfigMonitoredResource from a JSON
// response object.
func flattenUptimeCheckConfigMonitoredResourceMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigMonitoredResource {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigMonitoredResource{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigMonitoredResource{}
}
items := make(map[string]UptimeCheckConfigMonitoredResource)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigMonitoredResource(c, item.(map[string]interface{}), res)
}
return items
}
// flattenUptimeCheckConfigMonitoredResourceSlice flattens the contents of UptimeCheckConfigMonitoredResource from a JSON
// response object.
func flattenUptimeCheckConfigMonitoredResourceSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigMonitoredResource {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigMonitoredResource{}
}
if len(a) == 0 {
return []UptimeCheckConfigMonitoredResource{}
}
items := make([]UptimeCheckConfigMonitoredResource, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigMonitoredResource(c, item.(map[string]interface{}), res))
}
return items
}
// expandUptimeCheckConfigMonitoredResource expands an instance of UptimeCheckConfigMonitoredResource into a JSON
// request object.
func expandUptimeCheckConfigMonitoredResource(c *Client, f *UptimeCheckConfigMonitoredResource, res *UptimeCheckConfig) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.Type; !dcl.IsEmptyValueIndirect(v) {
m["type"] = v
}
if v := f.FilterLabels; !dcl.IsEmptyValueIndirect(v) {
m["labels"] = v
}
return m, nil
}
// flattenUptimeCheckConfigMonitoredResource flattens an instance of UptimeCheckConfigMonitoredResource from a JSON
// response object.
func flattenUptimeCheckConfigMonitoredResource(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfigMonitoredResource {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &UptimeCheckConfigMonitoredResource{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyUptimeCheckConfigMonitoredResource
}
r.Type = dcl.FlattenString(m["type"])
r.FilterLabels = dcl.FlattenKeyValuePairs(m["labels"])
return r
}
// expandUptimeCheckConfigResourceGroupMap expands the contents of UptimeCheckConfigResourceGroup into a JSON
// request object.
func expandUptimeCheckConfigResourceGroupMap(c *Client, f map[string]UptimeCheckConfigResourceGroup, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandUptimeCheckConfigResourceGroup(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandUptimeCheckConfigResourceGroupSlice expands the contents of UptimeCheckConfigResourceGroup into a JSON
// request object.
func expandUptimeCheckConfigResourceGroupSlice(c *Client, f []UptimeCheckConfigResourceGroup, res *UptimeCheckConfig) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandUptimeCheckConfigResourceGroup(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenUptimeCheckConfigResourceGroupMap flattens the contents of UptimeCheckConfigResourceGroup from a JSON
// response object.
func flattenUptimeCheckConfigResourceGroupMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigResourceGroup {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigResourceGroup{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigResourceGroup{}
}
items := make(map[string]UptimeCheckConfigResourceGroup)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigResourceGroup(c, item.(map[string]interface{}), res)
}
return items
}
// flattenUptimeCheckConfigResourceGroupSlice flattens the contents of UptimeCheckConfigResourceGroup from a JSON
// response object.
func flattenUptimeCheckConfigResourceGroupSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigResourceGroup {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigResourceGroup{}
}
if len(a) == 0 {
return []UptimeCheckConfigResourceGroup{}
}
items := make([]UptimeCheckConfigResourceGroup, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigResourceGroup(c, item.(map[string]interface{}), res))
}
return items
}
// expandUptimeCheckConfigResourceGroup expands an instance of UptimeCheckConfigResourceGroup into a JSON
// request object.
func expandUptimeCheckConfigResourceGroup(c *Client, f *UptimeCheckConfigResourceGroup, res *UptimeCheckConfig) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v, err := dcl.SelfLinkToNameExpander(f.GroupId); err != nil {
return nil, fmt.Errorf("error expanding GroupId into groupId: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["groupId"] = v
}
if v := f.ResourceType; !dcl.IsEmptyValueIndirect(v) {
m["resourceType"] = v
}
return m, nil
}
// flattenUptimeCheckConfigResourceGroup flattens an instance of UptimeCheckConfigResourceGroup from a JSON
// response object.
func flattenUptimeCheckConfigResourceGroup(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfigResourceGroup {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &UptimeCheckConfigResourceGroup{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyUptimeCheckConfigResourceGroup
}
r.GroupId = dcl.FlattenString(m["groupId"])
r.ResourceType = flattenUptimeCheckConfigResourceGroupResourceTypeEnum(m["resourceType"])
return r
}
// expandUptimeCheckConfigHttpCheckMap expands the contents of UptimeCheckConfigHttpCheck into a JSON
// request object.
func expandUptimeCheckConfigHttpCheckMap(c *Client, f map[string]UptimeCheckConfigHttpCheck, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandUptimeCheckConfigHttpCheck(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandUptimeCheckConfigHttpCheckSlice expands the contents of UptimeCheckConfigHttpCheck into a JSON
// request object.
func expandUptimeCheckConfigHttpCheckSlice(c *Client, f []UptimeCheckConfigHttpCheck, res *UptimeCheckConfig) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandUptimeCheckConfigHttpCheck(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenUptimeCheckConfigHttpCheckMap flattens the contents of UptimeCheckConfigHttpCheck from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigHttpCheck {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigHttpCheck{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigHttpCheck{}
}
items := make(map[string]UptimeCheckConfigHttpCheck)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigHttpCheck(c, item.(map[string]interface{}), res)
}
return items
}
// flattenUptimeCheckConfigHttpCheckSlice flattens the contents of UptimeCheckConfigHttpCheck from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigHttpCheck {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigHttpCheck{}
}
if len(a) == 0 {
return []UptimeCheckConfigHttpCheck{}
}
items := make([]UptimeCheckConfigHttpCheck, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigHttpCheck(c, item.(map[string]interface{}), res))
}
return items
}
// expandUptimeCheckConfigHttpCheck expands an instance of UptimeCheckConfigHttpCheck into a JSON
// request object.
func expandUptimeCheckConfigHttpCheck(c *Client, f *UptimeCheckConfigHttpCheck, res *UptimeCheckConfig) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.RequestMethod; !dcl.IsEmptyValueIndirect(v) {
m["requestMethod"] = v
}
if v := f.UseSsl; !dcl.IsEmptyValueIndirect(v) {
m["useSsl"] = v
}
if v := f.Path; !dcl.IsEmptyValueIndirect(v) {
m["path"] = v
}
if v := f.Port; !dcl.IsEmptyValueIndirect(v) {
m["port"] = v
}
if v, err := expandUptimeCheckConfigHttpCheckAuthInfo(c, f.AuthInfo, res); err != nil {
return nil, fmt.Errorf("error expanding AuthInfo into authInfo: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["authInfo"] = v
}
if v := f.MaskHeaders; !dcl.IsEmptyValueIndirect(v) {
m["maskHeaders"] = v
}
if v := f.Headers; !dcl.IsEmptyValueIndirect(v) {
m["headers"] = v
}
if v := f.ContentType; !dcl.IsEmptyValueIndirect(v) {
m["contentType"] = v
}
if v := f.ValidateSsl; !dcl.IsEmptyValueIndirect(v) {
m["validateSsl"] = v
}
if v := f.Body; !dcl.IsEmptyValueIndirect(v) {
m["body"] = v
}
return m, nil
}
// flattenUptimeCheckConfigHttpCheck flattens an instance of UptimeCheckConfigHttpCheck from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheck(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfigHttpCheck {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &UptimeCheckConfigHttpCheck{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyUptimeCheckConfigHttpCheck
}
r.RequestMethod = flattenUptimeCheckConfigHttpCheckRequestMethodEnum(m["requestMethod"])
if dcl.IsEmptyValueIndirect(m["requestMethod"]) {
c.Config.Logger.Info("Using default value for requestMethod.")
r.RequestMethod = UptimeCheckConfigHttpCheckRequestMethodEnumRef("GET")
}
r.UseSsl = dcl.FlattenBool(m["useSsl"])
r.Path = dcl.FlattenString(m["path"])
if dcl.IsEmptyValueIndirect(m["path"]) {
c.Config.Logger.Info("Using default value for path.")
r.Path = dcl.String("/")
}
r.Port = dcl.FlattenInteger(m["port"])
r.AuthInfo = flattenUptimeCheckConfigHttpCheckAuthInfo(c, m["authInfo"], res)
r.MaskHeaders = dcl.FlattenBool(m["maskHeaders"])
r.Headers = dcl.FlattenKeyValuePairs(m["headers"])
r.ContentType = flattenUptimeCheckConfigHttpCheckContentTypeEnum(m["contentType"])
r.ValidateSsl = dcl.FlattenBool(m["validateSsl"])
r.Body = dcl.FlattenString(m["body"])
return r
}
// expandUptimeCheckConfigHttpCheckAuthInfoMap expands the contents of UptimeCheckConfigHttpCheckAuthInfo into a JSON
// request object.
func expandUptimeCheckConfigHttpCheckAuthInfoMap(c *Client, f map[string]UptimeCheckConfigHttpCheckAuthInfo, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandUptimeCheckConfigHttpCheckAuthInfo(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandUptimeCheckConfigHttpCheckAuthInfoSlice expands the contents of UptimeCheckConfigHttpCheckAuthInfo into a JSON
// request object.
func expandUptimeCheckConfigHttpCheckAuthInfoSlice(c *Client, f []UptimeCheckConfigHttpCheckAuthInfo, res *UptimeCheckConfig) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandUptimeCheckConfigHttpCheckAuthInfo(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenUptimeCheckConfigHttpCheckAuthInfoMap flattens the contents of UptimeCheckConfigHttpCheckAuthInfo from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckAuthInfoMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigHttpCheckAuthInfo {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigHttpCheckAuthInfo{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigHttpCheckAuthInfo{}
}
items := make(map[string]UptimeCheckConfigHttpCheckAuthInfo)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigHttpCheckAuthInfo(c, item.(map[string]interface{}), res)
}
return items
}
// flattenUptimeCheckConfigHttpCheckAuthInfoSlice flattens the contents of UptimeCheckConfigHttpCheckAuthInfo from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckAuthInfoSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigHttpCheckAuthInfo {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigHttpCheckAuthInfo{}
}
if len(a) == 0 {
return []UptimeCheckConfigHttpCheckAuthInfo{}
}
items := make([]UptimeCheckConfigHttpCheckAuthInfo, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigHttpCheckAuthInfo(c, item.(map[string]interface{}), res))
}
return items
}
// expandUptimeCheckConfigHttpCheckAuthInfo expands an instance of UptimeCheckConfigHttpCheckAuthInfo into a JSON
// request object.
func expandUptimeCheckConfigHttpCheckAuthInfo(c *Client, f *UptimeCheckConfigHttpCheckAuthInfo, res *UptimeCheckConfig) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.Username; !dcl.IsEmptyValueIndirect(v) {
m["username"] = v
}
if v := f.Password; !dcl.IsEmptyValueIndirect(v) {
m["password"] = v
}
return m, nil
}
// flattenUptimeCheckConfigHttpCheckAuthInfo flattens an instance of UptimeCheckConfigHttpCheckAuthInfo from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckAuthInfo(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfigHttpCheckAuthInfo {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &UptimeCheckConfigHttpCheckAuthInfo{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyUptimeCheckConfigHttpCheckAuthInfo
}
r.Username = dcl.FlattenString(m["username"])
r.Password = dcl.FlattenString(m["password"])
return r
}
// expandUptimeCheckConfigTcpCheckMap expands the contents of UptimeCheckConfigTcpCheck into a JSON
// request object.
func expandUptimeCheckConfigTcpCheckMap(c *Client, f map[string]UptimeCheckConfigTcpCheck, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandUptimeCheckConfigTcpCheck(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandUptimeCheckConfigTcpCheckSlice expands the contents of UptimeCheckConfigTcpCheck into a JSON
// request object.
func expandUptimeCheckConfigTcpCheckSlice(c *Client, f []UptimeCheckConfigTcpCheck, res *UptimeCheckConfig) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandUptimeCheckConfigTcpCheck(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenUptimeCheckConfigTcpCheckMap flattens the contents of UptimeCheckConfigTcpCheck from a JSON
// response object.
func flattenUptimeCheckConfigTcpCheckMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigTcpCheck {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigTcpCheck{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigTcpCheck{}
}
items := make(map[string]UptimeCheckConfigTcpCheck)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigTcpCheck(c, item.(map[string]interface{}), res)
}
return items
}
// flattenUptimeCheckConfigTcpCheckSlice flattens the contents of UptimeCheckConfigTcpCheck from a JSON
// response object.
func flattenUptimeCheckConfigTcpCheckSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigTcpCheck {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigTcpCheck{}
}
if len(a) == 0 {
return []UptimeCheckConfigTcpCheck{}
}
items := make([]UptimeCheckConfigTcpCheck, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigTcpCheck(c, item.(map[string]interface{}), res))
}
return items
}
// expandUptimeCheckConfigTcpCheck expands an instance of UptimeCheckConfigTcpCheck into a JSON
// request object.
func expandUptimeCheckConfigTcpCheck(c *Client, f *UptimeCheckConfigTcpCheck, res *UptimeCheckConfig) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.Port; !dcl.IsEmptyValueIndirect(v) {
m["port"] = v
}
return m, nil
}
// flattenUptimeCheckConfigTcpCheck flattens an instance of UptimeCheckConfigTcpCheck from a JSON
// response object.
func flattenUptimeCheckConfigTcpCheck(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfigTcpCheck {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &UptimeCheckConfigTcpCheck{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyUptimeCheckConfigTcpCheck
}
r.Port = dcl.FlattenInteger(m["port"])
return r
}
// expandUptimeCheckConfigContentMatchersMap expands the contents of UptimeCheckConfigContentMatchers into a JSON
// request object.
func expandUptimeCheckConfigContentMatchersMap(c *Client, f map[string]UptimeCheckConfigContentMatchers, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandUptimeCheckConfigContentMatchers(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandUptimeCheckConfigContentMatchersSlice expands the contents of UptimeCheckConfigContentMatchers into a JSON
// request object.
func expandUptimeCheckConfigContentMatchersSlice(c *Client, f []UptimeCheckConfigContentMatchers, res *UptimeCheckConfig) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandUptimeCheckConfigContentMatchers(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenUptimeCheckConfigContentMatchersMap flattens the contents of UptimeCheckConfigContentMatchers from a JSON
// response object.
func flattenUptimeCheckConfigContentMatchersMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigContentMatchers {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigContentMatchers{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigContentMatchers{}
}
items := make(map[string]UptimeCheckConfigContentMatchers)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigContentMatchers(c, item.(map[string]interface{}), res)
}
return items
}
// flattenUptimeCheckConfigContentMatchersSlice flattens the contents of UptimeCheckConfigContentMatchers from a JSON
// response object.
func flattenUptimeCheckConfigContentMatchersSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigContentMatchers {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigContentMatchers{}
}
if len(a) == 0 {
return []UptimeCheckConfigContentMatchers{}
}
items := make([]UptimeCheckConfigContentMatchers, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigContentMatchers(c, item.(map[string]interface{}), res))
}
return items
}
// expandUptimeCheckConfigContentMatchers expands an instance of UptimeCheckConfigContentMatchers into a JSON
// request object.
func expandUptimeCheckConfigContentMatchers(c *Client, f *UptimeCheckConfigContentMatchers, res *UptimeCheckConfig) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
m := make(map[string]interface{})
if v := f.Content; !dcl.IsEmptyValueIndirect(v) {
m["content"] = v
}
if v := f.Matcher; !dcl.IsEmptyValueIndirect(v) {
m["matcher"] = v
}
return m, nil
}
// flattenUptimeCheckConfigContentMatchers flattens an instance of UptimeCheckConfigContentMatchers from a JSON
// response object.
func flattenUptimeCheckConfigContentMatchers(c *Client, i interface{}, res *UptimeCheckConfig) *UptimeCheckConfigContentMatchers {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &UptimeCheckConfigContentMatchers{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyUptimeCheckConfigContentMatchers
}
r.Content = dcl.FlattenString(m["content"])
r.Matcher = flattenUptimeCheckConfigContentMatchersMatcherEnum(m["matcher"])
if dcl.IsEmptyValueIndirect(m["matcher"]) {
c.Config.Logger.Info("Using default value for matcher.")
r.Matcher = UptimeCheckConfigContentMatchersMatcherEnumRef("CONTAINS_STRING")
}
return r
}
// flattenUptimeCheckConfigResourceGroupResourceTypeEnumMap flattens the contents of UptimeCheckConfigResourceGroupResourceTypeEnum from a JSON
// response object.
func flattenUptimeCheckConfigResourceGroupResourceTypeEnumMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigResourceGroupResourceTypeEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigResourceGroupResourceTypeEnum{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigResourceGroupResourceTypeEnum{}
}
items := make(map[string]UptimeCheckConfigResourceGroupResourceTypeEnum)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigResourceGroupResourceTypeEnum(item.(interface{}))
}
return items
}
// flattenUptimeCheckConfigResourceGroupResourceTypeEnumSlice flattens the contents of UptimeCheckConfigResourceGroupResourceTypeEnum from a JSON
// response object.
func flattenUptimeCheckConfigResourceGroupResourceTypeEnumSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigResourceGroupResourceTypeEnum {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigResourceGroupResourceTypeEnum{}
}
if len(a) == 0 {
return []UptimeCheckConfigResourceGroupResourceTypeEnum{}
}
items := make([]UptimeCheckConfigResourceGroupResourceTypeEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigResourceGroupResourceTypeEnum(item.(interface{})))
}
return items
}
// flattenUptimeCheckConfigResourceGroupResourceTypeEnum asserts that an interface is a string, and returns a
// pointer to a *UptimeCheckConfigResourceGroupResourceTypeEnum with the same value as that string.
func flattenUptimeCheckConfigResourceGroupResourceTypeEnum(i interface{}) *UptimeCheckConfigResourceGroupResourceTypeEnum {
s, ok := i.(string)
if !ok {
return nil
}
return UptimeCheckConfigResourceGroupResourceTypeEnumRef(s)
}
// flattenUptimeCheckConfigHttpCheckRequestMethodEnumMap flattens the contents of UptimeCheckConfigHttpCheckRequestMethodEnum from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckRequestMethodEnumMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigHttpCheckRequestMethodEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigHttpCheckRequestMethodEnum{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigHttpCheckRequestMethodEnum{}
}
items := make(map[string]UptimeCheckConfigHttpCheckRequestMethodEnum)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigHttpCheckRequestMethodEnum(item.(interface{}))
}
return items
}
// flattenUptimeCheckConfigHttpCheckRequestMethodEnumSlice flattens the contents of UptimeCheckConfigHttpCheckRequestMethodEnum from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckRequestMethodEnumSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigHttpCheckRequestMethodEnum {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigHttpCheckRequestMethodEnum{}
}
if len(a) == 0 {
return []UptimeCheckConfigHttpCheckRequestMethodEnum{}
}
items := make([]UptimeCheckConfigHttpCheckRequestMethodEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigHttpCheckRequestMethodEnum(item.(interface{})))
}
return items
}
// flattenUptimeCheckConfigHttpCheckRequestMethodEnum asserts that an interface is a string, and returns a
// pointer to a *UptimeCheckConfigHttpCheckRequestMethodEnum with the same value as that string.
func flattenUptimeCheckConfigHttpCheckRequestMethodEnum(i interface{}) *UptimeCheckConfigHttpCheckRequestMethodEnum {
s, ok := i.(string)
if !ok {
return nil
}
return UptimeCheckConfigHttpCheckRequestMethodEnumRef(s)
}
// flattenUptimeCheckConfigHttpCheckContentTypeEnumMap flattens the contents of UptimeCheckConfigHttpCheckContentTypeEnum from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckContentTypeEnumMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigHttpCheckContentTypeEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigHttpCheckContentTypeEnum{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigHttpCheckContentTypeEnum{}
}
items := make(map[string]UptimeCheckConfigHttpCheckContentTypeEnum)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigHttpCheckContentTypeEnum(item.(interface{}))
}
return items
}
// flattenUptimeCheckConfigHttpCheckContentTypeEnumSlice flattens the contents of UptimeCheckConfigHttpCheckContentTypeEnum from a JSON
// response object.
func flattenUptimeCheckConfigHttpCheckContentTypeEnumSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigHttpCheckContentTypeEnum {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigHttpCheckContentTypeEnum{}
}
if len(a) == 0 {
return []UptimeCheckConfigHttpCheckContentTypeEnum{}
}
items := make([]UptimeCheckConfigHttpCheckContentTypeEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigHttpCheckContentTypeEnum(item.(interface{})))
}
return items
}
// flattenUptimeCheckConfigHttpCheckContentTypeEnum asserts that an interface is a string, and returns a
// pointer to a *UptimeCheckConfigHttpCheckContentTypeEnum with the same value as that string.
func flattenUptimeCheckConfigHttpCheckContentTypeEnum(i interface{}) *UptimeCheckConfigHttpCheckContentTypeEnum {
s, ok := i.(string)
if !ok {
return nil
}
return UptimeCheckConfigHttpCheckContentTypeEnumRef(s)
}
// flattenUptimeCheckConfigContentMatchersMatcherEnumMap flattens the contents of UptimeCheckConfigContentMatchersMatcherEnum from a JSON
// response object.
func flattenUptimeCheckConfigContentMatchersMatcherEnumMap(c *Client, i interface{}, res *UptimeCheckConfig) map[string]UptimeCheckConfigContentMatchersMatcherEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]UptimeCheckConfigContentMatchersMatcherEnum{}
}
if len(a) == 0 {
return map[string]UptimeCheckConfigContentMatchersMatcherEnum{}
}
items := make(map[string]UptimeCheckConfigContentMatchersMatcherEnum)
for k, item := range a {
items[k] = *flattenUptimeCheckConfigContentMatchersMatcherEnum(item.(interface{}))
}
return items
}
// flattenUptimeCheckConfigContentMatchersMatcherEnumSlice flattens the contents of UptimeCheckConfigContentMatchersMatcherEnum from a JSON
// response object.
func flattenUptimeCheckConfigContentMatchersMatcherEnumSlice(c *Client, i interface{}, res *UptimeCheckConfig) []UptimeCheckConfigContentMatchersMatcherEnum {
a, ok := i.([]interface{})
if !ok {
return []UptimeCheckConfigContentMatchersMatcherEnum{}
}
if len(a) == 0 {
return []UptimeCheckConfigContentMatchersMatcherEnum{}
}
items := make([]UptimeCheckConfigContentMatchersMatcherEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenUptimeCheckConfigContentMatchersMatcherEnum(item.(interface{})))
}
return items
}
// flattenUptimeCheckConfigContentMatchersMatcherEnum asserts that an interface is a string, and returns a
// pointer to a *UptimeCheckConfigContentMatchersMatcherEnum with the same value as that string.
func flattenUptimeCheckConfigContentMatchersMatcherEnum(i interface{}) *UptimeCheckConfigContentMatchersMatcherEnum {
s, ok := i.(string)
if !ok {
return nil
}
return UptimeCheckConfigContentMatchersMatcherEnumRef(s)
}
// This function returns a matcher that checks whether a serialized resource matches this resource
// in its parameters (as defined by the fields in a Get, which definitionally define resource
// identity). This is useful in extracting the element from a List call.
func (r *UptimeCheckConfig) matcher(c *Client) func([]byte) bool {
return func(b []byte) bool {
cr, err := unmarshalUptimeCheckConfig(b, c, r)
if err != nil {
c.Config.Logger.Warning("failed to unmarshal provided resource in matcher.")
return false
}
nr := r.urlNormalized()
ncr := cr.urlNormalized()
c.Config.Logger.Infof("looking for %v\nin %v", nr, ncr)
if nr.Project == nil && ncr.Project == nil {
c.Config.Logger.Info("Both Project fields null - considering equal.")
} else if nr.Project == nil || ncr.Project == nil {
c.Config.Logger.Info("Only one Project field is null - considering unequal.")
return false
} else if *nr.Project != *ncr.Project {
return false
}
if nr.Name == nil && ncr.Name == nil {
c.Config.Logger.Info("Both Name fields null - considering equal.")
} else if nr.Name == nil || ncr.Name == nil {
c.Config.Logger.Info("Only one Name field is null - considering unequal.")
return false
} else if *nr.Name != *ncr.Name {
return false
}
return true
}
}
type uptimeCheckConfigDiff struct {
// The diff should include one or the other of RequiresRecreate or UpdateOp.
RequiresRecreate bool
UpdateOp uptimeCheckConfigApiOperation
FieldName string // used for error logging
}
func convertFieldDiffsToUptimeCheckConfigDiffs(config *dcl.Config, fds []*dcl.FieldDiff, opts []dcl.ApplyOption) ([]uptimeCheckConfigDiff, error) {
opNamesToFieldDiffs := make(map[string][]*dcl.FieldDiff)
// Map each operation name to the field diffs associated with it.
for _, fd := range fds {
for _, ro := range fd.ResultingOperation {
if fieldDiffs, ok := opNamesToFieldDiffs[ro]; ok {
fieldDiffs = append(fieldDiffs, fd)
opNamesToFieldDiffs[ro] = fieldDiffs
} else {
config.Logger.Infof("%s required due to diff: %v", ro, fd)
opNamesToFieldDiffs[ro] = []*dcl.FieldDiff{fd}
}
}
}
var diffs []uptimeCheckConfigDiff
// For each operation name, create a uptimeCheckConfigDiff which contains the operation.
for opName, fieldDiffs := range opNamesToFieldDiffs {
// Use the first field diff's field name for logging required recreate error.
diff := uptimeCheckConfigDiff{FieldName: fieldDiffs[0].FieldName}
if opName == "Recreate" {
diff.RequiresRecreate = true
} else {
apiOp, err := convertOpNameToUptimeCheckConfigApiOperation(opName, fieldDiffs, opts...)
if err != nil {
return diffs, err
}
diff.UpdateOp = apiOp
}
diffs = append(diffs, diff)
}
return diffs, nil
}
func convertOpNameToUptimeCheckConfigApiOperation(opName string, fieldDiffs []*dcl.FieldDiff, opts ...dcl.ApplyOption) (uptimeCheckConfigApiOperation, error) {
switch opName {
case "updateUptimeCheckConfigUpdateUptimeCheckConfigOperation":
return &updateUptimeCheckConfigUpdateUptimeCheckConfigOperation{FieldDiffs: fieldDiffs}, nil
default:
return nil, fmt.Errorf("no such operation with name: %v", opName)
}
}
func extractUptimeCheckConfigFields(r *UptimeCheckConfig) error {
vMonitoredResource := r.MonitoredResource
if vMonitoredResource == nil {
// note: explicitly not the empty object.
vMonitoredResource = &UptimeCheckConfigMonitoredResource{}
}
if err := extractUptimeCheckConfigMonitoredResourceFields(r, vMonitoredResource); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vMonitoredResource) {
r.MonitoredResource = vMonitoredResource
}
vResourceGroup := r.ResourceGroup
if vResourceGroup == nil {
// note: explicitly not the empty object.
vResourceGroup = &UptimeCheckConfigResourceGroup{}
}
if err := extractUptimeCheckConfigResourceGroupFields(r, vResourceGroup); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vResourceGroup) {
r.ResourceGroup = vResourceGroup
}
vHttpCheck := r.HttpCheck
if vHttpCheck == nil {
// note: explicitly not the empty object.
vHttpCheck = &UptimeCheckConfigHttpCheck{}
}
if err := extractUptimeCheckConfigHttpCheckFields(r, vHttpCheck); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vHttpCheck) {
r.HttpCheck = vHttpCheck
}
vTcpCheck := r.TcpCheck
if vTcpCheck == nil {
// note: explicitly not the empty object.
vTcpCheck = &UptimeCheckConfigTcpCheck{}
}
if err := extractUptimeCheckConfigTcpCheckFields(r, vTcpCheck); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vTcpCheck) {
r.TcpCheck = vTcpCheck
}
return nil
}
func extractUptimeCheckConfigMonitoredResourceFields(r *UptimeCheckConfig, o *UptimeCheckConfigMonitoredResource) error {
return nil
}
func extractUptimeCheckConfigResourceGroupFields(r *UptimeCheckConfig, o *UptimeCheckConfigResourceGroup) error {
return nil
}
func extractUptimeCheckConfigHttpCheckFields(r *UptimeCheckConfig, o *UptimeCheckConfigHttpCheck) error {
vAuthInfo := o.AuthInfo
if vAuthInfo == nil {
// note: explicitly not the empty object.
vAuthInfo = &UptimeCheckConfigHttpCheckAuthInfo{}
}
if err := extractUptimeCheckConfigHttpCheckAuthInfoFields(r, vAuthInfo); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vAuthInfo) {
o.AuthInfo = vAuthInfo
}
return nil
}
func extractUptimeCheckConfigHttpCheckAuthInfoFields(r *UptimeCheckConfig, o *UptimeCheckConfigHttpCheckAuthInfo) error {
return nil
}
func extractUptimeCheckConfigTcpCheckFields(r *UptimeCheckConfig, o *UptimeCheckConfigTcpCheck) error {
return nil
}
func extractUptimeCheckConfigContentMatchersFields(r *UptimeCheckConfig, o *UptimeCheckConfigContentMatchers) error {
return nil
}
func postReadExtractUptimeCheckConfigFields(r *UptimeCheckConfig) error {
vMonitoredResource := r.MonitoredResource
if vMonitoredResource == nil {
// note: explicitly not the empty object.
vMonitoredResource = &UptimeCheckConfigMonitoredResource{}
}
if err := postReadExtractUptimeCheckConfigMonitoredResourceFields(r, vMonitoredResource); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vMonitoredResource) {
r.MonitoredResource = vMonitoredResource
}
vResourceGroup := r.ResourceGroup
if vResourceGroup == nil {
// note: explicitly not the empty object.
vResourceGroup = &UptimeCheckConfigResourceGroup{}
}
if err := postReadExtractUptimeCheckConfigResourceGroupFields(r, vResourceGroup); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vResourceGroup) {
r.ResourceGroup = vResourceGroup
}
vHttpCheck := r.HttpCheck
if vHttpCheck == nil {
// note: explicitly not the empty object.
vHttpCheck = &UptimeCheckConfigHttpCheck{}
}
if err := postReadExtractUptimeCheckConfigHttpCheckFields(r, vHttpCheck); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vHttpCheck) {
r.HttpCheck = vHttpCheck
}
vTcpCheck := r.TcpCheck
if vTcpCheck == nil {
// note: explicitly not the empty object.
vTcpCheck = &UptimeCheckConfigTcpCheck{}
}
if err := postReadExtractUptimeCheckConfigTcpCheckFields(r, vTcpCheck); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vTcpCheck) {
r.TcpCheck = vTcpCheck
}
return nil
}
func postReadExtractUptimeCheckConfigMonitoredResourceFields(r *UptimeCheckConfig, o *UptimeCheckConfigMonitoredResource) error {
return nil
}
func postReadExtractUptimeCheckConfigResourceGroupFields(r *UptimeCheckConfig, o *UptimeCheckConfigResourceGroup) error {
return nil
}
func postReadExtractUptimeCheckConfigHttpCheckFields(r *UptimeCheckConfig, o *UptimeCheckConfigHttpCheck) error {
vAuthInfo := o.AuthInfo
if vAuthInfo == nil {
// note: explicitly not the empty object.
vAuthInfo = &UptimeCheckConfigHttpCheckAuthInfo{}
}
if err := extractUptimeCheckConfigHttpCheckAuthInfoFields(r, vAuthInfo); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vAuthInfo) {
o.AuthInfo = vAuthInfo
}
return nil
}
func postReadExtractUptimeCheckConfigHttpCheckAuthInfoFields(r *UptimeCheckConfig, o *UptimeCheckConfigHttpCheckAuthInfo) error {
return nil
}
func postReadExtractUptimeCheckConfigTcpCheckFields(r *UptimeCheckConfig, o *UptimeCheckConfigTcpCheck) error {
return nil
}
func postReadExtractUptimeCheckConfigContentMatchersFields(r *UptimeCheckConfig, o *UptimeCheckConfigContentMatchers) error {
return nil
}