mirror of
https://github.com/QwenLM/qwen-code.git
synced 2026-04-28 11:41:04 +00:00
- Bump channel package versions to 0.13.0 - Add publish steps for @qwen-code/channel-base and @qwen-code/channel-plugin-example - Update version script to convert file: references to semver for published packages This enables proper npm publishing of channel packages during the release process. Co-authored-by: Qwen-Coder <qwen-coder@alibabacloud.com> |
||
|---|---|---|
| .. | ||
| src | ||
| package.json | ||
| qwen-extension.json | ||
| README.md | ||
| tsconfig.json | ||
@qwen-code/channel-plugin-example
A reference channel plugin for Qwen Code. It connects to a WebSocket server and routes messages through the full channel pipeline (access control, session routing, agent bridge).
Use this package to:
- Try out the channel plugin system — install it as an extension and run it with the built-in mock server
- Use it as a starting point — fork the source to build your own channel adapter (see the Channel Plugin Developer Guide)
Quick start
1. Install the package
npm install @qwen-code/channel-plugin-example
2. Link it as a Qwen Code extension
The package ships a qwen-extension.json manifest, so it works as an extension out of the box:
qwen extensions link ./node_modules/@qwen-code/channel-plugin-example
3. Configure the channel
Add a channel entry to ~/.qwen/settings.json:
{
"channels": {
"my-plugin-test": {
"type": "plugin-example",
"serverWsUrl": "ws://localhost:9201",
"senderPolicy": "open",
"sessionScope": "user",
"cwd": "/path/to/your/project"
}
}
}
4. Start the mock server
npx qwen-channel-plugin-example-server
The server prints the HTTP and WebSocket URLs. You can customize ports with environment variables:
HTTP_PORT=8080 WS_PORT=8081 npx qwen-channel-plugin-example-server
5. Start the channel
In a separate terminal:
qwen channel start my-plugin-test
6. Send a message
curl -sX POST http://localhost:9200/message \
-H 'Content-Type: application/json' \
-d '{"senderId":"user1","senderName":"Tester","text":"What is 2+2?"}'
You should get a JSON response with the agent's reply.
How it works
Mock Server (HTTP + WS)
↕ WebSocket
MockPluginChannel (this package)
→ Envelope → ChannelBase.handleInbound()
→ SenderGate → SessionRouter → AcpBridge.prompt()
→ qwen-code agent → model API
← response
← sendMessage() → WebSocket → Mock Server
← HTTP response
Building your own channel
See src/MockPluginChannel.ts for a working example. The key points:
- Extend
ChannelBaseand implementconnect(),sendMessage(),disconnect() - Build an
Envelopefrom incoming platform messages and callthis.handleInbound(envelope) - Export a
pluginobject conforming toChannelPlugin - Add a
qwen-extension.jsonmanifest
Full guide: Channel Plugin Developer Guide