123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300 |
- <?php
- namespace App\Services\Coach;
- use App\Enums\TechnicianAuthStatus;
- use Illuminate\Support\Facades\Cache;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Facades\Log;
- class AccountService
- {
- private const CACHE_KEY_PREFIX = 'coach_info_';
- private const CACHE_TTL = 300; // 5分钟
- /**
- * 提交技师基本信息
- */
- public function submitBaseInfo($user, array $data)
- {
- DB::beginTransaction();
- try {
- $this->setTransactionConfig();
- abort_if(! $user->coach, 404, '技师信息不存在');
- // 检查是否有待审核的记录
- $pendingRecord = $user->coach->infoRecords()
- ->where('state', TechnicianAuthStatus::AUDITING->value)
- ->exists();
- abort_if($pendingRecord, 422, '已有待审核的基本信息记录');
- // 创建技师信息
- $record = $user->coach->infoRecords()->create(array_merge($data, [
- 'state' => TechnicianAuthStatus::AUDITING->value,
- ]));
- // 清除技师信息缓存
- $this->clearCoachCache($user->coach->id);
- DB::commit();
- $this->logInfo('技师提交基本信息成功', $user, $data);
- return ['message' => '基本信息提交成功'];
- } catch (\Exception $e) {
- DB::rollBack();
- $this->logError('提交技师基本信息失败', $user, $data, $e);
- throw $e;
- }
- }
- /**
- * 提交技师资质信息
- */
- public function submitQualification($user, array $data)
- {
- DB::beginTransaction();
- try {
- $this->setTransactionConfig();
- abort_if(! $user->coach, 404, '技师信息不存在');
- // 检查是否有待审核的记录
- $pendingRecord = $user->coach->qualRecords()
- ->where('state', TechnicianAuthStatus::AUDITING->value)
- ->exists();
- abort_if($pendingRecord, 422, '已有待审核的资质信息记录');
- // 创建资质信息
- $record = $user->coach->qualRecords()->create(array_merge($data, [
- 'state' => TechnicianAuthStatus::AUDITING->value,
- ]));
- // 清除技师信息缓存
- $this->clearCoachCache($user->coach->id);
- DB::commit();
- $this->logInfo('技师提交资质信息成功', $user, $data);
- return ['message' => '资质信息提交成功'];
- } catch (\Exception $e) {
- DB::rollBack();
- $this->logError('提交技师资质信息失败', $user, $data, $e);
- throw $e;
- }
- }
- /**
- * 提交实名认证信息
- */
- public function submitRealName($user, array $data)
- {
- DB::beginTransaction();
- try {
- $this->setTransactionConfig();
- abort_if(! $user->coach, 404, '技师信息不存在');
- // 检查是否有待审核的记录
- $pendingRecord = $user->coach->realRecords()
- ->where('state', TechnicianAuthStatus::AUDITING->value)
- ->exists();
- abort_if($pendingRecord, 422, '已有待审核的实名认证信息');
- // 创建实名认证信息
- $record = $user->coach->realRecords()->create(array_merge($data, [
- 'state' => TechnicianAuthStatus::AUDITING->value,
- ]));
- // 清除技师信息缓存
- $this->clearCoachCache($user->coach->id);
- DB::commit();
- $this->logInfo('技师提交实名认证信息成功', $user, $this->maskSensitiveData($data));
- return ['message' => '实名认证信息提交成功'];
- } catch (\Exception $e) {
- DB::rollBack();
- $this->logError('提交实名认证信息失败', $user, $this->maskSensitiveData($data), $e);
- throw $e;
- }
- }
- /**
- * 获取技师信息
- */
- public function getCoachInfo($user)
- {
- try {
- abort_if(! $user, 404, '用户不存在');
- abort_if(! $user->coach, 404, '技师信息不存在');
- return Cache::remember(
- self::CACHE_KEY_PREFIX.$user->coach->id,
- self::CACHE_TTL,
- function () use ($user) {
- return $this->fetchCoachInfo($user->coach);
- }
- );
- } catch (\Exception $e) {
- $this->logError('获取技师信息失败', $user, [], $e);
- throw $e;
- }
- }
- /**
- * 设置事务配置
- */
- private function setTransactionConfig()
- {
- DB::statement('SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED');
- DB::statement('SET SESSION innodb_lock_wait_timeout=10');
- }
- /**
- * 记录信息日志
- */
- private function logInfo(string $message, $user, array $data)
- {
- Log::info($message, [
- 'user_id' => $user->id,
- 'coach_id' => $user->coach->id,
- 'data' => $data,
- 'ip' => request()->ip(),
- 'timestamp' => now()->toDateTimeString(),
- ]);
- }
- /**
- * 记录错误日志
- */
- private function logError(string $message, $user, array $data, \Exception $e)
- {
- Log::error($message, [
- 'user_id' => $user->id,
- 'coach_id' => $user->coach->id ?? null,
- 'data' => $data,
- 'error' => $e->getMessage(),
- 'file' => $e->getFile(),
- 'line' => $e->getLine(),
- 'ip' => request()->ip(),
- 'timestamp' => now()->toDateTimeString(),
- ]);
- }
- /**
- * 获取技师详细信息
- */
- private function fetchCoachInfo($coach)
- {
- $baseInfo = $coach->infoRecords()->latest()->first();
- $qualification = $coach->qualRecords()->latest()->first();
- $realName = $coach->realRecords()->latest()->first();
- return [
- 'base_info' => $baseInfo ? $this->formatBaseInfo($baseInfo) : null,
- 'qualification' => $qualification ? $this->formatQualification($qualification) : null,
- 'real_name' => $realName ? $this->formatRealName($realName) : null,
- ];
- }
- /**
- * 格式化基本信息
- */
- private function formatBaseInfo($info)
- {
- return [
- 'nickname' => $info->nickname,
- 'avatar' => $info->avatar,
- 'gender' => $info->gender,
- 'mobile' => $this->maskMobile($info->mobile),
- 'birthday' => $info->birthday,
- 'work_years' => $info->work_years,
- 'intention_city' => $info->intention_city,
- 'introduction' => $info->introduction,
- 'state' => $info->state,
- 'state_text' => TechnicianAuthStatus::fromValue($info->state)->label(),
- 'audit_remark' => $info->audit_remark,
- ];
- }
- /**
- * 格式化资质信息
- */
- private function formatQualification($qual)
- {
- return [
- 'qual_type' => $qual->qual_type,
- 'qual_no' => $qual->qual_no,
- 'qual_photo' => $qual->qual_photo,
- 'valid_start' => $qual->valid_start,
- 'valid_end' => $qual->valid_end,
- 'state' => $qual->state,
- 'state_text' => TechnicianAuthStatus::fromValue($qual->state)->label(),
- 'audit_remark' => $qual->audit_remark,
- ];
- }
- /**
- * 格式化实名信息
- */
- private function formatRealName($real)
- {
- return [
- 'real_name' => $real->real_name,
- 'id_card' => $this->maskIdCard($real->id_card),
- 'id_card_front_photo' => $real->id_card_front_photo,
- 'id_card_back_photo' => $real->id_card_back_photo,
- 'id_card_hand_photo' => $real->id_card_hand_photo,
- 'state' => $real->state,
- 'state_text' => TechnicianAuthStatus::fromValue($real->state)->label(),
- 'audit_remark' => $real->audit_remark,
- ];
- }
- /**
- * 手机号脱敏
- */
- private function maskMobile($mobile)
- {
- return substr_replace($mobile, '****', 3, 4);
- }
- /**
- * 身份证号脱敏
- */
- private function maskIdCard($idCard)
- {
- return substr_replace($idCard, '****', 6, 8);
- }
- /**
- * 敏感数据脱敏
- */
- private function maskSensitiveData(array $data)
- {
- if (isset($data['id_card'])) {
- $data['id_card'] = $this->maskIdCard($data['id_card']);
- }
- if (isset($data['mobile'])) {
- $data['mobile'] = $this->maskMobile($data['mobile']);
- }
- return $data;
- }
- /**
- * 清除技师信息缓存
- */
- private function clearCoachCache($coachId)
- {
- Cache::forget(self::CACHE_KEY_PREFIX.$coachId);
- }
- }
|