n8n-nodes-pdf-split-merge
v2.0.0
Published
n8n community node to merge and split PDFs using the PDF API Hub
Maintainers
Readme

n8n-nodes-pdf-split-merge
PDF Split & Merge for n8n using the PDF API Hub.
This package adds a node that can:
- Merge multiple PDF URLs into a single PDF
- Split a PDF with a configurable mode (e.g., "each")
Authentication and base URL: the CLIENT-API-KEY is sent as a header to https://pdfapihub.com/api/v1.
Quick Start
[!TIP] New to building n8n nodes? The fastest way to get started is with
npm create @n8n/node. This command scaffolds a complete node package for you using the @n8n/node-cli.
To create a new node package from scratch:
npm create @n8n/nodeDevelop locally:
npm run devThis starts n8n with your nodes loaded and hot reload enabled.
Credentials
Create a credential of type "PDF API Hub" and set your API key. The node sends:
- Header:
CLIENT-API-KEY: <your-key> - Content-Type:
application/json
[!TIP] The declarative/low-code style (used in GitHub Issues) is the recommended approach for building nodes that interact with HTTP APIs. It significantly reduces boilerplate code and handles requests automatically.
Browse these examples to understand both approaches, then modify them or create your own.
Node Operations
The node exposes two operations:
- Merge PDF
- Endpoint:
POST https://pdfapihub.com/api/v1/pdf/merge - Parameters:
URLs(array of strings) — list of PDF URLs to mergeOutput Format(url/file) — return URL or download file
- Returns: merged PDF URL or file
- Endpoint:
- Split PDF
- Endpoint:
POST https://pdfapihub.com/api/v1/pdf/split - Parameters:
PDF URL(string) — the PDF to splitSplit Type(pages/each/chunks) — how to split the PDFPages(string) — specific pages to extract (e.g., "1-3,5")Number of Chunks(number) — number of chunks to split intoOutput Format(url/file) — return URLs or download files/ZIP
- Returns: split PDF URLs or files
- Endpoint:
These are excellent resources to understand how to structure your nodes, handle different API patterns, and implement advanced features.
Prerequisites
Before you begin, install the following on your development machine:
Required
- Node.js (v22 or higher) and npm
- Linux/Mac/WSL: Install via nvm
- Windows: Follow Microsoft's NodeJS guide
- git
Recommended
- Follow n8n's development environment setup guide
[!NOTE] The
@n8n/node-cliis included as a dev dependency and will be installed automatically when you runnpm install. The CLI includes n8n for local development, so you don't need to install n8n globally.
Getting Started with this Starter
Follow these steps to create your own n8n community node package:
1. Create Your Repository
Generate a new repository from this template, then clone it:
git clone https://github.com/<your-organization>/<your-repo-name>.git
cd <your-repo-name>2. Install Dependencies
npm installThis installs all required dependencies including the @n8n/node-cli.
Develop and Test Locally
Start n8n with your node loaded:
npm run devThis command runs n8n-node dev which:
- Builds your node with watch mode
- Starts n8n with your node available
- Automatically rebuilds when you make changes
- Opens n8n in your browser (usually http://localhost:5678)
You can now test your node in n8n workflows!
[!NOTE] Learn more about CLI commands in the @n8n/node-cli documentation.
Lint Your Code
Check for errors:
npm run lintAuto-fix issues when possible:
npm run lint:fixBuild for Production
When ready to publish:
npm run buildThis compiles your TypeScript code to the dist/ folder.
Prepare for Publishing
Before publishing:
- Update documentation: Replace this README with your node's documentation. Use README_TEMPLATE.md as a starting point.
- Update the LICENSE: Add your details to the LICENSE file.
- Test thoroughly: Ensure your node works in different scenarios.
Publish to npm
Publish your package to make it available to the n8n community:
npm publishLearn more about publishing to npm.
Submit for Verification (Optional)
Get your node verified for n8n Cloud:
Ensure your node meets the requirements:
- Uses MIT license ✅ (included in this starter)
- No external package dependencies
- Follows n8n's design guidelines
- Passes quality and security review
Submit through the n8n Creator Portal
Benefits of verification:
- Available directly in n8n Cloud
- Discoverable in the n8n nodes panel
- Verified badge for quality assurance
- Increased visibility in the n8n community
Available Scripts
This starter includes several npm scripts to streamline development:
| Script | Description |
| --------------------- | ---------------------------------------------------------------- |
| npm run dev | Start n8n with your node and watch for changes (runs n8n-node dev) |
| npm run build | Compile TypeScript to JavaScript for production (runs n8n-node build) |
| npm run build:watch | Build in watch mode (auto-rebuild on changes) |
| npm run lint | Check your code for errors and style issues (runs n8n-node lint) |
| npm run lint:fix | Automatically fix linting issues when possible (runs n8n-node lint --fix) |
| npm run release | Create a new release (runs n8n-node release) |
[!TIP] These scripts use the @n8n/node-cli under the hood. You can also run CLI commands directly, e.g.,
npx n8n-node dev.
Troubleshooting
My node doesn't appear in n8n
- Make sure you ran
npm installto install dependencies - Check that your node is listed in
package.jsonundern8n.nodes - Restart the dev server with
npm run dev - Check the console for any error messages
Linting errors
Run npm run lint:fix to automatically fix most common issues. For remaining errors, check the n8n node development guidelines.
TypeScript errors
Make sure you're using Node.js v22 or higher and have run npm install to get all type definitions.
Resources
- n8n Node Documentation - Complete guide to building nodes
- n8n Community Forum - Get help and share your nodes
- @n8n/node-cli Documentation - CLI tool reference
- n8n Creator Portal - Submit your node for verification
- Submit Community Nodes Guide - Verification requirements and process
Contributing
Have suggestions for improving this starter? Open an issue or submit a pull request!
