Service detection API - POST an opaque web request rule
Creates a new service detection rule for opaque and external web requests.
The request consumes and produces an application/json
payload.
POST | SaaS | https://{your-environment-id}.live.dynatrace.com/api/config/v1/service/detectionRules/OPAQUE_AND_EXTERNAL_WEB_REQUEST |
Environment ActiveGate | https://{your-activegate-domain}:9999/e/{your-environment-id}/api/config/v1/service/detectionRules/OPAQUE_AND_EXTERNAL_WEB_REQUEST |
Authentication
To execute this request, you need an access token with WriteConfig
scope.
To learn how to obtain and use it, see Tokens and authentication.
Parameters
Refer to JSON models to find all JSON models that depend on the type of the model.
Parameter | Type | Description | In | Required |
---|---|---|---|---|
position | string | The position of the new rule:
| query | optional |
body | Opaque | The JSON body of the request containing parameters of the new service detection rule. You must not specify the ID of the rule! The order field is ignored in this request. To enforce a particular order, use the | body | optional |
Request body objects
The OpaqueAndExternalWebRequestRule
object
The service detection rule of the OPAQUE_AND_EXTERNAL_WEB_REQUEST
type.
Element | Type | Description | Required |
---|---|---|---|
applicationId | Application | The contribution to the service ID calculation from the detected application ID. You have two mutually exclusive options:
| optional |
conditions | Conditions | A list of conditions of the rule. If several conditions are specified, the AND logic applies. | optional |
contextRoot | Context | The contribution to the service ID calculation from the detected context root. The context root is the first segment of the request URL after server name. For example, in the You have two options:
You can use one or both options. If you use both, the transformation applies to the modified URL. | optional |
description | string | A short description of the rule. | optional |
enabled | boolean | The rule is enabled( | required |
id | string | The ID of the service detection rule. | optional |
managementZones | string[] | The management zone (specified by the ID) of the process group for which this service detection rule should be created. You can specify only 1 management zone here. | optional |
metadata | Configuration | Metadata useful for debugging | optional |
name | string | The name of the rule. | required |
order | string | The order of the rule in the rules list. The rules are evaluated from top to bottom. The first matching rule applies. | optional |
port | Port | The contribution to the service ID calculation from the port, where the web request has been detected. | optional |
publicDomainName | Public | The contribution to the service ID calculation from the domain name where the web request has been detected. You have two mutually exclusive options:
| optional |
type | string | The type of the service detection rule. | required |
The ApplicationId
object
The contribution to the service ID calculation from the detected application ID.
You have two mutually exclusive options:
- Override the detected value with a specified static value. Specify the new value in the valueOverride field.
- Dynamically transform the detected value. Specify the transformation parameters in the transformations field.
Element | Type | Description | Required |
---|---|---|---|
transformations | Transformation | Transformations to be applied to the detected value. | optional |
valueOverride | string | The value to be used instead of the detected value. | optional |
The TransformationBase
object
Configuration of transformation of the detected value.
If several transformations are specified, they are handled sequentially from top to bottom. Each transformation is applied to the result of the preceding transformation. For example, the second transformation is applied to the result of the first transformation.
The actual set of fields depends on the type of the transformation. Find the list of actual objects in the description of the type field or see Service detection API - JSON models.
Element | Type | Description | Required |
---|---|---|---|
type | string | Defines the actual set of fields depending on the value. See one of the following objects:
| required |
The ConditionsOpaqueAndExternalWebRequestAttributeTypeDto
object
A condition of the service detection rule.
Element | Type | Description | Required |
---|---|---|---|
attributeType | string | The type of the attribute to be checked.
| required |
compareOperations | Compare | A list of conditions for the rule. If several conditions are specified, the AND logic applies. | optional |
The CompareOperation
object
The condition of the rule.
The actual set of fields depends on the type of the condition. Find the list of actual objects in the description of the type field or see Service detection API - JSON models.
Element | Type | Description | Required |
---|---|---|---|
type | string | Defines the actual set of fields depending on the value. See one of the following objects:
| required |
The ContextRoot
object
The contribution to the service ID calculation from the detected context root.
The context root is the first segment of the request URL after server name. For example, in the www.dynatrace.com/support/help/dynatrace-api/
URL the context root is support
.
You have two options:
- Keep a part of the detected URL. Specify the number of segments to be kept in the segmentsToCopyFromUrlPath field.
- Dynamically transform the detected URL. Specify the transformation parameters in the transformations field.
You can use one or both options. If you use both, the transformation applies to the modified URL.
Element | Type | Description | Required |
---|---|---|---|
segmentsToCopyFromUrlPath | integer | The number of segments of the URL to be kept. The URL is divided by slashes ( For example, if you specify | optional |
transformations | Context | Transformations to be applied to the detected value. | optional |
The ContextRootTransformation
object
Configuration of transformation of the detected value.
If several transformations are specified, they are handled sequentially from top to bottom. Each transformation is applied to the result of the preceding transformation. For example, the second transformation is applied to the result of the first transformation.
The actual set of fields depends on the type
of the transformation.
Element | Type | Description | Required |
---|---|---|---|
type | string | Defines the actual set of fields depending on the value. See one of the following objects:
| required |
The ConfigurationMetadata
object
Metadata useful for debugging
Element | Type | Description | Required |
---|---|---|---|
clusterVersion | string | Dynatrace version. | optional |
configurationVersions | integer[] | A sorted list of the version numbers of the configuration. | optional |
currentConfigurationVersions | string[] | A sorted list of version numbers of the configuration. | optional |
The Port
object
The contribution to the service ID calculation from the port, where the web request has been detected.
Element | Type | Description | Required |
---|---|---|---|
doNotUseForServiceId | boolean | The port is used ( | optional |
The PublicDomainName
object
The contribution to the service ID calculation from the domain name where the web request has been detected.
You have two mutually exclusive options:
- Override the detected value with a specified static value. Specify the new value in the valueOverride field.
- Dynamically transform the detected value. Specify the transformation parameters in the transformations field.
Element | Type | Description | Required |
---|---|---|---|
copyFromHostName | boolean | Use ( Not applicable if the override is specified. | optional |
transformations | Transformation | Transformations to be applied to the detected value. | optional |
valueOverride | string | The value to be used instead of the detected value. | optional |
Request body JSON model
This is a model of the request body, showing the possible elements. It has to be adjusted for usage in an actual request.
{"applicationId": {"valueOverride": "abc"},"conditions": [{"attributeType": "URL_HOST_NAME","compareOperations": [{"ignoreCase": "false","type": "STRING_CONTAINS","values": ["value1","value2"]}]}],"contextRoot": {"segmentsToCopyFromUrlPath": 2,"transformations": [{"delimiter": "/","type": "BEFORE"}]},"description": "REST API example","enabled": true,"managementZones": ["zone1"],"name": "My sample rule","port": {"doNotUseForServiceId": "true"},"publicDomainName": {"copyFromHostName": "true","transformations": [{"delimiter": "/","type": "BEFORE"}]},"type": "OPAQUE_AND_EXTERNAL_WEB_REQUEST"}
Response
Response codes
Code | Type | Description |
---|---|---|
201 | Entity | Success. The new service detection rule has been created. The response contains short representation of the rule, including the ID. |
400 | Error | Failed. The input is invalid. |
Response body objects
The EntityShortRepresentation
object
The short representation of a Dynatrace entity.
Element | Type | Description |
---|---|---|
description | string | A short description of the Dynatrace entity. |
id | string | The ID of the Dynatrace entity. |
name | string | The name of the Dynatrace entity. |
Response body JSON model
{"description": "Dynatrace entity for the REST API example","id": "6a98d7bc-abb9-44f8-ae6a-73e68e71812a","name": "Dynatrace entity"}
Validate payload
We recommend that you validate the payload before submitting it with an actual request. A response code of 204 indicates a valid payload.
The request consumes an application/json
payload.
POST | SaaS | https://{your-environment-id}.live.dynatrace.com/api/config/v1/service/detectionRules/OPAQUE_AND_EXTERNAL_WEB_REQUEST/validator |
Environment ActiveGate | https://{your-activegate-domain}:9999/e/{your-environment-id}/api/config/v1/service/detectionRules/OPAQUE_AND_EXTERNAL_WEB_REQUEST/validator |
Authentication
To execute this request, you need an access token with WriteConfig
scope.
To learn how to obtain and use it, see Tokens and authentication.
Response
Response codes
Code | Type | Description |
---|---|---|
204 | - | Validated. The service detection rule is valid. Response doesn't have a body. |
400 | Error | Failed. The input is invalid. |