mirror of
https://github.com/davegallant/rfd-notify.git
synced 2025-08-05 08:13:39 +00:00
106 lines
3.0 KiB
Markdown
106 lines
3.0 KiB
Markdown
# rfd-notify
|
|
|
|
This tool looks for matches on [RedFlagDeals.com forums](https://forums.redflagdeals.com/hot-deals-f9/) and will send push notifications via [apprise](https://github.com/caronc/apprise).
|
|
|
|
This was originally written before [alerts](https://www.redflagdeals.com/alerts/) existed. With rfd-notify, alerts never expire and support regular expressions.
|
|
|
|
## Prerequisites
|
|
|
|
- either [poetry](https://github.com/python-poetry/poetry), docker, or github actions
|
|
|
|
## Usage
|
|
|
|
The simplest way to get started is to clone this repo, and run with docker:
|
|
|
|
```sh
|
|
docker run -it -v "$(pwd)/examples/config.yml:/app/config.yml" ghcr.io/davegallant/rfd-notify:2
|
|
```
|
|
|
|
To run the code with [poetry](https://python-poetry.org/), clone this repo and run the following:
|
|
|
|
```shell
|
|
poetry install
|
|
poetry run python rfd_notify/cli.py -c examples/config.yml
|
|
```
|
|
|
|
### Environment Variables
|
|
|
|
The following environment variables are required:
|
|
|
|
| VARIABLE | DESCRIPTION |
|
|
| ----------- | ---------------------------------------------------------------------------------------- |
|
|
| APPRISE_URL | See [supported notifications](https://github.com/caronc/apprise#productivity-based-notifications). |
|
|
|
|
## Example Configuration
|
|
|
|
Pass a list of expressions to be used for discovering deals:
|
|
|
|
```yaml
|
|
# config.yml
|
|
expressions:
|
|
- pizza
|
|
- starbucks
|
|
- price error
|
|
```
|
|
|
|
## Github Actions (and Gitea Actions)
|
|
|
|
> Commiting the pickled data (previous_matches) back into the repository is a bit of a hack, but allows for a simpler setup.
|
|
|
|
An action can be setup to scan for deals, send a notification and store previously found deals in the repo.
|
|
|
|
The following workflow requires an `APPRISE_URL` [secret](https://docs.github.com/en/free-pro-team@latest/actions/reference/encrypted-secrets).
|
|
|
|
```yaml
|
|
# .github/workflows/rfd-notify.yml
|
|
|
|
on:
|
|
schedule:
|
|
- cron: "*/5 * * * *"
|
|
jobs:
|
|
rfd_notify:
|
|
name: rfd-notify
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
with:
|
|
sparse-checkout: |
|
|
config.yml
|
|
previous_matches
|
|
- name: git pull
|
|
run: git pull
|
|
- name: Run rfd-notify
|
|
uses: davegallant/rfd-notify@main
|
|
env:
|
|
APPRISE_URL: ${{ secrets.APPRISE_URL }}
|
|
- name: Commit and push changes
|
|
run: |
|
|
git config --local user.email "actions@github.com"
|
|
git config --local user.name "RFD Notify"
|
|
git add previous_matches
|
|
git commit -m "Update previous_matches" -a || true
|
|
git push
|
|
```
|
|
|
|
## Gitlab Pipelines
|
|
|
|
> Create a [scheduled pipeline](https://docs.gitlab.com/ee/ci/pipelines/schedules.html) to run on a regular interval.
|
|
|
|
With Gitlab Pipelines, the following configuration works:
|
|
|
|
```yaml
|
|
#.gitlab-ci.yml
|
|
default:
|
|
image:
|
|
name: ghcr.io/davegallant/rfd-notify:2
|
|
entrypoint: [""]
|
|
|
|
run:
|
|
cache:
|
|
- key: previous_matches
|
|
paths:
|
|
- previous_matches
|
|
script:
|
|
- python /app/rfd_notify/cli.py -c config.yml
|
|
```
|