From 324e03c08763b2dd201b25e8cf712c92797c1b6a Mon Sep 17 00:00:00 2001 From: "ci.datadog-api-spec" Date: Tue, 10 Oct 2023 13:48:52 +0000 Subject: [PATCH] Regenerate client from commit afb48804 of spec repo --- .apigentools-info | 8 +- .generator/schemas/v2/openapi.yaml | 179 ++++++++++++++++++ .../frozen.json | 1 + .../recording.har | 110 +++++++++++ .../CreateOrUpdateServiceDefinitions.ts | 10 +- ...teOrUpdateServiceDefinitions_2621709423.ts | 65 +++++++ features/v2/service_definition.feature | 15 +- packages/datadog-api-client-v2/index.ts | 8 + .../models/ObjectSerializer.ts | 18 +- .../models/ServiceDefinitionSchema.ts | 2 + .../models/ServiceDefinitionSchemaVersions.ts | 2 + .../models/ServiceDefinitionV2Dot2.ts | 151 +++++++++++++++ .../models/ServiceDefinitionV2Dot2Contact.ts | 59 ++++++ .../ServiceDefinitionV2Dot2Integrations.ts | 51 +++++ .../models/ServiceDefinitionV2Dot2Link.ts | 68 +++++++ .../models/ServiceDefinitionV2Dot2Opsgenie.ts | 51 +++++ .../ServiceDefinitionV2Dot2OpsgenieRegion.ts | 18 ++ .../ServiceDefinitionV2Dot2Pagerduty.ts | 41 ++++ .../models/ServiceDefinitionV2Dot2Version.ts | 14 ++ .../models/ServiceDefinitionsCreateRequest.ts | 2 + 20 files changed, 861 insertions(+), 12 deletions(-) create mode 100644 cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/frozen.json create mode 100644 cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/recording.har create mode 100644 examples/v2/service-definition/CreateOrUpdateServiceDefinitions_2621709423.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Contact.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Integrations.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Link.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Opsgenie.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2OpsgenieRegion.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Pagerduty.ts create mode 100644 packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Version.ts diff --git a/.apigentools-info b/.apigentools-info index 8086c18a4b5f..d282541f86d4 100644 --- a/.apigentools-info +++ b/.apigentools-info @@ -4,13 +4,13 @@ "spec_versions": { "v1": { "apigentools_version": "1.6.6", - "regenerated": "2023-10-10 07:51:57.967909", - "spec_repo_commit": "6482b048" + "regenerated": "2023-10-10 13:47:29.129078", + "spec_repo_commit": "afb48804" }, "v2": { "apigentools_version": "1.6.6", - "regenerated": "2023-10-10 07:51:57.983541", - "spec_repo_commit": "6482b048" + "regenerated": "2023-10-10 13:47:29.143556", + "spec_repo_commit": "afb48804" } } } \ No newline at end of file diff --git a/.generator/schemas/v2/openapi.yaml b/.generator/schemas/v2/openapi.yaml index 0eca5ce93f5d..2975fa2f4450 100644 --- a/.generator/schemas/v2/openapi.yaml +++ b/.generator/schemas/v2/openapi.yaml @@ -14994,6 +14994,7 @@ components: - $ref: '#/components/schemas/ServiceDefinitionV1' - $ref: '#/components/schemas/ServiceDefinitionV2' - $ref: '#/components/schemas/ServiceDefinitionV2Dot1' + - $ref: '#/components/schemas/ServiceDefinitionV2Dot2' type: object ServiceDefinitionSchemaVersions: description: Schema versions @@ -15001,11 +15002,13 @@ components: - v1 - v2 - v2.1 + - v2.2 type: string x-enum-varnames: - V1 - V2 - V2_1 + - V2_2 ServiceDefinitionV1: deprecated: true description: Deprecated - Service definition V1 for providing additional service @@ -15466,6 +15469,181 @@ components: type: string x-enum-varnames: - V2_1 + ServiceDefinitionV2Dot2: + description: Service definition v2.2 for providing service metadata and integrations. + properties: + application: + description: Identifier for a group of related services serving a product + feature, which the service is a part of. + example: my-app + type: string + contacts: + description: A list of contacts related to the services. + items: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2Contact' + type: array + dd-service: + description: Unique identifier of the service. Must be unique across all + services and is used to match with a service in Datadog. + example: my-service + type: string + description: + description: A short description of the service. + example: My service description + type: string + extensions: + additionalProperties: {} + description: Extensions to v2.2 schema. + example: + myorg/extension: extensionValue + type: object + integrations: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2Integrations' + langauges: + description: 'The service''s programming language. Datadog recognizes the + following languages: `dotnet`, `go`, `java`, `js`, `php`, `python`, `ruby`, + and `c++`.' + example: + - dotnet + - go + - java + - js + - php + - python + - ruby + - c++ + items: + type: string + type: array + lifecycle: + description: The current life cycle phase of the service. + example: sandbox + type: string + links: + description: A list of links related to the services. + items: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2Link' + type: array + schema-version: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2Version' + service-type: + description: 'The type of service. Datadog recognizes the following service + types: `database`, `cache`, `function`, `web`, `browser`, and `mobile`.' + example: web + type: string + tags: + description: A set of custom tags. + example: + - my:tag + - service:tag + items: + type: string + type: array + team: + description: Team that owns the service. It is used to locate a team defined + in Datadog Teams if it exists. + example: my-team + type: string + tier: + description: Importance of the service. + example: High + type: string + required: + - schema-version + - dd-service + type: object + ServiceDefinitionV2Dot2Contact: + description: Service owner's contacts information. + properties: + contact: + description: Contact value. + example: https://teams.microsoft.com/myteam + type: string + name: + description: Contact Name. + example: My team channel + type: string + type: + description: 'Contact type. Datadog recognizes the following types: `email`, + `slack`, and `microsoft-teams`.' + example: slack + type: string + required: + - type + - contact + type: object + ServiceDefinitionV2Dot2Integrations: + description: Third party integrations that Datadog supports. + properties: + opsgenie: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2Opsgenie' + pagerduty: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2Pagerduty' + type: object + ServiceDefinitionV2Dot2Link: + description: Service's external links. + properties: + name: + description: Link name. + example: Runbook + type: string + provider: + description: Link provider. + example: Github + type: string + type: + description: 'Link type. Datadog recognizes the following types: `runbook`, + `doc`, `repo`, `dashboard`, and `other`.' + example: runbook + type: string + url: + description: Link URL. + example: https://my-runbook + type: string + required: + - name + - type + - url + type: object + ServiceDefinitionV2Dot2Opsgenie: + description: Opsgenie integration for the service. + properties: + region: + $ref: '#/components/schemas/ServiceDefinitionV2Dot2OpsgenieRegion' + service-url: + description: Opsgenie service url. + example: https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000 + type: string + required: + - service-url + type: object + ServiceDefinitionV2Dot2OpsgenieRegion: + description: Opsgenie instance region. + enum: + - US + - EU + example: US + type: string + x-enum-varnames: + - US + - EU + ServiceDefinitionV2Dot2Pagerduty: + description: PagerDuty integration for the service. + properties: + service-url: + description: PagerDuty service url. + example: https://my-org.pagerduty.com/service-directory/PMyService + type: string + type: object + ServiceDefinitionV2Dot2Version: + default: v2.2 + description: Schema version being used. + enum: + - v2.2 + example: v2.2 + type: string + x-enum-varnames: + - V2_2 ServiceDefinitionV2Email: description: Service owner's email. properties: @@ -15649,6 +15827,7 @@ components: ServiceDefinitionsCreateRequest: description: Create service definitions request. oneOf: + - $ref: '#/components/schemas/ServiceDefinitionV2Dot2' - $ref: '#/components/schemas/ServiceDefinitionV2Dot1' - $ref: '#/components/schemas/ServiceDefinitionV2' - $ref: '#/components/schemas/ServiceDefinitionRaw' diff --git a/cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/frozen.json b/cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/frozen.json new file mode 100644 index 000000000000..9afa81626bf2 --- /dev/null +++ b/cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/frozen.json @@ -0,0 +1 @@ +"2023-10-06T18:44:31.430Z" diff --git a/cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/recording.har b/cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/recording.har new file mode 100644 index 000000000000..1dda09b9d936 --- /dev/null +++ b/cassettes/v2/Service-Definition_2211895093/Create-or-update-service-definition-using-schema-v2-2-returns-CREATED-response_2253238283/recording.har @@ -0,0 +1,110 @@ +{ + "log": { + "_recordingName": "Service Definition/Create or update service definition using schema v2-2 returns \"CREATED\" response", + "creator": { + "comment": "persister:fs", + "name": "Polly.JS", + "version": "6.0.5" + }, + "entries": [ + { + "_id": "9fecc08ce646b6f022342c5a3e0f60ee", + "_order": 0, + "cache": {}, + "request": { + "bodySize": 801, + "cookies": [], + "headers": [ + { + "_fromType": "array", + "name": "accept", + "value": "application/json" + }, + { + "_fromType": "array", + "name": "content-type", + "value": "application/json" + } + ], + "headersSize": 586, + "httpVersion": "HTTP/1.1", + "method": "POST", + "postData": { + "mimeType": "application/json", + "params": [], + "text": "{\"contacts\":[{\"contact\":\"contact@datadoghq.com\",\"name\":\"Team Email\",\"type\":\"email\"}],\"dd-service\":\"service-testcreateorupdateservicedefinitionusingschemav22returnscreatedresponse1696617871\",\"extensions\":{\"myorgextension\":\"extensionvalue\"},\"integrations\":{\"opsgenie\":{\"region\":\"US\",\"service-url\":\"https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000\"},\"pagerduty\":{\"service-url\":\"https://my-org.pagerduty.com/service-directory/PMyService\"}},\"links\":[{\"name\":\"Runbook\",\"type\":\"runbook\",\"url\":\"https://my-runbook\"},{\"name\":\"Source Code\",\"provider\":\"GitHub\",\"type\":\"repo\",\"url\":\"https://github.com/DataDog/schema\"},{\"name\":\"Architecture\",\"provider\":\"Gigoogle drivetHub\",\"type\":\"doc\",\"url\":\"https://my-runbook\"}],\"schema-version\":\"v2.2\",\"tags\":[\"my:tag\",\"service:tag\"],\"team\":\"my-team\"}" + }, + "queryString": [], + "url": "https://api.datadoghq.com/api/v2/services/definitions" + }, + "response": { + "bodySize": 1061, + "content": { + "mimeType": "application/json", + "size": 1061, + "text": "{\"data\":[{\"type\":\"service-definition\",\"attributes\":{\"meta\":{\"last-modified-time\":\"2023-10-06T18:44:32.076834625Z\",\"github-html-url\":\"\",\"ingestion-source\":\"api\",\"origin\":\"unknown\",\"origin-detail\":\"\",\"warnings\":[],\"ingested-schema-version\":\"v2.2\"},\"schema\":{\"schema-version\":\"v2.2\",\"dd-service\":\"service-testcreateorupdateservicedefinitionusingschemav22returnscreatedresponse1696617871\",\"team\":\"my-team\",\"contacts\":[{\"name\":\"Team Email\",\"type\":\"email\",\"contact\":\"contact@datadoghq.com\"}],\"links\":[{\"name\":\"Runbook\",\"type\":\"runbook\",\"url\":\"https://my-runbook\"},{\"name\":\"Source Code\",\"type\":\"repo\",\"provider\":\"GitHub\",\"url\":\"https://github.com/DataDog/schema\"},{\"name\":\"Architecture\",\"type\":\"doc\",\"provider\":\"Gigoogle drivetHub\",\"url\":\"https://my-runbook\"}],\"tags\":[\"my:tag\",\"service:tag\"],\"integrations\":{\"pagerduty\":{\"service-url\":\"https://my-org.pagerduty.com/service-directory/PMyService\"},\"opsgenie\":{\"service-url\":\"https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000\",\"region\":\"US\"}},\"extensions\":{\"myorgextension\":\"extensionvalue\"}}}}]}\n" + }, + "cookies": [], + "headers": [ + { + "name": "content-type", + "value": "application/json" + } + ], + "headersSize": 657, + "httpVersion": "HTTP/1.1", + "redirectURL": "", + "status": 200, + "statusText": "OK" + }, + "startedDateTime": "2023-10-06T18:44:31.992Z", + "time": 97 + }, + { + "_id": "da8b7ea8fd5632368dc01b71951fcebb", + "_order": 0, + "cache": {}, + "request": { + "bodySize": 0, + "cookies": [], + "headers": [ + { + "_fromType": "array", + "name": "accept", + "value": "*/*" + } + ], + "headersSize": 603, + "httpVersion": "HTTP/1.1", + "method": "DELETE", + "queryString": [], + "url": "https://api.datadoghq.com/api/v2/services/definitions/service-testcreateorupdateservicedefinitionusingschemav22returnscreatedresponse1696617871" + }, + "response": { + "bodySize": 46, + "content": { + "mimeType": "application/json", + "size": 46, + "text": "{\"errors\":[\"Not Found\"],\"error_details\":[{}]}\n" + }, + "cookies": [], + "headers": [ + { + "name": "content-type", + "value": "application/json" + } + ], + "headersSize": 655, + "httpVersion": "HTTP/1.1", + "redirectURL": "", + "status": 404, + "statusText": "Not Found" + }, + "startedDateTime": "2023-10-06T18:44:32.098Z", + "time": 214 + } + ], + "pages": [], + "version": "1.2" + } +} diff --git a/examples/v2/service-definition/CreateOrUpdateServiceDefinitions.ts b/examples/v2/service-definition/CreateOrUpdateServiceDefinitions.ts index 9a1e4e335bac..b46663129be1 100644 --- a/examples/v2/service-definition/CreateOrUpdateServiceDefinitions.ts +++ b/examples/v2/service-definition/CreateOrUpdateServiceDefinitions.ts @@ -12,9 +12,9 @@ const params: v2.ServiceDefinitionApiCreateOrUpdateServiceDefinitionsRequest = { application: "my-app", contacts: [ { - contact: "contact@datadoghq.com", - name: "Team Email", - type: "email", + contact: "https://teams.microsoft.com/myteam", + name: "My team channel", + type: "slack", }, ], ddService: "my-service", @@ -32,6 +32,7 @@ const params: v2.ServiceDefinitionApiCreateOrUpdateServiceDefinitionsRequest = { serviceUrl: "https://my-org.pagerduty.com/service-directory/PMyService", }, }, + langauges: ["dotnet", "go", "java", "js", "php", "python", "ruby", "c++"], lifecycle: "sandbox", links: [ { @@ -41,7 +42,8 @@ const params: v2.ServiceDefinitionApiCreateOrUpdateServiceDefinitionsRequest = { url: "https://my-runbook", }, ], - schemaVersion: "v2.1", + schemaVersion: "v2.2", + serviceType: "web", tags: ["my:tag", "service:tag"], team: "my-team", tier: "High", diff --git a/examples/v2/service-definition/CreateOrUpdateServiceDefinitions_2621709423.ts b/examples/v2/service-definition/CreateOrUpdateServiceDefinitions_2621709423.ts new file mode 100644 index 000000000000..b282caeb1337 --- /dev/null +++ b/examples/v2/service-definition/CreateOrUpdateServiceDefinitions_2621709423.ts @@ -0,0 +1,65 @@ +/** + * Create or update service definition using schema v2-2 returns "CREATED" response + */ + +import { client, v2 } from "@datadog/datadog-api-client"; + +const configuration = client.createConfiguration(); +const apiInstance = new v2.ServiceDefinitionApi(configuration); + +const params: v2.ServiceDefinitionApiCreateOrUpdateServiceDefinitionsRequest = { + body: { + contacts: [ + { + contact: "contact@datadoghq.com", + name: "Team Email", + type: "email", + }, + ], + ddService: "service-exampleservicedefinition", + extensions: { + myorgextension: "extensionvalue", + }, + integrations: { + opsgenie: { + region: "US", + serviceUrl: + "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000", + }, + pagerduty: { + serviceUrl: "https://my-org.pagerduty.com/service-directory/PMyService", + }, + }, + links: [ + { + name: "Runbook", + type: "runbook", + url: "https://my-runbook", + }, + { + name: "Source Code", + type: "repo", + provider: "GitHub", + url: "https://github.com/DataDog/schema", + }, + { + name: "Architecture", + type: "doc", + provider: "Gigoogle drivetHub", + url: "https://my-runbook", + }, + ], + schemaVersion: "v2.2", + tags: ["my:tag", "service:tag"], + team: "my-team", + }, +}; + +apiInstance + .createOrUpdateServiceDefinitions(params) + .then((data: v2.ServiceDefinitionCreateResponse) => { + console.log( + "API called successfully. Returned data: " + JSON.stringify(data) + ); + }) + .catch((error: any) => console.error(error)); diff --git a/features/v2/service_definition.feature b/features/v2/service_definition.feature index 68c556065320..9fbc2c65579c 100644 --- a/features/v2/service_definition.feature +++ b/features/v2/service_definition.feature @@ -10,21 +10,21 @@ Feature: Service Definition @generated @skip @team:DataDog/service-catalog Scenario: Create or update service definition returns "Bad Request" response Given new "CreateOrUpdateServiceDefinitions" request - And body with value {"application": "my-app", "contacts": [{"contact": "contact@datadoghq.com", "name": "Team Email", "type": "email"}], "dd-service": "my-service", "description": "My service description", "extensions": {"myorg/extension": "extensionValue"}, "integrations": {"opsgenie": {"region": "US", "service-url": "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"}, "pagerduty": {"service-url": "https://my-org.pagerduty.com/service-directory/PMyService"}}, "lifecycle": "sandbox", "links": [{"name": "Runbook", "provider": "Github", "type": "runbook", "url": "https://my-runbook"}], "schema-version": "v2.1", "tags": ["my:tag", "service:tag"], "team": "my-team", "tier": "High"} + And body with value {"application": "my-app", "contacts": [{"contact": "https://teams.microsoft.com/myteam", "name": "My team channel", "type": "slack"}], "dd-service": "my-service", "description": "My service description", "extensions": {"myorg/extension": "extensionValue"}, "integrations": {"opsgenie": {"region": "US", "service-url": "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"}, "pagerduty": {"service-url": "https://my-org.pagerduty.com/service-directory/PMyService"}}, "langauges": ["dotnet", "go", "java", "js", "php", "python", "ruby", "c++"], "lifecycle": "sandbox", "links": [{"name": "Runbook", "provider": "Github", "type": "runbook", "url": "https://my-runbook"}], "schema-version": "v2.2", "service-type": "web", "tags": ["my:tag", "service:tag"], "team": "my-team", "tier": "High"} When the request is sent Then the response status is 400 Bad Request @generated @skip @team:DataDog/service-catalog Scenario: Create or update service definition returns "CREATED" response Given new "CreateOrUpdateServiceDefinitions" request - And body with value {"application": "my-app", "contacts": [{"contact": "contact@datadoghq.com", "name": "Team Email", "type": "email"}], "dd-service": "my-service", "description": "My service description", "extensions": {"myorg/extension": "extensionValue"}, "integrations": {"opsgenie": {"region": "US", "service-url": "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"}, "pagerduty": {"service-url": "https://my-org.pagerduty.com/service-directory/PMyService"}}, "lifecycle": "sandbox", "links": [{"name": "Runbook", "provider": "Github", "type": "runbook", "url": "https://my-runbook"}], "schema-version": "v2.1", "tags": ["my:tag", "service:tag"], "team": "my-team", "tier": "High"} + And body with value {"application": "my-app", "contacts": [{"contact": "https://teams.microsoft.com/myteam", "name": "My team channel", "type": "slack"}], "dd-service": "my-service", "description": "My service description", "extensions": {"myorg/extension": "extensionValue"}, "integrations": {"opsgenie": {"region": "US", "service-url": "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"}, "pagerduty": {"service-url": "https://my-org.pagerduty.com/service-directory/PMyService"}}, "langauges": ["dotnet", "go", "java", "js", "php", "python", "ruby", "c++"], "lifecycle": "sandbox", "links": [{"name": "Runbook", "provider": "Github", "type": "runbook", "url": "https://my-runbook"}], "schema-version": "v2.2", "service-type": "web", "tags": ["my:tag", "service:tag"], "team": "my-team", "tier": "High"} When the request is sent Then the response status is 200 CREATED @generated @skip @team:DataDog/service-catalog Scenario: Create or update service definition returns "Conflict" response Given new "CreateOrUpdateServiceDefinitions" request - And body with value {"application": "my-app", "contacts": [{"contact": "contact@datadoghq.com", "name": "Team Email", "type": "email"}], "dd-service": "my-service", "description": "My service description", "extensions": {"myorg/extension": "extensionValue"}, "integrations": {"opsgenie": {"region": "US", "service-url": "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"}, "pagerduty": {"service-url": "https://my-org.pagerduty.com/service-directory/PMyService"}}, "lifecycle": "sandbox", "links": [{"name": "Runbook", "provider": "Github", "type": "runbook", "url": "https://my-runbook"}], "schema-version": "v2.1", "tags": ["my:tag", "service:tag"], "team": "my-team", "tier": "High"} + And body with value {"application": "my-app", "contacts": [{"contact": "https://teams.microsoft.com/myteam", "name": "My team channel", "type": "slack"}], "dd-service": "my-service", "description": "My service description", "extensions": {"myorg/extension": "extensionValue"}, "integrations": {"opsgenie": {"region": "US", "service-url": "https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"}, "pagerduty": {"service-url": "https://my-org.pagerduty.com/service-directory/PMyService"}}, "langauges": ["dotnet", "go", "java", "js", "php", "python", "ruby", "c++"], "lifecycle": "sandbox", "links": [{"name": "Runbook", "provider": "Github", "type": "runbook", "url": "https://my-runbook"}], "schema-version": "v2.2", "service-type": "web", "tags": ["my:tag", "service:tag"], "team": "my-team", "tier": "High"} When the request is sent Then the response status is 409 Conflict @@ -46,6 +46,15 @@ Feature: Service Definition And the response "data[0].attributes.meta.ingested-schema-version" is equal to "v2.1" And the response "data[0].attributes.schema.dd-service" is equal to "service-{{ unique_lower_alnum }}" + @team:DataDog/service-catalog + Scenario: Create or update service definition using schema v2-2 returns "CREATED" response + Given new "CreateOrUpdateServiceDefinitions" request + And body with value {"contacts":[{"contact":"contact@datadoghq.com","name":"Team Email","type":"email"}],"dd-service":"service-{{ unique_lower_alnum }}","extensions":{"myorgextension":"extensionvalue"},"integrations":{"opsgenie":{"region":"US","service-url":"https://my-org.opsgenie.com/service/123e4567-e89b-12d3-a456-426614174000"},"pagerduty":{"service-url":"https://my-org.pagerduty.com/service-directory/PMyService"}},"links":[{"name":"Runbook","type":"runbook","url":"https://my-runbook"},{"name":"Source Code","type":"repo","provider":"GitHub","url":"https://github.com/DataDog/schema"},{"name":"Architecture","type":"doc","provider":"Gigoogle drivetHub","url":"https://my-runbook"}],"schema-version":"v2.2","tags":["my:tag","service:tag"],"team":"my-team"} + When the request is sent + Then the response status is 200 CREATED + And the response "data[0].attributes.meta.ingested-schema-version" is equal to "v2.2" + And the response "data[0].attributes.schema.dd-service" is equal to "service-{{ unique_lower_alnum }}" + @generated @skip @team:DataDog/service-catalog Scenario: Delete a single service definition returns "Bad Request" response Given new "DeleteServiceDefinition" request diff --git a/packages/datadog-api-client-v2/index.ts b/packages/datadog-api-client-v2/index.ts index dc07db988e5d..2ae78b9a1c6c 100644 --- a/packages/datadog-api-client-v2/index.ts +++ b/packages/datadog-api-client-v2/index.ts @@ -1373,6 +1373,14 @@ export { ServiceDefinitionV2Dot1Pagerduty } from "./models/ServiceDefinitionV2Do export { ServiceDefinitionV2Dot1Slack } from "./models/ServiceDefinitionV2Dot1Slack"; export { ServiceDefinitionV2Dot1SlackType } from "./models/ServiceDefinitionV2Dot1SlackType"; export { ServiceDefinitionV2Dot1Version } from "./models/ServiceDefinitionV2Dot1Version"; +export { ServiceDefinitionV2Dot2 } from "./models/ServiceDefinitionV2Dot2"; +export { ServiceDefinitionV2Dot2Contact } from "./models/ServiceDefinitionV2Dot2Contact"; +export { ServiceDefinitionV2Dot2Integrations } from "./models/ServiceDefinitionV2Dot2Integrations"; +export { ServiceDefinitionV2Dot2Link } from "./models/ServiceDefinitionV2Dot2Link"; +export { ServiceDefinitionV2Dot2Opsgenie } from "./models/ServiceDefinitionV2Dot2Opsgenie"; +export { ServiceDefinitionV2Dot2OpsgenieRegion } from "./models/ServiceDefinitionV2Dot2OpsgenieRegion"; +export { ServiceDefinitionV2Dot2Pagerduty } from "./models/ServiceDefinitionV2Dot2Pagerduty"; +export { ServiceDefinitionV2Dot2Version } from "./models/ServiceDefinitionV2Dot2Version"; export { ServiceDefinitionV2Email } from "./models/ServiceDefinitionV2Email"; export { ServiceDefinitionV2EmailType } from "./models/ServiceDefinitionV2EmailType"; export { ServiceDefinitionV2Integrations } from "./models/ServiceDefinitionV2Integrations"; diff --git a/packages/datadog-api-client-v2/models/ObjectSerializer.ts b/packages/datadog-api-client-v2/models/ObjectSerializer.ts index 1623cf0b4b3a..8f88a52614c5 100644 --- a/packages/datadog-api-client-v2/models/ObjectSerializer.ts +++ b/packages/datadog-api-client-v2/models/ObjectSerializer.ts @@ -738,6 +738,12 @@ import { ServiceDefinitionV2Dot1MSTeams } from "./ServiceDefinitionV2Dot1MSTeams import { ServiceDefinitionV2Dot1Opsgenie } from "./ServiceDefinitionV2Dot1Opsgenie"; import { ServiceDefinitionV2Dot1Pagerduty } from "./ServiceDefinitionV2Dot1Pagerduty"; import { ServiceDefinitionV2Dot1Slack } from "./ServiceDefinitionV2Dot1Slack"; +import { ServiceDefinitionV2Dot2 } from "./ServiceDefinitionV2Dot2"; +import { ServiceDefinitionV2Dot2Contact } from "./ServiceDefinitionV2Dot2Contact"; +import { ServiceDefinitionV2Dot2Integrations } from "./ServiceDefinitionV2Dot2Integrations"; +import { ServiceDefinitionV2Dot2Link } from "./ServiceDefinitionV2Dot2Link"; +import { ServiceDefinitionV2Dot2Opsgenie } from "./ServiceDefinitionV2Dot2Opsgenie"; +import { ServiceDefinitionV2Dot2Pagerduty } from "./ServiceDefinitionV2Dot2Pagerduty"; import { ServiceDefinitionV2Email } from "./ServiceDefinitionV2Email"; import { ServiceDefinitionV2Integrations } from "./ServiceDefinitionV2Integrations"; import { ServiceDefinitionV2Link } from "./ServiceDefinitionV2Link"; @@ -1266,7 +1272,7 @@ const enumsMap: { [key: string]: any[] } = { "partial_replacement_from_beginning", "partial_replacement_from_end", ], - ServiceDefinitionSchemaVersions: ["v1", "v2", "v2.1"], + ServiceDefinitionSchemaVersions: ["v1", "v2", "v2.1", "v2.2"], ServiceDefinitionV1ResourceType: [ "doc", "wiki", @@ -1291,6 +1297,8 @@ const enumsMap: { [key: string]: any[] } = { ServiceDefinitionV2Dot1OpsgenieRegion: ["US", "EU"], ServiceDefinitionV2Dot1SlackType: ["slack"], ServiceDefinitionV2Dot1Version: ["v2.1"], + ServiceDefinitionV2Dot2OpsgenieRegion: ["US", "EU"], + ServiceDefinitionV2Dot2Version: ["v2.2"], ServiceDefinitionV2EmailType: ["email"], ServiceDefinitionV2LinkType: [ "doc", @@ -2185,6 +2193,12 @@ const typeMap: { [index: string]: any } = { ServiceDefinitionV2Dot1Opsgenie: ServiceDefinitionV2Dot1Opsgenie, ServiceDefinitionV2Dot1Pagerduty: ServiceDefinitionV2Dot1Pagerduty, ServiceDefinitionV2Dot1Slack: ServiceDefinitionV2Dot1Slack, + ServiceDefinitionV2Dot2: ServiceDefinitionV2Dot2, + ServiceDefinitionV2Dot2Contact: ServiceDefinitionV2Dot2Contact, + ServiceDefinitionV2Dot2Integrations: ServiceDefinitionV2Dot2Integrations, + ServiceDefinitionV2Dot2Link: ServiceDefinitionV2Dot2Link, + ServiceDefinitionV2Dot2Opsgenie: ServiceDefinitionV2Dot2Opsgenie, + ServiceDefinitionV2Dot2Pagerduty: ServiceDefinitionV2Dot2Pagerduty, ServiceDefinitionV2Email: ServiceDefinitionV2Email, ServiceDefinitionV2Integrations: ServiceDefinitionV2Integrations, ServiceDefinitionV2Link: ServiceDefinitionV2Link, @@ -2430,6 +2444,7 @@ const oneOfMap: { [index: string]: string[] } = { "ServiceDefinitionV1", "ServiceDefinitionV2", "ServiceDefinitionV2Dot1", + "ServiceDefinitionV2Dot2", ], ServiceDefinitionV2Contact: [ "ServiceDefinitionV2Email", @@ -2442,6 +2457,7 @@ const oneOfMap: { [index: string]: string[] } = { "ServiceDefinitionV2Dot1MSTeams", ], ServiceDefinitionsCreateRequest: [ + "ServiceDefinitionV2Dot2", "ServiceDefinitionV2Dot1", "ServiceDefinitionV2", "string", diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionSchema.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionSchema.ts index 3d1ddf292da8..4baf3f0d11e1 100644 --- a/packages/datadog-api-client-v2/models/ServiceDefinitionSchema.ts +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionSchema.ts @@ -6,6 +6,7 @@ import { ServiceDefinitionV1 } from "./ServiceDefinitionV1"; import { ServiceDefinitionV2 } from "./ServiceDefinitionV2"; import { ServiceDefinitionV2Dot1 } from "./ServiceDefinitionV2Dot1"; +import { ServiceDefinitionV2Dot2 } from "./ServiceDefinitionV2Dot2"; import { UnparsedObject } from "../../datadog-api-client-common/util"; @@ -17,4 +18,5 @@ export type ServiceDefinitionSchema = | ServiceDefinitionV1 | ServiceDefinitionV2 | ServiceDefinitionV2Dot1 + | ServiceDefinitionV2Dot2 | UnparsedObject; diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionSchemaVersions.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionSchemaVersions.ts index 6bbf7528d014..b7a792486a87 100644 --- a/packages/datadog-api-client-v2/models/ServiceDefinitionSchemaVersions.ts +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionSchemaVersions.ts @@ -14,7 +14,9 @@ export type ServiceDefinitionSchemaVersions = | typeof V1 | typeof V2 | typeof V2_1 + | typeof V2_2 | UnparsedObject; export const V1 = "v1"; export const V2 = "v2"; export const V2_1 = "v2.1"; +export const V2_2 = "v2.2"; diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2.ts new file mode 100644 index 000000000000..7e2e331b9301 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2.ts @@ -0,0 +1,151 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ +import { ServiceDefinitionV2Dot2Contact } from "./ServiceDefinitionV2Dot2Contact"; +import { ServiceDefinitionV2Dot2Integrations } from "./ServiceDefinitionV2Dot2Integrations"; +import { ServiceDefinitionV2Dot2Link } from "./ServiceDefinitionV2Dot2Link"; +import { ServiceDefinitionV2Dot2Version } from "./ServiceDefinitionV2Dot2Version"; + +import { AttributeTypeMap } from "../../datadog-api-client-common/util"; + +/** + * Service definition v2.2 for providing service metadata and integrations. + */ +export class ServiceDefinitionV2Dot2 { + /** + * Identifier for a group of related services serving a product feature, which the service is a part of. + */ + "application"?: string; + /** + * A list of contacts related to the services. + */ + "contacts"?: Array; + /** + * Unique identifier of the service. Must be unique across all services and is used to match with a service in Datadog. + */ + "ddService": string; + /** + * A short description of the service. + */ + "description"?: string; + /** + * Extensions to v2.2 schema. + */ + "extensions"?: { [key: string]: any }; + /** + * Third party integrations that Datadog supports. + */ + "integrations"?: ServiceDefinitionV2Dot2Integrations; + /** + * The service's programming language. Datadog recognizes the following languages: `dotnet`, `go`, `java`, `js`, `php`, `python`, `ruby`, and `c++`. + */ + "langauges"?: Array; + /** + * The current life cycle phase of the service. + */ + "lifecycle"?: string; + /** + * A list of links related to the services. + */ + "links"?: Array; + /** + * Schema version being used. + */ + "schemaVersion": ServiceDefinitionV2Dot2Version; + /** + * The type of service. Datadog recognizes the following service types: `database`, `cache`, `function`, `web`, `browser`, and `mobile`. + */ + "serviceType"?: string; + /** + * A set of custom tags. + */ + "tags"?: Array; + /** + * Team that owns the service. It is used to locate a team defined in Datadog Teams if it exists. + */ + "team"?: string; + /** + * Importance of the service. + */ + "tier"?: string; + + /** + * @ignore + */ + "_unparsed"?: boolean; + + /** + * @ignore + */ + static readonly attributeTypeMap: AttributeTypeMap = { + application: { + baseName: "application", + type: "string", + }, + contacts: { + baseName: "contacts", + type: "Array", + }, + ddService: { + baseName: "dd-service", + type: "string", + required: true, + }, + description: { + baseName: "description", + type: "string", + }, + extensions: { + baseName: "extensions", + type: "{ [key: string]: any; }", + }, + integrations: { + baseName: "integrations", + type: "ServiceDefinitionV2Dot2Integrations", + }, + langauges: { + baseName: "langauges", + type: "Array", + }, + lifecycle: { + baseName: "lifecycle", + type: "string", + }, + links: { + baseName: "links", + type: "Array", + }, + schemaVersion: { + baseName: "schema-version", + type: "ServiceDefinitionV2Dot2Version", + required: true, + }, + serviceType: { + baseName: "service-type", + type: "string", + }, + tags: { + baseName: "tags", + type: "Array", + }, + team: { + baseName: "team", + type: "string", + }, + tier: { + baseName: "tier", + type: "string", + }, + }; + + /** + * @ignore + */ + static getAttributeTypeMap(): AttributeTypeMap { + return ServiceDefinitionV2Dot2.attributeTypeMap; + } + + public constructor() {} +} diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Contact.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Contact.ts new file mode 100644 index 000000000000..0ad8ab93d82a --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Contact.ts @@ -0,0 +1,59 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ + +import { AttributeTypeMap } from "../../datadog-api-client-common/util"; + +/** + * Service owner's contacts information. + */ +export class ServiceDefinitionV2Dot2Contact { + /** + * Contact value. + */ + "contact": string; + /** + * Contact Name. + */ + "name"?: string; + /** + * Contact type. Datadog recognizes the following types: `email`, `slack`, and `microsoft-teams`. + */ + "type": string; + + /** + * @ignore + */ + "_unparsed"?: boolean; + + /** + * @ignore + */ + static readonly attributeTypeMap: AttributeTypeMap = { + contact: { + baseName: "contact", + type: "string", + required: true, + }, + name: { + baseName: "name", + type: "string", + }, + type: { + baseName: "type", + type: "string", + required: true, + }, + }; + + /** + * @ignore + */ + static getAttributeTypeMap(): AttributeTypeMap { + return ServiceDefinitionV2Dot2Contact.attributeTypeMap; + } + + public constructor() {} +} diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Integrations.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Integrations.ts new file mode 100644 index 000000000000..a57be5372541 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Integrations.ts @@ -0,0 +1,51 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ +import { ServiceDefinitionV2Dot2Opsgenie } from "./ServiceDefinitionV2Dot2Opsgenie"; +import { ServiceDefinitionV2Dot2Pagerduty } from "./ServiceDefinitionV2Dot2Pagerduty"; + +import { AttributeTypeMap } from "../../datadog-api-client-common/util"; + +/** + * Third party integrations that Datadog supports. + */ +export class ServiceDefinitionV2Dot2Integrations { + /** + * Opsgenie integration for the service. + */ + "opsgenie"?: ServiceDefinitionV2Dot2Opsgenie; + /** + * PagerDuty integration for the service. + */ + "pagerduty"?: ServiceDefinitionV2Dot2Pagerduty; + + /** + * @ignore + */ + "_unparsed"?: boolean; + + /** + * @ignore + */ + static readonly attributeTypeMap: AttributeTypeMap = { + opsgenie: { + baseName: "opsgenie", + type: "ServiceDefinitionV2Dot2Opsgenie", + }, + pagerduty: { + baseName: "pagerduty", + type: "ServiceDefinitionV2Dot2Pagerduty", + }, + }; + + /** + * @ignore + */ + static getAttributeTypeMap(): AttributeTypeMap { + return ServiceDefinitionV2Dot2Integrations.attributeTypeMap; + } + + public constructor() {} +} diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Link.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Link.ts new file mode 100644 index 000000000000..2d29e09512a6 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Link.ts @@ -0,0 +1,68 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ + +import { AttributeTypeMap } from "../../datadog-api-client-common/util"; + +/** + * Service's external links. + */ +export class ServiceDefinitionV2Dot2Link { + /** + * Link name. + */ + "name": string; + /** + * Link provider. + */ + "provider"?: string; + /** + * Link type. Datadog recognizes the following types: `runbook`, `doc`, `repo`, `dashboard`, and `other`. + */ + "type": string; + /** + * Link URL. + */ + "url": string; + + /** + * @ignore + */ + "_unparsed"?: boolean; + + /** + * @ignore + */ + static readonly attributeTypeMap: AttributeTypeMap = { + name: { + baseName: "name", + type: "string", + required: true, + }, + provider: { + baseName: "provider", + type: "string", + }, + type: { + baseName: "type", + type: "string", + required: true, + }, + url: { + baseName: "url", + type: "string", + required: true, + }, + }; + + /** + * @ignore + */ + static getAttributeTypeMap(): AttributeTypeMap { + return ServiceDefinitionV2Dot2Link.attributeTypeMap; + } + + public constructor() {} +} diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Opsgenie.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Opsgenie.ts new file mode 100644 index 000000000000..86b42533fa06 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Opsgenie.ts @@ -0,0 +1,51 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ +import { ServiceDefinitionV2Dot2OpsgenieRegion } from "./ServiceDefinitionV2Dot2OpsgenieRegion"; + +import { AttributeTypeMap } from "../../datadog-api-client-common/util"; + +/** + * Opsgenie integration for the service. + */ +export class ServiceDefinitionV2Dot2Opsgenie { + /** + * Opsgenie instance region. + */ + "region"?: ServiceDefinitionV2Dot2OpsgenieRegion; + /** + * Opsgenie service url. + */ + "serviceUrl": string; + + /** + * @ignore + */ + "_unparsed"?: boolean; + + /** + * @ignore + */ + static readonly attributeTypeMap: AttributeTypeMap = { + region: { + baseName: "region", + type: "ServiceDefinitionV2Dot2OpsgenieRegion", + }, + serviceUrl: { + baseName: "service-url", + type: "string", + required: true, + }, + }; + + /** + * @ignore + */ + static getAttributeTypeMap(): AttributeTypeMap { + return ServiceDefinitionV2Dot2Opsgenie.attributeTypeMap; + } + + public constructor() {} +} diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2OpsgenieRegion.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2OpsgenieRegion.ts new file mode 100644 index 000000000000..61c80b6fac56 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2OpsgenieRegion.ts @@ -0,0 +1,18 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ + +import { UnparsedObject } from "../../datadog-api-client-common/util"; + +/** + * Opsgenie instance region. + */ + +export type ServiceDefinitionV2Dot2OpsgenieRegion = + | typeof US + | typeof EU + | UnparsedObject; +export const US = "US"; +export const EU = "EU"; diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Pagerduty.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Pagerduty.ts new file mode 100644 index 000000000000..34d739ff55b7 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Pagerduty.ts @@ -0,0 +1,41 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ + +import { AttributeTypeMap } from "../../datadog-api-client-common/util"; + +/** + * PagerDuty integration for the service. + */ +export class ServiceDefinitionV2Dot2Pagerduty { + /** + * PagerDuty service url. + */ + "serviceUrl"?: string; + + /** + * @ignore + */ + "_unparsed"?: boolean; + + /** + * @ignore + */ + static readonly attributeTypeMap: AttributeTypeMap = { + serviceUrl: { + baseName: "service-url", + type: "string", + }, + }; + + /** + * @ignore + */ + static getAttributeTypeMap(): AttributeTypeMap { + return ServiceDefinitionV2Dot2Pagerduty.attributeTypeMap; + } + + public constructor() {} +} diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Version.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Version.ts new file mode 100644 index 000000000000..72f8d1502595 --- /dev/null +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionV2Dot2Version.ts @@ -0,0 +1,14 @@ +/** + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache-2.0 License. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2020-Present Datadog, Inc. + */ + +import { UnparsedObject } from "../../datadog-api-client-common/util"; + +/** + * Schema version being used. + */ + +export type ServiceDefinitionV2Dot2Version = typeof V2_2 | UnparsedObject; +export const V2_2 = "v2.2"; diff --git a/packages/datadog-api-client-v2/models/ServiceDefinitionsCreateRequest.ts b/packages/datadog-api-client-v2/models/ServiceDefinitionsCreateRequest.ts index 21773210721b..fad4758f2aff 100644 --- a/packages/datadog-api-client-v2/models/ServiceDefinitionsCreateRequest.ts +++ b/packages/datadog-api-client-v2/models/ServiceDefinitionsCreateRequest.ts @@ -5,6 +5,7 @@ */ import { ServiceDefinitionV2 } from "./ServiceDefinitionV2"; import { ServiceDefinitionV2Dot1 } from "./ServiceDefinitionV2Dot1"; +import { ServiceDefinitionV2Dot2 } from "./ServiceDefinitionV2Dot2"; import { UnparsedObject } from "../../datadog-api-client-common/util"; @@ -13,6 +14,7 @@ import { UnparsedObject } from "../../datadog-api-client-common/util"; */ export type ServiceDefinitionsCreateRequest = + | ServiceDefinitionV2Dot2 | ServiceDefinitionV2Dot1 | ServiceDefinitionV2 | string