OCHP_direct_ Extension
Prot. Version | Date | Comment |
---|---|---|
0.1 | 27-03-2015 | Concept, Functional specification. Commit: 77cccd838db692ab6f8b77fb4be8e81d59ec04e2 |
0.2 | 15-08-2016 | Functional enhancements, usability improvements. |
Copyright (c) 2015-2016 smartlab, e-laad.nl
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- Preface
- Introduction
- Partner-to-CHS interface description (Extension to OCHP)
- Partner-to-partner interface description (OCHPdirect interface)
- Messages
- Types
- Binding to Transport Protocol
- Combining OCHP_direct_ with OCHP
This document defines an extension to the Open Clearing House Protocol (OCHP). For more information visit ochp.eu.
This extesnsion follows the same conventions as OCHP:
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://tools.ietf.org/html/rfc2119](RFC 2119).
The cardinality is defined by the indicators *, +, ? and 1, where the last one is the default. The meaning and mapping to XML syntax is as follows:
Meaning | XML Schema | DTD |
---|---|---|
At most one | minOccurs="0" maxOccurs="1" |
? |
one or more | minOccurs="1" maxOccurs="unbounded" |
+ |
zero or more | minOccurs="0" maxOccurs="unbounded" |
* |
exactly one | (default) | 1 |
For some data fields a http://en.wikipedia.org/wiki/Regular_expression is provided as an additional but very precise definition of the data format.
The character > in front of any data field indicates a choice of multiple possibilities.
The character ~ appended to any data field indicates the implementation as XML attribute instead of an element.
For a general introduction to the OCHP, see the introduction section in the OCHP documentation.
The overall use case for this interface is to control services like charging sessions in an operator's backend while handling the user authorisation within an (from the operator's point of view) external system.
The customer story can be shortened to:
One (provider) app for all charging stations – regardless of their operator.
This generic main use cases splits up in several sub parts. Those are:
- Remote Start: A user starts a charging process at an operator‘s charge pole by using a provider‘s app. They are starting the process from a – of the operator's point of view – remote service.
- Remote Stop: A user stops a charging process at an operator‘s charge pole by using a provider‘s app (that was remotely started).
- Live Info: A user requests information about a charging process at an operator's charge pole by using a provider's app (from which the process was started).
- Charge Event: A user gets informed by a provider's app about status changes of a charging process at an operator's charge pole, even if it wasn't started remotely.
- Remote Control: A user controls a charging process at an operator‘s charge pole that was not remotely started by using a provider‘s app.
- Remote Action: A user triggers advanced and not charging process related actions at a charge point or charging station of an operator.
While all remote actions (start, stop, remote control) require the operator to act as a server to receive information and commands from the provider, the remaining use cases (charge event, live info) require the provider to act as a server as well.
The OCHP direct Interface describes a set of methods to control charging sessions in an EVSE operator's backend. While dedicated methods in the clearing house's interface extend its functionality to provide remote services, the actual service requests are sent between the operator and the provider directly. In those cases the operator backend acts as a server, in contrast to pure clients as common for all other OCHP communication. The reverse communication, from the operator system to the provider system is also possible. In that case the provider system will act as a SOAP server and the operator system as the client.
The following Figure illustrates the communication paths of OCHP direct. The extending messages of OCHP allow the publication of backend specification and the discovery of roaming partner's backends.
The backend specification is send and updated regularly. It contains all properties that describe the roaming partner's backend:
- The URL of the backend's OCHP direct endpoint(s).
- The security token of the backend. (See chapter Security of the OCHP direct interface for more information.)
- All business objects that are operated by this backend, represented by blacklists and/or whitelists.
This data can be mapped onto a data structure as illustrated in the following figure OCHP direct ER Model. The depictured data structure allows for dynamic updates of endpoints and partner-tokens, which is necessary to guarantee an uninterrupted service.
Remarkable about the data model is the absence of a backend entity. All related entities are bound to the roaming partner (operator or provider), identified by their IDs. Thus, each roaming partner is free to operate their services on one or multiple backend systems or even share one backend system with another roaming partner. This should cover all possible market situations.
Based on the assumption that OCHPdirect is used in addition to a regular OCHP connection via a clearing house, the following trust structure applies. However, OCHPdirect may also be used in other combinations, where the OCHP-part of the following description is to be covered by alternative methods.
When two roaming partners connect via OCHP and the clearing house, the authorisation and trust structure can be defined as follows:
- Both roaming partners trust the clearing house
- The operator authorises the provider to use their charging stations generally, by setting the roaming connection in the clearing house
- The provider authorises and trusts the operator to authorise the provider's customers generally
- The operator authorises the provider's customers at their charging stations for inividual charging sessions
In this situation the single authorisation is be done in the operator's backend on behalf of the provider. The provider trusts the operator that all sent customer tokens are getting authorised on all charge points or as based on the contract between both.
When direct authorisation requests come in place, the situation turns around:
- Both roaming partners trust the clearing house
- The operator authorises the provider to use their charging stations in general, by setting the roaming connection in the clearing house
- The operator authorises and trusts the provider to authorise their customers at the operator's charge points
- The provider authorises their own customers at the charging stations of the operator for inividual charging sessions
- This is based on the assumption that the provider in turn, will compensate the operator for all charging processes started this way.
In this new situation the operator gives the responsiblity to authorise charging sessions away to the provider. An operator therefore should not decline a remote authorisation for other than contractual or technically valid reasons. Essentially, the situation is the same with a whitelist exchange of RFID tokens - the operator trusts the provider to only send those tokens to the Clearing House that are authorised to access the charging infrastructure. Here, those trusted tokens / contracts get sent via OCHPdirect instead of through the CHS whitelist.
Each roaming partner who makes use of OCHP direct needs provide a SOAP server with a publicly accessible interface. This applies to both the operator and the provider. It is obvious that they must secure those interfaces to:
- restrict usage only to their current roaming partners and
- secure the transmitted data.
Therefore the interfaces must be protected on HTTP transport layer level, using SSL and Basic Authentication. Please note that this mechanism does not require client side certificates for authentication, only server side certificates in order to provide a secure SSL connection.
The OCHP direct interface of every roaming partner must be secured via TLS 1.2 (RFC6176).
The identification of the requester and the access restriction of the interface is done by varying identification tokens which are exchanged via the clearing house. (See Identification token distribution for further information.)
Each request to a OCHP direct interface must contain an Authorization HTTP header:
Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
The hash value in this header is composed through the following steps:
- The identification tokens of sender and receiver are combined into a string "receiver-token:sender-token"
- The resulting string is then encoded using the RFC2045-MIME variant of Base64 (RFC1945 This encoded string shall further be called (encoded) token combination.
- The authorization method and a space i.e.
Basic␣
is then put before the encoded token combination.
The OCHP direct endpoint should check for valid authorisation in order to prevent unintended usage of their endpoints or cyber-attacks.
The partner's tokens for identification and authorisation are exchanged and distributed through the clearing house. Based on the set roaming connections the tokens are made available. Each token is valid for a period of one full calendar day, synchronus to the UTC time, with an additional short overlap for token exchange.
This mechanism is used to guarantee uninterupted service in combination
with a high security level and compatibility with the majority of
systems. The synchronisation and token-exchange-cycle is as follows.
On day N
do:
- At 00:30 UTC: Invalidate/delete all token combinations of day
N-1
. - Generate new own token for day
N+1
. - Before 11:55 UTC: Send/upload own token for day
N+1
to the clearing house. - After 12:05 UTC: Fetch/download partner's tokens for day
N+1
from the clearing house. - Generate token combinations for day
N+1
from own and partner's tokens. HereAB2
. - At 23:50 UTC: Make token combinations for day
N+1
valid.
This means that each night from 23:50 UTC to 0:30 UTC, a set of two
token combinations is valid. Each token that is valid for a given day N
shall be considered valid from 23:50 UTC on day N-1
until 00:30 UTC
on day N+1
, giving it a total validity of 24:40 hours.
When communicating with another partners OCHPdirect system, the token
combination for day N
shall be used from 00:00 UTC (day N
) until
00:00 UTC of day N+1
.
This interface description extends the OCHP protocol. The additional methods are available in the interface of the Clearing House.
The backend of each roaming partner has to send the definition of its OCHP direct interface to the Clearing House to share that data with their connected roaming partners. The upload of the own interface definition is done in the following way:
- CMS or MDM sends the AddServiceEndpoints.req PDU.
- CHS responds with a AddServiceEndpoints.conf PDU.
The backend of each roaming partner has to fetch the global list of interface definitions from the CHS. The download of all interface of connected partners is done in the following way:
- CMS or MDM sends the GetServiceEndpoints.req PDU.
- CHS responds with GetServiceEndpoints.conf PDU.
This interface description is the core of OCHPdirect. The described methods must be available at the provider's backend MDM (InformProvider) and the operator's backend CMS (all other methods). The partners have to make sure they only connect to other partners' endpoints which their endpoint is compatible with. Partners may operate multiple endpoints and versions to allow connectivity to a higher number of roaming partners. In the case of two partners running multiple compatible versions, it is advised to use the most advanced version.
The backend of a provider may request the current live status for a list of EVSEs. This allows for a lower latency than the status distribution via the Clearing House and should provide better data quality.
- MDM sends the GetEvseStatus.req PDU.
- CMS responds with a GetStatus.conf PDU. See OCHP/GetStatus.conf
The backend of a provider may report an issue concerning the data or the compatibility or status of an EVSE to the operator to their information. The operator may decide how to handle the report (optional).
- MDM sends the ReportDiscrepancy.req PDU.
- CMS responds with a ReportDiscrepancy.conf PDU.
The remote operation of a charging process in an operator backend is done in three steps:
- Selection and reservation of the charge point
- Controlling of the charge point
- Release of the charge point
In step (1) an OCHP-direct session ID is generated by the operator and returned. This ID must be used in step (2) and (3). Step (2) may occur multiple times to change the parameters. The session is ended in step (3).
This makes it possible to maintain a mutal charging session in two systems.
The following figure gives an overview of the communication. After step (3) follows the CDR exchange process as described in OCHP. Calls from the operator to the provider (italic) are handled through the MDM interface at the provider backend (using the InformProvider method).
Before a charging process can be started, the provider needs to select an EVSE in an operator's backend. This establishes the session and generates the OCHP-direct session ID. The operator must reserve the selected charging station for the communicated Contract-ID.
The provider may request reservation until a certain time. It is up to the operator to decide whether or not to accept the provider's request for a reservation (duration). If the reservation request cannot be fulfilled, the operator should return the maximum TTL for the reservation they would accept, but establish the session nonetheless. It is then up to the provider to decide whether to accept this offer from the operator (and otherwise release the EVSE, cancelling the reservation).
- MDM sends the SelectEvse.req PDU.
- CMS responds with a SelectEvse.conf PDU.
When an EVSE was selected and a session successfully established, the EVSE can be controlled in the limits of the charging process by the provider.
- MDM sends the ControlEvse.req PDU.
- CMS responds with a ControlEvse.conf PDU.
Note: The control method ControlEvse.req can be called multiple times (at least once) during a charging session. Its parameters define whether the provider requests a start or end of the charging session or if they want to change it (in terms of it's parameters). The operator shall handle all three operations and respond to it's capabilities to actually execute the request accordingly.
After the end of the charging process the provider should release the prior selected EVSE.
- MDM sends the ReleaseEvse.req PDU.
- CMS responds with a ReleaseEvse.conf PDU.
Note: To end a charging session properly, the provider should always call ReleaseEvse.req. Additionally, they can also call ControlEvse.req with the parameter operation='end' to explicitly end a charging process. A session with no ongoing charging process (ControlEvse.req with operation='start' was not called or not successful) shall always be closed with ReleaseEvse.req. When the operator receives a valid ReleaseEvse.req for an ongoing charging process which was not ended with a call to ControlEvse.req with parameter operation='end', the operator should implicitly end the process. It is up to the operator to decide how long to keep any OCHPdirect session open and valid when there is no longer an active charging process attached to it (i.e. the charging process was explicitly stopped by ControlEvse.req with the parameter operation='end', but no ReleaseEvse.req was sent). It is recommended to reduce the TTL of these sessions to 15 minutes or less.
The provider must get informed by the operator about any status updates to an OCHP-direct charging process. This should cover at least the start, change and end functionalities. The operator's backend must make use of a threshold in order to avoid too many messages (it is recommended not to send InformProvider more than once every 15 minutes, unless the parameters of the charging process were changed or an InformProvider was requested by the Provider).
The provider may request additional InformProvider messages from the CPO to follow the progress of the charging process. In order not to overwhelm any system involved, it is strongly recommended not to exceed a frequency of 15 minutes between each such request.
The information types are:
- Start of a charging session: The process was authorized and the car is properly connected. The operator must send an InformProvider to the provider in this case.
- End of a charging session: The charging session has ended by any event and will not be resumed. The operator must send an InformProvider to the provider in this case.
- Metering information (status): This information should also be included in start and end messages. If possible, meter values should always be included in their most up-to-date form in any InformProvider message.
- Power management information (status): The charging parameters for the charging session have changed.
- Invoicing ready, CDR sent (finish)
When a status update to a charging process gets available, the operator informs the concerned provider.
- CMS sends the InformProviderMessage PDU.
- MDM responds with a InformProvider.conf PDU.
When a customer requests updated charging information to their charging process or when the provider deems it necessary to collect updated information on their behalf. May be called directly after SelectEvse to collect current meter values for the selected EVSE.
- MDM sends the InformProvider.req PDU.
- CMS responds with a InformProviderMessage PDU.
These messages are used to exchange the interface definitions of the OCHP direct interfaces between roaming partners.
This contains the field definition of the AddServiceEndpoints.req sent by the MDM or CMS towards the CHS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
providerEndpointArray | ProviderEndpoint | * | Array of endpoints of the partners provider system. |
operatorEndpointArray | OperatorEndpoint | * | Array of endpoints of the partners operator system. |
Note: The endpoint uploaded to the system may be rejected in case the security token used is not unique. It is up to the uploading partner to retry using a different token in this case.
This contains the field definition of the AddServiceEndpoints.conf sent by the CHS as response to the AddServiceEndpoints.req.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | Result | 1 | This contains the result of AddServiceEndpoints.req. |
This contains the field definition of the GetServiceEndpoints.req sent by a partner's system to the CHS. No fields are defined.
This contains the field definition of the GetServiceEndpoints.conf sent by the CHS as response to the GetServiceEndpoints.req.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | Result | 1 | This contains the result of GetServiceEndpoints.req. |
providerEndpointArray | ProviderEndpoint | * | Array of endpoints of all providers connected to the requester. |
operatorEndpointArray | OperatorEndpoint | * | Array of endpoints of all operators connected to the requester. |
This contains the field definition of the DirectEvseStatus.req sent by the MDM towards the CMS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
requestedEvseId | EvseId | + | List of EVSE-IDs the live status is requested for. |
This contains the field definition of the ReportDiscrepancy.req sent by the MDM towards the CMS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
evseId | EvseId | 1 | The charge point which is affected by the report. |
report | string(2000) | 1 | Textual or generated report of the discrepancy. |
This contains the field definition of the ReportDiscrepancy.conf sent by the CMS as a response to ReportDiscrepancy.req. No fields are defined.
This contains the field definition of the SelectEvse.req sent by the MDM towards the CMS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
evseId | EvseId | 1 | The charge point which is selected by the provider. |
contractId | ContractId | 1 | Contract-ID for which the charge point is selected. |
reserveUntil | DateTimeType | ? | The desired TTL for the reservation created for the selected EVSE (in UTC). |
Note: If no reserveUntil is defined in the request, it is up to the CPO to set a pre-defined TTL for the reservation and the session established (recommendation: 5 minutes). Once that TTL expires, the session and reservation should be invalidated.
Note: reserveUntil is intended to reserve an EVSE from now on and thus should not be requested too far into the future. It is recommended not to exceed a reservation request of 30 minutes. The maxReservation-element in the corresponding ChargePointInfo contains the maximum duration the CPO will allow reservation for.
Note: This function should be implemented in a way that it may be used to set reservations for physical tokens also. This is also valid for Contract-IDs that have multiple physical tokens assigned to them (using OCPP: parentIdTag).
This contains the field definition of the SelectEvse.conf sent by the CMS as a response to SelectEvse.req.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | DirectResult | 1 | This contains the result of SelectEvse.req. |
directId | DirectId | ? | The session id for this direct charging process on success. |
ttl | DateTimeType | ? | On success the time until this selection is valid. |
Note: Should the CPO not accept the extended duration of reservation for the selected EVSE, they should still create the session and return the maximum TTL they are willing to grant to the provider. It is then up to provider or their customer to accept this proposed TTL / reservation or to reject it (in which case the session should be closed by calling ReleaseEvse.req). If no reserveUntil is defined in the request, it is up to the CPO to set a session timeout (recommended: 5 minutes).
This contains the field definition of the ControlEvse.req sent by the MDM towards the CMS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
directId | DirectId | 1 | The session id referencing the direct charging process to be controlled. |
operation | DirectOperation | 1 | The operation to be performed for the selected charge point. |
maxPower | float | ? | Maximum authorised power in kilowatts. Example: "3.7", "8", "15" |
maxCurrent | float | ? | Maximum authorised current in ampere. Example: "16", "25", "32" |
onePhase | boolean | ? | Marks an AC-charging session to be limited to one-phase charging. |
maxEnergy | float | ? | Maximum authorised energy in kilowatthours. Example: "5.5", "20", "85" |
minEnergy | float | ? | Minimum required energy in kilowatthours. Example: "5.5", "20", "85" |
departure | DateTimeType | ? | Scheduled time of departure. |
Note: maxPower and maxCurrent should be used exclusively, otherwise it may be up to the CPO to choose the lower limit. The same goes for the one-phase limit, which may override maxPower limits only possible through three-phase charging.
This contains the field definition of the ControlEvse.conf sent by the CMS as a response to ControlEvse.req.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | DirectResult | 1 | This contains the result of ControlEvse.req. |
directId | DirectId | 1 | The session id for this direct charging process. |
ttl | DateTimeType | ? | On success the timeout for this session. |
Note: It is up to the CPO to define a ttl for the charging session established here and to find a reasonable limitation (recommendation: 24 hours). The CPO has to ensure that a customer can correctly disconnect their EV even if the session was already invalidated.
This contains the field definition of the ReleaseEvse.req sent by the MDM towards the CMS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
directId | DirectId | 1 | The session id referencing the direct charging process to be released. |
This contains the field definition of the ReleaseEvse.conf sent by the CMS as a response to ReleaseEvse.req.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | DirectResult | 1 | This contains the result of ReleaseEvse.req. |
directId | DirectId | 1 | The session id for this direct charging process. |
ttl | DateTimeType | ? | On success the timeout for this session. |
This contains the field definition of the InformProviderMessage sent by the CMS towards the MDM.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | DirectResult | 1 | This contains the result of InformProvider.req. Also to be sent for InformProviderMessages initiated by the CPO. |
message | DirectMessage | 1 | The operation that triggered the operator to send this message. |
evseId | EvseId | 1 | The charge point which is used for this charging process. |
contractId | ContractId | 1 | Contract-ID to which the charge point is assigned. |
directId | DirectId | 1 | The session id for this direct charging process. |
ttl | DateTimeType | ? | On success the timeout for this session. |
maxPower | float | ? | Maximum authorised power in kilowatts. Example: "3.7", "8", "15" |
maxCurrent | float | ? | Maximum authorised current in ampere. Example: "16", "25", "32" |
onePhase | boolean | ? | Marks an AC-charging session to be limited to one-phase charging. |
maxEnergy | float | ? | Maximum authorised energy in kilowatthours. Example: "5.5", "20", "85" |
minEnergy | float | ? | Minimum required energy in kilowatthours. Example: "5.5", "20", "85" |
departure | DateTimeType | ? | Scheduled time of departure. |
currentPower | float | ? | The currently supplied power limit in kilowatts in case of load management. Example: "3.7", "8", "15" |
chargedEnergy | float | ? | The amount of energy in kilowatthours transferred during this charging process. Example: "5.5", "20", "85" |
meterReading | MeterReading | ? | The current meter value as displayed on the meter with corresponding timestamp to enable displaying it to the user. Example: "12345.67" |
chargingPeriods | CdrPeriodType | * | Can be used to transfer billing information to the provider in near real time. |
currentCost | float | ? | The total cost of the charging process that will be billed by the operator up to this point. |
currency | string(3) | ? | The displayed and charged currency. Defined in ISO 4217 - Table A.1, alphabetic list. |
This contains the field definition of the InformProvider.req sent by the MDM towards the CMS.
Field Name | Field Type | Card. | Description |
---|---|---|---|
directId | DirectId | 1 | The session id for this direct charging process. |
This contains the field definition of the InformProvider.conf sent by the MDM as a response to InformProviderMessage.
Field Name | Field Type | Card. | Description |
---|---|---|---|
result | DirectResult | 1 | This contains the result of InformProviderMessage. |
These data types extend the OCHP interface and are understood by the Clearing House.
Contains a generic endpoint definition.
Field Name | Field Type | Card. | Description |
---|---|---|---|
url | string(255) | 1 | The endpoint address. |
namespaceUrl | string(255) | 1 | The WSDL namespace definition (i.e. version definition). |
accessToken | string(255) | 1 | The secret token to access this endpoint. |
validDate | string(10) | 1 | The day on which this endpoint/token combination is valid. |
Note: Any token for day N has to be treated as valid from day N-1 23:50 UTC to day N+1 0:30 UTC. Note: Any partner may operate more than one OCHPdirect endpoint to enable compatibility with a larger number of partners.
Contains the endpoint definition of a provider's MDM system. Expands the DirectEndpoint.
Field Name | Field Type | Card. | Description |
---|---|---|---|
url | string(255) | 1 | The endpoint address. |
namespaceUrl | string(255) | 1 | The WSDL namespace definition (i.e. version definition). |
accessToken | string(255) | 1 | The secret token to access this endpoint. |
validDate | string(10) | 1 | The day on which this endpoint/token combination is valid. |
whitelist | ContractPattern | + | List of patterns that match all Contract-IDs the endpoint is responsible for. |
blacklist | ContractPattern | * | List of patterns that match Contract-IDs the endpoint is not responsible for, but are matched by the whitelist. |
Note: Any token for day N has to be treated as valid from day N-1 23:50 UTC to day N+1 0:30 UTC. Note: Any partner may operate more than one OCHPdirect endpoint to enable compatibility with a larger number of partners.
Contains the endpoint definition of an operator's CMS backend. Expands the DirectEndpoint.
Field Name | Field Type | Card. | Description |
---|---|---|---|
url | string(255) | 1 | The endpoint address. |
namespaceUrl | string(255) | 1 | The WSDL namespace definition (i.e. version definition). |
accessToken | string(255) | 1 | The secret token to access this endpoint. |
validDate | string(10) | 1 | The day on which this endpoint/token combination is valid. |
whitelist | EvsePattern | + | List of patterns that match all EVSE-IDs the endpoint is responsible for. |
blacklist | EvsePattern | * | List of patterns that match EVSE-IDs the endpoint is not responsible for, but are matched by the whitelist. |
Note: Any token for day N
has to be treated as valid from day N-1
23:50 UTC to day N+1
0:30 UTC.
Note: Any partner may operate more than one OCHPdirect endpoint to enable compatibility with a larger number of partners.
Defines a pattern that matches Contract-IDs. The pattern must be
specified for IDs without optional seperators. The wildcard character
for the pattern is %
. The pattern as well as the ID is case sensitive.
[A-Za-z]{2}[A-Za-z0-9]{3}[Cc][A-Za-z0-9]{0,8}%?
Defines a pattern that matches EVSE-IDs. The pattern must be
specified for IDs without optional seperators. Seperators in the ID's
instance are handled as part of the alphabet. The wildcard character
for the pattern is %
.
[A-Z]{2}[A-Z0-9]{3}[E]([A-Z0-9]?[A-Z0-9\*]{0,30})%?
Contains result information.
Field Name | Field Type | Card. | Description |
---|---|---|---|
resultCode | DirectResultCodeType | 1 | The machine-readable result code. |
resultDescription | string | 1 | The human-readable error description. |
Result and error codes for the class Result as return value for method calls.
Value | Description |
---|---|
ok | Data accepted and processed. |
partly | Not all control parameters could be applied. |
not-found | Given EVSE-ID is not known to the operator. |
not-supported | Given EVSE-ID does not support OCHP-direct. |
invalid-id | The DirectId is not valid or has expired. |
server | Internal server error. |
This quick chapter shall give an overview of how certain result codes are supposed to be treated by OCHPdirect endpoints in order to reduce potential misunderstandings.
The session ID for one OCHP-direct charging process. The ID is created by the operator and used to reference the session by the provider. Must be unique per Operator-ID. There are two events that create a new DirectId:
- A successful call to SelectEvse by the provider
- Local start of a charging session (e.g. via RFID) for an OCHP-direct enabled Contract-ID at an OCHP-direct enabled EVSE
[A-Z0-9\-]{1,255}
Operations to control an OCHP-direct charging process.
Value | Description |
---|---|
start | Initiate the start. Operator should allow the user to plug in. |
change | Change the parameters of the charging process. |
end | End the charging process. Operator should allow the user to plug out. |
Messages to inform a provider about an OCHP-direct charging process.
Value | Description |
---|---|
start | A OCHPdirect charging process has been started. |
change | The parameters of the charging process were changed. |
info | A informative update is available, e.g. updated consumed energy value. |
end | The charging process has ended, the connector was unplugged. |
finish | The session is finished and the CDR was sent out. |
Contains one meter reading from a charge point.
Field Name | Field Type | Card. | Description |
---|---|---|---|
meterValue | float | 1 | The meter reading as transferred by the charging station (OCPP default unit: Wh). |
meterTime | LocalDateTimeType | 1 | The exact local time stamp of the time the meter reading was taken (belonging to the meter reading, e.g. as transferred by OCPP). |
For this protocol the SOAP Version 1.1 MUST be used.
OCHP_direct_ is made to be used in association with the classic OCHP and a clearing house. This section gives additional advice of how integrate it.
CDRs originating from OCHP_direct_ charging sessions are expected to follow this additional advice.
Field Name | Field Type | Card. | Additional advice |
---|---|---|---|
cdrId | string(36) | 1 | |
evseId | EvseId | 1 | |
emtId | EmtId | 1 | The field tokenType should be set to remote , the field instance should enhold the directId. |
contractId | ContractId | 1 | |
liveAuthId | LiveAuthId | ? | Not used with OCHPdirect. |
status | CdrStatusType | 1 | |
startDateTime | LocalDateTimeType | 1 | Start date and time of the direct session (successfull SelectEvse). Must be set in the local time of the charge point. |
endDateTime | LocalDateTimeType | 1 | End date and time of the charge session (log-off with the RFID badge, ControlEvse.operation = end or physical disconnect). Must be set in the local time of the charge point. |