Skip to content

KarnerTh/qlookout

Repository files navigation

Query-Lookout logo

Query-Lookout

⚠️ Project is under development - features and apis are subject to change

Query Lookout is a small and simple tool designed to simplify and enhance the way you monitor and manage your database content. As data grows in complexity and volume, keeping a vigilant eye on changes becomes crucial. Query-Lookout allows you to define rules, alerting you to relevant modifications or data constellations in your database.

Want to see what has changed? Take a look at the Changelog

How does it work

  1. Create a new lookout
    1. Define a display name
    2. Configure a cron expression how often it should run (details here)
    3. Define the SQL query that should be run
    4. Configure desired notification channels (in app notification is on by default)
  2. Define one or more rules that validate the result of the lookout
    1. Column that should be checked
    2. Row from which the value should be used (counting starts with 0)
    3. Column type (text, int, float)
    4. Rule type (exact value, should be null, greater/less than, between)
    5. Expected value
reamde_demo.mp4

Contents

Features

  • Rule-based Monitoring: Create customizable rules to monitor specific changes or data constellations in your database. Define conditions that matter most to you and receive timely alerts when those conditions are met.

  • Alert Notifications: Receive notifications in real-time through various channels, such as email, in app notifications or local notifications (more coming). Stay informed about important updates without the need to constantly check the database.

  • Easy Configuration: Set up rules effortlessly with an intuitive configuration interface. No need for complex queries or scripts – Query Lookout streamlines the process, making monitoring accessible to everyone.

  • Database Compatibility: Query Lookout supports a wide range of databases, ensuring flexibility and compatibility with popular database management systems.

  • Single Binary: Everything you need in one single binary - the core and web ui. Get up and running in a few steps - locally or whereever you want.

Getting started

  1. Install query-lookout (details here)
  2. Create the configuration file ~/.qlookout (details here)
    1. Important config is data_source, which defines the connection string to your database
  3. Run qlookout
  4. Open http://localhost:63000/
  5. Enjoy

Installation

go install github.com/KarnerTh/qlookout@main

or via docker

docker run \
    --network=""               `# if you want to access another docker container` \
    -v qlookout_data:/root     `# if you want to persist your data` \
    -e QL_DATA_SOURCE=""       `# the datasource which you want to query` \
    -p 63000:63000             `# port for the ui` \
    -p 63001:63001             `# port for the core` \
    ghcr.io/karnerth/qlookout:latest

Supported databases

Database Example Connection-String
SQLite3 sqlite3://your-file.db
PostgreSQL postgresql://user:password@localhost:5432/yourDb
MySQL mysql://root:password@tcp(127.0.0.1:3306)/yourDb
MSSQL sqlserver://user:password@localhost:1433?database=yourDb

Configuration

# required
data_source             The data source for the lookouts

# mail config
mail_from_address       From which mail address the notifcation mails are sent
mail_to_address         To which mail addresses notifcations are sent (multiple addresses separated by comma)
mail_smtp_host          SMTP host
mail_smtp_port          SMTP port
mail_username           SMTP username
mail_password           SMTP password

# optional
log_level               Log level of the core (error, warn, info, debug)
database_file           The file that is used for the internal sqlite database (defaults to `data.db` in your home directory)
base_url                Base url of the application (e.g. for the notification deeplink)

The configs are loaded in that order (details can be found here)

  • as environment variables with a QL_ prefix in ALL_CAPS
  • a yaml configuration file located in ~/.qlookout

Example config file

log_level: INFO
database_file: "custom_file_name.db"
data_source: "sqlite3://data.db"
base_url: "https://karnerth.github.io/portfolio/"
mail_from_address: "[email protected]"
mail_to_address: "[email protected],[email protected]"
mail_smtp_host: "localhost"
mail_smtp_port: "1025"
mail_username: "[email protected]"
mail_password: "superSecret1"

Example environment variables

export QL_LOG_LEVEL="INFO"
export QL_DATABASE_FILE="custom_file_name.db"
export QL_DATA_SOURCE="sqlite3://data.db"
export QL_BASE_URL="https://karnerth.github.io/portfolio/"
export QL_MAIL_FROM_ADDRESS="[email protected]"
export QL_MAIL_TO_ADDRESS="[email protected],[email protected]"
export QL_MAIL_SMTP_HOST="localhost"
export QL_MAIL_SMTP_PORT="1025"
export QL_MAIL_USERNAME="[email protected]"
export QL_MAIL_PASSWORD="superSecret1"