HTTP API that parses Postcode Address File records into correctly formatted address lines
Parses Postcode Address File records into correctly formatted address recognised by Royal Mail according to its Clear Addressing Guidelines.
Produces consistent address lines, a post town line and a postcode line via HTTP
- Exposes UK Clear Addressing as a HTTP service
- Deployable as a docker container or node.js application
- GitHub Repository
- Test Live on paf-api.ideal-postcodes.dev
- Docker Hub Image
- UK Clear Addressing Project
- NPM Package
- More information on Postcode Address File data attributes
- PAF Programmer's Guide
Try on paf-api.ideal-postcodes.dev
curl -X POST \
https://paf-api.ideal-postcodes.dev/parse \
-H 'Content-Type: application/json' \
-d '{ "sub_building_name": "Flat 8", "building_name": "Oxford House 110-114", "thoroughfare": "High Street" }'
This API responds to POST
requests to /parse
with a JSON payload representing a PAF Record
POST /parse
{
"postcode": "WS11 5SB",
"post_town": "CANNOCK",
"thoroughfare": "Pye Green Road",
"building_name": "Flower House 189A",
"organisation_name": "S D Alcott Florists",
}
{
"query": {
"postcode": "WS11 5SB",
"post_town": "CANNOCK",
"thoroughfare": "Pye Green Road",
"building_name": "Flower House 189A",
"organisation_name": "S D Alcott Florists",
"building_number": "",
"sub_building_name": "",
"dependant_locality": "",
"double_dependant_locality": "",
"dependant_thoroughfare": "",
"po_box": "",
"department_name": "",
},
"formatted": {
"postcode": "WS11 5SB",
"post_town": "CANNOCK",
"line_1": "S D Alcott Florists",
"line_2": "Flower House",
"line_3": "189a Pye Green Road",
"premise": "Flower House, 189a"
}
}
{
building_number: string | number;
building_name: string;
sub_building_name: string;
dependant_locality: string;
double_dependant_locality: string;
thoroughfare: string;
dependant_thoroughfare: string;
po_box: string;
post_town: string;
postcode: string;
department_name: string;
organisation_name: string;
}
Using the Docker CLI
docker pull idealpostcodes/paf-api:latest
docker run -p 8080:8080 idealpostcodes/paf-api
Alternatively with docker-compose
git clone https://github.com/ideal-postcodes/paf-api && cd paf-api
docker-compose up -d
Requires Node.js 8 or above
git clone https://github.com/ideal-postcodes/paf-api && cd paf-api && npm install
npm start # Traffic served on 8080
The npm module exports an Express app factory, which takes a pino
logger
const { App } = require("paf-api");
const app = App({ logger: pino() });
http.createServer(app).listen(PORT);
The following environment variables can be passed to the application.
PORT=8080 # Sets the port to listen on
MIT