> postmark
Send transactional emails with Postmark. Use when a user asks to send reliable transactional emails, improve email deliverability, use email templates with variables, or set up email sending for a SaaS app.
curl "https://skillshub.wtf/TerminalSkills/skills/postmark?format=md"Postmark
Overview
Postmark is an email delivery service focused on transactional emails (password resets, receipts, notifications). It has the highest deliverability rates in the industry (99%+ inbox placement), dedicated IP pools for transactional vs marketing, and built-in email templates.
Instructions
Step 1: Send with Node.js
// lib/postmark.ts — Postmark client
import { ServerClient } from 'postmark'
const client = new ServerClient(process.env.POSTMARK_API_TOKEN!)
// Send with HTML
await client.sendEmail({
From: 'notifications@myapp.com',
To: 'user@example.com',
Subject: 'Your order has shipped',
HtmlBody: '<h1>Order Shipped!</h1><p>Tracking: ABC123</p>',
TextBody: 'Order Shipped! Tracking: ABC123',
MessageStream: 'outbound', // 'outbound' for transactional, 'broadcast' for marketing
})
// Send with template
await client.sendEmailWithTemplate({
From: 'notifications@myapp.com',
To: 'user@example.com',
TemplateAlias: 'order-shipped',
TemplateModel: {
customer_name: 'Alice',
order_id: 'ORD-2025-001',
tracking_number: 'ABC123',
tracking_url: 'https://track.example.com/ABC123',
items: [
{ name: 'Widget Pro', quantity: 2, price: '$29.99' },
{ name: 'Gadget Plus', quantity: 1, price: '$49.99' },
],
},
MessageStream: 'outbound',
})
Step 2: Batch Sending
// Send up to 500 emails in one API call
await client.sendEmailBatch([
{
From: 'billing@myapp.com',
To: 'user1@example.com',
Subject: 'Invoice #INV-001',
HtmlBody: renderInvoice(invoice1),
Tag: 'invoice',
},
{
From: 'billing@myapp.com',
To: 'user2@example.com',
Subject: 'Invoice #INV-002',
HtmlBody: renderInvoice(invoice2),
Tag: 'invoice',
},
])
Step 3: Inbound Email Processing
// Postmark can forward inbound emails to your webhook
// POST /webhooks/inbound-email
export async function handleInboundEmail(req) {
const { From, Subject, TextBody, Attachments } = req.body
// Process support emails
await createSupportTicket({
from: From,
subject: Subject,
body: TextBody,
attachments: Attachments.map(a => ({
name: a.Name,
content: Buffer.from(a.Content, 'base64'),
})),
})
}
Guidelines
- Postmark separates transactional and marketing streams — transactional emails get priority delivery.
- Use server-side templates for consistent formatting; use React Email for complex layouts.
- Tags help track email categories (invoice, welcome, password-reset) in analytics.
- Postmark's bounce and spam complaint handling is automatic — it removes bad addresses.
- Free tier: 100 emails/month. Paid: $15/month for 10,000 emails.
> related_skills --same-repo
> zustand
You are an expert in Zustand, the small, fast, and scalable state management library for React. You help developers manage global state without boilerplate using Zustand's hook-based stores, selectors for performance, middleware (persist, devtools, immer), computed values, and async actions — replacing Redux complexity with a simple, un-opinionated API in under 1KB.
> zod
You are an expert in Zod, the TypeScript-first schema declaration and validation library. You help developers define schemas that validate data at runtime AND infer TypeScript types at compile time — eliminating the need to write types and validators separately. Used for API input validation, form validation, environment variables, config files, and any data boundary.
> xero-accounting
Integrate with the Xero accounting API to sync invoices, expenses, bank transactions, and contacts — and generate financial reports like P&L and balance sheet. Use when: connecting apps to Xero, automating bookkeeping workflows, syncing accounting data, or pulling financial reports programmatically.
> windsurf-rules
Configure Windsurf AI coding assistant with .windsurfrules and workspace rules. Use when: customizing Windsurf for a project, setting AI coding standards, creating team-shared Windsurf configurations, or tuning Cascade AI behavior.