Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/rozsival/oribot

📊 Where's your worklog?
https://github.com/rozsival/oribot

Last synced: 19 days ago
JSON representation

📊 Where's your worklog?

Awesome Lists containing this project

README

        



ApiTree s.r.o.


ApiTree


OriBot


Simple Slack bot to annoy Oriflame teammates with regular worklog agenda.


Where's your worklog?


QA
CodeQL
Deploy


## 💾 Installation

```bash
nvm use
yarn install
```

## 🚀 Deployment

This app is deployed to [Google Cloud Run](https://console.cloud.google.com/run/detail/europe-central2/oribot/)
via [Deploy action](.github/workflows/deploy.yml) on push to `main` branch.

After each deployment two parallel processes are started with `yarn start`:

- app (`yarn start:app`) – bot worker that runs messaging schedule every day at specified time
- server (`yarn start:server`) – [public web](https://oribot-vpnvbwijja-lm.a.run.app) just for the funsies

To save as many resources as possible, the Cloud Run instance auto-scales to 0 and idles when inactive. For this reason,
a [Cloud Scheduler job](https://console.cloud.google.com/cloudscheduler/jobs/edit/europe-central2/wakeup-oribot?project=apitree-oribot)
is created to wake OriBot up every day at 9:55 AM (Europe/Prague).

> 🧠 Do not forget to update the schedule based on the configuration below.

## ⚙ī¸ Configuration

The app uses `.env` config which is based on `.env.example`:

- `CHANNEL_ID` – Slack channel ID for messaging
- `ClOSURE_DAY` – day of month on which the worklog agenda closes (defaults to `25`)
- `DEBUG` – set `1` to disable sending messages and only output to console (defaults to `0`)
- `DEBUG_DATE` – when `DEBUG=1` use this to simulate a specific date for test run (defaults to `undefined`)
- `JOB_HOUR` – hour at which the messaging schedule runs daily (defaults to `10`)
- `JOB_MONTH_END` – month in which the messaging schedule ends (defaults to `11`)
- `JOB_MONTH_START` – month in which the messaging schedule starts (defaults to `2`)
- `PORT` – port on which the public web is served (defaults to `8080`)
- `TOKEN` – Slack [OAuth token](https://api.slack.com/apps/A0422H11QKS/oauth?) for ApiTree workspace
- `TZ` – timezone to be used for dates and times (defaults to `Europe/Prague`)

> ⚠ī¸ Values for `CHANNEL_ID` and `TOKEN` are mandatory and stored in
> the [Secret Manager](https://console.cloud.google.com/security/secret-manager?project=apitree-oribot).

> ℹī¸ Right click on channel name in Slack and use `View channel details` to find channel ID.

> 🎄 By default, December and January are skipped in schedule due to end-of-year specific closure.