The Custom device endpoint of the Topology and Smartscape API enables you to create a custom device with a specified name in your Dynatrace environment.
This page describes how to create a custom device without sending any data to it.
To learn how to report data to a custom device, see Report custom device metric via REST API.
The request consumes and produces an application/json
payload.
POST | SaaS | https://{your-environment-id}.live.dynatrace.com/api/v1/entity/infrastructure/custom/{customDeviceId} |
Environment ActiveGate | https://{your-activegate-domain}:9999/e/{your-environment-id}/api/v1/entity/infrastructure/custom/{customDeviceId} |
To execute this request, you need an access token with DataExport
scope.
To learn how to obtain and use it, see Tokens and authentication.
For this use case, the series element of the request body must be omitted.
The ID of the custom device.
If you use the ID of an existing device, the respective parameters will be updated.
Don't use Dynatrace entity ID here.
The JSON body of the request. Contains parameters of a custom device.
CustomDevicePushMessage
objectConfiguration of a custom device.
The URL of a configuration web page for the custom device, such as a login page for a firewall or router.
The name of the custom device that will appear in the user interface.
The icon to be displayed for your custom component within Smartscape. Provide the full URL of the icon file.
User defined group ID of entity.
The group ID helps to keep a consistent picture of device-group relations. One of many cases where a proper group is important is service detection: you can define which custom devices should lead to the same service by defining the same group ID for them.
If you set a group ID, it will be hashed into the Dynatrace entity ID of the custom device. In that case the custom device can only be part of one custom device group.
If you don't set the group ID, Dynatrace will create it based on the ID or type of the custom device. Also, the group will not be hashed into the device ID which means the device may switch groups.
The list of host names related to the custom device.
These names are used to automatically discover the horizontal communication relationship between this component and all other observed components within Smartscape. Once a connection is discovered, it is automatically mapped and shown within Smartscape.
If you send a value, the existing values will be overwritten.
If you send null
or an empty value; or omit this field, the existing values will be kept.
The list of IP addresses that belong to the custom device.
These addresses are used to automatically discover the horizontal communication relationship between this component and all other observed components within Smartscape. Once a connection is discovered, it is automatically mapped and shown within Smartscape.
If you send a value (including an empty value), the existing values will be overwritten.
If you send null
or omit this field, the existing values will be kept.
EntityTimeseriesData
objectInformation about a metric and its data points.
List of data points.
Each data point is an array, containing the timestamp and the value.
Timestamp is UTC milliseconds reported as a number, for example: 1520523365557
.
You have the guaranteed timeframe of 30 minutes into the past.
A custom metric must be registered before you can report a metric value. Therefore, the timestamp for reporting a value must be after the registration time of the metric.
Dimensions of the data points you're posting.
The key of the metric dimension must be defined earlier in the metric definition.
The ID of the metric, where you want to post data points.
This is a model of the request body, showing the possible elements. It has to be adjusted for usage in an actual request.
{"configUrl": "http://coffee-machine.dynatrace.internal.com/coffeemachine/manage","displayName": "coffeeMachine","favicon": "https://www.freefavicon.com/freefavicons/food/cup-of-coffee-152-78475.png","group": "myCustomDeviceGroup","hostNames": ["coffee-machine.dynatrace.internal.com"],"ipAddresses": ["10.0.0.1"],"listenPorts": [80],"properties": {},"series": [{"dataPoints": [[1521542929000,13]],"dimensions": {"office": "Linz"},"timeseriesId": "custom:created.coffee.metric"}],"tags": ["office-linz"],"type": "coffee machine"}
CustomDevicePushResult
objectThe result of a custom device push request. The entity ID is calculated automatically.
The Dynatrace entity ID of the custom device.
The Dynatrace entity ID of the custom device group.
{"entityId": "string","groupId": "string"}
In this example, the request creates custom device idOfmyCustomDevice
of type F5-Firewall
, with IP address 172.16.115.211
and listen port 9999
. The request also specifies some additional parameters.
See Report custom device metric via the Dynatrace API to learn how to submit data to the newly created custom device.
The API token is passed in the Authorization header.
The request returns the IDs of the custom device (see entityId
) and its group (see groupId
) as confirmation.
You can download or copy the example request body to try it out on your own.
curl -X POST \https://mySampleEnv.live.dynatrace.com/api/v1/entity/infrastructure/custom/idOfmyCustomDevice \-H 'Authorization: Api-Token dt0c01.abc123.abcdefjhij1234567890'-H 'Content-Type: application/json' \-d '{"displayName" : "F5 Firewall 24","ipAddresses" : ["172.16.115.211"],"listenPorts" : ["9999"],"type" : "F5-Firewall","favicon" : "http://assets.dynatrace.com/global/icons/f5.png","configUrl" : "http://192.128.0.1:8080","tags": ["REST example"],"properties" : {"Sample Property 1": "Sample value 1"}}'
https://mySampleEnv.live.dynatrace.com/api/v1/entity/infrastructure/custom/idOfmyCustomDevice
{"displayName": "F5 Firewall 24","ipAddresses": ["172.16.115.211"],"listenPorts": ["9999"],"type": "F5-Firewall","favicon": "http://assets.dynatrace.com/global/icons/f5.png","configUrl": "http://192.128.0.1:8080","tags": ["REST example"],"properties": {"Sample Property 1": "Sample value 1"}}
{"entityId": "CUSTOM_DEVICE-6A567B33AADC306E","groupId": "CUSTOM_DEVICE_GROUP-FC2E2ABF54F513D8"}
200