PDF Utilities MCP
Allows AI assistants like GitHub Copilot to read, create, merge, split, and edit PDF files through natural language commands.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@PDF Utilities MCPRead report.pdf"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
PDF Utilities MCP
A VS Code extension that provides comprehensive PDF manipulation tools for GitHub Copilot Chat via Model Context Protocol (MCP).
Overview
This project combines an MCP server with a VS Code extension to enable AI assistants like GitHub Copilot to work with PDF files through natural language commands. Users can read, create, merge, split, and edit PDFs directly from their chat interface.
Architecture
pdf-utilities-mcp/
├── src/ # MCP Server implementation
│ ├── index.ts # Server entry point and tool registration
│ └── pdf-tools.ts # PDF manipulation utilities
├── extension/ # VS Code Extension
│ ├── src/
│ │ ├── extension.ts # Extension activation and MCP integration
│ │ └── types.ts # TypeScript type definitions
│ ├── resources/
│ │ └── instructions/ # Copilot Chat instruction files
│ └── mcp-server/ # Built MCP server (copied from ../dist)
└── dist/ # Compiled MCP server outputFeatures
📖 Read PDFs: Extract text content with optional page range selection
📊 Get Info: Retrieve metadata (pages, title, author, size, etc.)
✍️ Create PDFs: Generate new PDFs from text with formatting options
🔗 Merge: Combine multiple PDF files into one
✂️ Split: Extract specific pages or ranges
📝 Update Metadata: Modify title, author, subject, keywords
📄 Extract Pages: Save individual pages as separate files
Installation
For Users
Install from VS Code Marketplace:
Open VS Code
Search for "PDF Utilities" in Extensions
Click Install
For Developers
# Clone the repository
git clone https://github.com/GleidsonFerSanP/pdf-utilities-mcp.git
cd pdf-utilities-mcp
# Install MCP server dependencies
npm install
# Build MCP server
npm run build
# Install extension dependencies
cd extension
npm install
# Build extension
npm run compile
# Copy MCP server to extension
cd ..
npm run copy-to-extensionDevelopment
Project Structure
MCP Server ( src/ ):
Uses @modelcontextprotocol/sdk for standardized tool interface
Implements 7 PDF tools using pdf-lib and pdf-parse
Runs as Node.js process via stdio transport
VS Code Extension ( extension/ ):
Registers MCP server with VS Code's lm.registerMcpServerDefinitionProvider
Provides commands for configuration and server management
Includes chat instructions for optimal Copilot integration
Building
# Build MCP server
npm run build
# Build extension
cd extension
npm run compile
# Copy server to extension folder
cd ..
npm run copy-to-extensionTesting
# Test MCP server directly
node dist/index.js
# Package extension for testing
cd extension
npm run package # Creates .vsix file
# Install .vsix in VS Code for testing
# Extensions > ... > Install from VSIXDevelopment Workflow
Make changes to MCP server in
src/Run
npm run buildto compileRun
npm run copy-to-extensionto update extensionReload VS Code window to test changes
Check logs in Output panel > "PDF Utilities"
Publishing
Prerequisites
Create VS Code Publisher account at https://marketplace.visualstudio.com/
Generate Personal Access Token (PAT)
Update
extension/.envwith your PAT
Publish Steps
# Build everything
npm run build
cd extension
npm run compile
cd ..
npm run copy-to-extension
# Package extension
cd extension
npm run package
# Verify the .vsix file works
# Install it manually in VS Code and test
# Publish to marketplace
npm run publishVersion Management
Update version in both:
package.json(root)extension/package.json
Follow semantic versioning: MAJOR. MINOR. PATCH
Configuration
Extension Settings
pdfUtilities.autoStart: Auto-start MCP server (default: true)pdfUtilities.logLevel: Logging verbosity (default: info)pdfUtilities.maxPdfSize: Maximum file size in MB (default: 50)
MCP Server Configuration
The MCP server is configured via the extension and doesn't require separate configuration.
API Documentation
Tool: read_pdf
Extract text from PDF file.
Parameters:
filePath(string, required): Absolute path to PDFpageRange(string, optional): Pages to extract (e.g., "1-5", "1, 3, 5-10")
Returns:
{
text: string;
pages: number;
info: PDFInfo;
}Tool: get_pdf_info
Get PDF metadata and information.
Parameters:
filePath(string, required): Absolute path to PDF
Returns:
{
pages: number;
title?: string;
author?: string;
subject?: string;
creator?: string;
producer?: string;
creationDate?: Date;
modificationDate?: Date;
fileSize: number;
filePath: string;
}Tool: create_pdf
Create new PDF from text content.
Parameters:
content(string, required): Text contentoutputPath(string, required): Save locationoptions(object, optional): Formatting optionstitle,author,subject(string): MetadatafontSize(number): Text size (default: 12)pageSize(string): Page size (default: "A4")
Returns:
{
success: boolean;
path: string;
pages: number;
}Tool: merge_pdfs
Combine multiple PDFs.
Parameters:
filePaths(string[], required): PDFs to mergeoutputPath(string, required): Output location
Returns:
{
success: boolean;
path: string;
pages: number;
}Tool: split_pdf
Extract pages to new PDF.
Parameters:
filePath(string, required): Source PDFpageRange(string, required): Pages to extractoutputPath(string, required): Output location
Returns:
{
success: boolean;
path: string;
pages: number;
}Tool: update_pdf_metadata
Modify PDF metadata.
Parameters:
filePath(string, required): PDF to updatemetadata(object, required): Fields to updatetitle,author,subject,keywords(string)
outputPath(string, optional): Save location (defaults to overwrite)
Returns:
{
success: boolean;
path: string;
}Tool: extract_pages
Extract pages to separate files.
Parameters:
filePath(string, required): Source PDFpages(number[], required): Page numbers to extractoutputDir(string, required): Output directoryprefix(string, optional): Filename prefix (default: "page")
Returns:
{
success: boolean;
files: string[];
}Troubleshooting
MCP Server Not Starting
Check Output panel:
View > Output > Select "PDF Utilities"Look for initialization messages. If server fails:
Verify
mcp-server/index.jsexists in extension folderRun rebuild:
npm run build && npm run copy-to-extensionReload VS Code
Tools Not Available in Copilot
Ensure extension is activated (check Extensions panel)
Verify MCP API is available (requires VS Code 1.85+)
Check that Copilot Chat is enabled
Restart Copilot: Command Palette > "GitHub Copilot: Restart Language Server"
Build Errors
Common issues:
TypeScript errors: Run
npm installin both root and extension foldersMissing dependencies:
npm installin correct directoryPath issues: Use
npm run copy-to-extensionto sync files
Contributing
Fork the repository
Create a feature branch
Make your changes
Add tests if applicable
Submit a pull request
Please follow existing code style and conventions.
License
MIT License - see LICENSE file for details.
Support
Credits
Built with Model Context Protocol
Icon design: Custom SVG
Note: This project requires GitHub Copilot Chat and VS Code 1.85+ with MCP support.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/GleidsonFerSanP/pdf-utilities-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server