From 6a71275027db683cc2d6b6df1d7558adc47ff156 Mon Sep 17 00:00:00 2001
From: James Meyer <james.meyer@operamail.com>
Date: Sun, 7 Oct 2012 20:47:55 -0500
Subject: LinHES-config:  fixed central NFS new feature, if central NFS is
 selected the entry is added to nfsmap_auto

---
 abs/core/LinHES-config/PKGBUILD        |  8 ++--
 abs/core/LinHES-config/mv_common.py    |  5 ++
 abs/core/LinHES-config/mv_config.py    |  2 +-
 abs/core/LinHES-config/mv_fileshare.py | 83 ++++++++++++++++++++++++++--------
 4 files changed, 73 insertions(+), 25 deletions(-)

diff --git a/abs/core/LinHES-config/PKGBUILD b/abs/core/LinHES-config/PKGBUILD
index 7471335..df69f79 100755
--- a/abs/core/LinHES-config/PKGBUILD
+++ b/abs/core/LinHES-config/PKGBUILD
@@ -1,6 +1,6 @@
 pkgname=LinHES-config
 pkgver=2.3
-pkgrel=168
+pkgrel=169
 conflicts=(MythVantage-config MythVantage-config-dev LinHES-config-dev LinHes-config )
 pkgdesc="Install and configure your system"
 depends=('bc' 'libstatgrab'  'mysql-python' 'expect' 'curl' 'dnsutils' 'parted'
@@ -127,7 +127,7 @@ build() {
 }
 md5sums=('59e18e35359bebcd9d639c5e5b5d290d'
          'f33e1a6f7985091b8d47cbaf7433f90f'
-         '1afacd0337d95f140b2a1777c27f041a'
+         'cb1f9d7a3438219048a679be87217f46'
          '2596460462cf6c889cf8f95485537b20'
          '985891a43f7c4c983eb2a362162f1a0f'
          'fda01259a4bc74d83c9092d338bd247a'
@@ -148,7 +148,7 @@ md5sums=('59e18e35359bebcd9d639c5e5b5d290d'
          '3d1e4a119f38cff0498bf8a67e94e4b3'
          '71fd2d0d448fc2fcd15415a1beed7109'
          'af6b3c5ec0d974b3e19ff1ed50662ee5'
-         '5f60c90ae0f48d71224d4dd6afad61ff'
+         'cbc7cb10bde9a133e16fb63df6242f29'
          'b845de3e05c1734cce4b9ac5e8f1baaf'
          'e869e2c72212881db1e4fa40b116efe5'
          '8b7dce4a3a0a281fa6656aa8781a648e'
@@ -160,7 +160,7 @@ md5sums=('59e18e35359bebcd9d639c5e5b5d290d'
          '67b651a8cd0dcccb368fe7d2402f05f3'
          'b4900090d841d3e390cb840cf16afd85'
          '6dd202ec664ede468e42edf600f7913d'
-         '923197a517cb83d77263e8cea8b8c16a'
+         'c9c9390ac12145169dfe9a76896db328'
          'f49d9ff1e6c3e484c9679079c74ad048'
          '2596460462cf6c889cf8f95485537b20'
          '4cba2bb55c6b8e27c57a6171f42d0455'
diff --git a/abs/core/LinHES-config/mv_common.py b/abs/core/LinHES-config/mv_common.py
index f1210ba..c2138dc 100755
--- a/abs/core/LinHES-config/mv_common.py
+++ b/abs/core/LinHES-config/mv_common.py
@@ -1,6 +1,7 @@
 # -*- coding: utf-8 -*-
 import logging, os, time
 import commands
+import subprocess
 import ConfigParser
 import urllib2
 config_file = "mv_config"
@@ -62,6 +63,10 @@ def read_config(module_config,data):
 
     return rvalue
 
+
+def runcmd_bg(cmd):
+    subprocess.Popen(cmd)
+
 def runcmd(cmd):
     if data_config.NOOPDEBUG=="FALSE":
         pass
diff --git a/abs/core/LinHES-config/mv_config.py b/abs/core/LinHES-config/mv_config.py
index 381f424..6c0744d 100755
--- a/abs/core/LinHES-config/mv_config.py
+++ b/abs/core/LinHES-config/mv_config.py
@@ -16,7 +16,7 @@ share_exclude_dir=['mysql','srv']
 SG_MAP_AUTONFS_SKIP=['media/tv','media/video','media/video_stuff']
 
 MAP_AUTONFS_SKIP=['lost+found','media','backup']
-
+nfs_options="rsize=16384,wsize=16384,intr"
 
 
 
diff --git a/abs/core/LinHES-config/mv_fileshare.py b/abs/core/LinHES-config/mv_fileshare.py
index ebb53c7..96e9a28 100755
--- a/abs/core/LinHES-config/mv_fileshare.py
+++ b/abs/core/LinHES-config/mv_fileshare.py
@@ -4,6 +4,7 @@ import mv_common
 import glob
 from urllib2 import Request, urlopen, URLError, HTTPError
 #client side
+#CentralNFSallhosts=
 
 def setup_nfs_client(systemconfig,data_config):
     nfslist=[]
@@ -13,6 +14,7 @@ def setup_nfs_client(systemconfig,data_config):
 
     if systemconfig.get("HaveCentralNFS") == "yes":
         logging.debug("    Using a Central NFS server")
+        logging.debug("    NFSserver:%s" %systemconfig.get("NFSserver"))
         if systemconfig.get("NFSserver") == "file:nfsmap":
         #if it's a file check for it, failure results in downloading attempt from MBE
             nfsmap_file=data_config.MYTHHOME+"/templates/nfsmap"
@@ -22,8 +24,15 @@ def setup_nfs_client(systemconfig,data_config):
                 nfsmap_file = download_nfsmap(systemconfig.get("dbhost"),nfsmap_serverfile)
             nfslist = process_nfsmap_file(nfsmap_file)
 
+        #check for other filesname:
+
+        elif re.search("^file:",systemconfig.get("NFSserver")):
+            filename=systemconfig.get("NFSserver").split(":")[1]
+            nfsmap_file=data_config.MYTHHOME+"/templates/"+filename
+            nfslist = process_nfsmap_file(nfsmap_file)
+
         # if it's an ip  parse ip and download file
-        elif re.search(systemconfig.get("NFSserver"),":nfsmap"):
+        elif re.search(":nfsmap$",systemconfig.get("NFSserver")):
             ip=systemconfig.get("NFSserver").split(":")[0]
             nfsmap_file = download_nfsmap(ip,nfsmap_serverfile)
             nfslist = process_nfsmap_file(nfsmap_file)
@@ -41,8 +50,9 @@ def setup_nfs_client(systemconfig,data_config):
             nfslist = process_nfsmap_file(nfsmap_file)
 
 
-    setup_nfs_fstab(nfslist)
+    setup_nfs_fstab(nfslist,data_config)
     logging.info("__End of nfs\n")
+    return nfslist
 
 
 def process_nfsmap_file(mapfile):
@@ -102,20 +112,30 @@ def setup_nfs_mkdir(nfs_dirname):
 
 
 
-def setup_nfs_fstab(nfslist):
+
+
+def setup_nfs_fstab(nfslist,data_config):
     logging.info("    Adding nfs paths to fstab")
+    nfs_options =  mythhome = data_config.nfs_options
     try:
         f = open('/etc/fstab', 'a')
         line = "#STARTSCRUB --------------anything in this block will be scrubbed\n"
         f.write(line)
         for s, m in nfslist:
-            line = "%s %s    nfs \n" %(s,m)
+            line = "%s %s   nfs %s \n" %(s,m,nfs_options)
             setup_nfs_mkdir(m)
             logging.debug("    %s",line)
             f.write(line)
         line = "#ENDSCRUB\n"
         f.write(line)
         f.close()
+
+        for s, m in nfslist:
+            logging.info("    nfs mounting %s",m)
+            cmd = ['mount',m]
+            mv_common.runcmd_bg(cmd)
+
+
     except:
         logging.critical("    *Couldn't open /etc/fstab for writing")
     logging.debug("   Done adding nfs paths to fstab")
@@ -257,7 +277,7 @@ create mask = 0755 ''' %(data_config.MYTHHOME,shreadonly)
         mv_common.restart_service("smbd")
 
     else:
-        logging.info("  Removing windows file sharing")
+        logging.info("    Removing windows file sharing")
         mv_common.remove_service("smbd")
         mv_common.remove_service("nmbd")
         mv_common.pacremove("samba")
@@ -284,7 +304,7 @@ def scan_for_shares():
 
     return share_list
 
-def setup_etc_exports(shares,data_config,servername):
+def setup_etc_exports(shares,data_config,servername,nfslist):
     #read in /etc/ exports
     conf_file="/etc/exports"
     excludes = data_config.share_exclude_dir
@@ -293,12 +313,18 @@ def setup_etc_exports(shares,data_config,servername):
 
     #print nfsmap_auto_skip
     nfs_auto_line ="%s:%s %s"
-
-
     nfs_map_auto = []
-
     share_list = []
 
+    #populate nfs_map_auto with nfs_list.  nfs_list is populated from the
+    #central nfs options
+    #nfslist looks like  [('silverraid:/raid0/data/media', '/data/storage/nfs/silverraid')]
+    for i in nfslist:
+        sharename = i[0]
+        mountpoint = i[1]
+        templine = "%s %s" %(sharename,mountpoint)
+        nfs_map_auto.append(templine)
+
 
     #create the lists for both /etc/exports and nfs_map_auto
     for share in shares:
@@ -326,9 +352,6 @@ def setup_etc_exports(shares,data_config,servername):
                         templine = nfs_auto_line %(servername,tempname,tempname)
                         nfs_map_auto.append(templine)
 
-
-
-
     new_exports=[]
     new_exports.append("#This file was generated by systemconfig.py -m fileshare")
     new_exports.append("#Use exportfs -arv to reread. \n\n")
@@ -348,7 +371,19 @@ def setup_etc_exports(shares,data_config,servername):
 
         logging.info("    writing nfsmap_auto")
         try:
-            os.makedirs("%s/templates/" %data_config.MYTHHOME)
+            dirname ="%s/templates/" %data_config.MYTHHOME
+            os.makedirs(dirname)
+            cmd =  "chmod 755 %s" %dirname
+            mv_common.runcmd(cmd)
+            cmd =  "chown mythtv:users %s" %dirname
+            mv_common.runcmd(cmd)
+        except:
+            pass
+        try:
+            cmd =  "chmod 755 %s" %dirname
+            mv_common.runcmd(cmd)
+            cmd =  "chown mythtv:users %s" %dirname
+            mv_common.runcmd(cmd)
         except:
             pass
         conf_file_nfs = "%s/templates/nfsmap_auto" %(data_config.MYTHHOME)
@@ -359,7 +394,7 @@ def setup_etc_exports(shares,data_config,servername):
             logging.debug("%s" %line)
         f.close()
     except:
-        logging.info("*   error writing /data/srv/htdocs/nfsmap_auto")
+        logging.info("*   error writing %s" %conf_file_nfs)
 
     try:
         logging.info("    writing /etc/exports")
@@ -374,14 +409,13 @@ def setup_etc_exports(shares,data_config,servername):
 
 
 
-def setup_NFSshares(UseNFS,templatefile,data_config,servername):
+def setup_NFSshares(UseNFS,templatefile,data_config,servername,nfslist):
     if UseNFS == "1":
         logging.info("    Activating NFS server")
         mv_common.pacinstall("nfs-utils")
         mv_common.pacinstall("rpcbind")
         shares = scan_for_shares()
-        setup_etc_exports(shares,data_config,servername)
-
+        setup_etc_exports(shares,data_config,servername,nfslist)
         mv_common.add_service("nfsd")
         mv_common.add_service("nfs-common")
         mv_common.add_service("rpcbind")
@@ -408,11 +442,20 @@ def setup_fileshare(systemconfig,data_config):
         logging.info("____Skipping of fileshare, config disabled____")
         return
     logging.info("____Start of fileshare configuration____")
-    #client
-    setup_nfs_client(systemconfig,data_config)
+
+    #client, nfslist will be used in case the central NFS needs to also be addressed
+    nfslist = setup_nfs_client(systemconfig,data_config)
+
     #server
+    if systemconfig.get("CentralNFSallhosts") == "0":
+        #reset nfslist to 0 so that central nfsshares do not get added to auto_nfs
+        nfslist = []
+
     setup_NFSshares(systemconfig.get("UseNFS"),
-                    systemconfig.get("TEMPLATES")+"/exports.template",data_config,systemconfig.get("hostname"))
+                    systemconfig.get("TEMPLATES")+"/exports.template",
+                    data_config,systemconfig.get("hostname"),
+                    nfslist)
+
     setup_samba(systemconfig,data_config)
 
     logging.info("__End of fileshare configuration\n")
-- 
cgit v0.12