收口聊天室安全边界并优化特效生命周期
This commit is contained in:
@@ -0,0 +1,23 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* 文件功能:聊天室动态内容净化工具
|
||||
*
|
||||
* 统一处理用户输入在系统消息、公告与商城赠言中的 HTML 转义,避免动态文本注入到前端 innerHTML。
|
||||
*/
|
||||
|
||||
namespace App\Support;
|
||||
|
||||
/**
|
||||
* 类功能:提供聊天室系统文案中用户可控字段的安全转义能力。
|
||||
*/
|
||||
class ChatContentSanitizer
|
||||
{
|
||||
/**
|
||||
* 将用户可控文本规整为可安全拼入受控 HTML 模板的字符串。
|
||||
*/
|
||||
public static function htmlText(?string $value): string
|
||||
{
|
||||
return e(trim((string) $value));
|
||||
}
|
||||
}
|
||||
@@ -43,6 +43,11 @@ class PositionPermissionRegistry
|
||||
*/
|
||||
public const ROOM_FULLSCREEN_EFFECT = 'room.fullscreen_effect';
|
||||
|
||||
/**
|
||||
* 职务奖励金币权限。
|
||||
*/
|
||||
public const ROOM_REWARD = 'room.reward';
|
||||
|
||||
/**
|
||||
* 用户警告权限。
|
||||
*/
|
||||
@@ -101,6 +106,11 @@ class PositionPermissionRegistry
|
||||
'label' => '全屏特效',
|
||||
'description' => '允许触发聊天室内全部全屏动画特效。',
|
||||
],
|
||||
self::ROOM_REWARD => [
|
||||
'group' => '用户管理',
|
||||
'label' => '奖励金币',
|
||||
'description' => '允许在额度限制内向低位阶用户发放职务金币奖励。',
|
||||
],
|
||||
self::USER_WARN => [
|
||||
'group' => '用户管理',
|
||||
'label' => '警告用户',
|
||||
|
||||
Reference in New Issue
Block a user