add: weekly schedule support
This commit is contained in:
parent
b3f75f4004
commit
44a83cd2c5
11 changed files with 220 additions and 79 deletions
controllers
|
@ -93,7 +93,7 @@ controllers::put_relays_one_by_id_and_num(const HttpRequestPtr &req,
|
|||
|
||||
Json::Value body = *req->getJsonObject();
|
||||
uuid_t active_schedule_id;
|
||||
if(schedule_dbo::parse_uid(body["active_schedule"].asCString(), active_schedule_id))
|
||||
if(schedule_dbo::parse_uid(body["active_schedule"]["id"].asCString(), active_schedule_id))
|
||||
{
|
||||
LOG_DEBUG << "bad active_schedule uuid";
|
||||
auto resp = HttpResponse::newHttpResponse();
|
||||
|
@ -102,18 +102,48 @@ controllers::put_relays_one_by_id_and_num(const HttpRequestPtr &req,
|
|||
return;
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
||||
}
|
||||
|
||||
relay_dbo *relay = relay_dbo::get_relay_for_controller(controller_id, relay_num);
|
||||
schedule_dbo **schedule = schedule_dbo::get_by_simple("uid", active_schedule_id, (intptr_t)&sqlite3_bind_blob, sizeof(uuid_t));
|
||||
|
||||
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);
|
||||
}
|
||||
|
||||
bool db_action_result;
|
||||
|
||||
if(relay)
|
||||
{
|
||||
strncpy(relay->name, body["name"].asCString(), 127);
|
||||
relay->active_schedule_id = schedule[0]->id;
|
||||
uuid_copy(relay->controller_id, controller_id);
|
||||
|
||||
relay->reload_active_schedule();
|
||||
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;
|
||||
|
||||
db_action_result = relay->update();
|
||||
}
|
||||
|
@ -123,10 +153,15 @@ controllers::put_relays_one_by_id_and_num(const HttpRequestPtr &req,
|
|||
relay->number = relay_num;
|
||||
strncpy(relay->name, body["name"].asCString(), 127);
|
||||
|
||||
relay->active_schedule_id = schedule[0]->id;
|
||||
uuid_copy(relay->controller_id, controller_id);
|
||||
for(int i = 0; i < 7; ++i)
|
||||
{
|
||||
relay->schedules[i] = schedules[i];
|
||||
}
|
||||
|
||||
relay->reload_active_schedule();
|
||||
relay->schedules[helpers::get_day_of_week()] = active_schedule;
|
||||
relay->active_schedule = active_schedule;
|
||||
|
||||
uuid_copy(relay->controller_id, controller_id);
|
||||
|
||||
db_action_result = relay->insert();
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue