summaryrefslogtreecommitdiff
path: root/AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h
diff options
context:
space:
mode:
authorAleksandar Donchev <aleksander.donchev@partner.bmw.de>2013-09-02 11:57:28 +0200
committerChristian Linke <Christian.Linke@bmw.de>2013-09-03 17:26:04 +0200
commita2edae5cee4254b933f42399edc0e092abd4f5cf (patch)
treeead58f525b947deed4b8c76ab9c89c80b5056227 /AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h
parent7aee1baeea1777318932cc49a8eac18f194233cd (diff)
downloadaudiomanager-a2edae5cee4254b933f42399edc0e092abd4f5cf.tar.gz
*PluginCommandInterfaceCAPI, PluginRoutingInterfaceCAPI, NodeStateCommunicatorCAPI with unit tests first version.
Choosing between DBUS and Common-API via cmake. CommonAPI - legacy support for DBus properties (Set 1) Signed-off-by: Christian Linke <christian.linke@bmw.de> (cherry picked from commit ea96ef59e29466667c90b506426e2a5a9cdb82d2)
Diffstat (limited to 'AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h')
-rw-r--r--AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h101
1 files changed, 101 insertions, 0 deletions
diff --git a/AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h b/AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h
new file mode 100644
index 0000000..6c063e5
--- /dev/null
+++ b/AudioManagerDaemon/include/CAmNodeStateCommunicatorCAPI.h
@@ -0,0 +1,101 @@
+/**
+ * Copyright (C) 2012, BMW AG
+ *
+ * This file is part of GENIVI Project AudioManager.
+ *
+ * Contributions are licensed to the GENIVI Alliance under one or more
+ * Contribution License Agreements.
+ *
+ * \copyright
+ * This Source Code Form is subject to the terms of the
+ * Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with
+ * this file, You can obtain one at http://mozilla.org/MPL/2.0/.
+ *
+ *
+ * \author Aleksandar Donchev, aleksander.donchev@partner.bmw.de BMW 2013
+ *
+ * \file CAmNodeStateCommunicatorCAPI.h
+ * For further information see http://www.genivi.org/.
+ *
+ */
+#ifndef CAMNODESTATECOMMUNICATORCAPI_H_
+#define CAMNODESTATECOMMUNICATORCAPI_H_
+
+#include <org/genivi/NodeStateManager/Consumer/ConsumerProxy.h>
+#include "CAmNodeStateCommunicator.h"
+#include "LifeCycleConsumerStubDefault.h"
+
+namespace am
+{
+using namespace CommonAPI;
+using namespace org::genivi::NodeStateManager::Consumer;
+using namespace org::genivi::NodeStateManager::LifeCycleConsumer;
+
+
+class CAmCommonAPIWrapper;
+/** communicates with the NSM
+ * The CAmNodeStateCommunicator communicates with the NodeStateManager via Dbus Common-API's wrapping mechanism. Only works, if CAmCommonAPIWrapper is enabled.
+ */
+class CAmNodeStateCommunicatorCAPI : public CAmNodeStateCommunicator
+{
+ /* A concrete implementation of the life cycle stub.
+ * An object from this class is instantiated from the common-api factory.
+ * It forwards the invocations to its delegate CAmNodeStateCommunicatorCAPI.
+ */
+ class CAmNodeStateCommunicatorServiceImpl : public LifeCycleConsumerStubDefault
+ {
+ CAmNodeStateCommunicatorCAPI *mpDelegate;
+ public:
+ CAmNodeStateCommunicatorServiceImpl ():mpDelegate(NULL) {}
+ CAmNodeStateCommunicatorServiceImpl (CAmNodeStateCommunicatorCAPI *aNSCommunicator):mpDelegate(aNSCommunicator) {}
+ ~CAmNodeStateCommunicatorServiceImpl() { mpDelegate = NULL; }
+
+ CAmNodeStateCommunicatorCAPI *getDelegate() { return mpDelegate; };
+ void setDelegate(CAmNodeStateCommunicatorCAPI *aDelegate) { mpDelegate = aDelegate; };
+
+ void LifecycleRequest(uint32_t Request, uint32_t RequestId, int32_t& ErrorCode) {
+ if(mpDelegate)
+ mpDelegate->cbReceivedLifecycleRequest(Request, RequestId, ErrorCode);
+ }
+ };
+
+ CAmCommonAPIWrapper *mpCAPIWrapper;
+ std::shared_ptr<ConsumerProxy<> > mNSMProxy;
+ std::shared_ptr<CAmNodeStateCommunicatorCAPI::CAmNodeStateCommunicatorServiceImpl> mNSMStub;
+public:
+ CAmNodeStateCommunicatorCAPI(CAmCommonAPIWrapper* iCAPIWrapper);
+ virtual ~CAmNodeStateCommunicatorCAPI();
+
+ am_Error_e nsmGetRestartReasonProperty(NsmRestartReason_e& restartReason) ;
+ am_Error_e nsmGetShutdownReasonProperty(NsmShutdownReason_e& ShutdownReason) ;
+ am_Error_e nsmGetRunningReasonProperty(NsmRunningReason_e& nsmRunningReason) ;
+ NsmErrorStatus_e nsmGetNodeState(NsmNodeState_e& nsmNodeState) ;
+ NsmErrorStatus_e nsmGetSessionState(const std::string& sessionName, const NsmSeat_e& seatID, NsmSessionState_e& sessionState) ;
+ NsmErrorStatus_e nsmGetApplicationMode(NsmApplicationMode_e& applicationMode) ;
+ NsmErrorStatus_e nsmRegisterShutdownClient(const uint32_t shutdownMode, const uint32_t timeoutMs) ;
+ NsmErrorStatus_e nsmUnRegisterShutdownClient(const uint32_t shutdownMode) ;
+ am_Error_e nsmGetInterfaceVersion(uint32_t& version) ;
+ NsmErrorStatus_e nsmSendLifecycleRequestComplete(const uint32_t RequestId, const NsmErrorStatus_e status) ;
+
+ bool isServiceAvailable();
+
+ static const char * CLIENT_STRING;
+ static const char * SERVER_STRING;
+ static const char * OBJECT_NAME;
+ static const char * BUS_NAME;
+
+private:
+ /* Client events */
+ void onNodeStateEvent(const int32_t nodeState);
+ void onNodeApplicationModeEvent(const int32_t nodeApplicationMode);
+ void onSessionStateChangedEvent(const std::string & sessionName, const int32_t seatID, const int32_t sessionState);
+ void onServiceStatusEvent(const CommonAPI::AvailabilityStatus& serviceStatus);
+ /* Service callbacks */
+ void cbReceivedLifecycleRequest(uint32_t Request, uint32_t RequestId, int32_t& ErrorCode);
+protected:
+ bool mIsServiceAvailable;
+};
+
+}
+/* namespace am */
+#endif /* CAMNODESTATECOMMUNICATORCAPI_H_ */