IczpNet.Chat.Application.Contracts 0.1.2

dotnet add package IczpNet.Chat.Application.Contracts --version 0.1.2                
NuGet\Install-Package IczpNet.Chat.Application.Contracts -Version 0.1.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="IczpNet.Chat.Application.Contracts" Version="0.1.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add IczpNet.Chat.Application.Contracts --version 0.1.2                
#r "nuget: IczpNet.Chat.Application.Contracts, 0.1.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install IczpNet.Chat.Application.Contracts as a Cake Addin
#addin nuget:?package=IczpNet.Chat.Application.Contracts&version=0.1.2

// Install IczpNet.Chat.Application.Contracts as a Cake Tool
#tool nuget:?package=IczpNet.Chat.Application.Contracts&version=0.1.2                

IM.Chat

abpvnext v6.0 chat module.

Startup

abp new IczpNet.Chat -t module --no-ui 

Set Startup object: IczpNet.Chat.AuthServer

Update-Database

Message

SenderId ReceiverId SessionId
C1 S1.1 S1-C1
s2 C2 S-C2

项目的需求

需求

在线状态

在线状态管理 IServiceStateManager

  1. 群/公众号 解析为 null
  2. 人/Anonymous/ShopWaiter/Customer 解析为 [Online | Offline]
  3. Shopper(自己或是子账号任何一下在线就解析为 [Online ]),都不在线都解析为【Offline】

Internal structure 数据结构

Message 消息表

ChatObject 聊天对象(参与会话)

Persion 人(用户、员工)
Customer 人(客户)
Room 群
Official 公众号
----OfficialGroup 公众号分组(人群定义、临时分组等)
Robot 机器人(智能对话)
Shopkeeper 电商掌柜(主账号)
ShopWaiter 店小二(子账号)
Square 广场

Session

Room

CreateRoom

{
  "name": "9999999999999999999999999",
  "code": "string",
  "ownerId": null,
  "type": 0,
  "description": "string",
  "chatObjectIdList": [
    "31F8B124-BEA6-85C4-B4E3-3A07BB313745","329A7C43-9B01-5966-322A-3A07D4A342EA","5B6A6100-CA52-8040-09F2-3A07D4A367ED","972157FA-2449-FEC6-49A1-3A07DE609F58",
  ]
}

待实现功能

以前要求未实现的功能

Roadmap

聊天对象(ChatObject)

  • 单用户绑定多个聊天对象
  • 机器人
  • 官方号(Official)
  • 订阅号(Subscription)
  • 掌柜(ShopKeeper)
  • 店小二(ShopWaiter)
  • 聊天广场(Square)
  • 匿名(Anonymous)
  • 动态信息添加(添加手机,QQ,职位等)

聊天对象扩展(ChatObject)

  • 个性签名(Motto)
  • 朋友圈

会话功能(Session)

  • 单聊
  • 群聊
  • 官方通知/功能号(Official)
  • 聊天广场
  • 订阅号/服务号
  • 客服系统(CallCenter)

会话验证系统(好友、加群、加聊天广场)

  • 好友验证、处理好友验证消息
  • 加群验证,群主/管理员处理验证
  • 设置验证方式(不需要验证、验证、自动拒绝验证)
  • 自动验证

会话单元(SessionUnit)

  • 我的会话消息
  • 会话成员(群内成员,广场成员)
  • 共同的好友、共同所在的群/广场
  • 群/广场内名称
  • 备注好友/群
  • 会话置顶
  • 会话免打扰功能
  • 标记为已读
  • 删除会话消息
  • 清除会话消息
  • 会话角标
  • 删除会话(不退群)
  • 退出会话(退群)
  • 会话开启与停用(官方号、功能号)
  • 订阅与取消订阅(订阅号、服务号)
  • 设置聊天背景
  • 只读会话(通知群、官方功能、公告等)
  • 【新消息】角标统计
  • 【私有消息】角标统计
  • 【特别关注】角标统计
  • 【@我】角标统计
  • 动态属性备注(添加手机,QQ,职位等)

