Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lazeroffmichael/ticktick-py
Unofficial TickTick API
https://github.com/lazeroffmichael/ticktick-py
Last synced: 4 months ago
JSON representation
Unofficial TickTick API
- Host: GitHub
- URL: https://github.com/lazeroffmichael/ticktick-py
- Owner: lazeroffmichael
- License: mit
- Created: 2020-12-09T06:33:49.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-03-21T06:40:21.000Z (11 months ago)
- Last Synced: 2024-10-01T02:58:23.902Z (5 months ago)
- Language: Python
- Homepage: https://lazeroffmichael.github.io/ticktick-py/
- Size: 4.36 MB
- Stars: 211
- Watchers: 11
- Forks: 30
- Open Issues: 31
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/29216/29216a30592643f0894a2e1740ef756a254e4e2b" alt="unit-tests"
[data:image/s3,"s3://crabby-images/4655d/4655d1d40573d24bccf26111967c0ca4d629f321" alt="documentation"](https://lazeroffmichael.github.io/ticktick-py/)# ticktick-py
## Unofficial TickTick API Client for Python 3## [Full Documentation](https://lazeroffmichael.github.io/ticktick-py/)
## Description
`ticktick-py` is an unofficial API library for interacting with [TickTick.com]().
It allows
users a way to interact with their [TickTick]() account
using [Python](https://www.python.org/).## Features
The library automatically fetches all the tasks, tags, lists, and more linked to your profile and stores them in a
dictionary named [`state`](docs/usage/api.md).- [Tasks](docs/usage/tasks.md)
- Create, Update, and Delete Tasks
- Acquire all your uncompleted tasks
- Move tasks easily between projects
- Acquire all completed tasks in a certain date range
- [Tags](docs/usage/tags.md)
- Batch create, update, and delete tags
- Create tags with parameters that are not usually allowed: `\\ / " # : * ? < > | Space`
- [Projects](docs/usage/projects.md)
- Batch create, update, and delete 'lists' (projects)
- Batch archive projects### Example: Creating A Task
Lets create a task in our ```inbox``` titled "Get Groceries"
``` python
name = 'Get Groceries' # Task Name
local_task = client.task.builder(name) # Create a dictionary for the task
groceries = client.task.create(local_task) # Actually create the task
```### Result
A simplified dictionary for the newly created task is returned.
```python
print(groceries){'id': '60c6a40b8f083f896c9444a0', 'projectId': 'inbox115781412', 'title': 'Get Groceries', 'timeZone': '',
'reminders': [], 'priority': 0, 'status': 0, 'sortOrder': -3298534883328, 'items': []}
```
You can retrieve the full dictionary with every parameter by using the `get_by_id` method.```python
full_task = client.get_by_id(groceries['id'])
print(full_task){'id': '60c6a40b8f083f896c9444a0', 'projectId': 'inbox115781412', 'sortOrder': -3298534883328,
'title': 'Get Groceries', 'timeZone': '', 'isFloating': False, 'reminder': '', 'reminders': [],
'priority': 0, 'status': 0, 'items': [], 'modifiedTime': '2021-06-14T00:34:19.907+0000', 'etag': 't8xnwewi',
'deleted': 0, 'createdTime': '2021-06-14T00:34:19.907+0000', 'creator': 113581412, 'tags': [], 'kind': 'TEXT'}
```**Created Task In `TickTick`**
data:image/s3,"s3://crabby-images/53899/53899ac4ab95dedbc87b5435781dc67d7d00a7c6" alt="image"
Most methods will return the object that was changed. Consult the [usage](docs/usage/api.md) documentation for more information on specific methods.
## InstallationNote: `ticktick-py` requires [Python 3.6](https://www.python.org/downloads/) or above.
```md
pip install ticktick-py
```## Get Started
### Register A New TickTick App
The library now uses TickTick's OpenAPI scheme when possible. This requires registering
a new app through TickTick's developer documentation.[OpenAPI Documentation](https://developer.ticktick.com/docs#/openapi)
Click on `Manage Apps` in the top right corner. You will be prompted to login with your
normal TickTick credentials if you are not already logged in.data:image/s3,"s3://crabby-images/d0d14/d0d1456bb071ba908e054ec6305f248ec9066658" alt="image"
Register a new app by clicking the `+App Name` button.
data:image/s3,"s3://crabby-images/7a5b7/7a5b7db766bb6546038cf01d30c77b016f0d56f2" alt="image"
`Name` is the only required parameter here. Once created you should see the app and be able to edit it.
data:image/s3,"s3://crabby-images/f3e96/f3e962c28105cb366b2ff3a306c855e068cfc532" alt="image"
There should now be a generated `Client ID` and `Client Secret` parameters. It is recommended you save these to your
environment, and make sure you do not share your actual `Client Secret`.data:image/s3,"s3://crabby-images/7b87c/7b87cf43e8e1190b0c763713036ab357b66281ba" alt="image"
For `OAuth Redirect URL` enter any URL you would like to be redirected to upon giving permissions to your account.
It does not have to be an actually live URL - this local host URL is fine for most purposes. It is also recommended you
save this URL to your environment.data:image/s3,"s3://crabby-images/b03a8/b03a8eddd3a2911860af7856012679605aab7da3" alt="image"
Once you have registered the app, you can now proceed with the rest of the setup.
### Required Imports
``` python
from ticktick.oauth2 import OAuth2 # OAuth2 Manager
from ticktick.api import TickTickClient # Main Interface
```### Setup
``` python
auth_client = OAuth2(client_id=client_id,
client_secret=client_secret,
redirect_uri=uri)client = TickTickClient(username, password, auth_client)
```The first time the OAuth2 object runs, you will need to manually accept permissions. A webbrowser will automatically
open.data:image/s3,"s3://crabby-images/afc62/afc62e1f6e5a83b6593b0baeffe85f50a1f8abe2" alt="image"
The default permissions are to Read and Write tasks (and are the only options right now). You can change the permissions
by specifying the `scope` parameter when creating your OAuth2 instance. More information can be found in the
[OAuth2 documention](docs/usage/oauth2.md).In the console you will be prompted to enter the URL that you were redirected to. It will be your specified OAuth URL
with some added parameters.```
Enter the URL you were redirected to:
>? http://127.0.0.1:8080/?code=RK3dSi&state=None
```That is it! Your token information is cached in a file (default is `.token-oauth`) so you will only have to manually
allow access the first time, and whenever the token expires. As of now it seems tokens expire after about 6 months.## Future Plans
- **General**
- Enhanced Team Support
- **Tasks**
- Get and Restore From Trash
- **Projects**
- Smart List Support
- Column Creation For Kanban View
- **Pomo and Focus**
- Getting the focus / pomo statistics for your profile
- Starting and stopping the focus / pomo timer
- **Habits**
- Get, create, archive, delete, and complete habits