Add extracted tools: CitrineOS, OpenOCPP, ShapeShifter

- CitrineOS core extracted (CSMS OCPP 2.0.1)
- OpenOCPP extracted (firmware OCPP 1.6J/2.0.1)
- ShapeShifter library installed (pip install -e)
- ShapeShifter specification extracted
- EVerest extracted

TODO updated with progress
This commit is contained in:
Eric F
2026-06-08 00:38:27 -04:00
parent 468cfeaa50
commit d398a6ced2
7326 changed files with 1177561 additions and 7 deletions

View File

@@ -0,0 +1,9 @@
load("//modules:module.bzl", "cc_everest_module")
cc_everest_module(
name = "DummyTokenProvider",
impls = ["main"],
deps = [
"//lib/everest/helpers",
],
)

View File

@@ -0,0 +1,25 @@
#
# AUTO GENERATED - MARKED REGIONS WILL BE KEPT
# template version 3
#
# module setup:
# - ${MODULE_NAME}: module name
ev_setup_cpp_module()
# ev@bcc62523-e22b-41d7-ba2f-825b493a3c97:v1
# insert your custom targets and additional config variables here
target_link_libraries(${MODULE_NAME}
PRIVATE
everest::helpers
)
# ev@bcc62523-e22b-41d7-ba2f-825b493a3c97:v1
target_sources(${MODULE_NAME}
PRIVATE
"main/auth_token_providerImpl.cpp"
)
# ev@c55432ab-152c-45a9-9d2e-7281d50c69c3:v1
# insert other things like install cmds etc here
# ev@c55432ab-152c-45a9-9d2e-7281d50c69c3:v1

View File

@@ -0,0 +1,15 @@
// SPDX-License-Identifier: Apache-2.0
// Copyright Pionix GmbH and Contributors to EVerest
#include "DummyTokenProvider.hpp"
namespace module {
void DummyTokenProvider::init() {
invoke_init(*p_main);
}
void DummyTokenProvider::ready() {
invoke_ready(*p_main);
}
} // namespace module

View File

@@ -0,0 +1,63 @@
// SPDX-License-Identifier: Apache-2.0
// Copyright Pionix GmbH and Contributors to EVerest
#ifndef DUMMY_TOKEN_PROVIDER_HPP
#define DUMMY_TOKEN_PROVIDER_HPP
//
// AUTO GENERATED - MARKED REGIONS WILL BE KEPT
// template version 2
//
#include "ld-ev.hpp"
// headers for provided interface implementations
#include <generated/interfaces/auth_token_provider/Implementation.hpp>
// headers for required interface implementations
#include <generated/interfaces/evse_manager/Interface.hpp>
// ev@4bf81b14-a215-475c-a1d3-0a484ae48918:v1
// insert your custom include headers here
// ev@4bf81b14-a215-475c-a1d3-0a484ae48918:v1
namespace module {
struct Conf {};
class DummyTokenProvider : public Everest::ModuleBase {
public:
DummyTokenProvider() = delete;
DummyTokenProvider(const ModuleInfo& info, std::unique_ptr<auth_token_providerImplBase> p_main,
std::unique_ptr<evse_managerIntf> r_evse, Conf& config) :
ModuleBase(info), p_main(std::move(p_main)), r_evse(std::move(r_evse)), config(config){};
const std::unique_ptr<auth_token_providerImplBase> p_main;
const std::unique_ptr<evse_managerIntf> r_evse;
const Conf& config;
// ev@1fce4c5e-0ab8-41bb-90f7-14277703d2ac:v1
// insert your public definitions here
// ev@1fce4c5e-0ab8-41bb-90f7-14277703d2ac:v1
protected:
// ev@4714b2ab-a24f-4b95-ab81-36439e1478de:v1
// insert your protected definitions here
// ev@4714b2ab-a24f-4b95-ab81-36439e1478de:v1
private:
friend class LdEverest;
void init();
void ready();
// ev@211cfdbe-f69a-4cd6-a4ec-f8aaa3d1b6c8:v1
// insert your private definitions here
// ev@211cfdbe-f69a-4cd6-a4ec-f8aaa3d1b6c8:v1
};
// ev@087e516b-124c-48df-94fb-109508c7cda9:v1
// insert other definitions here
// ev@087e516b-124c-48df-94fb-109508c7cda9:v1
} // namespace module
#endif // DUMMY_TOKEN_PROVIDER_HPP

