Marc Fiuczynski [Tue, 23 Feb 2010 05:25:14 +0000 (05:25 +0000)]
 
Call /etc/init.d/codemux only when codemux is installed
Daniel Hokka Zakrisson [Fri, 19 Feb 2010 17:47:42 +0000 (17:47 +0000)]
 
Setting tag NodeManager-1.8-24
Enable/disable the codemux service too.
Daniel Hokka Zakrisson [Fri, 19 Feb 2010 17:42:08 +0000 (17:42 +0000)]
 
Merge from trunk.
Thierry Parmentelat [Fri, 29 Jan 2010 14:14:32 +0000 (14:14 +0000)]
 
Branch 2.0 for module NodeManager created (as new trunk) from tag NodeManager-1.8-23
Thierry Parmentelat [Tue, 12 Jan 2010 14:48:50 +0000 (14:48 +0000)]
 
Setting tag NodeManager-1.8-23
emergency tag - make the setting of hmac by the sliverauth plugin more robust
Thierry Parmentelat [Tue, 12 Jan 2010 14:48:48 +0000 (14:48 +0000)]
 
Setting tag NodeManager-1.8-23
emergency tag - make the setting of hmac by the sliverauth plugin more robust
Thierry Parmentelat [Tue, 12 Jan 2010 14:41:36 +0000 (14:41 +0000)]
 
emergency fix for sliverauth & delegated slices
Thierry Parmentelat [Mon, 11 Jan 2010 14:57:53 +0000 (14:57 +0000)]
 
Setting tag NodeManager-1.8-22
support for f10 and f12 in the vref slice tag
Thierry Parmentelat [Mon, 11 Jan 2010 14:51:24 +0000 (14:51 +0000)]
 
support for f10 and f12 in the vref slice tag
Thierry Parmentelat [Sat, 9 Jan 2010 07:42:19 +0000 (07:42 +0000)]
 
Setting tag NodeManager-1.8-21
build on fedora12
uses slicename 'sfacm' instead of 'genicw'
Tony Mack [Wed, 6 Jan 2010 02:16:16 +0000 (02:16 +0000)]
 
renmaed _genicw to _sfacm
Tony Mack [Wed, 16 Dec 2009 02:20:30 +0000 (02:20 +0000)]
 
pl_genicw is allowed to call all methods
Thierry Parmentelat [Tue, 15 Dec 2009 09:49:06 +0000 (09:49 +0000)]
 
fix specfile
Sapan Bhatia [Fri, 30 Oct 2009 18:18:11 +0000 (18:18 +0000)]
 
Setting tag NodeManager-1.8-20
This tag is identical to 1.8-19. The main addition is PLC-controllable vsys scripts. The reason I am
retagging is to eliminate any confusion associated with the -19 tag which was (temporarily) modified a few
days ago.
Marc Fiuczynski [Fri, 30 Oct 2009 18:06:00 +0000 (18:06 +0000)]
 
Make usage of sliver auth configurable from the _default slice attribute
Sapan Bhatia [Wed, 28 Oct 2009 01:47:07 +0000 (01:47 +0000)]
 
Setting tag NodeManager-1.8-19
This patch makes vsys scripts PLC-configurable. Previously, vsys scripts needed to be
self-contained. With this change, they will be able to refer to the attributes associated with a
slice.
Sapan Bhatia [Wed, 28 Oct 2009 01:43:26 +0000 (01:43 +0000)]
 
Bug
Sapan Bhatia [Wed, 28 Oct 2009 01:42:19 +0000 (01:42 +0000)]
 
Bug fix: bracket
Sapan Bhatia [Wed, 28 Oct 2009 01:27:39 +0000 (01:27 +0000)]
 
Added a log message for every time a slice is blessed.
Sapan Bhatia [Wed, 28 Oct 2009 01:22:14 +0000 (01:22 +0000)]
 
New plugin for making vsys scripts PLC-controllable.
Barış Metin [Thu, 22 Oct 2009 09:13:40 +0000 (09:13 +0000)]
 
fix for syntax error
Setting tag NodeManager-1.8-18
--This line, and those below, will be ignored--
Please write a changelog for this new tag in the section above
DIFF=========
Index: tools.py
===================================================================
--- tools.py	(.../tags/NodeManager-1.8-17)	(révision 15402)
+++ tools.py	(.../trunk)	(révision 15402)
@@ -18,18 +18,21 @@
     return interface
 def get_hwaddr_from_plnode():
-    for line in open("/usr/boot/plnode.txt", 'r').readlines():
-        if line.startswith("NET_DEVICE"):
-            return line.split("=")[1].strip().strip('"')
+    try:
+        for line in open("/usr/boot/plnode.txt", 'r').readlines():
+            if line.startswith("NET_DEVICE"):
+                return line.split("=")[1].strip().strip('"')
+    except:
+        pass
     return None
 def get_if_from_hwaddr(hwaddr):
-   import sioc
-   devs = sioc.gifconf()
-   for dev in devs:
-      dev_hwaddr = sioc.gifhwaddr(dev)
-      if dev_hwaddr == hwaddr: return dev
-   return None
+    import sioc
+    devs = sioc.gifconf()
+    for dev in devs:
+        dev_hwaddr = sioc.gifhwaddr(dev)
+        if dev_hwaddr == hwaddr: return dev
+    return None
 def as_daemon_thread(run):
     """Call function <run> with no arguments in its own thread."""
Index: bwmon.py
===================================================================
--- bwmon.py	(.../tags/NodeManager-1.8-17)	(révision 15402)
+++ bwmon.py	(.../trunk)	(révision 15402)
@@ -324,7 +324,7 @@
                   (self.name,
                    bwlimit.format_tc_rate(maxrate),
                    bwlimit.format_tc_rate(maxi2rate)), 1)
