优化朋友圈

This commit is contained in:
2026-04-06 03:36:41 +08:00
parent dd6745fe24
commit 26fb271a54
2 changed files with 206 additions and 197 deletions
@@ -40,7 +40,7 @@ class FriendCircleController extends BaseController{
'top_unread_items' =>[],
'unread_item_ids' =>[],
'unread_count' =>0,
'settings' => Db::name('friend_circle_setting')->where('user_id',$user_id)->order('id','desc')->findOrEmpty()
'settings' => Db::name('user_extend')->where('user_id',$user_id)->findOrEmpty()
];
return $this->success('ok',$json);
}else{
@@ -52,7 +52,7 @@ class FriendCircleController extends BaseController{
$res = $this->newcount($request);
$response = $res->rawBody();
$json = json_decode($response,true);
$json['data']['settings'] = Db::name('friend_circle_setting')->where('user_id',$user_id)->order('id','desc')->findOrEmpty();
$json['data']['settings'] = Db::name('user_extend')->where('user_id',$user_id)->findOrEmpty();
// [
// 'bg' => '',
// ];
@@ -425,11 +425,8 @@ class FriendCircleController extends BaseController{
return $this->fail( $res);
}
Db::name('friend_circle_setting')->replace()->insert([
'user_id' => $user->id,
'bg' => $res[0]['file_name'],
'allow_days'=>0,
'created_at'=>0
Db::name('user_extend')->where('user_id',$user->id)->save([
'moments_banner' => $res[0]['file_name']
]);
//$result->ss = cdnurl($result->url);
//P($result);
+95 -83
View File
@@ -1,5 +1,6 @@
<?php
namespace app\api\controller;
use app\model\User as UserModel;
use app\model\FriendCircle as FriendCircleModel;
use app\model\FriendCircleLike as FriendCircleLikeModel;
@@ -12,25 +13,34 @@ use hg\apidoc\annotation as Apidoc;
/**
* 新朋友圈
*/
class MomentsController extends BaseController{
/**
* 不需要鉴权的方法
* @var array
*/
class MomentsController extends BaseController
{
public $noNeedAuth = ['*'];
/**
* 无需登录及鉴权的方法
* @var array
*/
public $noNeedLogin = [];
public $user_display_fields = 'id,userID,nickname,avatar';
/**
* 朋友圈设置
* @param string $userID 用户userID,可选,不填就查询自己
* @return void
*/
function info(Request $request): Response{
protected function getUserSettings(int $user_id): array
{
$result = Db::name('user_extend')
->where('user_id', $user_id)
->field('moments_allow_view_days,moments_banner')
->findOrEmpty();
return $result;
}
protected function processAvatar($data): void
{
if (is_array($data)) {
if (!empty($data['avatar'])) {
$data['avatar'] = cdnurl($data['avatar']);
}
} elseif (is_object($data) && !empty($data->avatar)) {
$data->avatar = cdnurl($data->avatar);
}
}
function info(Request $request): Response
{
$userID = Input('userID');
if ($userID) {
$user_id = \support\Encrypt::userIDDecode($userID);
@@ -38,19 +48,20 @@ class MomentsController extends BaseController{
'top_unread_items' => [],
'unread_item_ids' => [],
'unread_count' => 0,
'settings' => Db::name('user_extend')->where('user_id',$user_id)->field('moments_allow_view_days,moments_banner')->findOrEmpty()
'settings' => $this->getUserSettings($user_id)
];
return $this->success('ok', $json);
}else{
}
$user = \support\Jwt::getUser();
if (!$user) {
return $this->fail('请先登录');
}
$userID = $user->userID;
$res = $this->newcount($request);
$response = $res->rawBody();
$json = json_decode($response, true);
$json['data']['settings'] = Db::name('user_extend')->where('user_id',$user->id)->field('moments_allow_view_days,moments_banner')->findOrEmpty();
$json['data']['settings'] = $this->getUserSettings($user->id);
$top_unread_items = FriendCircleModel::whereIn('id', $json['data']['unread_item_ids'])
->with(['user' => function ($query) {
@@ -63,7 +74,7 @@ class MomentsController extends BaseController{
$res->withBody(json_encode($json));
return $res;
}
}
/**
* @Apidoc\Title("列表")
* @Apidoc\Method("GET")
@@ -78,33 +89,35 @@ class MomentsController extends BaseController{
$page = (int)Input('page', 1);
$limit = (int)Input('limit', 10);
$userID = Input('userID');
$query = FriendCircleModel::where('status', 1)
->with(['user' => function ($query) {
$query->field($this->user_display_fields);
}])
->order('created_at', 'desc');
if ($userID) {
// 如果指定了用户ID,只获取该用户的朋友圈
$user_id = \support\Encrypt::userIDDecode($userID);
$query->where('user_id', $user_id);
} else {
$current_userID = \support\Encrypt::userIDencode($current_user_id);
$query->whereIn('user_id',$this->getFriendUserIds($current_userID));
$current_userID = $current_user_id > 0 ? \support\Encrypt::userIDencode($current_user_id) : '';
$friendIds = $this->getFriendUserIds($current_userID);
if (empty($friendIds)) {
return $this->success('ok', []);
}
$query->whereIn('user_id', $friendIds);
}
$list = $query->paginate([
'list_rows' => $limit,
'page' => $page,
]);
if(!$userID){
if (!$userID && $list->count() > 0) {
cache('circle_last_read_id_' . $current_user_id, $list[0]['id']);
}
// 处理每条朋友圈数据
$items = $list->items();
$list->each(function ($item) use ($current_user_id) {
// 获取点赞列表
$likes = Db::name('friend_circle_like')->alias('f')
->join('user u', 'u.id=f.user_id')
->where('f.circle_id', $item->id)
@@ -113,19 +126,14 @@ class MomentsController extends BaseController{
->limit(20)
->select();
$likes = $likes ? $likes->toArray() : [];
// 检查当前用户是否已点赞
$is_liked = false;
if ($current_user_id > 0) {
$is_liked = null !== array_find($likes,function($item)use($current_user_id){
return $item['user_id'] == $current_user_id;
$is_liked = null !== array_find($likes, function ($like) use ($current_user_id) {
return $like['user_id'] == $current_user_id;
});
// FriendCircleLikeModel::where('circle_id', $item->id)
// ->where('user_id', $current_user_id)
// ->count() > 0;
}
// 获取评论列表(最新10条)
$comments = FriendCircleCommentModel::where('circle_id', $item->id)
->where('status', 1)
->with(['user' => function ($query) {
@@ -137,38 +145,28 @@ class MomentsController extends BaseController{
->limit(10)
->select();
// 格式化数据
$item->is_liked = $is_liked;
$item->likes = $likes;
$item->comments = $comments;
// 处理图片URL
if (!empty($item->files)) {
$files = is_array($item->files) ? $item->files : json_decode($item->files, true);
if (is_array($files)) {
$item->files = array_map(function($file) {
return cdnurl($file);
}, $files);
} else {
$item->files = [];
}
$item->files = is_array($files) ? array_map('cdnurl', $files) : [];
} else {
$item->files = [];
}
// 处理用户头像
if ($item->user && $item->user->avatar) {
$item->user->avatar = cdnurl($item->user->avatar);
}
// 处理点赞用户头像
foreach ($item->likes as $like) {
if ($like->user) {
$like->avatar = cdnurl($like->avatar);
foreach ($item->likes as &$like) {
if (!empty($like['avatar'])) {
$like['avatar'] = cdnurl($like['avatar']);
}
}
unset($like);
// 处理评论用户头像
foreach ($item->comments as $comment) {
if ($comment->user && $comment->user->avatar) {
$comment->user->avatar = cdnurl($comment->user->avatar);
@@ -177,6 +175,7 @@ class MomentsController extends BaseController{
$comment->replyUser->avatar = cdnurl($comment->replyUser->avatar);
}
}
return $item;
});
@@ -194,17 +193,17 @@ class MomentsController extends BaseController{
if (!$user) {
return $this->fail('请先登录');
}
$user_id = $user->id;
$circle_last_read_id = cache('circle_last_read_id_' . $user_id) ?: 0;
$userID = \support\Encrypt::userIDencode($user_id);
// 统计从上次查看时间到现在新增的朋友圈数量
$unread_item_ids = FriendCircleModel::where('status', 1)
->whereIn('user_id', $this->getFriendUserIds($userID))
->where('id', '>', $circle_last_read_id)
->order('id', 'desc')
->column('id');
return $this->success('ok', [
'unread_count' => count($unread_item_ids),
'unread_item_ids' => $unread_item_ids
@@ -228,13 +227,11 @@ class MomentsController extends BaseController{
$files = $request->post('files', '');
$address = $request->post('address', '');
$releaseType = $request->post('releaseType', '');
// 验证内容
if (empty($body)) {
return $this->fail('什么内容都木有啊');
}
// 处理图片列表
$files_array = [];
if (!empty($files)) {
if (is_string($files)) {
@@ -247,13 +244,11 @@ class MomentsController extends BaseController{
return $this->fail('图片列表格式错误');
}
// 限制图片数量
if (count($files_array) > 9) {
return $this->fail('最多只能上传9张图片');
}
}
// 创建朋友圈动态
$circle = FriendCircleModel::create([
'user_id' => $user->id,
'releaseType' => $releaseType,
@@ -282,7 +277,7 @@ class MomentsController extends BaseController{
$body = $request->post('body', '');
$circle_id = (int)$request->post('id');
$reply_userID = (int)$request->post('reply_userID');
$reply_userID = $request->post('reply_userID', '');
if (empty($body)) {
return $this->fail('评论内容不能为空');
@@ -292,7 +287,6 @@ class MomentsController extends BaseController{
return $this->fail('朋友圈动态ID错误');
}
// 检查朋友圈动态是否存在
$circle = FriendCircleModel::where('id', $circle_id)
->where('status', 1)
->find();
@@ -301,11 +295,11 @@ class MomentsController extends BaseController{
return $this->fail('朋友圈动态不存在');
}
// 如果回复评论,检查被回复的用户是否存在
$reply_user_id = 0;
if ($reply_userID ) {
$reply_user_id = \support\Encrypt::userIDDecode($reply_userID);
if (!empty($reply_userID)) {
$reply_user_id = (int)\support\Encrypt::userIDDecode($reply_userID);
}
if ($reply_user_id > 0) {
$reply_user = UserModel::where('id', $reply_user_id)->find();
if (!$reply_user) {
@@ -313,7 +307,6 @@ class MomentsController extends BaseController{
}
}
// 创建评论
$comment = FriendCircleCommentModel::create([
'circle_id' => $circle_id,
'user_id' => $user->id,
@@ -322,16 +315,17 @@ class MomentsController extends BaseController{
'status' => 1,
]);
// 更新朋友圈评论数
$circle->comment_count = FriendCircleCommentModel::where('circle_id', $circle_id)
->where('status', 1)
->count();
$circle->save();
$comment->user = Db::name('user')->field($this->user_display_fields)->where('id', $comment->user_id)->find();
$comment->replyUser = null;
if ($comment->reply_user_id) {
$comment->replyUser = Db::name('user')->field($this->user_display_fields)->where('id', $comment->reply_user_id)->find();
}
return $this->success('评论成功', $comment);
}
@@ -353,7 +347,6 @@ class MomentsController extends BaseController{
return $this->fail('朋友圈动态ID错误');
}
// 检查朋友圈动态是否存在
$circle = FriendCircleModel::where('id', $circle_id)
->where('status', 1)
->find();
@@ -362,19 +355,17 @@ class MomentsController extends BaseController{
return $this->fail('朋友圈动态不存在');
}
// 检查是否已点赞
$like = FriendCircleLikeModel::where('circle_id', $circle_id)
->where('user_id', $user->id)
->find();
if ($like) {
// 取消点赞
$like->delete();
$circle->like_count = max(0, $circle->like_count - 1);
$circle->save();
return $this->success('取消点赞成功', ['is_liked' => false]);
} else {
// 添加点赞
}
FriendCircleLikeModel::create([
'circle_id' => $circle_id,
'user_id' => $user->id,
@@ -383,69 +374,91 @@ class MomentsController extends BaseController{
$circle->save();
return $this->success('点赞成功', ['is_liked' => true]);
}
}
protected function getFriendUserIds($userID):array{
protected function getFriendUserIds($userID): array
{
if (!$userID) {
return [];
}
$cache_key = 'friend_id_list_' . $userID;
$result = cache($cache_key) ?: [];
if (count($result) === 0) {
$res = request()->IM->friend->getFriendList($userID);
$friendsInfo = $res['friendsInfo'];
foreach($friendsInfo as $k=>$v){
array_push($result,\support\Encrypt::userIDDecode($v['friendUser']['userID']));
$friendsInfo = $res['friendsInfo'] ?? [];
foreach ($friendsInfo as $v) {
$result[] = \support\Encrypt::userIDDecode($v['friendUser']['userID']);
}
cache($cache_key, $result, 3600);
}
$result[] = \support\Encrypt::userIDDecode($userID);
return $result;
}
/**
* 删除朋友圈
* @Apidoc\Method("POST")
* @Apidoc\Param("id", type="int", require=true, desc="朋友圈动态ID")
* @return Response
*/
function delete(Request $request): Response{
$id = $request->post('id');
function delete(Request $request): Response
{
$id = (int)$request->post('id');
$user = \support\Jwt::getUser();
if (!$user) {
return $this->fail('请先登录');
}
if($id){
if ($id > 0) {
FriendCircleModel::where('id', $id)->where('user_id', $user->id)->delete();
}
return $this->success('删除成功');
}
/**
* 设置朋友圈背景
* @param Request $request
* @return Response
*/
function upload_bg(Request $request){
function upload_bg(Request $request): Response
{
return $this->setBanner($request);
}
/**
* 设置朋友圈背景
* @Apidoc\Method("POST")
* @Apidoc\Param("file", type="File", require=true, desc="文件")
* @return Response
*/
function setBanner(Request $request){
function setBanner(Request $request): Response
{
try {
$user = \support\Jwt::getUser();
if (!$user) {
return $this->fail('请先登录');
}
$res = $this->_upload($request);
if (is_string($res)) {
return $this->fail($res);
}
Db::name('user_extend')->where('user_id',$user->id)->save([
$exist = Db::name('user_extend')->where('user_id', $user->id)->find();
if ($exist) {
Db::name('user_extend')
->where('user_id', $user->id)
->update(['moments_banner' => $res[0]['file_name']]);
} else {
Db::name('user_extend')->insert([
'user_id' => $user->id,
'moments_banner' => $res[0]['file_name'],
]);
}
return $this->success(__('successful'), [
'url' => $res[0]['file_name']
]);
@@ -453,5 +466,4 @@ class MomentsController extends BaseController{
return $this->error($e->getMessage());
}
}
}