|
@@ -245,7 +245,7 @@ public:
|
|
void delivery_complete(mqtt::delivery_token_ptr token) override
|
|
void delivery_complete(mqtt::delivery_token_ptr token) override
|
|
{
|
|
{
|
|
token=token;
|
|
token=token;
|
|
- std::cout << "Message delivered" << std::endl;
|
|
|
|
|
|
+ //std::cout << "Message delivered" << std::endl;
|
|
}
|
|
}
|
|
void message_arrived (mqtt::const_message_ptr msg) override
|
|
void message_arrived (mqtt::const_message_ptr msg) override
|
|
{
|
|
{
|
|
@@ -258,8 +258,8 @@ void* mqtt_control_thread(void*){
|
|
clientID = bel_mqtt_client_id,
|
|
clientID = bel_mqtt_client_id,
|
|
username = bel_mqtt_user_id,
|
|
username = bel_mqtt_user_id,
|
|
password = bel_mqtt_password;
|
|
password = bel_mqtt_password;
|
|
- const std::string TOPIC1("device/SE0001/sq");
|
|
|
|
- const std::string TOPIC2("device/SE0001/light");
|
|
|
|
|
|
+ const std::string TOPIC1("device/"+username+"/sq");
|
|
|
|
+ const std::string TOPIC2("device/"+username+"/light");
|
|
const int QOS = 1;
|
|
const int QOS = 1;
|
|
//const int TIMEOUT = 10000;
|
|
//const int TIMEOUT = 10000;
|
|
mqtt::async_client client(address, clientID,mqtt::create_options(MQTTVERSION_5));
|
|
mqtt::async_client client(address, clientID,mqtt::create_options(MQTTVERSION_5));
|
|
@@ -290,15 +290,21 @@ void* mqtt_control_thread(void*){
|
|
//printf("Size %i\n",mqtt_queue.size());
|
|
//printf("Size %i\n",mqtt_queue.size());
|
|
temp_mess=mqtt_queue.pop();
|
|
temp_mess=mqtt_queue.pop();
|
|
Json::Value event;
|
|
Json::Value event;
|
|
- if (temp_mess.bel_status==-1){
|
|
|
|
|
|
+ event["type"]=temp_mess.type;
|
|
|
|
+ if (temp_mess.type==1){
|
|
event["sq"]=temp_mess.sq;
|
|
event["sq"]=temp_mess.sq;
|
|
event["freq"]=temp_mess.freq;
|
|
event["freq"]=temp_mess.freq;
|
|
event["name"]=temp_mess.name;
|
|
event["name"]=temp_mess.name;
|
|
|
|
+
|
|
event["mountpoint"]=temp_mess.mountpoint;
|
|
event["mountpoint"]=temp_mess.mountpoint;
|
|
}
|
|
}
|
|
- if (temp_mess.bel_status!=-1){
|
|
|
|
|
|
+ if (temp_mess.type==2){
|
|
event["bel_status"]=temp_mess.bel_status;
|
|
event["bel_status"]=temp_mess.bel_status;
|
|
}
|
|
}
|
|
|
|
+ if (temp_mess.type==2){
|
|
|
|
+ event["type"]=temp_mess.type;
|
|
|
|
+ event["status"]="connect";
|
|
|
|
+ }
|
|
Json::StreamWriterBuilder builder;
|
|
Json::StreamWriterBuilder builder;
|
|
if (client.is_connected()){
|
|
if (client.is_connected()){
|
|
mqtt::message_ptr pubMessage = mqtt::make_message(TOPIC1,Json::writeString(builder, event), QOS, false);
|
|
mqtt::message_ptr pubMessage = mqtt::make_message(TOPIC1,Json::writeString(builder, event), QOS, false);
|
|
@@ -335,6 +341,7 @@ void* belysning_control_thread(void*){
|
|
mqtt_msg.audio = 0;
|
|
mqtt_msg.audio = 0;
|
|
mqtt_msg.mountpoint = str;
|
|
mqtt_msg.mountpoint = str;
|
|
mqtt_msg.bel_status = -1;
|
|
mqtt_msg.bel_status = -1;
|
|
|
|
+ mqtt_msg.type=2;
|
|
int status_data_temp=0;
|
|
int status_data_temp=0;
|
|
gettimeofday(&tv, 0);
|
|
gettimeofday(&tv, 0);
|
|
start_time=tv.tv_sec;
|
|
start_time=tv.tv_sec;
|
|
@@ -995,6 +1002,7 @@ void* demodulate(void* params) {
|
|
mqtt_msg.name = fparms->label;
|
|
mqtt_msg.name = fparms->label;
|
|
mqtt_msg.mountpoint = fparms->mountpoint;
|
|
mqtt_msg.mountpoint = fparms->mountpoint;
|
|
mqtt_msg.bel_status = -1;
|
|
mqtt_msg.bel_status = -1;
|
|
|
|
+ mqtt_msg.type=1;
|
|
mqtt_queue.push(mqtt_msg);
|
|
mqtt_queue.push(mqtt_msg);
|
|
}
|
|
}
|
|
channel->freqlist[channel->freq_idx].oldstatus = temp_status;
|
|
channel->freqlist[channel->freq_idx].oldstatus = temp_status;
|
|
@@ -1479,6 +1487,10 @@ int main(int argc, char* argv[]) {
|
|
THREAD mqtt_control_check;
|
|
THREAD mqtt_control_check;
|
|
pthread_create(&belysning_control_check, NULL, &belysning_control_thread, NULL);
|
|
pthread_create(&belysning_control_check, NULL, &belysning_control_thread, NULL);
|
|
pthread_create(&mqtt_control_check, NULL, &mqtt_control_thread, NULL);
|
|
pthread_create(&mqtt_control_check, NULL, &mqtt_control_thread, NULL);
|
|
|
|
+
|
|
|
|
+ mqtt_msg_t mqtt_msg;
|
|
|
|
+ mqtt_msg.type=3;
|
|
|
|
+ mqtt_queue.push(mqtt_msg);
|
|
THREAD output_check;
|
|
THREAD output_check;
|
|
pthread_create(&output_check, NULL, &output_check_thread, NULL);
|
|
pthread_create(&output_check, NULL, &output_check_thread, NULL);
|
|
|
|
|