mirror of https://github.com/jumpserver/jumpserver
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.
69 lines
2.5 KiB
69 lines
2.5 KiB
- hosts: sqlserver
|
|
gather_facts: no
|
|
vars:
|
|
ansible_python_interpreter: /usr/local/bin/python
|
|
|
|
tasks:
|
|
- name: Test SQLServer connection
|
|
community.general.mssql_script:
|
|
login_user: "{{ jms_account.username }}"
|
|
login_password: "{{ jms_account.secret }}"
|
|
login_host: "{{ jms_asset.address }}"
|
|
login_port: "{{ jms_asset.port }}"
|
|
name: '{{ jms_asset.spec_info.db_name }}'
|
|
script: |
|
|
SELECT @@version
|
|
register: db_info
|
|
|
|
- name: SQLServer version
|
|
set_fact:
|
|
info:
|
|
version: "{{ db_info.query_results[0][0][0][0].splitlines()[0] }}"
|
|
- debug:
|
|
var: info
|
|
|
|
- name: Check whether SQLServer User exist
|
|
community.general.mssql_script:
|
|
login_user: "{{ jms_account.username }}"
|
|
login_password: "{{ jms_account.secret }}"
|
|
login_host: "{{ jms_asset.address }}"
|
|
login_port: "{{ jms_asset.port }}"
|
|
name: '{{ jms_asset.spec_info.db_name }}'
|
|
script: "SELECT 1 from sys.sql_logins WHERE name='{{ account.username }}';"
|
|
when: db_info is succeeded
|
|
register: user_exist
|
|
|
|
- name: Change SQLServer password
|
|
community.general.mssql_script:
|
|
login_user: "{{ jms_account.username }}"
|
|
login_password: "{{ jms_account.secret }}"
|
|
login_host: "{{ jms_asset.address }}"
|
|
login_port: "{{ jms_asset.port }}"
|
|
name: '{{ jms_asset.spec_info.db_name }}'
|
|
script: "ALTER LOGIN {{ account.username }} WITH PASSWORD = '{{ account.secret }}'; select @@version"
|
|
ignore_errors: true
|
|
when: user_exist.query_results[0] | length != 0
|
|
register: change_info
|
|
|
|
- name: Add SQLServer user
|
|
community.general.mssql_script:
|
|
login_user: "{{ jms_account.username }}"
|
|
login_password: "{{ jms_account.secret }}"
|
|
login_host: "{{ jms_asset.address }}"
|
|
login_port: "{{ jms_asset.port }}"
|
|
name: '{{ jms_asset.spec_info.db_name }}'
|
|
script: "CREATE LOGIN {{ account.username }} WITH PASSWORD = '{{ account.secret }}'; select @@version"
|
|
ignore_errors: true
|
|
when: user_exist.query_results[0] | length == 0
|
|
register: change_info
|
|
|
|
- name: Verify password
|
|
community.general.mssql_script:
|
|
login_user: "{{ account.username }}"
|
|
login_password: "{{ account.secret }}"
|
|
login_host: "{{ jms_asset.address }}"
|
|
login_port: "{{ jms_asset.port }}"
|
|
name: '{{ jms_asset.spec_info.db_name }}'
|
|
script: |
|
|
SELECT @@version
|