logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

hts-mcp-server

Interface with the Hedera Testnet Mirror Node API to create wallets, check account balances, build transactions, and send signed transactions. The server is designed for interaction with the Hedera network while ensuring robust input validation.

Author

hts-mcp-server logo

hedera-dev

No License

Quick Info

GitHub GitHub Stars 1
NPM Weekly Downloads 0
Tools 1
Last Updated 2026-02-19

Tags

hederahtscloudhedera testnethedera networkservices hedera

Hedera MCP Server

A Model Context Protocol (MCP) server for interacting with the Hedera network. This server provides tools for creating Hedera wallets, checking account balances, building transactions, and sending signed transactions.

⚠️ Security Warning

This is a demo implementation and should NOT be used in production. The current implementation has several security vulnerabilities:

  • Private keys are sent in response bodies
  • No encryption of sensitive data
  • No transaction verification mechanisms

This implementation is meant to demonstrate the MCP concept and should be properly secured before being used in a production environment.

Main Objectives

The primary purpose of this MCP server is to demonstrate how transaction construction and execution can be handled by the MCP server, with the client only needing to verify the transaction. Specifically:

  1. Transaction construction happens entirely on the MCP server
  2. Clients signs the constructed transactions
  3. The MCP server handles transaction submission to the Hedera network
  4. This architecture allows for centralized transaction logic and reduces client-side complexity

Prerequisites

  • Node.js (v18 or higher)
  • npm or yarn
  • A Hedera account (for testnet or mainnet)

Installation

  1. Clone this repository: bash git clone https://github.com/hedera-dev/hedera-mcp-server.git cd hedera-mcp-server

  2. Install dependencies: bash npm install

  3. Create a .env file in the root directory with your Hedera credentials: HEDERA_OPERATOR_ID=your-operator-account-id HEDERA_OPERATOR_KEY=your-operator-private-key HEDERA_NETWORK=testnet # or mainnet PORT=3000 # optional, defaults to 3000

Building the Application

Compile the TypeScript code:

npm run build

For development with automatic recompilation:

npm run dev

Running the Server

Start the server:

npm start

The server will be available at http://localhost:3000 (or the port specified in your .env file).

Testing with the Test Client

The repository includes a test client script that demonstrates how to connect to the MCP server and use its tools. This client provides a complete end-to-end flow demonstrating all available tools.

Run the test client:

node test-client.js

The test client will: 1. Connect to the MCP server 2. List available tools 3. Create a new Hedera wallet (create-wallet tool) 4. Check the balance of the new account (check-balance tool) 5. Build a transaction transferring the account's entire balance to the operator account (build-transaction tool) 6. Sign the transaction on the client side using the Hedera SDK 7. Submit the signed transaction to the Hedera network (send-transaction tool) 8. Display the transaction result

This demonstrates the complete lifecycle of interacting with the Hedera network through the MCP server, from account creation to transaction submission.

Available MCP Tools

The server provides the following tools:

  1. create-wallet: Creates a new Hedera account with a minimal initial balance
  2. No input parameters required
  3. Returns account ID, public key, and private key

  4. check-balance: Checks the balance of a Hedera account

  5. Input: accountId (string)
  6. Returns the account balance in tinybars

  7. build-transaction: Builds a transfer transaction (without signing)

  8. Inputs:
    • senderAccountId (string)
    • recipientAccountId (string)
    • amount (number, in tinybars)
  9. Returns a base64-encoded transaction

  10. send-transaction: Sends a signed transaction to the Hedera network

  11. Input: signedTransaction (string, base64-encoded)
  12. Returns transaction status and ID

Deployment

A simple deployment script is included:

./deploy.sh

Make sure to make it executable first:

chmod +x deploy.sh

See Also

`