aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIsmaël Bouya <ismael.bouya@normalesup.org>2018-02-18 15:30:02 +0100
committerIsmaël Bouya <ismael.bouya@normalesup.org>2018-02-18 19:30:39 +0100
commit159df176f990fd1f819efcfd431677b78f367697 (patch)
tree51c7e2c7b2bafb475a07934caba6076490ecf29b
parent1dca26e507d12b9a38e8740e2c310c8bee4e173c (diff)
downloadPuppet-159df176f990fd1f819efcfd431677b78f367697.tar.gz
Puppet-159df176f990fd1f819efcfd431677b78f367697.tar.zst
Puppet-159df176f990fd1f819efcfd431677b78f367697.zip
Install and configure api and assets
-rw-r--r--modules/role/manifests/cryptoportfolio.pp157
-rw-r--r--modules/role/templates/cryptoportfolio/api_conf.toml.erb16
-rw-r--r--modules/role/templates/cryptoportfolio/cryptoportfolio-app.service.erb14
-rw-r--r--modules/role/templates/cryptoportfolio/static_conf.env.erb4
4 files changed, 159 insertions, 32 deletions
diff --git a/modules/role/manifests/cryptoportfolio.pp b/modules/role/manifests/cryptoportfolio.pp
index 046b79e..0f26527 100644
--- a/modules/role/manifests/cryptoportfolio.pp
+++ b/modules/role/manifests/cryptoportfolio.pp
@@ -5,23 +5,43 @@ class role::cryptoportfolio {
5 5
6 $password_seed = lookup("base_installation::puppet_pass_seed") |$key| { {} } 6 $password_seed = lookup("base_installation::puppet_pass_seed") |$key| { {} }
7 7
8 postgresql::server::db { 'cryptoportfolio': 8 $cf_pg_user = "cryptoportfolio"
9 user => 'cryptoportfolio', 9 $cf_pg_db = "cryptoportfolio"
10 password => postgresql_password('cryptoportfolio', generate_password(24, $password_seed, "postgres_cryptoportfolio")), 10 $cf_pg_password = generate_password(24, $password_seed, "postgres_cryptoportfolio")
11 $cf_pg_host = "localhost:5432"
12
13 $cf_user = "cryptoportfolio"
14 $cf_group = "cryptoportfolio"
15 $cf_home = "/opt/cryptoportfolio"
16 $cf_env = "prod"
17 $cf_front_app_host = "cryptoportfolio.immae.eu"
18 $cf_front_app_port = ""
19 $cf_front_app_ssl = "false"
20 $cf_front_app = "${cf_home}/go/src/immae.eu/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front"
21 $cf_front_app_api_workdir = "${cf_front_app}/cmd/app"
22 $cf_front_app_api_bin = "${cf_front_app_api_workdir}/cryptoportfolio-app"
23 $cf_front_app_api_conf = "${cf_home}/conf.toml"
24 $cf_front_app_api_secret = generate_password(24, $password_seed, "cryptoportfolio_api_secret")
25
26 $cf_front_app_static_conf = "${cf_front_app}/cmd/web/env/prod.env"
27
28 postgresql::server::db { $cf_pg_db:
29 user => $cf_pg_user,
30 password => postgresql_password($cf_pg_user, $cf_pg_password)
11 } 31 }
12 32
13 postgresql::server::pg_hba_rule { 'allow localhost TCP access to cryptoportfolio user': 33 postgresql::server::pg_hba_rule { 'allow localhost TCP access to cryptoportfolio user':
14 type => 'host', 34 type => 'host',
15 database => 'cryptoportfolio', 35 database => $cf_pg_db,
16 user => 'cryptoportfolio', 36 user => $cf_pg_user,
17 address => '127.0.0.1/32', 37 address => '127.0.0.1/32',
18 auth_method => 'md5', 38 auth_method => 'md5',
19 order => "b0", 39 order => "b0",
20 } 40 }
21 postgresql::server::pg_hba_rule { 'allow localhost ip6 TCP access to cryptoportfolio user': 41 postgresql::server::pg_hba_rule { 'allow localhost ip6 TCP access to cryptoportfolio user':
22 type => 'host', 42 type => 'host',
23 database => 'cryptoportfolio', 43 database => $cf_pg_db,
24 user => 'cryptoportfolio', 44 user => $cf_pg_user,
25 address => '::1/128', 45 address => '::1/128',
26 auth_method => 'md5', 46 auth_method => 'md5',
27 order => "b0", 47 order => "b0",
@@ -29,18 +49,16 @@ class role::cryptoportfolio {
29 49
30 class { 'nginx': } 50 class { 'nginx': }
31 51
32 nginx::resource::server { 'cryptoportfolio.immae.eu': 52 nginx::resource::server { $cf_front_app_host:
33 listen_port => 80, 53 listen_port => 80,
34 proxy => 'http://localhost:8000', 54 proxy => 'http://localhost:8000',
35 } 55 }
36 56
37 ensure_packages(["go", "npm", "nodejs", "yarn"]) 57 user { $cf_user:
38 58 name => $cf_user,
39 user { "cryptoportfolio":
40 name => "cryptoportfolio",
41 ensure => "present", 59 ensure => "present",
42 managehome => true, 60 managehome => true,
43 home => "/opt/cryptoportfolio", 61 home => $cf_home,
44 system => true, 62 system => true,
45 password => '!!', 63 password => '!!',
46 } 64 }
@@ -49,37 +67,112 @@ class role::cryptoportfolio {
49 $front_sha256 = lookup("cryptoportfolio::front_sha256") |$key| { {} } 67 $front_sha256 = lookup("cryptoportfolio::front_sha256") |$key| { {} }
50 68
51 unless empty($front_version) { 69 unless empty($front_version) {
52 file { "/opt/cryptoportfolio/front": 70 ensure_packages(["go", "npm", "nodejs", "yarn"])
53 ensure => directory,
54 mode => "0700",
55 owner => "cryptoportfolio",
56 group => "cryptoportfolio",
57 }
58 71
59 file { "/opt/cryptoportfolio/front/${front_version}": 72 file { [
60 ensure => directory, 73 "${cf_home}/go/",
74 "${cf_home}/go/src",
75 "${cf_home}/go/src/immae.eu",
76 "${cf_home}/go/src/immae.eu/Immae",
77 "${cf_home}/go/src/immae.eu/Immae/Projets",
78 "${cf_home}/go/src/immae.eu/Immae/Projets/Cryptomonnaies",
79 "${cf_home}/go/src/immae.eu/Immae/Projets/Cryptomonnaies/Cryptoportfolio",
80 $cf_front_app]:
81 ensure => "directory",
61 mode => "0700", 82 mode => "0700",
62 owner => "cryptoportfolio", 83 owner => $cf_user,
63 group => "cryptoportfolio", 84 group => $cf_group,
64 require => File["/opt/cryptoportfolio/front"], 85 require => User[$cf_user],
65 } 86 }
66 87
67 archive { "/opt/cryptoportfolio/front/${front_version}.tar.gz": 88 archive { "${cf_home}/${front_version}.tar.gz":
68 path => "/opt/cryptoportfolio/front/${front_version}.tar.gz", 89 path => "${cf_home}/${front_version}.tar.gz",
69 source => "https://git.immae.eu/releases/cryptoportfolio/front/front_${front_version}.tar.gz", 90 source => "https://git.immae.eu/releases/cryptoportfolio/front/front_${front_version}.tar.gz",
70 creates => "/opt/cryptoportfolio/front/${front_version}/README.md",
71 checksum_type => "sha256", 91 checksum_type => "sha256",
72 checksum => $front_sha256, 92 checksum => $front_sha256,
73 cleanup => false, 93 cleanup => false,
74 extract => true, 94 extract => true,
75 extract_path => "/opt/cryptoportfolio/front/${front_version}", 95 user => "cryptoportfolio",
76 require => File["/opt/cryptoportfolio/front/${front_version}"], 96 extract_path => $cf_front_app,
97 require => [User[$cf_user], File[$cf_front_app]],
77 } 98 }
78 99
79 file { "/opt/cryptoportfolio/front/current": 100 file { "${cf_home}/front":
80 ensure => "link", 101 ensure => "link",
81 target => "/opt/cryptoportfolio/front/${front_version}", 102 target => $cf_front_app,
82 require => Archive["/opt/cryptoportfolio/front/${front_version}.tar.gz"] 103 require => Archive["/opt/cryptoportfolio/${front_version}.tar.gz"]
104 }
105
106 exec { "go-get-dep":
107 user => $cf_user,
108 environment => ["HOME=${cf_home}"],
109 creates => "${cf_home}/go/bin/dep",
110 command => "/usr/bin/go get -u github.com/golang/dep/cmd/dep",
111 require => User[$cf_user],
112 }
113
114 exec { "go-cryptoportfolio-dependencies":
115 cwd => $cf_front_app,
116 user => $cf_user,
117 environment => ["HOME=${cf_home}"],
118 creates => "${cf_front_app}/vendor",
119 command => "${cf_home}/go/bin/dep ensure",
120 require => [Exec["go-get-dep"], Archive["${cf_home}/${front_version}.tar.gz"]],
121 }
122
123 exec { "go-cryptoportfolio-app":
124 cwd => $cf_front_app_api_workdir,
125 user => $cf_user,
126 environment => ["HOME=${cf_home}"],
127 creates => $cf_front_app_api_bin,
128 command => "/usr/bin/make build",
129 require => Exec["go-cryptoportfolio-dependencies"],
130 }
131
132 file { "/etc/systemd/system/cryptoportfolio-app.service":
133 mode => "0644",
134 owner => "root",
135 group => "root",
136 content => template("role/cryptoportfolio/cryptoportfolio-app.service.erb"),
137 } ~> exec { 'systemctl deamon-reload':
138 command => '/usr/bin/systemctl daemon-reload',
139 refreshonly => true
140 }
141
142 service { 'cryptoportfolio-app':
143 enable => true,
144 ensure => "running",
145 require => [File["/etc/systemd/system/cryptoportfolio-app.service"]],
146 }
147
148 file { $cf_front_app_api_conf:
149 owner => $cf_user,
150 group => $cf_group,
151 mode => "0600",
152 content => template("role/cryptoportfolio/api_conf.toml.erb"),
153 }
154
155 file { $cf_front_app_static_conf:
156 owner => $cf_user,
157 group => $cf_group,
158 mode => "0600",
159 content => template("role/cryptoportfolio/static_conf.env.erb"),
160 }
161
162 exec { "web-cryptoportfolio-dependencies":
163 cwd => "${cf_front_app}/cmd/web",
164 environment => ["HOME=${cf_home}"],
165 command => "/usr/bin/make install",
166 creates => "${cf_front_app}/cmd/web/node_modules",
167 require => [Package["npm"], Package["nodejs"], Package["yarn"]]
168 }
169
170 exec { "web-cryptoportfolio-build":
171 cwd => "${cf_front_app}/cmd/web",
172 environment => ["HOME=${cf_home}"],
173 command => "/usr/bin/make static ENV=${cf_env}",
174 creates => "${cf_front_app}/cmd/web/build/static",
175 require => [File[$cf_front_app_static_conf], Exec["web-cryptoportfolio-dependencies"]]
83 } 176 }
84 } 177 }
85 178
diff --git a/modules/role/templates/cryptoportfolio/api_conf.toml.erb b/modules/role/templates/cryptoportfolio/api_conf.toml.erb
new file mode 100644
index 0000000..13550c9
--- /dev/null
+++ b/modules/role/templates/cryptoportfolio/api_conf.toml.erb
@@ -0,0 +1,16 @@
1log_level="info"
2mode="<%= @cf_env %>"
3log_out="stdout"
4
5[db]
6user="<%= @cf_pg_user %>"
7password="<%= @cf_pg_password %>"
8database="<%= @cf_pg_db %>"
9address="<%= @cf_pg_host %>"
10
11[api]
12domain="<%= @cf_front_app_host %>"
13jwt_secret="<%= @cf_front_app_api_secret %>"
14
15[app]
16public_dir="../web/build/static"
diff --git a/modules/role/templates/cryptoportfolio/cryptoportfolio-app.service.erb b/modules/role/templates/cryptoportfolio/cryptoportfolio-app.service.erb
new file mode 100644
index 0000000..a521c0e
--- /dev/null
+++ b/modules/role/templates/cryptoportfolio/cryptoportfolio-app.service.erb
@@ -0,0 +1,14 @@
1[Unit]
2Description=Cryptoportfolio app
3
4[Service]
5Type=simple
6
7WorkingDirectory=<%= @cf_front_app_api_workdir %>
8User=<%= @cf_user %>
9Group=<%= @cf_group %>
10UMask=007
11
12ExecStart=<%= @cf_front_app_api_bin %> -conf <%= @cf_front_app_api_conf %>
13
14Restart=on-failure
diff --git a/modules/role/templates/cryptoportfolio/static_conf.env.erb b/modules/role/templates/cryptoportfolio/static_conf.env.erb
new file mode 100644
index 0000000..db9759d
--- /dev/null
+++ b/modules/role/templates/cryptoportfolio/static_conf.env.erb
@@ -0,0 +1,4 @@
1API_HOST="<%= @cf_front_app_host %>"
2API_PORT="<%= @cf_front_app_port %>"
3API_HTTPS="<%= @cf_front_app_ssl %>"
4