| name | notion |
|---|---|
| description | Manage Notion pages, databases, and comments from the command line. Search, view, create, and edit content in your Notion workspace. |
| allowed-tools | Bash(notion-cli:*) |
A CLI to manage Notion from the command line, using Notion's remote MCP server.
The notion-cli command must be available on PATH. To check:
notion-cli versionIf not installed:
go install github.com/lox/notion-cli@latestOr see: https://github.com/lox/notion-cli
The CLI uses OAuth authentication for MCP-backed commands. On first use, it opens a browser for authorization:
notion-cli auth login # Authenticate with Notion
notion-cli auth status # Check authentication status
notion-cli auth list # Show local profiles and auth state
notion-cli auth use work # Persist the active profile
notion-cli auth refresh # Refresh token if status shows expired token
notion-cli auth logout # Clear credentials
notion-cli --profile work auth login
notion-cli --profile work auth api setupFor CI/headless environments, set NOTION_ACCESS_TOKEN. To isolate credentials per workspace/account, pass --profile <name> or set NOTION_PROFILE.
Some fallback features also use the official Notion API:
notion-cli auth api setup
notion-cli auth api status
notion-cli auth api verify
notion-cli auth api unsetFor CI/headless environments, set NOTION_API_TOKEN.
notion-cli auth # Manage authentication
notion-cli page # Manage pages (list, view, create, upload, edit)
notion-cli db # Manage databases (list, query, create entries)
notion-cli search # Search the workspace
notion-cli comment # Manage comments (list, create)
notion-cli tools # List available MCP tools
notion-cli search "meeting notes" # Search workspace
notion-cli search "project" --limit 5 # Limit results
notion-cli search "query" --json # JSON outputAll page commands accept a URL, name, or ID to identify pages.
# List pages
notion-cli page list
notion-cli page list --limit 10
notion-cli page list --json
# View a page (renders as markdown in terminal)
notion-cli page view <page>
notion-cli page view <page> --no-comments # Hide page and block comments
notion-cli page view <page> --raw # Show raw Notion markup
notion-cli page view <page> --json # JSON output
notion-cli page view "Meeting Notes" # By name
notion-cli page view https://notion.so/... # By URL
# Create a page
notion-cli page create --title "New Page"
notion-cli page create --title "Doc" --content "# Heading\n\nContent here"
notion-cli page create --title "Child" --parent "Engineering" # Parent by name
notion-cli page create --title "Child" --parent <page-id> # Parent by ID
# Upload a markdown file as a page
notion-cli page upload ./document.md
notion-cli page upload ./doc.md --title "Custom Title"
notion-cli page upload ./doc.md --parent "Parent Page Name"
notion-cli page upload ./doc.md --parent-db <db-id> # Upload as database entry
# Sync a markdown file (create or update)
# First run creates the page and writes notion-id to the file's frontmatter.
# Subsequent runs update the page content using the stored notion-id.
notion-cli page sync ./document.md
notion-cli page sync ./document.md --parent "Engineering" # Set parent on first sync
notion-cli page sync ./document.md --parent-db <db-id> # Sync as database entry
notion-cli page sync ./document.md --title "Custom Title"
# Edit a page
notion-cli page edit <page> --replace "New content"
notion-cli page edit <page> --find "old text" --replace-with "new text"
notion-cli page edit <page> --find "section" --append "additional content"For page upload and page sync, standalone local markdown image lines like  are uploaded natively through the official API when configured. Local images must appear on their own line. Inline or mixed-content local image syntax is rejected.
page view shows open page-level comments and inline block discussions by default. Inline discussions are rendered beside their anchor text, with the anchor wrapped in [[...]] and the discussion shown immediately below it. Use --no-comments when you only want the page body, --raw to inspect the original Notion markup, and --json when an agent needs the page plus the Comments array.
page edit supports these mutually exclusive modes:
--replace "..."for full-page replacement.--find "..." --replace-with "..."for targeted replacement.--find "..." --append "..."for append-after-match.
When a targeted edit fails (for example MCP validation errors), fall back to full replacement by fetching content, editing locally, then applying --replace.
All database commands accept a URL, name, or ID to identify databases.
# List databases
notion-cli db list # List databases
notion-cli db list -q "project" # Filter by name
notion-cli db list --json
# Query a database
notion-cli db query <database-url-or-id> # Query a database
notion-cli db query <id> --json
# Create an entry in a database
notion-cli db create <database> --title "Entry Title"
notion-cli db create <database> -t "Title" --prop "Status=Not started"
notion-cli db create <database> -t "Title" --prop "date:Due:start=2026-03-01"
notion-cli db create <database> -t "Title" --content "Body text"
notion-cli db create <database> -t "Title" --file ./notes.md # Body from file
notion-cli db create <database> -t "Title" --jsonProperty format: Use --prop Key=Value for text/status properties. Date properties use expanded keys: --prop "date:Date Field:start=2026-01-15".
notion-cli comment list <page> # List open page and block comments
notion-cli comment list <page> --resolved # Include resolved discussions too
notion-cli comment list <page> --json
notion-cli comment list "Meeting Notes" # Resolve a page by name
notion-cli comment create <page> --content "Great work!"
notion-cli comment create https://notion.so/... --content "Looks good"The comment commands accept a page URL, ID, or name. comment list includes both page-level and block-level discussions by default and only shows open discussions unless --resolved is passed.
Most commands support --json for machine-readable output:
notion-cli page list --json | jq '.[0].url'
notion-cli search "api" --json | jq '.[] | .title'- Search first - Use
notion-cli searchto find pages before operating on them - Use URLs, names, or IDs - All page commands and comment commands resolve pages from any of these forms
- Explicit parent types - Use
--parentfor page parents,--parent-dbfor database parents onpage sync/page upload - Query databases first - Use
notion-cli db query <id>to see the schema and property types before creating entries - Check --help - Every command has detailed help:
notion-cli page edit --help - Inline comments by default -
page viewincludes open page comments and inline block discussions unless--no-commentsis set - Raw output - Use
--rawwithpage viewto see the original Notion markup - JSON for parsing - Use
--jsonwhen you need to extract specific fields, including theCommentsarray frompage view - Auth preflight - Run
notion-cli auth status --jsonbefore a multi-step workflow and refresh/login if needed - API fallback preflight - Run
notion-cli auth api verifybefore workflows that need local image upload - Error handling - If a targeted
page editcall fails, rerun with--replaceas a safe fallback