get('agent_id', ''))); $secret = trim((string) ($request->get('secret', ''))); $time = trim((string) ($request->get('time', ''))); $signature = trim((string) ($request->get('signature', ''))); if ($agentId === '' || $secret === '' || $time === '' || $signature === '') { return $this->fail('Missing parameters: agent_id, secret, time, signature are required', ReturnCode::PARAMS_ERROR); } $expectedSecret = config('api.auth_token_secret', ''); if ($expectedSecret === '') { return $this->fail('API_AUTH_TOKEN_SECRET is not configured', ReturnCode::SERVER_ERROR); } if ($secret !== $expectedSecret) { return $this->fail('Invalid secret', ReturnCode::FORBIDDEN); } $timeVal = (int) $time; $tolerance = (int) config('api.auth_token_time_tolerance', 300); $now = time(); if ($timeVal < $now - $tolerance || $timeVal > $now + $tolerance) { return $this->fail('Timestamp expired or invalid, please sync time', ReturnCode::FORBIDDEN); } $expectedSignature = md5($agentId . $secret . $time); if ($signature !== $expectedSignature) { return $this->fail('Signature verification failed', ReturnCode::FORBIDDEN); } $exp = (int) config('api.auth_token_exp', 86400); $tokenResult = JwtToken::generateToken([ 'id' => 0, 'agent_id' => $agentId, 'plat' => 'api_auth_token', 'access_exp' => $exp, ]); $token = $tokenResult['access_token']; if (!AuthTokenCache::setToken($agentId, $token)) { return $this->fail('Failed to generate token', ReturnCode::SERVER_ERROR); } return $this->success([ 'authtoken' => $token, ]); } }