Metadata-Version: 2.1
Name: PyNuclino
Version: 0.2.1
Summary: Nuclino API wrapper
Home-page: https://github.com/Vanderhoof/PyNuclino
Author: Daniel Minukhin
Author-email: ddddsa@gmail.com
License: MIT
Platform: any
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Topic :: Documentation
Classifier: Topic :: Text Processing :: Markup
Classifier: Topic :: Utilities
Requires-Python: >=3.7
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: ratelimit
Requires-Dist: requests

[![](https://img.shields.io/pypi/v/pynuclino.svg)](https://pypi.org/project/pynuclino/) [![](https://img.shields.io/pypi/dm/pynuclino.svg)](https://pypi.org/project/pynuclino/)  [![](https://img.shields.io/github/v/tag/Vanderhoof/pynuclino.svg?label=GitHub)](https://github.com/Vanderhoof/PyNuclino)

# PyNuclino

PyNuclino is a Python client for [Nuclino API](https://help.nuclino.com/d3a29686-api).

## Installation

```bash
pip3 install pynuclino
```

## Usage

Initialize the `Nuclino` object with your API key ([getting API key](https://help.nuclino.com/04598850-manage-api-keys)):

```python
>>> from nuclino import Nuclino
>>> client = Nuclino('your-api-key')
```

Get some data:

```python
>>> client.get_workspaces()
[<Workspace "Support">, <Workspace "Projects">, ...]
>>> client.get_teams()
[<Team "MyTeam">, <Team "TheirTeam">]
>>> client.get_items(team_id='your_team_id')
[<Item "Home office allowance">, <Collection "Leave">, <Item "Welcome!">, ...]
```

Objects have attributes:

```python
>>> item = client.get_item('item_id')
>>> i1.title
'Home office allowance'
>>> i1.created_at
'2022-01-26T16:32:41.981Z'
```

Attribute names correspond to the JSON field names, but in Python variable format: `createdAt` -> `created_at`.

Objects also have convenience methods:

```python
>>> team.get_workspaces()
[<Workspace "Support">, <Workspace "Projects">, ...]
>>> workspace.get_children()
[<Collection "Product FAQ">, <Collection "Canned responses">, ...]
>>> item.get_files()
[<file "6e54474a.png">, <file "c414f936.png">, ...]
```

You can update or delete items using Item object methods:

```python
>>> item = client.get_item('item_id')
>>> item.update(title='New Title', content='# New content\n')
<Item "New Title">
>>> item.delete()
{'id': 'fe94a28d-6c5c-4969-9ee7-7d6433f74adf'}
```

Full reference of methods and attributes is below.

## Rate limiting

Nuclino API usage is currently [rate limited](https://help.nuclino.com/b147124e-rate-limiting) to 150 requests per minute. PyNuclino uses [ratelimit](https://github.com/tomasbasham/ratelimit) library to handle rate limiting.

Default request limit is set to 140 req/min. To change it, set the `requests_per_minute` init parameter:

```python
>>> client = Nuclino('your-api-key', requests_per_minute=100)
```

## Reference

### Nuclino

`Nuclino(api_key, base_url, requests_per_minute)`


Nuclino is the main object that connects you to Nuclino API.

Initialization parameters:

* `api_key` (string, required) — your personal API key ([how to get an API key](https://help.nuclino.com/04598850-manage-api-keys)).
* `base_url` (string, optional) — base url for Nuclino API calls. Default: `https://api.nuclino.com/v0`.
* `requests_per_minute` (int, optional) — number of requests the client will allow sending per minute. If this limit is exceeded, the client will wait for some time before sending the next request. Default: `140`.

**Methods**

`get_user(user_id)`

Get a user by ID. Returns a single User object.

`get_teams(limit=None, after=None)`

List teams that you have access to. Returns list of Team objects.

`get_team(team_id)`

Get a team by ID. Returns a single Team object.

`get_workspaces(limit=None, after=None)`

List workspaces that you have access to. Returns list of Workspace objects.

`get_workspace(team_id)`

Get a workspace by ID. Returns a single Workspace object.

`get_items(team_id=None, workspace_id=None, limit=None, after=None, search=None)`

Get list of items in team or workspace. You must supply either `team_id` or `workspace_id`. Add search query in `search` parameter to search items. Returns list of Item and Collection objects.

`get_item(item_id)`

Get item or collection by ID. Returns a single Item or Collection object.

`get_collection(collection_id)`

Alias for `get_item` method, works the same.

`create_item(workspace_id=None, parent_id=None, object='item', title=None, content=None, index=None)`

Create a new item or collection (depending on the `object` param value). You must supply either `workspace_id` or `parent_id`.

`create_collection(workspace_id=None, parent_id=None, title=None, index=None)`

Create a new collection. You must supply either `workspace_id` or `parent_id`.

`update_item(item_id, title=None, content=None)`

Update item or collection. If `title` or `content` is none, it won't be changed.

`update_collection(collection_id, title=None)`

Update collection title.

`delete_title(item_id)`

Delete item or collection.

`delete_collection(collection_id)`

Alias for `delete_item` method, works the same.

`get_file(file_id)`

Get a file by ID. Returns a single File instance.

### User

**Atrributes**

* `id` (str) — user ID,
* `first_name` (str) — user's first name,
* `last_name` (str) — user's last name,
* `email` (str) — user's email address 
* `avatar_url` Optional(str) — URL address of the user's avatar image. None if the user has not set an avatar. 

### Team

**Attributes**

* `id` (str) — team ID,
* `url` (str) — team url,
* `name` (str) — team name,
* `created_at` (str) — date created in ISO 8601 format,
* `created_user_id` (str) — ID of the user who created this team.

**Methods**

`get_workspaces()`

Make an API call to get list of workspaces this team has.

### Workspace

**Attrubutes**

* `id` (str) — workspace ID,
* `team_id` (str) — ID of the team this workspace belongs to,
* `name` (str) — workspace name,
* `created_at` (str) — date created in ISO 8601 format,
* `created_user_id` (str) — ID of the user who created this workspace,
* `child_ids` (list) — list of IDs of top level items and collections from this workspace.

**Methods**

`get_team()`

Make an API call to get the team this workspace belongs to.

`get_children()`

Make API calls to get a list of top level items and collections from this workspace. Returns list of Item and Collection objects.

`create_item(object='item', title=None, content=None, index=None)`

Create an item or a collection (depending on the `object` param) in this workspace.

`create_collection(title=None, index=None)`

Create a collection in this workspace.

### Collection

**Attributes**

* `id` (str) — collection ID,
* `child_ids` (list) — list of IDs of items or collections that belong to this collection (only top level),
* `created_at` (str) — date created in ISO 8601 format,
* `created_user_id` (str) — ID of the user who created the collection,
* `last_updated_at` (str) — date last update in ISO 8601 format,
* `last_updated_user_id` (str) — ID of the user who last updated the collection,
* `title` (str) — collection title,
* `url` (str) — collection url,
* `workspace_id` (str) — ID of the workspace this collection belongs to.

**Methods**

`get_children()`

Make API calls to get list of items and collections that belong to this collection (only top level). Returns list of Item and Collection objects.

`get_workspace()`

Make an API call to get the workspace this collection belongs to.

`create_item(object='item', title=None, content=None, index=None)`

Create an item or a collection (depending on the `object` param) under this collection.

`create_collection(title=None, index=None)`

Create a collection under this collection.

`delete()`

Delete this collection.

`update(title)`

Update this collection title.

### Item

* `id` (str) — item ID,
* `content_meta` (dict) — item meta dictionary,
* `created_at` (str) — date created in ISO 8601 format,
* `created_user_id` (str) — ID of the user who created the item,
* `last_updated_at` (str) — date updated in ISO 8601 format,
* `last_updated_user_id` (str) — ID of the user who last updated the item,
* `title` (str) — item title,
* `url` (str) — item url,
* `workspace_id` (str) — ID of the workspace this item belongs to,
* `content` (str) — item content in Markdown (to get content use `get_item`, not `get_items`).

**Methods**

`get_workspace()`

Make an API call to get the workspace this item belongs to.

`get_items()`

Make API calls to get list of items that are referenced inside this item. Returns list of Item objects.

`get_files()`

Make API calls to get list of files that are attached to this item. Returns list of File objects.

`delete()`

Delete this item.

`update(title: None, content: None)`

Update this item. Title or content won't be changed if the corresponding param is empty.

### File

**Attributes**

* `id` (str) — file ID,
* `item_id` (str) — ID of the item this file is attached to,
* `file_name` (str) — file name,
* `created_at` (str) — date created in ISO 8601 format,
* `created_user_id` (str) — ID of the user who created the file,
* `download` (dict) — dictionary with download link and expiry date.

**Methods**

`get_item()`

Make an API call to get the item this file is attached to.
