BIT offers a RESTful API that only sends its responses back in JSON format. Currently, we only support GET, POST, and PUT call types. The address for these calls are made in the format found below. The first is when a resource is called in general, with option of more specific parameters being applied from there, and the second is there when you're looking for a specific driver or vehicle.
https://blueinktech.com/api/v1/<resource>
https://blueinktech.com/api/v1/<resource>/<id>
Each call must contain the x-api-key header along with the API key generated by the user for authentication purposes. The next section covers obtaining a key.
For directions on how to generate and manage your API keys in our new web portal, click here. For directions on how to manage your keys on the legacy portal, see below.
To make any calls using the BIT API, you'll need to generate an API key to use. This can be done by going to the "My Account" page in the web portal. Once there, click "Request API Key" in the "My API Keys" section of the page. You'll be presented with two sets of options: the carrier that will be using the key, and the second is the type of permissions the key will have (Read-Only or Read/Write). Once you've selected these options, you can click the key to copy it, or click on its type to change its permissions.
When a key is generated, all actions taken while using that key will be performed as if the user that generated the key had performed them. A key can only act within the carrier it was generated for, and may not be used to perform actions for other carriers even if the user generating the key is an admin for those carriers. A carrier is currently allowed up to 200 requests an hour across all keys. If the user that generated a key is removed as an admin for the carrier that the key was generated for, the key will no longer work.
The following parameters are standard to nearly every GET call that is made.
Name | Type | Description |
---|---|---|
page | int | This is used for the purposes of pagination. It defaults to 1 if nothing is supplied. |
per_page | int | This is used for the purposes of pagination. It defaults to 25 if nothing is supplied. |
timezone | string | This is used when a call receives or outputs a date/time. The default time that is used is UTC. The following are a list of valid time zones.
|
This returns a list of users for the carrier. Below are the addresses to access it and a list of parameters that can be supplied. The <id> in the address may be replaced with the id of a specific user.
https://blueinktech.com/api/v1/users/
https://blueinktech.com/api/v1/users/<id>
Name | Type | Description |
---|---|---|
duty_status | string | Search for users with this as their last duty status. Valid duty statuses are:
|
user_role | string | Search for a user of this role. Valid roles are:
|
{ "users": [ { "user": { "id": "12345", "roles": [ "Administrator" ], "time_zone": "US/Eastern", "carrier_name": "Test Trucking", "carrier_street": null, "carrier_city": null, "carrier_state": null, "carrier_zip": null, "terminal_street": null, "terminal_city": null, "terminal_state": null, "terminal_zip": null, "cycle": "USA 70 hour / 8 day", "duty_status": "On Duty not Driving", "yard_moves_enabled": true, "personal_conveyance_enabled": true, "updated_at": "2018-07-20 14:50:57" } }, { "user": { "id": "12346", "roles": [ "Driver" ], "time_zone": "US/Eastern", "carrier_name": "Test Trucking", "carrier_street": null, "carrier_city": null, "carrier_state": null, "carrier_zip": null, "terminal_street": null, "terminal_city": null, "terminal_state": null, "terminal_zip": null, "cycle": "Oilfield", "duty_status": "On Duty not Driving", "yard_moves_enabled": false, "personal_conveyance_enabled": false, "updated_at": "2017-12-22 21:37:16" } } ], "pagination": { "per_page": 25, "page_no": 1, "total": 5 } }
This returns a list of vehicles for the carrier. Below are the addresses to access it and a list of parameters that can be supplied. The <id> in the address may be replaced with the id of a specific vehicle.
https://blueinktech.com/api/v1/vehicles/
https://blueinktech.com/api/v1/vehicles/<id>
Name | Type | Description |
---|---|---|
driver_ids | string | Search for vehicles by its last driver. This is a comma delimited list of driver ids. |
[ { "vehicles": [ { "vehicle": { "id": "12345", "company_id": "123", "number": "Truck 1", "ifta": true, "vin": "1234ABC", "make": "FREIGHTLINER", "model": "Cascadia", "year": "2007", "air_scale": [ { "id": 12347, "axle_label": "Steer Axle", "axle_position": 1, "axle_lb": 11000, "empty_lb": 11000, "label": "15", "last_read": "2020-06-29T21:30:51" }, { "id": 12348, "axle_label": "Drive Axle", "axle_position": 2, "axle_lb": 40000, "empty_lb": 40000, "label": "16", "last_read": "2020-06-29T21:30:51" } ], "tpms": [ { "id": 123456, "equipment_row": 112800, "psi": 10, "psi_hi": 140, "psi_lo": 0, "label": 1, "degrees_farenheit": 70, "last_read": "2020-07-02T10:10:10" } ], "current_trailers": [ { "air_scale": null, "tpms": null, "trailer_id": 76, "number": "Trailer-18", "plate_number": "AAA123" }, { "air_scale": null, "tpms": [ { "id": 123456, "equipment_row": 206, "psi": 10, "psi_hi": 140, "psi_lo": 0, "label": 1, "degrees_farenheit": 70, "last_read": "2020-07-02T10:10:10" } ], "trailer_id": 206, "number": "TRL-5", "plate_number": null }, { "air_scale": [ { "id": 62311, "axle_label": "Trailer Axle", "axle_position": 3, "axle_lb": 2299, "empty_lb": 40000, "label": "15", "last_read": "2020-07-01T12:07:33" } ], "tpms": null, "trailer_id": 424, "number": "Trailer-10", "plate_number": null } ], "current_driver": { "id": "945", "first_name": "John", "last_name": "Smith", "emails": [ null ], "statuses": [ true ], "roles": [ "Driver" ] } } }, { "vehicle": { "id": "12346", "company_id": "123", "number": "Truck 2", "ifta": true, "vin": "1235ABC", "make": "FREIGHTLINER", "model": "Cascadia", "year": "2007", "air_scale": null, "tpms": null, "current_trailers": null, "current_driver": { "id": "1123", "first_name": "Rob", "last_name": "Smith", "emails": [ null ], "statuses": [ false, true ], "roles": [ "Administrator", "Driver" ] } } } ], "pagination": { "per_page": 100, "page_no": 1, "total": 17 } } ]
This returns a list of DVIRs for the carrier. Please note that a date range is required.
https://blueinktech.com/api/v1/inspections
Name | Type | Description |
---|---|---|
start_date | required date (YYYY-MM-DD) |
Date start |
end_date | required date (YYYY-MM-DD) |
Date end |
driver_ids | string | A comma delimited list of driver ids that have performed inspections. |
vehicle_ids | string | A comma delimited list of vehicle ids that have had inspections performed on them. |
status | string | Show inspections with or without defects. If no status is specified, vehicles with both defects and no defects will be returned. Valid inputs are:
|
{ "inspection_reports": [ { "inspection_report": { "id": "998", "inspection_user_id": "123", "issue_count": 0, "inspection_user_first_name": "John", "inspection_user_last_name": "Smith", "inspection_user_emails": [ null ], "time": "2018-06-01 5:05:53", "equipment": [ { "vehicle_id": 12345, "odometer": 125321, "vehicle_number": "Truck 154", "equipment_group": "Truck", "defects": null }, { "vehicle_id": null, "odometer": null, "vehicle_number": "Trailer 876", "equipment_group": "Trailer", "defects": null } ] } }, { "inspection_report": { "id": "999", "inspection_user_id": "123", "issue_count": 0, "inspection_user_first_name": "John", "inspection_user_last_name": "Smith", "inspection_user_emails": [ null ], "time": "2018-06-01 5:05:53", "equipment": [ { "vehicle_id": 12345, "odometer": 125789, "vehicle_number": "Truck 154", "equipment_group": "Truck", "defects": null }, { "vehicle_id": null, "odometer": null, "vehicle_number": "Trailer 876", "equipment_group": "Trailer", "defects": null } ] } } ], "pagination": { "per_page": 25, "page_no": 1, "total": 2 } }
This returns a list of current locations for vehicles. The <id> in the address may be replaced with the id of a specific vehicle. That vehicle must either have a subscription to Fleet Visibility or BIT Full Service.
https://blueinktech.com/api/v1/vehicle_locations/
https://blueinktech.com/api/v1/vehicle_locations/<id>
{ "vehicles": [ { "vehicle": { "id": "123", "number": "Trcuk 543", "year": "2007", "make": "PETERBILT", "model": "987", "vin": "9812AKSDJN123", "current_location": { "lat": "44.140891", "lon": "-88.295156", "located_at": "2018-05-25 00:12:30", "odometer": null, "speed_mph": 60.5 }, "current_driver": { "id": "123", "first_name": "John", "last_name": "Smith", "emails": [ null ], "roles": [ "Administrator", "Driver" ], "statuses": [ false, false ] } } } ], "pagination": { "per_page": 5, "page_no": 1, "total": 1 } }
This returns a list of places that the specified vehicle has been over the given time frame. The <id> in the address may be replaced with the id of a specific vehicle. That vehicle must either have a subscription to Fleet Visibility or BIT Full Service. Please note that a date range no larger than one week, and a vehicle id are required.
https://blueinktech.com/api/v1/vehicle_route/
https://blueinktech.com/api/v1/vehicle_route/<id>
Name | Type | Description |
---|---|---|
start_date | required date (YYYY-MM-DD) |
Date start |
end_date | required date (YYYY-MM-DD) |
Date end |
vehicle_id | required int |
Search for a route with the vehicle's id. |
{ "vehicle": [ { "id": 123, "vin": "1D7HG48N43S146681", "make": "FREIGHTLINER", "year": 2016, "model": "Cascadia", "number": "555" } ], "route": [ { "lat": 38.42259254866754, "lon": -82.44033799587523, "user_id": 12345, "odometer": 531616.2588849, "speed_mph": 0, "located_at": "2021-12-06T23:57:42.213" } ], "pagination": { "per_page": 1, "page_no": 1, "total": 2215 } }
This returns a list of current driver locations. The vehicle that the driver was driving must either have a subscription to Fleet Visibility or BIT Full Service. Below is the address to access it and a list of parameters that can be supplied.
https://blueinktech.com/api/v1/driver_locations
Name | Type | Description |
---|---|---|
driver_ids | string | A list of comma delimited driver ids used for getting their current location. |
{ "users": [ { "user": { "id": "123", "first_name": "John", "last_name": "Smith", "emails": [ null ], "statuses": [ true ], "roles": [ "Driver" ], "current_location": { "lat": "35.1359446", "lon": "-116.3613736", "located_at": "2018-05-25 012:30:22" }, "current_vehicle": { "id": "64216", "number": "Truck 841", "year": "2012", "make": "BIG TRUCK", "model": "ASD", "vin": "ASD123GAW" } } } ], "pagination": { "per_page": 20, "page_no": 1, "total": 1 } }
This returns of contacts for the carrier. These contacts can be listed as contacts for job legs by their ID
https://blueinktech.com/api/v1/job_details
Name | Type | Description |
---|---|---|
id | int | The ID of the contact you're looking for. |
first_name | string | Contacts with this as their first name. |
last_name | string | Contacts with this as their last name. |
string | Contacts with this as their email. |
{ "contacts": [ { "id": 30, "email": "test@test.c", "phone": "3045555555", "first_name": "John", "last_name": "Smith", "cell_phone": "7405555555" } ], "pagination": { "per_page": 25, "page_no": 1, "total": 25 } }
This returns a full list of jobs, their legs, weight, and cargo for the specified date range.
https://blueinktech.com/api/v1/job_details
Name | Type | Description |
---|---|---|
job_number | string | The name given to the job |
start_date | required date (YYYY-MM-DD) |
Start date range for the jobs that are listed |
end_date | required date (YYYY-MM-DD) |
End date range for the jobs that are listed |
{ "jobs": [ { "id": 686, "name": "Test Job", "notes": null, "start_time": "2021-08-29T12:13:00", "end_time": "2021-09-02T12:13:00", "location_start": "Point A", "location_start_geofence_id": 3030, "location_end": "Point B", "location_end_geofence_id": 3036, "status": "No Start Detected", "legs": [ { "job_leg_id": 406, "job_leg_order": 0, "driver": { "id": 1425, "first_name": "Robert", "last_name": "Johnson" }, "codriver": { "id": 1426, "first_name": "Michael", "last_name": "Robson" }, "vehicle": { "id": 1328, "number": "TST Truck", "engine_hours_start": 1000, "engine_hours_end": 1010, "fuel_level_start": null, "fuel_level_end": null, "odometer_start_mi": 55000, "odometer_end_mi": 55450 }, "trailers": [ { "id": 347480, "number": "TRL 1" }, { "id": 347730, "number": "TRL 2" }, { "id": 345582, "number": "TRL 3" } ], "scheduled_start_time": "2021-08-29T12:13:00", "scheduled_end_time": "2021-09-02T12:13:00", "actual_start_time": null, "actual_end_time": null, "scheduled_drive_time_minutes": 5760, "locations": { "start_geofence_id": 3030, "start_geofence_name": "Point A", "end_geofence_id": 3036, "end_geofence_name": "Point B" }, "contacts": { "start_contact_id": 35, "start_contact_first_name": "Jim", "start_contact_last_name": "Johnson", "end_contact_id": 37, "end_contact_first_name": "Bill", "end_contact_last_name": "Romano" }, "notes": "Some notes about this leg", "cargo": { "id": 228, "handling_unit": "hay bale", "quantity": 5, "stackable": false, "hazardous": false, "length_in": 24, "width_in": 34, "height_in": 44, "scheduled_weight_lb": 100, "actual_weight_lb": null }, "scheduled_distance_mi": null, "scheduled_weight_lb": 100, "actual_weight_lb": null } ] } ], "pagination": { "per_page": 25, "page_no": 1, "total": 14 } }
This starts the creation of a new user and sends an invite to the email address that's listed to finish account creation. The response returns the newly created user id.
https://blueinktech.com/api/v1/users
Name | Type | Description |
---|---|---|
required string |
The user's email. This will be the address the invitation will be sent to as well as their login. | |
first_name | required string |
The user's first name. |
last_name | required string |
The user's last name. |
role | required string |
The role the user will occupy. The following is a list of valid values.
|
{ "id": 1557 }
This creates a new vehicle. The response that is returned is the newly created vehicle
https://blueinktech.com/api/v1/vehicles
Name | Type | Description |
---|---|---|
number | required string |
This is the name of the vehicle that will be created. |
vin | required string |
The VIN of the vehicle. |
{ "vehicle_id": "1074" }
This creates a contact for use with the jobs API. The response will be the ID of the newly created contact.
https://blueinktech.com/api/v1/users
Name | Type | Description |
---|---|---|
first_name | required string |
First name of the contact |
last_name | required string |
Last name of the contact |
string | The email of the contact | |
phone | string | The phone number of the contact |
cell_phone | string | The cell phone number of the contact |
{ "id": 51 }
This creates a new job, job legs, and cargo. Jobs must be uniuqely named within the carrier, but a job can be updated. The response is the ID of the newly created job.
https://blueinktech.com/api/v1/vehicles
Name | Type | Description |
---|---|---|
name | required string |
The name of the job |
notes | string | Notes regarding the main job |
legs[] | required array |
You must have at least two legs when creating a job. You must specify an index for the job leg the information you're supplying relates to. |
legs[0][driver_id] | int | The driver responsible for driving this leg |
legs[0][codriver_id] | int | The codriver responsible for driving this leg |
legs[0][vehicle_id] | int | The id of the vehicle that is responsible for driving this leg. |
legs[0][scheduled_start_time] | date/time (YYYY-MM-DD HH:MM:SS) | The time this leg of the job is supposed to start. |
legs[0][scheduled_end_time] | date/time (YYYY-MM-DD HH:MM:SS) | The time this leg of the job is supposed to end. |
legs[0][notes] | string | Notes regarding this leg of the job. |
legs[0][scheduled_drive_time_min] | int | The amount of drive time there is for this leg of the job. If you don't supply drive time, it will be calculated for you based on leg start/end times |
legs[0][scheduled_distance_mi] | int | The number of miles that are supposed to be traveled for this leg of the job. |
legs[0][start_geofence_id] | required int |
The ID of the geofence that the leg starts from. You can supply either this or the name of the geofence. If you supply both, only the ID will be used. |
legs[0][start_geofence_name] | required string |
The name of the geofence that the leg starts from. You can supply either this or the ID of the geofence. If you supply both, only the ID will be used. |
legs[0][end_geofence_id] | required int |
The ID of the geofence that the leg ends at. You can supply either this or the name of the geofence. If you supply both, only the ID will be used. |
legs[0][end_geofence_name] | required string |
The name of the geofence that the leg ends at. You can supply either this or the ID of the geofence. If you supply both, only the ID will be used. |
legs[0][start_contact_id] | int | ID of the contact for the start of the leg |
legs[0][end_contact_id] | int | ID of the contact for the end of the leg |
legs[0][scheduled_weight_lb] | decimal | Expected leg weight in pounds |
legs[0][trailers][trailer_1_id] | int | ID of the first trailer that will be used for this job leg. |
legs[0][trailers][trailer_2_id] | int | ID of the second trailer that will be used for this job leg. |
legs[0][trailers][trailer_3_id] | int | ID of the third trailer that will be used for this job leg. |
legs[0][cargo][] | array | An array of cargo for the leg. |
legs[0][cargo][0][handling_unit] | string | The name of the unit the cargo is provided in (pallets, boxes, etc) |
legs[0][cargo][0][quantity] | int | The number of the unit being provided |
legs[0][cargo][0][stackable] | boolean | Is this cargo stackable? |
legs[0][cargo][0][hazardous] | boolean | Is this cargo hazardous? |
legs[0][cargo][0][length_in] | decimal | Length of the cargo in inches |
legs[0][cargo][0][width_in] | decimal | Width of the cargo in inches |
legs[0][cargo][0][height_in] | decimal | Height of the cargo in inches |
legs[0][cargo][0][scheduled_weight_lb] | decimal | Weight of the cargo in pounds. |
{ "id": 727 }
This updates a vehicles name. Names are unique within each carrier.
https://blueinktech.com/api/v1/vehicles
Name | Type | Description |
---|---|---|
id | required int |
The id of the vehicle to be updated. |
number | string | The new name of the vehicle |
{ "vehicle": { "id": "1075", "company_id": "1", "number": "new name", "ifta": false, "vin": "AFDKILU214IUH98ADG", "make": null, "model": null, "year": null, "current_driver": { "id": null, "first_name": null, "last_name": null, "emails": null, "statuses": null, "roles": null } } }
This updates an existing job. You must supply all of the information about the job when updating it including job legs, and cargo. You may supply the jobs existing ID and a new name for the job, or the existing jobs name to be updated. The paramters to update a job are exactly the same as those to create one. The response is the ID of the updated job.
https://blueinktech.com/api/v1/vehicles
Name | Type | Description |
---|---|---|
id | required string |
The ID of the job. You may supply this and the job name, or just the job name |
name | required string |
The name of the job |
notes | string | Notes regarding the main job |
legs[] | required array |
You must have at least two legs when creating a job. You must specify an index for the job leg the information you're supplying relates to. |
legs[0][driver_id] | int | The driver responsible for driving this leg |
legs[0][codriver_id] | int | The codriver responsible for driving this leg |
legs[0][vehicle_id] | int | The id of the vehicle that is responsible for driving this leg. |
legs[0][scheduled_start_time] | date/time (YYYY-MM-DD HH:MM:SS) | The time this leg of the job is supposed to start. |
legs[0][scheduled_end_time] | date/time (YYYY-MM-DD HH:MM:SS) | The time this leg of the job is supposed to end. |
legs[0][notes] | string | Notes regarding this leg of the job. |
legs[0][scheduled_drive_time_min] | int | The amount of drive time there is for this leg of the job. If you don't supply drive time, it will be calculated for you based on leg start/end times |
legs[0][scheduled_distance_mi] | int | The number of miles that are supposed to be traveled for this leg of the job. |
legs[0][start_geofence_id] | required int |
The ID of the geofence that the leg starts from. You can supply either this or the name of the geofence. If you supply both, only the ID will be used. |
legs[0][start_geofence_name] | required string |
The name of the geofence that the leg starts from. You can supply either this or the ID of the geofence. If you supply both, only the ID will be used. |
legs[0][end_geofence_id] | required int |
The ID of the geofence that the leg ends at. You can supply either this or the name of the geofence. If you supply both, only the ID will be used. |
legs[0][end_geofence_name] | required string |
The name of the geofence that the leg ends at. You can supply either this or the ID of the geofence. If you supply both, only the ID will be used. |
legs[0][start_contact_id] | int | ID of the contact for the start of the leg |
legs[0][end_contact_id] | int | ID of the contact for the end of the leg |
legs[0][scheduled_weight_lb] | decimal | Expected leg weight in pounds |
legs[0][trailers][trailer_1_id] | int | ID of the first trailer that will be used for this job leg. |
legs[0][trailers][trailer_2_id] | int | ID of the second trailer that will be used for this job leg. |
legs[0][trailers][trailer_3_id] | int | ID of the third trailer that will be used for this job leg. |
legs[0][cargo][] | array | An array of cargo for the leg. |
legs[0][cargo][0][handling_unit] | string | The name of the unit the cargo is provided in (pallets, boxes, etc) |
legs[0][cargo][0][quantity] | int | The number of the unit being provided |
legs[0][cargo][0][stackable] | boolean | Is this cargo stackable? |
legs[0][cargo][0][hazardous] | boolean | Is this cargo hazardous? |
legs[0][cargo][0][length_in] | decimal | Length of the cargo in inches |
legs[0][cargo][0][width_in] | decimal | Width of the cargo in inches |
legs[0][cargo][0][height_in] | decimal | Height of the cargo in inches |
legs[0][cargo][0][scheduled_weight_lb] | decimal | Weight of the cargo in pounds. |
{ "id": 727 }