4 * Created on: Mar 3, 2011
11 #include <plp/retval.h>
13 #include <plp/Data.hh>
14 #include <plp/Device.hh>
15 #include <plp/SensorDevice.hh>
16 #include <plp/DeviceConfig.hh>
18 #include "DeviceManagerServer.hh"
19 #include "../src/plp/devicebus/DeviceBusMessageId.hh"
21 using namespace plpdevicebus;
23 static void *device_data_reader_thread(void *thread_args_pointer) {
24 list<Device *> *_dev_lst;
25 list<Device *>::iterator list_iter;
31 read_int_sec = DeviceConfig::get_read_interval_seconds();
34 _dev_lst = (list<Device *> *)thread_args_pointer;
36 for (list_iter = _dev_lst->begin(); list_iter != _dev_lst->end(); list_iter++) {
37 device = (Device *)*list_iter;
38 sensor = dynamic_cast<SensorDevice *>(device);
40 data = sensor->get_data();
50 DeviceManagerServer::DeviceManagerServer(list<Device *> dev_lst_param) {
51 //DeviceConfig::set_base_dir_name(storage_dir_param);
52 //_dev_lst = Factory::get_device_list();
53 _dev_lst = dev_lst_param;
54 /* In some toolchains the size is not unsigned int instead of long
55 unsigned int, and that can cause warnings/errors without typecasting
57 log_info("device count: %lu\n", (long unsigned int)_dev_lst.size());
59 pthread_create(&_lstnr_thrd,
61 device_data_reader_thread,
65 DeviceManagerServer::~DeviceManagerServer() {
68 void DeviceManagerServer::get_device_list(const BusMessage *ret_val) {
70 list<Device *>::iterator list_iter;
78 ((BusMessage *)ret_val)->add_int_parameter(RSP__DEVICE_LIST__DEVICE_COUNT, _dev_lst.size());
79 for (list_iter = _dev_lst.begin(); list_iter != _dev_lst.end(); list_iter++) {
80 device = (Device *)*list_iter;
83 key << RSP__DEVICE_LIST__ID << indx;
84 ((BusMessage *)ret_val)->add_string_parameter(key.str(), device->get_id());
87 key << RSP__DEVICE_LIST__NAME << indx;
88 ((BusMessage *)ret_val)->add_string_parameter(key.str(), device->get_name());
91 key << RSP__DEVICE_LIST__TYPE << indx;
92 ((BusMessage *)ret_val)->add_string_parameter(key.str(), device->get_type());
95 key << RSP__DEVICE_LIST__LF_STATE << indx;
96 ((BusMessage *)ret_val)->add_int_parameter(key.str(), device->get_lifecycle_state());
97 sensor = dynamic_cast<SensorDevice *>(device);
100 key << RSP__DEVICE_LIST__DATA << indx;
101 data = sensor->get_data();
103 data_str = data->to_string();
104 log_debug("returning data: %s\n", data_str.c_str());
105 ((BusMessage *)ret_val)->add_string_parameter(key.str(), data_str);
114 const Device *DeviceManagerServer::get_device_by_id(string id_param) {
117 list<Device *>::iterator list_iter;
120 for(list_iter = _dev_lst.begin(); list_iter != _dev_lst.end(); list_iter++) {
121 device = (Device *)*list_iter;
122 if (device != NULL) {
123 if (device->get_id().compare(id_param) == 0) {
132 static void add_data_values_to_bus_message(const BusMessage *msg_rsp_param, Data *data, string key_name_base_param) {
138 cnt = data->get_value_count();
139 for (ii = 0; ii < cnt; ii++) {
141 key << key_name_base_param.c_str() << ii;
143 ((BusMessage *)msg_rsp_param)->add_double_parameter(key.str(), val);
147 void DeviceManagerServer::get_latest_data(BusMessage *msg_req_param, const BusMessage *ret_val) {
151 SensorDevice *sensor;
155 const DataReader *reader;
158 id = msg_req_param->get_string_parameter(REQ__GET_LATEST_DATA__ID, &err_flg);
159 if (err_flg == PLP_OK) {
160 dev = (Device *)get_device_by_id(id);
162 sensor = dynamic_cast<SensorDevice *>(dev);
163 if (sensor != NULL) {
164 reader = sensor->get_device_data();
165 data = ((DataReader *)reader)->get_latest_data();
167 cnt = data->get_value_count();
168 ((BusMessage *)ret_val)->add_int_parameter(RSP__GET_LATEST_DATA__VALUE_COUNT, cnt);
169 ((BusMessage *)ret_val)->add_string_parameter(RSP__GET_LATEST_DATA__DATE,
170 data->get_date().to_string());
171 add_data_values_to_bus_message(ret_val,
172 data, RSP__GET_LATEST_DATA__VALUE);
173 ((BusMessage *)ret_val)->printout();
174 dr = ((DataReader *)reader)->get_daily_summary(MIN);
176 if (dr->get_count() > 0) {
177 data = dr->get_first()->clone();;
178 add_data_values_to_bus_message(ret_val,
180 RSP__GET_LATEST_DATA__MIN_VALUE);
184 dr = ((DataReader *)reader)->get_daily_summary(MAX);
186 if (dr->get_count() > 0) {
187 data = dr->get_first()->clone();
188 add_data_values_to_bus_message(ret_val,
190 RSP__GET_LATEST_DATA__MAX_VALUE);