This API provides common access to Open010 protocol (311 protocol based) from Mejora Tu Ciudad MTC.
This API is mainly public, however, users can log in through the login process (Oauth 2.0), providing some special features.
Once logged in, you must send Authorization
header with the following format.
Authorization: Bearer your_auth_token
POST
- Creates or updates a resource
GET
- Retrieves a resource or list of resources
200 OK
- The request was successful (some API calls may return 201 instead).
400 Bad Request
- The request could not be understood or was missing required parameters.
403 Forbidden
- Access denied.
404 Not Found
- Resource was not found.
405 Method Not Allowed
- Requested method is not supported for the specified resource.
501 Not implemented
- The server does not support the facility required.
503 Service Unavailable
- The service is temporary unavailable (e.g. scheduled Platform Maintenance). Try again later.
If the request is done by a deprecated application version it can receive a 409 response if the update is mandatory, or a 209 if it is optional. The content response will be as follows:
{
error: 409,
message: "It is required to update this application",
}
The message
is a settable text that must be displayed to the end user.
This error can be received if the device is banned.
User-Agent
: android
, ios
, widget
, other
- Identify the platform that is executing the request.
X-Device-ID
- Unique identification of the device
X-API-Version
- Operating API version, it use to be the mayor version of the app.
X-APP-Version
- Version on the app [mayor].[minor].[build]
Accept-Language
- Supported language of the device
User authentication process
Field | Required | Possible values | Description |
---|---|---|---|
client_id | required | string | Oauth 2.0 client code |
app_key | required | string | MTC Application key |
username | required | string | User or email. |
password | required | string | User password. |
remote_access_token | required | string | facebook acces_token or google acces_token. |
register | optional | boolean | If true, registers user with given credentials when does not exist previously in database. |
first_name | optional | string | User first name. |
last_name | optional | string | User last name |
jurisdiction_id | optional | string | Jurisdiction to associate user with. |
notification_account_code | optional | string | Android or iOS device application id (used to send push notifications). |
device_type | optional | string | One of [ios, android, desktop]. Required if notification_account_code is provided |
device_brand | optional | string | Device Brand. Required if notification_account_code is provided |
device_model | optional | string | Device Model. Required if notification_account_code is provided |
device_os_version | optional | string | Device Os Version. Required if notification_account_code is provided |
username | deprecated | string | Deprecated since 3.0. To be removed in future versions. |
google_token | deprecated | string | Deprecated since 3.0. To be removed in future versions. |
user_id | deprecated | string | Deprecated since 3.0. To be removed in future versions. |
Login or register with username and password
Accept: application/json
Content-Type: application/json
{
"client_id":"52fb43b4a780378d298b456b_1kthjgfcfmas8o8c4c40848gsc0s0cso0sgkwwksks4o0g4cg4",
"app_key":"1",
"username":"helysm@radmas.com",
"password":"123456",
"notification_account_code":"APA91bEVoMYJDwzeTX3kYJml03WdVY-xPWokIx1_Ixm7L1Vfy214Mhh3c17OvOPhx3SP3fDv3vyy9YgkJBe9xUz9959dgdl7HOwBi-srgoKvqZXzG6tMqaSxpQ7I44P5Z5vZj3GQo6sF",
"device_type":"android",
"device_brand":"Nokia",
"device_model":"M111",
"device_os_version":"3.3"
}
200
ShowHideContent-Type: application/json
{
"access_token":"MjJlZGVjYTI1ZTAzZTljMzkzZjkyYTRiY",
"expires_in":604800,
"token_type":"bearer",
"refresh_token":"OTc1ODk0MjAxMzljNzk2Y2IyMzY1Njkw"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "User was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "not logged"
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Wrong password"
}
]
Login or register with facebook
Accept: application/json
Content-Type: application/json
{
"client_id":"52fb43b4a780378d298b456b_1kthjgfcfmas8o8c4c40848gsc0s0cso0sgkwwksks4o0g4cg4",
"app_key":"1",
"remote_access_token":"hjgfcfmas8o8c4c40848gsc0s0cso0s",
"notification_account_code":"APA91bEVoMYJDwzeTX3kYJml03WdVY-xPWokIx1_Ixm7L1Vfy214Mhh3c17OvOPhx3SP3fDv3vyy9YgkJBe9xUz9959dgdl7HOwBi-srgoKvqZXzG6tMqaSxpQ7I44P5Z5vZj3GQo6sF",
"device_type":"android",
"device_brand":"Nokia",
"device_model":"M111",
"device_os_version":"3.3"
}
200
ShowHideContent-Type: application/json
{
"access_token":"MjJlZGVjYTI1ZTAzZTljMzkzZjkyYTRiY",
"expires_in":604800,
"token_type":"bearer",
"refresh_token":"OTc1ODk0MjAxMzljNzk2Y2IyMzY1Njkw"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "not logged"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "facebook credentials not provided"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "facebook denied access"
}
Login or register with Google Plus
Accept: application/json
Content-Type: application/json
{
"client_id":"52fb43b4a780378d298b456b_1kthjgfcfmas8o8c4c40848gsc0s0cso0sgkwwksks4o0g4cg4",
"app_key":"1",
"remote_access_token":"hjgfcfmas8o8c4c40848gsc0s0cso0s",
"notification_account_code":"APA91bEVoMYJDwzeTX3kYJml03WdVY-xPWokIx1_Ixm7L1Vfy214Mhh3c17OvOPhx3SP3fDv3vyy9YgkJBe9xUz9959dgdl7HOwBi-srgoKvqZXzG6tMqaSxpQ7I44P5Z5vZj3GQo6sF",
"device_type":"android",
"device_brand":"Nokia",
"device_model":"M111",
"device_os_version":"3.3"
}
200
ShowHideContent-Type: application/json
{
"access_token":"MjJlZGVjYTI1ZTAzZTljMzkzZjkyYTRiY",
"expires_in":604800,
"token_type":"bearer",
"refresh_token":"OTc1ODk0MjAxMzljNzk2Y2IyMzY1Njkw"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Google API key was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "not logged"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "google credentials not provided"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "google denied access"
}
Logout from server, if device_id
is supplied, it will be removed from database. Authorization header is required.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"device_id" : "52fb43b4a780378d298b456b_1kthjgfcfmas8o8c4c40848gsc0s0cso0sgkwwksks4o0g4cg4"
}
200
ShowHideContent-Type: application/json
{
"code": 200,
"description": "successfully logged out"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "logout failed"
}
403
ShowHideContent-Type: application/json
{
"error": "invalid grant",
"error_description": "The access token provided is invalid."
}
Sends an e-mail to user to continue the reset password flow.
Accept: application/json
Content-Type: application/json
{
"username": "helysm@radmas.com",
"jurisdiction_id":"es.madrid",
"app_key":"1"
}
200
ShowHideContent-Type: application/json
{
"code": 200,
"description": "E-mail sent to user"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "user was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "application was not provided"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "user was not found"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "application was not found"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "jurisdiction was not found"
}
User configuration api calls. Authorization
header must be sent.
Field | Required | Description |
---|---|---|
notification_account_code | required | Application specific notification account code. |
device_type | required string | OriginDevice id provided in jurisdiction. |
app_key | required | app_key of related application. |
jurisdiction_id | required | Jurisdiction Id. |
widget_buttons_ids | optional array | Ids list of widgets that will be stored by the user as preferred and their display order. |
id | optional string | Identification User Id. |
optional string | Email to User. | |
first_name | optional string | First name to User login. |
nickname | optional string | Nickname to User login. |
old_password | optional string | Old Password to User login. |
new_password | optional string | New Password to User login. |
configuration | optional array | List Options configurations general to User. |
email_notification | optional array | List Options configurations email notification. |
app_notification | optional array | List Options configurations app notification. |
requests | optional boolean | Setting option email configuracion or app configuration request. |
comments | optional boolean | Setting option email configuracion or app configuration comments. |
alerts | optional boolean | Setting option email configuracion or app configuration alerts. |
follows | optional boolean | Setting option email configuracion or app configuration follows. |
The old_password and new_password is required for change password.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"id": "5781892791236646271621231",
"email": "user@domain.com",
"first_name": "lastName",
"nickname": "userNick",
"phone": "678954321",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"locale": "es",
"devices": [
{
"device_id": "1231456754234567665433",
"os_version": "2345",
"brand": "srtyh",
"model": "asdad"
}
],
"app_evaluations": [
{
"app_key": "1"
}
]
}
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "Access Denied"
}
]
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"first_name": "lastName",
"nickname": "userNick",
"old_password": "clavevieja",
"new_password": "clavenueva",
"phone": "678954321",
"avatar": "http://www.mejoratuciudad.org/images/profile.png",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"locale": "es"
}
200
ShowHideContent-Type: application/json
{
"email": "user@domain.com",
"first_name": "lastName",
"nickname": "userNick",
"avatar": "http://www.mejoratuciudad.org/images/profile.png",
"phone": "678954321",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"locale": "es"
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Nickname is too short"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Nickname already exists"
}
]
400
ShowHideContent-Type: application/json
Raised when new and old passwords are equal
[
{
"code": 400,
"description": "Password must be different"
}
]
400
ShowHideContent-Type: application/json
Raised if old password is incorrect
[
{
"code": 400,
"description": "Old password do not match"
}
]
400
ShowHideContent-Type: application/json
Raised when password is too short
[
{
"code": 400,
"description": "Password must at least of {length} characters length"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Avatar must be a valid url"
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "Access Denied"
}
]
Content-Type: multipart/form-data
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"email": "user@domain.com",
"first_name": "lastName",
"nickname": "userNick",
"avatar": "http://www.mejoratuciudad.org/images/profile.png",
"phone": "678954321",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"locale": "es"
}
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "Access Denied"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Image file required"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Error saving changes"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Error uploading image"
}
]
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"notification_account_code": "DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4",
"device_type": "5804ba659a60575c058b4583"
}
200
ShowHideContent-Type: application/json
{
"notification_account_code": "DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4",
"device_type": {
"id": "5804ba659a60575c058b4583",
"code": 2,
"alias": "Android",
"options": [
"android"
],
"color": "#ffc107",
"locale": "es"
}
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "application was not provided"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "notification_account_code was not provided"
}
]
400
ShowHideContent-Type: application/json
Raised when device_type is different from `android`,`ios`.
[
{
"code": 400,
"description": "device_type was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "device_type was not provided"
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "User was not found"
}
]
Adds a new device to the user. Returns the user’s profile with the newly added device.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"device_id": "APA-3124sdfs-gerydrtrw1245tdgdfghdfy4w5rw",
"registration_id": "APA91bHUCb7a3kXzt_TECnRLkFBqQ-CEn7TMeXgJfqReT4EZ8IRrHNDX2j",
"type": "ios",
"brand": "apple",
"model": "iphone 6S",
"os_version": "10"
}
200
ShowHideContent-Type: application/json
{
"preference": {},
"id": "582c94c4946b8451008b4567",
"email": "foo@bar.com",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"devices": [
{
"device_id": "1231456754234567665433",
"os_version": "2345",
"brand": "srtyh",
"model": "asdad",
"type": "android"
},
{
"device_id": "APA-3124sdfs-gerydrtrw1245tdgdfghdfy4w5rw",
"os_version": "10",
"brand": "apple",
"model": "iphone 6S",
"type": "ios"
}
]
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "User was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Device_id not provided"
}
]
Adds a new app evaluation to the user. Returns the user’s profile with the newly added device.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"rating":4,
"comment": "really good",
"app_key": 1
}
200
ShowHideContent-Type: application/json
{
"app_evaluations": [
{
"app_key": "1"
}
],
"preference": {},
"id": "582c94c4946b8451008b4567",
"email": "foo@bar.com",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"devices": [
{
"device_id": "1231456754234567665433",
"os_version": "2345",
"brand": "srtyh",
"model": "asdad",
"type": "android"
},
{
"device_id": "APA-3124sdfs-gerydrtrw1245tdgdfghdfy4w5rw",
"os_version": "10",
"brand": "apple",
"model": "iphone 6S",
"type": "ios"
}
]
}
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "User was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "App with app_key 1 was already evaluated by user"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "App with app_key 1 does not exist"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Missing parameters"
}
]
500
ShowHideContent-Type: application/json
[
{
"code": 500,
"description": "Error saving user"
}
]
Removes a device from a user.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"device_id": "APA-3124sdfs-gerydrtrw1245tdgdfghdfy4w5rw"
}
200
ShowHideContent-Type: application/json
{
"preference": {},
"id": "582c94c4946b8451008b4567",
"email": "foo@bar.com",
"configuration": {
"email_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
},
"app_notification": {
"requests": true,
"comments": true,
"alerts": true,
"follows": true
}
},
"devices": [
{
"device_id": "1231456754234567665433",
"os_version": "2345",
"brand": "srtyh",
"model": "asdad",
"type": "android"
}
]
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "User was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Missing parameters"
}
]
User preferences within the jurisdiction
Gets user preferences stored within the jurisdiction.
string
(required) Example: es.madridJurisdiction ID to show.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"widget_buttons_ids":
[
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4" ,
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F5" ,
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4"
]
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "Access Denied"
}
]
Updates user preferences stored within the jurisdiction.
string
(required) Example: es.madridJurisdiction ID to show.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
[
{
"widget_buttons_ids":
[
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4" ,
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F5" ,
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4"
]
}
]
200
ShowHideContent-Type: application/json
[
{
"widget_buttons_ids":
[
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4" ,
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F5" ,
"DSFKUSUJG89UDFS9Y8G79834IF43UI_34RF34F4"
]
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "Access Denied"
}
]
User legal terms api calls. Authorization
header must be sent.
Field | Description |
---|---|
origin_device | OriginDevice id (optional) |
If a user is using the app and legal terms have been updated, a response with code 510 will be sent. Said user will then be required to accept the new ones via api call, specifying the origin device they are accepted from.
Application options settings.
Field | Value | Description |
---|---|---|
name | string | Name applicacion. |
logo | string | Url logo image. |
active | boolean | Status active the application. |
default_jurisdiction_id | string | Default jurisdiction identification Id. |
U
Get Application Status
string
(required) Example: 1Application ID
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"name": "Mejora tu ciudad",
"logo": "http:\/\/www.radmas.com\/clientes\/ayto\/img\/logo.png",
"active": true,
"default_jurisdiction":"es.madrid"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "app_key does not exist or is not allowed"
}
Possible values for type are: cityapp
, workapp
, cityweb
.
Possible values for headboard type are: icon
, small_image
, gallery
.
This request return the application configuration for the specified type of device.
string
(required) Example: es.madridJurisdiction ID
string
(required) Example: cityappType of configuration
Accept: application/json
Content-Type: application/json
200
ShowHideContent-Type: application/json
{
"name": "Application Name",
"default_language": "es_ES",
"jurisdiction_id": "es.madrid",
"main_color": "#666666",
"font_color": "#FF0000",
"login_background_url": "https://example.com/category_light.png",
"login_logo_url": "https://example.com/category_light.png",
"managers_icon_url": "https://example.com/category_seat.png",
"app_icon_url": "https://example.com/category_seat.png",
"headboard": {
"type": "gallery",
"small_image": "https://example.com/category_seat.png",
"icon": "https://example.com/category_seat.png",
"gallery": [
{
"image_url": "https://example.com/category_light.png",
"image_link": "https://example.com/category_seat.png"
}
]
},
"cards": [
{
"id": "58bd2d144e4ea8a40d8b4d35",
"name": "A Twitter Card",
"preset": false,
"required": false,
"type": "twitter_card",
"channels": [
{
"id": "5a79c2354e4ea851038b45cf",
"name": "Jardineros"
},
{
"id": "5a79c2354e4ea851038b45d0",
"name": "Bomberos"
}
],
"accounts": [
{
"name": "@MejoraTuCiudad_",
"tags": [
{
"name": "BestApp",
"color": "#C6C6C6"
}
],
}
],
},
],
"buttons": [
{
"id": "58bd2d144e4ea8a40d8b4d33",
"name": "A Button",
"preset": true,
"required": true,
"button_type": "phoneCollection",
"collection": [
{
"name": "emergencias",
"value": "112",
}
],
"icon": ,
"tags": [
{
"id": "58bd2d144e4ea8a40d8b4d30",
"name": "Deportes",
"color": "#A8F962"
},
{
"id": "58bd2d144e4ea8a40d8b4d32",
"name": "Politica",
"color": "#F962A8"
}
]
}
]
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "App configuration was not found"
}
Possible values for type are: cityapp
, workapp
, cityweb
.
This request return the application configuration common for the specified type of device.
string
(required) Example: es.madridJurisdiction ID
string
(required) Example: cityappType of configuration
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"name": "Application Name",
"default_language": "es_ES",
"jurisdiction_id": "es.madrid",
"main_color": "#666666",
"font_color": "#FF0000",
"login_background_url": "https://example.com/category_light.png",
"login_logo_url": "https://example.com/category_light.png",
"managers_icon_url": "https://example.com/category_seat.png",
"app_icon_url": "https://example.com/category_seat.png",
"headboard": {
"type": "top_bar",
"small_image": "https://example.com/category_seat.png",
"icon": "https://example.com/category_seat.png",
"gallery": [
{
"image_url": "https://example.com/category_light.png",
"image_link": "https://example.com/category_seat.png"
}
]
},
"cards": [
{
"id": "5cd53fd64e4ea864018b4567",
"position": 8,
"priority": 5,
"name": "Twitter card!",
"preset": true,
"required": true,
"channels": [
{
"id": "5cd3ea744e4ea878088b459f",
"name": "Jardineros",
"external": false,
"public": false,
"jurisdictions": [
{
"jurisdiction_id": "es.madrid"
}
]
}
],
"type": "twitter_card"
},
],
"buttons": [
{
"id": "58bd2d144e4ea8a40d8b4d33",
"name": "A Button",
"preset": true,
"required": true,
"type": "button",
"button_type": "phoneCollection",
"collection": [
{
"name": "emergencias",
"value": "112",
}
],
"icon": "https://example.com/category_seat.png",
"tags": [
{
"id": "58bd2d144e4ea8a40d8b4d30",
"name": "Deportes",
"color": "#A8F962"
},
{
"id": "58bd2d144e4ea8a40d8b4d32",
"name": "Politica",
"color": "#F962A8"
}
]
}
]
}
401
ShowHideContent-Type: application/json
{
"error": "access_denied",
"error_description": "OAuth2 authentication required"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "App configuration was not found"
}
Possible values for type are: `cityapp`, `workapp`, `cityweb`.
This request return the user custom configuration for the specified user, jurisdiction and application type.
string
(required) Example: es.madridJurisdiction IDs
string
(required) Example: cityappType of configuration
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
```
{
"es.madrid": {
"active_buttons": [
{
"app_element": "58e23b074e4ea87b4a8b4f40",
"position": 1
},
{
"app_element": "58e23b074e4ea87b4a8b4f41",
"position": 1
},
],
"active_cards": [
{
"app_element": "58e23b074e4ea87b4a8b4f43",
"position": 3
},
{
"app_element": "58e23b074e4ea87b4a8b4f44",
"position": 2
}
]
},
"net.carboneroelmayor": {
"active_buttons": [
{
"app_element": "58e23b074e4ea87b4a8b4f42",
"position": 2
}
],
"active_cards": []
}
}
```
400
ShowHideContent-Type: application/json
```
[{
"code": 400,
"description": "Type not send"
}]
```
400
ShowHideContent-Type: application/json
```
[{
"code": 400,
"description": "Jurisdiction_ids not send"
}]
```
403
ShowHideContent-Type: application/json
```
[{
"code": 403,
"description": "User was not found"
}]
```
404
ShowHideContent-Type: application/json
```
[{
"code": 404,
"description": "Jurisdictions not found"
}]
```
404
ShowHideContent-Type: application/json
```
[{
"code": 404,
"description": "UserCustomConfigurations not found"
}]
string
(required) Example: es.madridJurisdiction IDs
string
(required) Example: cityappType of configuration
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"type" : "cityapp",
"jurisdiction_ids" : "es.madrid",
"active_cards": [
{
"app_element": "5a1802344e4ea8473d8b4be6",
"position": 1,
"selected": true,
"account_config": [
"test",
"youtube"
]
}
],
"active_buttons": [
{
"app_element": "5a1802344e4ea8473d8b4be6",
"position": 1,
"selected": true
}
]
}
200
ShowHideContent-Type: application/json
400
ShowHideContent-Type: application/json
```
[{
"code": 400,
"description": "Type not send"
}]
```
400
ShowHideContent-Type: application/json
```
[{
"code": 400,
"description": "Jurisdiction_ids not send"
}]
```
400
ShowHideContent-Type: application/json
```
[{
"code": 400,
"description": "UserCustomConfiguration params not valid"
}]
```
403
ShowHideContent-Type: application/json
```
[{
"code": 403,
"description": "User was not found"
}]
```
404
ShowHideContent-Type: application/json
```
[{
"code": 404,
"description": "Jurisdiction not found"
}]
```
404
ShowHideContent-Type: application/json
```
[{
"code": 404,
"description": "AppConfiguration not found"
}]
```
This request return the app element for the specified id.
string
(required) Example: 5cd53c944e4ea860018b456aAppElement id.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"id": "5cd53c944e4ea860018b456a",
"sources": [
{
"name": "20Minutos",
"source_link": "http://www.20minutos.es/rss",
"tags": [
{
"name": "Cultura",
"id": "Cultura",
"color": "#62F9A8"
}
],
"channels": [
{
"id": "5cd3ea744e4ea878088b459f",
"name": "Jardineros",
"external": false,
"public": false,
"jurisdictions": [
{
"jurisdiction_id": "es.madrid"
}
]
}
]
}
],
"configuration": {
"icon": "https://5cc844efe179b.png",
"predetermined_image": "https://5cc844d46ed48.png",
"content_image": "https://5cc844d46ed48.png",
"error_image": "https://5cc844ee5679b.png",
"color": "#8dbbff"
}
}
401
ShowHideContent-Type: application/json
{
"error": "access_denied",
"error_description": "OAuth2 authentication required"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "Application Element was not found"
}
This is the group of jurisdictions
The service has the following information:
Field | Possible values | Description |
---|---|---|
jurisdiction_id | string | External identifier, used in the public protocol to generate requests. |
name | string | Name of the jurisdiction. |
key_name | string | This string is used to adjust the map searches. |
server_url | string | Server base url where requests for this jurisdiction must be sent. |
active | bool | Check if the service is available to accept requests. |
icon | string | URL to the icon of this jurisdiction. |
logo | string | URL to the logo of this jurisdiction. |
main_logo | string | URL to the main_logo of this jurisdiction. |
loading_image | string | URL to the loading_image of this jurisdiction. |
login_image | string | URL to the login_image of this jurisdiction. |
header_icon | string | URL to the header_icon of this jurisdiction. |
color_header_text | string | Color of the header text of this jurisdiction. |
color_header_background | string | Color of the header background of this jurisdiction. |
color_button | string | Color button of this jurisdiction. |
color_font | string | Color font of this jurisdiction. |
color_icons | string | Color icons of this jurisdiction. |
lat | number | Jurisdiction geographic center latitude of jurisdiction. |
lng | number | Jurisdiction geographic center longitude of jurisdiction. |
geo_perimeter | array | Collection of [lat, long] defining jurisdiction geographic perimeter. |
geo_bound | array | Collection of [lat, long] defining jurisdiction geographic bounds. |
updated_datetime | string | Last jurisdiction update date ISO8601 . |
mobile_default_locale | string | Jurisdiction desired default language locale string for mobile apps (es , fr , en ), this parameter can be blank. |
app_key | string | Identification Application ID. |
typologies | array | Collection of typologies into Jurisdiction |
origin_devices | array | Collection of origin devices into Jurisdiction |
The following value in type the buttons will be removed in future versions:
Field | Values | Description |
---|---|---|
type | url | The value was replaced by the option url_collection and add all urls collections |
type | phone | The value was replaced by the option phone_collection and add all phones collections |
The following new values are available:
Field | Values | Description |
---|---|---|
type | url_collection | The value can be stored url collections |
type | phone_collection | The value can be stored phone collections |
type | social_collection | The value can be stored url social collections |
type | news_collection | The value can be stored url news collections |
type | notices_collection | The value can be stored url notices collections |
Get Jurisdiction definition.
Get list of application jurisdictions.
integer
(optional) Example: 1Application ID.
number
(required) Example: 32.48576Longitud Jurisdiction.
number
(required) Example: -32.48576Latitud Jurisdiction.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"only_registered_users": true,
"automatic_typology": false,
"id": "58984bf54e4ea84c078b4586",
"jurisdiction_id": "es.madrid",
"name": "Madrid",
"key_name": "Madrid, España",
"color_button": "#ADDFFF",
"long": -3.6795367,
"lat": 40.4378271,
"geo_perimeter": [
{
"long": -3.5217381831055,
"lat": 40.468696616332
},
{
"long": -3.5679632396211,
"lat": 40.439353064073
},
{
"long": -3.5819159572695,
"lat": 40.409735283428
},
{
"long": -3.5720558896365,
"lat": 40.368773317026
},
{
"long": -3.5887279662848,
"lat": 40.354309182685
},
{
"long": -3.6364916752453,
"lat": 40.352587390944
},
{
"long": -3.6880737806664,
"lat": 40.331872509877
},
{
"long": -3.7246333772507,
"lat": 40.333881515929
},
{
"long": -3.7215349190521,
"lat": 40.365633257583
},
{
"long": -3.7709562887878,
"lat": 40.360585848344
},
{
"long": -3.7825950487671,
"lat": 40.377695549523
},
{
"long": -3.7790933939209,
"lat": 40.400921921918
},
{
"long": -3.7957793542481,
"lat": 40.434808530162
},
{
"long": -3.7776528618165,
"lat": 40.44298363235
},
{
"long": -3.7510129140626,
"lat": 40.476047037837
},
{
"long": -3.6922398544922,
"lat": 40.512897776404
},
{
"long": -3.5877399999999,
"lat": 40.514539
}
],
"geo_bound": [
{
"long": -3.798113,
"lat": 40.36074
},
{
"long": -3.58774,
"lat": 40.514539
}
],
"buttons": [
{
"label": "Madrid",
"icon": "http://www.picaronablog.com/wp-content/uploads/google-hangouts-icon.png",
"url": "http://www.madrid.es",
"url_collection": [],
"phone_collection": [],
"social_collection": [],
"news_collection": [],
"type": "url",
"sequence": 0,
"optional": false
},
{
"label": "EMT",
"icon": "http://www.emtmadrid.es/img/logotipo.jpg",
"url": "http://www.emtmadrid.es/",
"url_collection": [],
"phone_collection": [],
"social_collection": [],
"news_collection": [],
"type": "url",
"sequence": 5,
"optional": false
}
],
"locales": [
"es"
],
"typologies": [
{
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
{
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
},
{
"id": "58984bf54e4ea84c078b45ad",
"name": "peticiones"
}
],
"typology_nodes": [
{
"id": "58984bf54e4ea84c078b459d",
"visible_name": "En progreso",
"order": 3,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b459c",
"visible_name": "Nuevo",
"order": 1,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b45a0",
"visible_name": "Rechazado",
"order": 2,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b459e",
"visible_name": "Resuelto",
"order": 4,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b459f",
"visible_name": "Solucionado",
"order": 5,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b45af",
"visible_name": "Considerada",
"order": 2,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45ad",
"name": "peticiones"
}
},
{
"id": "58984bf54e4ea84c078b45ae",
"visible_name": "Nueva",
"order": 1,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45ad",
"name": "peticiones"
}
},
{
"id": "58984bf54e4ea84c078b45b7",
"visible_name": "Cancelado",
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b6",
"visible_name": "Comunicado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b3",
"visible_name": "En curso",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b4",
"visible_name": "En ejecución",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b2",
"visible_name": "En progreso",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b5",
"visible_name": "Finalizado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b1",
"visible_name": "Recepcionado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b8",
"visible_name": "Trasladado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
}
],
"origin_devices": [
{
"id": "58984bf54e4ea84c078b457d",
"options": []
},
{
"id": "58984bf54e4ea84c078b457e",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b457f",
"options": [
"android"
]
},
{
"id": "58984bf54e4ea84c078b4580",
"options": [
"ios"
]
},
{
"id": "58984bf54e4ea84c078b4581",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4582",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4583",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4584",
"options": [
"facebook",
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4585",
"options": [
"twitter",
"inperson"
]
}
],
"icon": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/icon.jpg",
"logo": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/logo.png",
"main_logo": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/main_logo.png",
"header_icon": null,
"loading_image": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/loading_image.png",
"login_image": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/login_image.png"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "app_key was not provided"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "app_key does not exist or is not allowed"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "latitude or longitude not provided"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "No jurisdiction found in the specified coordinates"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "user can not join to this jurisdiction"
}
]
Get Jurisdiction definition.
Get a single instance of a jurisdiction.
string
(required) Example: es.madridJurisdiction ID to show.
integer
(optional) Example: 1Application ID.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"only_registered_users": true,
"automatic_typology": false,
"id": "58984bf54e4ea84c078b4586",
"jurisdiction_id": "es.madrid",
"name": "Madrid",
"key_name": "Madrid, España",
"color_button": "#ADDFFF",
"long": -3.6795367,
"lat": 40.4378271,
"geo_perimeter": [
{
"long": -3.5217381831055,
"lat": 40.468696616332
},
{
"long": -3.5679632396211,
"lat": 40.439353064073
},
{
"long": -3.5819159572695,
"lat": 40.409735283428
},
{
"long": -3.5720558896365,
"lat": 40.368773317026
},
{
"long": -3.5887279662848,
"lat": 40.354309182685
},
{
"long": -3.6364916752453,
"lat": 40.352587390944
},
{
"long": -3.6880737806664,
"lat": 40.331872509877
},
{
"long": -3.7246333772507,
"lat": 40.333881515929
},
{
"long": -3.7215349190521,
"lat": 40.365633257583
},
{
"long": -3.7709562887878,
"lat": 40.360585848344
},
{
"long": -3.7825950487671,
"lat": 40.377695549523
},
{
"long": -3.7790933939209,
"lat": 40.400921921918
},
{
"long": -3.7957793542481,
"lat": 40.434808530162
},
{
"long": -3.7776528618165,
"lat": 40.44298363235
},
{
"long": -3.7510129140626,
"lat": 40.476047037837
},
{
"long": -3.6922398544922,
"lat": 40.512897776404
},
{
"long": -3.5877399999999,
"lat": 40.514539
}
],
"geo_bound": [
{
"long": -3.798113,
"lat": 40.36074
},
{
"long": -3.58774,
"lat": 40.514539
}
],
"buttons": [
{
"label": "Madrid",
"icon": "http://www.picaronablog.com/wp-content/uploads/google-hangouts-icon.png",
"url": "http://www.madrid.es",
"url_collection": [],
"phone_collection": [],
"social_collection": [],
"news_collection": [],
"type": "url",
"sequence": 0,
"optional": false
},
{
"label": "EMT",
"icon": "http://www.emtmadrid.es/img/logotipo.jpg",
"url": "http://www.emtmadrid.es/",
"url_collection": [],
"phone_collection": [],
"social_collection": [],
"news_collection": [],
"type": "url",
"sequence": 5,
"optional": false
}
],
"locales": [
"es"
],
"typologies": [
{
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
{
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
},
{
"id": "58984bf54e4ea84c078b45ad",
"name": "peticiones"
}
],
"typology_nodes": [
{
"id": "58984bf54e4ea84c078b459d",
"visible_name": "En progreso",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b459c",
"visible_name": "Nuevo",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b45a0",
"visible_name": "Rechazado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b459e",
"visible_name": "Resuelto",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b459f",
"visible_name": "Solucionado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
}
},
{
"id": "58984bf54e4ea84c078b45af",
"visible_name": "Considerada",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45ad",
"name": "peticiones"
}
},
{
"id": "58984bf54e4ea84c078b45ae",
"visible_name": "Nueva",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45ad",
"name": "peticiones"
}
},
{
"id": "58984bf54e4ea84c078b45b7",
"visible_name": "Cancelado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b6",
"visible_name": "Comunicado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b3",
"visible_name": "En curso",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b4",
"visible_name": "En ejecución",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b2",
"visible_name": "En progreso",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b5",
"visible_name": "Finalizado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b1",
"visible_name": "Recepcionado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
},
{
"id": "58984bf54e4ea84c078b45b8",
"visible_name": "Trasladado",
"order": 0,
"color": "#7da038",
"typology": {
"id": "58984bf54e4ea84c078b45b0",
"name": "avisos_madrid"
}
}
],
"origin_devices": [
{
"id": "58984bf54e4ea84c078b457d",
"options": []
},
{
"id": "58984bf54e4ea84c078b457e",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b457f",
"options": [
"android"
]
},
{
"id": "58984bf54e4ea84c078b4580",
"options": [
"ios"
]
},
{
"id": "58984bf54e4ea84c078b4581",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4582",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4583",
"options": [
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4584",
"options": [
"facebook",
"inperson"
]
},
{
"id": "58984bf54e4ea84c078b4585",
"options": [
"twitter",
"inperson"
]
}
],
"icon": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/icon.jpg",
"logo": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/logo.png",
"main_logo": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/main_logo.png",
"header_icon": null,
"loading_image": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/loading_image.png",
"login_image": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/login_image.png"
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "app_key was not provided"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "app_key does not exist or is not allowed"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "user can not join to this jurisdiction"
}
]
404
ShowHideContent-Type: application/json
[
{
"code": 404,
"description": "jurisdiction_id was not found"
}
]
Get the jurisdiction which the sent position coordinates belong to.
Get a single instance of a jurisdiction.
integer
(required) Example: 1Application ID.
float
(required) Example: 40.632489Your position Longitude.
float
(required) Example: -3.16017Your position latitude.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"jurisdiction_id": "es.madrid"
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "app_key was not provided"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "app_key does not exist or is not allowed"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "latitude or longitude not provided"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "No jurisdiction found in the specified coordinates"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "user can not join to this jurisdiction"
}
]
This is the group of services
The creation of Services must be done through the Backoffice Application.
The service has the following information:
Field | Possible values | Description |
---|---|---|
metadata | boolean | Indicates when a service has attributes. |
group | string | Group the services. |
service_code | string | Service identifier, relative to jurisdiction. |
service_name | string | Name of the service. |
description | string | Short description of the service. |
public_requests | boolean | Determine is the request public. |
type | string | Type Service. |
keywords | string | Keywords settings the Service. |
service_icon | url | This can be a external url or a base64 url. Contains the image that is associated to this category in the mobile application and in the backoffice. |
social | boolean | Indicates when a service has comments in associated requests. |
attributes | array | The attributes are the metadata that can be defined in the request of this service. The attributes fields are detailed below. |
typology | array | The definition of Typology included into Service |
status_node | array | The definition of Status Node included into Service |
Field | Possible values | Description |
---|---|---|
id | string | Internal id of the service. |
code | string | Internal identifier of the service. |
variable | bool | Describe if the attribute is a variable (true) or it is used just to display some data. |
datatype | Options: string , number , datetime , date , text , singlevaluelist , multivaluelist | Describes the datatype of the value which expect to receive. |
required | bool | Name of the service. |
description | string | Detail of the attribute which is normally displayed to the user. |
order | number | Order in which this attribute is showed to the final user. |
values | array | Contains a list of values which can be selected when the datatype is singlevaluelist or multivaluelist . Every element contains a key and a name . |
deleted | boolean | Determine the deleted values services |
key | string | Key values services |
name | string | Name values services |
children_services | array | List Children component to service |
social | boolean | Determine the social service |
Field | Possible values | Description |
---|---|---|
id | string | Internal id of the typology. |
name | string | Name unique the typology |
visible_name | string | Visible name the typology |
Field | Possible values | Description |
---|---|---|
id | string | Internal id of the status node. |
name | string | Name unique the status node |
visible_name | string | Visible name the status node |
string array
(required) Example: es.madrid,es.funsalidaOne or more jurisdiction codes separated by commas
float
(optional) Example: 40.4432203Latitude of the center point to search. Required if lng is present.
float
(optional) Example: -3.7042705Longitude of the center point to search. Required if lat is present.
string array
(optional) Example: 57e9101d9a605741068b45af,57e9101d9a605741068b45cbOne or more typology ids separated by commas
string
(optional) Example: #a3065bColor assigned to service. Expressed in hex.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"metadata": true,
"group": "",
"jurisdiction_id": "es.madrid",
"visible_name": "Limpieza y Residuos (Avisos)",
"id": "58984bf54e4ea84c078b45d5",
"service_name": "Limpieza y Residuos",
"description": "Incidencias relacionadas con la recogida de residuos y la limpieza de las calles.",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
"service_icon": "https://s3-eu-west-1.amazonaws.com/static.open010.org/images_iyc/category_trash.png",
"social": true,
"evaluation": true
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "At least one valid jurisdiction is required"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "Both lat and lng must by provided"
}
]
Display the details of a Service
string
(required) Example: 1Service identifier.
string
(required) Example: es.madridJurisdiction id to which the required services belong.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"metadata": true,
"group": "",
"visible_name": "Limpieza y Residuos (Avisos)",
"id": "58984bf54e4ea84c078b45d5",
"service_code": "1",
"typology": {
"hasLocation": true,
"id": "58984bf54e4ea84c078b459b",
"name": "avisos",
"visible_name": "Avisos",
"icon": "",
"color": "#337ab7",
"with_medias": true,
"location_type": "geolocation"
},
"public_requests": true,
"service_icon": "https://s3-eu-west-1.amazonaws.com/static.open010.org/images_iyc/category_trash.png",
"public": true,
"attributes": [
{
"deleted": false,
"id": "58984c034e4ea84c078b47c7",
"code": "ESPACE",
"variable": true,
"datatype": "singlevaluelist",
"required": true,
"description": "¿Qué tipo de espacio es?",
"order": 0,
"values": [
{
"deleted": false,
"key": "123",
"name": "Parque"
},
{
"deleted": false,
"key": "124",
"name": "Jardín"
}
]
},
{
"deleted": false,
"id": "58984c034e4ea84c078b47ca",
"code": "ELEMENTTYPE",
"variable": true,
"datatype": "multivaluelist",
"required": true,
"description": "Zonas afectadas",
"order": 1,
"values": [
{
"deleted": false,
"key": "223",
"name": "Árbol"
},
{
"deleted": false,
"key": "224",
"name": "Planta"
},
{
"deleted": false,
"key": "225",
"name": "Arbusto"
},
{
"deleted": false,
"key": "226",
"name": "Césped"
}
]
},
{
"deleted": false,
"id": "58984c034e4ea84c078b47cf",
"code": "NUMBEROFELEMENTS",
"variable": true,
"datatype": "number",
"required": true,
"description": "Cantidad de elementos afectados",
"order": 2,
"values": []
},
{
"deleted": false,
"id": "58984c034e4ea84c078b47d0",
"code": "SEENONDATE",
"variable": true,
"datatype": "datetime",
"required": true,
"description": "¿Cuando divisaste el acontencimiento?",
"order": 3,
"values": []
},
{
"deleted": false,
"id": "58984c034e4ea84c078b47d1",
"code": "MOREINFO",
"variable": true,
"datatype": "text",
"required": false,
"description": "Amplíe la descripción de la incidencia.",
"order": 4,
"values": []
},
{
"deleted": false,
"id": "58984c034e4ea84c078b47d2",
"code": "LONGDESCRIPTION",
"variable": false,
"datatype": "text",
"required": false,
"description": "En un lugar de la Mancha, de cuyo nombre no quiero acordarme, no ha mucho tiempo que vivía un hidalgo de los de lanza en astillero, adarga antigua, rocín flaco y galgo corredor. Una olla de algo más vaca que carnero, salpicón las más noches, duelos y quebrantos los sábados, lentejas los viernes, algún palomino de añadidura los domingos, consumían las tres partes de su hacienda. El resto della concluían sayo de velarte, calzas de velludo para las fiestas con sus pantuflos de lo mismo, los días de entre semana se honraba con su vellori de lo más fino. Tenía en su casa una ama que pasaba de los cuarenta, y una sobrina que no llegaba a los veinte, y un mozo de campo y plaza, que así ensillaba el rocín como tomaba la podadera. Frisaba la edad de nuestro hidalgo con los cincuenta años, era de complexión recia, seco de carnes, enjuto de rostro; gran madrugador y amigo de la caza. Quieren decir que tenía el sobrenombre de Quijada o Quesada (que en esto hay alguna diferencia en los autores que deste caso escriben), aunque por conjeturas verosímiles se deja entender que se llama Quijana; pero esto importa poco a nuestro cuento; basta que en la narración dél no se salga un punto de la verdad.",
"order": 5,
"values": []
}
],
"social": true,
"evaluation": true,
"status_node": [
{
"name": "en_progreso",
"color": "#7da038",
"typology_node_id": "58984bf54e4ea84c078b459d",
"visible_name": "En progreso",
"id": "58984bf54e4ea84c078b45cf"
},
{
"name": "nuevo",
"color": "#7da038",
"typology_node_id": "58984bf54e4ea84c078b459c",
"visible_name": "Nuevo",
"id": "58984bf54e4ea84c078b45d0"
},
{
"name": "rechazado",
"color": "#7da038",
"typology_node_id": "58984bf54e4ea84c078b45a0",
"visible_name": "Rechazado",
"id": "58984bf54e4ea84c078b45d1"
},
{
"name": "resuelto",
"color": "#7da038",
"typology_node_id": "58984bf54e4ea84c078b459e",
"visible_name": "Resuelto",
"id": "58984bf54e4ea84c078b45d2"
},
{
"name": "solucionado",
"color": "#7da038",
"typology_node_id": "58984bf54e4ea84c078b459f",
"visible_name": "Solucionado",
"id": "58984bf54e4ea84c078b45d3"
}
],
"mandatory_informant_config": [
{
"required": false,
"field": "first_name",
"message": ""
},
{
"required": false,
"field": "last_name",
"message": ""
},
{
"required": false,
"field": "phone",
"message": ""
},
{
"required": false,
"field": "email",
"message": ""
},
{
"required": false,
"field": "twitter_nickname",
"message": ""
}
]
}
400
ShowHideContent-Type: application/json
[
{
"code": 404,
"description": "jurisdiction_id was not found"
}
]
404
ShowHideContent-Type: application/json
[
{
"code": 404,
"description": "service_code was not found "
}
]
Requests contains the information about any issue that can happen in the jurisdiction. To ensure a correct mapping between
both systems there is a token
(internal identifier) an a service_request_id
, which is a value that can be set by an external
system or it would be randomly generated.
This model is highly influenced by the Open311 Georeport v2 protocol, but it focus in management so there are aditional fields and options that are not available in this protocol.
This request return a set with the last requests in the jurisdiction.
If the lat
and long
parameters are set it try to find the requests that are in a area of 6Km. If no value is found it return all the requests without taking
into account the location.
string array
(required) Example: es.madrid,es.fuensalidaOne or more jurisdiction codes distinguish between commas
string
(optional) Example: 14092214355,14092214356Request ID’s
string
(optional) Example: 1Service ID’s
string
(optional) Example: 2014-07-01T00:00:00ZTimestamp in ISO 8601 format: YYYY-MM-DDTHH:MM:SSZ
Only Request created after this time are returned.
string
(optional) Example: 2014-08-13T17:45:01ZTimestamp in ISO 8601 format: YYYY-MM-DDTHH:MM:SSZ
Only Request created before this time are returned.
float
(optional) Example: 40.4432203Latitude of the center point to search in a 6km range. required if long
is defined
float
(optional) Example: -3.7042705Longitude of the center point to search in a 6km range. required if lat
is defined
boolean
(optional) Example: falseIf set to true
, only requests owned by the current user will be sent.
integer
(optional) Example: 1page number to be sent.
integer
(optional) Example: 10Maximum number of requests to be sent ( if page is set, the limit is for each page )…
string
(optional) Example: farolasDescription, address or ID requests
array
(optional) Example: 56e1a6809a6057f7068b45afFor multiple: status[]=56e1a6809a6057f7068b45af&status[]=56e1a6809a6057f7068b45b1
array
(optional) Example: 56e1a6809a6057f7068b45afFor multiple: typologies[]=56e1a6809a6057f7068b45af&typologies[]=56e1a6809a6057f7068b45b1
string
(optional) Example: 20kmMust be used with lat and long
boolean
(optional) Example: falseIf set to true
, only followed requests by the current user will be sent.
string
(optional) Example: date_ascValues sorting: own_desc, own_asc, date_desc, date_asc, updated_desc, updated_asc, seen_asc, priority_desc, followers_asc, unseen_comments_asc, assigned_self, distance (with distance, distance_from must be setted)
boolean
(optional) Example: 0If set to 1
, only requests with complaints will be sent
boolean
(optional) Example: 0If set to 1
, only requests with reiterations will be sent
boolean
(optional) Example: trueIf set to true
, only requests reiterated by the user will be sent
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"service_id": "58984bf54e4ea84c078b45e1",
"service_name": "Zonas verdes y arbolado",
"status_node_type": "initial_node",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
"token": "58984c594e4ea87e018b4573",
"service_request_id": "MAD1085",
"description": "Testing Open010 POST Request 1stTime",
"long": -3.742991,
"lat": 40.368958,
"status_node": {
"typology_node_id": "58984bf54e4ea84c078b459c",
"id": "58984bf54e4ea84c078b45dc"
},
"requested_datetime": "2017-02-06T10:13:45+0000",
"address": "Calle Falsa, 123",
"supporting": false,
"complaining": false,
"user": {
"id": "58984bf54e4ea84c078b4597"
},
"comments_count": 0,
"evaluation": 0,
"reiterations_count": 0,
"complaints_count": 0
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "jurisdiction_id was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "lat or long was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "user was not found"
}
]
This request return a set with the last requests in the jurisdiction.
If the lat
and long
parameters are set it try to find the requests that are in a area of 6Km. If no value is found it return all the requests without taking
into account the location.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"jurisdiction_ids": "es.madrid",
"service_request_ids": "580483cd9a6057ca048b4587",
"service_ids": "1",
"start_date": "2014-07-01T00:00:00Z",
"end_date": "2014-08-01T00:00:00Z",
"lat": 40.403040,
"long": -3.770370,
"own": false,
"page": 1,
"limit": 10,
"any_field": "farolas",
"status": ["56e1a6809a6057f7068b45af"],
"typologies": ["56e1a9461a6057f9531b09bd"],
"distance": "20km",
"following": true,
"order": "date_asc",
"complaints": 0,
"reiterations": 0,
"user_reiterated": true
}
200
ShowHideContent-Type: application/json
[
{
"service_id": "58984bf54e4ea84c078b45e1",
"service_name": "Zonas verdes y arbolado",
"status_node_type": "initial_node",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
"token": "58984c594e4ea87e018b4573",
"service_request_id": "MAD1085",
"description": "Testing Open010 POST Request 1stTime",
"long": -3.742991,
"lat": 40.368958,
"status_node": {
"typology_node_id": "58984bf54e4ea84c078b459c",
"id": "58984bf54e4ea84c078b45dc"
},
"requested_datetime": "2017-02-06T10:13:45+0000",
"address": "Calle Falsa, 123",
"supporting": false,
"complaining": false,
"user": {
"id": "58984bf54e4ea84c078b4597"
},
"comments_count": 0,
"evaluation": 0,
"reiterations_count": 0,
"complaints_count": 0
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "jurisdiction_id was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "lat or long was not found"
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "user was not found"
}
]
Lists all user created requests (no jurisdiction_id must be supplied).
int
(required) Example: 1App Key
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"service_id": "58984bf54e4ea84c078b45e1",
"service_name": "Zonas verdes y arbolado",
"status_node_type": "initial_node",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
"token": "58984c594e4ea87e018b4573",
"service_request_id": "MAD1085",
"description": "Testing Open010 POST Request 1stTime",
"long": -3.742991,
"lat": 40.368958,
"status_node": {
"typology_node_id": "58984bf54e4ea84c078b459c",
"id": "58984bf54e4ea84c078b45dc"
},
"requested_datetime": "2017-02-06T10:13:45+0000",
"address": "Calle Falsa, 123",
"supporting": false,
"complaining": false,
"user": {
"id": "58984bf54e4ea84c078b4597"
},
"comments_count": 0,
"evaluation": 0,
"reiterations_count": 0,
"complaints_count": 0
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "user was not found"
}
]
Get a single instance of a request.
string
(required) Example: 53ff033df98f71e7058b4571Request ID
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"service_id": "58984bf54e4ea84c078b45e1",
"service_name": "Zonas verdes y arbolado",
"status_node_type": "initial_node",
"typology": {
"id": "58984bf54e4ea84c078b459b",
"name": "avisos"
},
"token": "58984c594e4ea87e018b4573",
"service_request_id": "MAD1085",
"description": "Testing Open010 POST Request 1stTime",
"long": -3.742991,
"lat": 40.368958,
"status_node": {
"typology_node_id": "58984bf54e4ea84c078b459c",
"id": "58984bf54e4ea84c078b45dc"
},
"requested_datetime": "2017-02-06T10:13:45+0000",
"address": "Calle Falsa, 123",
"supporting": false,
"complaining": false,
"user": {
"id": "58984bf54e4ea84c078b4597"
},
"comments_count": 0,
"evaluation": 0,
"reiterations_count": 0,
"complaints_count": 0
}
400
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "jurisdiction_id was not found"
}
]
404
ShowHideContent-Type: application/json
[
{
"code": 404,
"description": "service_request_id was not found"
}
]
This request return a set with the coordinates of the last requests in the jurisdiction.
If the lat
and long
parameters are set it try to find the requests that are in a area of 6Km. If no value is found it return all the requests without taking
into account the location.
string array
(required) Example: es.madridOne or more jurisdiction codes distinguish between commas
string
(optional) Example: 14092214355Request ID
string
(optional) Example: 1Service Id
string
(optional) Example: 2014-07-01T00:00:00ZTimestamp in ISO 8601 format: YYYY-MM-DDTHH:MM:SSZ
Only Request created after this time are returned.
string
(optional) Example: 2014-08-13T17:45:01ZTimestamp in ISO 8601 format: YYYY-MM-DDTHH:MM:SSZ
Only Request created before this time are returned.
float
(optional) Example: 40.4432203Latitude of the center point to search in a 6km range. required if long
is defined
float
(optional) Example: -3.7042705Longitude of the center point to search in a 6km range. required if lat
is defined
boolean
(optional) Example: falseIf set to true
, only requests owned by the current user will be sent.
integer
(optional) Example: 1Number page of view Request.
integer
(optional) Example: -3.7042705Maximum number of requests to be sent.
string
(optional) Example: farolasDescription, address or ID requests
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"token": "57286e7e946b8412008b456d",
"long": -4.2669868469238,
"lat": 41.121618473181
},
{
"token": "57286048946b8412008b456a",
"long": -4.2669868469238,
"lat": 41.121618473181
},
{
"token": "57285300946b8411008b4567",
"long": -4.2669868469238,
"lat": 41.121618473181
},
{
"token": "57284eb3946b8412008b4567",
"long": -4.2669868469238,
"lat": 41.121618473181
},
{
"token": "572356a1946b8412008b4575",
"long": -4.2669868469238,
"lat": 41.121618473181
},
{
"token": "572351019a60579e218b4f42",
"long": -3.6855367,
"lat": 40.4495271
}
]
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "jurisdiction_id was not found"
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "lat or long was not found"
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "user was not found"
}
]
Field | Required | Description |
---|---|---|
app_key | required | App Key Id |
jurisdiction_id | required | Jurisdiction id. |
service_id | required | Service ID (category) used to categorize this request. |
description | required | Short description of the issue/request. |
lat | required | The request geoposition latitude. |
long | required | The request geoposition longitude. |
address_string | required | Address related to the geoposition. |
device_type | required | OriginDevice id provided in jurisdiction. |
first_name | required/optional | Name user register incidence - Is optional if the jurisdiction allows anonymous registration, otherwise it is required |
last_name | required/optional | Last Name user register incidence - Is optional if the jurisdiction allows anonymous registration, otherwise it is required |
required/optional | Email user register incidence - Is optional if the jurisdiction allows anonymous registration, otherwise it is required | |
situation | optional | Further description of the request location. |
attribute | optional | Request attributes defined by Service. Required if there are at least one of service’s attributes required |
public | optional | Marks when a request can be displayed in public requests list. |
device_id | optional | Identification mobile Ejm: [ccf7eb0d03274780]. |
email_notification | optional | If sent, the author will be set as following the request, the value true or false will set the communication via email active or inactive for that specific request |
push_notification | optional | If sent, the author will be set as following the request, the value true or false will set the communication via push active or inactive for that specific request |
sms_notification | optional | If sent, the author will be set as following the request, the value true or false will set the communication via sms active or inactive for that specific request (a phone number must be specified in the request or set in the user profile) |
medias | optional | array of strings containing already uploaded medias’names (5yw49wfsdfs.png ) |
geo_server_properties | optional | Array of geoServerProperty(administrative_level, name, administrative_level_weight) |
Generate a new request. By default, requests are created as anonymous. By adding Authorization
header requests are created associated to corresponding user.
string
(required) Example: es.madridId Jurisdiction id
boolean
(optional) Example: trueEmail notifications active/inactive for the request
boolean
(optional) Example: truePush notifications active/inactive for the request
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"app_key" : "1",
"jurisdiction_id": "es.madrid",
"service_id": "580483cd9a6057ca048b4587",
"description": "Esto es una descripción de ejemplo para el API de Open010",
"long": -3.770370,
"lat": 40.403040,
"address_string": "Calle Falsa, 123",
"device_type":"580483cd9a6057ca048b4587",
"device_id":"ccf7eb0d03274780",
"public": "1",
"first_name":"Radmas",
"last_name": "Company",
"email":"radmas@radmas.com",
"attribute": {
"1":"QV0"
},
"geo_server_properties": [
{
"administrative_level": "Colonia",
"name": "Aaaaa",
"administrative_level_weight": 7
}
]
}
200
ShowHideContent-Type: application/json
[
{
"token": "53ff1056f98f71d9698b456d",
"service_request_id": "14092247908"
}
]
200
ShowHideContent-Type: application/json
{
"requests": {
"token": "56d68cd8946b8416008b4567",
"service_request_id": "1206"
}
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Jurisdiction id is required."
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "attributes where not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "lat&long was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Coordinates are not within jurisdiction"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Invalid value {value} for attribute {code}"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "This value not empty."
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Token: request was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Description: cannot be longer than 2500 characters"
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "First_name: Parameter 'first_name' can't be empty.\nLast_name: Parameter 'last_name' can't be empty.\nEmail: Parameter 'email' can't be empty."
}
]
403
ShowHideContent-Type: application/json
[
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE not active"
}
]
string
(required) Example: 53df4fb76803fa443e8b456dRequest internal ID
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
[
"id": "5a33a2c94e4ea8df128b46a1",
"created_at": "2017-12-15T10:24:09+0000",
"type": "image/jpeg",
"deleted": false,
"media_code": "5a33a2c94e4ea8df128b46a1",
"created_datetime": "2017-12-15T10:24:09+0000",
"tags": [],
"media_metadata": [],
"request": [
"service_id": "5a33a2c34e4ea8df128b45e7"
],
"media_url": "https://open010.org/static/es.madrid/53ff16dc80db1.png"
]
}
400
ShowHideContent-Type: application/json
[
{
"code": 400,
"description": "request_token not exist"
}
]
Field | Required | Description |
---|---|---|
token | required | Request ID. |
media | required | File attachment |
type | required | File type (image or video) |
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"token": "14092214355",
"media": File,
"type": "image"
}
200
ShowHideContent-Type: application/json
{
"media_code": "53ff16ddf98f71eb698b4567",
"media_url": "https://open010.org/static/es.madrid/53ff16dc80db1.png",
"created_datetime": "2014-08-28T13:47:40+0200",
"type": "image"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "media was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "type was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "error field values request media"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "No more medias are allowed"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
Field | Required | Description |
---|---|---|
token | required | Request ID. |
files[ ] | required | Array of file attachments |
descriptions[ ] | optional | File descriptions in the same order as the files are uploaded |
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"token": "14092214355",
"files[0]": File,
"files[1]": File,
"descriptions[0]" : "File one"
}
200
ShowHideContent-Type: application/json
{
"id": "5a561f024e4ea8e6018b456a",
"created_at": "2018-01-10T14:11:13+0000",
"updated_at": "2018-01-10T14:11:14+0000",
"type": "1",
"description": "File one",
"url": "https://open010.org/local/open010/5a561f015d1cc.pdf"
},
{
"id": "5a561f024e4ea8e6018b456b",
"created_at": "2018-01-10T14:11:13+0000",
"updated_at": "2018-01-10T14:11:14+0000",
"type": "1",
"description": "11082017072112.xls",
"url": "https://open010.org/local/open010/5a561f02185ee.xls"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "too many files uploaded"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "request not found"
}
int
(required) Example: 1App Key
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"deleted": false,
"jurisdiction_id": "es.madrid",
"jurisdiction_name": "Madrid",
"service_code": "1",
"service_name": "Limpieza y Residuos",
"token": "53ff033df98f71e7058b4571",
"service_request_id": "14092214355",
"description": "This is a test",
"lat": 40.4432203,
"long": -3.7042705,
"requested_datetime": "2014-08-28T12:23:55+0200",
"updated_datetime": "2014-08-28T12:23:55+0200",
"address": "Calle Bravo Murillo, 77, 28003 Madrid, Madrid, España",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"priority": 0,
"following_count": 0,
"following": {
"isFollowing": true,
"channels": {
"email": true,
"push": false
}
},
"supporting_count": 0,
"supporting": false,
"complaining_count": 0,
"complaining": false,
"comments_count": 0,
"public": true,
"typology": {
"id": "57538bfe9a60573c048b458f",
"name": "avisos",
"visible_name": "Avisos"
},
"status_node": {
"name": "asignado",
"visible_name": "Asignado",
"id": "57538bfe9a60573c048b45d2"
}
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "user was not found"
}
string
(required) Example: 14092214355Request ID
string
(required) Example: es.madridJurisdiction code
boolean
(optional) Example: trueEmail notifications active/inactive for the request
boolean
(optional) Example: truePush notifications active/inactive for the request
boolean
(optional) Example: truePush sms active/inactive for the request
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"deleted": false,
"jurisdiction_id": "es.madrid",
"jurisdiction_name": "Madrid",
"service_code": "1",
"service_name": "Limpieza y Residuos",
"token": "53ff033df98f71e7058b4571",
"service_request_id": "14092214355",
"description": "This is a test",
"lat": 40.4432203,
"long": -3.7042705,
"requested_datetime": "2014-08-28T12:23:55+0200",
"updated_datetime": "2014-08-28T12:23:55+0200",
"address": "Calle Bravo Murillo, 77, 28003 Madrid, Madrid, España",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"seen": true,
"priority": 0,
"accepted": false,
"medias": [
{
"media_code": "53ff033df98f71e7058b4570",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"created_datetime": "2014-08-28T12:23:55+0200"
}
],
"following_count": 0,
"following": {
"isFollowing": true,
"channels": {
"email": true,
"push": false
}
},
"supporting_count": 0,
"supporting": false,
"complaining_count": 0,
"complaining": false,
"user": {
"id": "123810974734782622",
"nickname": "",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"security_user": {
"id": "123810981217278272",
"nickname": "",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"comments_count": 0,
"public": true,
"typology": {
"id": "57538bfe9a60573c048b458f",
"name": "avisos",
"visible_name": "Avisos"
},
"status_node": {
"name": "asignado",
"visible_name": "Asignado",
"id": "57538bfe9a60573c048b45d2"
}
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Already supported request"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
string
(required) Example: 14092214355Request ID
string
(required) Example: es.madridJurisdiction code
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"deleted": false,
"jurisdiction_id": "es.madrid",
"jurisdiction_name": "Madrid",
"service_code": "1",
"service_name": "Limpieza y Residuos",
"token": "53ff033df98f71e7058b4571",
"service_request_id": "14092214355",
"description": "This is a test",
"lat": 40.4432203,
"long": -3.7042705,
"requested_datetime": "2014-08-28T12:23:55+0200",
"updated_datetime": "2014-08-28T12:23:55+0200",
"address": "Calle Bravo Murillo, 77, 28003 Madrid, Madrid, España",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"seen": true,
"priority": 0,
"accepted": false,
"medias": [
{
"media_code": "53ff033df98f71e7058b4570",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"created_datetime": "2014-08-28T12:23:55+0200"
}
],
"following_count": 0,
"following": {
"isFollowing": false
}
},
"supporting_count": 0,
"supporting": false,
"complaining_count": 0,
"complaining": false,
"user": {
"id": "123810974734782622",
"nickname": "",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"security_user": {
"id": "123810981217278272",
"nickname": "",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"comments_count": 0,
"public": true,
"typology": {
"id": "57538bfe9a60573c048b458f",
"name": "avisos",
"visible_name": "Avisos"
},
"status_node": {
"name": "asignado",
"visible_name": "Asignado",
"id": "57538bfe9a60573c048b45d2"
}
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
string
(required) Example: 14092214355Request ID
string
(required) Example: es.madridJurisdiction code
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"deleted": false,
"jurisdiction_id": "es.madrid",
"jurisdiction_name": "Madrid",
"service_code": "1",
"service_name": "Limpieza y Residuos",
"token": "53ff033df98f71e7058b4571",
"service_request_id": "14092214355",
"description": "This is a test",
"lat": 40.4432203,
"long": -3.7042705,
"requested_datetime": "2014-08-28T12:23:55+0200",
"updated_datetime": "2014-08-28T12:23:55+0200",
"address": "Calle Bravo Murillo, 77, 28003 Madrid, Madrid, España",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"seen": true,
"priority": 0,
"accepted": false,
"medias": [
{
"media_code": "53ff033df98f71e7058b4570",
"media_url": "https://open010.org/static/es.madrid/53ff033b7735b.png",
"created_datetime": "2014-08-28T12:23:55+0200"
}
],
"following_count": 0,
"following": {
"isFollowing": true,
"channels": {
"email": true,
"push": false
}
},
"supporting_count": 0,
"supporting": false,
"complaining_count": 0,
"complaining": false,
"user": {
"id": "123810974734782622",
"nickname": "",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"security_user": {
"id": "123810981217278272",
"nickname": "",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"comments_count": 0,
"public": true,
"typology": {
"id": "57538bfe9a60573c048b458f",
"name": "avisos",
"visible_name": "Avisos"
},
"status_node": {
"name": "asignado",
"visible_name": "Asignado",
"id": "57538bfe9a60573c048b45d2"
}
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Already supported request"
}
Get the number of request which had finished successfully.
Field | Required | Description |
---|---|---|
jurisdiction_ids | required | Jurisdiction codes, separated by comma. |
last_days | required | Days to query, default 7. |
string
(required) Example: com.mycity,es.madridJurisdiction codes
integer
(optional) Example: 7Days to query, default 7
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"jurisdiction_id": "com.mycity,es.madrid",
"last_days": 7,
"count": 200
}
403
ShowHideContent-Type: application/json
{
"error": "invalid_grant",
"error_description": "The access token provided is invalid."
}
string
(required) Example: 53df4fb76803fa443e8b456dService internal ID
double
(required) Example: 40.3434526double
(required) Example: 40.3434526Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
[
{
"jurisdiction": "597ee85a4e4ea819028b4588",
"service_id": "597ee85c4e4ea819028b45e6",
"position": {
"lng": -3.6966153,
"lat": 40.3434526
},
"address_string": "Calle de S. Dalmacio, 21, 28021 Madrid, Spain",
"typology": {
"id": "597ee85b4e4ea819028b45aa",
"name": "avisos",
"visible_name": "Avisos",
"icon": "",
"color": "#337ab7",
"with_medias": true,
"location_type": "geolocation"
},
"status_node_targets": [
{
"name": "en_progreso",
"color": "#7da038",
"typology_node_id": "597ee85b4e4ea819028b45ac",
"visible_name": "En progreso",
"id": "597ee85c4e4ea819028b45df",
"manual_actions": [
"assign",
"reassign",
"auto_assign",
"comment",
"change_status",
"mark_as_duplicated",
"reiterate",
"complaint",
"generate_work_order",
"edit",
"pause_resume"
]}
[...]
]
}
200
ShowHideContent-Type: application/json
[]
404
ShowHideContent-Type: application/json
Service Not Configured
The comments have the following fields
Field | Required | Description |
---|---|---|
token | required | Internal identifier of the request. |
description | required | Content of the comment. |
jurisdiction_id | required | Id Jurisdiction id. |
created_datetime | optional | Creation date of the message. |
backoffice | optional | Manager user that created the comment. |
backffice_user.nickname | optional | Nickname of manager user. |
backoffice_user.avatar | optional | Avatar of manager user. |
user | optional | User that created the comment. |
user.nickname | optional | Nickname of user. |
user.avatar | optional | Avatar of user. |
medias_urls | optional | It contains a list of URLs of all links of the images linked to comment. |
medias | optional | List of images in String of Base64. |
medias_data | optional | List of images in File. |
List all comments associated with request references by token
Field | Description |
---|---|
comment_code | Internal identifier of the comment. |
user | User that created the comment. |
backoffice_user | Gestor that created the comment. |
description | Content of the comment. |
created_datetime | Creation date of the message. |
medias_urls | It contains a list of URLs of all links of the images linked to comment. |
Define data field Gestor “backoffice_user”
Field | Description |
---|---|
backoffice_user.id | Identifier internal of gestor. |
backoffice_user.nickname | Nickname of user. |
backoffice_user.avatar | Avatar of user. |
Define data field User “user”
Field | Description |
---|---|
user.id | Identifier internal of user. |
user.nickname | Nickname of user. |
user.avatar | Avatar of user. |
Define collection data field medias_url
Field | Description |
---|---|
id | Identifier internal image media. |
media_url | Url public image media |
string
(required) Example: 53df4fb76803fa443e8b456dRequest internal ID
string
(required) Example: es.madridId Jurisdiction id
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"comment_code": "53ff181ef98f71eb698b4568",
"user": {
"id": "53ff181ef98f71eb698b4869",
"nickname": "User Public Of the World",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"description": "test comment",
"created_datetime": "2014-08-28T13:53:02+0200",
"medias_urls": [
{
"id": "53ff181ef98f71eb698b6452",
"media_url": "https://aws.com/558813734b819.png"
},
{
"id": "53ff181ef98f71eb698b2345",
"media_url": "https://aws.com/5534567734b819.png"
}
]
}
]
200
ShowHideContent-Type: application/json
[
{
"comment_code": "53ff181ef98f71eb698b1111",
"backoffice_user": {
"id": "53ff181ef98f71eb698b2222",
"nickname": "User Private Gestor",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"description": "test comment",
"created_datetime": "2014-08-28T13:53:02+0200",
"medias_urls": [
{
"id": "53ff181ef98f71eb698b6662",
"media_url": "https://aws.com/558813734b819.png"
},
{
"id": "53ff181ef98f71eb698b8888",
"media_url": "https://aws.com/5534567734b819.png"
}
]
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "request was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "token was not found"
}
Add a new request comment. By adding Authorization
header requests are created associated to corresponding user.
Field | Required | Description |
---|---|---|
token | required | Internal identifier of the request. |
description | required | Content of the comment. |
medias | optional | List of images in String of Base64. |
medias_data | optional | List of images in File. |
string
(required) Example: es.madridId Jurisdiction id
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"token":"MAD1000",
"description": "Description New Comment",
"medias": [
"...",
"..."
],
"medias_data": [
"558813734b819.png",
"5534567734b819.png"
],
}
200
ShowHideContent-Type: application/json
{
"comment_code": "53ff181ef98f71eb698b4568",
"user": {
"id": "53ff181ef98f71eb698b4869",
"nickname": "User Public Of the World",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
},
"description": "test comment",
"created_datetime": "2014-08-28T13:53:02+0200",
"medias_urls": [
{
"id": "53ff181ef98f71eb698b2345",
"media_url": "https://aws.com/5534567734b819.png"
},
{
"id": "53ff181ef98f71eb698b2345",
"media_url": "https://aws.com/5534567734b819.png"
}
]
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "request was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
The evaluations have the following fields
Field | Required | Description |
---|---|---|
id | required | Internal identifier of the evaluation. |
evaluation | required | Evaluation value. Values can be 1, 2 or 3. |
user | optional | Author of the evaluation |
security_user | optional | Manager user that assigned the evaluation. |
List all evaluations associated to the request referenced by the token.
string
(required) Example: 53df4fb76803fa443e8b456dRequest internal ID
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"id": "53ff181ef98f71eb698b4568",
"evaluation": "2",
"user": {
"nickname": "PrototypeUser"
},
"security_user": {
"nickname": "PrototypeManager",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
}
}
]
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "USER_EVALUATION_ACCESS_MODULE_OPEN010_API not active"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "token was not found"
}
Adds a new request evaluation or updates an existing one. Needs Authorization
header to create an evaluation associated to corresponding user.
Only the author of the request can evaluate it.
To create or update an evaluation the following fields are required.
Field | Required | Description |
---|---|---|
token | required | Internal identifier of the request. |
evaluation | required | Evaluation value. Values can be 1, 2 or 3. |
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"token": "f181ef98f71eb698b4"
"evaluation": "1"
}
200
ShowHideContent-Type: application/json
[
{
"id": "53ff181ef98f71eb698b4568",
"evaluation": "2",
"user": {
"nickname": "PrototypeUser"
},
"security_user": {
"nickname": "PrototypeManager",
"avatar": "https://open010.org/static/es.madrid/Y60Tetl60apf79Iw.jpg"
}
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "evaluation was not provided"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "evaluation must be equal to 1, 2 or 3"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "This status of request it can not be evaluated"
}
401
ShowHideContent-Type: application/json
{
"code": 401,
"description": "you can not evaluate a request anonymously"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "USER_EVALUATION_ACCESS_MODULE_OPEN010_API not active"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "only authors can evaluate a request"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "Request has already been evaluated"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "request was not found"
}
409
ShowHideContent-Type: application/json
{
"code": 409,
"description": "anonymous requests can not be evaluated"
}
409
ShowHideContent-Type: application/json
{
"code": 409,
"description": "this request's Jurisdiction final evaluation module is not active"
}
409
ShowHideContent-Type: application/json
{
"code": 409,
"description": "this request's service has the final evaluation module deactivated"
}
Reiterations have the following fields
Field | Required | Description |
---|---|---|
token | required | Internal identifier of the request. |
description | optional | Content of the reiteration. |
source | optional | OriginDevice id provided in jurisdiction. |
follow_request | optional boolean | Follow reiterated request |
email_notification | optional boolean | If ‘follow_request’ is set, it will set the communication via email active or inactive for that specific request |
push_notification | optional boolean | If ‘follow_request’ is set, it will set the communication via push active or inactive for that specific request |
List all reiterations associated with request references by token
string
(required) Example: 53df4fb76803fa443e8b456dRequest internal ID
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"id": "57482eb7946b84f6008b4567",
"request": {
"token": "574d82943587b843d058b0476",
"following_count": 4,
"reiterations_count": 1,
"complaints_count": 0
},
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"email": "hola@ramdas.com",
"first_name": "Hola",
"last_name": "Radmas",
"phone": "3452345",
"datetime": "2016-05-27T11:25:43+0000",
"follow_request": true
},
{
"id": "57482f3e946b8404018b4567",
"request": {
"token": "574d8292946b843d058b4567",
"following_count": 0,
"reiterations_count": 1,
"complaints_count": 0
},
"description": "Continua",
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"user": {
"id": "574819c49a6057f9078b4584",
"nickname": "user"
},
"email": "user@radmas.com",
"first_name": "user",
"datetime": "2016-05-27T11:27:58+0000",
"follow_request": true
},
{
"id": "57482f5b946b8408018b4567",
"request": {
"token": "574d8292946b843d058b8479",
"following_count": 1,
"reiterations_count": 1,
"complaints_count": 1
},
"description": "Sigue habiendo basura por el suelo",
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"email": "hola@ramdas.com",
"datetime": "2016-05-27T11:28:27+0000",
"follow_request": true
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "token was not found"
}
Add a new request reiteration. By adding Authorization
header requests are created associated to corresponding user.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"description": "Reiteración",
"source": "5804ba659a60575c058b4581",
"follow_request": false,
"email_notification": false,
"push_notification": false,
"sms_notification": false
}
200
ShowHideContent-Type: application/json
{
"id": "57483af2946b8440018b4567",
"request": {
"token": "574d8292946b843d058b4567",
"following_count": 0,
"reiterations_count": 1,
"complaints_count": 0
},
"description": "Reiteración POSTMAN",
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"email": "jorge.garcia@radmas.com",
"first_name": "Jorge",
"last_name": "García",
"datetime": "2016-05-27T12:17:54+0000"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "Description: cannot be longer than 2500 characters"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
Complaints have the following fields
Field | Required | Description |
---|---|---|
token | required | Internal identifier of the request. |
description | optional | Content of the complaint. |
source | optional | OriginDevice id provided in jurisdiction. |
List all Complaints associated with request references by token
string
(required) Example: 53df4fb76803fa443e8b456dRequest internal ID
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"id": "57482eb7946b84f6008b4567",
"request": {
"token": "574d82943587b843d058b0476",
"following_count": 4,
"reiterations_count": 1,
"complaints_count": 0
},
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"email": "hola@ramdas.com",
"first_name": "Hola",
"last_name": "Radmas",
"phone": "3452345",
"datetime": "2016-05-27T11:25:43+0000",
"follow_request": true
},
{
"id": "57482f3e946b8404018b4567",
"request": {
"token": "574d8292946b843d058b4567",
"following_count": 0,
"reiterations_count": 1,
"complaints_count": 0
},
"description": "Continua",
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"user": {
"id": "574819c49a6057f9078b4584",
"nickname": "user"
},
"email": "user@radmas.com",
"first_name": "user",
"datetime": "2016-05-27T11:27:58+0000",
"follow_request": true
},
{
"id": "57482f5b946b8408018b4567",
"request": {
"token": "574d8292946b843d058b8479",
"following_count": 1,
"reiterations_count": 1,
"complaints_count": 1
},
"description": "Sigue habiendo basura por el suelo",
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"email": "hola@ramdas.com",
"datetime": "2016-05-27T11:28:27+0000",
"follow_request": true
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
404
ShowHideContent-Type: application/json
{
"code": 404,
"description": "token was not found"
}
Add a new request complaint. By adding Authorization
header requests are created associated to corresponding user.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
{
"description": "Denuncia",
"source": "5804ba659a60575c058b4581",
"email_notification": false,
"push_notification": false,
"sms_notification": false
}
200
ShowHideContent-Type: application/json
{
"id": "57483af2946b8440018b4567",
"request": {
"token": "574d8292946b843d058b8479",
"following_count": 1,
"reiterations_count": 1,
"complaints_count": 1
},
"description": "Denuncia POSTMAN",
"source": {
"id": "5804ba659a60575c058b4581",
"alias": "Otros"
},
"email": "jorge.garcia@radmas.com",
"first_name": "Jorge",
"last_name": "García",
"datetime": "2016-05-27T12:17:54+0000"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "token was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "REQUESTS_ACCESS_MODULE_OPEN010_API not active"
}
Defines all passible alert categories API calls. Categories are configured by jurisdiction and this calls are only available in case of jurisdiction activated it.
Field | Type | Description |
---|---|---|
id | int | Category identifier. |
name | string | Category name. |
icon | string | Category icon, base64 encoded. |
color | string | Hexadecimal category color. |
banner | string | URL category image. |
parent | object | Parent category object with fields [id, name, color]. Only avalable in plain list format. |
children | array | Category children categories. Only available in hierarchy list format. |
string
(required) Example: es.mtcJurisdiction to find by. Required if there is more than one jurisdiction.
string
(optional) Example: plainOne of [plain
, hierarchy
]. plain by default.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"id": 714,
"name": "General"
},
{
"id": 723,
"name": "children",
"icon": "",
"color": "#db8f8f",
"banner": "https://static.open010.org/541bf42aa5abf.jpg",
"parent": {
"id": 714,
"name": "General"
},
sponsoring_info: {
display: true,
description: "Esta información es importante.",
url: "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/sponsoring/55c1e97b62027.png"
}
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": 'format must be "plain" or "hierarchy".'
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "ALERTS_PREMIUM not active"
}
string
(required) Example: 714Category id.
string
(required) Example: es.mtcJurisdiction to find by. Required if there is more than one jurisdiction.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"id": 714,
"name": "General",
"children": [
{
"id": 723,
"name": "children",
"icon": "",
"color": "#db8f8f",
"banner": "https://static.open010.org/541bf42aa5abf.jpg",
"children": []
}
]
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "category not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "ALERTS_PREMIUM not active"
}
Alerts are jurisdiction relevant short communications. Such as events, important traffic or street info.
Field | Type | Description |
---|---|---|
id | string | Alert identifier. |
title | string | Title. |
description | string | Alert text content. |
more_info | string | Related link with more information. |
links | array | Array of related links. |
date | date | Date when the alert will start |
heading | boolean | Important alert. |
notification | boolean | Marks when the alert will be notified to applications. |
image | string | Alert related image. |
category | array | Category the alert belongs to. |
published_at | date | Date when alert became public. |
published_to | date | Date when alert will be unpublished. |
lat | float | The alert geoposition latitude. |
long | float | The alert geoposition longitude. |
string
(required) Example: es.mtcJurisdiction to find by. Required if there is more than one jurisdiction.
string
(optional) Example: 714Categories filter. It can be either a value or an array.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"title": "ImproveYourCity beats in Madrid",
"description": "ImproveYourCity is the new city issue reporting app in Madrid",
"more_info": "http://www.madrid.es",
"links": [
{
"link": "https://www.youtube.com/channel/UCESmx8_PfHLKErQCPEIgvgQ",
"description": "Videos Youtube"
}
],
"date": "2014-09-17T13:47:57+0200",
"heading": true,
"notification": false,
"image": "https://static.open010.org/iyc.jpg",
"category": {
"id": 714,
"name": "General",
"color": ""
},
"id": "1005",
"published_at": "2014-09-15T13:47:57+0200",
"published_to": "2014-09-20T13:47:57+0200",
"lat": 40.416726,
"lng": -3.703701
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "ALERTS_ACCESS_MODULE_OPEN010_API not active"
}
string
(required) Example: 714Alert id.
string
(required) Example: es.mtcJurisdiction to find by. Required if there is more than one jurisdiction.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"title": "ImproveYourCity beats in Madrid",
"description": "ImproveYourCity is the new city issue reporting app in Madrid",
"more_info": "http://www.madrid.es",
"links": [
{
"link": "https://www.youtube.com/channel/UCESmx8_PfHLKErQCPEIgvgQ",
"description": "Videos Youtube"
}
],
"date": "2014-09-17T13:47:57+0200",
"heading": true,
"notification": false,
"image": "https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/jorgegofi/alert/demo/iyc.jpg",
"category": {
"id": 714,
"name": "General",
"color": ""
},
"id": "1005",
"published_at": "2014-09-15T13:47:57+0200",
"published_to": "2014-09-20T13:47:57+0200",
"lat": 40.416726,
"lng": -3.703701
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "alert not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "ALERTS_ACCESS_MODULE_OPEN010_API not active"
}
Group management news jurisdictions
Field | Type | Description |
---|---|---|
id | string | News identification Id |
name | string | Name to news |
color | string | Color Code HTML to news |
icon | string | Icon assigned to news |
sources | arrays | List sources into news |
id | string | Id to Source identification |
name | string | Name to source |
url | string | Url access news |
string
(required) Example: es.mtcJurisdiction to find by. Required if there is more than one jurisdiction.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"id":"554cabac3ca0847e0c8b4567",
"name":"Tabl\u00f3n de anuncios",
"color":"#599e6d",
"icon":"",
"sources":
[
{
"id":"554cabac3ca0847e0c8b4568",
"name":"Ayuntamiento",
"url":"http:\/\/www.valencia.es\/ayuntamiento\/tablon_anuncios.nsf\/tablon.xml"
}
]
},
{
"id":"554cabc43ca084830c8b4567",
"name":"Agenda Cultural",
"color":"#d67474",
"icon":"",
"sources":
[
{
"id":"554cabc43ca084830c8b4568",
"name":"20minutos",
"url":"http:\/\/www.20minutos.es\/rss\/artes\/"
}
]
},
{
"id":"554cabe83ca084830c8b456b",
"name":"Sucesos",
"color":"#d1e00b",
"icon":"",
"sources":
[
{
"id":"554cabe83ca084830c8b456c",
"name":"20minutos",
"url":"http:\/\/www.20minutos.es\/rss\/"
}
]
},
{
"id":"554cac1b3ca084990c8b4567",
"name":"Cultura",
"color":"#4527a0",
"icon":"",
"sources":
[
{
"id":"554cac1b3ca084990c8b4568",
"name":"20minutos",
"url":"http:\/\/www.20minutos.es\/rss\/madrid\/"
}
]
},
{
"id":"554cac333ca084830c8b456f",
"name":"Deportes",
"color":"#ff8f00",
"icon":"",
"sources":
[
{
"id":"554cac333ca084830c8b4570",
"name":"20minutos",
"url":"http:\/\/www.20minutos.es\/rss\/deportes\/"
}
]
}
]
400
ShowHideContent-Type: application/json
{
"code": 400,
"description": "jurisdiction_id was not found"
}
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "NEWS_ACCESS_MODULE_OPEN010_API not active"
}
Releases are jurisdiction relevant short communications. Such as events, important traffic or street info.
Field | Type | Description |
---|---|---|
id | string | Release identifier. |
jurisdictions | array | Array of jurisdiction_id (Required) |
applicationTypes | array | Array of AppConfiguration ids (Required) |
name | string | Release title (Required) |
description | string | Release description (Required) |
tags | array | Array of Tag ids (Required) |
images | array | Collection of attached images |
start_date | date | Date and time when the release is published (Required) |
end_date | date | Date and time when the release is unpublished (Required) |
event_start_date | date | Date and time when the event starts |
event_end_date | date | Date and time when the event ends |
position | array | Array containing ‘lat’ and ‘long’ geoposition coordinates where the event takes place. |
address_string | string | Event address |
links | array | Collection of related links |
files | collection | Collection of attached files |
status | const | Release Status ("pending", “published” , “unpublished”) This field is automatically set |
string
(required) string
(required) int
(optional) int
(optional) Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
[
{
"id": "59281bcb4e4ea8da0f8b456f",
"jurisdictions": [
{
"name": "Carbonero el mayor"
}
],
"application_types": [
{
"id": "592813c74e4ea8b1158b4fab",
"name": "Actua Madrid"
}
],
"name": "test_Release2",
"description": "testing release API",
"tags": [
{
"name": "Deportes"
}
],
"images": [
"https://imageserver/logo.png"
],
"channels": [
{
"id": "5a79d73c4e4ea8b7038b45cf",
"name": "Jardineros"
},
{
"id": "5a79d73c4e4ea8b7038b45d0",
"name": "Bomberos"
}
]
"start_date": "2017-05-11T10:58:16.000+02:00",
"end_date": "2017-05-13T10:58:16.000+02:00",
"event_start_date": "2017-05-13T10:58:16.000+02:00",
"event_end_date": "2017-05-14T10:58:16.000+02:00",
"position": {
"long": -103.3325444,
"lat": 20.6805989
},
"address_string": "test address",
"links": [
{
"name": "TestLink",
"link": "http://testlink.com"
}
],
"files": []
}
]
403
ShowHideContent-Type: application/json
{
"code": 403,
"description": "Permission ALERTS_ACCESS_MODULE not granted"
}
401
ShowHideContent-Type: application/json
{
"error": "access_denied",
"error_description": "OAuth2 authentication required"
}
string
(required) Example: 5936543a4e4ea87f018b4568Release id.
Accept: application/json
Content-Type: application/json
Authorization: Bearer NTM0MTcxMjVjODViNTY5YTcxZWViZjNjZj
200
ShowHideContent-Type: application/json
{
"id": "59281bcb4e4ea8da0f8b456f",
"jurisdictions": [
{
"name": "Carbonero el mayor"
}
],
"application_types": [
{
"id": "592813c74e4ea8b1158b4fab",
"name": "Actua Madrid"
}
],
"name": "test_Release2",
"description": "testing release API",
"tags": [
{
"name": "Deportes"
}
],
"images": [
"https://s3-eu-west-1.amazonaws.com/static.lab.open010.org/local/jurisdiction/demojurisdictions/es.madrid/logo.png"
],
"start_date": "2017-05-11T10:58:16.000+02:00",
"end_date": "2017-05-13T10:58:16.000+02:00",
"event_start_date": "2017-05-13T10:58:16.000+02:00",
"event_end_date": "2017-05-14T10:58:16.000+02:00",
"position": {
"long": -103.3325444,
"lat": 20.6805989
},
"address_string": "test address",
"links": [
{
"name": "TestLink",
"link": "http://testlink.com"
}
],
"files": []
},
"channels": [
{
"id": "5a79d73c4e4ea8b7038b45cf",
"name": "Jardineros"
},
{
"id": "5a79d73c4e4ea8b7038b45d0",
"name": "Bomberos"
}
]
404
ShowHideContent-Type: application/json
{
"error_code": 1028,
"error_description": "Release not found"
}
Generated by aglio on 26 May 2020