CLI Commands
MK Notes provides two main commands to help you manage your markdown to Notion synchronization:
sync
The sync
command synchronizes a directory of markdown files to a Notion page, creating a matching page hierarchy.
Usage
mk-notes sync -i <directoryPath> -d <notionPageUrl> -k <notionApiKey>
Required Options
-i, --input <directoryPath>
: Path to the directory containing your markdown files-d, --destination <notionPageUrl>
: URL of the parent Notion page where content will be synchronized-k, --notion-api-key <notionApiKey>
: Your Notion API key for authentication
Example
mk-notes sync \
--input ./my-docs \
--destination https://notion.so/myworkspace/doc-123456 \
--notion-api-key secret_abc123...
This command will:
- Read all markdown files in the
./my-docs
directory - Create a matching page hierarchy in Notion
- Convert and sync the content to your specified Notion page
- Display a success message with the Notion page URL when complete
preview-sync
The preview-sync
command lets you preview how your markdown files will be organized in Notion before actually performing the synchronization. This is useful for verifying the structure before making any changes.
Usage
mk-notes preview-sync -i <directoryPath> [options]
Required Option
-i, --input <directoryPath>
: Path to the directory containing your markdown files
Optional Options
-f, --format <format>
: Output format for the previewplainText
(default): Shows a tree-like structurejson
: Outputs the structure in JSON format
-o, --output <output>
: Save the preview to a file instead of displaying it in the terminal
Examples
- Basic preview with default format:
mk-notes preview-sync --input ./my-docs
Output example:
├─ (Your parent Notion Page)
│ ├─ getting-started.md
│ ├─ guides/
│ │ ├─ installation.md
│ │ ├─ configuration.md
│ ├─ api/
│ │ ├─ endpoints.md
│ │ ├─ authentication.md
- Preview in JSON format:
mk-notes preview-sync --input ./my-docs --format json
- Save preview to a file:
mk-notes preview-sync --input ./my-docs --output preview.txt
Tips for Using CLI Commands
-
Directory Structure
- Organize your markdown files in a logical hierarchy
- Use directories to create sections and subsections
- Consider using
index.md
files for section introductions
-
Preview First
- Always use
preview-sync
before running the actual sync - Verify the structure matches your expectations
- Make adjustments to your file organization if needed
- Always use
-
Notion API Key
- Keep your API key secure
- Consider using environment variables for the API key
- Make sure your API key has the necessary permissions
-
Regular Backups
- Consider backing up your Notion pages before large syncs
- Use
preview-sync
to verify changes before updating existing content
For more details about how MK Notes organizes your content, see the Architecture documentation.