Commit e634eccd authored by Guillaume Hervier's avatar Guillaume Hervier

slapgrid: Add methods to SlapObject.Partition for more control

on generated supervisord config
parent ec1481e8
...@@ -438,15 +438,18 @@ class Partition(object): ...@@ -438,15 +438,18 @@ class Partition(object):
gid = stat_info.st_gid gid = stat_info.st_gid
return (uid, gid) return (uid, gid)
def addServiceToGroup(self, partition_id, runner_list, path, extension=''): def addProgramToGroup(self, partition_id, program_id, name, command,
as_user=True):
if as_user:
uid, gid = self.getUserGroupId() uid, gid = self.getUserGroupId()
for runner in runner_list: else:
uid, gid = 0, 0
self.partition_supervisor_configuration += '\n' + \ self.partition_supervisor_configuration += '\n' + \
PROGRAM_PARTITION_TEMPLATE % { PROGRAM_PARTITION_TEMPLATE % {
'program_id': '_'.join([partition_id, runner]), 'program_id': '{}_{}'.format(partition_id, program_id),
'program_directory': self.instance_path, 'program_directory': self.instance_path,
'program_command': os.path.join(path, runner), 'program_command': command,
'program_name': runner + extension, 'program_name': name,
'instance_path': self.instance_path, 'instance_path': self.instance_path,
'user_id': uid, 'user_id': uid,
'group_id': gid, 'group_id': gid,
...@@ -455,17 +458,32 @@ class Partition(object): ...@@ -455,17 +458,32 @@ class Partition(object):
'USER': pwd.getpwuid(uid).pw_name, 'USER': pwd.getpwuid(uid).pw_name,
} }
def addServiceToCustomGroup(self, group_suffix, partition_id, runner_list, def addCustomGroup(self, group_suffix, partition_id, program_list):
path, extension=''):
"""Add new services to supervisord that belong to specific group"""
group_partition_template = pkg_resources.resource_stream(__name__, group_partition_template = pkg_resources.resource_stream(__name__,
'templates/group_partition_supervisord.conf.in').read() 'templates/group_partition_supervisord.conf.in').read()
group_id = '-'.join([partition_id, group_suffix]) group_id = '{}-{}'.format(partition_id, group_suffix)
self.supervisor_configuration_group += group_partition_template % { self.supervisor_configuration_group += group_partition_template % {
'instance_id': group_id, 'instance_id': group_id,
'program_list': ','.join(['_'.join([group_id, runner]) 'program_list': ','.join(['{}_{}'.format(group_id, program_id)
for runner in runner_list]) for program_id in program_list]),
} }
return group_id
def addServiceToGroup(self, partition_id, runner_list, path, extension=''):
for runner in runner_list:
program_id = runner
program_name = runner + extension
program_command = os.path.join(path, runner)
self.addProgramToGroup(partition_id, program_id, program_name,
program_command)
def addServiceToCustomGroup(self, group_suffix, partition_id, runner_list,
path, extension=''):
"""Add new services to supervisord that belong to specific group"""
group_id = self.addCustomGroup(group_suffix, partition_id,
runner_list)
return self.addServiceToGroup(group_id, runner_list, path, extension) return self.addServiceToGroup(group_id, runner_list, path, extension)
def updateSymlink(self, sr_symlink, software_path): def updateSymlink(self, sr_symlink, software_path):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment