Server IP : 85.214.239.14 / Your IP : 3.129.63.214 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 : /proc/3/cwd/proc/3/cwd/srv/modoboa/env/lib64/python3.5/site-packages/ovh-0.5.0.dist-info/ |
Upload File : |
Metadata-Version: 2.1 Name: ovh Version: 0.5.0 Summary: "Official OVH.com API wrapper" Home-page: http://api.ovh.com Author: Jean-Tiare Le Bigot Author-email: jean-tiare.le-bigot@corp.ovh.com License: BSD Keywords: ovh,sdk,rest Platform: UNKNOWN Classifier: License :: OSI Approved :: BSD License Classifier: Development Status :: 5 - Production/Stable Classifier: Intended Audience :: Developers Classifier: Operating System :: OS Independent Classifier: Programming Language :: Python Classifier: Programming Language :: Python :: 2.7 Classifier: Programming Language :: Python :: 3 Classifier: Programming Language :: Python :: 3.4 Classifier: Programming Language :: Python :: 3.5 Classifier: Programming Language :: Python :: 3.6 Classifier: Topic :: Software Development :: Libraries :: Python Modules Classifier: Topic :: System :: Archiving :: Packaging Provides-Extra: dev Requires-Dist: coverage (==3.7.1) ; extra == 'dev' Requires-Dist: mock (==1.0.1) ; extra == 'dev' Requires-Dist: nose (==1.3.3) ; extra == 'dev' Requires-Dist: yanc (==0.2.4) ; extra == 'dev' Requires-Dist: Sphinx (==1.2.2) ; extra == 'dev' Requires-Dist: coveralls (==0.4.4) ; extra == 'dev' Requires-Dist: setuptools (>=30.3.0) ; extra == 'dev' Requires-Dist: wheel ; extra == 'dev' Provides-Extra: test Requires-Dist: coverage (==3.7.1) ; extra == 'test' Requires-Dist: mock (==1.0.1) ; extra == 'test' Requires-Dist: nose (==1.3.3) ; extra == 'test' Requires-Dist: yanc (==0.2.4) ; extra == 'test' .. image:: https://github.com/ovh/python-ovh/raw/master/docs/img/logo.png :alt: Python & OVH APIs :target: https://pypi.python.org/pypi/ovh Lightweight wrapper around OVH's APIs. Handles all the hard work including credential creation and requests signing. .. image:: https://img.shields.io/pypi/v/ovh.svg :alt: PyPi Version :target: https://pypi.python.org/pypi/ovh .. image:: https://img.shields.io/pypi/status/ovh.svg :alt: PyPi repository status :target: https://pypi.python.org/pypi/ovh .. image:: https://img.shields.io/pypi/pyversions/ovh.svg :alt: PyPi supported Python versions :target: https://pypi.python.org/pypi/ovh .. image:: https://img.shields.io/pypi/wheel/ovh.svg :alt: PyPi Wheel status :target: https://pypi.python.org/pypi/ovh .. image:: https://travis-ci.org/ovh/python-ovh.svg?branch=master :alt: Build Status :target: https://travis-ci.org/ovh/python-ovh .. image:: https://coveralls.io/repos/github/ovh/python-ovh/badge.svg :alt: Coverage Status :target: https://coveralls.io/github/ovh/python-ovh .. code:: python # -*- encoding: utf-8 -*- import ovh # Instantiate. Visit https://api.ovh.com/createToken/?GET=/me # to get your credentials client = ovh.Client( endpoint='ovh-eu', application_key='<application key>', application_secret='<application secret>', consumer_key='<consumer key>', ) # Print nice welcome message print "Welcome", client.get('/me')['firstname'] Installation ============ The python wrapper works with Python 2.7 and Python 3.4+. The easiest way to get the latest stable release is to grab it from `pypi <https://pypi.python.org/pypi/ovh>`_ using ``pip``. .. code:: bash pip install ovh Alternatively, you may get latest development version directly from Git. .. code:: bash pip install -e git+https://github.com/ovh/python-ovh.git#egg=ovh Example Usage ============= Use the API on behalf of a user ------------------------------- 1. Create an application ************************ To interact with the APIs, the SDK needs to identify itself using an ``application_key`` and an ``application_secret``. To get them, you need to register your application. Depending the API you plan to use, visit: - `OVH Europe <https://eu.api.ovh.com/createApp/>`_ - `OVH US <https://api.ovhcloud.com/createApp/>`_ - `OVH North-America <https://ca.api.ovh.com/createApp/>`_ - `So you Start Europe <https://eu.api.soyoustart.com/createApp/>`_ - `So you Start North America <https://ca.api.soyoustart.com/createApp/>`_ - `Kimsufi Europe <https://eu.api.kimsufi.com/createApp/>`_ - `Kimsufi North America <https://ca.api.kimsufi.com/createApp/>`_ Once created, you will obtain an **application key (AK)** and an **application secret (AS)**. 2. Configure your application ***************************** The easiest and safest way to use your application's credentials is to create an ``ovh.conf`` configuration file in application's working directory. Here is how it looks like: .. code:: ini [default] ; general configuration: default endpoint endpoint=ovh-eu [ovh-eu] ; configuration specific to 'ovh-eu' endpoint application_key=my_app_key application_secret=my_application_secret ; uncomment following line when writing a script application ; with a single consumer key. ;consumer_key=my_consumer_key Depending on the API you want to use, you may set the ``endpoint`` to: * ``ovh-eu`` for OVH Europe API * ``ovh-us`` for OVH US API * ``ovh-ca`` for OVH North-America API * ``soyoustart-eu`` for So you Start Europe API * ``soyoustart-ca`` for So you Start North America API * ``kimsufi-eu`` for Kimsufi Europe API * ``kimsufi-ca`` for Kimsufi North America API See Configuration_ for more information on available configuration mechanisms. .. note:: When using a versioning system, make sure to add ``ovh.conf`` to ignored files. It contains confidential/security-sensitive information! 3. Authorize your application to access a customer account ********************************************************** To allow your application to access a customer account using the API on your behalf, you need a **consumer key (CK)**. Here is a sample code you can use to allow your application to access a customer's information: .. code:: python # -*- encoding: utf-8 -*- import ovh # create a client using configuration client = ovh.Client() # Request RO, /me API access ck = client.new_consumer_key_request() ck.add_rules(ovh.API_READ_ONLY, "/me") # Request token validation = ck.request() print "Please visit %s to authenticate" % validation['validationUrl'] raw_input("and press Enter to continue...") # Print nice welcome message print "Welcome", client.get('/me')['firstname'] print "Btw, your 'consumerKey' is '%s'" % validation['consumerKey'] Returned ``consumerKey`` should then be kept to avoid re-authenticating your end-user on each use. .. note:: To request full and unlimited access to the API, you may use ``add_recursive_rules``: .. code:: python # Allow all GET, POST, PUT, DELETE on /* (full API) ck.add_recursive_rules(ovh.API_READ_WRITE, '/') Install a new mail redirection ------------------------------ e-mail redirections may be freely configured on domains and DNS zones hosted by OVH to an arbitrary destination e-mail using API call ``POST /email/domain/{domain}/redirection``. For this call, the api specifies that the source address shall be given under the ``from`` keyword. Which is a problem as this is also a reserved Python keyword. In this case, simply prefix it with a '_', the wrapper will automatically detect it as being a prefixed reserved keyword and will substitute it. Such aliasing is only supported with reserved keywords. .. code:: python # -*- encoding: utf-8 -*- import ovh DOMAIN = "example.com" SOURCE = "sales@example.com" DESTINATION = "contact@example.com" # create a client client = ovh.Client() # Create a new alias client.post('/email/domain/%s/redirection' % DOMAIN, _from=SOURCE, to=DESTINATION, localCopy=False ) print "Installed new mail redirection from %s to %s" % (SOURCE, DESTINATION) Grab bill list -------------- Let's say you want to integrate OVH bills into your own billing system, you could just script around the ``/me/bills`` endpoints and even get the details of each bill lines using ``/me/bill/{billId}/details/{billDetailId}``. This example assumes an existing Configuration_ with valid ``application_key``, ``application_secret`` and ``consumer_key``. .. code:: python # -*- encoding: utf-8 -*- import ovh # create a client client = ovh.Client() # Grab bill list bills = client.get('/me/bill') for bill in bills: details = client.get('/me/bill/%s' % bill) print "%12s (%s): %10s --> %s" % ( bill, details['date'], details['priceWithTax']['text'], details['pdfUrl'], ) Enable network burst in SBG1 ---------------------------- 'Network burst' is a free service but is opt-in. What if you have, say, 10 servers in ``SBG-1`` datacenter? You certainely don't want to activate it manually for each servers. You could take advantage of a code like this. This example assumes an existing Configuration_ with valid ``application_key``, ``application_secret`` and ``consumer_key``. .. code:: python # -*- encoding: utf-8 -*- import ovh # create a client client = ovh.Client() # get list of all server names servers = client.get('/dedicated/server/') # find all servers in SBG-1 datacenter for server in servers: details = client.get('/dedicated/server/%s' % server) if details['datacenter'] == 'sbg1': # enable burst on server client.put('/dedicated/server/%s/burst' % server, status='active') print "Enabled burst for %s server located in SBG-1" % server List application authorized to access your account -------------------------------------------------- Thanks to the application key / consumer key mechanism, it is possible to finely track applications having access to your data and revoke this access. This examples lists validated applications. It could easily be adapted to manage revocation too. This example assumes an existing Configuration_ with valid ``application_key``, ``application_secret`` and ``consumer_key``. .. code:: python # -*- encoding: utf-8 -*- import ovh from tabulate import tabulate # create a client client = ovh.Client() credentials = client.get('/me/api/credential', status='validated') # pretty print credentials status table = [] for credential_id in credentials: credential_method = '/me/api/credential/'+str(credential_id) credential = client.get(credential_method) application = client.get(credential_method+'/application') table.append([ credential_id, '[%s] %s' % (application['status'], application['name']), application['description'], credential['creation'], credential['expiration'], credential['lastUse'], ]) print tabulate(table, headers=['ID', 'App Name', 'Description', 'Token Creation', 'Token Expiration', 'Token Last Use']) Before running this example, make sure you have the `tabulate <https://pypi.python.org/pypi/tabulate>`_ library installed. It's a pretty cool library to pretty print tabular data in a clean and easy way. >>> pip install tabulate Open a KVM (remote screen) on a dedicated server ------------------------------------------------ Recent dedicated servers come with an IPMI interface. A lightweight control board embedded on the server. Using IPMI, it is possible to get a remote screen on a server. This is particularly useful to tweak the BIOS or troubleshoot boot issues. Hopefully, this can easily be automated using a simple script. It assumes Java Web Start is fully installed on the machine and a consumer key allowed on the server exists. .. code:: python # -*- encoding: utf-8 -*- import ovh import sys import time import tempfile import subprocess # check arguments if len(sys.argv) != 3: print "Usage: %s SERVER_NAME ALLOWED_IP_V4" % sys.argv[0] sys.exit(1) server_name = sys.argv[1] allowed_ip = sys.argv[2] # create a client client = ovh.Client() # create a KVM client.post('/dedicated/server/'+server_name+'/features/ipmi/access', ipToAllow=allowed_ip, ttl=15, type="kvmipJnlp") # open the KVM, when ready while True: try: # use a named temfile and feed it to java web start with tempfile.NamedTemporaryFile() as f: f.write(client.get('/dedicated/server/ns6457228.ip-178-33-61.eu/features/ipmi/access?type=kvmipJnlp')['value']) f.flush() subprocess.call(["javaws", f.name]) break except: time.sleep(1) Running is only a simple command line: .. code:: bash # Basic python open_kvm.py ns1234567.ip-178-42-42.eu $(curl ifconfig.ovh) # Use a specific consumer key OVH_CONSUMER_KEY=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA python open_kvm.py ns6457228.ip-178-33-61.eu $(curl -s ifconfig.ovh) Configuration ============= You have 3 ways to provide configuration to the client: - write it directly in the application code - read environment variables or predefined configuration files - read it from a custom configuration file Embed the configuration in the code ----------------------------------- The straightforward way to use OVH's API keys is to embed them directly in the application code. While this is very convenient, it lacks of elegance and flexibility. Example usage: .. code:: python client = ovh.Client( endpoint='ovh-eu', application_key='<application key>', application_secret='<application secret>', consumer_key='<consumer key>', ) Environment vars and predefined configuration files --------------------------------------------------- Alternatively it is suggested to use configuration files or environment variables so that the same code may run seamlessly in multiple environments. Production and development for instance. This wrapper will first look for direct instantiation parameters then ``OVH_ENDPOINT``, ``OVH_APPLICATION_KEY``, ``OVH_APPLICATION_SECRET`` and ``OVH_CONSUMER_KEY`` environment variables. If either of these parameter is not provided, it will look for a configuration file of the form: .. code:: ini [default] ; general configuration: default endpoint endpoint=ovh-eu [ovh-eu] ; configuration specific to 'ovh-eu' endpoint application_key=my_app_key application_secret=my_application_secret consumer_key=my_consumer_key The client will successively attempt to locate this configuration file in 1. Current working directory: ``./ovh.conf`` 2. Current user's home directory ``~/.ovh.conf`` 3. System wide configuration ``/etc/ovh.conf`` This lookup mechanism makes it easy to overload credentials for a specific project or user. Example usage: .. code:: python client = ovh.Client() Custom configuration file ------------------------- You can also specify a custom configuration file. With this method, you won't be able to inherit values from environment. Example usage: .. code:: python client = ovh.Client(config_file='/my/config.conf') Passing parameters ================== You can call all the methods of the API with the necessary arguments. If an API needs an argument colliding with a Python reserved keyword, it can be prefixed with an underscore. For example, ``from`` argument of ``POST /email/domain/{domain}/redirection`` may be replaced by ``_from``. With characters invalid in python argument name like a dot, you can: .. code:: python # -*- encoding: utf-8 -*- import ovh params = {} params['date.from'] = '2014-01-01' params['date.to'] = '2015-01-01' # create a client client = ovh.Client() # pass parameters using ** client.post('/me/bills', **params) Advanced usage ============== Un-authenticated calls ---------------------- If the user has not authenticated yet (ie, there is no valid Consumer Key), you may force ``python-ovh`` to issue the call by passing ``_need_auth=True`` to the high level ``get()``, ``post()``, ``put()`` and ``delete()`` helpers or ``need_auth=True`` to the low level method ``Client.call()`` and ``Client.raw_call()``. This is needed when calling ``POST /auth/credential`` and ``GET /auth/time`` which are used internally for authentication and can optionally be done for most of the ``/order`` calls. Access the raw requests response objects ---------------------------------------- The high level ``get()``, ``post()``, ``put()`` and ``delete()`` helpers as well as the lower level ``call()`` will returned a parsed json response or raise in case of error. In some rare scenario, advanced setups, you may need to perform customer processing on the raw request response. It may be accessed via ``raw_call()``. This is the lowest level call in ``python-ovh``. See the source for more information. Hacking ======= This wrapper uses standard Python tools, so you should feel at home with it. Here is a quick outline of what it may look like. A good practice is to run this from a ``virtualenv``. Get the sources --------------- .. code:: bash git clone https://github.com/ovh/python-ovh.git cd python-ovh python setup.py develop You've developed a new cool feature ? Fixed an annoying bug ? We'd be happy to hear from you ! Run the tests ------------- Simply run ``nosetests``. It will automatically load its configuration from ``setup.cfg`` and output full coverage status. Since we all love quality, please note that we do not accept contributions with test coverage under 100%. .. code:: bash pip install -e .[dev] nosetests # 100% coverage is a hard minimum Build the documentation ----------------------- Documentation is managed using the excellent ``Sphinx`` system. For example, to build HTML documentation: .. code:: bash cd python-ovh/docs make html Supported APIs ============== OVH Europe ---------- - **Documentation**: https://eu.api.ovh.com/ - **Community support**: api-subscribe@ml.ovh.net - **Console**: https://eu.api.ovh.com/console - **Create application credentials**: https://eu.api.ovh.com/createApp/ - **Create script credentials** (all keys at once): https://eu.api.ovh.com/createToken/ OVH US ---------- - **Documentation**: https://api.us.ovhcloud.com/ - **Console**: https://api.us.ovhcloud.com/console/ - **Create application credentials**: https://api.us.ovhcloud.com/createApp/ - **Create script credentials** (all keys at once): https://api.us.ovhcloud.com/createToken/ OVH North America ----------------- - **Documentation**: https://ca.api.ovh.com/ - **Community support**: api-subscribe@ml.ovh.net - **Console**: https://ca.api.ovh.com/console - **Create application credentials**: https://ca.api.ovh.com/createApp/ - **Create script credentials** (all keys at once): https://ca.api.ovh.com/createToken/ So you Start Europe ------------------- - **Documentation**: https://eu.api.soyoustart.com/ - **Community support**: api-subscribe@ml.ovh.net - **Console**: https://eu.api.soyoustart.com/console/ - **Create application credentials**: https://eu.api.soyoustart.com/createApp/ - **Create script credentials** (all keys at once): https://eu.api.soyoustart.com/createToken/ So you Start North America -------------------------- - **Documentation**: https://ca.api.soyoustart.com/ - **Community support**: api-subscribe@ml.ovh.net - **Console**: https://ca.api.soyoustart.com/console/ - **Create application credentials**: https://ca.api.soyoustart.com/createApp/ - **Create script credentials** (all keys at once): https://ca.api.soyoustart.com/createToken/ Kimsufi Europe -------------- - **Documentation**: https://eu.api.kimsufi.com/ - **Community support**: api-subscribe@ml.ovh.net - **Console**: https://eu.api.kimsufi.com/console/ - **Create application credentials**: https://eu.api.kimsufi.com/createApp/ - **Create script credentials** (all keys at once): https://eu.api.kimsufi.com/createToken/ Kimsufi North America --------------------- - **Documentation**: https://ca.api.kimsufi.com/ - **Community support**: api-subscribe@ml.ovh.net - **Console**: https://ca.api.kimsufi.com/console/ - **Create application credentials**: https://ca.api.kimsufi.com/createApp/ - **Create script credentials** (all keys at once): https://ca.api.kimsufi.com/createToken/ Related links ============= - **Contribute**: https://github.com/ovh/python-ovh - **Report bugs**: https://github.com/ovh/python-ovh/issues - **Download**: http://pypi.python.org/pypi/ovh License ======= 3-Clause BSD