mirror of
https://gitee.com/koogua/course-tencent-cloud.git
synced 2025-06-24 20:06:09 +08:00
137 lines
3.4 KiB
PHP
137 lines
3.4 KiB
PHP
<?php
|
|
|
|
namespace App\Services\Frontend;
|
|
|
|
use App\Models\ConsultVote as ConsultVoteModel;
|
|
use App\Models\User as UserModel;
|
|
use App\Repos\ConsultVote as ConsultVoteRepo;
|
|
use App\Validators\UserDailyLimit as UserDailyLimitValidator;
|
|
|
|
class ConsultVote extends Service
|
|
{
|
|
|
|
use ConsultTrait;
|
|
|
|
public function agree($id)
|
|
{
|
|
$consult = $this->checkConsult($id);
|
|
|
|
$user = $this->getLoginUser();
|
|
|
|
$validator = new UserDailyLimitValidator();
|
|
|
|
$validator->checkConsultVoteLimit($user);
|
|
|
|
$consultVoteRepo = new ConsultVoteRepo();
|
|
|
|
$consultVote = $consultVoteRepo->findConsultVote($consult->id, $user->id);
|
|
|
|
if (!$consultVote) {
|
|
|
|
$consultVote = new ConsultVoteModel();
|
|
|
|
$consultVote->consult_id = $consult->id;
|
|
$consultVote->user_id = $user->id;
|
|
$consultVote->type = ConsultVoteModel::TYPE_AGREE;
|
|
|
|
$consultVote->create();
|
|
|
|
$consult->agree_count += 1;
|
|
|
|
} else {
|
|
|
|
if ($consultVote->type == ConsultVoteModel::TYPE_AGREE) {
|
|
|
|
$consultVote->type = ConsultVoteModel::TYPE_NONE;
|
|
|
|
$consult->agree_count -= 1;
|
|
|
|
} elseif ($consultVote->type == ConsultVoteModel::TYPE_OPPOSE) {
|
|
|
|
$consultVote->type = ConsultVoteModel::TYPE_AGREE;
|
|
|
|
$consult->agree_count += 1;
|
|
$consult->oppose_count -= 1;
|
|
|
|
} elseif ($consultVote->type == ConsultVoteModel::TYPE_NONE) {
|
|
|
|
$consultVote->type = ConsultVoteModel::TYPE_AGREE;
|
|
|
|
$consult->agree_count += 1;
|
|
}
|
|
|
|
$consultVote->update();
|
|
}
|
|
|
|
$consult->update();
|
|
|
|
$this->incrUserDailyConsultVoteCount($user);
|
|
|
|
return $consult;
|
|
}
|
|
|
|
public function oppose($id)
|
|
{
|
|
$consult = $this->checkConsult($id);
|
|
|
|
$user = $this->getLoginUser();
|
|
|
|
$validator = new UserDailyLimitValidator();
|
|
|
|
$validator->checkConsultVoteLimit($user);
|
|
|
|
$consultVoteRepo = new ConsultVoteRepo();
|
|
|
|
$consultVote = $consultVoteRepo->findConsultVote($consult->id, $user->id);
|
|
|
|
if (!$consultVote) {
|
|
|
|
$consultVote = new ConsultVoteModel();
|
|
|
|
$consultVote->consult_id = $consult->id;
|
|
$consultVote->user_id = $user->id;
|
|
$consultVote->type = ConsultVoteModel::TYPE_OPPOSE;
|
|
|
|
$consultVote->create();
|
|
|
|
$consult->oppose_count += 1;
|
|
|
|
} else {
|
|
|
|
if ($consultVote->type == ConsultVoteModel::TYPE_AGREE) {
|
|
|
|
$consultVote->type = ConsultVoteModel::TYPE_OPPOSE;
|
|
|
|
$consult->agree_count -= 1;
|
|
$consult->oppose_count += 1;
|
|
|
|
} elseif ($consultVote->type == ConsultVoteModel::TYPE_OPPOSE) {
|
|
|
|
$consultVote->type = ConsultVoteModel::TYPE_NONE;
|
|
|
|
$consult->oppose_count -= 1;
|
|
|
|
} elseif ($consultVote->type == ConsultVoteModel::TYPE_NONE) {
|
|
|
|
$consultVote->type = ConsultVoteModel::TYPE_OPPOSE;
|
|
|
|
$consult->oppose_count += 1;
|
|
}
|
|
|
|
$consultVote->update();
|
|
}
|
|
|
|
$consult->update();
|
|
|
|
$this->incrUserDailyConsultVoteCount($user);
|
|
|
|
return $consult;
|
|
}
|
|
|
|
protected function incrUserDailyConsultVoteCount(UserModel $user)
|
|
{
|
|
$this->eventsManager->fire('userDailyCounter:incrConsultVoteCount', $this, $user);
|
|
}
|
|
|
|
}
|