e8328fd7c2
Slashes (/) in query strings are treated by Elasticsearch as delimiting a regexp expression. This is confusing especially when operating on swift object paths, and in general we feel that in general the confusion caused by mismatched slashes isn't offset by the ability to use regexps. If a user really needs to run a regexp they can use the query dsl; we could also consider adding a flag later. Change-Id: I892541820b077d8eb08ae635a843d8dc84a5f55a Closes-Bug: #1551946 |
||
---|---|---|
doc | ||
searchlightclient | ||
tools | ||
.gitignore | ||
.gitreview | ||
.testr.conf | ||
CONTRIBUTING.rst | ||
LICENSE | ||
MANIFEST.in | ||
README.rst | ||
babel.cfg | ||
openstack-common.conf | ||
requirements.txt | ||
setup.cfg | ||
setup.py | ||
test-requirements.txt | ||
tox.ini |
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()
[...]
- License: Apache License, Version 2.0
- Documentation: http://docs.openstack.org/developer/python-searchlightclient
- Source: http://git.openstack.org/cgit/openstack/python-searchlightclient
- Bugs: http://bugs.launchpad.net/python-searchlightclient
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