git://git.onelab.eu
/
nodemanager.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
505228d
)
Installs iptables for internet2.
author
Faiyaz Ahmed
<faiyaza@cs.princeton.edu>
Fri, 23 Feb 2007 21:21:50 +0000
(21:21 +0000)
committer
Faiyaz Ahmed
<faiyaza@cs.princeton.edu>
Fri, 23 Feb 2007 21:21:50 +0000
(21:21 +0000)
net.py
patch
|
blob
|
history
nm.py
patch
|
blob
|
history
diff --git
a/net.py
b/net.py
index
564aa24
..
9db7f73
100644
(file)
--- a/
net.py
+++ b/
net.py
@@
-3,8
+3,13
@@
import sioc
import bwlimit
import logger
import sioc
import bwlimit
import logger
+import string
-def GetSlivers(data):
+def GetSlivers(plc, data):
+ InitNodeLimit(data)
+ InitI2(plc, data)
+
+def InitNodeLimit(data):
# query running network interfaces
devs = sioc.gifconf()
ips = dict(zip(devs.values(), devs.keys()))
# query running network interfaces
devs = sioc.gifconf()
ips = dict(zip(devs.values(), devs.keys()))
@@
-45,5
+50,14
@@
def GetSlivers(data):
# some previously invalid sliver bwlimit is now valid
# again, or vice-versa.
# some previously invalid sliver bwlimit is now valid
# again, or vice-versa.
+def InitI2(plc, data):
+ if "Internet2" in data['groups']:
+ logger.log("This is an Internet2 node. Setting rules.")
+ i2nodes = []
+ i2nodeids = plc.GetNodeGroups(["Internet2"])[0]['node_ids']
+ for node in plc.GetNodeNetworks({"node_id": i2nodeids}, ["ip"]):
+ i2nodes.append(node['ip'])
+ bwlimit.exempt_init('Internet2', i2nodes)
+
def start(options, config):
pass
def start(options, config):
pass
diff --git
a/nm.py
b/nm.py
index
ae92e07
..
c4760fc
100644
(file)
--- a/
nm.py
+++ b/
nm.py
@@
-14,7
+14,7
@@
import logger
import tools
from config import Config
import tools
from config import Config
-from plcapi import PLCAPI
+from plcapi import PLCAPI
savedargv = sys.argv[:]
savedargv = sys.argv[:]
@@
-31,9
+31,13
@@
modules = []
def GetSlivers(plc):
data = plc.GetSlivers()
def GetSlivers(plc):
data = plc.GetSlivers()
+ # net needs access to API for i2 nodes.
for module in modules:
for module in modules:
- callback = getattr(module, 'GetSlivers')
- callback(data)
+ if module.__name__ == 'net':
+ module.GetSlivers(plc, data)
+ else:
+ callback = getattr(module, 'GetSlivers')
+ callback(data)
def run():
try:
def run():
try: