/**
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for
* license information.
*/
package com.microsoft.azure.management.compute;
import com.microsoft.azure.management.apigeneration.Beta;
import com.microsoft.azure.management.apigeneration.Fluent;
import com.microsoft.azure.management.resources.fluentcore.arm.models.ExternalChildResource;
import com.microsoft.azure.management.resources.fluentcore.model.Attachable;
import com.microsoft.azure.management.resources.fluentcore.model.Settable;
import rx.Observable;
import java.util.HashMap;
import java.util.Map;
/**
* An immutable client-side representation of an Azure virtual machine extension.
*/
@Fluent
public interface VirtualMachineExtension extends
VirtualMachineExtensionBase,
ExternalChildResource<VirtualMachineExtension, VirtualMachine> {
/**
* @return observable that emits virtual machine extension instance view
*/
@Beta
Observable<VirtualMachineExtensionInstanceView> getInstanceViewAsync();
/**
* @return the instance view of the virtual machine extension
*/
VirtualMachineExtensionInstanceView getInstanceView();
/**
* Grouping of virtual machine extension definition stages as a part of parent virtual machine definition.
*/
interface DefinitionStages {
/**
* The first stage of a virtual machine extension definition.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface Blank<ParentT>
extends WithImageOrPublisher<ParentT> {
}
/**
* The stage of the virtual machine extension definition allowing to specify extension image or specify name of
* the virtual machine extension publisher.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithImageOrPublisher<ParentT>
extends WithPublisher<ParentT> {
/**
* Specifies the virtual machine extension image to use.
*
* @param image the image
* @return the next stage of the definition
*/
WithAttach<ParentT> withImage(VirtualMachineExtensionImage image);
}
/**
* The stage of the virtual machine extension definition allowing to specify the publisher of the
* virtual machine extension image this extension is based on.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithPublisher<ParentT> {
/**
* Specifies the name of the virtual machine extension image publisher.
*
* @param extensionImagePublisherName the publisher name
* @return the next stage of the definition
*/
WithType<ParentT> withPublisher(String extensionImagePublisherName);
}
/**
* The stage of the virtual machine extension definition allowing to specify the type of the virtual machine
* extension image this extension is based on.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithType<ParentT> {
/**
* Specifies the type of the virtual machine extension image.
*
* @param extensionImageTypeName the image type name
* @return the next stage of the definition
*/
WithVersion<ParentT> withType(String extensionImageTypeName);
}
/**
* The stage of the virtual machine extension definition allowing to specify the type of the virtual machine
* extension version this extension is based on.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithVersion<ParentT> {
/**
* Specifies the version of the virtual machine image extension.
*
* @param extensionImageVersionName the version name
* @return the next stage of the definition
*/
WithAttach<ParentT> withVersion(String extensionImageVersionName);
}
/** The final stage of the virtual machine extension definition.
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithAttach<ParentT> extends
Attachable.InDefinition<ParentT>,
WithAutoUpgradeMinorVersion<ParentT>,
WithSettings<ParentT>,
WithTags<ParentT> {
}
/**
* The stage of the virtual machine extension definition allowing to enable or disable auto upgrade of the
* extension when when a new minor version of virtual machine extension image gets published.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithAutoUpgradeMinorVersion<ParentT> {
/**
* enables auto upgrade of the extension.
*
* @return the next stage of the definition
*/
WithAttach<ParentT> withMinorVersionAutoUpgrade();
/**
* disables auto upgrade of the extension.
*
* @return the next stage of the definition
*/
WithAttach<ParentT> withoutMinorVersionAutoUpgrade();
}
/**
* The stage of the virtual machine extension definition allowing to specify the public and private settings.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithSettings<ParentT> {
/**
* Specifies a public settings entry.
*
* @param key the key of a public settings entry
* @param value the value of the public settings entry
* @return the next stage of the definition
*/
WithAttach<ParentT> withPublicSetting(String key, Object value);
/**
* Specifies a private settings entry.
*
* @param key the key of a private settings entry
* @param value the value of the private settings entry
* @return the next stage of the definition
*/
WithAttach<ParentT> withProtectedSetting(String key, Object value);
/**
* Specifies public settings.
*
* @param settings the public settings
* @return the next stage of the definition
*/
WithAttach<ParentT> withPublicSettings(HashMap<String, Object> settings);
/**
* Specifies private settings.
*
* @param settings the private settings
* @return the next stage of the definition
*/
WithAttach<ParentT> withProtectedSettings(HashMap<String, Object> settings);
}
/**
* The stage of the virtual machine extension definition allowing to specify the tags.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface WithTags<ParentT> {
/**
* Specifies tags for the virtual machine extension.
* @param tags the tags to associate
* @return the next stage of the definition
*/
WithAttach<ParentT> withTags(Map<String, String> tags);
/**
* Adds a tag to the virtual machine extension.
* @param key the key for the tag
* @param value the value for the tag
* @return the next stage of the definition
*/
WithAttach<ParentT> withTag(String key, String value);
}
}
/**
* The entirety of a virtual machine extension definition as a part of parent definition.
*
* @param <ParentT> the stage of the parent definition to return to after attaching this definition
*/
interface Definition<ParentT> extends
DefinitionStages.Blank<ParentT>,
DefinitionStages.WithImageOrPublisher<ParentT>,
DefinitionStages.WithPublisher<ParentT>,
DefinitionStages.WithType<ParentT>,
DefinitionStages.WithVersion<ParentT>,
DefinitionStages.WithAttach<ParentT> {
}
/**
* Grouping of virtual machine extension definition stages as part of parent virtual machine update.
*/
interface UpdateDefinitionStages {
/**
* The first stage of a virtual machine extension definition.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface Blank<ParentT>
extends WithImageOrPublisher<ParentT> {
}
/**
* The stage of the virtual machine extension allowing to specify extension image or specify name of the
* virtual machine extension publisher.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithImageOrPublisher<ParentT>
extends WithPublisher<ParentT> {
/**
* Specifies the virtual machine extension image to use.
*
* @param image the image
* @return the next stage of the definition
*/
WithAttach<ParentT> withImage(VirtualMachineExtensionImage image);
}
/**
* The stage of the virtual machine extension definition allowing to specify the publisher of the
* virtual machine extension image this extension is based on.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithPublisher<ParentT> {
/**
* Specifies the name of the virtual machine extension image publisher.
*
* @param extensionImagePublisherName the publisher name
* @return the next stage of the definition
*/
WithType<ParentT> withPublisher(String extensionImagePublisherName);
}
/**
* The stage of the virtual machine extension definition allowing to specify the type of the virtual machine
* extension image this extension is based on.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithType<ParentT> {
/**
* Specifies the type of the virtual machine extension image.
*
* @param extensionImageTypeName the image type name
* @return the next stage of the definition
*/
WithVersion<ParentT> withType(String extensionImageTypeName);
}
/**
* The stage of the virtual machine extension definition allowing to specify the type of the virtual machine
* extension version this extension is based on.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithVersion<ParentT> {
/**
* Specifies the version of the virtual machine image extension.
*
* @param extensionImageVersionName the version name
* @return the next stage of the definition
*/
WithAttach<ParentT> withVersion(String extensionImageVersionName);
}
/** The final stage of the virtual machine extension definition.
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithAttach<ParentT> extends
Attachable.InUpdate<ParentT>,
WithAutoUpgradeMinorVersion<ParentT>,
WithSettings<ParentT>,
WithTags<ParentT> {
}
/**
* The stage of the virtual machine extension definition allowing to enable or disable auto upgrade of the
* extension when when a new minor version of virtual machine extension image gets published.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithAutoUpgradeMinorVersion<ParentT> {
/**
* enables auto upgrade of the extension.
*
* @return the next stage of the definition
*/
WithAttach<ParentT> withMinorVersionAutoUpgrade();
/**
* disables auto upgrade of the extension.
*
* @return the next stage of the definition
*/
WithAttach<ParentT> withoutMinorVersionAutoUpgrade();
}
/**
* The stage of the virtual machine extension definition allowing to specify the public and private settings.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithSettings<ParentT> {
/**
* Specifies a public settings entry.
*
* @param key the key of a public settings entry
* @param value the value of the public settings entry
* @return the next stage of the definition
*/
WithAttach<ParentT> withPublicSetting(String key, Object value);
/**
* Specifies a private settings entry.
*
* @param key the key of a private settings entry
* @param value the value of the private settings entry
* @return the next stage of the definition
*/
WithAttach<ParentT> withProtectedSetting(String key, Object value);
/**
* Specifies public settings.
*
* @param settings the public settings
* @return the next stage of the definition
*/
WithAttach<ParentT> withPublicSettings(HashMap<String, Object> settings);
/**
* Specifies private settings.
*
* @param settings the private settings
* @return the next stage of the definition
*/
WithAttach<ParentT> withProtectedSettings(HashMap<String, Object> settings);
}
/**
* The stage of the virtual machine extension definition allowing to specify the tags.
*
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface WithTags<ParentT> {
/**
* Specifies tags for the resource.
* @param tags tags to associate with the resource
* @return the next stage of the definition
*/
WithAttach<ParentT> withTags(Map<String, String> tags);
/**
* Adds a tag to the resource.
* @param key the key for the tag
* @param value the value for the tag
* @return the next stage of the definition
*/
WithAttach<ParentT> withTag(String key, String value);
}
}
/**
* The entirety of a virtual machine extension definition as a part of parent update.
* @param <ParentT> the stage of the parent update to return to after attaching this definition
*/
interface UpdateDefinition<ParentT> extends
UpdateDefinitionStages.Blank<ParentT>,
UpdateDefinitionStages.WithImageOrPublisher<ParentT>,
UpdateDefinitionStages.WithPublisher<ParentT>,
UpdateDefinitionStages.WithType<ParentT>,
UpdateDefinitionStages.WithVersion<ParentT>,
UpdateDefinitionStages.WithAttach<ParentT> {
}
/**
* Grouping of virtual machine extension update stages.
*/
interface UpdateStages {
/**
* The stage of the virtual machine extension update allowing to enable or disable auto upgrade of the
* extension when when a new minor version of virtual machine extension image gets published.
*/
interface WithAutoUpgradeMinorVersion {
/**
* enables auto upgrade of the extension.
*
* @return the next stage of the update
*/
Update withMinorVersionAutoUpgrade();
/**
* enables auto upgrade of the extension.
*
* @return the next stage of the update
*/
Update withoutMinorVersionAutoUpgrade();
}
/**
* The stage of the virtual machine extension update allowing to add or update public and private settings.
*/
interface WithSettings {
/**
* Specifies a public settings entry.
*
* @param key the key of a public settings entry
* @param value the value of the public settings entry
* @return the next stage of the update
*/
Update withPublicSetting(String key, Object value);
/**
* Specifies a private settings entry.
*
* @param key the key of a private settings entry
* @param value the value of the private settings entry
* @return the next stage of the update
*/
Update withProtectedSetting(String key, Object value);
/**
* Specifies public settings.
*
* @param settings the public settings
* @return the next stage of the update
*/
Update withPublicSettings(HashMap<String, Object> settings);
/**
* Specifies private settings.
*
* @param settings the private settings
* @return the next stage of the update
*/
Update withProtectedSettings(HashMap<String, Object> settings);
}
/**
* The stage of the virtual machine extension update allowing to add or update tags.
*/
interface WithTags {
/**
* Specifies tags for the virtual machine extension.
* @param tags tags indexed by name
* @return the next stage of the update
*/
Update withTags(Map<String, String> tags);
/**
* Adds a tag to the virtual machine extension.
* @param key the key for the tag
* @param value the value for the tag
* @return the next stage of the update
*/
Update withTag(String key, String value);
/**
* Removes a tag from the virtual machine extension.
* @param key the key of the tag to remove
* @return the next stage of the update
*/
Update withoutTag(String key);
}
}
/**
* The entirety of virtual machine extension update as a part of parent virtual machine update.
*/
interface Update extends
Settable<VirtualMachine.Update>,
UpdateStages.WithAutoUpgradeMinorVersion,
UpdateStages.WithSettings,
UpdateStages.WithTags {
}
}