Skip to content

A personalised Christmas video message maker using the Shotstack API. Built using Node.js Express with the option to deploy as a Serverless project.

License

Notifications You must be signed in to change notification settings

shotstack/christmas-demo-2020

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Shotstack Christmas Personalised Video Maker Demo

This project demonstrates how to use the Shotstack cloud video editing API to build an application that adds personalised text to a Christmas video using a form.

An HTML web form allows the user to a recipient name, personal message and a from name. A video is then created by the Shotstack API that overlays the text on top of the video.

View the live demo at: https://shotstack.io/demo/christmas-video/

The demo is built using Node JS and can be used with either Express Framework or deployed as a serverless projects using AWS Lambda and API Gateway.

Requirements

Project Structure

The project is divided in to a two components:

Backend API

The backend API with an endpoint, which prepares the edit and posts the data to the Shotstack API. A status endpoint is also available which can be polled to return the status of the video as it renders.

The backend API source code is in the api directory.

Frontend Web Form & Player

The frontend is a simple HTML form that allows the user to enter a search term and basic options to create a video. The form uses jQuery to submit the data to the backend API and poll the status of the current render. There is also a video player that is loaded with the final rendered video when ready.

The front end API source code is in the web directory.

Installation

Install node module dependencies:

cd api
npm install

Configuration

Copy the .env.dist file and rename it .env. Replace the environment variables below with your Shotstack API key (staging key):

SHOTSTACK_API_KEY=replace_with_your_shotstack_key

Run Locally

To start the API and serve the front end form (from the api directory):

cd api
npm run start

The visit http://localhost:3000

Deploy Serverless Application (optional)

The project has been built as a serverless application using the Serverless Framework and AWS Lambda. To understand more about the Serverless Framework and how to set everything up consult the documentation: https://serverless.com/framework/docs/providers/aws/

Lambda deployment uses a centralised S3 bucket which must be created first and the .env variable SERVERLESS_DEPLOYMENT_BUCKET_PREFIX must be set. The serverless region is appended to the bucket prefix. The final deployment bucket will look something like: my-serverless-deploys-ap-southeast-2

To deploy to AWS Lambda (from the api directory):

cd api
npm run deploy

Once the API is deployed set the var apiEndpoint variable in web/app.js to the returned API Gateway URL.

Run the web/index.html file locally or use AWS S3 static hosting to serve the web page.

About

A personalised Christmas video message maker using the Shotstack API. Built using Node.js Express with the option to deploy as a Serverless project.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published