wren-tools


Namewren-tools JSON
Version 0.4.1 PyPI version JSON
download
home_pageNone
SummaryThe simplest task management system with the most advanced features
upload_time2025-01-06 12:48:50
maintainerNone
docs_urlNone
authorNone
requires_python>=3.11
licenseNone
keywords note taking todo to do task management
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <h1 align="center">
Wren
</h1>

<p align="center">
a note taking application and a to-do management system that is ridiculously simple, yet very advanced.
</p>
<p align="center">
<img src="https://github.com/bjesus/knowts/assets/55081/ab1f5584-267c-45da-b7bd-96fb38c66143" height="200">
</p>

Wren is simple because every note is one file. The filename is the title, and the content is the note's content. This makes it very easy to sync tasks between devices, as conflicts can almost never happen, even if syncing isn't done real time. The files are plain text, so you can just write. If you want a task to repeat every Saturday you just prefix it with a cron syntax, e.g. `0 8 * * 6 weekly swim`, and if you want a task to appear from a specific time you just start it with the date, like `2030-01-01 check if Wren became super popular`.

Wren is advanced because it is very extensible - it comes (optionally!) with a Telegram bot that you can chat with to manage your notes, a Matrix bot, and even get AI-driven daily summaries as if you had a personal assistant. It also includes a tiny HTTP server that you can use to manage tasks using an API or from the browser, which can be used for displaying you tasks elsewhere (e.g. in your e-reader).

https://github.com/bjesus/wren/assets/55081/0deff819-ab30-4a64-a4db-5e9a29179309

## Installation

The easiest way to install Wren is with pip:

```
$ pip install wren-notes
```

To install with all optional dependencies:
```
$ pip install "wren-notes[telegram,http]"
```

## Usage

The management of tasks in Wren is simple:
- Tasks are just files living your `notes` folder. You might as well create them with `touch task` and edit them with `vim task`.
- Completed tasks are moved to your `done` folder.
- Tasks starting with a YYYY-MM-DD will not appear in the list of tasks before their time arrived.
- Tasks starting with a cron signature will not be moved when completed. Instead they'll be copied to the `done` directory, and will reappear automatically when the copied file is old enough.

### Command line

The regular usage mode Wren is the command line. For the following examples, `n` is my alias to `wren`, but you can use any alias or just call `wren` directly. Normal tasks can be created by just typing them
```
$ n build a spaceship
created task: build a spaceship

$ n go to the moon
created task: go to the moon

$ n 'discuss galaxy peace with aliens
tell them that we won't hurt them
and that we can probably reach some agreement'
created task: discuss galaxy peace with aliens
```

Reading a task content is done with the `-r` flag:
```
$ n -r galaxy
discuss galaxy peace with aliens
tell them that we won't hurt them
and that we can probably reach some agreement
```
Note that when referring to a task, you can give Wren any part of the task title.

For listing your current tasks, just run `n`. Or if you want to filter your tasks, you can use `n --ls query`:
```
$ n
➜ discuss galaxy peace with aliens
➜ go to the moon
➜ build a spaceship

$ n --ls th
➜ discuss galaxy peace with aliens
➜ go to the moon
```

Use  `-e` to edit a task in your `$EDITOR` or `-d` to mark it as done:
```
$ n -d moon
marked "go to the moon" as done
```

Check out everything you've done by using `-d` without a value:
```
$ n -d
➜ go to the moon
```

If you want to postpone a task, just prepend some timestamp to it:
```
$ n --prepend 2030-01-01 galaxy
renamed "discuss galaxy peace with aliens" to "2030-01-01 discuss galaxy peace with aliens"
```

### Integrations

##### Random task
Use `--one` to print one random task. I'm using it with [Waybar](https://github.com/Alexays/Waybar/) to always have one task displayed at the bottom of my screen, like this:
```
  "custom/task": {
    "tooltip": true,
    "max-length": 20,
    "interval": 60,
    "exec": "wren --one"
  },
```

##### AI Assistant

