server_maint 0.0.3 → 0.0.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (126) hide show
  1. data/.gitmodules +21 -0
  2. data/lib/cookbooks/aws/CHANGELOG.md +11 -0
  3. data/lib/cookbooks/aws/CONTRIBUTING +29 -0
  4. data/lib/cookbooks/aws/LICENSE +201 -0
  5. data/lib/cookbooks/aws/README.md +271 -0
  6. data/lib/cookbooks/aws/attributes/default.rb +20 -0
  7. data/lib/cookbooks/aws/libraries/ec2.rb +58 -0
  8. data/lib/cookbooks/aws/metadata.rb +7 -0
  9. data/lib/cookbooks/aws/providers/ebs_volume.rb +236 -0
  10. data/lib/cookbooks/aws/providers/elastic_ip.rb +90 -0
  11. data/lib/cookbooks/aws/providers/elastic_lb.rb +24 -0
  12. data/lib/cookbooks/aws/providers/resource_tag.rb +93 -0
  13. data/lib/cookbooks/aws/recipes/default.rb +25 -0
  14. data/lib/cookbooks/aws/resources/ebs_volume.rb +17 -0
  15. data/lib/cookbooks/aws/resources/elastic_ip.rb +11 -0
  16. data/lib/cookbooks/aws/resources/elastic_lb.rb +10 -0
  17. data/lib/cookbooks/aws/resources/resource_tag.rb +11 -0
  18. data/lib/cookbooks/database/.gitignore +1 -0
  19. data/lib/cookbooks/database/CHANGELOG.md +51 -0
  20. data/lib/cookbooks/database/CONTRIBUTING +29 -0
  21. data/lib/cookbooks/database/LICENSE +201 -0
  22. data/lib/cookbooks/database/README.md +468 -0
  23. data/lib/cookbooks/database/libraries/provider_database_mysql.rb +103 -0
  24. data/lib/cookbooks/database/libraries/provider_database_mysql_user.rb +76 -0
  25. data/lib/cookbooks/database/libraries/provider_database_postgresql.rb +131 -0
  26. data/lib/cookbooks/database/libraries/provider_database_postgresql_user.rb +83 -0
  27. data/lib/cookbooks/database/libraries/provider_database_sql_server.rb +109 -0
  28. data/lib/cookbooks/database/libraries/provider_database_sql_server_user.rb +106 -0
  29. data/lib/cookbooks/database/libraries/resource_database.rb +119 -0
  30. data/lib/cookbooks/database/libraries/resource_database_user.rb +90 -0
  31. data/lib/cookbooks/database/libraries/resource_mysql_database.rb +34 -0
  32. data/lib/cookbooks/database/libraries/resource_mysql_database_user.rb +34 -0
  33. data/lib/cookbooks/database/libraries/resource_postgresql_database.rb +35 -0
  34. data/lib/cookbooks/database/libraries/resource_postgresql_database_user.rb +35 -0
  35. data/lib/cookbooks/database/libraries/resource_sql_server_database.rb +34 -0
  36. data/lib/cookbooks/database/libraries/resource_sql_server_database_user.rb +34 -0
  37. data/lib/cookbooks/database/metadata.rb +22 -0
  38. data/lib/cookbooks/database/recipes/default.rb +20 -0
  39. data/lib/cookbooks/database/recipes/ebs_backup.rb +89 -0
  40. data/lib/cookbooks/database/recipes/ebs_volume.rb +204 -0
  41. data/lib/cookbooks/database/recipes/master.rb +78 -0
  42. data/lib/cookbooks/database/recipes/mysql.rb +20 -0
  43. data/lib/cookbooks/database/recipes/postgresql.rb +20 -0
  44. data/lib/cookbooks/database/recipes/snapshot.rb +62 -0
  45. data/lib/cookbooks/database/templates/default/app_grants.sql.erb +8 -0
  46. data/lib/cookbooks/database/templates/default/aws_config.erb +3 -0
  47. data/lib/cookbooks/database/templates/default/chef-solo-database-snapshot.cron.erb +6 -0
  48. data/lib/cookbooks/database/templates/default/chef-solo-database-snapshot.json.erb +1 -0
  49. data/lib/cookbooks/database/templates/default/chef-solo-database-snapshot.rb.erb +6 -0
  50. data/lib/cookbooks/database/templates/default/ebs-backup-cron.erb +2 -0
  51. data/lib/cookbooks/database/templates/default/ebs-db-backup.sh.erb +8 -0
  52. data/lib/cookbooks/database/templates/default/ebs-db-restore.sh.erb +10 -0
  53. data/lib/cookbooks/database/templates/default/s3cfg.erb +27 -0
  54. data/lib/cookbooks/mysql/.gitignore +5 -0
  55. data/lib/cookbooks/mysql/CHANGELOG.md +86 -0
  56. data/lib/cookbooks/mysql/CONTRIBUTING +29 -0
  57. data/lib/cookbooks/mysql/Gemfile +8 -0
  58. data/lib/cookbooks/mysql/LICENSE +201 -0
  59. data/lib/cookbooks/mysql/README.md +227 -0
  60. data/lib/cookbooks/mysql/attributes/client.rb +50 -0
  61. data/lib/cookbooks/mysql/attributes/server.rb +153 -0
  62. data/lib/cookbooks/mysql/files/default/tests/minitest/server_test.rb +36 -0
  63. data/lib/cookbooks/mysql/files/default/tests/minitest/support/helpers.rb +11 -0
  64. data/lib/cookbooks/mysql/libraries/helpers.rb +33 -0
  65. data/lib/cookbooks/mysql/metadata.rb +140 -0
  66. data/lib/cookbooks/mysql/recipes/client.rb +59 -0
  67. data/lib/cookbooks/mysql/recipes/default.rb +20 -0
  68. data/lib/cookbooks/mysql/recipes/ruby.rb +36 -0
  69. data/lib/cookbooks/mysql/recipes/server.rb +216 -0
  70. data/lib/cookbooks/mysql/recipes/server_ec2.rb +51 -0
  71. data/lib/cookbooks/mysql/templates/default/debian.cnf.erb +12 -0
  72. data/lib/cookbooks/mysql/templates/default/grants.sql.erb +15 -0
  73. data/lib/cookbooks/mysql/templates/default/my.cnf.erb +211 -0
  74. data/lib/cookbooks/mysql/templates/default/mysql-server.seed.erb +10 -0
  75. data/lib/cookbooks/mysql/templates/default/port_mysql.erb +3 -0
  76. data/lib/cookbooks/mysql/templates/windows/my.cnf.erb +61 -0
  77. data/lib/cookbooks/mysql/test/features/query_database.feature +26 -0
  78. data/lib/cookbooks/mysql/test/features/step_definitions/mysql_steps.rb +47 -0
  79. data/lib/cookbooks/mysql/test/features/support/env.rb +3 -0
  80. data/lib/cookbooks/mysql/test/features/support/mysql_helpers.rb +51 -0
  81. data/lib/cookbooks/mysql/test/kitchen/Kitchenfile +5 -0
  82. data/lib/cookbooks/mysql/test/kitchen/cookbooks/mysql_test/.gitignore +1 -0
  83. data/lib/cookbooks/mysql/test/kitchen/cookbooks/mysql_test/README.md +63 -0
  84. data/lib/cookbooks/mysql/test/kitchen/cookbooks/mysql_test/attributes/default.rb +27 -0
  85. data/lib/cookbooks/mysql/test/kitchen/cookbooks/mysql_test/metadata.rb +10 -0
  86. data/lib/cookbooks/mysql/test/kitchen/cookbooks/mysql_test/recipes/client.rb +20 -0
  87. data/lib/cookbooks/mysql/test/kitchen/cookbooks/mysql_test/recipes/server.rb +72 -0
  88. data/lib/cookbooks/openssl/CHANGELOG.md +0 -0
  89. data/lib/cookbooks/openssl/CONTRIBUTING +29 -0
  90. data/lib/cookbooks/openssl/LICENSE +201 -0
  91. data/lib/cookbooks/openssl/README.md +37 -0
  92. data/lib/cookbooks/openssl/libraries/secure_password.rb +37 -0
  93. data/lib/cookbooks/openssl/metadata.rb +8 -0
  94. data/lib/cookbooks/openssl/recipes/default.rb +19 -0
  95. data/lib/cookbooks/postgresql/CHANGELOG.md +35 -0
  96. data/lib/cookbooks/postgresql/CONTRIBUTING +29 -0
  97. data/lib/cookbooks/postgresql/LICENSE +201 -0
  98. data/lib/cookbooks/postgresql/README.md +148 -0
  99. data/lib/cookbooks/postgresql/attributes/default.rb +103 -0
  100. data/lib/cookbooks/postgresql/metadata.rb +21 -0
  101. data/lib/cookbooks/postgresql/recipes/client.rb +26 -0
  102. data/lib/cookbooks/postgresql/recipes/default.rb +20 -0
  103. data/lib/cookbooks/postgresql/recipes/ruby.rb +40 -0
  104. data/lib/cookbooks/postgresql/recipes/server.rb +64 -0
  105. data/lib/cookbooks/postgresql/recipes/server_debian.rb +64 -0
  106. data/lib/cookbooks/postgresql/recipes/server_redhat.rb +77 -0
  107. data/lib/cookbooks/postgresql/templates/default/debian.postgresql.conf.erb +499 -0
  108. data/lib/cookbooks/postgresql/templates/default/pg_hba.conf.erb +83 -0
  109. data/lib/cookbooks/postgresql/templates/default/redhat.postgresql.conf.erb +501 -0
  110. data/lib/cookbooks/sqlite/.gitignore +4 -0
  111. data/lib/cookbooks/sqlite/CHANGELOG.md +3 -0
  112. data/lib/cookbooks/sqlite/CONTRIBUTING +29 -0
  113. data/lib/cookbooks/sqlite/Gemfile +2 -0
  114. data/lib/cookbooks/sqlite/LICENSE +201 -0
  115. data/lib/cookbooks/sqlite/README.md +36 -0
  116. data/lib/cookbooks/sqlite/metadata.rb +12 -0
  117. data/lib/cookbooks/sqlite/recipes/default.rb +30 -0
  118. data/lib/cookbooks/sqlite/test/kitchen/Kitchenfile +1 -0
  119. data/lib/cookbooks/xfs/CHANGELOG.md +0 -0
  120. data/lib/cookbooks/xfs/CONTRIBUTING +29 -0
  121. data/lib/cookbooks/xfs/LICENSE +201 -0
  122. data/lib/cookbooks/xfs/README.md +30 -0
  123. data/lib/cookbooks/xfs/metadata.rb +12 -0
  124. data/lib/cookbooks/xfs/recipes/default.rb +26 -0
  125. data/lib/server_maint/version.rb +1 -1
  126. metadata +127 -4
