Update vehicle by ID
post
/fleetMonitoring/clientapi/v2/vehicles/{vehicle-id}
This operation updates information about a vehicle specified by its ID with the provided vehicle definition that is partial or complete.
Request
Supported Media Types
- application/json
Path Parameters
-
vehicle-id: string
The unique identifier of the vehicle.
Header Parameters
-
X-HTTP-Method-Override: string
To perform a partial update of the vehicle, the POST request should be orchestrated with method override set to PATCH.
-
X-ORACLE-IOT-ORG(optional): string
To allow targeting requests to different organizations. The header value should contain the organization identifier(orgId). This header is optional, if not provided orgId will be ORA_DEFAULT_ORG
Root Schema : Vehicle_update
Type:
Show Source
object
-
attributes(optional):
array attributes
Vehicle attributes
-
description(optional):
string
Vehicle Description
-
name(optional):
string
Vehicle Name
-
registrationNumber(optional):
string
Vehicle registration number
-
type(optional):
string
Vehicle Type ID
-
vin(optional):
string
Vehicle identification number
Nested Schema : Attribute_update
Type:
Show Source
object
-
name(optional):
string
Vehicle Attribute Name
-
type(optional):
string
One of [CUSTOM, SENSOR].
Response
Supported Media Types
- application/json
- application/vnd.oracle.resource+json;type=singular
200 Response
Successfully processed.
Root Schema : Vehicle_receive
Type:
Show Source
object
-
attributes:
array attributes
Vehicle attributes
-
description:
string
Vehicle Description
-
driverId:
string
Driver ID
-
id:
string
Vehicle ID
-
lastModifiedBy:
string
Vehicle modified by
-
lastModifiedTime:
integer
Vehicle last modified time (epoch time in milliseconds)
-
lastReportedTime:
integer
Vehicle last reported time (epoch time in milliseconds)
-
make:
string
Vehicle make
-
metricSnapshot:
object MetricSnapshot_receive
-
model:
string
Vehicle model
-
name:
string
Vehicle Name
-
registeredBy:
string
Vehicle registered by
-
registrationNumber:
string
Vehicle registration number
-
registrationTime:
integer
Time at which vehicle was registered (epoch time in milliseconds)
-
registrationTimeAsString:
string
Vehicle registration time
-
status:
string
Vehicle mobility status, One of [IN_MOTION, STOPPED, UNKNOWN, IDLING].
-
tripId:
string
Trip Id
-
type:
string
Vehicle Type ID
-
vin:
string
Vehicle identification number
-
year:
integer
Vehicle year
Nested Schema : MetricSnapshot_receive
Type:
Show Source
object
-
metricValues:
array metricValues
The metric values of an entity
Nested Schema : MetricValue_receive
Type:
Show Source
object
-
booleanValue(optional):
boolean
Property description was not set
-
computedTime:
integer
Property description was not set
-
confidenceLevel(optional):
integer
Property description was not set
-
entityId:
string
Property description was not set
-
entityType:
string
Property description was not set
-
esAdditionalData:
object esAdditionalData
Additional Properties Allowed: additionalPropertiesProperty description was not set
-
esRelationType:
object EsJoinFieldValue_receive
-
eventTime:
integer
Property description was not set
-
eventTimeAsString:
string
Property description was not set
-
geoLocationValue(optional):
object GeoPosition_receive
-
id:
string
Property description was not set
-
interval:
string
One of [DYNAMIC, CURRENT, EVERY2MINUTE, HOURLY, DAILY, NEXT24HOURS, WEEKLY, BIWEEKLY, NEXT7DAYS, NEXT30DAYS, MONTHLY, DAYS90, STATIC].
-
lastKnown:
boolean
Property description was not set
-
metadata:
object metadata
Additional Properties Allowed: additionalPropertiesProperty description was not set
-
name:
string
Property description was not set
-
numericValue(optional):
integer
Property description was not set
-
params:
object params
Additional Properties Allowed: additionalPropertiesProperty description was not set
-
stringValue(optional):
string
Property description was not set
-
type:
string
One of [KPI, PREDICTION, ANOMALY, TREND_NELSON, TREND, SENSOR, CORRELATION, CLUSTERING].
Nested Schema : esAdditionalData
Type:
object
Additional Properties Allowed
Show Source
-
string
A map of the following type: Map<String, String>
Property description was not set
Show Source
Nested Schema : EsJoinFieldValue_receive
Type:
Show Source
object
-
name:
string
Property description was not set
-
parent:
string
Property description was not set
Nested Schema : GeoPosition_receive
Type:
Show Source
object
-
additionalElements:
array additionalElements
Property description was not set
-
altitude:
number
Property description was not set
-
latitude:
number
Property description was not set
-
longitude:
number
Property description was not set
-
valid:
boolean
Property description was not set
Nested Schema : metadata
Type:
object
Additional Properties Allowed
Show Source
-
string
A map of the following type: Map<String, String>
Property description was not set
Show Source
Nested Schema : params
Type:
object
Additional Properties Allowed
Show Source
-
string
A map of the following type: Map<String, String>
Property description was not set
Show Source
400 Response
Bad Request. The request could not be understood by the server due to malformed syntax. The client SHOULD NOT repeat the request without modifications.
401 Response
Unauthorized. The request requires user authentication.
404 Response
Not Found. The server has not found anything matching the Request-URI. No indication is given of whether the condition is temporary or permanent.
405 Response
Method Not Allowed. The method specified in the Request-Line is not allowed for the resource identified by the Request-URI.
406 Response
Request Not Acceptable. The resource identified by the request is only capable of generating response entities which have content characteristics not acceptable according to the accept headers sent in the request.
415 Response
Unsupported Media Type. The request entity has a media type which the server or resource does not support.
Examples
curl -X POST
-u <username>:<password>
-H 'Accept: application/json'
-H 'Content-Type: application/json'
--header "X-HTTP-Method-Override: PATCH"
https://iotserver/fleetMonitoring/clientapi/v2/vehicles/{vehicle-id}
Example of Request Body
The following example shows the content of the request body in JSON format:
{
"name":"TestVehicle",
"vin":"12345",
"registrationNumber":"Reg-01-01-01",
"type":"17E1131D-4AC7-4551-A09B-C473FC3AF25F",
"description":"Test Vehicle",
"year":2017,
"attributes":[
{
"name":"test_attribute_custom",
"value":"value1"
},
{
"name":"Speed",
"value":{
"deviceId":"3192FE29-C248-42BC-9C1E-5B9E78A87AA4",
"deviceModel":"urn:com:oracle:iot:device:obd2",
"messageFormatField":"ora_obd2_vehicle_speed"
}
}
]
}
Example of Response Body
The following example shows the content of the response body in JSON format:
{
"id": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"name": "TestVehicle",
"make": "make_name",
"model": "model_name",
"year": 2017,
"status": "UNKNOWN",
"vin": "12345",
"type": "17E1131D-4AC7-4551-A09B-C473FC3AF25F",
"registrationNumber": "Reg-01-01-01",
"attributes": [
{
"name": "test_attribute_custom",
"value": "value1"
},
{
"name": "Speed",
"value": {
"deviceId": "3192FE29-C248-42BC-9C1E-5B9E78A87AA4",
"deviceModel": "urn:com:oracle:iot:device:obd2",
"messageFormatField": "ora_obd2_vehicle_speed"
}
}
],
"registrationTime": 1524555339308,
"registrationTimeAsString": "2018-04-24T07:35:39.308Z",
"lastModifiedTime": 1524555339308,
"lastModifiedTimeAsString": "2018-04-24T07:35:39.308Z",
"lastModifiedBy": "iot",
"description": "Test Vehicle",
"metricValues": [
{
"id": "1c4196cb-a8f9-39f8-95b9-2e2af265f7d2",
"name": "sys_openOutageIncidents",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"numericValue": 0
},
{
"id": "eb8916d6-b2d5-31a8-9fc0-e83fff45799c",
"name": "sys_fuelConsumed",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"numericValue": 0
},
{
"id": "b8a4acfe-af6a-3821-8301-9432328fd8d0",
"name": "sys_alerts",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"numericValue": 0
},
{
"id": "2176b6b7-e8b6-397c-8cbb-6218a24e738d",
"name": "sys_availabilityStatus",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"booleanValue": true
},
{
"id": "2b381dff-66b2-314b-9c43-5ec1d559d1db",
"name": "sys_openIncidents",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"numericValue": 0
},
{
"id": "a6d176fe-a283-3c74-aae2-7c759dfeb44a",
"name": "sys_consumedFuelCost",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"numericValue": 0
},
{
"id": "171bd431-7566-3414-ad41-315c46507fbf",
"name": "sys_utilizationStatus",
"entityType": "vehicles",
"eventTime": 1524555339469,
"computedTime": 1524555339469,
"eventTimeAsString": "2018-04-24T07:35:39Z",
"interval": "CURRENT",
"entityId": "FA1EE482-D601-4720-B4F6-0A338BF16E1C",
"type": "KPI",
"lastKnown": false,
"booleanValue": false
}
],
"links": [
{
"href": "https://iotserver/fleetMonitoring/clientapi/v2/vehicles",
"rel": "self"
},
{
"href": "https://iotserver/fleetMonitoring/clientapi/v2/vehicles",
"rel": "canonical"
}
]
}
Complete cURL Example
The following example shows a complete cURL command that you can use to perform the described operation:
curl -X POST
-u <username>:<password>
-H 'Accept: application/json'
-H 'Content-Type: application/json'
--header "X-HTTP-Method-Override: PATCH"
-d '{"registrationNumber":"Vehicle registration number","name":"Vehicle Name","description":"Vehicle Description","vin":"Vehicle identification number","attributes":[{"name":"Vehicle Attribute Name","type":"One of [CUSTOM, SENSOR]."}],"type":"Vehicle Type ID"}'
https://iotserver/fleetMonitoring/clientapi/v2/vehicles/56356774e5-70eb
Note that in the request,
https://iotserver
will be replaced by the name and port of your assigned IoT Cloud Service instance. The format of the Cloud Service instance is
https://myinstance-myidentitydomain.iot.us.oraclecloud.com
and the default port is 443.