|
- {%- if pillar.get('mysql', {}).server is defined %}
-
- {%- set server = pillar.mysql.server %}
-
- {%- for database_name, database in server.get('database', {}).iteritems() %}
-
- mysql_database_{{ database_name }}:
- mysql_database.present:
- - name: {{ database_name }}
-
- {%- for user in database.users %}
-
- mysql_user_{{ user.name }}_{{ database_name }}_{{ user.host }}:
- mysql_user.present:
- - host: '{{ user.host }}'
- - name: '{{ user.name }}'
- - password: {{ user.password }}
-
- mysql_grants_{{ user.name }}_{{ database_name }}_{{ user.host }}:
- mysql_grants.present:
- - grant: {{ user.rights }}
- - database: '{{ database_name }}.*'
- - user: '{{ user.name }}'
- - host: '{{ user.host }}'
- - require:
- - mysql_user: mysql_user_{{ user.name }}_{{ database_name }}_{{ user.host }}
- - mysql_database: mysql_database_{{ database_name }}
-
- {%- endfor %}
-
- {%- if database.initial_data is defined %}
-
- /root/mysql/scripts/restore_{{ database_name }}.sh:
- file.managed:
- - source: salt://mysql/conf/restore.sh
- - mode: 770
- - template: jinja
- - defaults:
- database_name: {{ database_name }}
- database: {{ database }}
- - require:
- - file: mysql_dirs
- - mysql_database: mysql_database_{{ database_name }}
-
- restore_mysql_database_{{ database_name }}:
- cmd.run:
- - name: /root/mysql/scripts/restore_{{ database_name }}.sh
- - unless: "[ -f /root/mysql/flags/{{ database_name }}-installed ]"
- - cwd: /root
- - require:
- - file: /root/mysql/scripts/restore_{{ database_name }}.sh
-
- {%- endif %}
-
- {%- endfor %}
-
- {%- if not grains.get('noservices', False) %}
- {%- for user in server.get('users', []) %}
- {%- set user_hosts = user.get('hosts', user.get('host', 'localhost'))|sequence %}
- {%- for host in user_hosts %}
- mysql_user_{{ user.name }}_{{ host }}:
- mysql_user.present:
- - host: '{{ user.host }}'
- - name: '{{ user.name }}'
- {%- if user['password_hash'] is defined %}
- - password_hash: '{{ user.password_hash }}'
- {%- elif user['password'] is defined and user['password'] != None %}
- - password: '{{ user.password }}'
- {%- else %}
- - allow_passwordless: True
- {%- endif %}
- - connection_charset: utf8
-
- {%- if 'grants' in user %}
- mysql_user_{{ user.name }}_{{ host }}_grants:
- mysql_grants.present:
- - name: {{ user.name }}
- - grant: {{ user['grants']|sequence|join(",") }}
- - database: '*.*'
- - grant_option: {{ user['grant_option'] | default(False) }}
- - user: {{ user.name }}
- - host: '{{ host }}'
- - connection_charset: utf8
- - require:
- - mysql_user_{{ user.name }}_{{ host }}
- {%- endif %}
-
- {%- if 'databases' in user %}
- {% for db in user['databases'] %}
- mysql_user_{{ user.name }}_{{ host }}_grants_db_{{ db }} ~ '_' ~ loop.index0:
- mysql_grants.present:
- - name: {{ user.name ~ '_' ~ db['database'] ~ '_' ~ db['table'] | default('all') }}
- - grant: {{db['grants']|sequence|join(",")}}
- - database: '{{ db['database'] }}.{{ db['table'] | default('*') }}'
- - grant_option: {{ db['grant_option'] | default(False) }}
- - user: {{ user.name }}
- - host: '{{ host }}'
- - connection_charset: utf8
- - require:
- - mysql_user_{{ user.name }}_{{ host }}
- - mysql_database_{{ db }}
- {%- endfor %}
- {%- endif %}
-
- {%- endfor %}
- {%- endfor %}
-
- {%- endif %}
-
- {%- set _galera_xinetd_srv = [] %}
-
- {%- for server_name, server in slave.get('bind', {}).iteritems() %}
- {%- if server.get.get('clustercheck', {}).get('enabled', False) == True %}
- {%- for bind in slave.bind %}
- {%- set index = '_{0}_{1}'.format(bind.address, bind.port) %}
- {%- set _ccheck = server.clustercheck %}
- {%- do _galera_xinetd_srv.append('clustercheck') %}
- /etc/xinetd.d/mysql_clustercheck{{ index }}_{{ _ccheck.get('clustercheckport', 9200) }}:
- file.managed:
- - source: salt://galera/files/xinet.d.conf
- - template: jinja
- - defaults:
- user: nobody
- # FIXME, add optins if check_attr host/port is defined etc..
- server: '/usr/local/bin/clustercheck {{ _ccheck.get('user', 'clustercheck') }} {{ _ccheck.get('password', 'clustercheck') }} {{ _ccheck.get('available_when_donor', 0) }} {{ _ccheck.get('available_when_readonly', 0) }}'
- port: _ccheck.get('port', 9200)
- flags: REUSE
- per_source: UNLIMITED
- - require:
- - file: /usr/local/bin/mysql_clustercheck
- - watch_in:
- - galera_xinetd_service
-
- {%- endfor %}
- {%- endif %}
- {%- endfor %}
-
- {% if 'clustercheck' in _galera_xinetd_srv %}
- clustercheck_dir:
- file.directory:
- - name: /usr/local/bin/
- - user: root
- - group: root
- - mode: 750
-
- /usr/local/bin/mysql_clustercheck:
- file.managed:
- - source: salt://galera/files/clustercheck.sh
- - user: root
- - group: root
- - mode: 755
- - require:
- - file: clustercheck_dir
- {%- endif %}
-
- {%- if _galera_xinetd_srv|length > 0 %}
- haproxy_xinetd_package:
- pkg.installed:
- - name: xinetd
-
- galera_xinetd_service:
- service.running:
- - name: xinetd
- - require:
- - pkg: xinetd
- {%- endif %}
-
-
- {%- endif %}
- {%- endif %}
|