loading…
Search for a command to run...
loading…
Enables Claude AI to interact with Viva Engage (Yammer) for browsing communities, searching posts, reading conversations, and posting replies.
Enables Claude AI to interact with Viva Engage (Yammer) for browsing communities, searching posts, reading conversations, and posting replies.
An open source Model Context Protocol (MCP) server that connects Claude AI to Viva Engage (Yammer). Browse your home network communities, search posts, read conversations, and post replies — all through natural conversation with Claude.
Built by Pranav Joshi
Once connected, you can ask Claude things like:
This MCP server works with your home network only (the primary organization network tied to your login credentials).
Why can't it access external networks?
Viva Engage supports two types of networks:
The Yammer REST API (www.yammer.com/api/v1) only returns data from your home network regardless of what parameters or tokens are used. External networks require browser session cookies that are only available after a full web-based login — something that cannot be replicated through API calls alone.
Microsoft's newer Graph API (graph.microsoft.com) also does not support external networks — it only works with networks in native mode within your own tenant.
This is a Microsoft API limitation, not a limitation of this MCP server. If Microsoft expands their API to support external networks in the future, this server can be updated to support them.
You ask Claude a question
↓
Claude calls this MCP server
↓
Server calls Viva Engage API using YOUR login
↓
Returns data only YOU can already see
↓
Claude answers your question
Privacy: Every user registers their own Azure app and uses their own Microsoft credentials. No data ever goes through anyone else's infrastructure. Your login token is stored encrypted on your machine only.
This is a one-time setup (~10 minutes). You register your own app under your own Microsoft account. No one else can use your app — it is tied to your credentials only.
mcp-viva-engage (or anything you like)Multiple Entra ID tenants → select Allow all tenantsPublic client/native (mobile & desktop)http://localhostuser_impersonationCommunity.Read.AllEngagementConversation.ReadWrite.AllStoryline.ReadWrite.AllNote for work/school accounts: Your organization's IT admin may need to grant consent for this app before you can log in for the first time. This is a one-time step. You can submit an approval request directly from the login screen when you first run the server.
# Clone the repo
git clone https://github.com/pranav4186/mcp-viva-engage.git
cd mcp-viva-engage
# Install dependencies
npm install
# Build
npm run build
Copy the example env file:
# Windows
copy .env.example .env
# Mac/Linux
cp .env.example .env
Open .env and fill in your values from Step 1:
AZURE_CLIENT_ID=your-application-client-id-here
AZURE_TENANT_ID=your-directory-tenant-id-here
Important: Never commit your
.envfile to GitHub. It is already in.gitignoreto prevent this.
Open your Claude Desktop config file:
%APPDATA%\Claude\claude_desktop_config.json~/Library/Application Support/Claude/claude_desktop_config.jsonAdd the viva-engage server to the mcpServers section:
{
"mcpServers": {
"viva-engage-mcp": {
"command": "node",
"args": ["C:/path/to/mcp-viva-engage/dist/server.js"],
"env": {
"AZURE_CLIENT_ID": "your-application-client-id-here",
"AZURE_TENANT_ID": "your-directory-tenant-id-here"
}
}
}
}
Replace
C:/path/to/mcp-viva-engagewith the actual path where you cloned the repo. Windows paths can use forward slashes/or double backslashes\\.
Fully quit and restart Claude Desktop after saving.
The first time you ask Claude something about Viva Engage:
Your session is kept encrypted on your machine. When you restart Claude Desktop you may need to log in again.
| Tool | Description |
|---|---|
get_networks |
Get all Viva Engage networks you belong to |
get_communities |
List all communities in your home network |
get_community_by_id |
Get details of a specific community by ID |
get_community_messages |
Get posts in a community — accepts name or ID, supports pagination |
get_recent_messages |
Get recent messages across all communities — great for daily summaries |
get_thread |
Get all messages in a conversation thread |
search_messages |
Search posts across your home network — supports date filtering |
post_message |
Post a new message to a community — accepts name or ID |
reply_to_message |
Reply to an existing conversation thread |
get_storyline_feed |
Get your personal Viva Engage storyline feed |
| What you ask Claude | What happens behind the scenes |
|---|---|
| "Summarize what's new today" | get_recent_messages with hours_ago: 24 |
| "What's new this week in ISV Collaboration?" | get_community_messages with name "ISV Collaboration" |
| "Find AL Extension posts this week" | search_messages with from_date set to 7 days ago |
| "Post to Developers group" | post_message with name "Developers" — no ID needed |
| "Summarize the last 10 posts in Business Central" | get_community_messages with name "Business Central" |
| 🔐 Your own Azure app | Every user registers their own app — no shared infrastructure |
| 🔐 Your own credentials | You log in with your own Microsoft account |
| 🔐 Encrypted token storage | Token is encrypted using Windows DPAPI (or plain file on Mac/Linux) |
| 🔐 No secrets in code | Client ID and Tenant ID stay in your local .env file only |
| 🔐 Delegated permissions | Server can only see what you can already see in Viva Engage |
| 🔐 Password never touched | Microsoft handles authentication entirely |
mcp-viva-engage/
├── src/
│ ├── auth/
│ │ └── auth.ts # Microsoft OAuth login with DPAPI encrypted cache
│ ├── yammerClient.ts # Viva Engage / Yammer API client
│ └── server.ts # MCP server and tool definitions
├── .env.example # Template — copy to .env and fill in your values
├── .gitignore # Prevents .env from being committed
├── package.json
├── tsconfig.json
└── README.md
"Approval required" on first login
Your organization requires admin consent for new apps. Ask your IT admin to approve the app in Azure portal → Enterprise Applications → find
mcp-viva-engage→ Grant admin consent. This is a one-time action.
Server not showing in Claude Desktop
Fully quit and restart Claude Desktop after editing the config file. Verify the path to
dist/server.jsis correct.
Login required again after restart
The encrypted token may have expired. Simply log in again — the session will be cached after login.
Only seeing home network communities
This is expected — see the Important Limitation section above. The Yammer REST API only supports home network access.
Path issues on Windows
Use either forward slashes
C:/path/to/dist/server.jsor double backslashesC:\\path\\to\\dist\\server.jsin the config file.
get_recent_messages is slow
This tool scans all your communities one by one. If you have many communities it may take 10-20 seconds. This is normal — the Yammer API does not support bulk message fetching.
get_recent_messages may hit this limit if you have many communities.post_message are published immediately. There is no draft or preview mode in the Yammer API.get_my_info — get current user profile for better contextlike_message — like/unlike postsget_community_members — list members of a communityget_community_messages now accepts community name or ID (no more looking up IDs)post_message now accepts community name or IDsearch_messages now supports date filtering (from_date parameter)get_recent_messages tool — scan all communities for recent activityget_community_messagesMIT — see LICENSE for details.
This is an independent open source project and is not affiliated with, endorsed by, or supported by Microsoft or Viva Engage. Use at your own risk.
Add this to claude_desktop_config.json and restart Claude Desktop.
{
"mcpServers": {
"mcp-viva-engage": {
"command": "npx",
"args": []
}
}
}