All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.azure.resourcemanager.compute.models.SecurityProfile Maven / Gradle / Ivy

Go to download

This package contains Microsoft Azure Compute Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt

There is a newer version: 2.44.0
Show newest version
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.

package com.azure.resourcemanager.compute.models;

import com.azure.core.annotation.Fluent;
import com.azure.json.JsonReader;
import com.azure.json.JsonSerializable;
import com.azure.json.JsonToken;
import com.azure.json.JsonWriter;
import java.io.IOException;

/**
 * Specifies the Security profile settings for the virtual machine or virtual machine scale set.
 */
@Fluent
public final class SecurityProfile implements JsonSerializable {
    /*
     * Specifies the security settings like secure boot and vTPM used while creating the virtual machine. Minimum
     * api-version: 2020-12-01.
     */
    private UefiSettings uefiSettings;

    /*
     * This property can be used by user in the request to enable or disable the Host Encryption for the virtual machine
     * or virtual machine scale set. This will enable the encryption for all the disks including Resource/Temp disk at
     * host itself. The default behavior is: The Encryption at host will be disabled unless this property is set to true
     * for the resource.
     */
    private Boolean encryptionAtHost;

    /*
     * Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable
     * UefiSettings. The default behavior is: UefiSettings will not be enabled unless this property is set.
     */
    private SecurityTypes securityType;

    /*
     * Specifies the Managed Identity used by ADE to get access token for keyvault operations.
     */
    private EncryptionIdentity encryptionIdentity;

    /*
     * Specifies ProxyAgent settings while creating the virtual machine. Minimum api-version: 2023-09-01.
     */
    private ProxyAgentSettings proxyAgentSettings;

    /**
     * Creates an instance of SecurityProfile class.
     */
    public SecurityProfile() {
    }

    /**
     * Get the uefiSettings property: Specifies the security settings like secure boot and vTPM used while creating the
     * virtual machine. Minimum api-version: 2020-12-01.
     * 
     * @return the uefiSettings value.
     */
    public UefiSettings uefiSettings() {
        return this.uefiSettings;
    }

    /**
     * Set the uefiSettings property: Specifies the security settings like secure boot and vTPM used while creating the
     * virtual machine. Minimum api-version: 2020-12-01.
     * 
     * @param uefiSettings the uefiSettings value to set.
     * @return the SecurityProfile object itself.
     */
    public SecurityProfile withUefiSettings(UefiSettings uefiSettings) {
        this.uefiSettings = uefiSettings;
        return this;
    }

    /**
     * Get the encryptionAtHost property: This property can be used by user in the request to enable or disable the Host
     * Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the
     * disks including Resource/Temp disk at host itself. The default behavior is: The Encryption at host will be
     * disabled unless this property is set to true for the resource.
     * 
     * @return the encryptionAtHost value.
     */
    public Boolean encryptionAtHost() {
        return this.encryptionAtHost;
    }

    /**
     * Set the encryptionAtHost property: This property can be used by user in the request to enable or disable the Host
     * Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the
     * disks including Resource/Temp disk at host itself. The default behavior is: The Encryption at host will be
     * disabled unless this property is set to true for the resource.
     * 
     * @param encryptionAtHost the encryptionAtHost value to set.
     * @return the SecurityProfile object itself.
     */
    public SecurityProfile withEncryptionAtHost(Boolean encryptionAtHost) {
        this.encryptionAtHost = encryptionAtHost;
        return this;
    }

    /**
     * Get the securityType property: Specifies the SecurityType of the virtual machine. It has to be set to any
     * specified value to enable UefiSettings. The default behavior is: UefiSettings will not be enabled unless this
     * property is set.
     * 
     * @return the securityType value.
     */
    public SecurityTypes securityType() {
        return this.securityType;
    }

    /**
     * Set the securityType property: Specifies the SecurityType of the virtual machine. It has to be set to any
     * specified value to enable UefiSettings. The default behavior is: UefiSettings will not be enabled unless this
     * property is set.
     * 
     * @param securityType the securityType value to set.
     * @return the SecurityProfile object itself.
     */
    public SecurityProfile withSecurityType(SecurityTypes securityType) {
        this.securityType = securityType;
        return this;
    }

