---
id: gh-factorio-ai-companion
name: "factorio-ai-companion"
url: https://skills.yangsir.net/skill/gh-factorio-ai-companion
author: lveillard
domain: game-dev
tags: ["factorio", "ai-companion", "game-mod", "rcon", "claude-code"]
install_count: 8
rating: 4.00 (20 reviews)
github: https://github.com/lveillard/factorio-ai-companion
---

# factorio-ai-companion

> 为Factorio 2.x提供AI伴侣，通过MCP协议与Claude Code双向聊天。玩家能用自然语言控制AI进行混合采矿、自主技能等操作，实现游戏内自动化与智能交互。

**Stats**: 8 installs · 4.0/5 (20 reviews)

## Before / After 对比

### Factorio AI伴侣智能控制

**Before**:

玩家在Factorio游戏中需要手动执行复杂操作或编写脚本，与游戏内AI交互有限，难以实现高效自动化。

**After**:

通过Claude Code使用自然语言直接控制AI伴侣，轻松实现混合采矿、自主技能等高级任务，大幅提升游戏体验和自动化水平。

| Metric | Before | After | Change |
|---|---|---|---|
| 操作复杂度 | 80分 | 20分 | -75% |

## Readme

# Factorio AI Companion

Bidirectional chat bridge between Factorio and Claude Code via MCP protocol.

## Status: ✅ Phase 1 Complete - Chat Bridge Working!

Bidirectional chat working between Factorio and Claude Code via RCON.

## Quick Start Guide

### 1. Install Dependencies

```bash
bun install
```

### 2. Install Factorio Mod

**Windows:**
```bash
xcopy /E /I factorio-mod "%APPDATA%\Factorio\mods\ai-companion"
```

**Linux/Mac:** See `factorio-mod/README.md`

### 3. Configure RCON in Factorio

Edit `%APPDATA%\Factorio\config\config.ini` and add these lines (if not already present):

```ini
local-rcon-socket=127.0.0.1:34198
local-rcon-password=factorio
```

**Or use the hidden settings GUI:**
1. In Factorio main menu, press **Ctrl+Alt** and click **Settings**
2. Go to **"The rest"** tab
3. Set `local-rcon-socket` to `127.0.0.1:34198`
4. Set `local-rcon-password` to `factorio`

### 4. Start Factorio Multiplayer

**Important:** RCON only works in multiplayer mode (even if playing solo).

1. Launch Factorio
2. **Multiplayer** → **Host New Game** (or **Load Game**)
3. Select your save and click **Play**
4. RCON will be automatically enabled

### 5. Test RCON Connection (Optional)

```bash
bun run src/rcon/test-connection.ts
```

Expected output:
```
✅ RCON connected on attempt 1
✅ Connection successful!
✅ RCON is working!
```

### 6. Start MCP Server

```bash
bun run src/index.ts
```

Expected output:
```
🚀 Starting Factorio MCP Server...
✅ RCON connected on attempt 1
📡 RCON connected to Factorio
✅ MCP server running on stdio

💡 Server is ready! Claude Code can now use:
   - get_companion_messages
   - send_companion_message
```

### 7. Connect Claude Code

The `.mcp.json` file in this project root configures Claude Code to use this server.

Claude Code will automatically start the MCP server when needed.

### 8. Test It!

**In Factorio chat:**
```
/companion Hello Claude! Can you help me?
```

**In Claude Code:**
```
Use the get_companion_messages tool
```

Claude will see:
```json
[
  {
    "player": "YourName",
    "message": "Hello Claude! Can you help me?",
    "tick": 12345
  }
]
```

**Claude can respond:**
```
Use send_companion_message with "Hello! I'm here to help!"
```

**In Factorio, you'll see:**
```
[AI Companion] Hello! I'm here to help!
```

## Tools Available

### `get_companion_messages`
Get unread messages from Factorio chat starting with `/companion`.

**Returns:** Array of `{player, message, tick}`

### `send_companion_message`
Send a message to Factorio chat as AI Companion.

**Input:** `{ message: string }`

## Architecture

```
Factorio (Lua mod captures /companion chat)
    ↕ RCON (TCP port 27000)
Node.js MCP Server (Bun)
    ↕ MCP Protocol (stdio)
Claude Code (You!)
```

## What's Built

- ✅ RCON client with retry logic
- ✅ Chat message parser
- ✅ Factorio Lua mod with FLE patterns
- ✅ MCP server with 2 tools
- ✅ Claude Code integration via .mcp.json

## Phase 2 (Future)

- AI-controlled character
- Game state introspection
- Automated building/crafting
- Multi-agent coordination

## Troubleshooting

**"Connection failed"**
- Make sure Factorio is running
- Check "Start as server" is enabled
- Verify RCON port is 27000
- Verify RCON password is "factorio"

**"No messages"**
- Type `/companion <message>` in Factorio chat (not just "companion")
- Check mod is enabled in Factorio → Mods menu
- Restart Factorio after installing mod

**"Command not found"**
- Make sure Bun is installed: https://bun.sh
- Run `bun --version` to verify

## Development

```bash
# Run tests
bun test

# Test RCON connection
bun run src/rcon/test-connection.ts

# Start MCP server
bun run src/index.ts
```

## Credits

Inspired by [Factorio Learning Environment](https://github.com/JackHopkins/factorio-learning-environment) patterns and best practices.

---
*Source: https://skills.yangsir.net/skill/gh-factorio-ai-companion*
*Markdown mirror: https://skills.yangsir.net/api/skill/gh-factorio-ai-companion/markdown*