moltrade
Operate the Moltrade trading bot (config, backtest, test-mode runs, Nostr signal broadcast, exchange adapters, strategy integration) in OpenClaw.
Like a lobster shell, security has layers — review code before you run it.
License
Runtime requirements
SKILL.md
Moltrade Bot Skill
Moltrade is a decentralized, automated trading assistant that lets you run quant strategies, share encrypted signals, and allow others to copy your trades—all securely via the Nostr network. Earn reputation and credits based on your trading performance.

YOUR 24/7 AI TRADER ! EARNING MONEY WHILE YOU'RE SLEEPING.
Advantages
Moltrade balances security, usability, and scalability. Key advantages include:
- Client-side Key self-hosting,not cloud Custody,: All sensitive keys and credentials remain on the user's machine; the cloud relay never holds funds or private keys, minimizing custodial risk.No access to private keys or funds.
- Encrypted, Targeted Communication: Signals are encrypted before publishing and only decryptable by intended subscribers, preserving strategy privacy and subscriber security.
- Lightweight Cloud Re-encryption & Broadcast: The cloud acts as an efficient relay/re-broadcaster without storing private keys; re-encryption or forwarding techniques improve delivery reliability and reach.
- One-Click Copy Trading (User Friendly): Provides an out-of-the-box copy-trading experience for non-expert users—set up in a few steps and execute signals locally.
- OpenClaw Strategy Advisor: Integrates OpenClaw as an advisory tool for automated backtests and improvement suggestions; users decide whether to adopt recommended changes.
- Cloud Can Be Decentralized Relayer Network: The lightweight relay architecture allows future migration to decentralized relay networks, reducing single points of failure and improving censorship resistance.
- Unified Incentive (Credit) System: A transparent, verifiable Credit mechanism rewards all participants (signal providers, followers, relay nodes), aligning incentives across the ecosystem.
How It Works (Simplified Flow)
1) Run Your Bot ──→ 2) Generate & Encrypt ──→ 3) Relay ──→ 4) Copy & Execute ──→ 5) Verify & Earn
Install & Init
- If you are inside OpenClaw, you can install directly via ClawHub:
clawhub search moltrade
clawhub install moltrade
- OR Clone the repo and install Python deps locally:
git clone https://github.com/hetu-project/moltrade.gitcd moltrade/trader && pip install -r requirements.txt
- Initialize a fresh config with the built-in wizard:
- Security Requirement: Always ask the human user to run
python main.py --initthemselves in a separate terminal. Do not ask for or handle their wallet private keys directly or save them to disk via agent scripts.
- Security Requirement: Always ask the human user to run
- For CI/agents, keep using the repo checkout; there is no separate pip package/CLI yet.
Update Config Safely
- Backup or show planned diff before edits.
- Change only requested fields (e.g.,
trading.exchange,trading.default_strategy,nostr.relays). - Validate JSON; keep types intact. Remind user to provide real secrets themselves.
Run Backtest (local)
- Install deps:
pip install -r trader/requirements.txt. - Command:
python trader/backtest.py --config trader/config.example.json --strategy <name> --symbol <symbol> --interval 1h --limit 500. - Report PnL/win rate/trade count/drawdown if available. Use redacted config (no real keys).
Start Bot (test mode)
- Ensure
config.jsonexists (runpython main.py --initif not) andtrading.exchangeset (default hyperliquid). - Command:
python trader/main.py --config config.json --test --strategy <name> --symbol <symbol> --interval 300. - Watch
trading_bot.log; never switch to live without explicit user approval.
Run Bot (live)
- Only after validation on test mode; remove
--testto hit mainnet. - Command:
python trader/main.py --config config.json --strategy <name> --symbol <symbol>. - Double-check keys, risk limits, and symbol before starting; live mode will place real orders.
Copy-trade Usage (live)
- Follower (mirrors leader, no strategy trading):
python trader/main.py --config trader/config.json --strategy momentum --symbol HYPE --copytrade follower
Broadcast Signals to Nostr
- Check
nostrblock:nsec,relayer_nostr_pubkey,relays,sid. SignalBroadcasteris wired inmain.py. In test mode, verifysend_trade_signal/send_execution_reportrun without errors.
Binance Spot Support
Moltrade supports Binance Spot trading via binance-sdk-spot. Set trading.exchange to "binance" in your config and provide API credentials.
Related Skills (raw API calls, not tied to the bot runtime):
binance/spot— Binance Spot REST API skill: market data, order management, account info. Requires API key + secret; supports testnet and mainnet.binance/square-post— Binance Square social platform skill: post trading insights/signals as text content via the Square OpenAPI. Requires a Square OpenAPI key.
Install Binance SDK
pip install binance-sdk-spot
Config Fields
Add a binance block alongside the existing trading block:
{
"trading": {
"exchange": "binance",
"default_symbol": "BTCUSDT",
"default_strategy": "momentum"
},
"binance": {
"api_key": "your_mainnet_api_key",
"api_secret": "your_mainnet_api_secret",
"testnet_api_key": "your_testnet_api_key",
"testnet_api_secret": "your_testnet_api_secret"
}
}
Note: Binance testnet uses keys generated separately at https://testnet.binance.vision (GitHub login required). Mainnet keys do not work on the testnet.
Testnet (–-test)
When --test is passed the bot routes all requests to testnet.binance.vision and uses binance.testnet_api_key / testnet_api_secret. If testnet keys are absent it falls back to mainnet keys, which will cause auth errors against the testnet endpoint.
python trader/main.py --config config.json --test --strategy momentum --symbol BTCUSDT
Live Trading
python trader/main.py --config config.json --strategy momentum --symbol BTCUSDT
Backtest
python trader/backtest.py --config trader/config.example.json --strategy momentum --symbol BTCUSDT --interval 1h --limit 500
Supported Interface
BinanceClient (trader/binance_api.py) implements the same interface as HyperliquidClient:
| Method | Description |
|---|---|
get_candles(symbol, interval, limit) | K-line data as [ts, open, high, low, close, vol] |
get_balance(asset) | Free balance for an asset (default "USDT") |
get_positions() | Non-zero asset balances (spot has no margin positions) |
get_open_orders() | All current open orders |
place_order(symbol, is_buy, size, price, order_type) | LIMIT or MARKET order with auto lot-size / tick-size rounding |
cancel_order(order_id, symbol) | Cancel by order ID |
cancel_all_orders(symbol) | Cancel all orders (optionally for one symbol) |
get_ticker_price(symbol) | Latest traded price |
Uniswap V3 Support
Moltrade supports decentralized swaps on EVM chains using Uniswap V3 Router via web3. Set trading.exchange to "uniswap" in your config. Note that DEX swaps are atomic; there are no open limit orders or margin positions, and price charting requires an external oracle (currently returns empty or mock data locally).
Install Web3
pip install web3
Config Fields
Add a uniswap block alongside the existing trading block:
{
"trading": {
"exchange": "uniswap",
"default_symbol": "WETH",
"default_strategy": "momentum"
},
"uniswap": {
"rpc_url": "https://eth-mainnet.g.alchemy.com/v2/...",
"private_key": "your_wallet_private_key",
"chain_id": 1,
"router_address": "0xE592427A0AEce92De3Edee1F18E0157C05861564",
"slippage_tolerance": 0.005,
"default_token_in": "0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2",
"default_token_out": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"
}
}
Polymarket Support
Moltrade supports prediction markets on Polymarket via the official py-clob-client. Set trading.exchange to "polymarket" in your config.
Install CLOB Client
pip install py-clob-client
Config Fields
Add a polymarket block alongside the existing trading block:
{
"trading": {
"exchange": "polymarket",
"default_symbol": "TOKEN_ID_HERE",
"default_strategy": "momentum"
},
"polymarket": {
"api_key": "your_polymarket_api_key",
"api_secret": "your_polymarket_api_secret",
"api_passphrase": "your_polymarket_api_passphrase",
"private_key": "your_wallet_private_key",
"chain_id": 137
}
}
Add Exchange Adapter
- Implement adapter in
trader/exchanges/matchingHyperliquidClientinterface (get_candles,get_balance,get_positions,place_order, etc.). - Register in
trader/exchanges/factory.pykeyed bytrading.exchange. - Update config
trading.exchangeand rerun backtest/test-mode.
Integrate New Strategy
- Follow
trader/strategies/INTEGRATION.mdto subclassBaseStrategyand register inget_strategy. - Add config under
strategies.<name>; backtest, then test-mode before live.
Safety / Secrets
- Never print or commit private keys, mnemonics, nsec, or shared keys.
- Default to test mode; require explicit consent for live trading.
Files
7 totalComments
Loading comments…
