| .. | ||
| docs | ||
| src | ||
| .env | ||
| package.json | ||
| README.md | ||
| tsconfig.json | ||
| vitest.config.ts | ||
⛏️ Minecraft agent player for アイリ (AIRI)
Note
This project is part of the Project アイリ (AIRI), we aim to build a LLM-driven VTuber like Neuro-sama (subscribe if you didn't!) if you are interested in, please do give it a try on live demo.
An intelligent Minecraft bot powered by LLM. AIRI can understand natural language commands, interact with the world, and assist players in various tasks.
🎥 Preview
✨ Features
- 🗣️ Natural language understanding
- 🏃♂️ Advanced pathfinding and navigation
- 🛠️ Block breaking and placing
- 🎯 Combat and PvP capabilities
- 🔄 Auto-reconnect on disconnection
- 📦 Inventory management
- 🤝 Player following and interaction
- 🌍 World exploration and mapping
🚀 Getting Started
📋 Prerequisites
- 📦 Node.js 23+
- 🔧 pnpm
- 🎮 A Minecraft server (1.20+)
🔨 Installation
- Clone the repository:
git clone https://github.com/moeru-ai/airi.git
cd services/minecraft
- Install dependencies:
pnpm install
- Create a
.env.localfile with your configuration:
Note
For all online accounts, un-comment the following line to toggle Microsoft authentication. Link for authentication will popup when the bot starts.
After signed in, according to how Minecraft protocol was implemented and also, authentication flow implemented here, the token will be cached with the cache IDs specified here in split files:
${hash}_live-cache.json${hash}_mca-cache.json${hash}_xbl-cache.jsoninside of the directory provided by
minecraft-folder-pathLinux:
~/.minecraft/nmp-cache/macOS:~/Library/Application Support/minecraft/nmp-cache/Windows:%appdata%/.minecraft/nmp-cache/where
${hash}is thesha1hash of the username you signing in with (as Minecraft username).
OPENAI_API_KEY=your_openai_api_key
OPENAI_API_BASEURL=your_openai_api_baseurl
BOT_USERNAME=your_bot_username
BOT_HOSTNAME=localhost
BOT_PORT=25565
BOT_AUTH='microsoft' # comment if you use offline mode
BOT_VERSION=1.20
- Start the bot:
pnpm dev
🎮 Usage
Once the bot is connected, you can interact with it using chat commands in Minecraft. All commands start with #.
Basic Commands
#help- Show available commands#follow- Make the bot follow you#stop- Stop the current action#come- Make the bot come to your location
Natural Language Commands
You can also give the bot natural language commands, and it will try to understand and execute them. For example:
- "Build a house"
- "Find some diamonds"
- "Help me fight these zombies"
- "Collect wood from nearby trees"
🛠️ Development
Project Structure
src/
├── agents/ # AI agent implementations
├── composables/# Reusable composable functions
├── libs/ # Core library code
├── mineflayer/ # Mineflayer plugin implementations
├── prompts/ # AI prompt templates
├── skills/ # Bot skills and actions
└── utils/ # Utility functions
Commands
pnpm dev- Start the bot in development modepnpm lint- Run ESLintpnpm typecheck- Run TypeScript type checkingpnpm test- Run tests
🙏 Acknowledgements
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
