2025-08-20 19:00:22 +08:00
|
|
|
|
#include "Station.h"
|
2025-08-26 18:36:25 +08:00
|
|
|
|
#include "database/DAO.h"
|
|
|
|
|
|
#include "database/SQL.h"
|
2025-08-28 18:42:37 +08:00
|
|
|
|
#include "common/fields.h"
|
|
|
|
|
|
#include "app/Device.h"
|
2025-09-01 20:08:40 +08:00
|
|
|
|
#include "common/Spdlogger.h"
|
2025-09-04 19:31:04 +08:00
|
|
|
|
#include "common/Utils.h"
|
|
|
|
|
|
#include "protocol/MqttEntity.h"
|
2025-09-09 19:26:05 +08:00
|
|
|
|
#include "common/JsonN.h"
|
2025-08-28 18:42:37 +08:00
|
|
|
|
|
2025-09-09 19:26:05 +08:00
|
|
|
|
Station::Station() : stationId(0)
|
2025-08-20 19:00:22 +08:00
|
|
|
|
{
|
2025-09-04 19:31:04 +08:00
|
|
|
|
mqttCli = std::make_shared<MqttClient>();
|
|
|
|
|
|
|
|
|
|
|
|
// 测试,设置默认值
|
|
|
|
|
|
for (int i = 1; i<=5; i++) { mapTempHumUnit[i] = TempHumUnit(Utils::random(20, 40), Utils::random(20, 80)); }
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 1; i<=5; i++) { mapFire40Unit[i] = 0; }
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 1; i<=5; i++) {
|
|
|
|
|
|
auto& unit = mapCoolingUnit[i];
|
|
|
|
|
|
unit.powerOn = 1;
|
|
|
|
|
|
unit.mode = i%2;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 1; i<=5; i++) {
|
|
|
|
|
|
auto& unit = mapAircUnit[i];
|
|
|
|
|
|
unit.powerOn = 1;
|
|
|
|
|
|
unit.temp = Utils::random(20, 40);
|
|
|
|
|
|
unit.hum = Utils::random(20, 80);
|
|
|
|
|
|
}
|
2025-08-20 19:00:22 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-08-28 18:42:37 +08:00
|
|
|
|
void Station::setFields(Fields& fields)
|
|
|
|
|
|
{
|
2025-09-09 19:26:05 +08:00
|
|
|
|
this->stationId = fields.get<int>(DMStation::STATION_ID);
|
2025-08-28 18:42:37 +08:00
|
|
|
|
this->name = fields.value(DMStation::NAME);
|
|
|
|
|
|
this->energyCapacity = fields.get<double>(DMStation::CAPACITY);
|
2025-09-04 19:31:04 +08:00
|
|
|
|
this->workModeId = fields.get<int>(DMStation::WORK_MODE);
|
|
|
|
|
|
this->code = fields.value(DMStation::CODE);
|
2025-09-10 20:10:51 +08:00
|
|
|
|
this->status = fields.get<int>(DMStation::STATUS);
|
2025-08-28 18:42:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-08-20 19:00:22 +08:00
|
|
|
|
void Station::addDevice(int deviceId, std::shared_ptr<Device> device)
|
|
|
|
|
|
{
|
2025-08-28 18:42:37 +08:00
|
|
|
|
mapDevice[deviceId] = device;
|
2025-09-06 15:23:07 +08:00
|
|
|
|
mapDeviceGroup[device->category].push_back(device);
|
2025-08-20 19:00:22 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::shared_ptr<Device> Station::getDevice(int deviceId)
|
|
|
|
|
|
{
|
2025-08-28 18:42:37 +08:00
|
|
|
|
auto iter = mapDevice.find(deviceId);
|
|
|
|
|
|
if (iter!=mapDevice.end())
|
2025-08-20 19:00:22 +08:00
|
|
|
|
{
|
|
|
|
|
|
return iter->second;
|
|
|
|
|
|
}
|
|
|
|
|
|
return nullptr;
|
2025-08-26 18:36:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-09-08 19:34:12 +08:00
|
|
|
|
std::shared_ptr<Device> Station::getDeviceByType(int deviceType, std::string code)
|
2025-08-28 18:42:37 +08:00
|
|
|
|
{
|
|
|
|
|
|
for (auto iter = mapDevice.begin(); iter!=mapDevice.end(); ++iter)
|
|
|
|
|
|
{
|
|
|
|
|
|
auto device = iter->second;
|
2025-09-08 19:34:12 +08:00
|
|
|
|
if (device->type == deviceType && device->code == code)
|
|
|
|
|
|
{
|
|
|
|
|
|
return device;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return nullptr;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Station::getDeviceByType(int deviceType, std::vector<std::shared_ptr<Device>>& res)
|
|
|
|
|
|
{
|
|
|
|
|
|
for (auto iter = mapDevice.begin(); iter!=mapDevice.end(); ++iter)
|
|
|
|
|
|
{
|
|
|
|
|
|
auto device = iter->second;
|
|
|
|
|
|
if (device->type == deviceType)
|
2025-08-28 18:42:37 +08:00
|
|
|
|
{
|
|
|
|
|
|
res.push_back(device);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-09-06 15:23:07 +08:00
|
|
|
|
int Station::getDeviceNumByGroup(int category)
|
2025-08-28 18:42:37 +08:00
|
|
|
|
{
|
2025-09-06 15:23:07 +08:00
|
|
|
|
return 0;
|
2025-08-28 18:42:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-09-06 15:23:07 +08:00
|
|
|
|
void Station::getDeviceByGroup(int category, std::vector<std::shared_ptr<Device>>& res)
|
2025-08-28 18:42:37 +08:00
|
|
|
|
{
|
2025-09-06 15:23:07 +08:00
|
|
|
|
auto iter = mapDeviceGroup.find(category);
|
|
|
|
|
|
if (iter != mapDeviceGroup.end())
|
2025-08-28 18:42:37 +08:00
|
|
|
|
{
|
2025-09-06 15:23:07 +08:00
|
|
|
|
res = iter->second;
|
2025-08-28 18:42:37 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-08-26 18:36:25 +08:00
|
|
|
|
void Station::setWorkMode(int modeId)
|
|
|
|
|
|
{
|
2025-08-28 18:42:37 +08:00
|
|
|
|
this->workModeId = modeId;
|
2025-08-26 18:36:25 +08:00
|
|
|
|
std::string sql = SQL(SQL::TYPE::update).table(DMStation::TABLENAME)
|
2025-09-04 19:31:04 +08:00
|
|
|
|
.update(DMStation::WORK_MODE, std::to_string(modeId))
|
2025-09-09 19:26:05 +08:00
|
|
|
|
.where(DMStation::STATION_ID + "=" + std::to_string(stationId)).str();
|
2025-08-26 18:36:25 +08:00
|
|
|
|
Errcode err = DAO::exec(NULL, sql);
|
|
|
|
|
|
if (err != Errcode::OK)
|
|
|
|
|
|
{
|
2025-09-01 20:08:40 +08:00
|
|
|
|
spdlog::error("set station work mode failed.");
|
2025-08-26 18:36:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Station::setPolicy(int policyId)
|
|
|
|
|
|
{
|
|
|
|
|
|
std::string sql = SQL(SQL::TYPE::update).table(DMStation::TABLENAME)
|
|
|
|
|
|
.update(DMStation::POLICY_ID, std::to_string(policyId))
|
2025-09-09 19:26:05 +08:00
|
|
|
|
.where(DMStation::STATION_ID + "=" + std::to_string(stationId)).str();
|
2025-08-26 18:36:25 +08:00
|
|
|
|
Errcode err = DAO::exec(NULL, sql);
|
|
|
|
|
|
if (err != Errcode::OK)
|
|
|
|
|
|
{
|
2025-09-01 20:08:40 +08:00
|
|
|
|
spdlog::error("set station policy failed.");
|
2025-08-26 18:36:25 +08:00
|
|
|
|
}
|
2025-08-28 18:42:37 +08:00
|
|
|
|
}
|
2025-09-09 19:26:05 +08:00
|
|
|
|
|
|
|
|
|
|
static std::string MapValueToJson(int npos, std::map<int, double>& mapV)
|
|
|
|
|
|
{
|
|
|
|
|
|
njson jsonarray = njson::array();
|
|
|
|
|
|
for (int i = 0; i<=npos; i++)
|
|
|
|
|
|
{
|
|
|
|
|
|
jsonarray.push_back(mapV[i]);
|
|
|
|
|
|
}
|
|
|
|
|
|
return jsonarray.dump();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Station::writeRuntimeData(std::string dt, int npos)
|
|
|
|
|
|
{
|
|
|
|
|
|
auto dao = DaoEntity::create("history_day");
|
|
|
|
|
|
for (auto iter = mapDevice.begin(); iter!=mapDevice.end(); ++iter)
|
|
|
|
|
|
{
|
|
|
|
|
|
auto device = iter->second;
|
|
|
|
|
|
if (device->cache(npos))
|
|
|
|
|
|
{
|
|
|
|
|
|
Fields fields;
|
|
|
|
|
|
fields.set("dt", dt);
|
|
|
|
|
|
fields.set("station_id", this->stationId);
|
|
|
|
|
|
fields.set("device_id", device->deviceId);
|
|
|
|
|
|
fields.set("datatype", 1);
|
|
|
|
|
|
fields.set("value", MapValueToJson(npos, device->mapCacheVoltage));
|
|
|
|
|
|
DAO::insertRuntimeData(dao, fields);
|
|
|
|
|
|
|
|
|
|
|
|
fields.set("datatype", 2);
|
|
|
|
|
|
fields.set("value", MapValueToJson(npos, device->mapCacheCurrent));
|
|
|
|
|
|
DAO::insertRuntimeData(dao, fields);
|
|
|
|
|
|
|
|
|
|
|
|
fields.set("datatype", 3);
|
|
|
|
|
|
fields.set("value", MapValueToJson(npos, device->mapCachePower));
|
|
|
|
|
|
DAO::insertRuntimeData(dao, fields);
|
|
|
|
|
|
|
|
|
|
|
|
spdlog::info("[device] write runtime date to database, deviceId={}", device->deviceId);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|