Deploy: 2026-05-22 23:55:19
This commit is contained in:
@@ -172,7 +172,7 @@ EOT
|
||||
$configuredGeminiKey = ($rule && !empty($rule['gemini_api_key'])) ? $rule['gemini_api_key'] : null;
|
||||
$apiKey = GeminiService::getGeminiApiKey($configuredGeminiKey);
|
||||
if (!empty($apiKey)) {
|
||||
$postponeData = $this->detectPostponement($text, $apiKey);
|
||||
$postponeData = $this->detectPostponement($text, $apiKey, $companyId);
|
||||
if ($postponeData !== null) {
|
||||
$hours = $postponeData['hours'];
|
||||
$postponeCount = ($context['postpone_count'] ?? 0) + 1;
|
||||
@@ -366,6 +366,15 @@ EOT
|
||||
}
|
||||
|
||||
$companyId = $context['company_id'] ?? 1;
|
||||
|
||||
// Check subscription limit for OCR
|
||||
if ($companyId !== 1) {
|
||||
if (!\App\Models\CompanySubscriptionUsage::hasRemainingLimit($companyId, 'ocr')) {
|
||||
error_log("[DriverRegistrationFlow] Company {$companyId} has exceeded its OCR limit.");
|
||||
return new FlowResult("⚠️ عذراً، لقد استهلك هذا المتجر الحد المسموح له من تحليل الصور والوصولات لهذا الشهر. يرجى إرسال استفسارك نصياً.", $step);
|
||||
}
|
||||
}
|
||||
|
||||
$rule = ChatbotRule::findActiveForRule($companyId);
|
||||
$configuredGeminiKey = ($rule && !empty($rule['gemini_api_key'])) ? $rule['gemini_api_key'] : null;
|
||||
$apiKey = GeminiService::getGeminiApiKey($configuredGeminiKey);
|
||||
@@ -389,6 +398,12 @@ EOT
|
||||
return new FlowResult($failMessage, $step);
|
||||
}
|
||||
|
||||
// Increment stats on successful OCR processing
|
||||
if ($companyId !== 1) {
|
||||
\App\Models\CompanySubscriptionUsage::incrementUsage($companyId, 'ocr');
|
||||
\App\Models\CompanySubscriptionUsage::incrementUsage($companyId, 'request');
|
||||
}
|
||||
|
||||
// Save URL and OCR JSON string in the conversation context
|
||||
$context[$step . '_url'] = $imageUrl;
|
||||
$context[$step . '_ocr'] = $ocrData;
|
||||
@@ -432,7 +447,7 @@ EOT
|
||||
/**
|
||||
* Detect if user wants to postpone, and return hours_delay if so.
|
||||
*/
|
||||
private function detectPostponement(string $text, string $apiKey): ?array
|
||||
private function detectPostponement(string $text, string $apiKey, int $companyId): ?array
|
||||
{
|
||||
if (empty($text)) {
|
||||
return null;
|
||||
@@ -471,6 +486,11 @@ EOT;
|
||||
return null;
|
||||
}
|
||||
|
||||
// Increment request limit on successful postponement check API call
|
||||
if ($companyId !== 1) {
|
||||
\App\Models\CompanySubscriptionUsage::incrementUsage($companyId, 'request');
|
||||
}
|
||||
|
||||
// Clean markdown block if present
|
||||
$response = trim(preg_replace('/```json|```/', '', $response));
|
||||
$data = json_decode($response, true);
|
||||
|
||||
Reference in New Issue
Block a user