summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdministrator <michellehzg@gmail.com>2016-05-25 12:12:59 +0800
committerAdministrator <michellehzg@gmail.com>2016-05-25 12:12:59 +0800
commit76980aaf49f5e48f87400acf2c8aa5d0662e7689 (patch)
treeaf0e6638fba055c2e063aea34b3022efd8a3cec6
parentd474dd0f20db9b9bc66908e54b47bcceb71fd490 (diff)
downloadpython-vyos-mgmt-76980aaf49f5e48f87400acf2c8aa5d0662e7689.tar.gz
python-vyos-mgmt-76980aaf49f5e48f87400acf2c8aa5d0662e7689.zip
fix bugs
-rw-r--r--vyroute/Router.py63
-rw-r--r--vyroute/basic_function/OSPFRoute.py7
-rw-r--r--vyroute/basic_function/RIPRoute.py5
-rw-r--r--vyroute/basic_function/StaticRoute.py9
4 files changed, 38 insertions, 46 deletions
diff --git a/vyroute/Router.py b/vyroute/Router.py
index fe95289..12629ff 100644
--- a/vyroute/Router.py
+++ b/vyroute/Router.py
@@ -70,13 +70,13 @@ class BasicRouter(Router):
:param address: Router address,example:'192.168.10.10'
:param cred: Router user and password,example:'vyos:vyos'
"""
- self.address = address
- self.cred = list(cred)
- self.divi = self.cred.index(":")
- self.username = ''.join(self.cred[:self.divi])
- self.passwd = ''.join(self.cred[self.divi+1:])
- self.account = Account(self.username, self.passwd)
- self.conn = SSH2()
+ self.__address = address
+ self.__cred = list(cred)
+ self.__divi = self.__cred.index(":")
+ self.__username = ''.join(self.__cred[:self.__divi])
+ self.__passwd = ''.join(self.__cred[self.__divi+1:])
+ self.__account = Account(self.__username, self.__passwd)
+ self.__conn = SSH2()
self.status = {"object": None, "commit": None, "save": None, "configure": None}
def login(self):
@@ -85,8 +85,8 @@ class BasicRouter(Router):
:return: a python dictionary
"""
try:
- if self.conn.connect(self.address) is True:
- self.conn.login(self.account)
+ if self.__conn.connect(self.__address) is True:
+ self.__conn.login(self.__account)
self.status["object"] = "login"
return {"Result": "Login successfully."}
else:
@@ -100,7 +100,7 @@ class BasicRouter(Router):
:return: a python dictionary
"""
try:
- self.conn.close(force=True)
+ self.__conn.close(force=True)
self.status["object"] = "logout"
return {"Result": "Logout successfully."}
except Exception, e:
@@ -114,7 +114,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] is None:
- self.conn.execute("configure")
+ self.__conn.execute("configure")
self.status["configure"] = "Yes"
return {"Result": "Active configure mode successfully."}
else:
@@ -135,7 +135,7 @@ class BasicRouter(Router):
if self.status["commit"] is None:
return {"Error": "You don't need to commit."}
if self.status["commit"] == "No":
- self.conn.execute("commit")
+ self.__conn.execute("commit")
self.status["commit"] = "Yes"
return {"Result": "Commit successfully."}
else:
@@ -159,8 +159,9 @@ class BasicRouter(Router):
if self.status["save"] is None:
return {"Error": "You don't need to save."}
if self.status["save"] == "No":
- self.conn.execute("save")
+ self.__conn.execute("save")
self.status["save"] = "Yes"
+ return {"Result": "Save successfully."}
else:
return {"Error": "You have saved!"}
else:
@@ -182,7 +183,7 @@ class BasicRouter(Router):
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
if force is True:
- self.conn.execute("exit")
+ self.__conn.execute("exit")
self.status["configure"] = None
self.status["save"] = None
self.status["commit"] = None
@@ -190,7 +191,7 @@ class BasicRouter(Router):
if force is False:
if self.status["commit"] == "Yes":
if self.status["save"] == "Yes":
- self.conn.execute("exit")
+ self.__conn.execute("exit")
self.status["configure"] = None
self.status["save"] = None
self.status["commit"] = None
@@ -215,7 +216,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = Modifylo.modifylo(self.conn, data)
+ res = Modifylo.modifylo(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -239,9 +240,7 @@ class BasicRouter(Router):
"""Static router setting
Parameter data example:
- {'config':[{'target':'10.20.10.0/24','next-hop':'10.20.10.1','distance':'1'},
- {'target':"192.168.20.0/24','next-hop':'192.168.20.1','distance':'1'},
- ],
+ {'config':{'target':'10.20.10.0/24','next-hop':'10.20.10.1','distance':'1'},
}
:param data: a python dictionary
@@ -250,7 +249,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = StaticRoute.staticroute(self.conn, data)
+ res = StaticRoute.staticroute(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -274,7 +273,7 @@ class BasicRouter(Router):
"""RIP protocols router setting
Parameter data example:
- {'config':['192.168.10.0/24','10.20.10.0/24'],
+ {'config':'192.168.10.0/24',
}
:param data: a python dictionary
@@ -283,7 +282,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = RIPRoute.riproute(self.conn, data)
+ res = RIPRoute.riproute(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -306,11 +305,9 @@ class BasicRouter(Router):
def ospf_area(self, data):
"""OSPF area setting
- Parameter data example:
- {'config':[{'area':'0','network':'192.168.10.0/24'},
- {'area':'0','network':'10.20.10.0/24'},
- ],
- }
+ Parameter data example:
+ {'config':{'area':'0','network':'192.168.10.0/24'},
+ }
:param data: a python dictionary
:return: a python dictionary
@@ -318,7 +315,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = OSPFRoute.ospfarea(self.conn, data)
+ res = OSPFRoute.ospfarea(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -351,7 +348,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = OSPFRoute.router_id(self.conn, data)
+ res = OSPFRoute.router_id(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -384,7 +381,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = OSPFRoute.ospf_redistribute(self.conn, data)
+ res = OSPFRoute.ospf_redistribute(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -412,7 +409,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = OSPFRoute.ospf_adjacency(self.conn)
+ res = OSPFRoute.ospf_adjacency(self.__conn)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -445,7 +442,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = OSPFRoute.ospf_default_route(self.conn, data)
+ res = OSPFRoute.ospf_default_route(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
@@ -478,7 +475,7 @@ class BasicRouter(Router):
try:
if self.status["object"] == "login":
if self.status["configure"] == "Yes":
- res = OSPFRoute.ospf_route_map(self.conn, data)
+ res = OSPFRoute.ospf_route_map(self.__conn, data)
if "Result" in res:
if self.status["commit"] == "No":
pass
diff --git a/vyroute/basic_function/OSPFRoute.py b/vyroute/basic_function/OSPFRoute.py
index b89edd6..d980a84 100644
--- a/vyroute/basic_function/OSPFRoute.py
+++ b/vyroute/basic_function/OSPFRoute.py
@@ -3,9 +3,7 @@ def ospfarea(obj, data):
"""This method provide a OSPF area configuration function
Parameter data example:
- {'config':[{'area':'0','network':'192.168.10.0/24'},
- {'area':'0','network':'10.20.10.0/24'},
- ],
+ {'config':{'area':'0','network':'192.168.10.0/24'},
}
:param obj: a connection object
@@ -16,8 +14,7 @@ def ospfarea(obj, data):
try:
# Configure ospf area
- for i in data["config"]:
- obj.execute(ospf_basic_configuration % (i['area'], i['network']))
+ obj.execute(ospf_basic_configuration % (data['config']['area'], data['config']['network']))
return {"Result": "Configured successfully"}
except Exception, e:
return {"Error": e}
diff --git a/vyroute/basic_function/RIPRoute.py b/vyroute/basic_function/RIPRoute.py
index 085299e..7ab0c19 100644
--- a/vyroute/basic_function/RIPRoute.py
+++ b/vyroute/basic_function/RIPRoute.py
@@ -3,7 +3,7 @@ def riproute(obj, data):
"""This method provide a RIP protocols router configuration function
Parameter data example:
- {'config':['192.168.10.0/24','10.20.10.0/24'],
+ {'config':'192.168.10.0/24',
}
:param obj: a connection object
@@ -14,8 +14,7 @@ def riproute(obj, data):
redistribute_configuration = "set protocols rip redistribute connected"
try:
# Configure RIP router
- for i in data['config']:
- obj.execute(rip_basic_configuration % i)
+ obj.execute(rip_basic_configuration % data['config'])
obj.execute(redistribute_configuration)
return {"Result": "Configured successfully"}
except Exception, e:
diff --git a/vyroute/basic_function/StaticRoute.py b/vyroute/basic_function/StaticRoute.py
index f0d6afc..b76e451 100644
--- a/vyroute/basic_function/StaticRoute.py
+++ b/vyroute/basic_function/StaticRoute.py
@@ -3,9 +3,7 @@ def staticroute(obj, data):
"""This method provide a basic static router configuration function
Parameter data example:
- {'config':[{'target':'10.20.10.0/24','next-hop':'10.20.10.1','distance':'1'},
- {'target':"192.168.20.0/24','next-hop':'192.168.20.1','distance':'1'},
- ],
+ {'config':{'target':'10.20.10.0/24','next-hop':'10.20.10.1','distance':'1'},
}
:param obj: a connection object
@@ -16,8 +14,9 @@ def staticroute(obj, data):
try:
# Configure static router
- for i in data['config']:
- obj.execute(static_basic_configuration % (i['target'], i['next-hop'], i['distance']))
+ obj.execute(static_basic_configuration % (data['config']['target'],
+ data['config']['next-hop'],
+ data['config']['distance']))
return {"Result": "Configured successfully"}
except Exception, e:
return {'Error': e}