From 82ced1fb275698748e1336d8c1a512ea90f52720 Mon Sep 17 00:00:00 2001 From: Marek Gradzki Date: Wed, 22 Aug 2018 06:59:36 +0200 Subject: examples: add ncclient examples of URL capability Change-Id: Icf3bfc331548d1e0f1862bf87615f7c03a24780a Signed-off-by: Marek Gradzki --- examples/ncclient/Readme.adoc | 20 +++++++++++-- examples/ncclient/acl/config_acl.xml | 2 +- examples/ncclient/acl/config_acl_update.xml | 2 +- examples/ncclient/bd/config_bd.xml | 2 +- examples/ncclient/copy_config_url.py | 44 +++++++++++++++++++++++++++++ examples/ncclient/nat/config_nat.xml | 2 +- examples/ncclient/nat/config_nat_update.xml | 2 +- 7 files changed, 67 insertions(+), 7 deletions(-) create mode 100755 examples/ncclient/copy_config_url.py (limited to 'examples/ncclient') diff --git a/examples/ncclient/Readme.adoc b/examples/ncclient/Readme.adoc index f2a97eb72..f3fafcb9d 100644 --- a/examples/ncclient/Readme.adoc +++ b/examples/ncclient/Readme.adoc @@ -90,7 +90,7 @@ Start honeycomb NOTE: Remember that HC by default persists config and restores it after restart. You can disable this behaviour using config/honeycomb.json. -== examples +== === ACL @@ -121,7 +121,7 @@ Example configuration of NAT on loopback interface. ./acl/test_nat_updates.sh ---- -== examples +== == ACL + [source] @@ -129,3 +129,19 @@ Example configuration of NAT on loopback interface. ./edit_config.py --validate acl/config_invalid_acl.xml ---- +== URL capability + +Provide URL as source or target. +Source URL can use file, http, https or ftp protocol. +Target URL can use file protocol. + +When using file protocol, provided patch should correspond to a file accessible by Honeycomb. + +Example: + +[source] +---- +./copy_config_url.py "file:///home/m/hc2vpp/examples/ncclient/bd/config_bd.xml" candidate +---- + + diff --git a/examples/ncclient/acl/config_acl.xml b/examples/ncclient/acl/config_acl.xml index 164fd5aaa..5c6c09403 100644 --- a/examples/ncclient/acl/config_acl.xml +++ b/examples/ncclient/acl/config_acl.xml @@ -5,7 +5,7 @@ ~ terms of the Eclipse Public License v1.0 which accompanies this distribution, ~ and is available at http://www.eclipse.org/legal/epl-v10.html --> - + diff --git a/examples/ncclient/acl/config_acl_update.xml b/examples/ncclient/acl/config_acl_update.xml index 5b99994c3..db4fd8bb5 100644 --- a/examples/ncclient/acl/config_acl_update.xml +++ b/examples/ncclient/acl/config_acl_update.xml @@ -5,7 +5,7 @@ ~ terms of the Eclipse Public License v1.0 which accompanies this distribution, ~ and is available at http://www.eclipse.org/legal/epl-v10.html --> - + diff --git a/examples/ncclient/bd/config_bd.xml b/examples/ncclient/bd/config_bd.xml index d7512239f..255ad3e5e 100644 --- a/examples/ncclient/bd/config_bd.xml +++ b/examples/ncclient/bd/config_bd.xml @@ -5,7 +5,7 @@ ~ terms of the Eclipse Public License v1.0 which accompanies this distribution, ~ and is available at http://www.eclipse.org/legal/epl-v10.html --> - + diff --git a/examples/ncclient/copy_config_url.py b/examples/ncclient/copy_config_url.py new file mode 100755 index 000000000..09c84012e --- /dev/null +++ b/examples/ncclient/copy_config_url.py @@ -0,0 +1,44 @@ +#!/usr/bin/env python2 +# +# Copyright (c) 2018 Cisco and/or its affiliates. +# 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. + +import argparse +import logging +from ncclient import manager + + +def _copy_config_url(source, target, host='localhost', port=2831, username='admin', password='admin'): + with manager.connect(host=host, port=port, username=username, password=password, hostkey_verify=False) as m: + logger.info("Connected to HC") + ret = m.copy_config(source=source, target=target) + logger.info(" successful:\n%s" % ret) + ret = m.commit() + logger.info(" successful:\n%s", ret) + + +if __name__ == '__main__': + logger = logging.getLogger("hc2vpp.examples.copy_config_url") + argparser = argparse.ArgumentParser(description="Configures VPP using RPC") + argparser.add_argument('source', help="source datastore name or URI of XML file with element") + argparser.add_argument('target', help="target datastore name or URI of XML file with element") + argparser.add_argument('--verbose', help="increase output verbosity", action="store_true") + args = argparser.parse_args() + + logger = logging.getLogger("hc2vpp.examples.copy_config") + if args.verbose: + logging.basicConfig(level=logging.DEBUG) + else: + logging.basicConfig(level=logging.INFO) + + _copy_config_url(args.source, args.target) diff --git a/examples/ncclient/nat/config_nat.xml b/examples/ncclient/nat/config_nat.xml index eb261f1d2..9c41cab79 100644 --- a/examples/ncclient/nat/config_nat.xml +++ b/examples/ncclient/nat/config_nat.xml @@ -5,7 +5,7 @@ ~ terms of the Eclipse Public License v1.0 which accompanies this distribution, ~ and is available at http://www.eclipse.org/legal/epl-v10.html --> - + local0 diff --git a/examples/ncclient/nat/config_nat_update.xml b/examples/ncclient/nat/config_nat_update.xml index 7c8bd9b9b..a6235addb 100644 --- a/examples/ncclient/nat/config_nat_update.xml +++ b/examples/ncclient/nat/config_nat_update.xml @@ -5,7 +5,7 @@ ~ terms of the Eclipse Public License v1.0 which accompanies this distribution, ~ and is available at http://www.eclipse.org/legal/epl-v10.html --> - + local0 -- cgit 1.2.3-korg