fhcap-cli 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (142) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +10 -0
  3. data/.rakeTasks +7 -0
  4. data/.rspec +1 -0
  5. data/CHANGELOG.md +15 -0
  6. data/Gemfile +4 -0
  7. data/LICENSE.txt +21 -0
  8. data/README.md +150 -0
  9. data/Rakefile +2 -0
  10. data/bin/fhcap +6 -0
  11. data/fhcap-cli.gemspec +44 -0
  12. data/lib/cookbooks/provision/libraries/provision.rb +140 -0
  13. data/lib/cookbooks/provision/metadata.rb +7 -0
  14. data/lib/cookbooks/provision/recipes/aws.rb +15 -0
  15. data/lib/cookbooks/provision/recipes/aws_cluster_create.rb +59 -0
  16. data/lib/cookbooks/provision/recipes/aws_cluster_create_elb.rb +61 -0
  17. data/lib/cookbooks/provision/recipes/aws_cluster_destroy.rb +52 -0
  18. data/lib/cookbooks/provision/recipes/cluster_create.rb +2 -0
  19. data/lib/cookbooks/provision/recipes/cluster_destroy.rb +2 -0
  20. data/lib/cookbooks/provision/recipes/cluster_destroy_instances.rb +11 -0
  21. data/lib/cookbooks/provision/recipes/cluster_provision.rb +4 -0
  22. data/lib/cookbooks/provision/recipes/cluster_provision_instances.rb +55 -0
  23. data/lib/cookbooks/provision/recipes/cluster_status.rb +24 -0
  24. data/lib/cookbooks/provision/recipes/common.rb +9 -0
  25. data/lib/cookbooks/provision/recipes/default.rb +5 -0
  26. data/lib/cookbooks/provision/recipes/openstack.rb +11 -0
  27. data/lib/cookbooks/provision/recipes/openstack_cluster_create.rb +11 -0
  28. data/lib/cookbooks/provision/recipes/openstack_cluster_destroy.rb +4 -0
  29. data/lib/cookbooks/provision/recipes/reset_rabbitmq.rb +49 -0
  30. data/lib/cookbooks/provision/recipes/restart_services.rb +24 -0
  31. data/lib/extensions/chef/provisioning.rb +21 -0
  32. data/lib/extensions/chef/provisioning/aws_driver/driver.rb +46 -0
  33. data/lib/extensions/chef/provisioning/chef_run_data.rb +18 -0
  34. data/lib/extensions/cheffish/merged_config.rb +9 -0
  35. data/lib/fhcap.rb +14 -0
  36. data/lib/fhcap/chef-dk/chef_runner.rb +94 -0
  37. data/lib/fhcap/cli.rb +75 -0
  38. data/lib/fhcap/cluster.rb +112 -0
  39. data/lib/fhcap/config.rb +104 -0
  40. data/lib/fhcap/cookbook.rb +75 -0
  41. data/lib/fhcap/dummy_node.rb +80 -0
  42. data/lib/fhcap/fhcap_helper.rb +9 -0
  43. data/lib/fhcap/kitchen.rb +235 -0
  44. data/lib/fhcap/knife.rb +74 -0
  45. data/lib/fhcap/knife_helper.rb +38 -0
  46. data/lib/fhcap/misc.rb +103 -0
  47. data/lib/fhcap/provider.rb +41 -0
  48. data/lib/fhcap/providers_helper.rb +60 -0
  49. data/lib/fhcap/repo.rb +52 -0
  50. data/lib/fhcap/repos_helper.rb +217 -0
  51. data/lib/fhcap/tasks/chef/chef_task_base.rb +82 -0
  52. data/lib/fhcap/tasks/chef/cookbook/list.rb +37 -0
  53. data/lib/fhcap/tasks/chef/cookbook/update_changelog.rb +63 -0
  54. data/lib/fhcap/tasks/chef/cookbook/update_metadata.rb +57 -0
  55. data/lib/fhcap/tasks/chef/cookbook/update_readme.rb +30 -0
  56. data/lib/fhcap/tasks/chef/cookbook/update_version.rb +90 -0
  57. data/lib/fhcap/tasks/chef/environments/create.rb +115 -0
  58. data/lib/fhcap/tasks/chef/environments/destroy.rb +37 -0
  59. data/lib/fhcap/tasks/chef/environments/promote_cookbooks.rb +47 -0
  60. data/lib/fhcap/tasks/chef/provisioning/chef_provisioning_task.rb +27 -0
  61. data/lib/fhcap/tasks/chef/provisioning/chef_provisioning_task_base.rb +38 -0
  62. data/lib/fhcap/tasks/chef/provisioning/create.rb +22 -0
  63. data/lib/fhcap/tasks/chef/provisioning/destroy.rb +21 -0
  64. data/lib/fhcap/tasks/chef/provisioning/provision.rb +19 -0
  65. data/lib/fhcap/tasks/chef/server/bootstrap.rb +165 -0
  66. data/lib/fhcap/tasks/chef/server/create_user.rb +97 -0
  67. data/lib/fhcap/tasks/chef/server/info.rb +82 -0
  68. data/lib/fhcap/tasks/chef/server/provision.rb +45 -0
  69. data/lib/fhcap/tasks/clean.rb +34 -0
  70. data/lib/fhcap/tasks/cluster/cluster_task_base.rb +57 -0
  71. data/lib/fhcap/tasks/cluster/create.rb +243 -0
  72. data/lib/fhcap/tasks/cluster/create_environment.rb +171 -0
  73. data/lib/fhcap/tasks/cluster/destroy.rb +30 -0
  74. data/lib/fhcap/tasks/cluster/destroy_environment.rb +28 -0
  75. data/lib/fhcap/tasks/cluster/info.rb +67 -0
  76. data/lib/fhcap/tasks/cluster/list.rb +40 -0
  77. data/lib/fhcap/tasks/cluster/provision.rb +46 -0
  78. data/lib/fhcap/tasks/cluster/status.rb +17 -0
  79. data/lib/fhcap/tasks/cluster/test.rb +15 -0
  80. data/lib/fhcap/tasks/knife/add.rb +111 -0
  81. data/lib/fhcap/tasks/knife/list.rb +22 -0
  82. data/lib/fhcap/tasks/knife/remove.rb +39 -0
  83. data/lib/fhcap/tasks/misc/create_dns_record.rb +100 -0
  84. data/lib/fhcap/tasks/misc/create_ssl_cert.rb +82 -0
  85. data/lib/fhcap/tasks/provider/add.rb +136 -0
  86. data/lib/fhcap/tasks/provider/list.rb +31 -0
  87. data/lib/fhcap/tasks/provider/remove.rb +28 -0
  88. data/lib/fhcap/tasks/repo/add.rb +57 -0
  89. data/lib/fhcap/tasks/repo/checkout.rb +144 -0
  90. data/lib/fhcap/tasks/repo/list.rb +22 -0
  91. data/lib/fhcap/tasks/repo/remove.rb +34 -0
  92. data/lib/fhcap/tasks/setup.rb +59 -0
  93. data/lib/fhcap/tasks/task_base.rb +89 -0
  94. data/lib/fhcap/thor_base.rb +121 -0
  95. data/lib/fhcap/version.rb +3 -0
  96. data/spec/fhcap/cli_spec.rb +6 -0
  97. data/spec/fhcap/tasks/cluster/create_spec.rb +46 -0
  98. data/spec/fhcap/tasks/knife/add_spec.rb +35 -0
  99. data/spec/fhcap/tasks/knife/remove_spec.rb +25 -0
  100. data/spec/fhcap/tasks/provider/add_spec.rb +61 -0
  101. data/spec/fhcap/tasks/provider/remove_spec.rb +25 -0
  102. data/spec/fhcap/tasks/repo/add_spec.rb +32 -0
  103. data/spec/fhcap/tasks/repo/remove_spec.rb +25 -0
  104. data/spec/fhcap/tasks/task_base_spec.rb +51 -0
  105. data/spec/fhcap/thor_base_spec.rb +9 -0
  106. data/spec/spec_helper.rb +23 -0
  107. data/spec/support/dummy_config.rb +7 -0
  108. data/spec/support/dummy_thor.rb +3 -0
  109. data/templates/chef/cookbook/changelog.md.erb +12 -0
  110. data/templates/chef/cookbook/metadata.erb +45 -0
  111. data/templates/chef/environment_core.json.erb +278 -0
  112. data/templates/chef/environment_empty.json.erb +10 -0
  113. data/templates/chef/environment_mbaas.json.erb +120 -0
  114. data/templates/chef/environment_single.json.erb +300 -0
  115. data/templates/cluster/aws/common.json.erb +43 -0
  116. data/templates/cluster/aws/core-3node.json.erb +106 -0
  117. data/templates/cluster/aws/core-small-9node.json.erb +333 -0
  118. data/templates/cluster/aws/mbaas-3node.json.erb +116 -0
  119. data/templates/cluster/aws/nginx-test.json.erb +93 -0
  120. data/templates/cluster/aws/single-blank.json.erb +41 -0
  121. data/templates/cluster/aws/single.json.erb +88 -0
  122. data/templates/cluster/core-3node.json.erb +8 -0
  123. data/templates/cluster/core-mbaas-6node.json.erb +13 -0
  124. data/templates/cluster/core-small-9node.json.erb +8 -0
  125. data/templates/cluster/mbaas-3node.json.erb +9 -0
  126. data/templates/cluster/nginx-test.json.erb +8 -0
  127. data/templates/cluster/openstack/common.json.erb +7 -0
  128. data/templates/cluster/openstack/core-3node.json.erb +14 -0
  129. data/templates/cluster/openstack/core-small-9node.json.erb +32 -0
  130. data/templates/cluster/openstack/mbaas-3node.json.erb +14 -0
  131. data/templates/cluster/openstack/nginx-test.json.erb +11 -0
  132. data/templates/cluster/openstack/single-blank.json.erb +10 -0
  133. data/templates/cluster/openstack/single.json.erb +10 -0
  134. data/templates/cluster/single-blank.json.erb +8 -0
  135. data/templates/cluster/single.json.erb +8 -0
  136. data/templates/init/knife.rb.erb +13 -0
  137. data/templates/kitchen/Cheffile.erb +11 -0
  138. data/templates/kitchen/kitchen.aws.yml.erb +35 -0
  139. data/templates/kitchen/kitchen.docker.yml.erb +24 -0
  140. data/templates/kitchen/kitchen.generate.yml.erb +2 -0
  141. data/templates/kitchen/kitchen.openstack.yml.erb +31 -0
  142. metadata +506 -0
