services/google/gkehub/beta/feature_internal.go (2,807 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 beta
import (
"bytes"
"context"
"encoding/json"
"fmt"
"io/ioutil"
"strings"
"github.com/GoogleCloudPlatform/declarative-resource-client-library/dcl"
"github.com/GoogleCloudPlatform/declarative-resource-client-library/dcl/operations"
)
func (r *Feature) validate() error {
if err := dcl.RequiredParameter(r.Project, "Project"); err != nil {
return err
}
if err := dcl.RequiredParameter(r.Location, "Location"); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(r.ResourceState) {
if err := r.ResourceState.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.Spec) {
if err := r.Spec.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.State) {
if err := r.State.validate(); err != nil {
return err
}
}
return nil
}
func (r *FeatureResourceState) validate() error {
return nil
}
func (r *FeatureSpec) validate() error {
if !dcl.IsEmptyValueIndirect(r.Multiclusteringress) {
if err := r.Multiclusteringress.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.Fleetobservability) {
if err := r.Fleetobservability.validate(); err != nil {
return err
}
}
return nil
}
func (r *FeatureSpecMulticlusteringress) validate() error {
if err := dcl.Required(r, "configMembership"); err != nil {
return err
}
return nil
}
func (r *FeatureSpecFleetobservability) validate() error {
if !dcl.IsEmptyValueIndirect(r.LoggingConfig) {
if err := r.LoggingConfig.validate(); err != nil {
return err
}
}
return nil
}
func (r *FeatureSpecFleetobservabilityLoggingConfig) validate() error {
if !dcl.IsEmptyValueIndirect(r.DefaultConfig) {
if err := r.DefaultConfig.validate(); err != nil {
return err
}
}
if !dcl.IsEmptyValueIndirect(r.FleetScopeLogsConfig) {
if err := r.FleetScopeLogsConfig.validate(); err != nil {
return err
}
}
return nil
}
func (r *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig) validate() error {
return nil
}
func (r *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig) validate() error {
return nil
}
func (r *FeatureState) validate() error {
if !dcl.IsEmptyValueIndirect(r.State) {
if err := r.State.validate(); err != nil {
return err
}
}
return nil
}
func (r *FeatureStateState) validate() error {
return nil
}
func (r *Feature) basePath() string {
params := map[string]interface{}{}
return dcl.Nprintf("https://gkehub.googleapis.com/v1beta1/", params)
}
// featureApiOperation represents a mutable operation in the underlying REST
// API such as Create, Update, or Delete.
type featureApiOperation interface {
do(context.Context, *Feature, *Client) error
}
// newUpdateFeatureUpdateFeatureRequest creates a request for an
// Feature resource's UpdateFeature update type by filling in the update
// fields based on the intended state of the resource.
func newUpdateFeatureUpdateFeatureRequest(ctx context.Context, f *Feature, c *Client) (map[string]interface{}, error) {
req := map[string]interface{}{}
res := f
_ = res
if v := f.Labels; !dcl.IsEmptyValueIndirect(v) {
req["labels"] = v
}
if v, err := expandFeatureSpec(c, f.Spec, res); err != nil {
return nil, fmt.Errorf("error expanding Spec into spec: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
req["spec"] = v
}
return req, nil
}
// marshalUpdateFeatureUpdateFeatureRequest converts the update into
// the final JSON request body.
func marshalUpdateFeatureUpdateFeatureRequest(c *Client, m map[string]interface{}) ([]byte, error) {
return json.Marshal(m)
}
type updateFeatureUpdateFeatureOperation 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 (c *Client) listFeatureRaw(ctx context.Context, r *Feature, 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 != FeatureMaxPage {
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 listFeatureOperation struct {
Resources []map[string]interface{} `json:"resources"`
Token string `json:"nextPageToken"`
}
func (c *Client) listFeature(ctx context.Context, r *Feature, pageToken string, pageSize int32) ([]*Feature, string, error) {
b, err := c.listFeatureRaw(ctx, r, pageToken, pageSize)
if err != nil {
return nil, "", err
}
var m listFeatureOperation
if err := json.Unmarshal(b, &m); err != nil {
return nil, "", err
}
var l []*Feature
for _, v := range m.Resources {
res, err := unmarshalMapFeature(v, c, r)
if err != nil {
return nil, m.Token, err
}
res.Project = r.Project
res.Location = r.Location
l = append(l, res)
}
return l, m.Token, nil
}
func (c *Client) deleteAllFeature(ctx context.Context, f func(*Feature) bool, resources []*Feature) 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.DeleteFeature(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 deleteFeatureOperation struct{}
func (op *deleteFeatureOperation) do(ctx context.Context, r *Feature, c *Client) error {
r, err := c.GetFeature(ctx, r)
if err != nil {
if dcl.IsNotFound(err) {
c.Config.Logger.InfoWithContextf(ctx, "Feature not found, returning. Original error: %v", err)
return nil
}
c.Config.Logger.WarningWithContextf(ctx, "GetFeature 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{}
resp, err := dcl.SendRequest(ctx, c.Config, "DELETE", u, body, c.Config.RetryProvider)
if err != nil {
return err
}
// wait for object to be deleted.
var o operations.StandardGCPOperation
if err := dcl.ParseResponse(resp.Response, &o); err != nil {
return err
}
if err := o.Wait(context.WithValue(ctx, dcl.DoNotLogRequestsKey, true), c.Config, r.basePath(), "GET"); err != nil {
return 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.GetFeature(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 createFeatureOperation struct {
response map[string]interface{}
}
func (op *createFeatureOperation) FirstResponse() (map[string]interface{}, bool) {
return op.response, len(op.response) > 0
}
func (op *createFeatureOperation) do(ctx context.Context, r *Feature, 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
}
resp, err := dcl.SendRequest(ctx, c.Config, "POST", u, bytes.NewBuffer(req), c.Config.RetryProvider)
if err != nil {
return err
}
// wait for object to be created.
var o operations.StandardGCPOperation
if err := dcl.ParseResponse(resp.Response, &o); err != nil {
return err
}
if err := o.Wait(context.WithValue(ctx, dcl.DoNotLogRequestsKey, true), c.Config, r.basePath(), "GET"); err != nil {
c.Config.Logger.Warningf("Creation failed after waiting for operation: %v", err)
return err
}
c.Config.Logger.InfoWithContextf(ctx, "Successfully waited for operation")
op.response, _ = o.FirstResponse()
if _, err := c.GetFeature(ctx, r); err != nil {
c.Config.Logger.WarningWithContextf(ctx, "get returned error: %v", err)
return err
}
return nil
}
func (c *Client) getFeatureRaw(ctx context.Context, r *Feature) ([]byte, error) {
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) featureDiffsForRawDesired(ctx context.Context, rawDesired *Feature, opts ...dcl.ApplyOption) (initial, desired *Feature, 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 *Feature
if sh := dcl.FetchStateHint(opts); sh != nil {
if r, ok := sh.(*Feature); !ok {
c.Config.Logger.WarningWithContextf(ctx, "Initial state hint was of the wrong type; expected Feature, got %T", sh)
} else {
fetchState = r
}
}
if fetchState == nil {
fetchState = rawDesired
}
// 1.2: Retrieval of raw initial state from API
rawInitial, err := c.GetFeature(ctx, fetchState)
if rawInitial == nil {
if !dcl.IsNotFound(err) {
c.Config.Logger.WarningWithContextf(ctx, "Failed to retrieve whether a Feature resource already exists: %s", err)
return nil, nil, nil, fmt.Errorf("failed to retrieve Feature resource: %v", err)
}
c.Config.Logger.InfoWithContext(ctx, "Found that Feature resource did not exist.")
// Perform canonicalization to pick up defaults.
desired, err = canonicalizeFeatureDesiredState(rawDesired, rawInitial)
return nil, desired, nil, err
}
c.Config.Logger.InfoWithContextf(ctx, "Found initial state for Feature: %v", rawInitial)
c.Config.Logger.InfoWithContextf(ctx, "Initial desired state for Feature: %v", rawDesired)
// The Get call applies postReadExtract and so the result may contain fields that are not part of API version.
if err := extractFeatureFields(rawInitial); err != nil {
return nil, nil, nil, err
}
// 1.3: Canonicalize raw initial state into initial state.
initial, err = canonicalizeFeatureInitialState(rawInitial, rawDesired)
if err != nil {
return nil, nil, nil, err
}
c.Config.Logger.InfoWithContextf(ctx, "Canonicalized initial state for Feature: %v", initial)
// 1.4: Canonicalize raw desired state into desired state.
desired, err = canonicalizeFeatureDesiredState(rawDesired, rawInitial, opts...)
if err != nil {
return nil, nil, nil, err
}
c.Config.Logger.InfoWithContextf(ctx, "Canonicalized desired state for Feature: %v", desired)
// 2.1: Comparison of initial and desired state.
diffs, err = diffFeature(c, desired, initial, opts...)
return initial, desired, diffs, err
}
func canonicalizeFeatureInitialState(rawInitial, rawDesired *Feature) (*Feature, error) {
// TODO(magic-modules-eng): write canonicalizer once relevant traits are added.
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 canonicalizeFeatureDesiredState(rawDesired, rawInitial *Feature, opts ...dcl.ApplyOption) (*Feature, error) {
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.ResourceState = canonicalizeFeatureResourceState(rawDesired.ResourceState, nil, opts...)
rawDesired.Spec = canonicalizeFeatureSpec(rawDesired.Spec, nil, opts...)
rawDesired.State = canonicalizeFeatureState(rawDesired.State, nil, opts...)
return rawDesired, nil
}
canonicalDesired := &Feature{}
if dcl.PartialSelfLinkToSelfLink(rawDesired.Name, rawInitial.Name) {
canonicalDesired.Name = rawInitial.Name
} else {
canonicalDesired.Name = rawDesired.Name
}
if dcl.IsZeroValue(rawDesired.Labels) || (dcl.IsEmptyValueIndirect(rawDesired.Labels) && dcl.IsEmptyValueIndirect(rawInitial.Labels)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
canonicalDesired.Labels = rawInitial.Labels
} else {
canonicalDesired.Labels = rawDesired.Labels
}
canonicalDesired.Spec = canonicalizeFeatureSpec(rawDesired.Spec, rawInitial.Spec, opts...)
if dcl.NameToSelfLink(rawDesired.Project, rawInitial.Project) {
canonicalDesired.Project = rawInitial.Project
} else {
canonicalDesired.Project = rawDesired.Project
}
if dcl.NameToSelfLink(rawDesired.Location, rawInitial.Location) {
canonicalDesired.Location = rawInitial.Location
} else {
canonicalDesired.Location = rawDesired.Location
}
return canonicalDesired, nil
}
func canonicalizeFeatureNewState(c *Client, rawNew, rawDesired *Feature) (*Feature, error) {
if dcl.IsEmptyValueIndirect(rawNew.Name) && dcl.IsEmptyValueIndirect(rawDesired.Name) {
rawNew.Name = rawDesired.Name
} else {
if dcl.PartialSelfLinkToSelfLink(rawDesired.Name, rawNew.Name) {
rawNew.Name = rawDesired.Name
}
}
if dcl.IsEmptyValueIndirect(rawNew.Labels) && dcl.IsEmptyValueIndirect(rawDesired.Labels) {
rawNew.Labels = rawDesired.Labels
} else {
}
if dcl.IsEmptyValueIndirect(rawNew.ResourceState) && dcl.IsEmptyValueIndirect(rawDesired.ResourceState) {
rawNew.ResourceState = rawDesired.ResourceState
} else {
rawNew.ResourceState = canonicalizeNewFeatureResourceState(c, rawDesired.ResourceState, rawNew.ResourceState)
}
if dcl.IsEmptyValueIndirect(rawNew.Spec) && dcl.IsEmptyValueIndirect(rawDesired.Spec) {
rawNew.Spec = rawDesired.Spec
} else {
rawNew.Spec = canonicalizeNewFeatureSpec(c, rawDesired.Spec, rawNew.Spec)
}
if dcl.IsEmptyValueIndirect(rawNew.State) && dcl.IsEmptyValueIndirect(rawDesired.State) {
rawNew.State = rawDesired.State
} else {
rawNew.State = canonicalizeNewFeatureState(c, rawDesired.State, rawNew.State)
}
if dcl.IsEmptyValueIndirect(rawNew.CreateTime) && dcl.IsEmptyValueIndirect(rawDesired.CreateTime) {
rawNew.CreateTime = rawDesired.CreateTime
} else {
}
if dcl.IsEmptyValueIndirect(rawNew.UpdateTime) && dcl.IsEmptyValueIndirect(rawDesired.UpdateTime) {
rawNew.UpdateTime = rawDesired.UpdateTime
} else {
}
if dcl.IsEmptyValueIndirect(rawNew.DeleteTime) && dcl.IsEmptyValueIndirect(rawDesired.DeleteTime) {
rawNew.DeleteTime = rawDesired.DeleteTime
} else {
}
rawNew.Project = rawDesired.Project
rawNew.Location = rawDesired.Location
return rawNew, nil
}
func canonicalizeFeatureResourceState(des, initial *FeatureResourceState, opts ...dcl.ApplyOption) *FeatureResourceState {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureResourceState{}
return cDes
}
func canonicalizeFeatureResourceStateSlice(des, initial []FeatureResourceState, opts ...dcl.ApplyOption) []FeatureResourceState {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureResourceState, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureResourceState(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureResourceState, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureResourceState(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureResourceState(c *Client, des, nw *FeatureResourceState) *FeatureResourceState {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureResourceState while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
if dcl.BoolCanonicalize(des.HasResources, nw.HasResources) {
nw.HasResources = des.HasResources
}
return nw
}
func canonicalizeNewFeatureResourceStateSet(c *Client, des, nw []FeatureResourceState) []FeatureResourceState {
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 []FeatureResourceState
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureResourceStateNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureResourceState(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 canonicalizeNewFeatureResourceStateSlice(c *Client, des, nw []FeatureResourceState) []FeatureResourceState {
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 []FeatureResourceState
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureResourceState(c, &d, &n))
}
return items
}
func canonicalizeFeatureSpec(des, initial *FeatureSpec, opts ...dcl.ApplyOption) *FeatureSpec {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureSpec{}
cDes.Multiclusteringress = canonicalizeFeatureSpecMulticlusteringress(des.Multiclusteringress, initial.Multiclusteringress, opts...)
cDes.Fleetobservability = canonicalizeFeatureSpecFleetobservability(des.Fleetobservability, initial.Fleetobservability, opts...)
return cDes
}
func canonicalizeFeatureSpecSlice(des, initial []FeatureSpec, opts ...dcl.ApplyOption) []FeatureSpec {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureSpec, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureSpec(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureSpec, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureSpec(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureSpec(c *Client, des, nw *FeatureSpec) *FeatureSpec {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureSpec while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
nw.Multiclusteringress = canonicalizeNewFeatureSpecMulticlusteringress(c, des.Multiclusteringress, nw.Multiclusteringress)
nw.Fleetobservability = canonicalizeNewFeatureSpecFleetobservability(c, des.Fleetobservability, nw.Fleetobservability)
return nw
}
func canonicalizeNewFeatureSpecSet(c *Client, des, nw []FeatureSpec) []FeatureSpec {
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 []FeatureSpec
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureSpecNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureSpec(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 canonicalizeNewFeatureSpecSlice(c *Client, des, nw []FeatureSpec) []FeatureSpec {
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 []FeatureSpec
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureSpec(c, &d, &n))
}
return items
}
func canonicalizeFeatureSpecMulticlusteringress(des, initial *FeatureSpecMulticlusteringress, opts ...dcl.ApplyOption) *FeatureSpecMulticlusteringress {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureSpecMulticlusteringress{}
if dcl.IsZeroValue(des.ConfigMembership) || (dcl.IsEmptyValueIndirect(des.ConfigMembership) && dcl.IsEmptyValueIndirect(initial.ConfigMembership)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.ConfigMembership = initial.ConfigMembership
} else {
cDes.ConfigMembership = des.ConfigMembership
}
return cDes
}
func canonicalizeFeatureSpecMulticlusteringressSlice(des, initial []FeatureSpecMulticlusteringress, opts ...dcl.ApplyOption) []FeatureSpecMulticlusteringress {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureSpecMulticlusteringress, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureSpecMulticlusteringress(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureSpecMulticlusteringress, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureSpecMulticlusteringress(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureSpecMulticlusteringress(c *Client, des, nw *FeatureSpecMulticlusteringress) *FeatureSpecMulticlusteringress {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureSpecMulticlusteringress while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
return nw
}
func canonicalizeNewFeatureSpecMulticlusteringressSet(c *Client, des, nw []FeatureSpecMulticlusteringress) []FeatureSpecMulticlusteringress {
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 []FeatureSpecMulticlusteringress
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureSpecMulticlusteringressNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureSpecMulticlusteringress(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 canonicalizeNewFeatureSpecMulticlusteringressSlice(c *Client, des, nw []FeatureSpecMulticlusteringress) []FeatureSpecMulticlusteringress {
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 []FeatureSpecMulticlusteringress
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureSpecMulticlusteringress(c, &d, &n))
}
return items
}
func canonicalizeFeatureSpecFleetobservability(des, initial *FeatureSpecFleetobservability, opts ...dcl.ApplyOption) *FeatureSpecFleetobservability {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureSpecFleetobservability{}
cDes.LoggingConfig = canonicalizeFeatureSpecFleetobservabilityLoggingConfig(des.LoggingConfig, initial.LoggingConfig, opts...)
return cDes
}
func canonicalizeFeatureSpecFleetobservabilitySlice(des, initial []FeatureSpecFleetobservability, opts ...dcl.ApplyOption) []FeatureSpecFleetobservability {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureSpecFleetobservability, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureSpecFleetobservability(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureSpecFleetobservability, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureSpecFleetobservability(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureSpecFleetobservability(c *Client, des, nw *FeatureSpecFleetobservability) *FeatureSpecFleetobservability {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureSpecFleetobservability while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
nw.LoggingConfig = canonicalizeNewFeatureSpecFleetobservabilityLoggingConfig(c, des.LoggingConfig, nw.LoggingConfig)
return nw
}
func canonicalizeNewFeatureSpecFleetobservabilitySet(c *Client, des, nw []FeatureSpecFleetobservability) []FeatureSpecFleetobservability {
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 []FeatureSpecFleetobservability
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureSpecFleetobservabilityNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureSpecFleetobservability(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 canonicalizeNewFeatureSpecFleetobservabilitySlice(c *Client, des, nw []FeatureSpecFleetobservability) []FeatureSpecFleetobservability {
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 []FeatureSpecFleetobservability
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureSpecFleetobservability(c, &d, &n))
}
return items
}
func canonicalizeFeatureSpecFleetobservabilityLoggingConfig(des, initial *FeatureSpecFleetobservabilityLoggingConfig, opts ...dcl.ApplyOption) *FeatureSpecFleetobservabilityLoggingConfig {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureSpecFleetobservabilityLoggingConfig{}
cDes.DefaultConfig = canonicalizeFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(des.DefaultConfig, initial.DefaultConfig, opts...)
cDes.FleetScopeLogsConfig = canonicalizeFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(des.FleetScopeLogsConfig, initial.FleetScopeLogsConfig, opts...)
return cDes
}
func canonicalizeFeatureSpecFleetobservabilityLoggingConfigSlice(des, initial []FeatureSpecFleetobservabilityLoggingConfig, opts ...dcl.ApplyOption) []FeatureSpecFleetobservabilityLoggingConfig {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureSpecFleetobservabilityLoggingConfig, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureSpecFleetobservabilityLoggingConfig(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureSpecFleetobservabilityLoggingConfig, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureSpecFleetobservabilityLoggingConfig(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureSpecFleetobservabilityLoggingConfig(c *Client, des, nw *FeatureSpecFleetobservabilityLoggingConfig) *FeatureSpecFleetobservabilityLoggingConfig {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureSpecFleetobservabilityLoggingConfig while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
nw.DefaultConfig = canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, des.DefaultConfig, nw.DefaultConfig)
nw.FleetScopeLogsConfig = canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, des.FleetScopeLogsConfig, nw.FleetScopeLogsConfig)
return nw
}
func canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigSet(c *Client, des, nw []FeatureSpecFleetobservabilityLoggingConfig) []FeatureSpecFleetobservabilityLoggingConfig {
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 []FeatureSpecFleetobservabilityLoggingConfig
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureSpecFleetobservabilityLoggingConfigNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureSpecFleetobservabilityLoggingConfig(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 canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigSlice(c *Client, des, nw []FeatureSpecFleetobservabilityLoggingConfig) []FeatureSpecFleetobservabilityLoggingConfig {
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 []FeatureSpecFleetobservabilityLoggingConfig
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureSpecFleetobservabilityLoggingConfig(c, &d, &n))
}
return items
}
func canonicalizeFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(des, initial *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, opts ...dcl.ApplyOption) *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
if dcl.IsZeroValue(des.Mode) || (dcl.IsEmptyValueIndirect(des.Mode) && dcl.IsEmptyValueIndirect(initial.Mode)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.Mode = initial.Mode
} else {
cDes.Mode = des.Mode
}
return cDes
}
func canonicalizeFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSlice(des, initial []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, opts ...dcl.ApplyOption) []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c *Client, des, nw *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig) *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureSpecFleetobservabilityLoggingConfigDefaultConfig while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
return nw
}
func canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSet(c *Client, des, nw []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig) []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
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 []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureSpecFleetobservabilityLoggingConfigDefaultConfigNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(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 canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSlice(c *Client, des, nw []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig) []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
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 []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, &d, &n))
}
return items
}
func canonicalizeFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(des, initial *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, opts ...dcl.ApplyOption) *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
if dcl.IsZeroValue(des.Mode) || (dcl.IsEmptyValueIndirect(des.Mode) && dcl.IsEmptyValueIndirect(initial.Mode)) {
// Desired and initial values are equivalent, so set canonical desired value to initial value.
cDes.Mode = initial.Mode
} else {
cDes.Mode = des.Mode
}
return cDes
}
func canonicalizeFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSlice(des, initial []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, opts ...dcl.ApplyOption) []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c *Client, des, nw *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig) *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
return nw
}
func canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSet(c *Client, des, nw []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig) []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
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 []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(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 canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSlice(c *Client, des, nw []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig) []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
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 []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, &d, &n))
}
return items
}
func canonicalizeFeatureState(des, initial *FeatureState, opts ...dcl.ApplyOption) *FeatureState {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureState{}
return cDes
}
func canonicalizeFeatureStateSlice(des, initial []FeatureState, opts ...dcl.ApplyOption) []FeatureState {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureState, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureState(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureState, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureState(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureState(c *Client, des, nw *FeatureState) *FeatureState {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureState while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
nw.State = canonicalizeNewFeatureStateState(c, des.State, nw.State)
return nw
}
func canonicalizeNewFeatureStateSet(c *Client, des, nw []FeatureState) []FeatureState {
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 []FeatureState
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureStateNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureState(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 canonicalizeNewFeatureStateSlice(c *Client, des, nw []FeatureState) []FeatureState {
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 []FeatureState
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureState(c, &d, &n))
}
return items
}
func canonicalizeFeatureStateState(des, initial *FeatureStateState, opts ...dcl.ApplyOption) *FeatureStateState {
if des == nil {
return initial
}
if des.empty {
return des
}
if initial == nil {
return des
}
cDes := &FeatureStateState{}
return cDes
}
func canonicalizeFeatureStateStateSlice(des, initial []FeatureStateState, opts ...dcl.ApplyOption) []FeatureStateState {
if dcl.IsEmptyValueIndirect(des) {
return initial
}
if len(des) != len(initial) {
items := make([]FeatureStateState, 0, len(des))
for _, d := range des {
cd := canonicalizeFeatureStateState(&d, nil, opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
items := make([]FeatureStateState, 0, len(des))
for i, d := range des {
cd := canonicalizeFeatureStateState(&d, &initial[i], opts...)
if cd != nil {
items = append(items, *cd)
}
}
return items
}
func canonicalizeNewFeatureStateState(c *Client, des, nw *FeatureStateState) *FeatureStateState {
if des == nil {
return nw
}
if nw == nil {
if dcl.IsEmptyValueIndirect(des) {
c.Config.Logger.Info("Found explicitly empty value for FeatureStateState while comparing non-nil desired to nil actual. Returning desired object.")
return des
}
return nil
}
if dcl.StringCanonicalize(des.Description, nw.Description) {
nw.Description = des.Description
}
if dcl.StringCanonicalize(des.UpdateTime, nw.UpdateTime) {
nw.UpdateTime = des.UpdateTime
}
return nw
}
func canonicalizeNewFeatureStateStateSet(c *Client, des, nw []FeatureStateState) []FeatureStateState {
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 []FeatureStateState
for _, d := range des {
matchedIndex := -1
for i, n := range nw {
if diffs, _ := compareFeatureStateStateNewStyle(&d, &n, dcl.FieldName{}); len(diffs) == 0 {
matchedIndex = i
break
}
}
if matchedIndex != -1 {
items = append(items, *canonicalizeNewFeatureStateState(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 canonicalizeNewFeatureStateStateSlice(c *Client, des, nw []FeatureStateState) []FeatureStateState {
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 []FeatureStateState
for i, d := range des {
n := nw[i]
items = append(items, *canonicalizeNewFeatureStateState(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 diffFeature(c *Client, desired, actual *Feature, 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{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.Labels, actual.Labels, dcl.DiffInfo{OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("Labels")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.ResourceState, actual.ResourceState, dcl.DiffInfo{OutputOnly: true, ObjectFunction: compareFeatureResourceStateNewStyle, EmptyObject: EmptyFeatureResourceState, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("ResourceState")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.Spec, actual.Spec, dcl.DiffInfo{ObjectFunction: compareFeatureSpecNewStyle, EmptyObject: EmptyFeatureSpec, OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("Spec")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.State, actual.State, dcl.DiffInfo{OutputOnly: true, ObjectFunction: compareFeatureStateNewStyle, EmptyObject: EmptyFeatureState, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("State")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.CreateTime, actual.CreateTime, dcl.DiffInfo{OutputOnly: true, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("CreateTime")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.UpdateTime, actual.UpdateTime, dcl.DiffInfo{OutputOnly: true, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("UpdateTime")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
newDiffs = append(newDiffs, ds...)
}
if ds, err := dcl.Diff(desired.DeleteTime, actual.DeleteTime, dcl.DiffInfo{OutputOnly: true, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("DeleteTime")); 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 ds, err := dcl.Diff(desired.Location, actual.Location, dcl.DiffInfo{OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Location")); 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 compareFeatureResourceStateNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureResourceState)
if !ok {
desiredNotPointer, ok := d.(FeatureResourceState)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureResourceState or *FeatureResourceState", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureResourceState)
if !ok {
actualNotPointer, ok := a.(FeatureResourceState)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureResourceState", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.State, actual.State, dcl.DiffInfo{OutputOnly: true, Type: "EnumType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("State")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.HasResources, actual.HasResources, dcl.DiffInfo{OutputOnly: true, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("HasResources")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureSpecNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureSpec)
if !ok {
desiredNotPointer, ok := d.(FeatureSpec)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpec or *FeatureSpec", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureSpec)
if !ok {
actualNotPointer, ok := a.(FeatureSpec)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpec", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Multiclusteringress, actual.Multiclusteringress, dcl.DiffInfo{ObjectFunction: compareFeatureSpecMulticlusteringressNewStyle, EmptyObject: EmptyFeatureSpecMulticlusteringress, OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("Multiclusteringress")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Fleetobservability, actual.Fleetobservability, dcl.DiffInfo{ObjectFunction: compareFeatureSpecFleetobservabilityNewStyle, EmptyObject: EmptyFeatureSpecFleetobservability, OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("Fleetobservability")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureSpecMulticlusteringressNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureSpecMulticlusteringress)
if !ok {
desiredNotPointer, ok := d.(FeatureSpecMulticlusteringress)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecMulticlusteringress or *FeatureSpecMulticlusteringress", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureSpecMulticlusteringress)
if !ok {
actualNotPointer, ok := a.(FeatureSpecMulticlusteringress)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecMulticlusteringress", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.ConfigMembership, actual.ConfigMembership, dcl.DiffInfo{Type: "ReferenceType", OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("ConfigMembership")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureSpecFleetobservabilityNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureSpecFleetobservability)
if !ok {
desiredNotPointer, ok := d.(FeatureSpecFleetobservability)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservability or *FeatureSpecFleetobservability", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureSpecFleetobservability)
if !ok {
actualNotPointer, ok := a.(FeatureSpecFleetobservability)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservability", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.LoggingConfig, actual.LoggingConfig, dcl.DiffInfo{ObjectFunction: compareFeatureSpecFleetobservabilityLoggingConfigNewStyle, EmptyObject: EmptyFeatureSpecFleetobservabilityLoggingConfig, OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("LoggingConfig")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureSpecFleetobservabilityLoggingConfigNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureSpecFleetobservabilityLoggingConfig)
if !ok {
desiredNotPointer, ok := d.(FeatureSpecFleetobservabilityLoggingConfig)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservabilityLoggingConfig or *FeatureSpecFleetobservabilityLoggingConfig", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureSpecFleetobservabilityLoggingConfig)
if !ok {
actualNotPointer, ok := a.(FeatureSpecFleetobservabilityLoggingConfig)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservabilityLoggingConfig", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.DefaultConfig, actual.DefaultConfig, dcl.DiffInfo{ObjectFunction: compareFeatureSpecFleetobservabilityLoggingConfigDefaultConfigNewStyle, EmptyObject: EmptyFeatureSpecFleetobservabilityLoggingConfigDefaultConfig, OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("DefaultConfig")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.FleetScopeLogsConfig, actual.FleetScopeLogsConfig, dcl.DiffInfo{ObjectFunction: compareFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigNewStyle, EmptyObject: EmptyFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("FleetScopeLogsConfig")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureSpecFleetobservabilityLoggingConfigDefaultConfigNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureSpecFleetobservabilityLoggingConfigDefaultConfig)
if !ok {
desiredNotPointer, ok := d.(FeatureSpecFleetobservabilityLoggingConfigDefaultConfig)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservabilityLoggingConfigDefaultConfig or *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureSpecFleetobservabilityLoggingConfigDefaultConfig)
if !ok {
actualNotPointer, ok := a.(FeatureSpecFleetobservabilityLoggingConfigDefaultConfig)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservabilityLoggingConfigDefaultConfig", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Mode, actual.Mode, dcl.DiffInfo{Type: "EnumType", OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("Mode")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig)
if !ok {
desiredNotPointer, ok := d.(FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig or *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig)
if !ok {
actualNotPointer, ok := a.(FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Mode, actual.Mode, dcl.DiffInfo{Type: "EnumType", OperationSelector: dcl.TriggersOperation("updateFeatureUpdateFeatureOperation")}, fn.AddNest("Mode")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureStateNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureState)
if !ok {
desiredNotPointer, ok := d.(FeatureState)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureState or *FeatureState", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureState)
if !ok {
actualNotPointer, ok := a.(FeatureState)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureState", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.State, actual.State, dcl.DiffInfo{OutputOnly: true, ObjectFunction: compareFeatureStateStateNewStyle, EmptyObject: EmptyFeatureStateState, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("State")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
return diffs, nil
}
func compareFeatureStateStateNewStyle(d, a interface{}, fn dcl.FieldName) ([]*dcl.FieldDiff, error) {
var diffs []*dcl.FieldDiff
desired, ok := d.(*FeatureStateState)
if !ok {
desiredNotPointer, ok := d.(FeatureStateState)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureStateState or *FeatureStateState", d)
}
desired = &desiredNotPointer
}
actual, ok := a.(*FeatureStateState)
if !ok {
actualNotPointer, ok := a.(FeatureStateState)
if !ok {
return nil, fmt.Errorf("obj %v is not a FeatureStateState", a)
}
actual = &actualNotPointer
}
if ds, err := dcl.Diff(desired.Code, actual.Code, dcl.DiffInfo{OutputOnly: true, Type: "EnumType", OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Code")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.Description, actual.Description, dcl.DiffInfo{OutputOnly: true, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("Description")); len(ds) != 0 || err != nil {
if err != nil {
return nil, err
}
diffs = append(diffs, ds...)
}
if ds, err := dcl.Diff(desired.UpdateTime, actual.UpdateTime, dcl.DiffInfo{OutputOnly: true, OperationSelector: dcl.RequiresRecreate()}, fn.AddNest("UpdateTime")); 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 *Feature) urlNormalized() *Feature {
normalized := dcl.Copy(*r).(Feature)
normalized.Name = dcl.SelfLinkToName(r.Name)
normalized.Project = dcl.SelfLinkToName(r.Project)
normalized.Location = dcl.SelfLinkToName(r.Location)
return &normalized
}
func (r *Feature) updateURL(userBasePath, updateName string) (string, error) {
nr := r.urlNormalized()
if updateName == "UpdateFeature" {
fields := map[string]interface{}{
"project": dcl.ValueOrEmptyString(nr.Project),
"location": dcl.ValueOrEmptyString(nr.Location),
"name": dcl.ValueOrEmptyString(nr.Name),
}
return dcl.URL("projects/{{project}}/locations/{{location}}/features/{{name}}", nr.basePath(), userBasePath, fields), nil
}
return "", fmt.Errorf("unknown update name: %s", updateName)
}
// marshal encodes the Feature resource into JSON for a Create request, and
// performs transformations from the resource schema to the API schema if
// necessary.
func (r *Feature) marshal(c *Client) ([]byte, error) {
m, err := expandFeature(c, r)
if err != nil {
return nil, fmt.Errorf("error marshalling Feature: %w", err)
}
return json.Marshal(m)
}
// unmarshalFeature decodes JSON responses into the Feature resource schema.
func unmarshalFeature(b []byte, c *Client, res *Feature) (*Feature, error) {
var m map[string]interface{}
if err := json.Unmarshal(b, &m); err != nil {
return nil, err
}
return unmarshalMapFeature(m, c, res)
}
func unmarshalMapFeature(m map[string]interface{}, c *Client, res *Feature) (*Feature, error) {
flattened := flattenFeature(c, m, res)
if flattened == nil {
return nil, fmt.Errorf("attempted to flatten empty json object")
}
return flattened, nil
}
// expandFeature expands Feature into a JSON request object.
func expandFeature(c *Client, f *Feature) (map[string]interface{}, error) {
m := make(map[string]interface{})
res := f
_ = res
if v, err := dcl.DeriveField("projects/%s/locations/%s/features/%s", f.Name, dcl.SelfLinkToName(f.Project), dcl.SelfLinkToName(f.Location), dcl.SelfLinkToName(f.Name)); err != nil {
return nil, fmt.Errorf("error expanding Name into name: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["name"] = v
}
if v := f.Labels; dcl.ValueShouldBeSent(v) {
m["labels"] = v
}
if v, err := expandFeatureSpec(c, f.Spec, res); err != nil {
return nil, fmt.Errorf("error expanding Spec into spec: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["spec"] = 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
}
if v, err := dcl.EmptyValue(); err != nil {
return nil, fmt.Errorf("error expanding Location into location: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["location"] = v
}
return m, nil
}
// flattenFeature flattens Feature from a JSON request object into the
// Feature type.
func flattenFeature(c *Client, i interface{}, res *Feature) *Feature {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
if len(m) == 0 {
return nil
}
resultRes := &Feature{}
resultRes.Name = dcl.FlattenString(m["name"])
resultRes.Labels = dcl.FlattenKeyValuePairs(m["labels"])
resultRes.ResourceState = flattenFeatureResourceState(c, m["resourceState"], res)
resultRes.Spec = flattenFeatureSpec(c, m["spec"], res)
resultRes.State = flattenFeatureState(c, m["state"], res)
resultRes.CreateTime = dcl.FlattenString(m["createTime"])
resultRes.UpdateTime = dcl.FlattenString(m["updateTime"])
resultRes.DeleteTime = dcl.FlattenString(m["deleteTime"])
resultRes.Project = dcl.FlattenString(m["project"])
resultRes.Location = dcl.FlattenString(m["location"])
return resultRes
}
// expandFeatureResourceStateMap expands the contents of FeatureResourceState into a JSON
// request object.
func expandFeatureResourceStateMap(c *Client, f map[string]FeatureResourceState, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureResourceState(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureResourceStateSlice expands the contents of FeatureResourceState into a JSON
// request object.
func expandFeatureResourceStateSlice(c *Client, f []FeatureResourceState, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureResourceState(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureResourceStateMap flattens the contents of FeatureResourceState from a JSON
// response object.
func flattenFeatureResourceStateMap(c *Client, i interface{}, res *Feature) map[string]FeatureResourceState {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureResourceState{}
}
if len(a) == 0 {
return map[string]FeatureResourceState{}
}
items := make(map[string]FeatureResourceState)
for k, item := range a {
items[k] = *flattenFeatureResourceState(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureResourceStateSlice flattens the contents of FeatureResourceState from a JSON
// response object.
func flattenFeatureResourceStateSlice(c *Client, i interface{}, res *Feature) []FeatureResourceState {
a, ok := i.([]interface{})
if !ok {
return []FeatureResourceState{}
}
if len(a) == 0 {
return []FeatureResourceState{}
}
items := make([]FeatureResourceState, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureResourceState(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureResourceState expands an instance of FeatureResourceState into a JSON
// request object.
func expandFeatureResourceState(c *Client, f *FeatureResourceState, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
return m, nil
}
// flattenFeatureResourceState flattens an instance of FeatureResourceState from a JSON
// response object.
func flattenFeatureResourceState(c *Client, i interface{}, res *Feature) *FeatureResourceState {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureResourceState{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureResourceState
}
r.State = flattenFeatureResourceStateStateEnum(m["state"])
r.HasResources = dcl.FlattenBool(m["hasResources"])
return r
}
// expandFeatureSpecMap expands the contents of FeatureSpec into a JSON
// request object.
func expandFeatureSpecMap(c *Client, f map[string]FeatureSpec, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureSpec(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureSpecSlice expands the contents of FeatureSpec into a JSON
// request object.
func expandFeatureSpecSlice(c *Client, f []FeatureSpec, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureSpec(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureSpecMap flattens the contents of FeatureSpec from a JSON
// response object.
func flattenFeatureSpecMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpec {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpec{}
}
if len(a) == 0 {
return map[string]FeatureSpec{}
}
items := make(map[string]FeatureSpec)
for k, item := range a {
items[k] = *flattenFeatureSpec(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureSpecSlice flattens the contents of FeatureSpec from a JSON
// response object.
func flattenFeatureSpecSlice(c *Client, i interface{}, res *Feature) []FeatureSpec {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpec{}
}
if len(a) == 0 {
return []FeatureSpec{}
}
items := make([]FeatureSpec, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpec(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureSpec expands an instance of FeatureSpec into a JSON
// request object.
func expandFeatureSpec(c *Client, f *FeatureSpec, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v, err := expandFeatureSpecMulticlusteringress(c, f.Multiclusteringress, res); err != nil {
return nil, fmt.Errorf("error expanding Multiclusteringress into multiclusteringress: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["multiclusteringress"] = v
}
if v, err := expandFeatureSpecFleetobservability(c, f.Fleetobservability, res); err != nil {
return nil, fmt.Errorf("error expanding Fleetobservability into fleetobservability: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["fleetobservability"] = v
}
return m, nil
}
// flattenFeatureSpec flattens an instance of FeatureSpec from a JSON
// response object.
func flattenFeatureSpec(c *Client, i interface{}, res *Feature) *FeatureSpec {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureSpec{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureSpec
}
r.Multiclusteringress = flattenFeatureSpecMulticlusteringress(c, m["multiclusteringress"], res)
r.Fleetobservability = flattenFeatureSpecFleetobservability(c, m["fleetobservability"], res)
return r
}
// expandFeatureSpecMulticlusteringressMap expands the contents of FeatureSpecMulticlusteringress into a JSON
// request object.
func expandFeatureSpecMulticlusteringressMap(c *Client, f map[string]FeatureSpecMulticlusteringress, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureSpecMulticlusteringress(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureSpecMulticlusteringressSlice expands the contents of FeatureSpecMulticlusteringress into a JSON
// request object.
func expandFeatureSpecMulticlusteringressSlice(c *Client, f []FeatureSpecMulticlusteringress, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureSpecMulticlusteringress(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureSpecMulticlusteringressMap flattens the contents of FeatureSpecMulticlusteringress from a JSON
// response object.
func flattenFeatureSpecMulticlusteringressMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecMulticlusteringress {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecMulticlusteringress{}
}
if len(a) == 0 {
return map[string]FeatureSpecMulticlusteringress{}
}
items := make(map[string]FeatureSpecMulticlusteringress)
for k, item := range a {
items[k] = *flattenFeatureSpecMulticlusteringress(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureSpecMulticlusteringressSlice flattens the contents of FeatureSpecMulticlusteringress from a JSON
// response object.
func flattenFeatureSpecMulticlusteringressSlice(c *Client, i interface{}, res *Feature) []FeatureSpecMulticlusteringress {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecMulticlusteringress{}
}
if len(a) == 0 {
return []FeatureSpecMulticlusteringress{}
}
items := make([]FeatureSpecMulticlusteringress, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecMulticlusteringress(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureSpecMulticlusteringress expands an instance of FeatureSpecMulticlusteringress into a JSON
// request object.
func expandFeatureSpecMulticlusteringress(c *Client, f *FeatureSpecMulticlusteringress, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.ConfigMembership; !dcl.IsEmptyValueIndirect(v) {
m["configMembership"] = v
}
return m, nil
}
// flattenFeatureSpecMulticlusteringress flattens an instance of FeatureSpecMulticlusteringress from a JSON
// response object.
func flattenFeatureSpecMulticlusteringress(c *Client, i interface{}, res *Feature) *FeatureSpecMulticlusteringress {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureSpecMulticlusteringress{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureSpecMulticlusteringress
}
r.ConfigMembership = dcl.FlattenString(m["configMembership"])
return r
}
// expandFeatureSpecFleetobservabilityMap expands the contents of FeatureSpecFleetobservability into a JSON
// request object.
func expandFeatureSpecFleetobservabilityMap(c *Client, f map[string]FeatureSpecFleetobservability, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureSpecFleetobservability(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureSpecFleetobservabilitySlice expands the contents of FeatureSpecFleetobservability into a JSON
// request object.
func expandFeatureSpecFleetobservabilitySlice(c *Client, f []FeatureSpecFleetobservability, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureSpecFleetobservability(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureSpecFleetobservabilityMap flattens the contents of FeatureSpecFleetobservability from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecFleetobservability {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecFleetobservability{}
}
if len(a) == 0 {
return map[string]FeatureSpecFleetobservability{}
}
items := make(map[string]FeatureSpecFleetobservability)
for k, item := range a {
items[k] = *flattenFeatureSpecFleetobservability(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureSpecFleetobservabilitySlice flattens the contents of FeatureSpecFleetobservability from a JSON
// response object.
func flattenFeatureSpecFleetobservabilitySlice(c *Client, i interface{}, res *Feature) []FeatureSpecFleetobservability {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecFleetobservability{}
}
if len(a) == 0 {
return []FeatureSpecFleetobservability{}
}
items := make([]FeatureSpecFleetobservability, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecFleetobservability(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureSpecFleetobservability expands an instance of FeatureSpecFleetobservability into a JSON
// request object.
func expandFeatureSpecFleetobservability(c *Client, f *FeatureSpecFleetobservability, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v, err := expandFeatureSpecFleetobservabilityLoggingConfig(c, f.LoggingConfig, res); err != nil {
return nil, fmt.Errorf("error expanding LoggingConfig into loggingConfig: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["loggingConfig"] = v
}
return m, nil
}
// flattenFeatureSpecFleetobservability flattens an instance of FeatureSpecFleetobservability from a JSON
// response object.
func flattenFeatureSpecFleetobservability(c *Client, i interface{}, res *Feature) *FeatureSpecFleetobservability {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureSpecFleetobservability{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureSpecFleetobservability
}
r.LoggingConfig = flattenFeatureSpecFleetobservabilityLoggingConfig(c, m["loggingConfig"], res)
return r
}
// expandFeatureSpecFleetobservabilityLoggingConfigMap expands the contents of FeatureSpecFleetobservabilityLoggingConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigMap(c *Client, f map[string]FeatureSpecFleetobservabilityLoggingConfig, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureSpecFleetobservabilityLoggingConfig(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureSpecFleetobservabilityLoggingConfigSlice expands the contents of FeatureSpecFleetobservabilityLoggingConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigSlice(c *Client, f []FeatureSpecFleetobservabilityLoggingConfig, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureSpecFleetobservabilityLoggingConfig(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureSpecFleetobservabilityLoggingConfigMap flattens the contents of FeatureSpecFleetobservabilityLoggingConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecFleetobservabilityLoggingConfig {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecFleetobservabilityLoggingConfig{}
}
if len(a) == 0 {
return map[string]FeatureSpecFleetobservabilityLoggingConfig{}
}
items := make(map[string]FeatureSpecFleetobservabilityLoggingConfig)
for k, item := range a {
items[k] = *flattenFeatureSpecFleetobservabilityLoggingConfig(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigSlice flattens the contents of FeatureSpecFleetobservabilityLoggingConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigSlice(c *Client, i interface{}, res *Feature) []FeatureSpecFleetobservabilityLoggingConfig {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecFleetobservabilityLoggingConfig{}
}
if len(a) == 0 {
return []FeatureSpecFleetobservabilityLoggingConfig{}
}
items := make([]FeatureSpecFleetobservabilityLoggingConfig, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecFleetobservabilityLoggingConfig(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureSpecFleetobservabilityLoggingConfig expands an instance of FeatureSpecFleetobservabilityLoggingConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfig(c *Client, f *FeatureSpecFleetobservabilityLoggingConfig, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v, err := expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, f.DefaultConfig, res); err != nil {
return nil, fmt.Errorf("error expanding DefaultConfig into defaultConfig: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["defaultConfig"] = v
}
if v, err := expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, f.FleetScopeLogsConfig, res); err != nil {
return nil, fmt.Errorf("error expanding FleetScopeLogsConfig into fleetScopeLogsConfig: %w", err)
} else if !dcl.IsEmptyValueIndirect(v) {
m["fleetScopeLogsConfig"] = v
}
return m, nil
}
// flattenFeatureSpecFleetobservabilityLoggingConfig flattens an instance of FeatureSpecFleetobservabilityLoggingConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfig(c *Client, i interface{}, res *Feature) *FeatureSpecFleetobservabilityLoggingConfig {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureSpecFleetobservabilityLoggingConfig{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureSpecFleetobservabilityLoggingConfig
}
r.DefaultConfig = flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, m["defaultConfig"], res)
r.FleetScopeLogsConfig = flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, m["fleetScopeLogsConfig"], res)
return r
}
// expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfigMap expands the contents of FeatureSpecFleetobservabilityLoggingConfigDefaultConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfigMap(c *Client, f map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSlice expands the contents of FeatureSpecFleetobservabilityLoggingConfigDefaultConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSlice(c *Client, f []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigMap flattens the contents of FeatureSpecFleetobservabilityLoggingConfigDefaultConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
}
if len(a) == 0 {
return map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
}
items := make(map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig)
for k, item := range a {
items[k] = *flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSlice flattens the contents of FeatureSpecFleetobservabilityLoggingConfigDefaultConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigSlice(c *Client, i interface{}, res *Feature) []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
}
if len(a) == 0 {
return []FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
}
items := make([]FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfig expands an instance of FeatureSpecFleetobservabilityLoggingConfigDefaultConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c *Client, f *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.Mode; !dcl.IsEmptyValueIndirect(v) {
m["mode"] = v
}
return m, nil
}
// flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfig flattens an instance of FeatureSpecFleetobservabilityLoggingConfigDefaultConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfig(c *Client, i interface{}, res *Feature) *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureSpecFleetobservabilityLoggingConfigDefaultConfig
}
r.Mode = flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum(m["mode"])
return r
}
// expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigMap expands the contents of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigMap(c *Client, f map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSlice expands the contents of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSlice(c *Client, f []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigMap flattens the contents of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
}
if len(a) == 0 {
return map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
}
items := make(map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig)
for k, item := range a {
items[k] = *flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSlice flattens the contents of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigSlice(c *Client, i interface{}, res *Feature) []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
}
if len(a) == 0 {
return []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
}
items := make([]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig expands an instance of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig into a JSON
// request object.
func expandFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c *Client, f *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
if v := f.Mode; !dcl.IsEmptyValueIndirect(v) {
m["mode"] = v
}
return m, nil
}
// flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig flattens an instance of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig(c *Client, i interface{}, res *Feature) *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig
}
r.Mode = flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum(m["mode"])
return r
}
// expandFeatureStateMap expands the contents of FeatureState into a JSON
// request object.
func expandFeatureStateMap(c *Client, f map[string]FeatureState, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureState(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureStateSlice expands the contents of FeatureState into a JSON
// request object.
func expandFeatureStateSlice(c *Client, f []FeatureState, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureState(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureStateMap flattens the contents of FeatureState from a JSON
// response object.
func flattenFeatureStateMap(c *Client, i interface{}, res *Feature) map[string]FeatureState {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureState{}
}
if len(a) == 0 {
return map[string]FeatureState{}
}
items := make(map[string]FeatureState)
for k, item := range a {
items[k] = *flattenFeatureState(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureStateSlice flattens the contents of FeatureState from a JSON
// response object.
func flattenFeatureStateSlice(c *Client, i interface{}, res *Feature) []FeatureState {
a, ok := i.([]interface{})
if !ok {
return []FeatureState{}
}
if len(a) == 0 {
return []FeatureState{}
}
items := make([]FeatureState, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureState(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureState expands an instance of FeatureState into a JSON
// request object.
func expandFeatureState(c *Client, f *FeatureState, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
return m, nil
}
// flattenFeatureState flattens an instance of FeatureState from a JSON
// response object.
func flattenFeatureState(c *Client, i interface{}, res *Feature) *FeatureState {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureState{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureState
}
r.State = flattenFeatureStateState(c, m["state"], res)
return r
}
// expandFeatureStateStateMap expands the contents of FeatureStateState into a JSON
// request object.
func expandFeatureStateStateMap(c *Client, f map[string]FeatureStateState, res *Feature) (map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := make(map[string]interface{})
for k, item := range f {
i, err := expandFeatureStateState(c, &item, res)
if err != nil {
return nil, err
}
if i != nil {
items[k] = i
}
}
return items, nil
}
// expandFeatureStateStateSlice expands the contents of FeatureStateState into a JSON
// request object.
func expandFeatureStateStateSlice(c *Client, f []FeatureStateState, res *Feature) ([]map[string]interface{}, error) {
if f == nil {
return nil, nil
}
items := []map[string]interface{}{}
for _, item := range f {
i, err := expandFeatureStateState(c, &item, res)
if err != nil {
return nil, err
}
items = append(items, i)
}
return items, nil
}
// flattenFeatureStateStateMap flattens the contents of FeatureStateState from a JSON
// response object.
func flattenFeatureStateStateMap(c *Client, i interface{}, res *Feature) map[string]FeatureStateState {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureStateState{}
}
if len(a) == 0 {
return map[string]FeatureStateState{}
}
items := make(map[string]FeatureStateState)
for k, item := range a {
items[k] = *flattenFeatureStateState(c, item.(map[string]interface{}), res)
}
return items
}
// flattenFeatureStateStateSlice flattens the contents of FeatureStateState from a JSON
// response object.
func flattenFeatureStateStateSlice(c *Client, i interface{}, res *Feature) []FeatureStateState {
a, ok := i.([]interface{})
if !ok {
return []FeatureStateState{}
}
if len(a) == 0 {
return []FeatureStateState{}
}
items := make([]FeatureStateState, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureStateState(c, item.(map[string]interface{}), res))
}
return items
}
// expandFeatureStateState expands an instance of FeatureStateState into a JSON
// request object.
func expandFeatureStateState(c *Client, f *FeatureStateState, res *Feature) (map[string]interface{}, error) {
if dcl.IsEmptyValueIndirect(f) {
return nil, nil
}
m := make(map[string]interface{})
return m, nil
}
// flattenFeatureStateState flattens an instance of FeatureStateState from a JSON
// response object.
func flattenFeatureStateState(c *Client, i interface{}, res *Feature) *FeatureStateState {
m, ok := i.(map[string]interface{})
if !ok {
return nil
}
r := &FeatureStateState{}
if dcl.IsEmptyValueIndirect(i) {
return EmptyFeatureStateState
}
r.Code = flattenFeatureStateStateCodeEnum(m["code"])
r.Description = dcl.FlattenString(m["description"])
r.UpdateTime = dcl.FlattenString(m["updateTime"])
return r
}
// flattenFeatureResourceStateStateEnumMap flattens the contents of FeatureResourceStateStateEnum from a JSON
// response object.
func flattenFeatureResourceStateStateEnumMap(c *Client, i interface{}, res *Feature) map[string]FeatureResourceStateStateEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureResourceStateStateEnum{}
}
if len(a) == 0 {
return map[string]FeatureResourceStateStateEnum{}
}
items := make(map[string]FeatureResourceStateStateEnum)
for k, item := range a {
items[k] = *flattenFeatureResourceStateStateEnum(item.(interface{}))
}
return items
}
// flattenFeatureResourceStateStateEnumSlice flattens the contents of FeatureResourceStateStateEnum from a JSON
// response object.
func flattenFeatureResourceStateStateEnumSlice(c *Client, i interface{}, res *Feature) []FeatureResourceStateStateEnum {
a, ok := i.([]interface{})
if !ok {
return []FeatureResourceStateStateEnum{}
}
if len(a) == 0 {
return []FeatureResourceStateStateEnum{}
}
items := make([]FeatureResourceStateStateEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureResourceStateStateEnum(item.(interface{})))
}
return items
}
// flattenFeatureResourceStateStateEnum asserts that an interface is a string, and returns a
// pointer to a *FeatureResourceStateStateEnum with the same value as that string.
func flattenFeatureResourceStateStateEnum(i interface{}) *FeatureResourceStateStateEnum {
s, ok := i.(string)
if !ok {
return nil
}
return FeatureResourceStateStateEnumRef(s)
}
// flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnumMap flattens the contents of FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnumMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum{}
}
if len(a) == 0 {
return map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum{}
}
items := make(map[string]FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum)
for k, item := range a {
items[k] = *flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum(item.(interface{}))
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnumSlice flattens the contents of FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnumSlice(c *Client, i interface{}, res *Feature) []FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum{}
}
if len(a) == 0 {
return []FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum{}
}
items := make([]FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum(item.(interface{})))
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum asserts that an interface is a string, and returns a
// pointer to a *FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum with the same value as that string.
func flattenFeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum(i interface{}) *FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnum {
s, ok := i.(string)
if !ok {
return nil
}
return FeatureSpecFleetobservabilityLoggingConfigDefaultConfigModeEnumRef(s)
}
// flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnumMap flattens the contents of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnumMap(c *Client, i interface{}, res *Feature) map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum{}
}
if len(a) == 0 {
return map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum{}
}
items := make(map[string]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum)
for k, item := range a {
items[k] = *flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum(item.(interface{}))
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnumSlice flattens the contents of FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum from a JSON
// response object.
func flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnumSlice(c *Client, i interface{}, res *Feature) []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum {
a, ok := i.([]interface{})
if !ok {
return []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum{}
}
if len(a) == 0 {
return []FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum{}
}
items := make([]FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum(item.(interface{})))
}
return items
}
// flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum asserts that an interface is a string, and returns a
// pointer to a *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum with the same value as that string.
func flattenFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum(i interface{}) *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnum {
s, ok := i.(string)
if !ok {
return nil
}
return FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigModeEnumRef(s)
}
// flattenFeatureStateStateCodeEnumMap flattens the contents of FeatureStateStateCodeEnum from a JSON
// response object.
func flattenFeatureStateStateCodeEnumMap(c *Client, i interface{}, res *Feature) map[string]FeatureStateStateCodeEnum {
a, ok := i.(map[string]interface{})
if !ok {
return map[string]FeatureStateStateCodeEnum{}
}
if len(a) == 0 {
return map[string]FeatureStateStateCodeEnum{}
}
items := make(map[string]FeatureStateStateCodeEnum)
for k, item := range a {
items[k] = *flattenFeatureStateStateCodeEnum(item.(interface{}))
}
return items
}
// flattenFeatureStateStateCodeEnumSlice flattens the contents of FeatureStateStateCodeEnum from a JSON
// response object.
func flattenFeatureStateStateCodeEnumSlice(c *Client, i interface{}, res *Feature) []FeatureStateStateCodeEnum {
a, ok := i.([]interface{})
if !ok {
return []FeatureStateStateCodeEnum{}
}
if len(a) == 0 {
return []FeatureStateStateCodeEnum{}
}
items := make([]FeatureStateStateCodeEnum, 0, len(a))
for _, item := range a {
items = append(items, *flattenFeatureStateStateCodeEnum(item.(interface{})))
}
return items
}
// flattenFeatureStateStateCodeEnum asserts that an interface is a string, and returns a
// pointer to a *FeatureStateStateCodeEnum with the same value as that string.
func flattenFeatureStateStateCodeEnum(i interface{}) *FeatureStateStateCodeEnum {
s, ok := i.(string)
if !ok {
return nil
}
return FeatureStateStateCodeEnumRef(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 *Feature) matcher(c *Client) func([]byte) bool {
return func(b []byte) bool {
cr, err := unmarshalFeature(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.Location == nil && ncr.Location == nil {
c.Config.Logger.Info("Both Location fields null - considering equal.")
} else if nr.Location == nil || ncr.Location == nil {
c.Config.Logger.Info("Only one Location field is null - considering unequal.")
return false
} else if *nr.Location != *ncr.Location {
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 featureDiff struct {
// The diff should include one or the other of RequiresRecreate or UpdateOp.
RequiresRecreate bool
UpdateOp featureApiOperation
FieldName string // used for error logging
}
func convertFieldDiffsToFeatureDiffs(config *dcl.Config, fds []*dcl.FieldDiff, opts []dcl.ApplyOption) ([]featureDiff, 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 []featureDiff
// For each operation name, create a featureDiff which contains the operation.
for opName, fieldDiffs := range opNamesToFieldDiffs {
// Use the first field diff's field name for logging required recreate error.
diff := featureDiff{FieldName: fieldDiffs[0].FieldName}
if opName == "Recreate" {
diff.RequiresRecreate = true
} else {
apiOp, err := convertOpNameToFeatureApiOperation(opName, fieldDiffs, opts...)
if err != nil {
return diffs, err
}
diff.UpdateOp = apiOp
}
diffs = append(diffs, diff)
}
return diffs, nil
}
func convertOpNameToFeatureApiOperation(opName string, fieldDiffs []*dcl.FieldDiff, opts ...dcl.ApplyOption) (featureApiOperation, error) {
switch opName {
case "updateFeatureUpdateFeatureOperation":
return &updateFeatureUpdateFeatureOperation{FieldDiffs: fieldDiffs}, nil
default:
return nil, fmt.Errorf("no such operation with name: %v", opName)
}
}
func extractFeatureFields(r *Feature) error {
vResourceState := r.ResourceState
if vResourceState == nil {
// note: explicitly not the empty object.
vResourceState = &FeatureResourceState{}
}
if err := extractFeatureResourceStateFields(r, vResourceState); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vResourceState) {
r.ResourceState = vResourceState
}
vSpec := r.Spec
if vSpec == nil {
// note: explicitly not the empty object.
vSpec = &FeatureSpec{}
}
if err := extractFeatureSpecFields(r, vSpec); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vSpec) {
r.Spec = vSpec
}
vState := r.State
if vState == nil {
// note: explicitly not the empty object.
vState = &FeatureState{}
}
if err := extractFeatureStateFields(r, vState); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vState) {
r.State = vState
}
return nil
}
func extractFeatureResourceStateFields(r *Feature, o *FeatureResourceState) error {
return nil
}
func extractFeatureSpecFields(r *Feature, o *FeatureSpec) error {
vMulticlusteringress := o.Multiclusteringress
if vMulticlusteringress == nil {
// note: explicitly not the empty object.
vMulticlusteringress = &FeatureSpecMulticlusteringress{}
}
if err := extractFeatureSpecMulticlusteringressFields(r, vMulticlusteringress); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vMulticlusteringress) {
o.Multiclusteringress = vMulticlusteringress
}
vFleetobservability := o.Fleetobservability
if vFleetobservability == nil {
// note: explicitly not the empty object.
vFleetobservability = &FeatureSpecFleetobservability{}
}
if err := extractFeatureSpecFleetobservabilityFields(r, vFleetobservability); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vFleetobservability) {
o.Fleetobservability = vFleetobservability
}
return nil
}
func extractFeatureSpecMulticlusteringressFields(r *Feature, o *FeatureSpecMulticlusteringress) error {
return nil
}
func extractFeatureSpecFleetobservabilityFields(r *Feature, o *FeatureSpecFleetobservability) error {
vLoggingConfig := o.LoggingConfig
if vLoggingConfig == nil {
// note: explicitly not the empty object.
vLoggingConfig = &FeatureSpecFleetobservabilityLoggingConfig{}
}
if err := extractFeatureSpecFleetobservabilityLoggingConfigFields(r, vLoggingConfig); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vLoggingConfig) {
o.LoggingConfig = vLoggingConfig
}
return nil
}
func extractFeatureSpecFleetobservabilityLoggingConfigFields(r *Feature, o *FeatureSpecFleetobservabilityLoggingConfig) error {
vDefaultConfig := o.DefaultConfig
if vDefaultConfig == nil {
// note: explicitly not the empty object.
vDefaultConfig = &FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
}
if err := extractFeatureSpecFleetobservabilityLoggingConfigDefaultConfigFields(r, vDefaultConfig); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vDefaultConfig) {
o.DefaultConfig = vDefaultConfig
}
vFleetScopeLogsConfig := o.FleetScopeLogsConfig
if vFleetScopeLogsConfig == nil {
// note: explicitly not the empty object.
vFleetScopeLogsConfig = &FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
}
if err := extractFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigFields(r, vFleetScopeLogsConfig); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vFleetScopeLogsConfig) {
o.FleetScopeLogsConfig = vFleetScopeLogsConfig
}
return nil
}
func extractFeatureSpecFleetobservabilityLoggingConfigDefaultConfigFields(r *Feature, o *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig) error {
return nil
}
func extractFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigFields(r *Feature, o *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig) error {
return nil
}
func extractFeatureStateFields(r *Feature, o *FeatureState) error {
vState := o.State
if vState == nil {
// note: explicitly not the empty object.
vState = &FeatureStateState{}
}
if err := extractFeatureStateStateFields(r, vState); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vState) {
o.State = vState
}
return nil
}
func extractFeatureStateStateFields(r *Feature, o *FeatureStateState) error {
return nil
}
func postReadExtractFeatureFields(r *Feature) error {
vResourceState := r.ResourceState
if vResourceState == nil {
// note: explicitly not the empty object.
vResourceState = &FeatureResourceState{}
}
if err := postReadExtractFeatureResourceStateFields(r, vResourceState); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vResourceState) {
r.ResourceState = vResourceState
}
vSpec := r.Spec
if vSpec == nil {
// note: explicitly not the empty object.
vSpec = &FeatureSpec{}
}
if err := postReadExtractFeatureSpecFields(r, vSpec); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vSpec) {
r.Spec = vSpec
}
vState := r.State
if vState == nil {
// note: explicitly not the empty object.
vState = &FeatureState{}
}
if err := postReadExtractFeatureStateFields(r, vState); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vState) {
r.State = vState
}
return nil
}
func postReadExtractFeatureResourceStateFields(r *Feature, o *FeatureResourceState) error {
return nil
}
func postReadExtractFeatureSpecFields(r *Feature, o *FeatureSpec) error {
vMulticlusteringress := o.Multiclusteringress
if vMulticlusteringress == nil {
// note: explicitly not the empty object.
vMulticlusteringress = &FeatureSpecMulticlusteringress{}
}
if err := extractFeatureSpecMulticlusteringressFields(r, vMulticlusteringress); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vMulticlusteringress) {
o.Multiclusteringress = vMulticlusteringress
}
vFleetobservability := o.Fleetobservability
if vFleetobservability == nil {
// note: explicitly not the empty object.
vFleetobservability = &FeatureSpecFleetobservability{}
}
if err := extractFeatureSpecFleetobservabilityFields(r, vFleetobservability); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vFleetobservability) {
o.Fleetobservability = vFleetobservability
}
return nil
}
func postReadExtractFeatureSpecMulticlusteringressFields(r *Feature, o *FeatureSpecMulticlusteringress) error {
return nil
}
func postReadExtractFeatureSpecFleetobservabilityFields(r *Feature, o *FeatureSpecFleetobservability) error {
vLoggingConfig := o.LoggingConfig
if vLoggingConfig == nil {
// note: explicitly not the empty object.
vLoggingConfig = &FeatureSpecFleetobservabilityLoggingConfig{}
}
if err := extractFeatureSpecFleetobservabilityLoggingConfigFields(r, vLoggingConfig); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vLoggingConfig) {
o.LoggingConfig = vLoggingConfig
}
return nil
}
func postReadExtractFeatureSpecFleetobservabilityLoggingConfigFields(r *Feature, o *FeatureSpecFleetobservabilityLoggingConfig) error {
vDefaultConfig := o.DefaultConfig
if vDefaultConfig == nil {
// note: explicitly not the empty object.
vDefaultConfig = &FeatureSpecFleetobservabilityLoggingConfigDefaultConfig{}
}
if err := extractFeatureSpecFleetobservabilityLoggingConfigDefaultConfigFields(r, vDefaultConfig); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vDefaultConfig) {
o.DefaultConfig = vDefaultConfig
}
vFleetScopeLogsConfig := o.FleetScopeLogsConfig
if vFleetScopeLogsConfig == nil {
// note: explicitly not the empty object.
vFleetScopeLogsConfig = &FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig{}
}
if err := extractFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigFields(r, vFleetScopeLogsConfig); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vFleetScopeLogsConfig) {
o.FleetScopeLogsConfig = vFleetScopeLogsConfig
}
return nil
}
func postReadExtractFeatureSpecFleetobservabilityLoggingConfigDefaultConfigFields(r *Feature, o *FeatureSpecFleetobservabilityLoggingConfigDefaultConfig) error {
return nil
}
func postReadExtractFeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfigFields(r *Feature, o *FeatureSpecFleetobservabilityLoggingConfigFleetScopeLogsConfig) error {
return nil
}
func postReadExtractFeatureStateFields(r *Feature, o *FeatureState) error {
vState := o.State
if vState == nil {
// note: explicitly not the empty object.
vState = &FeatureStateState{}
}
if err := extractFeatureStateStateFields(r, vState); err != nil {
return err
}
if !dcl.IsEmptyValueIndirect(vState) {
o.State = vState
}
return nil
}
func postReadExtractFeatureStateStateFields(r *Feature, o *FeatureStateState) error {
return nil
}