OCPP utility library.
Install:
npm i ocpp-util
Import:
const ocppUtil = require('ocpp-util');
The checkCardinality()
method verifies that the input has a correct cardinality.
ocppUtil.checkCardinality(card, input);
Parameters
card
{String} - expected cardinality.input
{Any} - input value to check.
Return value
Boolean. true
if input has passed the check.
Supported cardinalities:
0..1
,0..2
, ...,0..*
1..1
,1..2
, ...,1..*
The checkType()
method verifies that the input meets the requirements of the OCPP Primitive Datatypes.
ocppUtil.checkType(type, input, length);
Parameters
type
{String} - expected type.input
{Any} - input value to check.length
{Number} optional - maximal length of the value.
Return value
Boolean. true
if input has passed the check.
Supported types:
AnyType
- Text, data without specified length or format.string
- The characters defined in the Unicode character set are allowed to be used.identifierString
- Only the following character set is allowed:a-z, A-Z, 0-9, '*', '-', '_', '=', ':', '+', '|', '@', '.'
.integer
- 32 bit (31 bit resolution, 1 sign bit).decimal
- For data being reported by the Charging Station, the full resolution of the source data must be preserved. The decimal sent towards the Charging Station SHALL NOT have more than six decimal places.dateTime
- All time values exchanged between CSMS and Charging Station SHALL be formatted as defined in [RFC3339]. Additionally fractional seconds have been given an extra limit. The number of decimal places SHALL NOT exceed the maximum of 3.boolean
- Only allowed values:false
andtrue
.
This library provides an access to all enumeration types of OCPP 1.6 and OCPP 2.0.
ocppUtil.enums(version);
Parameters
version
{String} - desired version of the OCPP protocol.
Return value
Array of objects. Returns all enums of the specified version of the protocol.
Example:
const enums = ocppUtil.enums('2.0');
console.log(enums.TRANSACTION_EVENT); // [ 'Ended', 'Started', 'Updated' ]
npm run docs # generate docs
npm run http-docs # start HTTP server serving docs
npm test