Documentation ¶
Index ¶
- type AgenciesPrimitiveTypeHolder
- type Agency
- type ApplyExecutionPlanRequest
- type ApplyExecutionPlanRequestBody
- type ApplyExecutionPlanResponse
- type BaseTemplate
- type BaseTemplateVersion
- type ContinueRollbackStackRequest
- type ContinueRollbackStackRequestBody
- type ContinueRollbackStackResponse
- type CreateExecutionPlanRequest
- type CreateExecutionPlanRequestBody
- type CreateExecutionPlanResponse
- type CreateStackRequest
- type CreateStackRequestBody
- type CreateStackResponse
- type DeleteExecutionPlanRequest
- type DeleteExecutionPlanResponse
- type DeleteStackRequest
- type DeleteStackResponse
- type DeleteTemplateRequest
- type DeleteTemplateResponse
- type DeleteTemplateVersionRequest
- type DeleteTemplateVersionResponse
- type DeployStackRequest
- type DeployStackRequestBody
- type DeployStackResponse
- type DeploymentIdPrimitiveTypeHolder
- type EnableAutoRollbackPrimitiveTypeHolder
- type EnableDeletionProtectionPrimitiveTypeHolder
- type EncryptionStructure
- type EstimateExecutionPlanPriceRequest
- type EstimateExecutionPlanPriceResponse
- type EstimateExecutionPlanPriceResponseCurrency
- type EstimateExecutionPlanPriceResponseCurrencyEnum
- type ExecutionPlan
- type ExecutionPlanDescriptionPrimitiveTypeHolder
- type ExecutionPlanDiffAttribute
- type ExecutionPlanIdPrimitiveTypeHolder
- type ExecutionPlanItem
- type ExecutionPlanItemAction
- type ExecutionPlanItemActionEnum
- type ExecutionPlanItemMode
- type ExecutionPlanItemModeEnum
- type ExecutionPlanNamePrimitiveTypeHolder
- type ExecutionPlanStatus
- type ExecutionPlanStatusEnum
- type ExecutionPlanStatusMessagePrimitiveTypeHolder
- type ExecutionPlanStatusPrimitiveTypeHolder
- type ExecutionPlanStatusPrimitiveTypeHolderStatus
- type ExecutionPlanStatusPrimitiveTypeHolderStatusEnum
- type ExecutionPlanSummary
- type ExecutorPrimitiveTypeHolder
- type GetExecutionPlanMetadataRequest
- type GetExecutionPlanMetadataResponse
- type GetExecutionPlanMetadataResponseStatus
- type GetExecutionPlanMetadataResponseStatusEnum
- type GetExecutionPlanRequest
- type GetExecutionPlanResponse
- type GetStackMetadataRequest
- type GetStackMetadataResponse
- type GetStackMetadataResponseStatus
- type GetStackMetadataResponseStatusEnum
- type GetStackTemplateRequest
- type GetStackTemplateResponse
- type IndexPrimitiveTypeHolder
- type ItemsResponse
- type KmsStructure
- type ListExecutionPlansRequest
- type ListExecutionPlansResponse
- type ListStackEventsRequest
- type ListStackEventsResponse
- type ListStackOutputsRequest
- type ListStackOutputsResponse
- type ListStackResourcesRequest
- type ListStackResourcesResponse
- type ListStacksRequest
- type ListStacksResponse
- type ListTemplatesRequest
- type ListTemplatesResponse
- type ParseTemplateVariablesRequest
- type ParseTemplateVariablesRequestBody
- type ParseTemplateVariablesResponse
- type ResourceAttribute
- type ResourceNamePrimitiveTypeHolder
- type ResourcePriceResponse
- type ResourcePriceResponseChargeMode
- type ResourcePriceResponseChargeModeEnum
- type ResourcePriceResponsePeriodType
- type ResourcePriceResponsePeriodTypeEnum
- type ResourceTypePrimitiveTypeHolder
- type ShowTemplateMetadataRequest
- type ShowTemplateMetadataResponse
- type ShowTemplateVersionContentRequest
- type ShowTemplateVersionContentResponse
- type ShowTemplateVersionMetadataRequest
- type ShowTemplateVersionMetadataResponse
- type Stack
- type StackDescriptionPrimitiveTypeHolder
- type StackEvent
- type StackEventEventType
- type StackEventEventTypeEnum
- type StackIdPrimitiveTypeHolder
- type StackNamePrimitiveTypeHolder
- type StackOutput
- type StackResource
- type StackResourceResourceStatus
- type StackResourceResourceStatusEnum
- type StackStatus
- type StackStatusEnum
- type StackStatusMessagePrimitiveTypeHolder
- type StackStatusPrimitiveTypeHolder
- type StackStatusPrimitiveTypeHolderStatus
- type StackStatusPrimitiveTypeHolderStatusEnum
- type Template
- type TemplateBodyPrimitiveTypeHolder
- type TemplateUriPrimitiveTypeHolder
- type UpdateStackRequest
- type UpdateStackRequestBody
- type UpdateStackResponse
- type UpdateTemplateMetadataRequest
- type UpdateTemplateMetadataRequestBody
- type UpdateTemplateMetadataResponse
- type VariableResponse
- type VariableValidationResponse
- type VarsBodyPrimitiveTypeHolder
- type VarsStructure
- type VarsStructurePrimitiveTypeHolder
- type VarsUriContentPrimitiveTypeHolder
- type VarsUriPrimitiveTypeHolder
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AgenciesPrimitiveTypeHolder ¶
type AgenciesPrimitiveTypeHolder struct { // 委托授权的信息。 Agencies *[]Agency `json:"agencies,omitempty"` }
func (AgenciesPrimitiveTypeHolder) String ¶
func (o AgenciesPrimitiveTypeHolder) String() string
type Agency ¶
type Agency struct { // 用户使用的provider的名字。如果用户给与的provider_name含有重复的值,则返回400 ProviderName string `json:"provider_name"` // 对应provider所使用的IAM委托名称,资源编排服务会使用此委托的权限去访问、创建对应provider的资源 AgencyName string `json:"agency_name"` }
委托授权的信息
type ApplyExecutionPlanRequest ¶
type ApplyExecutionPlanRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` Body *ApplyExecutionPlanRequestBody `json:"body,omitempty"` }
Request Object
func (ApplyExecutionPlanRequest) String ¶
func (o ApplyExecutionPlanRequest) String() string
type ApplyExecutionPlanRequestBody ¶
type ApplyExecutionPlanRequestBody struct { // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
func (ApplyExecutionPlanRequestBody) String ¶
func (o ApplyExecutionPlanRequestBody) String() string
type ApplyExecutionPlanResponse ¶
type ApplyExecutionPlanResponse struct { // 标识部署的唯一Id,此Id由资源编排服务在触发部署、回滚等操作时生成,为UUID。 DeploymentId *string `json:"deployment_id,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ApplyExecutionPlanResponse) String ¶
func (o ApplyExecutionPlanResponse) String() string
type BaseTemplate ¶ added in v0.1.30
type BaseTemplate struct { // 模板的唯一ID,由模板服务随机生成 TemplateId string `json:"template_id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板的描述。可用于客户识别自己的模板 TemplateDescription *string `json:"template_description,omitempty"` // 模板的生成时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime string `json:"create_time"` // 模板的更新时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z UpdateTime string `json:"update_time"` }
模板基本信息
func (BaseTemplate) String ¶ added in v0.1.30
func (o BaseTemplate) String() string
type BaseTemplateVersion ¶ added in v0.1.30
type BaseTemplateVersion struct { // 模板的唯一ID,由模板服务随机生成 TemplateId string `json:"template_id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板版本的描述。可用于客户识别自己的模板版本 VersionDescription *string `json:"version_description,omitempty"` // 版本创建时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime string `json:"create_time"` }
模板版本基本信息
func (BaseTemplateVersion) String ¶ added in v0.1.30
func (o BaseTemplateVersion) String() string
type ContinueRollbackStackRequest ¶
type ContinueRollbackStackRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` Body *ContinueRollbackStackRequestBody `json:"body,omitempty"` }
Request Object
func (ContinueRollbackStackRequest) String ¶
func (o ContinueRollbackStackRequest) String() string
type ContinueRollbackStackRequestBody ¶
type ContinueRollbackStackRequestBody struct { // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
func (ContinueRollbackStackRequestBody) String ¶
func (o ContinueRollbackStackRequestBody) String() string
type ContinueRollbackStackResponse ¶
type ContinueRollbackStackResponse struct { // 继续回滚触发部署生成的唯一的deployment_id,由资源编排服务生成,通常为UUID DeploymentId *string `json:"deployment_id,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ContinueRollbackStackResponse) String ¶
func (o ContinueRollbackStackResponse) String() string
type CreateExecutionPlanRequest ¶
type CreateExecutionPlanRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` Body *CreateExecutionPlanRequestBody `json:"body,omitempty"` }
Request Object
func (CreateExecutionPlanRequest) String ¶
func (o CreateExecutionPlanRequest) String() string
type CreateExecutionPlanRequestBody ¶
type CreateExecutionPlanRequestBody struct { // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // HCL模板,描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_body中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的template_body。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateBody *string `json:"template_body,omitempty"` // HCL模板的OBS地址,该模板描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) 对应的文件应该是纯tf文件或zip压缩包 纯tf文件需要以`.tf`或者`.tf.json`结尾,并遵守HCL语法 压缩包目前只支持zip格式,文件需要以`.zip`结尾。解压后的文件不得包含\".tfvars\"文件 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_uri对应的模板文件中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的模板文件内容。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateUri *string `json:"template_uri,omitempty"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 执行计划的描述。可用于客户识别自己的执行计划。 Description *string `json:"description,omitempty"` // HCL参数结构。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * var_structure可以允许客户提交最简单的字符串类型的参数 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 * 如果vars_structure过大,可以使用vars_uri * 注意:vars_structure中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议设置encryption字段开启加密 VarsStructure *[]VarsStructure `json:"vars_structure,omitempty"` // HCL参数文件的内容。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * vars_body使用HCL的tfvars格式,用户可以将“.tfvars”中的内容提交到vars_body中。 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * 如果vars_body过大,可以使用vars_uri * 如果vars中都是简单的字符串格式,可以使用var_structure * 注意:vars_body中不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsBody *string `json:"vars_body,omitempty"` // HCL参数文件的OBS地址。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_uri中的内容使用HCL的tfvars格式,用户可以将“.tfvars”中的内容保存到文件并上传到OBS中,并将OBS pre-signed URL传递给vars_uri。 * 注意:vars_uri的内容不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsUri *string `json:"vars_uri,omitempty"` }
func (CreateExecutionPlanRequestBody) String ¶
func (o CreateExecutionPlanRequestBody) String() string
type CreateExecutionPlanResponse ¶
type CreateExecutionPlanResponse struct { // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (CreateExecutionPlanResponse) String ¶
func (o CreateExecutionPlanResponse) String() string
type CreateStackRequest ¶
type CreateStackRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` Body *CreateStackRequestBody `json:"body,omitempty"` }
Request Object
func (CreateStackRequest) String ¶
func (o CreateStackRequest) String() string
type CreateStackRequestBody ¶
type CreateStackRequestBody struct { // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 委托授权的信息。 Agencies *[]Agency `json:"agencies,omitempty"` // 资源栈的描述。可用于客户识别自己的资源栈。 Description *string `json:"description,omitempty"` // 删除保护的标识位,如果不传默认为false,即默认不开启资源栈删除保护(删除保护开启后资源栈不允许被删除) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的删除保护属性进行更新* EnableDeletionProtection *bool `json:"enable_deletion_protection,omitempty"` // 自动回滚的标识位,如果不传默认为false,即默认不开启资源栈自动回滚(自动回滚开启后,如果部署失败,则会自动回滚,并返回上一个稳定状态) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的自动回滚属性进行更新* EnableAutoRollback *bool `json:"enable_auto_rollback,omitempty"` // HCL模板,描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_body中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的template_body。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateBody *string `json:"template_body,omitempty"` // HCL模板的OBS地址,该模板描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) 对应的文件应该是纯tf文件或zip压缩包 纯tf文件需要以`.tf`或者`.tf.json`结尾,并遵守HCL语法 压缩包目前只支持zip格式,文件需要以`.zip`结尾。解压后的文件不得包含\".tfvars\"文件 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_uri对应的模板文件中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的模板文件内容。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateUri *string `json:"template_uri,omitempty"` // HCL参数文件的内容。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * vars_body使用HCL的tfvars格式,用户可以将“.tfvars”中的内容提交到vars_body中。 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * 如果vars_body过大,可以使用vars_uri * 如果vars中都是简单的字符串格式,可以使用var_structure * 注意:vars_body中不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsBody *string `json:"vars_body,omitempty"` // HCL参数结构。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * var_structure可以允许客户提交最简单的字符串类型的参数 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 * 如果vars_structure过大,可以使用vars_uri * 注意:vars_structure中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议设置encryption字段开启加密 VarsStructure *[]VarsStructure `json:"vars_structure,omitempty"` // HCL参数文件的OBS地址。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_uri中的内容使用HCL的tfvars格式,用户可以将“.tfvars”中的内容保存到文件并上传到OBS中,并将OBS pre-signed URL传递给vars_uri。 * 注意:vars_uri的内容不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsUri *string `json:"vars_uri,omitempty"` }
func (CreateStackRequestBody) String ¶
func (o CreateStackRequestBody) String() string
type CreateStackResponse ¶
type CreateStackResponse struct { // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 部署ID DeploymentId *string `json:"deployment_id,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (CreateStackResponse) String ¶
func (o CreateStackResponse) String() string
type DeleteExecutionPlanRequest ¶ added in v0.1.15
type DeleteExecutionPlanRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` }
Request Object
func (DeleteExecutionPlanRequest) String ¶ added in v0.1.15
func (o DeleteExecutionPlanRequest) String() string
type DeleteExecutionPlanResponse ¶ added in v0.1.15
type DeleteExecutionPlanResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (DeleteExecutionPlanResponse) String ¶ added in v0.1.15
func (o DeleteExecutionPlanResponse) String() string
type DeleteStackRequest ¶ added in v0.1.12
type DeleteStackRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
Request Object
func (DeleteStackRequest) String ¶ added in v0.1.12
func (o DeleteStackRequest) String() string
type DeleteStackResponse ¶ added in v0.1.12
type DeleteStackResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (DeleteStackResponse) String ¶ added in v0.1.12
func (o DeleteStackResponse) String() string
type DeleteTemplateRequest ¶ added in v0.1.30
type DeleteTemplateRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板的ID。当template_id存在时,模板服务会检查template_id是否和template_name匹配,不匹配会返回400 TemplateId *string `json:"template_id,omitempty"` }
Request Object
func (DeleteTemplateRequest) String ¶ added in v0.1.30
func (o DeleteTemplateRequest) String() string
type DeleteTemplateResponse ¶ added in v0.1.30
type DeleteTemplateResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (DeleteTemplateResponse) String ¶ added in v0.1.30
func (o DeleteTemplateResponse) String() string
type DeleteTemplateVersionRequest ¶ added in v0.1.30
type DeleteTemplateVersionRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板版本ID,以大写V开头,每次创建模板版本,模板版本ID数字部分会自增加一 VersionId string `json:"version_id"` // 模板的ID。当template_id存在时,模板服务会检查template_id是否和template_name匹配,不匹配会返回400 TemplateId *string `json:"template_id,omitempty"` }
Request Object
func (DeleteTemplateVersionRequest) String ¶ added in v0.1.30
func (o DeleteTemplateVersionRequest) String() string
type DeleteTemplateVersionResponse ¶ added in v0.1.30
type DeleteTemplateVersionResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (DeleteTemplateVersionResponse) String ¶ added in v0.1.30
func (o DeleteTemplateVersionResponse) String() string
type DeployStackRequest ¶
type DeployStackRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` Body *DeployStackRequestBody `json:"body,omitempty"` }
Request Object
func (DeployStackRequest) String ¶
func (o DeployStackRequest) String() string
type DeployStackRequestBody ¶
type DeployStackRequestBody struct { // HCL模板,描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_body中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的template_body。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateBody *string `json:"template_body,omitempty"` // HCL模板的OBS地址,该模板描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) 对应的文件应该是纯tf文件或zip压缩包 纯tf文件需要以`.tf`或者`.tf.json`结尾,并遵守HCL语法 压缩包目前只支持zip格式,文件需要以`.zip`结尾。解压后的文件不得包含\".tfvars\"文件 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_uri对应的模板文件中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的模板文件内容。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateUri *string `json:"template_uri,omitempty"` // HCL参数结构。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * var_structure可以允许客户提交最简单的字符串类型的参数 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 * 如果vars_structure过大,可以使用vars_uri * 注意:vars_structure中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议设置encryption字段开启加密 VarsStructure *[]VarsStructure `json:"vars_structure,omitempty"` // HCL参数文件的内容。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * vars_body使用HCL的tfvars格式,用户可以将“.tfvars”中的内容提交到vars_body中。 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * 如果vars_body过大,可以使用vars_uri * 如果vars中都是简单的字符串格式,可以使用var_structure * 注意:vars_body中不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsBody *string `json:"vars_body,omitempty"` // HCL参数文件的OBS地址。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_uri中的内容使用HCL的tfvars格式,用户可以将“.tfvars”中的内容保存到文件并上传到OBS中,并将OBS pre-signed URL传递给vars_uri。 * 注意:vars_uri的内容不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsUri *string `json:"vars_uri,omitempty"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
func (DeployStackRequestBody) String ¶
func (o DeployStackRequestBody) String() string
type DeployStackResponse ¶
type DeployStackResponse struct { // 部署ID DeploymentId *string `json:"deployment_id,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (DeployStackResponse) String ¶
func (o DeployStackResponse) String() string
type DeploymentIdPrimitiveTypeHolder ¶ added in v0.1.30
type DeploymentIdPrimitiveTypeHolder struct { // 标识部署的唯一Id,此Id由资源编排服务在触发部署、回滚等操作时生成,为UUID。 DeploymentId *string `json:"deployment_id,omitempty"` }
func (DeploymentIdPrimitiveTypeHolder) String ¶ added in v0.1.30
func (o DeploymentIdPrimitiveTypeHolder) String() string
type EnableAutoRollbackPrimitiveTypeHolder ¶
type EnableAutoRollbackPrimitiveTypeHolder struct { // 自动回滚的标识位,如果不传默认为false,即默认不开启资源栈自动回滚(自动回滚开启后,如果部署失败,则会自动回滚,并返回上一个稳定状态) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的自动回滚属性进行更新* EnableAutoRollback *bool `json:"enable_auto_rollback,omitempty"` }
func (EnableAutoRollbackPrimitiveTypeHolder) String ¶
func (o EnableAutoRollbackPrimitiveTypeHolder) String() string
type EnableDeletionProtectionPrimitiveTypeHolder ¶
type EnableDeletionProtectionPrimitiveTypeHolder struct { // 删除保护的标识位,如果不传默认为false,即默认不开启资源栈删除保护(删除保护开启后资源栈不允许被删除) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的删除保护属性进行更新* EnableDeletionProtection *bool `json:"enable_deletion_protection,omitempty"` }
func (EnableDeletionProtectionPrimitiveTypeHolder) String ¶
func (o EnableDeletionProtectionPrimitiveTypeHolder) String() string
type EncryptionStructure ¶
type EncryptionStructure struct {
Kms *KmsStructure `json:"kms"`
}
如果用户传递的var_value是已经加密过的,可以通过声名此项以要求资源编排服务在使用前进行解密,目前暂时只支持KMS加解密
func (EncryptionStructure) String ¶
func (o EncryptionStructure) String() string
type EstimateExecutionPlanPriceRequest ¶
type EstimateExecutionPlanPriceRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` }
Request Object
func (EstimateExecutionPlanPriceRequest) String ¶
func (o EstimateExecutionPlanPriceRequest) String() string
type EstimateExecutionPlanPriceResponse ¶
type EstimateExecutionPlanPriceResponse struct { // 币种,枚举值 * `CNY` - 元,中国站返回的币种 * `USD` - 美元,国际站返回的币种 Currency *EstimateExecutionPlanPriceResponseCurrency `json:"currency,omitempty"` // 执行计划中所有资源的询价结果 Items *[]ItemsResponse `json:"items,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (EstimateExecutionPlanPriceResponse) String ¶
func (o EstimateExecutionPlanPriceResponse) String() string
type EstimateExecutionPlanPriceResponseCurrency ¶
type EstimateExecutionPlanPriceResponseCurrency struct {
// contains filtered or unexported fields
}
func (EstimateExecutionPlanPriceResponseCurrency) MarshalJSON ¶
func (c EstimateExecutionPlanPriceResponseCurrency) MarshalJSON() ([]byte, error)
func (*EstimateExecutionPlanPriceResponseCurrency) UnmarshalJSON ¶
func (c *EstimateExecutionPlanPriceResponseCurrency) UnmarshalJSON(b []byte) error
func (EstimateExecutionPlanPriceResponseCurrency) Value ¶
func (c EstimateExecutionPlanPriceResponseCurrency) Value() string
type EstimateExecutionPlanPriceResponseCurrencyEnum ¶
type EstimateExecutionPlanPriceResponseCurrencyEnum struct { CNY EstimateExecutionPlanPriceResponseCurrency USD EstimateExecutionPlanPriceResponseCurrency }
func GetEstimateExecutionPlanPriceResponseCurrencyEnum ¶
func GetEstimateExecutionPlanPriceResponseCurrencyEnum() EstimateExecutionPlanPriceResponseCurrencyEnum
type ExecutionPlan ¶
type ExecutionPlan struct { // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 执行计划的描述。可用于客户识别自己的执行计划。 Description *string `json:"description,omitempty"` // 执行计划的状态 * `CREATION_IN_PROGRESS` - 正在创建,请等待 * `CREATION_FAILED` - 创建失败,请从status_message获取错误信息汇总 * `AVAILABLE` - 创建完成,可以调用ApplyExecutionPlan API进行执行 * `APPLY_IN_PROGRESS` - 执行中,可通过GetStackMetadata查询资源栈状态,通过ListStackEvents获取执行过程中产生的资源栈事件 * `APPLIED` - 已执行 Status *ExecutionPlanStatus `json:"status,omitempty"` // 当执行计划的状态为创建失败状态(即为 `CREATION_FAILED` 时),将会展示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` // 执行计划的生成时间,格式遵循RFC3339,精确到秒,UTC时区,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime *string `json:"create_time,omitempty"` // 执行计划的执行时间,格式遵循RFC3339,精确到秒,UTC时区,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z ApplyTime *string `json:"apply_time,omitempty"` }
func (ExecutionPlan) String ¶
func (o ExecutionPlan) String() string
type ExecutionPlanDescriptionPrimitiveTypeHolder ¶ added in v0.1.30
type ExecutionPlanDescriptionPrimitiveTypeHolder struct { // 执行计划的描述。可用于客户识别自己的执行计划。 Description *string `json:"description,omitempty"` }
func (ExecutionPlanDescriptionPrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ExecutionPlanDescriptionPrimitiveTypeHolder) String() string
type ExecutionPlanDiffAttribute ¶ added in v0.1.15
type ExecutionPlanDiffAttribute struct { // 当前资源将要被修改的参数的名字。 Name *string `json:"name,omitempty"` // 当前资源被修改的参数的原始值。 若是资源创建的场景,则previous_value为空 若远端资源产生了偏差,则同一个资源会返回两个ExecutionPlanItem,其中一个的drifted为true,另一个的drifted为false * drifted为true的previous_value为资源栈中所维持的资源属性和状态 * drifted为false的previous_value为provider请求远端资源后,远端资源所返回的资源属性和状态 若远端资源未产生偏差,则只会返回一个drifted为false的ExecutionPlanItem * drifted为false的previous_value为资源栈中所维持的资源属性和状态 PreviousValue *string `json:"previous_value,omitempty"` // 当前资源被修改的参数的目的值。 若是资源删除的场景,则target_value为空 若远端资源产生了偏差,则同一个资源会返回两个ExecutionPlanItem,其中一个的drifted为true,另一个的drifted为false * drifted为true的target_value为provider请求远端资源后,远端资源所返回的资源属性和状态 * drifted为false的target_value为基于用户模板更新的资源属性和状态 若远端资源未产生偏差,则只会返回一个drifted为false的ExecutionPlanItem * drifted为false的target_value为基于用户模板更新的资源属性和状态 TargetValue *string `json:"target_value,omitempty"` }
func (ExecutionPlanDiffAttribute) String ¶ added in v0.1.15
func (o ExecutionPlanDiffAttribute) String() string
type ExecutionPlanIdPrimitiveTypeHolder ¶ added in v0.1.30
type ExecutionPlanIdPrimitiveTypeHolder struct { // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` }
func (ExecutionPlanIdPrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ExecutionPlanIdPrimitiveTypeHolder) String() string
type ExecutionPlanItem ¶ added in v0.1.15
type ExecutionPlanItem struct { // 资源的类型 以HCL格式的模板为例,resource_type 为 huaweicloud_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_type 为 huaweicloud_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceType *string `json:"resource_type,omitempty"` // 资源的名称,默认为资源的逻辑名称 以HCL格式的模板为例,resource_name 为 my_hello_world_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_name 为 my_hello_world_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceName *string `json:"resource_name,omitempty"` // 资源的索引,若用户在模板中使用了count或for_each则会返回index。若index出现,则resource_name + index可以作为该资源的一种标识 若用户在模板中使用count,则index为从0开始的数字 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { count = 2 name = \"test_vpc\" } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\", \"count\": 2 } } } } “` 若用户在模板中使用for_each,则index为用户自定义的字符串 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { for_each = { \"vpc1\" = \"test_vpc\" \"vpc2\" = \"test_vpc\" } name = each.value } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"for_each\": { \"vpc1\": \"test_vpc\", \"vpc2\": \"test_vpc\" } \"name\": \"${each.value}\" } } } } “` Index *string `json:"index,omitempty"` // 资源变更的类型 * `ADD` - 新增资源 * `ADD_THEN_DELETE` - 由不可更新的资源返回,先创建新资源,再删除旧资源 * `DELETE ` - 删除资源 * `DELETE_THEN_ADD` - 由不可更新的资源返回,先删除旧资源,再创建新资源 * `UPDATE` - 更新资源 * `NO_OPERATION` - 仅变更资源的依赖关系,但是对资源本身并无修改的操作 Action *ExecutionPlanItemAction `json:"action,omitempty"` // 触发该项目变更的原因,例如用户更新模板;远端删除资源等等 ActionReason *string `json:"action_reason,omitempty"` // 该项目所属的provider名称。 ProviderName *string `json:"provider_name,omitempty"` // 资源模式 * `DATA` - 指可以在模板解析期间运行和获取服务端数据的资源类型,不会操作基础设施组件 * `RESOURCE` - 指通过模板管理的由服务定义的基础设施组件抽象,可以是物理资源也可以是逻辑资源 Mode *ExecutionPlanItemMode `json:"mode,omitempty"` // 当前资源的变更是否由偏差导致。 偏差,也叫漂移。指的是资源被资源编排服务创建以后,又经历过非资源编排服务触发的修改,如手动修改、调用SDK修改等,使得资源的配置与本服务所记录的资源的配置不一致。这种不一致便称为偏差。 当资源产生偏差以后: * 如果用户试图创建执行计划,则会提示用户产生偏差 * 如果用户直接部署,则偏差有可能被覆盖,资源编排服务只保证资源和模板最终一致。 资源的偏差有两种类型: * 资源定位属性被修改:如果是定位属性被修改,常见于删除后重建,此时资源已经不属于同一个资源。资源编排服务会认为此资源已经被删除,会尝试创建一个新的资源。 * 资源普通属性被修改:如果是普通属性被修改,则资源编排服务依然可以找到资源,但是下次部署会尝试修复偏差,即将资源保持和模板最终一致。 **注:资源编排服务团队极力推荐,如果资源是通过本服务创建的,请一直使用本服务进行维护和更新以确保资源和模板保持一致。建议非紧急事件以外的情况不要手动调整。** Drifted *bool `json:"drifted,omitempty"` // 资源的物理id,是唯一id,由为该资源提供服务的provider、云服务或其他服务提供方在资源部署的时候生成 ResourceId *string `json:"resource_id,omitempty"` // 执行计划项目中变更的属性,当无属性变更时为空列表。 Attributes *[]ExecutionPlanDiffAttribute `json:"attributes,omitempty"` }
func (ExecutionPlanItem) String ¶ added in v0.1.15
func (o ExecutionPlanItem) String() string
type ExecutionPlanItemAction ¶ added in v0.1.15
type ExecutionPlanItemAction struct {
// contains filtered or unexported fields
}
func (ExecutionPlanItemAction) MarshalJSON ¶ added in v0.1.15
func (c ExecutionPlanItemAction) MarshalJSON() ([]byte, error)
func (*ExecutionPlanItemAction) UnmarshalJSON ¶ added in v0.1.15
func (c *ExecutionPlanItemAction) UnmarshalJSON(b []byte) error
func (ExecutionPlanItemAction) Value ¶ added in v0.1.15
func (c ExecutionPlanItemAction) Value() string
type ExecutionPlanItemActionEnum ¶ added in v0.1.15
type ExecutionPlanItemActionEnum struct { ADD ExecutionPlanItemAction ADD_THEN_DELETE ExecutionPlanItemAction DELETE ExecutionPlanItemAction DELETE_THEN_ADD ExecutionPlanItemAction UPDATE ExecutionPlanItemAction NO_OPERATION ExecutionPlanItemAction }
func GetExecutionPlanItemActionEnum ¶ added in v0.1.15
func GetExecutionPlanItemActionEnum() ExecutionPlanItemActionEnum
type ExecutionPlanItemMode ¶ added in v0.1.15
type ExecutionPlanItemMode struct {
// contains filtered or unexported fields
}
func (ExecutionPlanItemMode) MarshalJSON ¶ added in v0.1.15
func (c ExecutionPlanItemMode) MarshalJSON() ([]byte, error)
func (*ExecutionPlanItemMode) UnmarshalJSON ¶ added in v0.1.15
func (c *ExecutionPlanItemMode) UnmarshalJSON(b []byte) error
func (ExecutionPlanItemMode) Value ¶ added in v0.1.15
func (c ExecutionPlanItemMode) Value() string
type ExecutionPlanItemModeEnum ¶ added in v0.1.15
type ExecutionPlanItemModeEnum struct { DATA ExecutionPlanItemMode RESOURCE ExecutionPlanItemMode }
func GetExecutionPlanItemModeEnum ¶ added in v0.1.15
func GetExecutionPlanItemModeEnum() ExecutionPlanItemModeEnum
type ExecutionPlanNamePrimitiveTypeHolder ¶ added in v0.1.30
type ExecutionPlanNamePrimitiveTypeHolder struct { // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` }
func (ExecutionPlanNamePrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ExecutionPlanNamePrimitiveTypeHolder) String() string
type ExecutionPlanStatus ¶
type ExecutionPlanStatus struct {
// contains filtered or unexported fields
}
func (ExecutionPlanStatus) MarshalJSON ¶
func (c ExecutionPlanStatus) MarshalJSON() ([]byte, error)
func (*ExecutionPlanStatus) UnmarshalJSON ¶
func (c *ExecutionPlanStatus) UnmarshalJSON(b []byte) error
func (ExecutionPlanStatus) Value ¶
func (c ExecutionPlanStatus) Value() string
type ExecutionPlanStatusEnum ¶
type ExecutionPlanStatusEnum struct { CREATION_IN_PROGRESS ExecutionPlanStatus CREATION_FAILED ExecutionPlanStatus AVAILABLE ExecutionPlanStatus APPLY_IN_PROGRESS ExecutionPlanStatus APPLIED ExecutionPlanStatus }
func GetExecutionPlanStatusEnum ¶
func GetExecutionPlanStatusEnum() ExecutionPlanStatusEnum
type ExecutionPlanStatusMessagePrimitiveTypeHolder ¶ added in v0.1.30
type ExecutionPlanStatusMessagePrimitiveTypeHolder struct { // 当执行计划的状态为创建失败状态(即为 `CREATION_FAILED` 时),将会展示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` }
func (ExecutionPlanStatusMessagePrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ExecutionPlanStatusMessagePrimitiveTypeHolder) String() string
type ExecutionPlanStatusPrimitiveTypeHolder ¶ added in v0.1.30
type ExecutionPlanStatusPrimitiveTypeHolder struct { // 执行计划的状态 * `CREATION_IN_PROGRESS` - 正在创建,请等待 * `CREATION_FAILED` - 创建失败,请从status_message获取错误信息汇总 * `AVAILABLE` - 创建完成,可以调用ApplyExecutionPlan API进行执行 * `APPLY_IN_PROGRESS` - 执行中,可通过GetStackMetadata查询资源栈状态,通过ListStackEvents获取执行过程中产生的资源栈事件 * `APPLIED` - 已执行 Status *ExecutionPlanStatusPrimitiveTypeHolderStatus `json:"status,omitempty"` }
func (ExecutionPlanStatusPrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ExecutionPlanStatusPrimitiveTypeHolder) String() string
type ExecutionPlanStatusPrimitiveTypeHolderStatus ¶ added in v0.1.30
type ExecutionPlanStatusPrimitiveTypeHolderStatus struct {
// contains filtered or unexported fields
}
func (ExecutionPlanStatusPrimitiveTypeHolderStatus) MarshalJSON ¶ added in v0.1.30
func (c ExecutionPlanStatusPrimitiveTypeHolderStatus) MarshalJSON() ([]byte, error)
func (*ExecutionPlanStatusPrimitiveTypeHolderStatus) UnmarshalJSON ¶ added in v0.1.30
func (c *ExecutionPlanStatusPrimitiveTypeHolderStatus) UnmarshalJSON(b []byte) error
func (ExecutionPlanStatusPrimitiveTypeHolderStatus) Value ¶ added in v0.1.30
func (c ExecutionPlanStatusPrimitiveTypeHolderStatus) Value() string
type ExecutionPlanStatusPrimitiveTypeHolderStatusEnum ¶ added in v0.1.30
type ExecutionPlanStatusPrimitiveTypeHolderStatusEnum struct { CREATION_IN_PROGRESS ExecutionPlanStatusPrimitiveTypeHolderStatus CREATION_FAILED ExecutionPlanStatusPrimitiveTypeHolderStatus AVAILABLE ExecutionPlanStatusPrimitiveTypeHolderStatus APPLY_IN_PROGRESS ExecutionPlanStatusPrimitiveTypeHolderStatus APPLIED ExecutionPlanStatusPrimitiveTypeHolderStatus }
func GetExecutionPlanStatusPrimitiveTypeHolderStatusEnum ¶ added in v0.1.30
func GetExecutionPlanStatusPrimitiveTypeHolderStatusEnum() ExecutionPlanStatusPrimitiveTypeHolderStatusEnum
type ExecutionPlanSummary ¶ added in v0.1.15
type ExecutionPlanSummary struct { // 新增资源数 ResourceAdd *int32 `json:"resource_add,omitempty"` // 更新资源数 ResourceUpdate *int32 `json:"resource_update,omitempty"` // 删除资源数 ResourceDelete *int32 `json:"resource_delete,omitempty"` }
func (ExecutionPlanSummary) String ¶ added in v0.1.15
func (o ExecutionPlanSummary) String() string
type ExecutorPrimitiveTypeHolder ¶
type ExecutorPrimitiveTypeHolder struct { }
func (ExecutorPrimitiveTypeHolder) String ¶
func (o ExecutorPrimitiveTypeHolder) String() string
type GetExecutionPlanMetadataRequest ¶ added in v0.1.30
type GetExecutionPlanMetadataRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` }
Request Object
func (GetExecutionPlanMetadataRequest) String ¶ added in v0.1.30
func (o GetExecutionPlanMetadataRequest) String() string
type GetExecutionPlanMetadataResponse ¶ added in v0.1.30
type GetExecutionPlanMetadataResponse struct { // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 执行计划的描述。可用于客户识别自己的执行计划。 Description *string `json:"description,omitempty"` // HCL参数结构。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * var_structure可以允许客户提交最简单的字符串类型的参数 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 * 如果vars_structure过大,可以使用vars_uri * 注意:vars_structure中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议设置encryption字段开启加密 VarsStructure *[]VarsStructure `json:"vars_structure,omitempty"` // vars_uri对应的文件内容 VarsUriContent *string `json:"vars_uri_content,omitempty"` // HCL参数文件的内容。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * vars_body使用HCL的tfvars格式,用户可以将“.tfvars”中的内容提交到vars_body中。 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * 如果vars_body过大,可以使用vars_uri * 如果vars中都是简单的字符串格式,可以使用var_structure * 注意:vars_body中不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsBody *string `json:"vars_body,omitempty"` // 执行计划的状态 * `CREATION_IN_PROGRESS` - 正在创建,请等待 * `CREATION_FAILED` - 创建失败,请从status_message获取错误信息汇总 * `AVAILABLE` - 创建完成,可以调用ApplyExecutionPlan API进行执行 * `APPLY_IN_PROGRESS` - 执行中,可通过GetStackMetadata查询资源栈状态,通过ListStackEvents获取执行过程中产生的资源栈事件 * `APPLIED` - 已执行 Status *GetExecutionPlanMetadataResponseStatus `json:"status,omitempty"` // 当执行计划的状态为创建失败状态(即为 `CREATION_FAILED` 时),将会展示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` // 执行计划的生成时间 格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime *string `json:"create_time,omitempty"` // 执行计划的执行时间 格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z ApplyTime *string `json:"apply_time,omitempty"` Summary *ExecutionPlanSummary `json:"summary,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (GetExecutionPlanMetadataResponse) String ¶ added in v0.1.30
func (o GetExecutionPlanMetadataResponse) String() string
type GetExecutionPlanMetadataResponseStatus ¶ added in v0.1.30
type GetExecutionPlanMetadataResponseStatus struct {
// contains filtered or unexported fields
}
func (GetExecutionPlanMetadataResponseStatus) MarshalJSON ¶ added in v0.1.30
func (c GetExecutionPlanMetadataResponseStatus) MarshalJSON() ([]byte, error)
func (*GetExecutionPlanMetadataResponseStatus) UnmarshalJSON ¶ added in v0.1.30
func (c *GetExecutionPlanMetadataResponseStatus) UnmarshalJSON(b []byte) error
func (GetExecutionPlanMetadataResponseStatus) Value ¶ added in v0.1.30
func (c GetExecutionPlanMetadataResponseStatus) Value() string
type GetExecutionPlanMetadataResponseStatusEnum ¶ added in v0.1.30
type GetExecutionPlanMetadataResponseStatusEnum struct { CREATION_IN_PROGRESS GetExecutionPlanMetadataResponseStatus CREATION_FAILED GetExecutionPlanMetadataResponseStatus AVAILABLE GetExecutionPlanMetadataResponseStatus APPLY_IN_PROGRESS GetExecutionPlanMetadataResponseStatus APPLIED GetExecutionPlanMetadataResponseStatus }
func GetGetExecutionPlanMetadataResponseStatusEnum ¶ added in v0.1.30
func GetGetExecutionPlanMetadataResponseStatusEnum() GetExecutionPlanMetadataResponseStatusEnum
type GetExecutionPlanRequest ¶ added in v0.1.15
type GetExecutionPlanRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 执行计划的名称。此名字在domain_id+区域+project_id+stack_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 ExecutionPlanName string `json:"execution_plan_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 执行计划(execution_plan)的唯一Id。 此Id由资源编排服务在生成执行计划的时候生成,为UUID。 由于执行计划名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的执行计划,删除,再重新创建一个同名执行计划。 对于团队并行开发,用户可能希望确保,当前我操作的执行计划就是我认为的那个,而不是其他队友删除后创建的同名执行计划。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的执行计划所对应的ID都不相同,更新不会影响ID。如果给与的execution_plan_id和当前执行计划的ID不一致,则返回400 ExecutionPlanId *string `json:"execution_plan_id,omitempty"` }
Request Object
func (GetExecutionPlanRequest) String ¶ added in v0.1.15
func (o GetExecutionPlanRequest) String() string
type GetExecutionPlanResponse ¶ added in v0.1.15
type GetExecutionPlanResponse struct { // 执行计划项目的列表 ExecutionPlanItems *[]ExecutionPlanItem `json:"execution_plan_items,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (GetExecutionPlanResponse) String ¶ added in v0.1.15
func (o GetExecutionPlanResponse) String() string
type GetStackMetadataRequest ¶ added in v0.1.15
type GetStackMetadataRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
Request Object
func (GetStackMetadataRequest) String ¶ added in v0.1.15
func (o GetStackMetadataRequest) String() string
type GetStackMetadataResponse ¶ added in v0.1.15
type GetStackMetadataResponse struct { // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈的描述。可用于客户识别自己的资源栈。 Description *string `json:"description,omitempty"` // HCL参数结构。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * var_structure可以允许客户提交最简单的字符串类型的参数 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 * 如果vars_structure过大,可以使用vars_uri * 注意:vars_structure中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议设置encryption字段开启加密 VarsStructure *[]VarsStructure `json:"vars_structure,omitempty"` // HCL参数文件的内容。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * vars_body使用HCL的tfvars格式,用户可以将“.tfvars”中的内容提交到vars_body中。 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * 如果vars_body过大,可以使用vars_uri * 如果vars中都是简单的字符串格式,可以使用var_structure * 注意:vars_body中不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsBody *string `json:"vars_body,omitempty"` // 删除保护的标识位,如果不传默认为false,即默认不开启资源栈删除保护(删除保护开启后资源栈不允许被删除) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的删除保护属性进行更新* EnableDeletionProtection *bool `json:"enable_deletion_protection,omitempty"` // 自动回滚的标识位,如果不传默认为false,即默认不开启资源栈自动回滚(自动回滚开启后,如果部署失败,则会自动回滚,并返回上一个稳定状态) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的自动回滚属性进行更新* EnableAutoRollback *bool `json:"enable_auto_rollback,omitempty"` // 资源栈的状态 * `CREATION_COMPLETE` - 生成空资源栈完成,并没有任何部署 * `DEPLOYMENT_IN_PROGRESS` - 正在部署,请等待 * `DEPLOYMENT_FAILED` - 部署失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 * `DEPLOYMENT_COMPLETE` - 部署完成 * `ROLLBACK_IN_PROGRESS` - 部署失败,正在回滚,请等待 * `ROLLBACK_FAILED` - 回滚失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 * `ROLLBACK_COMPLETE` - 回滚完成 * `DELETION_IN_PROGRESS` - 正在删除,请等待 * `DELETION_FAILED` - 删除失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 Status *GetStackMetadataResponseStatus `json:"status,omitempty"` // 委托授权的信息。 Agencies *[]Agency `json:"agencies,omitempty"` // 当资源栈的状态为任意失败状态(即以 `FAILED` 结尾时),将会展示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` // vars_uri对应的文件内容 VarsUriContent *string `json:"vars_uri_content,omitempty"` // 资源栈的生成时间 格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime *string `json:"create_time,omitempty"` // 资源栈的更新时间(更新场景包括元数据更新场景和部署场景) 格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z UpdateTime *string `json:"update_time,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (GetStackMetadataResponse) String ¶ added in v0.1.15
func (o GetStackMetadataResponse) String() string
type GetStackMetadataResponseStatus ¶ added in v0.1.15
type GetStackMetadataResponseStatus struct {
// contains filtered or unexported fields
}
func (GetStackMetadataResponseStatus) MarshalJSON ¶ added in v0.1.15
func (c GetStackMetadataResponseStatus) MarshalJSON() ([]byte, error)
func (*GetStackMetadataResponseStatus) UnmarshalJSON ¶ added in v0.1.15
func (c *GetStackMetadataResponseStatus) UnmarshalJSON(b []byte) error
func (GetStackMetadataResponseStatus) Value ¶ added in v0.1.15
func (c GetStackMetadataResponseStatus) Value() string
type GetStackMetadataResponseStatusEnum ¶ added in v0.1.15
type GetStackMetadataResponseStatusEnum struct { CREATION_COMPLETE GetStackMetadataResponseStatus DEPLOYMENT_IN_PROGRESS GetStackMetadataResponseStatus DEPLOYMENT_FAILED GetStackMetadataResponseStatus DEPLOYMENT_COMPLETE GetStackMetadataResponseStatus ROLLBACK_IN_PROGRESS GetStackMetadataResponseStatus ROLLBACK_FAILED GetStackMetadataResponseStatus ROLLBACK_COMPLETE GetStackMetadataResponseStatus DELETION_IN_PROGRESS GetStackMetadataResponseStatus DELETION_FAILED GetStackMetadataResponseStatus }
func GetGetStackMetadataResponseStatusEnum ¶ added in v0.1.15
func GetGetStackMetadataResponseStatusEnum() GetStackMetadataResponseStatusEnum
type GetStackTemplateRequest ¶
type GetStackTemplateRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
Request Object
func (GetStackTemplateRequest) String ¶
func (o GetStackTemplateRequest) String() string
type GetStackTemplateResponse ¶
type GetStackTemplateResponse struct { Location *string `json:"Location,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (GetStackTemplateResponse) String ¶
func (o GetStackTemplateResponse) String() string
type IndexPrimitiveTypeHolder ¶ added in v0.1.30
type IndexPrimitiveTypeHolder struct { // 资源的索引,若用户在模板中使用了count或for_each则会返回index。若index出现,则resource_name + index可以作为该资源的一种标识 若用户在模板中使用count,则index为从0开始的数字 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { count = 2 name = \"test_vpc\" } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\", \"count\": 2 } } } } “` 若用户在模板中使用for_each,则index为用户自定义的字符串 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { for_each = { \"vpc1\" = \"test_vpc\" \"vpc2\" = \"test_vpc\" } name = each.value } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"for_each\": { \"vpc1\": \"test_vpc\", \"vpc2\": \"test_vpc\" } \"name\": \"${each.value}\" } } } } “` Index *string `json:"index,omitempty"` }
func (IndexPrimitiveTypeHolder) String ¶ added in v0.1.30
func (o IndexPrimitiveTypeHolder) String() string
type ItemsResponse ¶
type ItemsResponse struct { // 资源的类型 以HCL格式的模板为例,resource_type 为 huaweicloud_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_type 为 huaweicloud_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceType *string `json:"resource_type,omitempty"` // 资源的名称,默认为资源的逻辑名称 以HCL格式的模板为例,resource_name 为 my_hello_world_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_name 为 my_hello_world_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceName *string `json:"resource_name,omitempty"` // 资源的索引,若用户在模板中使用了count或for_each则会返回index。若index出现,则resource_name + index可以作为该资源的一种标识 若用户在模板中使用count,则index为从0开始的数字 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { count = 2 name = \"test_vpc\" } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\", \"count\": 2 } } } } “` 若用户在模板中使用for_each,则index为用户自定义的字符串 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { for_each = { \"vpc1\" = \"test_vpc\" \"vpc2\" = \"test_vpc\" } name = each.value } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"for_each\": { \"vpc1\": \"test_vpc\", \"vpc2\": \"test_vpc\" } \"name\": \"${each.value}\" } } } } “` Index *string `json:"index,omitempty"` // 该资源或该资源当前所给予的参数是否支持进行询价 Supported *bool `json:"supported,omitempty"` // 该资源不支持询价的具体原因 UnsupportedMessage *string `json:"unsupported_message,omitempty"` // 该资源的询价信息 若该资源支持包周期计费或按需计费,或者该资源为免费资源,则返回该字段;若该资源不支持询价,则不返回该字段。 ResourcePrice *[]ResourcePriceResponse `json:"resource_price,omitempty"` }
func (ItemsResponse) String ¶
func (o ItemsResponse) String() string
type KmsStructure ¶
type KmsStructure struct { // 解密时,资源编排服务应该使用的KMS秘钥的ID,通常是加密时所使用的秘钥ID Id string `json:"id"` // 数据加密秘钥所对应的密文 CipherText string `json:"cipher_text"` }
如果用户给与的var_value是经过KMS加密的,可以通过传递相关加密信息,资源编排服务在使用的时候会帮助用户进行KMS解密 更多关于KMS加密以及KMS加密的样例代码请见:[KMS加密使用场景介绍](https://support.huaweicloud.com/productdesc-dew/dew_01_0006.html) **注意:** * 请确保用户给予资源编排服务的委托中包含对指定秘钥ID的操作权限 * KMS每个月有免费试用的额度,如果超过,则KMS需要收费,此费用不是资源编排服务收取,具体标准见:[https://www.huaweicloud.com/pricing.html?tab=detail#/dew](https://www.huaweicloud.com/pricing.html?tab=detail#/dew) * KMS加密只代表资源编排服务在存储和传输的时候传递的是密文,但是在stack-events中依然是明文,如果希望在log中以密文形式对待,请在模板中声名sensitive,更多关于sensitive的介绍见:[https://learn.hashicorp.com/tutorials/terraform/sensitive-variables](https://learn.hashicorp.com/tutorials/terraform/sensitive-variables)
func (KmsStructure) String ¶
func (o KmsStructure) String() string
type ListExecutionPlansRequest ¶
type ListExecutionPlansRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
Request Object
func (ListExecutionPlansRequest) String ¶
func (o ListExecutionPlansRequest) String() string
type ListExecutionPlansResponse ¶
type ListExecutionPlansResponse struct { // 执行计划列表。默认按照生成时间排序,最早生成的在最前 ExecutionPlans *[]ExecutionPlan `json:"execution_plans,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ListExecutionPlansResponse) String ¶
func (o ListExecutionPlansResponse) String() string
type ListStackEventsRequest ¶ added in v0.1.12
type ListStackEventsRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 标识部署的唯一Id,此Id由资源编排服务在触发部署、回滚等操作时生成,为UUID。 DeploymentId *string `json:"deployment_id,omitempty"` // 过滤条件 * 与(AND)运算符使用逗号(,)定义 * 或(OR)运算符使用竖线(|)定义,OR运算符优先级高于AND运算符 * 不支持括号 * 过滤运算符仅支持等号(==) * 过滤参数名及其值仅支持包含大小写英文、数字和下划线 * 过滤条件中禁止使用分号,若有分号,则此条过滤会被忽略 * 一个过滤参数仅能与一个与条件相关,一个与条件中的多个或条件仅能与一个过滤参数相关 Filter *string `json:"filter,omitempty"` // 选择的属性名称 * 属性名仅支持包含大小写英文、数字和下划线 * 多个属性名称之间以逗号(,)分隔 Field *string `json:"field,omitempty"` }
Request Object
func (ListStackEventsRequest) String ¶ added in v0.1.12
func (o ListStackEventsRequest) String() string
type ListStackEventsResponse ¶ added in v0.1.12
type ListStackEventsResponse struct { // 资源栈事件列表 StackEvents *[]StackEvent `json:"stack_events,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ListStackEventsResponse) String ¶ added in v0.1.12
func (o ListStackEventsResponse) String() string
type ListStackOutputsRequest ¶
type ListStackOutputsRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
Request Object
func (ListStackOutputsRequest) String ¶
func (o ListStackOutputsRequest) String() string
type ListStackOutputsResponse ¶
type ListStackOutputsResponse struct { // 资源栈输出列表 Outputs *[]StackOutput `json:"outputs,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ListStackOutputsResponse) String ¶
func (o ListStackOutputsResponse) String() string
type ListStackResourcesRequest ¶ added in v0.1.12
type ListStackResourcesRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
Request Object
func (ListStackResourcesRequest) String ¶ added in v0.1.12
func (o ListStackResourcesRequest) String() string
type ListStackResourcesResponse ¶ added in v0.1.12
type ListStackResourcesResponse struct { // 资源栈中所管理的资源信息列表 StackResources *[]StackResource `json:"stack_resources,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ListStackResourcesResponse) String ¶ added in v0.1.12
func (o ListStackResourcesResponse) String() string
type ListStacksRequest ¶
type ListStacksRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` }
Request Object
func (ListStacksRequest) String ¶
func (o ListStacksRequest) String() string
type ListStacksResponse ¶
type ListStacksResponse struct { // 资源栈列表。默认按照生成时间排序,最早生成的在最前 Stacks *[]Stack `json:"stacks,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ListStacksResponse) String ¶
func (o ListStacksResponse) String() string
type ListTemplatesRequest ¶ added in v0.1.30
type ListTemplatesRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` }
Request Object
func (ListTemplatesRequest) String ¶ added in v0.1.30
func (o ListTemplatesRequest) String() string
type ListTemplatesResponse ¶ added in v0.1.30
type ListTemplatesResponse struct { // 模板列表 Templates *[]Template `json:"templates,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ListTemplatesResponse) String ¶ added in v0.1.30
func (o ListTemplatesResponse) String() string
type ParseTemplateVariablesRequest ¶
type ParseTemplateVariablesRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` Body *ParseTemplateVariablesRequestBody `json:"body,omitempty"` }
Request Object
func (ParseTemplateVariablesRequest) String ¶
func (o ParseTemplateVariablesRequest) String() string
type ParseTemplateVariablesRequestBody ¶
type ParseTemplateVariablesRequestBody struct { // HCL模板,描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_body中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的template_body。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateBody *string `json:"template_body,omitempty"` // HCL模板的OBS地址,该模板描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) 对应的文件应该是纯tf文件或zip压缩包 纯tf文件需要以`.tf`或者`.tf.json`结尾,并遵守HCL语法 压缩包目前只支持zip格式,文件需要以`.zip`结尾。解压后的文件不得包含\".tfvars\"文件 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_uri对应的模板文件中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的模板文件内容。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateUri *string `json:"template_uri,omitempty"` }
func (ParseTemplateVariablesRequestBody) String ¶
func (o ParseTemplateVariablesRequestBody) String() string
type ParseTemplateVariablesResponse ¶
type ParseTemplateVariablesResponse struct { // 解析模板得到的参数列表 Variables *[]VariableResponse `json:"variables,omitempty"` HttpStatusCode int `json:"-"` }
Response Object
func (ParseTemplateVariablesResponse) String ¶
func (o ParseTemplateVariablesResponse) String() string
type ResourceAttribute ¶ added in v0.1.30
type ResourceAttribute struct { // 资源属性的键 Key *string `json:"key,omitempty"` // 资源属性的值 Value *string `json:"value,omitempty"` }
资源属性 以HCL格式的模板为例,资源属性的key 为 name,value 为 \"test_vpc\" ```hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } ``` 以json格式的模板为例,资源属性的key 为 name,value 为 \"test_vpc\" ```json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } ```
func (ResourceAttribute) String ¶ added in v0.1.30
func (o ResourceAttribute) String() string
type ResourceNamePrimitiveTypeHolder ¶ added in v0.1.30
type ResourceNamePrimitiveTypeHolder struct { // 资源的名称,默认为资源的逻辑名称 以HCL格式的模板为例,resource_name 为 my_hello_world_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_name 为 my_hello_world_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceName *string `json:"resource_name,omitempty"` }
func (ResourceNamePrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ResourceNamePrimitiveTypeHolder) String() string
type ResourcePriceResponse ¶
type ResourcePriceResponse struct { // 计费模式 * `PRE_PAID` - 包周期计费 * `POST_PAID` - 按需计费 * `FREE` - 免费 ChargeMode *ResourcePriceResponseChargeMode `json:"charge_mode,omitempty"` // 该资源最终优惠后的金额(只考虑官网折扣、商务折扣以及伙伴折扣,不包含促销折扣及优惠券),保留小数点后2位,向上取整,默认单位是元。 SalePrice *float64 `json:"sale_price,omitempty"` // 该资源的总优惠额,保留小数点后2位,向上取整,默认单位是元。 Discount *float64 `json:"discount,omitempty"` // 该资源的原价,保留小数点后2位,向上取整,默认单位是元。 OriginalPrice *float64 `json:"original_price,omitempty"` // 计费单位 若该资源支持包周期计费或按需计费,则会返回该字段;若该资源为免费资源,则不返回该字段。 * `HOUR` - 小时,按需计费的单位 * `DAY` - 天,按需计费的单位 * `MONTH` - 月,包周期计费的单位 * `YEAR` - 年,包周期计费的单位 * `BYTE` - 字节,按需计费的单位 * `MB` - 百万字节,包周期计费和按需计费的单位 * `GB` - 千兆字节,包周期计费和按需计费的单位 PeriodType *ResourcePriceResponsePeriodType `json:"period_type,omitempty"` // 该资源的计费数量,需要和period_type搭配使用 若该资源支持包周期计费或按需计费,则会返回该字段;若该资源为免费资源,则不返回该字段。 * 对于按需计费资源,此值默认返回1,代表在1个计费单位下,该资源的价格 * 对于包周期计费资源,此值与模板中该资源的period字段保持一致 PeriodCount *int32 `json:"period_count,omitempty"` }
func (ResourcePriceResponse) String ¶
func (o ResourcePriceResponse) String() string
type ResourcePriceResponseChargeMode ¶
type ResourcePriceResponseChargeMode struct {
// contains filtered or unexported fields
}
func (ResourcePriceResponseChargeMode) MarshalJSON ¶
func (c ResourcePriceResponseChargeMode) MarshalJSON() ([]byte, error)
func (*ResourcePriceResponseChargeMode) UnmarshalJSON ¶
func (c *ResourcePriceResponseChargeMode) UnmarshalJSON(b []byte) error
func (ResourcePriceResponseChargeMode) Value ¶
func (c ResourcePriceResponseChargeMode) Value() string
type ResourcePriceResponseChargeModeEnum ¶
type ResourcePriceResponseChargeModeEnum struct { PRE_PAID ResourcePriceResponseChargeMode POST_PAID ResourcePriceResponseChargeMode FREE ResourcePriceResponseChargeMode }
func GetResourcePriceResponseChargeModeEnum ¶
func GetResourcePriceResponseChargeModeEnum() ResourcePriceResponseChargeModeEnum
type ResourcePriceResponsePeriodType ¶
type ResourcePriceResponsePeriodType struct {
// contains filtered or unexported fields
}
func (ResourcePriceResponsePeriodType) MarshalJSON ¶
func (c ResourcePriceResponsePeriodType) MarshalJSON() ([]byte, error)
func (*ResourcePriceResponsePeriodType) UnmarshalJSON ¶
func (c *ResourcePriceResponsePeriodType) UnmarshalJSON(b []byte) error
func (ResourcePriceResponsePeriodType) Value ¶
func (c ResourcePriceResponsePeriodType) Value() string
type ResourcePriceResponsePeriodTypeEnum ¶
type ResourcePriceResponsePeriodTypeEnum struct { HOUR ResourcePriceResponsePeriodType DAY ResourcePriceResponsePeriodType MONTH ResourcePriceResponsePeriodType YEAR ResourcePriceResponsePeriodType BYTE ResourcePriceResponsePeriodType MB ResourcePriceResponsePeriodType GB ResourcePriceResponsePeriodType }
func GetResourcePriceResponsePeriodTypeEnum ¶
func GetResourcePriceResponsePeriodTypeEnum() ResourcePriceResponsePeriodTypeEnum
type ResourceTypePrimitiveTypeHolder ¶ added in v0.1.30
type ResourceTypePrimitiveTypeHolder struct { // 资源的类型 以HCL格式的模板为例,resource_type 为 huaweicloud_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_type 为 huaweicloud_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceType *string `json:"resource_type,omitempty"` }
func (ResourceTypePrimitiveTypeHolder) String ¶ added in v0.1.30
func (o ResourceTypePrimitiveTypeHolder) String() string
type ShowTemplateMetadataRequest ¶ added in v0.1.30
type ShowTemplateMetadataRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板的ID。当template_id存在时,模板服务会检查template_id是否和template_name匹配,不匹配会返回400 TemplateId *string `json:"template_id,omitempty"` }
Request Object
func (ShowTemplateMetadataRequest) String ¶ added in v0.1.30
func (o ShowTemplateMetadataRequest) String() string
type ShowTemplateMetadataResponse ¶ added in v0.1.30
type ShowTemplateMetadataResponse struct { // 模板的唯一ID,由模板服务随机生成 TemplateId string `json:"template_id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板的描述。可用于客户识别自己的模板 TemplateDescription *string `json:"template_description,omitempty"` // 模板的生成时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime string `json:"create_time"` // 模板的更新时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z UpdateTime string `json:"update_time"` HttpStatusCode int `json:"-"` }
Response Object
func (ShowTemplateMetadataResponse) String ¶ added in v0.1.30
func (o ShowTemplateMetadataResponse) String() string
type ShowTemplateVersionContentRequest ¶ added in v0.1.30
type ShowTemplateVersionContentRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板版本ID,以大写V开头,每次创建模板版本,模板版本ID数字部分会自增加一 VersionId string `json:"version_id"` // 模板的ID。当template_id存在时,模板服务会检查template_id是否和template_name匹配,不匹配会返回400 TemplateId *string `json:"template_id,omitempty"` }
Request Object
func (ShowTemplateVersionContentRequest) String ¶ added in v0.1.30
func (o ShowTemplateVersionContentRequest) String() string
type ShowTemplateVersionContentResponse ¶ added in v0.1.30
type ShowTemplateVersionContentResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (ShowTemplateVersionContentResponse) String ¶ added in v0.1.30
func (o ShowTemplateVersionContentResponse) String() string
type ShowTemplateVersionMetadataRequest ¶ added in v0.1.30
type ShowTemplateVersionMetadataRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板版本ID,以大写V开头,每次创建模板版本,模板版本ID数字部分会自增加一 VersionId string `json:"version_id"` // 模板的ID。当template_id存在时,模板服务会检查template_id是否和template_name匹配,不匹配会返回400 TemplateId *string `json:"template_id,omitempty"` }
Request Object
func (ShowTemplateVersionMetadataRequest) String ¶ added in v0.1.30
func (o ShowTemplateVersionMetadataRequest) String() string
type ShowTemplateVersionMetadataResponse ¶ added in v0.1.30
type ShowTemplateVersionMetadataResponse struct { // 模板的唯一ID,由模板服务随机生成 TemplateId string `json:"template_id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板版本的描述。可用于客户识别自己的模板版本 VersionDescription *string `json:"version_description,omitempty"` // 版本创建时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime string `json:"create_time"` HttpStatusCode int `json:"-"` }
Response Object
func (ShowTemplateVersionMetadataResponse) String ¶ added in v0.1.30
func (o ShowTemplateVersionMetadataResponse) String() string
type Stack ¶
type Stack struct { // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` // 资源栈的描述。可用于客户识别自己的资源栈。 Description *string `json:"description,omitempty"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 资源栈的状态 * `CREATION_COMPLETE` - 生成空资源栈完成,并没有任何部署 * `DEPLOYMENT_IN_PROGRESS` - 正在部署,请等待 * `DEPLOYMENT_FAILED` - 部署失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 * `DEPLOYMENT_COMPLETE` - 部署完成 * `ROLLBACK_IN_PROGRESS` - 部署失败,正在回滚,请等待 * `ROLLBACK_FAILED` - 回滚失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 * `ROLLBACK_COMPLETE` - 回滚完成 * `DELETION_IN_PROGRESS` - 正在删除,请等待 * `DELETION_FAILED` - 删除失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 Status *StackStatus `json:"status,omitempty"` // 资源栈的生成时间,格式遵循RFC3339,精确到秒,UTC时区,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime *string `json:"create_time,omitempty"` // 资源栈的更新时间,格式遵循RFC3339,精确到秒,UTC时区,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z UpdateTime *string `json:"update_time,omitempty"` // 在失败的时候(资源栈状态以FAILED结尾)会显示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` }
type StackDescriptionPrimitiveTypeHolder ¶
type StackDescriptionPrimitiveTypeHolder struct { // 资源栈的描述。可用于客户识别自己的资源栈。 Description *string `json:"description,omitempty"` }
func (StackDescriptionPrimitiveTypeHolder) String ¶
func (o StackDescriptionPrimitiveTypeHolder) String() string
type StackEvent ¶ added in v0.1.24
type StackEvent struct { // 资源的类型 以HCL格式的模板为例,resource_type 为 huaweicloud_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_type 为 huaweicloud_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceType *string `json:"resource_type,omitempty"` // 资源的名称,默认为资源的逻辑名称 以HCL格式的模板为例,resource_name 为 my_hello_world_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,resource_name 为 my_hello_world_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` ResourceName *string `json:"resource_name,omitempty"` // 资源id的名称,即对应资源作为id使用的值的名称,当资源未创建的时候,不返回resource_id_key 此id由provider定义,因此不同的provider可能遵循了不同的命名规则,具体的命名规则请与provider开发者确认或阅读provider文档 ResourceIdKey *string `json:"resource_id_key,omitempty"` // 资源id的值,即对应资源作为id使用的值,当资源未创建的时候,不返回resource_id_value ResourceIdValue *string `json:"resource_id_value,omitempty"` // 资源键,若用户在模板中使用了count或for_each则会返回resource_key 若用户在模板中使用count,则resource_key为从0开始的数字 以HCL格式的模板为例,模板中count为2,意味着将会生成两个资源,对应的resource_key分别为0和1 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { count = 2 name = \"test_vpc\" } “` 以json格式的模板为例,模板中count为2,意味着将会生成两个资源,对应的resource_key分别为0和1 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\", \"count\": 2 } } } } “` 若用户在模板中使用for_each,则resource_key为用户自定义的字符串 以HCL格式的模板为例,resource_key分别为vpc1和vpc2 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { for_each = { \"vpc1\" = \"test_vpc\" \"vpc2\" = \"test_vpc\" } name = each.value } “` 以json格式的模板为例,resource_key分别为vpc1和vpc2 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"for_each\": { \"vpc1\": \"test_vpc\", \"vpc2\": \"test_vpc\" } \"name\": \"${each.value}\" } } } } “` ResourceKey *string `json:"resource_key,omitempty"` // 事件发生的时间 格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z Time *string `json:"time,omitempty"` // 此次事件的类型 * `LOG` - 记录状态信息,比如当前状态,目标状态等。 * `ERROR` - 记录失败信息 * `DRIFT` - 记录资源偏移信息 * `SUMMARY` - 记录资源变更结果总结 * `CREATION_IN_PROGRESS` - 正在生成 * `CREATION_FAILED` - 生成失败 * `CREATION_COMPLETE` - 生成完成 * `DELETION_IN_PROGRESS` - 正在删除 * `DELETION_FAILED` - 删除失败 * `DELETION_COMPLETE` - 已经删除 * `UPDATE_IN_PROGRESS` - 正在更新。此处的更新特指非替换式更新,如果是替换式更新,则是DELETION后CREATION,或者CREATION后DELETION,具体以何种行为进行替换式更新由Provider定义。 * `UPDATE_FAILED` - 更新失败。此处的更新特指非替换式更新,如果是替换式更新,则是DELETION后CREATION,或者CREATION后DELETION,具体以何种行为进行替换式更新由Provider定义。 * `UPDATE_COMPLETE` - 更新完成。此处的更新特指非替换式更新,如果是替换式更新,则是DELETION后CREATION,或者CREATION后DELETION,具体以何种行为进行替换式更新由Provider定义。 EventType *StackEventEventType `json:"event_type,omitempty"` // 该资源栈事件对应的详细信息 EventMessage *string `json:"event_message,omitempty"` // 此事件执行所花的时间,以秒为单位 ElapsedSeconds *int32 `json:"elapsed_seconds,omitempty"` }
func (StackEvent) String ¶ added in v0.1.24
func (o StackEvent) String() string
type StackEventEventType ¶ added in v0.1.24
type StackEventEventType struct {
// contains filtered or unexported fields
}
func (StackEventEventType) MarshalJSON ¶ added in v0.1.24
func (c StackEventEventType) MarshalJSON() ([]byte, error)
func (*StackEventEventType) UnmarshalJSON ¶ added in v0.1.24
func (c *StackEventEventType) UnmarshalJSON(b []byte) error
func (StackEventEventType) Value ¶ added in v0.1.24
func (c StackEventEventType) Value() string
type StackEventEventTypeEnum ¶ added in v0.1.24
type StackEventEventTypeEnum struct { LOG StackEventEventType ERROR StackEventEventType DRIFT StackEventEventType SUMMARY StackEventEventType CREATION_IN_PROGRESS StackEventEventType CREATION_FAILED StackEventEventType CREATION_COMPLETE StackEventEventType DELETION_IN_PROGRESS StackEventEventType DELETION_FAILED StackEventEventType DELETION_COMPLETE StackEventEventType UPDATE_IN_PROGRESS StackEventEventType UPDATE_FAILED StackEventEventType UPDATE_COMPLETE StackEventEventType }
func GetStackEventEventTypeEnum ¶ added in v0.1.24
func GetStackEventEventTypeEnum() StackEventEventTypeEnum
type StackIdPrimitiveTypeHolder ¶
type StackIdPrimitiveTypeHolder struct { // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` }
func (StackIdPrimitiveTypeHolder) String ¶
func (o StackIdPrimitiveTypeHolder) String() string
type StackNamePrimitiveTypeHolder ¶
type StackNamePrimitiveTypeHolder struct { // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` }
func (StackNamePrimitiveTypeHolder) String ¶
func (o StackNamePrimitiveTypeHolder) String() string
type StackOutput ¶
type StackOutput struct { // 资源栈输出的名称,由用户在模板中定义 以 HCL 模板为例,name 为 vpc_id “`hcl output \"vpc_id\" { value = huaweicloud_vpc.my_hello_world_vpc.id } “` 以 json 模板为例,name 为 vpc_id “`json { \"output\": { \"vpc_id\": [ { \"value\": \"${huaweicloud_vpc.my_hello_world_vpc.id}\" } ] } } “` Name *string `json:"name,omitempty"` // 资源栈输出的描述,由用户在模板中定义 Description *string `json:"description,omitempty"` // 资源栈输出的类型 Type *string `json:"type,omitempty"` // 资源栈输出的值 Value *string `json:"value,omitempty"` // 标识该资源栈输出是否为敏感信息,由用户在模板中定义 若用户在模板中将该输出定义为sensitive,则返回体中该输出的value和type不会返回真实值,而是返回`<sensitive>` Sensitive *bool `json:"sensitive,omitempty"` }
资源栈输出
func (StackOutput) String ¶
func (o StackOutput) String() string
type StackResource ¶ added in v0.1.12
type StackResource struct { // 资源的物理id,由该资源的provider、云服务或其他服务提供方在资源部署的时候生成 注:与physical相关的参数可以在模板以外的地方,作为该资源的一种标识 PhysicalResourceId *string `json:"physical_resource_id,omitempty"` // 资源的物理名称,由该资源的provider、云服务或其他服务提供方在资源部署的时候定义 注:与physical相关的参数可以在模板以外的地方,作为该资源的一种标识 PhysicalResourceName *string `json:"physical_resource_name,omitempty"` // 资源的逻辑名称,由用户在模板中定义 注:与 logical 相关的参数仅仅在模板内部,作为该资源的一种标识 以HCL格式的模板为例,logical_resource_name 为 my_hello_world_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,logical_resource_name 为 my_hello_world_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` LogicalResourceName *string `json:"logical_resource_name,omitempty"` // 资源的类型 注:与 logical 相关的参数仅仅在模板内部,作为该资源的一种标识 以HCL格式的模板为例,logical_resource_type 为 huaweicloud_vpc “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { name = \"test_vpc\" } “` 以json格式的模板为例,logical_resource_type 为 huaweicloud_vpc “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\" } } } } “` LogicalResourceType *string `json:"logical_resource_type,omitempty"` // 资源的索引,若用户在模板中使用了count或for_each则会返回index_key。若index_key出现,则logical_resource_name + index_key可以作为该资源的一种标识 若用户在模板中使用count,则index_key为从0开始的数字 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { count = 2 name = \"test_vpc\" } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[0]`和`huaweicloud_vpc.my_hello_world_vpc[1]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"name\": \"test_vpc\", \"count\": 2 } } } } “` 若用户在模板中使用for_each,则index_key为用户自定义的字符串 以HCL格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`hcl resource \"huaweicloud_vpc\" \"my_hello_world_vpc\" { for_each = { \"vpc1\" = \"test_vpc\" \"vpc2\" = \"test_vpc\" } name = each.value } “` 以json格式的模板为例,用户在模板中可以通过`huaweicloud_vpc.my_hello_world_vpc[\"vpc1\"]`和`huaweicloud_vpc.my_hello_world_vpc[\"vpc2\"]`标识两个资源 “`json { \"resource\": { \"huaweicloud_vpc\": { \"my_hello_world_vpc\": { \"for_each\": { \"vpc1\": \"test_vpc\", \"vpc2\": \"test_vpc\" } \"name\": \"${each.value}\" } } } } “` IndexKey *string `json:"index_key,omitempty"` // 资源的状态 * `CREATION_IN_PROGRESS` - 正在生成 * `CREATION_FAILED` - 生成失败 * `CREATION_COMPLETE` - 生成完成 * `DELETION_IN_PROGRESS` - 正在删除 * `DELETION_FAILED` - 删除失败 * `DELETION_COMPLETE` - 已经删除 * `UPDATE_IN_PROGRESS` - 正在更新。此处的更新特指非替换式更新,如果是替换式更新,则使用CREATION后DELETION * `UPDATE_FAILED` - 更新失败。此处的更新特指非替换式更新,如果是替换式更新,则使用CREATION后DELETION * `UPDATE_COMPLETE` - 更新完成。此处的更新特指非替换式更新,如果是替换式更新,则使用CREATION后DELETION ResourceStatus *StackResourceResourceStatus `json:"resource_status,omitempty"` // 当该资源状态为任意失败状态(即以 `FAILED` 结尾时),将会展示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` // 资源属性列表 ResourceAttributes *[]ResourceAttribute `json:"resource_attributes,omitempty"` }
资源栈中所管理的资源信息
func (StackResource) String ¶ added in v0.1.12
func (o StackResource) String() string
type StackResourceResourceStatus ¶ added in v0.1.12
type StackResourceResourceStatus struct {
// contains filtered or unexported fields
}
func (StackResourceResourceStatus) MarshalJSON ¶ added in v0.1.12
func (c StackResourceResourceStatus) MarshalJSON() ([]byte, error)
func (*StackResourceResourceStatus) UnmarshalJSON ¶ added in v0.1.12
func (c *StackResourceResourceStatus) UnmarshalJSON(b []byte) error
func (StackResourceResourceStatus) Value ¶ added in v0.1.12
func (c StackResourceResourceStatus) Value() string
type StackResourceResourceStatusEnum ¶ added in v0.1.12
type StackResourceResourceStatusEnum struct { CREATION_IN_PROGRESS StackResourceResourceStatus CREATION_FAILED StackResourceResourceStatus CREATION_COMPLETE StackResourceResourceStatus DELETION_IN_PROGRESS StackResourceResourceStatus DELETION_FAILED StackResourceResourceStatus DELETION_COMPLETE StackResourceResourceStatus UPDATE_IN_PROGRESS StackResourceResourceStatus UPDATE_FAILED StackResourceResourceStatus UPDATE_COMPLETE StackResourceResourceStatus }
func GetStackResourceResourceStatusEnum ¶ added in v0.1.12
func GetStackResourceResourceStatusEnum() StackResourceResourceStatusEnum
type StackStatus ¶
type StackStatus struct {
// contains filtered or unexported fields
}
func (StackStatus) MarshalJSON ¶
func (c StackStatus) MarshalJSON() ([]byte, error)
func (*StackStatus) UnmarshalJSON ¶
func (c *StackStatus) UnmarshalJSON(b []byte) error
func (StackStatus) Value ¶
func (c StackStatus) Value() string
type StackStatusEnum ¶
type StackStatusEnum struct { CREATION_COMPLETE StackStatus DEPLOYMENT_IN_PROGRESS StackStatus DEPLOYMENT_FAILED StackStatus DEPLOYMENT_COMPLETE StackStatus ROLLBACK_IN_PROGRESS StackStatus ROLLBACK_FAILED StackStatus ROLLBACK_COMPLETE StackStatus DELETION_IN_PROGRESS StackStatus DELETION_FAILED StackStatus }
func GetStackStatusEnum ¶
func GetStackStatusEnum() StackStatusEnum
type StackStatusMessagePrimitiveTypeHolder ¶ added in v0.1.24
type StackStatusMessagePrimitiveTypeHolder struct { // 当资源栈的状态为任意失败状态(即以 `FAILED` 结尾时),将会展示简要的错误信息总结以供debug StatusMessage *string `json:"status_message,omitempty"` }
func (StackStatusMessagePrimitiveTypeHolder) String ¶ added in v0.1.24
func (o StackStatusMessagePrimitiveTypeHolder) String() string
type StackStatusPrimitiveTypeHolder ¶
type StackStatusPrimitiveTypeHolder struct { // 资源栈的状态 * `CREATION_COMPLETE` - 生成空资源栈完成,并没有任何部署 * `DEPLOYMENT_IN_PROGRESS` - 正在部署,请等待 * `DEPLOYMENT_FAILED` - 部署失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 * `DEPLOYMENT_COMPLETE` - 部署完成 * `ROLLBACK_IN_PROGRESS` - 部署失败,正在回滚,请等待 * `ROLLBACK_FAILED` - 回滚失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 * `ROLLBACK_COMPLETE` - 回滚完成 * `DELETION_IN_PROGRESS` - 正在删除,请等待 * `DELETION_FAILED` - 删除失败。请从status_message获取错误信息汇总,或者调用ListStackEvents获得事件详情 Status *StackStatusPrimitiveTypeHolderStatus `json:"status,omitempty"` }
func (StackStatusPrimitiveTypeHolder) String ¶
func (o StackStatusPrimitiveTypeHolder) String() string
type StackStatusPrimitiveTypeHolderStatus ¶
type StackStatusPrimitiveTypeHolderStatus struct {
// contains filtered or unexported fields
}
func (StackStatusPrimitiveTypeHolderStatus) MarshalJSON ¶
func (c StackStatusPrimitiveTypeHolderStatus) MarshalJSON() ([]byte, error)
func (*StackStatusPrimitiveTypeHolderStatus) UnmarshalJSON ¶
func (c *StackStatusPrimitiveTypeHolderStatus) UnmarshalJSON(b []byte) error
func (StackStatusPrimitiveTypeHolderStatus) Value ¶
func (c StackStatusPrimitiveTypeHolderStatus) Value() string
type StackStatusPrimitiveTypeHolderStatusEnum ¶
type StackStatusPrimitiveTypeHolderStatusEnum struct { CREATION_COMPLETE StackStatusPrimitiveTypeHolderStatus DEPLOYMENT_IN_PROGRESS StackStatusPrimitiveTypeHolderStatus DEPLOYMENT_FAILED StackStatusPrimitiveTypeHolderStatus DEPLOYMENT_COMPLETE StackStatusPrimitiveTypeHolderStatus ROLLBACK_IN_PROGRESS StackStatusPrimitiveTypeHolderStatus ROLLBACK_FAILED StackStatusPrimitiveTypeHolderStatus ROLLBACK_COMPLETE StackStatusPrimitiveTypeHolderStatus DELETION_IN_PROGRESS StackStatusPrimitiveTypeHolderStatus DELETION_FAILED StackStatusPrimitiveTypeHolderStatus }
func GetStackStatusPrimitiveTypeHolderStatusEnum ¶
func GetStackStatusPrimitiveTypeHolderStatusEnum() StackStatusPrimitiveTypeHolderStatusEnum
type Template ¶ added in v0.1.30
type Template struct { // 模板的唯一ID,由模板服务随机生成 TemplateId string `json:"template_id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` // 模板的描述。可用于客户识别自己的模板 TemplateDescription *string `json:"template_description,omitempty"` // 模板的生成时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z CreateTime string `json:"create_time"` // 模板的更新时间,格式遵循RFC3339,即yyyy-mm-ddTHH:MM:SSZ,如1970-01-01T00:00:00Z UpdateTime string `json:"update_time"` // 模板中最新的模板版本ID LatestVersionId string `json:"latest_version_id"` // -> 模板中最新模板版本的版本描述 LatestVersionDescription string `json:"latest_version_description"` }
type TemplateBodyPrimitiveTypeHolder ¶
type TemplateBodyPrimitiveTypeHolder struct { // HCL模板,描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_body中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的template_body。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateBody *string `json:"template_body,omitempty"` }
func (TemplateBodyPrimitiveTypeHolder) String ¶
func (o TemplateBodyPrimitiveTypeHolder) String() string
type TemplateUriPrimitiveTypeHolder ¶
type TemplateUriPrimitiveTypeHolder struct { // HCL模板的OBS地址,该模板描述了资源的目标状态。资源编排服务将比较此模板与当前远程资源的状态之间的区别。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) 对应的文件应该是纯tf文件或zip压缩包 纯tf文件需要以`.tf`或者`.tf.json`结尾,并遵守HCL语法 压缩包目前只支持zip格式,文件需要以`.zip`结尾。解压后的文件不得包含\".tfvars\"文件 template_body和template_uri 必须有且只有一个存在 *在CreateStack API中,template_body和template_uri可以都不给予* **注意:** * template_uri对应的模板文件中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的模板文件内容。如为敏感信息,建议将敏感信息通过vars_structure参数化,并设置encryption字段开启加密 TemplateUri *string `json:"template_uri,omitempty"` }
func (TemplateUriPrimitiveTypeHolder) String ¶
func (o TemplateUriPrimitiveTypeHolder) String() string
type UpdateStackRequest ¶ added in v0.1.24
type UpdateStackRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 资源栈的名称。此名字在domain_id+区域+project_id下应唯一,可以使用中文、大小写英文、数字、下划线、中划线。首字符需为中文或者英文,区分大小写。 StackName string `json:"stack_name"` Body *UpdateStackRequestBody `json:"body,omitempty"` }
Request Object
func (UpdateStackRequest) String ¶ added in v0.1.24
func (o UpdateStackRequest) String() string
type UpdateStackRequestBody ¶ added in v0.1.24
type UpdateStackRequestBody struct { // 资源栈的描述。可用于客户识别自己的资源栈。 Description *string `json:"description,omitempty"` // 资源栈(stack)的唯一Id。 此Id由资源编排服务在生成资源栈的时候生成,为UUID。 由于资源栈名仅仅在同一时间下唯一,即用户允许先生成一个叫HelloWorld的资源栈,删除,再重新创建一个同名资源栈。 对于团队并行开发,用户可能希望确保,当前我操作的资源栈就是我认为的那个,而不是其他队友删除后创建的同名资源栈。因此,使用ID就可以做到强匹配。 资源编排服务保证每次创建的资源栈所对应的ID都不相同,更新不会影响ID。如果给与的stack_id和当前资源栈的ID不一致,则返回400 StackId *string `json:"stack_id,omitempty"` // 删除保护的标识位,如果不传默认为false,即默认不开启资源栈删除保护(删除保护开启后资源栈不允许被删除) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的删除保护属性进行更新* EnableDeletionProtection *bool `json:"enable_deletion_protection,omitempty"` // 自动回滚的标识位,如果不传默认为false,即默认不开启资源栈自动回滚(自动回滚开启后,如果部署失败,则会自动回滚,并返回上一个稳定状态) *在UpdateStack API中,若该参数未在RequestBody中给予,则不会对资源栈的自动回滚属性进行更新* EnableAutoRollback *bool `json:"enable_auto_rollback,omitempty"` // 委托授权的信息。 Agencies *[]Agency `json:"agencies,omitempty"` }
func (UpdateStackRequestBody) String ¶ added in v0.1.24
func (o UpdateStackRequestBody) String() string
type UpdateStackResponse ¶ added in v0.1.24
type UpdateStackResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (UpdateStackResponse) String ¶ added in v0.1.24
func (o UpdateStackResponse) String() string
type UpdateTemplateMetadataRequest ¶ added in v0.1.30
type UpdateTemplateMetadataRequest struct { // 用户指定的,对于此请求的唯一ID,用于定位某个请求,推荐使用UUID ClientRequestId string `json:"Client-Request-Id"` // 用户希望创建的模板名称 TemplateName string `json:"template_name"` Body *UpdateTemplateMetadataRequestBody `json:"body,omitempty"` }
Request Object
func (UpdateTemplateMetadataRequest) String ¶ added in v0.1.30
func (o UpdateTemplateMetadataRequest) String() string
type UpdateTemplateMetadataRequestBody ¶ added in v0.1.30
type UpdateTemplateMetadataRequestBody struct { // 模板的唯一ID,由模板服务随机生成 TemplateId *string `json:"template_id,omitempty"` // 模板的描述。可用于客户识别自己的模板 TemplateDescription *string `json:"template_description,omitempty"` }
更新模板元数据请求体
func (UpdateTemplateMetadataRequestBody) String ¶ added in v0.1.30
func (o UpdateTemplateMetadataRequestBody) String() string
type UpdateTemplateMetadataResponse ¶ added in v0.1.30
type UpdateTemplateMetadataResponse struct {
HttpStatusCode int `json:"-"`
}
Response Object
func (UpdateTemplateMetadataResponse) String ¶ added in v0.1.30
func (o UpdateTemplateMetadataResponse) String() string
type VariableResponse ¶
type VariableResponse struct { // 参数的名字 以HCL格式的模板为例,name 为 `my_hello_world_variable` “`hcl variable \"my_hello_world_variable\" { type = string description = \"this is a variable\" default = \"hello world\" sensitive = false nullable = false validation { condition = length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \"hello\" error_message = \"my_hello_world_variable should start with 'hello'.\" } } “` 以json格式的模板为例,name 为 `my_hello_world_variable` “`json { \"variable\": { \"my_hello_world_variable\": [ { \"default\": \"hello world\", \"description\": \"this is a variable\", \"nullable\": false, \"sensitive\": false, \"type\": \"string\", \"validation\": [ { \"condition\": \"${length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \\\"hello\\\"}\", \"error_message\": \"my_hello_world_variable should start with 'hello'.\" } ] } ] } } “` Name *string `json:"name,omitempty"` // 参数的类型 以HCL格式的模板为例,type 为 `string` “`hcl variable \"my_hello_world_variable\" { type = string description = \"this is a variable\" default = \"hello world\" sensitive = false nullable = false validation { condition = length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \"hello\" error_message = \"my_hello_world_variable should start with 'hello'.\" } } “` 以json格式的模板为例,type 为 `string` “`json { \"variable\": { \"my_hello_world_variable\": [ { \"default\": \"hello world\", \"description\": \"this is a variable\", \"nullable\": false, \"sensitive\": false, \"type\": \"string\", \"validation\": [ { \"condition\": \"${length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \\\"hello\\\"}\", \"error_message\": \"my_hello_world_variable should start with 'hello'.\" } ] } ] } } “` Type *string `json:"type,omitempty"` // 参数的描述 以HCL格式的模板为例,description 为 `this is a variable` “`hcl variable \"my_hello_world_variable\" { type = string description = \"this is a variable\" default = \"hello world\" sensitive = false nullable = false validation { condition = length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \"hello\" error_message = \"my_hello_world_variable should start with 'hello'.\" } } “` 以json格式的模板为例,description 为 `this is a variable` “`json { \"variable\": { \"my_hello_world_variable\": [ { \"default\": \"hello world\", \"description\": \"this is a variable\", \"nullable\": false, \"sensitive\": false, \"type\": \"string\", \"validation\": [ { \"condition\": \"${length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \\\"hello\\\"}\", \"error_message\": \"my_hello_world_variable should start with 'hello'.\" } ] } ] } } “` Description *string `json:"description,omitempty"` // 参数默认值。此返回值的类型将与type保持一致 例如,对于type为string的变量,此值的返回类型为string;对于type为number的变量,此值的返回类型为number 以HCL格式的模板为例,default 为 `hello world` “`hcl variable \"my_hello_world_variable\" { type = string description = \"this is a variable\" default = \"hello world\" sensitive = false nullable = false validation { condition = length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \"hello\" error_message = \"my_hello_world_variable should start with 'hello'.\" } } “` 以json格式的模板为例,default 为 `hello world` “`json { \"variable\": { \"my_hello_world_variable\": [ { \"default\": \"hello world\", \"description\": \"this is a variable\", \"nullable\": false, \"sensitive\": false, \"type\": \"string\", \"validation\": [ { \"condition\": \"${length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \\\"hello\\\"}\", \"error_message\": \"my_hello_world_variable should start with 'hello'.\" } ] } ] } } “` Default *interface{} `json:"default,omitempty"` // 参数是否为敏感字段 若variable中没有定义sensitive,默认返回false。 以HCL格式的模板为例,sensitive 为 `false` “`hcl variable \"my_hello_world_variable\" { type = string description = \"this is a variable\" default = \"hello world\" sensitive = false nullable = false validation { condition = length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \"hello\" error_message = \"my_hello_world_variable should start with 'hello'.\" } } “` 以json格式的模板为例,sensitive 为 `false` “`json { \"variable\": { \"my_hello_world_variable\": [ { \"default\": \"hello world\", \"description\": \"this is a variable\", \"nullable\": false, \"sensitive\": false, \"type\": \"string\", \"validation\": [ { \"condition\": \"${length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \\\"hello\\\"}\", \"error_message\": \"my_hello_world_variable should start with 'hello'.\" } ] } ] } } “` Sensitive *bool `json:"sensitive,omitempty"` // 参数是否可设置为null。 若variable中没有定义nullable,默认返回true。 以HCL格式的模板为例,nullable 为 `false` “`hcl variable \"my_hello_world_variable\" { type = string description = \"this is a variable\" default = \"hello world\" sensitive = false nullable = false validation { condition = length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \"hello\" error_message = \"my_hello_world_variable should start with 'hello'.\" } } “` 以json格式的模板为例,nullable 为 `false` “`json { \"variable\": { \"my_hello_world_variable\": [ { \"default\": \"hello world\", \"description\": \"this is a variable\", \"nullable\": false, \"sensitive\": false, \"type\": \"string\", \"validation\": [ { \"condition\": \"${length(var.my_hello_world_variable) > 0 && substr(var.my_hello_world_variable, 0, 5) == \\\"hello\\\"}\", \"error_message\": \"my_hello_world_variable should start with 'hello'.\" } ] } ] } } “` Nullable *bool `json:"nullable,omitempty"` // 参数的校验模块 Validations *[]VariableValidationResponse `json:"validations,omitempty"` }
func (VariableResponse) String ¶
func (o VariableResponse) String() string
type VariableValidationResponse ¶
type VariableValidationResponse struct { // 校验表达式 Condition *string `json:"condition,omitempty"` // 校验失败后的错误信息 ErrorMessage *string `json:"error_message,omitempty"` }
func (VariableValidationResponse) String ¶
func (o VariableValidationResponse) String() string
type VarsBodyPrimitiveTypeHolder ¶
type VarsBodyPrimitiveTypeHolder struct { // HCL参数文件的内容。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * vars_body使用HCL的tfvars格式,用户可以将“.tfvars”中的内容提交到vars_body中。 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * 如果vars_body过大,可以使用vars_uri * 如果vars中都是简单的字符串格式,可以使用var_structure * 注意:vars_body中不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsBody *string `json:"vars_body,omitempty"` }
func (VarsBodyPrimitiveTypeHolder) String ¶
func (o VarsBodyPrimitiveTypeHolder) String() string
type VarsStructure ¶
type VarsStructure struct { // 参数的名字 VarKey string `json:"var_key"` // 参数的值。 注意,参数需要以字符串形式存在,如果是数字,也需要以字符串形式存在,如'10'。 如果需要支持不同类型,或者复杂结构,请使用vars_uri或vars_body VarValue string `json:"var_value"` Encryption *EncryptionStructure `json:"encryption,omitempty"` }
HCL支持参数,即,同一个模板可以给予不同的参数而达到不同的效果。 var_structure可以允许客户提交最简单的字符串类型的参数 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 如果vars_structure过大,可以使用vars_uri 注意:vars中不应该传递任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars
func (VarsStructure) String ¶
func (o VarsStructure) String() string
type VarsStructurePrimitiveTypeHolder ¶
type VarsStructurePrimitiveTypeHolder struct { // HCL参数结构。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 * var_structure可以允许客户提交最简单的字符串类型的参数 * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_structure中的值只支持简单的字符串类型,如果需要使用其他类型,需要用户自己在HCL引用时转换, 或者用户可以使用vars_uri、vars_body,vars_uri和vars_body中支持HCL支持的各种类型以及复杂结构 * 如果vars_structure过大,可以使用vars_uri * 注意:vars_structure中默认不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议设置encryption字段开启加密 VarsStructure *[]VarsStructure `json:"vars_structure,omitempty"` }
func (VarsStructurePrimitiveTypeHolder) String ¶
func (o VarsStructurePrimitiveTypeHolder) String() string
type VarsUriContentPrimitiveTypeHolder ¶ added in v0.1.30
type VarsUriContentPrimitiveTypeHolder struct { // vars_uri对应的文件内容 VarsUriContent *string `json:"vars_uri_content,omitempty"` }
func (VarsUriContentPrimitiveTypeHolder) String ¶ added in v0.1.30
func (o VarsUriContentPrimitiveTypeHolder) String() string
type VarsUriPrimitiveTypeHolder ¶
type VarsUriPrimitiveTypeHolder struct { // HCL参数文件的OBS地址。HCL模板支持参数传入,即,同一个模板可以给予不同的参数而达到不同的效果。 OBS地址支持同类型Region之间进行互相访问(Region分为通用Region和专属Region,通用Region指面向公共租户提供通用云服务的Region;专属Region指只承载同一类业务或只面向特定租户提供业务服务的专用Region) * 资源编排服务支持vars_structure,vars_body和vars_uri,如果他们中声名了同一个变量,将报错400 * vars_uri中的内容使用HCL的tfvars格式,用户可以将“.tfvars”中的内容保存到文件并上传到OBS中,并将OBS pre-signed URL传递给vars_uri。 * 注意:vars_uri的内容不应该含有任何敏感信息,资源编排服务会直接明文使用、log、展示、存储对应的vars。如为敏感信息,建议通过vars_structure并设置encryption字段传递 VarsUri *string `json:"vars_uri,omitempty"` }
func (VarsUriPrimitiveTypeHolder) String ¶
func (o VarsUriPrimitiveTypeHolder) String() string
Source Files ¶
- model_agencies_primitive_type_holder.go
- model_agency.go
- model_apply_execution_plan_request.go
- model_apply_execution_plan_request_body.go
- model_apply_execution_plan_response.go
- model_base_template.go
- model_base_template_version.go
- model_continue_rollback_stack_request.go
- model_continue_rollback_stack_request_body.go
- model_continue_rollback_stack_response.go
- model_create_execution_plan_request.go
- model_create_execution_plan_request_body.go
- model_create_execution_plan_response.go
- model_create_stack_request.go
- model_create_stack_request_body.go
- model_create_stack_response.go
- model_delete_execution_plan_request.go
- model_delete_execution_plan_response.go
- model_delete_stack_request.go
- model_delete_stack_response.go
- model_delete_template_request.go
- model_delete_template_response.go
- model_delete_template_version_request.go
- model_delete_template_version_response.go
- model_deploy_stack_request.go
- model_deploy_stack_request_body.go
- model_deploy_stack_response.go
- model_deployment_id_primitive_type_holder.go
- model_enable_auto_rollback_primitive_type_holder.go
- model_enable_deletion_protection_primitive_type_holder.go
- model_encryption_structure.go
- model_estimate_execution_plan_price_request.go
- model_estimate_execution_plan_price_response.go
- model_execution_plan.go
- model_execution_plan_description_primitive_type_holder.go
- model_execution_plan_diff_attribute.go
- model_execution_plan_id_primitive_type_holder.go
- model_execution_plan_item.go
- model_execution_plan_name_primitive_type_holder.go
- model_execution_plan_status_message_primitive_type_holder.go
- model_execution_plan_status_primitive_type_holder.go
- model_execution_plan_summary.go
- model_executor_primitive_type_holder.go
- model_get_execution_plan_metadata_request.go
- model_get_execution_plan_metadata_response.go
- model_get_execution_plan_request.go
- model_get_execution_plan_response.go
- model_get_stack_metadata_request.go
- model_get_stack_metadata_response.go
- model_get_stack_template_request.go
- model_get_stack_template_response.go
- model_index_primitive_type_holder.go
- model_items_response.go
- model_kms_structure.go
- model_list_execution_plans_request.go
- model_list_execution_plans_response.go
- model_list_stack_events_request.go
- model_list_stack_events_response.go
- model_list_stack_outputs_request.go
- model_list_stack_outputs_response.go
- model_list_stack_resources_request.go
- model_list_stack_resources_response.go
- model_list_stacks_request.go
- model_list_stacks_response.go
- model_list_templates_request.go
- model_list_templates_response.go
- model_parse_template_variables_request.go
- model_parse_template_variables_request_body.go
- model_parse_template_variables_response.go
- model_resource_attribute.go
- model_resource_name_primitive_type_holder.go
- model_resource_price_response.go
- model_resource_type_primitive_type_holder.go
- model_show_template_metadata_request.go
- model_show_template_metadata_response.go
- model_show_template_version_content_request.go
- model_show_template_version_content_response.go
- model_show_template_version_metadata_request.go
- model_show_template_version_metadata_response.go
- model_stack.go
- model_stack_description_primitive_type_holder.go
- model_stack_event.go
- model_stack_id_primitive_type_holder.go
- model_stack_name_primitive_type_holder.go
- model_stack_output.go
- model_stack_resource.go
- model_stack_status_message_primitive_type_holder.go
- model_stack_status_primitive_type_holder.go
- model_template.go
- model_template_body_primitive_type_holder.go
- model_template_uri_primitive_type_holder.go
- model_update_stack_request.go
- model_update_stack_request_body.go
- model_update_stack_response.go
- model_update_template_metadata_request.go
- model_update_template_metadata_request_body.go
- model_update_template_metadata_response.go
- model_variable_response.go
- model_variable_validation_response.go
- model_vars_body_primitive_type_holder.go
- model_vars_structure.go
- model_vars_structure_primitive_type_holder.go
- model_vars_uri_content_primitive_type_holder.go
- model_vars_uri_primitive_type_holder.go