Motorability History (3)
| Date | Good | Tolerable | Intolerable | Failed | No response |
|---|---|---|---|---|---|
| 2026-05-27 12:02:36 |
Run failed
-
|
Run failed
-
|
Run failed
-
|
Run failed
-
|
Run failed
-
|
| 2026-05-20 12:02:36 |
Run failed
-
|
Run failed
-
|
Run failed
-
|
Run failed
-
|
Run failed
-
|
| 2026-05-13 12:17:53 |
Run failed
-
|
Run failed
-
|
Run failed
-
|
Run failed
-
|
Run failed
-
|
API
API Reference (Current)
Base prefix: /api/ (for DRF endpoints under all_roads/api/urls.py)
1) List all segments
- Method:
GET - Path:
/api/all_segments/ - Handler:
all_roads.api.views.all_segments_view - Response: serialized Segment records (
SegmentSerializer,fields='__all__')
2) Queue refresh
- Method:
POST - Path:
/api/update-segments/queue/ - Handler:
all_roads.api.views.queue_refresh - Request JSON (optional):
{
"codes": ["F100LAS1", "F102RIV2"]
}- Response JSON:
{
"task_id": "<celery-task-id>"
}3) Task status
- Method:
GET - Path:
/api/tasks/<uuid:task_id>/ - Handler:
all_roads.api.views.task_status - Response JSON:
task_idstateresult(if successful)error(if failed)
Website JSON endpoints (non-DRF but API-like)
4) Road inventory route details
- Method:
GET - Path:
/road-inventory/route-details/ - Query params:
route(required)- Handler:
website.views.road_inventory_route_details - Response JSON:
summaryobjectsegmentsarray
5) Segment code search
- Method:
GET - Path:
/segments/search/ - Query params:
q(min length 2)- Handler:
website.views.segment_code_search
6) Road condition subsegments
- Method:
GET - Path:
/road-condition/subsegments/ - Query params:
segment(required)- Handler:
website.views.road_condition_subsegments
7) Road condition save draft
- Method:
POST - Path:
/road-condition/save-draft/ - Handler:
website.views.road_condition_save_draft - Creates draft defects for selected sub-segments where eligible.
8) Library segment editor
- Method:
POST - Path:
/library/road-inventory/segments/<segment_code>/ - Handler:
website.views.library_segment_editor - Purpose: update a segment from the Library Road Inventory edit modal.
9) Library subsegment editor
- Method:
POST - Path:
/library/road-inventory/subsegments/<subsegment_code>/ - Handler:
website.views.library_subsegment_editor - Purpose: update Library inline sub-segment fields:
start_pointend_point
10) Library segment bulk delete
- Method:
POST - Path:
/library/road-inventory/delete/ - Handler:
website.views.library_segments_bulk_delete - Purpose: bulk delete selected segment rows from Library Road Inventory.
11) Library subsegment bulk delete
- Method:
POST - Path:
/library/road-inventory/subsegments/delete/ - Handler:
website.views.library_subsegments_bulk_delete - Purpose: delete selected sub-segments from an expanded Library segment row and renumber the remaining sub-segments for that parent segment.
Auth and permissions notes
- Some endpoints currently use
AllowAnyand should be reviewed for production hardening if public write access is not intended. - JWT authentication is configured globally in DRF settings, but endpoint-level permission decorators control openness.
API operational recommendations
- Use queue refresh endpoint for production updates.
- Poll task status endpoint for completion and summary.
- Add rate and permission controls before exposing write-capable endpoints publicly.
Uploads
Uploading, please wait...