GithubHelp home page GithubHelp logo

zph / serverless-url-shortener Goto Github PK

View Code? Open in Web Editor NEW

This project forked from danielireson/serverless-url-shortener

0.0 0.0 0.0 3.32 MB

URL shortener for AWS Lambda and S3

License: MIT License

JavaScript 65.45% HTML 34.55%

serverless-url-shortener's Introduction

Serverless URL Shortener

A lightweight URL shortener built with the Serverless Framework using AWS Lambda and S3. Each URL redirection is stored as an S3 object with the Website-Redirect-Location metadata key set to the forwarding web address. AWS Lambda is used to create an API to save these objects. The website is served from the same S3 bucket.

Screenshot

Setup

Install dependencies

Head on over to the Serverless Framework docs and run through their quick-start guide. It’s mentioned in there as part of your setup, but be sure to install the AWS CLI and configure your AWS credentials. Then run npm install to get the NPM dependencies for the project.

Setup Route 53

Create Route 53 hosted zones for both the API and website.

Add environment variables

Create a copy of .env.example for each "stage" that you wish to deploy to (e.g .env.staging, .env.production) and then customise each configuration file as appropriate for your setup.

Name Description Required
BUCKET S3 bucket that will store URL redirects Y
REGION AWS region to deploy to Y
API_URL API endpoint the website will interact with Y
API_DOMAIN Custom API domain the API will be served from Y
API_HOSTED_ZONE AWS Route53 hosted zone ID with the custom API domain Y
API_CERTIFICATE_NAME AWS Certificate Authority certificate name for API domain Y
API_BASE_ENDPOINT API Gateway base path (e.g. prefix) for lambda function Y
SHORT_URL Base URL of shortened links (without trailing slash) Y
SHORT_DOMAIN Custom short domain to serve the website Y
SHORT_HOSTED_ZONE AWS Route53 hosted zone ID with the custom short domain Y
SHORT_DOMAIN_ACM_ARN AWS Certificate Authority certificate name for short domain Y
TITLE Customize the title of the website and form N
CREDIT Customize the credit name in the footer N
CREDIT_URL Customize the credit link in the footer N
AWS_PROFILE AWS profile setup in ~/.aws/credentials N

Deploy API

Run npm run deploy to deploy the API and website to AWS. The resources defined in serverless.yml will be automatically instantiated using CloudFormation. Prefix with the stage you want to deploy (e.g. STAGE=production npm run deploy).

Architecture based on serverless-aws-static-websites:

Architecture

Build template

Run npm run build to build the template with appropriate template variables.

Deploy website

Run npm run deploy:client to deploy the website using the AWS CLI.

You can add a ?vanity= query string parameter to the homepage to specify a vanity (custom) shortcode instead of a randomly-generated one. If the name is already taken, a random one will be used instead.

Libraries used

serverless-url-shortener's People

Contributors

danielireson avatar delfuego avatar joelvh avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.