cloud-mu 1.9.0.pre.beta

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.
Files changed (618) hide show
  1. checksums.yaml +7 -0
  2. data/Berksfile +56 -0
  3. data/Berksfile.lock +250 -0
  4. data/Jenkinsfile +184 -0
  5. data/LICENSE.md +37 -0
  6. data/README.md +26 -0
  7. data/bin/mu-aws-setup +376 -0
  8. data/bin/mu-cleanup +68 -0
  9. data/bin/mu-configure +1133 -0
  10. data/bin/mu-deploy +166 -0
  11. data/bin/mu-firewall-allow-clients +30 -0
  12. data/bin/mu-gcp-setup +200 -0
  13. data/bin/mu-gen-docs +34 -0
  14. data/bin/mu-gen-env +42 -0
  15. data/bin/mu-load-config.rb +158 -0
  16. data/bin/mu-node-manage +683 -0
  17. data/bin/mu-self-update +228 -0
  18. data/bin/mu-ssh +23 -0
  19. data/bin/mu-tunnel-nagios +144 -0
  20. data/bin/mu-upload-chef-artifacts +757 -0
  21. data/bin/mu-user-manage +275 -0
  22. data/cookbooks/awscli/LICENSE +37 -0
  23. data/cookbooks/awscli/README.md +58 -0
  24. data/cookbooks/awscli/attributes/default.rb +1 -0
  25. data/cookbooks/awscli/libraries/instance_metadata.rb +21 -0
  26. data/cookbooks/awscli/metadata.rb +20 -0
  27. data/cookbooks/awscli/recipes/default.rb +56 -0
  28. data/cookbooks/awscli/templates/default/config.erb +18 -0
  29. data/cookbooks/mu-activedirectory/CHANGELOG.md +13 -0
  30. data/cookbooks/mu-activedirectory/LICENSE +37 -0
  31. data/cookbooks/mu-activedirectory/README.md +6 -0
  32. data/cookbooks/mu-activedirectory/attributes/default.rb +98 -0
  33. data/cookbooks/mu-activedirectory/files/default/password-auth +32 -0
  34. data/cookbooks/mu-activedirectory/files/default/sshd_pol.pp +0 -0
  35. data/cookbooks/mu-activedirectory/files/default/sshd_pol.te +32 -0
  36. data/cookbooks/mu-activedirectory/files/default/syslogd_oddjobd.pp +0 -0
  37. data/cookbooks/mu-activedirectory/files/default/syslogd_oddjobd.te +10 -0
  38. data/cookbooks/mu-activedirectory/files/default/system-auth +34 -0
  39. data/cookbooks/mu-activedirectory/files/default/winbindpol.pp +0 -0
  40. data/cookbooks/mu-activedirectory/files/default/winbindpol.te +37 -0
  41. data/cookbooks/mu-activedirectory/libraries/config.rb +106 -0
  42. data/cookbooks/mu-activedirectory/libraries/helper.rb +86 -0
  43. data/cookbooks/mu-activedirectory/metadata.rb +17 -0
  44. data/cookbooks/mu-activedirectory/providers/domain.rb +152 -0
  45. data/cookbooks/mu-activedirectory/providers/domain_controller.rb +89 -0
  46. data/cookbooks/mu-activedirectory/providers/domain_node.rb +275 -0
  47. data/cookbooks/mu-activedirectory/recipes/default.rb +8 -0
  48. data/cookbooks/mu-activedirectory/recipes/domain-controller.rb +44 -0
  49. data/cookbooks/mu-activedirectory/recipes/domain-node.rb +50 -0
  50. data/cookbooks/mu-activedirectory/recipes/domain.rb +43 -0
  51. data/cookbooks/mu-activedirectory/recipes/sssd.rb +185 -0
  52. data/cookbooks/mu-activedirectory/resources/domain.rb +25 -0
  53. data/cookbooks/mu-activedirectory/resources/domain_controller.rb +25 -0
  54. data/cookbooks/mu-activedirectory/resources/domain_node.rb +20 -0
  55. data/cookbooks/mu-activedirectory/templates/default/dhclient-eth0.conf.erb +4 -0
  56. data/cookbooks/mu-activedirectory/templates/default/interface +0 -0
  57. data/cookbooks/mu-activedirectory/templates/default/krb5.conf.erb +23 -0
  58. data/cookbooks/mu-activedirectory/templates/default/ntp.conf.erb +56 -0
  59. data/cookbooks/mu-activedirectory/templates/default/smb.conf.erb +33 -0
  60. data/cookbooks/mu-activedirectory/templates/default/sssd.conf.erb +60 -0
  61. data/cookbooks/mu-activedirectory/templates/windows/Backup.xml.erb +20 -0
  62. data/cookbooks/mu-activedirectory/templates/windows/bkupInfo.xml.erb +1 -0
  63. data/cookbooks/mu-activedirectory/templates/windows/gpreprt.xml.erb +198 -0
  64. data/cookbooks/mu-activedirectory/templates/windows/gptmpl.inf.erb +12 -0
  65. data/cookbooks/mu-activedirectory/templates/windows/manifest.xml.erb +1 -0
  66. data/cookbooks/mu-firewall/CHANGELOG.md +11 -0
  67. data/cookbooks/mu-firewall/LICENSE +37 -0
  68. data/cookbooks/mu-firewall/README.md +5 -0
  69. data/cookbooks/mu-firewall/attributes/default.rb +3 -0
  70. data/cookbooks/mu-firewall/metadata.rb +16 -0
  71. data/cookbooks/mu-firewall/recipes/default.rb +10 -0
  72. data/cookbooks/mu-glusterfs/CHANGELOG.md +13 -0
  73. data/cookbooks/mu-glusterfs/LICENSE +37 -0
  74. data/cookbooks/mu-glusterfs/README.md +5 -0
  75. data/cookbooks/mu-glusterfs/attributes/default.rb +34 -0
  76. data/cookbooks/mu-glusterfs/metadata.rb +17 -0
  77. data/cookbooks/mu-glusterfs/recipes/client.rb +62 -0
  78. data/cookbooks/mu-glusterfs/recipes/default.rb +16 -0
  79. data/cookbooks/mu-glusterfs/recipes/samba.rb +57 -0
  80. data/cookbooks/mu-glusterfs/recipes/server.rb +200 -0
  81. data/cookbooks/mu-glusterfs/templates/default/mu-gluster-client.erb +71 -0
  82. data/cookbooks/mu-glusterfs/templates/default/smb.conf.erb +14 -0
  83. data/cookbooks/mu-jenkins/CHANGELOG.md +13 -0
  84. data/cookbooks/mu-jenkins/LICENSE +37 -0
  85. data/cookbooks/mu-jenkins/README.md +105 -0
  86. data/cookbooks/mu-jenkins/attributes/default.rb +42 -0
  87. data/cookbooks/mu-jenkins/files/default/cleanup_deploy_config.xml +73 -0
  88. data/cookbooks/mu-jenkins/files/default/deploy_config.xml +44 -0
  89. data/cookbooks/mu-jenkins/metadata.rb +21 -0
  90. data/cookbooks/mu-jenkins/recipes/default.rb +195 -0
  91. data/cookbooks/mu-jenkins/recipes/node-ssh-config.rb +54 -0
  92. data/cookbooks/mu-jenkins/recipes/public_key.rb +24 -0
  93. data/cookbooks/mu-jenkins/templates/default/example_job.config.xml.erb +24 -0
  94. data/cookbooks/mu-jenkins/templates/default/org.jvnet.hudson.plugins.SSHBuildWrapper.xml.erb +14 -0
  95. data/cookbooks/mu-jenkins/templates/default/ssh_config.erb +6 -0
  96. data/cookbooks/mu-master/CHANGELOG.md +13 -0
  97. data/cookbooks/mu-master/LICENSE +37 -0
  98. data/cookbooks/mu-master/README.md +6 -0
  99. data/cookbooks/mu-master/attributes/default.rb +95 -0
  100. data/cookbooks/mu-master/files/default/0-mu-log-server.conf +19 -0
  101. data/cookbooks/mu-master/files/default/addRSA.ldif +8 -0
  102. data/cookbooks/mu-master/files/default/check_mem.pl +197 -0
  103. data/cookbooks/mu-master/files/default/cloudamatic.png +0 -0
  104. data/cookbooks/mu-master/files/default/dirsrv_admin.pp +0 -0
  105. data/cookbooks/mu-master/files/default/dirsrv_admin.te +13 -0
  106. data/cookbooks/mu-master/files/default/nagios_selinux.pp +0 -0
  107. data/cookbooks/mu-master/files/default/nagios_selinux.te +51 -0
  108. data/cookbooks/mu-master/files/default/nagios_selinux_7.pp +0 -0
  109. data/cookbooks/mu-master/files/default/nagios_selinux_7.te +17 -0
  110. data/cookbooks/mu-master/files/default/pam_sshd +18 -0
  111. data/cookbooks/mu-master/files/default/ssl_enable.ldif +18 -0
  112. data/cookbooks/mu-master/files/default/syslogd_oddjobd.pp +0 -0
  113. data/cookbooks/mu-master/files/default/syslogd_oddjobd.te +10 -0
  114. data/cookbooks/mu-master/files/default/vimrc +19 -0
  115. data/cookbooks/mu-master/libraries/mu.rb +29 -0
  116. data/cookbooks/mu-master/metadata.rb +30 -0
  117. data/cookbooks/mu-master/providers/user.rb +41 -0
  118. data/cookbooks/mu-master/recipes/389ds.rb +164 -0
  119. data/cookbooks/mu-master/recipes/basepackages.rb +58 -0
  120. data/cookbooks/mu-master/recipes/caching_nameserver.rb +37 -0
  121. data/cookbooks/mu-master/recipes/default.rb +451 -0
  122. data/cookbooks/mu-master/recipes/eks-kubectl.rb +41 -0
  123. data/cookbooks/mu-master/recipes/firewall-holes.rb +70 -0
  124. data/cookbooks/mu-master/recipes/init.rb +542 -0
  125. data/cookbooks/mu-master/recipes/ssl-certs.rb +109 -0
  126. data/cookbooks/mu-master/recipes/sssd.rb +89 -0
  127. data/cookbooks/mu-master/recipes/update_nagios_only.rb +242 -0
  128. data/cookbooks/mu-master/recipes/vault.rb +111 -0
  129. data/cookbooks/mu-master/resources/user.rb +19 -0
  130. data/cookbooks/mu-master/templates/default/389-directory-setup.inf.erb +28 -0
  131. data/cookbooks/mu-master/templates/default/chef-server.rb.erb +18 -0
  132. data/cookbooks/mu-master/templates/default/dhclient-eth0.conf.erb +9 -0
  133. data/cookbooks/mu-master/templates/default/mu-momma-cat.erb +149 -0
  134. data/cookbooks/mu-master/templates/default/mu.rc.erb +9 -0
  135. data/cookbooks/mu-master/templates/default/openssl.cnf.erb +354 -0
  136. data/cookbooks/mu-master/templates/default/sssd.conf.erb +44 -0
  137. data/cookbooks/mu-master/templates/default/web_app.conf.erb +90 -0
  138. data/cookbooks/mu-mongo/CHANGELOG.md +13 -0
  139. data/cookbooks/mu-mongo/LICENSE +37 -0
  140. data/cookbooks/mu-mongo/README.md +5 -0
  141. data/cookbooks/mu-mongo/attributes/default.rb +22 -0
  142. data/cookbooks/mu-mongo/files/default/keyfile +16 -0
  143. data/cookbooks/mu-mongo/files/default/remove_nodes.js +5 -0
  144. data/cookbooks/mu-mongo/metadata.rb +17 -0
  145. data/cookbooks/mu-mongo/recipes/default.rb +149 -0
  146. data/cookbooks/mu-mongo/recipes/yum-update-rule.rb +18 -0
  147. data/cookbooks/mu-mongo/templates/default/mongo_create_openfema_db.js.erb +2 -0
  148. data/cookbooks/mu-mongo/templates/default/mongo_init.js.erb +1 -0
  149. data/cookbooks/mu-mongo/templates/default/mongo_logrotate.erb +14 -0
  150. data/cookbooks/mu-mongo/templates/default/mongo_replset_addnodes.js.erb +6 -0
  151. data/cookbooks/mu-mongo/templates/default/replset_init.js.erb +2 -0
  152. data/cookbooks/mu-openvpn/CHANGELOG.md +13 -0
  153. data/cookbooks/mu-openvpn/LICENSE +37 -0
  154. data/cookbooks/mu-openvpn/README.md +6 -0
  155. data/cookbooks/mu-openvpn/attributes/default.rb +119 -0
  156. data/cookbooks/mu-openvpn/metadata.rb +18 -0
  157. data/cookbooks/mu-openvpn/recipes/default.rb +108 -0
  158. data/cookbooks/mu-openvpn/templates/default/users.json.erb +42 -0
  159. data/cookbooks/mu-php54/CHANGELOG.md +12 -0
  160. data/cookbooks/mu-php54/LICENSE +37 -0
  161. data/cookbooks/mu-php54/README.md +0 -0
  162. data/cookbooks/mu-php54/files/centos/php.ini +1802 -0
  163. data/cookbooks/mu-php54/files/ubuntu/php.ini +1870 -0
  164. data/cookbooks/mu-php54/metadata.rb +21 -0
  165. data/cookbooks/mu-php54/recipes/default.rb +97 -0
  166. data/cookbooks/mu-splunk/CHANGELOG.md +37 -0
  167. data/cookbooks/mu-splunk/LICENSE +37 -0
  168. data/cookbooks/mu-splunk/README.md +451 -0
  169. data/cookbooks/mu-splunk/attributes/default.rb +95 -0
  170. data/cookbooks/mu-splunk/attributes/upgrade.rb +49 -0
  171. data/cookbooks/mu-splunk/definitions/splunk_installer.rb +103 -0
  172. data/cookbooks/mu-splunk/files/default/splunk-nocheck +10 -0
  173. data/cookbooks/mu-splunk/libraries/helpers.rb +72 -0
  174. data/cookbooks/mu-splunk/libraries/splunk_app_provider.rb +156 -0
  175. data/cookbooks/mu-splunk/libraries/splunk_app_resource.rb +43 -0
  176. data/cookbooks/mu-splunk/metadata.json +30 -0
  177. data/cookbooks/mu-splunk/metadata.rb +17 -0
  178. data/cookbooks/mu-splunk/recipes/client.rb +143 -0
  179. data/cookbooks/mu-splunk/recipes/default.rb +31 -0
  180. data/cookbooks/mu-splunk/recipes/disabled.rb +41 -0
  181. data/cookbooks/mu-splunk/recipes/install_forwarder.rb +23 -0
  182. data/cookbooks/mu-splunk/recipes/install_server.rb +23 -0
  183. data/cookbooks/mu-splunk/recipes/server.rb +53 -0
  184. data/cookbooks/mu-splunk/recipes/service.rb +95 -0
  185. data/cookbooks/mu-splunk/recipes/setup_auth.rb +49 -0
  186. data/cookbooks/mu-splunk/recipes/setup_ssl.rb +63 -0
  187. data/cookbooks/mu-splunk/recipes/upgrade.rb +94 -0
  188. data/cookbooks/mu-splunk/recipes/user.rb +34 -0
  189. data/cookbooks/mu-splunk/templates/default/base_logs_unix_inputs.conf.erb +26 -0
  190. data/cookbooks/mu-splunk/templates/default/inputs.conf.erb +13 -0
  191. data/cookbooks/mu-splunk/templates/default/outputs.conf.erb +9 -0
  192. data/cookbooks/mu-splunk/templates/default/splunk-init.erb +74 -0
  193. data/cookbooks/mu-splunk/templates/default/system-web.conf.erb +7 -0
  194. data/cookbooks/mu-tools/CHANGELOG.md +12 -0
  195. data/cookbooks/mu-tools/LICENSE +37 -0
  196. data/cookbooks/mu-tools/README.md +188 -0
  197. data/cookbooks/mu-tools/attributes/default.rb +142 -0
  198. data/cookbooks/mu-tools/attributes/ebs_rolling_snapshots.rb +3 -0
  199. data/cookbooks/mu-tools/files/amazon/etc/freshclam.conf +235 -0
  200. data/cookbooks/mu-tools/files/centos/CentOS-Base.repo +52 -0
  201. data/cookbooks/mu-tools/files/centos/etc/bashrc +93 -0
  202. data/cookbooks/mu-tools/files/centos/etc/freshclam.conf +235 -0
  203. data/cookbooks/mu-tools/files/centos/etc/login.defs +72 -0
  204. data/cookbooks/mu-tools/files/centos/etc/profile +77 -0
  205. data/cookbooks/mu-tools/files/centos/etc/security/limits.conf +57 -0
  206. data/cookbooks/mu-tools/files/centos/etc/sysconfig/init +19 -0
  207. data/cookbooks/mu-tools/files/centos/etc/sysctl.conf +82 -0
  208. data/cookbooks/mu-tools/files/centos-6/README_MU +0 -0
  209. data/cookbooks/mu-tools/files/centos-6/etc/audit/stig.rules +173 -0
  210. data/cookbooks/mu-tools/files/centos-6/etc/bashrc +90 -0
  211. data/cookbooks/mu-tools/files/centos-6/etc/login.defs +70 -0
  212. data/cookbooks/mu-tools/files/centos-6/etc/pam.d/su +12 -0
  213. data/cookbooks/mu-tools/files/centos-6/etc/profile +83 -0
  214. data/cookbooks/mu-tools/files/centos-6/etc/securetty +12 -0
  215. data/cookbooks/mu-tools/files/centos-6/etc/sysconfig/init +30 -0
  216. data/cookbooks/mu-tools/files/centos-6/etc/sysctl.conf +40 -0
  217. data/cookbooks/mu-tools/files/default/Mu_CA.pem +34 -0
  218. data/cookbooks/mu-tools/files/default/PSWindowsUpdate.zip +0 -0
  219. data/cookbooks/mu-tools/files/default/ebs_snapshots.py +123 -0
  220. data/cookbooks/mu-tools/files/default/etc/BANNER +0 -0
  221. data/cookbooks/mu-tools/files/default/etc/BANNER-FEDERAL +19 -0
  222. data/cookbooks/mu-tools/files/default/gpo_no_uac.zip +0 -0
  223. data/cookbooks/mu-tools/files/default/mypol.pp +0 -0
  224. data/cookbooks/mu-tools/files/default/mypol.te +37 -0
  225. data/cookbooks/mu-tools/files/default/nrpe_c7.pp +0 -0
  226. data/cookbooks/mu-tools/files/default/nrpe_c7.te +31 -0
  227. data/cookbooks/mu-tools/files/default/nrpe_check_disk.pp +0 -0
  228. data/cookbooks/mu-tools/files/default/nrpe_check_disk.te +11 -0
  229. data/cookbooks/mu-tools/files/default/nrpe_disk.pp +0 -0
  230. data/cookbooks/mu-tools/files/default/nrpe_disk.te +10 -0
  231. data/cookbooks/mu-tools/files/default/nrpe_file.pp +0 -0
  232. data/cookbooks/mu-tools/files/default/nrpe_file.te +31 -0
  233. data/cookbooks/mu-tools/files/default/ntrights +0 -0
  234. data/cookbooks/mu-tools/files/default/serverclass.conf +18 -0
  235. data/cookbooks/mu-tools/files/default/splunk-apps/base_logs_unix/local/app.conf +1 -0
  236. data/cookbooks/mu-tools/files/default/splunk-apps/base_logs_unix/local/inputs.conf +13 -0
  237. data/cookbooks/mu-tools/files/default/splunk-apps/base_logs_windows/local/app.conf +1 -0
  238. data/cookbooks/mu-tools/files/default/splunk-apps/base_logs_windows/local/inputs.conf +8 -0
  239. data/cookbooks/mu-tools/files/default/sshd_pol.pp +0 -0
  240. data/cookbooks/mu-tools/files/default/sshd_pol.te +32 -0
  241. data/cookbooks/mu-tools/files/redhat/etc/bashrc +93 -0
  242. data/cookbooks/mu-tools/files/redhat/etc/freshclam.conf +235 -0
  243. data/cookbooks/mu-tools/files/redhat/etc/login.defs +72 -0
  244. data/cookbooks/mu-tools/files/redhat/etc/profile +77 -0
  245. data/cookbooks/mu-tools/files/redhat/etc/security/limits.conf +57 -0
  246. data/cookbooks/mu-tools/files/redhat/etc/sysconfig/init +19 -0
  247. data/cookbooks/mu-tools/files/redhat/etc/sysctl.conf +82 -0
  248. data/cookbooks/mu-tools/files/redhat-6/README_MU +0 -0
  249. data/cookbooks/mu-tools/files/redhat-6/etc/audit/stig.rules +173 -0
  250. data/cookbooks/mu-tools/files/redhat-6/etc/bashrc +90 -0
  251. data/cookbooks/mu-tools/files/redhat-6/etc/login.defs +70 -0
  252. data/cookbooks/mu-tools/files/redhat-6/etc/pam.d/su +12 -0
  253. data/cookbooks/mu-tools/files/redhat-6/etc/profile +83 -0
  254. data/cookbooks/mu-tools/files/redhat-6/etc/securetty +12 -0
  255. data/cookbooks/mu-tools/files/redhat-6/etc/sysconfig/init +30 -0
  256. data/cookbooks/mu-tools/files/redhat-6/etc/sysctl.conf +40 -0
  257. data/cookbooks/mu-tools/files/redhat-7.1/etc/freshclam.conf +235 -0
  258. data/cookbooks/mu-tools/files/ubuntu-12.04/etc/bash.bashrc +64 -0
  259. data/cookbooks/mu-tools/files/ubuntu-12.04/etc/common-session +30 -0
  260. data/cookbooks/mu-tools/files/ubuntu-12.04/etc/login.defs +338 -0
  261. data/cookbooks/mu-tools/files/ubuntu-12.04/etc/profile +30 -0
  262. data/cookbooks/mu-tools/files/ubuntu-12.04/etc/security/limits.conf +56 -0
  263. data/cookbooks/mu-tools/files/ubuntu-12.04/etc/sysctl.conf +60 -0
  264. data/cookbooks/mu-tools/libraries/helper.rb +292 -0
  265. data/cookbooks/mu-tools/metadata.rb +28 -0
  266. data/cookbooks/mu-tools/recipes/add_admin_ssh_keys.rb +35 -0
  267. data/cookbooks/mu-tools/recipes/apply_security.rb +440 -0
  268. data/cookbooks/mu-tools/recipes/aws_api.rb +23 -0
  269. data/cookbooks/mu-tools/recipes/base_repositories.rb +31 -0
  270. data/cookbooks/mu-tools/recipes/cisbenchmark.rb +59 -0
  271. data/cookbooks/mu-tools/recipes/clamav.rb +53 -0
  272. data/cookbooks/mu-tools/recipes/cloudinit.rb +58 -0
  273. data/cookbooks/mu-tools/recipes/configure_oracle_tools.rb +81 -0
  274. data/cookbooks/mu-tools/recipes/disable-requiretty.rb +22 -0
  275. data/cookbooks/mu-tools/recipes/ebs_rolling_snapshots.rb +75 -0
  276. data/cookbooks/mu-tools/recipes/efs.rb +70 -0
  277. data/cookbooks/mu-tools/recipes/eks.rb +160 -0
  278. data/cookbooks/mu-tools/recipes/gcloud.rb +98 -0
  279. data/cookbooks/mu-tools/recipes/google_api.rb +25 -0
  280. data/cookbooks/mu-tools/recipes/maldet.rb +67 -0
  281. data/cookbooks/mu-tools/recipes/nagios.rb +19 -0
  282. data/cookbooks/mu-tools/recipes/newclient.rb +23 -0
  283. data/cookbooks/mu-tools/recipes/nrpe.rb +115 -0
  284. data/cookbooks/mu-tools/recipes/python_pip.rb +35 -0
  285. data/cookbooks/mu-tools/recipes/retrieve_application.rb +51 -0
  286. data/cookbooks/mu-tools/recipes/rsyslog.rb +65 -0
  287. data/cookbooks/mu-tools/recipes/set_local_fw.rb +57 -0
  288. data/cookbooks/mu-tools/recipes/set_mu_hostname.rb +81 -0
  289. data/cookbooks/mu-tools/recipes/split_var_partitions.rb +86 -0
  290. data/cookbooks/mu-tools/recipes/splunk-client.rb +69 -0
  291. data/cookbooks/mu-tools/recipes/splunk-server.rb +104 -0
  292. data/cookbooks/mu-tools/recipes/store_inspec_attr.rb +8 -0
  293. data/cookbooks/mu-tools/recipes/updates.rb +96 -0
  294. data/cookbooks/mu-tools/recipes/windows-client.rb +202 -0
  295. data/cookbooks/mu-tools/resources/aws_windows.rb +33 -0
  296. data/cookbooks/mu-tools/resources/disk.rb +88 -0
  297. data/cookbooks/mu-tools/resources/mommacat_request.rb +11 -0
  298. data/cookbooks/mu-tools/resources/scheduled_tasks.rb +29 -0
  299. data/cookbooks/mu-tools/resources/sshd_service.rb +45 -0
  300. data/cookbooks/mu-tools/resources/windows_users.rb +242 -0
  301. data/cookbooks/mu-tools/templates/amazon/sshd_config.erb +168 -0
  302. data/cookbooks/mu-tools/templates/centos-6/sshd_config.erb +212 -0
  303. data/cookbooks/mu-tools/templates/centos-7/sshd_config.erb +215 -0
  304. data/cookbooks/mu-tools/templates/default/0-mu-log-client.conf.erb +13 -0
  305. data/cookbooks/mu-tools/templates/default/conf.maldet.erb +137 -0
  306. data/cookbooks/mu-tools/templates/default/etc_hosts.erb +30 -0
  307. data/cookbooks/mu-tools/templates/default/etc_pamd_password-auth.erb +14 -0
  308. data/cookbooks/mu-tools/templates/default/etc_pamd_system-auth.erb +14 -0
  309. data/cookbooks/mu-tools/templates/default/etc_sysconfig_network.erb +12 -0
  310. data/cookbooks/mu-tools/templates/default/kubeconfig.erb +29 -0
  311. data/cookbooks/mu-tools/templates/default/kubelet.service.erb +35 -0
  312. data/cookbooks/mu-tools/templates/default/maldet_scanall.sh.erb +15 -0
  313. data/cookbooks/mu-tools/templates/default/nrpe.cfg.erb +233 -0
  314. data/cookbooks/mu-tools/templates/redhat-6/sshd_config.erb +213 -0
  315. data/cookbooks/mu-tools/templates/redhat-7/sshd_config.erb +215 -0
  316. data/cookbooks/mu-tools/templates/ubuntu-12.04/sshd_config.erb +146 -0
  317. data/cookbooks/mu-tools/templates/ubuntu-14.04/sshd_config.erb +145 -0
  318. data/cookbooks/mu-tools/templates/windows/Backup.xml.erb +20 -0
  319. data/cookbooks/mu-tools/templates/windows/bkupInfo.xml.erb +1 -0
  320. data/cookbooks/mu-tools/templates/windows/gpreprt.xml.erb +214 -0
  321. data/cookbooks/mu-tools/templates/windows/gptmpl.inf.erb +12 -0
  322. data/cookbooks/mu-tools/templates/windows/manifest.xml.erb +1 -0
  323. data/cookbooks/mu-tools/templates/windows/set_ad_dns_scheduled_task.ps1.erb +6 -0
  324. data/cookbooks/mu-tools/templates/windows/sshd_config.erb +136 -0
  325. data/cookbooks/mu-utility/CHANGELOG.md +12 -0
  326. data/cookbooks/mu-utility/LICENSE +37 -0
  327. data/cookbooks/mu-utility/README.md +6 -0
  328. data/cookbooks/mu-utility/attributes/default.rb +1 -0
  329. data/cookbooks/mu-utility/libraries/matchers.rb +21 -0
  330. data/cookbooks/mu-utility/metadata.rb +16 -0
  331. data/cookbooks/mu-utility/recipes/apt.rb +23 -0
  332. data/cookbooks/mu-utility/recipes/cleanup_image_helper.rb +118 -0
  333. data/cookbooks/mu-utility/recipes/iptables.rb +26 -0
  334. data/cookbooks/mu-utility/recipes/luks.rb +18 -0
  335. data/cookbooks/mu-utility/recipes/nat.rb +104 -0
  336. data/cookbooks/mu-utility/recipes/php.rb +33 -0
  337. data/cookbooks/mu-utility/recipes/rdp_gateway.rb +83 -0
  338. data/cookbooks/mu-utility/recipes/remi.rb +44 -0
  339. data/cookbooks/mu-utility/recipes/vim.rb +26 -0
  340. data/cookbooks/mu-utility/recipes/windows_basics.rb +37 -0
  341. data/cookbooks/mu-utility/recipes/zip.rb +26 -0
  342. data/cookbooks/mu-utility/templates/default/BundleConfig.xml.erb +34 -0
  343. data/cookbooks/mu-utility/templates/default/config.xml.erb +60 -0
  344. data/cookbooks/nagios/Berksfile +8 -0
  345. data/cookbooks/nagios/CHANGELOG.md +589 -0
  346. data/cookbooks/nagios/CONTRIBUTING.md +11 -0
  347. data/cookbooks/nagios/LICENSE +37 -0
  348. data/cookbooks/nagios/README.md +328 -0
  349. data/cookbooks/nagios/TESTING.md +2 -0
  350. data/cookbooks/nagios/attributes/config.rb +171 -0
  351. data/cookbooks/nagios/attributes/default.rb +228 -0
  352. data/cookbooks/nagios/chefignore +102 -0
  353. data/cookbooks/nagios/definitions/command.rb +33 -0
  354. data/cookbooks/nagios/definitions/contact.rb +33 -0
  355. data/cookbooks/nagios/definitions/contactgroup.rb +33 -0
  356. data/cookbooks/nagios/definitions/host.rb +33 -0
  357. data/cookbooks/nagios/definitions/hostdependency.rb +33 -0
  358. data/cookbooks/nagios/definitions/hostescalation.rb +34 -0
  359. data/cookbooks/nagios/definitions/hostgroup.rb +33 -0
  360. data/cookbooks/nagios/definitions/nagios_conf.rb +38 -0
  361. data/cookbooks/nagios/definitions/resource.rb +33 -0
  362. data/cookbooks/nagios/definitions/service.rb +33 -0
  363. data/cookbooks/nagios/definitions/servicedependency.rb +33 -0
  364. data/cookbooks/nagios/definitions/serviceescalation.rb +34 -0
  365. data/cookbooks/nagios/definitions/servicegroup.rb +33 -0
  366. data/cookbooks/nagios/definitions/timeperiod.rb +33 -0
  367. data/cookbooks/nagios/libraries/base.rb +314 -0
  368. data/cookbooks/nagios/libraries/command.rb +91 -0
  369. data/cookbooks/nagios/libraries/contact.rb +230 -0
  370. data/cookbooks/nagios/libraries/contactgroup.rb +112 -0
  371. data/cookbooks/nagios/libraries/custom_option.rb +36 -0
  372. data/cookbooks/nagios/libraries/data_bag_helper.rb +23 -0
  373. data/cookbooks/nagios/libraries/default.rb +90 -0
  374. data/cookbooks/nagios/libraries/host.rb +412 -0
  375. data/cookbooks/nagios/libraries/hostdependency.rb +181 -0
  376. data/cookbooks/nagios/libraries/hostescalation.rb +173 -0
  377. data/cookbooks/nagios/libraries/hostgroup.rb +119 -0
  378. data/cookbooks/nagios/libraries/nagios.rb +282 -0
  379. data/cookbooks/nagios/libraries/resource.rb +59 -0
  380. data/cookbooks/nagios/libraries/service.rb +455 -0
  381. data/cookbooks/nagios/libraries/servicedependency.rb +215 -0
  382. data/cookbooks/nagios/libraries/serviceescalation.rb +195 -0
  383. data/cookbooks/nagios/libraries/servicegroup.rb +144 -0
  384. data/cookbooks/nagios/libraries/timeperiod.rb +160 -0
  385. data/cookbooks/nagios/libraries/users_helper.rb +54 -0
  386. data/cookbooks/nagios/metadata.rb +25 -0
  387. data/cookbooks/nagios/recipes/_load_databag_config.rb +153 -0
  388. data/cookbooks/nagios/recipes/_load_default_config.rb +241 -0
  389. data/cookbooks/nagios/recipes/apache.rb +48 -0
  390. data/cookbooks/nagios/recipes/default.rb +204 -0
  391. data/cookbooks/nagios/recipes/nginx.rb +82 -0
  392. data/cookbooks/nagios/recipes/pagerduty.rb +143 -0
  393. data/cookbooks/nagios/recipes/server_package.rb +40 -0
  394. data/cookbooks/nagios/recipes/server_source.rb +164 -0
  395. data/cookbooks/nagios/templates/default/apache2.conf.erb +96 -0
  396. data/cookbooks/nagios/templates/default/cgi.cfg.erb +266 -0
  397. data/cookbooks/nagios/templates/default/commands.cfg.erb +13 -0
  398. data/cookbooks/nagios/templates/default/contacts.cfg.erb +37 -0
  399. data/cookbooks/nagios/templates/default/hostgroups.cfg.erb +25 -0
  400. data/cookbooks/nagios/templates/default/hosts.cfg.erb +15 -0
  401. data/cookbooks/nagios/templates/default/htpasswd.users.erb +6 -0
  402. data/cookbooks/nagios/templates/default/nagios.cfg.erb +22 -0
  403. data/cookbooks/nagios/templates/default/nginx.conf.erb +62 -0
  404. data/cookbooks/nagios/templates/default/pagerduty.cgi.erb +185 -0
  405. data/cookbooks/nagios/templates/default/resource.cfg.erb +27 -0
  406. data/cookbooks/nagios/templates/default/servicedependencies.cfg.erb +15 -0
  407. data/cookbooks/nagios/templates/default/servicegroups.cfg.erb +14 -0
  408. data/cookbooks/nagios/templates/default/services.cfg.erb +14 -0
  409. data/cookbooks/nagios/templates/default/templates.cfg.erb +31 -0
  410. data/cookbooks/nagios/templates/default/timeperiods.cfg.erb +13 -0
  411. data/cookbooks/s3fs/CHANGELOG.md +13 -0
  412. data/cookbooks/s3fs/LICENSE +37 -0
  413. data/cookbooks/s3fs/README.md +6 -0
  414. data/cookbooks/s3fs/attributes/default.rb +15 -0
  415. data/cookbooks/s3fs/files/default/fuse-2.9.3.zip +0 -0
  416. data/cookbooks/s3fs/metadata.rb +16 -0
  417. data/cookbooks/s3fs/recipes/default.rb +91 -0
  418. data/data_bags/demo/app.json +7 -0
  419. data/data_bags/nagios_services/chef.json +6 -0
  420. data/data_bags/nagios_services/linux_diskspace.json +5 -0
  421. data/data_bags/nagios_services/momma_cat.json +6 -0
  422. data/data_bags/nagios_services/mu-master-memory.json +5 -0
  423. data/data_bags/nagios_services/nagios_ui.json +6 -0
  424. data/data_bags/nagios_services/node_ssh.json +6 -0
  425. data/data_bags/nagios_services/ssh.json +6 -0
  426. data/demo/lambda_test.yaml +29 -0
  427. data/environments/DEV.json +8 -0
  428. data/environments/PROD.json +8 -0
  429. data/environments/dev.json +8 -0
  430. data/environments/development.json +8 -0
  431. data/environments/prod.json +8 -0
  432. data/extras/README.md +1 -0
  433. data/extras/admin-role-binding.yaml +16 -0
  434. data/extras/admin-user.yaml +6 -0
  435. data/extras/aws-auth-cm.yaml.erb +12 -0
  436. data/extras/clean-stock-amis +48 -0
  437. data/extras/git-fix-permissions-hook +12 -0
  438. data/extras/gitlab-eks-helper.sh.erb +20 -0
  439. data/extras/image-generators/README.md +2 -0
  440. data/extras/image-generators/aws/centos6.yaml +18 -0
  441. data/extras/image-generators/aws/centos7-govcloud.yaml +24 -0
  442. data/extras/image-generators/aws/centos7.yaml +17 -0
  443. data/extras/image-generators/aws/rhel7.yaml +17 -0
  444. data/extras/image-generators/aws/win2k12.yaml +16 -0
  445. data/extras/image-generators/aws/win2k16.yaml +16 -0
  446. data/extras/image-generators/aws/windows.yaml +18 -0
  447. data/extras/image-generators/gcp/centos6.yaml +17 -0
  448. data/extras/lambda_waf_domain_blacklist.py +103 -0
  449. data/extras/platform_berksfile_base +50 -0
  450. data/extras/ruby_rpm/build.sh +17 -0
  451. data/extras/ruby_rpm/muby.spec +44 -0
  452. data/extras/vault_tools/README.md +6 -0
  453. data/extras/vault_tools/export_vaults.sh +3 -0
  454. data/extras/vault_tools/recreate_vaults.sh +5 -0
  455. data/extras/vault_tools/test_vaults.sh +5 -0
  456. data/install/README.md +8 -0
  457. data/install/cfn_create_mu_master.json +1034 -0
  458. data/install/chef-server.rb.erb +19 -0
  459. data/install/deprecated-bash-library.sh +1891 -0
  460. data/install/images/Usage.png +0 -0
  461. data/install/installer +71 -0
  462. data/install/jenkinskeys.rb +8 -0
  463. data/install/user-dot-murc.erb +14 -0
  464. data/modules/html.erb +19 -0
  465. data/modules/mommacat.ru +426 -0
  466. data/modules/mu/cleanup.rb +339 -0
  467. data/modules/mu/cloud.rb +1446 -0
  468. data/modules/mu/clouds/README.md +201 -0
  469. data/modules/mu/clouds/aws/alarm.rb +319 -0
  470. data/modules/mu/clouds/aws/cache_cluster.rb +1010 -0
  471. data/modules/mu/clouds/aws/collection.rb +373 -0
  472. data/modules/mu/clouds/aws/container_cluster.rb +667 -0
  473. data/modules/mu/clouds/aws/database.rb +1836 -0
  474. data/modules/mu/clouds/aws/dnszone.rb +911 -0
  475. data/modules/mu/clouds/aws/firewall_rule.rb +641 -0
  476. data/modules/mu/clouds/aws/folder.rb +92 -0
  477. data/modules/mu/clouds/aws/function.rb +349 -0
  478. data/modules/mu/clouds/aws/group.rb +251 -0
  479. data/modules/mu/clouds/aws/loadbalancer.rb +888 -0
  480. data/modules/mu/clouds/aws/log.rb +363 -0
  481. data/modules/mu/clouds/aws/msg_queue.rb +480 -0
  482. data/modules/mu/clouds/aws/notification.rb +139 -0
  483. data/modules/mu/clouds/aws/role.rb +656 -0
  484. data/modules/mu/clouds/aws/search_domain.rb +646 -0
  485. data/modules/mu/clouds/aws/server.rb +2294 -0
  486. data/modules/mu/clouds/aws/server_pool.rb +1388 -0
  487. data/modules/mu/clouds/aws/storage_pool.rb +495 -0
  488. data/modules/mu/clouds/aws/user.rb +382 -0
  489. data/modules/mu/clouds/aws/userdata/README.md +4 -0
  490. data/modules/mu/clouds/aws/userdata/linux.erb +179 -0
  491. data/modules/mu/clouds/aws/userdata/windows.erb +278 -0
  492. data/modules/mu/clouds/aws/vpc.rb +1943 -0
  493. data/modules/mu/clouds/aws.rb +1009 -0
  494. data/modules/mu/clouds/cloudformation/alarm.rb +146 -0
  495. data/modules/mu/clouds/cloudformation/cache_cluster.rb +167 -0
  496. data/modules/mu/clouds/cloudformation/collection.rb +117 -0
  497. data/modules/mu/clouds/cloudformation/database.rb +278 -0
  498. data/modules/mu/clouds/cloudformation/dnszone.rb +274 -0
  499. data/modules/mu/clouds/cloudformation/firewall_rule.rb +308 -0
  500. data/modules/mu/clouds/cloudformation/loadbalancer.rb +193 -0
  501. data/modules/mu/clouds/cloudformation/log.rb +170 -0
  502. data/modules/mu/clouds/cloudformation/server.rb +370 -0
  503. data/modules/mu/clouds/cloudformation/server_pool.rb +279 -0
  504. data/modules/mu/clouds/cloudformation/vpc.rb +322 -0
  505. data/modules/mu/clouds/cloudformation.rb +733 -0
  506. data/modules/mu/clouds/docker.rb +30 -0
  507. data/modules/mu/clouds/google/container_cluster.rb +290 -0
  508. data/modules/mu/clouds/google/database.rb +152 -0
  509. data/modules/mu/clouds/google/firewall_rule.rb +267 -0
  510. data/modules/mu/clouds/google/group.rb +164 -0
  511. data/modules/mu/clouds/google/loadbalancer.rb +479 -0
  512. data/modules/mu/clouds/google/server.rb +1510 -0
  513. data/modules/mu/clouds/google/server_pool.rb +274 -0
  514. data/modules/mu/clouds/google/user.rb +266 -0
  515. data/modules/mu/clouds/google/userdata/README.md +4 -0
  516. data/modules/mu/clouds/google/userdata/linux.erb +137 -0
  517. data/modules/mu/clouds/google/userdata/windows.erb +275 -0
  518. data/modules/mu/clouds/google/vpc.rb +890 -0
  519. data/modules/mu/clouds/google.rb +811 -0
  520. data/modules/mu/config/README.md +11 -0
  521. data/modules/mu/config/alarm.rb +271 -0
  522. data/modules/mu/config/cache_cluster.rb +172 -0
  523. data/modules/mu/config/collection.rb +87 -0
  524. data/modules/mu/config/container_cluster.rb +103 -0
  525. data/modules/mu/config/container_cluster.yml +36 -0
  526. data/modules/mu/config/database.rb +458 -0
  527. data/modules/mu/config/database.yml +26 -0
  528. data/modules/mu/config/dnszone.rb +327 -0
  529. data/modules/mu/config/firewall_rule.rb +118 -0
  530. data/modules/mu/config/folder.rb +70 -0
  531. data/modules/mu/config/function.rb +140 -0
  532. data/modules/mu/config/group.rb +64 -0
  533. data/modules/mu/config/loadbalancer.rb +482 -0
  534. data/modules/mu/config/log.rb +47 -0
  535. data/modules/mu/config/log.yml +6 -0
  536. data/modules/mu/config/msg_queue.rb +47 -0
  537. data/modules/mu/config/msg_queue.yml +9 -0
  538. data/modules/mu/config/notification.rb +44 -0
  539. data/modules/mu/config/project.rb +71 -0
  540. data/modules/mu/config/role.rb +102 -0
  541. data/modules/mu/config/search_domain.rb +61 -0
  542. data/modules/mu/config/search_domain.yml +25 -0
  543. data/modules/mu/config/server.rb +587 -0
  544. data/modules/mu/config/server.yml +8 -0
  545. data/modules/mu/config/server_pool.rb +216 -0
  546. data/modules/mu/config/server_pool.yml +71 -0
  547. data/modules/mu/config/storage_pool.rb +145 -0
  548. data/modules/mu/config/user.rb +78 -0
  549. data/modules/mu/config/vpc.rb +743 -0
  550. data/modules/mu/config/vpc.yml +6 -0
  551. data/modules/mu/config.rb +2000 -0
  552. data/modules/mu/defaults/README.md +2 -0
  553. data/modules/mu/defaults/amazon_images.yaml +121 -0
  554. data/modules/mu/defaults/google_images.yaml +16 -0
  555. data/modules/mu/deploy.rb +686 -0
  556. data/modules/mu/groomer.rb +123 -0
  557. data/modules/mu/groomers/README.md +58 -0
  558. data/modules/mu/groomers/chef.rb +1024 -0
  559. data/modules/mu/kittens.rb +11319 -0
  560. data/modules/mu/logger.rb +208 -0
  561. data/modules/mu/master/README.md +27 -0
  562. data/modules/mu/master/chef.rb +471 -0
  563. data/modules/mu/master/ldap.rb +1005 -0
  564. data/modules/mu/master.rb +415 -0
  565. data/modules/mu/mommacat.rb +2703 -0
  566. data/modules/mu-load-config.rb +1 -0
  567. data/modules/mu.rb +724 -0
  568. data/modules/scratchpad.erb +1 -0
  569. data/modules/tests/super_complex_bok.yml +41 -0
  570. data/modules/tests/super_simple_bok.yml +40 -0
  571. data/mu.gemspec +62 -0
  572. data/roles/demo-dbservice-configure.json +19 -0
  573. data/roles/demo-portal-configure.json +19 -0
  574. data/roles/mu-master-jenkins.json +24 -0
  575. data/roles/mu-master-nagios-only.json +13 -0
  576. data/roles/mu-master.json +12 -0
  577. data/roles/mu-node.json +19 -0
  578. data/roles/mu-splunk-server.json +13 -0
  579. data/roles/mu-splunk.json +13 -0
  580. data/test/clean_up.py +25 -0
  581. data/test/demo-test-profile/README.md +3 -0
  582. data/test/demo-test-profile/controls/flask.rb +84 -0
  583. data/test/demo-test-profile/inspec.lock +7 -0
  584. data/test/demo-test-profile/inspec.yml +11 -0
  585. data/test/etco-test-profile/README.md +3 -0
  586. data/test/etco-test-profile/controls/all-in-one.rb +182 -0
  587. data/test/etco-test-profile/inspec.lock +7 -0
  588. data/test/etco-test-profile/inspec.yml +11 -0
  589. data/test/exec_inspec.py +246 -0
  590. data/test/exec_mu_install.py +241 -0
  591. data/test/exec_retry.py +44 -0
  592. data/test/mu-master-test/README.md +3 -0
  593. data/test/mu-master-test/controls/all_in_one.rb +557 -0
  594. data/test/mu-master-test/inspec.lock +3 -0
  595. data/test/mu-master-test/inspec.yml +11 -0
  596. data/test/mu-tools-test/README.md +3 -0
  597. data/test/mu-tools-test/controls/base.rb +265 -0
  598. data/test/mu-tools-test/inspec.lock +3 -0
  599. data/test/mu-tools-test/inspec.yml +8 -0
  600. data/test/simple-server-php-test/README.md +3 -0
  601. data/test/simple-server-php-test/controls/apachephp.rb +25 -0
  602. data/test/simple-server-php-test/controls/example.rb +19 -0
  603. data/test/simple-server-php-test/inspec.lock +7 -0
  604. data/test/simple-server-php-test/inspec.yml +12 -0
  605. data/test/simple-server-rails-test/README.md +3 -0
  606. data/test/simple-server-rails-test/controls/rails.rb +188 -0
  607. data/test/simple-server-rails-test/inspec.lock +7 -0
  608. data/test/simple-server-rails-test/inspec.yml +11 -0
  609. data/test/simple-windows-test/README.md +3 -0
  610. data/test/simple-windows-test/controls/windows.rb +20 -0
  611. data/test/simple-windows-test/inspec.lock +7 -0
  612. data/test/simple-windows-test/inspec.yml +11 -0
  613. data/test/smoke_test.rb +75 -0
  614. data/test/wordpress-test/README.md +3 -0
  615. data/test/wordpress-test/controls/wordpress.rb +97 -0
  616. data/test/wordpress-test/inspec.lock +7 -0
  617. data/test/wordpress-test/inspec.yml +11 -0
  618. metadata +979 -0
