Skip to content

mnapoli/serverless-pdf-generator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PDF generator built as a serverless application.

Runs on AWS Lambda, built with the Serverless Framework and Lift.

Why?

This is a small application that turns web pages into PDF.

  • Turns HTML pages to PDF using Chrome Headless and Puppeteer
  • Runs on AWS Lambda: extremely cheap, deploys in 1 minute, scales automatically
  • Generated PDFs are cached in AWS S3 to be served faster

This allows to generate PDF files by simply implementing web pages in your application.

Clear and simple API for your application:

https://123456.execute-api.us-east-1.amazonaws.com/pdf?url=<URL to export>

Demo

Try the live demo:

https://7f3oaopd3c.execute-api.us-east-1.amazonaws.com/pdf?url=https://bref.sh/docs/

☝️ the link above will export the bref.sh/docs/ page into a PDF.

Feel free to change the URL to export. However, the demo only allows generating PDF from the bref.sh domain.

Deployment

The URL of the deployed application should display in the terminal.

Usage

Call the application's URL and append the ?url= query parameter with the URL of the page you wish to export.

For example:

https://123456.execute-api.us-east-1.amazonaws.com/pdf?url=https://mywebsite.com/

The exported PDF will be returned.

Force regeneration

PDF are generated on the first HTTP call and cached into S3. That makes subsequent responses much faster.

To force regenerating the PDF (for example if the web page has changed), add the force=1 query parameter to the URL.

Configuration

Change the DOMAIN_WHITELIST environment variable to set the whitelisted domains.

Indeed, to avoid abuse, the application will only generate PDFs from pre-approved domain names.

About

Serverless PDF generator

Topics

Resources

Stars

Watchers

Forks