cloud-mu 2.1.0beta → 3.0.0beta
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/Berksfile +4 -5
- data/Berksfile.lock +179 -0
- data/README.md +1 -6
- data/ansible/roles/geerlingguy.firewall/templates/firewall.bash.j2 +0 -0
- data/ansible/roles/mu-installer/README.md +33 -0
- data/ansible/roles/mu-installer/defaults/main.yml +2 -0
- data/ansible/roles/mu-installer/handlers/main.yml +2 -0
- data/ansible/roles/mu-installer/meta/main.yml +60 -0
- data/ansible/roles/mu-installer/tasks/main.yml +13 -0
- data/ansible/roles/mu-installer/tests/inventory +2 -0
- data/ansible/roles/mu-installer/tests/test.yml +5 -0
- data/ansible/roles/mu-installer/vars/main.yml +2 -0
- data/bin/mu-adopt +125 -0
- data/bin/mu-aws-setup +4 -4
- data/bin/mu-azure-setup +265 -0
- data/bin/mu-azure-tests +43 -0
- data/bin/mu-cleanup +20 -8
- data/bin/mu-configure +224 -98
- data/bin/mu-deploy +8 -3
- data/bin/mu-gcp-setup +16 -8
- data/bin/mu-gen-docs +92 -8
- data/bin/mu-load-config.rb +52 -12
- data/bin/mu-momma-cat +36 -0
- data/bin/mu-node-manage +34 -27
- data/bin/mu-self-update +2 -2
- data/bin/mu-ssh +12 -8
- data/bin/mu-upload-chef-artifacts +11 -4
- data/bin/mu-user-manage +3 -0
- data/cloud-mu.gemspec +8 -11
- data/cookbooks/firewall/libraries/helpers_iptables.rb +2 -2
- data/cookbooks/firewall/metadata.json +1 -1
- data/cookbooks/firewall/recipes/default.rb +5 -9
- data/cookbooks/mu-firewall/attributes/default.rb +2 -0
- data/cookbooks/mu-firewall/metadata.rb +1 -1
- data/cookbooks/mu-glusterfs/templates/default/mu-gluster-client.erb +0 -0
- data/cookbooks/mu-master/Berksfile +2 -2
- data/cookbooks/mu-master/files/default/check_mem.pl +0 -0
- data/cookbooks/mu-master/files/default/cloudamatic.png +0 -0
- data/cookbooks/mu-master/metadata.rb +5 -4
- data/cookbooks/mu-master/recipes/389ds.rb +1 -1
- data/cookbooks/mu-master/recipes/basepackages.rb +30 -10
- data/cookbooks/mu-master/recipes/default.rb +59 -7
- data/cookbooks/mu-master/recipes/firewall-holes.rb +1 -1
- data/cookbooks/mu-master/recipes/init.rb +65 -47
- data/cookbooks/mu-master/recipes/{eks-kubectl.rb → kubectl.rb} +4 -10
- data/cookbooks/mu-master/recipes/sssd.rb +2 -1
- data/cookbooks/mu-master/recipes/update_nagios_only.rb +6 -6
- data/cookbooks/mu-master/templates/default/web_app.conf.erb +2 -2
- data/cookbooks/mu-master/templates/mods/ldap.conf.erb +4 -0
- data/cookbooks/mu-php54/Berksfile +1 -2
- data/cookbooks/mu-php54/metadata.rb +4 -5
- data/cookbooks/mu-php54/recipes/default.rb +1 -1
- data/cookbooks/mu-splunk/templates/default/splunk-init.erb +0 -0
- data/cookbooks/mu-tools/Berksfile +3 -2
- data/cookbooks/mu-tools/files/default/Mu_CA.pem +33 -0
- data/cookbooks/mu-tools/libraries/helper.rb +20 -8
- data/cookbooks/mu-tools/metadata.rb +5 -2
- data/cookbooks/mu-tools/recipes/apply_security.rb +2 -3
- data/cookbooks/mu-tools/recipes/eks.rb +1 -1
- data/cookbooks/mu-tools/recipes/gcloud.rb +5 -30
- data/cookbooks/mu-tools/recipes/nagios.rb +1 -1
- data/cookbooks/mu-tools/recipes/rsyslog.rb +1 -0
- data/cookbooks/mu-tools/recipes/selinux.rb +19 -0
- data/cookbooks/mu-tools/recipes/split_var_partitions.rb +0 -1
- data/cookbooks/mu-tools/recipes/windows-client.rb +256 -122
- data/cookbooks/mu-tools/resources/disk.rb +3 -1
- data/cookbooks/mu-tools/templates/amazon/sshd_config.erb +1 -1
- data/cookbooks/mu-tools/templates/default/etc_hosts.erb +1 -1
- data/cookbooks/mu-tools/templates/default/{kubeconfig.erb → kubeconfig-eks.erb} +0 -0
- data/cookbooks/mu-tools/templates/default/kubeconfig-gke.erb +27 -0
- data/cookbooks/mu-tools/templates/windows-10/sshd_config.erb +137 -0
- data/cookbooks/mu-utility/recipes/nat.rb +4 -0
- data/extras/alpha.png +0 -0
- data/extras/beta.png +0 -0
- data/extras/clean-stock-amis +2 -2
- data/extras/generate-stock-images +131 -0
- data/extras/git-fix-permissions-hook +0 -0
- data/extras/image-generators/AWS/centos6.yaml +17 -0
- data/extras/image-generators/{aws → AWS}/centos7-govcloud.yaml +0 -0
- data/extras/image-generators/{aws → AWS}/centos7.yaml +0 -0
- data/extras/image-generators/{aws → AWS}/rhel7.yaml +0 -0
- data/extras/image-generators/{aws → AWS}/win2k12.yaml +0 -0
- data/extras/image-generators/{aws → AWS}/win2k16.yaml +0 -0
- data/extras/image-generators/{aws → AWS}/windows.yaml +0 -0
- data/extras/image-generators/{gcp → Google}/centos6.yaml +1 -0
- data/extras/image-generators/Google/centos7.yaml +18 -0
- data/extras/python_rpm/build.sh +0 -0
- data/extras/release.png +0 -0
- data/extras/ruby_rpm/build.sh +0 -0
- data/extras/ruby_rpm/muby.spec +1 -1
- data/install/README.md +43 -5
- data/install/deprecated-bash-library.sh +0 -0
- data/install/installer +1 -1
- data/install/jenkinskeys.rb +0 -0
- data/install/mu-master.yaml +55 -0
- data/modules/mommacat.ru +41 -7
- data/modules/mu.rb +444 -149
- data/modules/mu/adoption.rb +500 -0
- data/modules/mu/cleanup.rb +235 -158
- data/modules/mu/cloud.rb +675 -138
- data/modules/mu/clouds/aws.rb +156 -24
- data/modules/mu/clouds/aws/alarm.rb +4 -14
- data/modules/mu/clouds/aws/bucket.rb +60 -18
- data/modules/mu/clouds/aws/cache_cluster.rb +8 -20
- data/modules/mu/clouds/aws/collection.rb +12 -22
- data/modules/mu/clouds/aws/container_cluster.rb +209 -118
- data/modules/mu/clouds/aws/database.rb +120 -45
- data/modules/mu/clouds/aws/dnszone.rb +7 -18
- data/modules/mu/clouds/aws/endpoint.rb +5 -15
- data/modules/mu/clouds/aws/firewall_rule.rb +144 -72
- data/modules/mu/clouds/aws/folder.rb +4 -11
- data/modules/mu/clouds/aws/function.rb +6 -16
- data/modules/mu/clouds/aws/group.rb +4 -12
- data/modules/mu/clouds/aws/habitat.rb +11 -13
- data/modules/mu/clouds/aws/loadbalancer.rb +40 -28
- data/modules/mu/clouds/aws/log.rb +5 -13
- data/modules/mu/clouds/aws/msg_queue.rb +9 -24
- data/modules/mu/clouds/aws/nosqldb.rb +4 -12
- data/modules/mu/clouds/aws/notifier.rb +6 -13
- data/modules/mu/clouds/aws/role.rb +69 -40
- data/modules/mu/clouds/aws/search_domain.rb +17 -20
- data/modules/mu/clouds/aws/server.rb +184 -94
- data/modules/mu/clouds/aws/server_pool.rb +33 -38
- data/modules/mu/clouds/aws/storage_pool.rb +5 -12
- data/modules/mu/clouds/aws/user.rb +59 -33
- data/modules/mu/clouds/aws/userdata/linux.erb +18 -30
- data/modules/mu/clouds/aws/userdata/windows.erb +9 -9
- data/modules/mu/clouds/aws/vpc.rb +214 -145
- data/modules/mu/clouds/azure.rb +978 -44
- data/modules/mu/clouds/azure/container_cluster.rb +413 -0
- data/modules/mu/clouds/azure/firewall_rule.rb +500 -0
- data/modules/mu/clouds/azure/habitat.rb +167 -0
- data/modules/mu/clouds/azure/loadbalancer.rb +205 -0
- data/modules/mu/clouds/azure/role.rb +211 -0
- data/modules/mu/clouds/azure/server.rb +810 -0
- data/modules/mu/clouds/azure/user.rb +257 -0
- data/modules/mu/clouds/azure/userdata/README.md +4 -0
- data/modules/mu/clouds/azure/userdata/linux.erb +137 -0
- data/modules/mu/clouds/azure/userdata/windows.erb +275 -0
- data/modules/mu/clouds/azure/vpc.rb +782 -0
- data/modules/mu/clouds/cloudformation.rb +12 -9
- data/modules/mu/clouds/cloudformation/firewall_rule.rb +5 -13
- data/modules/mu/clouds/cloudformation/server.rb +10 -1
- data/modules/mu/clouds/cloudformation/server_pool.rb +1 -0
- data/modules/mu/clouds/cloudformation/vpc.rb +0 -2
- data/modules/mu/clouds/google.rb +554 -117
- data/modules/mu/clouds/google/bucket.rb +173 -32
- data/modules/mu/clouds/google/container_cluster.rb +1112 -157
- data/modules/mu/clouds/google/database.rb +24 -47
- data/modules/mu/clouds/google/firewall_rule.rb +344 -89
- data/modules/mu/clouds/google/folder.rb +156 -79
- data/modules/mu/clouds/google/group.rb +272 -82
- data/modules/mu/clouds/google/habitat.rb +177 -52
- data/modules/mu/clouds/google/loadbalancer.rb +9 -34
- data/modules/mu/clouds/google/role.rb +1211 -0
- data/modules/mu/clouds/google/server.rb +491 -227
- data/modules/mu/clouds/google/server_pool.rb +233 -48
- data/modules/mu/clouds/google/user.rb +479 -125
- data/modules/mu/clouds/google/userdata/linux.erb +3 -3
- data/modules/mu/clouds/google/userdata/windows.erb +9 -9
- data/modules/mu/clouds/google/vpc.rb +381 -223
- data/modules/mu/config.rb +689 -214
- data/modules/mu/config/bucket.rb +1 -1
- data/modules/mu/config/cache_cluster.rb +1 -1
- data/modules/mu/config/cache_cluster.yml +0 -4
- data/modules/mu/config/container_cluster.rb +18 -9
- data/modules/mu/config/database.rb +6 -23
- data/modules/mu/config/firewall_rule.rb +9 -15
- data/modules/mu/config/folder.rb +22 -21
- data/modules/mu/config/habitat.rb +22 -21
- data/modules/mu/config/loadbalancer.rb +2 -2
- data/modules/mu/config/role.rb +9 -40
- data/modules/mu/config/server.rb +26 -5
- data/modules/mu/config/server_pool.rb +1 -1
- data/modules/mu/config/storage_pool.rb +2 -2
- data/modules/mu/config/user.rb +4 -0
- data/modules/mu/config/vpc.rb +350 -110
- data/modules/mu/defaults/{amazon_images.yaml → AWS.yaml} +37 -39
- data/modules/mu/defaults/Azure.yaml +17 -0
- data/modules/mu/defaults/Google.yaml +24 -0
- data/modules/mu/defaults/README.md +1 -1
- data/modules/mu/deploy.rb +168 -125
- data/modules/mu/groomer.rb +2 -1
- data/modules/mu/groomers/ansible.rb +104 -32
- data/modules/mu/groomers/chef.rb +96 -44
- data/modules/mu/kittens.rb +20602 -0
- data/modules/mu/logger.rb +38 -11
- data/modules/mu/master.rb +90 -8
- data/modules/mu/master/chef.rb +2 -3
- data/modules/mu/master/ldap.rb +0 -1
- data/modules/mu/master/ssl.rb +250 -0
- data/modules/mu/mommacat.rb +917 -513
- data/modules/scratchpad.erb +1 -1
- data/modules/tests/super_complex_bok.yml +0 -0
- data/modules/tests/super_simple_bok.yml +0 -0
- data/roles/mu-master.json +2 -1
- data/spec/azure_creds +5 -0
- data/spec/mu.yaml +56 -0
- data/spec/mu/clouds/azure_spec.rb +164 -27
- data/spec/spec_helper.rb +5 -0
- data/test/clean_up.py +0 -0
- data/test/exec_inspec.py +0 -0
- data/test/exec_mu_install.py +0 -0
- data/test/exec_retry.py +0 -0
- data/test/smoke_test.rb +0 -0
- metadata +90 -118
- data/cookbooks/mu-jenkins/Berksfile +0 -14
- data/cookbooks/mu-jenkins/CHANGELOG.md +0 -13
- data/cookbooks/mu-jenkins/LICENSE +0 -37
- data/cookbooks/mu-jenkins/README.md +0 -105
- data/cookbooks/mu-jenkins/attributes/default.rb +0 -42
- data/cookbooks/mu-jenkins/files/default/cleanup_deploy_config.xml +0 -73
- data/cookbooks/mu-jenkins/files/default/deploy_config.xml +0 -44
- data/cookbooks/mu-jenkins/metadata.rb +0 -21
- data/cookbooks/mu-jenkins/recipes/default.rb +0 -195
- data/cookbooks/mu-jenkins/recipes/node-ssh-config.rb +0 -54
- data/cookbooks/mu-jenkins/recipes/public_key.rb +0 -24
- data/cookbooks/mu-jenkins/templates/default/example_job.config.xml.erb +0 -24
- data/cookbooks/mu-jenkins/templates/default/org.jvnet.hudson.plugins.SSHBuildWrapper.xml.erb +0 -14
- data/cookbooks/mu-jenkins/templates/default/ssh_config.erb +0 -6
- data/cookbooks/nagios/Berksfile +0 -11
- data/cookbooks/nagios/CHANGELOG.md +0 -589
- data/cookbooks/nagios/CONTRIBUTING.md +0 -11
- data/cookbooks/nagios/LICENSE +0 -37
- data/cookbooks/nagios/README.md +0 -328
- data/cookbooks/nagios/TESTING.md +0 -2
- data/cookbooks/nagios/attributes/config.rb +0 -171
- data/cookbooks/nagios/attributes/default.rb +0 -228
- data/cookbooks/nagios/chefignore +0 -102
- data/cookbooks/nagios/definitions/command.rb +0 -33
- data/cookbooks/nagios/definitions/contact.rb +0 -33
- data/cookbooks/nagios/definitions/contactgroup.rb +0 -33
- data/cookbooks/nagios/definitions/host.rb +0 -33
- data/cookbooks/nagios/definitions/hostdependency.rb +0 -33
- data/cookbooks/nagios/definitions/hostescalation.rb +0 -34
- data/cookbooks/nagios/definitions/hostgroup.rb +0 -33
- data/cookbooks/nagios/definitions/nagios_conf.rb +0 -38
- data/cookbooks/nagios/definitions/resource.rb +0 -33
- data/cookbooks/nagios/definitions/service.rb +0 -33
- data/cookbooks/nagios/definitions/servicedependency.rb +0 -33
- data/cookbooks/nagios/definitions/serviceescalation.rb +0 -34
- data/cookbooks/nagios/definitions/servicegroup.rb +0 -33
- data/cookbooks/nagios/definitions/timeperiod.rb +0 -33
- data/cookbooks/nagios/libraries/base.rb +0 -314
- data/cookbooks/nagios/libraries/command.rb +0 -91
- data/cookbooks/nagios/libraries/contact.rb +0 -230
- data/cookbooks/nagios/libraries/contactgroup.rb +0 -112
- data/cookbooks/nagios/libraries/custom_option.rb +0 -36
- data/cookbooks/nagios/libraries/data_bag_helper.rb +0 -23
- data/cookbooks/nagios/libraries/default.rb +0 -90
- data/cookbooks/nagios/libraries/host.rb +0 -412
- data/cookbooks/nagios/libraries/hostdependency.rb +0 -181
- data/cookbooks/nagios/libraries/hostescalation.rb +0 -173
- data/cookbooks/nagios/libraries/hostgroup.rb +0 -119
- data/cookbooks/nagios/libraries/nagios.rb +0 -282
- data/cookbooks/nagios/libraries/resource.rb +0 -59
- data/cookbooks/nagios/libraries/service.rb +0 -455
- data/cookbooks/nagios/libraries/servicedependency.rb +0 -215
- data/cookbooks/nagios/libraries/serviceescalation.rb +0 -195
- data/cookbooks/nagios/libraries/servicegroup.rb +0 -144
- data/cookbooks/nagios/libraries/timeperiod.rb +0 -160
- data/cookbooks/nagios/libraries/users_helper.rb +0 -54
- data/cookbooks/nagios/metadata.rb +0 -25
- data/cookbooks/nagios/recipes/_load_databag_config.rb +0 -153
- data/cookbooks/nagios/recipes/_load_default_config.rb +0 -241
- data/cookbooks/nagios/recipes/apache.rb +0 -48
- data/cookbooks/nagios/recipes/default.rb +0 -204
- data/cookbooks/nagios/recipes/nginx.rb +0 -82
- data/cookbooks/nagios/recipes/pagerduty.rb +0 -143
- data/cookbooks/nagios/recipes/server_package.rb +0 -40
- data/cookbooks/nagios/recipes/server_source.rb +0 -164
- data/cookbooks/nagios/templates/default/apache2.conf.erb +0 -96
- data/cookbooks/nagios/templates/default/cgi.cfg.erb +0 -266
- data/cookbooks/nagios/templates/default/commands.cfg.erb +0 -13
- data/cookbooks/nagios/templates/default/contacts.cfg.erb +0 -37
- data/cookbooks/nagios/templates/default/hostgroups.cfg.erb +0 -25
- data/cookbooks/nagios/templates/default/hosts.cfg.erb +0 -15
- data/cookbooks/nagios/templates/default/htpasswd.users.erb +0 -6
- data/cookbooks/nagios/templates/default/nagios.cfg.erb +0 -22
- data/cookbooks/nagios/templates/default/nginx.conf.erb +0 -62
- data/cookbooks/nagios/templates/default/pagerduty.cgi.erb +0 -185
- data/cookbooks/nagios/templates/default/resource.cfg.erb +0 -27
- data/cookbooks/nagios/templates/default/servicedependencies.cfg.erb +0 -15
- data/cookbooks/nagios/templates/default/servicegroups.cfg.erb +0 -14
- data/cookbooks/nagios/templates/default/services.cfg.erb +0 -14
- data/cookbooks/nagios/templates/default/templates.cfg.erb +0 -31
- data/cookbooks/nagios/templates/default/timeperiods.cfg.erb +0 -13
- data/extras/image-generators/aws/centos6.yaml +0 -18
- data/modules/mu/defaults/google_images.yaml +0 -16
- data/roles/mu-master-jenkins.json +0 -24
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
source 'https://supermarket.chef.io'
|
|
2
|
-
source chef_repo: ".."
|
|
3
|
-
|
|
4
|
-
metadata
|
|
5
|
-
|
|
6
|
-
# Mu Cookbooks
|
|
7
|
-
cookbook 'mu-master'
|
|
8
|
-
cookbook 'mu-utility'
|
|
9
|
-
cookbook 'mu-tools'
|
|
10
|
-
|
|
11
|
-
# Supermarket Cookbooks
|
|
12
|
-
cookbook 'java', '~> 2.2.0'
|
|
13
|
-
cookbook 'jenkins', '~> 6.2.0'
|
|
14
|
-
cookbook 'chef-vault', '~> 3.1.1'
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
mu-jenkins CHANGELOG
|
|
2
|
-
====================
|
|
3
|
-
|
|
4
|
-
This file is used to list changes made in each version of the mu-jenkins cookbook.
|
|
5
|
-
|
|
6
|
-
0.1.0
|
|
7
|
-
-----
|
|
8
|
-
- [your_name] - Initial release of mu-jenkins
|
|
9
|
-
|
|
10
|
-
- - -
|
|
11
|
-
Check the [Markdown Syntax Guide](http://daringfireball.net/projects/markdown/syntax) for help with Markdown.
|
|
12
|
-
|
|
13
|
-
The [Github Flavored Markdown page](http://github.github.com/github-flavored-markdown/) describes the differences between markdown on github and standard markdown.
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
Through accessing, reading, or utilizing this software in any manner whatsoever
|
|
2
|
-
or through any means whatsoever, whether the access, reading or use is either
|
|
3
|
-
solely looking at this software or this software has been integrated into any
|
|
4
|
-
derivative work, the party accessing, reading, or utilizing the software
|
|
5
|
-
directly or indirectly agrees to abide by the following license.
|
|
6
|
-
|
|
7
|
-
The eGlobalTech Cloud Automation Platform is the Copyright (c) 2014 of Global
|
|
8
|
-
Tech Inc. All rights reserved.
|
|
9
|
-
|
|
10
|
-
Redistribution and use in source and binary forms, with or without
|
|
11
|
-
modification, are permitted provided that the following conditions are met:
|
|
12
|
-
|
|
13
|
-
1. Redistributions of source code must retain the above copyright notice, this
|
|
14
|
-
list of conditions and the following disclaimer.
|
|
15
|
-
|
|
16
|
-
2. Redistributions in binary form must reproduce the above copyright notice,
|
|
17
|
-
this list of conditions and the following disclaimer in the documentation
|
|
18
|
-
and/or other materials provided with the distribution.
|
|
19
|
-
|
|
20
|
-
3. Neither the name of the copyright holder nor the names of its contributors
|
|
21
|
-
may be used to endorse or promote products derived from this software without
|
|
22
|
-
specific prior written permission.
|
|
23
|
-
|
|
24
|
-
Global Tech, Inc. is the co-owner of any derivative works created with this
|
|
25
|
-
software.
|
|
26
|
-
|
|
27
|
-
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
28
|
-
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
29
|
-
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
30
|
-
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
31
|
-
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
32
|
-
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
33
|
-
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
34
|
-
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
35
|
-
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
36
|
-
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
37
|
-
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
mu-jenkins Cookbook
|
|
2
|
-
===================
|
|
3
|
-
This cookbook creates a working Jenkins installation. It can be deployed on a standalone node (see demo/jenkins.yaml) or as a Jenkins server on the mu-master itself.
|
|
4
|
-
|
|
5
|
-
Requirements
|
|
6
|
-
------------
|
|
7
|
-
This is a wrapper cookbook that is meant to be run after a Jenkins install using the Jenkins community cookbook. The recipe uses some groovy scripts to manage jenkins authentication from chef itself, and create an additional administrave Jenkins user for interactive work.
|
|
8
|
-
|
|
9
|
-
A jenkins vault must be present before invoking. Two items are required
|
|
10
|
-
- A users item containing passwords for each user enumerated in the default.jenkins_users attribute (see below). The mu-user password is required, as we need at least one interactive Jenkins user
|
|
11
|
-
- An admin item containing a public and private keypair that will be used by chef to authenticate to Jenkins after disabling anonymous authentication, and a username for this user
|
|
12
|
-
|
|
13
|
-
A third optional ssh item is used to store a keypair used by Jenkins to SSH to other nodes, to allow Jenkins to run code locally as part of a Jenkins job.
|
|
14
|
-
|
|
15
|
-
Create the vault items along these lines:
|
|
16
|
-
|
|
17
|
-
admin:
|
|
18
|
-
```
|
|
19
|
-
#!/usr/local/ruby-current/bin/ruby
|
|
20
|
-
require "openssl"
|
|
21
|
-
require 'net/ssh'
|
|
22
|
-
key = OpenSSL::PKey::RSA.new 2048
|
|
23
|
-
public_key = "#{key.public_key.ssh_type} #{[key.public_key.to_blob].pack('m0')}"
|
|
24
|
-
vault_opts="--mode client -u mu -F json"
|
|
25
|
-
vault_cmd = "knife vault create jenkins admin '{ \"public_key\":\"#{public_key}\", \"private_key\":\"#{key.to_pem.chomp!.gsub(/\n/, "\\n")}\", \"username\": \"master_user\" }' #{vault_opts} --search name:MU-MASTER"
|
|
26
|
-
exec vault_cmd
|
|
27
|
-
```
|
|
28
|
-
|
|
29
|
-
users:
|
|
30
|
-
```knife vault create jenkins users '{"mu_user_password":"feefiefoefum"}' --mode client -F json -u mu --search name:MU-MASTER```
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
#### packages
|
|
34
|
-
- `java` - jenkins needs Java to run
|
|
35
|
-
- `jenkins` - mu-jenkins needs jenkins to actually be installed
|
|
36
|
-
|
|
37
|
-
Attributes
|
|
38
|
-
----------
|
|
39
|
-
Some basic attributes on the java install and node address, plus Jenkins specifics:
|
|
40
|
-
|
|
41
|
-
#### mu-jenkins::default
|
|
42
|
-
<table>
|
|
43
|
-
<tr>
|
|
44
|
-
<th>Key</th>
|
|
45
|
-
<th>Type</th>
|
|
46
|
-
<th>Description</th>
|
|
47
|
-
<th>Default</th>
|
|
48
|
-
</tr>
|
|
49
|
-
<tr>
|
|
50
|
-
<td><tt>default.jenkins_users</tt></td>
|
|
51
|
-
<td>Hash</td>
|
|
52
|
-
<td>Jenkins users to create with their properties (excepting password) and a single vault to retrieve creds from</td>
|
|
53
|
-
<td><tt>:user_name => "mu_user", :fullname => "Mu-Demo-User", :email => "mu-developers@googlegroups.com", :vault => "jenkins", :vault_item => "users"}</tt></td>
|
|
54
|
-
</tr>
|
|
55
|
-
<tr>
|
|
56
|
-
<td><tt>default.jenkins_ssh_urls</tt></td>
|
|
57
|
-
<td>Array</td>
|
|
58
|
-
<td>IP addresses / DNS names of nodes Jenkins will SSH into</td>
|
|
59
|
-
<td><tt>[node[:ipaddress]]</tt></td>
|
|
60
|
-
</tr>
|
|
61
|
-
<tr>
|
|
62
|
-
<td><tt>default.jenkins_plugins</tt></td>
|
|
63
|
-
<td>Whitespace string</td>
|
|
64
|
-
<td>plugins to install</td>
|
|
65
|
-
<td><tt>%w{github ssh deploy}</tt></td>
|
|
66
|
-
</tr>
|
|
67
|
-
<tr>
|
|
68
|
-
<td><tt>default.jenkins_ssh_vault</tt></td>
|
|
69
|
-
<td>Hash</td>
|
|
70
|
-
<td>Preexisting vault containing a public private keypair that will be used to SSH to other nodes</td>
|
|
71
|
-
<td><tt>:vault => "jenkins", :item => "ssh"</tt></td>
|
|
72
|
-
</tr>
|
|
73
|
-
<tr>
|
|
74
|
-
<td><tt>default.jenkins_admin_vault</tt></td>
|
|
75
|
-
<td>Hash</td>
|
|
76
|
-
<td>Preexisting vault containing a public private keypair used by Chef to authenticate to Jenkins. This also include the username of the Jenkins user</td>
|
|
77
|
-
<td><tt>:vault => "jenkins", :item => "admin"</tt></td>
|
|
78
|
-
</tr>
|
|
79
|
-
</table>
|
|
80
|
-
|
|
81
|
-
Usage
|
|
82
|
-
-----
|
|
83
|
-
#### mu-jenkins::default
|
|
84
|
-
This cookbook can run in a standalone mode which creates a basic Jenkins install on a target node, or a mu-master mode which creates a Jenkins server on a mu master.
|
|
85
|
-
|
|
86
|
-
In either case the runlist will look like:
|
|
87
|
-
``` run_list:
|
|
88
|
-
- recipe[java]
|
|
89
|
-
- recipe[jenkins::master]
|
|
90
|
-
- recipe[mu-jenkins]
|
|
91
|
-
```
|
|
92
|
-
|
|
93
|
-
In the mu-master mode the cookbook is invoked with the role[mu-master-jenkins], which adds some attributes to trigger the jenkins-apache recipe, which places Jenkins behind a mu-master apache reverse proxy:
|
|
94
|
-
|
|
95
|
-
chef-client -l info -o recipe[java],recipe[jenkins::master],recipe[mu-jenkins]
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
Contributing
|
|
99
|
-
------------
|
|
100
|
-
Usual Cloudamatic process via pull request
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
License and Authors
|
|
104
|
-
-------------------
|
|
105
|
-
Authors: Ami Rahav, Robert Patt-Corner
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
default['jenkins_users'] = [
|
|
3
|
-
# {:user_name => "mu_user", :fullname => "Mu-Demo-User", :email => ENV['MU_ADMIN_EMAIL'], :vault => "jenkins", :vault_item => "users"}
|
|
4
|
-
]
|
|
5
|
-
|
|
6
|
-
default['jenkins_ssh_urls'] = [node['ipaddress']]
|
|
7
|
-
default['jenkins_plugins'] = %w{
|
|
8
|
-
token-macro git github deploy ldap scm-api git-client active-directory
|
|
9
|
-
ansicolor matrix-auth matrix-project workflow-scm-step junit workflow-api
|
|
10
|
-
workflow-step-api ssh credentials ssh-credentials plain-credentials mailer
|
|
11
|
-
display-url-api structs script-security jackson2-api
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
default['jenkins_ports_direct'] = %w{8080 443}
|
|
15
|
-
default['jenkins']['master']['jenkins_args'] = "" if default['jenkins']['master']['jenkins_args'].nil?
|
|
16
|
-
jenkins_args = "" if node['jenkins']['master']['jenkins_args'].nil?
|
|
17
|
-
override['jenkins']['master']['jenkins_args'] = "#{jenkins_args} --prefix=/jenkins"
|
|
18
|
-
default['jenkins']['master']['jvm_options'] = '-Xmx1024m -Djenkins.install.runSetupWizard=false'
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
alpn_version = '8.1.11.v20170118'
|
|
22
|
-
default['jenkins']['alpn']['version'] = alpn_version
|
|
23
|
-
default['jenkins']['alpn']['download_link'] = "http://central.maven.org/maven2/org/mortbay/jetty/alpn/alpn-boot/#{alpn_version}/alpn-boot-#{alpn_version}.jar"
|
|
24
|
-
|
|
25
|
-
# This isn't really true, but the Java libraries lose their minds over
|
|
26
|
-
# self-signed SSL certs like the one you'll usually find on
|
|
27
|
-
# https://#{$MU_CFG['public_address']}/jenkins (the real URL)
|
|
28
|
-
default['jenkins']['master']['endpoint'] = "http://localhost:8080/jenkins"
|
|
29
|
-
default['jenkins_ssh_vault'] = {
|
|
30
|
-
:vault => "jenkins", :item => "ssh"
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
default['jenkins_admin_vault'] = {
|
|
34
|
-
:vault => "jenkins", :item => "admin"
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
override['java']['jdk_version'] = 8
|
|
38
|
-
override['java']['flavor'] = 'oracle'
|
|
39
|
-
override['java']['jdk']['8']['x86_64']['url'] = 'http://download.oracle.com/otn-pub/java/jdk/8u131-b11/d54c1d3a095b4ff2b6607d096fa80163/jdk-8u131-linux-x64.tar.gz'
|
|
40
|
-
override['java']['jdk']['8']['x86_64']['checksum'] = '75b2cb2249710d822a60f83e28860053'
|
|
41
|
-
override["java"]["oracle"]["accept_oracle_download_terms"] = true
|
|
42
|
-
override['java']['oracle']['jce']['enabled'] = true
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
<?xml version='1.0' encoding='UTF-8'?>
|
|
2
|
-
<project>
|
|
3
|
-
<actions/>
|
|
4
|
-
<description>Clean up an extant Cloudamatic Deploy</description>
|
|
5
|
-
<keepDependencies>false</keepDependencies>
|
|
6
|
-
<properties>
|
|
7
|
-
<hudson.security.AuthorizationMatrixProperty>
|
|
8
|
-
<blocksInheritance>true</blocksInheritance>
|
|
9
|
-
<permission>hudson.model.Item.Cancel:master_user</permission>
|
|
10
|
-
<permission>hudson.model.Item.Cancel:mu_user</permission>
|
|
11
|
-
<permission>hudson.model.Item.Delete:master_user</permission>
|
|
12
|
-
<permission>hudson.model.Item.Delete:mu_user</permission>
|
|
13
|
-
<permission>hudson.model.Item.Read:master_user</permission>
|
|
14
|
-
<permission>hudson.model.Item.Read:mu_user</permission>
|
|
15
|
-
<permission>hudson.model.Item.Workspace:master_user</permission>
|
|
16
|
-
<permission>hudson.model.Item.Workspace:mu_user</permission>
|
|
17
|
-
<permission>hudson.model.Item.Build:master_user</permission>
|
|
18
|
-
<permission>hudson.model.Item.Build:mu_user</permission>
|
|
19
|
-
<permission>hudson.model.Item.Move:master_user</permission>
|
|
20
|
-
<permission>hudson.model.Item.Move:mu_user</permission>
|
|
21
|
-
<permission>hudson.model.Item.Configure:master_user</permission>
|
|
22
|
-
<permission>hudson.model.Item.Configure:mu_user</permission>
|
|
23
|
-
<permission>hudson.model.Item.Discover:master_user</permission>
|
|
24
|
-
<permission>hudson.model.Item.Discover:mu_user</permission>
|
|
25
|
-
</hudson.security.AuthorizationMatrixProperty>
|
|
26
|
-
<hudson.model.ParametersDefinitionProperty>
|
|
27
|
-
<parameterDefinitions>
|
|
28
|
-
<com.seitenbau.jenkins.plugins.dynamicparameter.ChoiceParameterDefinition plugin="dynamicparameter@0.2.0">
|
|
29
|
-
<name>Target_Deploy</name>
|
|
30
|
-
<description></description>
|
|
31
|
-
<__uuid>8a5d5b3c-c975-44f8-a1e2-7d3c4f3306f8</__uuid>
|
|
32
|
-
<__remote>false</__remote>
|
|
33
|
-
<__script>def proc = "ls -1a /home/jenkins/.mu/var/deployments/".execute()
|
|
34
|
-
def b = new StringBuffer()
|
|
35
|
-
proc.consumeProcessErrorStream(b)
|
|
36
|
-
def list = proc.text.readLines()
|
|
37
|
-
</__script>
|
|
38
|
-
<__localBaseDirectory serialization="custom">
|
|
39
|
-
<hudson.FilePath>
|
|
40
|
-
<default>
|
|
41
|
-
<remote>/home/jenkins/dynamic_parameter/classpath</remote>
|
|
42
|
-
</default>
|
|
43
|
-
<boolean>true</boolean>
|
|
44
|
-
</hudson.FilePath>
|
|
45
|
-
</__localBaseDirectory>
|
|
46
|
-
<__remoteBaseDirectory>dynamic_parameter_classpath</__remoteBaseDirectory>
|
|
47
|
-
<__classPath></__classPath>
|
|
48
|
-
<readonlyInputField>false</readonlyInputField>
|
|
49
|
-
</com.seitenbau.jenkins.plugins.dynamicparameter.ChoiceParameterDefinition>
|
|
50
|
-
</parameterDefinitions>
|
|
51
|
-
</hudson.model.ParametersDefinitionProperty>
|
|
52
|
-
</properties>
|
|
53
|
-
<scm class="hudson.scm.NullSCM"/>
|
|
54
|
-
<canRoam>true</canRoam>
|
|
55
|
-
<disabled>false</disabled>
|
|
56
|
-
<blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
|
|
57
|
-
<blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
|
|
58
|
-
<triggers/>
|
|
59
|
-
<concurrentBuild>false</concurrentBuild>
|
|
60
|
-
<builders>
|
|
61
|
-
<hudson.tasks.Shell>
|
|
62
|
-
<command>source ~/.murc
|
|
63
|
-
mu-cleanup $Target_Deploy
|
|
64
|
-
</command>
|
|
65
|
-
</hudson.tasks.Shell>
|
|
66
|
-
</builders>
|
|
67
|
-
<publishers/>
|
|
68
|
-
<buildWrappers>
|
|
69
|
-
<hudson.plugins.ansicolor.AnsiColorBuildWrapper plugin="ansicolor@0.4.1">
|
|
70
|
-
<colorMapName>xterm</colorMapName>
|
|
71
|
-
</hudson.plugins.ansicolor.AnsiColorBuildWrapper>
|
|
72
|
-
</buildWrappers>
|
|
73
|
-
</project>
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
<project>
|
|
2
|
-
<actions/>
|
|
3
|
-
<description></description>
|
|
4
|
-
<keepDependencies>false</keepDependencies>
|
|
5
|
-
<properties>
|
|
6
|
-
<hudson.security.AuthorizationMatrixProperty>
|
|
7
|
-
<blocksInheritance>true</blocksInheritance>
|
|
8
|
-
<permission>hudson.model.Item.Cancel:master_user</permission>
|
|
9
|
-
<permission>hudson.model.Item.Cancel:mu_user</permission>
|
|
10
|
-
<permission>hudson.model.Item.Delete:master_user</permission>
|
|
11
|
-
<permission>hudson.model.Item.Delete:mu_user</permission>
|
|
12
|
-
<permission>hudson.model.Item.Read:master_user</permission>
|
|
13
|
-
<permission>hudson.model.Item.Read:mu_user</permission>
|
|
14
|
-
<permission>hudson.model.Item.Workspace:master_user</permission>
|
|
15
|
-
<permission>hudson.model.Item.Workspace:mu_user</permission>
|
|
16
|
-
<permission>hudson.model.Item.Build:master_user</permission>
|
|
17
|
-
<permission>hudson.model.Item.Build:mu_user</permission>
|
|
18
|
-
<permission>hudson.model.Item.Move:master_user</permission>
|
|
19
|
-
<permission>hudson.model.Item.Move:mu_user</permission>
|
|
20
|
-
<permission>hudson.model.Item.Configure:master_user</permission>
|
|
21
|
-
<permission>hudson.model.Item.Configure:mu_user</permission>
|
|
22
|
-
<permission>hudson.model.Item.Discover:master_user</permission>
|
|
23
|
-
<permission>hudson.model.Item.Discover:mu_user</permission>
|
|
24
|
-
</hudson.security.AuthorizationMatrixProperty>
|
|
25
|
-
</properties>
|
|
26
|
-
<scm class="hudson.scm.NullSCM"/>
|
|
27
|
-
<canRoam>true</canRoam>
|
|
28
|
-
<disabled>false</disabled>
|
|
29
|
-
<blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
|
|
30
|
-
<blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
|
|
31
|
-
<triggers/>
|
|
32
|
-
<concurrentBuild>false</concurrentBuild>
|
|
33
|
-
<builders>
|
|
34
|
-
<hudson.tasks.Shell>
|
|
35
|
-
<command>/opt/mu/bin/mu-deploy /opt/mu/lib/demo/simple-server.yaml</command>
|
|
36
|
-
</hudson.tasks.Shell>
|
|
37
|
-
</builders>
|
|
38
|
-
<publishers/>
|
|
39
|
-
<buildWrappers>
|
|
40
|
-
<hudson.plugins.ansicolor.AnsiColorBuildWrapper plugin="ansicolor@0.4.1">
|
|
41
|
-
<colorMapName>xterm</colorMapName>
|
|
42
|
-
</hudson.plugins.ansicolor.AnsiColorBuildWrapper>
|
|
43
|
-
</buildWrappers>
|
|
44
|
-
</project>
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
name 'mu-jenkins'
|
|
2
|
-
maintainer 'eGlobalTech, Inc'
|
|
3
|
-
maintainer_email 'mu-developers@googlegroups.com'
|
|
4
|
-
license 'BSD-3-Clause'
|
|
5
|
-
description 'Installs/Configures mu-jenkins'
|
|
6
|
-
long_description IO.read(File.join(File.dirname(__FILE__), 'README.md'))
|
|
7
|
-
source_url 'https://github.com/cloudamatic/mu'
|
|
8
|
-
issues_url 'https://github.com/cloudamatic/mu/issues'
|
|
9
|
-
chef_version '>= 12.1' if respond_to?(:chef_version)
|
|
10
|
-
version '0.6.0'
|
|
11
|
-
|
|
12
|
-
%w( amazon centos redhat windows ).each do |os|
|
|
13
|
-
supports os
|
|
14
|
-
end
|
|
15
|
-
|
|
16
|
-
depends 'java', '~> 2.2.0'
|
|
17
|
-
depends 'jenkins', '~> 6.2.0'
|
|
18
|
-
depends 'chef-vault', '~> 3.1.1'
|
|
19
|
-
depends 'mu-master'
|
|
20
|
-
depends 'mu-utility'
|
|
21
|
-
depends 'mu-tools'
|
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
# Cookbook Name:: mu-jenkins
|
|
2
|
-
# Recipe:: default
|
|
3
|
-
#
|
|
4
|
-
# Copyright 2015, eGlobalTech, Inc
|
|
5
|
-
#
|
|
6
|
-
# All rights reserved - Do Not Redistribute
|
|
7
|
-
#
|
|
8
|
-
|
|
9
|
-
include_recipe 'mu-tools::disable-requiretty'
|
|
10
|
-
include_recipe 'chef-vault'
|
|
11
|
-
|
|
12
|
-
directory "/opt/java_jce" do
|
|
13
|
-
mode 0755
|
|
14
|
-
end
|
|
15
|
-
|
|
16
|
-
admin_vault = chef_vault_item(node['jenkins_admin_vault']['vault'], node['jenkins_admin_vault']['item'])
|
|
17
|
-
|
|
18
|
-
directory "Mu Jenkins home #{node['jenkins']['master']['home']}" do
|
|
19
|
-
path node['jenkins']['master']['home']
|
|
20
|
-
owner "jenkins"
|
|
21
|
-
recursive true
|
|
22
|
-
notifies :restart, 'service[jenkins]', :immediately
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
package %w{git bzip2}
|
|
26
|
-
|
|
27
|
-
#remote_file "#{node['jenkins']['master']['home']}/plugins/mailer.jpi" do
|
|
28
|
-
# source "http://updates.jenkins-ci.org/latest/mailer.hpi"
|
|
29
|
-
# owner "jenkins"
|
|
30
|
-
#end
|
|
31
|
-
|
|
32
|
-
ruby_block 'wait for jenkins' do
|
|
33
|
-
block do
|
|
34
|
-
sleep 30
|
|
35
|
-
end
|
|
36
|
-
action :nothing
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
# If security was enabled in a previous chef run then set the private key in the run_state
|
|
41
|
-
# now as required by the Jenkins cookbook
|
|
42
|
-
if node['application_attributes']['jenkins_auth_set']
|
|
43
|
-
ruby_block 'set jenkins private key' do
|
|
44
|
-
block do
|
|
45
|
-
Chef::Log.info("Setting the previously enabled jenkins private key")
|
|
46
|
-
node.run_state[:jenkins_private_key] = admin_vault['private_key'].strip
|
|
47
|
-
end
|
|
48
|
-
end
|
|
49
|
-
end
|
|
50
|
-
|
|
51
|
-
restart_jenkins = false
|
|
52
|
-
|
|
53
|
-
directory "mu-jenkins fix #{Chef::Config[:file_cache_path]} perms" do
|
|
54
|
-
path Chef::Config[:file_cache_path]
|
|
55
|
-
mode 0755
|
|
56
|
-
end
|
|
57
|
-
cacheparent = File.expand_path("..", Chef::Config[:file_cache_path])
|
|
58
|
-
directory "mu-jenkins fix #{cacheparent} perms" do
|
|
59
|
-
path cacheparent
|
|
60
|
-
mode 0755
|
|
61
|
-
end
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
# Download ALPN Jar file and fix to JENKINS_JAVA_OPTIONS
|
|
65
|
-
# open_jdk_version = `java -version 2>&1`
|
|
66
|
-
open_jdk_version = shell_out('java -version 2>&1').stdout.str
|
|
67
|
-
if open_jdk_version.include?("openjdk version \"1.8") and node['platform_family'] == 'rhel'
|
|
68
|
-
|
|
69
|
-
remote_file 'download_anlp_jar' do
|
|
70
|
-
source node['jenkins']['alpn']['download_link']
|
|
71
|
-
path "/home/jenkins/alpn-boot-#{node['jenkins']['alpn']['version']}.jar"
|
|
72
|
-
owner "jenkins"
|
|
73
|
-
notifies :restart, "service[jenkins]",:delayed
|
|
74
|
-
end
|
|
75
|
-
|
|
76
|
-
service "jenkins" do
|
|
77
|
-
action :nothing
|
|
78
|
-
end
|
|
79
|
-
|
|
80
|
-
end
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
node['jenkins_plugins'].each { |plugin|
|
|
86
|
-
# if !::File.exist?("#{node['jenkins']['master']['home']}/plugins/#{plugin}.jpi")
|
|
87
|
-
# restart_jenkins = true
|
|
88
|
-
# end
|
|
89
|
-
# XXX this runs as the 'jenkins' user, yet download the files as 0600/root
|
|
90
|
-
jenkins_plugin plugin
|
|
91
|
-
# do
|
|
92
|
-
# notifies :restart, 'service[jenkins]', :delayed
|
|
93
|
-
#not_if { ::File.exist?("#{node['jenkins']['master']['home']}/plugins/#{plugin}.jpi") }
|
|
94
|
-
# end
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
if !node['application_attributes']['jenkins_auth_set']
|
|
98
|
-
jenkins_command 'safe-restart'
|
|
99
|
-
jenkins_private_key_credentials admin_vault['username'] do
|
|
100
|
-
id '1671945-9fa7-4d24-ac87-51ea3b2aef4c'
|
|
101
|
-
description admin_vault['username']
|
|
102
|
-
private_key admin_vault['private_key'].strip
|
|
103
|
-
end
|
|
104
|
-
end
|
|
105
|
-
|
|
106
|
-
# The Jenkins service user that this cookbook uses MUST exist in our directory
|
|
107
|
-
mu_master_user admin_vault['username'] do
|
|
108
|
-
realname admin_vault['username']
|
|
109
|
-
# email $MU_CFG['jenkins']['admin_email'] || $MU_CFG['admin_email']
|
|
110
|
-
email "mu-developers@googlegroups.com"
|
|
111
|
-
end
|
|
112
|
-
|
|
113
|
-
# Add the admin user only if it has not been added already then notify the resource
|
|
114
|
-
# to configure the permissions for the admin user. Note that we check for existence of jenkins_auth_set,
|
|
115
|
-
# not value
|
|
116
|
-
jenkins_user admin_vault['username'] do
|
|
117
|
-
full_name admin_vault['username']
|
|
118
|
-
email "mu-developers@googlegroups.com"
|
|
119
|
-
public_keys [admin_vault['public_key'].strip]
|
|
120
|
-
#not_if { node['application_attributes'].attribute?('jenkins_auth_set') }
|
|
121
|
-
end
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
# Configure the permissions so that login is required and the admin user is an administrator
|
|
125
|
-
# after this point the private key will be required to execute jenkins scripts (including querying
|
|
126
|
-
# if users exist) so we notify the `set the security_enabled flag` resource to set this up.
|
|
127
|
-
# Also note that since Jenkins 1.556 the private key cannot be used until after the admin user
|
|
128
|
-
# has been added to the security realm
|
|
129
|
-
uidsearch = "uid={0}"
|
|
130
|
-
uidsearch = "sAMAccountName={0}" if $MU_CFG['ldap']['type'] == "Active Directory"
|
|
131
|
-
membersearch = "(| (member={0}) (uniqueMember={0}) (memberUid={1}))"
|
|
132
|
-
membersearch = "memberUid={0}" if $MU_CFG['ldap']['type'] == "389 Directory Services"
|
|
133
|
-
bind_creds = chef_vault_item($MU_CFG['ldap']['bind_creds']['vault'], $MU_CFG['ldap']['bind_creds']['item'])
|
|
134
|
-
jenkins_admins = ::MU::Master.listUsers.delete_if { |_u, data| !data['admin'] }.keys
|
|
135
|
-
#jenkins_regular = ::MU::Master.listUsers.delete_if { |u, data| data['admin'] or u == "jenkins" }.keys
|
|
136
|
-
regular_user_perms = ["Item.BUILD", "Item.CREATE", "Item.DISCOVER", "Item.READ"]
|
|
137
|
-
jenkins_script 'configure_jenkins_auth' do
|
|
138
|
-
command <<-EOH.gsub(/^ {4}/, '')
|
|
139
|
-
import jenkins.model.*
|
|
140
|
-
import hudson.security.*
|
|
141
|
-
import org.jenkinsci.plugins.*
|
|
142
|
-
def instance = Jenkins.getInstance()
|
|
143
|
-
def hudsonRealm = new HudsonPrivateSecurityRealm(false)
|
|
144
|
-
String groupSearchFilter = 'memberUid={0}'
|
|
145
|
-
SecurityRealm ldapRealm = new LDAPSecurityRealm(server='ldap://#{$MU_CFG['ldap']['dcs'].first}', rootDN = '#{$MU_CFG['ldap']['base_dn']}', userSearchBase='#{$MU_CFG['ldap']['user_ou'].sub(/,.*/, "")}', userSearch="#{uidsearch}", groupSearchBase='#{$MU_CFG['ldap']['group_ou'].sub(/,.*/, "")}', groupSearchFilter="", groupMembershipFilter = '#{membersearch}', managerDN = '#{bind_creds[$MU_CFG['ldap']['bind_creds']['username_field']]}', managerPasswordSecret = '#{bind_creds[$MU_CFG['ldap']['bind_creds']['password_field']]}', inhibitInferRootDN = false, disableMailAddressResolver = false, cache = null)
|
|
146
|
-
instance.setSecurityRealm(ldapRealm)
|
|
147
|
-
def strategy = new ProjectMatrixAuthorizationStrategy()
|
|
148
|
-
strategy.add(Jenkins.ADMINISTER, "#{$MU_CFG['ldap']['admin_group_name']}")
|
|
149
|
-
strategy.add(Jenkins.ADMINISTER, "#{admin_vault['username']}")
|
|
150
|
-
#{jenkins_admins.map { |u| "strategy.add(Jenkins.ADMINISTER, \"#{u}\")" }.join("\n")}
|
|
151
|
-
strategy.add(Jenkins.READ, "authenticated")
|
|
152
|
-
#{regular_user_perms.map { |p| "strategy.add(hudson.model.#{p}, \"authenticated\")" }.join("\n")}
|
|
153
|
-
instance.setAuthorizationStrategy(strategy)
|
|
154
|
-
instance.save()
|
|
155
|
-
EOH
|
|
156
|
-
# not_if "grep managerDN #{node['jenkins']['master']['home']}/config.xml | grep #{bind_creds[$MU_CFG['ldap']['bind_creds']['username_field']]}"
|
|
157
|
-
notifies :run, 'ruby_block[configure_jenkins_auth_set]', :immediately
|
|
158
|
-
action :nothing unless !::File.size?("#{node['jenkins']['master']['home']}/config.xml") or !::File.read("#{node['jenkins']['master']['home']}/config.xml").match(bind_creds[$MU_CFG['ldap']['bind_creds']['username_field']])
|
|
159
|
-
end
|
|
160
|
-
|
|
161
|
-
file "#{node['jenkins']['master']['home']}/user-list-chef-guard" do
|
|
162
|
-
content "
|
|
163
|
-
#{jenkins_admins.map { |u| "strategy.add(Jenkins.ADMINISTER, \"#{u}\")" }.join("\n")}
|
|
164
|
-
#{regular_user_perms.map { |p| "strategy.add(Jenkins.#{p}, \"authenticated\")" }.join("\n")}
|
|
165
|
-
#{bind_creds[$MU_CFG['ldap']['bind_creds']['username_field']]}
|
|
166
|
-
"
|
|
167
|
-
notifies :execute, "jenkins_script[configure_jenkins_auth]", :immediately
|
|
168
|
-
end
|
|
169
|
-
|
|
170
|
-
# Set the security enabled flag and set the run_state to use the configured private key
|
|
171
|
-
ruby_block 'configure_jenkins_auth_set' do
|
|
172
|
-
block do
|
|
173
|
-
node.run_state[:jenkins_private_key] = admin_vault['private_key'].strip
|
|
174
|
-
node.normal['application_attributes']['jenkins_auth_set'] = true
|
|
175
|
-
node.save
|
|
176
|
-
end
|
|
177
|
-
action :nothing
|
|
178
|
-
end
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
# Configure users from the vault
|
|
183
|
-
#node['jenkins_users'].each { |user|
|
|
184
|
-
# user_vault = chef_vault_item(user[:vault], user[:vault_item])
|
|
185
|
-
#
|
|
186
|
-
# # XXX This is dangerous. What if we stupidly step on the account of a
|
|
187
|
-
# # "real" user?
|
|
188
|
-
# ::MU::Master::LDAP.manageUser(user[:user_name], name: user[:fullname], password: user_vault[user[:user_name]+"_password"], admin: false, email: user[:email])
|
|
189
|
-
# jenkins_user user[:user_name] do
|
|
190
|
-
# full_name user[:fullname]
|
|
191
|
-
# email user[:email]
|
|
192
|
-
# password user_vault["#{user[:user_name]}_password"]
|
|
193
|
-
# sensitive true
|
|
194
|
-
# end
|
|
195
|
-
#}
|