// Copyright (c) 2016, 2018, 2025, Oracle and/or its affiliates. All rights reserved. // This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. // Code generated. DO NOT EDIT. // DNS API // // API for the DNS service. Use this API to manage DNS zones, records, and other DNS resources. // For more information, see Overview of the DNS Service (https://docs.oracle.com/iaas/Content/DNS/Concepts/dnszonemanagement.htm). // package dns import ( "encoding/json" "fmt" "strings" "github.com/nrdcg/oci-go-sdk/common/v1065" ) // UpdateResolverDetails The body for updating an existing resolver. // **Warning:** Oracle recommends that you avoid using any confidential information when you supply string values using the API. type UpdateResolverDetails struct { // The display name of the resolver. DisplayName *string `mandatory:"false" json:"displayName"` // Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. // For more information, see Resource Tags (https://docs.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). // // **Example:** `{"Department": "Finance"}` FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` // Defined tags for this resource. Each key is predefined and scoped to a namespace. // For more information, see Resource Tags (https://docs.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). // // **Example:** `{"Operations": {"CostCenter": "42"}}` DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` // The attached views. Views are evaluated in order. AttachedViews []AttachedViewDetails `mandatory:"false" json:"attachedViews"` // Rules for the resolver. Rules are evaluated in order. Rules []ResolverRuleDetails `mandatory:"false" json:"rules"` } func (m UpdateResolverDetails) String() string { return common.PointerString(m) } // ValidateEnumValue returns an error when providing an unsupported enum value // This function is being called during constructing API request process // Not recommended for calling this function directly func (m UpdateResolverDetails) ValidateEnumValue() (bool, error) { errMessage := []string{} if len(errMessage) > 0 { return true, fmt.Errorf("%s", strings.Join(errMessage, "\n")) } return false, nil } // UnmarshalJSON unmarshals from json func (m *UpdateResolverDetails) UnmarshalJSON(data []byte) (e error) { model := struct { DisplayName *string `json:"displayName"` FreeformTags map[string]string `json:"freeformTags"` DefinedTags map[string]map[string]interface{} `json:"definedTags"` AttachedViews []AttachedViewDetails `json:"attachedViews"` Rules []resolverruledetails `json:"rules"` }{} e = json.Unmarshal(data, &model) if e != nil { return } var nn interface{} m.DisplayName = model.DisplayName m.FreeformTags = model.FreeformTags m.DefinedTags = model.DefinedTags m.AttachedViews = make([]AttachedViewDetails, len(model.AttachedViews)) copy(m.AttachedViews, model.AttachedViews) m.Rules = make([]ResolverRuleDetails, len(model.Rules)) for i, n := range model.Rules { nn, e = n.UnmarshalPolymorphicJSON(n.JsonData) if e != nil { return e } if nn != nil { m.Rules[i] = nn.(ResolverRuleDetails) } else { m.Rules[i] = nil } } return }