softwarecontainer  0.18.0-739e8d7 2017-05-04
filegatewayparser.cpp
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 #include "filegatewayparser.h"
21 #include "jsonparser.h"
22 
23 namespace softwarecontainer {
24 
25 bool FileGatewayParser::parseConfigElement(const json_t *element, FileSetting &setting)
26 {
27  if (!JSONParser::read(element, "path-host", setting.pathInHost)) {
28  log_error() << "path-host key missing or of wrong type";
29  return false;
30  }
31 
32  if (!JSONParser::read(element, "path-container", setting.pathInContainer)) {
33  log_error() << "path-container key missing or of wrong type";
34  return false;
35  }
36 
37  if (setting.pathInHost.size() == 0) {
38  log_error() << "path-host setting is an empty string";
39  return false;
40  }
41 
42  if (setting.pathInContainer.size() == 0) {
43  log_error() << "path-container setting is an empty string";
44  return false;
45  }
46 
47  if (!JSONParser::readOptional(element, "read-only", setting.readOnly)) {
48  log_error() << "read-only has wrong format";
49  return false;
50  }
51 
52  return true;
53 }
54 
55 } // namespace softwarecontainer
static bool readOptional(const json_t *element, const char *key, std::string &result)
Reads an optional value from a JSON object.
Definition: jsonparser.cpp:24
Developers guide to adding a config item:
static bool read(const json_t *element, const char *key, std::string &result)
Reads a string from a JSON Object.
Definition: jsonparser.cpp:51