isaac-deprec 1.99.30

Sign up to get free protection for your applications and to get access to all the features.
Files changed (152) hide show
  1. data/CHANGELOG +226 -0
  2. data/COPYING +19 -0
  3. data/LICENSE +339 -0
  4. data/README +138 -0
  5. data/THANKS +5 -0
  6. data/bin/depify +133 -0
  7. data/docs/ANNOUNCE.deprec2 +47 -0
  8. data/docs/README.install +88 -0
  9. data/docs/README.nagios +22 -0
  10. data/docs/README.rails +20 -0
  11. data/docs/README.svn +31 -0
  12. data/docs/ROADMAP.txt +74 -0
  13. data/docs/deprec-1.x/deprec-1.x.quickstart +50 -0
  14. data/docs/deprec-1.x/notes.txt +12 -0
  15. data/docs/deprec_banner.gif +0 -0
  16. data/docs/offline_installation.txt +16 -0
  17. data/docs/windows_linux.txt +350 -0
  18. data/docs/xen/plan.txt +5 -0
  19. data/docs/xen/traffic_monitoring_with_vnstat.txt +95 -0
  20. data/docs/xen/xen-tools-notes.txt +31 -0
  21. data/docs/xen/xen_on_hardy.txt +39 -0
  22. data/lib/deprec/capistrano_extensions.rb +435 -0
  23. data/lib/deprec/recipes/aoe.rb +79 -0
  24. data/lib/deprec/recipes/apache.rb +179 -0
  25. data/lib/deprec/recipes/apt_mirror.rb +99 -0
  26. data/lib/deprec/recipes/ar_sendmail.rb +67 -0
  27. data/lib/deprec/recipes/canonical.rb +57 -0
  28. data/lib/deprec/recipes/deprec.rb +188 -0
  29. data/lib/deprec/recipes/deprecated.rb +71 -0
  30. data/lib/deprec/recipes/example.rb +115 -0
  31. data/lib/deprec/recipes/git.rb +97 -0
  32. data/lib/deprec/recipes/gitosis.rb +48 -0
  33. data/lib/deprec/recipes/heartbeat.rb +138 -0
  34. data/lib/deprec/recipes/logrotate.rb +54 -0
  35. data/lib/deprec/recipes/lvm.rb +20 -0
  36. data/lib/deprec/recipes/memcache.rb +49 -0
  37. data/lib/deprec/recipes/mongrel.rb +219 -0
  38. data/lib/deprec/recipes/monit.rb +135 -0
  39. data/lib/deprec/recipes/mysql.rb +115 -0
  40. data/lib/deprec/recipes/nagios.rb +305 -0
  41. data/lib/deprec/recipes/network.rb +93 -0
  42. data/lib/deprec/recipes/nginx.rb +144 -0
  43. data/lib/deprec/recipes/ntp.rb +103 -0
  44. data/lib/deprec/recipes/passenger.rb +114 -0
  45. data/lib/deprec/recipes/php.rb +91 -0
  46. data/lib/deprec/recipes/postfix.rb +115 -0
  47. data/lib/deprec/recipes/rails.rb +282 -0
  48. data/lib/deprec/recipes/ree.rb +33 -0
  49. data/lib/deprec/recipes/ruby.rb +65 -0
  50. data/lib/deprec/recipes/sphinx.rb +86 -0
  51. data/lib/deprec/recipes/ssh.rb +93 -0
  52. data/lib/deprec/recipes/svn.rb +171 -0
  53. data/lib/deprec/recipes/trac.rb +277 -0
  54. data/lib/deprec/recipes/ubuntu.rb +20 -0
  55. data/lib/deprec/recipes/users.rb +90 -0
  56. data/lib/deprec/recipes/utils.rb +39 -0
  57. data/lib/deprec/recipes/vnstat.rb +85 -0
  58. data/lib/deprec/recipes/wordpress.rb +99 -0
  59. data/lib/deprec/recipes/xen.rb +269 -0
  60. data/lib/deprec/recipes.rb +40 -0
  61. data/lib/deprec/templates/aoe/aoe-init +55 -0
  62. data/lib/deprec/templates/aoe/fence_aoemask +351 -0
  63. data/lib/deprec/templates/apache/httpd-vhost-app.conf.erb +144 -0
  64. data/lib/deprec/templates/apache/httpd.conf +465 -0
  65. data/lib/deprec/templates/apache/index.html.erb +37 -0
  66. data/lib/deprec/templates/apache/master.css +72 -0
  67. data/lib/deprec/templates/apt/sources.list +18 -0
  68. data/lib/deprec/templates/apt_mirror/apt-mirror-cron +4 -0
  69. data/lib/deprec/templates/apt_mirror/mirror.list +33 -0
  70. data/lib/deprec/templates/ar_sendmail/logrotate.conf.erb +9 -0
  71. data/lib/deprec/templates/ar_sendmail/monit.conf.erb +5 -0
  72. data/lib/deprec/templates/deprec/caprc.erb +14 -0
  73. data/lib/deprec/templates/heartbeat/authkeys.erb +2 -0
  74. data/lib/deprec/templates/heartbeat/ha.cf.erb +15 -0
  75. data/lib/deprec/templates/heartbeat/haresources.erb +1 -0
  76. data/lib/deprec/templates/logrotate/logrotate.conf.erb +32 -0
  77. data/lib/deprec/templates/mongrel/logrotate.conf.erb +11 -0
  78. data/lib/deprec/templates/mongrel/mongrel_cluster-init-script +54 -0
  79. data/lib/deprec/templates/mongrel/mongrel_cluster.yml.erb +10 -0
  80. data/lib/deprec/templates/mongrel/monit.conf.erb +17 -0
  81. data/lib/deprec/templates/monit/monit-init-script +104 -0
  82. data/lib/deprec/templates/monit/monitrc.erb +227 -0
  83. data/lib/deprec/templates/monit/nothing +0 -0
  84. data/lib/deprec/templates/mysql/create_databases.sql +20 -0
  85. data/lib/deprec/templates/mysql/database.yml.prod +6 -0
  86. data/lib/deprec/templates/mysql/database.yml.stage +6 -0
  87. data/lib/deprec/templates/mysql/my.cnf.erb +140 -0
  88. data/lib/deprec/templates/mysql/sphinx.conf.prod +542 -0
  89. data/lib/deprec/templates/mysql/sphinx.conf.stage +542 -0
  90. data/lib/deprec/templates/nagios/cgi.cfg.erb +321 -0
  91. data/lib/deprec/templates/nagios/check_linux_free_memory.pl +118 -0
  92. data/lib/deprec/templates/nagios/check_mongrel_cluster.rb +82 -0
  93. data/lib/deprec/templates/nagios/commands.cfg.erb +240 -0
  94. data/lib/deprec/templates/nagios/contacts.cfg.erb +57 -0
  95. data/lib/deprec/templates/nagios/hosts.cfg.erb +143 -0
  96. data/lib/deprec/templates/nagios/htpasswd.users +1 -0
  97. data/lib/deprec/templates/nagios/localhost.cfg.erb +157 -0
  98. data/lib/deprec/templates/nagios/nagios.cfg.erb +1274 -0
  99. data/lib/deprec/templates/nagios/nagios_apache_vhost.conf.erb +45 -0
  100. data/lib/deprec/templates/nagios/nrpe.cfg.erb +210 -0
  101. data/lib/deprec/templates/nagios/nrpe.xinetd.erb +16 -0
  102. data/lib/deprec/templates/nagios/resource.cfg.erb +34 -0
  103. data/lib/deprec/templates/nagios/services.cfg.erb +79 -0
  104. data/lib/deprec/templates/nagios/templates.cfg.erb +9 -0
  105. data/lib/deprec/templates/nagios/timeperiods.cfg.erb +94 -0
  106. data/lib/deprec/templates/network/hostname.erb +1 -0
  107. data/lib/deprec/templates/network/hosts.erb +2 -0
  108. data/lib/deprec/templates/network/interfaces.erb +18 -0
  109. data/lib/deprec/templates/network/resolv.conf.erb +6 -0
  110. data/lib/deprec/templates/nginx/logrotate.conf.erb +13 -0
  111. data/lib/deprec/templates/nginx/mime.types.erb +70 -0
  112. data/lib/deprec/templates/nginx/nginx-init-script +62 -0
  113. data/lib/deprec/templates/nginx/nginx.conf.erb +125 -0
  114. data/lib/deprec/templates/nginx/nginx.logrotate.d +12 -0
  115. data/lib/deprec/templates/nginx/nothing.conf +1 -0
  116. data/lib/deprec/templates/nginx/rails_nginx_vhost.conf.erb +41 -0
  117. data/lib/deprec/templates/ntp/ntp.conf.erb +42 -0
  118. data/lib/deprec/templates/passenger/apache_vhost.erb +10 -0
  119. data/lib/deprec/templates/passenger/passenger.erb +20 -0
  120. data/lib/deprec/templates/postfix/aliases.erb +3 -0
  121. data/lib/deprec/templates/postfix/dynamicmaps.cf.erb +8 -0
  122. data/lib/deprec/templates/postfix/main.cf.erb +36 -0
  123. data/lib/deprec/templates/postfix/master.cf.erb +77 -0
  124. data/lib/deprec/templates/sphinx/monit.conf.erb +5 -0
  125. data/lib/deprec/templates/ssh/ssh_config.erb +50 -0
  126. data/lib/deprec/templates/ssh/sshd_config.erb +78 -0
  127. data/lib/deprec/templates/subversion/svn.apache.vhost.erb +43 -0
  128. data/lib/deprec/templates/trac/apache_vhost.conf.erb +24 -0
  129. data/lib/deprec/templates/trac/nginx_vhost.conf.erb +26 -0
  130. data/lib/deprec/templates/trac/trac.ini.erb +169 -0
  131. data/lib/deprec/templates/trac/trac_deprec.png +0 -0
  132. data/lib/deprec/templates/trac/tracd-init.erb +43 -0
  133. data/lib/deprec/templates/trac/users.htdigest.erb +0 -0
  134. data/lib/deprec/templates/vnstat/config.php +57 -0
  135. data/lib/deprec/templates/wordpress/apache2_wordpress_vhost.conf.erb +31 -0
  136. data/lib/deprec/templates/wordpress/wp-config.php.erb +31 -0
  137. data/lib/deprec/templates/xen/15-disable-hwclock +40 -0
  138. data/lib/deprec/templates/xen/40-setup-networking +145 -0
  139. data/lib/deprec/templates/xen/network-bridge-wrapper +3 -0
  140. data/lib/deprec/templates/xen/xen-tools.conf.erb +220 -0
  141. data/lib/deprec/templates/xen/xend-config.sxp.erb +195 -0
  142. data/lib/deprec/templates/xen/xend-init.erb +57 -0
  143. data/lib/deprec/templates/xen/xendomains.erb +137 -0
  144. data/lib/deprec/templates/xen/xm.tmpl.erb +85 -0
  145. data/lib/deprec.rb +8 -0
  146. data/lib/deprec_cmd_completion.sh +26 -0
  147. data/lib/vmbuilder_plugins/all.rb +20 -0
  148. data/lib/vmbuilder_plugins/apt.rb +93 -0
  149. data/lib/vmbuilder_plugins/emerge.rb +76 -0
  150. data/lib/vmbuilder_plugins/gem.rb +90 -0
  151. data/lib/vmbuilder_plugins/std.rb +203 -0
  152. metadata +241 -0
