Skip to main content

Blue Book generates AI-powered multiple-choice questions for any exam or certification

Project description

Bluebook Logo

Blue Book

demo-gif

Blue Book is a web application that generates AI-powered multiple-choice questions for any exam or certification. It ships with a built-in preset for CompTIA Security+, but you can add any exam you need via the Exam Constructor. Powered by Google's Gemini API, it provides instant feedback, detailed explanations, and personalized study recommendations.

Project's Homepage

Features

Question Generation & Review

  • Generate multiple-choice questions for any exam using Gemini AI.
  • Focus generation on specific topics or objectives with additional requests.
  • Submit answers and receive immediate feedback with detailed explanations per choice.
  • Get personalized study recommendations based on your answers.

Exam Management

  • Ships with a built-in CompTIA Security+ preset.
  • Add custom exams for any certification or subject using the Exam Constructor.
  • Seamlessly switch between exams — each exam maintains its own isolated state.

Custom Prompts

  • Build and manage custom prompt templates via the Prompt Builder.
  • Use anchor-based templates to control exactly how questions are generated.
  • Select from your saved prompts when generating questions.

File Attachments

  • Upload reference files (study guides, notes, etc.) to a local cache.
  • Sync files to Gemini remote storage for AI-powered context.
  • Attach specific files to exams — attached files are included as context during question generation.

Persistence & State

  • SQLite database stores all saved questions, topics, exams and prompts.
  • Server-side sessions ensure state is preserved without cookie size limits.
  • Save individual questions for later revision.
  • Save and reuse custom topics per exam.
  • State is automatically saved and restored when switching between exams.

Tech Stack

Layer Technology
Backend Python 3.10+, Flask 3, Click CLI
AI Google Gemini API (google-genai)
Database SQLite via SQLModel
Validation Pydantic v2
Templating Jinja2
Sessions Flask-Session (server-side filesystem)
Sanitization Bleach
Container Multi-stage Docker build (Python 3.13 Alpine)

Installation

Docker (recommended)

Run with a pre-built image:

docker run -d -p 5000:5000 --platform linux/amd64 ilyasmut/student-bluebook

Or build from source with Docker Compose:

git clone https://github.com/ilya-smut/blue-book
cd blue-book/
docker compose up -d

pip / pipx

pip install student-bluebook
pipx install student-bluebook

Usage

Start the application:

bluebook start

Start in debug mode (verbose logging):

bluebook start --debug

The app will be available at http://localhost:5000. On first launch, you'll be prompted to enter your Gemini API key.

For a full walkthrough of the interface, see the wiki.

Disclaimer

Blue Book is an independent study tool and is not affiliated with, endorsed by, or sponsored by CompTIA or any other certification body. All certification names are trademarks of their respective owners. You can purchase official CompTIA study materials at their official website.

All questions are generated by third-party AI models (Google Gemini). The author of this application has no control over how these models were trained or what content they produce. Generated questions are intended as study aids and should not be treated as official exam material.

Please don't sue me.

Contributing

If you'd like to contribute to Blue Book, feel free to submit a pull request or open an issue.

License

This project is licensed under the GPLv3.

Contact

For any questions or feedback, feel free to reach out.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

student_bluebook-2.0.0.tar.gz (57.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

student_bluebook-2.0.0-py3-none-any.whl (70.1 kB view details)

Uploaded Python 3

File details

Details for the file student_bluebook-2.0.0.tar.gz.

File metadata

  • Download URL: student_bluebook-2.0.0.tar.gz
  • Upload date:
  • Size: 57.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.10.19 Linux/6.11.0-1018-azure

File hashes

Hashes for student_bluebook-2.0.0.tar.gz
Algorithm Hash digest
SHA256 a85b79fd50267919792f2e1acb020c578e9dc6608818c3d92527a2da32722fe0
MD5 782b143e26a2205a05bf3139918bbe6d
BLAKE2b-256 d86e718cb8e637dbc2d49796aababeeb7273a5c0caa290dbd60da8ba4e14e501

See more details on using hashes here.

File details

Details for the file student_bluebook-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: student_bluebook-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 70.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.10.19 Linux/6.11.0-1018-azure

File hashes

Hashes for student_bluebook-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e12579483182b630883cbdd6602e5c8f7e7f72b4cd4be0b9e4898e137f3917d6
MD5 f736d2ad9091e030415d7f5b589a69e1
BLAKE2b-256 f8e12ac992792601e9c767abd5b2be2ca6ab9c5697a586969b2095bc03ee87d5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page