Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature modes passenger services #763

Merged
merged 116 commits into from
Sep 9, 2022
Merged
Show file tree
Hide file tree
Changes from 92 commits
Commits
Show all changes
116 commits
Select commit Hold shift + click to select a range
c476f77
Add modality
avatarneil Jul 27, 2020
e380b00
WIP Adding state transitions for taxi
avatarneil Aug 13, 2020
3cb1163
Add multi-trip state model
avatarneil Aug 18, 2020
5b5e069
Add accessibility options
avatarneil Aug 18, 2020
5ac069c
Accessibility options cleanup
avatarneil Aug 18, 2020
42914b6
Update table of contents
avatarneil Aug 19, 2020
5f1bb02
Add trips endpoint
avatarneil Aug 19, 2020
de0467e
reserve_time -> reservation_time for trips
avatarneil Aug 24, 2020
61d5084
Clean up trips a bit
avatarneil Aug 25, 2020
eaadc54
%s\depot_enter\maintenance_start\g
avatarneil Aug 27, 2020
1a4827c
%s\depot_leave\maintenance_end\g
avatarneil Aug 27, 2020
b336adf
Rework propulsion_types slightly
avatarneil Aug 31, 2020
63e5210
Formatting cleanup
avatarneil Aug 31, 2020
f9dc02a
Add brief description to accessibility_options.
avatarneil Aug 31, 2020
6c266d7
Looser payment_methods in fare
avatarneil Aug 31, 2020
69840d7
Update vehicle events in agency to remove language about deregistrati…
avatarneil Aug 31, 2020
d3a38a0
typo
avatarneil Aug 31, 2020
d851e54
WIP updating reservation_type and reservation_method
avatarneil Aug 31, 2020
90446d5
Rename accessibility_options_used -> accessibility_options, add more …
avatarneil Sep 4, 2020
1c41180
replace boarding with accessible
avatarneil Sep 4, 2020
b904294
Rename MDS state diagram to Micromobility state diagram
philipjrose Sep 5, 2020
2ea5b32
Add Taxi state machine diagram
philipjrose Sep 5, 2020
6066652
Merge pull request #17 from lacuna-tech/feature/neil/extend-accessibi…
avatarneil Sep 8, 2020
7153b1f
Add requested_trip_start_location
avatarneil Sep 8, 2020
9805fcd
Formatting cleanup
avatarneil Sep 8, 2020
a4d2816
Add scheduled_trip_start_time
avatarneil Sep 9, 2020
2c1ddeb
Update reservation type description
avatarneil Sep 9, 2020
ae968de
Add decommissioned and recommissioned events for Taxi
avatarneil Sep 9, 2020
87cc3a6
fix minor typo
avatarneil Sep 9, 2020
65222f8
Clean up wording
avatarneil Sep 9, 2020
c1c42b1
Update modalities description
avatarneil Sep 9, 2020
8ce84d1
Update requirements
avatarneil Sep 9, 2020
6809645
Update general-information.md
brianngca Sep 9, 2020
a3f3597
Update general-information.md
avatarneil Sep 10, 2020
40b8ecc
Typos & formatting
avatarneil Sep 10, 2020
cd6c21c
Merge pull request #22 from lacuna-tech/feature/neil/update-modalitie…
avatarneil Sep 10, 2020
f460ac8
Merge pull request #21 from lacuna-tech/feature/neil/add-decommission…
avatarneil Sep 10, 2020
1eb549a
scheduled_trip_start_time -> quoted_trip_start_time
avatarneil Sep 10, 2020
cf74844
Merge pull request #18 from lacuna-tech/phil/add-taxi-state-machine-d…
avatarneil Sep 10, 2020
4b641db
Move things around a bit, share chunks of language between MM/Taxi, a…
avatarneil Sep 10, 2020
4529c93
Merge pull request #23 from lacuna-tech/feature/neil/rework-event-sta…
brianngca Sep 10, 2020
caff510
Merge pull request #19 from lacuna-tech/feature/neil/add_requested_tr…
avatarneil Sep 11, 2020
96cebd6
Merge branch 'add-taxi-mode' into feature/neil/add-scheduled-trip-sta…
avatarneil Sep 11, 2020
5bc8025
Merge pull request #20 from lacuna-tech/feature/neil/add-scheduled-tr…
avatarneil Sep 11, 2020
2e57e43
Extend language
avatarneil Sep 11, 2020
e6daec5
More language extension
avatarneil Sep 11, 2020
c8a75af
Table fix
avatarneil Sep 11, 2020
776c375
Update link
avatarneil Sep 11, 2020
b6dcbc4
Update wording for Trips endpoint in Agency
avatarneil Sep 11, 2020
9dd80cf
Update Fares
avatarneil Sep 11, 2020
e13d7c0
Update Fares some more
avatarneil Sep 11, 2020
a6c0f72
Fix formatting
avatarneil Sep 16, 2020
8c3e647
Add modality to Policy
avatarneil Sep 23, 2020
98be5bf
Default modality is micromobility
avatarneil Sep 23, 2020
7086cf9
Add accessibility options to policy
avatarneil Sep 23, 2020
ba0ccd9
wording cleanup
avatarneil Sep 23, 2020
540164e
Add note about existence of default for backwards compatibility
avatarneil Sep 30, 2020
1a31c04
Merge pull request #24 from lacuna-tech/feature/neil/add-modality-to-…
avatarneil Oct 13, 2020
52d99b6
Merge pull request #25 from lacuna-tech/feature/neil/add-accessibilty…
avatarneil Oct 13, 2020
437344f
Reword vehicle_id requirement
avatarneil May 25, 2021
63c8260
Merge remote-tracking branch 'upstream/feature-modes' into feature/ne…
avatarneil Dec 13, 2021
44ef38e
Formatting updates
avatarneil Dec 13, 2021
bc4c0a2
Remove bad link
avatarneil Dec 13, 2021
6d31f28
Modality -> Mode
avatarneil Dec 13, 2021
8fdfb4c
Remove dupe propulsion_types entry
avatarneil Dec 13, 2021
2653b6c
Move taxi vehicle states & events to modes/taxi.md
avatarneil Dec 13, 2021
bf34e43
Move mode from rule -> policy level
avatarneil Dec 13, 2021
b5299b0
Merge branch 'feature-modes' into feature/neil/add-taxi-to-feature-modes
marie-x Mar 16, 2022
d73d3c5
Ongoing refactor work to match modes PR
marie-x Mar 30, 2022
e001cea
refactor trip_id requirements
marie-x Mar 30, 2022
c4f3bc8
remove changes to general-information, propagate into modes stuff
marie-x Mar 30, 2022
9a82610
revert TOC changes
marie-x Mar 31, 2022
23cd4ee
don't over-link
marie-x Mar 31, 2022
9b8b0a3
Clean up TOC
avatarneil Apr 27, 2022
9b94225
Fix event_types and vehicle_states links
avatarneil Apr 27, 2022
dc4ecaa
Rename state machine diagrams
avatarneil Apr 27, 2022
5e23f0b
Don't re-iterate descriptions for propulsion_types, fix Policy TOS
avatarneil Apr 27, 2022
da59502
Taxi -> Passenger Services
avatarneil Apr 27, 2022
9451cbf
Remove root-level micromobility-state-machine-diagram.svg
avatarneil Apr 27, 2022
330d8b6
Align main README language with target branch a bit more
avatarneil Apr 27, 2022
37eaa47
Fix TOC formatting
avatarneil Apr 27, 2022
ba327d0
Merge pull request #735 from lacuna-tech/feature/neil/add-taxi-to-fea…
schnuerle Apr 28, 2022
09c5c0c
Cleanup pass
schnuerle Apr 28, 2022
50605ed
Cleanup and added provider_cancellation
schnuerle Apr 28, 2022
f89e123
Reverted TOC
schnuerle Apr 28, 2022
d0f30c3
Modes links and cleanup
schnuerle Apr 28, 2022
9ef33a1
Typo cleanup
schnuerle Apr 28, 2022
0340561
Added mode id text
schnuerle Apr 28, 2022
5cf046b
Added mode id for PS
schnuerle Apr 28, 2022
705f1ff
Updated intro text for modes
schnuerle Apr 28, 2022
6f8a254
Remove duplicate mode field, manual fixes to TOC
schnuerle May 3, 2022
5974594
Added ## Vehicle Characteristics section
schnuerle May 3, 2022
26a87df
Update to API list at top of page
schnuerle May 3, 2022
2996a63
Added PS state machine source
schnuerle May 3, 2022
c00728f
Added mode details
schnuerle May 11, 2022
b81a0ab
Added mode column to provider CSV
schnuerle May 11, 2022
9d8d69b
Add vehicle_attributes to trips
schnuerle May 11, 2022
c5f6e31
Added 2 more trip types for Micromobility
schnuerle May 12, 2022
c3f5572
Update description and journey types
schnuerle May 12, 2022
686f0a6
Update micro description and journey
schnuerle May 12, 2022
6c07893
Adding some trip attributes
schnuerle Aug 25, 2022
0e3523d
Updates to trip attributes and formatting
schnuerle Aug 25, 2022
aca8379
Clarifying mode-specific fields in trips
schnuerle Aug 26, 2022
314ba9f
Clarify start/end time and mode
schnuerle Aug 26, 2022
a4e6c7c
Updated TOC
schnuerle Aug 26, 2022
2699e82
Added examples of journeys
schnuerle Aug 29, 2022
59290a5
Removed VIN only language from vehicle_id
schnuerle Aug 29, 2022
c4d1d47
Added examples to vehicle_id
schnuerle Aug 29, 2022
d482776
Created new fare_attributes array
schnuerle Aug 29, 2022
8722dd2
Descriptions added to fare attributes
schnuerle Aug 29, 2022
6336a3d
Updated fare_type and driver_id
schnuerle Aug 30, 2022
2f9d58a
Added start/end location to trips
schnuerle Sep 6, 2022
756982e
Updating to match latest modes formatting
schnuerle Sep 8, 2022
4d69fd2
Add TOC links
schnuerle Sep 8, 2022
c33c9b4
Updating accessibility options
schnuerle Sep 8, 2022
4920f72
Added accessibility section
schnuerle Sep 8, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
- [Versions](#versions)
- [Technical Information](#technical-information)
- [Get Involved](#get-involved)
- [Membership](#membership)
- [Membership](#membership)
- [Cities Using MDS](#cities-using-mds)
- [Providers Using MDS](#providers-using-mds)
- [Software Companies Using MDS](#software-companies-using-mds)
Expand Down
36 changes: 22 additions & 14 deletions agency/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ A vehicle record is as follows:
| `vehicle_id` | String | Vehicle Identification Number (vehicle_id) visible on vehicle |
| `vehicle_type` | Enum | [Vehicle Type][vehicle-types] |
| `propulsion_types` | Enum[] | Array of [Propulsion Type][propulsion-types]; allows multiple values |
| `vehicle_attributes` | Array of [vehicle attributes](/modes/#vehicle-attributes) | Vehicle attributes appropriate for the current mode |
| `vehicle_attributes` | Array of [vehicle attributes](/modes/#vehicle-attributes) | Vehicle attributes appropriate for the current [mode][modes] |
schnuerle marked this conversation as resolved.
Show resolved Hide resolved
| `state` | Enum | Current vehicle state. See [Vehicle State][vehicle-states] |
| `prev_events` | Enum[] | Last [Vehicle Event][vehicle-events] |
| `updated` | [timestamp][ts] | Date of last event update |
Expand All @@ -111,7 +111,7 @@ Body Params:
| `vehicle_type` | Enum | Required | [Vehicle Type][vehicle-types] |
| `mode` | Enum | Required | [Mobility Mode][modes] |
| `propulsion_types` | Enum[] | Required | Array of [Propulsion Type][propulsion-types]; allows multiple values |
| `vehicle_attributes` | Array of [vehicle attributes](/modes/#vehicle-attributes) | Vehicle attributes appropriate for the current mode |
| `vehicle_attributes` | Conditionally Required | Array of [vehicle attributes](/modes/#vehicle-attributes) | Vehicle attributes appropriate for the current [mode][modes] |

201 Success Response:

Expand Down Expand Up @@ -143,7 +143,7 @@ Body Params:

| Field | Type | Required/Optional | Field Description |
| ------------ | ------- | ----------------- | -------------------------------------------------------------------- |
| `vehicle_id` | String | Required | Vehicle Identification Number (vehicle_id) visible on vehicle |
| `vehicle_id` | String | Required | License Plate (if present) or VIN visible on a vehicle |
schnuerle marked this conversation as resolved.
Show resolved Hide resolved

200 Success Response:

Expand All @@ -164,7 +164,7 @@ _No content returned if no vehicle matching `device_id` is found._

## Vehicle - Event

The vehicle `/event` endpoint allows the Provider to control the state of the vehicle including deregister a vehicle from the fleet.
The vehicle `/event` endpoint allows the Provider to control the state of the vehicle.

Endpoint: `/vehicles/{device_id}/event`
Method: `POST`
Expand All @@ -177,14 +177,14 @@ Path Params:

Body Params:

| Field | Type | Required/Optional | Field Description |
| ----------- | ----------------------------- | -------- | -------------------------------------------------------------------------------- |
| `vehicle_state` | Enum | Required | see [Vehicle States][vehicle-states] |
| `event_types` | Enum[] | Required | see [Vehicle Events][vehicle-events] |
| `timestamp` | [timestamp][ts] | Required | Date of last event update |
| `telemetry` | [Telemetry](#telemetry-data) | Required | Single point of telemetry. |
| Field | Type | Required/Optional | Field Description |
|-----------------|------------------------------|------------------------|------------------------------------------------------------------------------------------------------------|
| `vehicle_state` | Enum | Required | see [Vehicle States][vehicle-states] |
| `event_types` | Enum[] | Required | see [Vehicle Events][vehicle-events] |
| `timestamp` | [timestamp][ts] | Required | Date of last event update |
| `telemetry` | [Telemetry](#telemetry-data) | Required | Single point of telemetry |
| `event_geographies` | UUID[] | Optional | **[Beta feature](/general-information.md#beta-features):** *Yes (as of 1.1.0)*. Array of Geography UUIDs consisting of every Geography that contains the location of the event. See [Geography Driven Events][geography-driven-events]. Required if `telemetry` is not present. |
| `trip_id` | UUID | Optional | UUID provided by Operator to uniquely identify the trip. Required if `event_types` contains `trip_start`, `trip_end`, `trip_cancel`, `trip_enter_jurisdiction`, or `trip_leave_jurisdiction` |
| `trip_id` | UUID | Conditionally required | UUID provided by Operator to uniquely identify the trip. See `trip_id` requirements for each [mode][modes]. |

201 Success Response:

Expand Down Expand Up @@ -323,6 +323,8 @@ Path Params:

If `stop_id` is specified, `GET` will return an array with a single stop record, otherwise it will be a list of all stop records.

[Top][toc]

## Reservation Type

The reservation type enum expresses the urgency of a given reservation. This can be useful when attempting to quantify metrics around trips: for example, computing passenger wait-time. In the `on_demand` case, passenger wait-time may be quantified by the delta between the `reservation_time`, and the pick-up time; however, in the `scheduled` case, the wait time may be quantified based on the delta between the `scheduled_trip_start_time` found in the Trips payload, and the actual `trip_start_time`.
Expand All @@ -332,6 +334,8 @@ The reservation type enum expresses the urgency of a given reservation. This can
| `on_demand` | The passenger requested the vehicle as soon as possible |
| `scheduled` | The passenger requested the vehicle for a scheduled time in the future |

[Top][toc]

## Reservation Method

The reservation method enum describes the different ways in which a passenger can create their reservation.
Expand All @@ -342,6 +346,8 @@ The reservation method enum describes the different ways in which a passenger ca
| `street_hail` | Reservation was made by the passenger hailing the vehicle |
| `phone_dispatch` | Reservation was made by calling the dispatch operator |

[Top][toc]

## Fare

The Fare object describes a fare for a Trip.
Expand All @@ -354,6 +360,8 @@ The Fare object describes a fare for a Trip.
| currency | string | Required | ISO 4217 currency code |
| payment_methods | `string[]` | Optional | Breakdown of different payment methods used for a trip, e.g. cash, card, equity_program |

[Top][toc]

## Trip Metadata

The Trips endpoint serves two purposes:
Expand Down Expand Up @@ -394,9 +402,9 @@ Payload which was POST'd
| `bad_param` | A validation error occurred. | Array of parameters with errors |
| `missing_param` | A required parameter is missing. | Array of missing parameters |


[Top][toc]

[accessibility-options]: /general-information.md#accessibility-options
[beta]: /general-information.md#beta-features
[general]: /general-information.md
[geography-driven-events]: /general-information.md#geography-driven-events
Expand All @@ -409,6 +417,6 @@ Payload which was POST'd
[toc]: #table-of-contents
[ts]: /general-information.md#timestamps
[vehicle-types]: /general-information.md#vehicle-types
[vehicle-states]: /modes#vehicle-states
[vehicle-events]: /modes#event-types
[vehicle-states]: /modes/vehicle_states.md
[vehicle-events]: /modes/event_types.md
[versioning]: /general-information.md#versioning
96 changes: 57 additions & 39 deletions general-information.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,31 +4,33 @@ This document contains specifications that are shared between the various MDS AP

## Table of Contents

* [Beta Features](#beta-features)
* [Costs and Currencies](#costs-and-currencies)
* [Definitions](#definitions)
* [Devices](#devices)
* [Geographic Data][geo]
* [Geographic Telemetry Data](#geographic-telemetry-data)
* [Stop-based Geographic Data](#stop-based-geographic-data)
* [Intersection Operation](#intersection-operation)
* [Geography-Driven Events](#geography-driven-events)
* [Optional Authentication](#optional-authentication)
* [Propulsion Types](#propulsion-types)
* [Responses](#responses)
* [Error Messages](#error-messages)
* [Strings](#strings)
* [Stops](#stops)
* [Stop Status](#stop-status)
* [GBFS Compatibility](#gbfs-compatibility)
* [Timestamps](#timestamps)
* [UUIDs](#uuids)
* [Vehicle States](#vehicle-states)
* [Event Types](#event-types)
* [Vehicle State Events](#vehicle-state-events)
* [State Machine Diagram](#state-machine-diagram)
* [Vehicle Types](#vehicle-types)
* [Versioning](#versioning)
- [Beta Features](#beta-features)
- [Costs and Currencies](#costs-and-currencies)
- [Definitions](#definitions)
- [Devices](#devices)
- [Geographic Data](#geographic-data)
- [Geographic Telemetry Data](#geographic-telemetry-data)
- [Stop-based Geographic Data](#stop-based-geographic-data)
- [Intersection Operation](#intersection-operation)
- [Geography-Driven Events](#geography-driven-events)
- [Optional Authentication](#optional-authentication)
- [Responses](#responses)
- [Error Messages](#error-messages)
- [Strings](#strings)
- [Stops](#stops)
- [Stop Status](#stop-status)
- [GBFS Compatibility](#gbfs-compatibility)
- [Timestamps](#timestamps)
- [UUIDs](#uuids)
- [Vehicle Characteristics](#vehicle-characteristics)
- [Accessibility Options](#accessibility-options)
- [Propulsion Types](#propulsion-types)
- [Vehicle Types](#vehicle-types)
- [Vehicle States](#vehicle-states)
- [Event Types](#event-types)
- [Vehicle State Events](#vehicle-state-events)
- [State Machine Diagram](#state-machine-diagram)
- [Versioning](#versioning)

## Beta Features

Expand Down Expand Up @@ -176,19 +178,6 @@ Note if implementing the beta feature [Geography Driven Events](/general-informa

[Top][toc]

## Propulsion Types

| `propulsion` | Description |
| ----------------- | ------------------------------------------------------ |
| `human` | Pedal or foot propulsion |
| `electric_assist` | Provides power only alongside human propulsion |
| `electric` | Contains throttle mode with a battery-powered motor |
| `combustion` | Contains throttle mode with a gas engine-powered motor |

A vehicle may have one or more values from the `propulsion`, depending on the number of modes of operation. For example, a scooter that can be powered by foot or by electric motor would have the `propulsion` represented by the array `['human', 'electric']`. A bicycle with pedal-assist would have the `propulsion` represented by the array `['human', 'electric_assist']` if it can also be operated as a traditional bicycle.

[Top][toc]

## Responses

* **200:** OK: operation successful.
Expand Down Expand Up @@ -316,7 +305,35 @@ See new location within [individual modes](/modes#list-of-supported-modes) in [m

[Top][toc]

## Vehicle Types
## Vehicle Characteristics

Properties and characteristics of vehicles and devices.

[Top][toc]

### Accessibility Options
This enum represents the accessibility options available on a given vehicle, or the accessibility options utilized for a given trip. Optional and applicable only to certain [modes][modes].

| `accessibility_option` | Description |
|-------------------------|---------------------------------------|
| `wheelchair_accessible` | This vehicle is wheelchair accessible |

[Top][toc]

### Propulsion Types

| `propulsion` | Description |
| ----------------- | ------------------------------------------------------ |
| `human` | Pedal or foot propulsion |
| `electric_assist` | Provides power only alongside human propulsion |
| `electric` | Contains throttle mode with a battery-powered motor |
| `combustion` | Contains throttle mode with a gas engine-powered motor |

A vehicle may have one or more values from the `propulsion`, depending on the number of modes of operation. For example, a scooter that can be powered by foot or by electric motor would have the `propulsion` represented by the array `['human', 'electric']`. A bicycle with pedal-assist would have the `propulsion` represented by the array `['human', 'electric_assist']` if it can also be operated as a traditional bicycle.

[Top][toc]

### Vehicle Types

The list of allowed `vehicle_type` values in MDS. Aligning with [GBFS vehicle types form factors](https://github.com/NABSA/gbfs/blob/master/gbfs.md#vehicle_typesjson-added-in-v21-rc).

Expand Down Expand Up @@ -364,6 +381,7 @@ If an unsupported or invalid version is requested, the API must respond with a s
[geo]: #geographic-data
[geojson-feature]: https://tools.ietf.org/html/rfc7946#section-3.2
[geojson-point]: https://tools.ietf.org/html/rfc7946#section-3.1.2
[modes]: /modes/README.md
[policy]: /policy/README.md
[provider]: /provider/README.md
[st-intersects]: https://postgis.net/docs/ST_Intersects.html
Expand Down
6 changes: 3 additions & 3 deletions modes/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@ All MDS APIs should be mode-agnostic.

## Modes

The `mode` value is used to specify the applicable mobility category in MDS Policy, MDS Jurisdictions, and other parts of the spec. The only currently supported mode is `micromobility`, but others such as taxi and delivery robots are planned.
The `mode` value is used to specify the applicable mobility category in MDS Policy, MDS Jurisdictions, and many other parts of MDS.

A `mode` is defined as: A distinct regulatory framework for a type of mobility service, as distinguished by a combination of a) the data needed by regulators, b) the operating rules under which the service functions, c) the legal authority under which it is regulated, and the d) design and operating model of the service itself.

There will be some gray areas and some differences from one jurisdiction to another (e.g. taxis and ridehail may be regulated under the same rules on one place, but different rules in another). We do not need to pre-define a complete taxonomy of modes, or identify every modal boundary upfront, but would instead add modes on an as-needed basis, maintaining as much consistency of naming as possible.
There will be some gray areas and some differences from one jurisdiction to another (e.g. taxis and ridehail may be regulated under the same rules on one place, but different rules in another). MDS will not pre-define a complete taxonomy of modes, or identify every modal boundary upfront, but will instead add modes on an as-needed basis, maintaining as much consistency of naming as possible.

We should err on the side of treating highly similar services as one mode, but should consult with our members and community to inform each decision about how to integrate a new service and whether it needs to be designated as its own mode. This is a policy implementation question as much as it is a technical one.
We err on the side of treating highly similar services as one mode, but consult with our members and community to inform each decision about how to integrate a new service and whether it needs to be designated as its own mode. This is a policy implementation question as much as it is a technical one.

Each mode defined in MDS shall include key descriptive information, such as journey type (e.g. point-to-point, multi-segment, multi-segment overlapping), primary purpose (goods, single passenger, multi-passenger, etc.), and a description of the service being offered that aligns with terminology commonly understood by the public (e.g. “e-scooter” or “ridehailing”).

Expand Down
5 changes: 4 additions & 1 deletion modes/event_types.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,15 +14,18 @@ As with all MDS definitions, they should be described in a way that maximizes th
| `comms_restored` | Communications restored |
| `compliance_pick_up` | Pick up for compliance (rule violation) |
| `decommissioned` | Decommissioned |
| `driver_cancellation` | Driver cancelled a trip |
| `located` | Located (opposite of Missing) |
| `maintenance` | General maintenance |
| `maintenance_pick_up` | Pick up for maintenance |
| `missing` | Missing |
| `off_hours` | Off hours - end of service |
| `on_hours` | On hours - start of service |
| `passenger_cancellation` | Passenger cancelled a trip |
| `provider_cancellation` | Provider cancelled a trip |
| `provider_drop_off` | Drop off by the provider |
| `rebalance_pick_up` | Pick up for rebalancing |
| `reservation_cancel` | Reservation canceled |
| `reservation_cancel` | Reservation cancelled |
| `reservation_start` | Reservation started |
| `system_resume` | Resume system operations, e.g. start of day |
| `system_suspend` | Suspend system operations, e.g. end of day |
Expand Down
29 changes: 26 additions & 3 deletions modes/micromobility.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,21 @@ See the [modes overview](/modes) for how the mode specific information below app

Some fields used across MDS APIs are defined in more detail within each mode.

### Mode ID

The short name identifier for Micromobility used across MDS is `micromobility`.

### Journey ID

The `journey_id` field is not used with the micromobility mode.

### Trip ID Requirements

Required in events if `event_types` contains `trip_start`, `trip_end`, `trip_cancel`, `trip_enter_jurisdiction`, or `trip_leave_jurisdiction`.

### Trip Type

The `trip_type` field may have one of the following values:
The `trip_type` field **may** have one of the following values:

- `rider`: a single rider is taking a trip

Expand All @@ -37,9 +45,24 @@ The `trip_attributes` array is not used with the micromobility mode.
The `vehicle_attributes` array may have the following key value pairs:

- `year` (integer)
- `manufacturer` (string)
- `make` (string)
- `model` (string)

### Propulsion Types

#### Valid for vehicle_types: bicycle, scooter, moped, other

| `propulsion` |
| ----------------- |
| `human` |
| `electric_assist` |
| `electric` |
| `combustion` |

### Accessibility Options

Accessibility options are not used in micromobility.

[Top][toc]

## Vehicle States
Expand Down Expand Up @@ -155,7 +178,7 @@ Vehicles can enter the `unknown` state to and from any other state with the foll
### State Machine Diagram

This *State Machine Diagram* shows how `vehicle_state` and `event_type` relate to each other and how vehicles can transition between states. See [Google Slides](https://docs.google.com/presentation/d/1Ar2-ju8YlddSsTATvQw4YjsSa5108XtidtnJNk-UAfA/edit) for the source file.
![MDS State Machine Diagram](/modes/MDS-micromobility-state-machine-diagram.svg)
![MDS State Machine Diagram](/modes/micromobility-state-machine-diagram.svg)

[Top][toc]

Expand Down
Loading