Clapshot is an open-source, self-hosted tool for collaborative video/media review and annotation. It features a Rust-based API server and a Svelte-based web UI. This tool is ideal for scenarios requiring local hosting of videos due to:
If you don't require local hosting, or are not adept in networking and Linux, consider commercial cloud services which may offer more user-friendly interfaces and additional features out of the box.
Quick Start with Docker:
docker run --rm -it -p 0.0.0.0:8080:80 -v clapshot-demo:/mnt/clapshot-data/data elonen/clapshot:latest-demo
docker run --rm -it -p 0.0.0.0:8080:80 -v clapshot-demo-htadmin:/mnt/clapshot-data/data elonen/clapshot:latest-demo-htadmin
After the Docker image starts, access the web UI at http://127.0.0.1:8080
.
The basic auth multi-user demo uses PHP htadmin for user management. Default credentials are shown in the terminal.
Here are two alternative ways to deploy Clapshot + PHP Htadmin into a light production use:
If you have a virtualization platform (e.g. Proxmox) or a spare computer, here's how to install and configure a Debian 12 host for Clapshot:
/mnt/clapshot-data
.admin
and htadmin
passwords, and delete example users in Htadmin !!If you want to expose this to the Internet, you'll probably want to get HTTPS certificates with Let's Encrypt and use some reverse proxy to encrypt Clapshot traffic.
In this option, you'll run Clapshot + Htadmin in a Docker container (binding a local directory for Clapshot data), and then start Cloudflared in another container to expose Clapshot to the Internet over an HTTPS tunnel.
admin
and htadmin
passwords, and delete example users in Htadmin !!The same process can be adapted to any other HTTPS-Proxy-as-a-Service besides Cloudflare. You'll probably need to pay them something.
See the Sysadmin Guide for information on:
See Upgrading Guide for instructions on installing a new release over an old one.
Main components:
localhost
to the reverse proxy for plaintext HTTP and WSS.Production deployments also depend on:
Web Browser – Chrome works best. Loads and shows the Client.
Nginx Web Server – SSL reverse proxy between Client and Server + static asset delivery for browser. Also routes session auth to Authentication Proxy.
Authentication Proxy – Any auxilliary HTTP daemon that authenticates users and return a user id and username in HTTP headers. In the demo, this is /var/www/.htpasswd
+ PHP htadmin, but you can also use combinations like Okta + Vouch + LDAP Authz Proxy or something equally advanced.
Sqlite DB – Stores metadata, comments, user messages etc. Both Clapshot Server and Organizer(s) access this. This is just a file, not a daemon.
ffmpeg and mediainfo – Clapshot Server processes media files with these commands.
File System – Media files, HTML, JavaScript, CSS, thumbnail images etc, also clapshot.sqlite
.
See sequence diagram for details on how these interact when a user opens the main page.
Clapshot now includes an extensible Organizer Plugin system. Organizer can implement custom UIs, virtual folders, enforce access control based on your business logic, and integrate with existing systems (LDAP, project management databases, etc).
Organizers use gRPC to communicate with the Clapshot Server, and can be implemented in any language.
The provided default/example organizer, called “basic_folders” (in Python), implements:
The Organizer API is still evolving, so you are invited to provide feedback and discuss future development. However, please do not expect backward compatibility for now.
The development setup guide covers setting up the server and client development environments, and running local builds and tests.
Contributions are welcome, especially for features and improvements that benefit the wider user base. Please add your copyright notice for significant contributions.
Copyright 2022 – 2024 by Jarno Elonen
This split licensing allows you to implement proprietary UIs and workflows through custom Organizer plugins without releasing them to the public.