|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
|
|
|
|
|
|
__metaclass__ = type
|
|
|
|
|
|
|
|
DOCUMENTATION = '''
|
|
|
|
---
|
|
|
|
module: custom_rdp_ping
|
|
|
|
short_description: Use rdp to probe whether an asset is connectable
|
|
|
|
description:
|
|
|
|
- Use rdp to probe whether an asset is connectable
|
|
|
|
'''
|
|
|
|
|
|
|
|
EXAMPLES = '''
|
|
|
|
- name: >
|
|
|
|
Ping asset server.
|
|
|
|
custom_rdp_ping:
|
|
|
|
login_host: 127.0.0.1
|
|
|
|
login_port: 3389
|
|
|
|
login_user: jms
|
|
|
|
login_password: password
|
|
|
|
'''
|
|
|
|
|
|
|
|
RETURN = '''
|
|
|
|
is_available:
|
|
|
|
description: Windows server availability.
|
|
|
|
returned: always
|
|
|
|
type: bool
|
|
|
|
sample: true
|
|
|
|
conn_err_msg:
|
|
|
|
description: Connection error message.
|
|
|
|
returned: always
|
|
|
|
type: str
|
|
|
|
sample: ''
|
|
|
|
'''
|
|
|
|
|
|
|
|
import pyfreerdp
|
|
|
|
from typing import NamedTuple
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
|
|
|
|
|
|
|
|
|
|
# =========================================
|
|
|
|
# Module execution.
|
|
|
|
#
|
|
|
|
|
|
|
|
class Param(NamedTuple):
|
|
|
|
hostname: str
|
|
|
|
port: int
|
|
|
|
username: str
|
|
|
|
password: str
|
|
|
|
|
|
|
|
|
|
|
|
def common_argument_spec():
|
|
|
|
options = dict(
|
|
|
|
login_host=dict(type='str', required=False, default='localhost'),
|
|
|
|
login_port=dict(type='int', required=False, default=22),
|
|
|
|
login_user=dict(type='str', required=False, default='root'),
|
|
|
|
login_password=dict(type='str', required=False, no_log=True),
|
|
|
|
login_secret_type=dict(type='str', required=False, default='password'),
|
|
|
|
login_private_key_path=dict(type='str', required=False, no_log=True),
|
|
|
|
)
|
|
|
|
return options
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
options = common_argument_spec()
|
|
|
|
module = AnsibleModule(argument_spec=options, supports_check_mode=True)
|
|
|
|
result = {'changed': False, 'is_available': False}
|
|
|
|
|
|
|
|
secret_type = module.params['login_secret_type']
|
|
|
|
if secret_type != 'password':
|
|
|
|
module.fail_json(
|
|
|
|
msg=f'The current ansible does not support \
|
|
|
|
the verification method for {secret_type} types.'
|
|
|
|
)
|
|
|
|
return module.exit_json(**result)
|
|
|
|
|
|
|
|
params = Param(
|
|
|
|
hostname=module.params['login_host'],
|
|
|
|
port=module.params['login_port'],
|
|
|
|
username=module.params['login_user'],
|
|
|
|
password=module.params['login_password']
|
|
|
|
)
|
|
|
|
|
|
|
|
is_available = pyfreerdp.check_connectivity(*params, '', 0)
|
|
|
|
result['is_available'] = is_available
|
|
|
|
if not is_available:
|
|
|
|
module.fail_json(msg='Unable to connect to asset.')
|
|
|
|
return module.exit_json(**result)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|