diff --git a/.apigentools-info b/.apigentools-info index bb6c5b44ebd3..6f1d77771284 100644 --- a/.apigentools-info +++ b/.apigentools-info @@ -4,13 +4,13 @@ "spec_versions": { "v1": { "apigentools_version": "1.6.6", - "regenerated": "2024-10-07 14:32:12.782401", - "spec_repo_commit": "ef7c2778" + "regenerated": "2024-10-07 20:44:53.671285", + "spec_repo_commit": "5b4f9ebe" }, "v2": { "apigentools_version": "1.6.6", - "regenerated": "2024-10-07 14:32:12.797123", - "spec_repo_commit": "ef7c2778" + "regenerated": "2024-10-07 20:44:53.686318", + "spec_repo_commit": "5b4f9ebe" } } } \ No newline at end of file diff --git a/.generator/schemas/v1/openapi.yaml b/.generator/schemas/v1/openapi.yaml index e7f042346f47..c427699602cc 100644 --- a/.generator/schemas/v1/openapi.yaml +++ b/.generator/schemas/v1/openapi.yaml @@ -3314,6 +3314,12 @@ components: to be set to true.' example: true type: boolean + is_resource_change_collection_enabled: + default: false + description: When enabled, Datadog scans for all resource change data in + your Google Cloud environment. + example: true + type: boolean is_security_command_center_enabled: default: false description: 'When enabled, Datadog will attempt to collect Security Command diff --git a/.generator/schemas/v2/openapi.yaml b/.generator/schemas/v2/openapi.yaml index adb07799f7d8..29e09904cb0c 100644 --- a/.generator/schemas/v2/openapi.yaml +++ b/.generator/schemas/v2/openapi.yaml @@ -9566,6 +9566,12 @@ components: product for this service account. Note: This requires resource_collection_enabled to be set to true.' type: boolean + is_resource_change_collection_enabled: + default: false + description: When enabled, Datadog scans for all resource change data in + your Google Cloud environment. + example: true + type: boolean is_security_command_center_enabled: default: false description: 'When enabled, Datadog will attempt to collect Security Command diff --git a/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/frozen.json b/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/frozen.json index 6cbe8c24d636..2d0e7cdc92f8 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/frozen.json +++ b/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/frozen.json @@ -1 +1 @@ -"2024-01-31T21:16:03.254Z" +"2024-10-07T20:24:57.651Z" diff --git a/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/recording.har b/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/recording.har index 9e3aa861b1d7..056514b23435 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/recording.har +++ b/cassettes/v1/GCP-Integration_2417533655/Create-a-GCP-integration-returns-OK-response_610294268/recording.har @@ -8,11 +8,11 @@ }, "entries": [ { - "_id": "39099d420474c6096e87c89c0c161c61", + "_id": "1c662688a9e773d551b1e0fcea46593b", "_order": 0, "cache": {}, "request": { - "bodySize": 685, + "bodySize": 730, "cookies": [], "headers": [ { @@ -32,7 +32,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"3af93b0f1c973838@example.com\",\"client_id\":\"170673576317067357630\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"cloud_run_revision_filters\":[\"dr:dre\"],\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" + "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"f28619c1be385271@example.com\",\"client_id\":\"172833269717283326970\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"cloud_run_revision_filters\":[\"dr:dre\"],\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -57,11 +57,11 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2024-01-31T21:16:03.264Z", - "time": 428 + "startedDateTime": "2024-10-07T20:24:57.660Z", + "time": 684 }, { - "_id": "06f3a96597322f4179870a809aaab104", + "_id": "480d25bf2358ceb40d5b24e44502baed", "_order": 0, "cache": {}, "request": { @@ -79,13 +79,13 @@ "value": "application/json" } ], - "headersSize": 571, + "headersSize": 572, "httpVersion": "HTTP/1.1", "method": "DELETE", "postData": { "mimeType": "application/json", "params": [], - "text": "{\"client_email\":\"3af93b0f1c973838@example.com\",\"client_id\":\"170673576317067357630\",\"project_id\":\"datadog-apitest\"}" + "text": "{\"client_email\":\"f28619c1be385271@example.com\",\"client_id\":\"172833269717283326970\",\"project_id\":\"datadog-apitest\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -110,8 +110,8 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2024-01-31T21:16:03.699Z", - "time": 121 + "startedDateTime": "2024-10-07T20:24:58.352Z", + "time": 194 } ], "pages": [], diff --git a/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/frozen.json b/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/frozen.json index 739028d0a2e9..a1d8abab9312 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/frozen.json +++ b/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/frozen.json @@ -1 +1 @@ -"2023-12-20T13:20:18.421Z" +"2024-10-07T20:30:09.400Z" diff --git a/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/recording.har b/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/recording.har index a665e96b6425..ef42e9ba4c52 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/recording.har +++ b/cassettes/v1/GCP-Integration_2417533655/Delete-a-GCP-integration-returns-OK-response_2718821479/recording.har @@ -8,11 +8,11 @@ }, "entries": [ { - "_id": "f09b693fbd5d642e06d6ae96259a14a7", + "_id": "0ff241f67636c6b5894a91faf62bedfe", "_order": 0, "cache": {}, "request": { - "bodySize": 645, + "bodySize": 690, "cookies": [], "headers": [ { @@ -32,7 +32,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"40c7bfeef7b52e04@example.com\",\"client_id\":\"170307841817030784180\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" + "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"8c747ddd32fcd610@example.com\",\"client_id\":\"172833300917283330090\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -57,11 +57,11 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2023-12-20T13:20:18.438Z", - "time": 1957 + "startedDateTime": "2024-10-07T20:30:09.410Z", + "time": 676 }, { - "_id": "0ae87fc315cb6f68858b05f1eb5cdfcc", + "_id": "aae1fce9b9fa333cd4f698afa9092d52", "_order": 0, "cache": {}, "request": { @@ -85,7 +85,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"client_email\":\"40c7bfeef7b52e04@example.com\",\"client_id\":\"170307841817030784180\",\"project_id\":\"datadog-apitest\"}" + "text": "{\"client_email\":\"8c747ddd32fcd610@example.com\",\"client_id\":\"172833300917283330090\",\"project_id\":\"datadog-apitest\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -110,11 +110,11 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2023-12-20T13:20:20.407Z", - "time": 404 + "startedDateTime": "2024-10-07T20:30:10.094Z", + "time": 169 }, { - "_id": "0ae87fc315cb6f68858b05f1eb5cdfcc", + "_id": "aae1fce9b9fa333cd4f698afa9092d52", "_order": 1, "cache": {}, "request": { @@ -138,7 +138,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"client_email\":\"40c7bfeef7b52e04@example.com\",\"client_id\":\"170307841817030784180\",\"project_id\":\"datadog-apitest\"}" + "text": "{\"client_email\":\"8c747ddd32fcd610@example.com\",\"client_id\":\"172833300917283330090\",\"project_id\":\"datadog-apitest\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -163,8 +163,8 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2023-12-20T13:20:20.828Z", - "time": 333 + "startedDateTime": "2024-10-07T20:30:10.269Z", + "time": 139 } ], "pages": [], diff --git a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/frozen.json b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/frozen.json index c17ef3f60283..5e81839b4e6a 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/frozen.json +++ b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/frozen.json @@ -1 +1 @@ -"2024-01-31T21:16:03.829Z" +"2024-10-07T20:30:10.415Z" diff --git a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/recording.har b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/recording.har index 8c1f14efe11c..70807e8d9bec 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/recording.har +++ b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-cloud-run-revision-filters-returns-OK-response_1703063249/recording.har @@ -8,11 +8,11 @@ }, "entries": [ { - "_id": "d5af362cfd17a774895126db7016b73d", + "_id": "1efb84be77295de0a83ec317d530f22c", "_order": 0, "cache": {}, "request": { - "bodySize": 645, + "bodySize": 690, "cookies": [], "headers": [ { @@ -32,7 +32,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"edcdf6542ac6e6b6@example.com\",\"client_id\":\"170673576317067357630\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" + "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"0a9b348679053531@example.com\",\"client_id\":\"172833301017283330100\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -57,15 +57,15 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2024-01-31T21:16:03.836Z", - "time": 386 + "startedDateTime": "2024-10-07T20:30:10.418Z", + "time": 570 }, { - "_id": "b6bc74a2d4a7d7dcd8c4a4480213d777", + "_id": "6dade687fd9dd782f2b824e89185d6d6", "_order": 0, "cache": {}, "request": { - "bodySize": 688, + "bodySize": 733, "cookies": [], "headers": [ { @@ -85,7 +85,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"edcdf6542ac6e6b6@example.com\",\"client_id\":\"170673576317067357630\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"cloud_run_revision_filters\":[\"merp:derp\"],\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" + "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"0a9b348679053531@example.com\",\"client_id\":\"172833301017283330100\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"cloud_run_revision_filters\":[\"merp:derp\"],\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -110,11 +110,11 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2024-01-31T21:16:04.227Z", - "time": 137 + "startedDateTime": "2024-10-07T20:30:10.994Z", + "time": 189 }, { - "_id": "a91e4faee28489f69bbcf410954d7806", + "_id": "9418446c1823ade95f4a24e1692f8f74", "_order": 0, "cache": {}, "request": { @@ -138,7 +138,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"client_email\":\"edcdf6542ac6e6b6@example.com\",\"client_id\":\"170673576317067357630\",\"project_id\":\"datadog-apitest\"}" + "text": "{\"client_email\":\"0a9b348679053531@example.com\",\"client_id\":\"172833301017283330100\",\"project_id\":\"datadog-apitest\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -163,8 +163,8 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2024-01-31T21:16:04.370Z", - "time": 105 + "startedDateTime": "2024-10-07T20:30:11.188Z", + "time": 179 } ], "pages": [], diff --git a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/frozen.json b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/frozen.json index 05cbde0377ef..111ab8f2c536 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/frozen.json +++ b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/frozen.json @@ -1 +1 @@ -"2023-12-20T13:43:40.420Z" +"2024-10-07T20:30:11.373Z" diff --git a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/recording.har b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/recording.har index e5c638522657..23cb8642fa9e 100644 --- a/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/recording.har +++ b/cassettes/v1/GCP-Integration_2417533655/Update-a-GCP-integration-returns-OK-response_356662849/recording.har @@ -8,11 +8,11 @@ }, "entries": [ { - "_id": "948d959deb7c3dd5d6f9b005cc6ac91f", + "_id": "6ba08bc06cf220d8ee5e3e8fdd6b39d2", "_order": 0, "cache": {}, "request": { - "bodySize": 645, + "bodySize": 690, "cookies": [], "headers": [ { @@ -32,7 +32,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"5cf439fad579761d@example.com\",\"client_id\":\"170307982017030798200\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" + "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"b4b2a84c6669b5d4@example.com\",\"client_id\":\"172833301117283330110\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -57,15 +57,15 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2023-12-20T13:43:40.440Z", - "time": 745 + "startedDateTime": "2024-10-07T20:30:11.378Z", + "time": 553 }, { - "_id": "a4e0f5ca334eae20c292f85d670cf2eb", + "_id": "82037953bac51ed8c53cfcaf186070c4", "_order": 0, "cache": {}, "request": { - "bodySize": 645, + "bodySize": 690, "cookies": [], "headers": [ { @@ -85,7 +85,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"5cf439fad579761d@example.com\",\"client_id\":\"170307982017030798200\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" + "text": "{\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_email\":\"b4b2a84c6669b5d4@example.com\",\"client_id\":\"172833301117283330110\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\"host_filters\":\"key:value,filter:example\",\"is_cspm_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true,\"private_key\":\"private_key\",\"private_key_id\":\"123456789abcdefghi123456789abcdefghijklm\",\"project_id\":\"datadog-apitest\",\"resource_collection_enabled\":true,\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"type\":\"service_account\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -110,11 +110,11 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2023-12-20T13:43:41.198Z", - "time": 428 + "startedDateTime": "2024-10-07T20:30:11.936Z", + "time": 188 }, { - "_id": "430afe65f016121e09f1ca5d2830268f", + "_id": "93fedefef27b34f29e64c3e91dcd86fe", "_order": 0, "cache": {}, "request": { @@ -138,7 +138,7 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"client_email\":\"5cf439fad579761d@example.com\",\"client_id\":\"170307982017030798200\",\"project_id\":\"datadog-apitest\"}" + "text": "{\"client_email\":\"b4b2a84c6669b5d4@example.com\",\"client_id\":\"172833301117283330110\",\"project_id\":\"datadog-apitest\"}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v1/integration/gcp" @@ -163,8 +163,8 @@ "status": 200, "statusText": "OK" }, - "startedDateTime": "2023-12-20T13:43:41.643Z", - "time": 398 + "startedDateTime": "2024-10-07T20:30:12.129Z", + "time": 166 } ], "pages": [], diff --git a/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/frozen.json b/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/frozen.json index c9f654cd8941..ed483f7b76ad 100644 --- a/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/frozen.json +++ b/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/frozen.json @@ -1 +1 @@ -"2024-03-11T19:47:25.315Z" +"2024-10-07T20:25:02.725Z" diff --git a/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/recording.har b/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/recording.har index 16708fa0c71e..dd4cb91a0ebd 100644 --- a/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/recording.har +++ b/cassettes/v2/GCP-Integration_2417533655/Create-a-new-entry-for-your-service-account-with-security-command-center-enabled-returns-OK_41715253/recording.har @@ -8,11 +8,11 @@ }, "entries": [ { - "_id": "76bb956ebb016f2722e74c4c9c29f070", + "_id": "779eee28e3b87163288182039949f5d2", "_order": 0, "cache": {}, "request": { - "bodySize": 190, + "bodySize": 235, "cookies": [], "headers": [ { @@ -32,17 +32,17 @@ "postData": { "mimeType": "application/json", "params": [], - "text": "{\"data\":{\"attributes\":{\"client_email\":\"Test-48d87b38c858a0ef@test-project.iam.gserviceaccount.com\",\"host_filters\":[],\"is_security_command_center_enabled\":true},\"type\":\"gcp_service_account\"}}" + "text": "{\"data\":{\"attributes\":{\"client_email\":\"Test-d119bc7c8439bcb5@test-project.iam.gserviceaccount.com\",\"host_filters\":[],\"is_resource_change_collection_enabled\":true,\"is_security_command_center_enabled\":true},\"type\":\"gcp_service_account\"}}" }, "queryString": [], "url": "https://api.datadoghq.com/api/v2/integration/gcp/accounts" }, "response": { - "bodySize": 362, + "bodySize": 406, "content": { "mimeType": "application/json", - "size": 362, - "text": "{\"data\":{\"type\":\"gcp_service_account\",\"attributes\":{\"host_filters\":[],\"is_cspm_enabled\":false,\"resource_collection_enabled\":false,\"cloud_run_revision_filters\":[],\"client_email\":\"Test-48d87b38c858a0ef@test-project.iam.gserviceaccount.com\",\"account_tags\":[],\"is_security_command_center_enabled\":true,\"automute\":false},\"id\":\"0edb7a57-bd74-49da-ba0c-77d3cc756950\"}}\n" + "size": 406, + "text": "{\"data\":{\"type\":\"gcp_service_account\",\"attributes\":{\"client_email\":\"Test-d119bc7c8439bcb5@test-project.iam.gserviceaccount.com\",\"cloud_run_revision_filters\":[],\"host_filters\":[],\"automute\":false,\"resource_collection_enabled\":true,\"account_tags\":[],\"is_security_command_center_enabled\":true,\"is_resource_change_collection_enabled\":true,\"is_cspm_enabled\":false},\"id\":\"abdfa7a0-64b7-437d-99fe-13f56bbbfb15\"}}\n" }, "cookies": [], "headers": [ @@ -57,11 +57,11 @@ "status": 201, "statusText": "Created" }, - "startedDateTime": "2024-03-11T19:47:25.326Z", - "time": 422 + "startedDateTime": "2024-10-07T20:25:03.149Z", + "time": 797 }, { - "_id": "81fb43285440bc643f6a3b20f6197cd9", + "_id": "94ab4ea2f03e89c35a84f9f0d7cce950", "_order": 0, "cache": {}, "request": { @@ -74,11 +74,11 @@ "value": "*/*" } ], - "headersSize": 551, + "headersSize": 550, "httpVersion": "HTTP/1.1", "method": "DELETE", "queryString": [], - "url": "https://api.datadoghq.com/api/v2/integration/gcp/accounts/0edb7a57-bd74-49da-ba0c-77d3cc756950" + "url": "https://api.datadoghq.com/api/v2/integration/gcp/accounts/abdfa7a0-64b7-437d-99fe-13f56bbbfb15" }, "response": { "bodySize": 0, @@ -99,8 +99,8 @@ "status": 204, "statusText": "No Content" }, - "startedDateTime": "2024-03-11T19:47:25.769Z", - "time": 145 + "startedDateTime": "2024-10-07T20:25:03.969Z", + "time": 146 } ], "pages": [], diff --git a/examples/v1/gcp-integration/CreateGCPIntegration.ts b/examples/v1/gcp-integration/CreateGCPIntegration.ts index 37aabd97c4d5..2cbf16c87786 100644 --- a/examples/v1/gcp-integration/CreateGCPIntegration.ts +++ b/examples/v1/gcp-integration/CreateGCPIntegration.ts @@ -19,6 +19,7 @@ const params: v1.GCPIntegrationApiCreateGCPIntegrationRequest = { cloudRunRevisionFilters: ["dr:dre"], isCspmEnabled: true, isSecurityCommandCenterEnabled: true, + isResourceChangeCollectionEnabled: true, privateKey: "private_key", privateKeyId: "123456789abcdefghi123456789abcdefghijklm", projectId: "datadog-apitest", diff --git a/examples/v1/gcp-integration/UpdateGCPIntegration.ts b/examples/v1/gcp-integration/UpdateGCPIntegration.ts index 5c003b7620b1..c4770db7ec8c 100644 --- a/examples/v1/gcp-integration/UpdateGCPIntegration.ts +++ b/examples/v1/gcp-integration/UpdateGCPIntegration.ts @@ -18,6 +18,7 @@ const params: v1.GCPIntegrationApiUpdateGCPIntegrationRequest = { hostFilters: "key:value,filter:example", isCspmEnabled: true, isSecurityCommandCenterEnabled: true, + isResourceChangeCollectionEnabled: true, privateKey: "private_key", privateKeyId: "123456789abcdefghi123456789abcdefghijklm", projectId: "datadog-apitest", diff --git a/examples/v1/gcp-integration/UpdateGCPIntegration_3544259255.ts b/examples/v1/gcp-integration/UpdateGCPIntegration_3544259255.ts index 0063aab006f0..0ec69fe191f9 100644 --- a/examples/v1/gcp-integration/UpdateGCPIntegration_3544259255.ts +++ b/examples/v1/gcp-integration/UpdateGCPIntegration_3544259255.ts @@ -19,6 +19,7 @@ const params: v1.GCPIntegrationApiUpdateGCPIntegrationRequest = { cloudRunRevisionFilters: ["merp:derp"], isCspmEnabled: true, isSecurityCommandCenterEnabled: true, + isResourceChangeCollectionEnabled: true, privateKey: "private_key", privateKeyId: "123456789abcdefghi123456789abcdefghijklm", projectId: "datadog-apitest", diff --git a/examples/v2/gcp-integration/CreateGCPSTSAccount_2597004741.ts b/examples/v2/gcp-integration/CreateGCPSTSAccount_2597004741.ts index c9ff1086d4e5..0b7570638edf 100644 --- a/examples/v2/gcp-integration/CreateGCPSTSAccount_2597004741.ts +++ b/examples/v2/gcp-integration/CreateGCPSTSAccount_2597004741.ts @@ -12,6 +12,7 @@ const params: v2.GCPIntegrationApiCreateGCPSTSAccountRequest = { data: { attributes: { isSecurityCommandCenterEnabled: true, + isResourceChangeCollectionEnabled: true, clientEmail: "Test-252bf553ef04b351@test-project.iam.gserviceaccount.com", hostFilters: [], diff --git a/features/v1/gcp_integration.feature b/features/v1/gcp_integration.feature index b1473f1c1ce8..33a06d39fe92 100644 --- a/features/v1/gcp_integration.feature +++ b/features/v1/gcp_integration.feature @@ -13,21 +13,21 @@ Feature: GCP Integration @generated @skip @team:DataDog/gcp-integrations Scenario: Create a GCP integration returns "Bad Request" response Given new "CreateGCPIntegration" request - And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "api-dev@datadog-sandbox.iam.gserviceaccount.com", "client_id": "123456712345671234567", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "cloud_run_revision_filters": ["$KEY:$VALUE"], "errors": ["*"], "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} + And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "api-dev@datadog-sandbox.iam.gserviceaccount.com", "client_id": "123456712345671234567", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "cloud_run_revision_filters": ["$KEY:$VALUE"], "errors": ["*"], "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} When the request is sent Then the response status is 400 Bad Request @team:DataDog/gcp-integrations Scenario: Create a GCP integration returns "OK" response Given new "CreateGCPIntegration" request - And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "{{unique_hash}}@example.com", "client_id": "{{ timestamp("now") }}{{ timestamp("now") }}0", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "host_filters": "key:value,filter:example", "cloud_run_revision_filters": ["dr:dre"], "is_cspm_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} + And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "{{unique_hash}}@example.com", "client_id": "{{ timestamp("now") }}{{ timestamp("now") }}0", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "host_filters": "key:value,filter:example", "cloud_run_revision_filters": ["dr:dre"], "is_cspm_enabled": true, "is_security_command_center_enabled": true, "is_resource_change_collection_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} When the request is sent Then the response status is 200 OK @generated @skip @team:DataDog/gcp-integrations Scenario: Delete a GCP integration returns "Bad Request" response Given new "DeleteGCPIntegration" request - And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "api-dev@datadog-sandbox.iam.gserviceaccount.com", "client_id": "123456712345671234567", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "cloud_run_revision_filters": ["$KEY:$VALUE"], "errors": ["*"], "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} + And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "api-dev@datadog-sandbox.iam.gserviceaccount.com", "client_id": "123456712345671234567", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "cloud_run_revision_filters": ["$KEY:$VALUE"], "errors": ["*"], "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} When the request is sent Then the response status is 400 Bad Request @@ -55,14 +55,14 @@ Feature: GCP Integration Scenario: Update a GCP integration cloud run revision filters returns "OK" response Given there is a valid "gcp_account" in the system And new "UpdateGCPIntegration" request - And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "{{unique_hash}}@example.com", "client_id": "{{ timestamp("now") }}{{ timestamp("now") }}0", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "host_filters": "key:value,filter:example", "cloud_run_revision_filters": ["merp:derp"], "is_cspm_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} + And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "{{unique_hash}}@example.com", "client_id": "{{ timestamp("now") }}{{ timestamp("now") }}0", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "host_filters": "key:value,filter:example", "cloud_run_revision_filters": ["merp:derp"], "is_cspm_enabled": true, "is_security_command_center_enabled": true, "is_resource_change_collection_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} When the request is sent Then the response status is 200 OK @generated @skip @team:DataDog/gcp-integrations Scenario: Update a GCP integration returns "Bad Request" response Given new "UpdateGCPIntegration" request - And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "api-dev@datadog-sandbox.iam.gserviceaccount.com", "client_id": "123456712345671234567", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "cloud_run_revision_filters": ["$KEY:$VALUE"], "errors": ["*"], "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} + And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "api-dev@datadog-sandbox.iam.gserviceaccount.com", "client_id": "123456712345671234567", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "cloud_run_revision_filters": ["$KEY:$VALUE"], "errors": ["*"], "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} When the request is sent Then the response status is 400 Bad Request @@ -70,6 +70,6 @@ Feature: GCP Integration Scenario: Update a GCP integration returns "OK" response Given there is a valid "gcp_account" in the system And new "UpdateGCPIntegration" request - And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "{{unique_hash}}@example.com", "client_id": "{{ timestamp("now") }}{{ timestamp("now") }}0", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_security_command_center_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} + And body with value {"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs", "auth_uri": "https://accounts.google.com/o/oauth2/auth", "client_email": "{{unique_hash}}@example.com", "client_id": "{{ timestamp("now") }}{{ timestamp("now") }}0", "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL", "host_filters": "key:value,filter:example", "is_cspm_enabled": true, "is_security_command_center_enabled": true, "is_resource_change_collection_enabled": true, "private_key": "private_key", "private_key_id": "123456789abcdefghi123456789abcdefghijklm", "project_id": "datadog-apitest", "resource_collection_enabled": true, "token_uri": "https://accounts.google.com/o/oauth2/token", "type": "service_account"} When the request is sent Then the response status is 200 OK diff --git a/features/v1/given.json b/features/v1/given.json index 0880d17a9211..4b7ae56d5b4f 100644 --- a/features/v1/given.json +++ b/features/v1/given.json @@ -130,7 +130,7 @@ { "name": "body", "origin": "request", - "value": "{\n \"auth_provider_x509_cert_url\": \"https://www.googleapis.com/oauth2/v1/certs\",\n \"auth_uri\": \"https://accounts.google.com/o/oauth2/auth\",\n \"client_email\": \"{{unique_hash}}@example.com\",\n \"client_id\": \"{{ timestamp(\"now\") }}{{ timestamp(\"now\") }}0\",\n \"client_x509_cert_url\": \"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\n \"host_filters\": \"key:value,filter:example\",\n \"is_cspm_enabled\": true,\n \"is_security_command_center_enabled\": true,\n \"private_key\": \"private_key\",\n \"private_key_id\": \"123456789abcdefghi123456789abcdefghijklm\",\n \"project_id\": \"datadog-apitest\",\n \"resource_collection_enabled\": true,\n \"token_uri\": \"https://accounts.google.com/o/oauth2/token\",\n \"type\": \"service_account\"\n}" + "value": "{\n \"auth_provider_x509_cert_url\": \"https://www.googleapis.com/oauth2/v1/certs\",\n \"auth_uri\": \"https://accounts.google.com/o/oauth2/auth\",\n \"client_email\": \"{{unique_hash}}@example.com\",\n \"client_id\": \"{{ timestamp(\"now\") }}{{ timestamp(\"now\") }}0\",\n \"client_x509_cert_url\": \"https://www.googleapis.com/robot/v1/metadata/x509/$CLIENT_EMAIL\",\n \"host_filters\": \"key:value,filter:example\",\n \"is_cspm_enabled\": true,\n \"is_security_command_center_enabled\": true,\n \"is_resource_change_collection_enabled\": true,\n \"private_key\": \"private_key\",\n \"private_key_id\": \"123456789abcdefghi123456789abcdefghijklm\",\n \"project_id\": \"datadog-apitest\",\n \"resource_collection_enabled\": true,\n \"token_uri\": \"https://accounts.google.com/o/oauth2/token\",\n \"type\": \"service_account\"\n}" } ], "step": "there is a valid \"gcp_account\" in the system", diff --git a/features/v2/gcp_integration.feature b/features/v2/gcp_integration.feature index f595ae95449e..7ab3ec0b0ebf 100644 --- a/features/v2/gcp_integration.feature +++ b/features/v2/gcp_integration.feature @@ -34,14 +34,14 @@ Feature: GCP Integration @generated @skip @team:DataDog/gcp-integrations Scenario: Create a new entry for your service account returns "Bad Request" response Given new "CreateGCPSTSAccount" request - And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_security_command_center_enabled": true}, "type": "gcp_service_account"}} + And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true}, "type": "gcp_service_account"}} When the request is sent Then the response status is 400 Bad Request @generated @skip @team:DataDog/gcp-integrations Scenario: Create a new entry for your service account returns "Conflict" response Given new "CreateGCPSTSAccount" request - And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_security_command_center_enabled": true}, "type": "gcp_service_account"}} + And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true}, "type": "gcp_service_account"}} When the request is sent Then the response status is 409 Conflict @@ -104,12 +104,13 @@ Feature: GCP Integration @team:DataDog/gcp-integrations Scenario: Create a new entry for your service account with security command center enabled returns "OK" response Given new "CreateGCPSTSAccount" request - And body with value {"data": {"attributes": {"is_security_command_center_enabled": true, "client_email": "Test-{{ unique_hash }}@test-project.iam.gserviceaccount.com", "host_filters": []}, "type": "gcp_service_account"}} + And body with value {"data": {"attributes": {"is_security_command_center_enabled": true, "is_resource_change_collection_enabled": true, "client_email": "Test-{{ unique_hash }}@test-project.iam.gserviceaccount.com", "host_filters": []}, "type": "gcp_service_account"}} When the request is sent Then the response status is 201 OK And the response "data.type" is equal to "gcp_service_account" And the response "data.attributes.client_email" is equal to "Test-{{ unique_hash }}@test-project.iam.gserviceaccount.com" And the response "data.attributes.is_security_command_center_enabled" is equal to true + And the response "data.attributes.is_resource_change_collection_enabled" is equal to true @generated @skip @team:DataDog/gcp-integrations Scenario: Delete an STS enabled GCP Account returns "Bad Request" response @@ -150,7 +151,7 @@ Feature: GCP Integration Scenario: Update STS Service Account returns "Bad Request" response Given new "UpdateGCPSTSAccount" request And request contains "account_id" parameter from "REPLACE.ME" - And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_security_command_center_enabled": true}, "id": "d291291f-12c2-22g4-j290-123456678897", "type": "gcp_service_account"}} + And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true}, "id": "d291291f-12c2-22g4-j290-123456678897", "type": "gcp_service_account"}} When the request is sent Then the response status is 400 Bad Request @@ -158,7 +159,7 @@ Feature: GCP Integration Scenario: Update STS Service Account returns "Not Found" response Given new "UpdateGCPSTSAccount" request And request contains "account_id" parameter from "REPLACE.ME" - And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_security_command_center_enabled": true}, "id": "d291291f-12c2-22g4-j290-123456678897", "type": "gcp_service_account"}} + And body with value {"data": {"attributes": {"account_tags": [], "client_email": "datadog-service-account@test-project.iam.gserviceaccount.com", "cloud_run_revision_filters": ["$KEY:$VALUE"], "host_filters": [], "is_resource_change_collection_enabled": true, "is_security_command_center_enabled": true}, "id": "d291291f-12c2-22g4-j290-123456678897", "type": "gcp_service_account"}} When the request is sent Then the response status is 404 Not Found diff --git a/packages/datadog-api-client-v1/models/GCPAccount.ts b/packages/datadog-api-client-v1/models/GCPAccount.ts index 0cf931b25874..3d9616334d69 100644 --- a/packages/datadog-api-client-v1/models/GCPAccount.ts +++ b/packages/datadog-api-client-v1/models/GCPAccount.ts @@ -53,6 +53,10 @@ export class GCPAccount { * When enabled, Datadog will activate the Cloud Security Monitoring product for this service account. Note: This requires resource_collection_enabled to be set to true. */ "isCspmEnabled"?: boolean; + /** + * When enabled, Datadog scans for all resource change data in your Google Cloud environment. + */ + "isResourceChangeCollectionEnabled"?: boolean; /** * When enabled, Datadog will attempt to collect Security Command Center Findings. Note: This requires additional permissions on the service account. */ @@ -138,6 +142,10 @@ export class GCPAccount { baseName: "is_cspm_enabled", type: "boolean", }, + isResourceChangeCollectionEnabled: { + baseName: "is_resource_change_collection_enabled", + type: "boolean", + }, isSecurityCommandCenterEnabled: { baseName: "is_security_command_center_enabled", type: "boolean", diff --git a/packages/datadog-api-client-v2/models/GCPSTSServiceAccountAttributes.ts b/packages/datadog-api-client-v2/models/GCPSTSServiceAccountAttributes.ts index ee80bf6046d7..fe869888c357 100644 --- a/packages/datadog-api-client-v2/models/GCPSTSServiceAccountAttributes.ts +++ b/packages/datadog-api-client-v2/models/GCPSTSServiceAccountAttributes.ts @@ -35,6 +35,10 @@ export class GCPSTSServiceAccountAttributes { * When enabled, Datadog will activate the Cloud Security Monitoring product for this service account. Note: This requires resource_collection_enabled to be set to true. */ "isCspmEnabled"?: boolean; + /** + * When enabled, Datadog scans for all resource change data in your Google Cloud environment. + */ + "isResourceChangeCollectionEnabled"?: boolean; /** * When enabled, Datadog will attempt to collect Security Command Center Findings. Note: This requires additional permissions on the service account. */ @@ -84,6 +88,10 @@ export class GCPSTSServiceAccountAttributes { baseName: "is_cspm_enabled", type: "boolean", }, + isResourceChangeCollectionEnabled: { + baseName: "is_resource_change_collection_enabled", + type: "boolean", + }, isSecurityCommandCenterEnabled: { baseName: "is_security_command_center_enabled", type: "boolean",