Skip to main content

Academic portfolio CMS backend - pip-installable FastAPI library

Project description

ojsTerminalBio

A cyberpunk-themed academic portfolio CMS built with FastAPI. Create stunning terminal-style portfolio websites with a powerful admin interface.

Python License PyPI

โœจ Features

  • ๐ŸŽจ Cyberpunk terminal-style UI with matrix rain effect
  • ๐Ÿ“Š Admin dashboard for managing all content
  • ๐Ÿ“„ Dynamic page editor with drag-and-drop blocks
  • ๐Ÿ“š Publications, Projects, Students, Courses management
  • ๐ŸŽ“ Education & Experience sections
  • ๐Ÿ”— Dynamic external links (Google Scholar, DBLP, etc.)
  • ๐ŸŒ™ Light/Dark theme toggle
  • ๐Ÿ“ฑ Fully responsive design

๐Ÿš€ Quick Start

Installation

pip install ojsterminalbio

Initialize Database

ojsterminalbio init-db

Run Server

ojsterminalbio runserver

Access at: http://localhost:7777

Default Admin Login:

  • Email: admin@example.com
  • Password: admin123

โš ๏ธ Change these credentials immediately in production!


โš™๏ธ Configuration

Set environment variables or create a .env file:

# Required for production
export OJSTB_SECRET_KEY="your-secure-random-key"
export OJSTB_DEFAULT_ADMIN_EMAIL="your@email.com"
export OJSTB_DEFAULT_ADMIN_PASSWORD="secure-password"

# Optional
export OJSTB_DATABASE_URL="sqlite:///./ojsterminalbio.db"
export OJSTB_DEBUG="false"

๐Ÿ–ฅ๏ธ CLI Commands

Command Description
ojsterminalbio init-db Initialize/reset database
ojsterminalbio runserver Start development server
ojsterminalbio runserver --port 8000 Custom port
ojsterminalbio runserver --host 0.0.0.0 Allow external access

๐Ÿ“ Project Structure

After installation, the package includes:

ojsterminalbio/
โ”œโ”€โ”€ templates/           # Jinja2 HTML templates
โ”‚   โ”œโ”€โ”€ admin/          # Admin panel templates
โ”‚   โ””โ”€โ”€ public/         # Public-facing templates
โ”œโ”€โ”€ static/             # CSS, JS, images
โ”‚   โ””โ”€โ”€ css/
โ”‚       โ””โ”€โ”€ tailwind.css
โ”œโ”€โ”€ models/             # SQLAlchemy models
โ”œโ”€โ”€ routers/            # FastAPI routes
โ””โ”€โ”€ cli.py              # Command-line interface

๐ŸŽจ Customization

Theme Colors

In admin panel: Settings โ†’ Theme Primary Color

  • Cyan (default)
  • Pink
  • Amber
  • Green

Matrix Effect

Customize via admin:

  • Enable/disable matrix rain
  • Change characters (supports Unicode/Meitei script)
  • Adjust opacity and speed

๐Ÿ”ง Development

Clone & Setup

git clone https://github.com/Okramjimmy/ojsTerminalBio.git
cd ojsTerminalBio
python -m venv venv
source venv/bin/activate
pip install -e .

Run locally

ojsterminalbio init-db
ojsterminalbio runserver

๐Ÿ“ฆ Building from Source

pip install build
python -m build
pip install dist/ojsterminalbio-*.whl

๐Ÿค Contributing

  1. Fork the repository
  2. Create feature branch (git checkout -b feature/amazing)
  3. Commit changes (git commit -m 'Add amazing feature')
  4. Push to branch (git push origin feature/amazing)
  5. Open a Pull Request

๐Ÿ“„ License

MIT License - see LICENSE file.


๐Ÿ‘ค Author

Okram Jimmy Singh


๐Ÿ™ Acknowledgments

  • FastAPI framework
  • Tailwind CSS
  • Jinja2 templating

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

ojsterminalbio-0.1.5.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

ojsterminalbio-0.1.5-py3-none-any.whl (1.0 MB view details)

Uploaded Python 3

File details

Details for the file ojsterminalbio-0.1.5.tar.gz.

File metadata

  • Download URL: ojsterminalbio-0.1.5.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for ojsterminalbio-0.1.5.tar.gz
Algorithm Hash digest
SHA256 4d23f7ad3111f9807c1e9912a22bb945ffe8f1c1cd68680abe8f2e866decd6d9
MD5 213495692d293923601da4071bea967e
BLAKE2b-256 a12dd6d36338a3654572cd1e7460216da3cd7252c22c288f0d35ca1191292a0e

See more details on using hashes here.

File details

Details for the file ojsterminalbio-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: ojsterminalbio-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 1.0 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for ojsterminalbio-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 37f476f7e0ee4a113aa9260e9db193e392c3c029076fc6c0e9a8b02828a353b0
MD5 82e937c5d5d79df7880ebefa265872dd
BLAKE2b-256 fc94f17493bf10c41abe587fd2739e622acd30dd2c8c4555e3013e00593f2258

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