This video API project uses ffmpeg
and ffprobe
from the host machine's environment to upload and
download video files and metadata from supabase. It also lets the user merge two previously uploaded
video files into a single merged file.
-
Make sure you have
ffmpeg
andffprobe
installed on your machine, withlibx264
for video andlibfdk_aac
for audio. For example, on MacOS/Linux (using homebrew):$ brew tap homebrew-ffmpeg/ffmpeg $ brew install homebrew-ffmpeg/ffmpeg/ffmpeg --with-fdk-aac
-
Install node using nvm (or whatever method you prefer). Its always a good idea to click through
and check scripts for nastiness before piping them directly into bash. A .nvmrc file has been provided in this project to make sure the node version is correct.$ curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash $ cd path/to/project $ nvm use
-
Install pnpm and project dependencies
$ npm install -g pnpm $ pnpm install
-
Add a
.env
file. This file should contain the following properties, used to connect to a properly configured supabase service:SUPABASE_URL
andSUPABASE_ANON_KEY
. -
Choose whether you want to run the development or production build version of the project. For Development:
$ pnpm dev
For Production Build
$ pnpm build && pnpm start
A Dockerfile has been provided to build the project into a container. Note that we have to build ffmpeg from source because we are using libfdk-aac.
Swagger API docs are available at localhost:4000/api-docs
(or wherever you map the
container url and port to). These let you try out the live api if you want to test it.
-
Folder based routing:
Routes are defined by adding folders and files into the router directory. Folders represent path segments, and
[bracketed-values]
represent dynamic path segments that are injected into the handler asrequest.params
.Each route can have middleware provided to it by exporting an array instead of a single
Handler
function. This is whats happening withmulter
in the/videos
POST
endpoint. -
Co-located API docs:
This project uses
swagger-ui
andswagger-jsdoc
to co-locate the API documentation with the endpoints. Colocation is better for this because it removes a barrier from keeping docs up to date. Nobody likes stale API docs. Swagger was chosen so that we have the tools to live test the API. Live testing using the docs is also a great way to encourage docs to stay up to date. -
Web streams:
Wherever possible, this project endeavors to use web standards. Fetch was recently added to node.js core, and the version that was added aligns with the whatwg spec. This makes it mildly annoying to interact with the fs, which is written on the older node.js stream standard, but that is the cost of future-proofing.
-
Testing:
Endpoints were all developed using the swagger docs as a TDD mechanism. The swagger docs were written before the handlers and the handlers were built by sending requests from the swagger UI. In the future cypress of playwright should be added to make automated tests.