OpenStack Identity (Keystone) Client
Find a file
Gabriel Hurley 2914c2b1d1 Updates client to work with keystone essex roles API routes.
Also adds pep8 to requirements since it was missing, and adds the
automatically-created venv to the gitignore list.

Change-Id: Iafa05c1889d7706b79d0f9392a9ac24f2f5a1719
2012-01-28 18:43:19 -08:00
docs Support for version and extension discovery 2012-01-20 12:14:02 -06:00
keystoneclient Updates client to work with keystone essex roles API routes. 2012-01-28 18:43:19 -08:00
tests Add limit and marker to user_list and tenant_list 2012-01-26 16:14:48 -08:00
tools Updates client to work with keystone essex roles API routes. 2012-01-28 18:43:19 -08:00
.gitignore Updates client to work with keystone essex roles API routes. 2012-01-28 18:43:19 -08:00
.gitreview Added in common test, venv and gitreview stuff. 2011-12-22 00:12:22 +00:00
AUTHORS adding myself to authors 2011-11-17 10:07:29 -08:00
HACKING Initial commit. 2011-10-25 16:50:08 -07:00
LICENSE Initial commit. 2011-10-25 16:50:08 -07:00
MANIFEST.in Initial commit. 2011-10-25 16:50:08 -07:00
README.rst use full name for args in readme 2011-12-19 10:03:08 -08:00
run_tests.sh Added in common test, venv and gitreview stuff. 2011-12-22 00:12:22 +00:00
setup.cfg Initial commit. 2011-10-25 16:50:08 -07:00
setup.py Adjust version number to match other deliveries 2012-01-17 15:06:25 +01:00
tox.ini Modify tox.ini file to do the standard thigns. 2011-12-30 14:28:05 -08:00

Python bindings to the OpenStack Keystone API
=============================================

This is a client for the OpenStack Keystone API. There's a Python API (the
``keystoneclient`` module), and a command-line script (``keystone``). The
Keystone 2.0 API is still a moving target, so this module will remain in
"Beta" status until the API is finalized and fully implemented.

Development takes place on GitHub__. Bug reports and patches may be filed there.

__ https://github.com/4P/python-keystoneclient

This code a fork of `Rackspace's python-novaclient`__ which is in turn a fork of
`Jacobian's python-cloudservers`__. The python-keystoneclient is licensed under
the Apache License like the rest of OpenStack.

__ http://github.com/rackspace/python-novaclient
__ http://github.com/jacobian/python-cloudservers

.. contents:: Contents:
   :local:

Python API
----------

By way of a quick-start::

    # use v2.0 auth with http://example.com:5000/v2.0")
    >>> from keystoneclient.v2_0 import client
    >>> keystone = client.Client(username=USERNAME, password=PASSWORD, tenant_name=TENANT, auth_url=KEYSTONE_URL)
    >>> keystone.tenants.list()
    >>> tenant = keystone.tenants.create(name="test", descrption="My new tenant!", enabled=True)
    >>> tenant.delete()


Command-line API
----------------

.. attention:: COMING SOON

    The CLI is not yet implemented, but will follow the pattern laid
    out below.

Installing this package gets you a shell command, ``keystone``, that you
can use to interact with Keystone's API.

You'll need to provide your OpenStack username and API key. You can do this
with the ``--username``, ``--apikey`` and  ``--projectid`` params, but it's
easier to just set them as environment variables::

    export OS_TENANT_NAME=project
    export OS_USERNAME=user
    export OS_PASSWORD=pass

You will also need to define the authentication url with ``--url`` and the
version of the API with ``--version``.  Or set them as an environment
variables as well::

    export OS_AUTH_URL=http://example.com:5000/v2.0
    export KEYSTONE_ADMIN_URL=http://example.com:35357/v2.0

Since Keystone can return multiple regions in the Service Catalog, you
can specify the one you want with ``--region_name`` (or
``export KEYSTONE_REGION_NAME``). It defaults to the first in the list returned.

You'll find complete documentation on the shell by running
``keystone help``::

    usage: keystone [--username user] [--password password] 
                    [--tenant_name tenant] [--auth_url URL]
                   <subcommand> ...

    Command-line interface to the OpenStack Keystone API.

    Positional arguments:
      <subcommand>
        add-fixed-ip        Add a new fixed IP address to a servers network.


    Optional arguments:
      --username USER            Defaults to env[OS_USERNAME].
      --password PASSWORD        Defaults to env[OS_PASSWORD].
      --tenant_name TENANT_NAME  Defaults to env[OS_TENANT_NAME].
      --tenant_id TENANT_ID      Defaults to env[OS_TENANT_ID].
      --url AUTH_URL             Defaults to env[OS_AUTH_URL] or
      --version VERSION          Defaults to env[KEYSTONE_VERSION] or 2.0.
      --region_name NAME         The region name in the Keystone Service 
                                 Catalog to use after authentication. 
                                 Defaults to env[KEYSTONE_REGION_NAME] or the
                                 first item in the list returned.

    See "keystone help COMMAND" for help on a specific command.