add: device relay get one
fix: stuff
This commit is contained in:
parent
ac61c26d56
commit
a399050892
7 changed files with 64 additions and 9 deletions
|
@ -1,5 +1,6 @@
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#include <models/relay_dbo.h>
|
#include <models/relay_dbo.h>
|
||||||
|
#include <helpers.h>
|
||||||
#include "api_v1_devices.h"
|
#include "api_v1_devices.h"
|
||||||
|
|
||||||
using namespace api::v1;
|
using namespace api::v1;
|
||||||
|
@ -9,8 +10,7 @@ devices::get_relays_all(const HttpRequestPtr &req, std::function<void(const Http
|
||||||
const std::string& device_id)
|
const std::string& device_id)
|
||||||
{
|
{
|
||||||
|
|
||||||
relay_dbo **all_device_relays = relay_dbo::get_by_simple("device_id", (void *) device_id.c_str(),
|
relay_dbo **all_device_relays = relay_dbo::get_by_simple("device_id", (void *) device_id.c_str(), (intptr_t) sqlite3_bind_text);
|
||||||
(intptr_t) sqlite3_bind_text);
|
|
||||||
Json::Value all_relays_json(Json::arrayValue);
|
Json::Value all_relays_json(Json::arrayValue);
|
||||||
|
|
||||||
for(int i = 0; all_device_relays[i] != nullptr; i++)
|
for(int i = 0; all_device_relays[i] != nullptr; i++)
|
||||||
|
@ -30,7 +30,25 @@ devices::get_relays_one_by_id_and_num(const HttpRequestPtr &req,
|
||||||
std::function<void(const HttpResponsePtr &)> &&callback, const std::string& device_id,
|
std::function<void(const HttpResponsePtr &)> &&callback, const std::string& device_id,
|
||||||
int relay_num)
|
int relay_num)
|
||||||
{
|
{
|
||||||
relay_dbo **relays = relay_dbo::get_by_simple("id", (void *) (intptr_t) relay_num, (intptr_t) &sqlite3_bind_int);
|
helpers::sql_filter_builder *filters[2];
|
||||||
|
helpers::sql_filter_builder filter
|
||||||
|
{
|
||||||
|
"number",
|
||||||
|
(void*)(intptr_t)relay_num,
|
||||||
|
(intptr_t)&sqlite3_bind_int,
|
||||||
|
"AND"
|
||||||
|
};
|
||||||
|
helpers::sql_filter_builder filter2
|
||||||
|
{
|
||||||
|
"device_id",
|
||||||
|
(void*)device_id.c_str(),
|
||||||
|
(intptr_t)sqlite3_bind_text,
|
||||||
|
";"
|
||||||
|
};
|
||||||
|
filters[0] = &filter;
|
||||||
|
filters[1] = &filter2;
|
||||||
|
|
||||||
|
auto relays = relay_dbo::get_by(filters);
|
||||||
|
|
||||||
if(relays[0])
|
if(relays[0])
|
||||||
{
|
{
|
||||||
|
|
|
@ -187,6 +187,14 @@ device_dbo::get_by_simple(const char *key, const void *value, intptr_t bind_func
|
||||||
return device_db_select(stmt);
|
return device_db_select(stmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
device_dbo**
|
||||||
|
device_dbo::get_by(helpers::sql_filter_builder **filters)
|
||||||
|
{
|
||||||
|
sqlite3_stmt *stmt = helpers::create_sql_filtered_query("SELECT * FROM devices WHERE", filters);
|
||||||
|
|
||||||
|
return device_db_select(stmt);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
device_dbo::free_list(device_dbo **devices_list)
|
device_dbo::free_list(device_dbo **devices_list)
|
||||||
{
|
{
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <sqlite3.h>
|
#include <sqlite3.h>
|
||||||
#include <json/value.h>
|
#include <json/value.h>
|
||||||
|
#include <helpers.h>
|
||||||
|
|
||||||
class device_dbo
|
class device_dbo
|
||||||
{
|
{
|
||||||
|
@ -34,6 +35,9 @@ public:
|
||||||
static device_dbo**
|
static device_dbo**
|
||||||
get_by_simple(const char *key, const void *value, intptr_t bind_func);
|
get_by_simple(const char *key, const void *value, intptr_t bind_func);
|
||||||
|
|
||||||
|
static device_dbo**
|
||||||
|
get_by(helpers::sql_filter_builder **filters);
|
||||||
|
|
||||||
static device_dbo**
|
static device_dbo**
|
||||||
get_all();
|
get_all();
|
||||||
};
|
};
|
||||||
|
|
|
@ -47,7 +47,7 @@ relay_db_select_mapper(sqlite3_stmt *stmt)
|
||||||
new_relay->id = sqlite3_column_int(stmt, i);
|
new_relay->id = sqlite3_column_int(stmt, i);
|
||||||
break;
|
break;
|
||||||
case 'n':
|
case 'n':
|
||||||
switch(name[0])
|
switch(name[1])
|
||||||
{
|
{
|
||||||
case 'a': // name
|
case 'a': // name
|
||||||
strncpy(new_relay->name, (const char*)sqlite3_column_text(stmt, i), 127);
|
strncpy(new_relay->name, (const char*)sqlite3_column_text(stmt, i), 127);
|
||||||
|
@ -93,9 +93,8 @@ relay_db_select(sqlite3_stmt *stmt)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LOG_ERROR << "Error Selecting relays from database";
|
LOG_ERROR << "Error Selecting relays from database: " << sqlite3_errstr(s);
|
||||||
sqlite3_finalize(stmt);
|
break;
|
||||||
return nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -145,8 +144,11 @@ Json::Value
|
||||||
relay_dbo::to_json()
|
relay_dbo::to_json()
|
||||||
{
|
{
|
||||||
Json::Value relay_json;
|
Json::Value relay_json;
|
||||||
|
// relay_json["id"] = this->id;
|
||||||
relay_json["name"] = this->name;
|
relay_json["name"] = this->name;
|
||||||
relay_json["id"] = this->id;
|
relay_json["number"] = this->number;
|
||||||
|
relay_json["active_schedule_id"] = this->active_schedule_id;
|
||||||
|
relay_json["device_id"] = this->device_id;
|
||||||
|
|
||||||
return relay_json;
|
return relay_json;
|
||||||
}
|
}
|
||||||
|
@ -178,6 +180,13 @@ relay_dbo::get_by_simple(const char *key, const void *value, intptr_t bind_func)
|
||||||
return relay_db_select(stmt);
|
return relay_db_select(stmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
relay_dbo**
|
||||||
|
relay_dbo::get_by(helpers::sql_filter_builder **filters)
|
||||||
|
{
|
||||||
|
sqlite3_stmt *stmt = helpers::create_sql_filtered_query("SELECT * FROM relays WHERE", filters);
|
||||||
|
return relay_db_select(stmt);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
relay_dbo::free_list(relay_dbo **relays_list)
|
relay_dbo::free_list(relay_dbo **relays_list)
|
||||||
{
|
{
|
||||||
|
@ -187,4 +196,3 @@ relay_dbo::free_list(relay_dbo **relays_list)
|
||||||
}
|
}
|
||||||
free(relays_list);
|
free(relays_list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <sqlite3.h>
|
#include <sqlite3.h>
|
||||||
#include <json/value.h>
|
#include <json/value.h>
|
||||||
|
#include <helpers.h>
|
||||||
|
|
||||||
class relay_dbo
|
class relay_dbo
|
||||||
{
|
{
|
||||||
|
@ -33,6 +34,9 @@ public:
|
||||||
static relay_dbo**
|
static relay_dbo**
|
||||||
get_by_simple(const char *key, const void *value, intptr_t bind_func);
|
get_by_simple(const char *key, const void *value, intptr_t bind_func);
|
||||||
|
|
||||||
|
static relay_dbo**
|
||||||
|
get_by(helpers::sql_filter_builder **filters);
|
||||||
|
|
||||||
static relay_dbo**
|
static relay_dbo**
|
||||||
get_all();
|
get_all();
|
||||||
};
|
};
|
||||||
|
|
|
@ -177,6 +177,15 @@ schedule_dbo::get_by_simple(const char *key, const void *value, intptr_t bind_fu
|
||||||
";"
|
";"
|
||||||
};
|
};
|
||||||
filters[0] = &filter;
|
filters[0] = &filter;
|
||||||
|
|
||||||
|
sqlite3_stmt *stmt = helpers::create_sql_filtered_query("SELECT * FROM schedules WHERE", filters);
|
||||||
|
|
||||||
|
return schedule_db_select(stmt);
|
||||||
|
}
|
||||||
|
|
||||||
|
schedule_dbo**
|
||||||
|
schedule_dbo::get_by(helpers::sql_filter_builder **filters)
|
||||||
|
{
|
||||||
sqlite3_stmt *stmt = helpers::create_sql_filtered_query("SELECT * FROM schedules WHERE", filters);
|
sqlite3_stmt *stmt = helpers::create_sql_filtered_query("SELECT * FROM schedules WHERE", filters);
|
||||||
|
|
||||||
return schedule_db_select(stmt);
|
return schedule_db_select(stmt);
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <sqlite3.h>
|
#include <sqlite3.h>
|
||||||
#include <json/value.h>
|
#include <json/value.h>
|
||||||
|
#include <helpers.h>
|
||||||
#include "period.h"
|
#include "period.h"
|
||||||
#include "period_list.h"
|
#include "period_list.h"
|
||||||
|
|
||||||
|
@ -35,6 +36,9 @@ public:
|
||||||
static schedule_dbo**
|
static schedule_dbo**
|
||||||
get_by_simple(const char *key, const void *value, intptr_t bind_func);
|
get_by_simple(const char *key, const void *value, intptr_t bind_func);
|
||||||
|
|
||||||
|
static schedule_dbo**
|
||||||
|
get_by(helpers::sql_filter_builder **filters);
|
||||||
|
|
||||||
static schedule_dbo**
|
static schedule_dbo**
|
||||||
get_all();
|
get_all();
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue