]> pilppa.org Git - libplp.git/blobdiff - src/DeviceConfig.hh
api fixes and cleanups
[libplp.git] / src / DeviceConfig.hh
index bc8241603753689f5022b3f72c2bbe693425e87f..52f2db87397452bc4b60f32819323034dcd8a703 100644 (file)
@@ -9,19 +9,13 @@
 #define DEVICECONFIG_HH_
 
 #include <string>
+#include "DataSummary.hh"
 
 extern "C" {
        #include <uci.h>
-       #include "config.h"
        #include <stdbool.h>
 }
 
-enum EnumSummaryPeriod{PERIOD_YEARLY, PERIOD_MONTHLY, PERIOD_DAILY, PERIOD_HOURLY, PERIOD_MINUTELY, PERIOD_SECONDLY};
-enum EnumSummaryCalculationType {SUM, DELTA, MIN, MAX, MEAN};
-
-const std::string SUMMARY_PERIOD_NAMES_ARRAY[]         = {"yearly", "monthly", "daily", "minutely", "secondly"};
-const std::string CALCULATION_TYPE_NAMES_ARRAY[]       = {"sum", "delta", "min", "max", "mean"};
-
 #define DEVICE_CONFIG__FILE_NAME       "device_cfg"
 #define DEVICE_CONFIG__SECTION_TYPE    "device"
 #define DEVICE_CONFIG__SECTION_NAME    "base_data"
@@ -36,10 +30,15 @@ const std::string CALCULATION_TYPE_NAMES_ARRAY[]    = {"sum", "delta", "min", "max"
 namespace plp {
        struct ConfigHandle {
                public:
-                       ConfigHandle(uci_context *ctx_param, uci_package *pkg_param);
+                       ConfigHandle(uci_context *ctx_param,
+                               uci_package *pkg_param,
+                               const char *short_fname_param,
+                               const char *full_fname_param);
                        ~ConfigHandle();
                        struct uci_context      *_ctx;
                        struct uci_package      *_pkg;
+                       char                    *short_fname;
+                       char                    *full_fname;
        };
 
        class DeviceConfig {
@@ -48,20 +47,25 @@ namespace plp {
                        virtual ~DeviceConfig();
                        static std::string get_base_dir_name();
                        static void set_base_dir_name(std::string store_param);
+                       static long get_read_interval_seconds();
+                       static void set_read_interval_seconds(long seconds_param);
                        static DeviceConfig *get_device_config(std::string device_id);
-                       std::string get_config_value(std::string key);
-                       void set_config_value(std::string key,
+                       bool get_config_value(std::string key, std::string& value);
+                       bool set_config_value(std::string key,
                                        std::string value,
                                        bool save_immediately);
+                       std::string get_config_path_name();
+                       std::string get_config_file_name();
+                       std::string get_pathless_config_file_name();
                        EnumSummaryCalculationType get_summary_calculation_type();
                private:
                        static std::string      store_base_dir;
+                       static long             read_interval_seconds;
                        std::string             device_id;
                        std::string             device_type;
                        ConfigHandle            *uci_handle;
                        ConfigHandle *load_device_config(std::string device_id_param);
-                       std::string get_dir_name(std::string device_id);
-                       std::string get_file_name(std::string device_id_param);
+
        };
 }