Wren can also work like an AI Assistant. If you use `--summary` it will use GPT4 to create a nice human like message telling you what's waiting for you today, and congratulate you for the stuff you have completed recently. You can use it to update `/etc/motd` daily, or through the Telegram bot (below).

##### Telegram bot

Using `--telegram` will spin up a Telegram bot listener that will respond to your messages and allow you to create tasks, list them, edit them and so on. It will also allow you to set a cron-based schedule for receiving AI Assistant messages. This can be handy if you want to start your day with a message from Wren telling you about your upcoming tasks.

- List tasks using `/list`
- Create task by just writing it, e.g. `make a plan for going back to earth`
- Mark as done with `/done plan`
- See more at `/help`

If you want to run it outside your computer (e.g. so it's always available), I highly recommend using [Syncthing](https://syncthing.net/) to sync your notes.

##### HTTP Server

With `--http` you get both a simple tiny website that works through the browser, and an API server that accepts and returns JSON. Either browse to `http://localhost:8080` or send requests directly with the proper headers:
- List tasks: `curl http://localhost:8080`
- Create task: `curl http://localhost:8080 -d '{"task": "create HTTP interface"}' -H 'content-type: application/json'`
- Mark as done: `curl http://localhost:8080/content -X DELETE`

The HTTP server can be used to integrate with voice assistants, [Home Assistant](https://www.home-assistant.io/), [Tasker](https://joaoapps.com/tasker/) etc. Like with the Telegram bot, if you want to run it outside your computer, I recommend using [Syncthing](https://syncthing.net/).

##### Matrix bot

Using `--matrix` will spin up a Matrix bot that works very similarly to the Telegram bot.

- List tasks using `!list`
- Create task by just writing it, e.g. `make a plan for going back to earth`
- Mark as done with `!done plan`
- See more at `!help`

## Configuration

See the configuration path on your operating system using `--version`.

The schema is as follows and all keys are optional. Remove the comments from your actual file.
```
{
  "notes_dir": "~/Notes",  // This can absolute or include ~
  "done_dir": "done",      // This can be relative to the notes dir, or absolute
  "http_user": "",         // Fill this to enable basic HTTP auth for the HTTP server
  "http_password": "",     // Same as above
  "openai_token": "",      // Fill this if you want to use summaries
  "telegram_token": "",    // Fill this if you want the Telegram bot
  "allowed_telegram_chats": [
    1234564868             // Initiating a chat will print out the chat ID you should fill here
  ],
  // Below you can put context to give the AI assistant
  "about_user": "I work at NASA as Product Manager. Mars is the name of my dog." 
}
```

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "wren-tools",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.11",
    "maintainer_email": null,
    "keywords": "note taking, todo, to do, task management",
    "author": null,
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/fa/aa/7caa3e4105b0b9904e4215d371770ee867524eb0d97332bf68de8fa3f501/wren_tools-0.4.1.tar.gz",
    "platform": null,
    "description": "<h1 align=\"center\">\nWren\n</h1>\n\n<p align=\"center\">\na note taking application and a to-do management system that is ridiculously simple, yet very advanced.\n</p>\n<p align=\"center\">\n<img src=\"https://github.com/bjesus/knowts/assets/55081/ab1f5584-267c-45da-b7bd-96fb38c66143\" height=\"200\">\n</p>\n\nWren is simple because every note is one file. The filename is the title, and the content is the note's content. This makes it very easy to sync tasks between devices, as conflicts can almost never happen, even if syncing isn't done real time. The files are plain text, so you can just write. If you want a task to repeat every Saturday you just prefix it with a cron syntax, e.g. `0 8 * * 6 weekly swim`, and if you want a task to appear from a specific time you just start it with the date, like `2030-01-01 check if Wren became super popular`.\n\nWren is advanced because it is very extensible - it comes (optionally!) with a Telegram bot that you can chat with to manage your notes, a Matrix bot, and even get AI-driven daily summaries as if you had a personal assistant. It also includes a tiny HTTP server that you can use to manage tasks using an API or from the browser, which can be used for displaying you tasks elsewhere (e.g. in your e-reader).\n\nhttps://github.com/bjesus/wren/assets/55081/0deff819-ab30-4a64-a4db-5e9a29179309\n\n## Installation\n\nThe easiest way to install Wren is with pip:\n\n```\n$ pip install wren-notes\n```\n\nTo install with all optional dependencies:\n```\n$ pip install \"wren-notes[telegram,http]\"\n```\n\n## Usage\n\nThe management of tasks in Wren is simple:\n- Tasks are just files living your `notes` folder. You might as well create them with `touch task` and edit them with `vim task`.\n- Completed tasks are moved to your `done` folder.\n- Tasks starting with a YYYY-MM-DD will not appear in the list of tasks before their time arrived.\n- Tasks starting with a cron signature will not be moved when completed. Instead they'll be copied to the `done` directory, and will reappear automatically when the copied file is old enough.\n\n### Command line\n\nThe regular usage mode Wren is the command line. For the following examples, `n` is my alias to `wren`, but you can use any alias or just call `wren` directly. Normal tasks can be created by just typing them\n```\n$ n build a spaceship\ncreated task: build a spaceship\n\n$ n go to the moon\ncreated task: go to the moon\n\n$ n 'discuss galaxy peace with aliens\ntell them that we won't hurt them\nand that we can probably reach some agreement'\ncreated task: discuss galaxy peace with aliens\n```\n\nReading a task content is done with the `-r` flag:\n```\n$ n -r galaxy\ndiscuss galaxy peace with aliens\ntell them that we won't hurt them\nand that we can probably reach some agreement\n```\nNote that when referring to a task, you can give Wren any part of the task title.\n\nFor listing your current tasks, just run `n`. Or if you want to filter your tasks, you can use `n --ls query`:\n```\n$ n\n\u279c discuss galaxy peace with aliens\n\u279c go to the moon\n\u279c build a spaceship\n\n$ n --ls th\n\u279c discuss galaxy peace with aliens\n\u279c go to the moon\n```\n\nUse  `-e` to edit a task in your `$EDITOR` or `-d` to mark it as done:\n```\n$ n -d moon\nmarked \"go to the moon\" as done\n```\n\nCheck out everything you've done by using `-d` without a value:\n```\n$ n -d\n\u279c go to the moon\n```\n\nIf you want to postpone a task, just prepend some timestamp to it:\n```\n$ n --prepend 2030-01-01 galaxy\nrenamed \"discuss galaxy peace with aliens\" to \"2030-01-01 discuss galaxy peace with aliens\"\n```\n\n### Integrations\n\n##### Random task\nUse `--one` to print one random task. I'm using it with [Waybar](https://github.com/Alexays/Waybar/) to always have one task displayed at the bottom of my screen, like this:\n```\n  \"custom/task\": {\n    \"tooltip\": true,\n    \"max-length\": 20,\n    \"interval\": 60,\n    \"exec\": \"wren --one\"\n  },\n```\n\n##### AI Assistant\n\nWren can also work like an AI Assistant. If you use `--summary` it will use GPT4 to create a nice human like message telling you what's waiting for you today, and congratulate you for the stuff you have completed recently. You can use it to update `/etc/motd` daily, or through the Telegram bot (below).\n\n##### Telegram bot\n\nUsing `--telegram` will spin up a Telegram bot listener that will respond to your messages and allow you to create tasks, list them, edit them and so on. It will also allow you to set a cron-based schedule for receiving AI Assistant messages. This can be handy if you want to start your day with a message from Wren telling you about your upcoming tasks.\n\n- List tasks using `/list`\n- Create task by just writing it, e.g. `make a plan for going back to earth`\n- Mark as done with `/done plan`\n- See more at `/help`\n\nIf you want to run it outside your computer (e.g. so it's always available), I highly recommend using [Syncthing](https://syncthing.net/) to sync your notes.\n\n##### HTTP Server\n\nWith `--http` you get both a simple tiny website that works through the browser, and an API server that accepts and returns JSON. Either browse to `http://localhost:8080` or send requests directly with the proper headers:\n- List tasks: `curl http://localhost:8080`\n- Create task: `curl http://localhost:8080 -d '{\"task\": \"create HTTP interface\"}' -H 'content-type: application/json'`\n- Mark as done: `curl http://localhost:8080/content -X DELETE`\n\nThe HTTP server can be used to integrate with voice assistants, [Home Assistant](https://www.home-assistant.io/), [Tasker](https://joaoapps.com/tasker/) etc. Like with the Telegram bot, if you want to run it outside your computer, I recommend using [Syncthing](https://syncthing.net/).\n\n##### Matrix bot\n\nUsing `--matrix` will spin up a Matrix bot that works very similarly to the Telegram bot.\n\n- List tasks using `!list`\n- Create task by just writing it, e.g. `make a plan for going back to earth`\n- Mark as done with `!done plan`\n- See more at `!help`\n\n## Configuration\n\nSee the configuration path on your operating system using `--version`.\n\nThe schema is as follows and all keys are optional. Remove the comments from your actual file.\n```\n{\n  \"notes_dir\": \"~/Notes\",  // This can absolute or include ~\n  \"done_dir\": \"done\",      // This can be relative to the notes dir, or absolute\n  \"http_user\": \"\",         // Fill this to enable basic HTTP auth for the HTTP server\n  \"http_password\": \"\",     // Same as above\n  \"openai_token\": \"\",      // Fill this if you want to use summaries\n  \"telegram_token\": \"\",    // Fill this if you want the Telegram bot\n  \"allowed_telegram_chats\": [\n    1234564868             // Initiating a chat will print out the chat ID you should fill here\n  ],\n  // Below you can put context to give the AI assistant\n  \"about_user\": \"I work at NASA as Product Manager. Mars is the name of my dog.\" \n}\n```\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "The simplest task management system with the most advanced features",
    "version": "0.4.1",
    "project_urls": {
        "Homepage": "https://github.com/bjesus/wren"
    },
    "split_keywords": [
        "note taking",
        " todo",
        " to do",
        " task management"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "e274500a11ffcccff3aa94d8da50b315f8eb1976a213f20361d98ac15f104239",
                "md5": "f161b590adaac81f2bb95806a84d1062",
                "sha256": "db52e0f494f12f5124b9584d31a6c4f7a2bf2481e45b36cee8091c5d183bbdd4"
            },
            "downloads": -1,
            "filename": "wren_tools-0.4.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "f161b590adaac81f2bb95806a84d1062",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.11",
            "size": 13001,
            "upload_time": "2025-01-06T12:48:48",
            "upload_time_iso_8601": "2025-01-06T12:48:48.169965Z",
            "url": "https://files.pythonhosted.org/packages/e2/74/500a11ffcccff3aa94d8da50b315f8eb1976a213f20361d98ac15f104239/wren_tools-0.4.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "faaa7caa3e4105b0b9904e4215d371770ee867524eb0d97332bf68de8fa3f501",
                "md5": "9ca9f735bc749ae838882f920677deb8",
                "sha256": "6ec31313964b238ca5e0c104c6d7b8c86a0ea46692db38c671b0ea00d27883a5"
            },
            "downloads": -1,
            "filename": "wren_tools-0.4.1.tar.gz",
            "has_sig": false,
            "md5_digest": "9ca9f735bc749ae838882f920677deb8",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.11",
            "size": 14827,
            "upload_time": "2025-01-06T12:48:50",
            "upload_time_iso_8601": "2025-01-06T12:48:50.102405Z",
            "url": "https://files.pythonhosted.org/packages/fa/aa/7caa3e4105b0b9904e4215d371770ee867524eb0d97332bf68de8fa3f501/wren_tools-0.4.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-06 12:48:50",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "bjesus",
    "github_project": "wren",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "wren-tools"
}
        
Elapsed time: 0.89343s