The microservice API specification used by MyParcel.com located at https://carrier-specification.myparcel.com. This specification adheres to the OpenApi 3.1.0 specification and implements the JSON API specification.
The repository provides Docker containers to validate and preview the spec before committing changes. This is also used when validating pull requests. To install Docker, follow the steps in the documentation.
To set up the project for development run:
./mp.sh setup
./mp.sh up
- Start the containers which will start a server to watch file changes and reload automatically.
./mp.sh down
- Stop the containers.
./mp.sh validate
- Validate the specification.
NOTE: The validator only works when the containers are already running. Don't forget to start them.
Conventions based on the Swagger and JSON Schema specs.
Our internal conventions are described below.
To avoid discussion, the use of the above HTTP methods is described below.
- Used to create or replace a resource.
- Always returns the same response on repeated requests.
- Needs the full resource for the request (including the id for the to be created or replaced resource).
- Used to create a resource.
- Does not return the same response on repeated requests.
- Does not need the full resource for the request (often does not need the id for the to be created resource).
- Used to update an existing resource.
- Does not return the same response on repeated requests.
- Does not need the full resource for the request (you might only want to update a user's name for example).
The API versioning follows semantic versioning. The increment in version number is done manually and should be part of the pull request.
Definition file names follow PascalCasing. Where every first letter of a word (including the first word) is uppercase. For example, the definition for a country code would be found in:
specification/schemas/CountryCode.json
The files in specification/paths
are named after their corresponding API endpoints. Where resources start with an uppercase letter and path variables with a lowercase letter. For example, the definition of the following route:
carriers/{carrier_id}/services
can be found in:
specification/paths/Carriers-carrier_id-Services.json
Parameter file names are prefixed with the corresponding parameter type. A path parameter for carrier_id
would get the following file path:
specification/parameters/path-carrier_id.json
Unique parameters can just remain in the path file and do not need to be extracted to their own files.
All software by MyParcel.com is licensed under the MyParcel.com general terms and conditions.