com.aliyun.sdk.service.ecs20140526.models.CreateImagePipelineRequest Maven / Gradle / Ivy
Show all versions of alibabacloud-ecs20140526 Show documentation
// This file is auto-generated, don't edit it. Thanks.
package com.aliyun.sdk.service.ecs20140526.models;
import darabonba.core.RequestModel;
import darabonba.core.TeaModel;
import com.aliyun.sdk.gateway.pop.models.*;
/**
* {@link CreateImagePipelineRequest} extends {@link RequestModel}
*
* CreateImagePipelineRequest
*/
public class CreateImagePipelineRequest extends Request {
@com.aliyun.core.annotation.Host
@com.aliyun.core.annotation.NameInMap("SourceRegionId")
private String sourceRegionId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("AddAccount")
private java.util.List < Long > addAccount;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("BaseImage")
@com.aliyun.core.annotation.Validation(required = true)
private String baseImage;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("BaseImageType")
@com.aliyun.core.annotation.Validation(required = true)
private String baseImageType;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("BuildContent")
private String buildContent;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ClientToken")
private String clientToken;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("DeleteInstanceOnFailure")
private Boolean deleteInstanceOnFailure;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("Description")
private String description;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ImageName")
private String imageName;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("InstanceType")
private String instanceType;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("InternetMaxBandwidthOut")
private Integer internetMaxBandwidthOut;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("Name")
private String name;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("OwnerAccount")
private String ownerAccount;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("OwnerId")
private Long ownerId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("RegionId")
@com.aliyun.core.annotation.Validation(required = true)
private String regionId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ResourceGroupId")
private String resourceGroupId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ResourceOwnerAccount")
private String resourceOwnerAccount;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ResourceOwnerId")
private Long resourceOwnerId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("SystemDiskSize")
private Integer systemDiskSize;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("Tag")
private java.util.List < Tag> tag;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("ToRegionId")
private java.util.List < String > toRegionId;
@com.aliyun.core.annotation.Query
@com.aliyun.core.annotation.NameInMap("VSwitchId")
private String vSwitchId;
private CreateImagePipelineRequest(Builder builder) {
super(builder);
this.sourceRegionId = builder.sourceRegionId;
this.addAccount = builder.addAccount;
this.baseImage = builder.baseImage;
this.baseImageType = builder.baseImageType;
this.buildContent = builder.buildContent;
this.clientToken = builder.clientToken;
this.deleteInstanceOnFailure = builder.deleteInstanceOnFailure;
this.description = builder.description;
this.imageName = builder.imageName;
this.instanceType = builder.instanceType;
this.internetMaxBandwidthOut = builder.internetMaxBandwidthOut;
this.name = builder.name;
this.ownerAccount = builder.ownerAccount;
this.ownerId = builder.ownerId;
this.regionId = builder.regionId;
this.resourceGroupId = builder.resourceGroupId;
this.resourceOwnerAccount = builder.resourceOwnerAccount;
this.resourceOwnerId = builder.resourceOwnerId;
this.systemDiskSize = builder.systemDiskSize;
this.tag = builder.tag;
this.toRegionId = builder.toRegionId;
this.vSwitchId = builder.vSwitchId;
}
public static Builder builder() {
return new Builder();
}
public static CreateImagePipelineRequest create() {
return builder().build();
}
@Override
public Builder toBuilder() {
return new Builder(this);
}
/**
* @return sourceRegionId
*/
public String getSourceRegionId() {
return this.sourceRegionId;
}
/**
* @return addAccount
*/
public java.util.List < Long > getAddAccount() {
return this.addAccount;
}
/**
* @return baseImage
*/
public String getBaseImage() {
return this.baseImage;
}
/**
* @return baseImageType
*/
public String getBaseImageType() {
return this.baseImageType;
}
/**
* @return buildContent
*/
public String getBuildContent() {
return this.buildContent;
}
/**
* @return clientToken
*/
public String getClientToken() {
return this.clientToken;
}
/**
* @return deleteInstanceOnFailure
*/
public Boolean getDeleteInstanceOnFailure() {
return this.deleteInstanceOnFailure;
}
/**
* @return description
*/
public String getDescription() {
return this.description;
}
/**
* @return imageName
*/
public String getImageName() {
return this.imageName;
}
/**
* @return instanceType
*/
public String getInstanceType() {
return this.instanceType;
}
/**
* @return internetMaxBandwidthOut
*/
public Integer getInternetMaxBandwidthOut() {
return this.internetMaxBandwidthOut;
}
/**
* @return name
*/
public String getName() {
return this.name;
}
/**
* @return ownerAccount
*/
public String getOwnerAccount() {
return this.ownerAccount;
}
/**
* @return ownerId
*/
public Long getOwnerId() {
return this.ownerId;
}
/**
* @return regionId
*/
public String getRegionId() {
return this.regionId;
}
/**
* @return resourceGroupId
*/
public String getResourceGroupId() {
return this.resourceGroupId;
}
/**
* @return resourceOwnerAccount
*/
public String getResourceOwnerAccount() {
return this.resourceOwnerAccount;
}
/**
* @return resourceOwnerId
*/
public Long getResourceOwnerId() {
return this.resourceOwnerId;
}
/**
* @return systemDiskSize
*/
public Integer getSystemDiskSize() {
return this.systemDiskSize;
}
/**
* @return tag
*/
public java.util.List < Tag> getTag() {
return this.tag;
}
/**
* @return toRegionId
*/
public java.util.List < String > getToRegionId() {
return this.toRegionId;
}
/**
* @return vSwitchId
*/
public String getVSwitchId() {
return this.vSwitchId;
}
public static final class Builder extends Request.Builder {
private String sourceRegionId;
private java.util.List < Long > addAccount;
private String baseImage;
private String baseImageType;
private String buildContent;
private String clientToken;
private Boolean deleteInstanceOnFailure;
private String description;
private String imageName;
private String instanceType;
private Integer internetMaxBandwidthOut;
private String name;
private String ownerAccount;
private Long ownerId;
private String regionId;
private String resourceGroupId;
private String resourceOwnerAccount;
private Long resourceOwnerId;
private Integer systemDiskSize;
private java.util.List < Tag> tag;
private java.util.List < String > toRegionId;
private String vSwitchId;
private Builder() {
super();
}
private Builder(CreateImagePipelineRequest request) {
super(request);
this.sourceRegionId = request.sourceRegionId;
this.addAccount = request.addAccount;
this.baseImage = request.baseImage;
this.baseImageType = request.baseImageType;
this.buildContent = request.buildContent;
this.clientToken = request.clientToken;
this.deleteInstanceOnFailure = request.deleteInstanceOnFailure;
this.description = request.description;
this.imageName = request.imageName;
this.instanceType = request.instanceType;
this.internetMaxBandwidthOut = request.internetMaxBandwidthOut;
this.name = request.name;
this.ownerAccount = request.ownerAccount;
this.ownerId = request.ownerId;
this.regionId = request.regionId;
this.resourceGroupId = request.resourceGroupId;
this.resourceOwnerAccount = request.resourceOwnerAccount;
this.resourceOwnerId = request.resourceOwnerId;
this.systemDiskSize = request.systemDiskSize;
this.tag = request.tag;
this.toRegionId = request.toRegionId;
this.vSwitchId = request.vSwitchId;
}
/**
* SourceRegionId.
*/
public Builder sourceRegionId(String sourceRegionId) {
this.putHostParameter("SourceRegionId", sourceRegionId);
this.sourceRegionId = sourceRegionId;
return this;
}
/**
* The IDs of Alibaba Cloud accounts to which to share the image that will be created based on the image template. You can specify up to 20 account IDs.
*/
public Builder addAccount(java.util.List < Long > addAccount) {
this.putQueryParameter("AddAccount", addAccount);
this.addAccount = addAccount;
return this;
}
/**
* The source image.
*
*
* * If you set `BaseImageType` to IMAGE, set the BaseImage parameter to the ID of a custom image.
* * If you set `BaseImageType` to IMAGE_FAMILY, set the BaseImage parameter to the name of an image family.
*/
public Builder baseImage(String baseImage) {
this.putQueryParameter("BaseImage", baseImage);
this.baseImage = baseImage;
return this;
}
/**
* The type of the source image. Valid values:
*
*
* * IMAGE: image
* * IMAGE_FAMILY: image family
*/
public Builder baseImageType(String baseImageType) {
this.putQueryParameter("BaseImageType", baseImageType);
this.baseImageType = baseImageType;
return this;
}
/**
* The content of the image template. The content cannot exceed 16 KB in size and can contain up to 127 commands. For more information about the commands that are supported, see the "Usage notes" section of this topic.
*/
public Builder buildContent(String buildContent) {
this.putQueryParameter("BuildContent", buildContent);
this.buildContent = buildContent;
return this;
}
/**
* The client token that is used to ensure the idempotence of the request. You can use the client to generate the token, but you must make sure that the token is unique among different requests. The token can contain only ASCII characters and cannot exceed 64 characters in length.**** For more information, see [How to ensure idempotence](~~25693~~).
*/
public Builder clientToken(String clientToken) {
this.putQueryParameter("ClientToken", clientToken);
this.clientToken = clientToken;
return this;
}
/**
* Specifies whether to release the intermediate instance when the image cannot be created. Valid values:
*
*
* * true
* * false
*
* Default value: true.
*
* > If the intermediate instance cannot be started, the instance is released by default.
*/
public Builder deleteInstanceOnFailure(Boolean deleteInstanceOnFailure) {
this.putQueryParameter("DeleteInstanceOnFailure", deleteInstanceOnFailure);
this.deleteInstanceOnFailure = deleteInstanceOnFailure;
return this;
}
/**
* The description of the image template. The description must be 2 to 256 characters in length. It cannot start with `http://` or `https://`.
*/
public Builder description(String description) {
this.putQueryParameter("Description", description);
this.description = description;
return this;
}
/**
* The prefix of the image name. The prefix must be 2 to 64 characters in length. It must start with a letter and cannot start with `http://` or `https://`. It can contain letters, digits, colons (:), underscores (\_), periods (.), and hyphens (-).
*
*
* The system generates the final complete image name that consists of the specified prefix and the ID of the build task (`ExecutionId`) in the format of `{ImageName}_{ExecutionId}`.
*/
public Builder imageName(String imageName) {
this.putQueryParameter("ImageName", imageName);
this.imageName = imageName;
return this;
}
/**
* The instance type. You can call the [DescribeInstanceTypes](~~25620~~) to query instance types.
*
*
* If you do not configure this parameter, an instance type that provides the fewest vCPUs and memory resources is automatically selected. This configuration is subject to resource availability of instance types. For example, the ecs.g6.large instance type is automatically selected. If available ecs.g6.large resources are insufficient, the ecs.g6.xlarge instance type is selected.
*/
public Builder instanceType(String instanceType) {
this.putQueryParameter("InstanceType", instanceType);
this.instanceType = instanceType;
return this;
}
/**
* The size of the outbound public bandwidth for the intermediate instance. Unit: Mbit/s. Valid values: 0 to 100.
*
*
* Default value: 0.
*/
public Builder internetMaxBandwidthOut(Integer internetMaxBandwidthOut) {
this.putQueryParameter("InternetMaxBandwidthOut", internetMaxBandwidthOut);
this.internetMaxBandwidthOut = internetMaxBandwidthOut;
return this;
}
/**
* The name of the image template. The name must be 2 to 128 characters in length. It must start with a letter and cannot start with `http://` or `https://`. It can contain letters, digits, colons (:), underscores (\_), periods (.), and hyphens (-).
*
*
* > If you do not specify the `Name` parameter, the return value of `ImagePipelineId` is used.
*/
public Builder name(String name) {
this.putQueryParameter("Name", name);
this.name = name;
return this;
}
/**
* OwnerAccount.
*/
public Builder ownerAccount(String ownerAccount) {
this.putQueryParameter("OwnerAccount", ownerAccount);
this.ownerAccount = ownerAccount;
return this;
}
/**
* OwnerId.
*/
public Builder ownerId(Long ownerId) {
this.putQueryParameter("OwnerId", ownerId);
this.ownerId = ownerId;
return this;
}
/**
* The ID of the region. You can call the [DescribeRegions](~~25609~~) operation to query the most recent region list.
*/
public Builder regionId(String regionId) {
this.putQueryParameter("RegionId", regionId);
this.regionId = regionId;
return this;
}
/**
* The ID of the resource group.
*/
public Builder resourceGroupId(String resourceGroupId) {
this.putQueryParameter("ResourceGroupId", resourceGroupId);
this.resourceGroupId = resourceGroupId;
return this;
}
/**
* ResourceOwnerAccount.
*/
public Builder resourceOwnerAccount(String resourceOwnerAccount) {
this.putQueryParameter("ResourceOwnerAccount", resourceOwnerAccount);
this.resourceOwnerAccount = resourceOwnerAccount;
return this;
}
/**
* ResourceOwnerId.
*/
public Builder resourceOwnerId(Long resourceOwnerId) {
this.putQueryParameter("ResourceOwnerId", resourceOwnerId);
this.resourceOwnerId = resourceOwnerId;
return this;
}
/**
* The system disk size of the intermediate instance. Unit: GiB. Valid values: 20 to 500.
*
*
* Default value: 40.
*/
public Builder systemDiskSize(Integer systemDiskSize) {
this.putQueryParameter("SystemDiskSize", systemDiskSize);
this.systemDiskSize = systemDiskSize;
return this;
}
/**
* The tags to add to the template.
*/
public Builder tag(java.util.List < Tag> tag) {
this.putQueryParameter("Tag", tag);
this.tag = tag;
return this;
}
/**
* The IDs of regions to which you want to distribute the image that is created based on the image template. You can specify up to 20 region IDs.
*
*
* If you do not specify this parameter, the image is created only in the current region.
*/
public Builder toRegionId(java.util.List < String > toRegionId) {
this.putQueryParameter("ToRegionId", toRegionId);
this.toRegionId = toRegionId;
return this;
}
/**
* The ID of the vSwitch.
*
*
* If you do not specify this parameter, a new VPC and vSwitch are created. Make sure that the VPC quota in your account is sufficient. For more information, see [Limits and quotas](~~27750~~).
*/
public Builder vSwitchId(String vSwitchId) {
this.putQueryParameter("VSwitchId", vSwitchId);
this.vSwitchId = vSwitchId;
return this;
}
@Override
public CreateImagePipelineRequest build() {
return new CreateImagePipelineRequest(this);
}
}
public static class Tag extends TeaModel {
@com.aliyun.core.annotation.NameInMap("Key")
private String key;
@com.aliyun.core.annotation.NameInMap("Value")
private String value;
private Tag(Builder builder) {
this.key = builder.key;
this.value = builder.value;
}
public static Builder builder() {
return new Builder();
}
public static Tag create() {
return builder().build();
}
/**
* @return key
*/
public String getKey() {
return this.key;
}
/**
* @return value
*/
public String getValue() {
return this.value;
}
public static final class Builder {
private String key;
private String value;
/**
* The key of tag N. Valid values of N: 1 to 20. You cannot specify empty strings as tag keys. The tag key must be 1 to 128 characters in length and cannot contain `http://` or `https://`. It cannot start with `acs:` or `aliyun`.
*/
public Builder key(String key) {
this.key = key;
return this;
}
/**
* The value of tag N. Valid values of N: 1 to 20. The tag value can be an empty string. The tag value must be 0 to 128 characters in length. It cannot start with `acs:` or contain `http://` or `https://`.
*/
public Builder value(String value) {
this.value = value;
return this;
}
public Tag build() {
return new Tag(this);
}
}
}
}