RETIRED, OpenStack Search (Searchlight) Client
Go to file
Ghanshyam Mann d307e8e6ed [ussuri][goal] Drop python 2.7 support and testing
OpenStack is dropping the py2.7 support in ussuri cycle.

python-searchlightsclient is ready with python 3 and ok to drop the
python 2.7 support.

Complete discussion & schedule can be found in
- http://lists.openstack.org/pipermail/openstack-discuss/2019-October/010142.html
- https://etherpad.openstack.org/p/drop-python2-support

Ussuri Communtiy-wide goal:
https://governance.openstack.org/tc/goals/selected/ussuri/drop-py27.html

Change-Id: I37810f2e78523388a70cad0034f8d4d9e73e218b
2020-01-22 02:36:31 +00:00
doc [ussuri][goal] Drop python 2.7 support and testing 2020-01-22 02:36:31 +00:00
releasenotes/notes [ussuri][goal] Drop python 2.7 support and testing 2020-01-22 02:36:31 +00:00
searchlightclient Remove _LE variable 2019-09-26 23:06:07 +09:00
tools Avoid tox_install.sh for constraints support 2017-12-02 16:58:32 +00:00
.gitignore Switch to stestr 2018-07-09 18:10:37 +07:00
.gitreview OpenDev Migration Patch 2019-04-19 19:34:24 +00:00
.stestr.conf Switch to stestr 2018-07-09 18:10:37 +07:00
.zuul.yaml [ussuri][goal] Drop python 2.7 support and testing 2020-01-22 02:36:31 +00:00
CONTRIBUTING.rst Update storyboard links 2019-03-18 12:22:55 +09:00
LICENSE Init searchlightclient base 2015-11-28 16:40:16 +08:00
README.rst [ussuri][goal] Drop python 2.7 support and testing 2020-01-22 02:36:31 +00:00
babel.cfg Init searchlightclient base 2015-11-28 16:40:16 +08:00
lower-constraints.txt tox: Keeping going with docs 2019-10-24 20:09:55 +08:00
requirements.txt Updated from global requirements 2018-09-01 14:52:22 +09:00
setup.cfg [ussuri][goal] Drop python 2.7 support and testing 2020-01-22 02:36:31 +00:00
setup.py Updated from global requirements 2017-05-23 12:00:04 +00:00
test-requirements.txt Update hacking version 2018-12-29 09:54:02 +08:00
tox.ini [ussuri][goal] Drop python 2.7 support and testing 2020-01-22 02:36:31 +00:00

README.rst

Team and repository tags

image

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 Storyboard, where bugs can be filed. The code is hosted on OpenStack git repository. Patches must be submitted using Gerrit, not git repo pull requests.

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

Contents:

Install the client from PyPI

The program python-searchlightclient package is published on PyPI and so can be installed using the pip tool, which will manage installing all python dependencies:

$ pip install python-searchlightclient

Note

The packages on PyPI may lag behind the git repo in functionality.

Setup the client from source

  • Clone repository for python-searchlightclient:

    $ git clone https://opendev.org/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

Command-line API

Set Keystone environment variables to execute CLI commands against searchlight.

  • 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>. And you can work with a local installation by passing --os-token <TOKEN> and --os-url http://localhost:9393. You can also set up a Openstackclient config file to work with the CLI.

$ 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         |
+--------------------------+--------------------------+

Here are the full list of subcommands, Use -h to see options:

Subcommand Description
search facet list List Searchlight Facet
search resource type list List Searchlight Resource Type (Plugin)
search query Search Searchlight resource

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 py36 - traditional unit testing with python 3.6
  • tox -e py37 - traditional unit testing with python 3.7