Dre4m Shell
Server IP : 85.214.239.14  /  Your IP : 3.133.150.142
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/libcloud/common/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME SHELL ]     

Current File : /lib/python3/dist-packages/libcloud/common//liquidweb.py
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements.  See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License.  You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import base64

from libcloud.common.base import JsonResponse
from libcloud.common.base import ConnectionUserAndKey
from libcloud.utils.py3 import b
from libcloud.common.types import ProviderError


__all__ = [
    'API_HOST',
    'LiquidWebException',
    'LiquidWebResponse',
    'LiquidWebConnection',
]


# Endpoint for liquidweb api.
API_HOST = 'api.stormondemand.com'


class LiquidWebException(ProviderError):
    """The base class for other Liquidweb exceptions"""

    def __init__(self, value, http_code, extra=None):
        """
        :param value: message contained in error
        :type  value: ``str``

        :param http_code: error code
        :type  http_code: ``int``

        :param extra: extra fields specific to error type
        :type  extra: ``list``
        """
        self.extra = extra
        super(LiquidWebException, self).__init__(value, http_code, driver=None)

    def __str__(self):
        return "%s  %s" % (self.http_code, self.value)

    def __repr__(self):
        return "LiquidWebException %s %s" % (self.http_code, self.value)


class APIException(LiquidWebException):

    def __init__(self, error_class, full_msg, http_code, extra=None):
        self.error_class = error_class
        super(APIException, self).__init__(full_msg, http_code, extra=extra)

    def __str__(self):
        return "%s: %s" % (self.error_class, self.value)

    def __repr__(self):
        return "%s: %s" % (self.error_class, self.value)


EXCEPTIONS_FIELDS = {
    'LW::Exception::API::Internal': {
        'fields': []
    },
    'LW::Exception::API::InvalidEncoding': {
        'fields': ['encoding']
    },
    'LW::Exception::API::InvalidMethod': {
        'fields': ['method']
    },
    'LW::Exception::API::Maintenance': {
        'fields': []
    },
    'LW::Exception::API::RateLimit': {
        'fields': ['account', 'ip', 'method']
    },
    'LW::Exception::Authorization': {
        'fields': ['username']
    },
    'LW::Exception::DNS::NoResponse': {
        'fields': ['nameservers']
    },
    'LW::Exception::DNS::Servfail': {
        'fields': ['nameservers']
    },
    'LW::Exception::Deserialize': {
        'fields': ['data', 'encoding']
    },
    'LW::Exception::DuplicateRecord': {
        'fields': ['field', 'input', 'statement']
    },
    'LW::Exception::Forbidden': {
        'fields': []
    },
    'LW::Exception::Incapable': {
        'fields': ['capability', 'thing']
    },
    'LW::Exception::Input': {
        'fields': ['field']
    },
    'LW::Exception::Input::Disallowed': {
        'fields': ['field']
    },
    'LW::Exception::Input::Multiple': {
        'fields': ['errors', 'field', 'type']
    },
    'LW::Exception::Input::NotInRealm': {
        'fields': ['field', 'valid', 'value']
    },
    'LW::Exception::Input::OutOfBounds': {
        'fields': ['field', 'max', 'min', 'value']
    },
    'LW::Exception::Input::Required': {
        'fields': ['field', 'position']
    },
    'LW::Exception::Input::Unknown': {
        'fields': ['field', 'value']
    },
    'LW::Exception::Input::Validation': {
        'fields': ['field', 'type', 'value']
    },
    'LW::Exception::Permission': {
        'fields': ['account', 'identifier']
    },
    'LW::Exception::RecordNotFound': {
        'fields': ['field', 'input']
    },
    'LW::Exception::RemoteService::Authorization': {
        'fields': ['url']
    },
    'LW::Exception::Resource': {
        'fields': ['resource']
    },
    'LW::Exception::Resource::Insufficient': {
        'fields': ['available', 'requested', 'resource']
    },
    'LW::Exception::Resource::Unavailable': {
        'fields': ['resource']
    },
    'LW::Exception::Serialize': {
        'fields': ['data', 'encoding']
    },
    'LW::Exception::Workflow::Conflict': {
        'fields': ['conflict', 'workflow']
    }
}


class LiquidWebResponse(JsonResponse):
    objects = None
    errors = None

    def __init__(self, response, connection):
        self.errors = []
        super(LiquidWebResponse, self).__init__(response=response,
                                                connection=connection)
        self.objects, self.errors = self.parse_body_and_errors()
        if self.errors:
            error = self.errors.pop()
            raise self._make_excp(error, self.status)

    def parse_body_and_errors(self):
        data = []
        errors = []
        js = super(LiquidWebResponse, self).parse_body()
        if 'items' in js:
            data.append(js['items'])

        if 'name' in js:
            data.append(js)

        if 'deleted' in js:
            data.append(js['deleted'])

        if 'error_class' in js:
            errors.append(js)

        return (data, errors)

    def success(self):
        """
        Returns ``True`` if our request is successful.
        """
        return (len(self.errors) == 0)

    def _make_excp(self, error, status):
        """
        Raise LiquidWebException.
        """
        exc_type = error.get('error_class')
        message = error.get('full_message')
        try:
            _type = EXCEPTIONS_FIELDS[exc_type]
            fields = _type.get('fields')
            extra = {}
        except KeyError:
            fields = []

        for field in fields:
            extra[field] = error.get(field)
        return APIException(exc_type, message, status, extra=extra)


class LiquidWebConnection(ConnectionUserAndKey):
    host = API_HOST
    responseCls = LiquidWebResponse

    def add_default_headers(self, headers):
        b64string = b('%s:%s' % (self.user_id, self.key))
        encoded = base64.b64encode(b64string).decode('utf-8')
        authorization = 'Basic ' + encoded

        headers['Authorization'] = authorization
        headers['Content-Type'] = 'application/json'

        return headers

Anon7 - 2022
AnonSec Team