Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/elastic/workplace-search-python

Elastic Workplace Search Official Python Client
https://github.com/elastic/workplace-search-python

api-client elastic elastic-enterprise-search elastic-workplace-search python python-client search swiftype

Last synced: 3 months ago
JSON representation

Elastic Workplace Search Official Python Client

Awesome Lists containing this project

README

        

> **⚠️ This client is deprecated ⚠️**
>
> As of Enterprise Search version 7.10.0, we are directing users to the new [Enterprise Search Python Client](https://github.com/elastic/enterprise-search-python) and
> deprecating this client.
>
> This client will be compatible with all Enterprise Search 7.x releases, but will not be compatible with 8.x releases. Our development effort on this project will
> be limited to bug fixes. All future enhancements will be focused on the Enterprise Search Python Client.
>
> Thank you! - Elastic

GitHub Actions

> A first-party Python client for [Elastic Workplace Search](https://www.elastic.co/workplace-search).

## Contents

+ [Getting started](#getting-started-)
+ [Usage](#usage)
+ [FAQ](#faq-)
+ [Contribute](#contribute-)
+ [License](#license-)

***

## Getting started 🐣

Supports Python 2.7 and Python 3.4+.

Installed with
`pip `:

```bash
$ python -m pip install elastic_workplace_search
```

You can also download and install the project source:

```bash
$ python setup.py install
```

Depends on [requests](https://github.com/requests/requests) for making HTTP requests.

## Usage

### Creating a new Client

```python
from elastic_workplace_search import Client
authorization_token = 'authorization token'
client = Client(authorization_token)
```

Retrieve your access token and a content source key after creating your content source.

### Change API endpoint

```python
client = Client(authorization_token, "https://your-server.example.com/api/ws/v1")
```

### Custom Source Documents

Document API features are found in the `client.documents` module.

#### Indexing Documents

Indexing a document into a custom content source:

```python
content_source_key = 'content source key'
documents = [
{
'id': '1234',
'url': 'https://github.com/elastic/workplace-search-python',
'title': 'Elastic Workplace Search Official Python Client',
'body': 'A descriptive body, with document contents and metadata'
}
]

client.documents.index_documents(content_source_key, documents)
```

#### Deleting Documents

Deleting a document from a custom content source:

```python
content_source_key = 'content source key'
ids = ['1234']

client.documents.delete_documents(content_source_key, ids)
```

### Permissions

Permissions API features are found in the `client.permissions` module.

#### Listing all permissions

```python
content_source_key = 'content source key'

client.permissions.list_all_permissions(content_source_key)
```

#### Listing all permissions with paging

```python
content_source_key = 'content source key'

client.permissions.list_all_permissions(content_source_key, size=20, current=2)
```

#### Retrieve a User's permissions

```python
content_source_key = 'content source key'
user = 'enterprise_search'

client.permissions.get_user_permissions(content_source_key, user)
```

#### Add permissions to a User

```python
content_source_key = 'content source key'
user = 'enterprise_search'
permissions = ['permission1']

client.permissions.add_user_permissions(content_source_key, 'enterprise_search', { 'permissions': permissions })
```

#### Update a User's permissions

```python
content_source_key = 'content source key'
user = 'enterprise_search'
permissions = ['permission2']

client.permissions.update_user_permissions(content_source_key, 'enterprise_search', { 'permissions': permissions })
```

#### Remove permissions from a User

```python
content_source_key = 'content source key'
user = 'enterprise_search'
permissions = ['permission2']

client.permissions.remove_user_permissions(content_source_key, 'enterprise_search', { 'permissions': permissions })
```

## FAQ 🔮

### Where do I report issues with the client?

If something is not working as expected, please open an [issue](https://github.com/elastic/workplace-search-python/issues/new).

## Contribute 🚀

We welcome contributors to the project. Before you begin, a couple notes...

+ Before opening a pull request, please create an issue to [discuss the scope of your proposal](https://github.com/elastic/workplace-search-python/issues).
+ Please write simple code and concise documentation, when appropriate.

## License 📗

[Apache 2.0](https://github.com/elastic/workplace-search-python/blob/master/LICENSE.txt) © [Elastic](https://github.com/elastic)

Thank you to all the [contributors](https://github.com/elastic/workplace-search-python/graphs/contributors)!