Skip to main content

OpenStack Indexing and Search API Client Library

Project description

Team and repository tags

https://governance.openstack.org/tc/badges/python-searchlightclient.svg

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 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.

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

Setup the client from source

  • Clone repository for python-searchlightclient:

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

$ 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
  • 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/'
$ 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 py27 - traditional unit testing

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python-searchlightclient-1.3.0.tar.gz (38.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_searchlightclient-1.3.0-py2.py3-none-any.whl (44.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file python-searchlightclient-1.3.0.tar.gz.

File metadata

File hashes

Hashes for python-searchlightclient-1.3.0.tar.gz
Algorithm Hash digest
SHA256 48ac7ce00a878e80e426e138fe5562552435f4f63979f15964657c08ed034917
MD5 e5d4ba1b5ce7e8084e424d246220ccab
BLAKE2b-256 bda76572a008e3cfc2dc4bb012848a3b9e6c023f85663aaa7ea9e74ba9fb0ce3

See more details on using hashes here.

File details

Details for the file python_searchlightclient-1.3.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for python_searchlightclient-1.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ebad52aa8ad4809a04a61c262311258f49b7bc071d5ae15e6977942750baede3
MD5 90c2747b68e7b0248cba2c41ba7bb53e
BLAKE2b-256 8e20b0f4a920ebe9b1e0ecae43487766291ae10def0387eec396a630b8dd56aa

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page