View File

@@ -0,0 +1,33 @@
// SPDX-License-Identifier: Apache-2.0
// Copyright Pionix GmbH and Contributors to EVerest
#include "auth_token_providerImpl.hpp"
#include <everest/helpers/helpers.hpp>
namespace module {
namespace main {
void auth_token_providerImpl::init() {
mod->r_evse->subscribe_session_event([this](types::evse_manager::SessionEvent event) {
if (event.event == types::evse_manager::SessionEventEnum::SessionStarted) {
types::authorization::ProvidedIdToken token;
token.id_token = {config.token, types::authorization::IdTokenType::ISO14443};
token.authorization_type = types::authorization::string_to_authorization_type(config.type);
if (config.connector_id > 0) {
token.connectors.emplace({config.connector_id});
}
token.parent_id_token = {config.token, types::authorization::IdTokenType::ISO14443};
EVLOG_info << "Publishing new dummy token: " << everest::helpers::redact(token);
publish_provided_token(token);
}
});
}
void auth_token_providerImpl::ready() {
}
} // namespace main
} // namespace module

View File

@@ -0,0 +1,66 @@
// SPDX-License-Identifier: Apache-2.0
// Copyright Pionix GmbH and Contributors to EVerest
#ifndef MAIN_AUTH_TOKEN_PROVIDER_IMPL_HPP
#define MAIN_AUTH_TOKEN_PROVIDER_IMPL_HPP
//
// AUTO GENERATED - MARKED REGIONS WILL BE KEPT
// template version 3
//
#include <generated/interfaces/auth_token_provider/Implementation.hpp>
#include "../DummyTokenProvider.hpp"
// ev@75ac1216-19eb-4182-a85c-820f1fc2c091:v1
// insert your custom include headers here
// ev@75ac1216-19eb-4182-a85c-820f1fc2c091:v1
namespace module {
namespace main {
struct Conf {
std::string token;
std::string type;
double timeout;
int connector_id;
};
class auth_token_providerImpl : public auth_token_providerImplBase {
public:
auth_token_providerImpl() = delete;
auth_token_providerImpl(Everest::ModuleAdapter* ev, const Everest::PtrContainer<DummyTokenProvider>& mod,
Conf& config) :
auth_token_providerImplBase(ev, "main"), mod(mod), config(config){};
// ev@8ea32d28-373f-4c90-ae5e-b4fcc74e2a61:v1
// insert your public definitions here
// ev@8ea32d28-373f-4c90-ae5e-b4fcc74e2a61:v1
protected:
// no commands defined for this interface
// ev@d2d1847a-7b88-41dd-ad07-92785f06f5c4:v1
// insert your protected definitions here
// ev@d2d1847a-7b88-41dd-ad07-92785f06f5c4:v1
private:
const Everest::PtrContainer<DummyTokenProvider>& mod;
const Conf& config;
virtual void init() override;
virtual void ready() override;
// ev@3370e4dd-95f4-47a9-aaec-ea76f34a66c9:v1
// insert your private definitions here
// ev@3370e4dd-95f4-47a9-aaec-ea76f34a66c9:v1
};
// ev@3d7da0ad-02c2-493d-9920-0bbbd56b9876:v1
// insert other definitions here
// ev@3d7da0ad-02c2-493d-9920-0bbbd56b9876:v1
} // namespace main
} // namespace module
#endif // MAIN_AUTH_TOKEN_PROVIDER_IMPL_HPP

View File

@@ -0,0 +1,38 @@
description: >-
Dummy token provider that listens to AuthRequired event from evse_manager and then publishes one token
provides:
main:
description: Main implementation of dummy token provider always returning one configured token
interface: auth_token_provider
config:
token:
description: Dummy token string to return
type: string
minLength: 1
maxLength: 20
default: DEADBEEF
type:
description: Type to report for our dummy token
type: string
minLength: 2
maxLength: 32
default: RFID
timeout:
description: Time our dummy token is valid (in s)
type: number
minimum: 0
maximum: 120
default: 10
connector_id:
description: If >0, the generated token is only valid for this connector_id
type: integer
minimum: 0
default: 0
requires:
evse:
interface: evse_manager
metadata:
license: https://opensource.org/licenses/Apache-2.0
authors:
- Thilo Molitor
- Cornelius Claussen