| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- // Copyright 2018 JDCLOUD.COM
- //
- // 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.
- //
- // NOTE: This class is auto generated by the jdcloud code generator program.
- package apis
- import (
- "github.com/jdcloud-api/jdcloud-sdk-go/core"
- disk "github.com/jdcloud-api/jdcloud-sdk-go/services/disk/models"
- common "github.com/jdcloud-api/jdcloud-sdk-go/services/common/models"
- )
- type DescribeDisksRequest struct {
- core.JDCloudRequest
- /* 地域ID */
- RegionId string `json:"regionId"`
- /* 页码, 默认为1, 取值范围:[1,∞) (Optional) */
- PageNumber *int `json:"pageNumber"`
- /* 分页大小,默认为20,取值范围:[10,100] (Optional) */
- PageSize *int `json:"pageSize"`
- /* Tag筛选条件 (Optional) */
- Tags []disk.TagFilter `json:"tags"`
- /* diskId - 云硬盘ID,精确匹配,支持多个
- diskType - 云硬盘类型,精确匹配,支持多个,取值为 ssd,premium-hdd,ssd.io1,ssd.gp1,hdd.std1
- instanceId - 云硬盘所挂载主机的ID,精确匹配,支持多个
- instanceType - 云硬盘所挂载主机的类型,精确匹配,支持多个
- status - 可用区,精确匹配,支持多个
- az - 云硬盘状态,精确匹配,支持多个
- name - 云硬盘名称,模糊匹配,支持单个
- multiAttach - 云硬盘是否多点挂载,精确匹配,支持单个
- encrypted - 云硬盘是否加密,精确匹配,支持单个
- policyId - 绑定policyId的云硬盘,精确匹配,支持多个
- notPolicyId - 未绑定policyId的云硬盘,精确匹配,支持多个
- (Optional) */
- Filters []common.Filter `json:"filters"`
- }
- /*
- * param regionId: 地域ID (Required)
- *
- * @Deprecated, not compatible when mandatory parameters changed
- */
- func NewDescribeDisksRequest(
- regionId string,
- ) *DescribeDisksRequest {
- return &DescribeDisksRequest{
- JDCloudRequest: core.JDCloudRequest{
- URL: "/regions/{regionId}/disks",
- Method: "GET",
- Header: nil,
- Version: "v1",
- },
- RegionId: regionId,
- }
- }
- /*
- * param regionId: 地域ID (Required)
- * param pageNumber: 页码, 默认为1, 取值范围:[1,∞) (Optional)
- * param pageSize: 分页大小,默认为20,取值范围:[10,100] (Optional)
- * param tags: Tag筛选条件 (Optional)
- * param filters: diskId - 云硬盘ID,精确匹配,支持多个
- diskType - 云硬盘类型,精确匹配,支持多个,取值为 ssd,premium-hdd,ssd.io1,ssd.gp1,hdd.std1
- instanceId - 云硬盘所挂载主机的ID,精确匹配,支持多个
- instanceType - 云硬盘所挂载主机的类型,精确匹配,支持多个
- status - 可用区,精确匹配,支持多个
- az - 云硬盘状态,精确匹配,支持多个
- name - 云硬盘名称,模糊匹配,支持单个
- multiAttach - 云硬盘是否多点挂载,精确匹配,支持单个
- encrypted - 云硬盘是否加密,精确匹配,支持单个
- policyId - 绑定policyId的云硬盘,精确匹配,支持多个
- notPolicyId - 未绑定policyId的云硬盘,精确匹配,支持多个
- (Optional)
- */
- func NewDescribeDisksRequestWithAllParams(
- regionId string,
- pageNumber *int,
- pageSize *int,
- tags []disk.TagFilter,
- filters []common.Filter,
- ) *DescribeDisksRequest {
- return &DescribeDisksRequest{
- JDCloudRequest: core.JDCloudRequest{
- URL: "/regions/{regionId}/disks",
- Method: "GET",
- Header: nil,
- Version: "v1",
- },
- RegionId: regionId,
- PageNumber: pageNumber,
- PageSize: pageSize,
- Tags: tags,
- Filters: filters,
- }
- }
- /* This constructor has better compatible ability when API parameters changed */
- func NewDescribeDisksRequestWithoutParam() *DescribeDisksRequest {
- return &DescribeDisksRequest{
- JDCloudRequest: core.JDCloudRequest{
- URL: "/regions/{regionId}/disks",
- Method: "GET",
- Header: nil,
- Version: "v1",
- },
- }
- }
- /* param regionId: 地域ID(Required) */
- func (r *DescribeDisksRequest) SetRegionId(regionId string) {
- r.RegionId = regionId
- }
- /* param pageNumber: 页码, 默认为1, 取值范围:[1,∞)(Optional) */
- func (r *DescribeDisksRequest) SetPageNumber(pageNumber int) {
- r.PageNumber = &pageNumber
- }
- /* param pageSize: 分页大小,默认为20,取值范围:[10,100](Optional) */
- func (r *DescribeDisksRequest) SetPageSize(pageSize int) {
- r.PageSize = &pageSize
- }
- /* param tags: Tag筛选条件(Optional) */
- func (r *DescribeDisksRequest) SetTags(tags []disk.TagFilter) {
- r.Tags = tags
- }
- /* param filters: diskId - 云硬盘ID,精确匹配,支持多个
- diskType - 云硬盘类型,精确匹配,支持多个,取值为 ssd,premium-hdd,ssd.io1,ssd.gp1,hdd.std1
- instanceId - 云硬盘所挂载主机的ID,精确匹配,支持多个
- instanceType - 云硬盘所挂载主机的类型,精确匹配,支持多个
- status - 可用区,精确匹配,支持多个
- az - 云硬盘状态,精确匹配,支持多个
- name - 云硬盘名称,模糊匹配,支持单个
- multiAttach - 云硬盘是否多点挂载,精确匹配,支持单个
- encrypted - 云硬盘是否加密,精确匹配,支持单个
- policyId - 绑定policyId的云硬盘,精确匹配,支持多个
- notPolicyId - 未绑定policyId的云硬盘,精确匹配,支持多个
- (Optional) */
- func (r *DescribeDisksRequest) SetFilters(filters []common.Filter) {
- r.Filters = filters
- }
- // GetRegionId returns path parameter 'regionId' if exist,
- // otherwise return empty string
- func (r DescribeDisksRequest) GetRegionId() string {
- return r.RegionId
- }
- type DescribeDisksResponse struct {
- RequestID string `json:"requestId"`
- Error core.ErrorResponse `json:"error"`
- Result DescribeDisksResult `json:"result"`
- }
- type DescribeDisksResult struct {
- Disks []disk.Disk `json:"disks"`
- TotalCount int `json:"totalCount"`
- }
|