Skip to content
Snippets Groups Projects
Commit 03eced12 authored by nimrod's avatar nimrod
Browse files

Update meta, README. remove requirements.txt (wasn't needed, not a Python...

Update meta, README. remove requirements.txt (wasn't needed, not a Python project). Add backup job, dedicated Apache site, configure firewall.
parent 7a952a62
No related branches found
No related tags found
No related merge requests found
...@@ -10,14 +10,14 @@ Debian Jessie. ...@@ -10,14 +10,14 @@ Debian Jessie.
Role Variables Role Variables
-------------- --------------
::
git_directory: The directory to be created and used for all git repositories git_directory: /srv/git #The directory to be created and used for all git repositories served.
served.
Dependencies Dependencies
------------ ------------
None. The common role from https://www.shore.co.il/cgit/ansible-common/
Example Playbook Example Playbook
---------------- ----------------
...@@ -49,6 +49,7 @@ Repository is located at: https://www.shore.co.il/cgit/ansible-cgit ...@@ -49,6 +49,7 @@ Repository is located at: https://www.shore.co.il/cgit/ansible-cgit
todo todo
---- ----
- File a bug in Debian for using the wrong location of rst2html.
- Add pre-commit hooks. - Add pre-commit hooks.
- Consider adding gitolite. - Consider adding gitolite.
- Output log (cgit?, apache) to syslog.
- Collectd metrics.
--- ---
galaxy_info: galaxy_info:
author: Nimrod Adar author: Nimrod Adar
description: cgit description: cgit provisioning for Debian Jessie.
company: Shore technologies company: Shore technologies
# If the issue tracker for your role is not on github, uncomment the
# next line and provide a value
# issue_tracker_url: http://example.com/issue/tracker
# Some suggested licenses:
# - BSD (default)
# - MIT
# - GPLv2
# - GPLv3
# - Apache
# - CC-BY
license: MIT license: MIT
min_ansible_version: 1.2 min_ansible_version: 1.2
#
# Below are all platforms currently available. Just uncomment
# the ones that apply to your role. If you don't see your
# platform on this list, let us know and we'll get it added!
#
platforms: platforms:
#- name: EL
# versions:
# - all
# - 5
# - 6
# - 7
#- name: GenericUNIX
# versions:
# - all
# - any
#- name: Fedora
# versions:
# - all
# - 16
# - 17
# - 18
# - 19
# - 20
# - 21
# - 22
#- name: Windows
# versions:
# - all
# - 2012R2
#- name: SmartOS
# versions:
# - all
# - any
#- name: opensuse
# versions:
# - all
# - 12.1
# - 12.2
# - 12.3
# - 13.1
# - 13.2
#- name: Amazon
# versions:
# - all
# - 2013.03
# - 2013.09
#- name: GenericBSD
# versions:
# - all
# - any
#- name: FreeBSD
# versions:
# - all
# - 8.0
# - 8.1
# - 8.2
# - 8.3
# - 8.4
# - 9.0
# - 9.1
# - 9.1
# - 9.2
#- name: Ubuntu
# versions:
# - all
# - lucid
# - maverick
# - natty
# - oneiric
# - precise
# - quantal
# - raring
# - saucy
# - trusty
# - utopic
# - vivid
#- name: SLES
# versions:
# - all
# - 10SP3
# - 10SP4
# - 11
# - 11SP1
# - 11SP2
# - 11SP3
#- name: GenericLinux
# versions:
# - all
# - any
- name: Debian - name: Debian
versions: versions:
# - all
# - etch
- jessie - jessie
# - lenny categories:
# - squeeze - development
# - wheezy - system
#
# Below are all categories currently available. Just as with
# the platforms above, uncomment those that apply to your role.
#
#categories:
#- cloud
#- cloud:ec2
#- cloud:gce
#- cloud:rax
#- clustering
#- database
#- database:nosql
#- database:sql
#- development
#- monitoring
#- networking
#- packaging
#- system
#- web
dependencies: [] dependencies: []
# List your role dependencies here, one per line.
# Be sure to remove the '[]' above if you add dependencies
# to this list.
--- ---
# tasks file for ansible-cgit # tasks file for ansible-cgit
- name: Install packages
- name: apt install
apt: apt:
name: '{{ item }}' name: '{{ item }}'
state: present state: present
...@@ -11,21 +12,34 @@ ...@@ -11,21 +12,34 @@
- git - git
- apache2 - apache2
- python-docutils - python-docutils
- cron
- name: Enable mod-cgi - name: Enable Apache modules
notify:
- Restart Apache
apache2_module: apache2_module:
name: cgi name: '{{ item }}'
state: present state: present
notify:
- Restart Apache
with_items:
- cgi
- ssl
- name: Disable default Apache site
file:
path: /etc/apache2/sites-enabled/000-default.conf
state: absent
notify:
- Restart Apache
- name: Add configuration for cgit css - name: Add cgit Apache site
template: template:
src: cgit-css.conf.j2 src: cgit.conf.j2
dest: /etc/apache2/conf-enabled/cgit-css.conf dest: /etc/apache2/sites-enabled/cgit.conf
owner: root owner: root
group: root group: root
mode: '0644' mode: '0644'
notify:
- Restart Apache
- name: Create git repostories directory - name: Create git repostories directory
file: file:
...@@ -35,7 +49,8 @@ ...@@ -35,7 +49,8 @@
mode: '0777' mode: '0777'
state: directory state: directory
- name: Add symlink for rst2html (hack) - name: Add symlink for rst2html (hack, fixed in Stretch)
when: ansible_distribution_major_version < 9
file: file:
src: /usr/share/docutils/scripts/python2/rst2html src: /usr/share/docutils/scripts/python2/rst2html
dest: /usr/local/bin/rst2html.py dest: /usr/local/bin/rst2html.py
...@@ -91,3 +106,17 @@ ...@@ -91,3 +106,17 @@
- line: 'readme=:install.txt' - line: 'readme=:install.txt'
- line: 'readme=:INSTALL' - line: 'readme=:INSTALL'
- line: 'readme=:install' - line: 'readme=:install'
- name: Configure firewall
ufw:
rule: allow
port: 443
proto: tcp
- name: Add daily backup job
template:
src: cgit.j2
dest: /etc/cron.daily/cgit
owner: root
group: root
mode: '0755'
Alias /cgit/css "/usr/share/cgit/"
<VirtualHost _default_:443>
DocumentRoot /usr/share/cgit
Alias /css "/usr/share/cgit"
SSLEngine on
SSLCertificateFile {{ internal_tls_cert }}
SSLCertificateKeyFile {{ internal_tls_key }}
SSLProtocol all -SSLv2 -SSLv3
SSLCipherSuite !kRSA:!3DES:!RC4:!DES:!MD5:!aNULL:!NULL:AESGCM+ECDH:AES256+ECDH:AES128:+SHA1;
SSLHonorCipherOrder on
SSLCompression off
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</virtualHost>
#!/bin/sh -e
cd {{ git_directory|dirname }}
tar -cf /var/backups/git.tar.gz {{ git_directory|basename }}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment