RETIRED, OpenStack Search (Searchlight) Client
Go to file
OpenStack Proposal Bot 3c164de493 Updated from global requirements
Change-Id: I832901d481277e5cd575eebdddddf00554967a50
2016-01-21 17:47:26 +00:00
doc Update link to CLI Reference 2016-01-16 17:46:56 +01:00
searchlightclient Add facet list support 2015-12-05 07:15:26 +08:00
tools Init searchlightclient base 2015-11-28 16:40:16 +08:00
.gitignore Init searchlightclient base 2015-11-28 16:40:16 +08:00
.gitreview Added .gitreview 2015-11-19 10:13:03 +00:00
.testr.conf Init searchlightclient base 2015-11-28 16:40:16 +08:00
CONTRIBUTING.rst Init searchlightclient base 2015-11-28 16:40:16 +08:00
LICENSE Init searchlightclient base 2015-11-28 16:40:16 +08:00
MANIFEST.in Init searchlightclient base 2015-11-28 16:40:16 +08:00
README.rst Add resource type list CLI 2015-12-05 07:15:05 +08:00
babel.cfg Init searchlightclient base 2015-11-28 16:40:16 +08:00
openstack-common.conf Init searchlightclient base 2015-11-28 16:40:16 +08:00
requirements.txt Updated from global requirements 2016-01-21 17:47:26 +00:00
setup.cfg Add facet list support 2015-12-05 07:15:26 +08:00
setup.py Init searchlightclient base 2015-11-28 16:40:16 +08:00
test-requirements.txt Updated from global requirements 2016-01-19 13:52:56 +00:00
tox.ini Delete python bytecode before every test run 2016-01-10 16:21:58 +08:00

README.rst

python-searchlightclient

OpenStack Indexing and Search API Client Library

This is a client library for Searchlight built on the Searchlight API. It provides a Python API (the searchlightclient module) and a command-line tool (searchlight).

The project is hosted on Launchpad, where bugs can be filed. The code is hosted on Github. Patches must be submitted using Gerrit, not Github pull requests.

python-searchlightclient is licensed under the Apache License like the rest of OpenStack.

Contents:

Command-line API

To execute CLI commands to standalone searchlight set with keystone.

  • Clone repository for python-searchlightclient:

    $ git clone https://github.com/openstack/python-searchlightclient.git
    $ cd python-searchlightclient
  • Setup a virtualenv

Note

This is an optional step, but will allow Searchlightclient's dependencies to be installed in a contained environment that can be easily deleted if you choose to start over or uninstall Searchlightclient.

$ tox -evenv --notest

Activate the virtual environment whenever you want to work in it. All further commands in this section should be run with the venv active:

$ source .tox/venv/bin/activate

Note

When ALL steps are complete, deactivate the virtualenv: $ deactivate

  • Install Searchlightclient and its dependencies:

    (venv) $ python setup.py develop
  • To execute CLI commands:

    $ export OS_USERNAME=<user>
    $ export OS_PASSWORD=<password>
    $ export OS_TENANT_NAME=<project>
    $ export OS_AUTH_URL='http://localhost:5000/v2.0/'

Note

With devstack you just need to $ source openrc <user> <project>

$ openstack
(openstack) search resource-type list
+--------------------------+--------------------------+
| Name                     | Type                     |
+--------------------------+--------------------------+
| OS::Designate::RecordSet | OS::Designate::RecordSet |
| OS::Designate::Zone      | OS::Designate::Zone      |
| OS::Glance::Image        | OS::Glance::Image        |
| OS::Glance::Metadef      | OS::Glance::Metadef      |
| OS::Nova::Server         | OS::Nova::Server         |
+--------------------------+--------------------------+

Python API

To use with keystone as the authentication system:

>>> from keystoneclient.auth.identity import generic
>>> from keystoneclient import session
>>> from searchlightclient import client
>>> auth = generic.Password(auth_url=OS_AUTH_URL, username=OS_USERNAME, password=OS_PASSWORD, tenant_name=OS_TENANT_NAME)
>>> keystone_session = session.Session(auth=auth)
>>> sc = client.Client('1', session=keystone_session)
>>> sc.resource_types.list()
[...]

Testing

There are multiple test targets that can be run to validate the code.

  • tox -e pep8 - style guidelines enforcement
  • tox -e py27 - traditional unit testing