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

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://opendev.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 with python 2.7

  • tox -e py36 - traditional unit testing with python 3.6

  • tox -e py37 - traditional unit testing with python 3.7

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.6.0.tar.gz (39.8 kB view details)

Uploaded Source

Built Distribution

python_searchlightclient-1.6.0-py2.py3-none-any.whl (45.8 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: python-searchlightclient-1.6.0.tar.gz
  • Upload date:
  • Size: 39.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.5.2

File hashes

Hashes for python-searchlightclient-1.6.0.tar.gz
Algorithm Hash digest
SHA256 c365a994626a40d0ae7fb77a0c989d95af4445ad2e030a1bc8bb14e9f03bd56d
MD5 223a96a41c251724cb6561650ef4d460
BLAKE2b-256 0f0a7533b15a6fc51523e76febda5c5cf240f11df48cd05205ccec78d64d0b81

See more details on using hashes here.

Provenance

File details

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

File metadata

  • Download URL: python_searchlightclient-1.6.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 45.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.5.2

File hashes

Hashes for python_searchlightclient-1.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 3f4553f35990a094bed79f6c4818e09ed7ca63f07bc03d1c4d14d2840b885129
MD5 e2ad7b13453bb0e44e00f7b93a0ea43a
BLAKE2b-256 27dbbc2308b73b4016eb896da3fc43b79c4ac926072520bb26c23734ae8382ff

See more details on using hashes here.

Provenance

Supported by

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