diff options
-rw-r--r-- | doc/1.0-roadmap | 2 | ||||
-rw-r--r-- | doc/plugin-roles | 7 | ||||
-rw-r--r-- | src/lib/Server/Admin/Minestruct.py | 1 | ||||
-rw-r--r-- | src/lib/Server/Core.py | 50 | ||||
-rw-r--r-- | src/lib/Server/Plugin.py | 7 | ||||
-rw-r--r-- | src/lib/Server/Plugins/Git.py | 45 | ||||
-rw-r--r-- | src/lib/Server/Plugins/Svn.py | 44 | ||||
-rw-r--r-- | src/lib/Server/Plugins/__init__.py | 4 | ||||
-rwxr-xr-x | src/sbin/bcfg2-info | 7 | ||||
-rwxr-xr-x | src/sbin/bcfg2-server | 2 |
10 files changed, 115 insertions, 54 deletions
diff --git a/doc/1.0-roadmap b/doc/1.0-roadmap index 2daebb9d5..840de3e85 100644 --- a/doc/1.0-roadmap +++ b/doc/1.0-roadmap @@ -8,8 +8,8 @@ server. *** Build a comprehensive server plugin architecture *** make out of tree plugins work *** properties switch to connector plugin -** Left *** Version Control Backend +** Left *** Fix the POSIX path problem *** Clean up client/server statistics data format *** Multithreaded server (sync from Cobalt) diff --git a/doc/plugin-roles b/doc/plugin-roles index 03207fd4f..c8c47aa93 100644 --- a/doc/plugin-roles +++ b/doc/plugin-roles @@ -14,6 +14,7 @@ This documents available plugin roles. | Statistics | Statistics | done | | Pull Source | PullSource | done | | Pull Target | PullTarget | done | +| Version | Version | started| | Decision | Decision | done | | Remote | Remote | none | | Syncing | Syncing | none | @@ -44,6 +45,10 @@ This documents available plugin roles. ** Plugin can provide entry information about clients * Pull Target ** Plugin can accept entry data and merge it into the specification +* Version +** Plugin can read revision information from VCS of choice +** Will provide an interface for producing commits made by the + bcfg2-server * Decision 3) Configuration of plugins @@ -82,4 +87,4 @@ Statistics (if used) should be listed in the plugins line of bcfg2.conf. 5) Notes -* Need to ensure bundle accumulation occurs with connector groups
\ No newline at end of file +* Need to ensure bundle accumulation occurs with connector groups diff --git a/src/lib/Server/Admin/Minestruct.py b/src/lib/Server/Admin/Minestruct.py index 350833080..743641bc6 100644 --- a/src/lib/Server/Admin/Minestruct.py +++ b/src/lib/Server/Admin/Minestruct.py @@ -51,7 +51,6 @@ class Minestruct(Bcfg2.Server.Admin.StructureMode): for source in self.bcore.pull_sources: for item in source.GetExtra(client): extra.add(item) - print extra except: self.log.error("Failed to find extra entry info for client %s" % client) diff --git a/src/lib/Server/Core.py b/src/lib/Server/Core.py index b7a187c57..ad5573201 100644 --- a/src/lib/Server/Core.py +++ b/src/lib/Server/Core.py @@ -1,10 +1,6 @@ '''Bcfg2.Server.Core provides the runtime support for bcfg2 modules''' __revision__ = '$Revision$' -from ConfigParser import ConfigParser, NoSectionError, NoOptionError -c = ConfigParser() -c.read('/etc/bcfg2.conf') - from time import time from Bcfg2.Server.Plugin import PluginInitError, PluginExecutionError @@ -28,7 +24,7 @@ class CoreInitError(Exception): class Core(object): '''The Core object is the container for all Bcfg2 Server logic, and modules''' - def __init__(self, repo, plugins, password, vcs, encoding, + def __init__(self, repo, plugins, password, encoding, filemonitor='default'): object.__init__(self) self.datastore = repo @@ -46,14 +42,6 @@ class Core(object): self.revision = '-1' self.password = password self.encoding = encoding - try: - self.vcs = c.get('server', 'vcs') - if self.vcs == 'svn': - self.read_svn_revision() - elif self.vcs == 'git': - self.read_git_revision() - except: - self.vcs = 'none' if '' in plugins: plugins.remove('') @@ -224,37 +212,11 @@ class Core(object): '''Perform periodic update tasks''' count = self.fam.Service() if count: - if self.vcs == 'svn': - self.read_svn_revision() - elif self.vcs == 'git': - self.read_git_revision() - - def read_git_revision(self): - try: - data = os.popen("env LC_ALL=C git ls-remote %s" % - (self.datastore)).readlines() - revline = [line.split('\t')[0].strip() for line in data if \ - line.split('\t')[1].strip() == 'refs/heads/master'][-1] - self.revision = revline - except IndexError: - logger.error("Failed to read git ls-remote; disabling git support") - logger.error('''Ran command "git ls-remote %s"''' % (self.datastore)) - logger.error("Got output: %s" % data) - self.vcs = 'none' - - def read_svn_revision(self): - '''Read svn revision information for the bcfg2 repository''' - try: - data = os.popen("env LC_ALL=C svn info %s" \ - % (self.datastore)).readlines() - revline = [line.split(': ')[1].strip() for line in data \ - if line[:9] == 'Revision:'][-1] - self.revision = revline - except IndexError: - logger.error("Failed to read svn info; disabling svn support") - logger.error('''Ran command "svn info %s"''' % (self.datastore)) - logger.error("Got output: %s" % data) - self.vcs = 'none' + for plugin in self.plugins.values(): + if isinstance(plugin, Bcfg2.Server.Plugin.Version): + self.revision = plugin.get_revision() + else: + self.revision = -1 def GetDecisions(self, metadata, mode): result = [] diff --git a/src/lib/Server/Plugin.py b/src/lib/Server/Plugin.py index 8d702d435..21699657f 100644 --- a/src/lib/Server/Plugin.py +++ b/src/lib/Server/Plugin.py @@ -137,6 +137,13 @@ class GoalValidator(object): def validate_goals(self, metadata, goals): raise ValidationError, "not implemented" +class Version(object): + '''Interact with various version control systems''' + def get_revision(self): + return [] + def commit_data(self): + pass + # the rest of the file contains classes for coherent file caching class FileBacked(object): diff --git a/src/lib/Server/Plugins/Git.py b/src/lib/Server/Plugins/Git.py new file mode 100644 index 000000000..1c17c8e47 --- /dev/null +++ b/src/lib/Server/Plugins/Git.py @@ -0,0 +1,45 @@ +import os +import Bcfg2.Server.Plugin + +# for debugging output only +import logging +logger = logging.getLogger('Bcfg2.Plugins.Git') + +class Git(Bcfg2.Server.Plugin.Plugin, + Bcfg2.Server.Plugin.Version): + name = 'Git' + __version__ = '$Id$' + __author__ = 'bcfg-dev@mcs.anl.gov' + + def __init__(self, core, datastore): + Bcfg2.Server.Plugin.Plugin.__init__(self, core, datastore) + self.core = core + self.datastore = datastore + + # path to git directory for bcfg2 repo + git_dir = "%s/.git" % datastore + + # Read revision from bcfg2 repo + if os.path.isdir(git_dir): + self.get_revision() + else: + logger.error("%s is not a directory" % git_dir) + raise Bcfg2.Server.Plugin.PluginInitError + + logger.debug("Initialized git plugin with git directory = %s" % git_dir) + + def get_revision(self): + '''Read git revision information for the bcfg2 repository''' + try: + data = os.popen("env LC_ALL=C git ls-remote %s" % + (self.datastore)).readlines() + revline = [line.split('\t')[0].strip() for line in data if \ + line.split('\t')[1].strip() == 'refs/heads/master'][-1] + revision = revline + except IndexError: + logger.error("Failed to read git ls-remote; disabling git support") + logger.error('''Ran command "git ls-remote %s"''' % \ + (self.datastore)) + logger.error("Got output: %s" % data) + raise Bcfg2.Server.Plugin.PluginInitError + return revision diff --git a/src/lib/Server/Plugins/Svn.py b/src/lib/Server/Plugins/Svn.py new file mode 100644 index 000000000..269c3173b --- /dev/null +++ b/src/lib/Server/Plugins/Svn.py @@ -0,0 +1,44 @@ +import os +import Bcfg2.Server.Plugin + +# for debugging output only +import logging +logger = logging.getLogger('Bcfg2.Plugins.Svn') + +class Svn(Bcfg2.Server.Plugin.Plugin, + Bcfg2.Server.Plugin.Version): + name = 'Svn' + __version__ = '$Id$' + __author__ = 'bcfg-dev@mcs.anl.gov' + + def __init__(self, core, datastore): + Bcfg2.Server.Plugin.Plugin.__init__(self, core, datastore) + self.core = core + self.datastore = datastore + + # path to svn directory for bcfg2 repo + svn_dir = "%s/.svn" % datastore + + # Read revision from bcfg2 repo + if os.path.isdir(svn_dir): + self.get_revision() + else: + logger.error("%s is not a directory" % svn_dir) + raise Bcfg2.Server.Plugin.PluginInitError + + logger.debug("Initialized svn plugin with svn directory = %s" % svn_dir) + + def get_revision(self): + '''Read svn revision information for the bcfg2 repository''' + try: + data = os.popen("env LC_ALL=C svn info %s" \ + % (self.datastore)).readlines() + revline = [line.split(': ')[1].strip() for line in data \ + if line[:9] == 'Revision:'][-1] + revision = revline + except IndexError: + logger.error("Failed to read svn info; disabling svn support") + logger.error('''Ran command "svn info %s"''' % (self.datastore)) + logger.error("Got output: %s" % data) + raise Bcfg2.Server.Plugin.PluginInitError + return revision diff --git a/src/lib/Server/Plugins/__init__.py b/src/lib/Server/Plugins/__init__.py index 1e5c122c8..6382adbaf 100644 --- a/src/lib/Server/Plugins/__init__.py +++ b/src/lib/Server/Plugins/__init__.py @@ -1,7 +1,7 @@ '''imports for Bcfg2.Server.Plugins''' __revision__ = '$Revision$' -__all__ = ['Account', 'Base', 'Bundler', 'Cfg', 'Decisions', 'GBundler', +__all__ = ['Account', 'Base', 'Bundler', 'Cfg', 'Decisions', 'GBundler', 'Git', 'Hostbase', 'Metadata', 'NagiosGen', 'Packages', 'Properties', 'Probes', 'Pkgmgr', 'Rules', 'SSHbase', 'Statistics', 'Svcmgr', - 'TCheetah', 'SGenshi', 'TGenshi', 'Vhost'] + 'Svn', 'TCheetah', 'SGenshi', 'TGenshi', 'Vhost'] diff --git a/src/sbin/bcfg2-info b/src/sbin/bcfg2-info index bd04b599a..4d4e1aea1 100755 --- a/src/sbin/bcfg2-info +++ b/src/sbin/bcfg2-info @@ -25,10 +25,10 @@ def printTabular(rows): class infoCore(cmd.Cmd, Bcfg2.Server.Core.Core): - def __init__(self, repo, plgs, passwd, vcs, encoding, event_debug): + def __init__(self, repo, plgs, passwd, encoding, event_debug): cmd.Cmd.__init__(self) try: - Bcfg2.Server.Core.Core.__init__(self, repo, plgs, passwd, vcs, + Bcfg2.Server.Core.Core.__init__(self, repo, plgs, passwd, encoding) if event_debug: self.fam.debug = True @@ -294,7 +294,6 @@ if __name__ == '__main__': 'help': Bcfg2.Options.HELP, } optinfo.update({'repo': Bcfg2.Options.SERVER_REPOSITORY, - 'vcs': Bcfg2.Options.SERVER_VCS, 'plugins': Bcfg2.Options.SERVER_PLUGINS, 'password': Bcfg2.Options.SERVER_PASSWORD, 'event debug': Bcfg2.Options.DEBUG, @@ -303,7 +302,7 @@ if __name__ == '__main__': setup.parse(sys.argv[1:]) print setup loop = infoCore(setup['repo'], setup['plugins'], - setup['password'], setup['vcs'], setup['encoding'], + setup['password'], setup['encoding'], '-d' in sys.argv) if "args" in setup and setup['args']: loop.onecmd(" ".join(setup['args'])) diff --git a/src/sbin/bcfg2-server b/src/sbin/bcfg2-server index 0c1c5d01c..e75579376 100755 --- a/src/sbin/bcfg2-server +++ b/src/sbin/bcfg2-server @@ -35,7 +35,7 @@ class Bcfg2Serv(Bcfg2.Component.Component): try: self.Core = Core(setup['repo'], setup['plugins'], setup['password'], - setup['vcs'], setup['encoding'], setup['filemonitor']) + setup['encoding'], setup['filemonitor']) except CoreInitError, msg: logger.critical("Fatal error: %s" % (msg)) raise SystemExit, 1 |