会话管理功能

  • 会话生成器(SessionGenerator)
  • 会话盒子(SessionBox)
  • 创建聊天广场
  • 二维码扫码加入群聊
  • 二维码扫码加入聊天广场
  • 角色管理、角色权限分配
  • 组织架构
  • 角色管理、角色权限分配
  • 会话内权限(组织、角色、加人,踢人等)
  • 权限分组
  • 权限启用与禁用
  • 会话标签(SessionTag)--
  • 会话菜单功能
  • “拍一拍”
  • @所有人、@XXX
  • 禁言(管理员、群主)
  • 是否允许设置“免打扰”

群聊功能

  • 创建群聊
  • 邀请成员入群
  • 邀请成员加群
  • 群主权限(拥有所有权限)
  • 群角色功能(可配置多角色)
  • 群成员权限(可单一配置成员权限)
  • [权限]更新群名称并通知群成员
  • [权限]更新头头像并通知群成员
  • 转让群主
  • 共同所在的群
  • 加群验证(验证消息由【机器人/群助手】发送到【群主或管理员】)
  • 管理员/群主处理验证
  • 添加/取消【特别关注】(关注群成员,有新消息时标注为【特别关注】)
  • 入群方式设置
  • 二维码扫码加入群聊
  • 面对面加群
  • 邀请码加群
  • 群内组织架构
  • 群内公告
  • 群机器人提醒功能
  • 设置是否可以转发群里消息
  • 设置新成员“默认角色”
  • 设置新成员“历史消息查看范围”

聊天广场

  • 创建聊天广场
  • 广场成员(分组)
  • 特别关注(关注群成员,有新消息时标注为【特别关注】)
  • 设置广场进入方式(公有、私有)
  • 广场公告
  • 机器人提醒功能

单聊天功能

  • 设置“能过账号找到我”
  • 设置“通过手机号找到我”
  • 设置“好友验证方式”
  • 设置是否群内加好友

官方号功能号(Official)

  • 启用与停用功能
  • 设置是否可以停用
  • 设置是否为只读(通知功能 ,成员不能发消息,只能接收消息)

订阅号功能

  • 订阅与取消订阅(同时发会话内私有通知)
  • 设置是否可以停用
  • 设置是否为只读(通知功能 ,成员不能发消息,只能接收消息)
掌柜与店小二
  • 创建子账号
  • 子账号管理(开启、禁用、删除)
  • 消息同步
  • 消息转接
  • 账号状态设置(挂起、忙录)

消息模板功能

  • 系统消息(Command)
  • 文本消息
  • 图片消息
  • 语音消息
  • 视频消息
  • 文件消息
  • 文章消息
  • HTML消息
  • 链接消息
  • 名片消息
  • HTML消息[H5、markdown]
  • 位置消息(Location)
  • 历史聊天记录
  • 公告消息(群公告、广场公告)
  • 红包消息(未实现支付功能,只能积分形式收发红包)

消息扩展功能

  • 转发消息
  • 群发消息
  • 引用消息
  • 消息提醒器
  • 消息收藏夹
  • 消息已读记录器(ReadedRecorder)
  • 消息打开记录器(OpenedRecorder)
  • 敏感词过滤\审核
  • Elasticsearch(elastic.co)

客服系统(CallCenter)

  • 子账号管理
  • 设置服务状态(挂起、接收、忙录等)
  • 会话转接功能
  • 消息分流功能
  • 客户发起会话(自动加入会话)

智能对话功能(机器人)

  • 机器人账号
  • 机器人主动发通知
  • ChatGPT

开发者功能

  • 开发者设置(Token、EncodingAesKey、PostUrl)
  • 开启与关闭功能
  • 验证及验签(signature)
  • Http请求开发者服务日志
  • 后台作业调用开发者及重试功能
  • 验证开发者主机(HOST)
  • 开发者Demo
  • 开发者SDK

WebHook

  • 权限验证(APIKey)

  • ApiKey管理功能

  • Api日志

扩展功能

  • 实现共享位置

  • 扫码登录

  • 文件服务器(文件预览)

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on IczpNet.Chat.Application.Contracts:

Package Downloads
IczpNet.Chat.HttpApi.Client

IczpNet.Chat

IczpNet.Chat.Application

IczpNet.Chat

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.1.2 160 7/18/2024
0.1.1 119 7/17/2024