-
Notifications
You must be signed in to change notification settings - Fork 0
/
ThunderAccess.h
110 lines (96 loc) · 3.29 KB
/
ThunderAccess.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/*
* If not stated otherwise in this file or this component's license file the
* following copyright and licenses apply:
*
* Copyright 2018 RDK Management
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file ThunderAccess.h
* @brief shim for dispatching UVE HDMI input playback
*/
#ifndef THUNDERACCESS_H_
#define THUNDERACCESS_H_
#include <Module.h>
#include <core/core.h>
#include <websocket/websocket.h>
using namespace std;
using namespace WPEFramework;
#define THUNDER_RPC_TIMEOUT 5000
/**
* @class ThunderAccessAAMP
* @brief Support Thunder Plugin Access from AAMP
*/
class ThunderAccessAAMP
{
public:
/**
* @fn ThunderAccessAAMP
* @note Security tocken accusition, controller object creation
*/
ThunderAccessAAMP(std::string callsign, AampLogManager *logObj=NULL);
/**
* @fn ~ThunderAccessAAMP
* @note clean up
*/
~ThunderAccessAAMP();
/**
* @brief ThunderAccessAAMP copy constructor disabled
*/
ThunderAccessAAMP(const ThunderAccessAAMP&) = delete;
/**
* @brief ThunderAccessAAMP assignment disabled
*/
ThunderAccessAAMP& operator=(const ThunderAccessAAMP&) = delete;
/**
* @brief ActivatePlugin
* @note Plugin activation and Remote object creation
* @param Plugin Callsign
* @retval true on success
* @retval false on failure
*/
bool ActivatePlugin();
/**
* @fn InvokeJSONRPC
* @note Invoke JSONRPC call for the plugin
* @param method,param,result, method,waitTime reference to input param, result and waitTime (default = THUNDER_RPC_TIMEOUT)
* @retval true on success
* @retval false on failure
*/
bool InvokeJSONRPC(std::string method, const JsonObject ¶m, JsonObject &result, const uint32_t waitTime = THUNDER_RPC_TIMEOUT);
/**
* @fn SubscribeEvent
* @note Subscribe event data for the specific plugin
* @param eventName,functionHandler Event name, Event handler
* @retval true on success
* @retval false on failure
*/
bool SubscribeEvent (string eventName, std::function<void(const WPEFramework::Core::JSON::VariantContainer&)> functionHandler);
/**
* @fn UnSubscribeEvent
* @note unSubscribe event data for the specific plugin
* @param eventName Event name
* @retval true on success
* @retval false on failure
*/
bool UnSubscribeEvent (string eventName);
private:
/**< The Remote object connected to specific Plugin*/
JSONRPC::LinkType<Core::JSON::IElement> *remoteObject;
/**< The Remote object connected to controller Plugin*/
JSONRPC::LinkType<Core::JSON::IElement> *controllerObject;
std::string pluginCallsign;
AampLogManager *mLogObj;
};
#endif // THUNDERACCESS_H_