@@ -0,0 +1,61 @@
1
+ require 'spec_helper'
2
+ require "fhcap/tasks/provider/add"
3
+
4
+ describe Fhcap::Tasks::Provider::Add do
5
+
6
+ subject {
7
+ Fhcap::Tasks::Provider::Add.new(options)
8
+ }
9
+
10
+ let(:thor) do
11
+ DummyThor.new
12
+ end
13
+
14
+ context "aws" do
15
+
16
+ let(:options) do
17
+ {
18
+ :thor => thor,
19
+ :name => 'testawsprovider',
20
+ :type => 'aws',
21
+ :credentials => {
22
+ :'aws-access-key' => 'testkey',
23
+ :'aws-secret-key' => 'testsecret'
24
+ }
25
+ }
26
+ end
27
+
28
+ describe "#initialize" do
29
+ specify { expect(subject.name).to eq(options[:name]) }
30
+ specify { expect(subject.type).to eq(options[:type]) }
31
+ specify { expect(subject.credentials).to eq(options[:credentials]) }
32
+ specify { expect(subject.instance_variable_get(:@required_credentials)).to eq(%w{aws-access-key aws-secret-key}) }
33
+ end
34
+ end
35
+
36
+ context "openstack" do
37
+
38
+ let(:options) do
39
+ {
40
+ :thor => thor,
41
+ :name => 'testosprovider',
42
+ :type => 'openstack',
43
+ :credentials => {
44
+ :'os-auth-url' => 'testos-auth-url',
45
+ :'os-tenant-id' => 'testos-tenant-id',
46
+ :'os-tenant-name' => 'testos-tenant-name',
47
+ :'os-username' => 'testos-username',
48
+ :'os-os-password' => 'testos-password'
49
+ }
50
+ }
51
+ end
52
+
53
+ describe "#initialize" do
54
+ specify { expect(subject.name).to eq(options[:name]) }
55
+ specify { expect(subject.type).to eq(options[:type]) }
56
+ specify { expect(subject.credentials).to eq(options[:credentials]) }
57
+ specify { expect(subject.instance_variable_get(:@required_credentials)).to eq(%w{os-auth-url os-tenant-id os-tenant-name os-username os-password}) }
58
+ end
59
+ end
60
+
61
+ end
@@ -0,0 +1,25 @@
1
+ require 'spec_helper'
2
+ require "fhcap/tasks/knife/remove"
3
+
4
+ describe Fhcap::Tasks::Knife::Remove do
5
+
6
+ subject {
7
+ Fhcap::Tasks::Knife::Remove.new(options)
8
+ }
9
+
10
+ let(:thor) do
11
+ DummyThor.new
12
+ end
13
+
14
+ let(:options) do
15
+ {
16
+ :thor => thor,
17
+ :name => 'testrepo'
18
+ }
19
+ end
20
+
21
+ describe "#initialize" do
22
+ specify { expect(subject.name).to eq(options[:name]) }
23
+ end
24
+
25
+ end
@@ -0,0 +1,32 @@
1
+ require 'spec_helper'
2
+ require "fhcap/tasks/repo/add"
3
+
4
+ describe Fhcap::Tasks::Repo::Add do
5
+
6
+ subject {
7
+ Fhcap::Tasks::Repo::Add.new(options)
8
+ }
9
+
10
+ let(:config) do
11
+ {:repos => {}}
12
+ end
13
+
14
+ let(:thor) do
15
+ DummyThor.new
16
+ end
17
+
18
+ let(:options) do
19
+ {
20
+ :config => config,
21
+ :thor => thor,
22
+ :name => 'testrepo',
23
+ :url => 'https://example.com',
24
+ }
25
+ end
26
+
27
+ describe "#initialize" do
28
+ specify { expect(subject.name).to eq(options[:name]) }
29
+ specify { expect(subject.repo_config[:url]).to eq(options[:url]) }
30
+ end
31
+
32
+ end
@@ -0,0 +1,25 @@
1
+ require 'spec_helper'
2
+ require "fhcap/tasks/repo/remove"
3
+
4
+ describe Fhcap::Tasks::Repo::Remove do
5
+
6
+ subject {
7
+ Fhcap::Tasks::Repo::Remove.new(options)
8
+ }
9
+
10
+ let(:thor) do
11
+ DummyThor.new
12
+ end
13
+
14
+ let(:options) do
15
+ {
16
+ :thor => thor,
17
+ :name => 'testrepo'
18
+ }
19
+ end
20
+
21
+ describe "#initialize" do
22
+ specify { expect(subject.name).to eq(options[:name]) }
23
+ end
24
+
25
+ end
@@ -0,0 +1,51 @@
1
+ require 'spec_helper'
2
+ require "fhcap/tasks/repo/remove"
3
+
4
+ class DummyThor < Fhcap::ThorBase
5
+
6
+ end
7
+
8
+ class DummyTask < Fhcap::Tasks::TaskBase
9
+
10
+ end
11
+
12
+ describe Fhcap::Tasks::TaskBase do
13
+
14
+ subject { task }
15
+
16
+ let(:thor) do
17
+ DummyThor.new
18
+ end
19
+
20
+ let(:options) do
21
+ {:thor => thor, :config => {}}
22
+ end
23
+
24
+ let(:task) do
25
+ DummyTask.new(options)
26
+ end
27
+
28
+ describe "#initialize" do
29
+ specify { expect(subject.options).to eq(options) }
30
+ specify { expect(subject.thor).to eq(thor) }
31
+ specify { expect(subject.verbose).to be_falsey }
32
+ specify { expect(subject.config).to eq({}) }
33
+ end
34
+
35
+ describe "#exit_with_error" do
36
+
37
+ it "should exit with error" do
38
+ expect { subject.exit_with_error('test message') }.to raise_error(SystemExit)
39
+ end
40
+
41
+ it "should output correct error message" do
42
+ expect {
43
+ begin subject.exit_with_error('test message')
44
+ rescue SystemExit
45
+ end
46
+ }.to output(/test message/).to_stdout
47
+ end
48
+
49
+ end
50
+
51
+ end
@@ -0,0 +1,9 @@
1
+ require 'spec_helper'
2
+ require "fhcap/thor_base"
3
+
4
+ describe Fhcap::ThorBase do
5
+ describe "#initialize" do
6
+ it "sets default config" do
7
+ end
8
+ end
9
+ end
@@ -0,0 +1,23 @@
1
+
2
+ require "fhcap"
3
+ require "fhcap/cli"
4
+ require 'support/dummy_thor'
5
+ require 'support/dummy_config'
6
+
7
+ RSpec.configure do |config|
8
+
9
+ config.warnings = false
10
+
11
+ original_stderr = $stderr
12
+ original_stdout = $stdout
13
+ config.before(:all) do
14
+ # Redirect stderr and stdout
15
+ $stderr = File.open(File::NULL, "w")
16
+ $stdout = File.open(File::NULL, "w")
17
+ end
18
+ config.after(:all) do
19
+ $stderr = original_stderr
20
+ $stdout = original_stdout
21
+ end
22
+
23
+ end
@@ -0,0 +1,7 @@
1
+ class DummyConfig < Fhcap::Config
2
+
3
+ def default_dir
4
+ File.join(Dir.pwd)
5
+ end
6
+
7
+ end
@@ -0,0 +1,3 @@
1
+ class DummyThor < Fhcap::ThorBase
2
+
3
+ end
@@ -0,0 +1,12 @@
1
+ <%= config[:cookbook] %> CHANGELOG
2
+ ==========================
3
+
4
+ This file is used to list changes made in each version of the <%= config[:cookbook] %> cookbook.
5
+ <%- config[:changelog].sort_by{|k,v| Gem::Version.new(k) }.reverse.each do |version, entries| -%>
6
+
7
+ ## <%= version %>:
8
+
9
+ <%- entries.each do |entry| -%>
10
+ * <%= entry%>
11
+ <%- end -%>
12
+ <%- end -%>
@@ -0,0 +1,45 @@
1
+ name '<%= cookbook %>'
2
+ maintainer '<%= maintainer %>'
3
+ maintainer_email '<%= maintainer_email %>'
4
+ license '<%= license%>'
5
+ description '<%= description %>'
6
+ long_description IO.read(File.join(File.dirname(__FILE__), 'README.md'))
7
+ version '<%= version %>'
8
+
9
+ <% platforms.each do |k,v| %>
10
+ supports '<%= k %>'
11
+ <% end %>
12
+
13
+ <% dependencies.sort.each do |k,v| %>
14
+ depends '<%= k %>'
15
+ <% end %>
16
+
17
+ <% sanatized_recipes_hash = {}
18
+ recipes.each do |k, v|
19
+ v = "" if v.empty?
20
+ k = "#{k}::default" if /::/ !~ k
21
+ sanatized_recipes_hash[k.to_s] = v
22
+ end
23
+ %>
24
+ <% sanatized_recipes_hash.sort.each do |k, v| %>
25
+ recipe '<%= k.to_s %>', '<%= v %>'
26
+ <% end %>
27
+ <% attributes.sort.each do |attr_name, attr_hash| %>
28
+
29
+ attribute '<%= attr_name %>',
30
+ <% sanatized_attrs_hash = {}
31
+ attr_hash.each do |k, v|
32
+ if k == 'calculated' || k == 'type' || (k == 'choice' && v.empty?)
33
+ next
34
+ end
35
+ sanatized_attrs_hash[k] = v
36
+ end
37
+ %>
38
+ <% sanatized_attrs_hash.sort.each_with_index do |attr, index| %>
39
+ <%
40
+ k = attr[0]
41
+ v = attr[1]
42
+ %>
43
+ :<%= k %> => <% if v.is_a? Array %><%=v%><% else %>"<%== v %>"<%end%><%if index < sanatized_attrs_hash.length - 1%>,<%end%>
44
+ <% end %>
45
+ <% end %>
@@ -0,0 +1,278 @@
1
+ <%-
2
+ require 'securerandom'
3
+
4
+ @passwords = {}
5
+
6
+ def random_password(name)
7
+ unless @passwords[name]
8
+ @passwords[name]= SecureRandom.urlsafe_base64(6)
9
+ end
10
+ @passwords[name]
11
+ end
12
+ -%>
13
+ {
14
+ "name": "<%= config[:name] %>",
15
+ "description": "<%= config[:name] %> Environment",
16
+ "cookbook_versions": {
17
+ },
18
+ "json_class": "Chef::Environment",
19
+ "chef_type": "environment",
20
+ "default_attributes": {
21
+ "apache2": {
22
+ "buildfarm": {
23
+ "url": "e103-stg-digman-01.feedhenry.net"
24
+ }
25
+ },
26
+ "apache2_feedhenry": {
27
+ "ops_proxy": {
28
+ "enabled": false
29
+ }
30
+ },
31
+ "feedhenry_common": {
32
+ "backups": {
33
+ "enabled": false
34
+ },
35
+ "domain": "<%= config[:domain] %>",
36
+ "baseurl": "<%= config[:name] %>.feedhenry.local",
37
+ "manage": {
38
+ "denyhosts": false
39
+ },
40
+ "notifications": {
41
+ "enabled": false,
42
+ "email": "root"
43
+ }
44
+ },
45
+ "feedhenry_galera": {
46
+ "safe-updates": false,
47
+ "wsrep": {
48
+ "password": "<%= random_password('galerawsrep') %>"
49
+ }
50
+ },
51
+ "fh-aaa": {
52
+ "conf": {
53
+ "fhaaa": {
54
+ "database": {
55
+ "auth": {
56
+ "user": "u-aaa",
57
+ "pass": "<%= random_password('mongoaaa') %>"
58
+ }
59
+ }
60
+ }
61
+ }
62
+ },
63
+ "fh-ditch": {
64
+ "conf": {
65
+ "millicore": {
66
+ "protocol": "http",
67
+ "url": "CHANGEME"
68
+ }
69
+ }
70
+ },
71
+ "fh-messaging": {
72
+ "conf": {
73
+ "database": {
74
+ "auth": {
75
+ "user": "u-messaging",
76
+ "pass": "<%= random_password('mongomessaging') %>"
77
+ }
78
+ }
79
+ },
80
+ "fileimportconfig": {
81
+ "metrics_servers_appserver_names": "local.localhost",
82
+ "metrics_servers_dynoserver_names": "local.localhost"
83
+ }
84
+ },
85
+ "fh-metrics": {
86
+ "conf": {
87
+ "metrics": {
88
+ "database": {
89
+ "auth": {
90
+ "user": "u-messaging",
91
+ "pass": "<%= random_password('mongomessaging') %>"
92
+ }
93
+ }
94
+ }
95
+ }
96
+ },
97
+ "fh-supercore": {
98
+ "conf": {
99
+ "fhsupercore": {
100
+ "database": {
101
+ "auth": {
102
+ "user": "u-supercore",
103
+ "pass": "<%= random_password('mongosupercore') %>",
104
+ "enabled": false
105
+ }
106
+ }
107
+ }
108
+ }
109
+ },
110
+ "millicore": {
111
+ "migrates": {
112
+ "enabled": true
113
+ },
114
+ "conf": {
115
+ "csrf": {
116
+ "checks": {
117
+ "enabled": true
118
+ }
119
+ },
120
+ "digger": {
121
+ "callbackhost": "127.0.0.1",
122
+ "polling": {
123
+ "iphone": true,
124
+ "android": true
125
+ },
126
+ "download": {
127
+ "host": "e103-stg-digman-01.feedhenry.net"
128
+ }
129
+ },
130
+ "ditch": {
131
+ "client": {
132
+ "server": {
133
+ "url": "CHANGEME"
134
+ }
135
+ }
136
+ },
137
+ "environments": {
138
+ "enabled": true
139
+ },
140
+ "fh": {
141
+ "autosetup": {
142
+ "enabled": true,
143
+ "password": "<%= random_password('autosetup') %>",
144
+ "admin": {
145
+ "password": "<%= random_password('autosetup') %>"
146
+ }
147
+ }
148
+ },
149
+ "fhaaa": {
150
+ "authorisation": {
151
+ "enabled": true
152
+ }
153
+ },
154
+ "fhcore": {
155
+ "polling_status": {
156
+ "enabled": false
157
+ }
158
+ },
159
+ "git": {
160
+ "enabled": true,
161
+ "admin-host": "git.<%= config[:domain] %>",
162
+ "external-host": "git.<%= config[:domain] %>",
163
+ "service": "gitlab-shell",
164
+ "enable-branch-selector": true
165
+ },
166
+ "mongodb": {
167
+ "migrates": {
168
+ "enabled": true
169
+ }
170
+ },
171
+ "nodejs": {
172
+ "development": {
173
+ "url": "CHANGEME",
174
+ "user": "CHANGEME",
175
+ "password": "CHANGEME"
176
+ },
177
+ "release": {
178
+ "url": "CHANGEME",
179
+ "user": "CHANGEME",
180
+ "password": "CHANGEME"
181
+ }
182
+ },
183
+ "server": {
184
+ "environment": "development"
185
+ },
186
+ "studio-js-preview-default-device": "galaxy_s6",
187
+ "studio-js-cloudresources-enabled": false,
188
+ "studio-js-admin-environments-mbaases-ui": true,
189
+ "studio": {
190
+ "version": {
191
+ "option": {
192
+ "enabled": false
193
+ }
194
+ }
195
+ }
196
+ }
197
+ },
198
+ "mongodb": {
199
+ "auto_configure": {
200
+ "replicaset": true
201
+ },
202
+ "configfile": null,
203
+ "nojournal": true
204
+ },
205
+ "mongodb_feedhenry": {
206
+ "replicaset_enabled": true,
207
+ "auth_enabled": false,
208
+ "backups": {
209
+ "host_role": "platform_mongo_server",
210
+ "enabled": false
211
+ },
212
+ "admin": {
213
+ "user": "admin",
214
+ "pass": "<%= random_password('mongoadmin') %>"
215
+ }
216
+ },
217
+ "mysql_feedhenry": {
218
+ "backups": {
219
+ "enabled": false
220
+ },
221
+ "db": {
222
+ "core_password": "<%= random_password('mysqlcore') %>",
223
+ "core_admin_password": "<%= random_password('mysqlcoreadmin') %>",
224
+ "backup_password": "<%= random_password('mysqlbackup') %>",
225
+ "munin_password": "<%= random_password('mysqlmunin') %>",
226
+ "nagios_password": "<%= random_password('mysqlnagios') %>",
227
+ "nrpe_password": "<%= random_password('mysqlnrpe') %>"
228
+ },
229
+ "subnet": {
230
+ "whitelist": []
231
+ },
232
+ "logrotate": {
233
+ "enabled": false
234
+ }
235
+ },
236
+ "nagios": {
237
+ "services_databag": "nagios_services,nagios_services_<%= config[:name].gsub('-', '_') %>",
238
+ "contacts_databag": "nagios_contacts",
239
+ "notifications_enabled": 0
240
+ },
241
+ "nginx_feedhenry": {
242
+ "ssl_cert_item": "wildcard.<%= config[:domain] %>",
243
+ "loadbalancer": "<%= config[:domain].gsub('.', '\\.') %>"
244
+ }
245
+ },
246
+ "override_attributes": {
247
+ "authorization": {
248
+ "sudo": {
249
+ "passwordless": true
250
+ }
251
+ },
252
+ "denyhosts": {
253
+ "allowed_hosts": [],
254
+ "config": {
255
+ "admin_email": "",
256
+ "block_service": ""
257
+ }
258
+ },
259
+ "mysql": {
260
+ "server_root_password": "<%= random_password('mysqlroot') %>"
261
+ },
262
+ "rabbitmq_feedhenry": {
263
+ "pass": "<%= random_password('rabbitfeedhenry') %>"
264
+ },
265
+ "rabbitmq_feedhenry_tasks": {
266
+ "pass": "<%= random_password('rabbitfeedhenrytasks') %>"
267
+ },
268
+ "rabbitmq_feedhenry_internal": {
269
+ "pass": "<%= random_password('rabbitfeedhenryinternal') %>"
270
+ },
271
+ "rabbitmq": {
272
+ "erlang_cookie": "<%= random_password('rabbiterlangcookie') %>"
273
+ },
274
+ "redis": {
275
+ "password": "feedhenry101"
276
+ }
277
+ }
278
+ }