diff --git a/languages/cpp/src/shared/include/error.h b/languages/cpp/src/shared/include/error.h index 07d6268a..b02859b3 100644 --- a/languages/cpp/src/shared/include/error.h +++ b/languages/cpp/src/shared/include/error.h @@ -16,26 +16,24 @@ * SPDX-License-Identifier: Apache-2.0 */ -#ifndef FIREBOLT_ERROR_H -#define FIREBOLT_ERROR_H +#pragma once -#ifdef __cplusplus -extern "C" { -#endif +namespace Firebolt { -typedef enum FireboltSDKError { - FireboltSDKErrorNone = 0, - FireboltSDKErrorGeneral = 1, - FireboltSDKErrorUnavailable = 2, - FireboltSDKErrorTimedout = 3, - FireboltSDKErrorNotSubscribed = 4, - FireboltSDKErrorUnknown = 5, - FireboltSDKErrorInUse = 6, - FireboltSDKErrorNotSupported = 7 -} FireboltSDKError_t; + enum class Error : int32_t { + None = 0, + General = 1, + Timedout = 2, + NotConnected = 3, + AlreadyConnected = 4, + //AuthenticationError, ? + InvalidRequest = -32600, + MethodNotFound = -32601, + InvalidParams = -32602, + CapabilityNotAvaialbale = -50300, + CapabilityNotSupported = -50100, + CapabilityGet = -50200, + CapabilityNotPermitted = -40300, + }; -#ifdef __cplusplus } -#endif - -#endif // FIREBOLT_ERROR_H diff --git a/languages/cpp/src/shared/src/Accessor/Accessor.cpp b/languages/cpp/src/shared/src/Accessor/Accessor.cpp index 6d4aceae..e34630ed 100644 --- a/languages/cpp/src/shared/src/Accessor/Accessor.cpp +++ b/languages/cpp/src/shared/src/Accessor/Accessor.cpp @@ -27,15 +27,13 @@ namespace FireboltSDK { , _transport(nullptr) , _config() { + ASSERT(_singleton == nullptr); _singleton = this; _config.FromString(configLine); Logger::SetLogLevel(WPEFramework::Core::EnumerateType(_config.LogLevel.Value().c_str()).Value()); FIREBOLT_LOG_INFO(Logger::Category::OpenRPC, Logger::Module(), "Url = %s", _config.WsUrl.Value().c_str()); - CreateTransport(_config.WsUrl.Value().c_str(), _config.WaitTime.Value()); - CreateEventHandler(); - _workerPool = WPEFramework::Core::ProxyType::Create(_config.WorkerPool.ThreadCount.Value(), _config.WorkerPool.StackSize.Value(), _config.WorkerPool.QueueSize.Value()); WPEFramework::Core::WorkerPool::Assign(&(*_workerPool)); _workerPool->Run(); @@ -43,23 +41,23 @@ namespace FireboltSDK { Accessor::~Accessor() { - DestroyTransport(); - DestroyEventHandler(); WPEFramework::Core::IWorkerPool::Assign(nullptr); _workerPool->Stop(); + + ASSERT(_singleton != nullptr); _singleton = nullptr; } - int32_t Accessor::CreateEventHandler() + Firebolt::Error Accessor::CreateEventHandler() { Event::Instance().Configure(_transport); - return FireboltSDKErrorNone; + return Firebolt::Error::None; } - int32_t Accessor::DestroyEventHandler() + Firebolt::Error Accessor::DestroyEventHandler() { Event::Dispose(); - return FireboltSDKErrorNone; + return Firebolt::Error::None; } Event& Accessor::GetEventManager() @@ -67,29 +65,25 @@ namespace FireboltSDK { return Event::Instance(); } - int32_t Accessor::CreateTransport(const string& url, const uint32_t waitTime = DefaultWaitTime) + Firebolt::Error Accessor::CreateTransport(const string& url, const Transport::Listener& listener, const uint32_t waitTime = DefaultWaitTime) { if (_transport != nullptr) { delete _transport; } - _transport = new Transport(static_cast(url), waitTime); - if (WaitForLinkReady(_transport, waitTime) != FireboltSDKErrorNone) { - delete _transport; - _transport = nullptr; - } + _transport = new Transport(static_cast(url), waitTime, listener); ASSERT(_transport != nullptr); - return ((_transport != nullptr) ? FireboltSDKErrorNone : FireboltSDKErrorUnavailable); + return ((_transport != nullptr) ? Firebolt::Error::None : Firebolt::Error::Timedout); } - int32_t Accessor::DestroyTransport() + Firebolt::Error Accessor::DestroyTransport() { if (_transport != nullptr) { delete _transport; _transport = nullptr; } - return FireboltSDKErrorNone; + return Firebolt::Error::None; } Transport* Accessor::GetTransport() @@ -98,20 +92,4 @@ namespace FireboltSDK { return _transport; } - int32_t Accessor::WaitForLinkReady(Transport* transport, const uint32_t waitTime = DefaultWaitTime) { - uint32_t waiting = (waitTime == WPEFramework::Core::infinite ? WPEFramework::Core::infinite : waitTime); - static constexpr uint32_t SLEEPSLOT_TIME = 100; - - // Right, a wait till connection is closed is requested.. - while ((waiting > 0) && (transport->IsOpen() == false)) { - - uint32_t sleepSlot = (waiting > SLEEPSLOT_TIME ? SLEEPSLOT_TIME : waiting); - - // Right, lets sleep in slices of 100 ms - SleepMs(sleepSlot); - - waiting -= (waiting == WPEFramework::Core::infinite ? 0 : sleepSlot); - } - return (((waiting == 0) || (transport->IsOpen() == true)) ? FireboltSDKErrorNone : FireboltSDKErrorTimedout); - } } diff --git a/languages/cpp/src/shared/src/Accessor/Accessor.h b/languages/cpp/src/shared/src/Accessor/Accessor.h index e247df98..7284df16 100644 --- a/languages/cpp/src/shared/src/Accessor/Accessor.h +++ b/languages/cpp/src/shared/src/Accessor/Accessor.h @@ -103,15 +103,31 @@ namespace FireboltSDK { delete _singleton; } } + + void Connect(const Transport::Listener& listener) + { + CreateTransport(_config.WsUrl.Value().c_str(), listener, _config.WaitTime.Value()); + CreateEventHandler(); + } + + Firebolt::Error Disconnect() + { + Firebolt::Error status = Firebolt::Error::None; + status = DestroyTransport(); + if (status == Firebolt::Error::None) { + status = DestroyEventHandler(); + } + return status; + } + Event& GetEventManager(); Transport* GetTransport(); private: - int32_t CreateEventHandler(); - int32_t DestroyEventHandler(); - int32_t CreateTransport(const string& url, const uint32_t waitTime); - int32_t DestroyTransport(); - int32_t WaitForLinkReady(Transport* transport, const uint32_t waitTime); + Firebolt::Error CreateEventHandler(); + Firebolt::Error DestroyEventHandler(); + Firebolt::Error CreateTransport(const string& url, const Transport::Listener& listener, const uint32_t waitTime); + Firebolt::Error DestroyTransport(); private: WPEFramework::Core::ProxyType _workerPool; diff --git a/languages/cpp/src/shared/src/Event/Event.cpp b/languages/cpp/src/shared/src/Event/Event.cpp index c1fdff6f..2438e3c4 100644 --- a/languages/cpp/src/shared/src/Event/Event.cpp +++ b/languages/cpp/src/shared/src/Event/Event.cpp @@ -60,33 +60,35 @@ namespace FireboltSDK { _transport->SetEventHandler(this); } - int32_t Event::Unsubscribe(const string& eventName, void* usercb) + Firebolt::Error Event::Unsubscribe(const string& eventName, void* usercb) { - int32_t status = Revoke(eventName, usercb); + Firebolt::Error status = Revoke(eventName, usercb); - if (status == FireboltSDKErrorNone) { + if (status == Firebolt::Error::None) { if (_transport != nullptr) { const string parameters("{\"listen\":false}"); status = _transport->Unsubscribe(eventName, parameters); } + } else { + status = Firebolt::Error::None; } - return ((status == FireboltSDKErrorInUse) ? FireboltSDKErrorNone: status); + return status; } - int32_t Event::ValidateResponse(const WPEFramework::Core::ProxyType& jsonResponse, bool& enabled) /* override */ + Firebolt::Error Event::ValidateResponse(const WPEFramework::Core::ProxyType& jsonResponse, bool& enabled) /* override */ { - int32_t result = FireboltSDKErrorGeneral; + Firebolt::Error result = Firebolt::Error::General; Response response; _transport->FromMessage((WPEFramework::Core::JSON::IElement*)&response, *jsonResponse); if (response.Listening.IsSet() == true) { - result = FireboltSDKErrorNone; + result = Firebolt::Error::None; enabled = response.Listening.Value(); } return result; } - int32_t Event::Dispatch(const string& eventName, const WPEFramework::Core::ProxyType& jsonResponse) /* override */ + Firebolt::Error Event::Dispatch(const string& eventName, const WPEFramework::Core::ProxyType& jsonResponse) /* override */ { string response = jsonResponse->Result.Value(); _adminLock.Lock(); @@ -117,12 +119,12 @@ namespace FireboltSDK { } _adminLock.Unlock(); - return FireboltSDKErrorNone;; + return Firebolt::Error::None;; } - int32_t Event::Revoke(const string& eventName, void* usercb) + Firebolt::Error Event::Revoke(const string& eventName, void* usercb) { - int32_t status = FireboltSDKErrorNone; + Firebolt::Error status = Firebolt::Error::None; _adminLock.Lock(); EventMap::iterator eventIndex = _eventMap.find(eventName); if (eventIndex != _eventMap.end()) { @@ -137,7 +139,7 @@ namespace FireboltSDK { if (eventIndex->second.size() == 0) { _eventMap.erase(eventIndex); } else { - status = FireboltSDKErrorInUse; + status = Firebolt::Error::General; } } _adminLock.Unlock(); diff --git a/languages/cpp/src/shared/src/Event/Event.h b/languages/cpp/src/shared/src/Event/Event.h index dd65cb53..cf2fdced 100644 --- a/languages/cpp/src/shared/src/Event/Event.h +++ b/languages/cpp/src/shared/src/Event/Event.h @@ -26,7 +26,7 @@ namespace FireboltSDK { class Event : public IEventHandler { public: - typedef std::function DispatchFunction; + typedef std::function DispatchFunction; private: enum State : uint8_t { IDLE, @@ -73,20 +73,20 @@ namespace FireboltSDK { public: template - int32_t Subscribe(const string& eventName, const CALLBACK& callback, void* usercb, const void* userdata) + Firebolt::Error Subscribe(const string& eventName, const CALLBACK& callback, void* usercb, const void* userdata) { JsonObject jsonParameters; return Subscribe(eventName, jsonParameters, callback, usercb, userdata); } template - int32_t Subscribe(const string& eventName, JsonObject& jsonParameters, const CALLBACK& callback, void* usercb, const void* userdata) + Firebolt::Error Subscribe(const string& eventName, JsonObject& jsonParameters, const CALLBACK& callback, void* usercb, const void* userdata) { - int32_t status = FireboltSDKErrorUnavailable; + Firebolt::Error status = Firebolt::Error::General; if (_transport != nullptr) { status = Assign(eventName, callback, usercb, userdata); - if (status == FireboltSDKErrorNone) { + if (status == Firebolt::Error::None) { Response response; WPEFramework::Core::JSON::Variant Listen = true; @@ -96,13 +96,11 @@ namespace FireboltSDK { status = _transport->Subscribe(eventName, parameters, response); - if (status != FireboltSDKErrorNone) { + if (status != Firebolt::Error::None) { Revoke(eventName, usercb); } else if ((response.Listening.IsSet() == true) && (response.Listening.Value() == true)) { - status = FireboltSDKErrorNone; - } else { - status = FireboltSDKErrorNotSubscribed; + status = Firebolt::Error::None; } } } @@ -110,21 +108,21 @@ namespace FireboltSDK { return status; } - int32_t Unsubscribe(const string& eventName, void* usercb); + Firebolt::Error Unsubscribe(const string& eventName, void* usercb); private: template - int32_t Assign(const string& eventName, const CALLBACK& callback, void* usercb, const void* userdata) + Firebolt::Error Assign(const string& eventName, const CALLBACK& callback, void* usercb, const void* userdata) { - int32_t status = FireboltSDKErrorNone; + Firebolt::Error status = Firebolt::Error::General; std::function actualCallback = callback; - DispatchFunction implementation = [actualCallback](void* usercb, const void* userdata, const string& parameters) -> int32_t { + DispatchFunction implementation = [actualCallback](void* usercb, const void* userdata, const string& parameters) -> Firebolt::Error { WPEFramework::Core::ProxyType* inbound = new WPEFramework::Core::ProxyType(); *inbound = WPEFramework::Core::ProxyType::Create(); (*inbound)->FromString(parameters); actualCallback(usercb, userdata, static_cast(inbound)); - return (FireboltSDKErrorNone); + return (Firebolt::Error::None); }; CallbackData callbackData = {implementation, userdata, State::IDLE}; @@ -134,26 +132,25 @@ namespace FireboltSDK { CallbackMap::iterator callbackIndex = eventIndex->second.find(usercb); if (callbackIndex == eventIndex->second.end()) { eventIndex->second.emplace(std::piecewise_construct, std::forward_as_tuple(usercb), std::forward_as_tuple(callbackData)); - } else { - // Already registered, no need to register again; - status = FireboltSDKErrorInUse; + status = Firebolt::Error::None; } } else { CallbackMap callbackMap; callbackMap.emplace(std::piecewise_construct, std::forward_as_tuple(usercb), std::forward_as_tuple(callbackData)); _eventMap.emplace(std::piecewise_construct, std::forward_as_tuple(eventName), std::forward_as_tuple(callbackMap)); + status = Firebolt::Error::None; } _adminLock.Unlock(); return status; } - int32_t Revoke(const string& eventName, void* usercb); + Firebolt::Error Revoke(const string& eventName, void* usercb); private: - int32_t ValidateResponse(const WPEFramework::Core::ProxyType& jsonResponse, bool& enabled) override; - int32_t Dispatch(const string& eventName, const WPEFramework::Core::ProxyType& jsonResponse) override; + Firebolt::Error ValidateResponse(const WPEFramework::Core::ProxyType& jsonResponse, bool& enabled) override; + Firebolt::Error Dispatch(const string& eventName, const WPEFramework::Core::ProxyType& jsonResponse) override; private: EventMap _eventMap; diff --git a/languages/cpp/src/shared/src/Logger/Logger.cpp b/languages/cpp/src/shared/src/Logger/Logger.cpp index 44ebaba8..3bcce643 100644 --- a/languages/cpp/src/shared/src/Logger/Logger.cpp +++ b/languages/cpp/src/shared/src/Logger/Logger.cpp @@ -45,13 +45,13 @@ ENUM_CONVERSION_END(FireboltSDK::Logger::Category) namespace FireboltSDK { /* static */ Logger::LogLevel Logger::_logLevel = Logger::LogLevel::Error; - int32_t Logger::SetLogLevel(Logger::LogLevel logLevel) + Firebolt::Error Logger::SetLogLevel(Logger::LogLevel logLevel) { ASSERT(logLevel < Logger::LogLevel::MaxLevel); - int32_t status = FireboltSDKErrorNotSupported; + Firebolt::Error status = Firebolt::Error::General; if (logLevel < Logger::LogLevel::MaxLevel) { _logLevel = logLevel; - status = FireboltSDKErrorNone; + status = Firebolt::Error::None; } return status; } diff --git a/languages/cpp/src/shared/src/Logger/Logger.h b/languages/cpp/src/shared/src/Logger/Logger.h index b8e42031..43506dbf 100644 --- a/languages/cpp/src/shared/src/Logger/Logger.h +++ b/languages/cpp/src/shared/src/Logger/Logger.h @@ -49,7 +49,7 @@ namespace FireboltSDK { ~Logger() = default; public: - static int32_t SetLogLevel(LogLevel logLevel); + static Firebolt::Error SetLogLevel(LogLevel logLevel); static void Log(LogLevel logLevel, Category category, const std::string& module, const std::string file, const std::string function, const uint16_t line, const std::string& format, ...); public: diff --git a/languages/cpp/src/shared/src/Properties/Properties.h b/languages/cpp/src/shared/src/Properties/Properties.h index eaf6c1a4..52051397 100644 --- a/languages/cpp/src/shared/src/Properties/Properties.h +++ b/languages/cpp/src/shared/src/Properties/Properties.h @@ -33,15 +33,15 @@ namespace FireboltSDK { public: template - static int32_t Get(const string& propertyName, WPEFramework::Core::ProxyType& response) + static Firebolt::Error Get(const string& propertyName, WPEFramework::Core::ProxyType& response) { - int32_t status = FireboltSDKErrorUnavailable; + Firebolt::Error status = Firebolt::Error::General; Transport* transport = Accessor::Instance().GetTransport(); if (transport != nullptr) { JsonObject parameters; RESPONSETYPE responseType; status = transport->Invoke(propertyName, parameters, responseType); - if (status == FireboltSDKErrorNone) { + if (status == Firebolt::Error::None) { ASSERT(response.IsValid() == false); if (response.IsValid() == true) { response.Release(); @@ -57,14 +57,14 @@ namespace FireboltSDK { } template - static int32_t Get(const string& propertyName, const PARAMETERS& parameters, WPEFramework::Core::ProxyType& response) + static Firebolt::Error Get(const string& propertyName, const PARAMETERS& parameters, WPEFramework::Core::ProxyType& response) { - int32_t status = FireboltSDKErrorUnavailable; + Firebolt::Error status = Firebolt::Error::General; Transport* transport = Accessor::Instance().GetTransport(); if (transport != nullptr) { RESPONSETYPE responseType; status = transport->Invoke(propertyName, parameters, responseType); - if (status == FireboltSDKErrorNone) { + if (status == Firebolt::Error::None) { ASSERT(response.IsValid() == false); if (response.IsValid() == true) { response.Release(); @@ -81,9 +81,9 @@ namespace FireboltSDK { template - static int32_t Get(const string& propertyName, RESPONSETYPE& response) + static Firebolt::Error Get(const string& propertyName, RESPONSETYPE& response) { - int32_t status = FireboltSDKErrorUnavailable; + Firebolt::Error status = Firebolt::Error::General; Transport* transport = Accessor::Instance().GetTransport(); if (transport != nullptr) { JsonObject parameters; @@ -96,9 +96,9 @@ namespace FireboltSDK { } template - static int32_t Get(const string& propertyName, const PARAMETERS& parameters, RESPONSETYPE& response) + static Firebolt::Error Get(const string& propertyName, const PARAMETERS& parameters, RESPONSETYPE& response) { - int32_t status = FireboltSDKErrorUnavailable; + Firebolt::Error status = Firebolt::Error::General; Transport* transport = Accessor::Instance().GetTransport(); if (transport != nullptr) { status = transport->Invoke(propertyName, parameters, response); @@ -110,9 +110,9 @@ namespace FireboltSDK { } template - static int32_t Set(const string& propertyName, const PARAMETERS& parameters) + static Firebolt::Error Set(const string& propertyName, const PARAMETERS& parameters) { - int32_t status = FireboltSDKErrorUnavailable; + Firebolt::Error status = Firebolt::Error::General; Transport* transport = Accessor::Instance().GetTransport(); if (transport != nullptr) { JsonObject responseType; @@ -125,12 +125,12 @@ namespace FireboltSDK { } template - static int32_t Subscribe(const string& propertyName, JsonObject& paramsters, const CALLBACK& callback, void* usercb, const void* userdata) + static Firebolt::Error Subscribe(const string& propertyName, JsonObject& paramsters, const CALLBACK& callback, void* usercb, const void* userdata) { return Event::Instance().Subscribe(EventName(propertyName), paramsters, callback, usercb, userdata); } - static int32_t Unsubscribe(const string& propertyName, void* usercb) + static Firebolt::Error Unsubscribe(const string& propertyName, void* usercb) { return Event::Instance().Unsubscribe(EventName(propertyName), usercb); } diff --git a/languages/cpp/src/shared/src/Transport/Transport.h b/languages/cpp/src/shared/src/Transport/Transport.h index 6b80cd25..fccafcbe 100644 --- a/languages/cpp/src/shared/src/Transport/Transport.h +++ b/languages/cpp/src/shared/src/Transport/Transport.h @@ -441,8 +441,8 @@ namespace FireboltSDK { class IEventHandler { public: - virtual int32_t ValidateResponse(const WPEFramework::Core::ProxyType& jsonResponse, bool& enabled) = 0; - virtual int32_t Dispatch(const string& eventName, const WPEFramework::Core::ProxyType& jsonResponse) = 0; + virtual Firebolt::Error ValidateResponse(const WPEFramework::Core::ProxyType& jsonResponse, bool& enabled) = 0; + virtual Firebolt::Error Dispatch(const string& eventName, const WPEFramework::Core::ProxyType& jsonResponse) = 0; virtual ~IEventHandler() = default; }; @@ -455,20 +455,20 @@ namespace FireboltSDK { using EventMap = std::map; typedef std::function& jsonResponse, bool& enabled)> EventResponseValidatioionFunction; - class Job : public WPEFramework::Core::IDispatch { + class CommunicationJob : public WPEFramework::Core::IDispatch { protected: - Job(const WPEFramework::Core::ProxyType& inbound, class Transport* parent) + CommunicationJob(const WPEFramework::Core::ProxyType& inbound, class Transport* parent) : _inbound(inbound) , _parent(parent) { } public: - Job() = delete; - Job(const Job&) = delete; - Job& operator=(const Job&) = delete; + CommunicationJob() = delete; + CommunicationJob(const CommunicationJob&) = delete; + CommunicationJob& operator=(const CommunicationJob&) = delete; - ~Job() = default; + ~CommunicationJob() = default; public: static WPEFramework::Core::ProxyType Create(const WPEFramework::Core::ProxyType& inbound, class Transport* parent); @@ -483,6 +483,36 @@ namespace FireboltSDK { class Transport* _parent; }; + class ConnectionJob : public WPEFramework::Core::IDispatch { + protected: + ConnectionJob(class Transport* parent) + : _parent(parent) + { + } + + public: + ConnectionJob() = delete; + ConnectionJob(const ConnectionJob&) = delete; + ConnectionJob& operator=(const ConnectionJob&) = delete; + + ~ConnectionJob() = default; + + public: + static WPEFramework::Core::ProxyType Create(class Transport* parent); + + void Dispatch() override + { + if (Firebolt::Error::None != _parent->WaitForLinkReady()) { + _parent->NotifyStatus(Firebolt::Error::Timedout); + } + } + + private: + const WPEFramework::Core::ProxyType _inbound; + class Transport* _parent; + }; + + protected: static constexpr uint32_t DefaultWaitTime = 10000; @@ -492,11 +522,15 @@ namespace FireboltSDK { private: static constexpr const TCHAR* PathPrefix = _T("/"); + + public: + typedef std::function Listener; + public: Transport() = delete; Transport(const Transport&) = delete; Transport& operator=(Transport&) = delete; - Transport(const WPEFramework::Core::URL& url, const uint32_t waitTime) + Transport(const WPEFramework::Core::URL& url, const uint32_t waitTime, const Listener listener) : _adminLock() , _connectId(WPEFramework::Core::NodeId(url.Host().Value().c_str(), url.Port().Value())) , _channel(Channel::Instance(_connectId, ((url.Path().Value().rfind(PathPrefix, 0) == 0) ? url.Path().Value() : string(PathPrefix + url.Path().Value())), url.Query().Value(), true)) @@ -504,8 +538,12 @@ namespace FireboltSDK { , _pendingQueue() , _scheduledTime(0) , _waitTime(waitTime) + , _listener(listener) + , _status(Firebolt::Error::NotConnected) { _channel->Register(*this); + WPEFramework::Core::ProxyType job = WPEFramework::Core::ProxyType(WPEFramework::Core::ProxyType::Create(this)); + WPEFramework::Core::IWorkerPool::Instance().Submit(job); } virtual ~Transport() @@ -536,25 +574,25 @@ namespace FireboltSDK { } template - int32_t Invoke(const string& method, const PARAMETERS& parameters, RESPONSE& response) + Firebolt::Error Invoke(const string& method, const PARAMETERS& parameters, RESPONSE& response) { Entry slot; uint32_t id = _channel->Sequence(); - int32_t result = Send(method, parameters, id); - if (result == WPEFramework::Core::ERROR_NONE) { + Firebolt::Error result = Send(method, parameters, id); + if (result == Firebolt::Error::None) { result = WaitForResponse(id, response, _waitTime); } - return (FireboltErrorValue(result)); + return (result); } template - int32_t Subscribe(const string& eventName, const string& parameters, RESPONSE& response) + Firebolt::Error Subscribe(const string& eventName, const string& parameters, RESPONSE& response) { Entry slot; uint32_t id = _channel->Sequence(); - int32_t result = Send(eventName, parameters, id); - if (result == WPEFramework::Core::ERROR_NONE) { + Firebolt::Error result = Send(eventName, parameters, id); + if (result == Firebolt::Error::None) { _adminLock.Lock(); _eventMap.emplace(std::piecewise_construct, std::forward_as_tuple(eventName), @@ -564,17 +602,39 @@ namespace FireboltSDK { result = WaitForEventResponse(id, eventName, response, _waitTime); } - return (FireboltErrorValue(result)); + return (result); } - int32_t Unsubscribe(const string& eventName, const string& parameters) + Firebolt::Error Unsubscribe(const string& eventName, const string& parameters) { Revoke(eventName); Entry slot; uint32_t id = _channel->Sequence(); - int32_t result = Send(eventName, parameters, id); - return (FireboltErrorValue(result)); + return Send(eventName, parameters, id); + } + + void NotifyStatus(Firebolt::Error status) + { + _listener(false, status); + } + + Firebolt::Error WaitForLinkReady() + { + uint32_t waiting = _waitTime; + static constexpr uint32_t SLEEPSLOT_TIME = 100; + + // Right, a wait till connection is closed is requested.. + while ((waiting > 0) && (IsOpen() == false) && (_status == Firebolt::Error::NotConnected)) { + + uint32_t sleepSlot = (waiting > SLEEPSLOT_TIME ? SLEEPSLOT_TIME : waiting); + + // Right, lets sleep in slices of 100 ms + SleepMs(sleepSlot); + + waiting -= (waiting == WPEFramework::Core::infinite ? 0 : sleepSlot); + } + return (((waiting == 0) || (IsOpen() == true)) ? Firebolt::Error::None : Firebolt::Error::Timedout); } private: @@ -619,7 +679,8 @@ namespace FireboltSDK { virtual void Opened() { - // Nice to know :-) + _status = Firebolt::Error::None; + _listener(true, _status); } void Closed() @@ -635,12 +696,13 @@ namespace FireboltSDK { } _adminLock.Unlock(); + _listener(false, _status); } int32_t Submit(const WPEFramework::Core::ProxyType& inbound) { int32_t result = WPEFramework::Core::ERROR_UNAVAILABLE; - WPEFramework::Core::ProxyType job = WPEFramework::Core::ProxyType(WPEFramework::Core::ProxyType::Create(inbound, this)); + WPEFramework::Core::ProxyType job = WPEFramework::Core::ProxyType(WPEFramework::Core::ProxyType::Create(inbound, this)); WPEFramework::Core::IWorkerPool::Instance().Submit(job); return result; } @@ -684,7 +746,7 @@ namespace FireboltSDK { template - int32_t Send(const string& method, const PARAMETERS& parameters, const uint32_t& id) + Firebolt::Error Send(const string& method, const PARAMETERS& parameters, const uint32_t& id) { int32_t result = WPEFramework::Core::ERROR_UNAVAILABLE; @@ -718,11 +780,11 @@ namespace FireboltSDK { result = WPEFramework::Core::ERROR_NONE; } } - return result; + return FireboltErrorValue(result); } template - int32_t WaitForResponse(const uint32_t& id, RESPONSE& response, const uint32_t waitTime) + Firebolt::Error WaitForResponse(const uint32_t& id, RESPONSE& response, const uint32_t waitTime) { int32_t result = WPEFramework::Core::ERROR_TIMEDOUT; _adminLock.Lock(); @@ -753,14 +815,14 @@ namespace FireboltSDK { _adminLock.Lock(); _pendingQueue.erase(id); _adminLock.Unlock(); - return result; + return FireboltErrorValue(result); } static constexpr uint32_t WAITSLOT_TIME = 100; template - int32_t WaitForEventResponse(const uint32_t& id, const string& eventName, RESPONSE& response, const uint32_t waitTime) + Firebolt::Error WaitForEventResponse(const uint32_t& id, const string& eventName, RESPONSE& response, const uint32_t waitTime) { - int32_t result = WPEFramework::Core::ERROR_TIMEDOUT; + Firebolt::Error result = Firebolt::Error::Timedout; _adminLock.Lock(); typename PendingMap::iterator index = _pendingQueue.find(id); Entry& slot(index->second); @@ -776,14 +838,13 @@ namespace FireboltSDK { // that closed? if (jsonResponse.IsValid() == true) { if (jsonResponse->Error.IsSet() == true) { - result = jsonResponse->Error.Code.Value(); + result = FireboltErrorValue(jsonResponse->Error.Code.Value()); } else { if ((jsonResponse->Result.IsSet() == true) && (jsonResponse->Result.Value().empty() == false)) { - result = WPEFramework::Core::ERROR_NONE; bool enabled; result = _eventHandler->ValidateResponse(jsonResponse, enabled); - if (result == WPEFramework::Core::ERROR_NONE) { + if (result == Firebolt::Error::None) { FromMessage((INTERFACE*)&response, *jsonResponse); if (enabled) { _adminLock.Lock(); @@ -798,10 +859,10 @@ namespace FireboltSDK { } } } else { - result = WPEFramework::Core::ERROR_TIMEDOUT; + result = Firebolt::Error::Timedout; } waiting -= (waiting == WPEFramework::Core::infinite ? 0 : waitSlot); - } while ((result != WPEFramework::Core::ERROR_NONE) && (waiting > 0 )); + } while ((result != Firebolt::Error::None) && (waiting > 0 )); _adminLock.Lock(); _pendingQueue.erase(id); _adminLock.Unlock(); @@ -860,22 +921,20 @@ namespace FireboltSDK { return; } - int32_t FireboltErrorValue(const uint32_t error) + Firebolt::Error FireboltErrorValue(const uint32_t error) { - int32_t fireboltError = error; + Firebolt::Error fireboltError = Firebolt::Error::General; switch (error) { case WPEFramework::Core::ERROR_NONE: - fireboltError = FireboltSDKErrorNone; + fireboltError = Firebolt::Error::None; break; case WPEFramework::Core::ERROR_GENERAL: - fireboltError = FireboltSDKErrorGeneral; - break; case WPEFramework::Core::ERROR_UNAVAILABLE: - fireboltError = FireboltSDKErrorUnavailable; + fireboltError = Firebolt::Error::General; break; case WPEFramework::Core::ERROR_TIMEDOUT: - fireboltError = FireboltSDKErrorTimedout; + fireboltError = Firebolt::Error::Timedout; break; default: break; @@ -893,5 +952,7 @@ namespace FireboltSDK { EventMap _eventMap; uint64_t _scheduledTime; uint32_t _waitTime; + Listener _listener; + Firebolt::Error _status; }; } diff --git a/languages/cpp/src/shared/test/OpenRPCTests.cpp b/languages/cpp/src/shared/test/OpenRPCTests.cpp index 03fd2645..5faa5b19 100644 --- a/languages/cpp/src/shared/test/OpenRPCTests.cpp +++ b/languages/cpp/src/shared/test/OpenRPCTests.cpp @@ -86,8 +86,8 @@ namespace FireboltSDK { WPEFramework::Core::ProxyType response; int32_t status = FireboltSDK::Properties::Get(method, response); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status == FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status == Firebolt::Error::None) { FIREBOLT_LOG_INFO(Logger::Category::OpenRPC, Logger::Module(), "DeviceId : %s", response->Value().c_str()); } else { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Get %s status = %d\n", method.c_str(), status); @@ -102,8 +102,8 @@ namespace FireboltSDK { WPEFramework::Core::ProxyType response; int32_t status = FireboltSDK::Properties::Get(method, response); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status == FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status == Firebolt::Error::None) { FIREBOLT_LOG_INFO(Logger::Category::OpenRPC, Logger::Module(), "DeviceVersion"); PrintJsonObject(response->Variants()); } else { @@ -119,8 +119,8 @@ namespace FireboltSDK { WPEFramework::Core::ProxyType response; int32_t status = FireboltSDK::Properties::Get(method, response); - EXPECT_NE(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_NE(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Get %s status = %d\n", method.c_str(), status); } @@ -134,8 +134,8 @@ namespace FireboltSDK { parameters["reason"] = "remoteButton"; int32_t status = FireboltSDK::Properties::Set(method, parameters); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Set %s status = %d\n", method.c_str(), status); } @@ -148,8 +148,8 @@ namespace FireboltSDK { JsonObject parameters; int32_t status = FireboltSDK::Properties::Set(method, parameters); - EXPECT_NE(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_NE(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Set %s status = %d", method.c_str(), status); } @@ -178,8 +178,8 @@ namespace FireboltSDK { JsonObject jsonParameters; int32_t status = Properties::Subscribe(eventName, jsonParameters, deviceNameChangeCallback,reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Set %s status = %d", eventName.c_str(), status); } else { @@ -189,7 +189,7 @@ namespace FireboltSDK { eventControl->WaitForEvent(WPEFramework::Core::infinite); } - EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), FireboltSDKErrorNone); + EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), Firebolt::Error::None); delete eventControl; return status; @@ -206,8 +206,8 @@ namespace FireboltSDK { JsonObject jsonParameters; int32_t status = Properties::Subscribe(eventName, jsonParameters, deviceNameChangeCallback,reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Set %s status = %d", eventName.c_str(), status); } else { @@ -215,15 +215,15 @@ namespace FireboltSDK { "%s Yes registered successfully", __func__); status = Properties::Subscribe(eventName, jsonParameters, deviceNameChangeCallback, reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorInUse); - if (status == FireboltSDKErrorInUse) { + EXPECT_EQ(status, Firebolt::Error::General); + if (status == Firebolt::Error::General) { FIREBOLT_LOG_INFO(Logger::Category::OpenRPC, Logger::Module(), "%s Yes this device.name event is already registered with same callback", __func__); } - status = ((status == FireboltSDKErrorInUse) ? FireboltSDKErrorNone : status); + status = ((status == Firebolt::Error::General) ? Firebolt::Error::None : status); } - EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), FireboltSDKErrorNone); + EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), Firebolt::Error::None); delete eventControl; return status; @@ -279,8 +279,8 @@ namespace FireboltSDK { JsonObject jsonParameters; int32_t status = Properties::Subscribe(eventName, jsonParameters, deviceNameChangeMultipleCallback, reinterpret_cast(NotifyEvent1), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Set %s status = %d", eventName.c_str(), status); } else { @@ -288,19 +288,19 @@ namespace FireboltSDK { "%s Yes registered successfully, Waiting for event...", __func__); } - if (status == FireboltSDKErrorNone) { + if (status == Firebolt::Error::None) { FireboltSDK::Tests::EventControl* eventControl2 = new FireboltSDK::Tests::EventControl("EventControl2"); userdata = static_cast(eventControl2); status = Properties::Subscribe(eventName, jsonParameters, deviceNameChangeMultipleCallback, reinterpret_cast(NotifyEvent2), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(Logger::Category::OpenRPC, Logger::Module(), "Set %s status = %d", eventName.c_str(), status); } else { status = Properties::Subscribe(eventName, jsonParameters, deviceNameChangeMultipleCallback, reinterpret_cast(NotifyEvent2), userdata); - EXPECT_EQ(status, FireboltSDKErrorInUse); - status = ((status == FireboltSDKErrorInUse) ? FireboltSDKErrorNone : status); + EXPECT_EQ(status, Firebolt::Error::General); + status = ((status == Firebolt::Error::General) ? Firebolt::Error::None : status); FIREBOLT_LOG_INFO(Logger::Category::OpenRPC, Logger::Module(), "%s Yes registered second callback also successfully, waiting for events...\n", __func__); @@ -308,10 +308,10 @@ namespace FireboltSDK { eventControl1->WaitForEvent(WPEFramework::Core::infinite); eventControl2->WaitForEvent(WPEFramework::Core::infinite); } - EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent2)), FireboltSDKErrorNone); + EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent2)), Firebolt::Error::None); delete eventControl2; } - EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent1)), FireboltSDKErrorNone); + EXPECT_EQ(Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent1)), Firebolt::Error::None); delete eventControl1; return status; @@ -353,8 +353,8 @@ int32_t test_properties_get_device_id() WPEFramework::Core::ProxyType response; int32_t status = FireboltSDK::Properties::Get(method, response); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status == FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status == Firebolt::Error::None) { FIREBOLT_LOG_INFO(FireboltSDK::Logger::Category::OpenRPC, "ctest", "DeviceId : %s", response->Value().c_str()); } else { @@ -372,8 +372,8 @@ int32_t test_properties_set() parameters["reason"] = "remoteButton"; int32_t status = FireboltSDK::Properties::Set(method, parameters); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, "ctest", "Set %s status = %d", method.c_str(), status); } @@ -403,8 +403,8 @@ int32_t test_eventregister() JsonObject jsonParameters; int32_t status = FireboltSDK::Properties::Subscribe(eventName, jsonParameters, deviceNameChangeCallbackForC, reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, "ctest", "%s Set %s status = %d", __func__, eventName.c_str(), status); } else { @@ -414,7 +414,7 @@ int32_t test_eventregister() } delete eventControl; - EXPECT_EQ(FireboltSDK::Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), FireboltSDKErrorNone); + EXPECT_EQ(FireboltSDK::Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), Firebolt::Error::None); return status; } @@ -430,8 +430,8 @@ int32_t test_eventregister_with_same_callback() JsonObject jsonParameters; int32_t status = FireboltSDK::Properties::Subscribe(eventName, jsonParameters, deviceNameChangeCallbackForC, reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, "ctest", "%s Set %s status = %d", __func__, eventName.c_str(), status); } else { @@ -439,16 +439,16 @@ int32_t test_eventregister_with_same_callback() "%s Yes registered successfully", __func__); status = FireboltSDK::Properties::Subscribe(eventName, jsonParameters, deviceNameChangeCallbackForC, reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorInUse); - if (status == FireboltSDKErrorInUse) { + EXPECT_EQ(status, Firebolt::Error::General); + if (status == Firebolt::Error::General) { FIREBOLT_LOG_INFO(FireboltSDK::Logger::Category::OpenRPC, "ctest", "%s Yes this device.name event is already registered with same callback", __func__); } - status = ((status == FireboltSDKErrorInUse) ? FireboltSDKErrorNone : status); + status = ((status == Firebolt::Error::General) ? Firebolt::Error::None : status); } delete eventControl; - EXPECT_EQ(FireboltSDK::Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), FireboltSDKErrorNone); + EXPECT_EQ(FireboltSDK::Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), Firebolt::Error::None); return status; } @@ -464,8 +464,8 @@ int32_t test_eventregister_by_providing_callback() JsonObject jsonParameters; int32_t status = FireboltSDK::Tests::SubscribeEventForC(eventName, jsonParameters, deviceNameChangeCallbackForC, reinterpret_cast(NotifyEvent), userdata); - EXPECT_EQ(status, FireboltSDKErrorNone); - if (status != FireboltSDKErrorNone) { + EXPECT_EQ(status, Firebolt::Error::None); + if (status != Firebolt::Error::None) { FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, "ctest", "%s Set %s status = %d", __func__, eventName.c_str(), status); } else { @@ -475,14 +475,14 @@ int32_t test_eventregister_by_providing_callback() } delete eventControl; - EXPECT_EQ(FireboltSDK::Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), FireboltSDKErrorNone); + EXPECT_EQ(FireboltSDK::Properties::Unsubscribe(eventName, reinterpret_cast(NotifyEvent)), Firebolt::Error::None); return status; } #include "TypesPriv.h" int32_t test_string_set_get_value() { - int32_t status = FireboltSDKErrorNone; + int32_t status = Firebolt::Error::None; FireboltSDK::JSON::String* str = new FireboltSDK::JSON::String(); WPEFramework::Core::JSON::String wpeJsonStr("TestString"); Firebolt_String_t handle = reinterpret_cast(str); diff --git a/languages/cpp/templates/codeblocks/setter.c b/languages/cpp/templates/codeblocks/setter.c index c66068bc..b444c738 100644 --- a/languages/cpp/templates/codeblocks/setter.c +++ b/languages/cpp/templates/codeblocks/setter.c @@ -1,7 +1,12 @@ -/* ${method.rpc.name} - ${method.description} */ -int32_t ${method.Name}( ${method.signature.params} ) -{ - const string method = _T("${info.title.lowercase}.${method.rpc.name}"); + + /* ${method.rpc.name} - ${method.description} */ + void ${method.Name}( ${method.signature.params}${if.params}, ${end.if.params}Firebolt::Error *err = nullptr ) + { + const string method = _T("${info.title.lowercase}.${method.rpc.name}"); + + JsonObject jsonParameters; ${if.params}${method.params.serialization}${end.if.params} - return FireboltSDK::Properties::Set(method, jsonParameters); -} + + Firebolt::Error status = FireboltSDK::Properties::Set(method, jsonParameters); + return; + } diff --git a/languages/cpp/templates/declarations/default.c b/languages/cpp/templates/declarations/default.c index 2c19a1ef..e69de29b 100644 --- a/languages/cpp/templates/declarations/default.c +++ b/languages/cpp/templates/declarations/default.c @@ -1,6 +0,0 @@ - /* - ${method.name} - ${method.description} - ${method.params.annotations}${if.deprecated} * @deprecated ${method.deprecation}${end.if.deprecated} - */ - virtual int32_t ${method.Name}( ${method.signature.params}${if.result}${if.params}, ${end.if.params}${method.result.type}& ${method.result.name}${end.if.result} ) = 0; \ No newline at end of file diff --git a/languages/cpp/templates/declarations/event.c b/languages/cpp/templates/declarations/event.c index d2df4f12..8939efc8 100644 --- a/languages/cpp/templates/declarations/event.c +++ b/languages/cpp/templates/declarations/event.c @@ -1,8 +1,8 @@ /* ${method.name} - ${method.description} */ struct I${method.Name}Notification { - virtual void ${method.Name} ( ${event.signature.callback.params}${if.event.params}, ${end.if.event.params}${method.result.properties} ) = 0; + virtual void ${method.Name}( ${event.signature.callback.params}${if.event.params}, ${end.if.event.params}${event.result.type} ) = 0; }; // signature callback params: ${event.signature.callback.params} // method result properties : ${method.result.properties} - virtual int32_t subscribe ( ${event.signature.params}${if.event.params}, ${end.if.event.params}I${method.Name}Notification& notification ) = 0; - virtual int32_t unsubscribe ( I${method.Name}Notification& notification ) = 0; \ No newline at end of file + virtual void Subscribe( ${event.signature.params}${if.event.params}, ${end.if.event.params}I${method.Name}Notification& notification, Firebolt::Error *err = nullptr ) = 0; + virtual void Unsubscribe( I${method.Name}Notification& notification, Firebolt::Error *err = nullptr ) = 0; diff --git a/languages/cpp/templates/declarations/polymorphic-pull-event.c b/languages/cpp/templates/declarations/polymorphic-pull-event.c index 178678ad..e69de29b 100644 --- a/languages/cpp/templates/declarations/polymorphic-pull-event.c +++ b/languages/cpp/templates/declarations/polymorphic-pull-event.c @@ -1,8 +0,0 @@ - /* ${method.name} - ${method.description} */ - struct I{method.Name}Notification { - virtual void ${method.Name} ( ${method.pulls.param.type}& value ) = 0; - }; - - virtual int32_t subscribe ( I{method.Name}Notification& notification ) = 0; - virtual int32_t unsubscribe ( I{method.Name}Notification& notification ) = 0; - diff --git a/languages/cpp/templates/declarations/polymorphic-pull.c b/languages/cpp/templates/declarations/polymorphic-pull.c index 6588a635..e69de29b 100644 --- a/languages/cpp/templates/declarations/polymorphic-pull.c +++ b/languages/cpp/templates/declarations/polymorphic-pull.c @@ -1,2 +0,0 @@ - /* ${method.name} - ${method.description} */ - virtual int32_t ${method.Name}( ${method.signature.params} ) = 0; diff --git a/languages/cpp/templates/declarations/polymorphic-reducer.c b/languages/cpp/templates/declarations/polymorphic-reducer.c index a6f50d1b..e69de29b 100644 --- a/languages/cpp/templates/declarations/polymorphic-reducer.c +++ b/languages/cpp/templates/declarations/polymorphic-reducer.c @@ -1,5 +0,0 @@ - /* - * ${method.summary} - * ${method.params} - */ - virtual int32_t ${method.Name}(${method.signature.params}${if.result.properties}${if.params}, ${end.if.params}${end.if.result.properties}${method.result.properties}) = 0; diff --git a/languages/cpp/templates/declarations/property.h b/languages/cpp/templates/declarations/property.h index 09cc5d7d..6d8890e4 100644 --- a/languages/cpp/templates/declarations/property.h +++ b/languages/cpp/templates/declarations/property.h @@ -1,5 +1,5 @@ /* - * ${method.description} - * ${method.params} - */ -virtual int32_t ${method.Name} (${method.signature.params}${if.params}, ${end.if.params}${method.result.properties}) = 0; + * ${method.description} + * ${method.params} + */ + virtual ${method.signature.result} ${method.Name}( ${method.signature.params}${if.params}, ${end.if.params}Firebolt::Error *err = nullptr ) const = 0; diff --git a/languages/cpp/templates/declarations/setter.h b/languages/cpp/templates/declarations/setter.h index 64e4d19e..b1035bc4 100644 --- a/languages/cpp/templates/declarations/setter.h +++ b/languages/cpp/templates/declarations/setter.h @@ -1,5 +1,5 @@ /* - ${method.rpc.name} - ${method.description} - */ - virtual int32_t ${method.Name}( ${method.signature.params} ) = 0; + ${method.rpc.name} + ${method.description} + */ + virtual void ${method.Name}( ${method.signature.params}${if.params}, ${end.if.params}Firebolt::Error *err = nullptr ) = 0; diff --git a/languages/cpp/templates/methods/calls-metrics.c b/languages/cpp/templates/methods/calls-metrics.c index d38c499f..8b137891 100644 --- a/languages/cpp/templates/methods/calls-metrics.c +++ b/languages/cpp/templates/methods/calls-metrics.c @@ -1,29 +1 @@ -/* ${method.rpc.name} - ${method.description} */ -void Metrics_${method.Name}Dispatcher(const void*${if.result} result${end.if.result}) { - Metrics_${method.Name}(${if.result}(static_cast<${method.result.json.type}>(const_cast(result)))${end.if.result}); -} -int32_t ${info.Title}_${method.Name}( ${method.signature.params}${if.result}${if.params}, ${end.if.params}OUT ${method.result.type}* ${method.result.name}${end.if.result}${if.signature.empty}void${end.if.signature.empty} ) { - int32_t status = FireboltSDKErrorUnavailable; - FireboltSDK::Transport* transport = FireboltSDK::Accessor::Instance().GetTransport(); - if (transport != nullptr) { - - ${method.params.serialization.with.indent} - ${method.result.json.type} jsonResult; - status = transport->Invoke("${info.title}.${method.rpc.name}", jsonParameters, jsonResult); - if (status == FireboltSDKErrorNone) { - FIREBOLT_LOG_INFO(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "${info.Title}.${method.rpc.name} is successfully invoked"); - ${method.result.instantiation.with.indent} - - void* result = nullptr; - ${if.result}result = static_cast(new ${method.result.json.type});${end.if.result} - WPEFramework::Core::ProxyType job = WPEFramework::Core::ProxyType(WPEFramework::Core::ProxyType::Create(Metrics_${method.Name}Dispatcher, result)); - WPEFramework::Core::IWorkerPool::Instance().Submit(job); - } - - } else { - FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "Error in getting Transport err = %d", status); - } - - return status; -} diff --git a/languages/cpp/templates/methods/default.c b/languages/cpp/templates/methods/default.c index c375d30f..e69de29b 100644 --- a/languages/cpp/templates/methods/default.c +++ b/languages/cpp/templates/methods/default.c @@ -1,21 +0,0 @@ -/* ${method.rpc.name} - ${method.description} */ -int32_t ${info.Title}_${method.Name}( ${method.signature.params}${if.result}${if.params}, ${end.if.params} ${method.result.type}* ${method.result.name}${end.if.result}${if.signature.empty}void${end.if.signature.empty} ) { - - int32_t status = FireboltSDKErrorUnavailable; - FireboltSDK::Transport* transport = FireboltSDK::Accessor::Instance().GetTransport(); - if (transport != nullptr) { - - ${method.params.serialization.with.indent} - ${method.result.json.type} jsonResult; - status = transport->Invoke("${info.title.lowercase}.${method.rpc.name}", jsonParameters, jsonResult); - if (status == FireboltSDKErrorNone) { - FIREBOLT_LOG_INFO(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "${info.Title}.${method.rpc.name} is successfully invoked"); - ${method.result.instantiation.with.indent} - } - - } else { - FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "Error in getting Transport err = %d", status); - } - - return status; -} diff --git a/languages/cpp/templates/methods/event.c b/languages/cpp/templates/methods/event.c index 85ae3b48..e6eb56a7 100644 --- a/languages/cpp/templates/methods/event.c +++ b/languages/cpp/templates/methods/event.c @@ -1,27 +1,27 @@ -/* ${method.rpc.name} - ${method.description} */ -static void ${info.Title}${method.Name}InnerCallback( void* userCB, const void* userData, void* response ) -{ + /* ${method.rpc.name} - ${method.description} */ + static void ${info.Title}${method.Name}InnerCallback( void* notification, const void* userData, void* jsonResponse ) + { ${event.callback.params.serialization} - ASSERT(jsonResponse->IsValid() == true); - if (jsonResponse->IsValid() == true) { + ASSERT(proxyResponse->IsValid() == true); + + if (proxyResponse->IsValid() == true) { ${event.callback.result.instantiation} - ${info.Title}${method.Name}Callback callback = reinterpret_cast<${info.Title}${method.Name}Callback>(userCB); - callback(userData, ${event.callback.response.instantiation}); - } -} -int32_t ${info.Title}_Register_${method.Name}( ${event.signature.params}${if.event.params}, ${end.if.event.params}${info.Title}${method.Name}Callback userCB, const void* userData ) -{ - const string eventName = _T("${info.title.lowercase}.${method.rpc.name}"); - int32_t status = FireboltSDKErrorNone; + proxyResponse->Release(); - if (userCB != nullptr) { - ${event.params.serialization} - status = FireboltSDK::Event::Instance().Subscribe<${event.result.json.type}>(eventName, jsonParameters, ${info.Title}${method.Name}InnerCallback, reinterpret_cast(userCB), userData); - } - return status; -} -int32_t ${info.Title}_Unregister_${method.Name}( ${info.Title}${method.Name}Callback userCB) -{ - return FireboltSDK::Event::Instance().Unsubscribe(_T("${info.title.lowercase}.${method.rpc.name}"), reinterpret_cast(userCB)); -} + I${method.Name}Notification& notifier = *(reinterpret_cast(notification)); + notifier.${method.Name}(${event.callback.response.instantiation}); + } + } + void Subscribe( ${event.signature.params}${if.event.params}, ${end.if.event.params}I${method.Name}Notification& notification, Firebolt::Error *err = nullptr ) + { + const string eventName = _T("${info.title.lowercase}.${method.rpc.name}"); + Firebolt::Error status = Firebolt::Error::None; + JsonObject jsonParameters; +${event.params.serialization} + status = FireboltSDK::Event::Instance().Subscribe<${event.result.json.type}>(eventName, jsonParameters, ${info.Title}${method.Name}InnerCallback, reinterpret_cast(¬ification), nullptr); + } + void Unsubscribe( I${method.Name}Notification& notification, Firebolt::Error *err = nullptr ) + { + Firebolt::Error status = FireboltSDK::Event::Instance().Unsubscribe(_T("${info.title.lowercase}.${method.rpc.name}"), reinterpret_cast(¬ification)); + } diff --git a/languages/cpp/templates/methods/polymorphic-pull-event.c b/languages/cpp/templates/methods/polymorphic-pull-event.c index 49aa1dba..e69de29b 100644 --- a/languages/cpp/templates/methods/polymorphic-pull-event.c +++ b/languages/cpp/templates/methods/polymorphic-pull-event.c @@ -1,54 +0,0 @@ -/* ${method.rpc.name} - ${method.description} */ -static void ${info.Title}${method.Name}InnerCallback( void* userCB, const void* userData, void* response ) -{ -${event.callback.params.serialization} - ASSERT(jsonResponse->IsValid() == true); - if (jsonResponse->IsValid() == true) { - - ${info.Title}${method.Name}Callback callback = reinterpret_cast<${info.Title}${method.Name}Callback>(userCB); - - WPEFramework::Core::ProxyType<${method.pulls.param.json.type}>* requestParam = new WPEFramework::Core::ProxyType<${method.pulls.param.json.type}>(); - *requestParam = WPEFramework::Core::ProxyType<${method.pulls.param.json.type}>::Create(); - *(*requestParam) = (*jsonResponse)->${event.pulls.param.name}Parameters; - - ${method.pulls.type} result = reinterpret_cast<${method.pulls.type}>(callback(userData, reinterpret_cast<${method.pulls.param.type}>(requestParam))); - - JsonObject jsonParameters; - WPEFramework::Core::JSON::Variant CorrelationId = (*jsonResponse)->CorrelationId.Value(); - jsonParameters.Set(_T("correlationId"), CorrelationId); - - ${method.pulls.json.type}& resultObj = *(*(reinterpret_cast*>(result))); - string resultStr; - resultObj.ToString(resultStr); - WPEFramework::Core::JSON::VariantContainer resultContainer(resultStr); - WPEFramework::Core::JSON::Variant Result = resultContainer; - jsonParameters.Set(_T("result"), Result); - - FireboltSDK::Transport* transport = FireboltSDK::Accessor::Instance().GetTransport(); - if (transport != nullptr) { - WPEFramework::Core::JSON::Boolean jsonResult; - int32_t status = transport->Invoke(_T("${info.title.lowercase}.${method.pulls.for}"), jsonParameters, jsonResult); - if (status == FireboltSDKErrorNone) { - FIREBOLT_LOG_INFO(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "${info.Title}.${method.rpc.name} is successfully pushed with status as %d", jsonResult.Value()); - } - } else { - FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "Error in getting Transport"); - } - } -} -int32_t ${info.Title}_Register_${method.Name}( ${info.Title}${method.Name}Callback userCB, const void* userData ) -{ - const string eventName = _T("${info.title.lowercase}.${method.rpc.name}"); - int32_t status = FireboltSDKErrorNone; - - if (userCB != nullptr) { - ${event.params.serialization} - status = FireboltSDK::Event::Instance().Subscribe<${event.result.json.type}>(eventName, jsonParameters, ${info.Title}${method.Name}InnerCallback, reinterpret_cast(userCB), userData); - } - return status; -} -int32_t ${info.Title}_Unregister_${method.Name}( ${info.Title}${method.Name}Callback userCB) -{ - return FireboltSDK::Event::Instance().Unsubscribe(_T("${info.title.lowercase}.${method.rpc.name}"), reinterpret_cast(userCB)); -} - diff --git a/languages/cpp/templates/methods/polymorphic-pull.c b/languages/cpp/templates/methods/polymorphic-pull.c index 840566e2..e69de29b 100644 --- a/languages/cpp/templates/methods/polymorphic-pull.c +++ b/languages/cpp/templates/methods/polymorphic-pull.c @@ -1,22 +0,0 @@ -/* ${method.rpc.name} - ${method.description} */ -int32_t ${info.Title}_Push${method.Name}( ${method.signature.params} ) -{ - int32_t status = FireboltSDKErrorUnavailable; - - FireboltSDK::Transport* transport = FireboltSDK::Accessor::Instance().GetTransport(); - if (transport != nullptr) { - string correlationId = ""; - ${method.params.serialization.with.indent} - - WPEFramework::Core::JSON::Boolean jsonResult; - status = transport->Invoke(_T("${info.title.lowercase}.${method.rpc.name}"), jsonParameters, jsonResult); - if (status == FireboltSDKErrorNone) { - FIREBOLT_LOG_INFO(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "${info.Title}.${method.rpc.name} is successfully pushed with status as %d", jsonResult.Value()); - status = (jsonResult.Value() == true) ? FireboltSDKErrorNone : FireboltSDKErrorNotSupported; - } - } else { - FIREBOLT_LOG_ERROR(FireboltSDK::Logger::Category::OpenRPC, FireboltSDK::Logger::Module(), "Error in getting Transport"); - } - - return status; -} diff --git a/languages/cpp/templates/methods/property.c b/languages/cpp/templates/methods/property.c index 7f375d81..479eb3b5 100644 --- a/languages/cpp/templates/methods/property.c +++ b/languages/cpp/templates/methods/property.c @@ -1,14 +1,14 @@ -/* ${method.rpc.name} - ${method.description} */ -int32_t ${info.Title}_Get${method.Name}( ${method.signature.params}${if.params}, ${end.if.params} ${method.result.type}* ${method.result.name} ) -{ - const string method = _T("${info.title.lowercase}.${method.rpc.name}"); -${if.params}${method.params.serialization}${end.if.params} - ${method.result.json} jsonResult; - ${if.params}int32_t status = FireboltSDK::Properties::Get(method, jsonParameters, jsonResult);${end.if.params} - ${if.params.empty}int32_t status = FireboltSDK::Properties::Get(method, jsonResult);${end.if.params.empty} - if (status == FireboltSDKErrorNone) { + /* ${method.rpc.name} - ${method.description} */ + ${method.signature.result} ${method.Name}( ${method.signature.params}${if.params}, ${end.if.params}Firebolt::Error *err = nullptr ) const + { + const string method = _T("${info.title.lowercase}.${method.rpc.name}"); + ${if.params}${method.params.serialization}${end.if.params} + ${method.result.json} jsonResult; +${method.result.initialization} + ${if.params}Firebolt::Error status = FireboltSDK::Properties::Get(method, jsonParameters, jsonResult);${end.if.params} + ${if.params.empty}Firebolt::Error status = FireboltSDK::Properties::Get(method, jsonResult);${end.if.params.empty} + if (status == Firebolt::Error::None) { ${method.result.instantiation} - } - return status; -} -${method.setter} + } + return ${method.result.name}; + }${method.setter} diff --git a/languages/cpp/templates/modules/include/module.h b/languages/cpp/templates/modules/include/module.h index 462c9a30..6080265e 100644 --- a/languages/cpp/templates/modules/include/module.h +++ b/languages/cpp/templates/modules/include/module.h @@ -18,24 +18,28 @@ #pragma once -#include +#include "error.h" /* ${IMPORTS} */ ${if.declarations}namespace Firebolt { namespace ${info.Title} { +${if.enums} // Enums - /* ${ENUMS} */ - +/* ${ENUMS} */${end.if.enums} +${if.types} // Types /* ${TYPES} */ - +${end.if.types} struct I${info.Title} { - virtual ~I${info.Title} = default; + static I${info.Title}& Instance(); + static void Dispose(); + + virtual ~I${info.Title}() = default; -// Methods & Events -/* ${DECLARATIONS} */ + // Methods & Events + /* ${DECLARATIONS} */ }; diff --git a/languages/cpp/templates/modules/src/module.cpp b/languages/cpp/templates/modules/src/module.cpp index 8cef2390..ebdbb0b7 100644 --- a/languages/cpp/templates/modules/src/module.cpp +++ b/languages/cpp/templates/modules/src/module.cpp @@ -20,22 +20,70 @@ /* ${IMPORTS} */ #include "${info.title.lowercase}.h" -${if.types}namespace Firebolt { +${if.implementations} +namespace Firebolt { +namespace ${info.Title} { +${if.enums} -/* ${ENUMS:json-types} */ +/* ${ENUMS:json-types} */${end.if.enums} +${if.types} + // Types +/* ${TYPES:json-types} */${end.if.types} -${if.definitions}namespace ${info.Title} { + ${if.definitions}class ${info.Title}Impl : public I${info.Title} { + private: + ${info.Title}Impl() + { + ASSERT(_singleton == nullptr); + _singleton = this; + } -// Types - /* ${TYPES:json-types} */ + public: + ${info.Title}Impl(const ${info.Title}Impl&) = delete; + ${info.Title}Impl& operator=(const ${info.Title}Impl&) = delete; -// Methods -/* ${METHODS} */ + ~${info.Title}Impl() + { + ASSERT(_singleton != nullptr); + _singleton = nullptr; + } -// Events -/* ${EVENTS} */ + static ${info.Title}Impl& Instance() + { + static ${info.Title}Impl* instance = new ${info.Title}Impl(); + ASSERT(instance != nullptr); + return *instance; + } + static void Dispose() + { + if (_singleton != nullptr) { + delete _singleton; + } + } -}${end.if.definitions} -}${end.if.types} \ No newline at end of file + + // Methods + /* ${METHODS} */ + + // Events + /* ${EVENTS} */ + + private: + static ${info.Title}Impl* _singleton; + };${end.if.definitions} + + ${info.Title}Impl* ${info.Title}Impl::_singleton = nullptr; + + /* static */ I${info.Title}& I${info.Title}::Instance() + { + return (${info.Title}Impl::Instance()); + } + /* static */ void I${info.Title}::Dispose() + { + ${info.Title}Impl::Dispose(); + } + +}//namespace ${info.Title} +}${end.if.implementations} diff --git a/languages/cpp/templates/schemas/include/common/module.h b/languages/cpp/templates/schemas/include/common/module.h index 5628e5b3..87ba7425 100644 --- a/languages/cpp/templates/schemas/include/common/module.h +++ b/languages/cpp/templates/schemas/include/common/module.h @@ -18,19 +18,18 @@ #pragma once -#include +#include "error.h" /* ${IMPORTS} */ -namespace Firebolt { +${if.declarations}namespace Firebolt { namespace ${info.Title} { - +${if.enums} // Enums -/* ${ENUMS} */ - +/* ${ENUMS} */${end.if.enums} +${if.types} // Types -/* ${TYPES} */ - +/* ${TYPES} */${end.if.types} } //namespace ${info.Title} -} +}${end.if.declarations} diff --git a/languages/cpp/templates/schemas/src/jsondata_module.h b/languages/cpp/templates/schemas/src/jsondata_module.h index 6e220163..916b8698 100644 --- a/languages/cpp/templates/schemas/src/jsondata_module.h +++ b/languages/cpp/templates/schemas/src/jsondata_module.h @@ -23,8 +23,8 @@ ${if.schemas}namespace Firebolt { namespace ${info.Title} { - // Types + // Types /* ${SCHEMAS:json-types} */ - } +} }${end.if.schemas} diff --git a/languages/cpp/templates/schemas/src/module_common.cpp b/languages/cpp/templates/schemas/src/module_common.cpp index 5570982c..87498ab8 100644 --- a/languages/cpp/templates/schemas/src/module_common.cpp +++ b/languages/cpp/templates/schemas/src/module_common.cpp @@ -19,23 +19,11 @@ #include "FireboltSDK.h" /* ${IMPORTS} */ #include "jsondata_${info.title.lowercase}.h" +${if.enums} -namespace Firebolt { +namespace WPEFramework { /* ${ENUMS} */ -namespace ${info.Title} { - - -// Methods -/* ${METHODS} */ - -// Events -/* ${EVENTS} */ - - -} //namespace ${info.Title} - -} - +}${end.if.enums} diff --git a/languages/cpp/templates/sections/methods.h b/languages/cpp/templates/sections/methods.h index 3ab606c0..e8200eb0 100644 --- a/languages/cpp/templates/sections/methods.h +++ b/languages/cpp/templates/sections/methods.h @@ -1,4 +1 @@ - -// Methods - ${method.list} diff --git a/languages/cpp/templates/types/enum.cpp b/languages/cpp/templates/types/enum.cpp index 9c98f888..e162ef43 100644 --- a/languages/cpp/templates/types/enum.cpp +++ b/languages/cpp/templates/types/enum.cpp @@ -1,4 +1,4 @@ /* ${title} ${description} */ - ENUM_CONVERSION_BEGIN(${info.Title}_${name}) - { ${info.TITLE}_${NAME}_${key}, _T("${value}") }, - ENUM_CONVERSION_END(${info.Title}_${name}) + ENUM_CONVERSION_BEGIN(Firebolt::${info.Title}::${name}) + { Firebolt::${info.Title}::${name}::${key}, _T("${value}") }, + ENUM_CONVERSION_END(Firebolt::${info.Title}::${name})