This project aimed at creating a lightweight and easy platform to share videos and clips with your friends. After uploading a clip, a new page is generated and makes the video available to watch for 48 hours, after which the page and the video file are deleted.
I like the idea of pastebin and wanted something similar for videos, since most of the clips I wanted to share were too large for chat applications like Discord.
The first idea inlcuded to let the user chose how long the video should be available, but to keep the system minimal, a simple cron job just scrubs every page and video older than 48 hours.
Check out the website at bruh-clips.com.
Coded in vanilla JavaScript, HTML and PHP, this project does not need any special deployment procedure or dependencies. Just put all the content of the "web" folder on a webserver and point a domain at it.
Only the cron job needs to be configured/started manually.
-
The user selects a valid video file (currently set to: only .mp4 and max. 500mb) from his system and clicks on upload.
-
home.js takes the video and snaps a frame at the end of the video (duration * 0.90) to use as a thumbnail.
-
The file is transmitted to the server using a XMLHttpRequest.
-
upload.php handles the server-side validation and entire upload process:
- Valdiate the video file and check if the webserver still has enough space left. If any validation step fails, the script will return an error message to be displayed.
- Generate a random ID to use for the videofile, generated thumbnail and new HTML page.
- Build together a new HTML page using the template.html and redirect the user to it afterwards
-
The user lands on the new page and can copy the link to share it. Thumbnail and videoname will be used in the link preview on any social media which supports the Open Graph Protocol.
-
48 hours after uploading, the cron job will delete thumbnail, videofile and HTML page from the server. All visitors after that will be redirected to a 404 page.
- Create a custom validation for the upload form.
- Integrate the possibility to cut/trim a clip before uploading using ffmpeg and server-side rendering.
- Set up CI/CD for this repository to publish changes directly to bruh-clips.com.
(not in that order)