--- a/playbook-example.yml Mon Jul 16 08:29:38 2018 +0000
+++ b/playbook-example.yml Mon Jul 16 16:31:47 2018 +0800
\ No newline at end of file
+ # NOTE: you probably don't want to run these pre_tasks on a real box. Just
+ # bear in mind that to be able to access hgweb from inside the box, you
+ # need to use the virtual host name (i.e. http://127.0.0.1/ won't work).
+ # So make sure you either have DNS records for hg.mydomain or it's in
+ - name: Update /etc/hosts
+ line: '127.0.0.1 {{ hostname }} hg.{{ hostname }}'
+ # NOTE: hgweb role depends on Apache httpd (and mod_wsgi) being installed.
+ # It's recommended to install them in a separate apache2 role, not in
+ # pre_tasks like in this example playbook.
+ - name: Install Apache httpd
+ - name: Enable mod_wsgi
+ - name: Disable default Apache httpd site
+ path: /etc/apache2/sites-enabled/000-default.conf
+ # NOTE: hgweb role notifies this handler:
+ # Naturally, the handler is not defined in the role itself, so this example
+ # playbook includes it here.
+ - name: restart apache2
+# NOTE: how to test that it works correctly (also see the note about DNS):
+# curl -I http://hg.mydomain/
+# will check hgweb pages, look for "200 Script output follows" status
+# curl -I http://hg.mydomain/static/mercurial.js
+# will check serving static files via Apache httpd, look for "200 OK" status
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/defaults/main.yml Mon Jul 16 16:31:47 2018 +0800
+hgweb_contact: 'Me Myself <me@mydomain>'
+hgweb_mercurial_url: https://www.mercurial-scm.org/repo/hg
+hgweb_mercurial_rev: stable
+hgweb_evolve_url: https://www.mercurial-scm.org/repo/evolve
+hgweb_evolve_rev: stable
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/files/robots.txt Mon Jul 16 16:31:47 2018 +0800
+Disallow: /*/comparison/
+# Graph page is a more expensive log
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/handlers/main.yml Mon Jul 16 16:31:47 2018 +0800
+ command: make --directory /home/{{ hgweb_user }}/hg/ local
+ become_user: '{{ hgweb_user }}'
+ path: /home/{{ hgweb_user }}/hgwebfiles/hgweb.wsgi
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/tasks/appinstall.yml Mon Jul 16 16:31:47 2018 +0800
+- name: Ensure required directories exist
+ path: /home/{{ hgweb_user }}/{{ item }}/
+- name: Pull Mercurial {{ hgweb_mercurial_rev }}
+ repo: '{{ hgweb_mercurial_url }}'
+ dest: /home/{{ hgweb_user }}/hg/
+ revision: '{{ hgweb_mercurial_rev }}'
+- name: Pull Evolve {{ hgweb_evolve_rev }}
+ repo: '{{ hgweb_evolve_url }}'
+ dest: /home/{{ hgweb_user }}/evolve/
+ revision: '{{ hgweb_evolve_rev }}'
+- name: Add config files
+ dest: /home/{{ hgweb_user }}/hgwebfiles/{{ item }}
+ dest: /home/{{ hgweb_user }}/hgwebfiles/robots.txt
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/tasks/main.yml Mon Jul 16 16:31:47 2018 +0800
+ name: '{{ hgweb_user }}'
+- name: Install packages
+ tags: [packages, inert]
+- include: appinstall.yml
+ become_user: '{{ hgweb_user }}'
+- name: Add {{ hgweb_subdomain }}.{{ hostname }} Apache httpd site
+ src: etc/apache2/sites-available/hgweb.conf
+ dest: /etc/apache2/sites-available/{{ hgweb_subdomain }}.{{ hostname }}.conf
+- name: Enable {{ hgweb_subdomain }}.{{ hostname }} Apache httpd site
+ src: /etc/apache2/sites-available/{{ hgweb_subdomain }}.{{ hostname }}.conf
+ dest: /etc/apache2/sites-enabled/050-{{ hgweb_subdomain }}.{{ hostname }}.conf
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/templates/etc/apache2/sites-available/hgweb.conf Mon Jul 16 16:31:47 2018 +0800
+ ServerName {{ hgweb_subdomain }}.{{ hostname }}
+ ServerAdmin webmaster@{{ hostname }}
+ DocumentRoot /home/{{ hgweb_user }}/hg/mercurial/templates
+ ErrorLog ${APACHE_LOG_DIR}/{{ hgweb_subdomain }}.{{ hostname }}.error.log
+ CustomLog ${APACHE_LOG_DIR}/{{ hgweb_subdomain }}.{{ hostname }}.access.log combined
+ WSGIScriptAlias / /home/{{ hgweb_user }}/hgwebfiles/hgweb.wsgi
+ WSGIDaemonProcess hgweb user='{{ hgweb_user }}'
+# home=/home/{{ hgweb_user }}/hgwebfiles/
+# group='{{ hgweb_user }}'
+# processes=2 maximum-requests=100
+ Alias /static/ /home/{{ hgweb_user }}/hg/mercurial/templates/static/
+ <Directory /home/{{ hgweb_user }}/hg/mercurial/templates/static>
+ Alias /robots.txt /home/{{ hgweb_user }}/hgwebfiles/robots.txt
+ <Directory /home/{{ hgweb_user }}/hgwebfiles>
+ Redirect 301 /favicon.ico /static/hgicon.png
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/templates/hgweb.conf Mon Jul 16 16:31:47 2018 +0800
+/ = /home/{{ hgweb_user }}/repos/*
+evolve.serveronly = /home/{{ hgweb_user }}/evolve/hgext3rd/evolve/serveronly.py
+baseurl = http://{{ hgweb_subdomain }}.{{ hostname }}/
+logourl = http://{{ hgweb_subdomain }}.{{ hostname }}/
+contact = {{ hgweb_contact }}
+highlightfiles = size('<100k')
+highlightonlymatchfilename = True
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/roles/hgweb/templates/hgweb.wsgi Mon Jul 16 16:31:47 2018 +0800
+# Path to repo or hgweb config to serve (see 'hg help hgweb')
+config = "/home/{{ hgweb_user }}/hgwebfiles/hgweb.conf"
+# Uncomment and adjust if Mercurial is not installed system-wide
+# (consult "installed modules" path from 'hg debuginstall'):
+import sys; sys.path.insert(0, "/home/{{ hgweb_user }}/hg/")
+# Uncomment to send python tracebacks to the browser if an error occurs:
+#import cgitb; cgitb.enable()
+# enable demandloading to reduce startup time
+from mercurial import demandimport; demandimport.enable()
+from mercurial.hgweb import hgweb
+application = hgweb(config)