Introduction
Welcome to the DataScope API! You can use our API to access DataScope API endpoints, which can get information collected from the DataScope platform and App.
We have language bindings in Shell and Ruby! You can view code examples in the dark area to the right, and you can switch the programming language of the examples with the tabs in the top right.
Authentication
DataScope uses API keys to allow access to the API. You can register a new DataScope API key at our developer portal.
DataScope expects for the API key to be included in all API requests to the server in a header that looks like the following:
Authorization: b1cd93mfls9fdmfkadn23
Answers
Get All Answers
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/v2/answers'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/v2/answers"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"form_name":"Example Form",
"form_state":"Accepted",
"user_name":"Example User",
"user_identifier":"user@email.com",
"code":"2342",
"form_id":432,
"created_at":"2018-04-16T16:52:05.000Z",
"form_answer_id":257189,
"latitude":-33.398803,
"longitude":-70.559834,
"[question_name1]": "[question_value1]",
"[question_name2]": "[question_value2]",
"[question_name3]": "[question_value3]"
}
]
This endpoint retrieves last answers (Limit 200)
HTTP Request
GET https://www.mydatascope.com/api/external/v2/answers
Query Parameters
Parameter | Default | Description |
---|---|---|
form_id | blank | If set, only get values of one form. This ID is in the URL at the moment of modify one form. eg. https://mydatascope.com/task_forms/XXXX/edit |
user_id | blank | If set, get values of only one user |
start | last 7 days | set the start date range |
end | today | set the end date range (Max range is 90 days) |
location_id | blank | set the answers of onlye one location |
date_modified | false | Bring forms by modification date or just new ones |
limit | 200 | Number of submission, default and max is 200 |
offset | 0 | pagination to bring next 200 submissions in some date range |
Output Parameter
Parameter | Type | Description |
---|---|---|
form_code | String | Public identifier of the form answer. |
form_state | String | Last status of the form answer. |
form_id | integer | Internal code of the form, fixed to all answers of that form. |
form_answer_id | Integer | Internal code of the form answer. |
form_name | String | Name of the form. |
user_name | String | Name of the user. |
created_at | Date | When the form was received. |
latitude | Float | Latitude where the form was answered. |
longitude | Float | Longitude where the form was answered. |
question_name | (String, Date, Number) | String with each question name and value. |
Get All Answers with metadata
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/answers'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/answers"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"answers":[
{
"question_name":"Client Name",
"name":"Client",
"question_value":"Company 1",
"question_type":"select_metadata",
"subform_index":0,
"metadata_type": "locations",
"metadata_id": 4234,
"question_id":1,
"form_code":"2342",
"form_state": "Accepted",
"form_id":34543,
"form_answer_id":432432
}
],
"form_name":"Example Form",
"form_state":"Accepted",
"user_name":"Example User",
"code":"2342",
"form_id":432,
"created_at":"2018-04-16T16:52:05.000Z",
"form_answer_id":257189,
"latitude":-33.398803,
"longitude":-70.559834
"assign_id":"A32",
"assign_internal_id":"4322",
"assign_location_name":"Client 1 Factory A",
"assign_location_description":"description Client 1",
"assign_location_code":"client1",
}
]
This endpoint retrieves last answers (Limit 600)
HTTP Request
GET https://www.mydatascope.com/api/external/answers
Query Parameters
Parameter | Default | Description |
---|---|---|
form_id | blank | If set, only get values of one form |
user_id | blank | If set, get values of only one user |
start | last 7 days | set the start date range |
end | today | set the end date range |
location_id | blank | set the answers of onlye one location |
Output Parameter
Parameter | Type | Description |
---|---|---|
answers | Array | array with all the question of the specific form answer. |
question_name | String | The name of the grouped question. |
name | String | Name of the specific Question. |
question_type | String | Type of the question. |
subform_index | Integer | If use a subform indicate the iteration inside the subform. |
metadata_id | Integer | Identifier of the metadata object of the List |
metadata_type | String | Identifier of the list of metadata (location, products, and more) |
question_id | Integer | Internal identifier of the question. |
form_code | String | Public identifier of the form answer. |
form_state | String | Last status of the form answer. |
form_id | integer | Internal code of the form, fixed to all answers of that form. |
form_answer_id | Integer | Internal code of the form answer. |
form_name | String | Name of the form. |
user_name | String | Name of the user. |
created_at | Datetime | When the form was received. |
latitude | Float | Latitude where the form was answered. |
longitude | Floar | Longitude where the form was answered. |
finished | Boolean | Identify if synchronization process finished. |
updated_at | Datetime | Last date and time When the form was updated |
assign_id | Integer | Assign ID generated by user |
assign_internal_id | Integer | Assign ID generated by system |
assign_location_name | String | Name of the location of the assigned Task |
assign_location_description | String | Description of the location assigned |
assign_location_code" | String | Code of the location assigned |
Change Answer
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/change_form_answer'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/change_form_answer"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"status": "ok",
"form_answer": {
"id": "4325235",
"form_id": "6344234"
}
}
]
HTTP Request
POST https://www.mydatascope.com/api/external/change_form_answer
Query Parameters
Parameter | Description |
---|---|
form_name | name of ID of the form |
form_code | Code of the response |
question_name | Name of the question to change |
question_value | Value of the question to change |
subform_index | Number to specify the subform index (Starting from 1). Leave blank if question it's not inside subform*. |
Locations
Get All Locations
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/locations'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/locations"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"id":432432,
"name":"Client ABC",
"description":"Company ABC description",
"code":"534534",
"address":"1600 Amphitheatre Parkway, Mountain View, CA",
"city":"SF",
"country":"US",
"latitude":37.395013,
"longitude":-122.084374,
"region":"CA",
"phone":"4324234",
"company_code":"432432",
"company_name":"Client ABC S.A"
}
]
This endpoint retrieves all locations
HTTP Request
GET https://www.mydatascope.com/api/external/locations
Output Parameter
Parameter | Type | Description |
---|---|---|
id | Integer | Internal identifier of the location |
name | String | Name of the location |
description | String | Description of the location |
code | String | Code of the location |
address | Integer | Address of the location |
city | Integer | City |
country | String | Country |
latitude | String | Latitude GPS Coordinates |
longitude | integer | Longitude GPS Coordinates |
region | Integer | Region |
phone | String | Phone |
company_code | String | Code of the company |
company_name | Date | Name of the Company |
Create a Location
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/locations'
response = RestClient.post url, {
location: {
name: "Test Location",
description: "This is a test location created by API",
code: "LOC_TEST01",
company_code: "DSCODE_1",
company_name: "Datascope Home",
address: "P. Sherman, 42 Wallaby Way",
city: "Sydney",
country: "Australia",
latitude: -33.673992,
longitude: 151.285829,
phone: "+18888888",
email: "location@test.com"
}
}.to_json, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/locations"
-H "Authorization: b1cd93mfls9fdmfkadn23"
-X POST
-d '{
"location": {
"name": "Test Location",
"description": "This is a test location created by API",
"code": "LOC_TEST01",
"company_code": "DSCODE_1",
"company_name": "Datascope Home",
"address": "P. Sherman, 42 Wallaby Way",
"city": "Sydney",
"country": "Australia",
"latitude": -33.673992,
"longitude": 151.285829,
"phone": "+18888888",
"email": "location@test.com"
}
}'
When successfull the above command returns JSON structured like this, you can check the description of each parameter below:
{
"id": "123456",
"name": "Test Location",
"description": "This is a test location created by API",
"code": "LOC_TEST01",
"company_code": "DSCODE_1",
"company_name": "Datascope Home",
"address": "P. Sherman, 42 Wallaby Way",
"city": "Sydney",
"country": "Australia",
"latitude": -33.673992,
"longitude": 151.285829,
"phone": "+18888888",
"email": "location@test.com"
}
This endpoint create a location
HTTP Request
POST https://www.mydatascope.com/api/external/locations
Input Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the location |
description | String | Description of the location |
code | String | Code of the location |
address | Integer | Address of the location |
city | Integer | City |
country | String | Country |
latitude | String | Latitude GPS Coordinates |
longitude | integer | Longitude GPS Coordinates |
phone | String | Phone |
company_code | String | Code of the company |
company_name | Date | Name of the Company |
String | Email of the Company |
Return Codes:
Code | Description |
---|---|
201 | Successfull |
403 | Forbidden |
422 | Wrong parameters, check documentation |
Update a Location
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/locations/123456'
response = RestClient.post url, {
location: {
name: "Test Location",
description: "This is a test location created by API",
code: "LOC_TEST01",
company_code: "DSCODE_1",
company_name: "Datascope Home",
address: "P. Sherman, 42 Wallaby Way",
city: "Sydney",
country: "Australia",
latitude: -33.673992,
longitude: 151.285829,
phone: "+18888888",
email: "location@test.com"
}
}.to_json, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/locations/123456"
-H "Authorization: b1cd93mfls9fdmfkadn23"
-X POST
-d '{
"location": {
"name": "Test Location",
"description": "This is a test location created by API",
"code": "LOC_TEST01",
"company_code": "DSCODE_1",
"company_name": "Datascope Home",
"address": "P. Sherman, 42 Wallaby Way",
"city": "Sydney",
"country": "Australia",
"latitude": -33.673992,
"longitude": 151.285829,
"phone": "+18888888",
"email": "location@test.com"
}
}'
When successfull the above command returns JSON structured like this, you can check the description of each parameter below:
{
"id": "123456",
"name": "Test Location",
"description": "This is a test location created by API",
"code": "LOC_TEST01",
"company_code": "DSCODE_1",
"company_name": "Datascope Home",
"address": "P. Sherman, 42 Wallaby Way",
"city": "Sydney",
"country": "Australia",
"latitude": -33.673992,
"longitude": 151.285829,
"phone": "+18888888",
"email": "location@test.com"
}
This endpoint updates a location
HTTP Request
POST https://www.mydatascope.com/api/external/locations
Input Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the location |
description | String | Description of the location |
code | String | Code of the location |
address | Integer | Address of the location |
city | Integer | City |
country | String | Country |
latitude | String | Latitude GPS Coordinates |
longitude | integer | Longitude GPS Coordinates |
phone | String | Phone |
company_code | String | Code of the company |
company_name | Date | Name of the Company |
String | Email of the Company |
Return Codes:
Code | Description |
---|---|
201 | Successfull |
403 | Forbidden |
422 | Wrong parameters, check documentation |
Lists
Get All List elements
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_objects'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => { metadata_type: 'products_examples'}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_objects"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"id":505680,
"name":"Product 1",
"description":"Product Description",
"attribute1":"Atribute example 1",
"attribute2":"Attribute example 2",
"list_id":424324,
"account_id":4234234,
"code":"prod0",
"created_at":"2015-12-03T17:48:47.000-02:00",
"updated_at":"2015-12-03T17:48:47.000-02:00"
},
{
"id":505689,
"name":"Product 2",
"description":"Product Description",
"attribute1":"Atribute example 1",
"attribute2":"Attribute example 2",
"list_id":424324,
"account_id":4234234,
"code":"prod9",
"created_at":"2018-12-03T17:48:47.000-02:00",
"updated_at":"2018-12-03T17:48:47.000-02:00"
}
]
This endpoint retrieves all list items of a specific list
HTTP Request
GET https://www.mydatascope.com/api/external/metadata_objects
Query Parameters
Parameter | Default | Description |
---|---|---|
metadata_type | blank | Internal code to identify the list (products, locations and more) |
Output Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the element of the list |
description | String | Description of the element of the list |
attribute1 | String | Custom attribute of the element of the list |
attribute2 | String | Custom attribute of the element of the list |
created_at | Datetime | Date when the list element was created |
updated_at | Datetime | Date when the list element was updated |
Get an element of the list
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_object'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => { metadata_type: 'products_examples', metadata_id: 4324324}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_object"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
{
"id":505680,
"name":"Product 1",
"description":"Product Description",
"attribute1":"Atribute example 1",
"attribute2":"Attribute example 2",
"list_id":424324,
"account_id":4234234,
"code":"prod0",
"created_at":"2015-12-03T17:48:47.000-02:00",
"updated_at":"2015-12-03T17:48:47.000-02:00"
}
This endpoint retrieves a specific element of the list
HTTP Request
GET https://www.mydatascope.com/api/external/metadata_object
Query Parameters
Parameter | Default | Description |
---|---|---|
metadata_type | blank | Internal code to identify the list (products, locations and more) |
metadata_id | blank | Internal identifier of the element of the list |
Output Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the element of the list |
description | String | Description of the element of the list |
attribute1 | String | Custom attribute of the element of the list |
attribute2 | String | Custom attribute of the element of the list |
created_at | Datetime | Date when the list element was created |
updated_at | Datetime | Date when the list element was updated |
Create a List Element
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_object?metadata_type=LIST_TEST2'
response = RestClient.post url, {
list_object: {
name: "Test List Object 2",
description: "This is a test Object created by API",
code: "LIST_OBJECT_TEST2",
attribute1: "ATTR1",
attribute2: "ATTR2"
}
}.to_json, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_object?metadata_type=LIST_TEST2"
-H "Authorization: b1cd93mfls9fdmfkadn23"
-X POST
-d '{
"list_object": {
"name": "Test List Object 2",
"description": "This is a test Object created by API",
"code": "LIST_OBJECT_TEST2",
"attribute1": "ATTR1",
"attribute2": "ATTR2"
}
}'
When successfull the above command returns JSON structured like this, you can check the description of each parameter below:
{
"id": 123456,
"name": "Test List Object 2",
"description": "This is a test Object created by API",
"code": "LIST_OBJECT_TEST2",
"created_at": "2024-09-05T06:31:59.000-03:00",
"updated_at": "2024-09-05T06:31:59.000-03:00",
"metadata_type": "LIST_TEST2"
}
This endpoint creates a list element
HTTP Request
POST https://www.mydatascope.com/api/external/metadata_object
Query params:
Parameter | Type | Description |
---|---|---|
metadata_type | blank | Internal code to identify the list (products, and more*) |
*For locations objects use locations API
Input Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the element of the list |
description | String | Description of the element of the list |
code | String | Internal code of the element of the list |
attribute1 | String | Custom attribute of the element of the list |
attribute2 | String | Custom attribute of the element of the list |
Return Codes:
Code | Description |
---|---|
201 | Successfull |
403 | Forbidden |
422 | Wrong parameters, check documentation |
Update a List Element
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_object/123456'
response = RestClient.post url, {
list_object: {
name: "Test List Object 2",
description: "This is a test Object created by API",
code: "LIST_OBJECT_TEST2",
attribute1: "ATTR1",
attribute2: "ATTR2"
}
}.to_json, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_object/123456"
-H "Authorization: b1cd93mfls9fdmfkadn23"
-X POST
-d '{
"list_object": {
"name": "Test List Object 2",
"description": "This is a test Object created by API",
"code": "LIST_OBJECT_TEST2",
"attribute1": "ATTR1",
"attribute2": "ATTR2"
}
}'
When successfull the above command returns JSON structured like this, you can check the description of each parameter below:
{
"id": 123456,
"name": "Test List Object 2",
"description": "This is a test Object created by API",
"code": "LIST_OBJECT_TEST2",
"created_at": "2024-09-05T06:31:59.000-03:00",
"updated_at": "2024-09-05T06:31:59.000-03:00",
"metadata_type": "LIST_TEST2"
}
This endpoint updates a list object
HTTP Request
POST https://www.mydatascope.com/api/external/metadata_object/{id}
Input Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the element of the list |
description | String | Description of the element of the list |
code | String | Internal code of the element of the list |
attribute1 | String | Custom attribute of the element of the list |
attribute2 | String | Custom attribute of the element of the list |
Return Codes:
Code | Description |
---|---|
201 | Successfull |
403 | Forbidden |
422 | Wrong parameters, check documentation |
Create a empty List
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_types'
response = RestClient.post url, {
list: {
name: "Test List",
description: "This is a test location created by API",
code: "LIST_TEST",
list_type: "standard"
}
}.to_json, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_types"
-H "Authorization: b1cd93mfls9fdmfkadn23"
-X POST
-d '{
"list": {
"name": "Test List",
"description": "This is a test location created by API",
"code": "LIST_TEST",
"list_type": "standard"
}
}'
When successfull the above command returns JSON structured like this, you can check the description of each parameter below:
{
"id": 123456,
"name": "Test List",
"description": "This is a test location created by API",
"code": "LIST_TEST",
"list_type": "standard"
}
This endpoint creates a empty list
HTTP Request
POST https://www.mydatascope.com/api/external/metadata_types
Input Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the element of the list |
description | String | Description of the element of the list |
code | String | Internal code of the element of the list |
list_type | String | Valid values: ("standard", "percent", "price") |
Return Codes:
Code | Description |
---|---|
201 | Successfull |
403 | Forbidden |
422 | Wrong parameters, check documentation |
Update a List
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_types/123456'
response = RestClient.post url, {
list: {
name: "Test List",
description: "This is a test location created by API",
code: "LIST_TEST",
list_type: "standard"
}
}.to_json, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_types/123456"
-H "Authorization: b1cd93mfls9fdmfkadn23"
-X POST
-d '{
"list": {
"name": "Test List",
"description": "This is a test location created by API",
"code": "LIST_TEST",
"list_type": "standard"
}
}'
When successfull the above command returns JSON structured like this, you can check the description of each parameter below:
{
"id": 123456,
"name": "Test List",
"description": "This is a test location created by API",
"code": "LIST_TEST",
"list_type": "standard"
}
This endpoint updates a list
HTTP Request
POST https://www.mydatascope.com/api/external/metadata_types/{id}
Input Parameter
Parameter | Type | Description |
---|---|---|
name | String | Name of the element of the list |
description | String | Description of the element of the list |
code | String | Internal code of the element of the list |
list_type | String | Valid values: ("standard", "percent", "price") |
Return Codes:
Code | Description |
---|---|
201 | Successfull |
403 | Forbidden |
422 | Wrong parameters, check documentation |
Bulk Update List Elements
This endpoint allows bulk updating of metadata list objects, with soft deletion of objects not in the incoming list. If an object with an existing code is provided, it will be updated. If a new code is used, the object will be created.
Warning: This operation will delete all existing objects for the specified metadata_type and replace them with the new objects provided. This endpoint is currently in an experimental stage. Changes may be made to functionality or structure as we continue testing and refining its implementation.
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/metadata_objects/bulk_update'
response = RestClient.post url, {
metadata_type: "your_list_code",
name: "Safety Equipment List",
list_objects: [
{
code: "PPE001",
name: "Helmet",
description: "Safety helmet in good condition",
attribute1: "Mandatory",
attribute2: "Daily check"
},
{
code: "PPE002",
name: "Boots",
description: "Steel-toed safety boots",
attribute1: "Mandatory",
attribute2: "Check for wear"
},
{
code: "PPE003",
name: "Glasses",
description: "Safety glasses with side shields",
attribute1: "Mandatory",
attribute2: "Clean daily"
}
]
}.to_json, {
:Authorization => '<YOUR_API_TOKEN>',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/metadata_objects/bulk_update"
-H "Authorization: <YOUR_API_TOKEN>"
-X POST
-d '{
"metadata_type": "your_list_code",
"name": "Safety Equipment List",
"list_objects": [
{
"code": "PPE001",
"name": "Helmet",
"description": "Safety helmet in good condition",
"attribute1": "Mandatory",
"attribute2": "Daily check"
},
{
"code": "PPE002",
"name": "Boots",
"description": "Steel-toed safety boots",
"attribute1": "Mandatory",
"attribute2": "Check for wear"
},
{
"code": "PPE003",
"name": "Glasses",
"description": "Safety glasses with side shields",
"attribute1": "Mandatory",
"attribute2": "Clean daily"
}
]
}'
When successful, the above command returns JSON structured like this:
{
"id": 1,
"name": "Safety Equipment List",
"description": "List for safety equipment",
"code": "your_list_code",
"list_type": "standard",
"length": 3
}
HTTP Request
POST https://www.mydatascope.com/api/external/metadata_objects/bulk_update
Input Parameters
Parameter | Type | Description |
---|---|---|
metadata_type | String | Internal code to identify the list (must not be "locations") |
name | String | Name of the list to be created or updated |
list_objects | Array | Array of objects to be created or updated |
List Object Structure
Each object in the list_objects
array should have the following structure:
Parameter | Type | Description |
---|---|---|
code | String | Internal code of the list element |
name | String | Name of the list element |
description | String | Description of the list element |
attribute1 | String | Custom attribute of the list element |
attribute2 | String | Custom attribute of the list element |
Return Codes
Code | Description |
---|---|
200 | Successful |
400 | Bad Request if metadata_type is locations |
403 | Forbidden |
422 | Wrong parameters, check documentation |
500 | Internal Server Error |
Response
The response includes:
Field | Type | Description |
---|---|---|
id | Integer | ID of the updated list |
name | String | Name of the updated list |
description | String | Description of the updated list |
code | String | Code for the updated list |
list_type | String | Type of the list |
length | Integer | Number of active list objects |
Task Assigns
Create Task Assign
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/assign_task'
response = RestClient.post url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => {}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/assign_task"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"form_id":432432,
"user_id": "user1@email.com",
"date":"2021-05-10 15:00",
"l_code":"l25",
"task_instruction":"",
"gap":"5"
}
]
HTTP Request
POST https://www.mydatascope.com/api/external/assign_task
Query Parameters
Parameter | Type | Description |
---|---|---|
form_id | Integer | Internal identifier of the Form. ID in the URL https://www.mydatascope.com/task_forms/[ID]/edit |
user_id | String | User Email |
date | Datetime | Date of the assigned Task (YYY-mm-dd HH:MM) |
l_code | String | Code of the Location |
location_name | String | Name of the location. Only needed if need to create or update |
location_address | String | Address of the Location |
l_phone | String | Phone of the Location |
l_email | String | Email of the Location |
c_name | String | Company Name of the location |
c_code | String | Company tax id of the location |
latitude | String | Latitude of the location |
longitude | String | Longitude of the location |
task_instruction | String | Instruction of the task |
gap | Integer | Hours to perform task |
code | String | Code to identify the task |
Notifications
List Last notifications
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/notifications'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => { start: '10/12/2019', end: '30/12/2019'}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/notifications"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"id":2345,
"type":"PDF",
"url":"https://www.mydatascope.com/pdf_url_example",
"form_name":"Form Name",
"form_code":"25",
"user":"user@email.com",
"created_at":"2019-12-03T17:48:47.000-02:00"
}]
This endpoint retrieves all list items of a specific list
HTTP Request
GET https://www.mydatascope.com/api/external/notifications
Query Parameters
Parameter | Default | Description |
---|---|---|
start | last 7 days | set the start date range |
end | today | set the end date range |
Output Parameter
Parameter | Type | Description |
---|---|---|
id | String | Identifier of the notification |
type | String | Type of notification: PDF or Excel |
url | String | URL of the notified file |
form_name | String | Name of the form |
form_code | String | Code of the form |
user | String | Name of the user |
created_at | Datetime | Date when the list element was created |
updated_at | Datetime | Date when the list element was updated |
Files
List Last generated files
require 'rest-client'
require 'json'
url = 'https://www.mydatascope.com/api/external/files'
response = RestClient.get url, {
:Authorization => 'b1cd93mfls9fdmfkadn23',
:params => { start: '10/12/2019', end: '30/12/2019'}
}
JSON.parse(response)
curl "https://www.mydatascope.com/api/external/files"
-H "Authorization: b1cd93mfls9fdmfkadn23"
The above command returns JSON structured like this, you can check the description of each parameter below:
[
{
"id":2345,
"type":"PDF",
"url":"https://www.mydatascope.com/pdf_url_example",
"form_name":"Form Name",
"form_code":"25",
"user":"user@email.com"
}]
This endpoint retrieves all list items of a specific list
HTTP Request
GET https://www.mydatascope.com/api/external/files
Query Parameters
Parameter | Default | Description |
---|---|---|
start | last 7 days | set the start date range |
end | today | set the end date range |
Output Parameter
Parameter | Type | Description |
---|---|---|
id | String | Identifier of the notification |
type | String | Type of notification: PDF or Excel |
url | String | URL of the notified file |
form_name | String | Name of the form |
form_code | String | Code of the form |
user | String | Name of the user |
Webhooks
Sometimes people call webhooks reverse APIs, but perhaps more accurately a webhook lets you skip a step. With most APIs there’s a request followed by a response. No request is required for a webhook, it just sends the data when it’s available.
To use a webhook, you register a URL with the company providing the service. That URL is a place within your application that will accept the data and do something with it. In some cases, you can tell the provider the situations when you’d like to receive data. Whenever there’s something new, the webhook will send it to your URL.
DataScope Webhook notifications are sent in an HTTP POST request, and their contents (containing the response data) are in JSON format.
Configuration
To configure the webhook you need to go to the Integrations section and then Webhooks and click on New Webhook.
Output
The webhook will return a JSON with this structure:
[{
"form_name": "[Form Name] (String)",
"code": "[Code Form ID] (String)",
"latitude": "[latitude] (Float)",
"longitude": "[longitude] (Float)",
"[question_name][question_id]": {
"name": "[Question name] (String)",
"label": "[Section Name] (String)",
"row" "[Nº repeatable field] (Integer) Default: null",
"value": "[Value of the answer] (String)",
"type": "[Type of question]*",
"id": "[Internal ID of the question] (Integer)"
}
}]
Errors
The DataScope API uses the following error codes:
Error Code | Meaning |
---|---|
400 | Bad Request -- Your request is invalid. |
401 | Unauthorized -- Your API key is wrong. |
403 | Forbidden -- The DataScope requested is hidden for administrators only. |
404 | Not Found -- The specified request could not be found. |
405 | Method Not Allowed -- You tried to access with an invalid method. |
406 | Not Acceptable -- You requested a format that isn't json. |
429 | Too Many Requests -- You're requesting too much! Slow down! |
500 | Internal Server Error -- We had a problem with our server. Try again later. |
503 | Service Unavailable -- We're temporarily offline for maintenance. Please try again later. |