Saltstack Official MongoDB Formula
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

119 lines
3.0KB

  1. {%- from "mongodb/map.jinja" import server with context %}
  2. {%- if server.enabled %}
  3. mongodb_packages:
  4. pkg.installed:
  5. - names: {{ server.pkgs }}
  6. /etc/mongodb.conf:
  7. file.managed:
  8. - source: salt://mongodb/files/mongodb.conf
  9. - template: jinja
  10. - require:
  11. - pkg: mongodb_packages
  12. {%- if server.shared_key is defined %}
  13. /etc/mongodb.key:
  14. file.managed:
  15. - contents_pillar: mongodb:server:shared_key
  16. - mode: 600
  17. - user: mongodb
  18. - require:
  19. - pkg: mongodb_packages
  20. - watch_in:
  21. - service: mongodb_service
  22. {%- endif %}
  23. {{ server.lock_dir }}:
  24. file.directory:
  25. - makedirs: true
  26. mongodb_service:
  27. service.running:
  28. - name: {{ server.service }}
  29. - enable: true
  30. - require:
  31. - file: {{ server.lock_dir }}
  32. - pkg: mongodb_packages
  33. - watch:
  34. - file: /etc/mongodb.conf
  35. {%- if server.members is not defined or server.master == pillar.linux.system.name %}
  36. {# We are not a cluster or we are master #}
  37. /var/tmp/mongodb_user.js:
  38. file.managed:
  39. - source: salt://mongodb/files/user.js
  40. - template: jinja
  41. - mode: 600
  42. - user: root
  43. mongodb_change_root_password:
  44. cmd.run:
  45. - name: 'mongo localhost:27017/admin /var/tmp/mongodb_user.js && touch {{ server.lock_dir }}/mongodb_password_changed'
  46. - require:
  47. - file: /var/tmp/mongodb_user.js
  48. - service: mongodb_service
  49. - creates: {{ server.lock_dir }}/mongodb_password_changed
  50. {%- for database_name, database in server.get('database', {}).iteritems() %}
  51. mongodb_database_{{ database_name }}:
  52. mongodb_user.present:
  53. - name: {{ database_name }}
  54. - passwd: {{ database.password }}
  55. - user: admin
  56. - password: {{ server.admin.password }}
  57. {%- if server.members is defined %}
  58. require:
  59. - cmd: mongodb_setup_cluster
  60. {%- endif %}
  61. /var/tmp/mongodb_user_{{ database_name }}.js:
  62. file.managed:
  63. - source: salt://mongodb/files/user_role.js
  64. - template: jinja
  65. - mode: 600
  66. - user: root
  67. - require:
  68. - mongodb_user: {{ database_name }}
  69. - defaults:
  70. database_name: {{ database_name }}
  71. mongodb_{{ database_name }}_fix_role:
  72. cmd.run:
  73. - name: 'mongo localhost:27017/admin -u admin -p {{ server.admin.password }} /var/tmp/mongodb_user_{{ database_name }}.js && touch {{ server.lock_dir }}/mongodb_user_{{ database_name }}_created'
  74. - require:
  75. - file: /var/tmp/mongodb_user_{{ database_name }}.js
  76. - service: mongodb_service
  77. - creates: {{ server.lock_dir }}/mongodb_user_{{ database_name }}_created
  78. {%- endfor %}
  79. {%- if server.members is defined %}
  80. /var/tmp/mongodb_cluster.js:
  81. file.managed:
  82. - source: salt://mongodb/files/cluster.js
  83. - template: jinja
  84. - mode: 600
  85. - user: root
  86. mongodb_setup_cluster:
  87. cmd.run:
  88. - name: 'mongo localhost:27017/admin /var/tmp/mongodb_cluster.js && mongo localhost:27017/admin --quiet --eval "rs.conf()" | grep object -q'
  89. - unless: 'mongo localhost:27017/admin -u admin -p {{ server.admin.password }} --quiet --eval "rs.conf()" | grep object -q'
  90. - require:
  91. - service: mongodb_service
  92. - file: /var/tmp/mongodb_cluster.js
  93. - require_in:
  94. - cmd: mongodb_change_root_password
  95. {%- endif %}
  96. {%- endif %}
  97. {%- endif %}