Draft blog posts, LinkedIn posts, release notes, and newsletters in your team's house voice without leaving Slack.

A Slack-based content assistant built on Eve. Writers @mention it in Slack and it drafts blog posts, LinkedIn posts, release notes, and newsletters in your house voice, pulling source material from Notion and publishing approved pieces back to Notion as the signed-in writer.
Deploying with the button provisions everything the agent needs and wires it up for you:
SLACK_CONNECTOR, with the event trigger pointed at
/eve/v1/slack),NOTION_CONNECTOR),Once deployed, @mention the bot in your Slack workspace to start drafting.
| Layer | Technology |
|---|---|
| Agent framework | Eve |
| Language | TypeScript (strict, ESM) |
| Chat surface | Slack, via Vercel Connect |
| Source & publishing | Notion (MCP), user-scoped OAuth via Vercel Connect |
| File storage | Vercel Blob, authenticated by OIDC |
| Model access | Vercel AI Gateway (default: Claude Opus 4.8) |
| Sandbox | Vercel Sandbox |
| Lint & format | Ultracite (Biome) |
Zero static keys. Authentication runs entirely on Vercel Connect
(Slack and Notion) and Vercel OIDC (Vercel Blob and AI
Gateway). There are no API keys or client secrets to manage in code or .env files: Notion is
authorized per writer in the browser, and Blob and the model authenticate with the project's
OIDC token.
agent/agent.ts # model configurationinstructions.md # the agent's behaviorchannels/slack.ts # Slack surface (Vercel Connect credentials)connections/notion.ts # Notion workspace, user-scoped OAuth via Vercel Connectsandbox.ts # Vercel Sandbox backendtools/lint_against_style.ts # deterministic banned-words checkupload_asset.ts # Vercel Blob: store text or binary contentlist_assets.ts # Vercel Blob: browse stored assetsget_asset_info.ts # Vercel Blob: metadata without downloadingdownload_asset.ts # Vercel Blob: read a stored file backdelete_asset.ts # Vercel Blob: delete (requires approval)skills/blog-style/ # voice, structure, and a canonical example postlinkedin-style/release-notes-style/newsletter-style/
Link the project you deployed (or a fresh one) and pull its environment:
vercel linkvercel env pull
Then run the development server and link a model provider with /model in the TUI:
pnpm dev
You can chat with the agent directly in the dev TUI to test the drafting, style-lint, Notion, and Blob flows. The Slack surface itself only runs against a deployment. Ship changes with:
eve deploy
This project uses Ultracite (a Biome preset) for linting and formatting:
pnpm check # check formatting and lint rulespnpm fix # auto-fix what is fixable
The Deploy button provisions these for you. To set them up manually (for a project you didn't create with the button), use the Vercel CLI:
# Notion connector (note the printed UID, e.g. mcp.notion.com/notion -> NOTION_CONNECTOR)vercel connect create mcp.notion.com --name notion# Slack connector (note the UID, e.g. slack/<name> -> SLACK_CONNECTOR), then point its# event trigger at the route the agent servesvercel connect create slack --name <name> --triggersvercel connect attach slack/<name> --triggers --trigger-path /eve/v1/slack# Blob store, connected to the project for all environmentsvercel blob create-store <name> --access public --yes
agent/skills/*/SKILL.md, and the
references/banned-words.json each one lints against. Add a new surface by adding a new
skill folder.agent/instructions.md.agent/agent.ts (or run /model in the dev TUI).agent/tools/. The filename is the tool name.The agent auto-updates as you edit these files.