solanaceae_ecosystem/plugins/plugin_transfer_auto_accept.cpp

64 lines
1.4 KiB
C++
Raw Normal View History

2023-08-19 23:22:33 +02:00
#include <solanaceae/plugin/solana_plugin_v1.h>
#include "./transfer_auto_accept.hpp"
#include <solanaceae/util/config_model.hpp>
#include <memory>
2024-01-07 17:44:50 +01:00
#include <limits>
2023-08-19 23:22:33 +02:00
#include <iostream>
static std::unique_ptr<TransferAutoAccept> g_taa = nullptr;
constexpr const char* plugin_name = "TransferAutoAccept";
2023-08-19 23:22:33 +02:00
extern "C" {
SOLANA_PLUGIN_EXPORT const char* solana_plugin_get_name(void) {
return plugin_name;
2023-08-19 23:22:33 +02:00
}
SOLANA_PLUGIN_EXPORT uint32_t solana_plugin_get_version(void) {
return SOLANA_PLUGIN_VERSION;
}
SOLANA_PLUGIN_EXPORT uint32_t solana_plugin_start(struct SolanaAPI* solana_api) {
std::cout << "PLUGIN " << plugin_name << " START()\n";
2023-08-19 23:22:33 +02:00
if (solana_api == nullptr) {
return 1;
}
try {
auto* rmm = PLUG_RESOLVE_INSTANCE(RegistryMessageModel);
auto* conf = PLUG_RESOLVE_INSTANCE(ConfigModelI);
2023-08-19 23:22:33 +02:00
// static store, could be anywhere tho
// construct with fetched dependencies
g_taa = std::make_unique<TransferAutoAccept>(*rmm, *conf);
2023-08-19 23:22:33 +02:00
// register types
PLUG_PROVIDE_INSTANCE(TransferAutoAccept, plugin_name, g_taa.get());
} catch (const ResolveException& e) {
std::cerr << "PLUGIN " << plugin_name << " " << e.what << "\n";
return 2;
2023-08-19 23:22:33 +02:00
}
return 0;
}
SOLANA_PLUGIN_EXPORT void solana_plugin_stop(void) {
std::cout << "PLUGIN " << plugin_name << " STOP()\n";
2023-08-19 23:22:33 +02:00
g_taa.reset();
}
2024-01-07 17:44:50 +01:00
SOLANA_PLUGIN_EXPORT float solana_plugin_tick(float delta) {
2023-08-19 23:22:33 +02:00
(void)delta;
g_taa->iterate();
2024-01-07 17:44:50 +01:00
return std::numeric_limits<float>::max();
2023-08-19 23:22:33 +02:00
}
} // extern C