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

com.azure.resourcemanager.compute.models.GalleryImageVersion 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.

package com.azure.resourcemanager.compute.models;

import com.azure.core.annotation.Fluent;
import com.azure.resourcemanager.compute.ComputeManager;
import com.azure.resourcemanager.compute.fluent.models.GalleryImageVersionInner;
import com.azure.core.management.Region;
import com.azure.resourcemanager.resources.fluentcore.arm.models.HasManager;
import com.azure.resourcemanager.resources.fluentcore.model.Appliable;
import com.azure.resourcemanager.resources.fluentcore.model.Creatable;
import com.azure.resourcemanager.resources.fluentcore.model.HasInnerModel;
import com.azure.resourcemanager.resources.fluentcore.model.Indexable;
import com.azure.resourcemanager.resources.fluentcore.model.Refreshable;
import com.azure.resourcemanager.resources.fluentcore.model.Updatable;
import java.time.OffsetDateTime;
import java.util.List;
import java.util.Map;

/** An immutable client-side representation of an Azure gallery image version. */
@Fluent
public interface GalleryImageVersion
    extends HasInnerModel,
        Indexable,
        Refreshable,
        Updatable,
        HasManager {
    /** @return the ARM id of the image version. */
    String id();

    /** @return the default location of the image version. */
    String location();

    /** @return the image version name. */
    String name();

    /** @return the provisioningState of image version resource. */
    String provisioningState();

    /** @return the publishingProfile configuration of the image version. */
    GalleryImageVersionPublishingProfile publishingProfile();

    /** @return the regions in which the image version is available. */
    List availableRegions();

    /** @return the date indicating image version's end of life. */
    OffsetDateTime endOfLifeDate();

    /**
     * @return true if the image version is excluded from considering as a candidate when VM is created with 'latest'
     *     image version, false otherwise.
     */
    Boolean isExcludedFromLatest();

    /** @return the replicationStatus of image version in published regions. */
    ReplicationStatus replicationStatus();

    /** @return the image version storageProfile describing OS and data disks. */
    GalleryImageVersionStorageProfile storageProfile();

    /** @return the tags associated with the image version. */
    Map tags();

    /** @return the type. */
    String type();

    /** The entirety of the gallery image version definition. */
    interface Definition
        extends DefinitionStages.Blank,
            DefinitionStages.WithImage,
            DefinitionStages.WithLocation,
            DefinitionStages.WithSource,
            DefinitionStages.WithCreate {
    }

    /** Grouping of gallery image version definition stages. */
    interface DefinitionStages {
        /** The first stage of a gallery image version definition. */
        interface Blank extends WithImage {
        }

        /** The stage of the gallery image version definition allowing to specify parent image. */
        interface WithImage {
            /**
             * Specifies the image container to hold this image version.
             *
             * @param resourceGroupName the name of the resource group
             * @param galleryName the name of the gallery
             * @param galleryImageName the name of the gallery image
             * @return the next definition stage
             */
            WithLocation withExistingImage(String resourceGroupName, String galleryName, String galleryImageName);
        }

        /** The stage of the gallery image version definition allowing to specify location. */
        interface WithLocation {
            /**
             * Specifies the default location for the image version.
             *
             * @param location resource location
             * @return the next definition stage
             */
            WithSource withLocation(String location);

            /**
             * Specifies location.
             *
             * @param location resource location
             * @return the next definition stage
             */
            WithSource withLocation(Region location);
        }

        /** The stage of the image version definition allowing to specify the source. */
        interface WithSource {
            /**
             * Specifies that the provided custom image needs to be used as source of the image version.
             *
             * @param customImageId the ARM id of the custom image
             * @return the next definition stage
             */
            WithCreate withSourceCustomImage(String customImageId);

            /**
             * Specifies that the provided custom image needs to be used as source of the image version.
             *
             * @param customImage the custom image
             * @return the next definition stage
             */
            WithCreate withSourceCustomImage(VirtualMachineCustomImage customImage);
        }

        /**
         * The stage of image version definition allowing to specify the regions in which the image version has to be
         * available.
         */
        interface WithAvailableRegion {
            /**
             * Specifies a region in which image version needs to be available.
             *
             * @param region the region
             * @param replicaCount the replication count
             * @return the next definition stage
             */
            WithCreate withRegionAvailability(Region region, int replicaCount);

            /**
             * Specifies list of regions in which image version needs to be available.
             *
             * @param regions the region list
             * @return the next definition stage
             */
            WithCreate withRegionAvailability(List regions);
        }

        /** The stage of the gallery image version definition allowing to specify end of life of the version. */
        interface WithEndOfLifeDate {
            /**
             * Specifies end of life date of the image version.
             *
             * @param endOfLifeDate The end of life date
             * @return the next definition stage
             */
            WithCreate withEndOfLifeDate(OffsetDateTime endOfLifeDate);
        }

        /**
         * The stage of the gallery image version definition allowing to specify that the version should not be
         * considered as a candidate version when VM is deployed with 'latest' as version of the image.
         */
        interface WithExcludeFromLatest {
            /**
             * Specifies that this version is not a candidate to consider as latest.
             *
             * @return the next definition stage
             */
            WithCreate withExcludedFromLatest();
        }

        /** The stage of the gallery image version definition allowing to specify Tags. */
        interface WithTags {
            /**
             * Specifies tags.
             *
             * @param tags the resource tags
             * @return the next definition stage
             */
            WithCreate withTags(Map tags);
        }

        /**
         * The stage of the definition which contains all the minimum required inputs for the resource to be created
         * (via {@link WithCreate#create()}), but also allows for any other optional settings to be specified.
         */
        interface WithCreate
            extends Creatable,
                DefinitionStages.WithAvailableRegion,
                DefinitionStages.WithEndOfLifeDate,
                DefinitionStages.WithExcludeFromLatest,
                DefinitionStages.WithTags {
        }
    }
    /** The template for a gallery image version update operation, containing all the settings that can be modified. */
    interface Update
        extends Appliable,
            UpdateStages.WithAvailableRegion,
            UpdateStages.WithEndOfLifeDate,
            UpdateStages.WithExcludeFromLatest,
            UpdateStages.WithTags {
    }

    /** Grouping of gallery image version update stages. */
    interface UpdateStages {
        /**
         * The stage of image version update allowing to specify the regions in which the image version has to be
         * available.
         */
        interface WithAvailableRegion {
            /**
             * Specifies a region in which image version needs to be available.
             *
             * @param region the region
             * @param replicaCount the replication count
             * @return the next update stage
             */
            Update withRegionAvailability(Region region, int replicaCount);

            /**
             * Specifies list of regions in which image version needs to be available.
             *
             * @param regions the region list
             * @return the next update stage
             */
            Update withRegionAvailability(List regions);

            /**
             * Specifies that an image version should be removed from an existing region serving it.
             * 

* Removing region would set safetyProfile.allowDeletionOfReplicatedLocations to true. * * @param region the region * @return the next update stage */ Update withoutRegionAvailability(Region region); } /** The stage of the gallery image version update allowing to specify end of life of the version. */ interface WithEndOfLifeDate { /** * Specifies end of life date of the image version. * * @param endOfLifeDate The end of life of this gallery image * @return the next update stage */ Update withEndOfLifeDate(OffsetDateTime endOfLifeDate); } /** * The stage of the gallery image version definition allowing to specify whether this version should be a * candidate version to be considered when VM is deployed with 'latest' as version of the image. */ interface WithExcludeFromLatest { /** * Specifies that this version is not a candidate to consider as latest. * * @return the next update stage */ Update withExcludedFromLatest(); /** * Specifies that this version is a candidate to consider as latest. * * @return the next update stage */ Update withoutExcludedFromLatest(); } /** The stage of the gallery image version update allowing to specify Tags. */ interface WithTags { /** * Specifies tags. * * @param tags resource tags * @return the next update stage */ Update withTags(Map tags); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy