Thierry Parmentelat [Fri, 29 Jan 2010 14:21:20 +0000 (14:21 +0000)]
 
Setting tag NodeManager-2.0-1
first working version of 5.0:
pld.c/, db-config.d/ and nodeconfig/ scripts should now sit in the module they belong to
nodefamily is 3-fold with pldistro-fcdistro-arch
relies on GetSlivers to expose 'GetSliceFamily' for slivers
(in addition to the 'vref' tag that's still exposed too)
logging reviewed for more convenience
support for 'service nm restartdebug'
make sync knows how to publish uncommitted code on a test node
Thierry Parmentelat [Fri, 29 Jan 2010 14:21:18 +0000 (14:21 +0000)]
 
Setting tag NodeManager-2.0-1
first working version of 5.0:
pld.c/, db-config.d/ and nodeconfig/ scripts should now sit in the module they belong to
nodefamily is 3-fold with pldistro-fcdistro-arch
relies on GetSlivers to expose 'GetSliceFamily' for slivers
(in addition to the 'vref' tag that's still exposed too)
logging reviewed for more convenience
support for 'service nm restartdebug'
make sync knows how to publish uncommitted code on a test node
Thierry Parmentelat [Fri, 29 Jan 2010 14:14:38 +0000 (14:14 +0000)]
 
Branch 2.0 for module NodeManager created (as new trunk) from tag NodeManager-1.8-23
Thierry Parmentelat [Thu, 28 Jan 2010 17:24:03 +0000 (17:24 +0000)]
 
logs for when PLC is unreachable
Thierry Parmentelat [Thu, 28 Jan 2010 14:12:32 +0000 (14:12 +0000)]
 
fixed broken slice-creation
Thierry Parmentelat [Wed, 27 Jan 2010 18:44:46 +0000 (18:44 +0000)]
 
fixed and moved the server-side yum scripts, from nodeconfig/yum to BootstrapFS/nodeconfig/yum
  now known as the nodeyum package
  (might need some moer work for properly handling kexcludes in multi-fc plcs)
cleaned up all uses of /etc/planetlab/{node,slice}family
nodeconfig now does not need the build/ module anymore at build time
Thierry Parmentelat [Fri, 22 Jan 2010 11:29:00 +0000 (11:29 +0000)]
 
various tricks and notes for smoother debugging
Thierry Parmentelat [Fri, 22 Jan 2010 10:17:45 +0000 (10:17 +0000)]
 
log the setname operation
Thierry Parmentelat [Thu, 21 Jan 2010 15:14:53 +0000 (15:14 +0000)]
 
log_data_in_file is helpful of its own when debugging
Thierry Parmentelat [Thu, 21 Jan 2010 15:14:27 +0000 (15:14 +0000)]
 
undo broken change
Thierry Parmentelat [Wed, 20 Jan 2010 21:20:27 +0000 (21:20 +0000)]
 
run curl without the silent flag; provide more details when cannot connect
Thierry Parmentelat [Wed, 20 Jan 2010 18:57:08 +0000 (18:57 +0000)]
 
svn:keywords
Thierry Parmentelat [Wed, 20 Jan 2010 18:54:19 +0000 (18:54 +0000)]
 
revised layout
Thierry Parmentelat [Tue, 19 Jan 2010 22:38:26 +0000 (22:38 +0000)]
 
new global PLC_FLAVOUR category to globally chose sliver vref image
new method GetSliceFamily, value passed in GetSlivers
NodeManager does not have this logic anymore
Sapan Bhatia [Tue, 12 Jan 2010 21:02:48 +0000 (21:02 +0000)]
 
Store the slice id of the current vserver on disk, rather than sticking it in the kernel.
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 [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 16:37:40 +0000 (16:37 +0000)]
 
Get slice tags from within sliver using nm api.
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 [Fri, 26 Jun 2009 18:33:58 +0000 (18:33 +0000)]
 
Rerun start up scripts after re-enable.
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 [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
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:44:55 +0000 (17:44 +0000)]
 
Use log_call instead of os.system().
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:24:40 +0000 (21:24 +0000)]
 
Tagging module NodeManager - NodeManager-1.8-1
Faiyaz Ahmed [Tue, 24 Mar 2009 19:47:07 +0000 (19:47 +0000)]
 
Merge from Branch.
Faiyaz Ahmed [Mon, 16 Feb 2009 20:14:44 +0000 (20:14 +0000)]
 
Merge from branch.
*  Changes delegate class to controller
*  Adds ability to disable HTBs
*  fixes bug in nm.py when API is unavailable.
*  adds sysctl slice attribute
Faiyaz Ahmed [Thu, 22 Jan 2009 18:42:17 +0000 (18:42 +0000)]
 
Can disable slice HTB's via PLC_SlICE_PREFIX+_default: sliceattribute net_max_rate=-1
Thierry Parmentelat [Mon, 15 Dec 2008 13:05:23 +0000 (13:05 +0000)]
 
always store latest data from GetSlivers in /var/log/getslivers.txt, not only when verbose
Daniel Hokka Zakrisson [Wed, 3 Dec 2008 17:36:30 +0000 (17:36 +0000)]
 
Use pyplnet.
Daniel Hokka Zakrisson [Tue, 2 Dec 2008 03:44:49 +0000 (03:44 +0000)]
 
Use codemux condrestart.