@@ -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
@@ -0,0 +1,20 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :ubuntu do
5
+
6
+ task :update do
7
+ apt.update
8
+ end
9
+
10
+ task :upgrade do
11
+ apt.upgrade
12
+ end
13
+
14
+ task :restart do
15
+ sudo "reboot"
16
+ end
17
+
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,90 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :users do
5
+
6
+ # desc "Create user account"
7
+ # task :add do
8
+ # target_user = Capistrano::CLI.ui.ask "Enter userid for new user" do |q|
9
+ # q.default = user
10
+ # end
11
+ # deprec2.useradd(target_user, :shell => '/bin/bash')
12
+ # puts "Setting password for new account"
13
+ # deprec2.invoke_with_input("passwd #{target_user}", /UNIX password/)
14
+ # end
15
+
16
+ desc "Create account"
17
+ task :add do
18
+ target_user = Capistrano::CLI.ui.ask "Enter userid for new user" do |q|
19
+ q.default = user
20
+ end
21
+ make_admin = Capistrano::CLI.ui.ask "Should this be an admin account?" do |q|
22
+ q.default = 'no'
23
+ end
24
+ copy_keys = false
25
+ if File.readable?("config/ssh/authorized_keys/#{target_user}")
26
+ copy_keys = Capistrano::CLI.ui.ask "I've found an authorized_keys file for #{target_user}. Should I copy it out?" do |q|
27
+ q.default = 'yes'
28
+ end
29
+ end
30
+
31
+ new_password = Capistrano::CLI.ui.ask("Enter new password for #{target_user}") { |q| q.echo = false }
32
+
33
+ deprec2.useradd(target_user, :shell => '/bin/bash')
34
+
35
+ deprec2.invoke_with_input("passwd #{target_user}", /UNIX password/, new_password)
36
+
37
+ if make_admin.grep(/y/i)
38
+ deprec2.groupadd('admin')
39
+ deprec2.add_user_to_group(target_user, 'admin')
40
+ deprec2.append_to_file_if_missing('/etc/sudoers', '%admin ALL=(ALL) ALL')
41
+ end
42
+
43
+ if copy_keys && copy_keys.grep(/y/i)
44
+ set :target_user, target_user
45
+ top.deprec.ssh.setup_keys
46
+ end
47
+
48
+ end
49
+
50
+ desc "Create account"
51
+ task :add_admin do
52
+ puts 'deprecated! use deprec:users:add'
53
+ add
54
+ end
55
+
56
+ desc "Change user password"
57
+ task :passwd do
58
+ target_user = Capistrano::CLI.ui.ask "Enter user to change password for" do |q|
59
+ q.default = user if user.is_a?(String)
60
+ end
61
+ new_password = Capistrano::CLI.ui.ask("Enter new password for #{target_user}") { |q| q.echo = false }
62
+
63
+ deprec2.invoke_with_input("passwd #{target_user}", /UNIX password/, new_password)
64
+ end
65
+
66
+ desc "Add user to group"
67
+ task :add_user_to_group do
68
+ target_user = Capistrano::CLI.ui.ask "Which user?" do |q|
69
+ q.default = user if user.is_a?(String)
70
+ end
71
+ target_group = Capistrano::CLI.ui.ask "Add to which group?" do |q|
72
+ q.default = 'deploy'
73
+ end
74
+ deprec2.add_user_to_group(target_user, target_group)
75
+ end
76
+
77
+ # desc "Create group"
78
+ # task :add_group do
79
+ # target_group = Capistrano::CLI.ui.ask "Enter name for new group"
80
+ # deprec2.groupadd(target_group)
81
+ # end
82
+ #
83
+ # desc "Add user to group"
84
+ # task :add_user_to_group do
85
+ # # XXX not yet implemented
86
+ # end
87
+
88
+ end
89
+ end
90
+ end
@@ -0,0 +1,39 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :utils do
5
+
6
+ SRC_PACKAGES[:daemonize] = {
7
+ :filename => 'daemonize-1.5.2.tar.gz',
8
+ :md5sum => "c016f1a17f03ec976873d0a283a1a038 daemonize-1.5.2.tar.gz",
9
+ :dir => 'daemonize-1.5.2',
10
+ :url => "http://www.clapper.org/software/daemonize/daemonize-1.5.2.tar.gz",
11
+ :unpack => "tar zxf daemonize-1.5.2.tar.gz;",
12
+ :configure => %w(
13
+ ./configure
14
+ ;
15
+ ).reject{|arg| arg.match '#'}.join(' '),
16
+ :make => 'make;',
17
+ :install => 'make install;'
18
+ }
19
+
20
+ namespace :daemonize do
21
+
22
+ desc "Install daemonize"
23
+ task :install do
24
+ deprec2.download_src(SRC_PACKAGES[:daemonize], src_dir)
25
+ deprec2.install_from_src(SRC_PACKAGES[:daemonize], src_dir)
26
+ end
27
+
28
+ end
29
+
30
+ desc "Install some handy network utils"
31
+ task :net do
32
+ apps = %w(lynx nmap netcat mailx mutt telnet vim-full dnsutils rsync)
33
+ apt.install( {:base => apps}, :stable )
34
+ end
35
+
36
+ end
37
+ end
38
+ end
39
+
@@ -0,0 +1,85 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+
4
+ namespace :deprec do
5
+ namespace :vnstat do
6
+
7
+ desc <<-EOF
8
+ vnstat description
9
+ EOF
10
+ task :default do
11
+ end
12
+
13
+ SRC_PACKAGES[:vnstat] = {
14
+ :url => "http://humdi.net/vnstat/vnstat-1.6.tar.gz",
15
+ :md5sum => "ccaffe8e70d47e0cf2f25e52daa25712 vnstat-1.6.tar.gz",
16
+ :configure => '',
17
+ :post_install => 'vnstat --testkernel && vnstat -u -i eth0'
18
+ }
19
+
20
+ desc <<-EOF
21
+ Install vnstat. Add interfaces with 'vnstat -u -i ethN'
22
+ (where N is interface number).
23
+
24
+ View stats using the vnstat command line tool.
25
+ EOF
26
+ task :install do
27
+ install_deps
28
+ deprec2.download_src(SRC_PACKAGES[:vnstat], src_dir)
29
+ deprec2.install_from_src(SRC_PACKAGES[:vnstat], src_dir)
30
+ end
31
+
32
+ # install dependencies for monit
33
+ task :install_deps do
34
+ # apt.install( {:base => %w(flex bison libssl-dev)}, :stable )
35
+ end
36
+
37
+ end
38
+
39
+
40
+ namespace :vnstat_php do
41
+
42
+ SRC_PACKAGES[:vnstat_php] = {
43
+ :url => "http://www.sqweek.com/sqweek/files/vnstat_php_frontend-1.3.tar.gz",
44
+ :md5sum => "190b37808ae16bd1c1a132434b170437 vnstat_php_frontend-1.3.tar.gz",
45
+ :configure => '',
46
+ :make => '',
47
+ :install => "test -d /var/www/vnstat_php_frontend-1.3 && rm -fr /var/www/vnstat_php_frontend-1.3; mv #{src_dir}/vnstat_php_frontend-1.3 /var/www &&
48
+ ln -sf /var/www/vnstat_php_frontend-1.3 /var/www/vnstat"
49
+ }
50
+
51
+ task :install do
52
+ install_deps
53
+ deprec2.download_src(SRC_PACKAGES[:vnstat_php], src_dir)
54
+ deprec2.install_from_src(SRC_PACKAGES[:vnstat_php], src_dir)
55
+ end
56
+
57
+ # install dependencies for monit
58
+ task :install_deps do
59
+ apt.install( {:base => %w(apache2 php5 php5-gd)}, :stable )
60
+ end
61
+
62
+ SYSTEM_CONFIG_FILES[:vnstat] = [
63
+
64
+ {:template => 'config.php',
65
+ :path => '/var/www/vnstat',
66
+ :mode => 0755,
67
+ :owner => 'root:root'}
68
+
69
+ ]
70
+
71
+ task :config_gen do
72
+ SYSTEM_CONFIG_FILES[:vnstat].each do |file|
73
+ deprec2.render_template(:vnstat, file)
74
+ end
75
+ end
76
+
77
+ desc "Push monit config files to server"
78
+ task :config do
79
+ deprec2.push_configs(:vnstat, SYSTEM_CONFIG_FILES[:vnstat])
80
+ end
81
+
82
+ end
83
+
84
+ end
85
+ end
@@ -0,0 +1,99 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+
4
+ require 'digest'
5
+
6
+ set :application, 'wordpress'
7
+ set(:wordpress_domain) { Capistrano::CLI.ui.ask 'Enter domain wordpress will be served on' }
8
+ set :db_name, 'wordpress'
9
+ set :db_user, 'wordpress'
10
+ set(:db_pass) { Capistrano::CLI.ui.ask 'Enter db password for wordpress' }
11
+ set(:db_host) { Capistrano::CLI.ui.ask 'Enter db hostname for wordpress' }
12
+ set :db_charset, 'utf8'
13
+ set :db_collate, ''
14
+
15
+ set(:auth_key) { Digest::SHA1.hexdigest srand.to_s }
16
+ set(:secure_auth_key) { Digest::SHA1.hexdigest srand.to_s }
17
+ set(:logged_in_key) { Digest::SHA1.hexdigest srand.to_s }
18
+
19
+ set(:wordpress_install_dir) { "#{deploy_to}/public" }
20
+
21
+
22
+ namespace :deprec do
23
+ namespace :wordpress do
24
+
25
+ # We're using the lambda because we want wordpress_install_dir to
26
+ # pick up on the value for :application if it's overridden in deploy.rb
27
+ #
28
+ SRC_PACKAGES[:wordpress] =
29
+ {
30
+ :url => "http://wordpress.org/latest.tar.gz",
31
+ :dir => 'wordpress'
32
+ }
33
+
34
+ desc "Install Wordpress"
35
+ task :install do
36
+ install_deps unless ENV['SKIP_DEPS'] # save time by skipping deps (when reinstalling)
37
+ deprec2.download_src(SRC_PACKAGES[:wordpress], src_dir)
38
+ deprec2.unpack_src(SRC_PACKAGES[:wordpress], src_dir)
39
+ deprec2.mkdir wordpress_install_dir, :via => :sudo
40
+ sudo "cp -r #{src_dir}/wordpress/* #{wordpress_install_dir}/"
41
+ end
42
+
43
+ task :install_deps do
44
+ top.deprec.apache.install
45
+ top.deprec.php.install
46
+ end
47
+
48
+ PROJECT_CONFIG_FILES[:wordpress] = [
49
+
50
+ {:template => "wp-config.php.erb",
51
+ :path => 'wp-config.php',
52
+ :mode => 0755,
53
+ :owner => 'root:root'},
54
+
55
+ {:template => "apache2_wordpress_vhost.conf.erb",
56
+ :path => 'apache2_wordpress_vhost.conf',
57
+ :mode => 0755,
58
+ :owner => 'root:root'}
59
+
60
+ ]
61
+
62
+ desc "Generate configuration file(s) for mongrel from template(s)"
63
+ task :config_gen do
64
+ config_gen_project
65
+ end
66
+
67
+ task :config_gen_project do
68
+ PROJECT_CONFIG_FILES[:wordpress].each do |file|
69
+ deprec2.render_template(:wordpress, file)
70
+ end
71
+ end
72
+
73
+ desc "Push wordpress config files to server"
74
+ task :config, :roles => :wordpress do
75
+ config_project
76
+ end
77
+
78
+ task :config_project, :roles => :wordpress do
79
+ deprec2.push_configs(:wordpress, PROJECT_CONFIG_FILES[:wordpress])
80
+ sudo "ln -sf #{deploy_to}/wordpress/wp-config.php #{wordpress_install_dir}/wp-config.php"
81
+ sudo "ln -sf #{deploy_to}/wordpress/apache2_wordpress_vhost.conf #{apache_vhost_dir}/#{application}.conf"
82
+ end
83
+
84
+ desc <<-EOF
85
+ Create a database for WordPress on your web server, as well as
86
+ a MySQL user who has all privileges for accessing and modifying it.
87
+ EOF
88
+ task :create_database, :roles => lambda { db_host } do
89
+ run <<-EOF
90
+ mysql -u root -e 'create database #{DB_NAME}'
91
+ mysql -u root -e 'grant all on sct_blog.* to '#{DB_USER}'@'%' identified by '#{DB_PASSWORD}'
92
+ mysql -u root -e 'flush privileges'
93
+ EOF
94
+ end
95
+
96
+ end
97
+ end
98
+
99
+ end