|
|
---
|
|
|
title: Tailchat —— 插件化的开源聊天平台
|
|
|
description: Tailchat 是一款易拓展、方便使用,并且完全免费开源的聊天平台
|
|
|
authors: moonrailgun
|
|
|
slug: intro
|
|
|
image: /img/logo.svg
|
|
|
keywords:
|
|
|
- tailchat
|
|
|
- 介绍
|
|
|
- 开源
|
|
|
- 开源聊天工具
|
|
|
tags: [介绍]
|
|
|
---
|
|
|
|
|
|
## 前言 First of all
|
|
|
|
|
|
大家好,我是[moonrailgun](https://github.com/moonrailgun),今天为大家介绍的是我个人开发的开源插件式聊天软件: [Tailchat](https://github.com/msgbyte/tailchat)
|
|
|
|
|
|
Tailchat 是一款易拓展、方便使用,并且完全免费开源的聊天平台。在部分思想上借鉴了 [Discord](https://discord.com/) 并在此致敬!
|
|
|
|
|
|
|
|
|
## 动机 Motivation
|
|
|
|
|
|
曾经痴迷于 TRPG, 并花了4年的业余时间做了人生第一款聊天软件 [TRPG Engine](https://github.com/TRPGEngine/Client)。但是受限于题材方面的问题,使用的人虽然一直有,但是并没有太多。
|
|
|
|
|
|
而且因为开发之初受到经验的限制,虽然当初经过了很多次重构,但是仍然背负上了很多的技术债务。而且因为当初没有做好分布式架构的设计,因此在面对实际的单机业务性能瓶颈时也没有非常好的解决方案,导致在高峰期只能让用户处于相对慢的系统响应中。
|
|
|
|
|
|
因此我将在 [TRPG Engine](https://github.com/TRPGEngine/Client) 的开发中遇到的问题收集起来,并重新整理了我的业务需求,开发出了新的继承者 [Tailchat](https://github.com/msgbyte/tailchat)。
|
|
|
|
|
|
因为最开始首先于小众的业务, [Tailchat](https://github.com/msgbyte/tailchat) 的设计之初就做好了易于拓展的准备。定位是除了核心的聊天场景以外,其他的业务需要都是由插件提供的。甚至是聊天的富文本渲染方式、消息的通知也是由插件提供的。作为使用者/开发者,能够方便得为 [Tailchat](https://github.com/msgbyte/tailchat) 拓展新的能力,或者将已有的能力集成到 [Tailchat](https://github.com/msgbyte/tailchat) 中
|
|
|
|
|
|
[Tailchat](https://github.com/msgbyte/tailchat) 名字来源于其logo,是两只猫尾巴纠缠在一起的形象,表示猫与猫之间最直接的沟通方式。
|
|
|
|
|
|
## 功能 Feature
|
|
|
|
|
|
### 登录页
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/94f27/94f27bec4ba3eb5e37290073cb728707841efda6" alt=""
|
|
|
|
|
|
登录页除了支持正常的 **登录**、**注册**,为降低使用门槛还允许先进行 **游客访问**,无需注册直接使用。同时还支持 **忘记密码** 功能。向通过用户发送邮件来帮助用户重置密码
|
|
|
|
|
|
> **NOTICE**: 忘记密码功能需要管理员配置SMTP服务
|
|
|
|
|
|
此处以访客为例,创建一个名为 `猫之使徒` 的访客:
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/131d4/131d4b3c378de97dc03330e48463f50a764d1860" alt=""
|
|
|
|
|
|
|
|
|
进入主页面后如下显示:
|
|
|
data:image/s3,"s3://crabby-images/8f6df/8f6df8fb3e9a3cd187cecd16ede13be0a17ad4c5" alt=""
|
|
|
|
|
|
可以通过点击最上面的认领账号来补充用户信息以方便下次登录
|
|
|
|
|
|
### 添加好友
|
|
|
|
|
|
切换到 `添加好友` 标签页,可以看到系统为您生成的4位唯一标识:
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/50988/50988bed2f2f58da33aa6c56a7b06b71c18a0c7c" alt=""
|
|
|
|
|
|
在本例中的唯一标识是`猫之使徒#1216`,您可以通过将这段字符串发送给好友来添加好友。
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d45df/d45df1f916af593d4dea72c6ba08ce2937710bcc" alt=""
|
|
|
|
|
|
### 插件中心
|
|
|
|
|
|
[Tailchat](https://github.com/msgbyte/tailchat) 设计之初就提供了强大的插件系统,通过插件系统能极大拓展[Tailchat](https://github.com/msgbyte/tailchat)自身的能力。
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a2609/a260946dc2429142137d51249edd1cfa0e65d527" alt=""
|
|
|
|
|
|
> NOTICE: 插件本身设计是运行在 可信执行环境(TEE) 中, 请不要随意通过手动安装的方式安装不明来源的第三方插件
|
|
|
|
|
|
### 个人设置
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cc12f/cc12f831524b32b248b30ed9bd3cc4ef7d2f407f" alt=""
|
|
|
|
|
|
用户可以在左下方的"···"中打开个人设置。可以自定义头像,修改名称,修改密码等操作。
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9702e/9702e0e85cf6e2606d5d25d99e4ee00f03d652a8" alt=""
|
|
|
|
|
|
通过剪裁工具可以很方便的选出自己想要的部分
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/04410/0441077840c62ca5c84f0e302091e057eeb8d718" alt=""
|
|
|
|
|
|
### 系统设置
|
|
|
|
|
|
在系统设置中可以修改界面语言和界面主题。
|
|
|
|
|
|
主题除了 [Tailchat](https://github.com/msgbyte/tailchat) 自带的`暗色主题`和`亮色主题`以及根据当前系统设置自动切换的`自动`以外均为插件提供
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3ee64/3ee641619c2d57e6575295129d9606cb58d3fade" alt=""
|
|
|
|
|
|
> 目前 Tailchat 支持的语言仅为 `简体中文` 和 `英语`。欢迎有能力的开发者帮助 Tailchat 进行国际化翻译的工作
|
|
|
|
|
|
### 群组聊天
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ac10f/ac10f2dba61d588d95643fc759677f3da4957df2" alt=""
|
|
|
|
|
|
点击左上角导航栏的绿色加号即可创建群组
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e48b2/e48b216fe2a5fa684a1bff5aee2e5d2c1eb155e0" alt=""
|
|
|
|
|
|
预设了两个布局模板,直接选择`默认群组`
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a1ab2/a1ab22a9bbd3dc539e33809cd640937e47e48404" alt=""
|
|
|
|
|
|
随意取个名字,点击创建。系统则会创建一个群组并自动跳转到该群组
|
|
|
|
|
|
界面布局如下:
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2e71e/2e71e3fd3187a10967d6524e10ab6eb9f7890d81" alt=""
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/78c4b/78c4be81728381cd6e2daf57fcb0555e5fb6b198" alt=""
|
|
|
|
|
|
输入框支持 `@` 群组成员:
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bf186/bf18612aebed78fe0ead1f856e8b5eed5d8730d3" alt=""
|
|
|
|
|
|
### 群组设置
|
|
|
|
|
|
点击左上角的标题栏可以点开群组详情页
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e6c9d/e6c9d050b9253403671ea7218b78542c12a0957b" alt=""
|
|
|
|
|
|
点击查看详情可以进入到群组的详情页
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/78ef6/78ef66bd00792ec3558971dcab6ec8a721c2fd60" alt=""
|
|
|
|
|
|
在此处可以:
|
|
|
- 修改群组头像
|
|
|
- 修改群组名称
|
|
|
- 管理群组面板
|
|
|
|
|
|
#### 面板管理
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/53f67/53f6746f516c6c49765b65a1eb01db1d4596942f" alt=""
|
|
|
|
|
|
创建面板可以直接创建一个面板,内置的面板类型有:
|
|
|
- 聊天频道
|
|
|
- 面板分组
|
|
|
- 网页面板
|
|
|
|
|
|
网页面板可以直接输入一个网址,可以将自己喜好的网址直接集成到 Tailchat 的群组侧边栏
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ebcd0/ebcd0a5beb452bdf5f0d57e1c5f825e10eff7020" alt=""
|
|
|
|
|
|
比如我们插入一个访问 Bilibili 的网页面板,则效果如下:
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e98c5/e98c585f57c5f0ac09c880caba1b7df775ab79ba" alt=""
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f83db/f83db9cbca18bb7be33f7183b85f1ae4173a34fc" alt=""
|
|
|
|
|
|
|
|
|
> NOTICE: 因为浏览器的安全策略问题,如果当前 Tailchat 使用了https协议,那么只能支持嵌入 https 协议的网页
|
|
|
|
|
|
> NOTICE: 因为浏览器的安全策略问题,嵌入的网址需要允许被使用iframe嵌入
|
|
|
|
|
|
## 相关连接
|
|
|
|
|
|
开源地址:
|
|
|
- [https://github.com/msgbyte/tailchat](https://github.com/msgbyte/tailchat)
|
|
|
- [https://github.com/msgbyte/tailchat-server](https://github.com/msgbyte/tailchat-server)
|