Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dtinth/automatron
Personal LINE bot to automate various tasks. Home automation, expense tracking, transaction monitoring
https://github.com/dtinth/automatron
airtable chatbot cloud-iot-core cloud-run express line-bot typescript
Last synced: 4 days ago
JSON representation
Personal LINE bot to automate various tasks. Home automation, expense tracking, transaction monitoring
- Host: GitHub
- URL: https://github.com/dtinth/automatron
- Owner: dtinth
- Created: 2018-10-30T14:29:12.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-06T05:36:46.000Z (4 months ago)
- Last Synced: 2025-01-11T09:09:15.934Z (11 days ago)
- Topics: airtable, chatbot, cloud-iot-core, cloud-run, express, line-bot, typescript
- Language: HTML
- Homepage: https://dt.in.th/automatron.html
- Size: 4.72 MB
- Stars: 176
- Watchers: 7
- Forks: 34
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# automatron
This is my personal LINE bot that helps me automate various tasks of everyday life, such as
**home control** (air conditioner, lights and plugs) and **expense tracking** (record how much I spend each day).
[See below for a feature tour.](#features)I recommend every developer to try creating their own personal assistant chat bot.
It’s a great way to practice coding and improve problem solving skills.
And it helps make life more convenient!It is written in TypeScript and runs on [Google Cloud Run](https://cloud.google.com/run) on top of [evalaas](https://github.com/dtinth/evalaas) JavaScript-execution platform.
## features
- [home automation](#home-automation)
- [expense tracking](#expense-tracking)
- [transaction aggregation](#transaction-aggregation)
- [image-to-text](#image-to-text)
- [livescript evaluation](#livescript-evaluation)### home automation
![home automation](./images/home_automation.png)
I have a Raspberry Pi set up which can [control lights](https://github.com/dtinth/hue.sh), [air conditioner](https://medium.com/@dtinth/remotely-turning-on-my-air-conditioner-through-google-assistant-1a1441471e9d), and [smart plugs](https://ifttt.com/services/kasa). It receives commands via [Google Cloud IoT Core](https://cloud.google.com/iot-core/), performs the action, and then reports back to automatron via [its API](#cli-api).
### expense tracking
![expense tracking](./images/expense_tracking.png)
Simple expense tracking by typing in the amount + category. Example: 50f means ฿50 for food. Data is saved in [Airtable](https://airtable.com/).
On mobile, tapping the bubble’s body (containing the amount) will take me to the created Airtable record. This allows me to easily edit or add remarks to the record. Tapping the bubble’s footer (containing the stats) will take me to Airtable view, which lets me see all the recorded data.
### transaction aggregation
![transaction_aggregation](./images/transaction_aggregation.png)
I [set up IFTTT to read SMS messages](https://ifttt.com/services/android_messages) and send it to automatron. It then uses [transaction-parser-th](https://github.com/dtinth/transaction-parser-th) to parse SMS message and extract transaction information. It is then sent to me as a [flex message](https://developers.line.me/en/docs/messaging-api/using-flex-messages/).
![quick_replies](./images/quick_replies.png)
In mobile phone, [quick reply buttons](https://developers.line.me/en/docs/messaging-api/using-quick-reply/) lets me quickly turn a transaction into an expense record by simply tapping on the category.
![auto_expense](./images/auto_expense.png)
Certain kinds of transactions can be automatically be turned into an expense, for example, when I [take BTS Skytrain using Rabbit LINE Pay card](https://brandinside.asia/rabbit-line-pay-bts/). Having many features in one bot enabled this kind of tight integrations.
### image-to-text
![image_to_text](./images/image_to_text.png)
automatron can also convert image to text using [Google Cloud Vision API](https://cloud.google.com/vision/).
### livescript evaluation
![livescript](./images/livescript.png)
[LiveScript](https://livescript.net/) interpreter is included, which allows me to do some quick calculations.
### cli / api
![api](./images/api.png)
`POST /text` sends a text command to automatron. This is equivalent to sending a text message through LINE. This allows me to create a CLI tool that lets me talk to automatron from my terminal.
`POST /post` sends a message to my LINE account directly. This allows the [home automation](#home-automation) scripts to report back to me whenever the script is invoked.
## project structure
This project is a monorepo managed by [Rush](https://rushjs.io/). It contains multiple subprojects:
- [core](./core) — The core automatron service running on Google Cloud Run.
- [webui](./webui) — The web-based UI running on Vercel.### other projects
- [automatron-prelude](https://github.dev/dtinth/automatron-prelude/blob/main/prelude.js) contains code experimentation.