New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@dizzzmas/sst-url-shortener

Package Overview
Dependencies
Maintainers
0
Versions
19
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@dizzzmas/sst-url-shortener

  • 0.0.0-1730077680418
  • npm
  • Socket score

Version published
Maintainers
0
Created
Source

:hocho: sst-url-shortener

Host your own URL shortener on AWS with SST and chop up those beefy links in a breeze!

  • :twisted_rightwards_arrows: Add as a component to your existing SST app or deploy standalone and integrate with your JS/Python/Go backend via the OpenAPI sdk
  • :lock: Opt-in API bearer auth and Swagger docs UI
  • :sparkles: URL search and expiration support
  • :house: Bring your custom domain
  • :moneybag: Serverless and fully within AWS Free Tier, 0 upfront cost

diagram

Pre-requisites

If this is your first time using SST or deploying to AWS, make sure you have the AWS credentials properly setup

Quickstart

Standalone SST app

This is for cases when you can't or don't want to integrate the URLShortener component into your existing SST app. Here we will create a new SST app and use an OpenAPI SDK to integrate with our backend deployed elsewhere.

  • Create a new project:
mkdir my-shortener-app && cd my-shortener-app
npm init -y
  • Init SST and install the URLShortener component:
npx sst@latest init
npm install @dizzzmas/sst-url-shortener
  • Declare the URL shortener component in sst.config.ts:
/// <reference path="./.sst/platform/config.d.ts" />
import { UrlShortener } from "@dizzzmas/sst-url-shortener";

export default $config({
  app(input) {
    return {
      name: "url-shortener",
      removal: input?.stage === "production" ? "retain" : "remove",
      home: "aws",
    };
  },
  async run() {
    const urlShortener = new UrlShortener({})

    return {
      api: urlShortener.api.url,
    }
  },
});
  • Deploy the app to your personal stage via SST dev mode:
npx sst dev

Notice that our app once deployed returns a URL of an API endpoint. By default the API doesn't require authentication and has Swagger UI enabled. We can visit {api}/ui to access the swagger UI and test our API.

Backend integration via OpenAPI SDK

JS/Python/Go SDKs are available. Below is an example of using the JS SDK to shorten a URL:

Install the SDK in your backend project

npm install @dizzzmas/sst-url-shortener-sdk

Use it:

import SstURLShortener from '@dizzzmas/sst-url-shortener-sdk';

const client = new SstURLShortener({
  baseURL: "YOUR_API_URL",
  bearerToken: undefined // auth disabled in this example
});

async function main() {
  const newUrl = await client.urls.create({
    originalUrl: "https://sst.dev/docs"
  });
  const shortUrl = newUrl.result.shortUrl;
  console.log(shortUrl);  // the shortened URL

  const urls = await client.urls.search({});
  console.log(urls.result);
}

main();

Add as a component to an existing SST app

Install the component:

npm install @dizzzmas/sst-url-shortener

Modify sst.config.ts to include the component:

import { UrlShortener } from "@dizzzmas/sst-url-shortener";

async run() {
  // ...your existing components
  const urlShortener = new UrlShortener({});

  // link URL shortener to another component e.g. a lambda function
  const example = new sst.aws.Function("Example", {
    link: [...urlShortener.link],
    handler: "example.handler",
    url: true,
  })
}

Inside the example.ts Lambda handler:

import { ShortUrl } from "@dizzzmas/sst-url-shortener"

export const handler = async () => {
  const { shortUrl } = await ShortUrl.create({
    originalUrl: "https://sst.dev/docs"
  })
  console.log("new short url", shortUrl)

  const searchResult = await ShortUrl.search({})
  console.log("search results", searchResult)

  return shortUrl
}

Component configuration

Authentication

API bearer authentication is disabled by default and can be enabled via setting enableApiAuth to true on the component.

const shortener = new UrlShortener({
  enableApiAuth: true,
})

Make sure you specify the Bearer token expected by the API for authentication.

The Bearer token can be set via UrlShortenerApiAuthKey SST Secret and defaults to your_secret

npx sst secret set UrlShortenerApiAuthKey "YOUR_TOKEN"

Swagger UI

Swagger UI is enabled by default and can be disabled via settings enableOpenApiDocs to false on the component.

const shortener = new UrlShortener({
  enableOpenApiDocs: false,
})

Custom domain

You can specify a custom domain for the URL shortener and its API.

const shortener = new UrlShortener({
  domain: {
    name: "share.acme.com",
    dns: sst.aws.dns()
  }
})

The above example will results in short URLs looking like https://share.acme.com/etogiyeu, and the API looking like https://api.share.acme.com/ui

Custom domains work out of the box if you use AWS Route53, Cloudflare or Vercel as your DNS provider, but will require manual setup for other providers. Please check out SST Custom Domains docs for more info.

Short id length

Short id is the alphanumeric identifier for your URLs generated using cuid2 e.g. in https://share.acme.com/etogiyeu the short id is etogiyeu

Its length can be anywhere from 4 to 24 characters and defaults to 8.

const shortener = new UrlShortener({
  shortIdLength: 12
})

Transform underlying resources

You can fully customize the underlying resources thanks to the SST Transform feature.

const shortener = new UrlShortener({
  transform: {
    redirectHandler: {
      function: {
        timeout: 30
      }
    }
  }
})

FAQs

Package last updated on 28 Oct 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc