This repository contains XML Schemas used in EWP APIs for street and postal addressing. It follows the same versioning rules as all EWP APIs do. Other projects are welcome to reuse this schema, along with its namespace. We are also open to suggestions of extending it.
As of 2016, there are no standard addressing schemes. They vary widely from country to country. Even the Universal Postal Union says so. Unfortunately, this means that developers in each of the partner countries will often have database structures not strictly compatible with one another, and this in turn MAY mean some additional work to implement proper conversion, or change your data model. There's simply no other way.
The format we have chosen allows to specify addresses in two different ways:
-
The structural format. It should allow majority of server developers to provide the addresses in a structural form compatible with most current European standards (as of 2016), but there is a possibility that it will need to be extended in the future.
-
The simple fallback format, which leaves a "side door" open for use cases we cannot currently predict (i.e. countries which use, or will use, different standards). This format follows best practices used by companies who work with international shipping, so it seems to be a reasonable choice for a fallback. (Of the two formats, this one is probably less likely to become deprecated in the future.)
You may compare both formats by reviewing the attached XSD and the examples below.
Street Address and Mailing Address - many of us don't realize that, but for some recipients there's a big difference between one and another. You can read on this here.
In some EWP APIs we require server developers to be aware which type of address they provide (or we allow them to provide both). Client developers also should have this distinction in mind (for example, should you risk importing street addresses, if your database expects mailing addresses only?).
See attached schema.xsd
file.
Two ways of expressing a single address:
<mailing-address>
<recipientName>John Doe, Head of IRO Office</recipientName>
<!-- Option 1: The simple fallback format -->
<addressLine>Casmir Palace</addressLine>
<addressLine>Krakowskie Przedmieście 26/28</addressLine>
<postalCode>00-927</postalCode>
<locality>Warszawa</locality>
<country>PL</country>
</mailing-address>
<mailing-address>
<recipientName>John Doe, Head of IRO Office</recipientName>
<!-- Option 2: Structural -->
<buildingNumber>26/28</buildingNumber>
<buildingName>Casmir Palace</buildingName>
<streetName>Krakowskie Przedmieście</streetName>
<postalCode>00-927</postalCode>
<locality>Warszawa</locality>
<country>PL</country>
</mailing-address>
Valid mailing address, but not a valid street address:
<mailing-address>
<postOfficeBox>1072</postOfficeBox>
<postalCode>0316</postalCode>
<locality>Oslo</locality>
<country>NO</country>
</mailing-address>
Somewhat valid street address, but probably not a valid mailing address:
<street-address>
<addressLine>University of Oslo</addressLine>
<locality>Oslo</locality>
<country>NO</country>
</street-address>
Missing <locality>
or <country>
should be a very rare case, but it is not
strictly forbidden. Many clients won't recognize it as a valid address, but if
you cannot provide it in a more structured form, then it's still better than
nothing (see this issue):
<mailing-address>
<addressLine>Casmir Palace, Krakowskie Przedmieście 26/28, 00-927 Warszawa, POLAND</addressLine>
</mailing-address>
An extremely limited address - with only a country (and possibly a city) present. Many clients won't recognize it as a valid address, but others might use even that limited information. It seems better to provide it this way, rather than providing nothing (e.g. see this issue):
<street-address>
<country>NO</country>
</street-address>