- Infrastructure
- @satorijs/core
- @satorijs/element
- @satorijs/satori
- @satorijs/protocol
- @satorijs/plugin-server
- Ecosystem
- DingTalk (钉钉)
- Discord
- KOOK (开黑啦)
- Lark (飞书)
- Line
- Matrix
- QQ Guild
- Slack
- Telegram
- WeCom (企业微信)
- Wechat Official (微信公众号)
- Zulip
import { Context } from '@satorijs/core'
import discord from '@satorijs/adapter-discord'
// create a new context
const ctx = new Context()
// configure a Discord account
ctx.plugin(discord, {
token: 'xxxxxx',
})
// listen to message events
ctx.on('message', (session) => {
console.log(session.content)
})
// start application
await ctx.start()
import { Context } from '@satorijs/core'
import router from '@cordisjs/plugin-server'
import telegram from '@satorijs/adapter-telegram'
// your application will be listening http://localhost:8080
// and be available at https://example.com
const ctx = new Context({
port: 8080,
selfUrl: 'https://example.com',
})
// you need a router plugin to handle http requests
ctx.plugin(router)
ctx.plugin(telegram, {
// telegram supports two ways of connection: server and polling
protocol: 'server',
path: '/telegram',
token: 'xxxxxx',
})
// specify multiple accounts with different platforms and protocols
ctx.plugin(discord, {
token: 'xxxxxx',
})
ctx.plugin(telegram, {
protocol: 'server',
token: 'yyyyyy',
})
ctx.plugin(telegram, {
protocol: 'polling',
token: 'zzzzzz',
})
Based on cordis.
const fork = ctx.plugin(discord, {
token: 'xxxxxx',
})
fork.dispose()