Automatic coupon clipper for Safeway's online "Safeway for U" coupons
Project description
Automatic Safeway coupon clipper
safeway-coupons is a script that will log in to an account on safeway.com, and attempt to select all of the "Safeway for U" electronic coupons on the site so they don't have to each be clicked manually.
Installation and usage with Docker
A Docker container is provided which runs safeway-coupons with cron. The cron schedule and your Safeway account details may be configured using environment variables, or with an accounts file.
Example docker-compose.yaml
with configuration via environment variables:
version: "3.7"
services:
safeway-coupons:
image: ghcr.io/smkent/safeway-coupons:latest
environment:
CRON_SCHEDULE: "0 2 * * *" # Run at 2:00 AM each day
SMTPHOST: your.smtp.host
SAFEWAY_ACCOUNT_USERNAME: your.safeway.account.email@example.com
SAFEWAY_ACCOUNT_PASSWORD: very_secret
SAFEWAY_ACCOUNT_MAIL_FROM: your.email@example.com
SAFEWAY_ACCOUNT_MAIL_TO: your.email@example.com
restart: unless-stopped
Example docker-compose.yaml
with configuration via accounts file:
version: "3.7"
services:
safeway-coupons:
image: ghcr.io/smkent/safeway-coupons:latest
environment:
CRON_SCHEDULE: "0 2 * * *" # Run at 2:00 AM each day
SMTPHOST: your.smtp.host
SAFEWAY_ACCOUNTS_FILE: /accounts_file
restart: unless-stopped
volumes:
- path/to/safeway_accounts_file:/accounts_file:ro
Start the container by running:
docker-compose up -d
Debugging information can be viewed in the container log:
docker-compose logs -f
Installation from PyPI
safeway-coupons is available on PyPI:
pip install safeway-coupons
sendmail
is needed for email support.
For best results, run this program once a day or so with a cron daemon.
Usage
For full usage options, run
safeway-coupons --help
Configuration
safeway-coupons can clip coupons for one or more Safeway accounts in a single run, depending on the configuration method used.
If a sender email address is configured, a summary email will be sent for each
Safeway account via sendmail
. The email recipient defaults to the Safeway
account email address, but can be overridden for each account.
Accounts are searched via the following methods in the listed order. Only one account configuration method may be used at a time.
With environment variables
A single Safeway account can be configured with environment variables:
SAFEWAY_ACCOUNT_USERNAME
: Account email address (required)SAFEWAY_ACCOUNT_PASSWORD
: Account password (required)SAFEWAY_ACCOUNT_MAIL_FROM
: Sender address for email summarySAFEWAY_ACCOUNT_MAIL_TO
: Recipient address for email summary
With config file
Multiple Safeway accounts can be provided in an ini-style config file, with a section for each account. For example:
email_sender = sender@example.com ; optional
[safeway.account@example.com] ; required
password = 12345 ; required
notify = your.email@example.com ; optional
Provide the path to your config file using the -c
or --accounts-config
option:
safeway-coupons -c path/to/config/file
Development
Poetry installation
Via pipx
:
pip install pipx
pipx install poetry
pipx inject poetry poetry-dynamic-versioning poetry-pre-commit-plugin
Via pip
:
pip install poetry
poetry self add poetry-dynamic-versioning poetry-pre-commit-plugin
Development tasks
- Setup:
poetry install
- Run static checks:
poetry run poe lint
orpoetry run pre-commit run --all-files
- Run static checks and tests:
poetry run poe test
Created from smkent/cookie-python using cookiecutter
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for safeway_coupons-0.1.15-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7c9f4967814dcf26fce9d1e5886cebc64f6e31ee7c9c63de88e7b40fe61336fd |
|
MD5 | a937fb5b715ae55baa9f6d6cb9fad964 |
|
BLAKE2b-256 | 29119361b6951a9f5e50b723d0a026d9507c257b38b8ba421651f4930677a691 |