@@ -0,0 +1,73 @@
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 = &quot;ls -1a /home/jenkins/.mu/var/deployments/&quot;.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>
@@ -0,0 +1,44 @@
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>
@@ -0,0 +1,21 @@
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'
@@ -0,0 +1,195 @@
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.exists?("#{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.exists?("#{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
+ #}
@@ -0,0 +1,54 @@
1
+ #
2
+ # Cookbook Name:: mu-jenkins
3
+ # Recipe:: node-ssh-config
4
+ #
5
+ # Copyright 2015, eGlobalTech, Inc
6
+ #
7
+ # All rights reserved - Do Not Redistribute
8
+ #
9
+
10
+ include_recipe 'mu-jenkins::public_key'
11
+ include_recipe 'mu-tools::disable-requiretty'
12
+ include_recipe 'chef-vault'
13
+
14
+ ssh_vault = chef_vault_item(node['jenkins_ssh_vault']['vault'], node['jenkins_ssh_vault']['item'])
15
+
16
+ case node['platform']
17
+ when platform_family?('rhel')
18
+ if platform?("centos")
19
+ ssh_user = "root" if node['platform_version'].to_i == 6
20
+ ssh_user = "centos" if node['platform_version'].to_i == 7
21
+ else
22
+ ssh_user = "ec2-user"
23
+ end
24
+
25
+ directory "#{node['jenkins']['master']['home']}/.ssh" do
26
+ owner "jenkins"
27
+ group "jenkins"
28
+ mode 0700
29
+ end
30
+
31
+ ssh_key_path = "#{node['jenkins']['master']['home']}/.ssh/jenkins_ssh"
32
+
33
+ template "#{node['jenkins']['master']['home']}/.ssh/config" do
34
+ source "ssh_config.erb"
35
+ owner "jenkins"
36
+ group "jenkins"
37
+ mode 0600
38
+ variables(
39
+ :ssh_user => ssh_user,
40
+ :ssh_key_path => ssh_key_path,
41
+ :ssh_urls => node['jenkins_ssh_urls']
42
+ )
43
+ end
44
+
45
+ file ssh_key_path do
46
+ owner "jenkins"
47
+ group "jenkins"
48
+ mode 0400
49
+ content ssh_vault['private_key'].strip
50
+ sensitive true
51
+ end
52
+ else
53
+ Chef::Log.info("Unsupported platform #{node['platform']}")
54
+ end
@@ -0,0 +1,24 @@
1
+ #
2
+ # Cookbook Name:: mu-jenkins
3
+ # Recipe:: default
4
+ #
5
+ # Copyright 2015, eGlobalTech, Inc
6
+ #
7
+ # All rights reserved - Do Not Redistribute
8
+ #
9
+
10
+ case node['platform']
11
+ when platform_family?('rhel')
12
+ include_recipe 'chef-vault'
13
+
14
+ ssh_vault = chef_vault_item(node['jenkins_ssh_vault']['vault'], node['jenkins_ssh_vault']['item'])
15
+
16
+ ssh_authorized_keys = "/root/.ssh/authorized_keys" if node['platform_version'].to_i == 6
17
+ ssh_authorized_keys = "/home/centos/.ssh/authorized_keys" if node['platform_version'].to_i == 7
18
+
19
+ execute "echo '#{ssh_vault['public_key'].strip}' >> #{ssh_authorized_keys}" do
20
+ not_if "grep '^#{ssh_vault['public_key'].strip}$' #{ssh_authorized_keys}"
21
+ end
22
+ else
23
+ Chef::Log.info("Unsupported platform #{node['platform']}")
24
+ end
@@ -0,0 +1,24 @@
1
+ <?xml version='1.0' encoding='UTF-8'?>
2
+ <project>
3
+ <actions/>
4
+ <description></description>
5
+ <keepDependencies>false</keepDependencies>
6
+ <properties/>
7
+ <scm class="hudson.scm.NullSCM"/>
8
+ <canRoam>true</canRoam>
9
+ <disabled>false</disabled>
10
+ <blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
11
+ <blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
12
+ <triggers/>
13
+ <concurrentBuild>false</concurrentBuild>
14
+ <builders>
15
+ <org.jvnet.hudson.plugins.SSHBuilder plugin="ssh@2.4">
16
+ <siteName><%= @ssh_user %>@<%= @node_ip %>:22</siteName>
17
+ <command>sudo su - &lt;&lt; eoh
18
+ chef-client
19
+ eoh</command>
20
+ </org.jvnet.hudson.plugins.SSHBuilder>
21
+ </builders>
22
+ <publishers/>
23
+ <buildWrappers/>
24
+ </project>
@@ -0,0 +1,14 @@
1
+ <?xml version='1.0' encoding='UTF-8'?>
2
+ <org.jvnet.hudson.plugins.SSHBuildWrapper_-DescriptorImpl plugin="ssh@2.4">
3
+ <sites>
4
+ <org.jvnet.hudson.plugins.SSHSite>
5
+ <hostname><%= @node_ip %></hostname>
6
+ <port>22</port>
7
+ <username><%= @ssh_user %></username>
8
+ <password></password>
9
+ <keyfile><%= @ssh_key_path %></keyfile>
10
+ <serverAliveInterval>0</serverAliveInterval>
11
+ <pty>false</pty>
12
+ </org.jvnet.hudson.plugins.SSHSite>
13
+ </sites>
14
+ </org.jvnet.hudson.plugins.SSHBuildWrapper_-DescriptorImpl>
@@ -0,0 +1,6 @@
1
+ <% @ssh_urls.each { |url| %>
2
+ Host <%= url %>
3
+ User <%= @ssh_user %>
4
+ IdentityFile <%= @ssh_key_path %>
5
+ StrictHostKeyChecking no
6
+ <% } %>
@@ -0,0 +1,13 @@
1
+ mu-master CHANGELOG
2
+ ====================
3
+
4
+ This file is used to list changes made in each version of the mu-master cookbook.
5
+
6
+ 0.1.0
7
+ -----
8
+ - [your_name] - Initial release of mu-master
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.
@@ -0,0 +1,37 @@
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
+
@@ -0,0 +1,6 @@
1
+ mu-master Cookbook
2
+ ===================
3
+
4
+ This is the key Mu-master cookbook!
5
+
6
+ TODO: Improve Readme.md
@@ -0,0 +1,95 @@
1
+ # Copyright:: Copyright (c) 2014 eGlobalTech, Inc., all rights reserved
2
+ #
3
+ # Licensed under the BSD-3 license (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License in the root of the project or at
6
+ #
7
+ # http://egt-labs.com/mu/LICENSE.html
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ default['firewall']['redhat7_iptables'] = true
16
+ default['apache']['docroot_dir'] = "/var/www/html"
17
+ default['apache']['default_site_enabled'] = false
18
+ default['apache']['mod_ssl']['cipher_suite'] = "ALL:!3DES:!ADH:!EXPORT:!SSLv2:!RC4+RSA:+HIGH:!MEDIUM:!LOW"
19
+ default['apache']['mod_ssl']['directives']['SSLProtocol'] = "all -SSLv2 -SSLv3"
20
+
21
+ default['apache']['contact'] = $MU_CFG['mu_admin_email']
22
+ default['apache']['traceenable'] = 'Off'
23
+
24
+ default["apache"]["listen"] = ["*:80", "*:443", "*:8443"]
25
+
26
+ override["nagios"]["http_port"] = 8443
27
+ default['nagios']['enable_ssl'] = true
28
+ default['nagios']['sysadmin_email'] = $MU_CFG['mu_admin_email']
29
+ default['nagios']['ssl_cert_file'] = $MU_CFG['ssl']['cert']
30
+ default['nagios']['ssl_cert_key'] = $MU_CFG['ssl']['key']
31
+ if $MU_CFG['ssl'].has_key?("chain") and !$MU_CFG['ssl']['chain'].empty?
32
+ default['nagios']['ssl_cert_chain_file'] = $MU_CFG['ssl']['chain']
33
+ end
34
+ if !$MU_CFG['public_address'].match(/^\d+\.\d+\.\d+\.\d+$/)
35
+ default["nagios"]["server_name"] = $MU_CFG['public_address']
36
+ else
37
+ default["nagios"]["server_name"] = node['hostname']
38
+ default['nagios']['server']['server_alias'] = $MU_CFG['public_address']
39
+ end
40
+ #default['nagios']['server']['server_alias'] = node[:fqdn]+", "+node[:hostname]+", "+node['local_hostname']+", "+node['local_ipv4']+", "+node['public_hostname']+", "+node['public_ipv4']
41
+ default["nagios"]["log_dir"] = "/var/log/httpd"
42
+ default['nagios']['cgi-bin'] = "/usr/lib/cgi-bin/"
43
+ default['nagios']['cgi-path'] = "/nagios/cgi-bin/"
44
+ default['nagios']['server_role'] = "mu-master"
45
+ default['nagios']['server']['install_method'] = 'source'
46
+ default['nagios']['multi_environment_monitoring'] = true
47
+ default['nagios']['users_databag'] = "nagios_users"
48
+ default['nagios']['conf']['enable_notifications'] = 1
49
+ default['nagios']['interval_length'] = 1
50
+ default['nagios']['conf']['interval_length'] = 1
51
+ default['nagios']['default_host']['notification_interval'] = 7200
52
+ default['nagios']['default_host']['check_interval'] = 180
53
+ default['nagios']['default_host']['retry_interval'] = 60
54
+ default['nagios']['conf']['service_check_timeout'] = 10
55
+ default['nagios']['default_host']['max_check_attempts'] = 4
56
+ default['nagios']['default_host']['check_command'] = "check_node_ssh"
57
+ default['nagios']['default_service']['check_interval'] = 180
58
+ default['nagios']['default_service']['retry_interval'] = 30
59
+ default['nagios']['default_service']['notification_interval'] = 7200
60
+ default['nagios']['server']['url'] = "https://assets.nagios.com/downloads/nagioscore/releases/nagios-4.1.1.tar.gz"
61
+ default['nagios']['server']['version'] = "4.1.1"
62
+ default['nagios']['server']['src_dir'] = "nagios-4.1.1"
63
+ default['nagios']['server']['checksum'] = "986c93476b0fee2b2feb7a29ccf857cc691bed7ca4e004a5361ba11f467b0401"
64
+ # XXX dumb bug in Nagios cookbook
65
+ #default['nagios']['url'] = "https://#{$MU_CFG['public_address']}/nagios"
66
+ default['nagios']['url'] = default["nagios"]["server_name"]
67
+ nrpe_host = []
68
+ nrpe_host << MU.my_public_ip if MU.my_public_ip
69
+ nrpe_host << MU.my_private_ip if MU.my_private_ip
70
+ nrpe_host << node['ipaddress'] if nrpe_host.empty?
71
+ default['nrpe']['allowed_hosts'] = nrpe_host.uniq
72
+
73
+ # No idea why this is set wrong by default
74
+ default['chef_node_name'] = node.name
75
+ default['nagios']['host_name_attribute'] = 'chef_node_name'
76
+
77
+ default['application_attributes']['logs']['volume_size_gb'] = 50
78
+ default['application_attributes']['logs']['mount_device'] = "/dev/xvdl"
79
+ default['application_attributes']['logs']['label'] = "#{node['hostname']} /Mu_Logs"
80
+ default['application_attributes']['logs']['secure_location'] = MU.adminBucketName
81
+ default['application_attributes']['logs']['ebs_keyfile'] = "log_vol_ebs_key"
82
+ default['application_attributes']['logs']['mount_directory'] = "/Mu_Logs"
83
+
84
+ case node['platform']
85
+ when "centos"
86
+ ssh_user = "root" if node['platform_version'].to_i == 6
87
+ ssh_user = "centos" if node['platform_version'].to_i == 7
88
+ when "redhat"
89
+ ssh_user = "ec2-user"
90
+ end
91
+
92
+ default['application_attributes']['sshd_allow_groups'] = "#{ssh_user} mu-users"
93
+ default['application_attributes']['sshd_allow_password_auth'] = true
94
+ default['update_nagios_only'] = false
95
+ default['apache']['listen'] = [80, 443, 8443]
@@ -0,0 +1,19 @@
1
+ # make gtls driver the default
2
+ $DefaultNetstreamDriver gtls
3
+
4
+ # certificate files
5
+ $DefaultNetstreamDriverCAFile /etc/pki/rsyslog/Mu_CA.pem
6
+ $DefaultNetstreamDriverCertFile /etc/pki/rsyslog/rsyslog.crt
7
+ $DefaultNetstreamDriverKeyFile /etc/pki/rsyslog/rsyslog.key
8
+
9
+ $ModLoad imtcp # load TCP listener
10
+
11
+ $InputTCPServerStreamDriverMode 1 # run driver in TLS-only mode
12
+ $InputTCPServerStreamDriverAuthMode anon # client is NOT authenticated
13
+ $InputTCPServerRun 10514 # start up listener at port 10514
14
+
15
+ if $fromhost-ip != '127.0.0.1' then /Mu_Logs/nodes.log
16
+
17
+ & ~
18
+
19
+ if $fromhost-ip == '127.0.0.1' then /Mu_Logs/master.log
@@ -0,0 +1,8 @@
1
+ dn: cn=RSA,cn=encryption,cn=config
2
+ changetype: add
3
+ objectclass: top
4
+ objectclass: nsEncryptionModule
5
+ cn: RSA
6
+ nsSSLPersonalitySSL: ldap
7
+ nsSSLToken: internal (software)
8
+ nsSSLActivation: on