123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- #include "guardcore.h"
- #include "../AGBoxDog/boxshm.h"
- #include "../agVideoProcess/boxdeviceshm.h"
- AGBoxShm *agBoxShm;
- BoxDeviceShm *boxDeviceShm;
- void GuardCore::shm_init(){
- QSqlQuery qry;
- QString sql = QString("select mqtt_ip,mqtt_port,user_name,pass_word from yt_t_mqtt where item_name = 'data-agbox'");
- qry = db.exec(sql);
- while (qry.next()) {
- ip = qry.value(0).toString();
- port = qry.value(1).toString();
- username = qry.value(2).toString();
- password = qry.value(3).toString();
- }
- qry.clear();
- sql.clear();
- }
- bool GuardCore::shm_load(){
- key_t key;
- int shmid;
- if((key=ftok(SHM_PATH,static_cast<int>(SHM_PORT)))==-1){
- return false;
- }
- if((shmid=shmget(key,sizeof(AGBoxShm),IPC_CREAT|0666))==-1){
- return false;
- }
- agBoxShm = static_cast<AGBoxShm *>(shmat(shmid,nullptr,0));
- if((key=ftok(VIDEO_PATH,static_cast<int>(VIDEO_PORT)))==-1){
- return false;
- }
- if((shmid=shmget(key,sizeof(BoxDeviceShm),IPC_CREAT|0666))==-1){
- return false;
- }
- boxDeviceShm = static_cast<BoxDeviceShm *>(shmat(shmid,nullptr,0));
- shm_init();
- return true;
- }
- GuardCore::GuardCore(QObject *parent) : QObject(parent)
- {
- logthread = new LogThread(this);
- logthread->start();
- db = QSqlDatabase::addDatabase("QSQLITE","conf_db");
- db.setDatabaseName(QString("/opt/db/yt_conf.db"));
- if(!db.open()){
- logthread->appendData(QString("[agguard] open yt_conf.db failed"));
- }
- if(shm_load()){
- logthread->appendData(QString("[agguard] shm load success"));
- }
- mqttIdx = 1;
- m_client = new QMQTT::Client(QHostAddress(ip),static_cast<quint16>(port.toInt()),this);
- connect(m_client,&QMQTT::Client::connected,this,&GuardCore::onConnected);
- m_client->setUsername(username);
- m_client->setPassword(password.toLatin1());
- m_client->setCleanSession(true);
- m_client->connectToHost();
- dbthread = new DatabaseThread(this);
- dbthread->start();
- httpthread = new HttpThread(this);
- connect(httpthread,&HttpThread::dataLog,this,&GuardCore::dataLog);
- connect(httpthread,&HttpThread::mqttData,this,&GuardCore::mqtt_data);
- connect(httpthread,&HttpThread::appendSql,this,&GuardCore::append_sql);
- tcpserver = new TcpServer(this);
- connect(tcpserver,&TcpServer::tcp_log,this,&GuardCore::dataLog);
- }
- GuardCore::~GuardCore()
- {
- logthread->stop();
- dbthread->stop();
- httpthread->stop();
- }
- void GuardCore::start()
- {
- tcpserver->start();
- }
- void GuardCore::onConnected()
- {
- logthread->appendData(QString("mqtt onConnected"));
- }
- void GuardCore::dataLog(QString log)
- {
- logthread->appendData(log);
- }
- void GuardCore::mqtt_data(QString mqtt_msg)
- {
- printf("test2222 [%s]\n",mqtt_msg.toUtf8().data());
- if((m_client->connectionState()==QMQTT::STATE_INIT)||(m_client->connectionState()==QMQTT::STATE_DISCONNECTED)){
- m_client->connectToHost();
- }
- m_client->publish(QMQTT::Message(mqttIdx++,"data-collector",mqtt_msg.toUtf8()));
- if(mqttIdx > 9999){
- mqttIdx = 1;
- }
- }
- void GuardCore::append_sql(QString sql)
- {
- dbthread->appendSql(sql);
- }
|