EMANE  1.2.1
configurationupdatehandler.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013,2016 - Adjacent Link LLC, Bridgewater, New Jersey
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * * Neither the name of Adjacent Link LLC nor the names of its
16  * contributors may be used to endorse or promote products derived
17  * from this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  */
32 
34 #include "configurationservice.h"
36 #include "anyutils.h"
37 
38 std::string
40 process(const EMANERemoteControlPortAPI::Request::Update::Configuration & configuration,
41  std::uint32_t u32Sequence,
42  std::uint32_t u32Reference)
43 {
44  bool bUpdate{true};
45 
46  ConfigurationUpdate updates;
47 
49 
50  for(const auto & parameter : configuration.parameters())
51  {
52  std::vector<Any> anys;
53 
54  for(const auto & any : parameter.values())
55  {
56  try
57  {
58  anys.push_back(toAny(any));
59  }
60  catch(AnyException & exp)
61  {
62  response.set_type(EMANERemoteControlPortAPI::Response::TYPE_RESPONSE_ERROR);
63 
64  auto pError = response.mutable_error();
65 
66  pError->set_type(EMANERemoteControlPortAPI::Response::Error::TYPE_ERROR_PARAMETER);
67 
68  pError->set_description(exp.what());
69 
70  bUpdate = false;
71 
72  break;
73  }
74  }
75 
76  updates.push_back(std::make_pair(parameter.name(),std::move(anys)));
77  }
78 
79  if(bUpdate)
80  {
81  try
82  {
83  ConfigurationServiceSingleton::instance()->update(configuration.buildid(),updates);
84 
85  response.set_type(EMANERemoteControlPortAPI::Response::TYPE_RESPONSE_UPDATE);
86  }
87  catch(ConfigurationException & exp)
88  {
89  response.set_type(EMANERemoteControlPortAPI::Response::TYPE_RESPONSE_ERROR);
90 
91  auto pError = response.mutable_error();
92 
93  pError->set_type(EMANERemoteControlPortAPI::Response::Error::TYPE_ERROR_PARAMETER);
94 
95  pError->set_description(exp.what());
96  }
97  }
98 
99  response.set_reference(u32Reference);
100 
101  response.set_sequence(u32Sequence);
102 
103  std::string sSerialization;
104 
105  if(!response.SerializeToString(&sSerialization))
106  {
107  throw SerializationException("unable to serialize configuration update response");
108  }
109 
110  return sSerialization;
111 }
SerializationException is thrown when an exception occurs during serialization or deserialization of ...
ConfigurationException is thrown when an exception occurs during configuration processing.
Any toAny(EMANERemoteControlPortAPI::Any any)
Definition: anyutils.h:92
const char * what() const
Definition: exception.h:62
void update(BuildId buildId, const ConfigurationUpdate &update)
std::vector< ConfigurationNameAnyValues > ConfigurationUpdate
static std::string process(const EMANERemoteControlPortAPI::Request::Update::Configuration &configuration, std::uint32_t u32Sequence, std::uint32_t u32Reference)
AnyException is thrown when an exception occurs during creation or conversion of an Any...
Definition: anyexception.h:46
static ConfigurationService * instance()
Definition: singleton.h:56