ocpp-client

Crates.ioocpp-client
lib.rsocpp-client
version
sourcesrc
created_at2024-07-30 14:14:05.696511
updated_at2024-12-06 11:32:15.371002
descriptionOCPP Client Implementation. Use this library to implement an OCPP charge point
homepage
repositoryhttps://github.com/flowionab/ocpp-client
max_upload_size
id1319835
Cargo.toml error:TOML parse error at line 18, column 1 | 18 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include`
size0
Joatin Granlund (Joatin)

documentation

README

OCPP Client

Crates.io Documentation .github/workflows/ci.yaml

Overview

ocpp-client is a Rust library that provides an OCPP (Open Charge Point Protocol) client implementation. This library enables developers to integrate with central system (CSMS) that use the OCPP protocol, allowing for seamless communication and efficient.

Features

  • OCPP 1.6 and 2.0.1 support: Communicate with OCPP 1.6 or 2.0.1 JSON compliant servers (CSMS).
  • Async/Await support: Built using asynchronous Rust for high performance and scalability.
  • Customizable: Easily extendable to add custom message handlers or to support additional OCPP features.
  • Error Handling: Robust error handling and logging to assist in debugging and maintenance.
  • Comprehensive Documentation: Detailed documentation with examples to get you started quickly.

Installation

Add the following to your Cargo.toml:

[dependencies]
ocpp-client = "0.1"

Usage

Here's a simple example to get you started:

use ocpp_client::connect;

#[tokio::main]
async fn main() {
    let client = connect("wss://my-csms.com/CHARGER_IDENTITY").await?;
    
    match client {
        OCPP1_6(client) => {
            // Do 1.6 specific operations
        },
        OCPP2_0_1(client) => {
            // Do 2.0.1 specific operations
        },
    }
}

Documentation

The full documentation is available on docs.rs.

Examples

Check out the examples directory for more usage examples.

Contributing

Contributions are welcome! Please see the CONTRIBUTING.md for more details.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Commit count: 30

cargo fmt