The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in https://www.ietf.org/rfc/rfc2119.txt.
Abbr. | Description |
---|---|
CDR |
Charge Detail Record |
CPO |
Charging Point Operator |
eMSP |
e-Mobility Service Provider |
EV |
Electric Vehicle |
EVSE |
Electric Vehicle Supply Equipment. Is considered as an independently operated and managed part of a Charge Point that can deliver energy to one EV at a time. |
JSON |
JavaScript Simple Object Notation |
NAP |
National Access Point |
NSP |
Navigation Service Provider |
OCPP |
Open Charge Point Protocol |
SCSP |
Smart Charging Service Provider |
In the EV Charging landscape, different market roles can be identified.
Role | Description |
---|---|
CPO |
Charging Point Operator: Operates a network of Charge Points. |
eMSP |
e-Mobility Service Provider: gives EV drivers access to charging services. |
Hub |
Can connect one or more CPOs to one or more eMSPs. |
NAP |
National Access Point: Provides a national Database with all (public) Charging Locations, information can be sent and retrieved from the NAP (that makes it different from a typical NSP). |
NSP |
Navigation Service Provider: Provides EV drivers with location information of Charge Points. |
Roaming Hub |
See: Hub |
SCSP |
Smart Charging Service Provider: Provided Smart Charging service to other parties might use a lot of different inputs to calculate Smart Charging Profiles. |
Some of these roles can be combined in one company. A Platform can provide service for multiple CPOs or eMSPs, but also for both eMSPs and CPOs.
OCPI 2.0/2.1.1 had a very strict definition of roles: only CPO and eMSP. But this is rare in the real world, there are almost no parties that are strictly CPO or eMSP and have their own platform. In the real world, lots of parties provide service to CPOs that are not running their own platform. A lot of CPOs are also eMSP. With OCPI 2.1.1 and earlier that meant having to set up an OCPI connection per role.
OCPI 2.2 introduces more roles and abstracts the role from the OCPI connection itself. OCPI 2.2 talks about Platforms connecting to Platforms, or Platforms connecting via Hubs to other Platforms. The Platform itself is not a role. The Platform provides services for 1 or more roles.
Examples of platforms:
-
A pure CPO: Not providing services to other CPOs. Not being an eMSP. Running its own software that connects via OCPI.
Is defined in OCPI as a Platform has 1 CPO role, the CPO role of that company. -
A Company that has a cloud-based eMSP software solution, it offers to companies that want to be eMSP, but don’t want to host/run their own software.
Is a Platform that has a number of eMSP roles, one for each eMSP the company is providing services for. Not for this company itself because the company itself is not an eMSP. -
A Company that operates public Charge Points and also provides eMSP service to EV drivers, running their own software platform.
Is seen in OCPI as a Platform that has 2 roles: CPO and eMSP for this company. -
If one the companies above starts to offer their service to other CPOs and eMSP, it is in OCPI still seen as 1 platform. This platform then provides multiple CPO and eMSP roles.
The following table shows the typical modules implemented by the different roles. These are not required. The table shows the typical communication role: Receiver, Sender or Both.
Modules | CPO | eMSP | Hub | NSP | NAP | SCSP |
---|---|---|---|---|---|---|
Sender |
Receiver |
Both |
||||
Receiver |
Both |
Sender |
||||
Receiver |
Sender |
Both |
||||
Both |
Both |
Both |
Both |
Both |
Both |
|
Receiver |
Receiver |
Sender |
Receiver |
Receiver |
Receiver |
|
Sender |
Receiver |
Both |
Receiver |
Both |
||
Sender |
Receiver |
Both |
Receiver |
|||
Sender |
Receiver |
Both |
Receiver |
Both |
||
Receiver |
Sender |
Both |
||||
Both |
Both |
Both |
Both |
Both |
Both |
Term | Description |
---|---|
Broadcast Push |
When communicating via a Hub, a data owner can do a single call to the Hub, the Hub then calls all receiving systems. |
Charge Point |
The physical system where an EV can be charged. A Charge Point has one or more EVSEs. Sometimes called Charging Station |
Client Owned Objects |
In a normal REST interface the server is the owner of data, when a new resource is created by call POST, the server creates the URL where the resource can be found by a client. |
Configuration Module |
OCPI Module needed to setup en maintain OCPI connections, but does not provide information for the EV driver:
Credentials, Versions
and Hub Client Info. |
Functional Module |
OCPI Module that provides functionality/information for the EV Driver, such as: Tokens,
Locations, CDRs etc. |
Open Routing Request |
This is for Platforms that are connected via a Hub. When a system send a pull request to the Hub,
and does not know, or care about, the owner of information, but asks the Hub to route the GET to the correct Platform.
The Hub finds the correct Platform and routes the request to that Platform. |
Platform |
Software that provides services via OCPI. A platform can provide service for a single eMSP or CPO, or for multiple CPOs or eMSPs. It can even provide services for both eMSPs and CPOs at the same time. |
Pull |
A system calls GET request to retrieve information from the system that owns the data. |
Push |
The system (owning the data) actively calls POST/PUT/PATCH to update other systems with new/updated information. |
In OCPI it is advised to use eMI3 compliant names for Contract IDs and EVSE IDs. The provider and the operator name is important here, to target the right provider or operator, they need to be known upfront, at least between the cooperating parties.
In several standards, an issuing authority is mentioned that will keep a central registry of known Providers and Operators. At this moment, the following countries have an authority that keeps track of the known providers and operators:
The Dutch foundation, named eViolin keeps the registry for The Netherlands, Belgium and Luxembourg.
-
The list of operator IDs and provider IDs can be viewed on their website eViolin/Leden.
The BDEW organisation keeps the registry for Germany in their general code number service bdew-codes.de.
Austrian Mobile Power GmbH maintains a registry for Austria. This list is not publicly available. For more information visit austrian-mobile-power.at
The AFIREV* organization will keep/keeps the registry for France. It provides operation Id for CPO and eMSP in compliance with eMI3 id structure. The prefix of these Ids is the “fr” country code. AFIREV will also be in charge of the definition of EVSE-Id structure, Charging-Pool-Id structure (location), and Contract-Id structure for France. AFIREV bases its requirements and recommendations on eMI3 definitions.
AFIREV stands for: Association Française pour l’Itinérance de la Recharge Électrique des Véhicules
The charging topology, as relevant to the eMSP, consists of three entities:
-
Connector is a specific socket or cable available for the EV to make use of.
-
EVSE is the part that controls the power supply to a single EV in a single session. An EVSE may provide multiple connectors but only one of these can be active at the same time.
-
Location is a group of one or more EVSEs that belong together geographically or spatially.
A Location is typically the exact location of one or more EVSEs, but it can also be the entrance of a parking garage or a gated community. It is up to the CPO to use whatever makes the most sense in a specific situation. Once arrived at the location, any further instructions to reach the EVSE from the Location are stored in the EVSE object itself (such as the floor number, visual identification or manual instructions).
To prevent issues with capitals in variable names, the naming in JSON is not CamelCase but snake_case. All variables are lowercase and include an underscore for a whitespace.
When defining the cardinality of a field, the following symbols are used throughout this document:
Symbol | Description | Type |
---|---|---|
? |
An optional object. If not set, it might be |
Object |
1 |
Required object. |
Object |
* |
A list of zero or more objects. If empty, it might be |
[Object] |
+ |
A list of at least one object. |
[Object] |
OCPI does not specify how long a system should store data. Companies are RECOMMENDED to make this part of business contracts. Parties also will need to oblige to local legislation.
When a new version of OCPI is implemented, the data exchanged via the old version does not have to be available via the newer version of OCPI. Hence, the Version end-point will probably have different end-points per version. So when an object is stored with a URL that contains a version, it is NOT REQUIRED to be available at a URL with a different version number.