X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=setup.py;h=10c40c2bbc3af7d24dd2432c3e416249126f55c8;hb=b66306b1358def8542a702b711f58542e9a14c31;hp=ef545cd24b86de3c4c3d6b89e9c4eb9fab6c23c8;hpb=53cfd89c9fa5735ffd22b265d18e0dcf1d2cf106;p=sfa.git diff --git a/setup.py b/setup.py index ef545cd2..10c40c2b 100755 --- a/setup.py +++ b/setup.py @@ -4,19 +4,24 @@ Installation script for the geniwrapper module """ -import os, sys +import sys, os, os.path +from glob import glob import shutil from distutils.core import setup -scripts = [ 'config/sfa-config-tty', +bins = [ 'config/sfa-config-tty', 'sfa/plc/sfa-import-plc.py', + 'sfa/plc/sfa-nuke-plc.py', 'sfa/server/sfa-server.py', + 'sfa/server/sfa-clean-peer-records.py', 'sfa/client/sfi.py', 'sfa/client/getNodes.py', 'sfa/client/getRecord.py', 'sfa/client/setRecord.py', 'sfa/client/genidump.py', + 'sfatables/sfatables', ] + package_dirs = [ 'sfa', 'sfa/client', 'sfa/methods', @@ -24,31 +29,42 @@ package_dirs = [ 'sfa', 'sfa/server', 'sfa/trust', 'sfa/util', + 'sfa/rspecs', + 'sfa/rspecs/aggregates', + 'sfa/rspecs/aggregates/vini', + 'sfatables', + 'sfatables/commands', + 'sfatables/processors', ] -data_files = [ ('/etc/sfa/', [ 'config/aggregates.xml', - 'config/registries.xml', - 'config/sfa_config', - 'config/sfi_config', - ]), - ('/etc/init.d/', ['sfa/init.d/sfa']), - ] + + +data_files = [('/etc/sfa/', [ 'config/aggregates.xml', + 'config/registries.xml', + 'config/sfa_config', + 'config/sfi_config']), + ('/etc/sfatables/matches/', glob('sfatables/matches/*.xml')), + ('/etc/sfatables/targets/', glob('sfatables/targets/*.xml')), + ('/etc/init.d/', ['sfa/init.d/sfa'])] + +# add sfatables processors as data_files +processor_files = [f for f in glob('sfatables/processors/*') if os.path.isfile(f)] +data_files.append(('/etc/sfatables/processors/', processor_files)) +processor_subdirs = [d for d in glob('sfatables/processors/*') if os.path.isdir(d)] +for d in processor_subdirs: + etc_dir = os.path.join("/etc/sfatables/processors", os.path.basename(d)) + d_files = [f for f in glob(d + '/*') if os.path.isfile(f)] + data_files.append((etc_dir, processor_files)) + initscripts = [ '/etc/init.d/sfa' ] - + if sys.argv[1] in ['uninstall', 'remove', 'delete', 'clean']: python_path = sys.path - site_packages_path = [ path + os.sep + 'sfa' for path in python_path if path.endswith('site-packages')] - remove_dirs = ['/etc/sfa/'] + site_packages_path - remove_files = [ '/usr/bin/sfa-config-tty', - '/usr/bin/sfa-import-plc.py', - '/usr/bin/sfa-nuke-plc.py', - '/usr/bin/sfa-server.py', - '/usr/bin/sfi.py', - '/usr/bin/getNodes.py', - '/usr/bin/getRecord.py', - '/usr/bin/setRecord.py', - '/usr/bin/genidump.py', - ] + initscripts - + site_packages_path = [ os.path.join(p,'sfa') for p in python_path if p.endswith('site-packages')] + site_packages_path += [ os.path.join(p,'sfatables') for p in python_path if p.endswith('site-packages')] + remove_dirs = ['/etc/sfa/', '/etc/sfatables'] + site_packages_path + remove_bins = [ '/usr/bin/' + os.path.basename(bin) for bin in bins ] + remove_files = remove_bins + initscripts + # remove files for filepath in remove_files: print "removing", filepath, "...", @@ -63,15 +79,12 @@ if sys.argv[1] in ['uninstall', 'remove', 'delete', 'clean']: shutil.rmtree(directory) print "success" except: print "failed" - else: - # avoid repeating what's in the specfile already setup(name='sfa', packages = package_dirs, data_files = data_files, ext_modules = [], py_modules = [], - scripts = scripts, - ) + scripts = bins)