Commit 86c3b58f authored by root's avatar root

[WIP] Agent

parent a7cf2ea1
##############################################################################
#
# Copyright (c) 2012 Vifib SARL and Contributors. All Rights Reserved.
#
# WARNING: This program as such is intended to be used by professional
# programmers who take the whole responsibility of assessing all potential
# consequences resulting from its eventual inadequacies and bugs
# End users who are looking for a ready-to-use solution with commercial
# guarantees and support are strongly adviced to contract a Free Software
# Service Company
#
# This program is Free Software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 3
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
#############################################################################
import zc.buildout
from slapos.recipe.librecipe import GenericBaseRecipe
import sys
class Recipe(GenericBaseRecipe):
def install(self):
path_list = []
configuration_path = self.options["config"]
header = """[DEFAULT]
master_url = %s
key = %s
cert = %s
max_install_duration = %s
max_uninstall_duration = %s
max_request_duration = %s
max_destroy_duration = %s
""" % (self.options["master-url"],
"\n ".join(self.options["key"].split("\n")),
"\n ".join(self.options["cert"].split("\n")),
self.options["default_max_install_duration"],
self.options["default_max_uninstall_duration"],
self.options["default_max_request_duration"],
self.options["default_max_destroy_duration"])
with open(configuration_path, "w") as configuration:
configuration.write(header + self.options["configuration"])
path_list.append(self.createPythonScript(
self.options['wrapper'],
'slapos.recipe.librecipe.execute.execute',
[self.options["agent_binary"], '--pidfile=%s' % self.options["pidfile"],
"--log=%s" % self.options["log"], configuration_path]))
path_list.append(configuration_path)
return path_list
import os
import sys
import time
def catdatefile(args):
directory = args[0]
try:
suffix = args[1]
except IndexError:
suffix = '.log'
f = open(os.path.join(directory,
time.strftime('%Y-%m-%d.%H:%M.%s') + suffix), 'aw')
for line in sys.stdin.read():
f.write(line)
f.close()
[agent]
master_url = ${slap-parameter:master_url}
key = ${user-key:output}
cert = ${user-certificate:output}
timeout = ${slap-parameter:timeout}
node_title = ${slap-parameter:node_title}
test_title = ${slap-parameter:test_title}
project_title = ${slap-parameter:project_title}
task_count = ${slap-parameter:task_count}
report_url = ${slap-parameter:report_url}
...@@ -6,28 +6,52 @@ eggs-directory = ${buildout:eggs-directory} ...@@ -6,28 +6,52 @@ eggs-directory = ${buildout:eggs-directory}
develop-eggs-directory = ${buildout:develop-eggs-directory} develop-eggs-directory = ${buildout:develop-eggs-directory}
offline = true offline = true
[directory] [directory]
recipe = slapos.cookbook:mkdirectory recipe = slapos.cookbook:mkdirectory
etc = $${buildout:directory}/etc etc = $${buildout:directory}/etc
run = $${:etc}/run service = $${buildout:directory}/etc/service
run = $${buildout:directory}/etc/run
agentlog = $${buildout:directory}/var/log/agent agentlog = $${buildout:directory}/var/log/agent
srv = $${buildout:directory}/srv srv = $${buildout:directory}/srv
bin = $${buildout:directory}/bin bin = $${buildout:directory}/bin
[instance] [instance]
recipe = slapos.cookbook:agent recipe = slapos.cookbook:wrapper
agent_binary = ${buildout:directory}/bin/agent command-line =
pidfile = $${directory:srv}/agent.pid ${buildout:bin-directory}/agent
log = $${directory:agentlog}/agent.log --pidfile=$${directory:srv}/agent.pid
wrapper = $${directory:run}/agent --log=$${directory:agentlog}/agent.log
config = $${directory:etc}/agent.cfg $${agent-cfg:output}
master-url = $${slap-parameter:master-url}
key = $${slap-parameter:userkey} wrapper-path = $${directory:service}/agent
cert = $${slap-parameter:usercertificate} output = $${:wrapper-path}
configuration = $${slap-parameter:configuration}
default_max_install_duration = $${slap-parameter:default_max_install_duration} [agent-cfg]
default_max_uninstall_duration = $${slap-parameter:default_max_uninstall_duration} recipe = slapos.recipe.template
default_max_request_duration = $${slap-parameter:default_max_request_duration} url = ${agent.cfg.in:output}
default_max_destroy_duration = $${slap-parameter:default_max_destroy_duration} output = $${directory:etc}/agent.cfg
[user-key]
recipe = slapos.recipe.template
url = ${configuration.template:output}
output = $${directory:etc}/certificate.key
content = $${slap-parameter:user_key}
[user-certificate]
recipe = slapos.recipe.template
url = ${configuration.template:output}
output = $${directory:etc}/certificate.crt
content = $${slap-parameter:user_certificate}
[slap-parameter]
timeout = 3600
configuration_url =
user_key =
user_certificate =
master_url =
node_title =
test_title =
project_title =
task_count = 1
report_url =
...@@ -4,40 +4,25 @@ extends = ...@@ -4,40 +4,25 @@ extends =
../../component/git/buildout.cfg ../../component/git/buildout.cfg
../../stack/slapos.cfg ../../stack/slapos.cfg
develop =
${:parts-directory}/slapos.cookbook-repository
${:parts-directory}/slapos.toolbox-repository
parts = parts =
template template
template-agent template-agent
slapos.cookbook-repository
slapos.toolbox-repository
check-recipe
slapos-cookbook slapos-cookbook
script script
# Local development [configuration.template]
[slapos.cookbook-repository] recipe = slapos.recipe.download
recipe = slapos.recipe.build:gitclone url = ${:_profile_base_location_}/configuration.template
repository = http://git.erp5.org/repos/slapos.git output = ${buildout:directory}/parts/configuration.template/configuration.template
branch = agent md5sum = b9cf97ba7a70423119519337112adbd2
git-executable = ${git:location}/bin/git mode = 0644
[slapos.toolbox-repository]
recipe = slapos.recipe.build:gitclone
repository = http://git.erp5.org/repos/slapos.toolbox.git
branch = agent3
git-executable = ${git:location}/bin/git
[check-recipe] [agent.cfg.in]
recipe = plone.recipe.command recipe = slapos.recipe.download
stop-on-error = true url = ${:_profile_base_location_}/agent.cfg.in
update-command = ${:command} output = ${buildout:directory}/parts/agent.cfg.in/agent.cfg.in
command = md5sum = 390c12441e813533d55c9f981e8162b6
grep parts ${buildout:develop-eggs-directory}/slapos.cookbook.egg-link; mode = 0644
grep parts ${buildout:develop-eggs-directory}/slapos.toolbox.egg-link
[template] [template]
recipe = slapos.recipe.template recipe = slapos.recipe.template
...@@ -50,7 +35,7 @@ mode = 0644 ...@@ -50,7 +35,7 @@ mode = 0644
recipe = slapos.recipe.template recipe = slapos.recipe.template
url = ${:_profile_base_location_}/instance-agent.cfg url = ${:_profile_base_location_}/instance-agent.cfg
output = ${buildout:directory}/template-agent.cfg output = ${buildout:directory}/template-agent.cfg
md5sum = 7c5c43eb98d5a11961d72fce97a8e67b md5sum = 19c6387fd0d542fd1d7b01e3445f6735
mode = 0644 mode = 0644
[script] [script]
...@@ -60,3 +45,43 @@ eggs = ...@@ -60,3 +45,43 @@ eggs =
slapos.core slapos.core
slapos.toolbox[agent] slapos.toolbox[agent]
erp5.util erp5.util
[versions]
apache-libcloud = 0.17.0
ecdsa = 0.13
erp5.util = 0.4.42
gitdb = 0.6.4
pycrypto = 2.6.1
slapos.recipe.download = 1.0
slapos.recipe.template = 2.8
slapos.toolbox = 0.50
smmap = 0.9.0
# Required by:
# slapos.toolbox==0.50
GitPython = 1.0.1
# Required by:
# slapos.toolbox==0.50
atomize = 0.2.0
# Required by:
# apache-libcloud==0.17.0
backports.ssl-match-hostname = 3.4.0.2
# Required by:
# slapos.toolbox==0.50
feedparser = 5.2.1
# Required by:
# slapos.toolbox==0.50
lockfile = 0.10.2
# Required by:
# slapos.toolbox==0.50
paramiko = 1.15.2
# Required by:
# slapos.toolbox==0.50
rpdb = 0.1.5
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