This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (pypi.python.org).
Help us improve Python packaging - Donate today!

Elasticsearch integration with asyncio.

Project Description

aioes is a asyncio compatible library for working with Elasticsearch

Documentation

Read aioes documentation on Read The Docs: http://aioes.readthedocs.io/

Example

import asyncio
from aioes import Elasticsearch

@asyncio.coroutine
def go():
    es = Elasticsearch(['localhost:9200'])
    ret = yield from es.create(index="my-index",
                               doc_type="test-type",
                               id=42,
                               body={"str": "data",
                                     "int": 1})
    assert (ret == {'_id': '42',
                    '_index': 'my-index',
                    '_type': 'test-type',
                    '_version': 1,
                    'ok': True})

    answer = yield from es.get(index="my-index",
                               doc_type="test-type",
                               id=42)
    assert answer['_source'] == {'str': 'data', 'int': 1}

loop = asyncio.get_event_loop()
loop.run_until_complete(go())

Requirements

Tests

Make sure you have an instance of Elasticsearch running on port 9200 before executing the tests.

In order for all tests to work you need to add the following lines in the config/elasticsearch.yml configuration file:

Enable groovy scripts:

script.groovy.sandbox.enabled: true

Set a repository path:

path.repo: ["/tmp"]

The test suite uses py.test, simply run:

$ py.test

License

aioes is offered under the BSD license.

CHANGES

0.7.2 (2017-04-19)

  • Allow custom Connector in Transport: #138, #137.
  • Several typos in documentation fixed.

0.7.0 (2017-03-29)

  • Fix Elasticsearch 5.x compatibility issues: #48, #72, #112, #73, #123.
  • Add stored_fields to mget, search and explain methods (#123).
  • Add wait_for_no_relocating_shards parameter in health (#123).
  • Add filter, token_filter, char_filter params in analyze (#123).
  • Add force_merge method (renamed optimize) (#123).
  • Add ignore_idle_threads param in hot_threads #123.
  • Update project dependencies.
  • Convert tests to pytest.

0.6.1 (2016-09-08)

  • Accept bytes as payload #42
  • Convert Elasticsearch.close() into a coroutine.

0.6.0 (2016-09-08)

  • Add support for verify_ssl #43

0.5.0 (2016-07-16)

  • Allow scheme, username and password in connections #40

0.4.0 (2016-02-10)

  • Fix ES2+ compatibility in transport address regex #38

0.3.0 (2016-01-27)

  • Use aiohttp.ClientSession internally #36

0.2.0 (2015-10-08)

  • Make compatible with Elasticsearch 1.7
  • Support Python 3.5
  • Drop Python 3.3 support
  • Relicense under Apache 2

0.1.0 (2014-10-04)

  • Initial release
Release History

Release History

This version
History Node

0.7.2

History Node

0.7.0

History Node

0.6.1

History Node

0.6.0

History Node

0.5.0

History Node

0.4.0

History Node

0.3.0

History Node

0.2.0

History Node

0.1.0

Download Files

Download Files

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

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
aioes-0.7.2-py3-none-any.whl (31.7 kB) Copy SHA256 Checksum SHA256 py3 Wheel Apr 19, 2017
aioes-0.7.2.tar.gz (65.2 kB) Copy SHA256 Checksum SHA256 Source Apr 19, 2017

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting