[slap-parameters] recipe = slapos.cookbook:slapconfiguration computer = $${slap-connection:computer-id} partition = $${slap-connection:partition-id} url = $${slap-connection:server-url} key = $${slap-connection:key-file} cert = $${slap-connection:cert-file} [monitor-parameters] json-filename = monitor.json json-path = $${monitor-directory:monitor-result}/$${:json-filename} rss-filename = rssfeed.html rss-path = $${monitor-directory:public-cgi}/$${:rss-filename} executable = $${monitor-directory:bin}/monitor.py port = 9685 htaccess-file = $${monitor-directory:etc}/.htaccess-monitor url = https://[$${slap-parameters:ipv6-random}]:$${:port} index-filename = index.cgi index-path = $${monitor-directory:www}/$${:index-filename} db-path = $${monitor-directory:etc}/monitor.db monitor-password-path = $${monitor-directory:etc}/.monitor.shadow [monitor-directory] recipe = slapos.cookbook:mkdirectory # Standard directory needed by monitoring stack home = $${buildout:directory} etc = $${:home}/etc bin = $${:home}/bin srv = $${:home}/srv var = $${:home}/var log = $${:var}/log run = $${:var}/run service = $${:etc}/service/ etc-run = $${:etc}/run/ tmp = $${:home}/tmp promise = $${:etc}/promise cron-entries = $${:etc}/cron.d crontabs = $${:etc}/crontabs cronstamps = $${:etc}/cronstamps ca-dir = $${:srv}/ssl www = $${:var}/www cgi-bin = $${:var}/cgi-bin monitoring-cgi = $${:cgi-bin}/monitoring knowledge0-cgi = $${:cgi-bin}/zero-knowledge public-cgi = $${:cgi-bin}/public monitor-custom-scripts = $${:etc}/monitor monitor-result = $${:var}/monitor private-directory = $${:srv}/monitor-private [public-symlink] recipe = cns.recipe.symlink symlink = $${monitor-directory:public-cgi} = $${monitor-directory:www}/public autocreate = true [cron] recipe = slapos.cookbook:cron dcrond-binary = ${dcron:location}/sbin/crond cron-entries = $${monitor-directory:cron-entries} crontabs = $${monitor-directory:crontabs} cronstamps = $${monitor-directory:cronstamps} catcher = $${cron-simplelogger:wrapper} binary = $${monitor-directory:service}/crond # Add log to cron [cron-simplelogger] recipe = slapos.cookbook:simplelogger wrapper = $${monitor-directory:bin}/cron_simplelogger log = $${monitor-directory:log}/cron.log [cron-entry-monitor] <= cron recipe = slapos.cookbook:cron.d name = launch-monitor frequency = */5 * * * * command = $${deploy-monitor-script:rendered} -a [cron-entry-rss] <= cron recipe = slapos.cookbook:cron.d name = build-rss frequency = */5 * * * * command = $${make-rss:rendered} [setup-static-files] recipe = hexagonit.recipe.download url = ${download-monitor-static:destination}/${download-monitor-static:filename} filename = static destination = $${monitor-directory:www} ignore-existing = true strip-top-level-dir = true mode = 0644 [deploy-index] recipe = slapos.recipe.template:jinja2 template = ${index:location}/${index:filename} rendered = $${monitor-parameters:index-path} update-apache-access = ${apache:location}/bin/htpasswd -cb $${monitor-parameters:htaccess-file} admin mode = 0744 context = key cgi_directory monitor-directory:cgi-bin raw index_template $${deploy-index-template:location}/$${deploy-index-template:filename} key monitor_password_path monitor-parameters:monitor-password-path key monitor_password_script_path deploy-monitor-password-cgi:rendered key apache_update_command :update-apache-access raw extra_eggs_interpreter ${buildout:directory}/bin/${extra-eggs:interpreter} raw default_page /welcome.html [deploy-index-template] recipe = hexagonit.recipe.download url = ${index-template:location}/$${:filename} destination = $${monitor-directory:www} filename = ${index-template:filename} download-only = true mode = 0644 [deploy-status-cgi] recipe = slapos.recipe.template:jinja2 template = ${status-cgi:location}/${status-cgi:filename} rendered = $${monitor-directory:monitoring-cgi}/$${:filename} filename = status.cgi mode = 0744 context = key json_file monitor-parameters:json-path key monitor_bin monitor-parameters:executable key pwd monitor-directory:monitoring-cgi key this_file :filename raw python_executable ${buildout:executable} [deploy-status-history-cgi] recipe = slapos.recipe.template:jinja2 template = ${status-history-cgi:location}/${status-history-cgi:filename} rendered = $${monitor-directory:monitoring-cgi}/$${:filename} filename = status-history.cgi mode = 0744 context = key monitor_db_path monitor-parameters:db-path key status_history_length zero-parameters:status-history-length raw python_executable ${buildout:executable} [deploy-settings-cgi] recipe = slapos.recipe.template:jinja2 template = ${settings-cgi:location}/${settings-cgi:filename} rendered = $${monitor-directory:knowledge0-cgi}/$${:filename} filename = settings.cgi mode = 0744 context = raw config_cfg $${buildout:directory}/knowledge0.cfg raw timestamp $${buildout:directory}/.timestamp raw python_executable ${buildout:executable} key pwd monitor-directory:knowledge0-cgi key this_file :filename [deploy-monitor-password-cgi] recipe = slapos.recipe.template:jinja2 template = ${monitor-password-cgi:location}/${monitor-password-cgi:filename} rendered = $${monitor-directory:knowledge0-cgi}/$${:filename} filename = monitor-password.cgi mode = 0744 context = raw python_executable ${buildout:executable} key pwd monitor-directory:knowledge0-cgi key this_file :filename [deploy-monitor-script] recipe = slapos.recipe.template:jinja2 template = ${monitor-bin:location}/${monitor-bin:filename} rendered = $${monitor-parameters:executable} mode = 0744 context = section directory monitor-directory section monitor_parameter monitor-parameters key monitoring_file_json monitor-parameters:json-path raw python_executable ${buildout:executable} [make-rss] recipe = slapos.recipe.template:jinja2 template = ${make-rss-script:output} rendered = $${monitor-directory:bin}/make-rss.sh mode = 0744 context = section directory monitor-directory section monitor_parameters monitor-parameters [monitor-directory-access] recipe = plone.recipe.command command = ln -s $${:source} $${monitor-directory:private-directory} source = [monitor-instance-log-access] recipe = plone.recipe.command command = if [ -d $${:source} ]; then ln -s $${:source} $${monitor-directory:private-directory}/instance-logs; fi update-command = if [ -d $${:source} ]; then ln -s $${:source} $${monitor-directory:private-directory}/instance-logs; fi source = $${monitor-directory:home}/.slapgrid/log/ [cadirectory] recipe = slapos.cookbook:mkdirectory requests = $${monitor-directory:ca-dir}/requests/ private = $${monitor-directory:ca-dir}/private/ certs = $${monitor-directory:ca-dir}/certs/ newcerts = $${monitor-directory:ca-dir}/newcerts/ crl = $${monitor-directory:ca-dir}/crl/ [certificate-authority] recipe = slapos.cookbook:certificate_authority openssl-binary = ${openssl:location}/bin/openssl ca-dir = $${monitor-directory:ca-dir} requests-directory = $${cadirectory:requests} wrapper = $${monitor-directory:service}/certificate_authority ca-private = $${cadirectory:private} ca-certs = $${cadirectory:certs} ca-newcerts = $${cadirectory:newcerts} ca-crl = $${cadirectory:crl} [ca-httpd] <= certificate-authority recipe = slapos.cookbook:certificate_authority.request key-file = $${cadirectory:certs}/httpd.key cert-file = $${cadirectory:certs}/httpd.crt executable = $${monitor-directory:bin}/cgi-httpd wrapper = $${monitor-directory:service}/cgi-httpd # Put domain name name = example.com ########### # Deploy a webserver running cgi scripts for monitoring ########### [public] recipe = slapos.cookbook:zero-knowledge.write filename = knowledge0.cfg status-history-length = 5 [zero-parameters] recipe = slapos.cookbook:zero-knowledge.read filename = $${public:filename} # XXX could it be something lighter? [cgi-httpd-configuration-file] recipe = collective.recipe.template input = inline: PidFile "$${:pid-file}" ServerName example.com ServerAdmin someone@email <IfDefine !MonitorPort> Listen [$${:listening-ip}]:$${monitor-parameters:port} Define MonitorPort </IfDefine> DocumentRoot "$${:document-root}" ErrorLog "$${:error-log}" LoadModule unixd_module modules/mod_unixd.so LoadModule access_compat_module modules/mod_access_compat.so LoadModule authz_core_module modules/mod_authz_core.so LoadModule authn_core_module modules/mod_authn_core.so LoadModule authz_host_module modules/mod_authz_host.so LoadModule mime_module modules/mod_mime.so LoadModule cgid_module modules/mod_cgid.so LoadModule dir_module modules/mod_dir.so LoadModule ssl_module modules/mod_ssl.so LoadModule alias_module modules/mod_alias.so LoadModule autoindex_module modules/mod_autoindex.so LoadModule auth_basic_module modules/mod_auth_basic.so LoadModule authz_user_module modules/mod_authz_user.so LoadModule authn_file_module modules/mod_authn_file.so # SSL Configuration <IfDefine !SSLConfigured> Define SSLConfigured SSLCertificateFile $${ca-httpd:cert-file} SSLCertificateKeyFile $${ca-httpd:key-file} SSLRandomSeed startup builtin SSLRandomSeed connect builtin SSLRandomSeed startup /dev/urandom 256 SSLRandomSeed connect builtin SSLProtocol -ALL +SSLv3 +TLSv1 SSLHonorCipherOrder On SSLCipherSuite RC4-SHA:HIGH:!ADH </IfDefine> SSLEngine On ScriptSock $${:cgid-pid-file} <Directory $${:document-root}> SSLVerifyDepth 1 SSLRequireSSL SSLOptions +StrictRequire # XXX: security???? Options +ExecCGI AddHandler cgi-script .cgi DirectoryIndex $${monitor-parameters:index-filename} </Directory> Alias /private/ $${monitor-directory:private-directory}/ <Directory $${monitor-directory:private-directory}> Order Deny,Allow Deny from env=AUTHREQUIRED <Files ".??*"> Order Allow,Deny Deny from all </Files> AuthType Basic AuthName "Private access" AuthUserFile "$${monitor-parameters:htaccess-file}" Require valid-user Options Indexes FollowSymLinks Satisfy all </Directory> output = $${monitor-directory:etc}/cgi-httpd.conf listening-ip = $${slap-parameters:ipv6-random} # XXX: randomize-me htdocs = $${monitor-directory:www} pid-file = $${monitor-directory:run}/cgi-httpd.pid cgid-pid-file = $${monitor-directory:run}/cgi-httpd-cgid.pid document-root = $${monitor-directory:www} error-log = $${monitor-directory:log}/cgi-httpd-error-log [cgi-httpd-wrapper] recipe = slapos.cookbook:wrapper apache-executable = ${apache:location}/bin/httpd command-line = $${:apache-executable} -f $${cgi-httpd-configuration-file:output} -DFOREGROUND wrapper-path = $${ca-httpd:executable} [cgi-httpd-graceful-wrapper] recipe = slapos.cookbook:wrapper command-line = kill -USR1 $(cat $${cgi-httpd-configuration-file:pid-file}) wrapper-path = $${monitor-directory:etc-run}/cgi-httpd-graceful [monitor-promise] recipe = slapos.cookbook:check_url_available path = $${monitor-directory:promise}/monitor url = $${monitor-parameters:url}/$${monitor-parameters:index-filename} check-secure = 1 dash_path = ${dash:location}/bin/dash curl_path = ${curl:location}/bin/curl [publish-connection-informations] recipe = slapos.cookbook:publish monitor_url = $${monitor-parameters:url}