
esa
Integrates Claude AI with esa's API to manage documents, allowing you to search, create, edit, and organize posts and comments through conversation.
Provides a bridge to esa's API for document management, enabling search, creation, updates, and deletion of posts and comments with member management and categorization capabilities
What it does
- Search esa posts using queries
- Create new posts and comments
- Update existing post content
- Delete posts and comments
- List team members
- Manage post categories and tags
Best for
About esa
esa is a community-built MCP server published by kajirita2002 that provides AI assistants with tools and capabilities via the Model Context Protocol. esa server connects to the esa API for seamless document and member management, enabling easy post search, creation, upd It is categorized under productivity.
How to install
You can install esa in your AI client of choice. Use the install panel on this page to get one-click setup for Cursor, Claude Desktop, VS Code, and other MCP-compatible clients. This server runs locally on your machine via the stdio transport.
License
esa is released under the MIT license. This is a permissive open-source license, meaning you can freely use, modify, and distribute the software.
esa MCP Server
Read this in Japanese
Overview
This server is an interface that uses the Model Context Protocol (MCP) to enable Claude AI to interact with the esa API.
With this MCP server, Claude AI can perform operations such as searching, creating, and updating esa documents.
About the Repository
This repository provides a standalone implementation of the esa MCP server. It integrates Claude AI with esa to streamline document management.
Setup
Prerequisites
- Node.js 18 or higher
- esa API access token
- esa team name
Installation
# Install globally
npm install -g @kajirita2002/esa-mcp-server
# Or use directly with npx
npx @kajirita2002/esa-mcp-server
Setting Environment Variables
# Set environment variables
export ESA_ACCESS_TOKEN="your_esa_access_token"
export ESA_TEAM="your_team_name"
MCP Configuration Example
If you're using this MCP server, add the following configuration to your mcp_config.json file:
"esa": {
"command": "npx",
"args": ["-y", "@kajirita2002/esa-mcp-server"],
"env": {
"ESA_ACCESS_TOKEN": "your_esa_access_token",
"ESA_TEAM": "your_team_name"
}
}
Starting the Server
# Start the server
npm start
Available Tools
This MCP server provides the following tools:
Post Related
-
esa_list_posts- Get a list of posts in the team
- Input:
q(string, optional): Search queryinclude(string, optional): Related data to include in the response (e.g. 'comments,stargazers')sort(string, optional): Sort method (updated, created, number, stars, watches, comments, best_match)order(string, optional): Sort order (desc, asc)per_page(number, optional): Number of results per page (max: 100)page(number, optional): Page number to retrieve
-
esa_get_post- Get detailed information about a specific post
- Input:
post_number(number, required): Post number to retrieveinclude(string, optional): Related data to include in the response (e.g. 'comments,stargazers')
-
esa_create_post- Create a new post
- Input:
name(string, required): Post titlebody_md(string, optional): Post body (Markdown format)tags(array of string, optional): List of tags for the postcategory(string, optional): Post categorywip(boolean, optional, default: true): Whether to mark as WIP (Work In Progress)message(string, optional): Change messageuser(string, optional): Poster's screen_name (only team owners can specify)template_post_id(number, optional): ID of the post to use as a template
-
esa_update_post- Update an existing post
- Input:
post_number(number, required): Post number to updatename(string, optional): New title for the postbody_md(string, optional): New body for the post (Markdown format)tags(array of string, optional): New list of tags for the postcategory(string, optional): New category for the postwip(boolean, optional): Whether to mark as WIP (Work In Progress)message(string, optional): Change messagecreated_by(string, optional): Poster's screen_name (only team owners can specify)original_revision(string, optional): Revision to base the update on
Comment Related
-
esa_list_comments- Get a list of comments for a post
- Input:
post_number(number, required): Post number to get comments forpage(number, optional): Page number to retrieveper_page(number, optional): Number of results per page (max: 100)
-
esa_get_comment- Get a specific comment
- Input:
comment_id(number, required): ID of the comment to retrieveinclude(string, optional): Related data to include in the response (e.g. 'stargazers')
-
esa_create_comment- Post a comment to an article
- Input:
post_number(number, required): Post number to comment onbody_md(string, required): Comment body (Markdown format)user(string, optional): Poster's screen_name (only team owners can specify)
Member Related
-
esa_get_members- Get a list of team members
- Input:
page(number, optional): Page number to retrieveper_page(number, optional): Number of results per page (max: 100)
-
esa_get_member- Get information about a specific team member
- Input:
screen_name_or_email(string, required): Screen name or email of the member to retrieve
Usage Example
Here's an example of Claude using this MCP server to create an esa post:
[Claude] Please create a new post in esa. The title should be "Project X Progress Report" and the body should include "# This Week's Progress\n\n- Implementation of Feature A completed\n- Testing of Feature B started\n\n## Next Week's Plan\n\n- Start implementation of Feature C".
[MCP Server] Using the esa_create_post tool to create a new post.
[Result]
{
"number": 123,
"name": "Project X Progress Report",
"body_md": "# This Week's Progress\n\n- Implementation of Feature A completed\n- Testing of Feature B started\n\n## Next Week's Plan\n\n- Start implementation of Feature C",
"wip": false,
"created_at": "2023-06-01T12:34:56+09:00",
"updated_at": "2023-06-01T12:34:56+09:00",
"url": "https://your-team.esa.io/posts/123"
}
[Claude] The post has been created successfully. The post number is 123, and you can access it at the following URL:
https://your-team.esa.io/posts/123
Troubleshooting
Access Token Issues
Error: Request failed with status code 401
If you see this error, your esa access token may be invalid or expired. Generate a new access token from the esa settings screen and update your environment variable.
Permission Issues
Error: Request failed with status code 403
If you see this error, the current access token doesn't have the necessary permissions. Check the permissions for your access token in the esa settings screen and issue a new token if needed.
License
Provided under the MIT License.
Alternatives
Related Skills
Browse all skillsLeveraging AI coding assistants and tools to boost development productivity, while maintaining oversight to ensure quality results.
Creates educational Teams channel posts for internal knowledge sharing about Claude Code features, tools, and best practices. Applies when writing posts, announcements, or documentation to teach colleagues effective Claude Code usage, announce new features, share productivity tips, or document lessons learned. Provides templates, writing guidelines, and structured approaches emphasizing concrete examples, underlying principles, and connections to best practices like context engineering. Activates for content involving Teams posts, channel announcements, feature documentation, or tip sharing.
Expert methodology for defining, tracking, and interpreting engineering performance metrics including DORA, team health, productivity, and executive reporting.
This skill should be used whenever users request personal assistance tasks such as schedule management, task tracking, reminder setting, habit monitoring, productivity advice, time management, or any query requiring personalized responses based on user preferences and context. On first use, collects comprehensive user information including schedule, working habits, preferences, goals, and routines. Maintains an intelligent database that automatically organizes and prioritizes information, keeping relevant data and discarding outdated context.
Boost your productivity with automated task management
Optimize local development workflow with Cursor. Triggers on "cursor workflow", "cursor development loop", "cursor productivity", "cursor daily workflow". Use when working with cursor local dev loop functionality. Trigger with phrases like "cursor local dev loop", "cursor loop", "cursor".