Journal Mandala MCP
This MCP server allows Claude to read and write journal entries and todos on Journal Mandala directly from conversations.
add_journal_entry: Create a new journal entry with optionaltitle(auto-generated if omitted),event(what happened),thought(how you felt),entry_date(YYYY-MM-DD, defaults to today in JST),entry_time(HH:MM),tags(array of strings), andstar_rating(1–5). At least one oftitle,event, orthoughtis required.find_entries: Retrieve recent journal entries (default 20, max 100), sorted by updated order — useful for obtaining entry IDs for further actions.update_entry: Partially update an existing entry by its ID, supporting the same fields asadd_journal_entryandadd_todo.add_todo: Create a new todo item with a requiredtitle, optionalthought(notes),entry_date,due_date,status(pending,in_progress,completed,cancelled),todo_points(estimated effort), andtags.
Additional features:
Multi-account support via multiple API keys, selectable through natural language.
Optional
JOURNAL_MANDALA_API_URLenvironment variable to override the default API endpoint.Compatible with Claude Desktop and Claude Code via the MCP protocol.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Journal Mandala MCPRecord today's team meeting and my thoughts about the project progress"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Journal Mandala MCP
Journal Mandala に Claude から直接日記エントリを書き込むための MCP サーバーです。
「思考の流れ」を会話の途中でマンダラに刻みたいときに使います。
必要なもの
Node.js 20+
Claude Desktop (または Claude Code)
Journal Mandala の API キー (発行方法は「APIキーの取得」参照)
インストール
npm でグローバルにインストールします。
npm install -g --install-links github:takezone/journal-mandala-mcp--install-links は必須(付けないと一時ディレクトリへのsymlinkになって起動できなくなる)。
更新するときも同じコマンドを再実行。もし過去に --install-links なしで入れて壊れている場合は:
npm uninstall -g journal-mandala-mcp
# 残骸掃除 (npm prefix は `npm prefix -g` で確認)
rm -rf $(npm prefix -g)/lib/node_modules/journal-mandala-mcp
rm -rf $(npm prefix -g)/lib/node_modules/.journal-mandala-mcp-*
npm install -g --install-links github:takezone/journal-mandala-mcpClaude Desktop の設定
~/Library/Application Support/Claude/claude_desktop_config.json (macOS) を編集:
1アカウント運用
{
"mcpServers": {
"journal-mandala": {
"command": "journal-mandala-mcp",
"env": {
"JOURNAL_MANDALA_API_KEY": "jm_XXXXXXXXXXXXXXXXXXXXXXXX"
}
}
}
}2アカウント(personal / work)を切り替えたい場合
{
"mcpServers": {
"journal-mandala-personal": {
"command": "journal-mandala-mcp",
"env": {
"JOURNAL_MANDALA_API_KEY": "jm_PERSONAL_KEY"
}
},
"journal-mandala-work": {
"command": "journal-mandala-mcp",
"env": {
"JOURNAL_MANDALA_API_KEY": "jm_WORK_KEY"
}
}
}
}それぞれ別ツールとして Claude から見えます。「work に記録して」のように自然言語で切り替え可能。
設定後は Claude Desktop を再起動。
APIキーの取得
現在は Journal Mandala 管理者(@takezone)に以下を伝えて発行してもらってください:
自分の Google アカウントのメールアドレス
ラベル名(例:
alice-personal)
管理者から API キーが送られてきたら、上の設定の JOURNAL_MANDALA_API_KEY にコピペします。
Note: 将来的にブラウザで自動発行できる予定です。
使い方
Claude との会話で「今日の出来事をジャーナルに記録して」のように依頼すると、add_journal_entry ツールが呼ばれて Journal Mandala にエントリが追加されます。
提供ツール:
add_journal_entry — 日記エントリ追加
titleタイトル(省略可)event出来事(何があったか)thought思考(どう感じたか)entry_date日付YYYY-MM-DD(省略時は JST 今日)entry_time時刻HH:MMtagsタグ配列 — 文字列の配列として渡すこと✅ 正:
["仕事", "運動"]❌ 誤:
["[\"仕事\",\"運動\"]"](JSON 文字列化した配列を1要素にしない)
star_rating1-5 評価
find_entries — 最近のエントリ一覧
id を取得する目的で使う。直近更新順で返す。
limit取得件数 (デフォルト 20、最大 100)
update_entry — 既存エントリ更新
id 指定で部分更新。指定したフィールドのみ上書き、省略したフィールドは維持。
id必須他は
add_journal_entry/add_todoと同じフィールドが全て任意指定可能
使い方: find_entries で id を調べる → update_entry で更新
add_todo — Todo 追加
titleタスク名(必須)thoughtタスクに関するメモ(任意)entry_date作成日(省略時は JST 今日)due_date期限日YYYY-MM-DD(任意)todo_statuspending|in_progress|completed|cancelled(省略時 pending)todo_points見積もりポイント(任意)is_today今日やるリストフラグ(任意)tagsタグ配列1: 微妙・ネガティブな出来事2: 普通の1日(デフォルト)3: そこそこ良いことがあった日4: かなり良いことがあった日5: 人生の一大イベント級安易に 5 を付けない。基本は 2、良いことがあれば 3 or 4
title / event / thought のいずれか1つは必須です。
オプション環境変数
JOURNAL_MANDALA_API_URL— APIエンドポイント (デフォルト:https://journal-mandala.vercel.app)
トラブルシューティング
Claude にツールが表示されない → 設定ファイルのJSON構文エラーの可能性。Claude Desktop の Developer メニューで MCP ログを確認
API エラー 401 →
JOURNAL_MANDALA_API_KEYが無効。管理者に再発行を依頼ネットワークエラー → Vercel の稼働状況を確認
管理者向け: APIキーの管理と復旧
運用者がキーを紛失した時の参考。このMCPはVercel側に保存された正本を参照するので、~/.claude.json のコピーが消えても復旧できる。
3層構造
層 | 場所 | 役割 |
サーバー env var | Vercel | 初期seedの静的アカウント配列(正本) |
サーバー KV | Vercel KV (Upstash Redis) |
|
クライアント |
| 認証用のキーコピー(失くしても再取得可) |
API認証時は KV → env var の順に照合される。
復旧手順(プロジェクトオーナー)
プロジェクトディレクトリ(journal-mandala 本体)で:
# Vercel プロジェクトと連携(初回のみ)
vercel link --yes --project journal-mandala
# サーバー環境変数をローカルに取得
vercel env pull .env.vercel
# env var 内のキー確認
grep JM_API_ACCOUNTS .env.vercel
# KV 内のキー一覧スキャン
source .env.vercel
curl -s "${KV_REST_API_URL}/scan/0/match/jm:account:*/count/100" \
-H "Authorization: Bearer ${KV_REST_API_TOKEN}"
# 特定アカウントの中身を見る
curl -s "${KV_REST_API_URL}/get/jm:account:jm_XXXXX" \
-H "Authorization: Bearer ${KV_REST_API_TOKEN}"
# 終わったら機密情報を必ず削除
rm -f .env.vercel .vercel/project.json && rmdir .vercel 2>/dev/null新規キー発行
Chrome で対象Googleアカウントでログイン
https://journal-mandala.vercel.app/api/enroll?label=<任意ラベル>を開くOAuth承認 → 画面にAPIキーが1回だけ表示されるのでコピー
~/.claude.jsonのmcpServers.*.env.JOURNAL_MANDALA_API_KEYに反映
同じGoogleアカウントで再enrollすると、古いキーは自動失効し新しいキーに差し替わる。
別のMac(2台目以降)にセットアップする
APIキーはGoogleアカウントに紐付いているので、マシンが変わっても同じキーが使える(再enroll不要)。
# 1. (未インストールなら) Node.js をインストール
brew install node
# 2. MCPサーバーをグローバルインストール
npm install -g --install-links github:takezone/journal-mandala-mcp
# 3. ~/.claude.json に mcpServers を追記(既存設定を壊さないよう python でマージ推奨)
python3 - <<'PY'
import json, os
p = os.path.expanduser('~/.claude.json')
with open(p) as f: c = json.load(f)
c.setdefault('mcpServers', {})
c['mcpServers'].update({
'journal-mandala-personal': {
'command': 'journal-mandala-mcp',
'env': {'JOURNAL_MANDALA_API_KEY': 'jm_XXXXX'} # ←実キー
},
'journal-mandala-work': {
'command': 'journal-mandala-mcp',
'env': {'JOURNAL_MANDALA_API_KEY': 'jm_YYYYY'} # ←実キー
},
})
with open(p, 'w') as f: json.dump(c, f, indent=2, ensure_ascii=False)
print('updated')
PY
# 4. Claude Code を再起動(/exit → claude 再実行)既存キーが手元にない場合: 家のMacの ~/.claude.json からコピーするか、上記「復旧手順」でVercelから取得する。
分散運用のすすめ: 家Mac と 会社Mac で別キーを使うと(例: ?label=personal-home / ?label=personal-work)、片方が漏れても他方に影響せず、ローテーションも片側ずつで済む。同じキーで揃える方が利便性は高いが、好みで選ぶ。
ライセンス
MIT
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Tools
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/takezone/journal-mandala-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server