-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathexplain.pp
118 lines (96 loc) · 3.35 KB
/
explain.pp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# Unfortunately there is no way to automatically detect current project directory
if $use_vagrant {
$PROJECT_DIR = '/vagrant'
} else {
fail('Replace this line with correct $PROJECT_DIR value assignment.')
}
# We need to order provision commands [ https://docs.puppetlabs.com/learning/ordering.html ]
Exec['update_pkgs_index']->
Package['curl'] ->
Package['postgresql-9.3'] ->
Package['libexpat1-dev'] ->
Package['libpq-dev'] ->
Exec['install_cpanm']->
Exec['install_cpanm_dbi']->
Exec['install_cpanm_dbd_pg']->
Exec['install_cpanm_date_simple']->
Exec['install_cpanm_mail_sender']->
Exec['install_cpanm_email_valid']->
Exec['install_cpanm_pg_explain']->
Exec['install_cpanm_mojolicious']->
Exec['createuser']->
Exec['createdb']->
Exec['psql_create']->
Exec['psql_apply_patches']->
Exec['psql_grant']->
Exec['run_daemon']
Exec {
path => [
'/usr/local/bin',
'/usr/bin',
'/bin'],
logoutput => true,
}
exec { 'update_pkgs_index': command => 'apt-get update' }
exec { 'install_cpanm': command => 'curl -L http://cpanmin.us | perl - --self-upgrade' }
exec { 'install_cpanm_dbi': command => 'cpanm --notest DBI' }
exec { 'install_cpanm_dbd_pg': command => 'cpanm --notest DBD::Pg' }
exec { 'install_cpanm_date_simple': command => 'cpanm --notest Date::Simple' }
exec { 'install_cpanm_mail_sender': command => 'cpanm --notest Mail::Sender' }
exec { 'install_cpanm_email_valid': command => 'cpanm --notest Email::Valid' }
exec { 'install_cpanm_pg_explain': command => 'cpanm --notest Pg::Explain', timeout => 600 } # Takes about 450-500 secs.
exec { 'install_cpanm_mojolicious': command => 'cpanm --notest Mojolicious' }
exec { 'createuser': command => 'sudo -u postgres psql -c "create role explain with login password \'explain\'"' }
exec { 'createdb': command => 'sudo -u postgres createdb -E utf8 -O explain explain' }
exec { 'psql_create':
command => sprintf("sudo -u postgres psql -d explain < %s/sql/create.sql", $PROJECT_DIR)
}
exec { 'psql_apply_patches':
command => sprintf("ls -1 %s/sql/patch-???.sql | sort | xargs -n1 sudo -u postgres psql -d explain -q -f", $PROJECT_DIR)
}
exec { 'psql_grant':
command => 'sudo -u postgres psql -d explain -c "GRANT USAGE ON SCHEMA public, plans TO explain; GRANT ALL ON ALL TABLES IN SCHEMA public,plans TO explain;"'
}
exec { 'run_daemon': command => sprintf("hypnotoad %s/explain.pl > /dev/null 2> /dev/null &", $PROJECT_DIR) }
package { 'curl': # required by cpanminus installation
ensure => installed
}
package { 'postgresql-9.3':
ensure => installed
}
package { 'libexpat1-dev': # required by XML::Parser
ensure => installed
}
package { 'libpq-dev': # required by DBD::Pg
ensure => installed
}
package { 'nginx':
ensure => installed
}
file { '/etc/nginx/conf.d/explain.conf':
owner => 'root',
group => 'root',
content => '
server {
listen 80;
server_name explain.depesz.loc;
location / {
proxy_pass http://127.0.0.1:12004;
}
}
',
notify => Service['nginx'],
require => Package['nginx'],
}
file { '/etc/nginx/sites-enabled/default':
ensure => "absent",
purge => true,
notify => Service['nginx'],
require => Package['nginx'],
}
service { 'nginx':
ensure => running,
enable => true,
hasstatus => true,
hasrestart => true,
}