The fastify-pdf-export
plugin for Fastify enables the generation and export of PDF files from URLs using Puppeteer.
npm install @autotelic/fastify-pdf-export
import Fastify from 'fastify'
import fastifyPdfExport from 'fastify-pdf-export'
const fastify = Fastify()
fastify.register(fastifyPdfExport)
fastify.get('/', async (request, reply) => {
const { pdfExport } = fastify
const { pdf } = await pdfExport({
pdfUrl: 'http://example.com'
})
reply.type('application/pdf').send(pdf)
})
fastify.listen({ port: 3000 }, err => {
if (err) throw err
console.log(`Server listening on ${fastify.server.address().port}`)
})
The fastify-pdf-export
plugin extends your Fastify instance with a new method: pdfExport
. This method is used to generate PDFs from provided URLs using Puppeteer.
Generates a PDF from the specified URL.
pdfUrl
(string): Required.The URL of the webpage to be converted into a PDF.pdfOptions
(PDFOptions
): Optional. Configuration options for the PDF generation, as defined by Puppeteer'sPDFOptions
. This includes settings such asformat
,margin
,printBackground
, etc.launchOptions
(BrowserLaunchArgumentOptions
): Optional. Configuration options for launching the Puppeteer browser instance, as defined by Puppeteer'sBrowserLaunchArgumentOptions
. This includes settings such asheadless
,args
,ignoreHTTPSErrors
, etc. By default,headless
is set tonew
.
A promise that resolves to an object containing:
pdf
: ABuffer
containing the generated PDF data.error
: An error object, if any error occurred during the PDF generation process.
const { pdf, error } = await fastify.pdfExport({
pdfUrl: 'http://example.com',
pdfOptions: { format: 'A4' },
launchOptions: { headless: 'new' }
});