visfleet-deprec 2.1.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (183) hide show
  1. data/CHANGELOG +398 -0
  2. data/COPYING +19 -0
  3. data/LICENSE +339 -0
  4. data/README +154 -0
  5. data/THANKS +17 -0
  6. data/bin/depify +139 -0
  7. data/docs/EXAMPLE-installing_tracks.txt +41 -0
  8. data/docs/README.nagios +22 -0
  9. data/docs/README.rails +17 -0
  10. data/docs/config_gen_explained.txt +39 -0
  11. data/docs/deprec-1.x/deprec-1.x.quickstart +50 -0
  12. data/docs/deprec-1.x/notes.txt +12 -0
  13. data/docs/old/deprec_banner.gif +0 -0
  14. data/docs/windows_linux.txt +350 -0
  15. data/docs/xen/traffic_monitoring_with_vnstat.txt +95 -0
  16. data/docs/xen/xen-tools-notes.txt +31 -0
  17. data/docs/xen/xen_on_hardy.txt +39 -0
  18. data/lib/deprec.rb +8 -0
  19. data/lib/deprec/capistrano_extensions.rb +438 -0
  20. data/lib/deprec/recipes.rb +7 -0
  21. data/lib/deprec/recipes/aoe.rb +79 -0
  22. data/lib/deprec/recipes/app/mongrel.rb +213 -0
  23. data/lib/deprec/recipes/app/passenger.rb +270 -0
  24. data/lib/deprec/recipes/ar_sendmail.rb +67 -0
  25. data/lib/deprec/recipes/canonical.rb +68 -0
  26. data/lib/deprec/recipes/chef.rb +68 -0
  27. data/lib/deprec/recipes/collectd.rb +112 -0
  28. data/lib/deprec/recipes/db/couchdb.rb +107 -0
  29. data/lib/deprec/recipes/db/mysql.rb +139 -0
  30. data/lib/deprec/recipes/db/postgresql.rb +104 -0
  31. data/lib/deprec/recipes/db/sqlite.rb +37 -0
  32. data/lib/deprec/recipes/ddclient.rb +51 -0
  33. data/lib/deprec/recipes/deprec.rb +199 -0
  34. data/lib/deprec/recipes/deprecated.rb +71 -0
  35. data/lib/deprec/recipes/example.rb +115 -0
  36. data/lib/deprec/recipes/git.rb +97 -0
  37. data/lib/deprec/recipes/gitosis.rb +55 -0
  38. data/lib/deprec/recipes/haproxy.rb +106 -0
  39. data/lib/deprec/recipes/heartbeat.rb +138 -0
  40. data/lib/deprec/recipes/integrity.rb +108 -0
  41. data/lib/deprec/recipes/logrotate.rb +54 -0
  42. data/lib/deprec/recipes/lvm.rb +20 -0
  43. data/lib/deprec/recipes/memcache.rb +49 -0
  44. data/lib/deprec/recipes/monit.rb +143 -0
  45. data/lib/deprec/recipes/nagios.rb +330 -0
  46. data/lib/deprec/recipes/network.rb +93 -0
  47. data/lib/deprec/recipes/ntp.rb +103 -0
  48. data/lib/deprec/recipes/php.rb +58 -0
  49. data/lib/deprec/recipes/postfix.rb +115 -0
  50. data/lib/deprec/recipes/rails.rb +337 -0
  51. data/lib/deprec/recipes/ruby/mri.rb +55 -0
  52. data/lib/deprec/recipes/ruby/ree.rb +40 -0
  53. data/lib/deprec/recipes/sphinx.rb +86 -0
  54. data/lib/deprec/recipes/ssh.rb +111 -0
  55. data/lib/deprec/recipes/ssl.rb +56 -0
  56. data/lib/deprec/recipes/starling.rb +119 -0
  57. data/lib/deprec/recipes/svn.rb +171 -0
  58. data/lib/deprec/recipes/syslog.rb +63 -0
  59. data/lib/deprec/recipes/trac.rb +277 -0
  60. data/lib/deprec/recipes/ubuntu.rb +35 -0
  61. data/lib/deprec/recipes/users.rb +90 -0
  62. data/lib/deprec/recipes/utils.rb +58 -0
  63. data/lib/deprec/recipes/vnstat.rb +85 -0
  64. data/lib/deprec/recipes/web/apache.rb +143 -0
  65. data/lib/deprec/recipes/web/nginx.rb +172 -0
  66. data/lib/deprec/recipes/wordpress.rb +96 -0
  67. data/lib/deprec/recipes/wpmu.rb +103 -0
  68. data/lib/deprec/recipes/xen.rb +278 -0
  69. data/lib/deprec/recipes/xentools.rb +75 -0
  70. data/lib/deprec/recipes_minus_rails.rb +61 -0
  71. data/lib/deprec/templates/aoe/aoe-init +55 -0
  72. data/lib/deprec/templates/aoe/fence_aoemask +351 -0
  73. data/lib/deprec/templates/apache/namevirtualhosts.conf +5 -0
  74. data/lib/deprec/templates/apache/ports.conf.erb +5 -0
  75. data/lib/deprec/templates/apache/status.conf.erb +17 -0
  76. data/lib/deprec/templates/ar_sendmail/logrotate.conf.erb +9 -0
  77. data/lib/deprec/templates/ar_sendmail/monit.conf.erb +5 -0
  78. data/lib/deprec/templates/chef/chef.json.erb +1 -0
  79. data/lib/deprec/templates/chef/solo.rb +2 -0
  80. data/lib/deprec/templates/collectd/collectd-init.d +153 -0
  81. data/lib/deprec/templates/collectd/collectd.conf.erb +686 -0
  82. data/lib/deprec/templates/ddclient/ddclient.conf.erb +11 -0
  83. data/lib/deprec/templates/ddclient/ddclient.erb +15 -0
  84. data/lib/deprec/templates/deprec/caprc.erb +14 -0
  85. data/lib/deprec/templates/haproxy/haproxy-init.d +120 -0
  86. data/lib/deprec/templates/haproxy/haproxy.cfg.erb +42 -0
  87. data/lib/deprec/templates/heartbeat/authkeys.erb +2 -0
  88. data/lib/deprec/templates/heartbeat/ha.cf.erb +15 -0
  89. data/lib/deprec/templates/heartbeat/haresources.erb +1 -0
  90. data/lib/deprec/templates/integrity/apache_vhost.erb +4 -0
  91. data/lib/deprec/templates/integrity/config.ru.erb +21 -0
  92. data/lib/deprec/templates/integrity/config.yml.erb +43 -0
  93. data/lib/deprec/templates/logrotate/logrotate.conf.erb +32 -0
  94. data/lib/deprec/templates/mongrel/apache_vhost.conf.erb +148 -0
  95. data/lib/deprec/templates/mongrel/logrotate.conf.erb +11 -0
  96. data/lib/deprec/templates/mongrel/mongrel_cluster-init-script +54 -0
  97. data/lib/deprec/templates/mongrel/mongrel_cluster.yml.erb +10 -0
  98. data/lib/deprec/templates/mongrel/monit.conf.erb +17 -0
  99. data/lib/deprec/templates/mongrel/nginx_vhost.conf.erb +41 -0
  100. data/lib/deprec/templates/monit/monit-init-script +104 -0
  101. data/lib/deprec/templates/monit/monitrc.erb +227 -0
  102. data/lib/deprec/templates/monit/nothing +0 -0
  103. data/lib/deprec/templates/mysql/create_databases.sql +20 -0
  104. data/lib/deprec/templates/mysql/database.yml.prod +6 -0
  105. data/lib/deprec/templates/mysql/database.yml.stage +6 -0
  106. data/lib/deprec/templates/mysql/my.cnf.erb +140 -0
  107. data/lib/deprec/templates/mysql/sphinx.conf.prod +542 -0
  108. data/lib/deprec/templates/mysql/sphinx.conf.stage +542 -0
  109. data/lib/deprec/templates/nagios/README +32 -0
  110. data/lib/deprec/templates/nagios/cgi.cfg.erb +357 -0
  111. data/lib/deprec/templates/nagios/check_linux_free_memory.pl +118 -0
  112. data/lib/deprec/templates/nagios/check_mongrel_cluster.rb +82 -0
  113. data/lib/deprec/templates/nagios/htpasswd.users +1 -0
  114. data/lib/deprec/templates/nagios/mrtg.cfg +180 -0
  115. data/lib/deprec/templates/nagios/nagios.cfg.erb +1325 -0
  116. data/lib/deprec/templates/nagios/nrpe.cfg.erb +222 -0
  117. data/lib/deprec/templates/nagios/nrpe.xinetd.erb +16 -0
  118. data/lib/deprec/templates/nagios/objects/commands.cfg.erb +265 -0
  119. data/lib/deprec/templates/nagios/objects/contacts.cfg.erb +89 -0
  120. data/lib/deprec/templates/nagios/objects/hosts.cfg.erb +114 -0
  121. data/lib/deprec/templates/nagios/objects/localhost.cfg.erb +116 -0
  122. data/lib/deprec/templates/nagios/objects/services.cfg.erb +165 -0
  123. data/lib/deprec/templates/nagios/objects/timeperiods.cfg.erb +94 -0
  124. data/lib/deprec/templates/nagios/resource.cfg.erb +34 -0
  125. data/lib/deprec/templates/network/hostname.erb +1 -0
  126. data/lib/deprec/templates/network/hosts.erb +2 -0
  127. data/lib/deprec/templates/network/interfaces.erb +18 -0
  128. data/lib/deprec/templates/network/resolv.conf.erb +6 -0
  129. data/lib/deprec/templates/nginx/logrotate.conf.erb +13 -0
  130. data/lib/deprec/templates/nginx/mime.types.erb +70 -0
  131. data/lib/deprec/templates/nginx/nginx-init-script +62 -0
  132. data/lib/deprec/templates/nginx/nginx.conf.erb +125 -0
  133. data/lib/deprec/templates/nginx/nginx.logrotate.d +12 -0
  134. data/lib/deprec/templates/nginx/nothing.conf +1 -0
  135. data/lib/deprec/templates/nginx/rails_nginx_vhost.conf.erb +41 -0
  136. data/lib/deprec/templates/ntp/ntp.conf.erb +42 -0
  137. data/lib/deprec/templates/passenger/apache_vhost.erb +29 -0
  138. data/lib/deprec/templates/passenger/apache_vhost_disabled.erb +18 -0
  139. data/lib/deprec/templates/passenger/logrotate.conf.erb +12 -0
  140. data/lib/deprec/templates/passenger/passenger.conf.erb +21 -0
  141. data/lib/deprec/templates/passenger/passenger.load.erb +3 -0
  142. data/lib/deprec/templates/postfix/aliases.erb +3 -0
  143. data/lib/deprec/templates/postfix/dynamicmaps.cf.erb +8 -0
  144. data/lib/deprec/templates/postfix/main.cf.erb +36 -0
  145. data/lib/deprec/templates/postfix/master.cf.erb +77 -0
  146. data/lib/deprec/templates/postgresql/pg_hba.conf.erb +3 -0
  147. data/lib/deprec/templates/sphinx/monit.conf.erb +5 -0
  148. data/lib/deprec/templates/ssh/ssh_config.erb +50 -0
  149. data/lib/deprec/templates/ssh/sshd_config.erb +78 -0
  150. data/lib/deprec/templates/ssl/make-ssl-cert +138 -0
  151. data/lib/deprec/templates/ssl/ssl-cert-snakeoil.key +15 -0
  152. data/lib/deprec/templates/ssl/ssl-cert-snakeoil.pem +19 -0
  153. data/lib/deprec/templates/starling/monit.conf.erb +14 -0
  154. data/lib/deprec/templates/starling/starling-init-script.erb +71 -0
  155. data/lib/deprec/templates/subversion/svn.apache.vhost.erb +43 -0
  156. data/lib/deprec/templates/syslog/syslog.conf.erb +71 -0
  157. data/lib/deprec/templates/syslog/syslogd.erb +13 -0
  158. data/lib/deprec/templates/trac/apache_vhost.conf.erb +24 -0
  159. data/lib/deprec/templates/trac/nginx_vhost.conf.erb +26 -0
  160. data/lib/deprec/templates/trac/trac.ini.erb +169 -0
  161. data/lib/deprec/templates/trac/trac_deprec.png +0 -0
  162. data/lib/deprec/templates/trac/tracd-init.erb +43 -0
  163. data/lib/deprec/templates/trac/users.htdigest.erb +0 -0
  164. data/lib/deprec/templates/vnstat/config.php +57 -0
  165. data/lib/deprec/templates/wordpress/apache2_wordpress_vhost.conf.erb +31 -0
  166. data/lib/deprec/templates/wordpress/wp-config.php.erb +31 -0
  167. data/lib/deprec/templates/wpmu/apache_vhost.conf.erb +13 -0
  168. data/lib/deprec/templates/xen/network-bridge-wrapper +3 -0
  169. data/lib/deprec/templates/xen/xend-config.sxp.erb +195 -0
  170. data/lib/deprec/templates/xen/xend-init.erb +57 -0
  171. data/lib/deprec/templates/xen/xendomains.erb +137 -0
  172. data/lib/deprec/templates/xentools/15-disable-hwclock +40 -0
  173. data/lib/deprec/templates/xentools/40-setup-networking +145 -0
  174. data/lib/deprec/templates/xentools/xen-tools.conf.erb +276 -0
  175. data/lib/deprec/templates/xentools/xm.tmpl.erb +138 -0
  176. data/lib/deprec_cmd_completion.sh +26 -0
  177. data/lib/deprec_minus_rails.rb +12 -0
  178. data/lib/vmbuilder_plugins/all.rb +20 -0
  179. data/lib/vmbuilder_plugins/apt.rb +93 -0
  180. data/lib/vmbuilder_plugins/emerge.rb +76 -0
  181. data/lib/vmbuilder_plugins/gem.rb +97 -0
  182. data/lib/vmbuilder_plugins/std.rb +203 -0
  183. metadata +245 -0
