2019-07-20 21:33:17 +00:00
|
|
|
#include <netdb.h>
|
|
|
|
#include <models/relay_dbo.h>
|
2019-07-20 22:29:05 +00:00
|
|
|
#include <helpers.h>
|
2020-04-23 23:33:34 +00:00
|
|
|
#include <mpack.h>
|
2019-07-22 20:06:13 +00:00
|
|
|
#include <models/controller_dbo.h>
|
2019-07-29 20:02:38 +00:00
|
|
|
#include <models/schedule_dbo.h>
|
|
|
|
#include <config.h>
|
2020-04-18 19:29:52 +00:00
|
|
|
#include <enums.h>
|
2019-07-22 20:06:13 +00:00
|
|
|
#include "api_v1_controllers.h"
|
2019-07-20 21:33:17 +00:00
|
|
|
|
|
|
|
using namespace api::v1;
|
|
|
|
|
|
|
|
void
|
2019-07-22 20:06:13 +00:00
|
|
|
controllers::get_relays_all(const HttpRequestPtr &req, std::function<void(const HttpResponsePtr &)> &&callback,
|
2020-02-23 19:06:14 +00:00
|
|
|
const std::string& controller_id_str)
|
2019-07-20 21:33:17 +00:00
|
|
|
{
|
2020-02-23 19:06:14 +00:00
|
|
|
uuid_t controller_id;
|
|
|
|
if(uuid_parse(controller_id_str.c_str(), controller_id))
|
|
|
|
{
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k400BadRequest);
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
relay_dbo **all_controller_relays = relay_dbo::get_by_simple("controller_id", (void *) controller_id, (intptr_t) sqlite3_bind_blob, sizeof(uuid_t));
|
2019-07-20 21:33:17 +00:00
|
|
|
Json::Value all_relays_json(Json::arrayValue);
|
|
|
|
|
2019-07-22 20:06:13 +00:00
|
|
|
for(int i = 0; all_controller_relays[i] != nullptr; i++)
|
2019-07-20 21:33:17 +00:00
|
|
|
{
|
2019-07-22 20:06:13 +00:00
|
|
|
all_relays_json.append(all_controller_relays[i]->to_json());
|
2019-07-20 21:33:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
auto resp = HttpResponse::newHttpJsonResponse(all_relays_json);
|
|
|
|
|
|
|
|
callback(resp);
|
|
|
|
|
2019-07-22 20:06:13 +00:00
|
|
|
relay_dbo::free_list(all_controller_relays);
|
2019-07-20 21:33:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2019-07-22 20:06:13 +00:00
|
|
|
controllers::get_relays_one_by_id_and_num(const HttpRequestPtr &req,
|
2020-02-23 19:06:14 +00:00
|
|
|
std::function<void(const HttpResponsePtr &)> &&callback, const std::string& controller_id_str,
|
2019-07-20 21:33:17 +00:00
|
|
|
int relay_num)
|
|
|
|
{
|
2020-02-23 19:06:14 +00:00
|
|
|
uuid_t controller_id;
|
|
|
|
if(uuid_parse(controller_id_str.c_str(), controller_id))
|
|
|
|
{
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k400BadRequest);
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
relay_dbo *relay = relay_dbo::get_relay_for_controller(controller_id, relay_num);
|
2019-07-21 22:00:07 +00:00
|
|
|
|
|
|
|
if(relay)
|
2019-07-20 21:33:17 +00:00
|
|
|
{
|
2019-07-21 22:00:07 +00:00
|
|
|
auto resp = HttpResponse::newHttpJsonResponse(relay->to_json());
|
2019-07-20 21:33:17 +00:00
|
|
|
|
|
|
|
callback(resp);
|
2019-07-21 22:00:07 +00:00
|
|
|
|
|
|
|
delete relay;
|
2019-07-20 21:33:17 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k404NotFound);
|
|
|
|
|
|
|
|
callback(resp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2019-07-22 20:06:13 +00:00
|
|
|
controllers::put_relays_one_by_id_and_num(const HttpRequestPtr &req,
|
2020-02-23 19:06:14 +00:00
|
|
|
std::function<void(const HttpResponsePtr &)> &&callback, const std::string& controller_id_str,
|
2019-07-20 21:33:17 +00:00
|
|
|
int relay_num)
|
|
|
|
{
|
2020-02-23 19:06:14 +00:00
|
|
|
uuid_t controller_id;
|
|
|
|
if(uuid_parse(controller_id_str.c_str(), controller_id))
|
|
|
|
{
|
2020-04-18 19:29:52 +00:00
|
|
|
LOG_DEBUG << "bad uuid";
|
2020-02-23 19:06:14 +00:00
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k400BadRequest);
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if(!relay_dbo::valid_num_for_controller(controller_id, relay_num))
|
2019-07-21 22:00:07 +00:00
|
|
|
{
|
2020-04-18 19:29:52 +00:00
|
|
|
LOG_DEBUG << "invalid num for controller";
|
2019-07-21 22:00:07 +00:00
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k400BadRequest);
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Json::Value body = *req->getJsonObject();
|
2020-02-23 19:06:14 +00:00
|
|
|
uuid_t active_schedule_id;
|
2020-04-23 15:00:12 +00:00
|
|
|
if(schedule_dbo::parse_uid(body["active_schedule"]["id"].asCString(), active_schedule_id))
|
2020-02-23 19:06:14 +00:00
|
|
|
{
|
2020-04-18 19:29:52 +00:00
|
|
|
LOG_DEBUG << "bad active_schedule uuid";
|
2020-02-23 19:06:14 +00:00
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k400BadRequest);
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-04-23 15:00:12 +00:00
|
|
|
uuid_t schedules_ids[7];
|
|
|
|
for(int i = 0; i < 7; ++i)
|
|
|
|
{
|
|
|
|
if(schedule_dbo::parse_uid(body["schedules"][i]["id"].asCString(), schedules_ids[i]))
|
|
|
|
{
|
|
|
|
LOG_DEBUG << "parse_uid failed for schedule " << i;
|
|
|
|
auto res = drogon::HttpResponse::newHttpResponse();
|
|
|
|
res->setStatusCode(k400BadRequest);
|
|
|
|
callback(res);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-23 19:06:14 +00:00
|
|
|
relay_dbo *relay = relay_dbo::get_relay_for_controller(controller_id, relay_num);
|
2020-04-23 15:00:12 +00:00
|
|
|
|
|
|
|
schedule_dbo **schedule_list = schedule_dbo::get_by_simple("uid", active_schedule_id, (intptr_t)&sqlite3_bind_blob, sizeof(uuid_t));
|
|
|
|
schedule_dbo *active_schedule = schedule_list[0];
|
|
|
|
|
|
|
|
free(schedule_list);
|
|
|
|
|
|
|
|
schedule_dbo *schedules[7];
|
|
|
|
for(int i = 0; i < 7; ++i)
|
|
|
|
{
|
|
|
|
schedule_list = schedule_dbo::get_by_simple("uid", schedules_ids[i], (intptr_t)&sqlite3_bind_blob, sizeof(uuid_t));
|
|
|
|
schedules[i] = schedule_list[0];
|
|
|
|
free(schedule_list);
|
|
|
|
}
|
2019-07-21 22:00:07 +00:00
|
|
|
|
|
|
|
bool db_action_result;
|
|
|
|
|
|
|
|
if(relay)
|
|
|
|
{
|
2019-07-30 11:22:19 +00:00
|
|
|
strncpy(relay->name, body["name"].asCString(), 127);
|
2020-04-19 00:44:35 +00:00
|
|
|
uuid_copy(relay->controller_id, controller_id);
|
|
|
|
|
2020-04-23 15:00:12 +00:00
|
|
|
for(int i = 0; i < 7; ++i)
|
|
|
|
{
|
|
|
|
relay->schedules[i] = schedules[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
relay->schedules[helpers::get_day_of_week()] = active_schedule;
|
|
|
|
relay->active_schedule = active_schedule;
|
2019-07-21 22:00:07 +00:00
|
|
|
|
|
|
|
db_action_result = relay->update();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
relay = new relay_dbo();
|
|
|
|
relay->number = relay_num;
|
2019-07-30 11:22:19 +00:00
|
|
|
strncpy(relay->name, body["name"].asCString(), 127);
|
2020-02-23 19:06:14 +00:00
|
|
|
|
2020-04-23 15:00:12 +00:00
|
|
|
for(int i = 0; i < 7; ++i)
|
|
|
|
{
|
|
|
|
relay->schedules[i] = schedules[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
relay->schedules[helpers::get_day_of_week()] = active_schedule;
|
|
|
|
relay->active_schedule = active_schedule;
|
2019-07-21 22:00:07 +00:00
|
|
|
|
2020-04-23 15:00:12 +00:00
|
|
|
uuid_copy(relay->controller_id, controller_id);
|
2019-09-08 17:34:37 +00:00
|
|
|
|
2019-07-21 22:00:07 +00:00
|
|
|
db_action_result = relay->insert();
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!db_action_result)
|
|
|
|
{
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k500InternalServerError);
|
|
|
|
callback(resp);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-04-19 00:44:35 +00:00
|
|
|
auto schedules = schedule_dbo::get_by_simple("uid", active_schedule_id, (intptr_t)&sqlite3_bind_blob, sizeof(uuid_t));
|
2020-02-23 19:06:14 +00:00
|
|
|
auto controllers = controller_dbo::get_by_simple("id", controller_id, (intptr_t)&sqlite3_bind_blob, sizeof(uuid_t));
|
2019-07-29 20:02:38 +00:00
|
|
|
|
2020-04-18 19:29:52 +00:00
|
|
|
uint16_t *periods = schedules[0]->periods->to_blob();
|
|
|
|
uint16_t periods_count = periods[0];
|
2019-07-29 20:02:38 +00:00
|
|
|
|
2020-04-23 23:33:34 +00:00
|
|
|
char* data;
|
|
|
|
size_t size;
|
|
|
|
mpack_writer_t writer;
|
|
|
|
mpack_writer_init_growable(&writer, &data, &size);
|
|
|
|
|
|
|
|
mpack_start_map(&writer, 5);
|
|
|
|
mpack_write_uint(&writer, COMMAND_MAPPING_CODE);
|
|
|
|
mpack_write_u8(&writer, config::command_code_set_schedule);
|
|
|
|
mpack_write_uint(&writer, COMMAND_MAPPING_RELAY_NUM);
|
|
|
|
mpack_write_u8(&writer, relay_num);
|
|
|
|
mpack_write_uint(&writer, COMMAND_MAPPING_PERIODS_COUNT);
|
|
|
|
mpack_write_u16(&writer, periods_count);
|
|
|
|
mpack_write_uint(&writer, COMMAND_MAPPING_SCHEDULE_ID);
|
|
|
|
mpack_write_bin(&writer, (char*)schedules[0]->uid, sizeof(uuid_t));
|
|
|
|
mpack_write_uint(&writer, COMMAND_MAPPING_PERIODS_BLOB);
|
2020-04-18 19:29:52 +00:00
|
|
|
// periods + 1 to skip length in periods[0]
|
|
|
|
// periods_count * 2 because each uint16_t is a timestamp. 2 are start and end
|
2020-04-23 23:33:34 +00:00
|
|
|
mpack_write_bin(&writer, (char*)(periods + 1), sizeof(uint16_t) * periods_count * 2);
|
|
|
|
mpack_finish_map(&writer);
|
|
|
|
|
|
|
|
// finish writing
|
|
|
|
if (mpack_writer_destroy(&writer) != mpack_ok) {
|
|
|
|
LOG_ERROR << "an error occurred encoding the data";
|
|
|
|
auto resp = HttpResponse::newHttpResponse();
|
|
|
|
resp->setStatusCode(k500InternalServerError);
|
|
|
|
callback(resp);
|
|
|
|
return;
|
|
|
|
}
|
2020-04-18 19:29:52 +00:00
|
|
|
|
2020-04-23 23:33:34 +00:00
|
|
|
controllers[0]->command(config::command_code_set_name, data, size);
|
2020-04-18 19:29:52 +00:00
|
|
|
|
|
|
|
free(periods);
|
2019-07-29 20:02:38 +00:00
|
|
|
|
2019-07-21 22:00:07 +00:00
|
|
|
auto resp = HttpResponse::newHttpJsonResponse(relay->to_json());
|
|
|
|
callback(resp);
|
2019-07-29 20:02:38 +00:00
|
|
|
|
|
|
|
schedule_dbo::free_list(schedules);
|
|
|
|
controller_dbo::free_list(controllers);
|
2019-07-21 22:00:07 +00:00
|
|
|
}
|
2019-07-20 21:33:17 +00:00
|
|
|
|
2019-07-21 22:00:07 +00:00
|
|
|
delete relay;
|
2020-02-23 19:06:14 +00:00
|
|
|
}
|