X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=setup.py;h=f0f89a49546174270b89737dc2240347386c16d5;hb=refs%2Fheads%2Ftrunk%4014639;hp=6ca820dc42cca56e2b1e6619da704c9560376092;hpb=7242b5b14505ea15db8f4d9116184a81a201ed79;p=sfa.git diff --git a/setup.py b/setup.py index 6ca820dc..f0f89a49 100755 --- a/setup.py +++ b/setup.py @@ -1,50 +1,83 @@ #!/usr/bin/python """ -Installation script for the geniwrapper module +Installation script for the sfa module """ import sys, os, os.path +from glob import glob import shutil from distutils.core import setup -bins = [ 'config/sfa-config-tty', - 'sfa/plc/sfa-import-plc.py', - 'sfa/plc/sfa-nuke-plc.py', - 'sfa/server/sfa-server.py', - 'sfa/client/sfi.py', - 'sfa/client/getNodes.py', - 'sfa/client/getRecord.py', - 'sfa/client/setRecord.py', - 'sfa/client/genidump.py', - ] -remove_bins = [ '/usr/bin/' + os.path.basename(bin) for bin in bins ] +bins = [ + 'config/sfa-config-tty', + 'config/gen-sfa-cm-config.py', + 'sfa/plc/sfa-import-plc.py', + 'sfa/plc/sfa-nuke-plc.py', + 'sfa/server/sfa-ca.py', + 'sfa/server/sfa-server.py', + 'sfa/server/sfa-clean-peer-records.py', + 'sfa/server/sfa_component_setup.py', + 'sfa/client/sfi.py', + 'sfa/client/getNodes.py', + 'sfa/client/getRecord.py', + 'sfa/client/setRecord.py', + 'sfa/client/sfadump.py', + 'sfa/client/sfiListNodes.py', + 'sfa/client/sfiListSlivers.py', + 'sfa/client/sfiAddSliver.py', + 'sfa/client/sfiDeleteSliver.py', + 'sfa/client/sfiAddAttribute.py', + 'sfa/client/sfiDeleteAttribute.py', + 'sfatables/sfatables', + 'keyconvert/keyconvert.py' + ] + +package_dirs = [ + 'sfa', + 'sfa/client', + 'sfa/methods', + 'sfa/plc', + 'sfa/server', + 'sfa/trust', + 'sfa/util', + 'sfa/managers', + 'sfa/rspecs', + 'sfa/rspecs/aggregates', + 'sfatables', + 'sfatables/commands', + 'sfatables/processors', + ] + + +data_files = [('/etc/sfa/', [ 'config/aggregates.xml', + 'config/registries.xml', + 'config/default_config.xml', + 'config/sfi_config', + 'sfa/managers/pl/pl.rng']), + ('/etc/sfatables/matches/', glob('sfatables/matches/*.xml')), + ('/etc/sfatables/targets/', glob('sfatables/targets/*.xml')), + ('/etc/init.d/', ['sfa/init.d/sfa', 'sfa/init.d/sfa-cm'])] + +# 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', '/etc/init.d/sfa-cm' ] -package_dirs = [ 'sfa', - 'sfa/client', - 'sfa/methods', - 'sfa/plc', - 'sfa/server', - 'sfa/trust', - 'sfa/util', - 'sfa/rspecs', - 'sfa/rspecs/aggregates' - ] -data_files = [ ('/etc/sfa/', [ 'config/aggregates.xml', - 'config/registries.xml', - 'config/sfa_config', - 'config/sfi_config', - ]), - ('/etc/init.d/', ['sfa/init.d/sfa']), - ] -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 + 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, "...", @@ -59,15 +92,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 = bins, - ) + scripts = bins)