diff --git a/.changelog/2502.txt b/.changelog/2502.txt
new file mode 100644
index 0000000000..9c183c977a
--- /dev/null
+++ b/.changelog/2502.txt
@@ -0,0 +1,3 @@
+```release-note:enhancement
+resource/tencentcloud_mysql_instance: Optimize the availability zone problem when modifying the configuration after active/standby switchover.
+```
diff --git a/.changelog/2509.txt b/.changelog/2509.txt
new file mode 100644
index 0000000000..b55ce4f80d
--- /dev/null
+++ b/.changelog/2509.txt
@@ -0,0 +1,4 @@
+```release-note:enhancement
+resource/tencentcloud_instance: fix private ip release problem
+```
+
diff --git a/.changelog/2512.txt b/.changelog/2512.txt
new file mode 100644
index 0000000000..6f75a6cad0
--- /dev/null
+++ b/.changelog/2512.txt
@@ -0,0 +1,3 @@
+```release-note:enhancement
+resource/tencentcloud_clb_attachments: support param `eni_ip`
+```
\ No newline at end of file
diff --git a/CHANGELOG.md b/CHANGELOG.md
index f985ee3a09..8f98c1c5a6 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,3 +1,11 @@
+## 1.81.72 (January 30, 2024)
+
+ENHANCEMENTS:
+
+* resource/tencentcloud_ccn_attachment: support tke cluster addon modify ([#2507](https://github.com/tencentcloudstack/terraform-provider-tencentcloud/pull/2507))
+* resource/tencentcloud_instance: fix private ip release problem ([#2509](https://github.com/tencentcloudstack/terraform-provider-tencentcloud/pull/2509))
+* resource/tencentcloud_mysql_instance: Optimize the availability zone problem when modifying the configuration after active/standby switchover. ([#2502](https://github.com/tencentcloudstack/terraform-provider-tencentcloud/pull/2502))
+
## 1.81.71 (January 26, 2024)
ENHANCEMENTS:
diff --git a/go.mod b/go.mod
index 590106c364..9e8226266f 100644
--- a/go.mod
+++ b/go.mod
@@ -46,7 +46,7 @@ require (
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/clb v1.0.847
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cloudaudit v1.0.544
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cls v1.0.711
- github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.853
+ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.857
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.624
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cwp v1.0.762
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cynosdb v1.0.692
@@ -107,8 +107,9 @@ require (
require (
github.com/hashicorp/go-uuid v1.0.3
+ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing v1.0.856
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cdwpg v1.0.772
- github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.853
+ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.857
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/dasb v1.0.798
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/oceanus v1.0.831
github.com/wI2L/jsondiff v0.3.0
diff --git a/go.sum b/go.sum
index 1459f498d2..306e21a224 100644
--- a/go.sum
+++ b/go.sum
@@ -834,6 +834,8 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/bi v1.0.770 h1:5FWt9F+a
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/bi v1.0.770/go.mod h1:zuWcAJVIXbHbOR7i6SKK0wNlvPLt5Su4ijOZGMJbUi8=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/bi v1.0.824 h1:DVKvZ6h+qd7tadUrCjVAkCCmE3TsbK2ZmwGd3AJcpWc=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/bi v1.0.824/go.mod h1:DvBpDX/qdJG4KKLeULmRvhAjPYiw8za0HeTSu2y/lFw=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing v1.0.856 h1:zJBb69FBBNZko4PbDScqj9wogPatzNYEXAJ862IBoMQ=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing v1.0.856/go.mod h1:P+VGibeVh8pW4N85x9ee0xzXsZoT9jzjHYD8GaAiyG4=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.760 h1:Ky9dRsTL2HXKWUrTFpQFZWQ1TrM+o+P35kczR7thalo=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.760/go.mod h1:AAfdrxknvUedvigxbbzKQLxN+1EG5NPbytpiqmfuFvU=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.760 h1:oGY4IigfIw0iQKh3/cOY29KBeEeFbvJft69e0beyfdI=
@@ -954,14 +956,15 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.845 h1:fiiV
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.845/go.mod h1:r5r4xbfxSaeR04b166HGsBa/R4U3SueirEUpXGuw+Q0=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.847 h1:ITZmxAWfbr5yikJ4T30yVYMW3jpa/oTmNbPnw/h1Vq0=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.847/go.mod h1:r5r4xbfxSaeR04b166HGsBa/R4U3SueirEUpXGuw+Q0=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.849 h1:ieRAJU2lnAcaDK25W29C9R7iyR5IR4E+5DujRfu5wls=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.849/go.mod h1:r5r4xbfxSaeR04b166HGsBa/R4U3SueirEUpXGuw+Q0=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.853 h1:TNYjF1jDLLNTirAkq7zRT9iF9xC2ZjgwpXsVSEBQvgQ=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.853/go.mod h1:r5r4xbfxSaeR04b166HGsBa/R4U3SueirEUpXGuw+Q0=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.849 h1:Q48wD8VMYTjasH0yAqCIoSkiIwtge3Gzem5pmJx9h54=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.849/go.mod h1:lTyS8mn+Au4aWFFHFsTmyAFYW5mxylw366QBJ0040eU=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.856 h1:4PaaKxPjh0dmRzzz0CRZSZlbvzQIPcg4TE1Ibz0Cdlk=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.856/go.mod h1:r5r4xbfxSaeR04b166HGsBa/R4U3SueirEUpXGuw+Q0=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.857 h1:6TxCHz3zSG67cLDDu8w3TkFm/FwiyiAWBhcidGXWH/0=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.857/go.mod h1:r5r4xbfxSaeR04b166HGsBa/R4U3SueirEUpXGuw+Q0=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.853 h1:Ofgedv4BWvDYX1Ff/5H2wYShan8mC1OtaHQJq+rG0pE=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.853/go.mod h1:iDYmWmDEfR74RzWU5kO1UWFsWu/c0pMtEtnoWRMvaJQ=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.857 h1:ANnIsWqF7OjfH0Bvnnj3zniFs/7JAhHKaRQTJo1pIiA=
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.857/go.mod h1:d+OvJbz/yKr64+Scu00s/PoHtmnJBaOcFLom79zJ0jg=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.624 h1:nEZqsoqt1pEoaP9JjkHQy3/H00suCfzlHW1qOm2nYD8=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.624/go.mod h1:+TXSVyeKwt1IhZRqKPbTREteBcP+K07Q846/ilNzLWA=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cwp v1.0.762 h1:2egy69SP/wPsmnfozcQVZ6tUY6F6N/TpEe/7xtXrc/8=
@@ -1004,8 +1007,6 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/mariadb v1.0.672 h1:sR3
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/mariadb v1.0.672/go.mod h1:o3rBKhtfIJfw4BG22M0CQVLQAc0WqIsbyRI/EW52Ka0=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/mongodb v1.0.651 h1:Ohb58H6gIlTcd73CF+goUlEdNJ2CYkYUHTYxV/M4UL4=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/mongodb v1.0.651/go.mod h1:HLqsSgUnwgkE+XecQajekinjz1B7S+1U1J66puH4jpQ=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/monitor v1.0.839 h1:eRIkvwwyw7Guh3Ayr3J5tKSWfNX9WQBQ5zzNpBYoBHQ=
-github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/monitor v1.0.839/go.mod h1:4OoBA087NHVdyeRJFy/SML7kIJmt54DtNkNlJWZp8oE=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/monitor v1.0.844 h1:ZR7FSnv4k1j0BpJHg6JDbJ6YJ2YfLhX2xVIUcuweKm4=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/monitor v1.0.844/go.mod h1:a7PfDWl0B3QV+g99asQHumDNScEEMl+7lkXP0KXt8Xg=
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/mps v1.0.777 h1:SoH/KkqkEUw8iDmQDZCw5Saf319Ceyt3v8Vqodo8DiY=
diff --git a/tencentcloud/common/cloud_common.go b/tencentcloud/common/cloud_common.go
new file mode 100644
index 0000000000..61c5598112
--- /dev/null
+++ b/tencentcloud/common/cloud_common.go
@@ -0,0 +1,185 @@
+package common
+
+import (
+ "encoding/json"
+ "log"
+ "strconv"
+ "strings"
+ "time"
+
+ cls "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cls/v20201016"
+
+ cam "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam/v20190116"
+ "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/connectivity"
+ "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/internal/helper"
+)
+
+const (
+ // DefaultSearchLogStartTimestamp sync logs start time 2023-11-07 16:41:00
+ DefaultSearchLogStartTimestamp = 1699346460000
+
+ DefaultTopicId = "aef50d54-b17d-4782-8618-a7873203ec29"
+
+ QueryGrammarRule = " AND "
+)
+
+// ResourceAccountInfo 资源账户信息
+type ResourceAccountInfo struct {
+ ResourceType string // 资源类型
+ ResourceName string // 资源名称
+ AccountId string // 主账号ID
+ PrincipalId string // 用户ID
+ UserName string // 用户名
+}
+
+// GetResourceCreatorAccountInfo get resource creator user info
+func GetResourceCreatorAccountInfo(client *connectivity.TencentCloudClient, resourceCreateAction string, resources []*ResourceInstance) map[string]*ResourceAccountInfo {
+ resourceIdToSubAccountInfoMap := make(map[string]*ResourceAccountInfo)
+ if resourceCreateAction == "" {
+ return resourceIdToSubAccountInfoMap
+ }
+
+ request := cls.NewSearchLogRequest()
+ request.From = helper.IntInt64(DefaultSearchLogStartTimestamp)
+ request.To = helper.Int64(CurrentTimeMillisecond())
+ request.TopicId = helper.String(DefaultTopicId)
+
+ for _, r := range resources {
+ query := resourceCreateAction + QueryGrammarRule
+ if r.Id != "" {
+ query = query + r.Id
+ } else if r.Name != "" {
+ query = query + r.Name
+ } else {
+ continue
+ }
+ request.Query = helper.String(query)
+
+ response, err := client.UseClsClient().SearchLog(request)
+ if err != nil {
+ log.Printf("[CRITAL] search resource[%v] log data error: %v", r.Id, err.Error())
+ return resourceIdToSubAccountInfoMap
+ }
+ if response == nil || response.Response == nil {
+ log.Printf("[CRITAL] search resource[%v] log data response is nil", r.Id)
+ return resourceIdToSubAccountInfoMap
+ }
+ if len(response.Response.Results) == 0 {
+ log.Printf("[CRITAL] search resource[%v] log data response results is empty", r.Id)
+ return resourceIdToSubAccountInfoMap
+ }
+
+ result := response.Response.Results[0]
+ if result != nil {
+ var jsonData string
+ if len(*result.LogJson) > 2 {
+ jsonData = *result.LogJson
+ } else if len(*result.RawLog) > 2 {
+ jsonData = *result.RawLog
+ } else {
+ continue
+ }
+
+ resourceAccountInfo := ParseLogJsonData(jsonData)
+ if resourceAccountInfo.PrincipalId == resourceAccountInfo.UserName &&
+ resourceAccountInfo.PrincipalId != resourceAccountInfo.AccountId {
+ userName := GetSubAccountUserName(client, resourceAccountInfo.PrincipalId)
+ resourceAccountInfo.UserName = userName
+ }
+ resourceIdToSubAccountInfoMap[r.Id] = resourceAccountInfo
+ }
+ }
+
+ return resourceIdToSubAccountInfoMap
+}
+
+// GetSubAccountUserName get sub account user name
+func GetSubAccountUserName(client *connectivity.TencentCloudClient, uin string) string {
+ uinNum, err := strconv.ParseUint(uin, 10, 64)
+ if err != nil {
+ log.Printf("[CRITAL] parse uin[%v] to uint64 type error: %v", uin, err.Error())
+ return ""
+ }
+
+ request := cam.NewDescribeSubAccountsRequest()
+
+ uinArray := []*uint64{helper.Uint64(uinNum)}
+ request.FilterSubAccountUin = uinArray
+
+ response, err := client.UseCamClient().DescribeSubAccounts(request)
+ if err != nil {
+ log.Printf("[CRITAL] get sub account[%v] data error: %v", uin, err.Error())
+ return ""
+ }
+ if response == nil || response.Response == nil {
+ log.Printf("[CRITAL] get sub account[%v] data response is nil", uin)
+ return ""
+ }
+
+ name := response.Response.SubAccounts[0].Name
+ return *name
+}
+
+// CurrentTimeMillisecond get the current millisecond timestamp
+func CurrentTimeMillisecond() int64 {
+ return time.Now().UnixNano() / int64(time.Millisecond)
+}
+
+func ParseLogJsonData(jsonData string) *ResourceAccountInfo {
+ if jsonData == "" {
+ return nil
+ }
+
+ var data map[string]interface{}
+ err := json.Unmarshal([]byte(jsonData), &data)
+ if err != nil {
+ log.Printf("[CRITAL] parse log json data[%v] error: %v", jsonData, err.Error())
+ return nil
+ }
+
+ resourceType := ""
+ if v, ok := data["resourceType"]; ok {
+ resourceType = v.(string)
+ }
+ resourceName := ""
+ if v, ok := data["resourceName"]; ok {
+ resourceName = v.(string)
+ if resourceName != "" {
+ resourceName = strings.Split(resourceName, "/")[0]
+ }
+ }
+ accountId, principalId, userName := parseUserIdentityFields(data)
+
+ return &ResourceAccountInfo{
+ ResourceType: resourceType,
+ ResourceName: resourceName,
+ AccountId: accountId,
+ PrincipalId: principalId,
+ UserName: userName,
+ }
+}
+
+func parseUserIdentityFields(data map[string]interface{}) (accountId, principalId, userName string) {
+ if v, ok := data["userIdentity.accountId"]; ok {
+ accountId = v.(string)
+ }
+ if v, ok := data["userIdentity.principalId"]; ok {
+ principalId = v.(string)
+ }
+ if v, ok := data["userIdentity.userName"]; ok {
+ userName = v.(string)
+ }
+ if v, ok := data["userIdentity"]; ok {
+ switch v := v.(type) {
+ case string:
+ var userIdentity map[string]string
+ err := json.Unmarshal([]byte(v), &userIdentity)
+ if err == nil {
+ accountId = userIdentity["accountId"]
+ principalId = userIdentity["principalId"]
+ userName = userIdentity["userName"]
+ }
+ }
+ }
+ return
+}
diff --git a/tencentcloud/common/file_common.go b/tencentcloud/common/file_common.go
new file mode 100644
index 0000000000..1507e9465c
--- /dev/null
+++ b/tencentcloud/common/file_common.go
@@ -0,0 +1,90 @@
+package common
+
+import (
+ "encoding/csv"
+ "log"
+ "os"
+ "path/filepath"
+ "time"
+)
+
+const (
+ SweeperResourceScanDir = "../../../tmp/resource_scan/"
+ SweeperNonKeepResourceScanDir = "../../../tmp/non_keep_resource_scan/"
+)
+
+var ResourceScanHeader = []string{"资源类型", "资源名称", "实例ID", "实例名称", "分类", "创建时长(天)", "创建者用户ID", "创建者用户名"}
+var NonKeepResourceScanHeader = []string{"ResourceType", "ResourceName", "InstanceId", "InstanceName", "PrincipalId", "UserName"}
+
+// WriteCsvFileData write data to csv file
+func WriteCsvFileData(dirPath string, header []string, data [][]string) error {
+ log.Printf("[INFO] write csv file data[%v] to path[%v] start", len(data), dirPath)
+
+ count := 0
+ defer func() {
+ log.Printf("[INFO] write csv file data to path[%v] success count[%v]", dirPath, count)
+ }()
+
+ if len(data) == 0 {
+ return nil
+ }
+
+ err := os.MkdirAll(dirPath, 0755)
+ if err != nil {
+ log.Printf("[CRITAL] create directory %s error: %v", dirPath, err.Error())
+ return err
+ }
+
+ currentDate := time.Now().Format("20060102")
+ filePath := filepath.Join(dirPath, currentDate+".csv")
+
+ _, err = os.Stat(filePath)
+ if os.IsNotExist(err) {
+ err = GenerateCsvFile(filePath, header)
+ if err != nil {
+ log.Printf("[CRITAL] generate csv file error: %v", err.Error())
+ return err
+ }
+ }
+
+ file, err := os.OpenFile(filePath, os.O_APPEND|os.O_WRONLY, 0644)
+ if err != nil {
+ log.Printf("[CRITAL] open csv file error: %v", err.Error())
+ return err
+ }
+ defer file.Close()
+
+ writer := csv.NewWriter(file)
+
+ for _, row := range data {
+ err = writer.Write(row)
+ if err != nil {
+ log.Printf("[CRITAL] write data[%v] to csv file error: %v", row, err.Error())
+ return err
+ }
+ count++
+ }
+ writer.Flush()
+
+ return nil
+}
+
+// GenerateCsvFile generate when csv file does not exist
+func GenerateCsvFile(filePath string, header []string) error {
+ file, err := os.Create(filePath)
+ if err != nil {
+ log.Printf("[CRITAL] create csv file error: %v", err.Error())
+ return err
+ }
+ defer file.Close()
+
+ writer := csv.NewWriter(file)
+ err = writer.Write(header)
+ if err != nil {
+ log.Printf("[CRITAL] write header to csv file error: %v", err.Error())
+ return err
+ }
+ writer.Flush()
+
+ return nil
+}
diff --git a/tencentcloud/common/resource_scan.go b/tencentcloud/common/resource_scan.go
new file mode 100644
index 0000000000..2e7495ac99
--- /dev/null
+++ b/tencentcloud/common/resource_scan.go
@@ -0,0 +1,176 @@
+package common
+
+import (
+ "fmt"
+ "log"
+ "regexp"
+ "strconv"
+ "time"
+
+ "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/connectivity"
+)
+
+const (
+ KeepResource = "keep"
+ NonKeepResource = "non-keep"
+)
+
+// TimeFormats add all possible time formats
+var TimeFormats = []string{
+ time.RFC3339, //ISO8601 UTC time
+ "2006-01-02 15:04:05",
+ // add other time formats here
+}
+
+type ResourceInstance struct {
+ Id string
+ Name string
+ CreatTime string
+ DefaultKeep bool
+}
+
+func ProcessScanCloudResources(client *connectivity.TencentCloudClient, resources, nonKeepResources []*ResourceInstance, resourceCreateAction string) {
+ ProcessResources(client, resources, resourceCreateAction)
+
+ ProcessNonKeepResources(client, nonKeepResources, resourceCreateAction)
+}
+
+// ProcessResources Process all scanned cloud resources
+func ProcessResources(client *connectivity.TencentCloudClient, resources []*ResourceInstance, resourceCreateAction string) {
+ resourceIdToSubAccountInfoMap := GetResourceCreatorAccountInfo(client, resourceCreateAction, resources)
+
+ data := make([][]string, len(resources))
+ for i, r := range resources {
+ isResourceKeep := CheckResourceNameKeep(r.Name)
+ // some resources default to keep
+ if r.DefaultKeep {
+ isResourceKeep = KeepResource
+ }
+
+ creationDuration, err := DaysSinceCreation(r.CreatTime)
+ if err != nil {
+ log.Printf("[CRITAL] compute resource creation duration error: %v", err.Error())
+ }
+
+ var resourceType, resourceName, principalId, userName string
+ creatorAccountInfo := resourceIdToSubAccountInfoMap[r.Id]
+ if creatorAccountInfo != nil {
+ resourceType = creatorAccountInfo.ResourceType
+ resourceName = creatorAccountInfo.ResourceName
+ principalId = creatorAccountInfo.PrincipalId
+ userName = creatorAccountInfo.UserName
+ }
+
+ data[i] = []string{
+ resourceType,
+ resourceName,
+ r.Id,
+ r.Name,
+ isResourceKeep,
+ creationDuration,
+ principalId,
+ userName,
+ }
+ }
+ err := WriteCsvFileData(SweeperResourceScanDir, ResourceScanHeader, data)
+ if err != nil {
+ log.Printf("[CRITAL] write csv file data error: %v", err.Error())
+ }
+}
+
+// ProcessNonKeepResources Processing scanned non-keep cloud resources
+func ProcessNonKeepResources(client *connectivity.TencentCloudClient, nonKeepResources []*ResourceInstance, resourceCreateAction string) {
+ resourceIdToSubAccountInfoMap := GetResourceCreatorAccountInfo(client, resourceCreateAction, nonKeepResources)
+
+ data := make([][]string, len(nonKeepResources))
+ for i, r := range nonKeepResources {
+ var resourceType, resourceName, principalId, userName string
+ creatorAccountInfo := resourceIdToSubAccountInfoMap[r.Id]
+ if creatorAccountInfo != nil {
+ resourceType = creatorAccountInfo.ResourceType
+ resourceName = creatorAccountInfo.ResourceName
+ principalId = creatorAccountInfo.PrincipalId
+ userName = creatorAccountInfo.UserName
+ }
+
+ data[i] = []string{
+ resourceType,
+ resourceName,
+ r.Id,
+ r.Name,
+ principalId,
+ userName,
+ }
+ }
+ err := WriteCsvFileData(SweeperNonKeepResourceScanDir, NonKeepResourceScanHeader, data)
+ if err != nil {
+ log.Printf("[CRITAL] write csv file data error: %v", err.Error())
+ }
+}
+
+// CheckResourceNameKeep check whether to keep resource name
+func CheckResourceNameKeep(name string) string {
+ flag := CheckResourcePersist(name, "")
+ if flag {
+ return KeepResource
+ }
+ return NonKeepResource
+}
+
+// CheckResourcePersist check whether to persist resource
+func CheckResourcePersist(name, createTime string) bool {
+ if name == "" && createTime == "" {
+ return false
+ }
+ parsedTime, _ := ParsedTime(createTime)
+
+ createdWithin30Minutes := false
+ if parsedTime != nil {
+ createdWithin30Minutes = parsedTime.Add(time.Minute * 30).After(time.Now())
+ }
+
+ flag := regexp.MustCompile("^(keep|Default)").MatchString(name)
+ return flag || createdWithin30Minutes
+}
+
+// DaysSinceCreation compute resource creation duration
+func DaysSinceCreation(createTime string) (string, error) {
+ parsedTime, err := ParsedTime(createTime)
+ if err != nil {
+ return "", err
+ }
+
+ duration := time.Since(*parsedTime)
+ days := duration.Hours() / 24
+
+ return fmt.Sprintf("%.2f", days), nil
+}
+
+// ParsedTime parse time
+func ParsedTime(createTime string) (*time.Time, error) {
+ if createTime == "" {
+ return nil, nil
+ }
+
+ var parsedTime time.Time
+ var err error
+
+ timestamp, err := strconv.ParseInt(createTime, 10, 64)
+ if err == nil {
+ parsedTime = time.Unix(timestamp, 0)
+ } else {
+ // try parsing input strings using different time formats
+ for _, format := range TimeFormats {
+ parsedTime, err = time.ParseInLocation(format, createTime, time.Local)
+ if err == nil {
+ break
+ }
+ }
+ }
+
+ if err != nil {
+ log.Printf("[CRITAL] unable to parse create time[%s]", createTime)
+ return nil, fmt.Errorf("unable to parse create time: %v", err.Error())
+ }
+ return &parsedTime, nil
+}
diff --git a/tencentcloud/connectivity/client.go b/tencentcloud/connectivity/client.go
index 4c5744bc56..f01fa02561 100644
--- a/tencentcloud/connectivity/client.go
+++ b/tencentcloud/connectivity/client.go
@@ -8,6 +8,7 @@ import (
"strconv"
"time"
+ billing "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709"
csip "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip/v20221121"
dasb "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/dasb/v20191018"
@@ -202,6 +203,7 @@ type TencentCloudClient struct {
biConn *bi.Client
cdwpgConn *cdwpg.Client
csipConn *csip.Client
+ billingConn *billing.Client
//internal version: replace client begin, please do not modify this annotation and refrain from inserting any code between the beginning and end lines of the annotation.
//internal version: replace client end, please do not modify this annotation and refrain from inserting any code between the beginning and end lines of the annotation.
}
@@ -1379,6 +1381,20 @@ func (me *TencentCloudClient) UseCdwpgClient() *cdwpg.Client {
return me.cdwpgConn
}
+// UseBillingClient returns billing client for service
+func (me *TencentCloudClient) UseBillingClient() *billing.Client {
+ if me.billingConn != nil {
+ return me.billingConn
+ }
+
+ cpf := me.NewClientProfile(300)
+ cpf.Language = "zh-CN"
+ me.billingConn, _ = billing.NewClient(me.Credential, me.Region, cpf)
+ me.billingConn.WithHttpTransport(&LogRoundTripper{})
+
+ return me.billingConn
+}
+
// UseCsipClient returns csip client for service
func (me *TencentCloudClient) UseCsipClient() *csip.Client {
if me.csipConn != nil {
diff --git a/tencentcloud/services/as/resource_tc_as_attachment_test.go b/tencentcloud/services/as/resource_tc_as_attachment_test.go
index e8d95576c1..80448174ad 100644
--- a/tencentcloud/services/as/resource_tc_as_attachment_test.go
+++ b/tencentcloud/services/as/resource_tc_as_attachment_test.go
@@ -28,13 +28,31 @@ func testSweepAsAttachment(r string) error {
logId := tccommon.GetLogId(tccommon.ContextNil)
ctx := context.WithValue(context.TODO(), tccommon.LogIdKey, logId)
cli, _ := tcacctest.SharedClientForRegion(r)
- asService := svcas.NewAsService(cli.(tccommon.ProviderMeta).GetAPIV3Conn())
+ client := cli.(tccommon.ProviderMeta).GetAPIV3Conn()
+ asService := svcas.NewAsService(client)
scalingGroups, err := asService.DescribeAutoScalingGroupByFilter(ctx, "", "", "", nil)
if err != nil {
return fmt.Errorf("list scaling group error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range scalingGroups {
+ if !tccommon.CheckResourcePersist(*v.AutoScalingGroupName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.AutoScalingGroupId,
+ Name: *v.AutoScalingGroupName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.AutoScalingGroupId,
+ Name: *v.AutoScalingGroupName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateAutoScalingGroup")
+
for _, v := range scalingGroups {
scalingGroupId := *v.AutoScalingGroupId
scalingGroupName := *v.AutoScalingGroupName
diff --git a/tencentcloud/services/cam/resource_tc_cam_group_test.go b/tencentcloud/services/cam/resource_tc_cam_group_test.go
index becdd2574d..d06f62ba20 100644
--- a/tencentcloud/services/cam/resource_tc_cam_group_test.go
+++ b/tencentcloud/services/cam/resource_tc_cam_group_test.go
@@ -4,6 +4,7 @@ import (
"context"
"fmt"
"log"
+ "strconv"
"testing"
tcacctest "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/acctest"
@@ -33,6 +34,24 @@ func init() {
if err != nil {
return err
}
+
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range groups {
+ if !tccommon.CheckResourcePersist(*v.GroupName, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: strconv.FormatUint(*v.GroupId, 10),
+ Name: *v.GroupName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: strconv.FormatUint(*v.GroupId, 10),
+ Name: *v.GroupName,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateGroup")
+
for _, v := range groups {
name := *v.GroupName
diff --git a/tencentcloud/services/cbs/resource_tc_cbs_storage_test.go b/tencentcloud/services/cbs/resource_tc_cbs_storage_test.go
index 76b2b7977d..7840cedf5e 100644
--- a/tencentcloud/services/cbs/resource_tc_cbs_storage_test.go
+++ b/tencentcloud/services/cbs/resource_tc_cbs_storage_test.go
@@ -27,11 +27,27 @@ func init() {
service := localcbs.NewCbsService(client)
disks, err := service.DescribeDisksByFilter(ctx, nil)
-
if err != nil {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range disks {
+ if !tccommon.CheckResourcePersist(*v.DiskName, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.DiskId,
+ Name: *v.DiskName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.DiskId,
+ Name: *v.DiskName,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateDisks")
+
for i := range disks {
disk := disks[i]
id := *disk.DiskId
diff --git a/tencentcloud/services/ccn/resource_tc_ccn_test.go b/tencentcloud/services/ccn/resource_tc_ccn_test.go
index 8b970e5cdc..fae4f7c7ad 100644
--- a/tencentcloud/services/ccn/resource_tc_ccn_test.go
+++ b/tencentcloud/services/ccn/resource_tc_ccn_test.go
@@ -32,15 +32,32 @@ func testSweepCcnInstance(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := localccn.NewVpcService(client.GetAPIV3Conn())
+ vpcService := localccn.NewVpcService(client)
instances, err := vpcService.DescribeCcns(ctx, "", "")
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(v.Name(), v.CreateTime()) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: v.CcnId(),
+ Name: v.Name(),
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: v.CcnId(),
+ Name: v.Name(),
+ CreatTime: v.CreateTime(),
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateCcn")
+
for _, v := range instances {
instanceId := v.CcnId()
instanceName := v.Name()
diff --git a/tencentcloud/services/cdb/resource_tc_mysql_instance.go b/tencentcloud/services/cdb/resource_tc_mysql_instance.go
index fa26613718..9da7393edf 100644
--- a/tencentcloud/services/cdb/resource_tc_mysql_instance.go
+++ b/tencentcloud/services/cdb/resource_tc_mysql_instance.go
@@ -1068,7 +1068,7 @@ func mysqlAllInstanceRoleUpdate(ctx context.Context, d *schema.ResourceData, met
memSize := int64(d.Get("mem_size").(int))
cpu := int64(d.Get("cpu").(int))
volumeSize := int64(d.Get("volume_size").(int))
- slaveDeployMode := int64(d.Get("slave_deploy_mode").(int))
+ var slaveDeployMode int64 = -1
slaveSyncMode := int64(d.Get("slave_sync_mode").(int))
deviceType := ""
firstSlaveZone := ""
@@ -1095,6 +1095,12 @@ func mysqlAllInstanceRoleUpdate(ctx context.Context, d *schema.ResourceData, met
waitSwitch = int64(v.(int))
}
+ if d.HasChange("slave_deploy_mode") {
+ if v, ok := d.GetOkExists("slave_deploy_mode"); ok {
+ slaveDeployMode = int64(v.(int))
+ }
+ }
+
asyncRequestId, err := mysqlService.UpgradeDBInstance(ctx, d.Id(), memSize, cpu, volumeSize, fastUpgrade, deviceType, slaveDeployMode, slaveSyncMode, firstSlaveZone, secondSlaveZone, waitSwitch)
if err != nil {
diff --git a/tencentcloud/services/cdb/resource_tc_mysql_instance_test.go b/tencentcloud/services/cdb/resource_tc_mysql_instance_test.go
index 08192e1454..7aebc1cc3a 100644
--- a/tencentcloud/services/cdb/resource_tc_mysql_instance_test.go
+++ b/tencentcloud/services/cdb/resource_tc_mysql_instance_test.go
@@ -47,12 +47,30 @@ func testSweepMySQLInstance(region string) error {
if err != nil {
return err
}
+ items := response.Response.Items
- if len(response.Response.Items) == 0 {
+ if len(items) == 0 {
return nil
}
- for _, v := range response.Response.Items {
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range items {
+ if !tccommon.CheckResourcePersist(*v.InstanceId, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.InstanceId,
+ Name: *v.InstanceName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.InstanceId,
+ Name: *v.InstanceName,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateDBInstance")
+
+ for _, v := range items {
id := *v.InstanceId
name := *v.InstanceName
if tcacctest.IsResourcePersist(name, nil) {
diff --git a/tencentcloud/services/clb/data_source_tc_clb_attachments.go b/tencentcloud/services/clb/data_source_tc_clb_attachments.go
index 490fc0b3bf..08dc06d366 100644
--- a/tencentcloud/services/clb/data_source_tc_clb_attachments.go
+++ b/tencentcloud/services/clb/data_source_tc_clb_attachments.go
@@ -75,6 +75,11 @@ func DataSourceTencentCloudClbServerAttachments() *schema.Resource {
Computed: true,
Description: "Id of the backend server.",
},
+ "eni_ip": {
+ Type: schema.TypeString,
+ Computed: true,
+ Description: "Elastic network card unique ID.",
+ },
"port": {
Type: schema.TypeInt,
Computed: true,
diff --git a/tencentcloud/services/clb/resource_tc_clb_instance_test.go b/tencentcloud/services/clb/resource_tc_clb_instance_test.go
index 844633e28f..94d71f4490 100644
--- a/tencentcloud/services/clb/resource_tc_clb_instance_test.go
+++ b/tencentcloud/services/clb/resource_tc_clb_instance_test.go
@@ -47,6 +47,23 @@ func testSweepClbInstance(region string) error {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range res {
+ if !tccommon.CheckResourcePersist(*v.LoadBalancerName, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.LoadBalancerId,
+ Name: *v.LoadBalancerName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.LoadBalancerId,
+ Name: *v.LoadBalancerName,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateLoadBalancer")
+
if len(res) > 0 {
for _, v := range res {
id := *v.LoadBalancerId
diff --git a/tencentcloud/services/clb/service_tencentcloud_clb.go b/tencentcloud/services/clb/service_tencentcloud_clb.go
index 53c66d6c6a..c62f9c2ed3 100644
--- a/tencentcloud/services/clb/service_tencentcloud_clb.go
+++ b/tencentcloud/services/clb/service_tencentcloud_clb.go
@@ -1232,13 +1232,12 @@ func (me *ClbService) DescribeTargetGroups(ctx context.Context, targetGroupId st
if targetGroupId != "" {
request.TargetGroupIds = []*string{&targetGroupId}
}
- request.Filters = make([]*clb.Filter, 0, len(filters))
for k, v := range filters {
- filter := clb.Filter{
+ tmpFilter := clb.Filter{
Name: helper.String(k),
Values: []*string{helper.String(v)},
}
- request.Filters = append(request.Filters, &filter)
+ request.Filters = append(request.Filters, &tmpFilter)
}
var offset uint64 = 0
diff --git a/tencentcloud/services/cls/resource_tc_cls_topic_test.go b/tencentcloud/services/cls/resource_tc_cls_topic_test.go
index 282e70153b..f9c6b66023 100644
--- a/tencentcloud/services/cls/resource_tc_cls_topic_test.go
+++ b/tencentcloud/services/cls/resource_tc_cls_topic_test.go
@@ -31,15 +31,32 @@ func testSweepClsTopic(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- clsService := localcls.NewClsService(client.GetAPIV3Conn())
+ clsService := localcls.NewClsService(client)
instances, err := clsService.DescribeClsTopicByFilter(ctx, nil)
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.TopicName, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.TopicId,
+ Name: *v.TopicName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.TopicId,
+ Name: *v.TopicName,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateTopic")
+
for _, v := range instances {
instanceId := v.TopicId
instanceName := v.TopicName
diff --git a/tencentcloud/services/cos/resource_tc_cos_bucket_test.go b/tencentcloud/services/cos/resource_tc_cos_bucket_test.go
index b14d648f42..6f9e0ced2c 100644
--- a/tencentcloud/services/cos/resource_tc_cos_bucket_test.go
+++ b/tencentcloud/services/cos/resource_tc_cos_bucket_test.go
@@ -31,14 +31,29 @@ func testSweepCosBuckets(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- cosService := localcos.NewCosService(client.GetAPIV3Conn())
+ cosService := localcos.NewCosService(client)
buckets, err := cosService.ListBuckets(ctx)
if err != nil {
return fmt.Errorf("list buckets error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range buckets {
+ if !tccommon.CheckResourcePersist(*v.Name, v.CreationDate.Format("2006-01-02 15:04:05")) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Name: *v.Name,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Name: *v.Name,
+ CreatTime: v.CreationDate.Format("2006-01-02 15:04:05"),
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "PutBucket")
+
//prefix := regexp.MustCompile("^(tf|test)-")
for _, v := range buckets {
diff --git a/tencentcloud/services/csip/resource_tc_csip_risk_center.go b/tencentcloud/services/csip/resource_tc_csip_risk_center.go
index 6447236422..59125452d1 100644
--- a/tencentcloud/services/csip/resource_tc_csip_risk_center.go
+++ b/tencentcloud/services/csip/resource_tc_csip_risk_center.go
@@ -4,6 +4,7 @@ import (
"context"
"fmt"
"log"
+ "strings"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
@@ -287,6 +288,29 @@ func resourceTencentCloudCsipRiskCenterCreate(d *schema.ResourceData, meta inter
if dMap, ok := helper.InterfacesHeadMap(d, "task_advance_cfg"); ok {
taskAdvanceCFG := csip.TaskAdvanceCFG{}
+ if v, ok := dMap["port_risk"]; ok {
+ for _, item := range v.([]interface{}) {
+ portRiskMap := item.(map[string]interface{})
+ portRiskAdvanceCFGParamItem := csip.PortRiskAdvanceCFGParamItem{}
+ if v, ok := portRiskMap["port_sets"]; ok {
+ portRiskAdvanceCFGParamItem.PortSets = helper.String(v.(string))
+ }
+
+ if v, ok := portRiskMap["check_type"]; ok {
+ portRiskAdvanceCFGParamItem.CheckType = helper.IntInt64(v.(int))
+ }
+
+ if v, ok := portRiskMap["detail"]; ok {
+ portRiskAdvanceCFGParamItem.Detail = helper.String(v.(string))
+ }
+
+ if v, ok := portRiskMap["enable"]; ok {
+ portRiskAdvanceCFGParamItem.Enable = helper.IntInt64(v.(int))
+ }
+ taskAdvanceCFG.PortRisk = append(taskAdvanceCFG.PortRisk, &portRiskAdvanceCFGParamItem)
+ }
+ }
+
if v, ok := dMap["vul_risk"]; ok {
for _, item := range v.([]interface{}) {
vulRiskMap := item.(map[string]interface{})
@@ -381,7 +405,7 @@ func resourceTencentCloudCsipRiskCenterCreate(d *schema.ResourceData, meta inter
},
}
- err = resource.Retry(tccommon.ReadRetryTimeout*40, func() *resource.RetryError {
+ err = resource.Retry(tccommon.ReadRetryTimeout*60, func() *resource.RetryError {
result, e := meta.(tccommon.ProviderMeta).GetAPIV3Conn().UseCsipClient().DescribeScanTaskList(waitRequest)
if e != nil {
return tccommon.RetryError(e)
@@ -440,7 +464,8 @@ func resourceTencentCloudCsipRiskCenterRead(d *schema.ResourceData, meta interfa
}
if riskCenter.ScanItem != nil {
- _ = d.Set("scan_item", riskCenter.ScanItem)
+ tmpList := strings.Split(*riskCenter.ScanItem, tccommon.COMMA_SP)
+ _ = d.Set("scan_item", tmpList)
}
if riskCenter.Assets != nil {
@@ -509,6 +534,7 @@ func resourceTencentCloudCsipRiskCenterUpdate(d *schema.ResourceData, meta inter
)
request.TaskId = &taskId
+ request.ScanPlanType = helper.IntInt64(1)
if v, ok := d.GetOk("task_name"); ok {
request.TaskName = helper.String(v.(string))
@@ -574,6 +600,29 @@ func resourceTencentCloudCsipRiskCenterUpdate(d *schema.ResourceData, meta inter
if dMap, ok := helper.InterfacesHeadMap(d, "task_advance_cfg"); ok {
taskAdvanceCFG := csip.TaskAdvanceCFG{}
+ if v, ok := dMap["port_risk"]; ok {
+ for _, item := range v.([]interface{}) {
+ portRiskMap := item.(map[string]interface{})
+ portRiskAdvanceCFGParamItem := csip.PortRiskAdvanceCFGParamItem{}
+ if v, ok := portRiskMap["port_sets"]; ok {
+ portRiskAdvanceCFGParamItem.PortSets = helper.String(v.(string))
+ }
+
+ if v, ok := portRiskMap["check_type"]; ok {
+ portRiskAdvanceCFGParamItem.CheckType = helper.IntInt64(v.(int))
+ }
+
+ if v, ok := portRiskMap["detail"]; ok {
+ portRiskAdvanceCFGParamItem.Detail = helper.String(v.(string))
+ }
+
+ if v, ok := portRiskMap["enable"]; ok {
+ portRiskAdvanceCFGParamItem.Enable = helper.IntInt64(v.(int))
+ }
+ taskAdvanceCFG.PortRisk = append(taskAdvanceCFG.PortRisk, &portRiskAdvanceCFGParamItem)
+ }
+ }
+
if v, ok := dMap["vul_risk"]; ok {
for _, item := range v.([]interface{}) {
vulRiskMap := item.(map[string]interface{})
diff --git a/tencentcloud/services/csip/resource_tc_csip_risk_center.md b/tencentcloud/services/csip/resource_tc_csip_risk_center.md
index 17f9c1c774..2084da9ef5 100644
--- a/tencentcloud/services/csip/resource_tc_csip_risk_center.md
+++ b/tencentcloud/services/csip/resource_tc_csip_risk_center.md
@@ -38,39 +38,40 @@ resource "tencentcloud_csip_risk_center" "example" {
If task_mode is 2
```hcl
-resource "tencentcloud_csip_risk_center" "example" {
+resource "tencentcloud_csip_risk_center" "example1" {
task_name = "tf_example"
scan_asset_type = 2
- scan_item = ["port", "poc"]
+ scan_item = ["port", "configrisk", "poc", "weakpass"]
task_mode = 2
assets {
- asset_name = "iac-test"
- instance_type = "1"
- asset_type = "PublicIp"
- asset = "49.232.172.248"
- region = "ap-beijing"
- }
-
- assets {
- asset_name = "iac-test"
- instance_type = "POSTGRES"
- asset_type = "Db"
- asset = "postgres-fnexv5bj"
+ asset_name = "sub machine of tke"
+ instance_type = "Instance"
+ asset_type = "CVM"
+ asset = "ins-9p3dkkwy"
region = "ap-guangzhou"
}
task_advance_cfg {
port_risk {
check_type = 0
- detail = "22、8080、80、443、3380、3389常见流量端口"
+ detail = "22、8080、80、443、3380、3389常见流量端"
port_sets = "常见端口"
enable = 1
}
vul_risk {
- risk_id = "b52a4fcc1f24fa323b87cc41f370aa43"
+ risk_id = "f79e371ce5f644f0fdc72a143144c4b2"
enable = 1
}
+ weak_pwd_risk {
+ check_item_id = 50
+ enable = 1
+ }
+ cfg_risk {
+ item_id = "02c9337f-a6da-49b4-8858-64663a02b79f"
+ enable = 1
+ resource_type = "cdb;rds"
+ }
}
}
```
diff --git a/tencentcloud/services/csip/resource_tc_csip_risk_center_test.go b/tencentcloud/services/csip/resource_tc_csip_risk_center_test.go
index 36f0014c85..5c3a59baeb 100644
--- a/tencentcloud/services/csip/resource_tc_csip_risk_center_test.go
+++ b/tencentcloud/services/csip/resource_tc_csip_risk_center_test.go
@@ -23,13 +23,9 @@ func TestAccTencentCloudCsipRiskCenterResource_basic(t *testing.T) {
resource.TestCheckResourceAttr("tencentcloud_csip_risk_center.example", "task_name", "tf_example"),
resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "scan_asset_type"),
resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "scan_item"),
- resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "scan_plan_type"),
- resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "assets"),
- resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "scan_plan_content"),
- resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "self_defining_assets"),
- resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "scan_from"),
- resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "task_advance_cfg"),
+ resource.TestCheckResourceAttr("tencentcloud_csip_risk_center.example", "scan_plan_type", "46 51 16 */1 * * *"),
resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "task_mode"),
+ resource.TestCheckResourceAttrSet("tencentcloud_csip_risk_center.example", "assets"),
),
},
},
@@ -39,10 +35,17 @@ func TestAccTencentCloudCsipRiskCenterResource_basic(t *testing.T) {
const testAccCsipRiskCenter = `
resource "tencentcloud_csip_risk_center" "example" {
task_name = "tf_example"
- scan_asset_type = 3
- scan_item = ["port", "poc"]
- scan_plan_type = 0
+ scan_asset_type = 1
+ scan_item = ["port", "poc", "weakpass"]
scan_plan_content = "46 51 16 */1 * * *"
- task_mode = 1
+ task_mode = 0
+
+ assets {
+ asset_name = "iac-test"
+ instance_type = "1"
+ asset_type = "PublicIp"
+ asset = "49.232.172.248"
+ region = "ap-beijing"
+ }
}
`
diff --git a/tencentcloud/services/cvm/resource_tc_instance.go b/tencentcloud/services/cvm/resource_tc_instance.go
index c06b99e310..f994d7282f 100644
--- a/tencentcloud/services/cvm/resource_tc_instance.go
+++ b/tencentcloud/services/cvm/resource_tc_instance.go
@@ -1455,30 +1455,17 @@ func resourceTencentCloudInstanceDelete(d *schema.ResourceData, meta interface{}
return err
}
- // wait ip release
- if len(instance.PrivateIpAddresses) > 0 {
- vpcService := vpc.NewVpcService(meta.(tccommon.ProviderMeta).GetAPIV3Conn())
- params := make(map[string]interface{})
- params["VpcId"] = instance.VirtualPrivateCloud.VpcId
- params["SubnetId"] = instance.VirtualPrivateCloud.SubnetId
- params["IpAddresses"] = instance.PrivateIpAddresses
- err := resource.Retry(5*tccommon.ReadRetryTimeout, func() *resource.RetryError {
- usedIpAddress, errRet := vpcService.DescribeVpcUsedIpAddressByFilter(ctx, params)
- if errRet != nil {
- return tccommon.RetryError(errRet, tccommon.InternalError)
- }
- if len(usedIpAddress) > 0 {
- return resource.RetryableError(fmt.Errorf("wait cvm private ip release..."))
- }
+ vpcService := vpc.NewVpcService(meta.(tccommon.ProviderMeta).GetAPIV3Conn())
- return nil
- })
+ if notExist {
+ err := waitIpRelease(ctx, vpcService, instance)
if err != nil {
return err
}
+ return nil
}
- if notExist || !forceDelete {
+ if !forceDelete {
return nil
}
@@ -1592,6 +1579,11 @@ func resourceTencentCloudInstanceDelete(d *schema.ResourceData, meta interface{}
}
}
}
+
+ err = waitIpRelease(ctx, vpcService, instance)
+ if err != nil {
+ return err
+ }
return nil
}
@@ -1702,3 +1694,28 @@ func waitForOperationFinished(d *schema.ResourceData, meta interface{}, timeout
}
return nil
}
+
+func waitIpRelease(ctx context.Context, vpcService vpc.VpcService, instance *cvm.Instance) error {
+ // wait ip release
+ if len(instance.PrivateIpAddresses) > 0 {
+ params := make(map[string]interface{})
+ params["VpcId"] = instance.VirtualPrivateCloud.VpcId
+ params["SubnetId"] = instance.VirtualPrivateCloud.SubnetId
+ params["IpAddresses"] = instance.PrivateIpAddresses
+ err := resource.Retry(5*tccommon.ReadRetryTimeout, func() *resource.RetryError {
+ usedIpAddress, errRet := vpcService.DescribeVpcUsedIpAddressByFilter(ctx, params)
+ if errRet != nil {
+ return tccommon.RetryError(errRet, tccommon.InternalError)
+ }
+ if len(usedIpAddress) > 0 {
+ return resource.RetryableError(fmt.Errorf("wait cvm private ip release..."))
+ }
+
+ return nil
+ })
+ if err != nil {
+ return err
+ }
+ }
+ return nil
+}
diff --git a/tencentcloud/services/cvm/resource_tc_instance_test.go b/tencentcloud/services/cvm/resource_tc_instance_test.go
index 5e9e8d6e54..f17dfdba11 100644
--- a/tencentcloud/services/cvm/resource_tc_instance_test.go
+++ b/tencentcloud/services/cvm/resource_tc_instance_test.go
@@ -31,15 +31,32 @@ func testSweepCvmInstance(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- cvmService := svccvm.NewCvmService(client.GetAPIV3Conn())
+ cvmService := svccvm.NewCvmService(client)
instances, err := cvmService.DescribeInstanceByFilter(ctx, nil, nil)
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.InstanceName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.InstanceId,
+ Name: *v.InstanceName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.InstanceId,
+ Name: *v.InstanceName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "RunInstances")
+
for _, v := range instances {
instanceId := *v.InstanceId
//instanceName := *v.InstanceName
@@ -102,6 +119,32 @@ func TestAccTencentCloudInstanceResource_Basic(t *testing.T) {
})
}
+func TestAccTencentCloudInstanceResource_PrepaidBasic(t *testing.T) {
+ t.Parallel()
+
+ id := "tencentcloud_instance.cvm_prepaid_basic"
+ resource.Test(t, resource.TestCase{
+ PreCheck: func() { tcacctest.AccPreCheck(t) },
+ IDRefreshName: id,
+ Providers: tcacctest.AccProviders,
+ Steps: []resource.TestStep{
+ {
+ Config: testAccTencentCloudInstancePrepaidBasic,
+ Check: resource.ComposeTestCheckFunc(
+ tcacctest.AccCheckTencentCloudDataSourceID(id),
+ testAccCheckTencentCloudInstanceExists(id),
+ resource.TestCheckResourceAttr(id, "instance_status", "RUNNING"),
+ resource.TestCheckResourceAttrSet(id, "private_ip"),
+ resource.TestCheckResourceAttrSet(id, "vpc_id"),
+ resource.TestCheckResourceAttrSet(id, "subnet_id"),
+ resource.TestCheckResourceAttrSet(id, "project_id"),
+ resource.TestCheckResourceAttr(id, "tags.hostname", "tci"),
+ ),
+ },
+ },
+ })
+}
+
func TestAccTencentCloudInstanceResource_WithDataDisk(t *testing.T) {
t.Parallel()
@@ -756,6 +799,26 @@ resource "tencentcloud_instance" "cvm_basic" {
}
`
+const testAccTencentCloudInstancePrepaidBasic = tcacctest.DefaultInstanceVariable + `
+resource "tencentcloud_instance" "cvm_prepaid_basic" {
+ instance_name = var.instance_name
+ availability_zone = var.availability_cvm_zone
+ image_id = data.tencentcloud_images.default.images.0.image_id
+ instance_type = data.tencentcloud_instance_types.default.instance_types.0.instance_type
+ vpc_id = var.cvm_vpc_id
+ subnet_id = var.cvm_subnet_id
+ system_disk_type = "CLOUD_PREMIUM"
+ project_id = 0
+ instance_charge_type = "PREPAID"
+ instance_charge_type_prepaid_period = 1
+ instance_charge_type_prepaid_renew_flag = "NOTIFY_AND_MANUAL_RENEW"
+ force_delete = true
+ tags = {
+ hostname = "tci"
+ }
+}
+`
+
const testAccTencentCloudInstanceWithDataDiskOrder = tcacctest.DefaultInstanceVariable + `
resource "tencentcloud_instance" "foo" {
instance_name = var.instance_name
diff --git a/tencentcloud/services/scf/resource_tc_scf_function_test.go b/tencentcloud/services/scf/resource_tc_scf_function_test.go
index 6ef152784d..405c7c1e66 100644
--- a/tencentcloud/services/scf/resource_tc_scf_function_test.go
+++ b/tencentcloud/services/scf/resource_tc_scf_function_test.go
@@ -44,6 +44,24 @@ func init() {
if err != nil {
continue
}
+
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range funs {
+ if !tccommon.CheckResourcePersist(*v.FunctionName, *v.AddTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.FunctionId,
+ Name: *v.FunctionName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.FunctionId,
+ Name: *v.FunctionName,
+ CreatTime: *v.AddTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateFunction")
+
for _, fun := range funs {
createTime := tccommon.StringToTime(*fun.AddTime)
now := time.Now()
diff --git a/tencentcloud/services/sqlserver/resource_tc_sqlserver_account_test.go b/tencentcloud/services/sqlserver/resource_tc_sqlserver_account_test.go
index db193dc281..e17d039f9a 100644
--- a/tencentcloud/services/sqlserver/resource_tc_sqlserver_account_test.go
+++ b/tencentcloud/services/sqlserver/resource_tc_sqlserver_account_test.go
@@ -46,6 +46,21 @@ func init() {
accounts, _ := service.DescribeSqlserverAccounts(ctx, instanceId)
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range accounts {
+ if !tccommon.CheckResourcePersist(*v.Name, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Name: *v.Name,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Name: *v.Name,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateAccount")
+
for i := range accounts {
account := accounts[i]
name := *account.Name
diff --git a/tencentcloud/services/sqlserver/resource_tc_sqlserver_db_test.go b/tencentcloud/services/sqlserver/resource_tc_sqlserver_db_test.go
index 3ae817944f..6c210b0527 100644
--- a/tencentcloud/services/sqlserver/resource_tc_sqlserver_db_test.go
+++ b/tencentcloud/services/sqlserver/resource_tc_sqlserver_db_test.go
@@ -51,11 +51,25 @@ func init() {
}
dbs, err := service.DescribeDBsOfInstance(ctx, insId)
-
if err != nil {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range dbs {
+ if !tccommon.CheckResourcePersist(*v.Name, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Name: *v.Name,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Name: *v.Name,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateDB")
+
for i := range dbs {
db := dbs[i]
if !strings.HasPrefix(*db.Name, "test") {
diff --git a/tencentcloud/services/sqlserver/resource_tc_sqlserver_instance_test.go b/tencentcloud/services/sqlserver/resource_tc_sqlserver_instance_test.go
index fc8998b13c..3d6b07f30b 100644
--- a/tencentcloud/services/sqlserver/resource_tc_sqlserver_instance_test.go
+++ b/tencentcloud/services/sqlserver/resource_tc_sqlserver_instance_test.go
@@ -36,6 +36,23 @@ func init() {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.Name, *v.CreateTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.InstanceId,
+ Name: *v.Name,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.InstanceId,
+ Name: *v.Name,
+ CreatTime: *v.CreateTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateDBInstances")
+
err = batchDeleteSQLServerInstances(ctx, service, instances)
if err != nil {
diff --git a/tencentcloud/services/tcr/resource_tc_tcr_customized_domain_test.go b/tencentcloud/services/tcr/resource_tc_tcr_customized_domain_test.go
index 9a69e64d1f..b3b6c35f1b 100644
--- a/tencentcloud/services/tcr/resource_tc_tcr_customized_domain_test.go
+++ b/tencentcloud/services/tcr/resource_tc_tcr_customized_domain_test.go
@@ -25,7 +25,8 @@ func testSweepTcrCustomizedDomain(r string) error {
logId := tccommon.GetLogId(tccommon.ContextNil)
ctx := context.WithValue(context.TODO(), tccommon.LogIdKey, logId)
cli, _ := tcacctest.SharedClientForRegion(r)
- tcrService := svctcr.NewTCRService(cli.(tccommon.ProviderMeta).GetAPIV3Conn())
+ client := cli.(tccommon.ProviderMeta).GetAPIV3Conn()
+ tcrService := svctcr.NewTCRService(client)
domains, err := tcrService.DescribeTcrCustomizedDomainById(ctx, tcacctest.DefaultTCRInstanceId, nil)
if err != nil {
@@ -35,6 +36,22 @@ func testSweepTcrCustomizedDomain(r string) error {
return nil
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range domains {
+ if !tccommon.CheckResourcePersist(*v.DomainName, "") {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.RegistryId,
+ Name: *v.DomainName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.RegistryId,
+ Name: *v.DomainName,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateInstanceCustomizedDomain")
+
for _, v := range domains {
delName := *v.DomainName
diff --git a/tencentcloud/services/tcr/resource_tc_tcr_immutable_tag_rule_test.go b/tencentcloud/services/tcr/resource_tc_tcr_immutable_tag_rule_test.go
index 2a07120bc2..744f075828 100644
--- a/tencentcloud/services/tcr/resource_tc_tcr_immutable_tag_rule_test.go
+++ b/tencentcloud/services/tcr/resource_tc_tcr_immutable_tag_rule_test.go
@@ -31,7 +31,8 @@ func testSweepTcrImmutableTagRule(r string) error {
logId := tccommon.GetLogId(tccommon.ContextNil)
ctx := context.WithValue(context.TODO(), tccommon.LogIdKey, logId)
cli, _ := tcacctest.SharedClientForRegion(r)
- tcrService := svctcr.NewTCRService(cli.(tccommon.ProviderMeta).GetAPIV3Conn())
+ client := cli.(tccommon.ProviderMeta).GetAPIV3Conn()
+ tcrService := svctcr.NewTCRService(client)
// the non-keep namespace will be removed directly when run sweeper tencentcloud_tcr_namespace
// so... only need to care about the rules under the keep namespace
@@ -45,6 +46,20 @@ func testSweepTcrImmutableTagRule(r string) error {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range rules {
+ if !tccommon.CheckResourcePersist("", "") {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: helper.Int64ToStr(*v.RuleId),
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: helper.Int64ToStr(*v.RuleId),
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateImmutableTagRules")
+
for _, rule := range rules {
ruleId := helper.Int64ToStr(*rule.RuleId)
diff --git a/tencentcloud/services/tcr/resource_tc_tcr_instance_test.go b/tencentcloud/services/tcr/resource_tc_tcr_instance_test.go
index 4cddb0dbe5..5f2f1e1486 100644
--- a/tencentcloud/services/tcr/resource_tc_tcr_instance_test.go
+++ b/tencentcloud/services/tcr/resource_tc_tcr_instance_test.go
@@ -36,6 +36,23 @@ func init() {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.RegistryName, *v.CreatedAt) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.RegistryId,
+ Name: *v.RegistryName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.RegistryId,
+ Name: *v.RegistryName,
+ CreatTime: *v.CreatedAt,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateInstance")
+
for i := range instances {
ins := instances[i]
id := *ins.RegistryId
diff --git a/tencentcloud/services/tcr/resource_tc_tcr_namespace_test.go b/tencentcloud/services/tcr/resource_tc_tcr_namespace_test.go
index 75d502dbe8..af6e9c7261 100644
--- a/tencentcloud/services/tcr/resource_tc_tcr_namespace_test.go
+++ b/tencentcloud/services/tcr/resource_tc_tcr_namespace_test.go
@@ -3,6 +3,7 @@ package tcr_test
import (
"context"
"fmt"
+ "strconv"
"strings"
"testing"
@@ -52,6 +53,23 @@ func init() {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range namespaces {
+ if !tccommon.CheckResourcePersist(*v.Name, *v.CreationTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: strconv.FormatInt(*v.NamespaceId, 10),
+ Name: *v.Name,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: strconv.FormatInt(*v.NamespaceId, 10),
+ Name: *v.Name,
+ CreatTime: *v.CreationTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateNamespace")
+
for i := range namespaces {
n := namespaces[i]
if tcacctest.IsResourcePersist(*n.Name, nil) {
diff --git a/tencentcloud/services/tcr/resource_tc_tcr_repository_test.go b/tencentcloud/services/tcr/resource_tc_tcr_repository_test.go
index 20aafbcd96..7ee81825f7 100644
--- a/tencentcloud/services/tcr/resource_tc_tcr_repository_test.go
+++ b/tencentcloud/services/tcr/resource_tc_tcr_repository_test.go
@@ -29,7 +29,8 @@ func testSweepTCRRepository(r string) error {
logId := tccommon.GetLogId(tccommon.ContextNil)
ctx := context.WithValue(context.TODO(), tccommon.LogIdKey, logId)
cli, _ := tcacctest.SharedClientForRegion(r)
- tcrService := svctcr.NewTCRService(cli.(tccommon.ProviderMeta).GetAPIV3Conn())
+ client := cli.(tccommon.ProviderMeta).GetAPIV3Conn()
+ tcrService := svctcr.NewTCRService(client)
var filters []*tcr.Filter
filters = append(filters, &tcr.Filter{
@@ -54,6 +55,27 @@ func testSweepTCRRepository(r string) error {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range repos {
+ names := strings.Split(*v.Name, "/")
+ if len(names) != 2 {
+ continue
+ }
+ repoName := names[1]
+
+ if !tccommon.CheckResourcePersist(repoName, *v.CreationTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Name: repoName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Name: repoName,
+ CreatTime: *v.CreationTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateRepository")
+
for i := range repos {
n := repos[i]
names := strings.Split(*n.Name, "/")
diff --git a/tencentcloud/services/tcr/resource_tc_tcr_token_test.go b/tencentcloud/services/tcr/resource_tc_tcr_token_test.go
index 892990d775..4273892e08 100644
--- a/tencentcloud/services/tcr/resource_tc_tcr_token_test.go
+++ b/tencentcloud/services/tcr/resource_tc_tcr_token_test.go
@@ -54,6 +54,21 @@ func init() {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range tokens {
+ if !tccommon.CheckResourcePersist("", *v.CreatedAt) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.Id,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.Id,
+ CreatTime: *v.CreatedAt,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateInstanceToken")
+
for i := range tokens {
token := tokens[i]
id := *token.Id
diff --git a/tencentcloud/services/tke/resource_tc_kubernetes_cluster_test.go b/tencentcloud/services/tke/resource_tc_kubernetes_cluster_test.go
index 17fa059bfb..b8c996ad63 100644
--- a/tencentcloud/services/tke/resource_tc_kubernetes_cluster_test.go
+++ b/tencentcloud/services/tke/resource_tc_kubernetes_cluster_test.go
@@ -37,6 +37,23 @@ func init() {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range clusters {
+ if !tccommon.CheckResourcePersist(v.ClusterName, v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: v.ClusterId,
+ Name: v.ClusterName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: v.ClusterId,
+ Name: v.ClusterName,
+ CreatTime: v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateCluster")
+
for _, v := range clusters {
id := v.ClusterId
name := v.ClusterName
diff --git a/tencentcloud/services/tke/resource_tc_kubernetes_node_pool_test.go b/tencentcloud/services/tke/resource_tc_kubernetes_node_pool_test.go
index 655ceff7af..f29d09a17f 100644
--- a/tencentcloud/services/tke/resource_tc_kubernetes_node_pool_test.go
+++ b/tencentcloud/services/tke/resource_tc_kubernetes_node_pool_test.go
@@ -64,6 +64,23 @@ func testNodePoolSweep(region string) error {
if len(nodePools) == 0 {
return nil
}
+
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range nodePools {
+ if !tccommon.CheckResourcePersist(*v.Name, "") {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.NodePoolId,
+ Name: *v.Name,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.NodePoolId,
+ Name: *v.Name,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateClusterNodePool")
+
for i := range nodePools {
poolId := *nodePools[i].NodePoolId
poolName := nodePools[i].Name
diff --git a/tencentcloud/services/tke/resource_tc_kubernetes_scale_worker_test.go b/tencentcloud/services/tke/resource_tc_kubernetes_scale_worker_test.go
index da0a8a18db..17616415af 100644
--- a/tencentcloud/services/tke/resource_tc_kubernetes_scale_worker_test.go
+++ b/tencentcloud/services/tke/resource_tc_kubernetes_scale_worker_test.go
@@ -50,6 +50,9 @@ func init() {
return err
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+
cvmService := svccvm.NewCvmService(client)
instanceIds := make([]string, 0)
for i := range workers {
@@ -62,6 +65,18 @@ func init() {
continue
}
+ if !tccommon.CheckResourcePersist(*instance.InstanceName, worker.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: worker.InstanceId,
+ Name: *instance.InstanceName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: worker.InstanceId,
+ Name: *instance.InstanceName,
+ CreatTime: worker.CreatedTime,
+ })
+
created, err := time.Parse(tccommon.TENCENTCLOUD_COMMON_TIME_LAYOUT, worker.CreatedTime)
if err != nil {
created = time.Time{}
@@ -72,6 +87,8 @@ func init() {
instanceIds = append(instanceIds, worker.InstanceId)
}
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateClusterInstances")
+
err = service.DeleteClusterInstances(ctx, clusterId, instanceIds)
if err != nil {
return err
diff --git a/tencentcloud/services/vpc/resource_tc_eni_test.go b/tencentcloud/services/vpc/resource_tc_eni_test.go
index 32a7ab24ef..c00439748e 100644
--- a/tencentcloud/services/vpc/resource_tc_eni_test.go
+++ b/tencentcloud/services/vpc/resource_tc_eni_test.go
@@ -32,15 +32,32 @@ func testSweepEniInstance(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ vpcService := svcvpc.NewVpcService(client)
instances, err := vpcService.DescribeEniByFilters(ctx, nil, nil, nil, nil, nil, nil, nil, nil)
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.NetworkInterfaceName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.NetworkInterfaceId,
+ Name: *v.NetworkInterfaceName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.NetworkInterfaceId,
+ Name: *v.NetworkInterfaceName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateNetworkInterface")
+
for _, v := range instances {
instanceId := *v.NetworkInterfaceId
instanceName := v.NetworkInterfaceName
diff --git a/tencentcloud/services/vpc/resource_tc_ha_vip_test.go b/tencentcloud/services/vpc/resource_tc_ha_vip_test.go
index 09b37f1cf9..f7bc3c95ae 100644
--- a/tencentcloud/services/vpc/resource_tc_ha_vip_test.go
+++ b/tencentcloud/services/vpc/resource_tc_ha_vip_test.go
@@ -34,15 +34,32 @@ func testSweepHaVipInstance(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ vpcService := svcvpc.NewVpcService(client)
instances, err := vpcService.DescribeHaVipByFilter(ctx, nil)
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.HaVipName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.HaVipId,
+ Name: *v.HaVipName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.HaVipId,
+ Name: *v.HaVipName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateHaVip")
+
for _, v := range instances {
instanceId := *v.HaVipId
instanceName := *v.HaVipName
diff --git a/tencentcloud/services/vpc/resource_tc_nat_gateway_test.go b/tencentcloud/services/vpc/resource_tc_nat_gateway_test.go
index 748086f7c0..266e3f99f9 100644
--- a/tencentcloud/services/vpc/resource_tc_nat_gateway_test.go
+++ b/tencentcloud/services/vpc/resource_tc_nat_gateway_test.go
@@ -32,15 +32,32 @@ func testSweepNatInstance(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ vpcService := svcvpc.NewVpcService(client)
instances, err := vpcService.DescribeNatGatewayByFilter(ctx, nil)
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.NatGatewayName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.NatGatewayId,
+ Name: *v.NatGatewayName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.NatGatewayId,
+ Name: *v.NatGatewayName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateNatGateway")
+
for _, v := range instances {
instanceId := *v.NatGatewayId
instanceName := v.NatGatewayName
diff --git a/tencentcloud/services/vpc/resource_tc_security_group_test.go b/tencentcloud/services/vpc/resource_tc_security_group_test.go
index f3a2810339..e96628d9bd 100644
--- a/tencentcloud/services/vpc/resource_tc_security_group_test.go
+++ b/tencentcloud/services/vpc/resource_tc_security_group_test.go
@@ -31,15 +31,31 @@ func testSweepSecurityGroups(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
- service := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
+ service := svcvpc.NewVpcService(client)
sgs, err := service.DescribeSecurityGroups(ctx, nil, nil, nil, nil)
-
if err != nil {
return fmt.Errorf("DescribeSecurityGroups error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range sgs {
+ if !tccommon.CheckResourcePersist(*v.SecurityGroupName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.SecurityGroupId,
+ Name: *v.SecurityGroupName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.SecurityGroupId,
+ Name: *v.SecurityGroupName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateSecurityGroup")
+
for _, v := range sgs {
name := *v.SecurityGroupName
id := *v.SecurityGroupId
diff --git a/tencentcloud/services/vpc/resource_tc_subnet_test.go b/tencentcloud/services/vpc/resource_tc_subnet_test.go
index 80c19ea27e..5a78902a2c 100644
--- a/tencentcloud/services/vpc/resource_tc_subnet_test.go
+++ b/tencentcloud/services/vpc/resource_tc_subnet_test.go
@@ -31,9 +31,9 @@ func testSweepSubnet(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ vpcService := svcvpc.NewVpcService(client)
instances, err := vpcService.DescribeSubnets(ctx, "", "", "", "",
nil, nil, nil, "", "")
@@ -41,6 +41,23 @@ func testSweepSubnet(region string) error {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(v.Name(), v.CreateTime()) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: v.SubnetId(),
+ Name: v.Name(),
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: v.SubnetId(),
+ Name: v.Name(),
+ CreatTime: v.CreateTime(),
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateSubnet")
+
for _, v := range instances {
instanceId := v.SubnetId()
diff --git a/tencentcloud/services/vpc/resource_tc_vpc_test.go b/tencentcloud/services/vpc/resource_tc_vpc_test.go
index 44289321c9..77fd4059b5 100644
--- a/tencentcloud/services/vpc/resource_tc_vpc_test.go
+++ b/tencentcloud/services/vpc/resource_tc_vpc_test.go
@@ -31,15 +31,32 @@ func testSweepVpcInstance(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ vpcService := svcvpc.NewVpcService(client)
instances, err := vpcService.DescribeVpcs(ctx, "", "", nil, nil, "", "")
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(v.Name(), v.CreateTime()) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: v.VpcId(),
+ Name: v.Name(),
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: v.VpcId(),
+ Name: v.Name(),
+ CreatTime: v.CreateTime(),
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateVpc")
+
for _, v := range instances {
instanceId := v.VpcId()
instanceName := v.Name()
diff --git a/tencentcloud/services/vpn/resource_tc_vpn_gateway_test.go b/tencentcloud/services/vpn/resource_tc_vpn_gateway_test.go
index d8482f485b..7bfeca6146 100644
--- a/tencentcloud/services/vpn/resource_tc_vpn_gateway_test.go
+++ b/tencentcloud/services/vpn/resource_tc_vpn_gateway_test.go
@@ -33,15 +33,32 @@ func testSweepVpnGateway(region string) error {
if err != nil {
return fmt.Errorf("getting tencentcloud client error: %s", err.Error())
}
- client := sharedClient.(tccommon.ProviderMeta)
+ client := sharedClient.(tccommon.ProviderMeta).GetAPIV3Conn()
- vpcService := svcvpc.NewVpcService(client.GetAPIV3Conn())
+ vpcService := svcvpc.NewVpcService(client)
instances, err := vpcService.DescribeVpnGwByFilter(ctx, nil)
if err != nil {
return fmt.Errorf("get instance list error: %s", err.Error())
}
+ // add scanning resources
+ var resources, nonKeepResources []*tccommon.ResourceInstance
+ for _, v := range instances {
+ if !tccommon.CheckResourcePersist(*v.VpnGatewayName, *v.CreatedTime) {
+ nonKeepResources = append(nonKeepResources, &tccommon.ResourceInstance{
+ Id: *v.VpnGatewayId,
+ Name: *v.VpnGatewayName,
+ })
+ }
+ resources = append(resources, &tccommon.ResourceInstance{
+ Id: *v.VpnGatewayId,
+ Name: *v.VpnGatewayName,
+ CreatTime: *v.CreatedTime,
+ })
+ }
+ tccommon.ProcessScanCloudResources(client, resources, nonKeepResources, "CreateVpnGateway")
+
for _, v := range instances {
vpnGwId := *v.VpnGatewayId
diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/LICENSE b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/LICENSE
new file mode 100644
index 0000000000..efc75a2253
--- /dev/null
+++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/LICENSE
@@ -0,0 +1,201 @@
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
+ APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+ Copyright (c) 2017-2018 Tencent Ltd.
+
+ 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.
diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/client.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/client.go
new file mode 100644
index 0000000000..f4bd67cd2d
--- /dev/null
+++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/client.go
@@ -0,0 +1,1914 @@
+// 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.
+
+package v20180709
+
+import (
+ "context"
+ "errors"
+ "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common"
+ tchttp "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http"
+ "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/profile"
+)
+
+const APIVersion = "2018-07-09"
+
+type Client struct {
+ common.Client
+}
+
+// Deprecated
+func NewClientWithSecretId(secretId, secretKey, region string) (client *Client, err error) {
+ cpf := profile.NewClientProfile()
+ client = &Client{}
+ client.Init(region).WithSecretId(secretId, secretKey).WithProfile(cpf)
+ return
+}
+
+func NewClient(credential common.CredentialIface, region string, clientProfile *profile.ClientProfile) (client *Client, err error) {
+ client = &Client{}
+ client.Init(region).
+ WithCredential(credential).
+ WithProfile(clientProfile)
+ return
+}
+
+
+func NewCreateAllocationTagRequest() (request *CreateAllocationTagRequest) {
+ request = &CreateAllocationTagRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "CreateAllocationTag")
+
+
+ return
+}
+
+func NewCreateAllocationTagResponse() (response *CreateAllocationTagResponse) {
+ response = &CreateAllocationTagResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// CreateAllocationTag
+// 批量设置分账标签
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) CreateAllocationTag(request *CreateAllocationTagRequest) (response *CreateAllocationTagResponse, err error) {
+ return c.CreateAllocationTagWithContext(context.Background(), request)
+}
+
+// CreateAllocationTag
+// 批量设置分账标签
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) CreateAllocationTagWithContext(ctx context.Context, request *CreateAllocationTagRequest) (response *CreateAllocationTagResponse, err error) {
+ if request == nil {
+ request = NewCreateAllocationTagRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("CreateAllocationTag require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewCreateAllocationTagResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewCreateSavingPlanOrderRequest() (request *CreateSavingPlanOrderRequest) {
+ request = &CreateSavingPlanOrderRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "CreateSavingPlanOrder")
+
+
+ return
+}
+
+func NewCreateSavingPlanOrderResponse() (response *CreateSavingPlanOrderResponse) {
+ response = &CreateSavingPlanOrderResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// CreateSavingPlanOrder
+// 创建节省计划订单,创建订单完成需调用PayDeals接口完成订单支付
+//
+// 可能返回的错误码:
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) CreateSavingPlanOrder(request *CreateSavingPlanOrderRequest) (response *CreateSavingPlanOrderResponse, err error) {
+ return c.CreateSavingPlanOrderWithContext(context.Background(), request)
+}
+
+// CreateSavingPlanOrder
+// 创建节省计划订单,创建订单完成需调用PayDeals接口完成订单支付
+//
+// 可能返回的错误码:
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) CreateSavingPlanOrderWithContext(ctx context.Context, request *CreateSavingPlanOrderRequest) (response *CreateSavingPlanOrderResponse, err error) {
+ if request == nil {
+ request = NewCreateSavingPlanOrderRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("CreateSavingPlanOrder require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewCreateSavingPlanOrderResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDeleteAllocationTagRequest() (request *DeleteAllocationTagRequest) {
+ request = &DeleteAllocationTagRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DeleteAllocationTag")
+
+
+ return
+}
+
+func NewDeleteAllocationTagResponse() (response *DeleteAllocationTagResponse) {
+ response = &DeleteAllocationTagResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DeleteAllocationTag
+// 批量取消设置分账标签
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) DeleteAllocationTag(request *DeleteAllocationTagRequest) (response *DeleteAllocationTagResponse, err error) {
+ return c.DeleteAllocationTagWithContext(context.Background(), request)
+}
+
+// DeleteAllocationTag
+// 批量取消设置分账标签
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) DeleteAllocationTagWithContext(ctx context.Context, request *DeleteAllocationTagRequest) (response *DeleteAllocationTagResponse, err error) {
+ if request == nil {
+ request = NewDeleteAllocationTagRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DeleteAllocationTag require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDeleteAllocationTagResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeAccountBalanceRequest() (request *DescribeAccountBalanceRequest) {
+ request = &DescribeAccountBalanceRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeAccountBalance")
+
+
+ return
+}
+
+func NewDescribeAccountBalanceResponse() (response *DescribeAccountBalanceResponse) {
+ response = &DescribeAccountBalanceResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeAccountBalance
+// 获取云账户余额信息。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION = "FailedOperation"
+// FAILEDOPERATION_PAYPRICEERROR = "FailedOperation.PayPriceError"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+// UNSUPPORTEDOPERATION = "UnsupportedOperation"
+func (c *Client) DescribeAccountBalance(request *DescribeAccountBalanceRequest) (response *DescribeAccountBalanceResponse, err error) {
+ return c.DescribeAccountBalanceWithContext(context.Background(), request)
+}
+
+// DescribeAccountBalance
+// 获取云账户余额信息。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION = "FailedOperation"
+// FAILEDOPERATION_PAYPRICEERROR = "FailedOperation.PayPriceError"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+// UNSUPPORTEDOPERATION = "UnsupportedOperation"
+func (c *Client) DescribeAccountBalanceWithContext(ctx context.Context, request *DescribeAccountBalanceRequest) (response *DescribeAccountBalanceResponse, err error) {
+ if request == nil {
+ request = NewDescribeAccountBalanceRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeAccountBalance require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeAccountBalanceResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillDetailRequest() (request *DescribeBillDetailRequest) {
+ request = &DescribeBillDetailRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillDetail")
+
+
+ return
+}
+
+func NewDescribeBillDetailResponse() (response *DescribeBillDetailResponse) {
+ response = &DescribeBillDetailResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillDetail
+// 获取账单明细数据。
+//
+// 注意事项:
+//
+// 1.在请求接口时,由于网络不稳定或其它异常,可能会导致请求失败。如果您遇到这种情况,我们建议您在接口请求失败时,手动发起重试操作,这样可以更好地确保您的接口请求能够成功执行。
+//
+// 2.对于账单明细数据量级很大(例如每月账单明细量级超过20w)的客户,通过 API 调用账单数据效率较低,建议您开通账单数据存储功能,通过存储桶中获取账单文件进行分析。[账单存储至COS桶](https://cloud.tencent.com/document/product/555/61275)
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_QUERYCOUNTFAILED = "FailedOperation.QueryCountFailed"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+// UNSUPPORTEDOPERATION = "UnsupportedOperation"
+func (c *Client) DescribeBillDetail(request *DescribeBillDetailRequest) (response *DescribeBillDetailResponse, err error) {
+ return c.DescribeBillDetailWithContext(context.Background(), request)
+}
+
+// DescribeBillDetail
+// 获取账单明细数据。
+//
+// 注意事项:
+//
+// 1.在请求接口时,由于网络不稳定或其它异常,可能会导致请求失败。如果您遇到这种情况,我们建议您在接口请求失败时,手动发起重试操作,这样可以更好地确保您的接口请求能够成功执行。
+//
+// 2.对于账单明细数据量级很大(例如每月账单明细量级超过20w)的客户,通过 API 调用账单数据效率较低,建议您开通账单数据存储功能,通过存储桶中获取账单文件进行分析。[账单存储至COS桶](https://cloud.tencent.com/document/product/555/61275)
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_QUERYCOUNTFAILED = "FailedOperation.QueryCountFailed"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+// UNSUPPORTEDOPERATION = "UnsupportedOperation"
+func (c *Client) DescribeBillDetailWithContext(ctx context.Context, request *DescribeBillDetailRequest) (response *DescribeBillDetailResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillDetailRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillDetail require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillDetailResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillDetailForOrganizationRequest() (request *DescribeBillDetailForOrganizationRequest) {
+ request = &DescribeBillDetailForOrganizationRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillDetailForOrganization")
+
+
+ return
+}
+
+func NewDescribeBillDetailForOrganizationResponse() (response *DescribeBillDetailForOrganizationResponse) {
+ response = &DescribeBillDetailForOrganizationResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillDetailForOrganization
+// 成员账号获取管理账号代付账单(费用明细)。
+//
+// 注意事项:在请求接口时,由于网络不稳定或其它异常,可能会导致请求失败。如果您遇到这种情况,我们建议您在接口请求失败时,手动发起重试操作,这样可以更好地确保您的接口请求能够成功执行。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_QUERYCOUNTFAILED = "FailedOperation.QueryCountFailed"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+// UNSUPPORTEDOPERATION = "UnsupportedOperation"
+func (c *Client) DescribeBillDetailForOrganization(request *DescribeBillDetailForOrganizationRequest) (response *DescribeBillDetailForOrganizationResponse, err error) {
+ return c.DescribeBillDetailForOrganizationWithContext(context.Background(), request)
+}
+
+// DescribeBillDetailForOrganization
+// 成员账号获取管理账号代付账单(费用明细)。
+//
+// 注意事项:在请求接口时,由于网络不稳定或其它异常,可能会导致请求失败。如果您遇到这种情况,我们建议您在接口请求失败时,手动发起重试操作,这样可以更好地确保您的接口请求能够成功执行。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_QUERYCOUNTFAILED = "FailedOperation.QueryCountFailed"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+// UNSUPPORTEDOPERATION = "UnsupportedOperation"
+func (c *Client) DescribeBillDetailForOrganizationWithContext(ctx context.Context, request *DescribeBillDetailForOrganizationRequest) (response *DescribeBillDetailForOrganizationResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillDetailForOrganizationRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillDetailForOrganization require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillDetailForOrganizationResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillDownloadUrlRequest() (request *DescribeBillDownloadUrlRequest) {
+ request = &DescribeBillDownloadUrlRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillDownloadUrl")
+
+
+ return
+}
+
+func NewDescribeBillDownloadUrlResponse() (response *DescribeBillDownloadUrlResponse) {
+ response = &DescribeBillDownloadUrlResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillDownloadUrl
+// 该接口支持通过传参,获取L0-PDF、L1-汇总、L2-资源、L3-明细、账单包、五类账单文件下载链接
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) DescribeBillDownloadUrl(request *DescribeBillDownloadUrlRequest) (response *DescribeBillDownloadUrlResponse, err error) {
+ return c.DescribeBillDownloadUrlWithContext(context.Background(), request)
+}
+
+// DescribeBillDownloadUrl
+// 该接口支持通过传参,获取L0-PDF、L1-汇总、L2-资源、L3-明细、账单包、五类账单文件下载链接
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) DescribeBillDownloadUrlWithContext(ctx context.Context, request *DescribeBillDownloadUrlRequest) (response *DescribeBillDownloadUrlResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillDownloadUrlRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillDownloadUrl require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillDownloadUrlResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillListRequest() (request *DescribeBillListRequest) {
+ request = &DescribeBillListRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillList")
+
+
+ return
+}
+
+func NewDescribeBillListResponse() (response *DescribeBillListResponse) {
+ response = &DescribeBillListResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillList
+// 获取收支明细列表,支持翻页和参数过滤
+//
+// 可能返回的错误码:
+// AUTHFAILURE = "AuthFailure"
+// FAILEDOPERATION = "FailedOperation"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeBillList(request *DescribeBillListRequest) (response *DescribeBillListResponse, err error) {
+ return c.DescribeBillListWithContext(context.Background(), request)
+}
+
+// DescribeBillList
+// 获取收支明细列表,支持翻页和参数过滤
+//
+// 可能返回的错误码:
+// AUTHFAILURE = "AuthFailure"
+// FAILEDOPERATION = "FailedOperation"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeBillListWithContext(ctx context.Context, request *DescribeBillListRequest) (response *DescribeBillListResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillListRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillList require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillListResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillResourceSummaryRequest() (request *DescribeBillResourceSummaryRequest) {
+ request = &DescribeBillResourceSummaryRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillResourceSummary")
+
+
+ return
+}
+
+func NewDescribeBillResourceSummaryResponse() (response *DescribeBillResourceSummaryResponse) {
+ response = &DescribeBillResourceSummaryResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillResourceSummary
+// 获取账单资源汇总数据
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_SUMMARYDATANOTREADY = "FailedOperation.SummaryDataNotReady"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+func (c *Client) DescribeBillResourceSummary(request *DescribeBillResourceSummaryRequest) (response *DescribeBillResourceSummaryResponse, err error) {
+ return c.DescribeBillResourceSummaryWithContext(context.Background(), request)
+}
+
+// DescribeBillResourceSummary
+// 获取账单资源汇总数据
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_SUMMARYDATANOTREADY = "FailedOperation.SummaryDataNotReady"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+func (c *Client) DescribeBillResourceSummaryWithContext(ctx context.Context, request *DescribeBillResourceSummaryRequest) (response *DescribeBillResourceSummaryResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillResourceSummaryRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillResourceSummary require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillResourceSummaryResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillResourceSummaryForOrganizationRequest() (request *DescribeBillResourceSummaryForOrganizationRequest) {
+ request = &DescribeBillResourceSummaryForOrganizationRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillResourceSummaryForOrganization")
+
+
+ return
+}
+
+func NewDescribeBillResourceSummaryForOrganizationResponse() (response *DescribeBillResourceSummaryForOrganizationResponse) {
+ response = &DescribeBillResourceSummaryForOrganizationResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillResourceSummaryForOrganization
+// 成员账号获取管理账号代付账单(按资源汇总)
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_SUMMARYDATANOTREADY = "FailedOperation.SummaryDataNotReady"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+func (c *Client) DescribeBillResourceSummaryForOrganization(request *DescribeBillResourceSummaryForOrganizationRequest) (response *DescribeBillResourceSummaryForOrganizationResponse, err error) {
+ return c.DescribeBillResourceSummaryForOrganizationWithContext(context.Background(), request)
+}
+
+// DescribeBillResourceSummaryForOrganization
+// 成员账号获取管理账号代付账单(按资源汇总)
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_SUMMARYDATANOTREADY = "FailedOperation.SummaryDataNotReady"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+func (c *Client) DescribeBillResourceSummaryForOrganizationWithContext(ctx context.Context, request *DescribeBillResourceSummaryForOrganizationRequest) (response *DescribeBillResourceSummaryForOrganizationResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillResourceSummaryForOrganizationRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillResourceSummaryForOrganization require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillResourceSummaryForOrganizationResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryRequest() (request *DescribeBillSummaryRequest) {
+ request = &DescribeBillSummaryRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummary")
+
+
+ return
+}
+
+func NewDescribeBillSummaryResponse() (response *DescribeBillSummaryResponse) {
+ response = &DescribeBillSummaryResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummary
+// 该接口支持通过传参,按照产品、项目、地域、计费模式和标签五个维度获取账单费用明细。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummary(request *DescribeBillSummaryRequest) (response *DescribeBillSummaryResponse, err error) {
+ return c.DescribeBillSummaryWithContext(context.Background(), request)
+}
+
+// DescribeBillSummary
+// 该接口支持通过传参,按照产品、项目、地域、计费模式和标签五个维度获取账单费用明细。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryWithContext(ctx context.Context, request *DescribeBillSummaryRequest) (response *DescribeBillSummaryResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummary require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryByPayModeRequest() (request *DescribeBillSummaryByPayModeRequest) {
+ request = &DescribeBillSummaryByPayModeRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummaryByPayMode")
+
+
+ return
+}
+
+func NewDescribeBillSummaryByPayModeResponse() (response *DescribeBillSummaryByPayModeResponse) {
+ response = &DescribeBillSummaryByPayModeResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummaryByPayMode
+// 获取按计费模式汇总费用分布
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByPayMode(request *DescribeBillSummaryByPayModeRequest) (response *DescribeBillSummaryByPayModeResponse, err error) {
+ return c.DescribeBillSummaryByPayModeWithContext(context.Background(), request)
+}
+
+// DescribeBillSummaryByPayMode
+// 获取按计费模式汇总费用分布
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByPayModeWithContext(ctx context.Context, request *DescribeBillSummaryByPayModeRequest) (response *DescribeBillSummaryByPayModeResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryByPayModeRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummaryByPayMode require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryByPayModeResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryByProductRequest() (request *DescribeBillSummaryByProductRequest) {
+ request = &DescribeBillSummaryByProductRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummaryByProduct")
+
+
+ return
+}
+
+func NewDescribeBillSummaryByProductResponse() (response *DescribeBillSummaryByProductResponse) {
+ response = &DescribeBillSummaryByProductResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummaryByProduct
+// 获取产品汇总费用分布
+//
+// 可能返回的错误码:
+// AUTHFAILURE_UNAUTHORIZEDOPERATION = "AuthFailure.UnauthorizedOperation"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByProduct(request *DescribeBillSummaryByProductRequest) (response *DescribeBillSummaryByProductResponse, err error) {
+ return c.DescribeBillSummaryByProductWithContext(context.Background(), request)
+}
+
+// DescribeBillSummaryByProduct
+// 获取产品汇总费用分布
+//
+// 可能返回的错误码:
+// AUTHFAILURE_UNAUTHORIZEDOPERATION = "AuthFailure.UnauthorizedOperation"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByProductWithContext(ctx context.Context, request *DescribeBillSummaryByProductRequest) (response *DescribeBillSummaryByProductResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryByProductRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummaryByProduct require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryByProductResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryByProjectRequest() (request *DescribeBillSummaryByProjectRequest) {
+ request = &DescribeBillSummaryByProjectRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummaryByProject")
+
+
+ return
+}
+
+func NewDescribeBillSummaryByProjectResponse() (response *DescribeBillSummaryByProjectResponse) {
+ response = &DescribeBillSummaryByProjectResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummaryByProject
+// 获取按项目汇总费用分布
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByProject(request *DescribeBillSummaryByProjectRequest) (response *DescribeBillSummaryByProjectResponse, err error) {
+ return c.DescribeBillSummaryByProjectWithContext(context.Background(), request)
+}
+
+// DescribeBillSummaryByProject
+// 获取按项目汇总费用分布
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByProjectWithContext(ctx context.Context, request *DescribeBillSummaryByProjectRequest) (response *DescribeBillSummaryByProjectResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryByProjectRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummaryByProject require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryByProjectResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryByRegionRequest() (request *DescribeBillSummaryByRegionRequest) {
+ request = &DescribeBillSummaryByRegionRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummaryByRegion")
+
+
+ return
+}
+
+func NewDescribeBillSummaryByRegionResponse() (response *DescribeBillSummaryByRegionResponse) {
+ response = &DescribeBillSummaryByRegionResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummaryByRegion
+// 获取按地域汇总费用分布
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByRegion(request *DescribeBillSummaryByRegionRequest) (response *DescribeBillSummaryByRegionResponse, err error) {
+ return c.DescribeBillSummaryByRegionWithContext(context.Background(), request)
+}
+
+// DescribeBillSummaryByRegion
+// 获取按地域汇总费用分布
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByRegionWithContext(ctx context.Context, request *DescribeBillSummaryByRegionRequest) (response *DescribeBillSummaryByRegionResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryByRegionRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummaryByRegion require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryByRegionResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryByTagRequest() (request *DescribeBillSummaryByTagRequest) {
+ request = &DescribeBillSummaryByTagRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummaryByTag")
+
+
+ return
+}
+
+func NewDescribeBillSummaryByTagResponse() (response *DescribeBillSummaryByTagResponse) {
+ response = &DescribeBillSummaryByTagResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummaryByTag
+// 获取按标签汇总费用分布
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByTag(request *DescribeBillSummaryByTagRequest) (response *DescribeBillSummaryByTagResponse, err error) {
+ return c.DescribeBillSummaryByTagWithContext(context.Background(), request)
+}
+
+// DescribeBillSummaryByTag
+// 获取按标签汇总费用分布
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryByTagWithContext(ctx context.Context, request *DescribeBillSummaryByTagRequest) (response *DescribeBillSummaryByTagResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryByTagRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummaryByTag require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryByTagResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeBillSummaryForOrganizationRequest() (request *DescribeBillSummaryForOrganizationRequest) {
+ request = &DescribeBillSummaryForOrganizationRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeBillSummaryForOrganization")
+
+
+ return
+}
+
+func NewDescribeBillSummaryForOrganizationResponse() (response *DescribeBillSummaryForOrganizationResponse) {
+ response = &DescribeBillSummaryForOrganizationResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeBillSummaryForOrganization
+// 该接口支持通过传参,按照产品、项目、地域、计费模式和标签五个维度获取账单费用明细。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryForOrganization(request *DescribeBillSummaryForOrganizationRequest) (response *DescribeBillSummaryForOrganizationResponse, err error) {
+ return c.DescribeBillSummaryForOrganizationWithContext(context.Background(), request)
+}
+
+// DescribeBillSummaryForOrganization
+// 该接口支持通过传参,按照产品、项目、地域、计费模式和标签五个维度获取账单费用明细。
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeBillSummaryForOrganizationWithContext(ctx context.Context, request *DescribeBillSummaryForOrganizationRequest) (response *DescribeBillSummaryForOrganizationResponse, err error) {
+ if request == nil {
+ request = NewDescribeBillSummaryForOrganizationRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeBillSummaryForOrganization require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeBillSummaryForOrganizationResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeCostDetailRequest() (request *DescribeCostDetailRequest) {
+ request = &DescribeCostDetailRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeCostDetail")
+
+
+ return
+}
+
+func NewDescribeCostDetailResponse() (response *DescribeCostDetailResponse) {
+ response = &DescribeCostDetailResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeCostDetail
+// 查询消耗明细
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+func (c *Client) DescribeCostDetail(request *DescribeCostDetailRequest) (response *DescribeCostDetailResponse, err error) {
+ return c.DescribeCostDetailWithContext(context.Background(), request)
+}
+
+// DescribeCostDetail
+// 查询消耗明细
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+func (c *Client) DescribeCostDetailWithContext(ctx context.Context, request *DescribeCostDetailRequest) (response *DescribeCostDetailResponse, err error) {
+ if request == nil {
+ request = NewDescribeCostDetailRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeCostDetail require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeCostDetailResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeCostSummaryByProductRequest() (request *DescribeCostSummaryByProductRequest) {
+ request = &DescribeCostSummaryByProductRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeCostSummaryByProduct")
+
+
+ return
+}
+
+func NewDescribeCostSummaryByProductResponse() (response *DescribeCostSummaryByProductResponse) {
+ response = &DescribeCostSummaryByProductResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeCostSummaryByProduct
+// 获取按产品汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByProduct(request *DescribeCostSummaryByProductRequest) (response *DescribeCostSummaryByProductResponse, err error) {
+ return c.DescribeCostSummaryByProductWithContext(context.Background(), request)
+}
+
+// DescribeCostSummaryByProduct
+// 获取按产品汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByProductWithContext(ctx context.Context, request *DescribeCostSummaryByProductRequest) (response *DescribeCostSummaryByProductResponse, err error) {
+ if request == nil {
+ request = NewDescribeCostSummaryByProductRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeCostSummaryByProduct require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeCostSummaryByProductResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeCostSummaryByProjectRequest() (request *DescribeCostSummaryByProjectRequest) {
+ request = &DescribeCostSummaryByProjectRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeCostSummaryByProject")
+
+
+ return
+}
+
+func NewDescribeCostSummaryByProjectResponse() (response *DescribeCostSummaryByProjectResponse) {
+ response = &DescribeCostSummaryByProjectResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeCostSummaryByProject
+// 获取按项目汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByProject(request *DescribeCostSummaryByProjectRequest) (response *DescribeCostSummaryByProjectResponse, err error) {
+ return c.DescribeCostSummaryByProjectWithContext(context.Background(), request)
+}
+
+// DescribeCostSummaryByProject
+// 获取按项目汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByProjectWithContext(ctx context.Context, request *DescribeCostSummaryByProjectRequest) (response *DescribeCostSummaryByProjectResponse, err error) {
+ if request == nil {
+ request = NewDescribeCostSummaryByProjectRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeCostSummaryByProject require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeCostSummaryByProjectResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeCostSummaryByRegionRequest() (request *DescribeCostSummaryByRegionRequest) {
+ request = &DescribeCostSummaryByRegionRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeCostSummaryByRegion")
+
+
+ return
+}
+
+func NewDescribeCostSummaryByRegionResponse() (response *DescribeCostSummaryByRegionResponse) {
+ response = &DescribeCostSummaryByRegionResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeCostSummaryByRegion
+// 获取按地域汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByRegion(request *DescribeCostSummaryByRegionRequest) (response *DescribeCostSummaryByRegionResponse, err error) {
+ return c.DescribeCostSummaryByRegionWithContext(context.Background(), request)
+}
+
+// DescribeCostSummaryByRegion
+// 获取按地域汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByRegionWithContext(ctx context.Context, request *DescribeCostSummaryByRegionRequest) (response *DescribeCostSummaryByRegionResponse, err error) {
+ if request == nil {
+ request = NewDescribeCostSummaryByRegionRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeCostSummaryByRegion require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeCostSummaryByRegionResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeCostSummaryByResourceRequest() (request *DescribeCostSummaryByResourceRequest) {
+ request = &DescribeCostSummaryByResourceRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeCostSummaryByResource")
+
+
+ return
+}
+
+func NewDescribeCostSummaryByResourceResponse() (response *DescribeCostSummaryByResourceResponse) {
+ response = &DescribeCostSummaryByResourceResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeCostSummaryByResource
+// 获取按资源汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByResource(request *DescribeCostSummaryByResourceRequest) (response *DescribeCostSummaryByResourceResponse, err error) {
+ return c.DescribeCostSummaryByResourceWithContext(context.Background(), request)
+}
+
+// DescribeCostSummaryByResource
+// 获取按资源汇总消耗详情
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeCostSummaryByResourceWithContext(ctx context.Context, request *DescribeCostSummaryByResourceRequest) (response *DescribeCostSummaryByResourceResponse, err error) {
+ if request == nil {
+ request = NewDescribeCostSummaryByResourceRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeCostSummaryByResource require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeCostSummaryByResourceResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeDealsByCondRequest() (request *DescribeDealsByCondRequest) {
+ request = &DescribeDealsByCondRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeDealsByCond")
+
+
+ return
+}
+
+func NewDescribeDealsByCondResponse() (response *DescribeDealsByCondResponse) {
+ response = &DescribeDealsByCondResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeDealsByCond
+// 查询订单
+//
+// 可能返回的错误码:
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeDealsByCond(request *DescribeDealsByCondRequest) (response *DescribeDealsByCondResponse, err error) {
+ return c.DescribeDealsByCondWithContext(context.Background(), request)
+}
+
+// DescribeDealsByCond
+// 查询订单
+//
+// 可能返回的错误码:
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeDealsByCondWithContext(ctx context.Context, request *DescribeDealsByCondRequest) (response *DescribeDealsByCondResponse, err error) {
+ if request == nil {
+ request = NewDescribeDealsByCondRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeDealsByCond require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeDealsByCondResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeDosageCosDetailByDateRequest() (request *DescribeDosageCosDetailByDateRequest) {
+ request = &DescribeDosageCosDetailByDateRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeDosageCosDetailByDate")
+
+
+ return
+}
+
+func NewDescribeDosageCosDetailByDateResponse() (response *DescribeDosageCosDetailByDateResponse) {
+ response = &DescribeDosageCosDetailByDateResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeDosageCosDetailByDate
+// 获取COS产品用量明细
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeDosageCosDetailByDate(request *DescribeDosageCosDetailByDateRequest) (response *DescribeDosageCosDetailByDateResponse, err error) {
+ return c.DescribeDosageCosDetailByDateWithContext(context.Background(), request)
+}
+
+// DescribeDosageCosDetailByDate
+// 获取COS产品用量明细
+//
+// 可能返回的错误码:
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeDosageCosDetailByDateWithContext(ctx context.Context, request *DescribeDosageCosDetailByDateRequest) (response *DescribeDosageCosDetailByDateResponse, err error) {
+ if request == nil {
+ request = NewDescribeDosageCosDetailByDateRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeDosageCosDetailByDate require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeDosageCosDetailByDateResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeDosageDetailByDateRequest() (request *DescribeDosageDetailByDateRequest) {
+ request = &DescribeDosageDetailByDateRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeDosageDetailByDate")
+
+
+ return
+}
+
+func NewDescribeDosageDetailByDateResponse() (response *DescribeDosageDetailByDateResponse) {
+ response = &DescribeDosageDetailByDateResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeDosageDetailByDate
+// 按日期获取产品用量明细
+//
+// 可能返回的错误码:
+// AUTHFAILURE = "AuthFailure"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeDosageDetailByDate(request *DescribeDosageDetailByDateRequest) (response *DescribeDosageDetailByDateResponse, err error) {
+ return c.DescribeDosageDetailByDateWithContext(context.Background(), request)
+}
+
+// DescribeDosageDetailByDate
+// 按日期获取产品用量明细
+//
+// 可能返回的错误码:
+// AUTHFAILURE = "AuthFailure"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+func (c *Client) DescribeDosageDetailByDateWithContext(ctx context.Context, request *DescribeDosageDetailByDateRequest) (response *DescribeDosageDetailByDateResponse, err error) {
+ if request == nil {
+ request = NewDescribeDosageDetailByDateRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeDosageDetailByDate require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeDosageDetailByDateResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeDosageDetailListRequest() (request *DescribeDosageDetailListRequest) {
+ request = &DescribeDosageDetailListRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeDosageDetailList")
+
+
+ return
+}
+
+func NewDescribeDosageDetailListResponse() (response *DescribeDosageDetailListResponse) {
+ response = &DescribeDosageDetailListResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeDosageDetailList
+// 获取已接入标准用量明细模板产品的用量明细数据,目前已接入并支持查询的产品包括:云联络中心、实时音视频、实时音视频、智能媒资托管、CODING DevOps、全球IP应用加速
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_QUERYDBFAILED = "FailedOperation.QueryDBFailed"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER_PARAMCHECKFAILED = "InvalidParameter.ParamCheckFailed"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeDosageDetailList(request *DescribeDosageDetailListRequest) (response *DescribeDosageDetailListResponse, err error) {
+ return c.DescribeDosageDetailListWithContext(context.Background(), request)
+}
+
+// DescribeDosageDetailList
+// 获取已接入标准用量明细模板产品的用量明细数据,目前已接入并支持查询的产品包括:云联络中心、实时音视频、实时音视频、智能媒资托管、CODING DevOps、全球IP应用加速
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_QUERYDBFAILED = "FailedOperation.QueryDBFailed"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER_PARAMCHECKFAILED = "InvalidParameter.ParamCheckFailed"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+func (c *Client) DescribeDosageDetailListWithContext(ctx context.Context, request *DescribeDosageDetailListRequest) (response *DescribeDosageDetailListResponse, err error) {
+ if request == nil {
+ request = NewDescribeDosageDetailListRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeDosageDetailList require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeDosageDetailListResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeSavingPlanCoverageRequest() (request *DescribeSavingPlanCoverageRequest) {
+ request = &DescribeSavingPlanCoverageRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeSavingPlanCoverage")
+
+
+ return
+}
+
+func NewDescribeSavingPlanCoverageResponse() (response *DescribeSavingPlanCoverageResponse) {
+ response = &DescribeSavingPlanCoverageResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeSavingPlanCoverage
+// 查询当前用户节省计划覆盖率明细数据,如无特别说明,金额单位均为元(国内站)或者美元(国际站)。
+//
+// 可能返回的错误码:
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanCoverage(request *DescribeSavingPlanCoverageRequest) (response *DescribeSavingPlanCoverageResponse, err error) {
+ return c.DescribeSavingPlanCoverageWithContext(context.Background(), request)
+}
+
+// DescribeSavingPlanCoverage
+// 查询当前用户节省计划覆盖率明细数据,如无特别说明,金额单位均为元(国内站)或者美元(国际站)。
+//
+// 可能返回的错误码:
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanCoverageWithContext(ctx context.Context, request *DescribeSavingPlanCoverageRequest) (response *DescribeSavingPlanCoverageResponse, err error) {
+ if request == nil {
+ request = NewDescribeSavingPlanCoverageRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeSavingPlanCoverage require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeSavingPlanCoverageResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeSavingPlanOverviewRequest() (request *DescribeSavingPlanOverviewRequest) {
+ request = &DescribeSavingPlanOverviewRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeSavingPlanOverview")
+
+
+ return
+}
+
+func NewDescribeSavingPlanOverviewResponse() (response *DescribeSavingPlanOverviewResponse) {
+ response = &DescribeSavingPlanOverviewResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeSavingPlanOverview
+// 查用当前用户明细节省计划总览查询时段内的使用情况
+//
+// 可能返回的错误码:
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanOverview(request *DescribeSavingPlanOverviewRequest) (response *DescribeSavingPlanOverviewResponse, err error) {
+ return c.DescribeSavingPlanOverviewWithContext(context.Background(), request)
+}
+
+// DescribeSavingPlanOverview
+// 查用当前用户明细节省计划总览查询时段内的使用情况
+//
+// 可能返回的错误码:
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanOverviewWithContext(ctx context.Context, request *DescribeSavingPlanOverviewRequest) (response *DescribeSavingPlanOverviewResponse, err error) {
+ if request == nil {
+ request = NewDescribeSavingPlanOverviewRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeSavingPlanOverview require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeSavingPlanOverviewResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeSavingPlanResourceInfoRequest() (request *DescribeSavingPlanResourceInfoRequest) {
+ request = &DescribeSavingPlanResourceInfoRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeSavingPlanResourceInfo")
+
+
+ return
+}
+
+func NewDescribeSavingPlanResourceInfoResponse() (response *DescribeSavingPlanResourceInfoResponse) {
+ response = &DescribeSavingPlanResourceInfoResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeSavingPlanResourceInfo
+// 查询节省计划详情
+//
+// 可能返回的错误码:
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanResourceInfo(request *DescribeSavingPlanResourceInfoRequest) (response *DescribeSavingPlanResourceInfoResponse, err error) {
+ return c.DescribeSavingPlanResourceInfoWithContext(context.Background(), request)
+}
+
+// DescribeSavingPlanResourceInfo
+// 查询节省计划详情
+//
+// 可能返回的错误码:
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanResourceInfoWithContext(ctx context.Context, request *DescribeSavingPlanResourceInfoRequest) (response *DescribeSavingPlanResourceInfoResponse, err error) {
+ if request == nil {
+ request = NewDescribeSavingPlanResourceInfoRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeSavingPlanResourceInfo require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeSavingPlanResourceInfoResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeSavingPlanUsageRequest() (request *DescribeSavingPlanUsageRequest) {
+ request = &DescribeSavingPlanUsageRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeSavingPlanUsage")
+
+
+ return
+}
+
+func NewDescribeSavingPlanUsageResponse() (response *DescribeSavingPlanUsageResponse) {
+ response = &DescribeSavingPlanUsageResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeSavingPlanUsage
+// 查用当前用户明细节省计划查询时段内的使用情况
+//
+// 可能返回的错误码:
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanUsage(request *DescribeSavingPlanUsageRequest) (response *DescribeSavingPlanUsageResponse, err error) {
+ return c.DescribeSavingPlanUsageWithContext(context.Background(), request)
+}
+
+// DescribeSavingPlanUsage
+// 查用当前用户明细节省计划查询时段内的使用情况
+//
+// 可能返回的错误码:
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeSavingPlanUsageWithContext(ctx context.Context, request *DescribeSavingPlanUsageRequest) (response *DescribeSavingPlanUsageResponse, err error) {
+ if request == nil {
+ request = NewDescribeSavingPlanUsageRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeSavingPlanUsage require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeSavingPlanUsageResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeTagListRequest() (request *DescribeTagListRequest) {
+ request = &DescribeTagListRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeTagList")
+
+
+ return
+}
+
+func NewDescribeTagListResponse() (response *DescribeTagListResponse) {
+ response = &DescribeTagListResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeTagList
+// 获取分账标签
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) DescribeTagList(request *DescribeTagListRequest) (response *DescribeTagListResponse, err error) {
+ return c.DescribeTagListWithContext(context.Background(), request)
+}
+
+// DescribeTagList
+// 获取分账标签
+//
+// 可能返回的错误码:
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+// INVALIDPARAMETER = "InvalidParameter"
+func (c *Client) DescribeTagListWithContext(ctx context.Context, request *DescribeTagListRequest) (response *DescribeTagListResponse, err error) {
+ if request == nil {
+ request = NewDescribeTagListRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeTagList require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeTagListResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeVoucherInfoRequest() (request *DescribeVoucherInfoRequest) {
+ request = &DescribeVoucherInfoRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeVoucherInfo")
+
+
+ return
+}
+
+func NewDescribeVoucherInfoResponse() (response *DescribeVoucherInfoResponse) {
+ response = &DescribeVoucherInfoResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeVoucherInfo
+// 获取代金券相关信息
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_INVALIDAPPID = "FailedOperation.InvalidAppId"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeVoucherInfo(request *DescribeVoucherInfoRequest) (response *DescribeVoucherInfoResponse, err error) {
+ return c.DescribeVoucherInfoWithContext(context.Background(), request)
+}
+
+// DescribeVoucherInfo
+// 获取代金券相关信息
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_INVALIDAPPID = "FailedOperation.InvalidAppId"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeVoucherInfoWithContext(ctx context.Context, request *DescribeVoucherInfoRequest) (response *DescribeVoucherInfoResponse, err error) {
+ if request == nil {
+ request = NewDescribeVoucherInfoRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeVoucherInfo require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeVoucherInfoResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewDescribeVoucherUsageDetailsRequest() (request *DescribeVoucherUsageDetailsRequest) {
+ request = &DescribeVoucherUsageDetailsRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "DescribeVoucherUsageDetails")
+
+
+ return
+}
+
+func NewDescribeVoucherUsageDetailsResponse() (response *DescribeVoucherUsageDetailsResponse) {
+ response = &DescribeVoucherUsageDetailsResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// DescribeVoucherUsageDetails
+// 获取代金券使用记录
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_INVALIDAPPID = "FailedOperation.InvalidAppId"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeVoucherUsageDetails(request *DescribeVoucherUsageDetailsRequest) (response *DescribeVoucherUsageDetailsResponse, err error) {
+ return c.DescribeVoucherUsageDetailsWithContext(context.Background(), request)
+}
+
+// DescribeVoucherUsageDetails
+// 获取代金券使用记录
+//
+// 可能返回的错误码:
+// FAILEDOPERATION_INVALIDAPPID = "FailedOperation.InvalidAppId"
+// INTERNALERROR = "InternalError"
+// INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+// INVALIDPARAMETER = "InvalidParameter"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+func (c *Client) DescribeVoucherUsageDetailsWithContext(ctx context.Context, request *DescribeVoucherUsageDetailsRequest) (response *DescribeVoucherUsageDetailsResponse, err error) {
+ if request == nil {
+ request = NewDescribeVoucherUsageDetailsRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("DescribeVoucherUsageDetails require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewDescribeVoucherUsageDetailsResponse()
+ err = c.Send(request, response)
+ return
+}
+
+func NewPayDealsRequest() (request *PayDealsRequest) {
+ request = &PayDealsRequest{
+ BaseRequest: &tchttp.BaseRequest{},
+ }
+
+ request.Init().WithApiInfo("billing", APIVersion, "PayDeals")
+
+
+ return
+}
+
+func NewPayDealsResponse() (response *PayDealsResponse) {
+ response = &PayDealsResponse{
+ BaseResponse: &tchttp.BaseResponse{},
+ }
+ return
+
+}
+
+// PayDeals
+// 支付订单
+//
+// 可能返回的错误码:
+// FAILEDOPERATION = "FailedOperation"
+// FAILEDOPERATION_AGENTPAYDEALCANNOTDOWN = "FailedOperation.AgentPayDealCannotDown"
+// FAILEDOPERATION_BALANCEINSUFFICIENT = "FailedOperation.BalanceInsufficient"
+// FAILEDOPERATION_INVALIDDEAL = "FailedOperation.InvalidDeal"
+// FAILEDOPERATION_INVALIDVOUCHER = "FailedOperation.InvalidVoucher"
+// FAILEDOPERATION_NEEDPAYTOGETER = "FailedOperation.NeedPayTogeter"
+// FAILEDOPERATION_NEEDPAYTOGETHER = "FailedOperation.NeedPayTogether"
+// FAILEDOPERATION_PAYPRICEERROR = "FailedOperation.PayPriceError"
+// FAILEDOPERATION_PAYSUCCDELIVERFAILED = "FailedOperation.PaySuccDeliverFailed"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+// UNAUTHORIZEDOPERATION_CERTIFICATIONNEEDUPGRADE = "UnauthorizedOperation.CertificationNeedUpgrade"
+// UNAUTHORIZEDOPERATION_NOTCERTIFICATION = "UnauthorizedOperation.NotCertification"
+func (c *Client) PayDeals(request *PayDealsRequest) (response *PayDealsResponse, err error) {
+ return c.PayDealsWithContext(context.Background(), request)
+}
+
+// PayDeals
+// 支付订单
+//
+// 可能返回的错误码:
+// FAILEDOPERATION = "FailedOperation"
+// FAILEDOPERATION_AGENTPAYDEALCANNOTDOWN = "FailedOperation.AgentPayDealCannotDown"
+// FAILEDOPERATION_BALANCEINSUFFICIENT = "FailedOperation.BalanceInsufficient"
+// FAILEDOPERATION_INVALIDDEAL = "FailedOperation.InvalidDeal"
+// FAILEDOPERATION_INVALIDVOUCHER = "FailedOperation.InvalidVoucher"
+// FAILEDOPERATION_NEEDPAYTOGETER = "FailedOperation.NeedPayTogeter"
+// FAILEDOPERATION_NEEDPAYTOGETHER = "FailedOperation.NeedPayTogether"
+// FAILEDOPERATION_PAYPRICEERROR = "FailedOperation.PayPriceError"
+// FAILEDOPERATION_PAYSUCCDELIVERFAILED = "FailedOperation.PaySuccDeliverFailed"
+// INVALIDPARAMETER = "InvalidParameter"
+// INVALIDPARAMETERVALUE = "InvalidParameterValue"
+// UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+// UNAUTHORIZEDOPERATION_CERTIFICATIONNEEDUPGRADE = "UnauthorizedOperation.CertificationNeedUpgrade"
+// UNAUTHORIZEDOPERATION_NOTCERTIFICATION = "UnauthorizedOperation.NotCertification"
+func (c *Client) PayDealsWithContext(ctx context.Context, request *PayDealsRequest) (response *PayDealsResponse, err error) {
+ if request == nil {
+ request = NewPayDealsRequest()
+ }
+
+ if c.GetCredential() == nil {
+ return nil, errors.New("PayDeals require credential")
+ }
+
+ request.SetContext(ctx)
+
+ response = NewPayDealsResponse()
+ err = c.Send(request, response)
+ return
+}
diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/errors.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/errors.go
new file mode 100644
index 0000000000..48639dc483
--- /dev/null
+++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/errors.go
@@ -0,0 +1,97 @@
+// 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.
+
+package v20180709
+
+const (
+ // 此产品的特有错误码
+
+ // CAM签名/鉴权错误。
+ AUTHFAILURE = "AuthFailure"
+
+ // 没有权限。
+ AUTHFAILURE_UNAUTHORIZEDOPERATION = "AuthFailure.UnauthorizedOperation"
+
+ // 操作失败。
+ FAILEDOPERATION = "FailedOperation"
+
+ // 代理支付设备不能降配。
+ FAILEDOPERATION_AGENTPAYDEALCANNOTDOWN = "FailedOperation.AgentPayDealCannotDown"
+
+ // 账户余额不足。
+ FAILEDOPERATION_BALANCEINSUFFICIENT = "FailedOperation.BalanceInsufficient"
+
+ // appId不符。
+ FAILEDOPERATION_INVALIDAPPID = "FailedOperation.InvalidAppId"
+
+ // 订单状态错误,只有未支付订单才能支付。
+ FAILEDOPERATION_INVALIDDEAL = "FailedOperation.InvalidDeal"
+
+ // 代金券不可用。
+ FAILEDOPERATION_INVALIDVOUCHER = "FailedOperation.InvalidVoucher"
+
+ // 一起购买的订单必须同时支付。
+ FAILEDOPERATION_NEEDPAYTOGETER = "FailedOperation.NeedPayTogeter"
+
+ // 套餐订单需一起购买。
+ FAILEDOPERATION_NEEDPAYTOGETHER = "FailedOperation.NeedPayTogether"
+
+ // 支付失败,请联系腾讯云工作人员处理。
+ FAILEDOPERATION_PAYPRICEERROR = "FailedOperation.PayPriceError"
+
+ // 支付成功但发货失败,请联系腾讯云工作人员处理。
+ FAILEDOPERATION_PAYSUCCDELIVERFAILED = "FailedOperation.PaySuccDeliverFailed"
+
+ // 获取数据条数失败。
+ FAILEDOPERATION_QUERYCOUNTFAILED = "FailedOperation.QueryCountFailed"
+
+ // 查询数据失败
+ FAILEDOPERATION_QUERYDBFAILED = "FailedOperation.QueryDBFailed"
+
+ // 汇总数据正在构建中,请稍后再试。
+ FAILEDOPERATION_SUMMARYDATANOTREADY = "FailedOperation.SummaryDataNotReady"
+
+ // 不存在该分账标签键。
+ FAILEDOPERATION_TAGKEYNOTEXIST = "FailedOperation.TagKeyNotExist"
+
+ // 内部错误。
+ INTERNALERROR = "InternalError"
+
+ // 网关错误。
+ INTERNALERROR_GATEWAYERROR = "InternalError.GatewayError"
+
+ // 未定义异常。
+ INTERNALERROR_UNKNOWNERROR = "InternalError.UnknownError"
+
+ // 参数错误。
+ INVALIDPARAMETER = "InvalidParameter"
+
+ // 参数校验出错
+ INVALIDPARAMETER_PARAMCHECKFAILED = "InvalidParameter.ParamCheckFailed"
+
+ // 参数取值错误。
+ INVALIDPARAMETERVALUE = "InvalidParameterValue"
+
+ // 账号没有cam授权。
+ UNAUTHORIZEDOPERATION_CAMNOAUTH = "UnauthorizedOperation.CamNoAuth"
+
+ // 因账号安全升级,购买云资源需完善您的实名信息。
+ UNAUTHORIZEDOPERATION_CERTIFICATIONNEEDUPGRADE = "UnauthorizedOperation.CertificationNeedUpgrade"
+
+ // 账号没有实名认证,支付失败。
+ UNAUTHORIZEDOPERATION_NOTCERTIFICATION = "UnauthorizedOperation.NotCertification"
+
+ // 操作不支持。
+ UNSUPPORTEDOPERATION = "UnsupportedOperation"
+)
diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/models.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/models.go
new file mode 100644
index 0000000000..e3ccd5eaa7
--- /dev/null
+++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709/models.go
@@ -0,0 +1,5510 @@
+// 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.
+
+package v20180709
+
+import (
+ tcerr "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/errors"
+ tchttp "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http"
+ "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/json"
+)
+
+type ActionSummaryOverviewItem struct {
+ // 交易类型编码
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 交易类型:如包年包月新购、包年包月续费、按量计费扣费等类型
+ ActionTypeName *string `json:"ActionTypeName,omitnil" name:"ActionTypeName"`
+
+ // 费用所占百分比,两位小数
+ RealTotalCostRatio *string `json:"RealTotalCostRatio,omitnil" name:"RealTotalCostRatio"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 账单月份,格式2019-08
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type ApplicableProducts struct {
+ // 适用商品名称,值为“全产品通用”或商品名称组成的string,以","分割。
+ GoodsName *string `json:"GoodsName,omitnil" name:"GoodsName"`
+
+ // postPay后付费/prePay预付费/riPay预留实例/空字符串或者"*"表示全部模式。如GoodsName为多个商品名以","分割组成的string,而PayMode为"*",表示每一件商品的模式都为"*"。
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+}
+
+type BillDetail struct {
+ // 产品名称:用户所采购的各类云产品,例如:云服务器 CVM
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 子产品名称:用户采购的具体产品细分类型,例如:云服务器 CVM-标准型 S1
+ ProductCodeName *string `json:"ProductCodeName,omitnil" name:"ProductCodeName"`
+
+ // 计费模式:资源的计费模式,区分为包年包月和按量计费
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 项目名称:资源归属的项目,用户在控制台给资源自主分配项目,未分配则是默认项目
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 地域:资源所属地域,如华南地区(广州)
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 可用区:资源所属可用区,如广州三区
+ ZoneName *string `json:"ZoneName,omitnil" name:"ZoneName"`
+
+ // 资源 ID:账单中出账对象 ID,不同产品因资源形态不同,资源内容不完全相同,如云服务器 CVM 为对应的实例 ID
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 资源别名:用户在控制台为资源设置的名称,如果未设置,则默认为空
+ ResourceName *string `json:"ResourceName,omitnil" name:"ResourceName"`
+
+ // 交易类型,如包年包月新购、包年包月续费、按量计费扣费等类型
+ ActionTypeName *string `json:"ActionTypeName,omitnil" name:"ActionTypeName"`
+
+ // 订单ID:包年包月计费模式下订购的订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 交易ID:结算扣费单号
+ BillId *string `json:"BillId,omitnil" name:"BillId"`
+
+ // 扣费时间:结算扣费时间
+ PayTime *string `json:"PayTime,omitnil" name:"PayTime"`
+
+ // 开始使用时间:产品服务开始使用时间
+ FeeBeginTime *string `json:"FeeBeginTime,omitnil" name:"FeeBeginTime"`
+
+ // 结束使用时间:产品服务结束使用时间
+ FeeEndTime *string `json:"FeeEndTime,omitnil" name:"FeeEndTime"`
+
+ // 组件列表
+ ComponentSet []*BillDetailComponent `json:"ComponentSet,omitnil" name:"ComponentSet"`
+
+ // 支付者UIN:支付者的账号 ID,账号 ID 是用户在腾讯云的唯一账号标识
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 使用者UIN:实际使用资源的账号 ID
+ OwnerUin *string `json:"OwnerUin,omitnil" name:"OwnerUin"`
+
+ // 操作者UIN:操作者账号 ID(预付费资源下单或后付费操作开通资源账号的 ID 或者角色 ID )
+ OperateUin *string `json:"OperateUin,omitnil" name:"OperateUin"`
+
+ // 标签信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Tags []*BillTagInfo `json:"Tags,omitnil" name:"Tags"`
+
+ // 产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 子产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 交易类型编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 地域ID
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RegionId *string `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 价格属性:该组件除单价、时长外的其他影响折扣定价的属性信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ PriceInfo []*string `json:"PriceInfo,omitnil" name:"PriceInfo"`
+
+ // 关联交易单据ID:和本笔交易关联单据 ID,如,冲销订单,记录原订单、重结订单,退费单记录对应的原购买订单号
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AssociatedOrder *BillDetailAssociatedOrder `json:"AssociatedOrder,omitnil" name:"AssociatedOrder"`
+
+ // 计算说明:特殊交易类型计费结算的详细计算说明,如退费及变配
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Formula *string `json:"Formula,omitnil" name:"Formula"`
+
+ // 计费规则:各产品详细的计费规则官网说明链接
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ FormulaUrl *string `json:"FormulaUrl,omitnil" name:"FormulaUrl"`
+
+ // 账单归属日
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillDay *string `json:"BillDay,omitnil" name:"BillDay"`
+
+ // 账单归属月
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+
+ // 账单记录ID
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Id *string `json:"Id,omitnil" name:"Id"`
+}
+
+type BillDetailAssociatedOrder struct {
+ // 新购订单
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ PrepayPurchase *string `json:"PrepayPurchase,omitnil" name:"PrepayPurchase"`
+
+ // 续费订单
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ PrepayRenew *string `json:"PrepayRenew,omitnil" name:"PrepayRenew"`
+
+ // 升配订单
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ PrepayModifyUp *string `json:"PrepayModifyUp,omitnil" name:"PrepayModifyUp"`
+
+ // 冲销订单
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ReverseOrder *string `json:"ReverseOrder,omitnil" name:"ReverseOrder"`
+
+ // 优惠调整后订单
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ NewOrder *string `json:"NewOrder,omitnil" name:"NewOrder"`
+
+ // 优惠调整前订单
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Original *string `json:"Original,omitnil" name:"Original"`
+}
+
+type BillDetailComponent struct {
+ // 组件类型:用户购买的产品或服务对应的组件大类,例如:云服务器 CVM 的组件:CPU、内存等
+ ComponentCodeName *string `json:"ComponentCodeName,omitnil" name:"ComponentCodeName"`
+
+ // 组件名称:用户购买的产品或服务,所包含的具体组件
+ ItemCodeName *string `json:"ItemCodeName,omitnil" name:"ItemCodeName"`
+
+ // 组件刊例价:组件的官网原始单价(如果客户享受一口价/合同价则默认不展示)
+ SinglePrice *string `json:"SinglePrice,omitnil" name:"SinglePrice"`
+
+ // 组件指定价(已废弃)
+ //
+ // Deprecated: SpecifiedPrice is deprecated.
+ SpecifiedPrice *string `json:"SpecifiedPrice,omitnil" name:"SpecifiedPrice"`
+
+ // 组件价格单位:组件价格的单位,单位构成:元/用量单位/时长单位
+ PriceUnit *string `json:"PriceUnit,omitnil" name:"PriceUnit"`
+
+ // 组件用量:该组件实际结算用量,组件用量 = 组件原始用量 - 抵扣用量(含资源包
+ UsedAmount *string `json:"UsedAmount,omitnil" name:"UsedAmount"`
+
+ // 组件用量单位:组件用量对应的单位
+ UsedAmountUnit *string `json:"UsedAmountUnit,omitnil" name:"UsedAmountUnit"`
+
+ // 原始用量/时长:组件被资源包抵扣前的原始用量/时长
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RealTotalMeasure *string `json:"RealTotalMeasure,omitnil" name:"RealTotalMeasure"`
+
+ // 抵扣用量/时长(含资源包):组件被资源包抵扣的用量/时长
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DeductedMeasure *string `json:"DeductedMeasure,omitnil" name:"DeductedMeasure"`
+
+ // 使用时长:资源使用的时长
+ TimeSpan *string `json:"TimeSpan,omitnil" name:"TimeSpan"`
+
+ // 时长单位:资源使用时长的单位
+ TimeUnitName *string `json:"TimeUnitName,omitnil" name:"TimeUnitName"`
+
+ // 组件原价:原价 = 组件刊例价 * 组件用量 * 使用时长(如果客户享受一口价/合同价则默认不展示,退费类场景也默认不展示)
+ Cost *string `json:"Cost,omitnil" name:"Cost"`
+
+ // 折扣率:本资源享受的折扣率(如果客户享受一口价/合同价则默认不展示,退费场景也默认不展示)
+ Discount *string `json:"Discount,omitnil" name:"Discount"`
+
+ // 优惠类型
+ ReduceType *string `json:"ReduceType,omitnil" name:"ReduceType"`
+
+ // 优惠后总价:优惠后总价=(原价 - 预留实例抵扣原价 - 节省计划抵扣原价)* 折扣率
+ RealCost *string `json:"RealCost,omitnil" name:"RealCost"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 组件类型编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ItemCode *string `json:"ItemCode,omitnil" name:"ItemCode"`
+
+ // 组件名称编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ComponentCode *string `json:"ComponentCode,omitnil" name:"ComponentCode"`
+
+ // 组件单价:组件的折后单价,组件单价 = 刊例价 * 折扣
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ContractPrice *string `json:"ContractPrice,omitnil" name:"ContractPrice"`
+
+ // 实例类型:购买的产品服务对应的实例类型,包括资源包、RI、SP、竞价实例。正常的实例展示默认为不展示
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ InstanceType *string `json:"InstanceType,omitnil" name:"InstanceType"`
+
+ // 预留实例抵扣的使用时长:本产品或服务使用预留实例抵扣的使用时长
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RiTimeSpan *string `json:"RiTimeSpan,omitnil" name:"RiTimeSpan"`
+
+ // 预留实例抵扣组件原价:本产品或服务使用预留实例抵扣的组件原价金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ OriginalCostWithRI *string `json:"OriginalCostWithRI,omitnil" name:"OriginalCostWithRI"`
+
+ // 节省计划抵扣率:节省计划可用余额额度范围内,节省计划对于此组件打的折扣率
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SPDeductionRate *string `json:"SPDeductionRate,omitnil" name:"SPDeductionRate"`
+
+ // 节省计划抵扣金额(已废弃)
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ //
+ // Deprecated: SPDeduction is deprecated.
+ SPDeduction *string `json:"SPDeduction,omitnil" name:"SPDeduction"`
+
+ // 节省计划抵扣组件原价:节省计划抵扣原价=节省计划包抵扣金额/节省计划抵扣率
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ OriginalCostWithSP *string `json:"OriginalCostWithSP,omitnil" name:"OriginalCostWithSP"`
+
+ // 混合折扣率:综合各类折扣抵扣信息后的最终折扣率,混合折扣率 = 优惠后总价 / 组件原价
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BlendedDiscount *string `json:"BlendedDiscount,omitnil" name:"BlendedDiscount"`
+
+ // 配置描述:资源配置规格信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ComponentConfig []*BillDetailComponentConfig `json:"ComponentConfig,omitnil" name:"ComponentConfig"`
+}
+
+type BillDetailComponentConfig struct {
+ // 配置描述名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Name *string `json:"Name,omitnil" name:"Name"`
+
+ // 配置描述值
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Value *string `json:"Value,omitnil" name:"Value"`
+}
+
+type BillDistributionResourceSummary struct {
+ // 产品名称:用户所采购的各类云产品,例如:云服务器 CVM
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 子产品名称:用户采购的具体产品细分类型,例如:云服务器 CVM-标准型 S1
+ ProductCodeName *string `json:"ProductCodeName,omitnil" name:"ProductCodeName"`
+
+ // 计费模式:资源的计费模式,区分为包年包月和按量计费
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 项目名称:资源归属的项目,用户在控制台给资源自主分配项目,未分配则是默认项目
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 地域:资源所属地域,如华南地区(广州)
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 可用区:资源所属可用区,如广州三区
+ ZoneName *string `json:"ZoneName,omitnil" name:"ZoneName"`
+
+ // 资源 ID:账单中出账对象 ID,不同产品因资源形态不同,资源内容不完全相同,如云服务器 CVM 为对应的实例 ID
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 资源别名:用户在控制台为资源设置的名称,如果未设置,则默认为空
+ ResourceName *string `json:"ResourceName,omitnil" name:"ResourceName"`
+
+ // 交易类型:如包年包月新购、包年包月续费、按量计费扣费等类型
+ ActionTypeName *string `json:"ActionTypeName,omitnil" name:"ActionTypeName"`
+
+ // 订单ID:包年包月计费模式下订购的订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 扣费时间:结算扣费时间
+ PayTime *string `json:"PayTime,omitnil" name:"PayTime"`
+
+ // 开始使用时间:产品服务开始使用时间
+ FeeBeginTime *string `json:"FeeBeginTime,omitnil" name:"FeeBeginTime"`
+
+ // 结束使用时间:产品服务结束使用时间
+ FeeEndTime *string `json:"FeeEndTime,omitnil" name:"FeeEndTime"`
+
+ // 配置描述:该资源下的计费项名称和用量合并展示,仅在资源账单体现
+ ConfigDesc *string `json:"ConfigDesc,omitnil" name:"ConfigDesc"`
+
+ // 扩展字段1:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField1 *string `json:"ExtendField1,omitnil" name:"ExtendField1"`
+
+ // 扩展字段2:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField2 *string `json:"ExtendField2,omitnil" name:"ExtendField2"`
+
+ // 原价:原价 = 组件刊例价 * 组件用量 * 使用时长(如果客户享受一口价/合同价则默认不展示,退费类场景也默认不展示)
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+
+ // 折扣率:本资源享受的折扣率(如果客户享受一口价/合同价则默认不展示,退费场景也默认不展示)
+ Discount *string `json:"Discount,omitnil" name:"Discount"`
+
+ // 优惠类型
+ ReduceType *string `json:"ReduceType,omitnil" name:"ReduceType"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 扩展字段3:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField3 *string `json:"ExtendField3,omitnil" name:"ExtendField3"`
+
+ // 扩展字段4:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField4 *string `json:"ExtendField4,omitnil" name:"ExtendField4"`
+
+ // 扩展字段5:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField5 *string `json:"ExtendField5,omitnil" name:"ExtendField5"`
+
+ // 标签信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Tags []*BillTagInfo `json:"Tags,omitnil" name:"Tags"`
+
+ // 使用者UIN:实际使用资源的账号 ID
+ OwnerUin *string `json:"OwnerUin,omitnil" name:"OwnerUin"`
+
+ // 操作者UIN:操作者账号 ID(预付费资源下单或后付费操作开通资源账号的 ID 或者角色 ID )
+ OperateUin *string `json:"OperateUin,omitnil" name:"OperateUin"`
+
+ // 产品编码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 子产品编码
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 地域ID
+ RegionId *int64 `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 实例类型:购买的产品服务对应的实例类型,包括资源包、RI、SP、竞价实例。正常的实例展示默认为不展示
+ InstanceType *string `json:"InstanceType,omitnil" name:"InstanceType"`
+
+ // 预留实例抵扣组件原价:本产品或服务使用预留实例抵扣的组件原价金额
+ OriginalCostWithRI *string `json:"OriginalCostWithRI,omitnil" name:"OriginalCostWithRI"`
+
+ // 节省计划抵扣金额(已废弃)
+ //
+ // Deprecated: SPDeduction is deprecated.
+ SPDeduction *string `json:"SPDeduction,omitnil" name:"SPDeduction"`
+
+ // 节省计划抵扣组件原价:节省计划抵扣原价=节省计划包抵扣金额/节省计划抵扣率
+ OriginalCostWithSP *string `json:"OriginalCostWithSP,omitnil" name:"OriginalCostWithSP"`
+
+ // 账单归属月
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+}
+
+type BillResourceSummary struct {
+ // 产品名称:用户所采购的各类云产品,例如:云服务器 CVM
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 子产品名称:用户采购的具体产品细分类型,例如:云服务器 CVM-标准型 S1
+ ProductCodeName *string `json:"ProductCodeName,omitnil" name:"ProductCodeName"`
+
+ // 计费模式:资源的计费模式,区分为包年包月和按量计费
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 项目名称:资源归属的项目,用户在控制台给资源自主分配项目,未分配则是默认项目
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 地域:资源所属地域,如华南地区(广州)
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 可用区:资源所属可用区,如广州三区
+ ZoneName *string `json:"ZoneName,omitnil" name:"ZoneName"`
+
+ // 资源 ID:账单中出账对象 ID,不同产品因资源形态不同,资源内容不完全相同,如云服务器 CVM 为对应的实例 ID
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 资源别名:用户在控制台为资源设置的名称,如果未设置,则默认为空
+ ResourceName *string `json:"ResourceName,omitnil" name:"ResourceName"`
+
+ // 交易类型:如包年包月新购、包年包月续费、按量计费扣费等类型
+ ActionTypeName *string `json:"ActionTypeName,omitnil" name:"ActionTypeName"`
+
+ // 订单ID:包年包月计费模式下订购的订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 扣费时间:结算扣费时间
+ PayTime *string `json:"PayTime,omitnil" name:"PayTime"`
+
+ // 开始使用时间:产品服务开始使用时间
+ FeeBeginTime *string `json:"FeeBeginTime,omitnil" name:"FeeBeginTime"`
+
+ // 结束使用时间:产品服务结束使用时间
+ FeeEndTime *string `json:"FeeEndTime,omitnil" name:"FeeEndTime"`
+
+ // 配置描述:该资源下的计费项名称和用量合并展示,仅在资源账单体现
+ ConfigDesc *string `json:"ConfigDesc,omitnil" name:"ConfigDesc"`
+
+ // 扩展字段1:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField1 *string `json:"ExtendField1,omitnil" name:"ExtendField1"`
+
+ // 扩展字段2:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField2 *string `json:"ExtendField2,omitnil" name:"ExtendField2"`
+
+ // 原价:原价 = 组件刊例价 * 组件用量 * 使用时长(如果客户享受一口价/合同价则默认不展示,退费类场景也默认不展示)
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+
+ // 折扣率:本资源享受的折扣率(如果客户享受一口价/合同价则默认不展示,退费场景也默认不展示)
+ Discount *string `json:"Discount,omitnil" name:"Discount"`
+
+ // 优惠类型
+ ReduceType *string `json:"ReduceType,omitnil" name:"ReduceType"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 扩展字段3:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField3 *string `json:"ExtendField3,omitnil" name:"ExtendField3"`
+
+ // 扩展字段4:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField4 *string `json:"ExtendField4,omitnil" name:"ExtendField4"`
+
+ // 扩展字段5:产品对应的扩展属性信息,仅在资源账单体现
+ ExtendField5 *string `json:"ExtendField5,omitnil" name:"ExtendField5"`
+
+ // 标签信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Tags []*BillTagInfo `json:"Tags,omitnil" name:"Tags"`
+
+ // 支付者UIN:支付者的账号 ID,账号 ID 是用户在腾讯云的唯一账号标识
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 使用者UIN:实际使用资源的账号 ID
+ OwnerUin *string `json:"OwnerUin,omitnil" name:"OwnerUin"`
+
+ // 操作者UIN:操作者账号 ID(预付费资源下单或后付费操作开通资源账号的 ID 或者角色 ID )
+ OperateUin *string `json:"OperateUin,omitnil" name:"OperateUin"`
+
+ // 产品编码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 子产品编码
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 地域ID
+ RegionId *int64 `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 实例类型:购买的产品服务对应的实例类型,包括资源包、RI、SP、竞价实例。正常的实例展示默认为不展示
+ InstanceType *string `json:"InstanceType,omitnil" name:"InstanceType"`
+
+ // 预留实例抵扣组件原价:本产品或服务使用预留实例抵扣的组件原价金额
+ OriginalCostWithRI *string `json:"OriginalCostWithRI,omitnil" name:"OriginalCostWithRI"`
+
+ // 节省计划抵扣金额(已废弃)
+ //
+ // Deprecated: SPDeduction is deprecated.
+ SPDeduction *string `json:"SPDeduction,omitnil" name:"SPDeduction"`
+
+ // 节省计划抵扣组件原价:节省计划抵扣原价=节省计划包抵扣金额/节省计划抵扣率
+ OriginalCostWithSP *string `json:"OriginalCostWithSP,omitnil" name:"OriginalCostWithSP"`
+
+ // 账单归属月
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+}
+
+type BillTagInfo struct {
+ // 分账标签键
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 标签值
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+type BillTransactionInfo struct {
+ // 收支类型:deduct 扣费, recharge 充值, return 退费, block 冻结, unblock 解冻
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 流水金额,单位(分);正数表示入账,负数表示出账
+ Amount *int64 `json:"Amount,omitnil" name:"Amount"`
+
+ // 可用余额,单位(分);正数表示入账,负数表示出账
+ Balance *int64 `json:"Balance,omitnil" name:"Balance"`
+
+ // 流水号,如20190131020000236005203583326401
+ BillId *string `json:"BillId,omitnil" name:"BillId"`
+
+ // 描述信息
+ OperationInfo *string `json:"OperationInfo,omitnil" name:"OperationInfo"`
+
+ // 操作时间"2019-01-31 23:35:10.000"
+ OperationTime *string `json:"OperationTime,omitnil" name:"OperationTime"`
+
+ // 现金账户余额,单位(分)
+ Cash *int64 `json:"Cash,omitnil" name:"Cash"`
+
+ // 赠送金余额,单位(分)
+ Incentive *int64 `json:"Incentive,omitnil" name:"Incentive"`
+
+ // 冻结余额,单位(分)
+ Freezing *int64 `json:"Freezing,omitnil" name:"Freezing"`
+
+ // 交易渠道
+ PayChannel *string `json:"PayChannel,omitnil" name:"PayChannel"`
+
+ // 扣费模式:trade 包年包月(预付费),hourh 按量-小时结,hourd 按量-日结,hourm 按量-月结,month 按量-月结
+ DeductMode *string `json:"DeductMode,omitnil" name:"DeductMode"`
+}
+
+type BusinessSummaryInfo struct {
+ // 产品编码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 产品名称:用户所采购的各类云产品,例如:云服务器 CVM
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+}
+
+type BusinessSummaryOverviewItem struct {
+ // 产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 产品名称:用户所采购的各类云产品,例如:云服务器 CVM
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 费用所占百分比,两位小数
+ RealTotalCostRatio *string `json:"RealTotalCostRatio,omitnil" name:"RealTotalCostRatio"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 账单月份,格式2019-08
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type BusinessSummaryTotal struct {
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type ConditionBusiness struct {
+ // 产品名称代码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 产品名称
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+}
+
+type ConditionPayMode struct {
+ // 付费模式
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 付费模式名称
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+}
+
+type ConditionProject struct {
+ // 项目ID
+ ProjectId *string `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 项目名称
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+}
+
+type ConditionRegion struct {
+ // 地域ID
+ RegionId *string `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 地域名称
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+}
+
+type Conditions struct {
+ // 只支持6和12两个值
+ TimeRange *uint64 `json:"TimeRange,omitnil" name:"TimeRange"`
+
+ // 产品名称代码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 地域ID
+ RegionId *int64 `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 付费模式,可选prePay和postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 资源关键字
+ ResourceKeyword *string `json:"ResourceKeyword,omitnil" name:"ResourceKeyword"`
+
+ // 产品名称代码
+ BusinessCodes []*string `json:"BusinessCodes,omitnil" name:"BusinessCodes"`
+
+ // 子产品名称代码
+ ProductCodes []*string `json:"ProductCodes,omitnil" name:"ProductCodes"`
+
+ // 地域ID
+ RegionIds []*int64 `json:"RegionIds,omitnil" name:"RegionIds"`
+
+ // 项目ID
+ ProjectIds []*int64 `json:"ProjectIds,omitnil" name:"ProjectIds"`
+
+ // 付费模式,可选prePay和postPay
+ PayModes []*string `json:"PayModes,omitnil" name:"PayModes"`
+
+ // 交易类型
+ ActionTypes []*string `json:"ActionTypes,omitnil" name:"ActionTypes"`
+
+ // 是否隐藏0元流水
+ HideFreeCost *int64 `json:"HideFreeCost,omitnil" name:"HideFreeCost"`
+
+ // 排序规则,可选desc和asc
+ OrderByCost *string `json:"OrderByCost,omitnil" name:"OrderByCost"`
+
+ // 交易ID
+ BillIds []*string `json:"BillIds,omitnil" name:"BillIds"`
+
+ // 组件编码
+ ComponentCodes []*string `json:"ComponentCodes,omitnil" name:"ComponentCodes"`
+
+ // 文件ID
+ FileIds []*string `json:"FileIds,omitnil" name:"FileIds"`
+
+ // 文件类型
+ FileTypes []*string `json:"FileTypes,omitnil" name:"FileTypes"`
+
+ // 状态
+ Status []*uint64 `json:"Status,omitnil" name:"Status"`
+}
+
+type ConsumptionBusinessSummaryDataItem struct {
+ // 产品名称代码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 产品名称
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 折后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 费用趋势
+ Trend *ConsumptionSummaryTrend `json:"Trend,omitnil" name:"Trend"`
+
+ // 现金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 代金券
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+}
+
+type ConsumptionProjectSummaryDataItem struct {
+ // 项目ID
+ ProjectId *string `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 项目名称
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 折后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 趋势
+ Trend *ConsumptionSummaryTrend `json:"Trend,omitnil" name:"Trend"`
+
+ // 产品消耗详情
+ Business []*ConsumptionBusinessSummaryDataItem `json:"Business,omitnil" name:"Business"`
+
+ // 现金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 代金券
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+}
+
+type ConsumptionRegionSummaryDataItem struct {
+ // 地域ID
+ RegionId *string `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 地域名称
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 折后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 趋势
+ Trend *ConsumptionSummaryTrend `json:"Trend,omitnil" name:"Trend"`
+
+ // 产品消费详情
+ Business []*ConsumptionBusinessSummaryDataItem `json:"Business,omitnil" name:"Business"`
+}
+
+type ConsumptionResourceSummaryConditionValue struct {
+ // 产品列表
+ Business []*ConditionBusiness `json:"Business,omitnil" name:"Business"`
+
+ // 项目列表
+ Project []*ConditionProject `json:"Project,omitnil" name:"Project"`
+
+ // 地域列表
+ Region []*ConditionRegion `json:"Region,omitnil" name:"Region"`
+
+ // 付费模式列表
+ PayMode []*ConditionPayMode `json:"PayMode,omitnil" name:"PayMode"`
+}
+
+type ConsumptionResourceSummaryDataItem struct {
+ // 资源ID
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 资源名称
+ ResourceName *string `json:"ResourceName,omitnil" name:"ResourceName"`
+
+ // 折后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金花费
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 项目ID
+ ProjectId *string `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 项目名称
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 地域ID
+ RegionId *string `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 地域名称
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 付费模式
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 付费模式名称
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 产品名称代码
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 产品名称
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 消耗类型
+ ConsumptionTypeName *string `json:"ConsumptionTypeName,omitnil" name:"ConsumptionTypeName"`
+
+ // 折前价
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RealCost *string `json:"RealCost,omitnil" name:"RealCost"`
+
+ // 费用起始时间
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ FeeBeginTime *string `json:"FeeBeginTime,omitnil" name:"FeeBeginTime"`
+
+ // 费用结束时间
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ FeeEndTime *string `json:"FeeEndTime,omitnil" name:"FeeEndTime"`
+
+ // 天数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DayDiff *string `json:"DayDiff,omitnil" name:"DayDiff"`
+
+ // 每日消耗
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DailyTotalCost *string `json:"DailyTotalCost,omitnil" name:"DailyTotalCost"`
+
+ // 订单号
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 代金券
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 赠送金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 分成金
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+}
+
+type ConsumptionSummaryTotal struct {
+ // 折后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+}
+
+type ConsumptionSummaryTrend struct {
+ // 趋势类型,upward上升/downward下降/none无
+ Type *string `json:"Type,omitnil" name:"Type"`
+
+ // 趋势值,Type为none是该字段值为null
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Value *string `json:"Value,omitnil" name:"Value"`
+}
+
+type CosDetailSets struct {
+ // 存储桶名称
+ BucketName *string `json:"BucketName,omitnil" name:"BucketName"`
+
+ // 用量开始时间
+ DosageBeginTime *string `json:"DosageBeginTime,omitnil" name:"DosageBeginTime"`
+
+ // 用量结束时间
+ DosageEndTime *string `json:"DosageEndTime,omitnil" name:"DosageEndTime"`
+
+ // 子产品名称
+ SubProductCodeName *string `json:"SubProductCodeName,omitnil" name:"SubProductCodeName"`
+
+ // 计费项名称
+ BillingItemCodeName *string `json:"BillingItemCodeName,omitnil" name:"BillingItemCodeName"`
+
+ // 用量
+ DosageValue *string `json:"DosageValue,omitnil" name:"DosageValue"`
+
+ // 单位
+ Unit *string `json:"Unit,omitnil" name:"Unit"`
+}
+
+type CostComponentSet struct {
+ // 组件类型名称
+ ComponentCodeName *string `json:"ComponentCodeName,omitnil" name:"ComponentCodeName"`
+
+ // 组件名称
+ ItemCodeName *string `json:"ItemCodeName,omitnil" name:"ItemCodeName"`
+
+ // 刊例价
+ SinglePrice *string `json:"SinglePrice,omitnil" name:"SinglePrice"`
+
+ // 刊例价单位
+ PriceUnit *string `json:"PriceUnit,omitnil" name:"PriceUnit"`
+
+ // 用量
+ UsedAmount *string `json:"UsedAmount,omitnil" name:"UsedAmount"`
+
+ // 用量单位
+ UsedAmountUnit *string `json:"UsedAmountUnit,omitnil" name:"UsedAmountUnit"`
+
+ // 原价
+ Cost *string `json:"Cost,omitnil" name:"Cost"`
+
+ // 折扣
+ Discount *string `json:"Discount,omitnil" name:"Discount"`
+
+ // 折后价
+ RealCost *string `json:"RealCost,omitnil" name:"RealCost"`
+
+ // 代金券支付金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 现金支付金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送金支付金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+}
+
+type CostDetail struct {
+ // 支付者uin
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 产品名称
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 子产品名称
+ ProductCodeName *string `json:"ProductCodeName,omitnil" name:"ProductCodeName"`
+
+ // 计费模式名称
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 项目名称
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 区域名称
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 地区名称
+ ZoneName *string `json:"ZoneName,omitnil" name:"ZoneName"`
+
+ // 资源id
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 资源名称
+ ResourceName *string `json:"ResourceName,omitnil" name:"ResourceName"`
+
+ // 类型名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ActionTypeName *string `json:"ActionTypeName,omitnil" name:"ActionTypeName"`
+
+ // 订单id
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 交易id
+ BillId *string `json:"BillId,omitnil" name:"BillId"`
+
+ // 费用开始时间
+ FeeBeginTime *string `json:"FeeBeginTime,omitnil" name:"FeeBeginTime"`
+
+ // 费用结束时间
+ FeeEndTime *string `json:"FeeEndTime,omitnil" name:"FeeEndTime"`
+
+ // 组件明细
+ ComponentSet []*CostComponentSet `json:"ComponentSet,omitnil" name:"ComponentSet"`
+
+ // 子产品名称代码
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+}
+
+// Predefined struct for user
+type CreateAllocationTagRequestParams struct {
+ // 用户分账标签键
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+type CreateAllocationTagRequest struct {
+ *tchttp.BaseRequest
+
+ // 用户分账标签键
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+func (r *CreateAllocationTagRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *CreateAllocationTagRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "TagKey")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "CreateAllocationTagRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type CreateAllocationTagResponseParams struct {
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type CreateAllocationTagResponse struct {
+ *tchttp.BaseResponse
+ Response *CreateAllocationTagResponseParams `json:"Response"`
+}
+
+func (r *CreateAllocationTagResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *CreateAllocationTagResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type CreateSavingPlanOrderRequestParams struct {
+ // 地域编码
+ RegionId *int64 `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 区域编码
+ ZoneId *int64 `json:"ZoneId,omitnil" name:"ZoneId"`
+
+ // 预付费类型
+ PrePayType *string `json:"PrePayType,omitnil" name:"PrePayType"`
+
+ // 时长
+ TimeSpan *uint64 `json:"TimeSpan,omitnil" name:"TimeSpan"`
+
+ // 时长单位
+ TimeUnit *string `json:"TimeUnit,omitnil" name:"TimeUnit"`
+
+ // 商品唯一标识
+ CommodityCode *string `json:"CommodityCode,omitnil" name:"CommodityCode"`
+
+ // 承诺时长内的小额金额(单位:元)
+ PromiseUseAmount *uint64 `json:"PromiseUseAmount,omitnil" name:"PromiseUseAmount"`
+
+ // 节省计划的指定生效时间,若不传则为当前下单时间。传参数格式:"2023-10-01 00:00:00",仅支持指定日期的0点时刻
+ SpecifyEffectTime *string `json:"SpecifyEffectTime,omitnil" name:"SpecifyEffectTime"`
+
+ // 可重入ID
+ ClientToken *string `json:"ClientToken,omitnil" name:"ClientToken"`
+}
+
+type CreateSavingPlanOrderRequest struct {
+ *tchttp.BaseRequest
+
+ // 地域编码
+ RegionId *int64 `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 区域编码
+ ZoneId *int64 `json:"ZoneId,omitnil" name:"ZoneId"`
+
+ // 预付费类型
+ PrePayType *string `json:"PrePayType,omitnil" name:"PrePayType"`
+
+ // 时长
+ TimeSpan *uint64 `json:"TimeSpan,omitnil" name:"TimeSpan"`
+
+ // 时长单位
+ TimeUnit *string `json:"TimeUnit,omitnil" name:"TimeUnit"`
+
+ // 商品唯一标识
+ CommodityCode *string `json:"CommodityCode,omitnil" name:"CommodityCode"`
+
+ // 承诺时长内的小额金额(单位:元)
+ PromiseUseAmount *uint64 `json:"PromiseUseAmount,omitnil" name:"PromiseUseAmount"`
+
+ // 节省计划的指定生效时间,若不传则为当前下单时间。传参数格式:"2023-10-01 00:00:00",仅支持指定日期的0点时刻
+ SpecifyEffectTime *string `json:"SpecifyEffectTime,omitnil" name:"SpecifyEffectTime"`
+
+ // 可重入ID
+ ClientToken *string `json:"ClientToken,omitnil" name:"ClientToken"`
+}
+
+func (r *CreateSavingPlanOrderRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *CreateSavingPlanOrderRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "RegionId")
+ delete(f, "ZoneId")
+ delete(f, "PrePayType")
+ delete(f, "TimeSpan")
+ delete(f, "TimeUnit")
+ delete(f, "CommodityCode")
+ delete(f, "PromiseUseAmount")
+ delete(f, "SpecifyEffectTime")
+ delete(f, "ClientToken")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "CreateSavingPlanOrderRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type CreateSavingPlanOrderResponseParams struct {
+ // 订单号
+ BigDealId *string `json:"BigDealId,omitnil" name:"BigDealId"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type CreateSavingPlanOrderResponse struct {
+ *tchttp.BaseResponse
+ Response *CreateSavingPlanOrderResponseParams `json:"Response"`
+}
+
+func (r *CreateSavingPlanOrderResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *CreateSavingPlanOrderResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+type Deal struct {
+ // 订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 订单的状态 1:未支付 2:已支付3:发货中 4:已发货 5:发货失败 6:已退款 7:已关单 8:订单过期 9:订单已失效 10:产品已失效 11:代付拒绝 12:支付中
+ Status *int64 `json:"Status,omitnil" name:"Status"`
+
+ // 支付者
+ Payer *string `json:"Payer,omitnil" name:"Payer"`
+
+ // 创建时间
+ CreateTime *string `json:"CreateTime,omitnil" name:"CreateTime"`
+
+ // 创建人
+ Creator *string `json:"Creator,omitnil" name:"Creator"`
+
+ // 实际支付金额(分)
+ RealTotalCost *int64 `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 代金券抵扣金额(分)
+ VoucherDecline *int64 `json:"VoucherDecline,omitnil" name:"VoucherDecline"`
+
+ // 项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 产品分类ID
+ GoodsCategoryId *int64 `json:"GoodsCategoryId,omitnil" name:"GoodsCategoryId"`
+
+ // 产品详情
+ ProductInfo []*ProductInfo `json:"ProductInfo,omitnil" name:"ProductInfo"`
+
+ // 时长
+ TimeSpan *float64 `json:"TimeSpan,omitnil" name:"TimeSpan"`
+
+ // 时间单位
+ TimeUnit *string `json:"TimeUnit,omitnil" name:"TimeUnit"`
+
+ // 货币单位
+ Currency *string `json:"Currency,omitnil" name:"Currency"`
+
+ // 折扣率
+ Policy *float64 `json:"Policy,omitnil" name:"Policy"`
+
+ // 单价(分)
+ Price *float64 `json:"Price,omitnil" name:"Price"`
+
+ // 原价(分)
+ TotalCost *float64 `json:"TotalCost,omitnil" name:"TotalCost"`
+
+ // 产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 子产品编码
+ SubProductCode *string `json:"SubProductCode,omitnil" name:"SubProductCode"`
+
+ // 大订单号
+ BigDealId *string `json:"BigDealId,omitnil" name:"BigDealId"`
+
+ // 退费公式
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Formula *string `json:"Formula,omitnil" name:"Formula"`
+
+ // 退费涉及订单信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RefReturnDeals *string `json:"RefReturnDeals,omitnil" name:"RefReturnDeals"`
+
+ // 付费模式:prePay 预付费 postPay后付费 riPay预留实例
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 交易类型
+ // modifyNetworkMode 调整带宽模式
+ // modifyNetworkSize 调整带宽大小
+ // refund 退款
+ // downgrade 降配
+ // upgrade 升配
+ // renew 续费
+ // purchase 购买
+ // preMoveOut 包年包月迁出资源
+ // preMoveIn 包年包月迁入资源
+ // preToPost 预付费转后付费
+ // postMoveOut 按量计费迁出资源
+ // postMoveIn 按量计费迁入资源
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Action *string `json:"Action,omitnil" name:"Action"`
+
+ // 产品编码中文名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductName *string `json:"ProductName,omitnil" name:"ProductName"`
+
+ // 子产品编码中文名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubProductName *string `json:"SubProductName,omitnil" name:"SubProductName"`
+
+ // 订单对应的资源id, 查询参数Limit超过200,将返回null
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ResourceId []*string `json:"ResourceId,omitnil" name:"ResourceId"`
+}
+
+// Predefined struct for user
+type DeleteAllocationTagRequestParams struct {
+ // 用户分账标签键
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+type DeleteAllocationTagRequest struct {
+ *tchttp.BaseRequest
+
+ // 用户分账标签键
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+func (r *DeleteAllocationTagRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DeleteAllocationTagRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "TagKey")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DeleteAllocationTagRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DeleteAllocationTagResponseParams struct {
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DeleteAllocationTagResponse struct {
+ *tchttp.BaseResponse
+ Response *DeleteAllocationTagResponseParams `json:"Response"`
+}
+
+func (r *DeleteAllocationTagResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DeleteAllocationTagResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeAccountBalanceRequestParams struct {
+
+}
+
+type DescribeAccountBalanceRequest struct {
+ *tchttp.BaseRequest
+
+}
+
+func (r *DescribeAccountBalanceRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeAccountBalanceRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeAccountBalanceRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeAccountBalanceResponseParams struct {
+ // 接口做过变更,为兼容老接口,本字段与RealBalance相同,为当前真实可用余额,单位 分
+ Balance *int64 `json:"Balance,omitnil" name:"Balance"`
+
+ // 查询的用户Uin
+ Uin *uint64 `json:"Uin,omitnil" name:"Uin"`
+
+ // 当前真实可用余额,单位 分
+ RealBalance *float64 `json:"RealBalance,omitnil" name:"RealBalance"`
+
+ // 现金账户余额,单位 分
+ CashAccountBalance *float64 `json:"CashAccountBalance,omitnil" name:"CashAccountBalance"`
+
+ // 收益转入账户余额,单位 分
+ IncomeIntoAccountBalance *float64 `json:"IncomeIntoAccountBalance,omitnil" name:"IncomeIntoAccountBalance"`
+
+ // 赠送账户余额,单位 分
+ PresentAccountBalance *float64 `json:"PresentAccountBalance,omitnil" name:"PresentAccountBalance"`
+
+ // 冻结金额,单位 分
+ FreezeAmount *float64 `json:"FreezeAmount,omitnil" name:"FreezeAmount"`
+
+ // 欠费金额,单位 分
+ OweAmount *float64 `json:"OweAmount,omitnil" name:"OweAmount"`
+
+ // 是否允许欠费消费
+ IsAllowArrears *bool `json:"IsAllowArrears,omitnil" name:"IsAllowArrears"`
+
+ // 是否限制信用额度
+ IsCreditLimited *bool `json:"IsCreditLimited,omitnil" name:"IsCreditLimited"`
+
+ // 信用额度
+ CreditAmount *float64 `json:"CreditAmount,omitnil" name:"CreditAmount"`
+
+ // 可用信用额度
+ CreditBalance *float64 `json:"CreditBalance,omitnil" name:"CreditBalance"`
+
+ // 真实可用信用额度
+ RealCreditBalance *float64 `json:"RealCreditBalance,omitnil" name:"RealCreditBalance"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeAccountBalanceResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeAccountBalanceResponseParams `json:"Response"`
+}
+
+func (r *DescribeAccountBalanceResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeAccountBalanceResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillDetailForOrganizationRequestParams struct {
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ //
+ // Deprecated: PeriodType is deprecated.
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 月份,格式为yyyy-mm,Month和BeginTime&EndTime必传一个,如果有传BeginTime&EndTime则Month字段无效。最多可拉取近18个月内的数据。
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期开始时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取18个月内的数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 周期结束时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取近18个月内的数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 付费模式 prePay(表示包年包月)/postPay(表示按时按量)
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 项目ID:资源所属项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 上一次请求返回的上下文信息,翻页查询Month>=2023-05的月份的数据可加快查询速度,数据量10万级别以上的用户建议使用,查询速度可提升2~10倍
+ Context *string `json:"Context,omitnil" name:"Context"`
+}
+
+type DescribeBillDetailForOrganizationRequest struct {
+ *tchttp.BaseRequest
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 月份,格式为yyyy-mm,Month和BeginTime&EndTime必传一个,如果有传BeginTime&EndTime则Month字段无效。最多可拉取近18个月内的数据。
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期开始时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取18个月内的数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 周期结束时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取近18个月内的数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 付费模式 prePay(表示包年包月)/postPay(表示按时按量)
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 项目ID:资源所属项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 上一次请求返回的上下文信息,翻页查询Month>=2023-05的月份的数据可加快查询速度,数据量10万级别以上的用户建议使用,查询速度可提升2~10倍
+ Context *string `json:"Context,omitnil" name:"Context"`
+}
+
+func (r *DescribeBillDetailForOrganizationRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillDetailForOrganizationRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "PeriodType")
+ delete(f, "Month")
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "NeedRecordNum")
+ delete(f, "PayMode")
+ delete(f, "ResourceId")
+ delete(f, "ActionType")
+ delete(f, "ProjectId")
+ delete(f, "BusinessCode")
+ delete(f, "Context")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillDetailForOrganizationRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillDetailForOrganizationResponseParams struct {
+ // 详情列表
+ DetailSet []*DistributionBillDetail `json:"DetailSet,omitnil" name:"DetailSet"`
+
+ // 总记录数,24小时缓存一次,可能比实际总记录数少
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Total *uint64 `json:"Total,omitnil" name:"Total"`
+
+ // 本次请求的上下文信息,可用于下一次请求的请求参数中,加快查询速度
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Context *string `json:"Context,omitnil" name:"Context"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillDetailForOrganizationResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillDetailForOrganizationResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillDetailForOrganizationResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillDetailForOrganizationResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillDetailRequestParams struct {
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ //
+ // Deprecated: PeriodType is deprecated.
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 月份,格式为yyyy-mm,Month和BeginTime&EndTime必传一个,如果有传BeginTime&EndTime则Month字段无效。最多可拉取近18个月内的数据。
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期开始时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取18个月内的数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 周期结束时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取近18个月内的数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 已废弃参数,未开放
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 付费模式 prePay(表示包年包月)/postPay(表示按时按量)
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 项目ID:资源所属项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 上一次请求返回的上下文信息,翻页查询Month>=2023-05的月份的数据可加快查询速度,数据量10万级别以上的用户建议使用,查询速度可提升2~10倍
+ Context *string `json:"Context,omitnil" name:"Context"`
+
+ // 支付者的账号 ID(账号 ID 是用户在腾讯云的唯一账号标识),默认查询本账号账单,如集团管理账号需查询成员账号自付的账单,该字段需入参成员账号UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+type DescribeBillDetailRequest struct {
+ *tchttp.BaseRequest
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 月份,格式为yyyy-mm,Month和BeginTime&EndTime必传一个,如果有传BeginTime&EndTime则Month字段无效。最多可拉取近18个月内的数据。
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期开始时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取18个月内的数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 周期结束时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为相同月份,不支持跨月查询,查询结果是整月数据。最多可拉取近18个月内的数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 已废弃参数,未开放
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 付费模式 prePay(表示包年包月)/postPay(表示按时按量)
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 项目ID:资源所属项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 上一次请求返回的上下文信息,翻页查询Month>=2023-05的月份的数据可加快查询速度,数据量10万级别以上的用户建议使用,查询速度可提升2~10倍
+ Context *string `json:"Context,omitnil" name:"Context"`
+
+ // 支付者的账号 ID(账号 ID 是用户在腾讯云的唯一账号标识),默认查询本账号账单,如集团管理账号需查询成员账号自付的账单,该字段需入参成员账号UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+func (r *DescribeBillDetailRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillDetailRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "PeriodType")
+ delete(f, "Month")
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "NeedRecordNum")
+ delete(f, "ProductCode")
+ delete(f, "PayMode")
+ delete(f, "ResourceId")
+ delete(f, "ActionType")
+ delete(f, "ProjectId")
+ delete(f, "BusinessCode")
+ delete(f, "Context")
+ delete(f, "PayerUin")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillDetailRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillDetailResponseParams struct {
+ // 详情列表
+ DetailSet []*BillDetail `json:"DetailSet,omitnil" name:"DetailSet"`
+
+ // 总记录数,24小时缓存一次,可能比实际总记录数少
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Total *uint64 `json:"Total,omitnil" name:"Total"`
+
+ // 本次请求的上下文信息,可用于下一次请求的请求参数中,加快查询速度
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Context *string `json:"Context,omitnil" name:"Context"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillDetailResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillDetailResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillDetailResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillDetailResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillDownloadUrlRequestParams struct {
+ // 账单类型,枚举值
+ // billOverview=L0-PDF账单
+ // billSummary=L1-汇总账单
+ // billResource=L2-资源账单
+ // billDetail=L3-明细账单
+ // billPack=账单包
+ FileType *string `json:"FileType,omitnil" name:"FileType"`
+
+ // 账单月份
+ // 支持的最早开始月份为2021-01
+ // L0-PDF&账单包不支持当月下载,当月账单请在次月1号19:00出账后下载
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 下载的账号 ID列表,默认查询本账号账单,如集团管理账号需下载成员账号自付的账单,该字段需入参成员账号UIN
+ ChildUin []*string `json:"ChildUin,omitnil" name:"ChildUin"`
+}
+
+type DescribeBillDownloadUrlRequest struct {
+ *tchttp.BaseRequest
+
+ // 账单类型,枚举值
+ // billOverview=L0-PDF账单
+ // billSummary=L1-汇总账单
+ // billResource=L2-资源账单
+ // billDetail=L3-明细账单
+ // billPack=账单包
+ FileType *string `json:"FileType,omitnil" name:"FileType"`
+
+ // 账单月份
+ // 支持的最早开始月份为2021-01
+ // L0-PDF&账单包不支持当月下载,当月账单请在次月1号19:00出账后下载
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 下载的账号 ID列表,默认查询本账号账单,如集团管理账号需下载成员账号自付的账单,该字段需入参成员账号UIN
+ ChildUin []*string `json:"ChildUin,omitnil" name:"ChildUin"`
+}
+
+func (r *DescribeBillDownloadUrlRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillDownloadUrlRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "FileType")
+ delete(f, "Month")
+ delete(f, "ChildUin")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillDownloadUrlRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillDownloadUrlResponseParams struct {
+ // 账单文件是否准备就绪,0文件生成中,1文件已生成
+ Ready *int64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 账单文件下载链接,有效时长为一小时
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DownloadUrl *string `json:"DownloadUrl,omitnil" name:"DownloadUrl"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillDownloadUrlResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillDownloadUrlResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillDownloadUrlResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillDownloadUrlResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillListRequestParams struct {
+ // 查询范围的起始时间(包含)时间格式 yyyy-MM-dd HH:mm:ss 开始时间和结束时间差值小于等于六个月
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 查询范围的结束时间(包含)时间格式 yyyy-MM-dd HH:mm:ss ,开始时间和结束时间差值小于等于六个月
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 翻页偏移量,初始值为0
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 每页的限制数量
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 交易类型: all所有交易类型,recharge充值,return退款,unblock解冻,agentin资金转入,advanced垫付,cash提现,deduct扣费,block冻结,agentout资金转出,repay垫付回款,repayment还款(仅国际信用账户),adj_refund调增(仅国际信用账户),adj_deduct调减(仅国际信用账户)
+ PayType []*string `json:"PayType,omitnil" name:"PayType"`
+
+ // 扣费模式,
+ // 当所选的交易类型为扣费deduct时:
+ // all所有扣费类型;trade预付费支付;hour_h按量小时结;hour_d按量日结;hour_m按量月结;decompensate调账扣费;other第三方扣费;panshi 线下项目扣费;offline 线下产品扣费;
+ //
+ // 当所选的交易类型为扣费recharge时:
+ // online 在线充值;bank-enterprice 银企直连;offline 线下充值;transfer 分成充值
+ //
+ // 当所选的交易类型为扣费cash时:
+ // online 线上提现;offline 线下提现;panshi 赠送金清零
+ //
+ // 当所选的交易类型为扣费advanced时:
+ // advanced 垫付充值
+ //
+ // 当所选的交易类型为扣费repay时:
+ // panshi 垫付回款
+ //
+ // 当所选的交易类型为扣费block时:
+ // other 第三方冻结;hour 按量冻结;month按月冻结
+ //
+ // 当所选的交易类型为扣费return时:
+ // compensate 调账补偿;trade 预付费退款
+ //
+ // 当所选的交易类型为扣费unblock时:
+ // other 第三方解冻;hour 按量解冻;month 按月解冻
+ SubPayType []*string `json:"SubPayType,omitnil" name:"SubPayType"`
+
+ // 是否返回0元交易金额的交易项,取值:0-不返回,1-返回。不传该参数则不返回
+ WithZeroAmount *uint64 `json:"WithZeroAmount,omitnil" name:"WithZeroAmount"`
+}
+
+type DescribeBillListRequest struct {
+ *tchttp.BaseRequest
+
+ // 查询范围的起始时间(包含)时间格式 yyyy-MM-dd HH:mm:ss 开始时间和结束时间差值小于等于六个月
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 查询范围的结束时间(包含)时间格式 yyyy-MM-dd HH:mm:ss ,开始时间和结束时间差值小于等于六个月
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 翻页偏移量,初始值为0
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 每页的限制数量
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 交易类型: all所有交易类型,recharge充值,return退款,unblock解冻,agentin资金转入,advanced垫付,cash提现,deduct扣费,block冻结,agentout资金转出,repay垫付回款,repayment还款(仅国际信用账户),adj_refund调增(仅国际信用账户),adj_deduct调减(仅国际信用账户)
+ PayType []*string `json:"PayType,omitnil" name:"PayType"`
+
+ // 扣费模式,
+ // 当所选的交易类型为扣费deduct时:
+ // all所有扣费类型;trade预付费支付;hour_h按量小时结;hour_d按量日结;hour_m按量月结;decompensate调账扣费;other第三方扣费;panshi 线下项目扣费;offline 线下产品扣费;
+ //
+ // 当所选的交易类型为扣费recharge时:
+ // online 在线充值;bank-enterprice 银企直连;offline 线下充值;transfer 分成充值
+ //
+ // 当所选的交易类型为扣费cash时:
+ // online 线上提现;offline 线下提现;panshi 赠送金清零
+ //
+ // 当所选的交易类型为扣费advanced时:
+ // advanced 垫付充值
+ //
+ // 当所选的交易类型为扣费repay时:
+ // panshi 垫付回款
+ //
+ // 当所选的交易类型为扣费block时:
+ // other 第三方冻结;hour 按量冻结;month按月冻结
+ //
+ // 当所选的交易类型为扣费return时:
+ // compensate 调账补偿;trade 预付费退款
+ //
+ // 当所选的交易类型为扣费unblock时:
+ // other 第三方解冻;hour 按量解冻;month 按月解冻
+ SubPayType []*string `json:"SubPayType,omitnil" name:"SubPayType"`
+
+ // 是否返回0元交易金额的交易项,取值:0-不返回,1-返回。不传该参数则不返回
+ WithZeroAmount *uint64 `json:"WithZeroAmount,omitnil" name:"WithZeroAmount"`
+}
+
+func (r *DescribeBillListRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillListRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartTime")
+ delete(f, "EndTime")
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "PayType")
+ delete(f, "SubPayType")
+ delete(f, "WithZeroAmount")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillListRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillListResponseParams struct {
+ // 收支明细列表
+ TransactionList []*BillTransactionInfo `json:"TransactionList,omitnil" name:"TransactionList"`
+
+ // 总条数
+ Total *int64 `json:"Total,omitnil" name:"Total"`
+
+ // 退费总额,单位(分)
+ ReturnAmount *float64 `json:"ReturnAmount,omitnil" name:"ReturnAmount"`
+
+ // 充值总额,单位(分)
+ RechargeAmount *float64 `json:"RechargeAmount,omitnil" name:"RechargeAmount"`
+
+ // 冻结总额,单位(分)
+ BlockAmount *float64 `json:"BlockAmount,omitnil" name:"BlockAmount"`
+
+ // 解冻总额,单位(分)
+ UnblockAmount *float64 `json:"UnblockAmount,omitnil" name:"UnblockAmount"`
+
+ // 扣费总额,单位(分)
+ DeductAmount *float64 `json:"DeductAmount,omitnil" name:"DeductAmount"`
+
+ // 资金转入总额,单位(分)
+ AgentInAmount *float64 `json:"AgentInAmount,omitnil" name:"AgentInAmount"`
+
+ // 垫付充值总额,单位(分)
+ AdvanceRechargeAmount *float64 `json:"AdvanceRechargeAmount,omitnil" name:"AdvanceRechargeAmount"`
+
+ // 提现扣减总额,单位(分)
+ WithdrawAmount *float64 `json:"WithdrawAmount,omitnil" name:"WithdrawAmount"`
+
+ // 资金转出总额,单位(分)
+ AgentOutAmount *float64 `json:"AgentOutAmount,omitnil" name:"AgentOutAmount"`
+
+ // 还垫付总额,单位(分)
+ AdvancePayAmount *float64 `json:"AdvancePayAmount,omitnil" name:"AdvancePayAmount"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillListResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillListResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillListResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillListResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillResourceSummaryForOrganizationRequestParams struct {
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为1000
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 月份,格式为yyyy-mm。不能早于开通账单2.0的月份
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ //
+ // Deprecated: PeriodType is deprecated.
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 付费模式 prePay/postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 分账标签键,用户自定义(支持2021-01以后账单查询)
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 分账标签值,该参数为空表示该标签键下未设置标签值的记录
+ // (支持2021-01以后账单查询)
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+type DescribeBillResourceSummaryForOrganizationRequest struct {
+ *tchttp.BaseRequest
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为1000
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 月份,格式为yyyy-mm。不能早于开通账单2.0的月份
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 付费模式 prePay/postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 分账标签键,用户自定义(支持2021-01以后账单查询)
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 分账标签值,该参数为空表示该标签键下未设置标签值的记录
+ // (支持2021-01以后账单查询)
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+func (r *DescribeBillResourceSummaryForOrganizationRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillResourceSummaryForOrganizationRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "Month")
+ delete(f, "PeriodType")
+ delete(f, "NeedRecordNum")
+ delete(f, "ActionType")
+ delete(f, "ResourceId")
+ delete(f, "PayMode")
+ delete(f, "BusinessCode")
+ delete(f, "TagKey")
+ delete(f, "TagValue")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillResourceSummaryForOrganizationRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillResourceSummaryForOrganizationResponseParams struct {
+ // 资源汇总列表
+ ResourceSummarySet []*BillDistributionResourceSummary `json:"ResourceSummarySet,omitnil" name:"ResourceSummarySet"`
+
+ // 资源汇总列表总数,入参NeedRecordNum为0时不返回
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Total *int64 `json:"Total,omitnil" name:"Total"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillResourceSummaryForOrganizationResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillResourceSummaryForOrganizationResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillResourceSummaryForOrganizationResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillResourceSummaryForOrganizationResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillResourceSummaryRequestParams struct {
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为1000
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 月份,格式为yyyy-mm。不能早于开通账单2.0的月份
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ //
+ // Deprecated: PeriodType is deprecated.
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 付费模式 prePay/postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 支付者的账号 ID(账号 ID 是用户在腾讯云的唯一账号标识),默认查询本账号账单,如集团管理账号需查询成员账号自付的账单,该字段需入参成员账号UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 分账标签键,用户自定义(支持2021-01以后账单查询)
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 分账标签值,该参数为空表示该标签键下未设置标签值的记录
+ // (支持2021-01以后账单查询)
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+type DescribeBillResourceSummaryRequest struct {
+ *tchttp.BaseRequest
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为1000
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 月份,格式为yyyy-mm。不能早于开通账单2.0的月份
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 周期类型,byUsedTime按计费周期/byPayTime按扣费周期。需要与费用中心该月份账单的周期保持一致。您可前往[账单概览](https://console.cloud.tencent.com/expense/bill/overview)页面顶部查看确认您的账单统计周期类型。
+ PeriodType *string `json:"PeriodType,omitnil" name:"PeriodType"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *int64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 查询交易类型(请使用交易类型名称入参),入参示例枚举如下:
+ // 包年包月新购
+ // 包年包月续费
+ // 包年包月配置变更
+ // 包年包月退款
+ // 按量计费扣费
+ // 线下项目扣费
+ // 线下产品扣费
+ // 调账扣费
+ // 调账补偿
+ // 按量计费小时结
+ // 按量计费日结
+ // 按量计费月结
+ // 竞价实例小时结
+ // 线下项目调账补偿
+ // 线下产品调账补偿
+ // 优惠扣费
+ // 优惠补偿
+ // 按量计费迁入资源
+ // 按量计费迁出资源
+ // 包年包月迁入资源
+ // 包年包月迁出资源
+ // 预付费用
+ // 小时费用
+ // 预留实例退款
+ // 按量计费冲正
+ // 包年包月转按量
+ // 保底扣款
+ // 节省计划小时费用
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 付费模式 prePay/postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 产品名称代码
+ // 备注:如需获取当月使用过的BusinessCode,请调用API:获取产品汇总费用分布
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 支付者的账号 ID(账号 ID 是用户在腾讯云的唯一账号标识),默认查询本账号账单,如集团管理账号需查询成员账号自付的账单,该字段需入参成员账号UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 分账标签键,用户自定义(支持2021-01以后账单查询)
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 分账标签值,该参数为空表示该标签键下未设置标签值的记录
+ // (支持2021-01以后账单查询)
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+func (r *DescribeBillResourceSummaryRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillResourceSummaryRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "Month")
+ delete(f, "PeriodType")
+ delete(f, "NeedRecordNum")
+ delete(f, "ActionType")
+ delete(f, "ResourceId")
+ delete(f, "PayMode")
+ delete(f, "BusinessCode")
+ delete(f, "PayerUin")
+ delete(f, "TagKey")
+ delete(f, "TagValue")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillResourceSummaryRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillResourceSummaryResponseParams struct {
+ // 资源汇总列表
+ ResourceSummarySet []*BillResourceSummary `json:"ResourceSummarySet,omitnil" name:"ResourceSummarySet"`
+
+ // 资源汇总列表总数,入参NeedRecordNum为0时不返回
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Total *int64 `json:"Total,omitnil" name:"Total"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillResourceSummaryResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillResourceSummaryResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillResourceSummaryResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillResourceSummaryResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByPayModeRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+type DescribeBillSummaryByPayModeRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+func (r *DescribeBillSummaryByPayModeRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByPayModeRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "PayerUin")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryByPayModeRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByPayModeResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 各付费模式花费分布详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryOverview []*PayModeSummaryOverviewItem `json:"SummaryOverview,omitnil" name:"SummaryOverview"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryByPayModeResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryByPayModeResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryByPayModeResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByPayModeResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByProductRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 款项类别,与L0账单上的汇总类别对应。
+ // 此参数自账单3.0(即2021-05)之后开始生效。
+ // 枚举值:
+ // consume-消费
+ // refund-退款
+ // adjustment-调账
+ PayType *string `json:"PayType,omitnil" name:"PayType"`
+}
+
+type DescribeBillSummaryByProductRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 款项类别,与L0账单上的汇总类别对应。
+ // 此参数自账单3.0(即2021-05)之后开始生效。
+ // 枚举值:
+ // consume-消费
+ // refund-退款
+ // adjustment-调账
+ PayType *string `json:"PayType,omitnil" name:"PayType"`
+}
+
+func (r *DescribeBillSummaryByProductRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByProductRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "PayerUin")
+ delete(f, "PayType")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryByProductRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByProductResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 总花费详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryTotal *BusinessSummaryTotal `json:"SummaryTotal,omitnil" name:"SummaryTotal"`
+
+ // 各产品花费分布
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryOverview []*BusinessSummaryOverviewItem `json:"SummaryOverview,omitnil" name:"SummaryOverview"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryByProductResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryByProductResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryByProductResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByProductResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByProjectRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+type DescribeBillSummaryByProjectRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+func (r *DescribeBillSummaryByProjectRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByProjectRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "PayerUin")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryByProjectRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByProjectResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 各项目花费分布详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryOverview []*ProjectSummaryOverviewItem `json:"SummaryOverview,omitnil" name:"SummaryOverview"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryByProjectResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryByProjectResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryByProjectResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByProjectResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByRegionRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+type DescribeBillSummaryByRegionRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+func (r *DescribeBillSummaryByRegionRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByRegionRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "PayerUin")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryByRegionRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByRegionResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 各地域花费分布详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryOverview []*RegionSummaryOverviewItem `json:"SummaryOverview,omitnil" name:"SummaryOverview"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryByRegionResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryByRegionResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryByRegionResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByRegionResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByTagRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 分账标签键,用户自定义
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 分账标签值
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+type DescribeBillSummaryByTagRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 分账标签键,用户自定义
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 分账标签值
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+}
+
+func (r *DescribeBillSummaryByTagRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByTagRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "TagKey")
+ delete(f, "PayerUin")
+ delete(f, "TagValue")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryByTagRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryByTagResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 各标签值花费分布详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryOverview []*TagSummaryOverviewItem `json:"SummaryOverview,omitnil" name:"SummaryOverview"`
+
+ // 总数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SummaryTotal *SummaryTotal `json:"SummaryTotal,omitnil" name:"SummaryTotal"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryByTagResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryByTagResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryByTagResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryByTagResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryForOrganizationRequestParams struct {
+ // 账单月份,格式为2023-04
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 账单维度类型,枚举值如下:business、project、region、payMode、tag
+ GroupType *string `json:"GroupType,omitnil" name:"GroupType"`
+
+ // 标签键,GroupType=tag获取标签维度账单时传
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+type DescribeBillSummaryForOrganizationRequest struct {
+ *tchttp.BaseRequest
+
+ // 账单月份,格式为2023-04
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 账单维度类型,枚举值如下:business、project、region、payMode、tag
+ GroupType *string `json:"GroupType,omitnil" name:"GroupType"`
+
+ // 标签键,GroupType=tag获取标签维度账单时传
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+func (r *DescribeBillSummaryForOrganizationRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryForOrganizationRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Month")
+ delete(f, "GroupType")
+ delete(f, "TagKey")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryForOrganizationRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryForOrganizationResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 账单多维度汇总消费详情
+ SummaryDetail []*SummaryDetail `json:"SummaryDetail,omitnil" name:"SummaryDetail"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryForOrganizationResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryForOrganizationResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryForOrganizationResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryForOrganizationResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryRequestParams struct {
+ // 账单月份,格式为2023-04
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 账单维度类型,枚举值如下:business、project、region、payMode、tag
+ GroupType *string `json:"GroupType,omitnil" name:"GroupType"`
+
+ // 标签键,GroupType=tag获取标签维度账单时传
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+type DescribeBillSummaryRequest struct {
+ *tchttp.BaseRequest
+
+ // 账单月份,格式为2023-04
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 账单维度类型,枚举值如下:business、project、region、payMode、tag
+ GroupType *string `json:"GroupType,omitnil" name:"GroupType"`
+
+ // 标签键,GroupType=tag获取标签维度账单时传
+ TagKey []*string `json:"TagKey,omitnil" name:"TagKey"`
+}
+
+func (r *DescribeBillSummaryRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Month")
+ delete(f, "GroupType")
+ delete(f, "TagKey")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeBillSummaryRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeBillSummaryResponseParams struct {
+ // 数据是否准备好,0准备中,1已就绪。(Ready=0,为当前UIN首次进行初始化出账,预计需要5~10分钟出账,请于10分钟后重试即可)
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 账单多维度汇总消费详情
+ SummaryDetail []*SummaryDetail `json:"SummaryDetail,omitnil" name:"SummaryDetail"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeBillSummaryResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeBillSummaryResponseParams `json:"Response"`
+}
+
+func (r *DescribeBillSummaryResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeBillSummaryResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostDetailRequestParams struct {
+ // 数量,最大值为100
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 周期开始时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为同一月份,暂不支持跨月拉取。可拉取的数据是开通成本分析后,且距今 24 个月内的数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 周期结束时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为同一月份,暂不支持跨月拉取。可拉取的数据是开通成本分析后,且距今 24 个月内的数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 月份,格式为yyyy-mm,Month和BeginTime&EndTime必传一个,如果有传BeginTime&EndTime则Month字段无效。不能早于开通成本分析的月份,最多可拉取24个月内的数据。
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 查询指定产品信息(暂时未开放获取)
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 付费模式 prePay/postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+}
+
+type DescribeCostDetailRequest struct {
+ *tchttp.BaseRequest
+
+ // 数量,最大值为100
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 周期开始时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为同一月份,暂不支持跨月拉取。可拉取的数据是开通成本分析后,且距今 24 个月内的数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 周期结束时间,格式为yyyy-mm-dd hh:ii:ss,Month和BeginTime&EndTime必传一个,如果有该字段则Month字段无效。BeginTime和EndTime必须一起传,且为同一月份,暂不支持跨月拉取。可拉取的数据是开通成本分析后,且距今 24 个月内的数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 是否需要访问列表的总记录数,用于前端分页
+ // 1-表示需要, 0-表示不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 月份,格式为yyyy-mm,Month和BeginTime&EndTime必传一个,如果有传BeginTime&EndTime则Month字段无效。不能早于开通成本分析的月份,最多可拉取24个月内的数据。
+ Month *string `json:"Month,omitnil" name:"Month"`
+
+ // 查询指定产品信息(暂时未开放获取)
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 付费模式 prePay/postPay
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 查询指定资源信息
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+}
+
+func (r *DescribeCostDetailRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostDetailRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "NeedRecordNum")
+ delete(f, "Month")
+ delete(f, "ProductCode")
+ delete(f, "PayMode")
+ delete(f, "ResourceId")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeCostDetailRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostDetailResponseParams struct {
+ // 消耗明细
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DetailSet []*CostDetail `json:"DetailSet,omitnil" name:"DetailSet"`
+
+ // 记录数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Total *uint64 `json:"Total,omitnil" name:"Total"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeCostDetailResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeCostDetailResponseParams `json:"Response"`
+}
+
+func (r *DescribeCostDetailResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostDetailResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByProductRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+}
+
+type DescribeCostSummaryByProductRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+}
+
+func (r *DescribeCostSummaryByProductRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByProductRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "PayerUin")
+ delete(f, "NeedRecordNum")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeCostSummaryByProductRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByProductResponseParams struct {
+ // 数据是否准备好,0未准备好,1准备好
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 消耗详情
+ Total *ConsumptionSummaryTotal `json:"Total,omitnil" name:"Total"`
+
+ // 消耗按产品汇总详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Data []*ConsumptionBusinessSummaryDataItem `json:"Data,omitnil" name:"Data"`
+
+ // 记录数量,NeedRecordNum为0是返回null
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RecordNum *uint64 `json:"RecordNum,omitnil" name:"RecordNum"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeCostSummaryByProductResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeCostSummaryByProductResponseParams `json:"Response"`
+}
+
+func (r *DescribeCostSummaryByProductResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByProductResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByProjectRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+}
+
+type DescribeCostSummaryByProjectRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+}
+
+func (r *DescribeCostSummaryByProjectRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByProjectRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "PayerUin")
+ delete(f, "NeedRecordNum")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeCostSummaryByProjectRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByProjectResponseParams struct {
+ // 数据是否准备好,0未准备好,1准备好
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 消耗详情
+ Total *ConsumptionSummaryTotal `json:"Total,omitnil" name:"Total"`
+
+ // 消耗按业务汇总详情
+ Data []*ConsumptionProjectSummaryDataItem `json:"Data,omitnil" name:"Data"`
+
+ // 记录数量,NeedRecordNum为0是返回null
+ RecordNum *uint64 `json:"RecordNum,omitnil" name:"RecordNum"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeCostSummaryByProjectResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeCostSummaryByProjectResponseParams `json:"Response"`
+}
+
+func (r *DescribeCostSummaryByProjectResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByProjectResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByRegionRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+}
+
+type DescribeCostSummaryByRegionRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+}
+
+func (r *DescribeCostSummaryByRegionRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByRegionRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "PayerUin")
+ delete(f, "NeedRecordNum")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeCostSummaryByRegionRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByRegionResponseParams struct {
+ // 数据是否准备好,0未准备好,1准备好
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 消耗详情
+ Total *ConsumptionSummaryTotal `json:"Total,omitnil" name:"Total"`
+
+ // 消耗按地域汇总详情
+ Data []*ConsumptionRegionSummaryDataItem `json:"Data,omitnil" name:"Data"`
+
+ // 记录数量,NeedRecordNum为0是返回null
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RecordNum *uint64 `json:"RecordNum,omitnil" name:"RecordNum"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeCostSummaryByRegionResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeCostSummaryByRegionResponseParams `json:"Response"`
+}
+
+func (r *DescribeCostSummaryByRegionResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByRegionResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByResourceRequestParams struct {
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 是否需要返回过滤条件,0不需要,1需要,默认不需要
+ NeedConditionValue *uint64 `json:"NeedConditionValue,omitnil" name:"NeedConditionValue"`
+
+ // 过滤条件,只支持ResourceKeyword(资源关键字,支持资源id及资源名称模糊查询),ProjectIds(项目id),RegionIds(地域id),PayModes(付费模式,可选prePay和postPay),HideFreeCost(是否隐藏0元流水,可选0和1),OrderByCost(按费用排序规则,可选desc和asc)
+ Conditions *Conditions `json:"Conditions,omitnil" name:"Conditions"`
+}
+
+type DescribeCostSummaryByResourceRequest struct {
+ *tchttp.BaseRequest
+
+ // 目前必须和EndTime相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 目前必须和BeginTime为相同月份,不支持跨月查询,且查询结果是整月数据,例如 BeginTime为2018-09,EndTime 为 2018-09,查询结果是 2018 年 9 月数据。
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 每次获取数据量,最大值为100
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量,默认从0开始
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 查询账单数据的用户UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+
+ // 是否需要返回记录数量,0不需要,1需要,默认不需要
+ NeedRecordNum *uint64 `json:"NeedRecordNum,omitnil" name:"NeedRecordNum"`
+
+ // 是否需要返回过滤条件,0不需要,1需要,默认不需要
+ NeedConditionValue *uint64 `json:"NeedConditionValue,omitnil" name:"NeedConditionValue"`
+
+ // 过滤条件,只支持ResourceKeyword(资源关键字,支持资源id及资源名称模糊查询),ProjectIds(项目id),RegionIds(地域id),PayModes(付费模式,可选prePay和postPay),HideFreeCost(是否隐藏0元流水,可选0和1),OrderByCost(按费用排序规则,可选desc和asc)
+ Conditions *Conditions `json:"Conditions,omitnil" name:"Conditions"`
+}
+
+func (r *DescribeCostSummaryByResourceRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByResourceRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "BeginTime")
+ delete(f, "EndTime")
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "PayerUin")
+ delete(f, "NeedRecordNum")
+ delete(f, "NeedConditionValue")
+ delete(f, "Conditions")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeCostSummaryByResourceRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeCostSummaryByResourceResponseParams struct {
+ // 数据是否准备好,0未准备好,1准备好
+ Ready *uint64 `json:"Ready,omitnil" name:"Ready"`
+
+ // 消耗详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Total *ConsumptionSummaryTotal `json:"Total,omitnil" name:"Total"`
+
+ // 过滤条件
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ConditionValue *ConsumptionResourceSummaryConditionValue `json:"ConditionValue,omitnil" name:"ConditionValue"`
+
+ // 记录数量
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RecordNum *uint64 `json:"RecordNum,omitnil" name:"RecordNum"`
+
+ // 资源消耗详情
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Data []*ConsumptionResourceSummaryDataItem `json:"Data,omitnil" name:"Data"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeCostSummaryByResourceResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeCostSummaryByResourceResponseParams `json:"Response"`
+}
+
+func (r *DescribeCostSummaryByResourceResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeCostSummaryByResourceResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDealsByCondRequestParams struct {
+ // 开始时间 2016-01-01 00:00:00
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 结束时间 2016-02-01 00:00:00 建议跨度不超过3个月
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 一页多少条数据,默认是20条,最大不超过1000
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 第多少页,从0开始,默认是0
+ Offset *int64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 订单状态,默认为4(成功的订单)
+ // 订单的状态
+ // 1:未支付
+ // 2:已支付3:发货中
+ // 4:已发货
+ // 5:发货失败
+ // 6:已退款
+ // 7:已关单
+ // 8:订单过期
+ // 9:订单已失效
+ // 10:产品已失效
+ // 11:代付拒绝
+ // 12:支付中
+ Status *int64 `json:"Status,omitnil" name:"Status"`
+
+ // 订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 大订单号
+ BigDealId *string `json:"BigDealId,omitnil" name:"BigDealId"`
+
+ // 资源id
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+}
+
+type DescribeDealsByCondRequest struct {
+ *tchttp.BaseRequest
+
+ // 开始时间 2016-01-01 00:00:00
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 结束时间 2016-02-01 00:00:00 建议跨度不超过3个月
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 一页多少条数据,默认是20条,最大不超过1000
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 第多少页,从0开始,默认是0
+ Offset *int64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 订单状态,默认为4(成功的订单)
+ // 订单的状态
+ // 1:未支付
+ // 2:已支付3:发货中
+ // 4:已发货
+ // 5:发货失败
+ // 6:已退款
+ // 7:已关单
+ // 8:订单过期
+ // 9:订单已失效
+ // 10:产品已失效
+ // 11:代付拒绝
+ // 12:支付中
+ Status *int64 `json:"Status,omitnil" name:"Status"`
+
+ // 订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 大订单号
+ BigDealId *string `json:"BigDealId,omitnil" name:"BigDealId"`
+
+ // 资源id
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+}
+
+func (r *DescribeDealsByCondRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDealsByCondRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartTime")
+ delete(f, "EndTime")
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "Status")
+ delete(f, "OrderId")
+ delete(f, "BigDealId")
+ delete(f, "ResourceId")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeDealsByCondRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDealsByCondResponseParams struct {
+ // 订单列表
+ Deals []*Deal `json:"Deals,omitnil" name:"Deals"`
+
+ // 订单总数
+ TotalCount *int64 `json:"TotalCount,omitnil" name:"TotalCount"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeDealsByCondResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeDealsByCondResponseParams `json:"Response"`
+}
+
+func (r *DescribeDealsByCondResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDealsByCondResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDosageCosDetailByDateRequestParams struct {
+ // 查询用量开始时间,例如:2020-09-01
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 查询用量结束时间,例如:2020-09-30(与开始时间同月,不支持跨月查询)
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // COS 存储桶名称,可通过Get Service 接口是用来获取请求者名下的所有存储空间列表(Bucket list)https://cloud.tencent.com/document/product/436/8291
+ BucketName *string `json:"BucketName,omitnil" name:"BucketName"`
+}
+
+type DescribeDosageCosDetailByDateRequest struct {
+ *tchttp.BaseRequest
+
+ // 查询用量开始时间,例如:2020-09-01
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 查询用量结束时间,例如:2020-09-30(与开始时间同月,不支持跨月查询)
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // COS 存储桶名称,可通过Get Service 接口是用来获取请求者名下的所有存储空间列表(Bucket list)https://cloud.tencent.com/document/product/436/8291
+ BucketName *string `json:"BucketName,omitnil" name:"BucketName"`
+}
+
+func (r *DescribeDosageCosDetailByDateRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDosageCosDetailByDateRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartDate")
+ delete(f, "EndDate")
+ delete(f, "BucketName")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeDosageCosDetailByDateRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDosageCosDetailByDateResponseParams struct {
+ // 用量数组
+ DetailSets []*CosDetailSets `json:"DetailSets,omitnil" name:"DetailSets"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeDosageCosDetailByDateResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeDosageCosDetailByDateResponseParams `json:"Response"`
+}
+
+func (r *DescribeDosageCosDetailByDateResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDosageCosDetailByDateResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+type DescribeDosageDetail struct {
+ // 日期
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Date *string `json:"Date,omitnil" name:"Date"`
+
+ // 账号 ID 是用户在腾讯云的唯一账号标识
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Uin *string `json:"Uin,omitnil" name:"Uin"`
+
+ // 用量统计类型
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DosageType *string `json:"DosageType,omitnil" name:"DosageType"`
+
+ // 产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 子产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubProductCode *string `json:"SubProductCode,omitnil" name:"SubProductCode"`
+
+ // 组件类型编码
+ //
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillingItemCode *string `json:"BillingItemCode,omitnil" name:"BillingItemCode"`
+
+ // 组件编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubBillingItemCode *string `json:"SubBillingItemCode,omitnil" name:"SubBillingItemCode"`
+
+ // 产品名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductCodeName *string `json:"ProductCodeName,omitnil" name:"ProductCodeName"`
+
+ // 子产品名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubProductCodeName *string `json:"SubProductCodeName,omitnil" name:"SubProductCodeName"`
+
+ // 组件类型
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillingItemCodeName *string `json:"BillingItemCodeName,omitnil" name:"BillingItemCodeName"`
+
+ // 组件
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubBillingItemCodeName *string `json:"SubBillingItemCodeName,omitnil" name:"SubBillingItemCodeName"`
+
+ // 用量单位
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DosageUnit *string `json:"DosageUnit,omitnil" name:"DosageUnit"`
+
+ // 用量起始时间
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DosageBeginTime *string `json:"DosageBeginTime,omitnil" name:"DosageBeginTime"`
+
+ // 用量截止时间
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DosageEndTime *string `json:"DosageEndTime,omitnil" name:"DosageEndTime"`
+
+ // 标准用量
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DosageValue *float64 `json:"DosageValue,omitnil" name:"DosageValue"`
+
+ // 抵扣用量
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DeductValue *float64 `json:"DeductValue,omitnil" name:"DeductValue"`
+
+ // 抵扣余量
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RemainValue *float64 `json:"RemainValue,omitnil" name:"RemainValue"`
+
+ // sdkAppId
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SdkAppId *string `json:"SdkAppId,omitnil" name:"SdkAppId"`
+
+ // 其他信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AttrStr []*JsonObject `json:"AttrStr,omitnil" name:"AttrStr"`
+
+ // 用量模板名称
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SheetName []*string `json:"SheetName,omitnil" name:"SheetName"`
+}
+
+// Predefined struct for user
+type DescribeDosageDetailByDateRequestParams struct {
+ // 查询账单开始日期,如 2019-01-01
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 查询账单结束日期,如 2019-01-01, 时间跨度不超过7天
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 互动直播:
+ // 10194 互动直播-核心机房 :
+ // 10195 互动直播-边缘机房
+ //
+ // cdn业务:
+ // 102383:CDN静态加速流量(国内)
+ // 102384:CDN静态加速带宽(国内)
+ // 102385:CDN静态加速流量(海外)
+ // 102386:CDN静态加速带宽(海外)
+ //
+ // 100967:弹性公网IP-按流量计费
+ // 101065:公网负载均衡-按流量计费
+ //
+ // 视频直播
+ // 10226 视频直播流量(国内)
+ // 10227 视频直播带宽(国内)
+ // 100763 视频直播流量(海外)
+ // 100762 视频直播宽带(海外)
+ //
+ // 仅支持以上产品
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 查询域名 例如 www.qq.com
+ // 非CDN业务查询时传入空字符串,返回的值为空
+ Domain *string `json:"Domain,omitnil" name:"Domain"`
+
+ // 1、如果为空,则返回EIP或CLB所有实例的明细;
+ // 2、如果传入实例名,则返回该实例明细
+ InstanceID *string `json:"InstanceID,omitnil" name:"InstanceID"`
+
+ // 支付者的账号 ID(账号 ID 是用户在腾讯云的唯一账号标识),默认查询本账号账单,如集团管理账号需查询成员账号自付的账单,该字段需入参成员账号UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+type DescribeDosageDetailByDateRequest struct {
+ *tchttp.BaseRequest
+
+ // 查询账单开始日期,如 2019-01-01
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 查询账单结束日期,如 2019-01-01, 时间跨度不超过7天
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 互动直播:
+ // 10194 互动直播-核心机房 :
+ // 10195 互动直播-边缘机房
+ //
+ // cdn业务:
+ // 102383:CDN静态加速流量(国内)
+ // 102384:CDN静态加速带宽(国内)
+ // 102385:CDN静态加速流量(海外)
+ // 102386:CDN静态加速带宽(海外)
+ //
+ // 100967:弹性公网IP-按流量计费
+ // 101065:公网负载均衡-按流量计费
+ //
+ // 视频直播
+ // 10226 视频直播流量(国内)
+ // 10227 视频直播带宽(国内)
+ // 100763 视频直播流量(海外)
+ // 100762 视频直播宽带(海外)
+ //
+ // 仅支持以上产品
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 查询域名 例如 www.qq.com
+ // 非CDN业务查询时传入空字符串,返回的值为空
+ Domain *string `json:"Domain,omitnil" name:"Domain"`
+
+ // 1、如果为空,则返回EIP或CLB所有实例的明细;
+ // 2、如果传入实例名,则返回该实例明细
+ InstanceID *string `json:"InstanceID,omitnil" name:"InstanceID"`
+
+ // 支付者的账号 ID(账号 ID 是用户在腾讯云的唯一账号标识),默认查询本账号账单,如集团管理账号需查询成员账号自付的账单,该字段需入参成员账号UIN
+ PayerUin *string `json:"PayerUin,omitnil" name:"PayerUin"`
+}
+
+func (r *DescribeDosageDetailByDateRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDosageDetailByDateRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartDate")
+ delete(f, "EndDate")
+ delete(f, "ProductCode")
+ delete(f, "Domain")
+ delete(f, "InstanceID")
+ delete(f, "PayerUin")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeDosageDetailByDateRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDosageDetailByDateResponseParams struct {
+ // 计量单位
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Unit *string `json:"Unit,omitnil" name:"Unit"`
+
+ // 用量数组
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DetailSets []*DetailSet `json:"DetailSets,omitnil" name:"DetailSets"`
+
+ // 错误码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RetCode *int64 `json:"RetCode,omitnil" name:"RetCode"`
+
+ // 错误信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RetMsg *string `json:"RetMsg,omitnil" name:"RetMsg"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeDosageDetailByDateResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeDosageDetailByDateResponseParams `json:"Response"`
+}
+
+func (r *DescribeDosageDetailByDateResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDosageDetailByDateResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDosageDetailListRequestParams struct {
+ // 用量起始时间,如:2023-02-01
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 用量截止时间,如:2023-02-28
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 产品编码,已支持查询的产品如下:
+ // p_ccc(云联络中心)
+ // p_rav(实时音视频)
+ // p_pstn(号码保护)
+ // p_smh(智能媒资托管)
+ // p_coding_devops(CODING DevOps)
+ // p_dsa(全球IP应用加速)
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 数据偏移量(从0开始)
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 单次数据量(最大3000)
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 用量统计类型:用量明细的数据统计汇总周期类型,包括minute-按5分钟汇总、hour-按小时汇总、day-按天汇总、month-按月汇总、comm-其他,默认查询所有类型明细,目前各产品已支持的统计类型如下:
+ // p_ccc(云联络中心):comm、day
+ // p_rav(实时音视频):minute、day
+ // p_pstn(号码保护):comm
+ // p_smh(智能媒资托管):day
+ // p_coding_devops(CODING DevOps):comm、day
+ // p_dsa(全球IP应用加速):minute
+ DosageType *string `json:"DosageType,omitnil" name:"DosageType"`
+}
+
+type DescribeDosageDetailListRequest struct {
+ *tchttp.BaseRequest
+
+ // 用量起始时间,如:2023-02-01
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 用量截止时间,如:2023-02-28
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 产品编码,已支持查询的产品如下:
+ // p_ccc(云联络中心)
+ // p_rav(实时音视频)
+ // p_pstn(号码保护)
+ // p_smh(智能媒资托管)
+ // p_coding_devops(CODING DevOps)
+ // p_dsa(全球IP应用加速)
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 数据偏移量(从0开始)
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 单次数据量(最大3000)
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 用量统计类型:用量明细的数据统计汇总周期类型,包括minute-按5分钟汇总、hour-按小时汇总、day-按天汇总、month-按月汇总、comm-其他,默认查询所有类型明细,目前各产品已支持的统计类型如下:
+ // p_ccc(云联络中心):comm、day
+ // p_rav(实时音视频):minute、day
+ // p_pstn(号码保护):comm
+ // p_smh(智能媒资托管):day
+ // p_coding_devops(CODING DevOps):comm、day
+ // p_dsa(全球IP应用加速):minute
+ DosageType *string `json:"DosageType,omitnil" name:"DosageType"`
+}
+
+func (r *DescribeDosageDetailListRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDosageDetailListRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartTime")
+ delete(f, "EndTime")
+ delete(f, "ProductCode")
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "DosageType")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeDosageDetailListRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeDosageDetailListResponseParams struct {
+ // 用量明细集合
+ Record []*DescribeDosageDetail `json:"Record,omitnil" name:"Record"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeDosageDetailListResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeDosageDetailListResponseParams `json:"Response"`
+}
+
+func (r *DescribeDosageDetailListResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeDosageDetailListResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanCoverageRequestParams struct {
+ // 费用起始日期,格式yyyy-MM-dd
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 费用结束日期,格式yyyy-MM-dd
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,以此类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为200
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 取值包括1(缺省值)和2,1表示按天统计覆盖率,2表示按月统计覆盖率,此参数仅影响返回的RateSet聚合粒度,不影响返回的DetailSet
+ PeriodType *uint64 `json:"PeriodType,omitnil" name:"PeriodType"`
+}
+
+type DescribeSavingPlanCoverageRequest struct {
+ *tchttp.BaseRequest
+
+ // 费用起始日期,格式yyyy-MM-dd
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 费用结束日期,格式yyyy-MM-dd
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,以此类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 数量,最大值为200
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 取值包括1(缺省值)和2,1表示按天统计覆盖率,2表示按月统计覆盖率,此参数仅影响返回的RateSet聚合粒度,不影响返回的DetailSet
+ PeriodType *uint64 `json:"PeriodType,omitnil" name:"PeriodType"`
+}
+
+func (r *DescribeSavingPlanCoverageRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanCoverageRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartDate")
+ delete(f, "EndDate")
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "PeriodType")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeSavingPlanCoverageRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanCoverageResponseParams struct {
+ // 节省计划覆盖率明细数据
+ DetailSet []*SavingPlanCoverageDetail `json:"DetailSet,omitnil" name:"DetailSet"`
+
+ // 节省计划覆盖率聚合数据
+ RateSet []*SavingPlanCoverageRate `json:"RateSet,omitnil" name:"RateSet"`
+
+ // 查询命中的节省计划覆盖率明细数据总条数
+ TotalCount *uint64 `json:"TotalCount,omitnil" name:"TotalCount"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeSavingPlanCoverageResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeSavingPlanCoverageResponseParams `json:"Response"`
+}
+
+func (r *DescribeSavingPlanCoverageResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanCoverageResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanOverviewRequestParams struct {
+ // 开始时间,格式yyyy-MM-dd 注:查询范围请勿超过6个月
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 结束时间,格式yyyy-MM-dd
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 分页偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 每页数量,最大值为200
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+}
+
+type DescribeSavingPlanOverviewRequest struct {
+ *tchttp.BaseRequest
+
+ // 开始时间,格式yyyy-MM-dd 注:查询范围请勿超过6个月
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 结束时间,格式yyyy-MM-dd
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 分页偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 每页数量,最大值为200
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+}
+
+func (r *DescribeSavingPlanOverviewRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanOverviewRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartDate")
+ delete(f, "EndDate")
+ delete(f, "Offset")
+ delete(f, "Limit")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeSavingPlanOverviewRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanOverviewResponseParams struct {
+ // 节省计划总览明细数据
+ Overviews []*SavingPlanOverviewDetail `json:"Overviews,omitnil" name:"Overviews"`
+
+ // 查询命中的节省计划总览明细数据总条数
+ Total *uint64 `json:"Total,omitnil" name:"Total"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeSavingPlanOverviewResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeSavingPlanOverviewResponseParams `json:"Response"`
+}
+
+func (r *DescribeSavingPlanOverviewResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanOverviewResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanResourceInfoRequestParams struct {
+ // 数量,最大值为100
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 购买开始时间,格式yyyy-MM-dd
+ CreateStartDate *string `json:"CreateStartDate,omitnil" name:"CreateStartDate"`
+
+ // 购买结束时间,格式yyyy-MM-dd
+ CreateEndDate *string `json:"CreateEndDate,omitnil" name:"CreateEndDate"`
+}
+
+type DescribeSavingPlanResourceInfoRequest struct {
+ *tchttp.BaseRequest
+
+ // 数量,最大值为100
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 购买开始时间,格式yyyy-MM-dd
+ CreateStartDate *string `json:"CreateStartDate,omitnil" name:"CreateStartDate"`
+
+ // 购买结束时间,格式yyyy-MM-dd
+ CreateEndDate *string `json:"CreateEndDate,omitnil" name:"CreateEndDate"`
+}
+
+func (r *DescribeSavingPlanResourceInfoRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanResourceInfoRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "CreateStartDate")
+ delete(f, "CreateEndDate")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeSavingPlanResourceInfoRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanResourceInfoResponseParams struct {
+ // 记录数
+ Total *uint64 `json:"Total,omitnil" name:"Total"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeSavingPlanResourceInfoResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeSavingPlanResourceInfoResponseParams `json:"Response"`
+}
+
+func (r *DescribeSavingPlanResourceInfoResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanResourceInfoResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanUsageRequestParams struct {
+ // 开始时间,格式yyyy-MM-dd 注:查询范围请勿超过6个月
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 结束时间,格式yyyy-MM-dd
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 分页偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 每页数量,最大值为200
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 查询结果数据的时间间隔
+ TimeInterval *string `json:"TimeInterval,omitnil" name:"TimeInterval"`
+}
+
+type DescribeSavingPlanUsageRequest struct {
+ *tchttp.BaseRequest
+
+ // 开始时间,格式yyyy-MM-dd 注:查询范围请勿超过6个月
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 结束时间,格式yyyy-MM-dd
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 分页偏移量
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 每页数量,最大值为200
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 查询结果数据的时间间隔
+ TimeInterval *string `json:"TimeInterval,omitnil" name:"TimeInterval"`
+}
+
+func (r *DescribeSavingPlanUsageRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanUsageRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "StartDate")
+ delete(f, "EndDate")
+ delete(f, "Offset")
+ delete(f, "Limit")
+ delete(f, "TimeInterval")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeSavingPlanUsageRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeSavingPlanUsageResponseParams struct {
+ // 节省计划使用率数据
+ Usages []*SavingPlanUsageDetail `json:"Usages,omitnil" name:"Usages"`
+
+ // 查询命中的节省计划总览明细数据总条数
+ Total *uint64 `json:"Total,omitnil" name:"Total"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeSavingPlanUsageResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeSavingPlanUsageResponseParams `json:"Response"`
+}
+
+func (r *DescribeSavingPlanUsageResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeSavingPlanUsageResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeTagListRequestParams struct {
+ // 数量,最大值为1000
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 分账标签键,用作模糊搜索
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 标签类型,枚举值:0普通标签,1分账标签,用作筛选,不传获取全部标签键
+ Status *uint64 `json:"Status,omitnil" name:"Status"`
+
+ // 排序方式,枚举值:asc排升序,desc排降序
+ OrderType *string `json:"OrderType,omitnil" name:"OrderType"`
+}
+
+type DescribeTagListRequest struct {
+ *tchttp.BaseRequest
+
+ // 数量,最大值为1000
+ Limit *uint64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 分页偏移量,Offset=0表示第一页,如果Limit=100,则Offset=100表示第二页,Offset=200表示第三页,依次类推
+ Offset *uint64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 分账标签键,用作模糊搜索
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 标签类型,枚举值:0普通标签,1分账标签,用作筛选,不传获取全部标签键
+ Status *uint64 `json:"Status,omitnil" name:"Status"`
+
+ // 排序方式,枚举值:asc排升序,desc排降序
+ OrderType *string `json:"OrderType,omitnil" name:"OrderType"`
+}
+
+func (r *DescribeTagListRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeTagListRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "TagKey")
+ delete(f, "Status")
+ delete(f, "OrderType")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeTagListRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeTagListResponseParams struct {
+ // 总记录数
+ RecordNum *uint64 `json:"RecordNum,omitnil" name:"RecordNum"`
+
+ // 标签信息
+ Data []*TagDataInfo `json:"Data,omitnil" name:"Data"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeTagListResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeTagListResponseParams `json:"Response"`
+}
+
+func (r *DescribeTagListResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeTagListResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeVoucherInfoRequestParams struct {
+ // 一页多少条数据,默认是20条,最大不超过1000
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 第多少页,默认是1
+ Offset *int64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 券状态:待使用:unUsed,已使用: used,已发货:delivered,已作废: cancel,已过期:overdue
+ Status *string `json:"Status,omitnil" name:"Status"`
+
+ // 代金券id
+ VoucherId *string `json:"VoucherId,omitnil" name:"VoucherId"`
+
+ // 代金券订单id
+ CodeId *string `json:"CodeId,omitnil" name:"CodeId"`
+
+ // 商品码
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 活动id
+ ActivityId *string `json:"ActivityId,omitnil" name:"ActivityId"`
+
+ // 代金券名称
+ VoucherName *string `json:"VoucherName,omitnil" name:"VoucherName"`
+
+ // 发放开始时间,例:2021-01-01
+ TimeFrom *string `json:"TimeFrom,omitnil" name:"TimeFrom"`
+
+ // 发放结束时间,例:2021-01-01
+ TimeTo *string `json:"TimeTo,omitnil" name:"TimeTo"`
+
+ // 指定排序字段:BeginTime开始时间、EndTime到期时间、CreateTime创建时间
+ SortField *string `json:"SortField,omitnil" name:"SortField"`
+
+ // 指定升序降序:desc、asc
+ SortOrder *string `json:"SortOrder,omitnil" name:"SortOrder"`
+
+ // 付费模式,postPay后付费/prePay预付费/riPay预留实例/""或者"*"表示全部模式,如果payMode为""或"*",那么productCode与subProductCode必须传空
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 付费场景PayMode=postPay时:spotpay-竞价实例,"settle account"-普通后付费PayMode=prePay时:purchase-包年包月新购,renew-包年包月续费(自动续费),modify-包年包月配置变更(变配)PayMode=riPay时:oneOffFee-预留实例预付,hourlyFee-预留实例每小时扣费,*-支持全部付费场景
+ PayScene *string `json:"PayScene,omitnil" name:"PayScene"`
+
+ // 操作人,默认就是用户uin
+ Operator *string `json:"Operator,omitnil" name:"Operator"`
+
+ // 代金券主类型 has_price 为有价现金券 no_price 为无价代金券
+ VoucherMainType *string `json:"VoucherMainType,omitnil" name:"VoucherMainType"`
+
+ // 代金券副类型 discount 为折扣券 deduct 为抵扣券
+ VoucherSubType *string `json:"VoucherSubType,omitnil" name:"VoucherSubType"`
+}
+
+type DescribeVoucherInfoRequest struct {
+ *tchttp.BaseRequest
+
+ // 一页多少条数据,默认是20条,最大不超过1000
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 第多少页,默认是1
+ Offset *int64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 券状态:待使用:unUsed,已使用: used,已发货:delivered,已作废: cancel,已过期:overdue
+ Status *string `json:"Status,omitnil" name:"Status"`
+
+ // 代金券id
+ VoucherId *string `json:"VoucherId,omitnil" name:"VoucherId"`
+
+ // 代金券订单id
+ CodeId *string `json:"CodeId,omitnil" name:"CodeId"`
+
+ // 商品码
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 活动id
+ ActivityId *string `json:"ActivityId,omitnil" name:"ActivityId"`
+
+ // 代金券名称
+ VoucherName *string `json:"VoucherName,omitnil" name:"VoucherName"`
+
+ // 发放开始时间,例:2021-01-01
+ TimeFrom *string `json:"TimeFrom,omitnil" name:"TimeFrom"`
+
+ // 发放结束时间,例:2021-01-01
+ TimeTo *string `json:"TimeTo,omitnil" name:"TimeTo"`
+
+ // 指定排序字段:BeginTime开始时间、EndTime到期时间、CreateTime创建时间
+ SortField *string `json:"SortField,omitnil" name:"SortField"`
+
+ // 指定升序降序:desc、asc
+ SortOrder *string `json:"SortOrder,omitnil" name:"SortOrder"`
+
+ // 付费模式,postPay后付费/prePay预付费/riPay预留实例/""或者"*"表示全部模式,如果payMode为""或"*",那么productCode与subProductCode必须传空
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 付费场景PayMode=postPay时:spotpay-竞价实例,"settle account"-普通后付费PayMode=prePay时:purchase-包年包月新购,renew-包年包月续费(自动续费),modify-包年包月配置变更(变配)PayMode=riPay时:oneOffFee-预留实例预付,hourlyFee-预留实例每小时扣费,*-支持全部付费场景
+ PayScene *string `json:"PayScene,omitnil" name:"PayScene"`
+
+ // 操作人,默认就是用户uin
+ Operator *string `json:"Operator,omitnil" name:"Operator"`
+
+ // 代金券主类型 has_price 为有价现金券 no_price 为无价代金券
+ VoucherMainType *string `json:"VoucherMainType,omitnil" name:"VoucherMainType"`
+
+ // 代金券副类型 discount 为折扣券 deduct 为抵扣券
+ VoucherSubType *string `json:"VoucherSubType,omitnil" name:"VoucherSubType"`
+}
+
+func (r *DescribeVoucherInfoRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeVoucherInfoRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "Status")
+ delete(f, "VoucherId")
+ delete(f, "CodeId")
+ delete(f, "ProductCode")
+ delete(f, "ActivityId")
+ delete(f, "VoucherName")
+ delete(f, "TimeFrom")
+ delete(f, "TimeTo")
+ delete(f, "SortField")
+ delete(f, "SortOrder")
+ delete(f, "PayMode")
+ delete(f, "PayScene")
+ delete(f, "Operator")
+ delete(f, "VoucherMainType")
+ delete(f, "VoucherSubType")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeVoucherInfoRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeVoucherInfoResponseParams struct {
+ // 券总数
+ TotalCount *int64 `json:"TotalCount,omitnil" name:"TotalCount"`
+
+ // 总余额(微分)
+ TotalBalance *int64 `json:"TotalBalance,omitnil" name:"TotalBalance"`
+
+ // 代金券相关信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ VoucherInfos []*VoucherInfos `json:"VoucherInfos,omitnil" name:"VoucherInfos"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeVoucherInfoResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeVoucherInfoResponseParams `json:"Response"`
+}
+
+func (r *DescribeVoucherInfoResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeVoucherInfoResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeVoucherUsageDetailsRequestParams struct {
+ // 一页多少条数据,默认是20条,最大不超过1000
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 第多少页,默认是1
+ Offset *int64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 代金券id
+ VoucherId *string `json:"VoucherId,omitnil" name:"VoucherId"`
+
+ // 操作人,默认就是用户uin
+ Operator *string `json:"Operator,omitnil" name:"Operator"`
+}
+
+type DescribeVoucherUsageDetailsRequest struct {
+ *tchttp.BaseRequest
+
+ // 一页多少条数据,默认是20条,最大不超过1000
+ Limit *int64 `json:"Limit,omitnil" name:"Limit"`
+
+ // 第多少页,默认是1
+ Offset *int64 `json:"Offset,omitnil" name:"Offset"`
+
+ // 代金券id
+ VoucherId *string `json:"VoucherId,omitnil" name:"VoucherId"`
+
+ // 操作人,默认就是用户uin
+ Operator *string `json:"Operator,omitnil" name:"Operator"`
+}
+
+func (r *DescribeVoucherUsageDetailsRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeVoucherUsageDetailsRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "Limit")
+ delete(f, "Offset")
+ delete(f, "VoucherId")
+ delete(f, "Operator")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeVoucherUsageDetailsRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type DescribeVoucherUsageDetailsResponseParams struct {
+ // 券总数
+ TotalCount *int64 `json:"TotalCount,omitnil" name:"TotalCount"`
+
+ // 总已用金额(微分)
+ TotalUsedAmount *int64 `json:"TotalUsedAmount,omitnil" name:"TotalUsedAmount"`
+
+ // 代金券使用记录细节
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ UsageRecords []*UsageRecords `json:"UsageRecords,omitnil" name:"UsageRecords"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type DescribeVoucherUsageDetailsResponse struct {
+ *tchttp.BaseResponse
+ Response *DescribeVoucherUsageDetailsResponseParams `json:"Response"`
+}
+
+func (r *DescribeVoucherUsageDetailsResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *DescribeVoucherUsageDetailsResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+type DetailPoint struct {
+ // 时间
+ Time *string `json:"Time,omitnil" name:"Time"`
+
+ // 值
+ Value *string `json:"Value,omitnil" name:"Value"`
+}
+
+type DetailSet struct {
+ // 域名
+ Domain *string `json:"Domain,omitnil" name:"Domain"`
+
+ // 使用数据明细
+ DetailPoints []*DetailPoint `json:"DetailPoints,omitnil" name:"DetailPoints"`
+
+ // 实例ID
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ InstanceID *string `json:"InstanceID,omitnil" name:"InstanceID"`
+}
+
+type DistributionBillDetail struct {
+ // 产品名称:用户所采购的各类云产品,例如:云服务器 CVM
+ BusinessCodeName *string `json:"BusinessCodeName,omitnil" name:"BusinessCodeName"`
+
+ // 子产品名称:用户采购的具体产品细分类型,例如:云服务器 CVM-标准型 S1
+ ProductCodeName *string `json:"ProductCodeName,omitnil" name:"ProductCodeName"`
+
+ // 计费模式:资源的计费模式,区分为包年包月和按量计费
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 项目名称:资源归属的项目,用户在控制台给资源自主分配项目,未分配则是默认项目
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 地域:资源所属地域,如华南地区(广州)
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 可用区:资源所属可用区,如广州三区
+ ZoneName *string `json:"ZoneName,omitnil" name:"ZoneName"`
+
+ // 资源 ID:账单中出账对象 ID,不同产品因资源形态不同,资源内容不完全相同,如云服务器 CVM 为对应的实例 ID
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 资源别名:用户在控制台为资源设置的名称,如果未设置,则默认为空
+ ResourceName *string `json:"ResourceName,omitnil" name:"ResourceName"`
+
+ // 交易类型,如包年包月新购、包年包月续费、按量计费扣费等类型
+ ActionTypeName *string `json:"ActionTypeName,omitnil" name:"ActionTypeName"`
+
+ // 订单ID:包年包月计费模式下订购的订单号
+ OrderId *string `json:"OrderId,omitnil" name:"OrderId"`
+
+ // 交易ID:结算扣费单号
+ BillId *string `json:"BillId,omitnil" name:"BillId"`
+
+ // 扣费时间:结算扣费时间
+ PayTime *string `json:"PayTime,omitnil" name:"PayTime"`
+
+ // 开始使用时间:产品服务开始使用时间
+ FeeBeginTime *string `json:"FeeBeginTime,omitnil" name:"FeeBeginTime"`
+
+ // 结束使用时间:产品服务结束使用时间
+ FeeEndTime *string `json:"FeeEndTime,omitnil" name:"FeeEndTime"`
+
+ // 组件列表
+ ComponentSet []*BillDetailComponent `json:"ComponentSet,omitnil" name:"ComponentSet"`
+
+ // 使用者UIN:实际使用资源的账号 ID
+ OwnerUin *string `json:"OwnerUin,omitnil" name:"OwnerUin"`
+
+ // 操作者UIN:操作者账号 ID(预付费资源下单或后付费操作开通资源账号的 ID 或者角色 ID )
+ OperateUin *string `json:"OperateUin,omitnil" name:"OperateUin"`
+
+ // 标签信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Tags []*BillTagInfo `json:"Tags,omitnil" name:"Tags"`
+
+ // 产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BusinessCode *string `json:"BusinessCode,omitnil" name:"BusinessCode"`
+
+ // 子产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 交易类型编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ActionType *string `json:"ActionType,omitnil" name:"ActionType"`
+
+ // 地域ID
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RegionId *string `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 项目ID
+ ProjectId *int64 `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 价格属性:该组件除单价、时长外的其他影响折扣定价的属性信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ PriceInfo []*string `json:"PriceInfo,omitnil" name:"PriceInfo"`
+
+ // 关联交易单据ID:和本笔交易关联单据 ID,如,冲销订单,记录原订单、重结订单,退费单记录对应的原购买订单号
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AssociatedOrder *BillDetailAssociatedOrder `json:"AssociatedOrder,omitnil" name:"AssociatedOrder"`
+
+ // 计算说明:特殊交易类型计费结算的详细计算说明,如退费及变配
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Formula *string `json:"Formula,omitnil" name:"Formula"`
+
+ // 计费规则:各产品详细的计费规则官网说明链接
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ FormulaUrl *string `json:"FormulaUrl,omitnil" name:"FormulaUrl"`
+
+ // 账单归属月
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+
+ // 账单归属日
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ BillDay *string `json:"BillDay,omitnil" name:"BillDay"`
+}
+
+type ExcludedProducts struct {
+ // 不适用商品名称
+ GoodsName *string `json:"GoodsName,omitnil" name:"GoodsName"`
+
+ // postPay后付费/prePay预付费/riPay预留实例/空字符串或者"*"表示全部模式。
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+}
+
+type JsonObject struct {
+ // key值
+ Key *string `json:"Key,omitnil" name:"Key"`
+
+ // value值
+ Value *string `json:"Value,omitnil" name:"Value"`
+}
+
+// Predefined struct for user
+type PayDealsRequestParams struct {
+ // 需要支付的一个或者多个子订单号,与BigDealIds字段两者必须且仅传一个参数
+ OrderIds []*string `json:"OrderIds,omitnil" name:"OrderIds"`
+
+ // 是否自动使用代金券,1:是,0否,默认0
+ AutoVoucher *int64 `json:"AutoVoucher,omitnil" name:"AutoVoucher"`
+
+ // 代金券ID列表,目前仅支持指定一张代金券
+ VoucherIds []*string `json:"VoucherIds,omitnil" name:"VoucherIds"`
+
+ // 需要支付的一个或者多个大订单号,与OrderIds字段两者必须且仅传一个参数
+ BigDealIds []*string `json:"BigDealIds,omitnil" name:"BigDealIds"`
+}
+
+type PayDealsRequest struct {
+ *tchttp.BaseRequest
+
+ // 需要支付的一个或者多个子订单号,与BigDealIds字段两者必须且仅传一个参数
+ OrderIds []*string `json:"OrderIds,omitnil" name:"OrderIds"`
+
+ // 是否自动使用代金券,1:是,0否,默认0
+ AutoVoucher *int64 `json:"AutoVoucher,omitnil" name:"AutoVoucher"`
+
+ // 代金券ID列表,目前仅支持指定一张代金券
+ VoucherIds []*string `json:"VoucherIds,omitnil" name:"VoucherIds"`
+
+ // 需要支付的一个或者多个大订单号,与OrderIds字段两者必须且仅传一个参数
+ BigDealIds []*string `json:"BigDealIds,omitnil" name:"BigDealIds"`
+}
+
+func (r *PayDealsRequest) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *PayDealsRequest) FromJsonString(s string) error {
+ f := make(map[string]interface{})
+ if err := json.Unmarshal([]byte(s), &f); err != nil {
+ return err
+ }
+ delete(f, "OrderIds")
+ delete(f, "AutoVoucher")
+ delete(f, "VoucherIds")
+ delete(f, "BigDealIds")
+ if len(f) > 0 {
+ return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "PayDealsRequest has unknown keys!", "")
+ }
+ return json.Unmarshal([]byte(s), &r)
+}
+
+// Predefined struct for user
+type PayDealsResponseParams struct {
+ // 此次操作支付成功的子订单号数组
+ OrderIds []*string `json:"OrderIds,omitnil" name:"OrderIds"`
+
+ // 此次操作支付成功的资源Id数组
+ ResourceIds []*string `json:"ResourceIds,omitnil" name:"ResourceIds"`
+
+ // 此次操作支付成功的大订单号数组
+ BigDealIds []*string `json:"BigDealIds,omitnil" name:"BigDealIds"`
+
+ // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
+ RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
+}
+
+type PayDealsResponse struct {
+ *tchttp.BaseResponse
+ Response *PayDealsResponseParams `json:"Response"`
+}
+
+func (r *PayDealsResponse) ToJsonString() string {
+ b, _ := json.Marshal(r)
+ return string(b)
+}
+
+// FromJsonString It is highly **NOT** recommended to use this function
+// because it has no param check, nor strict type check
+func (r *PayDealsResponse) FromJsonString(s string) error {
+ return json.Unmarshal([]byte(s), &r)
+}
+
+type PayModeSummaryOverviewItem struct {
+ // 计费模式编码
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 计费模式:区分为包年包月和按量计费
+ PayModeName *string `json:"PayModeName,omitnil" name:"PayModeName"`
+
+ // 费用所占百分比,两位小数
+ RealTotalCostRatio *string `json:"RealTotalCostRatio,omitnil" name:"RealTotalCostRatio"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+
+ // 按交易类型汇总消费详情
+ Detail []*ActionSummaryOverviewItem `json:"Detail,omitnil" name:"Detail"`
+}
+
+type ProductInfo struct {
+ // 商品详情名称标识
+ Name *string `json:"Name,omitnil" name:"Name"`
+
+ // 商品详情
+ Value *string `json:"Value,omitnil" name:"Value"`
+}
+
+type ProjectSummaryOverviewItem struct {
+ // 项目ID
+ ProjectId *string `json:"ProjectId,omitnil" name:"ProjectId"`
+
+ // 项目名称:资源归属的项目,用户在控制台给资源自主分配项目,未分配则是默认项目
+ ProjectName *string `json:"ProjectName,omitnil" name:"ProjectName"`
+
+ // 费用所占百分比,两位小数
+ RealTotalCostRatio *string `json:"RealTotalCostRatio,omitnil" name:"RealTotalCostRatio"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 账单月份,格式2019-08
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type RegionSummaryOverviewItem struct {
+ // 地域ID
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RegionId *string `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 地域名称:资源所属地域,例如华南地区(广州)
+ RegionName *string `json:"RegionName,omitnil" name:"RegionName"`
+
+ // 费用所占百分比,两位小数
+ RealTotalCostRatio *string `json:"RealTotalCostRatio,omitnil" name:"RealTotalCostRatio"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 账单月份,格式2019-08
+ BillMonth *string `json:"BillMonth,omitnil" name:"BillMonth"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type SavingPlanCoverageDetail struct {
+ // 资源 ID:账单中出账对象 ID,不同产品因资源形态不同,资源内容不完全相同,如云服务器 CVM 为对应的实例 ID
+ ResourceId *string `json:"ResourceId,omitnil" name:"ResourceId"`
+
+ // 地域ID
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RegionId *uint64 `json:"RegionId,omitnil" name:"RegionId"`
+
+ // 产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductCode *string `json:"ProductCode,omitnil" name:"ProductCode"`
+
+ // 子产品编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubProductCode *string `json:"SubProductCode,omitnil" name:"SubProductCode"`
+
+ // 费用起始日期,格式yyyy-MM-dd
+ StartDate *string `json:"StartDate,omitnil" name:"StartDate"`
+
+ // 费用结束日期,格式yyyy-MM-dd,目前与StartDate相等
+ EndDate *string `json:"EndDate,omitnil" name:"EndDate"`
+
+ // 节省计划覆盖金额(即节省计划支付金额)
+ SpCoveredAmount *float64 `json:"SpCoveredAmount,omitnil" name:"SpCoveredAmount"`
+
+ // 节省计划未覆盖金额(即优惠后总价)
+ SpUncoveredAmount *float64 `json:"SpUncoveredAmount,omitnil" name:"SpUncoveredAmount"`
+
+ // 总支出(即节省计划未覆盖金额 + 节省计划覆盖金额)
+ TotalRealAmount *float64 `json:"TotalRealAmount,omitnil" name:"TotalRealAmount"`
+
+ // 按量计费预期金额(即折前价 * 折扣)
+ ExpectedAmount *float64 `json:"ExpectedAmount,omitnil" name:"ExpectedAmount"`
+
+ // 覆盖率结果,取值[0, 100]
+ SpCoverage *float64 `json:"SpCoverage,omitnil" name:"SpCoverage"`
+}
+
+type SavingPlanCoverageRate struct {
+ // 聚合时间维度,按天聚合格式为yyyy-MM-dd,按月聚合格式为yyyy-MM
+ DatePoint *string `json:"DatePoint,omitnil" name:"DatePoint"`
+
+ // 覆盖率结果,取值[0, 100]
+ Rate *float64 `json:"Rate,omitnil" name:"Rate"`
+}
+
+type SavingPlanOverviewDetail struct {
+ // 节省计划类型
+ SpType *string `json:"SpType,omitnil" name:"SpType"`
+
+ // 支付类型
+ PayType *uint64 `json:"PayType,omitnil" name:"PayType"`
+
+ // 支付金额(单位:元)
+ PayAmount *string `json:"PayAmount,omitnil" name:"PayAmount"`
+
+ // 开始时间 yyyy-mm-dd HH:mm:ss格式
+ StartTime *string `json:"StartTime,omitnil" name:"StartTime"`
+
+ // 结束时间 yyyy-mm-dd HH:mm:ss格式
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 购买时间 yyyy-mm-dd HH:mm:ss格式
+ BuyTime *string `json:"BuyTime,omitnil" name:"BuyTime"`
+
+ // 状态
+ Status *uint64 `json:"Status,omitnil" name:"Status"`
+
+ // 累计节省金额(单位:元)
+ SavingAmount *string `json:"SavingAmount,omitnil" name:"SavingAmount"`
+
+ // 地域
+ Region []*string `json:"Region,omitnil" name:"Region"`
+}
+
+type SavingPlanUsageDetail struct {
+ // 节省计划类型
+ SpType *string `json:"SpType,omitnil" name:"SpType"`
+
+ // 节省计划状态
+ Status *uint64 `json:"Status,omitnil" name:"Status"`
+
+ // 累计抵扣的金额(单位:元)
+ DeductAmount *string `json:"DeductAmount,omitnil" name:"DeductAmount"`
+
+ // 累计承诺消费金额(单位:元)
+ PromiseAmount *string `json:"PromiseAmount,omitnil" name:"PromiseAmount"`
+
+ // 累计净节省金额(单位:元)
+ NetSavings *string `json:"NetSavings,omitnil" name:"NetSavings"`
+
+ // 使用率
+ UtilizationRate *float64 `json:"UtilizationRate,omitnil" name:"UtilizationRate"`
+
+ // 累计流失金额(单位:元)
+ LossAmount *string `json:"LossAmount,omitnil" name:"LossAmount"`
+
+ // 累计按量计费预期金额(单位:元)
+ DosageAmount *string `json:"DosageAmount,omitnil" name:"DosageAmount"`
+
+ // 累计成本金额(单位:元)
+ CostAmount *string `json:"CostAmount,omitnil" name:"CostAmount"`
+
+ // 地域
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Region []*string `json:"Region,omitnil" name:"Region"`
+}
+
+type SummaryDetail struct {
+ // 账单维度编码
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ GroupKey *string `json:"GroupKey,omitnil" name:"GroupKey"`
+
+ // 账单维度值
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ GroupValue *string `json:"GroupValue,omitnil" name:"GroupValue"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+
+ // 优惠后总价
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 产品汇总信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Business []*BusinessSummaryInfo `json:"Business,omitnil" name:"Business"`
+}
+
+type SummaryTotal struct {
+ // 优惠后总价
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type TagDataInfo struct {
+ // 分账标签键
+ TagKey *string `json:"TagKey,omitnil" name:"TagKey"`
+
+ // 标签类型,0普通标签,1分账标签
+ Status *int64 `json:"Status,omitnil" name:"Status"`
+
+ // 设置分账标签时间,普通标签不返回
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ UpdateTime *string `json:"UpdateTime,omitnil" name:"UpdateTime"`
+}
+
+type TagSummaryOverviewItem struct {
+ // 标签值
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TagValue *string `json:"TagValue,omitnil" name:"TagValue"`
+
+ // 费用所占百分比,两位小数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RealTotalCostRatio *string `json:"RealTotalCostRatio,omitnil" name:"RealTotalCostRatio"`
+
+ // 优惠后总价
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RealTotalCost *string `json:"RealTotalCost,omitnil" name:"RealTotalCost"`
+
+ // 现金账户支出:通过现金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CashPayAmount *string `json:"CashPayAmount,omitnil" name:"CashPayAmount"`
+
+ // 赠送账户支出:使用赠送金支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ IncentivePayAmount *string `json:"IncentivePayAmount,omitnil" name:"IncentivePayAmount"`
+
+ // 优惠券支出:使用各类优惠券(如代金券、现金券等)支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ VoucherPayAmount *string `json:"VoucherPayAmount,omitnil" name:"VoucherPayAmount"`
+
+ // 分成金账户支出:通过分成金账户支付的金额
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TransferPayAmount *string `json:"TransferPayAmount,omitnil" name:"TransferPayAmount"`
+
+ // 原价,单位为元。TotalCost字段自账单3.0(即2021-05)之后开始生效,账单3.0之前返回"-"。合同价的情况下,TotalCost字段与官网价格存在差异,也返回“-”。
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TotalCost *string `json:"TotalCost,omitnil" name:"TotalCost"`
+}
+
+type UsageDetails struct {
+ // 商品名
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ProductName *string `json:"ProductName,omitnil" name:"ProductName"`
+
+ // 商品细节
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SubProductName *string `json:"SubProductName,omitnil" name:"SubProductName"`
+}
+
+type UsageRecords struct {
+ // 使用金额(微分)
+ UsedAmount *int64 `json:"UsedAmount,omitnil" name:"UsedAmount"`
+
+ // 使用时间
+ UsedTime *string `json:"UsedTime,omitnil" name:"UsedTime"`
+
+ // 使用记录细节
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ UsageDetails []*UsageDetails `json:"UsageDetails,omitnil" name:"UsageDetails"`
+}
+
+type VoucherInfos struct {
+ // 代金券拥有者
+ OwnerUin *string `json:"OwnerUin,omitnil" name:"OwnerUin"`
+
+ // 券状态:待使用:unUsed,已使用: used,已发货:delivered,已作废: cancel,已过期:overdue
+ Status *string `json:"Status,omitnil" name:"Status"`
+
+ // 代金券面额(微分)
+ NominalValue *int64 `json:"NominalValue,omitnil" name:"NominalValue"`
+
+ // 剩余金额(微分)
+ Balance *int64 `json:"Balance,omitnil" name:"Balance"`
+
+ // 代金券id
+ VoucherId *string `json:"VoucherId,omitnil" name:"VoucherId"`
+
+ // postPay后付费/prePay预付费/riPay预留实例/空字符串或者'*'表示全部模式
+ PayMode *string `json:"PayMode,omitnil" name:"PayMode"`
+
+ // 付费场景PayMode=postPay时:spotpay-竞价实例,"settle account"-普通后付费PayMode=prePay时:purchase-包年包月新购,renew-包年包月续费(自动续费),modify-包年包月配置变更(变配)PayMode=riPay时:oneOffFee-预留实例预付,hourlyFee-预留实例每小时扣费,*-支持全部付费场景
+ PayScene *string `json:"PayScene,omitnil" name:"PayScene"`
+
+ // 有效期生效时间
+ BeginTime *string `json:"BeginTime,omitnil" name:"BeginTime"`
+
+ // 有效期截止时间
+ EndTime *string `json:"EndTime,omitnil" name:"EndTime"`
+
+ // 适用商品信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ApplicableProducts *ApplicableProducts `json:"ApplicableProducts,omitnil" name:"ApplicableProducts"`
+
+ // 不适用商品信息
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ExcludedProducts []*ExcludedProducts `json:"ExcludedProducts,omitnil" name:"ExcludedProducts"`
+}
\ No newline at end of file
diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http/request.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http/request.go
index fc27bae73a..ce7d3c228d 100644
--- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http/request.go
+++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http/request.go
@@ -265,7 +265,7 @@ func CompleteCommonParams(request Request, region string, requestClient string)
params["Action"] = request.GetAction()
params["Timestamp"] = strconv.FormatInt(time.Now().Unix(), 10)
params["Nonce"] = strconv.Itoa(rand.Int())
- params["RequestClient"] = "SDK_GO_1.0.853"
+ params["RequestClient"] = "SDK_GO_1.0.857"
if requestClient != "" {
params["RequestClient"] += ": " + requestClient
}
diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip/v20221121/models.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip/v20221121/models.go
index 1eaf307d99..5dff517f5d 100644
--- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip/v20221121/models.go
+++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip/v20221121/models.go
@@ -311,6 +311,20 @@ type AssetInfoDetail struct {
ScanTime *string `json:"ScanTime,omitnil" name:"ScanTime"`
}
+type AssetInstanceTypeMap struct {
+ // 资产类型
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Text *string `json:"Text,omitnil" name:"Text"`
+
+ // 资产类型
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Value *string `json:"Value,omitnil" name:"Value"`
+
+ // 资产类型和实例类型映射关系
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ InstanceTypeList []*FilterDataObject `json:"InstanceTypeList,omitnil" name:"InstanceTypeList"`
+}
+
type AssetTag struct {
// 标签的key值,可以是字母、数字、下划线
// 注意:此字段可能返回 null,表示取不到有效值。
@@ -903,6 +917,54 @@ type CVMAssetVO struct {
// 1新资产;0 非新资产
// 注意:此字段可能返回 null,表示取不到有效值。
IsNewAsset *uint64 `json:"IsNewAsset,omitnil" name:"IsNewAsset"`
+
+ // 0 未安装 1安装 2:安装中
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CVMAgentStatus *int64 `json:"CVMAgentStatus,omitnil" name:"CVMAgentStatus"`
+
+ // 1:开启 0:未开启
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CVMStatus *int64 `json:"CVMStatus,omitnil" name:"CVMStatus"`
+
+ // 1:客户端已安装 0:未安装 2: Agentless
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ DefenseModel *int64 `json:"DefenseModel,omitnil" name:"DefenseModel"`
+
+ // 1:已安装 0:未安装
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ TatStatus *int64 `json:"TatStatus,omitnil" name:"TatStatus"`
+
+ // cpu趋势图
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CpuTrend []*Element `json:"CpuTrend,omitnil" name:"CpuTrend"`
+
+ // 内存趋势图
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ MemoryTrend []*Element `json:"MemoryTrend,omitnil" name:"MemoryTrend"`
+
+ // 1:agent在线 0:agent离线 2:主机离线
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AgentStatus *int64 `json:"AgentStatus,omitnil" name:"AgentStatus"`
+
+ // 本月防护关闭次数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CloseDefenseCount *int64 `json:"CloseDefenseCount,omitnil" name:"CloseDefenseCount"`
+
+ // 运行状态
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ InstanceState *string `json:"InstanceState,omitnil" name:"InstanceState"`
+
+ // 安全组数据
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SecurityGroupIds []*string `json:"SecurityGroupIds,omitnil" name:"SecurityGroupIds"`
+
+ // 物理内存占用KB
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AgentMemRss *int64 `json:"AgentMemRss,omitnil" name:"AgentMemRss"`
+
+ // CPU使用率百分比
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AgentCpuPer *float64 `json:"AgentCpuPer,omitnil" name:"AgentCpuPer"`
}
type ClbListenerListInfo struct {
@@ -1528,6 +1590,9 @@ func (r *DescribeCVMAssetInfoResponse) FromJsonString(s string) error {
// Predefined struct for user
type DescribeCVMAssetsRequestParams struct {
+ // 集团账号的成员id
+ MemberId []*string `json:"MemberId,omitnil" name:"MemberId"`
+
// -
Filter *Filter `json:"Filter,omitnil" name:"Filter"`
}
@@ -1535,6 +1600,9 @@ type DescribeCVMAssetsRequestParams struct {
type DescribeCVMAssetsRequest struct {
*tchttp.BaseRequest
+ // 集团账号的成员id
+ MemberId []*string `json:"MemberId,omitnil" name:"MemberId"`
+
// -
Filter *Filter `json:"Filter,omitnil" name:"Filter"`
}
@@ -1551,6 +1619,7 @@ func (r *DescribeCVMAssetsRequest) FromJsonString(s string) error {
if err := json.Unmarshal([]byte(s), &f); err != nil {
return err
}
+ delete(f, "MemberId")
delete(f, "Filter")
if len(f) > 0 {
return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "DescribeCVMAssetsRequest has unknown keys!", "")
@@ -1604,6 +1673,10 @@ type DescribeCVMAssetsResponseParams struct {
// 注意:此字段可能返回 null,表示取不到有效值。
OsList []*FilterDataObject `json:"OsList,omitnil" name:"OsList"`
+ // 资产类型和实例类型的对应关系
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AssetMapInstanceTypeList []*AssetInstanceTypeMap `json:"AssetMapInstanceTypeList,omitnil" name:"AssetMapInstanceTypeList"`
+
// 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
}
@@ -3386,6 +3459,9 @@ func (r *DescribeTaskLogURLResponse) FromJsonString(s string) error {
// Predefined struct for user
type DescribeVULRiskAdvanceCFGListRequestParams struct {
+ // 集团账号的成员id
+ MemberId []*string `json:"MemberId,omitnil" name:"MemberId"`
+
// 任务ID
TaskId *string `json:"TaskId,omitnil" name:"TaskId"`
@@ -3396,6 +3472,9 @@ type DescribeVULRiskAdvanceCFGListRequestParams struct {
type DescribeVULRiskAdvanceCFGListRequest struct {
*tchttp.BaseRequest
+ // 集团账号的成员id
+ MemberId []*string `json:"MemberId,omitnil" name:"MemberId"`
+
// 任务ID
TaskId *string `json:"TaskId,omitnil" name:"TaskId"`
@@ -3415,6 +3494,7 @@ func (r *DescribeVULRiskAdvanceCFGListRequest) FromJsonString(s string) error {
if err := json.Unmarshal([]byte(s), &f); err != nil {
return err
}
+ delete(f, "MemberId")
delete(f, "TaskId")
delete(f, "Filter")
if len(f) > 0 {
@@ -3444,6 +3524,10 @@ type DescribeVULRiskAdvanceCFGListResponseParams struct {
// 注意:此字段可能返回 null,表示取不到有效值。
CheckFromLists []*FilterDataObject `json:"CheckFromLists,omitnil" name:"CheckFromLists"`
+ // 漏洞标签列表
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ VulTagList []*FilterDataObject `json:"VulTagList,omitnil" name:"VulTagList"`
+
// 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。
RequestId *string `json:"RequestId,omitnil" name:"RequestId"`
}
@@ -3691,6 +3775,16 @@ type DomainAssetVO struct {
BotAccessCount *int64 `json:"BotAccessCount,omitnil" name:"BotAccessCount"`
}
+type Element struct {
+ // 统计类型
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Key *string `json:"Key,omitnil" name:"Key"`
+
+ // 统计对象
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Value *string `json:"Value,omitnil" name:"Value"`
+}
+
type Filter struct {
// 查询数量限制
Limit *int64 `json:"Limit,omitnil" name:"Limit"`
@@ -4383,6 +4477,20 @@ type OrganizationUserInfo struct {
TcMemberType *int64 `json:"TcMemberType,omitnil" name:"TcMemberType"`
}
+type PortRiskAdvanceCFGParamItem struct {
+ // 端口集合,以逗号分隔
+ PortSets *string `json:"PortSets,omitnil" name:"PortSets"`
+
+ // 检测项类型,0-系统定义,1-用户自定义
+ CheckType *int64 `json:"CheckType,omitnil" name:"CheckType"`
+
+ // 检测项描述
+ Detail *string `json:"Detail,omitnil" name:"Detail"`
+
+ // 是否启用,1-启用,0-禁用
+ Enable *int64 `json:"Enable,omitnil" name:"Enable"`
+}
+
type PortViewPortRisk struct {
// 影响资产
NoHandleCount *int64 `json:"NoHandleCount,omitnil" name:"NoHandleCount"`
@@ -4457,14 +4565,14 @@ type RiskCenterStatusKey struct {
// 风险ID
Id *string `json:"Id,omitnil" name:"Id"`
- // APP ID
- AppId *string `json:"AppId,omitnil" name:"AppId"`
-
// 公网IP/域名
PublicIPDomain *string `json:"PublicIPDomain,omitnil" name:"PublicIPDomain"`
// 实例ID
InstanceId *string `json:"InstanceId,omitnil" name:"InstanceId"`
+
+ // APP ID
+ AppId *string `json:"AppId,omitnil" name:"AppId"`
}
type ScanTaskInfo struct {
@@ -4776,6 +4884,25 @@ type ServerRiskSuggestion struct {
Body *string `json:"Body,omitnil" name:"Body"`
}
+type ServiceSupport struct {
+ // 产品名称:
+ // "cfw_waf_virtual", "cwp_detect", "cwp_defense", "cwp_fix"
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ServiceName *string `json:"ServiceName,omitnil" name:"ServiceName"`
+
+ // 已处理的资产总数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SupportHandledCount *int64 `json:"SupportHandledCount,omitnil" name:"SupportHandledCount"`
+
+ // 支持的资产总数
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ SupportTotalCount *int64 `json:"SupportTotalCount,omitnil" name:"SupportTotalCount"`
+
+ // 是否支持该产品1支持;0不支持
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ IsSupport *bool `json:"IsSupport,omitnil" name:"IsSupport"`
+}
+
// Predefined struct for user
type StopRiskCenterTaskRequestParams struct {
// 任务id 列表
@@ -4914,6 +5041,9 @@ type Tags struct {
}
type TaskAdvanceCFG struct {
+ // 端口风险高级配置
+ PortRisk []*PortRiskAdvanceCFGParamItem `json:"PortRisk,omitnil" name:"PortRisk"`
+
// 漏洞风险高级配置
VulRisk []*TaskCenterVulRiskInputParam `json:"VulRisk,omitnil" name:"VulRisk"`
@@ -5105,6 +5235,30 @@ type VULRiskAdvanceCFGList struct {
// 影响组件
// 注意:此字段可能返回 null,表示取不到有效值。
ImpactComponent *string `json:"ImpactComponent,omitnil" name:"ImpactComponent"`
+
+ // 漏洞Payload
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ Payload *string `json:"Payload,omitnil" name:"Payload"`
+
+ // 技术参考
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ References *string `json:"References,omitnil" name:"References"`
+
+ // cvss评分
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ CVSS *string `json:"CVSS,omitnil" name:"CVSS"`
+
+ // 攻击热度
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ AttackHeat *string `json:"AttackHeat,omitnil" name:"AttackHeat"`
+
+ // 安全产品支持情况
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ ServiceSupport []*ServiceSupport `json:"ServiceSupport,omitnil" name:"ServiceSupport"`
+
+ // 最新检测时间
+ // 注意:此字段可能返回 null,表示取不到有效值。
+ RecentScanTime *string `json:"RecentScanTime,omitnil" name:"RecentScanTime"`
}
type VULViewVULRisk struct {
diff --git a/vendor/modules.txt b/vendor/modules.txt
index 19d4549a78..ba7b09c756 100644
--- a/vendor/modules.txt
+++ b/vendor/modules.txt
@@ -1112,6 +1112,9 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/as/v20180419
# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/bi v1.0.824
## explicit; go 1.14
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/bi/v20220105
+# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing v1.0.856
+## explicit; go 1.14
+github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/billing/v20180709
# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.760
## explicit; go 1.14
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam/v20190116
@@ -1157,7 +1160,7 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cloudaudit/v20190319
# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cls v1.0.711
## explicit; go 1.14
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cls/v20201016
-# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.853
+# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.857
## explicit; go 1.11
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/errors
@@ -1165,7 +1168,7 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/http
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/json
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/profile
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/regions
-# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.853
+# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip v1.0.857
## explicit; go 1.14
github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/csip/v20221121
# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.624
diff --git a/website/docs/d/clb_attachments.html.markdown b/website/docs/d/clb_attachments.html.markdown
index 58a849c8dc..417f32f9bc 100644
--- a/website/docs/d/clb_attachments.html.markdown
+++ b/website/docs/d/clb_attachments.html.markdown
@@ -40,6 +40,7 @@ In addition to all arguments above, the following attributes are exported:
* `protocol_type` - Type of protocol within the listener, and available values include `TCP`, `UDP`, `HTTP`, `HTTPS` and `TCP_SSL`. NOTES: `TCP_SSL` is testing internally, please apply if you need to use.
* `rule_id` - ID of the CLB listener rule.
* `targets` - Information of the backends to be attached.
+ * `eni_ip` - Elastic network card unique ID.
* `instance_id` - Id of the backend server.
* `port` - Port of the backend server.
* `weight` - Forwarding weight of the backend service, the range of [0, 100], defaults to `10`.