# frozen_string_literal: true
# Copyright (c) 2017-2018 THL A29 Limited, a Tencent company. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
module TencentCloud
module Hai
module V20230812
# 应用信息
class ApplicationInfo < TencentCloud::Common::AbstractModel
# @param ApplicationId: 应用id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationId: String
# @param ApplicationName: 应用名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationName: String
# @param Description: 应用描述
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Description: String
# @param ConfigEnvironment: 应用的环境配置
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConfigEnvironment: String
# @param MinSystemDiskSize: 系统盘大小下限
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MinSystemDiskSize: Integer
# @param ApplicationType: 应用类型,目前该项取值可以为PRIVATE_APPLICATION或者PUBLIC_APPLICATION
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationType: String
# @param ApplicationState: 应用状态:CREATING-创建中;ONLINE -正常在线;DELETING -删除中;ARREARS - 欠费隔离
# 示例值:ONLINE
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationState: String
# @param CreateTime: 应用创建时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CreateTime: String
# @param ApplicationSize: 应用大小
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationSize: Integer
attr_accessor :ApplicationId, :ApplicationName, :Description, :ConfigEnvironment, :MinSystemDiskSize, :ApplicationType, :ApplicationState, :CreateTime, :ApplicationSize
def initialize(applicationid=nil, applicationname=nil, description=nil, configenvironment=nil, minsystemdisksize=nil, applicationtype=nil, applicationstate=nil, createtime=nil, applicationsize=nil)
@ApplicationId = applicationid
@ApplicationName = applicationname
@Description = description
@ConfigEnvironment = configenvironment
@MinSystemDiskSize = minsystemdisksize
@ApplicationType = applicationtype
@ApplicationState = applicationstate
@CreateTime = createtime
@ApplicationSize = applicationsize
end
def deserialize(params)
@ApplicationId = params['ApplicationId']
@ApplicationName = params['ApplicationName']
@Description = params['Description']
@ConfigEnvironment = params['ConfigEnvironment']
@MinSystemDiskSize = params['MinSystemDiskSize']
@ApplicationType = params['ApplicationType']
@ApplicationState = params['ApplicationState']
@CreateTime = params['CreateTime']
@ApplicationSize = params['ApplicationSize']
end
end
# CreateMuskPrompt请求参数结构体
class CreateMuskPromptRequest < TencentCloud::Common::AbstractModel
# @param WorkgroupId: workgroup id
# @type WorkgroupId: String
# @param WorkflowId: workflow id
# @type WorkflowId: String
# @param PromptParams: prompt 参数
# @type PromptParams: String
attr_accessor :WorkgroupId, :WorkflowId, :PromptParams
def initialize(workgroupid=nil, workflowid=nil, promptparams=nil)
@WorkgroupId = workgroupid
@WorkflowId = workflowid
@PromptParams = promptparams
end
def deserialize(params)
@WorkgroupId = params['WorkgroupId']
@WorkflowId = params['WorkflowId']
@PromptParams = params['PromptParams']
end
end
# CreateMuskPrompt返回参数结构体
class CreateMuskPromptResponse < TencentCloud::Common::AbstractModel
# @param PromptId: prompt id
# @type PromptId: String
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :PromptId, :RequestId
def initialize(promptid=nil, requestid=nil)
@PromptId = promptid
@RequestId = requestid
end
def deserialize(params)
@PromptId = params['PromptId']
@RequestId = params['RequestId']
end
end
# DescribeApplications请求参数结构体
class DescribeApplicationsRequest < TencentCloud::Common::AbstractModel
# @param ApplicationIds: 应用id列表
# @type ApplicationIds: Array
# @param Filters: 过滤器,跟ApplicationIds不能共用,支持的filter主要有:
# application-id: 精确匹配;
# scene-id: 精确匹配;
# application-name: 模糊匹配;
# application-type: 精确匹配;
# @type Filters: Array
# @param Offset: 偏移量,默认为0
# @type Offset: Integer
# @param Limit: 返回量,默认为20
# MC:1000
# 用户:100
# @type Limit: Integer
# @param OrderField: 应用列表排序的依据字段。取值范围:"CREATED_TIME":依据应用的创建时间排序。 "APPLICATION_SIZE":依据应用的大小排序。默认按应用的创建时间排序。
# @type OrderField: String
# @param Order: 输出应用列表的排列顺序。取值范围:"ASC":升序排列。 "DESC":降序排列。默认按降序排列。
# @type Order: String
attr_accessor :ApplicationIds, :Filters, :Offset, :Limit, :OrderField, :Order
def initialize(applicationids=nil, filters=nil, offset=nil, limit=nil, orderfield=nil, order=nil)
@ApplicationIds = applicationids
@Filters = filters
@Offset = offset
@Limit = limit
@OrderField = orderfield
@Order = order
end
def deserialize(params)
@ApplicationIds = params['ApplicationIds']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
@OrderField = params['OrderField']
@Order = params['Order']
end
end
# DescribeApplications返回参数结构体
class DescribeApplicationsResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 应用总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TotalCount: Integer
# @param ApplicationSet: 分页返回的应用列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :ApplicationSet, :RequestId
def initialize(totalcount=nil, applicationset=nil, requestid=nil)
@TotalCount = totalcount
@ApplicationSet = applicationset
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['ApplicationSet'].nil?
@ApplicationSet = []
params['ApplicationSet'].each do |i|
applicationinfo_tmp = ApplicationInfo.new
applicationinfo_tmp.deserialize(i)
@ApplicationSet << applicationinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeInstanceNetworkStatus请求参数结构体
class DescribeInstanceNetworkStatusRequest < TencentCloud::Common::AbstractModel
# @param InstanceIds: 实例ID数组,单次请求最多不超过100个实例
# @type InstanceIds: Array
attr_accessor :InstanceIds
def initialize(instanceids=nil)
@InstanceIds = instanceids
end
def deserialize(params)
@InstanceIds = params['InstanceIds']
end
end
# DescribeInstanceNetworkStatus返回参数结构体
class DescribeInstanceNetworkStatusResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 查询结果集长度
# @type TotalCount: Integer
# @param NetworkStatusSet: 查询结果集
# 注意:此字段可能返回 null,表示取不到有效值。
# @type NetworkStatusSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :NetworkStatusSet, :RequestId
def initialize(totalcount=nil, networkstatusset=nil, requestid=nil)
@TotalCount = totalcount
@NetworkStatusSet = networkstatusset
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['NetworkStatusSet'].nil?
@NetworkStatusSet = []
params['NetworkStatusSet'].each do |i|
networkstatus_tmp = NetworkStatus.new
networkstatus_tmp.deserialize(i)
@NetworkStatusSet << networkstatus_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeInstances请求参数结构体
class DescribeInstancesRequest < TencentCloud::Common::AbstractModel
# @param InstanceIds: 实例元组
# @type InstanceIds: Array
# @param Filters: 描述键值对过滤器,用于条件过滤查询。目前支持的过滤器有:instance-id,实例id;instance-state,实例状态;charge-type,付费方式;public-ip-address,公网IP过滤
# @type Filters: Array
# @param Offset: 偏移量,默认为0
# @type Offset: Integer
# @param Limit: 返回量,默认为20
# @type Limit: Integer
attr_accessor :InstanceIds, :Filters, :Offset, :Limit
def initialize(instanceids=nil, filters=nil, offset=nil, limit=nil)
@InstanceIds = instanceids
@Filters = filters
@Offset = offset
@Limit = limit
end
def deserialize(params)
@InstanceIds = params['InstanceIds']
unless params['Filters'].nil?
@Filters = []
params['Filters'].each do |i|
filter_tmp = Filter.new
filter_tmp.deserialize(i)
@Filters << filter_tmp
end
end
@Offset = params['Offset']
@Limit = params['Limit']
end
end
# DescribeInstances返回参数结构体
class DescribeInstancesResponse < TencentCloud::Common::AbstractModel
# @param TotalCount: 实例总数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TotalCount: Integer
# @param InstanceSet: 分页实例详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TotalCount, :InstanceSet, :RequestId
def initialize(totalcount=nil, instanceset=nil, requestid=nil)
@TotalCount = totalcount
@InstanceSet = instanceset
@RequestId = requestid
end
def deserialize(params)
@TotalCount = params['TotalCount']
unless params['InstanceSet'].nil?
@InstanceSet = []
params['InstanceSet'].each do |i|
instance_tmp = Instance.new
instance_tmp.deserialize(i)
@InstanceSet << instance_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeRegions请求参数结构体
class DescribeRegionsRequest < TencentCloud::Common::AbstractModel
def initialize()
end
def deserialize(params)
end
end
# DescribeRegions返回参数结构体
class DescribeRegionsResponse < TencentCloud::Common::AbstractModel
# @param RegionSet: 地域列表
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RegionSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :RegionSet, :RequestId
def initialize(regionset=nil, requestid=nil)
@RegionSet = regionset
@RequestId = requestid
end
def deserialize(params)
unless params['RegionSet'].nil?
@RegionSet = []
params['RegionSet'].each do |i|
regioninfo_tmp = RegionInfo.new
regioninfo_tmp.deserialize(i)
@RegionSet << regioninfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeScenes请求参数结构体
class DescribeScenesRequest < TencentCloud::Common::AbstractModel
# @param SceneIds: 场景id列表
# @type SceneIds: Array
attr_accessor :SceneIds
def initialize(sceneids=nil)
@SceneIds = sceneids
end
def deserialize(params)
@SceneIds = params['SceneIds']
end
end
# DescribeScenes返回参数结构体
class DescribeScenesResponse < TencentCloud::Common::AbstractModel
# @param SceneSet: 场景详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SceneSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :SceneSet, :RequestId
def initialize(sceneset=nil, requestid=nil)
@SceneSet = sceneset
@RequestId = requestid
end
def deserialize(params)
unless params['SceneSet'].nil?
@SceneSet = []
params['SceneSet'].each do |i|
sceneinfo_tmp = SceneInfo.new
sceneinfo_tmp.deserialize(i)
@SceneSet << sceneinfo_tmp
end
end
@RequestId = params['RequestId']
end
end
# DescribeServiceLoginSettings请求参数结构体
class DescribeServiceLoginSettingsRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# @type InstanceId: String
# @param ServiceName: 服务名称
# @type ServiceName: String
attr_accessor :InstanceId, :ServiceName
def initialize(instanceid=nil, servicename=nil)
@InstanceId = instanceid
@ServiceName = servicename
end
def deserialize(params)
@InstanceId = params['InstanceId']
@ServiceName = params['ServiceName']
end
end
# DescribeServiceLoginSettings返回参数结构体
class DescribeServiceLoginSettingsResponse < TencentCloud::Common::AbstractModel
# @param LoginSettings: 服务登录配置详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LoginSettings: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :LoginSettings, :RequestId
def initialize(loginsettings=nil, requestid=nil)
@LoginSettings = loginsettings
@RequestId = requestid
end
def deserialize(params)
unless params['LoginSettings'].nil?
@LoginSettings = []
params['LoginSettings'].each do |i|
loginsetting_tmp = LoginSetting.new
loginsetting_tmp.deserialize(i)
@LoginSettings << loginsetting_tmp
end
end
@RequestId = params['RequestId']
end
end
# 描述键值对过滤器,用于条件过滤查询。例如过滤ID、名称、状态等
# - 若存在多个Filter时,Filter间的关系为逻辑与(AND)关系。
# - 若同一个Filter存在多个Values,同一Filter下Values间的关系为逻辑或(OR)关系。
class Filter < TencentCloud::Common::AbstractModel
# @param Name: 需要过滤的字段。
# @type Name: String
# @param Values: 字段的过滤值。
# @type Values: Array
attr_accessor :Name, :Values
def initialize(name=nil, values=nil)
@Name = name
@Values = values
end
def deserialize(params)
@Name = params['Name']
@Values = params['Values']
end
end
# InquirePriceRunInstances请求参数结构体
class InquirePriceRunInstancesRequest < TencentCloud::Common::AbstractModel
# @param ApplicationId: 应用ID
# @type ApplicationId: String
# @param BundleType: 算力套餐类型
# @type BundleType: String
# @param SystemDisk: 实例系统盘配置信息。若不指定该参数,则按照系统默认值进行分配。
# @type SystemDisk: :class:`Tencentcloud::Hai.v20230812.models.SystemDisk`
# @param InstanceCount: 购买实例数量。
# @type InstanceCount: Integer
# @param InstanceName: 实例显示名称
# @type InstanceName: String
# @param ClientToken: 幂等请求token
# @type ClientToken: String
# @param DryRun: DryRun为True就是只验接口连通性,默认为False
# @type DryRun: Boolean
# @param InstanceChargeType: 付费方式,POSTPAID_BY_HOUR按量后付费,PREPAID_BY_MONTH预付费按月,PREPAID_BY_DAY预付费按天
# @type InstanceChargeType: String
# @param InstanceChargePrepaid: 预付费参数
# @type InstanceChargePrepaid: :class:`Tencentcloud::Hai.v20230812.models.InstanceChargePrepaid`
attr_accessor :ApplicationId, :BundleType, :SystemDisk, :InstanceCount, :InstanceName, :ClientToken, :DryRun, :InstanceChargeType, :InstanceChargePrepaid
def initialize(applicationid=nil, bundletype=nil, systemdisk=nil, instancecount=nil, instancename=nil, clienttoken=nil, dryrun=nil, instancechargetype=nil, instancechargeprepaid=nil)
@ApplicationId = applicationid
@BundleType = bundletype
@SystemDisk = systemdisk
@InstanceCount = instancecount
@InstanceName = instancename
@ClientToken = clienttoken
@DryRun = dryrun
@InstanceChargeType = instancechargetype
@InstanceChargePrepaid = instancechargeprepaid
end
def deserialize(params)
@ApplicationId = params['ApplicationId']
@BundleType = params['BundleType']
unless params['SystemDisk'].nil?
@SystemDisk = SystemDisk.new
@SystemDisk.deserialize(params['SystemDisk'])
end
@InstanceCount = params['InstanceCount']
@InstanceName = params['InstanceName']
@ClientToken = params['ClientToken']
@DryRun = params['DryRun']
@InstanceChargeType = params['InstanceChargeType']
unless params['InstanceChargePrepaid'].nil?
@InstanceChargePrepaid = InstanceChargePrepaid.new
@InstanceChargePrepaid.deserialize(params['InstanceChargePrepaid'])
end
end
end
# InquirePriceRunInstances返回参数结构体
class InquirePriceRunInstancesResponse < TencentCloud::Common::AbstractModel
# @param Price: 发货参数对应的价格组合,当DryRun=True,会返回空
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Price: :class:`Tencentcloud::Hai.v20230812.models.Price`
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :Price, :RequestId
def initialize(price=nil, requestid=nil)
@Price = price
@RequestId = requestid
end
def deserialize(params)
unless params['Price'].nil?
@Price = Price.new
@Price.deserialize(params['Price'])
end
@RequestId = params['RequestId']
end
end
# 实例信息
class Instance < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param InstanceName: 实例名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceName: String
# @param InstanceState: 实例状态:
# PENDING:表示创建中
# LAUNCH_FAILED:表示创建失败
# RUNNING:表示运行中
# ARREARS:表示待回收
# STOPPED_NO_CHARGE:表示关机不收费
# TERMINATING:表示销毁中
# TERMINATED:表示已销毁
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceState: String
# @param ApplicationName: 应用名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ApplicationName: String
# @param BundleName: 算力套餐名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type BundleName: String
# @param GPUCount: 实例所包含的GPU卡数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GPUCount: Integer
# @param GPUPerformance: 算力
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GPUPerformance: String
# @param GPUMemory: 显存
# 注意:此字段可能返回 null,表示取不到有效值。
# @type GPUMemory: String
# @param CPU: CPU核数
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CPU: String
# @param Memory: 内存
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Memory: String
# @param SystemDisk: 系统盘数据
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SystemDisk: :class:`Tencentcloud::Hai.v20230812.models.SystemDisk`
# @param PrivateIpAddresses: 内网ip地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PrivateIpAddresses: Array
# @param PublicIpAddresses: 公网ip地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PublicIpAddresses: Array
# @param SecurityGroupIds: 安全组ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SecurityGroupIds: Array
# @param LatestOperation: 实例最新操作
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LatestOperation: String
# @param LatestOperationState: 实例最新操作状态:
# SUCCESS:表示操作成功
# OPERATING:表示操作执行中
# FAILED:表示操作失败
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LatestOperationState: String
# @param CreateTime: 实例创建时间
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CreateTime: String
# @param MaxOutBandwidth: 公网出带宽上限,默认10Mbps
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MaxOutBandwidth: String
# @param MaxFreeTraffic: 每月免费流量,默认500G
# 注意:此字段可能返回 null,表示取不到有效值。
# @type MaxFreeTraffic: String
# @param ConfigurationEnvironment: 应用配置环境
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ConfigurationEnvironment: String
# @param LoginServices: 实例包含的登录服务详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type LoginServices: Array
# @param OSType: 应用服务的操作系统类型
# 注意:此字段可能返回 null,表示取不到有效值。
# @type OSType: String
attr_accessor :InstanceId, :InstanceName, :InstanceState, :ApplicationName, :BundleName, :GPUCount, :GPUPerformance, :GPUMemory, :CPU, :Memory, :SystemDisk, :PrivateIpAddresses, :PublicIpAddresses, :SecurityGroupIds, :LatestOperation, :LatestOperationState, :CreateTime, :MaxOutBandwidth, :MaxFreeTraffic, :ConfigurationEnvironment, :LoginServices, :OSType
def initialize(instanceid=nil, instancename=nil, instancestate=nil, applicationname=nil, bundlename=nil, gpucount=nil, gpuperformance=nil, gpumemory=nil, cpu=nil, memory=nil, systemdisk=nil, privateipaddresses=nil, publicipaddresses=nil, securitygroupids=nil, latestoperation=nil, latestoperationstate=nil, createtime=nil, maxoutbandwidth=nil, maxfreetraffic=nil, configurationenvironment=nil, loginservices=nil, ostype=nil)
@InstanceId = instanceid
@InstanceName = instancename
@InstanceState = instancestate
@ApplicationName = applicationname
@BundleName = bundlename
@GPUCount = gpucount
@GPUPerformance = gpuperformance
@GPUMemory = gpumemory
@CPU = cpu
@Memory = memory
@SystemDisk = systemdisk
@PrivateIpAddresses = privateipaddresses
@PublicIpAddresses = publicipaddresses
@SecurityGroupIds = securitygroupids
@LatestOperation = latestoperation
@LatestOperationState = latestoperationstate
@CreateTime = createtime
@MaxOutBandwidth = maxoutbandwidth
@MaxFreeTraffic = maxfreetraffic
@ConfigurationEnvironment = configurationenvironment
@LoginServices = loginservices
@OSType = ostype
end
def deserialize(params)
@InstanceId = params['InstanceId']
@InstanceName = params['InstanceName']
@InstanceState = params['InstanceState']
@ApplicationName = params['ApplicationName']
@BundleName = params['BundleName']
@GPUCount = params['GPUCount']
@GPUPerformance = params['GPUPerformance']
@GPUMemory = params['GPUMemory']
@CPU = params['CPU']
@Memory = params['Memory']
unless params['SystemDisk'].nil?
@SystemDisk = SystemDisk.new
@SystemDisk.deserialize(params['SystemDisk'])
end
@PrivateIpAddresses = params['PrivateIpAddresses']
@PublicIpAddresses = params['PublicIpAddresses']
@SecurityGroupIds = params['SecurityGroupIds']
@LatestOperation = params['LatestOperation']
@LatestOperationState = params['LatestOperationState']
@CreateTime = params['CreateTime']
@MaxOutBandwidth = params['MaxOutBandwidth']
@MaxFreeTraffic = params['MaxFreeTraffic']
@ConfigurationEnvironment = params['ConfigurationEnvironment']
unless params['LoginServices'].nil?
@LoginServices = []
params['LoginServices'].each do |i|
loginservice_tmp = LoginService.new
loginservice_tmp.deserialize(i)
@LoginServices << loginservice_tmp
end
end
@OSType = params['OSType']
end
end
# 实例预付费入参
class InstanceChargePrepaid < TencentCloud::Common::AbstractModel
# @param Period: 时长,默认值:1
# @type Period: Integer
# @param RenewFlag: 续费标志可选参数:
# NOTIFY_AND_MANUAL_RENEW:表示默认状态(用户未设置,即初始状态:若用户有预付费不停服特权,也会对该值进行自动续费)
# NOTIFY_AND_AUTO_RENEW:表示自动续费
# DISABLE_NOTIFY_AND_MANUAL_RENEW:表示明确不自动续费(用户设置)
# 默认值:NOTIFY_AND_MANUAL_RENEW
# @type RenewFlag: String
# @param TimeUnit: 时长单位,默认值MONTH
# @type TimeUnit: String
attr_accessor :Period, :RenewFlag, :TimeUnit
def initialize(period=nil, renewflag=nil, timeunit=nil)
@Period = period
@RenewFlag = renewflag
@TimeUnit = timeunit
end
def deserialize(params)
@Period = params['Period']
@RenewFlag = params['RenewFlag']
@TimeUnit = params['TimeUnit']
end
end
# 套餐价格
class ItemPrice < TencentCloud::Common::AbstractModel
# @param UnitPrice: 原单价
# 注意:此字段可能返回 null,表示取不到有效值。
# @type UnitPrice: Float
# @param DiscountUnitPrice: 折扣后单价
# 注意:此字段可能返回 null,表示取不到有效值。
# @type DiscountUnitPrice: Float
# @param Discount: 折扣
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Discount: Float
# @param ChargeUnit: 单位:时/月
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ChargeUnit: String
# @param Amount: 商品数量
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Amount: Integer
attr_accessor :UnitPrice, :DiscountUnitPrice, :Discount, :ChargeUnit, :Amount
def initialize(unitprice=nil, discountunitprice=nil, discount=nil, chargeunit=nil, amount=nil)
@UnitPrice = unitprice
@DiscountUnitPrice = discountunitprice
@Discount = discount
@ChargeUnit = chargeunit
@Amount = amount
end
def deserialize(params)
@UnitPrice = params['UnitPrice']
@DiscountUnitPrice = params['DiscountUnitPrice']
@Discount = params['Discount']
@ChargeUnit = params['ChargeUnit']
@Amount = params['Amount']
end
end
# 分实例价格
class ItemPriceDetail < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param InstancePrice: 实例价格详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstancePrice: :class:`Tencentcloud::Hai.v20230812.models.ItemPrice`
# @param CloudDiskPrice: 磁盘价格详情
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CloudDiskPrice: :class:`Tencentcloud::Hai.v20230812.models.ItemPrice`
# @param InstanceTotalPrice: 该实例的总价钱
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceTotalPrice: :class:`Tencentcloud::Hai.v20230812.models.ItemPrice`
attr_accessor :InstanceId, :InstancePrice, :CloudDiskPrice, :InstanceTotalPrice
def initialize(instanceid=nil, instanceprice=nil, clouddiskprice=nil, instancetotalprice=nil)
@InstanceId = instanceid
@InstancePrice = instanceprice
@CloudDiskPrice = clouddiskprice
@InstanceTotalPrice = instancetotalprice
end
def deserialize(params)
@InstanceId = params['InstanceId']
unless params['InstancePrice'].nil?
@InstancePrice = ItemPrice.new
@InstancePrice.deserialize(params['InstancePrice'])
end
unless params['CloudDiskPrice'].nil?
@CloudDiskPrice = ItemPrice.new
@CloudDiskPrice.deserialize(params['CloudDiskPrice'])
end
unless params['InstanceTotalPrice'].nil?
@InstanceTotalPrice = ItemPrice.new
@InstanceTotalPrice.deserialize(params['InstanceTotalPrice'])
end
end
end
# 登录服务详情
class LoginService < TencentCloud::Common::AbstractModel
# @param ServiceName: 登录方式名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceName: String
attr_accessor :ServiceName
def initialize(servicename=nil)
@ServiceName = servicename
end
def deserialize(params)
@ServiceName = params['ServiceName']
end
end
# 某服务的登录配置
class LoginSetting < TencentCloud::Common::AbstractModel
# @param ServiceName: 服务名称
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ServiceName: String
# @param Url: 服务登录url
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Url: String
attr_accessor :ServiceName, :Url
def initialize(servicename=nil, url=nil)
@ServiceName = servicename
@Url = url
end
def deserialize(params)
@ServiceName = params['ServiceName']
@Url = params['Url']
end
end
# HAI 实例的网络配置和消耗情况
class NetworkStatus < TencentCloud::Common::AbstractModel
# @param InstanceId: HAI 的实例 ID
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstanceId: String
# @param AddressIp: 公网 IP 地址
# 注意:此字段可能返回 null,表示取不到有效值。
# @type AddressIp: String
# @param Bandwidth: 出带宽上限,单位Mbps
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Bandwidth: Integer
# @param TotalTrafficAmount: 流量包总量,单位GB
# 注意:此字段可能返回 null,表示取不到有效值。
# @type TotalTrafficAmount: Float
# @param RemainingTrafficAmount: 流量包剩余量,单位GB
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RemainingTrafficAmount: Float
attr_accessor :InstanceId, :AddressIp, :Bandwidth, :TotalTrafficAmount, :RemainingTrafficAmount
def initialize(instanceid=nil, addressip=nil, bandwidth=nil, totaltrafficamount=nil, remainingtrafficamount=nil)
@InstanceId = instanceid
@AddressIp = addressip
@Bandwidth = bandwidth
@TotalTrafficAmount = totaltrafficamount
@RemainingTrafficAmount = remainingtrafficamount
end
def deserialize(params)
@InstanceId = params['InstanceId']
@AddressIp = params['AddressIp']
@Bandwidth = params['Bandwidth']
@TotalTrafficAmount = params['TotalTrafficAmount']
@RemainingTrafficAmount = params['RemainingTrafficAmount']
end
end
# 费用数据结构体
class Price < TencentCloud::Common::AbstractModel
# @param InstancePrice: 实例价格信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type InstancePrice: :class:`Tencentcloud::Hai.v20230812.models.ItemPrice`
# @param CloudDiskPrice: 云盘价格信息
# 注意:此字段可能返回 null,表示取不到有效值。
# @type CloudDiskPrice: :class:`Tencentcloud::Hai.v20230812.models.ItemPrice`
# @param PriceDetailSet: 分实例价格
# 注意:此字段可能返回 null,表示取不到有效值。
# @type PriceDetailSet: Array
attr_accessor :InstancePrice, :CloudDiskPrice, :PriceDetailSet
def initialize(instanceprice=nil, clouddiskprice=nil, pricedetailset=nil)
@InstancePrice = instanceprice
@CloudDiskPrice = clouddiskprice
@PriceDetailSet = pricedetailset
end
def deserialize(params)
unless params['InstancePrice'].nil?
@InstancePrice = ItemPrice.new
@InstancePrice.deserialize(params['InstancePrice'])
end
unless params['CloudDiskPrice'].nil?
@CloudDiskPrice = ItemPrice.new
@CloudDiskPrice.deserialize(params['CloudDiskPrice'])
end
unless params['PriceDetailSet'].nil?
@PriceDetailSet = []
params['PriceDetailSet'].each do |i|
itempricedetail_tmp = ItemPriceDetail.new
itempricedetail_tmp.deserialize(i)
@PriceDetailSet << itempricedetail_tmp
end
end
end
end
# 地域列表
class RegionInfo < TencentCloud::Common::AbstractModel
# @param Region: ap-guangzhou
# 注意:此字段可能返回 null,表示取不到有效值。
# @type Region: String
# @param RegionName: 华南地区(广州)
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RegionName: String
# @param RegionState: 地域是否可用状态
# AVAILABLE:可用
# 注意:此字段可能返回 null,表示取不到有效值。
# @type RegionState: String
# @param ScholarRocketSupportState: 学术加速是否支持:
# NO_NEED_SUPPORT表示不需支持;NOT_SUPPORT_YET表示暂未支持;ALREADY_SUPPORT表示已经支持。对于ALREADY_SUPPORT的地域才需进一步调用DescribeScholarRocketStatus查看学术加速是开启还是关闭
# 注意:此字段可能返回 null,表示取不到有效值。
# @type ScholarRocketSupportState: String
attr_accessor :Region, :RegionName, :RegionState, :ScholarRocketSupportState
def initialize(region=nil, regionname=nil, regionstate=nil, scholarrocketsupportstate=nil)
@Region = region
@RegionName = regionname
@RegionState = regionstate
@ScholarRocketSupportState = scholarrocketsupportstate
end
def deserialize(params)
@Region = params['Region']
@RegionName = params['RegionName']
@RegionState = params['RegionState']
@ScholarRocketSupportState = params['ScholarRocketSupportState']
end
end
# RunInstances请求参数结构体
class RunInstancesRequest < TencentCloud::Common::AbstractModel
# @param ApplicationId: 应用ID
# @type ApplicationId: String
# @param BundleType: 算力套餐类型
# @type BundleType: String
# @param SystemDisk: 实例系统盘配置信息。若不指定该参数,则按照系统默认值进行分配。
# @type SystemDisk: :class:`Tencentcloud::Hai.v20230812.models.SystemDisk`
# @param InstanceCount: 购买实例数量。
# @type InstanceCount: Integer
# @param InstanceName: 实例显示名称
# @type InstanceName: String
# @param ClientToken: 幂等请求的token
# @type ClientToken: String
# @param DryRun: DryRun为True就是只验接口连通性,默认为False
# @type DryRun: Boolean
attr_accessor :ApplicationId, :BundleType, :SystemDisk, :InstanceCount, :InstanceName, :ClientToken, :DryRun
def initialize(applicationid=nil, bundletype=nil, systemdisk=nil, instancecount=nil, instancename=nil, clienttoken=nil, dryrun=nil)
@ApplicationId = applicationid
@BundleType = bundletype
@SystemDisk = systemdisk
@InstanceCount = instancecount
@InstanceName = instancename
@ClientToken = clienttoken
@DryRun = dryrun
end
def deserialize(params)
@ApplicationId = params['ApplicationId']
@BundleType = params['BundleType']
unless params['SystemDisk'].nil?
@SystemDisk = SystemDisk.new
@SystemDisk.deserialize(params['SystemDisk'])
end
@InstanceCount = params['InstanceCount']
@InstanceName = params['InstanceName']
@ClientToken = params['ClientToken']
@DryRun = params['DryRun']
end
end
# RunInstances返回参数结构体
class RunInstancesResponse < TencentCloud::Common::AbstractModel
# @param InstanceIdSet: 实例ID列表
# @type InstanceIdSet: Array
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :InstanceIdSet, :RequestId
def initialize(instanceidset=nil, requestid=nil)
@InstanceIdSet = instanceidset
@RequestId = requestid
end
def deserialize(params)
@InstanceIdSet = params['InstanceIdSet']
@RequestId = params['RequestId']
end
end
# 场景详情
class SceneInfo < TencentCloud::Common::AbstractModel
# @param SceneId: 场景id
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SceneId: String
# @param SceneName: 场景名
# 注意:此字段可能返回 null,表示取不到有效值。
# @type SceneName: String
attr_accessor :SceneId, :SceneName
def initialize(sceneid=nil, scenename=nil)
@SceneId = sceneid
@SceneName = scenename
end
def deserialize(params)
@SceneId = params['SceneId']
@SceneName = params['SceneName']
end
end
# StartInstance请求参数结构体
class StartInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param DryRun: 默认为False,True代表只验证接口连通性
# @type DryRun: Boolean
attr_accessor :InstanceId, :DryRun
def initialize(instanceid=nil, dryrun=nil)
@InstanceId = instanceid
@DryRun = dryrun
end
def deserialize(params)
@InstanceId = params['InstanceId']
@DryRun = params['DryRun']
end
end
# StartInstance返回参数结构体
class StartInstanceResponse < TencentCloud::Common::AbstractModel
# @param TaskId: task任务id
# @type TaskId: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TaskId, :RequestId
def initialize(taskid=nil, requestid=nil)
@TaskId = taskid
@RequestId = requestid
end
def deserialize(params)
@TaskId = params['TaskId']
@RequestId = params['RequestId']
end
end
# StopInstance请求参数结构体
class StopInstanceRequest < TencentCloud::Common::AbstractModel
# @param InstanceId: 实例ID
# @type InstanceId: String
# @param StopMode: hai实例关机的模式,目前仅支持关机不收费:
# STOP_CHARGE -- 关闭hai实例,释放计算资源,停止收取计算资源的费用。
# 注意:默认值为STOP_CHARGE
# @type StopMode: String
# @param DryRun: 默认为False,True代表只验证接口连通性
# @type DryRun: Boolean
attr_accessor :InstanceId, :StopMode, :DryRun
def initialize(instanceid=nil, stopmode=nil, dryrun=nil)
@InstanceId = instanceid
@StopMode = stopmode
@DryRun = dryrun
end
def deserialize(params)
@InstanceId = params['InstanceId']
@StopMode = params['StopMode']
@DryRun = params['DryRun']
end
end
# StopInstance返回参数结构体
class StopInstanceResponse < TencentCloud::Common::AbstractModel
# @param TaskId: task任务id
# @type TaskId: Integer
# @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。
# @type RequestId: String
attr_accessor :TaskId, :RequestId
def initialize(taskid=nil, requestid=nil)
@TaskId = taskid
@RequestId = requestid
end
def deserialize(params)
@TaskId = params['TaskId']
@RequestId = params['RequestId']
end
end
# 描述了操作系统所在块设备即系统盘的信息
class SystemDisk < TencentCloud::Common::AbstractModel
# @param DiskType: 系统盘类型。系统盘类型限制详见[存储概述](https://cloud.tencent.com/document/product/213/4952)。取值范围: