From 98dec7a7616cf7821e6ef9af320657d7d5ff8b4f Mon Sep 17 00:00:00 2001 From: Arunma <41282634+gitmkn@users.noreply.github.com> Date: Sun, 8 Oct 2023 20:50:07 +0800 Subject: [PATCH] Feat/cat resource (#2143) * feat: support cat * faet: support task * fix: Modify the interface DescribeProbeNodes to DescribeNodes * fix: modify sdk * fix: modify sdk * fix: modify test * fix: modify test * fix: modify test * fix: modify test * fix: modify test * fix: modify provider * fix: modify provider * fix: modify provider * fix: modify provider * fix: modify provider * fix: modify go mod * fix: modify go mod * fix: add doc * fix: add changelog * Update 2143.txt changelog update --------- Co-authored-by: andrewjiang <104899514+andrew-tx@users.noreply.github.com> --- .changelog/2143.txt | 11 + go.mod | 9 +- go.sum | 4 + .../data_source_tc_cat_metric_data.go | 154 ++++++ .../data_source_tc_cat_metric_data_test.go | 83 +++ tencentcloud/data_source_tc_cat_node.go | 32 +- tencentcloud/data_source_tc_cat_node_test.go | 17 +- tencentcloud/provider.go | 2 + tencentcloud/resource_tc_cat_task_set.go | 88 +++- tencentcloud/resource_tc_cat_task_set_test.go | 126 +++++ tencentcloud/service_tencentcloud_cat.go | 105 +++- .../tencentcloud/cat/v20180409/client.go | 68 +++ .../tencentcloud/cat/v20180409/models.go | 497 ++++++++++-------- .../tencentcloud/common/http/request.go | 2 +- vendor/modules.txt | 4 +- website/docs/d/cat_metric_data.html.markdown | 46 ++ website/docs/d/cat_node.html.markdown | 1 + website/docs/r/cat_task_set.html.markdown | 1 + website/tencentcloud.erb | 3 + 19 files changed, 1028 insertions(+), 225 deletions(-) create mode 100644 .changelog/2143.txt create mode 100644 tencentcloud/data_source_tc_cat_metric_data.go create mode 100644 tencentcloud/data_source_tc_cat_metric_data_test.go create mode 100644 website/docs/d/cat_metric_data.html.markdown diff --git a/.changelog/2143.txt b/.changelog/2143.txt new file mode 100644 index 0000000000..1be5dde35a --- /dev/null +++ b/.changelog/2143.txt @@ -0,0 +1,11 @@ +```release-note:new-data-source +tencentcloud_cat_metric_data +``` + +```release-note:enhancement +datasource/tencentcloud_cat_node: Add computed `task_types` +``` + +```release-note:enhancement +resource/tencentcloud_cat_task_set: Support `suspend` and `resume` for dial test tasks +``` diff --git a/go.mod b/go.mod index 5b5c9b8d39..7c15057ea0 100644 --- a/go.mod +++ b/go.mod @@ -30,19 +30,20 @@ require ( github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/apm v1.0.624 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/as v1.0.756 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.409 - github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.520 + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.760 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cbs v1.0.591 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cdb v1.0.699 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cdn v1.0.539 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cdwch v1.0.745 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cfs v1.0.627 + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cfw v1.0.759 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/chdfs v1.0.600 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/ciam v1.0.695 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/ckafka v1.0.748 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/clb v1.0.693 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.759 + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.760 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.624 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cwp v1.0.589 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cynosdb v1.0.692 @@ -93,16 +94,14 @@ require ( github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/tsf v1.0.674 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/vod v1.0.199 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/vpc v1.0.755 + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/waf v1.0.759 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/wedata v1.0.725 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/wss v1.0.199 - github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cfw v1.0.759 - github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/waf v1.0.759 github.com/tencentyun/cos-go-sdk-v5 v0.7.42-0.20230629101357-7edd77448a0f github.com/yangwenmai/ratelimit v0.0.0-20180104140304-44221c2292e1 gopkg.in/yaml.v2 v2.4.0 ) - require ( 4d63.com/gocheckcompilerdirectives v1.2.1 // indirect 4d63.com/gochecknoglobals v0.2.1 // indirect diff --git a/go.sum b/go.sum index b1f19e5808..1c5eae565e 100644 --- a/go.sum +++ b/go.sum @@ -786,6 +786,8 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.409 h1:ToZpNh7 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.409/go.mod h1:U24yUxCDruJLayOsP/onO2E/7+9ljeNsNO+phu+PeiM= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.520 h1:n4FN0PI+1MVWi+RGQbD/cElXjquZQK0K1h1Z1nNWNWw= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.520/go.mod h1:gzI+2Qd/iUfPPQQjW30k0G3mJ3m7tXeXrydJMm8jsOo= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.760 h1:oGY4IigfIw0iQKh3/cOY29KBeEeFbvJft69e0beyfdI= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.760/go.mod h1:SoBOZr6fklP8zeHaq7XOnCd5xBypU2R94nOPafYX1J4= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cbs v1.0.591 h1:TPGLjH6wqkA5Iirl6xCxFkWwrtCZ8ZmeF7ASzqUbsZA= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cbs v1.0.591/go.mod h1:nCAGfVTXZkVnurkbjF3b0FM6RwGztE9t8D9Ms1unaKo= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cbs v1.0.592 h1:xowULQ7Mca1TjHyjAGe8RYjg37yhWpne5Q+TihFNHVA= @@ -878,6 +880,8 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.758 h1:T7Ry github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.758/go.mod h1:7sCQWVkxcsR38nffDW057DRGk8mUjK1Ing/EFOK8s8Y= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.759 h1:flWgFybB3MYWFxwRO4yXbdiPT3SNwjSLuXCXsfs6kN4= github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.759/go.mod h1:7sCQWVkxcsR38nffDW057DRGk8mUjK1Ing/EFOK8s8Y= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.760 h1:OyUPYgXBZNh3erZZ4jhpFH+aGtcCB1TUUtYX4WbR+xg= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.760/go.mod h1:7sCQWVkxcsR38nffDW057DRGk8mUjK1Ing/EFOK8s8Y= 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.589 h1:LZihgirMH0vsaGScYexxwY0fTss9vHaSZs/YOQUVESg= diff --git a/tencentcloud/data_source_tc_cat_metric_data.go b/tencentcloud/data_source_tc_cat_metric_data.go new file mode 100644 index 0000000000..498416e41d --- /dev/null +++ b/tencentcloud/data_source_tc_cat_metric_data.go @@ -0,0 +1,154 @@ +/* +Use this data source to query detailed information of cat metric_data +Example Usage +```hcl +data "tencentcloud_cat_metric_data" "metric_data" { + analyze_task_type = "AnalyzeTaskType_Network" + metric_type = "gauge" + field = "avg(\"ping_time\")" + filters = [ + "\"host\" = 'www.qq.com'", + "time >= now()-1h", + ] +} +``` +*/ +package tencentcloud + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + cat "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409" + sdkErrors "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/errors" + "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/internal/helper" +) + +func dataSourceTencentCloudCatMetricData() *schema.Resource { + return &schema.Resource{ + Read: dataSourceTencentCloudCatMetricDataRead, + Schema: map[string]*schema.Schema{ + "analyze_task_type": { + Required: true, + Type: schema.TypeString, + Description: "Analysis of task type, supported types: `AnalyzeTaskType_Network`: network quality, `AnalyzeTaskType_Browse`: page performance, `AnalyzeTaskType_Transport`: port performance, `AnalyzeTaskType_UploadDownload`: file transport, `AnalyzeTaskType_MediaStream`: audiovisual experience.", + }, + + "metric_type": { + Required: true, + Type: schema.TypeString, + Description: "Metric type, metrics queries are passed with gauge by default.", + }, + + "field": { + Required: true, + Type: schema.TypeString, + Description: "Detailed fields of metrics, specified metrics can be passed or aggregate metrics, such as avg(ping_time) means entire delay.", + }, + + "filter": { + Optional: true, + Type: schema.TypeString, + Description: "Filter conditions can be passed as a single filter or multiple parameters concatenated together.", + }, + + "group_by": { + Optional: true, + Type: schema.TypeString, + Description: "Aggregation time, such as 1m, 1d, 30d, and so on.", + }, + + "filters": { + Required: true, + Type: schema.TypeSet, + Elem: &schema.Schema{ + Type: schema.TypeString, + }, + Description: "Multiple condition filtering, supports combining multiple filtering conditions for query.", + }, + + "metric_set": { + Computed: true, + Type: schema.TypeString, + Description: "Return JSON string.", + }, + + "result_output_file": { + Type: schema.TypeString, + Optional: true, + Description: "Used to save results.", + }, + }, + } +} + +func dataSourceTencentCloudCatMetricDataRead(d *schema.ResourceData, meta interface{}) error { + defer logElapsed("data_source.tencentcloud_cat_metric_data.read")() + defer inconsistentCheck(d, meta)() + + logId := getLogId(contextNil) + + ctx := context.WithValue(context.TODO(), logIdKey, logId) + + paramMap := make(map[string]interface{}) + if v, ok := d.GetOk("analyze_task_type"); ok { + paramMap["AnalyzeTaskType"] = helper.String(v.(string)) + } + + if v, ok := d.GetOk("metric_type"); ok { + paramMap["MetricType"] = helper.String(v.(string)) + } + + if v, ok := d.GetOk("field"); ok { + paramMap["Field"] = helper.String(v.(string)) + } + + if v, ok := d.GetOk("filter"); ok { + paramMap["Filter"] = helper.String(v.(string)) + } + + if v, ok := d.GetOk("group_by"); ok { + paramMap["GroupBy"] = helper.String(v.(string)) + } + + if v, ok := d.GetOk("filters"); ok { + filtersSet := v.(*schema.Set).List() + paramMap["Filters"] = helper.InterfacesStringsPoint(filtersSet) + } + + service := CatService{client: meta.(*TencentCloudClient).apiV3Conn} + + var metric *cat.DescribeProbeMetricDataResponseParams + err := resource.Retry(readRetryTimeout, func() *resource.RetryError { + result, e := service.DescribeCatMetricDataByFilter(ctx, paramMap) + if e != nil { + if sdkError, ok := e.(*sdkErrors.TencentCloudSDKError); ok { + if sdkError.Code == "FailedOperation.DbQueryFailed" { + return resource.NonRetryableError(e) + } + } + return retryError(e) + } + metric = result + return nil + }) + if err != nil { + return err + } + + var metricSet string + if metric != nil && metric.MetricSet != nil { + metricSet = *metric.MetricSet + _ = d.Set("metric_set", metric.MetricSet) + } + + d.SetId(helper.DataResourceIdsHash([]string{metricSet})) + output, ok := d.GetOk("result_output_file") + if ok && output.(string) != "" { + if e := writeToFile(output.(string), metricSet); e != nil { + return e + } + } + return nil +} diff --git a/tencentcloud/data_source_tc_cat_metric_data_test.go b/tencentcloud/data_source_tc_cat_metric_data_test.go new file mode 100644 index 0000000000..a2827dc8ad --- /dev/null +++ b/tencentcloud/data_source_tc_cat_metric_data_test.go @@ -0,0 +1,83 @@ +package tencentcloud + +import ( + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" +) + +// go test -test.run TestAccTencentCloudCatMetricDataDataSource_basic -v +func TestAccTencentCloudCatMetricDataDataSource_basic(t *testing.T) { + t.Parallel() + resource.Test(t, resource.TestCase{ + PreCheck: func() { + testAccPreCheck(t) + }, + Providers: testAccProviders, + Steps: []resource.TestStep{ + { + Config: testAccCatMetricDataDataSource, + Check: resource.ComposeTestCheckFunc( + testAccCheckTencentCloudDataSourceID("data.tencentcloud_cat_metric_data.metric_data"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_metric_data.metric_data", "metric_set"), + ), + }, + }, + }) +} + +const testAccCatMetricDataDataSource = ` +resource "tencentcloud_cat_task_set" "task_set" { + interval = 1 + nodes = [ + "12136", + "12137", + ] + parameters = jsonencode( + { + blackList = "" + filterIp = 0 + grabBag = 0 + ipType = 0 + netDigOn = 1 + netDnsNs = "" + netDnsOn = 1 + netDnsQuerymethod = 1 + netDnsServer = 2 + netDnsTimeout = 5 + netIcmpActivex = 0 + netIcmpActivexStr = "" + netIcmpDataCut = 1 + netIcmpInterval = 0.5 + netIcmpNum = 20 + netIcmpOn = 1 + netIcmpSize = 32 + netIcmpTimeout = 20 + netTracertNum = 30 + netTracertOn = 1 + netTracertTimeout = 60 + whiteList = "" + } + ) + tags = {} + task_category = 1 + task_type = 5 + + batch_tasks { + name = "terraform-test" + target_address = "www.baidu.com" + } +} + +data "tencentcloud_cat_metric_data" "metric_data" { + analyze_task_type = "AnalyzeTaskType_Network" + metric_type = "gauge" + field = "avg(\"ping_time\")" + filters = [ + "\"host\" = 'www.baidu.com'", + "time >= now()-1h", + ] + depends_on = [ tencentcloud_cat_task_set.task_set ] +} + +` diff --git a/tencentcloud/data_source_tc_cat_node.go b/tencentcloud/data_source_tc_cat_node.go index 6d14234f7e..bff9e7d957 100644 --- a/tencentcloud/data_source_tc_cat_node.go +++ b/tencentcloud/data_source_tc_cat_node.go @@ -113,6 +113,12 @@ func dataSourceTencentCloudCatNode() *schema.Resource { Computed: true, Description: "Node status: 1=running, 2=offline.", }, + "task_types": { + Type: schema.TypeList, + Elem: &schema.Schema{Type: schema.TypeInt}, + Computed: true, + Description: "The task types supported by the node. `1`: page performance, `2`: file upload, `3`: file download, `4`: port performance, `5`: network quality, `6`: audio and video experience.", + }, }, }, }, @@ -158,7 +164,7 @@ func dataSourceTencentCloudCatNodeRead(d *schema.ResourceData, meta interface{}) var nodeSets []*cat.NodeDefine err := resource.Retry(readRetryTimeout, func() *resource.RetryError { - results, e := catService.DescribeCatNodeByFilter(ctx, paramMap) + results, e := catService.DescribeCatProbeNodeByFilter(ctx, paramMap) if e != nil { return retryError(e) } @@ -170,6 +176,20 @@ func dataSourceTencentCloudCatNodeRead(d *schema.ResourceData, meta interface{}) return err } + var nodeSetExt []*cat.NodeDefineExt + err = resource.Retry(readRetryTimeout, func() *resource.RetryError { + results, e := catService.DescribeCatNodeByFilter(ctx, paramMap) + if e != nil { + return retryError(e) + } + nodeSetExt = results + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s read Cat nodeSet failed, reason:%+v", logId, err) + return err + } + ids := make([]string, 0, len(nodeSets)) nodeSetList := make([]map[string]interface{}, 0, len(nodeSets)) if nodeSets != nil { @@ -205,6 +225,16 @@ func dataSourceTencentCloudCatNodeRead(d *schema.ResourceData, meta interface{}) if nodeSet.NodeDefineStatus != nil { nodeSetMap["node_define_status"] = nodeSet.NodeDefineStatus } + + for _, node := range nodeSetExt { + if *node.Code == *nodeSet.Code { + if node.TaskTypes != nil { + nodeSetMap["task_types"] = node.TaskTypes + } + break + } + } + ids = append(ids, *nodeSet.Name) nodeSetList = append(nodeSetList, nodeSetMap) } diff --git a/tencentcloud/data_source_tc_cat_node_test.go b/tencentcloud/data_source_tc_cat_node_test.go index cff43f99cb..799a97e961 100644 --- a/tencentcloud/data_source_tc_cat_node_test.go +++ b/tencentcloud/data_source_tc_cat_node_test.go @@ -6,6 +6,7 @@ import ( "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" ) +// go test -test.run TestAccTencentCloudCatNodeDataSource -v func TestAccTencentCloudCatNodeDataSource(t *testing.T) { t.Parallel() @@ -17,6 +18,18 @@ func TestAccTencentCloudCatNodeDataSource(t *testing.T) { Config: testAccDataSourceCatNode, Check: resource.ComposeTestCheckFunc( testAccCheckTencentCloudDataSourceID("data.tencentcloud_cat_node.node"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.#"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.city"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.code"), + // resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.code_type"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.district"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.ip_type"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.location"), + // resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.name"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.net_service"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.node_define_status"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.task_types.#"), + resource.TestCheckResourceAttrSet("data.tencentcloud_cat_node.node", "node_define.0.type"), ), }, }, @@ -27,8 +40,8 @@ const testAccDataSourceCatNode = ` data "tencentcloud_cat_node" "node"{ node_type = 1 - location = 2 - is_ipv6 = false + location = 2 + is_ipv6 = false } ` diff --git a/tencentcloud/provider.go b/tencentcloud/provider.go index ca2a5ba2e8..9c4c2ddef1 100644 --- a/tencentcloud/provider.go +++ b/tencentcloud/provider.go @@ -1275,6 +1275,7 @@ Cloud Automated Testing(CAT) Data Source tencentcloud_cat_probe_data tencentcloud_cat_node + tencentcloud_cat_metric_data Resource tencentcloud_cat_task_set @@ -2218,6 +2219,7 @@ func Provider() *schema.Provider { "tencentcloud_tdcpg_instances": dataSourceTencentCloudTdcpgInstances(), "tencentcloud_cat_probe_data": dataSourceTencentCloudCatProbeData(), "tencentcloud_cat_node": dataSourceTencentCloudCatNode(), + "tencentcloud_cat_metric_data": dataSourceTencentCloudCatMetricData(), "tencentcloud_rum_project": dataSourceTencentCloudRumProject(), "tencentcloud_rum_offline_log_config": dataSourceTencentCloudRumOfflineLogConfig(), "tencentcloud_rum_whitelist": dataSourceTencentCloudRumWhitelist(), diff --git a/tencentcloud/resource_tc_cat_task_set.go b/tencentcloud/resource_tc_cat_task_set.go index e028a6aefc..66470aca20 100644 --- a/tencentcloud/resource_tc_cat_task_set.go +++ b/tencentcloud/resource_tc_cat_task_set.go @@ -44,7 +44,6 @@ resource "tencentcloud_cat_task_set" "task_set" { "createdBy" = "terraform" } } - ``` Import @@ -142,6 +141,12 @@ func resourceTencentCloudCatTaskSet() *schema.Resource { Description: "Timer task cron expression.", }, + "operate": { + Type: schema.TypeString, + Optional: true, + Description: "The input is valid when the parameter is modified, `suspend`/`resume`, used to suspend/resume the dial test task.", + }, + "status": { Type: schema.TypeInt, Computed: true, @@ -379,10 +384,6 @@ func resourceTencentCloudCatTaskSetUpdate(d *schema.ResourceData, meta interface } } - if d.HasChange("batch_tasks") { - return fmt.Errorf("`batch_tasks` do not support change now.") - } - if d.HasChange("task_type") { return fmt.Errorf("`task_type` do not support change now.") } @@ -391,6 +392,42 @@ func resourceTencentCloudCatTaskSetUpdate(d *schema.ResourceData, meta interface return fmt.Errorf("`task_category` do not support change now.") } + if d.HasChange("batch_tasks") { + oldInterface, newInterface := d.GetChange("batch_tasks") + oldMap := make(map[string]interface{}) + newMap := make(map[string]interface{}) + for _, item := range oldInterface.([]interface{}) { + oldMap = item.(map[string]interface{}) + } + for _, item := range newInterface.([]interface{}) { + newMap = item.(map[string]interface{}) + } + replace, _ := diffTags(oldMap, newMap) + + if _, ok := replace["target_address"]; ok { + return fmt.Errorf("`target_address` do not support change now.") + } + + if v, ok := replace["name"]; ok { + requestTaskAttributes := cat.NewUpdateProbeTaskAttributesRequest() + requestTaskAttributes.TaskId = &taskId + requestTaskAttributes.Name = &v + err := resource.Retry(writeRetryTimeout, func() *resource.RetryError { + result, e := meta.(*TencentCloudClient).apiV3Conn.UseCatClient().UpdateProbeTaskAttributes(requestTaskAttributes) + if e != nil { + return retryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s Suspend cat task failed, reason:%+v", logId, err) + return err + } + } + } + err := resource.Retry(writeRetryTimeout, func() *resource.RetryError { result, e := meta.(*TencentCloudClient).apiV3Conn.UseCatClient().UpdateProbeTaskConfigurationList(request) if e != nil { @@ -407,6 +444,47 @@ func resourceTencentCloudCatTaskSetUpdate(d *schema.ResourceData, meta interface return err } + if d.HasChange("operate") { + if v, ok := d.GetOk("operate"); ok { + operate := v.(string) + if operate == "suspend" { + requestSuspend := cat.NewSuspendProbeTaskRequest() + requestSuspend.TaskIds = append(requestSuspend.TaskIds, &taskId) + err := resource.Retry(writeRetryTimeout, func() *resource.RetryError { + result, e := meta.(*TencentCloudClient).apiV3Conn.UseCatClient().SuspendProbeTask(requestSuspend) + if e != nil { + return retryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s Suspend cat task failed, reason:%+v", logId, err) + return err + } + } else if operate == "resume" { + requestResume := cat.NewResumeProbeTaskRequest() + requestResume.TaskIds = append(requestResume.TaskIds, &taskId) + err := resource.Retry(writeRetryTimeout, func() *resource.RetryError { + result, e := meta.(*TencentCloudClient).apiV3Conn.UseCatClient().ResumeProbeTask(requestResume) + if e != nil { + return retryError(e) + } else { + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), result.ToJsonString()) + } + return nil + }) + if err != nil { + log.Printf("[CRITAL]%s Resume cat task failed, reason:%+v", logId, err) + return err + } + } else { + return fmt.Errorf("`operate` only allows the input of suspend/resume.") + } + } + } + if d.HasChange("tags") { tcClient := meta.(*TencentCloudClient).apiV3Conn tagService := &TagService{client: tcClient} diff --git a/tencentcloud/resource_tc_cat_task_set_test.go b/tencentcloud/resource_tc_cat_task_set_test.go index 8a8adee722..af93f32005 100644 --- a/tencentcloud/resource_tc_cat_task_set_test.go +++ b/tencentcloud/resource_tc_cat_task_set_test.go @@ -6,6 +6,7 @@ import ( "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" ) +// go test -i; go test -test.run TestAccTencentCloudCatTaskSet_basic -v func TestAccTencentCloudCatTaskSet_basic(t *testing.T) { t.Parallel() @@ -17,6 +18,16 @@ func TestAccTencentCloudCatTaskSet_basic(t *testing.T) { Config: testAccCatTaskSet, Check: resource.ComposeTestCheckFunc( resource.TestCheckResourceAttrSet("tencentcloud_cat_task_set.task_set", "id"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "batch_tasks.#", "1"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "batch_tasks.0.name", "demo"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "batch_tasks.0.target_address", "http://www.baidu.com"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "task_type", "5"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "nodes.#", "5"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "interval", "6"), + resource.TestCheckResourceAttrSet("tencentcloud_cat_task_set.task_set", "parameters"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "task_category", "1"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "cron", "* 0-6 * * *"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "tags.createdBy", "terraform"), ), }, { @@ -24,6 +35,29 @@ func TestAccTencentCloudCatTaskSet_basic(t *testing.T) { ImportState: true, ImportStateVerify: true, }, + { + Config: testAccCatTaskSetUp, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_cat_task_set.task_set", "id"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "batch_tasks.0.name", "demo_test"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "batch_tasks.0.target_address", "http://www.baidu.com"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "task_type", "5"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "nodes.#", "5"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "interval", "6"), + resource.TestCheckResourceAttrSet("tencentcloud_cat_task_set.task_set", "parameters"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "task_category", "1"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "cron", "* 0-6 * * *"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "tags.createdBy", "terraform"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "status", "4"), + ), + }, + { + Config: testAccCatTaskSetResume, + Check: resource.ComposeTestCheckFunc( + resource.TestCheckResourceAttrSet("tencentcloud_cat_task_set.task_set", "id"), + resource.TestCheckResourceAttr("tencentcloud_cat_task_set.task_set", "status", "10"), + ), + }, }, }) } @@ -72,3 +106,95 @@ resource "tencentcloud_cat_task_set" "task_set" { } ` + +const testAccCatTaskSetUp = ` + +resource "tencentcloud_cat_task_set" "task_set" { + batch_tasks { + name = "demo_test" + target_address = "http://www.baidu.com" + } + task_type = 5 + nodes = ["12136", "12137", "12138", "12141", "12144"] + interval = 6 + parameters = jsonencode( + { + "ipType" = 0, + "grabBag" = 0, + "filterIp" = 0, + "netIcmpOn" = 1, + "netIcmpActivex" = 0, + "netIcmpTimeout" = 20, + "netIcmpInterval" = 0.5, + "netIcmpNum" = 20, + "netIcmpSize" = 32, + "netIcmpDataCut" = 1, + "netDnsOn" = 1, + "netDnsTimeout" = 5, + "netDnsQuerymethod" = 1, + "netDnsNs" = "", + "netDigOn" = 1, + "netDnsServer" = 2, + "netTracertOn" = 1, + "netTracertTimeout" = 60, + "netTracertNum" = 30, + "whiteList" = "", + "blackList" = "", + "netIcmpActivexStr" = "" + } + ) + task_category = 1 + cron = "* 0-6 * * *" + tags = { + "createdBy" = "terraform" + } + operate = "suspend" +} + +` + +const testAccCatTaskSetResume = ` + +resource "tencentcloud_cat_task_set" "task_set" { + batch_tasks { + name = "demo_test" + target_address = "http://www.baidu.com" + } + task_type = 5 + nodes = ["12136", "12137", "12138", "12141", "12144"] + interval = 6 + parameters = jsonencode( + { + "ipType" = 0, + "grabBag" = 0, + "filterIp" = 0, + "netIcmpOn" = 1, + "netIcmpActivex" = 0, + "netIcmpTimeout" = 20, + "netIcmpInterval" = 0.5, + "netIcmpNum" = 20, + "netIcmpSize" = 32, + "netIcmpDataCut" = 1, + "netDnsOn" = 1, + "netDnsTimeout" = 5, + "netDnsQuerymethod" = 1, + "netDnsNs" = "", + "netDigOn" = 1, + "netDnsServer" = 2, + "netTracertOn" = 1, + "netTracertTimeout" = 60, + "netTracertNum" = 30, + "whiteList" = "", + "blackList" = "", + "netIcmpActivexStr" = "" + } + ) + task_category = 1 + cron = "* 0-6 * * *" + tags = { + "createdBy" = "terraform" + } + operate = "resume" +} + +` diff --git a/tencentcloud/service_tencentcloud_cat.go b/tencentcloud/service_tencentcloud_cat.go index 10856e5c3a..3d0cf90ed7 100644 --- a/tencentcloud/service_tencentcloud_cat.go +++ b/tencentcloud/service_tencentcloud_cat.go @@ -91,7 +91,7 @@ func (me *CatService) DeleteCatTaskSetById(ctx context.Context, taskId string) ( return } -func (me *CatService) DescribeCatNodeByFilter(ctx context.Context, param map[string]interface{}) (node []*cat.NodeDefine, errRet error) { +func (me *CatService) DescribeCatProbeNodeByFilter(ctx context.Context, param map[string]interface{}) (node []*cat.NodeDefine, errRet error) { var ( logId = getLogId(ctx) request = cat.NewDescribeProbeNodesRequest() @@ -143,6 +143,59 @@ func (me *CatService) DescribeCatNodeByFilter(ctx context.Context, param map[str return } +// DescribeNodes interface is an alternative interface to DescribeProbeNodes, but it lacks the NodeDefineStatus field, so both interfaces are used at the same time. +func (me *CatService) DescribeCatNodeByFilter(ctx context.Context, param map[string]interface{}) (node []*cat.NodeDefineExt, errRet error) { + var ( + logId = getLogId(ctx) + request = cat.NewDescribeNodesRequest() + ) + + defer func() { + if errRet != nil { + log.Printf("[CRITAL]%s api[%s] fail, request body [%s], reason[%s]\n", + logId, "query object", request.ToJsonString(), errRet.Error()) + } + }() + + for k, v := range param { + if k == "node_type" { + request.NodeType = v.(*int64) + } + + if k == "location" { + request.Location = v.(*int64) + } + + if k == "is_ipv6" { + request.IsIPv6 = v.(*bool) + } + + if k == "node_name" { + request.NodeName = v.(*string) + } + + if k == "pay_mode" { + request.PayMode = v.(*int64) + } + + } + + ratelimit.Check(request.GetAction()) + response, err := me.client.UseCatClient().DescribeNodes(request) + if err != nil { + log.Printf("[CRITAL]%s api[%s] fail, request body [%s], reason[%s]\n", + logId, request.GetAction(), request.ToJsonString(), err.Error()) + errRet = err + return + } + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", + logId, request.GetAction(), request.ToJsonString(), response.ToJsonString()) + + node = append(node, response.Response.NodeSet...) + + return +} + func (me *CatService) DescribeCatProbeDataByFilter(ctx context.Context, param map[string]interface{}) (probeData []*cat.DetailedSingleDataDefine, errRet error) { var ( logId = getLogId(ctx) @@ -237,3 +290,53 @@ func (me *CatService) DescribeCatProbeDataByFilter(ctx context.Context, param ma return } + +func (me *CatService) DescribeCatMetricDataByFilter(ctx context.Context, param map[string]interface{}) (metricData *cat.DescribeProbeMetricDataResponseParams, errRet error) { + var ( + logId = getLogId(ctx) + request = cat.NewDescribeProbeMetricDataRequest() + ) + + defer func() { + if errRet != nil { + log.Printf("[CRITAL]%s api[%s] fail, request body [%s], reason[%s]\n", logId, request.GetAction(), request.ToJsonString(), errRet.Error()) + } + }() + + for k, v := range param { + if k == "AnalyzeTaskType" { + request.AnalyzeTaskType = v.(*string) + } + if k == "MetricType" { + request.MetricType = v.(*string) + } + if k == "Field" { + request.Field = v.(*string) + } + if k == "Filter" { + request.Filter = v.(*string) + } + if k == "GroupBy" { + request.GroupBy = v.(*string) + } + if k == "Filters" { + request.Filters = v.([]*string) + } + } + + ratelimit.Check(request.GetAction()) + response, err := me.client.UseCatClient().DescribeProbeMetricData(request) + if err != nil { + errRet = err + return + } + log.Printf("[DEBUG]%s api[%s] success, request body [%s], response body [%s]\n", logId, request.GetAction(), request.ToJsonString(), response.ToJsonString()) + + if response == nil || response.Response == nil { + return + } + + metricData = response.Response + + return +} diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/client.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/client.go index 5db0fa27b9..1b160dd0ab 100644 --- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/client.go +++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/client.go @@ -345,6 +345,7 @@ func NewDescribeProbeMetricDataResponse() (response *DescribeProbeMetricDataResp // 查询云拨测指标数据,指标支持使用sum,avg,max,min聚合函数进行指标数据查询 // // 可能返回的错误码: +// FAILEDOPERATION = "FailedOperation" // FAILEDOPERATION_DBQUERYFAILED = "FailedOperation.DbQueryFailed" func (c *Client) DescribeProbeMetricData(request *DescribeProbeMetricDataRequest) (response *DescribeProbeMetricDataResponse, err error) { return c.DescribeProbeMetricDataWithContext(context.Background(), request) @@ -354,6 +355,7 @@ func (c *Client) DescribeProbeMetricData(request *DescribeProbeMetricDataRequest // 查询云拨测指标数据,指标支持使用sum,avg,max,min聚合函数进行指标数据查询 // // 可能返回的错误码: +// FAILEDOPERATION = "FailedOperation" // FAILEDOPERATION_DBQUERYFAILED = "FailedOperation.DbQueryFailed" func (c *Client) DescribeProbeMetricDataWithContext(ctx context.Context, request *DescribeProbeMetricDataRequest) (response *DescribeProbeMetricDataResponse, err error) { if request == nil { @@ -619,6 +621,72 @@ func (c *Client) SuspendProbeTaskWithContext(ctx context.Context, request *Suspe return } +func NewUpdateProbeTaskAttributesRequest() (request *UpdateProbeTaskAttributesRequest) { + request = &UpdateProbeTaskAttributesRequest{ + BaseRequest: &tchttp.BaseRequest{}, + } + + request.Init().WithApiInfo("cat", APIVersion, "UpdateProbeTaskAttributes") + + + return +} + +func NewUpdateProbeTaskAttributesResponse() (response *UpdateProbeTaskAttributesResponse) { + response = &UpdateProbeTaskAttributesResponse{ + BaseResponse: &tchttp.BaseResponse{}, + } + return +} + +// UpdateProbeTaskAttributes +// 更新探测任务属性 +// +// 可能返回的错误码: +// FAILEDOPERATION_DBQUERYFAILED = "FailedOperation.DbQueryFailed" +// FAILEDOPERATION_DBRECORDCREATEFAILED = "FailedOperation.DbRecordCreateFailed" +// FAILEDOPERATION_DBRECORDUPDATEFAILED = "FailedOperation.DbRecordUpdateFailed" +// FAILEDOPERATION_NOVALIDNODES = "FailedOperation.NoValidNodes" +// FAILEDOPERATION_RESOURCENOTFOUND = "FailedOperation.ResourceNotFound" +// FAILEDOPERATION_TASKNOTRUNNING = "FailedOperation.TaskNotRunning" +// FAILEDOPERATION_TASKNOTSUSPENDED = "FailedOperation.TaskNotSuspended" +// FAILEDOPERATION_TASKOPERATIONNOTALLOW = "FailedOperation.TaskOperationNotAllow" +// INTERNALERROR = "InternalError" +// INVALIDPARAMETER = "InvalidParameter" +func (c *Client) UpdateProbeTaskAttributes(request *UpdateProbeTaskAttributesRequest) (response *UpdateProbeTaskAttributesResponse, err error) { + return c.UpdateProbeTaskAttributesWithContext(context.Background(), request) +} + +// UpdateProbeTaskAttributes +// 更新探测任务属性 +// +// 可能返回的错误码: +// FAILEDOPERATION_DBQUERYFAILED = "FailedOperation.DbQueryFailed" +// FAILEDOPERATION_DBRECORDCREATEFAILED = "FailedOperation.DbRecordCreateFailed" +// FAILEDOPERATION_DBRECORDUPDATEFAILED = "FailedOperation.DbRecordUpdateFailed" +// FAILEDOPERATION_NOVALIDNODES = "FailedOperation.NoValidNodes" +// FAILEDOPERATION_RESOURCENOTFOUND = "FailedOperation.ResourceNotFound" +// FAILEDOPERATION_TASKNOTRUNNING = "FailedOperation.TaskNotRunning" +// FAILEDOPERATION_TASKNOTSUSPENDED = "FailedOperation.TaskNotSuspended" +// FAILEDOPERATION_TASKOPERATIONNOTALLOW = "FailedOperation.TaskOperationNotAllow" +// INTERNALERROR = "InternalError" +// INVALIDPARAMETER = "InvalidParameter" +func (c *Client) UpdateProbeTaskAttributesWithContext(ctx context.Context, request *UpdateProbeTaskAttributesRequest) (response *UpdateProbeTaskAttributesResponse, err error) { + if request == nil { + request = NewUpdateProbeTaskAttributesRequest() + } + + if c.GetCredential() == nil { + return nil, errors.New("UpdateProbeTaskAttributes require credential") + } + + request.SetContext(ctx) + + response = NewUpdateProbeTaskAttributesResponse() + err = c.Send(request, response) + return +} + func NewUpdateProbeTaskConfigurationListRequest() (request *UpdateProbeTaskConfigurationListRequest) { request = &UpdateProbeTaskConfigurationListRequest{ BaseRequest: &tchttp.BaseRequest{}, diff --git a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/models.go b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/models.go index e9ceffecc4..441ef3b8d3 100644 --- a/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/models.go +++ b/vendor/github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409/models.go @@ -15,86 +15,86 @@ package v20180409 import ( - "encoding/json" 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" ) // Predefined struct for user type CreateProbeTasksRequestParams struct { // 批量任务名-地址 - BatchTasks []*ProbeTaskBasicConfiguration `json:"BatchTasks,omitempty" name:"BatchTasks"` + BatchTasks []*ProbeTaskBasicConfiguration `json:"BatchTasks,omitnil" name:"BatchTasks"` // 任务类型 - TaskType *int64 `json:"TaskType,omitempty" name:"TaskType"` + TaskType *int64 `json:"TaskType,omitnil" name:"TaskType"` // 拨测节点 - Nodes []*string `json:"Nodes,omitempty" name:"Nodes"` + Nodes []*string `json:"Nodes,omitnil" name:"Nodes"` // 拨测间隔 - Interval *int64 `json:"Interval,omitempty" name:"Interval"` + Interval *int64 `json:"Interval,omitnil" name:"Interval"` // 拨测参数 - Parameters *string `json:"Parameters,omitempty" name:"Parameters"` + Parameters *string `json:"Parameters,omitnil" name:"Parameters"` // 任务分类 //
  • 1 = PC
  • //
  • 2 = Mobile
  • - TaskCategory *int64 `json:"TaskCategory,omitempty" name:"TaskCategory"` + TaskCategory *int64 `json:"TaskCategory,omitnil" name:"TaskCategory"` // 定时任务cron表达式 - Cron *string `json:"Cron,omitempty" name:"Cron"` + Cron *string `json:"Cron,omitnil" name:"Cron"` // 资源标签值 - Tag []*Tag `json:"Tag,omitempty" name:"Tag"` + Tag []*Tag `json:"Tag,omitnil" name:"Tag"` // 测试类型,包含定时测试与即时测试 - ProbeType *uint64 `json:"ProbeType,omitempty" name:"ProbeType"` + ProbeType *uint64 `json:"ProbeType,omitnil" name:"ProbeType"` // 插件类型 - PluginSource *string `json:"PluginSource,omitempty" name:"PluginSource"` + PluginSource *string `json:"PluginSource,omitnil" name:"PluginSource"` // 客户端ID - ClientNum *string `json:"ClientNum,omitempty" name:"ClientNum"` + ClientNum *string `json:"ClientNum,omitnil" name:"ClientNum"` } type CreateProbeTasksRequest struct { *tchttp.BaseRequest // 批量任务名-地址 - BatchTasks []*ProbeTaskBasicConfiguration `json:"BatchTasks,omitempty" name:"BatchTasks"` + BatchTasks []*ProbeTaskBasicConfiguration `json:"BatchTasks,omitnil" name:"BatchTasks"` // 任务类型 - TaskType *int64 `json:"TaskType,omitempty" name:"TaskType"` + TaskType *int64 `json:"TaskType,omitnil" name:"TaskType"` // 拨测节点 - Nodes []*string `json:"Nodes,omitempty" name:"Nodes"` + Nodes []*string `json:"Nodes,omitnil" name:"Nodes"` // 拨测间隔 - Interval *int64 `json:"Interval,omitempty" name:"Interval"` + Interval *int64 `json:"Interval,omitnil" name:"Interval"` // 拨测参数 - Parameters *string `json:"Parameters,omitempty" name:"Parameters"` + Parameters *string `json:"Parameters,omitnil" name:"Parameters"` // 任务分类 //
  • 1 = PC
  • //
  • 2 = Mobile
  • - TaskCategory *int64 `json:"TaskCategory,omitempty" name:"TaskCategory"` + TaskCategory *int64 `json:"TaskCategory,omitnil" name:"TaskCategory"` // 定时任务cron表达式 - Cron *string `json:"Cron,omitempty" name:"Cron"` + Cron *string `json:"Cron,omitnil" name:"Cron"` // 资源标签值 - Tag []*Tag `json:"Tag,omitempty" name:"Tag"` + Tag []*Tag `json:"Tag,omitnil" name:"Tag"` // 测试类型,包含定时测试与即时测试 - ProbeType *uint64 `json:"ProbeType,omitempty" name:"ProbeType"` + ProbeType *uint64 `json:"ProbeType,omitnil" name:"ProbeType"` // 插件类型 - PluginSource *string `json:"PluginSource,omitempty" name:"PluginSource"` + PluginSource *string `json:"PluginSource,omitnil" name:"PluginSource"` // 客户端ID - ClientNum *string `json:"ClientNum,omitempty" name:"ClientNum"` + ClientNum *string `json:"ClientNum,omitnil" name:"ClientNum"` } func (r *CreateProbeTasksRequest) ToJsonString() string { @@ -129,10 +129,10 @@ func (r *CreateProbeTasksRequest) FromJsonString(s string) error { // Predefined struct for user type CreateProbeTasksResponseParams struct { // 任务ID列表 - TaskIDs []*string `json:"TaskIDs,omitempty" name:"TaskIDs"` + TaskIDs []*string `json:"TaskIDs,omitnil" name:"TaskIDs"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type CreateProbeTasksResponse struct { @@ -154,14 +154,14 @@ func (r *CreateProbeTasksResponse) FromJsonString(s string) error { // Predefined struct for user type DeleteProbeTaskRequestParams struct { // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` } type DeleteProbeTaskRequest struct { *tchttp.BaseRequest // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` } func (r *DeleteProbeTaskRequest) ToJsonString() string { @@ -186,18 +186,18 @@ func (r *DeleteProbeTaskRequest) FromJsonString(s string) error { // Predefined struct for user type DeleteProbeTaskResponseParams struct { // 任务总量 - Total *int64 `json:"Total,omitempty" name:"Total"` + Total *int64 `json:"Total,omitnil" name:"Total"` // 任务成功量 // 注意:此字段可能返回 null,表示取不到有效值。 - SuccessCount *int64 `json:"SuccessCount,omitempty" name:"SuccessCount"` + SuccessCount *int64 `json:"SuccessCount,omitnil" name:"SuccessCount"` // 任务执行结果 // 注意:此字段可能返回 null,表示取不到有效值。 - Results []*TaskResult `json:"Results,omitempty" name:"Results"` + Results []*TaskResult `json:"Results,omitnil" name:"Results"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type DeleteProbeTaskResponse struct { @@ -219,10 +219,10 @@ func (r *DeleteProbeTaskResponse) FromJsonString(s string) error { // Predefined struct for user type DescribeDetailedSingleProbeDataRequestParams struct { // 开始时间戳(毫秒级) - BeginTime *uint64 `json:"BeginTime,omitempty" name:"BeginTime"` + BeginTime *uint64 `json:"BeginTime,omitnil" name:"BeginTime"` // 结束时间戳(毫秒级) - EndTime *uint64 `json:"EndTime,omitempty" name:"EndTime"` + EndTime *uint64 `json:"EndTime,omitnil" name:"EndTime"` // 任务类型 // AnalyzeTaskType_Network:网络质量 @@ -230,27 +230,27 @@ type DescribeDetailedSingleProbeDataRequestParams struct { // AnalyzeTaskType_UploadDownload:文件传输(含文件上传、文件下载) // AnalyzeTaskType_Transport:端口性能 // AnalyzeTaskType_MediaStream:音视频体验 - TaskType *string `json:"TaskType,omitempty" name:"TaskType"` + TaskType *string `json:"TaskType,omitnil" name:"TaskType"` // 待排序字段 // 可以填写 ProbeTime 拨测时间排序 // 也可填写SelectedFields 中的选中字段 - SortField *string `json:"SortField,omitempty" name:"SortField"` + SortField *string `json:"SortField,omitnil" name:"SortField"` // true表示升序 - Ascending *bool `json:"Ascending,omitempty" name:"Ascending"` + Ascending *bool `json:"Ascending,omitnil" name:"Ascending"` // 选中字段 - SelectedFields []*string `json:"SelectedFields,omitempty" name:"SelectedFields"` + SelectedFields []*string `json:"SelectedFields,omitnil" name:"SelectedFields"` // 起始取数位置 - Offset *int64 `json:"Offset,omitempty" name:"Offset"` + Offset *int64 `json:"Offset,omitnil" name:"Offset"` // 取数数量 - Limit *int64 `json:"Limit,omitempty" name:"Limit"` + Limit *int64 `json:"Limit,omitnil" name:"Limit"` // 任务ID - TaskID []*string `json:"TaskID,omitempty" name:"TaskID"` + TaskID []*string `json:"TaskID,omitnil" name:"TaskID"` // 拨测点运营商 // @@ -259,7 +259,7 @@ type DescribeDetailedSingleProbeDataRequestParams struct { // 电信:中国电信 // 移动:中国移动 // 联通:中国联通 - Operators []*string `json:"Operators,omitempty" name:"Operators"` + Operators []*string `json:"Operators,omitnil" name:"Operators"` // 拨测点地区 // @@ -268,10 +268,10 @@ type DescribeDetailedSingleProbeDataRequestParams struct { // 国内一般是省级单位,如广东、广西、中国香港、新疆;直辖市则填北京、上海 // // 境外一般是国家名,如澳大利亚、新加坡 - Districts []*string `json:"Districts,omitempty" name:"Districts"` + Districts []*string `json:"Districts,omitnil" name:"Districts"` // 错误类型 - ErrorTypes []*string `json:"ErrorTypes,omitempty" name:"ErrorTypes"` + ErrorTypes []*string `json:"ErrorTypes,omitnil" name:"ErrorTypes"` // 城市 // 这里实际按拨测结果中的城市来填写即可 @@ -282,17 +282,17 @@ type DescribeDetailedSingleProbeDataRequestParams struct { // 武汉市 // 首尔 // 多伦多 - City []*string `json:"City,omitempty" name:"City"` + City []*string `json:"City,omitnil" name:"City"` } type DescribeDetailedSingleProbeDataRequest struct { *tchttp.BaseRequest // 开始时间戳(毫秒级) - BeginTime *uint64 `json:"BeginTime,omitempty" name:"BeginTime"` + BeginTime *uint64 `json:"BeginTime,omitnil" name:"BeginTime"` // 结束时间戳(毫秒级) - EndTime *uint64 `json:"EndTime,omitempty" name:"EndTime"` + EndTime *uint64 `json:"EndTime,omitnil" name:"EndTime"` // 任务类型 // AnalyzeTaskType_Network:网络质量 @@ -300,27 +300,27 @@ type DescribeDetailedSingleProbeDataRequest struct { // AnalyzeTaskType_UploadDownload:文件传输(含文件上传、文件下载) // AnalyzeTaskType_Transport:端口性能 // AnalyzeTaskType_MediaStream:音视频体验 - TaskType *string `json:"TaskType,omitempty" name:"TaskType"` + TaskType *string `json:"TaskType,omitnil" name:"TaskType"` // 待排序字段 // 可以填写 ProbeTime 拨测时间排序 // 也可填写SelectedFields 中的选中字段 - SortField *string `json:"SortField,omitempty" name:"SortField"` + SortField *string `json:"SortField,omitnil" name:"SortField"` // true表示升序 - Ascending *bool `json:"Ascending,omitempty" name:"Ascending"` + Ascending *bool `json:"Ascending,omitnil" name:"Ascending"` // 选中字段 - SelectedFields []*string `json:"SelectedFields,omitempty" name:"SelectedFields"` + SelectedFields []*string `json:"SelectedFields,omitnil" name:"SelectedFields"` // 起始取数位置 - Offset *int64 `json:"Offset,omitempty" name:"Offset"` + Offset *int64 `json:"Offset,omitnil" name:"Offset"` // 取数数量 - Limit *int64 `json:"Limit,omitempty" name:"Limit"` + Limit *int64 `json:"Limit,omitnil" name:"Limit"` // 任务ID - TaskID []*string `json:"TaskID,omitempty" name:"TaskID"` + TaskID []*string `json:"TaskID,omitnil" name:"TaskID"` // 拨测点运营商 // @@ -329,7 +329,7 @@ type DescribeDetailedSingleProbeDataRequest struct { // 电信:中国电信 // 移动:中国移动 // 联通:中国联通 - Operators []*string `json:"Operators,omitempty" name:"Operators"` + Operators []*string `json:"Operators,omitnil" name:"Operators"` // 拨测点地区 // @@ -338,10 +338,10 @@ type DescribeDetailedSingleProbeDataRequest struct { // 国内一般是省级单位,如广东、广西、中国香港、新疆;直辖市则填北京、上海 // // 境外一般是国家名,如澳大利亚、新加坡 - Districts []*string `json:"Districts,omitempty" name:"Districts"` + Districts []*string `json:"Districts,omitnil" name:"Districts"` // 错误类型 - ErrorTypes []*string `json:"ErrorTypes,omitempty" name:"ErrorTypes"` + ErrorTypes []*string `json:"ErrorTypes,omitnil" name:"ErrorTypes"` // 城市 // 这里实际按拨测结果中的城市来填写即可 @@ -352,7 +352,7 @@ type DescribeDetailedSingleProbeDataRequest struct { // 武汉市 // 首尔 // 多伦多 - City []*string `json:"City,omitempty" name:"City"` + City []*string `json:"City,omitnil" name:"City"` } func (r *DescribeDetailedSingleProbeDataRequest) ToJsonString() string { @@ -389,13 +389,13 @@ func (r *DescribeDetailedSingleProbeDataRequest) FromJsonString(s string) error // Predefined struct for user type DescribeDetailedSingleProbeDataResponseParams struct { // 单次详情数据 - DataSet []*DetailedSingleDataDefine `json:"DataSet,omitempty" name:"DataSet"` + DataSet []*DetailedSingleDataDefine `json:"DataSet,omitnil" name:"DataSet"` // 符合条件的数据总数 - TotalNumber *int64 `json:"TotalNumber,omitempty" name:"TotalNumber"` + TotalNumber *int64 `json:"TotalNumber,omitnil" name:"TotalNumber"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type DescribeDetailedSingleProbeDataResponse struct { @@ -420,24 +420,24 @@ type DescribeNodesRequestParams struct { //
  • 1 = IDC
  • //
  • 2 = LastMile
  • //
  • 3 = Mobile
  • - NodeType *int64 `json:"NodeType,omitempty" name:"NodeType"` + NodeType *int64 `json:"NodeType,omitnil" name:"NodeType"` // 节点区域 //
  • 1 = 中国大陆
  • //
  • 2 = 港澳台
  • //
  • 3 = 境外
  • - Location *int64 `json:"Location,omitempty" name:"Location"` + Location *int64 `json:"Location,omitnil" name:"Location"` // 是否IPv6 - IsIPv6 *bool `json:"IsIPv6,omitempty" name:"IsIPv6"` + IsIPv6 *bool `json:"IsIPv6,omitnil" name:"IsIPv6"` // 名字模糊搜索 - NodeName *string `json:"NodeName,omitempty" name:"NodeName"` + NodeName *string `json:"NodeName,omitnil" name:"NodeName"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` // 任务类型 //
  • 1 = 页面性能
  • @@ -446,7 +446,7 @@ type DescribeNodesRequestParams struct { //
  • 4 = 端口性能
  • //
  • 5 = 网络质量
  • //
  • 6 = 音视频体验
  • - TaskType *int64 `json:"TaskType,omitempty" name:"TaskType"` + TaskType *int64 `json:"TaskType,omitnil" name:"TaskType"` } type DescribeNodesRequest struct { @@ -456,24 +456,24 @@ type DescribeNodesRequest struct { //
  • 1 = IDC
  • //
  • 2 = LastMile
  • //
  • 3 = Mobile
  • - NodeType *int64 `json:"NodeType,omitempty" name:"NodeType"` + NodeType *int64 `json:"NodeType,omitnil" name:"NodeType"` // 节点区域 //
  • 1 = 中国大陆
  • //
  • 2 = 港澳台
  • //
  • 3 = 境外
  • - Location *int64 `json:"Location,omitempty" name:"Location"` + Location *int64 `json:"Location,omitnil" name:"Location"` // 是否IPv6 - IsIPv6 *bool `json:"IsIPv6,omitempty" name:"IsIPv6"` + IsIPv6 *bool `json:"IsIPv6,omitnil" name:"IsIPv6"` // 名字模糊搜索 - NodeName *string `json:"NodeName,omitempty" name:"NodeName"` + NodeName *string `json:"NodeName,omitnil" name:"NodeName"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` // 任务类型 //
  • 1 = 页面性能
  • @@ -482,7 +482,7 @@ type DescribeNodesRequest struct { //
  • 4 = 端口性能
  • //
  • 5 = 网络质量
  • //
  • 6 = 音视频体验
  • - TaskType *int64 `json:"TaskType,omitempty" name:"TaskType"` + TaskType *int64 `json:"TaskType,omitnil" name:"TaskType"` } func (r *DescribeNodesRequest) ToJsonString() string { @@ -513,10 +513,10 @@ func (r *DescribeNodesRequest) FromJsonString(s string) error { type DescribeNodesResponseParams struct { // 节点列表 // 注意:此字段可能返回 null,表示取不到有效值。 - NodeSet []*NodeDefineExt `json:"NodeSet,omitempty" name:"NodeSet"` + NodeSet []*NodeDefineExt `json:"NodeSet,omitnil" name:"NodeSet"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type DescribeNodesResponse struct { @@ -543,23 +543,23 @@ type DescribeProbeMetricDataRequestParams struct { // AnalyzeTaskType_Transport:端口性能 // AnalyzeTaskType_UploadDownload:文件传输 // AnalyzeTaskType_MediaStream:音视频体验 - AnalyzeTaskType *string `json:"AnalyzeTaskType,omitempty" name:"AnalyzeTaskType"` + AnalyzeTaskType *string `json:"AnalyzeTaskType,omitnil" name:"AnalyzeTaskType"` // 指标类型,指标查询默认传gauge - MetricType *string `json:"MetricType,omitempty" name:"MetricType"` + MetricType *string `json:"MetricType,omitnil" name:"MetricType"` // 指标详细字段,可以传递传具体的指标也可以对指标进行聚合查询例如:"avg(ping_time)"代表整体时延(ms) - Field *string `json:"Field,omitempty" name:"Field"` + Field *string `json:"Field,omitnil" name:"Field"` // 过滤条件可以传单个过滤条件也可以拼接多个参数 - Filter *string `json:"Filter,omitempty" name:"Filter"` + Filter *string `json:"Filter,omitnil" name:"Filter"` // 聚合时间, 1m、1d、30d 等等 - GroupBy *string `json:"GroupBy,omitempty" name:"GroupBy"` + GroupBy *string `json:"GroupBy,omitnil" name:"GroupBy"` // 多条件过滤,支持多个过滤条件组合查询 // 例如:[""host" = 'www.test.com'", "time >= now()-1h"] - Filters []*string `json:"Filters,omitempty" name:"Filters"` + Filters []*string `json:"Filters,omitnil" name:"Filters"` } type DescribeProbeMetricDataRequest struct { @@ -571,23 +571,23 @@ type DescribeProbeMetricDataRequest struct { // AnalyzeTaskType_Transport:端口性能 // AnalyzeTaskType_UploadDownload:文件传输 // AnalyzeTaskType_MediaStream:音视频体验 - AnalyzeTaskType *string `json:"AnalyzeTaskType,omitempty" name:"AnalyzeTaskType"` + AnalyzeTaskType *string `json:"AnalyzeTaskType,omitnil" name:"AnalyzeTaskType"` // 指标类型,指标查询默认传gauge - MetricType *string `json:"MetricType,omitempty" name:"MetricType"` + MetricType *string `json:"MetricType,omitnil" name:"MetricType"` // 指标详细字段,可以传递传具体的指标也可以对指标进行聚合查询例如:"avg(ping_time)"代表整体时延(ms) - Field *string `json:"Field,omitempty" name:"Field"` + Field *string `json:"Field,omitnil" name:"Field"` // 过滤条件可以传单个过滤条件也可以拼接多个参数 - Filter *string `json:"Filter,omitempty" name:"Filter"` + Filter *string `json:"Filter,omitnil" name:"Filter"` // 聚合时间, 1m、1d、30d 等等 - GroupBy *string `json:"GroupBy,omitempty" name:"GroupBy"` + GroupBy *string `json:"GroupBy,omitnil" name:"GroupBy"` // 多条件过滤,支持多个过滤条件组合查询 // 例如:[""host" = 'www.test.com'", "time >= now()-1h"] - Filters []*string `json:"Filters,omitempty" name:"Filters"` + Filters []*string `json:"Filters,omitnil" name:"Filters"` } func (r *DescribeProbeMetricDataRequest) ToJsonString() string { @@ -618,10 +618,10 @@ func (r *DescribeProbeMetricDataRequest) FromJsonString(s string) error { type DescribeProbeMetricDataResponseParams struct { // 返回指标 JSON 序列化后的字符串,具体如下所示: // "[{\"name\":\"task_navigate_request_gauge\",\"columns\":[\"time\",\"avg(first_screen_time) / 1000\"],\"values\":[[1641571200,6.756600000000001]],\"tags\":null}]" - MetricSet *string `json:"MetricSet,omitempty" name:"MetricSet"` + MetricSet *string `json:"MetricSet,omitnil" name:"MetricSet"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type DescribeProbeMetricDataResponse struct { @@ -646,24 +646,24 @@ type DescribeProbeNodesRequestParams struct { //
  • 1 = IDC
  • //
  • 2 = LastMile
  • //
  • 3 = Mobile
  • - NodeType *int64 `json:"NodeType,omitempty" name:"NodeType"` + NodeType *int64 `json:"NodeType,omitnil" name:"NodeType"` // 节点区域 //
  • 1 = 中国大陆
  • //
  • 2 = 港澳台
  • //
  • 3 = 海外
  • - Location *int64 `json:"Location,omitempty" name:"Location"` + Location *int64 `json:"Location,omitnil" name:"Location"` // 是否IPv6 - IsIPv6 *bool `json:"IsIPv6,omitempty" name:"IsIPv6"` + IsIPv6 *bool `json:"IsIPv6,omitnil" name:"IsIPv6"` // 名字模糊搜索 - NodeName *string `json:"NodeName,omitempty" name:"NodeName"` + NodeName *string `json:"NodeName,omitnil" name:"NodeName"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` } type DescribeProbeNodesRequest struct { @@ -673,24 +673,24 @@ type DescribeProbeNodesRequest struct { //
  • 1 = IDC
  • //
  • 2 = LastMile
  • //
  • 3 = Mobile
  • - NodeType *int64 `json:"NodeType,omitempty" name:"NodeType"` + NodeType *int64 `json:"NodeType,omitnil" name:"NodeType"` // 节点区域 //
  • 1 = 中国大陆
  • //
  • 2 = 港澳台
  • //
  • 3 = 海外
  • - Location *int64 `json:"Location,omitempty" name:"Location"` + Location *int64 `json:"Location,omitnil" name:"Location"` // 是否IPv6 - IsIPv6 *bool `json:"IsIPv6,omitempty" name:"IsIPv6"` + IsIPv6 *bool `json:"IsIPv6,omitnil" name:"IsIPv6"` // 名字模糊搜索 - NodeName *string `json:"NodeName,omitempty" name:"NodeName"` + NodeName *string `json:"NodeName,omitnil" name:"NodeName"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` } func (r *DescribeProbeNodesRequest) ToJsonString() string { @@ -720,10 +720,10 @@ func (r *DescribeProbeNodesRequest) FromJsonString(s string) error { type DescribeProbeNodesResponseParams struct { // 节点列表 // 注意:此字段可能返回 null,表示取不到有效值。 - NodeSet []*NodeDefine `json:"NodeSet,omitempty" name:"NodeSet"` + NodeSet []*NodeDefine `json:"NodeSet,omitnil" name:"NodeSet"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type DescribeProbeNodesResponse struct { @@ -745,13 +745,13 @@ func (r *DescribeProbeNodesResponse) FromJsonString(s string) error { // Predefined struct for user type DescribeProbeTasksRequestParams struct { // 任务 ID 列表 - TaskIDs []*string `json:"TaskIDs,omitempty" name:"TaskIDs"` + TaskIDs []*string `json:"TaskIDs,omitnil" name:"TaskIDs"` // 任务名 - TaskName *string `json:"TaskName,omitempty" name:"TaskName"` + TaskName *string `json:"TaskName,omitnil" name:"TaskName"` // 拨测目标 - TargetAddress *string `json:"TargetAddress,omitempty" name:"TargetAddress"` + TargetAddress *string `json:"TargetAddress,omitnil" name:"TargetAddress"` // 任务状态列表 //
  • 1 = 创建中
  • @@ -764,23 +764,23 @@ type DescribeProbeTasksRequestParams struct { //
  • 8 = 任务删除异常
  • //
  • 9 = 任务删除
  • //
  • 10 = 定时任务暂停中
  • - TaskStatus []*int64 `json:"TaskStatus,omitempty" name:"TaskStatus"` + TaskStatus []*int64 `json:"TaskStatus,omitnil" name:"TaskStatus"` // 偏移量,默认为0 - Offset *int64 `json:"Offset,omitempty" name:"Offset"` + Offset *int64 `json:"Offset,omitnil" name:"Offset"` // 返回数量,默认为20,最大值为100 - Limit *int64 `json:"Limit,omitempty" name:"Limit"` + Limit *int64 `json:"Limit,omitnil" name:"Limit"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` // 订单状态 //
  • 1 = 正常
  • //
  • 2 = 欠费
  • - OrderState *int64 `json:"OrderState,omitempty" name:"OrderState"` + OrderState *int64 `json:"OrderState,omitnil" name:"OrderState"` // 拨测类型 //
  • 1 = 页面浏览
  • @@ -791,32 +791,32 @@ type DescribeProbeTasksRequestParams struct { //
  • 6 =流媒体
  • // // 即使拨测只支持页面浏览,网络质量,文件下载 - TaskType []*int64 `json:"TaskType,omitempty" name:"TaskType"` + TaskType []*int64 `json:"TaskType,omitnil" name:"TaskType"` // 节点类型 - TaskCategory []*int64 `json:"TaskCategory,omitempty" name:"TaskCategory"` + TaskCategory []*int64 `json:"TaskCategory,omitnil" name:"TaskCategory"` // 排序的列 - OrderBy *string `json:"OrderBy,omitempty" name:"OrderBy"` + OrderBy *string `json:"OrderBy,omitnil" name:"OrderBy"` // 是否正序 - Ascend *bool `json:"Ascend,omitempty" name:"Ascend"` + Ascend *bool `json:"Ascend,omitnil" name:"Ascend"` // 资源标签值 - TagFilters []*KeyValuePair `json:"TagFilters,omitempty" name:"TagFilters"` + TagFilters []*KeyValuePair `json:"TagFilters,omitnil" name:"TagFilters"` } type DescribeProbeTasksRequest struct { *tchttp.BaseRequest // 任务 ID 列表 - TaskIDs []*string `json:"TaskIDs,omitempty" name:"TaskIDs"` + TaskIDs []*string `json:"TaskIDs,omitnil" name:"TaskIDs"` // 任务名 - TaskName *string `json:"TaskName,omitempty" name:"TaskName"` + TaskName *string `json:"TaskName,omitnil" name:"TaskName"` // 拨测目标 - TargetAddress *string `json:"TargetAddress,omitempty" name:"TargetAddress"` + TargetAddress *string `json:"TargetAddress,omitnil" name:"TargetAddress"` // 任务状态列表 //
  • 1 = 创建中
  • @@ -829,23 +829,23 @@ type DescribeProbeTasksRequest struct { //
  • 8 = 任务删除异常
  • //
  • 9 = 任务删除
  • //
  • 10 = 定时任务暂停中
  • - TaskStatus []*int64 `json:"TaskStatus,omitempty" name:"TaskStatus"` + TaskStatus []*int64 `json:"TaskStatus,omitnil" name:"TaskStatus"` // 偏移量,默认为0 - Offset *int64 `json:"Offset,omitempty" name:"Offset"` + Offset *int64 `json:"Offset,omitnil" name:"Offset"` // 返回数量,默认为20,最大值为100 - Limit *int64 `json:"Limit,omitempty" name:"Limit"` + Limit *int64 `json:"Limit,omitnil" name:"Limit"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` // 订单状态 //
  • 1 = 正常
  • //
  • 2 = 欠费
  • - OrderState *int64 `json:"OrderState,omitempty" name:"OrderState"` + OrderState *int64 `json:"OrderState,omitnil" name:"OrderState"` // 拨测类型 //
  • 1 = 页面浏览
  • @@ -856,19 +856,19 @@ type DescribeProbeTasksRequest struct { //
  • 6 =流媒体
  • // // 即使拨测只支持页面浏览,网络质量,文件下载 - TaskType []*int64 `json:"TaskType,omitempty" name:"TaskType"` + TaskType []*int64 `json:"TaskType,omitnil" name:"TaskType"` // 节点类型 - TaskCategory []*int64 `json:"TaskCategory,omitempty" name:"TaskCategory"` + TaskCategory []*int64 `json:"TaskCategory,omitnil" name:"TaskCategory"` // 排序的列 - OrderBy *string `json:"OrderBy,omitempty" name:"OrderBy"` + OrderBy *string `json:"OrderBy,omitnil" name:"OrderBy"` // 是否正序 - Ascend *bool `json:"Ascend,omitempty" name:"Ascend"` + Ascend *bool `json:"Ascend,omitnil" name:"Ascend"` // 资源标签值 - TagFilters []*KeyValuePair `json:"TagFilters,omitempty" name:"TagFilters"` + TagFilters []*KeyValuePair `json:"TagFilters,omitnil" name:"TagFilters"` } func (r *DescribeProbeTasksRequest) ToJsonString() string { @@ -906,13 +906,13 @@ func (r *DescribeProbeTasksRequest) FromJsonString(s string) error { type DescribeProbeTasksResponseParams struct { // 任务列表 // 注意:此字段可能返回 null,表示取不到有效值。 - TaskSet []*ProbeTask `json:"TaskSet,omitempty" name:"TaskSet"` + TaskSet []*ProbeTask `json:"TaskSet,omitnil" name:"TaskSet"` // 任务总数 - Total *int64 `json:"Total,omitempty" name:"Total"` + Total *int64 `json:"Total,omitnil" name:"Total"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type DescribeProbeTasksResponse struct { @@ -933,209 +933,229 @@ func (r *DescribeProbeTasksResponse) FromJsonString(s string) error { type DetailedSingleDataDefine struct { // 拨测时间戳 - ProbeTime *uint64 `json:"ProbeTime,omitempty" name:"ProbeTime"` + ProbeTime *uint64 `json:"ProbeTime,omitnil" name:"ProbeTime"` // 储存所有string类型字段 - Labels []*Label `json:"Labels,omitempty" name:"Labels"` + Labels []*Label `json:"Labels,omitnil" name:"Labels"` // 储存所有float类型字段 - Fields []*Field `json:"Fields,omitempty" name:"Fields"` + Fields []*Field `json:"Fields,omitnil" name:"Fields"` } type Field struct { // 自定义字段编号 - ID *uint64 `json:"ID,omitempty" name:"ID"` + ID *uint64 `json:"ID,omitnil" name:"ID"` // 自定义字段名称/说明 - Name *string `json:"Name,omitempty" name:"Name"` + Name *string `json:"Name,omitnil" name:"Name"` // 字段值 - Value *float64 `json:"Value,omitempty" name:"Value"` + Value *float64 `json:"Value,omitnil" name:"Value"` } type KeyValuePair struct { // 健 - Key *string `json:"Key,omitempty" name:"Key"` + Key *string `json:"Key,omitnil" name:"Key"` // 值 - Value *string `json:"Value,omitempty" name:"Value"` + Value *string `json:"Value,omitnil" name:"Value"` } type Label struct { // 自定义字段编号 - ID *uint64 `json:"ID,omitempty" name:"ID"` + ID *uint64 `json:"ID,omitnil" name:"ID"` // 自定义字段名称/说明 - Name *string `json:"Name,omitempty" name:"Name"` + Name *string `json:"Name,omitnil" name:"Name"` // 字段值 - Value *string `json:"Value,omitempty" name:"Value"` + Value *string `json:"Value,omitnil" name:"Value"` } type NodeDefine struct { // 节点名称 - Name *string `json:"Name,omitempty" name:"Name"` + Name *string `json:"Name,omitnil" name:"Name"` // 节点代码 - Code *string `json:"Code,omitempty" name:"Code"` + Code *string `json:"Code,omitnil" name:"Code"` // 节点类型 //
  • 1 = IDC
  • //
  • 2 = LastMile
  • //
  • 3 = Mobile
  • - Type *int64 `json:"Type,omitempty" name:"Type"` + Type *int64 `json:"Type,omitnil" name:"Type"` // 网络服务商 - NetService *string `json:"NetService,omitempty" name:"NetService"` + NetService *string `json:"NetService,omitnil" name:"NetService"` // 区域 - District *string `json:"District,omitempty" name:"District"` + District *string `json:"District,omitnil" name:"District"` // 城市 - City *string `json:"City,omitempty" name:"City"` + City *string `json:"City,omitnil" name:"City"` // IP 类型 //
  • 1 = IPv4
  • //
  • 2 = IPv6
  • // 注意:此字段可能返回 null,表示取不到有效值。 - IPType *int64 `json:"IPType,omitempty" name:"IPType"` + IPType *int64 `json:"IPType,omitnil" name:"IPType"` // 区域 //
  • 1 = 中国大陆
  • //
  • 2 = 港澳台
  • //
  • 3 = 国外
  • // 注意:此字段可能返回 null,表示取不到有效值。 - Location *int64 `json:"Location,omitempty" name:"Location"` + Location *int64 `json:"Location,omitnil" name:"Location"` // 节点类型 如果为base 则为可用性拨测点,为空则为高级拨测点 // 注意:此字段可能返回 null,表示取不到有效值。 - CodeType *string `json:"CodeType,omitempty" name:"CodeType"` + CodeType *string `json:"CodeType,omitnil" name:"CodeType"` // 节点状态:1-运行,2-下线 // 注意:此字段可能返回 null,表示取不到有效值。 - NodeDefineStatus *uint64 `json:"NodeDefineStatus,omitempty" name:"NodeDefineStatus"` + NodeDefineStatus *uint64 `json:"NodeDefineStatus,omitnil" name:"NodeDefineStatus"` } type NodeDefineExt struct { // 节点名称 - Name *string `json:"Name,omitempty" name:"Name"` + Name *string `json:"Name,omitnil" name:"Name"` // 节点代码 - Code *string `json:"Code,omitempty" name:"Code"` + Code *string `json:"Code,omitnil" name:"Code"` // 节点类型 //
  • 1 = IDC
  • //
  • 2 = LastMile
  • //
  • 3 = Mobile
  • - Type *int64 `json:"Type,omitempty" name:"Type"` + Type *int64 `json:"Type,omitnil" name:"Type"` // 网络服务商 - NetService *string `json:"NetService,omitempty" name:"NetService"` + NetService *string `json:"NetService,omitnil" name:"NetService"` // 区域 - District *string `json:"District,omitempty" name:"District"` + District *string `json:"District,omitnil" name:"District"` // 城市 - City *string `json:"City,omitempty" name:"City"` + City *string `json:"City,omitnil" name:"City"` // IP 类型 //
  • 1 = IPv4
  • //
  • 2 = IPv6
  • // 注意:此字段可能返回 null,表示取不到有效值。 - IPType *int64 `json:"IPType,omitempty" name:"IPType"` + IPType *int64 `json:"IPType,omitnil" name:"IPType"` // 区域 //
  • 1 = 中国大陆
  • //
  • 2 = 港澳台
  • //
  • 3 = 境外
  • // 注意:此字段可能返回 null,表示取不到有效值。 - Location *int64 `json:"Location,omitempty" name:"Location"` + Location *int64 `json:"Location,omitnil" name:"Location"` // 节点类型 如果为base 则为可用性拨测点,为空则为高级拨测点 // 注意:此字段可能返回 null,表示取不到有效值。 - CodeType *string `json:"CodeType,omitempty" name:"CodeType"` + CodeType *string `json:"CodeType,omitnil" name:"CodeType"` // 节点支持的任务类型。1: 页面性能 2: 文件上传 3: 文件下载 4: 端口性能 5: 网络质量 6: 音视频体验 // 注意:此字段可能返回 null,表示取不到有效值。 - TaskTypes []*int64 `json:"TaskTypes,omitempty" name:"TaskTypes"` + TaskTypes []*int64 `json:"TaskTypes,omitnil" name:"TaskTypes"` } type ProbeTask struct { // 任务名 // 注意:此字段可能返回 null,表示取不到有效值。 - Name *string `json:"Name,omitempty" name:"Name"` + Name *string `json:"Name,omitnil" name:"Name"` // 任务 ID - TaskId *string `json:"TaskId,omitempty" name:"TaskId"` + TaskId *string `json:"TaskId,omitnil" name:"TaskId"` - // 任务类型 - TaskType *int64 `json:"TaskType,omitempty" name:"TaskType"` + // 拨测类型 + //
  • 1 = 页面浏览
  • + //
  • 2 =文件上传
  • + //
  • 3 = 文件下载
  • + //
  • 4 = 端口性能
  • + //
  • 5 = 网络质量
  • + //
  • 6 =流媒体
  • + // + // 即时拨测只支持页面浏览,网络质量,文件下载 + TaskType *int64 `json:"TaskType,omitnil" name:"TaskType"` // 拨测节点列表 - Nodes []*string `json:"Nodes,omitempty" name:"Nodes"` + Nodes []*string `json:"Nodes,omitnil" name:"Nodes"` // 拨测间隔 - Interval *int64 `json:"Interval,omitempty" name:"Interval"` + Interval *int64 `json:"Interval,omitnil" name:"Interval"` // 拨测参数 - Parameters *string `json:"Parameters,omitempty" name:"Parameters"` + Parameters *string `json:"Parameters,omitnil" name:"Parameters"` // 任务状态 - Status *int64 `json:"Status,omitempty" name:"Status"` + //
  • 1 = 创建中
  • + //
  • 2 = 运行中
  • + //
  • 3 = 运行异常
  • + //
  • 4 = 暂停中
  • + //
  • 5 = 暂停异常
  • + //
  • 6 = 任务暂停
  • + //
  • 7 = 任务删除中
  • + //
  • 8 = 任务删除异常
  • + //
  • 9 = 任务删除
  • + //
  • 10 = 定时任务暂停中
  • + Status *int64 `json:"Status,omitnil" name:"Status"` // 目标地址 - TargetAddress *string `json:"TargetAddress,omitempty" name:"TargetAddress"` + TargetAddress *string `json:"TargetAddress,omitnil" name:"TargetAddress"` // 付费模式 //
  • 1 = 试用版本
  • //
  • 2 = 付费版本
  • - PayMode *int64 `json:"PayMode,omitempty" name:"PayMode"` + PayMode *int64 `json:"PayMode,omitnil" name:"PayMode"` // 订单状态 //
  • 1 = 正常
  • //
  • 2 = 欠费
  • - OrderState *int64 `json:"OrderState,omitempty" name:"OrderState"` + OrderState *int64 `json:"OrderState,omitnil" name:"OrderState"` // 任务分类 //
  • 1 = PC
  • //
  • 2 = Mobile
  • - TaskCategory *int64 `json:"TaskCategory,omitempty" name:"TaskCategory"` + TaskCategory *int64 `json:"TaskCategory,omitnil" name:"TaskCategory"` // 创建时间 - CreatedAt *string `json:"CreatedAt,omitempty" name:"CreatedAt"` + CreatedAt *string `json:"CreatedAt,omitnil" name:"CreatedAt"` // 定时任务cron表达式 // 注意:此字段可能返回 null,表示取不到有效值。 - Cron *string `json:"Cron,omitempty" name:"Cron"` + Cron *string `json:"Cron,omitnil" name:"Cron"` // 定时任务启动状态 + //
  • 1 = 定时任务表达式生效
  • + //
  • 2 = 定时任务表达式未生效(一般为任务手动暂停)
  • // 注意:此字段可能返回 null,表示取不到有效值。 - CronState *int64 `json:"CronState,omitempty" name:"CronState"` + CronState *int64 `json:"CronState,omitnil" name:"CronState"` // 任务当前绑定的标签 // 注意:此字段可能返回 null,表示取不到有效值。 - TagInfoList []*KeyValuePair `json:"TagInfoList,omitempty" name:"TagInfoList"` + TagInfoList []*KeyValuePair `json:"TagInfoList,omitnil" name:"TagInfoList"` } type ProbeTaskBasicConfiguration struct { // 拨测任务名称 - Name *string `json:"Name,omitempty" name:"Name"` + Name *string `json:"Name,omitnil" name:"Name"` // 拨测目标地址 - TargetAddress *string `json:"TargetAddress,omitempty" name:"TargetAddress"` + TargetAddress *string `json:"TargetAddress,omitnil" name:"TargetAddress"` } // Predefined struct for user type ResumeProbeTaskRequestParams struct { // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` } type ResumeProbeTaskRequest struct { *tchttp.BaseRequest // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` } func (r *ResumeProbeTaskRequest) ToJsonString() string { @@ -1160,18 +1180,18 @@ func (r *ResumeProbeTaskRequest) FromJsonString(s string) error { // Predefined struct for user type ResumeProbeTaskResponseParams struct { // 任务总量 - Total *int64 `json:"Total,omitempty" name:"Total"` + Total *int64 `json:"Total,omitnil" name:"Total"` // 任务成功量 // 注意:此字段可能返回 null,表示取不到有效值。 - SuccessCount *int64 `json:"SuccessCount,omitempty" name:"SuccessCount"` + SuccessCount *int64 `json:"SuccessCount,omitnil" name:"SuccessCount"` // 任务执行详情 // 注意:此字段可能返回 null,表示取不到有效值。 - Results []*TaskResult `json:"Results,omitempty" name:"Results"` + Results []*TaskResult `json:"Results,omitnil" name:"Results"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type ResumeProbeTaskResponse struct { @@ -1193,14 +1213,14 @@ func (r *ResumeProbeTaskResponse) FromJsonString(s string) error { // Predefined struct for user type SuspendProbeTaskRequestParams struct { // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` } type SuspendProbeTaskRequest struct { *tchttp.BaseRequest // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` } func (r *SuspendProbeTaskRequest) ToJsonString() string { @@ -1225,18 +1245,18 @@ func (r *SuspendProbeTaskRequest) FromJsonString(s string) error { // Predefined struct for user type SuspendProbeTaskResponseParams struct { // 任务总量 - Total *int64 `json:"Total,omitempty" name:"Total"` + Total *int64 `json:"Total,omitnil" name:"Total"` // 任务成功量 // 注意:此字段可能返回 null,表示取不到有效值。 - SuccessCount *int64 `json:"SuccessCount,omitempty" name:"SuccessCount"` + SuccessCount *int64 `json:"SuccessCount,omitnil" name:"SuccessCount"` // 任务执行结果 // 注意:此字段可能返回 null,表示取不到有效值。 - Results []*TaskResult `json:"Results,omitempty" name:"Results"` + Results []*TaskResult `json:"Results,omitnil" name:"Results"` // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type SuspendProbeTaskResponse struct { @@ -1257,68 +1277,129 @@ func (r *SuspendProbeTaskResponse) FromJsonString(s string) error { type Tag struct { // key - TagKey *string `json:"TagKey,omitempty" name:"TagKey"` + TagKey *string `json:"TagKey,omitnil" name:"TagKey"` // value - TagValue *string `json:"TagValue,omitempty" name:"TagValue"` + TagValue *string `json:"TagValue,omitnil" name:"TagValue"` } type TaskResult struct { // 任务 ID - TaskId *string `json:"TaskId,omitempty" name:"TaskId"` + TaskId *string `json:"TaskId,omitnil" name:"TaskId"` // 是否成功 // 注意:此字段可能返回 null,表示取不到有效值。 - Success *bool `json:"Success,omitempty" name:"Success"` + Success *bool `json:"Success,omitnil" name:"Success"` // 错误信息 // 注意:此字段可能返回 null,表示取不到有效值。 - ErrorMessage *string `json:"ErrorMessage,omitempty" name:"ErrorMessage"` + ErrorMessage *string `json:"ErrorMessage,omitnil" name:"ErrorMessage"` +} + +// Predefined struct for user +type UpdateProbeTaskAttributesRequestParams struct { + // 任务 ID + TaskId *string `json:"TaskId,omitnil" name:"TaskId"` + + // 任务名 + Name *string `json:"Name,omitnil" name:"Name"` +} + +type UpdateProbeTaskAttributesRequest struct { + *tchttp.BaseRequest + + // 任务 ID + TaskId *string `json:"TaskId,omitnil" name:"TaskId"` + + // 任务名 + Name *string `json:"Name,omitnil" name:"Name"` +} + +func (r *UpdateProbeTaskAttributesRequest) 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 *UpdateProbeTaskAttributesRequest) FromJsonString(s string) error { + f := make(map[string]interface{}) + if err := json.Unmarshal([]byte(s), &f); err != nil { + return err + } + delete(f, "TaskId") + delete(f, "Name") + if len(f) > 0 { + return tcerr.NewTencentCloudSDKError("ClientError.BuildRequestError", "UpdateProbeTaskAttributesRequest has unknown keys!", "") + } + return json.Unmarshal([]byte(s), &r) +} + +// Predefined struct for user +type UpdateProbeTaskAttributesResponseParams struct { + // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` +} + +type UpdateProbeTaskAttributesResponse struct { + *tchttp.BaseResponse + Response *UpdateProbeTaskAttributesResponseParams `json:"Response"` +} + +func (r *UpdateProbeTaskAttributesResponse) 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 *UpdateProbeTaskAttributesResponse) FromJsonString(s string) error { + return json.Unmarshal([]byte(s), &r) } // Predefined struct for user type UpdateProbeTaskConfigurationListRequestParams struct { // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` // 拨测节点 - Nodes []*string `json:"Nodes,omitempty" name:"Nodes"` + Nodes []*string `json:"Nodes,omitnil" name:"Nodes"` // 拨测间隔 - Interval *int64 `json:"Interval,omitempty" name:"Interval"` + Interval *int64 `json:"Interval,omitnil" name:"Interval"` // 拨测参数 - Parameters *string `json:"Parameters,omitempty" name:"Parameters"` + Parameters *string `json:"Parameters,omitnil" name:"Parameters"` // 定时任务cron表达式 - Cron *string `json:"Cron,omitempty" name:"Cron"` + Cron *string `json:"Cron,omitnil" name:"Cron"` // 预付费套餐id // 需要与taskId对应 - ResourceIDs []*string `json:"ResourceIDs,omitempty" name:"ResourceIDs"` + ResourceIDs []*string `json:"ResourceIDs,omitnil" name:"ResourceIDs"` } type UpdateProbeTaskConfigurationListRequest struct { *tchttp.BaseRequest // 任务 ID - TaskIds []*string `json:"TaskIds,omitempty" name:"TaskIds"` + TaskIds []*string `json:"TaskIds,omitnil" name:"TaskIds"` // 拨测节点 - Nodes []*string `json:"Nodes,omitempty" name:"Nodes"` + Nodes []*string `json:"Nodes,omitnil" name:"Nodes"` // 拨测间隔 - Interval *int64 `json:"Interval,omitempty" name:"Interval"` + Interval *int64 `json:"Interval,omitnil" name:"Interval"` // 拨测参数 - Parameters *string `json:"Parameters,omitempty" name:"Parameters"` + Parameters *string `json:"Parameters,omitnil" name:"Parameters"` // 定时任务cron表达式 - Cron *string `json:"Cron,omitempty" name:"Cron"` + Cron *string `json:"Cron,omitnil" name:"Cron"` // 预付费套餐id // 需要与taskId对应 - ResourceIDs []*string `json:"ResourceIDs,omitempty" name:"ResourceIDs"` + ResourceIDs []*string `json:"ResourceIDs,omitnil" name:"ResourceIDs"` } func (r *UpdateProbeTaskConfigurationListRequest) ToJsonString() string { @@ -1348,7 +1429,7 @@ func (r *UpdateProbeTaskConfigurationListRequest) FromJsonString(s string) error // Predefined struct for user type UpdateProbeTaskConfigurationListResponseParams struct { // 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 - RequestId *string `json:"RequestId,omitempty" name:"RequestId"` + RequestId *string `json:"RequestId,omitnil" name:"RequestId"` } type UpdateProbeTaskConfigurationListResponse struct { 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 c68073ddb2..2be7d85400 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.759" + params["RequestClient"] = "SDK_GO_1.0.760" if requestClient != "" { params["RequestClient"] += ": " + requestClient } diff --git a/vendor/modules.txt b/vendor/modules.txt index f7695c6c49..a32e7e7783 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -1058,7 +1058,7 @@ github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/as/v20180419 # github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam v1.0.409 ## explicit; go 1.14 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam/v20190116 -# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.520 +# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat v1.0.760 ## explicit; go 1.14 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cat/v20180409 # github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cbs v1.0.591 @@ -1097,7 +1097,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.759 +# github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.760 ## explicit; go 1.14 github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/errors diff --git a/website/docs/d/cat_metric_data.html.markdown b/website/docs/d/cat_metric_data.html.markdown new file mode 100644 index 0000000000..de70a2cb80 --- /dev/null +++ b/website/docs/d/cat_metric_data.html.markdown @@ -0,0 +1,46 @@ +--- +subcategory: "Cloud Automated Testing(CAT)" +layout: "tencentcloud" +page_title: "TencentCloud: tencentcloud_cat_metric_data" +sidebar_current: "docs-tencentcloud-datasource-cat_metric_data" +description: |- + Use this data source to query detailed information of cat metric_data +--- + +# tencentcloud_cat_metric_data + +Use this data source to query detailed information of cat metric_data + +## Example Usage + +```hcl +data "tencentcloud_cat_metric_data" "metric_data" { + analyze_task_type = "AnalyzeTaskType_Network" + metric_type = "gauge" + field = "avg(\"ping_time\")" + filters = [ + "\"host\" = 'www.qq.com'", + "time >= now()-1h", + ] +} +``` + +## Argument Reference + +The following arguments are supported: + +* `analyze_task_type` - (Required, String) Analysis of task type, supported types: `AnalyzeTaskType_Network`: network quality, `AnalyzeTaskType_Browse`: page performance, `AnalyzeTaskType_Transport`: port performance, `AnalyzeTaskType_UploadDownload`: file transport, `AnalyzeTaskType_MediaStream`: audiovisual experience. +* `field` - (Required, String) Detailed fields of metrics, specified metrics can be passed or aggregate metrics, such as avg(ping_time) means entire delay. +* `filters` - (Required, Set: [`String`]) Multiple condition filtering, supports combining multiple filtering conditions for query. +* `metric_type` - (Required, String) Metric type, metrics queries are passed with gauge by default. +* `filter` - (Optional, String) Filter conditions can be passed as a single filter or multiple parameters concatenated together. +* `group_by` - (Optional, String) Aggregation time, such as 1m, 1d, 30d, and so on. +* `result_output_file` - (Optional, String) Used to save results. + +## Attributes Reference + +In addition to all arguments above, the following attributes are exported: + +* `metric_set` - Return JSON string. + + diff --git a/website/docs/d/cat_node.html.markdown b/website/docs/d/cat_node.html.markdown index bef719dd7b..9191e39335 100644 --- a/website/docs/d/cat_node.html.markdown +++ b/website/docs/d/cat_node.html.markdown @@ -46,6 +46,7 @@ In addition to all arguments above, the following attributes are exported: * `name` - Node name. * `net_service` - Network service provider. * `node_define_status` - Node status: 1=running, 2=offline. + * `task_types` - The task types supported by the node. `1`: page performance, `2`: file upload, `3`: file download, `4`: port performance, `5`: network quality, `6`: audio and video experience. * `type` - Node Type;1 = IDC,2 = LastMile,3 = Mobile. diff --git a/website/docs/r/cat_task_set.html.markdown b/website/docs/r/cat_task_set.html.markdown index cfc2e5d05d..ea5b75bc6e 100644 --- a/website/docs/r/cat_task_set.html.markdown +++ b/website/docs/r/cat_task_set.html.markdown @@ -67,6 +67,7 @@ The following arguments are supported: * `task_category` - (Required, Int) Task category,1:PC,2:Mobile. * `task_type` - (Required, Int) Task Type 1:Page Performance, 2:File upload,3:File Download,4:Port performance 5:Audio and video. * `cron` - (Optional, String) Timer task cron expression. +* `operate` - (Optional, String) The input is valid when the parameter is modified, `suspend`/`resume`, used to suspend/resume the dial test task. * `tags` - (Optional, Map) Tag description list. The `batch_tasks` object supports the following: diff --git a/website/tencentcloud.erb b/website/tencentcloud.erb index ebefc79b2e..78ce9eee09 100644 --- a/website/tencentcloud.erb +++ b/website/tencentcloud.erb @@ -587,6 +587,9 @@
  • Data Sources