@@ -0,0 +1,148 @@
1
+ Description
2
+ ===========
3
+
4
+ Installs and configures PostgreSQL as a client or a server.
5
+
6
+ Requirements
7
+ ============
8
+
9
+ ## Platforms
10
+
11
+ * Debian, Ubuntu
12
+ * Red Hat/CentOS/Scientific (6.0+ required) - "EL6-family"
13
+ * Fedora
14
+ * SUSE
15
+
16
+ Tested on:
17
+
18
+ * Ubuntu 10.04, 11.10, 12.04
19
+ * Red Hat 6.1, Scientific 6.1, CentOS 6.3
20
+
21
+ ## Cookboooks
22
+
23
+ Requires Opscode's `openssl` cookbook for secure password generation.
24
+
25
+ Requires a C compiler and development headers in order to build the
26
+ `pg` RubyGem to provide Ruby bindings in the `ruby` recipe.
27
+
28
+ Opscode's `build-essential` cookbook provides this functionality on
29
+ Debian, Ubuntu, and EL6-family.
30
+
31
+ While not required, Opscode's `database` cookbook contains resources
32
+ and providers that can interact with a PostgreSQL database. This
33
+ cookbook is a dependency of database.
34
+
35
+ Attributes
36
+ ==========
37
+
38
+ The following attributes are set based on the platform, see the
39
+ `attributes/default.rb` file for default values.
40
+
41
+ * `node['postgresql']['version']` - version of postgresql to manage
42
+ * `node['postgresql']['dir']` - home directory of where postgresql
43
+ data and configuration lives.
44
+
45
+ * `node['postgresql']['client']['packages']` - An array of package names
46
+ that should be installed on "client" systems.
47
+ * `node['postgresql']['server']['packages']` - An array of package names
48
+ that should be installed on "server" systems.
49
+
50
+
51
+ The following attributes are generated in
52
+ `recipe[postgresql::server]`.
53
+
54
+ * `node['postgresql']['password']['postgres']` - randomly generated
55
+ password by the `openssl` cookbook's library.
56
+ * `node['postgresql']['ssl']` - whether to enable SSL (off for version
57
+ 8.3, true for 8.4).
58
+
59
+ Recipes
60
+ =======
61
+
62
+ default
63
+ -------
64
+
65
+ Includes the client recipe.
66
+
67
+ client
68
+ ------
69
+
70
+ Installs postgresql client packages and development headers during the
71
+ compile phase. Also installs the `pg` Ruby gem during the compile
72
+ phase so it can be made available for the `database` cookbook's
73
+ resources, providers and libraries.
74
+
75
+ ruby
76
+ ----
77
+
78
+ **NOTE** This recipe may not currently work when installing Chef with
79
+ the
80
+ ["Omnibus" full stack installer](http://opscode.com/chef/install) on
81
+ some platforms due to an incompatibility with OpenSSL. See
82
+ [COOK-1406](http://tickets.opscode.com/browse/COOK-1406)
83
+
84
+ Install the `pg` gem under Chef's Ruby environment so it can be used
85
+ in other recipes.
86
+
87
+ server
88
+ ------
89
+
90
+ Includes the `server_debian` or `server_redhat` recipe to get the
91
+ appropriate server packages installed and service managed. Also
92
+ manages the configuration for the server:
93
+
94
+ * generates a strong default password (via `openssl`) for `postgres`
95
+ * sets the password for postgres
96
+ * manages the `pg_hba.conf` file.
97
+
98
+ server\_debian
99
+ --------------
100
+
101
+ Installs the postgresql server packages, manages the postgresql
102
+ service and the postgresql.conf file.
103
+
104
+ server\_redhat
105
+ --------------
106
+
107
+ Manages the postgres user and group (with UID/GID 26, per RHEL package
108
+ conventions), installs the postgresql server packages, initializes the
109
+ database and manages the postgresql service, and manages the
110
+ postgresql.conf file.
111
+
112
+ Resources/Providers
113
+ ===================
114
+
115
+ See the [database](http://community.opscode.com/cookbooks/database)
116
+ for resources and providers that can be used for managing PostgreSQL
117
+ users and databases.
118
+
119
+ Usage
120
+ =====
121
+
122
+ On systems that need to connect to a PostgreSQL database, add to a run
123
+ list `recipe[postgresql]` or `recipe[postgresql::client]`.
124
+
125
+ On systems that should be PostgreSQL servers, use
126
+ `recipe[postgresql::server]` on a run list. This recipe does set a
127
+ password and expect to use it. It performs a node.save when Chef is
128
+ not running in `solo` mode. If you're using `chef-solo`, you'll need
129
+ to set the attribute `node['postgresql']['password']['postgres']` in
130
+ your node's `json_attribs` file or in a role.
131
+
132
+ License and Author
133
+ ==================
134
+
135
+ Author:: Joshua Timberman (<joshua@opscode.com>)
136
+ Author:: Lamont Granquist (<lamont@opscode.com>)
137
+
138
+ Licensed under the Apache License, Version 2.0 (the "License");
139
+ you may not use this file except in compliance with the License.
140
+ You may obtain a copy of the License at
141
+
142
+ http://www.apache.org/licenses/LICENSE-2.0
143
+
144
+ Unless required by applicable law or agreed to in writing, software
145
+ distributed under the License is distributed on an "AS IS" BASIS,
146
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
147
+ See the License for the specific language governing permissions and
148
+ limitations under the License.
@@ -0,0 +1,103 @@
1
+ #
2
+ # Cookbook Name:: postgresql
3
+ # Attributes:: postgresql
4
+ #
5
+ # Copyright 2008-2009, Opscode, Inc.
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+ #
19
+
20
+ case platform
21
+ when "debian"
22
+
23
+ case
24
+ when platform_version.to_f <= 5.0
25
+ default['postgresql']['version'] = "8.3"
26
+ when platform_version.to_f == 6.0
27
+ default['postgresql']['version'] = "8.4"
28
+ else
29
+ default['postgresql']['version'] = "9.1"
30
+ end
31
+
32
+ set['postgresql']['dir'] = "/etc/postgresql/#{node['postgresql']['version']}/main"
33
+ default['postgresql']['client']['packages'] = %w{postgresql-client libpq-dev}
34
+ default['postgresql']['server']['packages'] = %w{postgresql}
35
+
36
+ when "ubuntu"
37
+
38
+ case
39
+ when platform_version.to_f <= 9.04
40
+ default['postgresql']['version'] = "8.3"
41
+ when platform_version.to_f <= 11.04
42
+ default['postgresql']['version'] = "8.4"
43
+ else
44
+ default['postgresql']['version'] = "9.1"
45
+ end
46
+
47
+ set['postgresql']['dir'] = "/etc/postgresql/#{node['postgresql']['version']}/main"
48
+ default['postgresql']['client']['packages'] = %w{postgresql-client libpq-dev}
49
+ default['postgresql']['server']['packages'] = %w{postgresql}
50
+
51
+ when "fedora"
52
+
53
+ if platform_version.to_f <= 12
54
+ default['postgresql']['version'] = "8.3"
55
+ else
56
+ default['postgresql']['version'] = "8.4"
57
+ end
58
+
59
+ set['postgresql']['dir'] = "/var/lib/pgsql/data"
60
+ default['postgresql']['client']['packages'] = %w{postgresql-devel}
61
+ default['postgresql']['server']['packages'] = %w{postgresql-server}
62
+
63
+ when "amazon"
64
+
65
+ default['postgresql']['version'] = "8.4"
66
+ set['postgresql']['dir'] = "/var/lib/pgsql/data"
67
+ default['postgresql']['client']['packages'] = %w{postgresql-devel}
68
+ default['postgresql']['server']['packages'] = %w{postgresql-server}
69
+
70
+ when "redhat","centos","scientific"
71
+
72
+ default['postgresql']['version'] = "8.4"
73
+ set['postgresql']['dir'] = "/var/lib/pgsql/data"
74
+
75
+ if node['platform_version'].to_f >= 6.0
76
+ default['postgresql']['client']['packages'] = %w{postgresql-devel}
77
+ default['postgresql']['server']['packages'] = %w{postgresql-server}
78
+ else
79
+ default['postgresql']['client']['packages'] = ["postgresql#{node['postgresql']['version'].split('.').join}-devel"]
80
+ default['postgresql']['server']['packages'] = ["postgresql#{node['postgresql']['version'].split('.').join}-server"]
81
+ end
82
+
83
+ when "suse"
84
+
85
+ case
86
+ when platform_version.to_f <= 11.1
87
+ default['postgresql']['version'] = "8.3"
88
+ else
89
+ default['postgresql']['version'] = "9.0"
90
+ end
91
+
92
+ set['postgresql']['dir'] = "/var/lib/pgsql/data"
93
+ default['postgresql']['client']['packages'] = %w{postgresql-client libpq-dev}
94
+ default['postgresql']['server']['packages'] = %w{postgresql-server}
95
+
96
+ else
97
+ default['postgresql']['version'] = "8.4"
98
+ set['postgresql']['dir'] = "/etc/postgresql/#{node['postgresql']['version']}/main"
99
+ default['postgresql']['client']['packages'] = ["postgresql"]
100
+ default['postgresql']['server']['packages'] = ["postgresql"]
101
+ end
102
+
103
+ default['postgresql']['listen_addresses'] = "localhost"
@@ -0,0 +1,21 @@
1
+ maintainer "Opscode, Inc."
2
+ maintainer_email "cookbooks@opscode.com"
3
+ license "Apache 2.0"
4
+ description "Installs and configures postgresql for clients or servers"
5
+ long_description IO.read(File.join(File.dirname(__FILE__), 'README.md'))
6
+ version "1.0.1"
7
+ recipe "postgresql", "Includes postgresql::client"
8
+ recipe "postgresql::client", "Installs postgresql client package(s)"
9
+ recipe "postgresql::server", "Installs postgresql server packages, templates"
10
+ recipe "postgresql::server_redhat", "Installs postgresql server packages, redhat family style"
11
+ recipe "postgresql::server_debian", "Installs postgresql server packages, debian family style"
12
+
13
+ %w{ ubuntu debian fedora suse }.each do |os|
14
+ supports os
15
+ end
16
+
17
+ %w{redhat centos scientific}.each do |el|
18
+ supports el, ">= 6.0"
19
+ end
20
+
21
+ depends "openssl"
@@ -0,0 +1,26 @@
1
+ #
2
+ # Cookbook Name:: postgresql
3
+ # Recipe:: client
4
+ #
5
+ # Author:: Joshua Timberman (<joshua@opscode.com>)
6
+ # Author:: Lamont Granquist (<lamont@opscode.com>)
7
+ # Copyright 2009-2011 Opscode, Inc.
8
+ #
9
+ # Licensed under the Apache License, Version 2.0 (the "License");
10
+ # you may not use this file except in compliance with the License.
11
+ # You may obtain a copy of the License at
12
+ #
13
+ # http://www.apache.org/licenses/LICENSE-2.0
14
+ #
15
+ # Unless required by applicable law or agreed to in writing, software
16
+ # distributed under the License is distributed on an "AS IS" BASIS,
17
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
+ # See the License for the specific language governing permissions and
19
+ # limitations under the License.
20
+ #
21
+
22
+ node['postgresql']['client']['packages'].each do |pg_pack|
23
+ package pg_pack do
24
+ action :install
25
+ end
26
+ end
@@ -0,0 +1,20 @@
1
+ #
2
+ # Cookbook Name:: postgresql
3
+ # Recipe:: default
4
+ #
5
+ # Copyright 2009, Opscode, Inc.
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+ #
19
+
20
+ include_recipe "postgresql::client"
@@ -0,0 +1,40 @@
1
+ #
2
+ # Cookbook Name:: postgresql
3
+ # Recipe:: ruby
4
+ #
5
+ # Author:: Joshua Timberman (<joshua@opscode.com>)
6
+ # Copyright 2012 Opscode, Inc.
7
+ #
8
+ # Licensed under the Apache License, Version 2.0 (the "License");
9
+ # you may not use this file except in compliance with the License.
10
+ # You may obtain a copy of the License at
11
+ #
12
+ # http://www.apache.org/licenses/LICENSE-2.0
13
+ #
14
+ # Unless required by applicable law or agreed to in writing, software
15
+ # distributed under the License is distributed on an "AS IS" BASIS,
16
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+
21
+ begin
22
+ require 'pg'
23
+ rescue LoadError
24
+ execute "apt-get update" do
25
+ ignore_failure true
26
+ action :nothing
27
+ end.run_action(:run) if node['platform_family'] == "debian"
28
+
29
+ node.set['build_essential']['compiletime'] = true
30
+ include_recipe "build-essential"
31
+ include_recipe "postgresql::client"
32
+
33
+ node['postgresql']['client']['packages'].each do |pg_pack|
34
+
35
+ resources("package[#{pg_pack}]").run_action(:install)
36
+
37
+ end
38
+
39
+ chef_gem "pg"
40
+ end
@@ -0,0 +1,64 @@
1
+ #/postgresql.conf.
2
+ # Cookbook Name:: postgresql
3
+ # Recipe:: server
4
+ #
5
+ # Author:: Joshua Timberman (<joshua@opscode.com>)
6
+ # Author:: Lamont Granquist (<lamont@opscode.com>)
7
+ # Copyright 2009-2011, Opscode, Inc.
8
+ #
9
+ # Licensed under the Apache License, Version 2.0 (the "License");
10
+ # you may not use this file except in compliance with the License.
11
+ # You may obtain a copy of the License at
12
+ #
13
+ # http://www.apache.org/licenses/LICENSE-2.0
14
+ #
15
+ # Unless required by applicable law or agreed to in writing, software
16
+ # distributed under the License is distributed on an "AS IS" BASIS,
17
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
+ # See the License for the specific language governing permissions and
19
+ # limitations under the License.
20
+ #
21
+
22
+ ::Chef::Recipe.send(:include, Opscode::OpenSSL::Password)
23
+
24
+ include_recipe "postgresql::client"
25
+
26
+ # randomly generate postgres password
27
+ node.set_unless['postgresql']['password']['postgres'] = secure_password
28
+ node.save unless Chef::Config[:solo]
29
+
30
+ if node['postgresql']['version'].to_f <= 8.3
31
+ node.default['postgresql']['ssl'] = "off"
32
+ else
33
+ node.default['postgresql']['ssl'] = "true"
34
+ end
35
+
36
+ # Include the right "family" recipe for installing the server
37
+ # since they do things slightly differently.
38
+ case node['platform']
39
+ when "redhat", "centos", "fedora", "suse", "scientific", "amazon"
40
+ include_recipe "postgresql::server_redhat"
41
+ when "debian", "ubuntu"
42
+ include_recipe "postgresql::server_debian"
43
+ end
44
+
45
+ template "#{node['postgresql']['dir']}/pg_hba.conf" do
46
+ source "pg_hba.conf.erb"
47
+ owner "postgres"
48
+ group "postgres"
49
+ mode 00600
50
+ notifies :reload, resources(:service => "postgresql"), :immediately
51
+ end
52
+
53
+ # Default PostgreSQL install has 'ident' checking on unix user 'postgres'
54
+ # and 'md5' password checking with connections from 'localhost'. This script
55
+ # runs as user 'postgres', so we can execute the 'role' and 'database' resources
56
+ # as 'root' later on, passing the below credentials in the PG client.
57
+ bash "assign-postgres-password" do
58
+ user 'postgres'
59
+ code <<-EOH
60
+ echo "ALTER ROLE postgres ENCRYPTED PASSWORD '#{node['postgresql']['password']['postgres']}';" | psql
61
+ EOH
62
+ not_if "echo '\connect' | PGPASSWORD=#{node['postgresql']['password']['postgres']} psql --username=postgres --no-password -h localhost"
63
+ action :run
64
+ end
@@ -0,0 +1,64 @@
1
+ #
2
+ # Cookbook Name:: postgresql
3
+ # Recipe:: server
4
+ #
5
+ # Author:: Joshua Timberman (<joshua@opscode.com>)
6
+ # Author:: Lamont Granquist (<lamont@opscode.com>)#
7
+ # Copyright 2009-2011, Opscode, Inc.
8
+ #
9
+ # Licensed under the Apache License, Version 2.0 (the "License");
10
+ # you may not use this file except in compliance with the License.
11
+ # You may obtain a copy of the License at
12
+ #
13
+ # http://www.apache.org/licenses/LICENSE-2.0
14
+ #
15
+ # Unless required by applicable law or agreed to in writing, software
16
+ # distributed under the License is distributed on an "AS IS" BASIS,
17
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
+ # See the License for the specific language governing permissions and
19
+ # limitations under the License.
20
+ #
21
+
22
+ include_recipe "postgresql::client"
23
+
24
+
25
+ if node['postgresql']['version'].to_f <= 8.3
26
+ node.default['postgresql']['ssl'] = "off"
27
+ else
28
+ node.default['postgresql']['ssl'] = "true"
29
+ end
30
+
31
+ node['postgresql']['server']['packages'].each do |pg_pack|
32
+ package pg_pack do
33
+ action :install
34
+ end
35
+ end
36
+
37
+ service "postgresql" do
38
+ case node['platform']
39
+ when "ubuntu"
40
+ case
41
+ when node['platform_version'].to_f <= 10.04
42
+ service_name "postgresql-#{node['postgresql']['version']}"
43
+ else
44
+ service_name "postgresql"
45
+ end
46
+ when "debian"
47
+ case
48
+ when node['platform_version'].to_f <= 5.0
49
+ service_name "postgresql-#{node['postgresql']['version']}"
50
+ else
51
+ service_name "postgresql"
52
+ end
53
+ end
54
+ supports :restart => true, :status => true, :reload => true
55
+ action [:enable, :start]
56
+ end
57
+
58
+ template "#{node['postgresql']['dir']}/postgresql.conf" do
59
+ source "debian.postgresql.conf.erb"
60
+ owner "postgres"
61
+ group "postgres"
62
+ mode 0600
63
+ notifies :restart, resources(:service => "postgresql"), :immediately
64
+ end
@@ -0,0 +1,77 @@
1
+ #
2
+ # Cookbook Name:: postgresql
3
+ # Recipe:: server
4
+ #
5
+ # Author:: Joshua Timberman (<joshua@opscode.com>)
6
+ # Author:: Lamont Granquist (<lamont@opscode.com>)
7
+ # Copyright 2009-2011, Opscode, Inc.
8
+ #
9
+ # Licensed under the Apache License, Version 2.0 (the "License");
10
+ # you may not use this file except in compliance with the License.
11
+ # You may obtain a copy of the License at
12
+ #
13
+ # http://www.apache.org/licenses/LICENSE-2.0
14
+ #
15
+ # Unless required by applicable law or agreed to in writing, software
16
+ # distributed under the License is distributed on an "AS IS" BASIS,
17
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18
+ # See the License for the specific language governing permissions and
19
+ # limitations under the License.
20
+ #
21
+
22
+ include_recipe "postgresql::client"
23
+
24
+ # Create a group and user like the package will.
25
+ # Otherwise the templates fail.
26
+
27
+ group "postgres" do
28
+ gid 26
29
+ end
30
+
31
+ user "postgres" do
32
+ shell "/bin/bash"
33
+ comment "PostgreSQL Server"
34
+ home "/var/lib/pgsql"
35
+ gid "postgres"
36
+ system true
37
+ uid 26
38
+ supports :manage_home => false
39
+ end
40
+
41
+ node['postgresql']['server']['packages'].each do |pg_pack|
42
+ package pg_pack do
43
+ action :install
44
+ end
45
+ end
46
+
47
+ case node['platform']
48
+ when "redhat","centos","scientific"
49
+ case
50
+ when node['platform_version'].to_f >= 6.0
51
+ package "postgresql-server"
52
+ else
53
+ package "postgresql#{node['postgresql']['version'].split('.').join}-server"
54
+ end
55
+ when "fedora","suse"
56
+ package "postgresql-server"
57
+ end
58
+
59
+ # Following not valid for 9.x version of postgresql
60
+ if node['postgresql']['version'].to_f < 9.0
61
+ execute "/sbin/service postgresql initdb" do
62
+ not_if { ::FileTest.exist?(File.join(node['postgresql']['dir'], "PG_VERSION")) }
63
+ end
64
+ end
65
+
66
+ service "postgresql" do
67
+ supports :restart => true, :status => true, :reload => true
68
+ action [:enable, :start]
69
+ end
70
+
71
+ template "#{node['postgresql']['dir']}/postgresql.conf" do
72
+ source "redhat.postgresql.conf.erb"
73
+ owner "postgres"
74
+ group "postgres"
75
+ mode 0600
76
+ notifies :restart, resources(:service => "postgresql"), :immediately
77
+ end