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

Add policy author spec #3

Open
wants to merge 6 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 4 commits
Commits
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
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
.venv/
.venv/
*.swp

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't be modifying the .gitignore

125 changes: 125 additions & 0 deletions policy-author/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
# Policy-Author API (draft)

## Background

The Policy API specifies an endpoint and a JSON schema for communicating mobility policy to providers. This document describes a companion API to the provider-facing Policy endpoints for creating and editing Policy and Geography objects.

[Policy PR](https://github.com/CityOfLosAngeles/mobility-data-specification/pull/322)

## Endpoints

The agency-facing Policy Author API consists of the following endpoints. The endpoints to list Policy and Geography objects are defined in the Policy API. The only addition is that when calling the GET /policies endpoint, append ?unpublished to get the unpublished ones, separate from the published ones. Adding ?unpublished will have no effect if your access token has a provider_id.

### Policy Endpoints

Responses must set the `Content-Type` header, as specified in the [Provider versioning](../provider/README.md#versioning) section. They must also specify the API version in the JSON-formatted response body, under the `version` key.

#### Schema

See Policy API.

Metadata is free-form JSON format.

### GET /policies

Get a list of policies.

A note: the `get_published` and `get_unpublished` parameters only make sense in the Policy Author version of this endpoint, because the Policy Author API is intended for use by Agencies and not Providers. Providers should never be able to see unpublished Policies, as those are not yet meant for public consumption.

Parameters:
| Name | Type | R/O | Description |
| ------------ | --------- | --- | ---------------------------------------------- |
| `id` | UUID | Optional | If provided, returns one policy object with the matching UUID; default is to return all policy objects. |

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems wrong, it should definitely be a policy_id parameter (which is what it is in the reference impl)

| `get_published` | string | O | If set to the string 'true', returns metadata of published policies. |
| `get_unpublished` | string | O | If set to the string 'true', returns metadata of unpublished policies. |

Response codes:
- 200 - success
- 400 - cannot return results because both params were set to true
- 401 - unauthorized
- 404 - not found
- 500 - server error


### POST /policies

Create a new unpublished (mutable) Policy

Payload: a new Policy object, without a `policy_id`

; a failure explanation on failure

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Typo?


Response codes:

- 201 - Created. Returns: the Policy object on success, including a `policy_id` and a `version` indicating the current API version.
- 400 - Policy does not conform to schema

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can also send a 409 upon a conflict

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Which I suppose doesn't make sense considering we auto-fill a policy_id, I'll remove that error handling

- 401 - Unauthorized (if any auth issue)
- 500 - Server error (hopefully doesn’t happen)

### PUT /policies/{id}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should be /{policy_id}


Update an existing Policy. Must be unpublished.

Payload: a new Policy object

Response codes:

- 200 - success, returns Policy object
- 400 - Policy does not conform to schema
- 401 - unauthorized
- 404 - not found
- 409 - conflict (if immutable)
- 500 - server error

### POST /policies/{id}/publish

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/policies/{policy_id}/publish


Publish (make immutable) a Policy. Must be unpublished.

Response codes:

- 200 - success
- 401 - unauthorized
- 404 - not found
- 409 - conflict (if already published)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should add 424 for a missing dependency

- 500 - server error

### GET /policies/meta

Get a list of policy metadata.

Parameters:
| Name | Type | R/O | Description |
| ------------ | --------- | --- | ---------------------------------------------- |
| `get_published` | string | O | If set to the string 'true', returns metadata of published policies. |
| `get_unpublished` | string | O | If set to the string 'true', returns metadata of unpublished policies. |

Response codes:
- 200 - success
- 400 - cannot return results because both params were set to true
- 401 - unauthorized
- 404 - not found
- 500 - server error


### GET /policies/{id}/meta

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/policies/{policy_id}/meta


Get metadata for a specific policy.

Response codes:
- 200 - success
- 401 - unauthorized
- 404 - not found
- 500 - server error


### PUT /policies/{id}/meta

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/policies/{policy_id}/meta

Edit metadata for a specific policy. Takes a PolicyMetadata object in the request body.

Response codes:
- 200 - success
- 401 - unauthorized
- 404 - not found
- 500 - server error



32 changes: 15 additions & 17 deletions policy/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ This specification describes the digital relationship between _mobility as a ser

## Background

The goal of this specification is to enable Agencies to create, revise, and publish machine-readable policies, as sets of rules for individual and collective device behavior exhibited by both _mobility as a service_ Providers and riders / users. Examples of policies include:
The goal of this specification is to enable Agencies to publish machine-readable policies, as sets of rules for individual and collective device behavior exhibited by both _mobility as a service_ Providers and riders / users. Examples of policies include:

- City-wide and localized caps (e.g. "Minimum 500 and maximum 3000 scooters within city boundaries")
- Exclusion zones (e.g. "No scooters are permitted in this district on weekends")
Expand All @@ -22,6 +22,12 @@ The goal of this specification is to enable Agencies to create, revise, and publ

The machine-readable format allows Providers to obtain policies and compute compliance where it can be determined entirely by data obtained internally.

Policies will typically be linked to one or more associated geographies. Geography descriptions (e.g. geofences or lists of street segments) must also be maintained by the Agency indefinitely. Policies without specific geographies (global policies) are assumed to apply to the entire service area managed by the Agency.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't mention service areas, no longer a thing. Perhaps better to say something like "assumed to apply to all jurisdictions managed by the Agency".


Geographical data will be stored as immutable GeoJSON, referenced by UUID. See the Geography and Geography Author specs for information on the Geography schema, and how Agencies are expected to create and maintain Geographies and serve them to Providers. In a future revision of Agency, we will deprecate the existing `/service_areas` endpoint. `/service_areas` currently only handles GeoJSON MultiPolygon and Polygon objects, and Policy documents might prefer Points for locations such as drop-zones. Policy may be used for a variety of enforcement actions, so it's important for the Agency to persist and keep immutable both Policy and Geography data.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

GeoJSON FeatureCollection instead of just GeoJSON.

/service_areas has already been deprecated.




[Top](#table-of-contents)

## Distribution
Expand Down Expand Up @@ -80,11 +86,10 @@ The response to a client request must include a valid HTTP status code defined i

#### Policies

Endpoint: `/policies/{id}`
Method: `GET`
`data` Payload: `{ "policies": [] }`, an array of objects with the structure [outlined below](#policy).
#### GET `/policies/`
`data` Payload: `{ "policies": [] }`, an array of Policy objects.

##### Query Parameters
Parameters

| Name | Type | Required / Optional | Description |
| ------------ | --------- | --- | ---------------------------------------------- |
Expand All @@ -98,18 +103,6 @@ Policies will be returned in order of effective date (see schema below), with pa

`provider_id` is an implicit parameter and will be encoded in the authentication mechanism, or a complete list of policies should be produced. If the Agency decides that Provider-specific policy documents should not be shared with other Providers (e.g. punitive policy in response to violations), an Agency should filter policy objects before serving them via this endpoint.

#### Geographies

Endpoint: `/geographies/{id}`
Method: `GET`
`data` Payload: `{ geographies: [] }`, an array of GeoJSON `Feature` objects.

##### Query Parameters

| Name | Type | Required / Optional | Description |
| ------------ | --------- | --- | ---------------------------------------------- |
| `id` | UUID | Optional | If provided, returns one geography object with the matching UUID; default is to return all geography objects. |

### Flat Files

To use flat files, policies shall be represented in two (2) files:
Expand Down Expand Up @@ -168,6 +161,11 @@ The optional `end_date` field applies to all policies represented in the file.

## Schema

<a name="policy-fields"></a>

### Policy Fields


All response fields must use `lower_case_with_underscores`.

Response bodies must be a `UTF-8` encoded JSON object and must minimally include the MDS `version`, a timestamp indicating the last time the data was `updated`, and a `data` payload:
Expand Down