-            bwlimit.set(xid = self.xid, dev = dev_default
+            bwlimit.set(xid = self.xid, dev = dev_default,
                 minrate = self.MinRate * 1000,
                 maxrate = self.MaxRate * 1000,
                 maxexemptrate = self.Maxi2Rate * 1000,
Anil-Kumar Vengalil [Thu, 22 Oct 2009 07:39:05 +0000 (07:39 +0000)]
 
bug-fix
Barış Metin [Wed, 21 Oct 2009 15:42:34 +0000 (15:42 +0000)]
 
wrap open() with try/except
Anil-Kumar Vengalil [Wed, 21 Oct 2009 10:40:20 +0000 (10:40 +0000)]
 
Setting tag NodeManager-1.8-17
-fixed problem with sioc import at the build side
-bwlimit.set() now accepts the device and does not asume that it is eth0
Barış Metin [Wed, 21 Oct 2009 10:19:34 +0000 (10:19 +0000)]
 
import sioc only when needed.
Anil-Kumar Vengalil [Wed, 21 Oct 2009 10:15:07 +0000 (10:15 +0000)]
 
testing: this is to avoid building failing while building myplc-doc
Barış Metin [Tue, 20 Oct 2009 12:58:19 +0000 (12:58 +0000)]
 
- don't hardcode the device name (depends on util-vserver-pl change rev. 15385)
Setting tag NodeManager-1.8-16
--This line, and those below, will be ignored--
Please write a changelog for this new tag in the section above
DIFF=========
Index: tools.py
===================================================================
--- tools.py	(.../tags/NodeManager-1.8-15)	(révision 15386)
+++ tools.py	(.../trunk)	(révision 15386)
@@ -8,12 +8,31 @@
 import threading
 import fcntl
 import commands
+import sioc
 import logger
 PID_FILE = '/var/run/nm.pid'
+def get_default_if():
+    interface = get_if_from_hwaddr(get_hwaddr_from_plnode())
+    if not interface: interface = "eth0"
+    return interface
+
+def get_hwaddr_from_plnode():
+    for line in open("/usr/boot/plnode.txt", 'r').readlines():
+        if line.startswith("NET_DEVICE"):
+            return line.split("=")[1].strip().strip('"')
+    return None
+
+def get_if_from_hwaddr(hwaddr):
+    devs = sioc.gifconf()
+    for dev in devs:
+        dev_hwaddr = sioc.gifhwaddr(dev)
+        if dev_hwaddr == hwaddr: return dev
+    return None
+
 def as_daemon_thread(run):
     """Call function <run> with no arguments in its own thread."""
     thr = threading.Thread(target=run)
Index: bwmon.py
===================================================================
--- bwmon.py	(.../tags/NodeManager-1.8-15)	(révision 15386)
+++ bwmon.py	(.../trunk)	(révision 15386)
@@ -52,8 +52,9 @@
 seconds_per_day = 24 * 60 * 60
 bits_per_byte = 8
+dev_default = tools.get_default_if()
 # Burst to line rate (or node cap).  Set by NM. in KBit/s
-default_MaxRate = int(bwlimit.get_bwcap() / 1000)
+default_MaxRate = int(bwlimit.get_bwcap(dev_default) / 1000)
 default_Maxi2Rate = int(bwlimit.bwmax / 1000)
 # 5.4 Gbyte per day. 5.4 * 1024 k * 1024M * 1024G
 # 5.4 Gbyte per day max allowed transfered per recording period
@@ -323,7 +324,7 @@
                   (self.name,
                    bwlimit.format_tc_rate(maxrate),
                    bwlimit.format_tc_rate(maxi2rate)), 1)
-            bwlimit.set(xid = self.xid,
+            bwlimit.set(xid = self.xid, dev = dev_default
                 minrate = self.MinRate * 1000,
                 maxrate = self.MaxRate * 1000,
                 maxexemptrate = self.Maxi2Rate * 1000,
@@ -704,7 +705,7 @@
         nmdbcopy = copy.deepcopy(database.db)
         database.db_lock.release()
         try:
-            if getDefaults(nmdbcopy) and len(bwlimit.tc("class show dev eth0")) > 0:
+            if getDefaults(nmdbcopy) and len(bwlimit.tc("class show dev %s" % dev_default)) > 0:
                 # class show to check if net:InitNodeLimit:bwlimit.init has run.
                 sync(nmdbcopy)
             else: logger.log("bwmon:  BW limits DISABLED.")
Index: net.py
===================================================================
--- net.py	(.../tags/NodeManager-1.8-15)	(révision 15386)
+++ net.py	(.../trunk)	(révision 15386)
@@ -11,8 +11,10 @@
 import sioc, plnet
 # local modules
-import bwlimit, logger, iptables
+import bwlimit, logger, iptables, tools
+dev_default = tools.get_default_if()
+
 def start(options, conf):
     logger.log("net plugin starting up...")
@@ -22,7 +24,7 @@
     if 'OVERRIDES' in dir(config):
         if config.OVERRIDES.get('net_max_rate') == '-1':
             logger.log("net: Slice and node BW Limits disabled.")
-            if len(bwlimit.tc("class show dev eth0")):
+            if len(bwlimit.tc("class show dev %s" % dev_default)):
                 logger.verbose("*** DISABLING NODE BW LIMITS ***")
                 bwlimit.stop()
         else:
Index: plugins/rawdisk.py
===================================================================
--- plugins/rawdisk.py	(.../tags/NodeManager-1.8-15)	(révision 15386)
+++ plugins/rawdisk.py	(.../trunk)	(révision 15386)
@@ -39,7 +39,6 @@
             break
         buf = buf.strip()
         fields = re.split(pat, buf)
-        print fields
         dev = fields[-1]
         if not dev.startswith("dm-") and dev.endswith("1") and dev not in in_vg:
             devices.append("/dev/%s" % dev)
Daniel Hokka Zakrisson [Fri, 16 Oct 2009 15:12:03 +0000 (15:12 +0000)]
 
Remove debugging statement.
Anil-Kumar Vengalil [Wed, 14 Oct 2009 09:23:51 +0000 (09:23 +0000)]
 
correcting file path
Barış Metin [Wed, 14 Oct 2009 09:03:16 +0000 (09:03 +0000)]
 
use dev_default for bwlimit.set()
Barış Metin [Wed, 14 Oct 2009 08:47:48 +0000 (08:47 +0000)]
 
don't hardcode the device name.
Marc Fiuczynski [Fri, 9 Oct 2009 15:43:24 +0000 (15:43 +0000)]
 
The seed for random previously was the meaning of life (i.e., 42) but
that resulted in a not so random choice for the hmac.  This
implementation now uses a random.seed that is based on the current
time.
Setting tag NodeManager-1.8-15
Thierry Parmentelat [Fri, 9 Oct 2009 15:19:13 +0000 (15:19 +0000)]
 
typo
Marc Fiuczynski [Wed, 7 Oct 2009 21:47:54 +0000 (21:47 +0000)]
 
minor improvements with the hope that slivers across machines get different hmacs
Marc Fiuczynski [Tue, 6 Oct 2009 20:43:59 +0000 (20:43 +0000)]
 
Setting tag NodeManager-1.8-14
Minor fix such that sliverauth.py makes a more specific call to
GetSliceTags that include that specific tagname it is looking for.
Daniel Hokka Zakrisson [Sat, 26 Sep 2009 12:30:50 +0000 (12:30 +0000)]
 
Only get the hmac tag.
Stephen Soltesz [Sun, 20 Sep 2009 01:52:21 +0000 (01:52 +0000)]
 
Setting tag NodeManager-1.8-13
Fix bug that prevented 'OVERRIDES' for working correctly.
Stephen Soltesz [Sat, 19 Sep 2009 19:55:30 +0000 (19:55 +0000)]
 
fixing the logic for r14697 and adding a clarifying note.
Marc Fiuczynski [Sat, 19 Sep 2009 01:57:31 +0000 (01:57 +0000)]
 
Faiyaz Ahmed [Tue, 8 Sep 2009 20:14:03 +0000 (20:14 +0000)]
 
Setting tag NodeManager-1.8-12
Increase disk limits to 10G per sliver
Sanity check slice for home directory before starting (hack)
Check codemux arguments
Faiyaz Ahmed [Mon, 7 Sep 2009 19:10:31 +0000 (19:10 +0000)]
 
Increase disk limit.
Marc Fiuczynski [Thu, 13 Aug 2009 16:17:15 +0000 (16:17 +0000)]
 
Be a bit more robust to poorly defined codemux attribute values
Marc Fiuczynski [Thu, 13 Aug 2009 16:16:31 +0000 (16:16 +0000)]
 
clean up of the 'configure' method.  Now provides more failure information
Faiyaz Ahmed [Thu, 6 Aug 2009 20:23:31 +0000 (20:23 +0000)]
 
Setting tag NodeManager-1.8-11
* Fix Delegation
* Move plcapi in plugin-api GetSlivers() calls.
* Persistent Authcheck and resync session when auth failure
Faiyaz Ahmed [Thu, 6 Aug 2009 20:21:20 +0000 (20:21 +0000)]
 
loop on authcheck code in case session is wrong AND api is unavailable.
Faiyaz Ahmed [Thu, 6 Aug 2009 16:35:33 +0000 (16:35 +0000)]
 
Change plugin API (GetSlivers()) argument order to avoid unnecessary PLCAPI dependency.  Fixes Delegation.
Faiyaz Ahmed [Tue, 4 Aug 2009 17:09:41 +0000 (17:09 +0000)]
 
formatting
Faiyaz Ahmed [Tue, 4 Aug 2009 16:29:19 +0000 (16:29 +0000)]
 
Setting tag NodeManager-1.8-10
Disabling sliverauth module.  Not ready for deployment.
Faiyaz Ahmed [Tue, 4 Aug 2009 16:27:18 +0000 (16:27 +0000)]
 
bump util-vserver-python requires.  old util-vserver-python's paths are wrong.
Faiyaz Ahmed [Tue, 4 Aug 2009 16:18:44 +0000 (16:18 +0000)]
 
Disabling sliverauth
Faiyaz Ahmed [Mon, 3 Aug 2009 21:35:17 +0000 (21:35 +0000)]
 
Setting tag NodeManager-1.8-9
Fixing overrides semantics.
Faiyaz Ahmed [Mon, 3 Aug 2009 21:31:26 +0000 (21:31 +0000)]
 
Fix overrides to clean out when none present.
Faiyaz Ahmed [Mon, 3 Aug 2009 20:57:44 +0000 (20:57 +0000)]
 
Setting tag NodeManager-1.8-8
Generalized plugins
Fixed initscript start up bug.
Faiyaz Ahmed [Mon, 3 Aug 2009 20:55:38 +0000 (20:55 +0000)]
 
Rearranging and moving trunk to 1.8.
Faiyaz Ahmed [Mon, 3 Aug 2009 20:45:56 +0000 (20:45 +0000)]
 
NM does not fork often.  A stack limit is now unnecessary.
This fixes the crond bug inside slivers.
Marc Fiuczynski [Tue, 21 Jul 2009 18:50:24 +0000 (18:50 +0000)]
 
cleanup: use os.path.join
Daniel Hokka Zakrisson [Mon, 20 Jul 2009 23:28:12 +0000 (23:28 +0000)]
 
Tabs vs. spaces.
Marc Fiuczynski [Fri, 17 Jul 2009 04:05:35 +0000 (04:05 +0000)]
 
use a temp file to write the keys
Marc Fiuczynski [Fri, 17 Jul 2009 04:04:01 +0000 (04:04 +0000)]
 
only copy in the /dev/sd* file if its not there
Marc Fiuczynski [Thu, 16 Jul 2009 21:23:49 +0000 (21:23 +0000)]
 
NodeManager plugin to empower slivers to make API calls.
Marc Fiuczynski [Thu, 16 Jul 2009 21:23:14 +0000 (21:23 +0000)]
 
NodeManager plugin to support mapping unused raw disks into a slice
that has the rawdisk sliver tag.
Marc Fiuczynski [Thu, 16 Jul 2009 19:53:42 +0000 (19:53 +0000)]
 
NM plugin to pull down special account keys: specifically site_admin and root
Marc Fiuczynski [Wed, 15 Jul 2009 13:35:12 +0000 (13:35 +0000)]
 
Need to use , rather than / as the sed separator
Faiyaz Ahmed [Tue, 14 Jul 2009 18:21:45 +0000 (18:21 +0000)]
 
Syntax error in overrides
Marc Fiuczynski [Thu, 9 Jul 2009 02:27:34 +0000 (02:27 +0000)]
 
sync up with what's on the branch
Marc Fiuczynski [Thu, 9 Jul 2009 02:26:35 +0000 (02:26 +0000)]
 
Updated to pass plugins an API handle (plc) and the plc_config (config) in addition to the data pulled down from GetSlivers; Also made known_modules (which are basically plugins) and plugins use the same function signature
Marc Fiuczynski [Tue, 7 Jul 2009 22:00:38 +0000 (22:00 +0000)]
 
as a plugin, be more verbose about when they are started
Marc Fiuczynski [Tue, 7 Jul 2009 21:58:00 +0000 (21:58 +0000)]
 
- change so that NodeManager/plugins are always loaded, as that's
  where codemux & vsys live
Marc Fiuczynski [Tue, 7 Jul 2009 21:50:08 +0000 (21:50 +0000)]
 
net.py is a 'required' 'plugin' module similar to conf_files.py, bwmon.py, and sm.py
Marc Fiuczynski [Tue, 7 Jul 2009 21:10:06 +0000 (21:10 +0000)]
 
Change local GetSlivers() callbacks to take args as (plc,data,config)
Marc Fiuczynski [Tue, 7 Jul 2009 20:32:36 +0000 (20:32 +0000)]
 
- turn net.py into a NM plugin and move to plugin directory
- pass plc, data, and config to each plugin
Faiyaz Ahmed [Mon, 6 Jul 2009 21:13:18 +0000 (21:13 +0000)]
 
Call to get whole record, not just tags.
Faiyaz Ahmed [Mon, 6 Jul 2009 21:13:18 +0000 (21:13 +0000)]
 
Call to get whole record, not just tags.
Faiyaz Ahmed [Mon, 6 Jul 2009 16:37:40 +0000 (16:37 +0000)]
 
Get slice tags from within sliver using nm api.
Faiyaz Ahmed [Mon, 6 Jul 2009 16:37:40 +0000 (16:37 +0000)]
 
Get slice tags from within sliver using nm api.
Faiyaz Ahmed [Tue, 30 Jun 2009 15:28:08 +0000 (15:28 +0000)]
 
Tagging module NodeManager - NodeManager-1.8-7
* Fix delegation authentication problem
* Can now disable codemux using _default slice, and setting tag {codemux: -1}
Faiyaz Ahmed [Mon, 29 Jun 2009 20:56:52 +0000 (20:56 +0000)]
 
* give all modules access to the API and to the config class
* Fix delegation
* codemux can be disabled using the _default slice
Faiyaz Ahmed [Mon, 29 Jun 2009 20:48:28 +0000 (20:48 +0000)]
 
* give all modules access to the API and to the config class
* Fix delegation
* codemux can be disabled using the _default slice
Faiyaz Ahmed [Mon, 29 Jun 2009 17:06:45 +0000 (17:06 +0000)]
 
Manually updating spec files.  Tagged for 1.8-6.
Faiyaz Ahmed [Fri, 26 Jun 2009 18:33:58 +0000 (18:33 +0000)]
 
Rerun start up scripts after re-enable.
Faiyaz Ahmed [Fri, 26 Jun 2009 18:33:58 +0000 (18:33 +0000)]
 
Rerun start up scripts after re-enable.
Faiyaz Ahmed [Fri, 5 Jun 2009 17:29:18 +0000 (17:29 +0000)]
 
Making branch in line with tag.  there was an issue tagging i fixed by hand, and forgot to take care of this.  Apologies.
Faiyaz Ahmed [Thu, 4 Jun 2009 19:00:32 +0000 (19:00 +0000)]
 
update bw limits
Faiyaz Ahmed [Thu, 4 Jun 2009 18:59:53 +0000 (18:59 +0000)]
 
Updated bw limits
Faiyaz Ahmed [Mon, 1 Jun 2009 20:12:40 +0000 (20:12 +0000)]
 
Double bw limits.
Faiyaz Ahmed [Mon, 1 Jun 2009 20:12:40 +0000 (20:12 +0000)]
 
Double bw limits.
Stephen Soltesz [Tue, 26 May 2009 22:04:37 +0000 (22:04 +0000)]
 
Tagging module NodeManager - NodeManager-1.8-4
* Update session key when out of synch with PLC
* PLCDefaults uses tagname
Faiyaz Ahmed [Tue, 26 May 2009 18:47:44 +0000 (18:47 +0000)]
 
Merge changes from trunk.  Check auth and recompute session key when out of synch.  Also update PLCDefaults.
Faiyaz Ahmed [Tue, 26 May 2009 18:46:00 +0000 (18:46 +0000)]
 
attributes are now tagnames.  Also move debugging output to statements before places where data is used.
Marc Fiuczynski [Wed, 20 May 2009 13:24:38 +0000 (13:24 +0000)]
 
clean up .ssh/authorized_keys setup for slices
Thierry Parmentelat [Fri, 17 Apr 2009 11:15:46 +0000 (11:15 +0000)]
 
Tagging module NodeManager - NodeManager-1.8-3
log invokations of vsys
Barış Metin [Mon, 6 Apr 2009 10:18:22 +0000 (10:18 +0000)]
 
guard AuthCheck with try/except as it will raise an exception.
Barış Metin [Mon, 6 Apr 2009 09:46:34 +0000 (09:46 +0000)]
 
if authentication with the session fails try authenticating with hmac
to get a new session.
Faiyaz Ahmed [Wed, 1 Apr 2009 17:47:08 +0000 (17:47 +0000)]
 
use log_call instead of os.system to capture restart messages.
Faiyaz Ahmed [Wed, 1 Apr 2009 17:44:55 +0000 (17:44 +0000)]
 
Use log_call instead of os.system().
Faiyaz Ahmed [Fri, 27 Mar 2009 19:52:50 +0000 (19:52 +0000)]
 
Tagging module NodeManager - NodeManager-1.8-2
Faiyaz Ahmed [Fri, 27 Mar 2009 19:50:29 +0000 (19:50 +0000)]
 
change from call()/check_call to Popen() in log_exec.  This will raise and log an exception when spawned processes barf.  nm.daemon should now be empty :-D
Faiyaz Ahmed [Fri, 27 Mar 2009 19:50:29 +0000 (19:50 +0000)]
 
change from call()/check_call to Popen() in log_exec.  This will raise and log an exception when spawned processes barf.  nm.daemon should now be empty :-D
Faiyaz Ahmed [Tue, 24 Mar 2009 21:25:09 +0000 (21:25 +0000)]
 
Branch 1.9 for module NodeManager created (as new trunk) from tag NodeManager-1.8-1
Faiyaz Ahmed [Tue, 24 Mar 2009 21:25:05 +0000 (21:25 +0000)]
 
Branch 1.9 for module NodeManager created (as new trunk) from tag NodeManager-1.8-1