feature: chatbot pimpinan
This commit is contained in:
@@ -153,6 +153,72 @@ class OpenAIService
|
||||
|
||||
return trim($response['choices'][0]['message']['content'] ?? 'No response');
|
||||
}
|
||||
|
||||
public function classifyMainGenerateText($prompt) {
|
||||
$response = $this->client->chat()->create([
|
||||
'model' => 'gpt-4o-mini',
|
||||
'messages' => [
|
||||
[
|
||||
'role' => 'system',
|
||||
'content' => "You are an assistant that classifies text into one of the following categories:
|
||||
- reklame (ads or product/service promotions)
|
||||
- business_or_industries (business or industries in general)
|
||||
- customers (customers, consumers, or service users)
|
||||
- pbg (tasks related to Building Approval)
|
||||
- retribusi (retributions related to PBG)
|
||||
- spatial_plannings (spatial planning)
|
||||
- tourisms (tourism and tourist destinations)
|
||||
- umkms (Micro, Small, and Medium Enterprises)
|
||||
|
||||
Respond with only one of the categories above without any additional explanation."
|
||||
],
|
||||
[
|
||||
'role' => 'user',
|
||||
'content' => "Classify the following text:\n\n" . $prompt
|
||||
],
|
||||
],
|
||||
]);
|
||||
|
||||
return trim($response['choices'][0]['message']['content'] ?? 'No response');
|
||||
}
|
||||
|
||||
public function createMainQuery($classify, $prompt)
|
||||
{
|
||||
// Load file JSON
|
||||
$jsonPath = public_path('templates/table_config.json');
|
||||
$jsonConfig = json_decode(file_get_contents($jsonPath), true);
|
||||
|
||||
// Pastikan kategori tersedia dalam konfigurasi
|
||||
if (!isset($jsonConfig[$classify])) {
|
||||
return "Error: Kategori tidak ditemukan dalam konfigurasi.";
|
||||
}
|
||||
|
||||
// Ambil nama tabel dan kolom
|
||||
$tableName = $jsonConfig[$classify]['table_name'];
|
||||
$columns = implode(', ', $jsonConfig[$classify]['list_column']);
|
||||
|
||||
$response = $this->client->chat()->create([
|
||||
'model' => 'gpt-4o-mini',
|
||||
'messages' => [
|
||||
[
|
||||
'role' => 'system',
|
||||
'content' => "You are an AI assistant that generates only valid MariaDB queries based on user requests.
|
||||
Use the following table information to construct the SQL query:
|
||||
|
||||
- Table Name: $tableName
|
||||
- Available Columns: $columns
|
||||
|
||||
Generate only the SQL query without any explanation or additional text."
|
||||
],
|
||||
[
|
||||
'role' => 'user',
|
||||
'content' => $prompt
|
||||
],
|
||||
],
|
||||
]);
|
||||
|
||||
return trim($response['choices'][0]['message']['content'] ?? 'No response');
|
||||
}
|
||||
|
||||
public function mainGenerateText($prompt) {
|
||||
$response = $this->client->chat()->create([
|
||||
|
||||
Reference in New Issue
Block a user