
Security News
The Hidden Blast Radius of the Axios Compromise
The Axios compromise shows how time-dependent dependency resolution makes exposure harder to detect and contain.
@itaylor/markdowner
Advanced tools
Convert various file formats to markdown using AI and specialized converters
Convert various file formats to markdown using AI and specialized converters.
For AI features (choose one):
Option 1: OpenAI (or compatible services):
# Get API key from OpenAI, or use any OpenAI-compatible service
export OPENAI_API_KEY="your-api-key-here"
Option 2: Ollama (local):
# Install Ollama
curl -fsSL https://ollama.com/install.sh | sh
# Pull model and start server
ollama pull gemma3:27b
ollama serve
# Convert file to markdown (uses local Ollama by default)
markdowner document.pdf
# Save to file
markdowner document.pdf -o output.md
# Use OpenAI
markdowner document.pdf \
--openai-base-url https://api.openai.com/v1 \
--openai-api-key $OPENAI_API_KEY \
--openai-model gpt-4-vision-preview
# Use Ollama on remote server
markdowner document.pdf \
--openai-base-url http://remote:11434/v1 \
--openai-api-key ollama \
--openai-model gemma3:27b
# Legacy Ollama syntax (still supported)
markdowner file.pdf --ollama-url http://localhost:11434
# Disable AI (faster, basic extraction for pdfs, images will throw)
markdowner document.pdf --no-ai
import { markdowner } from 'markdowner';
// With OpenAI
const markdown = await markdowner('./document.pdf', {
openai: {
baseURL: 'https://api.openai.com/v1',
apiKey: process.env.OPENAI_API_KEY,
model: 'gpt-4-vision-preview',
},
});
// With Ollama using OpenAI-compatible API
const markdown = await markdowner('./document.pdf', {
openai: {
baseURL: 'http://localhost:11434/v1',
apiKey: 'ollama', // required but unused
model: 'gemma3:27b',
},
});
// Legacy Ollama syntax (still supported)
const markdown = await markdowner('./document.pdf', {
ollamaUrl: 'http://localhost:11434',
});
// Without AI (faster, basic extraction only)
const markdown = await markdowner('./document.pdf', {});
FAQs
Convert various file formats to markdown using AI and specialized converters
We found that @itaylor/markdowner demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

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.

Security News
The Axios compromise shows how time-dependent dependency resolution makes exposure harder to detect and contain.

Research
A supply chain attack on Axios introduced a malicious dependency, plain-crypto-js@4.2.1, published minutes earlier and absent from the project’s GitHub releases.

Research
Malicious versions of the Telnyx Python SDK on PyPI delivered credential-stealing malware via a multi-stage supply chain attack.