softwarecontainer  0.18.0-739e8d7 2017-05-04
cgroupsparser.h
1 /*
2  * Copyright (C) 2016-2017 Pelagicore AB
3  *
4  * Permission to use, copy, modify, and/or distribute this software for
5  * any purpose with or without fee is hereby granted, provided that the
6  * above copyright notice and this permission notice appear in all copies.
7  *
8  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
9  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
10  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR
11  * BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES
12  * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
13  * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
14  * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
15  * SOFTWARE.
16  *
17  * For further information see LICENSE
18  */
19 
20 #pragma once
21 
22 #include <jansson.h>
23 
24 #include "softwarecontainer-common.h"
25 
26 namespace softwarecontainer {
27 
29 {
30  LOG_DECLARE_CLASS_CONTEXT("CGPA", "CGroups Gateway Parser");
31 
32 public:
33  CGroupsParser();
34  /*
35  * @brief Parse given configuration element to the settings
36  *
37  * @param element : represents configuration element
38  */
39  void parseCGroupsGatewayConfiguration(const json_t *element);
40 
41  /*
42  * @brief Get the map of cgroup settings
43  *
44  * @return A list of cgroup settings ready to be applied
45  */
46  const std::map<std::string, std::string> &getSettings();
47 private :
48  std::map<std::string, std::string> m_settings;
49 
50  /*
51  * @brief Regulate the setting value due to its multiplier
52  *
53  * @param settingValue : decimal value without unit information
54  * @param multiply : multiplication value either KB, MB or GB
55  *
56  * @return A string to regulated final value
57  */
58  std::string convertToBytes(const std::string settingValue, const int multiply);
59 
60  /*
61  * @brief Converts the setting value to bytes
62  *
63  * @param settingValue : value to be applied to a setting
64  *
65  * @return A string to a value in bytes
66  */
67  std::string suffixCorrection(const std::string settingValue);
68 };
69 
70 } // namespace softwarecontainer
Developers guide to adding a config item: