How I Built Subtis from Scratch

February 25, 2025

TL;DR

After two years of development, I'm thrilled to announce that Subtis is now live!

Subtis is a free, open-source project that helps users find perfectly synced movie subtitles.

Subtis Landing Page

The Problem

As both a software engineer and movie enthusiast, I've always been frustrated with the current subtitle ecosystem. While services like Subdivx and OpenSubtitles exist, they cater more to power users than the average viewer who simply wants to enjoy their favorite movie with synchronized subtitles.

Subdivx Interface OpenSubtitles Interface

Core Features

Search & Discovery

  • Lightning-fast subtitle search
  • Smart file-based matching
  • Intuitive movie name search
  • Advanced mode for power users

Integration & Metadata

  • Seamless video player integration
  • One-click subtitle downloads
  • Rich movie metadata
  • Cross-platform compatibility

Design Process

The journey began with a simple subtitle indexer for various providers. Instead of diving straight into Figma, I found that sketching potential UI designs on paper proved more efficient for rapid iteration.

Subtis Initial Sketches

This hands-on approach not only sped up the design process but also gave our designers a solid foundation while maintaining their creative freedom.

Technical Architecture

The biggest technical challenge was handling different movie versions and their corresponding subtitles. I solved this with a real-time search system powered by WebSockets, delivering results in 20-30 seconds.

Subtis Real-time Search

To enhance the user experience during searches, we show engaging movie trailers and teasers, making the wait feel more like entertainment than downtime.

System Flow

Subtis System Architecture
  1. Automated daily subtitle database updates
  2. Efficient API serving with smart caching
  3. Asynchronous processing for new requests
  4. Real-time WebSocket search capabilities
  5. Robust database storage and notifications
  6. Intelligent Cloudflare cache management

Tech Stack

Backend & Infrastructure

  • Bun runtime (mono-repo support)
  • Fly.io for real-time services
  • Hono API framework
  • Supabase database & storage
  • Cloudflare Workers & Pages

Frontend & UI

  • React Router V7
  • Shadcn UI components
  • Tailwind CSS
  • TypeScript

Database Design

A well-thought-out database design was crucial for scalability and maintainability. After multiple iterations, we arrived at a schema that supports all planned features while maintaining performance.

Subtis Database Schema

Key Learnings

Development Process

  • User-first development approach
  • Database design fundamentals
  • Clear project vision
  • Advanced string manipulation
  • Transparent development

Project Management

  • Strategic team building
  • User feedback integration
  • Phased feature releases
  • Resilient development

Back to the 90's

I wanted to recapture the simplicity and directness of early web products, focusing on user experience without modern web annoyances.

  • No paywalls or subscriptions
  • Zero cookie popups
  • Direct download links
  • No login required

Final Thoughts

Building Subtis has been an incredible journey of learning and growth. It's a perfect example of how personal projects can both showcase technical expertise and reignite the pure joy of coding.

I hope Subtis's story inspires you to tackle your own projects and solve real problems for real users.

The project is fully open-source and available on GitHub. I welcome your feedback and contributions!