aboutsummaryrefslogtreecommitdiffstats
path: root/test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp
diff options
context:
space:
mode:
authorWojciech Sliwka <wojciech.sliwka@nokia.com>2019-07-10 13:48:52 +0200
committerGary Wu <gary.wu@futurewei.com>2019-07-19 17:18:49 +0000
commit032ff22ef20b59950a8b5fae8d2ba6d03e93ac93 (patch)
tree98058dcf2726b3f432cecffc42bd7cbccca3555e /test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp
parent79c9b78adb7fbc943fd2aee7d333fd3cadf5b8f3 (diff)
Opensourcing new version of Simulator
Additional info in README.md Issue-ID: INT-1134 Signed-off-by: Wojciech Sliwka <wojciech.sliwka@nokia.com> Change-Id: I06d41fd3f361b7a451b30b702882810e4136a129
Diffstat (limited to 'test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp')
-rw-r--r--test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp74
1 files changed, 74 insertions, 0 deletions
diff --git a/test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp b/test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp
new file mode 100644
index 000000000..56c33f0de
--- /dev/null
+++ b/test/mocks/pnfsimulator/netconfsimulator/netopeer-change-saver-native/Application.cpp
@@ -0,0 +1,74 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * Simulator
+ * ================================================================================
+ * Copyright (C) 2019 Nokia. All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ */
+
+#include "Application.h"
+#include <cstdio>
+#include <unistd.h>
+#include "sysrepo/Session.hpp"
+#include "SysrepoCallback.h"
+
+Application::~Application() {
+ this->subscriber->unsubscribe();
+ this->session->session_stop();
+ sr_disconnect(this->connection->_conn);
+ std::cout << "Application closed correctly " << std::endl;
+}
+
+void Application::run() {
+ /*create kafka wrapper object*/
+ auto kafkaWrapper = std::make_shared<KafkaWrapper>(this->brokers,this->topic_name);
+
+ std::cout << "Application will watch for changes in " << module_name << std::endl;
+ /* connect to sysrepo */
+ this->connection = new sysrepo::Connection("example_application");
+ sysrepo::S_Connection conn(new sysrepo::Connection("example_application"));
+
+ /* start session */
+ sysrepo::S_Session sess(new sysrepo::Session(conn));
+
+ this->session = sess;
+ /* subscribe for changes in running config */
+ sysrepo::S_Subscribe subscribe(new sysrepo::Subscribe(sess));
+ std::shared_ptr<SysrepoCallback> cb(new SysrepoCallback(kafkaWrapper));
+
+ subscribe->module_change_subscribe(module_name, cb);
+ this->subscriber = subscribe;
+
+ /* read startup config */
+ std::cout << "\n ========== READING STARTUP CONFIG: ==========\n" << std::endl;
+
+ cb->print_current_config(sess, module_name);
+
+ std::cout << "\n ========== STARTUP CONFIG APPLIED AS RUNNING ==========\n" << std::endl;
+
+ /* loop until ctrl-c is pressed / SIGINT is received */
+ while (!exit_application) {
+ sleep(1000); /* or do some more useful work... */
+ }
+
+ std::cout << "Application exit requested, exiting." << std::endl;
+
+}
+
+Application::Application(const char *module_name, const char *brokers, const char *topic_name) {
+ this->module_name = module_name;
+ this->brokers = brokers;
+ this->topic_name = topic_name;
+}