Developer Guide
Splunk DB Connect can be easily integrated into your system. It can be used in a variety of scenarios, such as password rotation, expanding bulk action capabilities, etc.
Generate the API documentation
To call a specific functionality, use the cURL command to get the API documentation using the OpenAPI specifications:
        $ curl http://<Host>:<Task-Server-Port>/api/openapi.<json|yaml>
      
You can get the port of the task server in Splunk DB Connect > Configuration > Settings > Task Server Port, the default value is 9998.
Sample request:
Visualise the API documentation
The YAML or JSON format can be difficult to read and understand, in which case we recommend using Swagger Editor
Request an Authorization token
When you communicate with the Splunk DB Connect API, you will need to provide an authorization token on the security layer. You can request the Authorization token from Splunk:
        $ curl -k https://<Host>:<Management-Port>/services/auth/login -d "output_mode=json" --data-urlencode username=<Username> --data-urlencode password=<Password>
      
You can get the management port in Splunk > Settings > Server Settings > General Settings > Management port, the default value is 8089.
Make a request to the API
Once you've reviewed the API documentation and obtained an authorization token, you're ready to call the API.
        $ curl http://<Host>:<Task-Server-Port>/api/<resource> -H "X-DBX-SESSION_KEY:<Session-Key>"
      
Sample request to get a connection status:
        $ curl http://localhost:9998/api/connections/MySQL/status -H "X-DBX-SESSION_KEY:***"
      
Use case scenarios
Password Rotation
If you have enabled password rotation in your database server and have configured a way to notify safety you system about the new password, you can call Splunk DB Connect API to update that specific identity.
- Submit a request to update the identity: $ curl -X PUT http://<Host>:<Task-Server-Port>/api/identities/MySQL -H "Content-Type: application/json" -H "X-DBX-SESSION_KEY:***" -d '{"name": "MySQL","username": "root", "password": "root"}'
Note: it requires passing each required attribute in the body, in this case they are name, username and password.
Database outages
To disable Splunk DB Connect inputs for a given connection due to some degradation or unexpected interruptions in database performance:
- Get inputs: $ curl http://<Host>:<Task-Server-Port>/api/inputs -H "X-DBX-SESSION_KEY:***"
- Filter by given connection.
- Submit a request to disable each of the inputs, one by one:: $ curl -X PUT http://<Host>:<Task-Server-Port>/api/inputs/<Name> -H "Content-Type: application/json" -H "X-DBX-SESSION_KEY:***" -d '{"disabled": true, ...}'
Note: Each required attribute must be passed in the body. Modify the JSON object returned by the API to by changing the value from disabled to true.