    /**
     * Get the encryptionIdentity property: Specifies the Managed Identity used by ADE to get access token for keyvault
     * operations.
     * 
     * @return the encryptionIdentity value.
     */
    public EncryptionIdentity encryptionIdentity() {
        return this.encryptionIdentity;
    }

    /**
     * Set the encryptionIdentity property: Specifies the Managed Identity used by ADE to get access token for keyvault
     * operations.
     * 
     * @param encryptionIdentity the encryptionIdentity value to set.
     * @return the SecurityProfile object itself.
     */
    public SecurityProfile withEncryptionIdentity(EncryptionIdentity encryptionIdentity) {
        this.encryptionIdentity = encryptionIdentity;
        return this;
    }

    /**
     * Get the proxyAgentSettings property: Specifies ProxyAgent settings while creating the virtual machine. Minimum
     * api-version: 2023-09-01.
     * 
     * @return the proxyAgentSettings value.
     */
    public ProxyAgentSettings proxyAgentSettings() {
        return this.proxyAgentSettings;
    }

    /**
     * Set the proxyAgentSettings property: Specifies ProxyAgent settings while creating the virtual machine. Minimum
     * api-version: 2023-09-01.
     * 
     * @param proxyAgentSettings the proxyAgentSettings value to set.
     * @return the SecurityProfile object itself.
     */
    public SecurityProfile withProxyAgentSettings(ProxyAgentSettings proxyAgentSettings) {
        this.proxyAgentSettings = proxyAgentSettings;
        return this;
    }

    /**
     * Validates the instance.
     * 
     * @throws IllegalArgumentException thrown if the instance is not valid.
     */
    public void validate() {
        if (uefiSettings() != null) {
            uefiSettings().validate();
        }
        if (encryptionIdentity() != null) {
            encryptionIdentity().validate();
        }
        if (proxyAgentSettings() != null) {
            proxyAgentSettings().validate();
        }
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public JsonWriter toJson(JsonWriter jsonWriter) throws IOException {
        jsonWriter.writeStartObject();
        jsonWriter.writeJsonField("uefiSettings", this.uefiSettings);
        jsonWriter.writeBooleanField("encryptionAtHost", this.encryptionAtHost);
        jsonWriter.writeStringField("securityType", this.securityType == null ? null : this.securityType.toString());
        jsonWriter.writeJsonField("encryptionIdentity", this.encryptionIdentity);
        jsonWriter.writeJsonField("proxyAgentSettings", this.proxyAgentSettings);
        return jsonWriter.writeEndObject();
    }

    /**
     * Reads an instance of SecurityProfile from the JsonReader.
     * 
     * @param jsonReader The JsonReader being read.
     * @return An instance of SecurityProfile if the JsonReader was pointing to an instance of it, or null if it was
     * pointing to JSON null.
     * @throws IOException If an error occurs while reading the SecurityProfile.
     */
    public static SecurityProfile fromJson(JsonReader jsonReader) throws IOException {
        return jsonReader.readObject(reader -> {
            SecurityProfile deserializedSecurityProfile = new SecurityProfile();
            while (reader.nextToken() != JsonToken.END_OBJECT) {
                String fieldName = reader.getFieldName();
                reader.nextToken();

                if ("uefiSettings".equals(fieldName)) {
                    deserializedSecurityProfile.uefiSettings = UefiSettings.fromJson(reader);
                } else if ("encryptionAtHost".equals(fieldName)) {
                    deserializedSecurityProfile.encryptionAtHost = reader.getNullable(JsonReader::getBoolean);
                } else if ("securityType".equals(fieldName)) {
                    deserializedSecurityProfile.securityType = SecurityTypes.fromString(reader.getString());
                } else if ("encryptionIdentity".equals(fieldName)) {
                    deserializedSecurityProfile.encryptionIdentity = EncryptionIdentity.fromJson(reader);
                } else if ("proxyAgentSettings".equals(fieldName)) {
                    deserializedSecurityProfile.proxyAgentSettings = ProxyAgentSettings.fromJson(reader);
                } else {
                    reader.skipChildren();
                }
            }

            return deserializedSecurityProfile;
        });
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy