Skip to content
This repository has been archived by the owner on Jan 22, 2025. It is now read-only.

Latest commit

 

History

History
46 lines (28 loc) · 3.39 KB

README.md

File metadata and controls

46 lines (28 loc) · 3.39 KB

Logo of NOCPP

nocpp (No Charge Point Protocol)

📋 Description

NOCPP is the result of a project at the Ostwestfalen-Lippe University of Applied Sciences. It was developed by students of the Computer Engineering course. The client for this project is the company rt-solutions.de, which provides advice and solutions in information and OT security.

Logo of rt-solutions.de

NOCPP is an application for targeted pentesting of a charging station. The OCPP connection between the Charge Point (CP) and the Charge Station Management System (CSMS) is used as an attack parameter. In addition to various selected fuzzing attack scenarios, information gathering is also implemented. New attack scenarios can be easily implemented using a state machine. The results of the attacks, configurations and tests are exported in a results PDF.

This project is based on the Open-Source OCPP implementation in Python by The Mobility House, which you can find here.

⚠️ Further Project Development

The version of nocpp published here is the first development of this software. Future developments will be published exclusively on Gitlab, in this repository..

💾 Charge Point support

Currently OCPP 1.6-J (JSON) is the only supported version.

The application was tested on a charging station from the manufacturer Weidmüller, model AC Smart Advanced.

🚀 System Requirements

Please make sure you use Python version 3.10 or higher.

NOCPP only works with the websockets library in the specific version 12.0.

✅ Getting Started

At this point I would like to emphasize once again that this software is only a prototype as a proof of concept. It cannot therefore be ruled out that it may contain errors.

To execute the application, run Main.py. For automation, the following console arguments can be passed to the script for execution.

  • skip-websocket-config (Skips the manual WebSocket setup and uses default values. This argument blocks the set arguments.)
  • set-ip-address=[ipv4-address] (Set a specific IPv4 Address, uses default if the specified address is invalid.)
  • set-port=[port] (Set a specific port, uses default if the specified port is invalid.)

💣 Attack Szenarios

NOCPP uses various attack techniques, including inserting different data types and data values, as well as code injection. Please note that the effectiveness of this tool varies depending on the charging station. NOCPP recognizes successful system requests as well as error messages. In the event of a connection interruption (timeout), this is noted and the program is safely shut down. Due to the asynchronous program structure, this process can take significantly longer than the generation of the result PDF.

The execution of the attack scenarios can be variably adapted in the state machine contained in the CSMS.py file. New attack scenarios can also be easily added.

For the implementation of the attack scenarios, I recommend using the OCPP specification. However, the implementation on the respective charging stations can differ (significantly).