// Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. // This product includes software developed at Datadog (https://www.datadoghq.com/). // Copyright 2019-Present Datadog, Inc. package datadogV2 import ( "encoding/json" "fmt" "github.com/DataDog/datadog-api-client-go/v2/api/datadog" ) // Permission Permission object. type Permission struct { // Attributes of a permission. Attributes *PermissionAttributes `json:"attributes,omitempty"` // ID of the permission. Id *string `json:"id,omitempty"` // Permissions resource type. Type PermissionsType `json:"type"` // UnparsedObject contains the raw value of the object if there was an error when deserializing into the struct UnparsedObject map[string]interface{} `json:"-"` AdditionalProperties map[string]interface{} } // NewPermission instantiates a new Permission object. // This constructor will assign default values to properties that have it defined, // and makes sure properties required by API are set, but the set of arguments // will change when the set of required properties is changed. func NewPermission(typeVar PermissionsType) *Permission { this := Permission{} this.Type = typeVar return &this } // NewPermissionWithDefaults instantiates a new Permission object. // This constructor will only assign default values to properties that have it defined, // but it doesn't guarantee that properties required by API are set. func NewPermissionWithDefaults() *Permission { this := Permission{} var typeVar PermissionsType = PERMISSIONSTYPE_PERMISSIONS this.Type = typeVar return &this } // GetAttributes returns the Attributes field value if set, zero value otherwise. func (o *Permission) GetAttributes() PermissionAttributes { if o == nil || o.Attributes == nil { var ret PermissionAttributes return ret } return *o.Attributes } // GetAttributesOk returns a tuple with the Attributes field value if set, nil otherwise // and a boolean to check if the value has been set. func (o *Permission) GetAttributesOk() (*PermissionAttributes, bool) { if o == nil || o.Attributes == nil { return nil, false } return o.Attributes, true } // HasAttributes returns a boolean if a field has been set. func (o *Permission) HasAttributes() bool { return o != nil && o.Attributes != nil } // SetAttributes gets a reference to the given PermissionAttributes and assigns it to the Attributes field. func (o *Permission) SetAttributes(v PermissionAttributes) { o.Attributes = &v } // GetId returns the Id field value if set, zero value otherwise. func (o *Permission) GetId() string { if o == nil || o.Id == nil { var ret string return ret } return *o.Id } // GetIdOk returns a tuple with the Id field value if set, nil otherwise // and a boolean to check if the value has been set. func (o *Permission) GetIdOk() (*string, bool) { if o == nil || o.Id == nil { return nil, false } return o.Id, true } // HasId returns a boolean if a field has been set. func (o *Permission) HasId() bool { return o != nil && o.Id != nil } // SetId gets a reference to the given string and assigns it to the Id field. func (o *Permission) SetId(v string) { o.Id = &v } // GetType returns the Type field value. func (o *Permission) GetType() PermissionsType { if o == nil { var ret PermissionsType return ret } return o.Type } // GetTypeOk returns a tuple with the Type field value // and a boolean to check if the value has been set. func (o *Permission) GetTypeOk() (*PermissionsType, bool) { if o == nil { return nil, false } return &o.Type, true } // SetType sets field value. func (o *Permission) SetType(v PermissionsType) { o.Type = v } // MarshalJSON serializes the struct using spec logic. func (o Permission) MarshalJSON() ([]byte, error) { toSerialize := map[string]interface{}{} if o.UnparsedObject != nil { return json.Marshal(o.UnparsedObject) } if o.Attributes != nil { toSerialize["attributes"] = o.Attributes } if o.Id != nil { toSerialize["id"] = o.Id } toSerialize["type"] = o.Type for key, value := range o.AdditionalProperties { toSerialize[key] = value } return json.Marshal(toSerialize) } // UnmarshalJSON deserializes the given payload. func (o *Permission) UnmarshalJSON(bytes []byte) (err error) { raw := map[string]interface{}{} all := struct { Attributes *PermissionAttributes `json:"attributes,omitempty"` Id *string `json:"id,omitempty"` Type *PermissionsType `json:"type"` }{} if err = json.Unmarshal(bytes, &all); err != nil { err = json.Unmarshal(bytes, &raw) if err != nil { return err } o.UnparsedObject = raw return nil } if all.Type == nil { return fmt.Errorf("required field type missing") } additionalProperties := make(map[string]interface{}) if err = json.Unmarshal(bytes, &additionalProperties); err == nil { datadog.DeleteKeys(additionalProperties, &[]string{"attributes", "id", "type"}) } else { return err } if v := all.Type; !v.IsValid() { err = json.Unmarshal(bytes, &raw) if err != nil { return err } o.UnparsedObject = raw return nil } if all.Attributes != nil && all.Attributes.UnparsedObject != nil && o.UnparsedObject == nil { err = json.Unmarshal(bytes, &raw) if err != nil { return err } o.UnparsedObject = raw } o.Attributes = all.Attributes o.Id = all.Id o.Type = *all.Type if len(additionalProperties) > 0 { o.AdditionalProperties = additionalProperties } return nil }