aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/libhomescreen.hpp5
-rw-r--r--src/libhomescreen.cpp49
2 files changed, 40 insertions, 14 deletions
diff --git a/include/libhomescreen.hpp b/include/libhomescreen.hpp
index e51e01c..417ccdc 100644
--- a/include/libhomescreen.hpp
+++ b/include/libhomescreen.hpp
@@ -58,6 +58,7 @@ public:
static const std::vector<std::string> event_list;
/* Method */
+ int init(const char *hostname, const int port, const char *token);
int init(const int port, const std::string& token);
int tapShortcut(const char* application_id);
@@ -86,6 +87,7 @@ public:
private:
int initialize_websocket();
+ int initialize_websocket(const char *hostname, const int port, const char *token);
void (*onEvent)(const std::string& event, struct json_object* event_contents);
void (*onReply)(struct json_object* reply);
@@ -96,9 +98,6 @@ private:
sd_event* mploop;
std::string muri;
- int mport = 2000;
- std::string mtoken = "hs";
-
std::map<EventType, handler_func> handlers;
public:
diff --git a/src/libhomescreen.cpp b/src/libhomescreen.cpp
index ad18ca4..dd5d363 100644
--- a/src/libhomescreen.cpp
+++ b/src/libhomescreen.cpp
@@ -123,8 +123,9 @@ LibHomeScreen::~LibHomeScreen()
* This function is initializer
*
* #### Parameters
- * - port [in] : This argument should be specified to the port number to be used for websocket
- * - token [in] : This argument should be specified to the token to be used for websocket
+ * - hostname [in] : This argument should be specified to the hostname to be used for websocket
+ * - port [in] : This argument should be specified to the port number to be used for websocket
+ * - token [in] : This argument should be specified to the token to be used for websocket
*
* #### Return
* Nothing
@@ -133,20 +134,16 @@ LibHomeScreen::~LibHomeScreen()
* Use this constructor
*
*/
-int LibHomeScreen::init(const int port, const string& token)
+int LibHomeScreen::init(const char *hostname, const int port, const char *token)
{
int ret = 0;
- if(port > 0 && token.size() > 0)
- {
- mport = port;
- mtoken = token;
- }
- else
+ if(port < 0 || token == nullptr || token[0] == 0)
{
HMI_ERROR("libhomescreen","port and token should be > 0, Initial port and token uses.");
}
- ret = initialize_websocket();
+ ret = initialize_websocket(hostname, port, token);
+
if(ret != 0 )
{
HMI_ERROR("libhomescreen","Failed to initialize websocket");
@@ -159,6 +156,25 @@ int LibHomeScreen::init(const int port, const string& token)
}
/**
+ * This function is initializer
+ *
+ * #### Parameters
+ * - port [in] : This argument should be specified to the port number to be used for websocket
+ * - token [in] : This argument should be specified to the token to be used for websocket
+ *
+ * #### Return
+ * Nothing
+ *
+ * #### Note
+ * Use this constructor
+ *
+ */
+int LibHomeScreen::init(const int port, const string& token)
+{
+ return init(nullptr, port, token.c_str());
+}
+
+/**
* This function register callback function for reply/event message from home screen
*
* #### Parameters
@@ -187,6 +203,7 @@ int LibHomeScreen::initialize_websocket()
mploop = NULL;
onEvent = nullptr;
onReply = nullptr;
+
int ret = sd_event_new(&mploop);
if(ret < 0)
{
@@ -204,7 +221,7 @@ int LibHomeScreen::initialize_websocket()
minterface.on_hangup = _on_hangup_static;
minterface.on_call = _on_call_static;
minterface.on_event = _on_event_static;
- muri += "ws://localhost:" + to_string(mport) + "/api?token=" + mtoken; /*To be modified*/
+
sp_websock = afb_ws_client_connect_wsj1(mploop, muri.c_str(), &minterface, this);
if(sp_websock == NULL)
{
@@ -220,6 +237,16 @@ END:
return -1;
}
+int LibHomeScreen::initialize_websocket(const char *hostname, const int port, const char *token)
+{
+ if (hostname == nullptr)
+ hostname = "localhost";
+ muri = std::string("ws://") + hostname + ":" + to_string(port) + "/api?token=" + token; /*To be modified*/
+
+ return initialize_websocket();
+}
+
+
/**
* Sending ShortCut Icon tapped event
*