mirror of https://github.com/ansible/ansible.git
[stable-2.7] Add an user facts module for Online (#44709)
(cherry picked from commit 5cf9644003
)
Co-authored-by: Rémy Léone <remy.leone@gmail.com>
pull/45166/merge
parent
8a8da98546
commit
4fff85d66f
@ -0,0 +1,116 @@
|
|||||||
|
import json
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import env_fallback
|
||||||
|
from ansible.module_utils.urls import fetch_url
|
||||||
|
|
||||||
|
|
||||||
|
def online_argument_spec():
|
||||||
|
return dict(
|
||||||
|
api_token=dict(required=True, fallback=(env_fallback, ['ONLINE_TOKEN', 'ONLINE_API_KEY', 'ONLINE_OAUTH_TOKEN', 'ONLINE_API_TOKEN']),
|
||||||
|
no_log=True, aliases=['oauth_token']),
|
||||||
|
api_url=dict(fallback=(env_fallback, ['ONLINE_API_URL']), default='https://api.online.net/api/v1', aliases=['base_url']),
|
||||||
|
api_timeout=dict(type='int', default=30, aliases=['timeout']),
|
||||||
|
validate_certs=dict(default=True, type='bool'),
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class OnlineException(Exception):
|
||||||
|
|
||||||
|
def __init__(self, message):
|
||||||
|
self.message = message
|
||||||
|
|
||||||
|
|
||||||
|
class Response(object):
|
||||||
|
|
||||||
|
def __init__(self, resp, info):
|
||||||
|
self.body = None
|
||||||
|
if resp:
|
||||||
|
self.body = resp.read()
|
||||||
|
self.info = info
|
||||||
|
|
||||||
|
@property
|
||||||
|
def json(self):
|
||||||
|
if not self.body:
|
||||||
|
if "body" in self.info:
|
||||||
|
return json.loads(self.info["body"])
|
||||||
|
return None
|
||||||
|
try:
|
||||||
|
return json.loads(self.body)
|
||||||
|
except ValueError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def status_code(self):
|
||||||
|
return self.info["status"]
|
||||||
|
|
||||||
|
@property
|
||||||
|
def ok(self):
|
||||||
|
return self.status_code in (200, 201, 202, 204)
|
||||||
|
|
||||||
|
|
||||||
|
class Online(object):
|
||||||
|
|
||||||
|
def __init__(self, module):
|
||||||
|
self.module = module
|
||||||
|
self.headers = {
|
||||||
|
'Authorization': "Bearer %s" % self.module.params.get('api_token'),
|
||||||
|
'User-Agent': self.get_user_agent_string(module),
|
||||||
|
'Content-type': 'application/json',
|
||||||
|
}
|
||||||
|
self.name = None
|
||||||
|
|
||||||
|
def get_resources(self):
|
||||||
|
results = self.get('/%s' % self.name)
|
||||||
|
if not results.ok:
|
||||||
|
raise OnlineException('Error fetching {0} ({1}) [{2}: {3}]'.format(
|
||||||
|
self.name, '%s/%s' % (self.module.params.get('api_url'), self.name),
|
||||||
|
results.status_code, results.json['message']
|
||||||
|
))
|
||||||
|
|
||||||
|
return results.json
|
||||||
|
|
||||||
|
def _url_builder(self, path):
|
||||||
|
if path[0] == '/':
|
||||||
|
path = path[1:]
|
||||||
|
return '%s/%s' % (self.module.params.get('api_url'), path)
|
||||||
|
|
||||||
|
def send(self, method, path, data=None, headers=None):
|
||||||
|
url = self._url_builder(path)
|
||||||
|
data = self.module.jsonify(data)
|
||||||
|
|
||||||
|
if headers is not None:
|
||||||
|
self.headers.update(headers)
|
||||||
|
|
||||||
|
resp, info = fetch_url(
|
||||||
|
self.module, url, data=data, headers=self.headers, method=method,
|
||||||
|
timeout=self.module.params.get('api_timeout')
|
||||||
|
)
|
||||||
|
|
||||||
|
# Exceptions in fetch_url may result in a status -1, the ensures a proper error to the user in all cases
|
||||||
|
if info['status'] == -1:
|
||||||
|
self.module.fail_json(msg=info['msg'])
|
||||||
|
|
||||||
|
return Response(resp, info)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def get_user_agent_string(module):
|
||||||
|
return "ansible %s Python %s" % (module.ansible_version, sys.version.split(' ')[0])
|
||||||
|
|
||||||
|
def get(self, path, data=None, headers=None):
|
||||||
|
return self.send('GET', path, data, headers)
|
||||||
|
|
||||||
|
def put(self, path, data=None, headers=None):
|
||||||
|
return self.send('PUT', path, data, headers)
|
||||||
|
|
||||||
|
def post(self, path, data=None, headers=None):
|
||||||
|
return self.send('POST', path, data, headers)
|
||||||
|
|
||||||
|
def delete(self, path, data=None, headers=None):
|
||||||
|
return self.send('DELETE', path, data, headers)
|
||||||
|
|
||||||
|
def patch(self, path, data=None, headers=None):
|
||||||
|
return self.send("PATCH", path, data, headers)
|
||||||
|
|
||||||
|
def update(self, path, data=None, headers=None):
|
||||||
|
return self.send("UPDATE", path, data, headers)
|
@ -0,0 +1,75 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
||||||
|
from __future__ import (absolute_import, division, print_function)
|
||||||
|
__metaclass__ = type
|
||||||
|
|
||||||
|
ANSIBLE_METADATA = {'metadata_version': '1.1',
|
||||||
|
'status': ['preview'],
|
||||||
|
'supported_by': 'community'}
|
||||||
|
|
||||||
|
DOCUMENTATION = r'''
|
||||||
|
---
|
||||||
|
module: online_user_facts
|
||||||
|
short_description: Gather facts about Online user.
|
||||||
|
description:
|
||||||
|
- Gather facts about the user.
|
||||||
|
version_added: "2.7"
|
||||||
|
author:
|
||||||
|
- "Remy Leone (@sieben)"
|
||||||
|
extends_documentation_fragment: online
|
||||||
|
'''
|
||||||
|
|
||||||
|
EXAMPLES = r'''
|
||||||
|
- name: Gather Online user facts
|
||||||
|
online_user_facts:
|
||||||
|
'''
|
||||||
|
|
||||||
|
RETURN = r'''
|
||||||
|
---
|
||||||
|
online_user_facts:
|
||||||
|
description: Response from Online API
|
||||||
|
returned: success
|
||||||
|
type: complex
|
||||||
|
contains:
|
||||||
|
"online_user_facts": {
|
||||||
|
"company": "foobar LLC",
|
||||||
|
"email": "foobar@example.com",
|
||||||
|
"first_name": "foo",
|
||||||
|
"id": 42,
|
||||||
|
"last_name": "bar",
|
||||||
|
"login": "foobar"
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
from ansible.module_utils.online import (
|
||||||
|
Online, OnlineException, online_argument_spec
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class OnlineUserFacts(Online):
|
||||||
|
|
||||||
|
def __init__(self, module):
|
||||||
|
super(OnlineUserFacts, self).__init__(module)
|
||||||
|
self.name = 'user'
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
module = AnsibleModule(
|
||||||
|
argument_spec=online_argument_spec(),
|
||||||
|
supports_check_mode=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
try:
|
||||||
|
module.exit_json(
|
||||||
|
ansible_facts={'online_user_facts': OnlineUserFacts(module).get_resources()}
|
||||||
|
)
|
||||||
|
except OnlineException as exc:
|
||||||
|
module.fail_json(msg=exc.message)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
@ -0,0 +1,36 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
||||||
|
|
||||||
|
class ModuleDocFragment(object):
|
||||||
|
|
||||||
|
# Standard documentation fragment
|
||||||
|
DOCUMENTATION = '''
|
||||||
|
options:
|
||||||
|
api_token:
|
||||||
|
description:
|
||||||
|
- Online OAuth token.
|
||||||
|
aliases: ['oauth_token']
|
||||||
|
api_url:
|
||||||
|
description:
|
||||||
|
- Online API URL
|
||||||
|
default: 'https://api.online.net/api/v1'
|
||||||
|
aliases: ['base_url']
|
||||||
|
api_timeout:
|
||||||
|
description:
|
||||||
|
- HTTP timeout to Online API in seconds.
|
||||||
|
default: 30
|
||||||
|
aliases: ['timeout']
|
||||||
|
validate_certs:
|
||||||
|
description:
|
||||||
|
- Validate SSL certs of the Online API.
|
||||||
|
default: yes
|
||||||
|
type: bool
|
||||||
|
notes:
|
||||||
|
- Also see the API documentation on U(https://console.online.net/en/api/)
|
||||||
|
- If C(api_token) is not set within the module, the following
|
||||||
|
environment variables can be used in decreasing order of precedence
|
||||||
|
C(ONLINE_TOKEN), C(ONLINE_API_KEY), C(ONLINE_OAUTH_TOKEN), C(ONLINE_API_TOKEN)
|
||||||
|
- If one wants to use a different C(api_url) one can also set the C(ONLINE_API_URL)
|
||||||
|
environment variable.
|
||||||
|
'''
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
- hosts: localhost
|
||||||
|
gather_facts: no
|
||||||
|
connection: local
|
||||||
|
|
||||||
|
roles:
|
||||||
|
- { role: online_user_facts, tags: test_online_user_facts }
|
@ -0,0 +1,14 @@
|
|||||||
|
# ONLINE_TOKEN='XXX' ansible-playbook ./test/legacy/online.yml --tags test_online_user_facts
|
||||||
|
|
||||||
|
- name: Get user information and register it in a variable
|
||||||
|
online_user_facts:
|
||||||
|
register: user
|
||||||
|
|
||||||
|
- name: Display user variable
|
||||||
|
debug:
|
||||||
|
var: user
|
||||||
|
|
||||||
|
- name: Ensure retrieval of user facts is success
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- user is success
|
Loading…
Reference in New Issue