@@ -0,0 +1,171 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ require 'fileutils'
3
+ require 'uri'
4
+
5
+ # http://svnbook.red-bean.com/en/1.4/svn-book.html#svn.serverconfig.choosing.apache
6
+
7
+ Capistrano::Configuration.instance(:must_exist).load do
8
+ namespace :deprec do
9
+ namespace :svn do
10
+
11
+ set :scm_group, 'scm'
12
+
13
+ # Extract svn attributes from :repository URL
14
+ #
15
+ # Two examples of :repository entries are:
16
+ #
17
+ # set :repository, 'svn+ssh://scm.deprecated.org/var/svn/deprec/trunk'
18
+ # set :repository, 'file:///tmp/svn/deprec/trunk'
19
+ #
20
+ # This has only been tested with svn+ssh but file: should work.
21
+ #
22
+ set (:svn_scheme) { URI.parse(repository).scheme }
23
+ set (:svn_host) { URI.parse(repository).host }
24
+ set (:repos_path) { URI.parse(repository).path }
25
+ set (:repos_root) {
26
+ URI.parse(repository).path.sub(/\/(trunk|tags|branches)$/, '')
27
+ }
28
+
29
+ # account name to perform actions on (such as granting access to an account)
30
+ # this is a hack to allow us to optionally pass a variable to tasks
31
+ set (:svn_account) do
32
+ Capistrano::CLI.ui.ask 'account name'
33
+ end
34
+
35
+ set(:svn_backup_dir) { File.join(backup_dir, 'svn') }
36
+
37
+ desc "Install Subversion"
38
+ task :install do
39
+ install_deps
40
+ # XXX should really check if apache has already been installed
41
+ # XXX can do that when we move to rake
42
+ # deprec2.download_src(src_package, src_dir)
43
+ # deprec2.install_from_src(src_package, src_dir)
44
+ end
45
+
46
+ desc "install dependencies for Subversion"
47
+ task :install_deps do
48
+ apt.install( {:base => %w(subversion)}, :stable )
49
+ # XXX deprec1 - was building from source to get subversion-1.4.5 onto dapper. Compiled swig bindings for trac
50
+ # apt.install( {:base => %w(build-essential wget libneon25 libneon25-dev swig python-dev libexpat1-dev)}, :stable )
51
+ end
52
+
53
+ desc "grant a user access to svn repos"
54
+ task :grant_user_access, :roles => :scm do
55
+ # creates account, scm_group and adds account to group
56
+ deprec2.useradd(svn_account)
57
+ deprec2.groupadd(scm_group)
58
+ deprec2.add_user_to_group(svn_account, scm_group)
59
+ end
60
+
61
+ desc "Create subversion repository and import project into it"
62
+ task :setup, :roles => :scm do
63
+ create_repos
64
+ import
65
+ end
66
+
67
+ desc "Create a subversion repository"
68
+ task :create_repos, :roles => :scm do
69
+ set :svn_account, top.user
70
+ grant_user_access
71
+ deprec2.mkdir(repos_root, :mode => 02775, :group => scm_group, :via => :sudo)
72
+ sudo "svnadmin verify #{repos_root} > /dev/null 2>&1 || sudo svnadmin create #{repos_root}"
73
+ sudo "chmod -R g+w #{repos_root}"
74
+ end
75
+
76
+ # Adapted from code in Bradley Taylors RailsMachine gem
77
+ desc "Import project into subversion repository."
78
+ task :import, :roles => :scm do
79
+ new_path = "../#{application}"
80
+ tags = repository.sub("trunk", "tags")
81
+ branches = repository.sub("trunk", "branches")
82
+ puts "Adding branches and tags"
83
+ system "svn mkdir -m 'Adding tags and branches directories' #{tags} #{branches}"
84
+ puts "Importing application."
85
+ system "svn import #{repository} -m 'Import'"
86
+ cwd = Dir.getwd
87
+ puts "Moving application to new directory"
88
+ Dir.chdir '../'
89
+ system "mv #{cwd} #{cwd}.imported"
90
+ puts "Checking out application."
91
+ system "svn co #{repository} #{application}"
92
+ Dir.chdir application
93
+ remove_log_and_tmp
94
+ puts "Your repository is: #{repository}"
95
+ end
96
+
97
+ # Lifted from Bradley Taylors RailsMachine gem
98
+ desc "remove and ignore log files and tmp from subversion"
99
+ task :remove_log_and_tmp, :roles => :scm do
100
+ puts "removing log directory contents from svn"
101
+ system "svn remove log/*"
102
+ puts "ignoring log directory"
103
+ system "svn propset svn:ignore '*.log' log/"
104
+ system "svn update log/"
105
+ puts "removing contents of tmp sub-directorys from svn"
106
+ system "svn remove tmp/cache/*"
107
+ system "svn remove tmp/pids/*"
108
+ system "svn remove tmp/sessions/*"
109
+ system "svn remove tmp/sockets/*"
110
+ puts "ignoring tmp directory"
111
+ system "svn propset svn:ignore '*' tmp/cache"
112
+ system "svn propset svn:ignore '*' tmp/pids"
113
+ system "svn propset svn:ignore '*' tmp/sessions"
114
+ system "svn propset svn:ignore '*' tmp/sockets"
115
+ system "svn update tmp/"
116
+ puts "committing changes"
117
+ system "svn commit -m 'Removed and ignored log files and tmp'"
118
+ end
119
+
120
+ # desc "Cache svn name and password on the server. Useful for http-based repositories."
121
+ task :cache_credentials do
122
+ run_with_input "svn list #{repository}"
123
+ end
124
+
125
+ desc "create backup of trac repository"
126
+ task :backup, :roles => :scm do
127
+ # http://svnbook.red-bean.com/nightly/en/svn.reposadmin.maint.html#svn.reposadmin.maint.backup
128
+ # XXX do we need this? insane!
129
+ # echo "REPOS_BASE=/var/svn" > ~/.svntoolsrc
130
+ DATE=`date +%Y%m%d-%a`
131
+
132
+ timestamp = Time.now.strftime("%Y%m%d-%a")
133
+ deprec2.mkdir(svn_backup_dir, :owner => :root, :group => :deploy, :mode => 0775, :via => :sudo)
134
+ dest_dir = File.join(svn_backup_dir, "#{application}_#{timestamp}")
135
+ sudo "svnadmin hotcopy #{repos_root} #{dest_dir}"
136
+ end
137
+
138
+ task :restore, :roles => :scm do
139
+ # prompt user to select from list of locally stored backups
140
+ # tracd_stop
141
+ # copy out backup
142
+ end
143
+
144
+
145
+ # XXX TODO
146
+ # desc "backup repository"
147
+ # task :svn_backup_respository, :roles => :scm do
148
+ # puts "read http://svnbook.red-bean.com/nightly/en/svn-book.html#svn.reposadmin.maint.backup"
149
+ # end
150
+
151
+ end
152
+ end
153
+ end
154
+
155
+ # svnserve setup
156
+ # I've previously used ssh exclusively I've decided svnserve is a reasonable choice for collaboration on open source projects.
157
+ # It's easier to setup than apache/ssl webdav access.
158
+ #
159
+ # sudo useradd svn
160
+ # sudo mkdir -p /var/svn/deprec_svnserve_root
161
+ # sudo ln -sf /var/www/apps/deprec/repos /var/svn/deprec_svnserve_root/deprec
162
+ # sudo chown -R svn /var/svn/deprec_svnserve_root/deprec
163
+
164
+ #
165
+ # XXX put password file into svn and command to push it
166
+ #
167
+ # # run svnserve
168
+ # sudo -u svn svnserve --daemon --root /var/svn/deprec_svnserve_root
169
+ #
170
+ # # check it out now
171
+ # svn co svn://scm.deprecated.org/deprec/trunk deprec
@@ -0,0 +1,63 @@
1
+ # Copyright 2006-2009 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :syslog do
5
+
6
+ set(:syslog_server) { Capistrano::CLI.ui.ask 'Enter Syslog server hostname' }
7
+
8
+ desc "Install syslog"
9
+ task :install do
10
+ install_deps
11
+ end
12
+
13
+ # install dependencies for sysklogd
14
+ task :install_deps do
15
+ apt.install( {:base => %w(sysklogd)}, :stable )
16
+ end
17
+
18
+ SYSTEM_CONFIG_FILES[:syslog] = [
19
+
20
+ { :template => 'syslog.conf.erb',
21
+ :path => '/etc/syslog.conf',
22
+ :mode => 0644,
23
+ :owner => 'root:root'},
24
+
25
+ { :template => 'syslogd.erb',
26
+ :path => '/etc/default/syslogd',
27
+ :mode => 0644,
28
+ :owner => 'root:root'}
29
+
30
+ ]
31
+
32
+ desc "Generate Syslog configs"
33
+ task :config_gen do
34
+ SYSTEM_CONFIG_FILES[:syslog].each do |file|
35
+ deprec2.render_template(:syslog, file)
36
+ end
37
+ end
38
+
39
+ desc "Push Syslog config files to server"
40
+ task :config, :roles => :all_hosts, :except => {:syslog_master => true} do
41
+ deprec2.push_configs(:syslog, SYSTEM_CONFIG_FILES[:syslog])
42
+ restart
43
+ end
44
+
45
+ desc "Start Syslog"
46
+ task :start, :roles => :all_hosts, :except => { :syslog_master => true } do
47
+ run "#{sudo} /etc/init.d/sysklogd start"
48
+ end
49
+
50
+ desc "Stop Syslog"
51
+ task :stop, :roles => :all_hosts, :except => { :syslog_master => true } do
52
+ run "#{sudo} /etc/init.d/sysklogd stop"
53
+ end
54
+
55
+ desc "Restart Syslog"
56
+ task :restart, :roles => :all_hosts, :except => { :syslog_master => true } do
57
+ run "#{sudo} /etc/init.d/sysklogd restart"
58
+ end
59
+
60
+ end
61
+
62
+ end
63
+ end
@@ -0,0 +1,277 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do namespace :trac do
4
+
5
+ # Master tracd process for server
6
+ set :tracd_cmd, '/usr/bin/tracd'
7
+ set :tracd_port, '9000'
8
+ set :tracd_pidfile, '/var/run/tracd.pid'
9
+
10
+ # Settings for this projects trac instance
11
+ set(:tracd_domain_root) { domain.sub(/.*?\./,'') } # strip subdomain from domain
12
+ set(:tracd_vhost_domain) { "trac-#{application}.#{tracd_domain_root}" } # nginx will proxy this domain to tracd
13
+
14
+ set(:trac_backup_dir) { "#{backup_dir}/trac" }
15
+ set(:trac_path) { exists?(:deploy_to) ? "#{deploy_to}/trac" : Capistrano::CLI.ui.ask('path to trac config') }
16
+ set(:tracd_parent_dir) { "/etc/trac.d" }
17
+ set(:trac_password_file) { "#{trac_path}/conf/users.htdigest" }
18
+ set(:trac_account) { Capistrano::CLI.prompt('enter new trac user account name') }
19
+ set :trac_passwordfile_exists, true # hack - should check on remote system instead
20
+ set(:trac_header_logo_link) { trac_home_url }
21
+ # We will symlink each projects trac dir into this dir for tracd to find
22
+
23
+ # project
24
+ set(:trac_domain) { domain.sub(/^.*?\./, 'trac.') }
25
+ set(:trac_home_url) { "http://#{trac_domain}/" }
26
+ set(:trac_desc) { application }
27
+
28
+ # Settings only used for generating trac.ini for this project
29
+ # - notification
30
+ set :trac_always_notify_owner, false
31
+ set :trac_always_notify_reporter, false
32
+ set :trac_always_notify_updater, true
33
+ set :trac_smtp_always_bcc, ''
34
+ set :trac_smtp_always_cc, ''
35
+ set :trac_smtp_default_domain, ''
36
+ set :trac_smtp_enabled, true
37
+ set :trac_smtp_from, 'trac@localhost'
38
+ set :trac_smtp_password, ''
39
+ set :trac_smtp_port, 25
40
+ set :trac_smtp_replyto, 'trac@localhost'
41
+ set :trac_smtp_server, 'localhost'
42
+ set :trac_smtp_subject_prefix, '__default__'
43
+ set :trac_smtp_user, ''
44
+ set :trac_use_public_cc, false
45
+ set :trac_use_short_addr, false
46
+ set :trac_use_tls, false
47
+ # - other
48
+ set(:trac_base_url) { trac_home_url }
49
+
50
+ desc "Install trac on server"
51
+ task :install, :roles => :scm do
52
+ install_deps
53
+ sudo "easy_install Trac==0.11rc1"
54
+ create_pid_dir
55
+ create_parent_dir
56
+ config_gen_system
57
+ config_system
58
+ activate_system
59
+ end
60
+
61
+ task :install_deps do
62
+ apt.install( {:base => %w(sqlite3 python-setuptools python-subversion)}, :stable )
63
+ end
64
+
65
+ # The start script has a couple of config values in it.
66
+ # We may want to extract them into a config file later
67
+ # and install this script as part of the :install task.
68
+ SYSTEM_CONFIG_FILES[:trac] = [
69
+ {:template => 'tracd-init.erb',
70
+ :path => '/etc/init.d/tracd',
71
+ :mode => 0755,
72
+ :owner => 'root:root'}
73
+ ]
74
+
75
+ PROJECT_CONFIG_FILES[:trac] = [
76
+ {:template => 'users.htdigest.erb',
77
+ :path => "conf/users.htdigest",
78
+ :mode => 0644,
79
+ :owner => 'root:root'},
80
+
81
+ {:template => 'trac.ini.erb',
82
+ :path => "conf/trac.ini",
83
+ :mode => 0644,
84
+ :owner => 'root:root'},
85
+
86
+ {:template => 'nginx_vhost.conf.erb',
87
+ :path => "conf/nginx_vhost.conf",
88
+ :mode => 0644,
89
+ :owner => 'root:root'}
90
+ ]
91
+
92
+ desc "Generate config files for trac"
93
+ task :config_gen do
94
+ config_gen_system
95
+ config_gen_project
96
+ end
97
+
98
+ task :config_gen_system do
99
+ SYSTEM_CONFIG_FILES[:trac].each do |file|
100
+ deprec2.render_template(:trac, file)
101
+ end
102
+ end
103
+
104
+ task :config_gen_project do
105
+ PROJECT_CONFIG_FILES[:trac].each do |file|
106
+ deprec2.render_template(:trac, file)
107
+ end
108
+ end
109
+
110
+ desc "Push trac config files to server"
111
+ task :config, :roles => :scm do
112
+ config_system
113
+ config_project
114
+ restart
115
+ top.deprec.nginx.restart
116
+ end
117
+
118
+ task :config_system, :roles => :scm do
119
+ deprec2.push_configs(:trac, SYSTEM_CONFIG_FILES[:trac])
120
+ end
121
+
122
+ task :config_project, :roles => :scm do
123
+ deprec2.push_configs(:trac, PROJECT_CONFIG_FILES[:trac])
124
+ symlink_nginx_vhost
125
+ end
126
+
127
+ desc "Initialize the trac db for this project"
128
+ task :setup, :roles => :scm do
129
+ init
130
+ config_gen_project
131
+ config_project
132
+ activate_project
133
+ # set_default_permissions # XXX re-enable this
134
+ # create trac account for current user
135
+ set :trac_account, user
136
+ set :trac_passwordfile_exists, false # hack - should check on remote system instead
137
+ # user_add # XXX re-enable
138
+ end
139
+
140
+ task :init, :roles => :scm do
141
+ deprec2.mkdir(trac_path, :via => :sudo)
142
+ sudo "trac-admin #{trac_path} initenv #{application} sqlite:db/trac.db svn #{repos_root}"
143
+ end
144
+
145
+ task :set_default_permissions, :roles => :scm do
146
+ anonymous_disable
147
+ authenticated_enable
148
+ end
149
+
150
+ task :start, :roles => :scm do
151
+ sudo "/etc/init.d/tracd start"
152
+ end
153
+
154
+ task :stop, :roles => :scm do
155
+ sudo "/etc/init.d/tracd stop"
156
+ end
157
+
158
+ task :restart, :roles => :scm do
159
+ stop
160
+ start
161
+ end
162
+
163
+ task :activate, :roles => :scm do
164
+ activate_system
165
+ activate_project
166
+ end
167
+
168
+ task :activate_system, :roles => :scm do
169
+ sudo "update-rc.d tracd defaults"
170
+ end
171
+
172
+ task :activate_project, :roles => :scm do
173
+ symlink_project
174
+ end
175
+
176
+ task :deactivate, :roles => :scm do
177
+ deactivate_system
178
+ deactivate_project
179
+ end
180
+
181
+ task :deactivate_system, :roles => :scm do
182
+ sudo "update-rc.d -f tracd remove"
183
+ end
184
+
185
+ task :deactivate_project, :roles => :scm do
186
+ unlink_project
187
+ unlink_nginx_vhost
188
+ restart
189
+ end
190
+
191
+ desc "Create backup of trac repository"
192
+ task :backup, :roles => :web do
193
+ # http://trac.edgewall.org/wiki/TracBackup
194
+ timestamp = Time.now.utc.strftime("%Y%m%d%H%M%S")
195
+ dest_dir = File.join(trac_backup_dir, "trac_#{application}_#{timestamp}")
196
+ sudo "trac-admin #{trac_path} hotcopy #{dest_dir}"
197
+ end
198
+
199
+ desc "Restore trac repository from backup"
200
+ task :restore, :roles => :web do
201
+ # prompt user to select from list of locally stored backups
202
+ # tracd_stop
203
+ # copy out backup
204
+ end
205
+
206
+ #
207
+ # Service specific tasks for end users
208
+ #
209
+ desc "create a trac user"
210
+ task :user_add, :roles => :scm do
211
+ create_file = trac_passwordfile_exists ? '' : ' -c '
212
+ htdigest = '/usr/local/apache2/bin/htdigest'
213
+ # XXX check if htdigest file exists and add '-c' option if not
214
+ # sudo "test -f #{trac_path/conf/users.htdigest}
215
+ create_file = trac_passwordfile_exists ? '' : ' -c '
216
+ deprec2.sudo_with_input("#{htdigest} #{create_file} #{trac_path}/conf/users.htdigest #{application} #{trac_account}", /password:/)
217
+ end
218
+
219
+ desc "list trac users"
220
+ task :list_users, :roles => :scm do
221
+ sudo "cat #{trac_path}/conf/users.htdigest"
222
+ end
223
+
224
+ # desc "disable anonymous access to everything"
225
+ task :anonymous_disable, :roles => :scm do
226
+ sudo "trac-admin #{trac_path} permission remove anonymous '*'"
227
+ end
228
+
229
+ # desc "enable authenticated users access to everything"
230
+ task :authenticated_enable, :roles => :scm do
231
+ sudo "trac-admin #{trac_path} permission add authenticated TRAC_ADMIN"
232
+ end
233
+
234
+ #
235
+ # Helper tasks used by other tasks
236
+ #
237
+
238
+ # Link the trac repos for this project into the master trac repos dir
239
+ # We do this so we can use trac for multiple projects on the same server
240
+ task :symlink_project, :roles => :scm do
241
+ sudo "ln -sf #{trac_path} #{tracd_parent_dir}/#{application}"
242
+ end
243
+
244
+ task :unlink_project, :roles => :scm do
245
+ link = "#{tracd_parent_dir}/#{application}"
246
+ sudo "test -h #{link} && sudo unlink #{link} || true"
247
+ end
248
+
249
+ task :symlink_nginx_vhost, :roles => :scm do
250
+ sudo "ln -sf #{deploy_to}/trac/conf/nginx_vhost.conf #{nginx_vhost_dir}/tracd-#{application}.conf"
251
+ end
252
+
253
+ task :unlink_nginx_vhost, :roles => :scm do
254
+ link = "#{nginx_vhost_dir}/tracd-#{application}.conf"
255
+ sudo "test -h #{link} && unlink #{link} || true"
256
+ end
257
+
258
+ # task :symlink_apache_vhost, :roles => :scm do
259
+ # sudo "ln -sf #{deploy_to}/trac/conf/trac_apache_vhost.conf #{apache_vhost_dir}/#{application}-trac.conf"
260
+ # end
261
+ #
262
+ # task :unlink_apache_vhost, :roles => :scm do
263
+ # link = "#{apache_vhost_dir}/#{application}-trac.conf"
264
+ # sudo "test -h #{link} && unlink #{link} || true"
265
+ # end
266
+
267
+ task :create_pid_dir, :roles => :scm do
268
+ deprec2.mkdir(File.dirname(tracd_pidfile))
269
+ end
270
+
271
+ task :create_parent_dir, :roles => :scm do
272
+ deprec2.mkdir(tracd_parent_dir, :via => :sudo)
273
+ end
274
+
275
+ end end
276
+
277
+ end