mirror of
https://github.com/vrana/adminer.git
synced 2025-08-08 07:36:44 +02:00
121 lines
4.2 KiB
PHP
121 lines
4.2 KiB
PHP
<?php
|
|
|
|
/** AI prompt in SQL command generating the queries with Google Gemini
|
|
* Beware that this sends your whole database structure (not data) to Google Gemini.
|
|
* @link https://gemini.google.com/
|
|
* @link https://www.adminer.org/plugins/#use
|
|
* @author Jakub Vrana, https://www.vrana.cz/
|
|
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
|
|
* @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
|
|
*/
|
|
class AdminerSqlGemini extends Adminer\Plugin {
|
|
private $apiKey;
|
|
private $model;
|
|
|
|
/**
|
|
* @param string $apiKey The default key is shared with all users and may run out of quota; get your own API key at: https://aistudio.google.com/apikey
|
|
* @param string $model Available models: https://ai.google.dev/gemini-api/docs/models#available-models
|
|
*/
|
|
function __construct($apiKey = 'AIzaSyDWDbPjmvH9_hphsnY_yJGdue42qRMG3do', $model = "gemini-2.0-flash") {
|
|
$this->apiKey = $apiKey;
|
|
$this->model = $model;
|
|
}
|
|
|
|
function headers() {
|
|
if (isset($_POST["gemini"]) && !isset($_POST["query"])) {
|
|
$prompt = "I have a " . Adminer\get_driver(Adminer\DRIVER) . " database with this structure:\n\n";
|
|
foreach (Adminer\tables_list() as $table => $type) {
|
|
$prompt .= Adminer\create_sql($table, false, "CREATE") . ";\n\n";
|
|
}
|
|
$prompt .= "Prefer returning relevant columns including primary key.\n\n";
|
|
$prompt .= "Give me this SQL query and nothing else:\n\n$_POST[gemini]\n\n";
|
|
//~ echo $prompt; exit;
|
|
$context = stream_context_create(array("http" => array(
|
|
"method" => "POST",
|
|
"header" => array("User-Agent: AdminerSqlGemini/" . Adminer\VERSION, "Content-Type: application/json"),
|
|
"content" => '{"contents": [{"parts":[{"text": ' . json_encode($prompt) . '}]}]}',
|
|
"ignore_errors" => true,
|
|
)));
|
|
$response = json_decode(file_get_contents("https://generativelanguage.googleapis.com/v1beta/models/$this->model:generateContent?key=$this->apiKey", false, $context));
|
|
if (isset($response->error)) {
|
|
echo "-- " . $response->error->message;
|
|
} else {
|
|
$text = $response->candidates[0]->content->parts[0]->text;
|
|
$text2 = preg_replace('~(\n|^)```sql\n(.+)\n```(\n|$)~sU', "*/\n\n\\2\n\n/*", "/*\n$text\n*/", -1, $count);
|
|
echo ($count ? preg_replace('~/\*\s*\*/\n*~', '', $text2) : $text);
|
|
}
|
|
exit;
|
|
}
|
|
}
|
|
|
|
function sqlPrintAfter() {
|
|
echo "<p><textarea name='gemini' rows='5' cols='50' placeholder='" . $this->lang('Ask Gemini') . "'>" . Adminer\h($_POST["gemini"]) . "</textarea>\n";
|
|
?>
|
|
<p><input type='button' value='Gemini'>
|
|
<script <?php echo Adminer\nonce(); ?>>
|
|
const geminiText = qsl('textarea');
|
|
const geminiButton = qsl('input');
|
|
|
|
function setSqlareaValue(value) {
|
|
const sqlarea = qs('textarea.sqlarea');
|
|
sqlarea.value = value;
|
|
sqlarea.onchange && sqlarea.onchange();
|
|
}
|
|
|
|
geminiButton.onclick = () => {
|
|
setSqlareaValue('-- <?php echo $this->lang('Just a sec...'); ?>');
|
|
ajax(
|
|
'',
|
|
req => setSqlareaValue(req.responseText),
|
|
'gemini=' + encodeURIComponent(geminiText.value)
|
|
);
|
|
};
|
|
|
|
geminiText.onfocus = event => {
|
|
alterClass(findDefaultSubmit(geminiText), 'default');
|
|
alterClass(geminiButton, 'default', true);
|
|
event.stopImmediatePropagation();
|
|
};
|
|
|
|
geminiText.onblur = () => {
|
|
alterClass(geminiButton, 'default');
|
|
};
|
|
|
|
geminiText.onkeydown = event => {
|
|
if (isCtrl(event) && (event.keyCode == 13 || event.keyCode == 10)) {
|
|
geminiButton.onclick();
|
|
event.stopPropagation();
|
|
}
|
|
};
|
|
</script>
|
|
<?php
|
|
}
|
|
|
|
function screenshot() {
|
|
return "https://www.adminer.org/static/plugins/sql-gemini.gif";
|
|
}
|
|
|
|
// use the phrases from https://gemini.google.com/
|
|
protected $translations = array(
|
|
'cs' => array(
|
|
'' => 'Generování SQL příkazů pomocí umělé inteligence Google Gemini',
|
|
'Ask Gemini' => 'Zeptat se Gemini',
|
|
'Just a sec...' => 'Chviličku...',
|
|
),
|
|
'pl' => array(
|
|
'Ask Gemini' => 'Zapytaj Gemini',
|
|
'Just a sec...' => 'Chwileczkę...',
|
|
),
|
|
'de' => array(
|
|
'' => 'KI-Eingabeaufforderung im SQL-Befehl zur Erstellung der Abfragen mit Google Gemini',
|
|
'Ask Gemini' => 'Gemini fragen',
|
|
'Just a sec...' => 'Einen Moment...',
|
|
),
|
|
'ja' => array(
|
|
'' => 'Google Gemini AI を用いて SQL 文を生成',
|
|
'Ask Gemini' => 'Gemini に聞く',
|
|
'Just a sec...' => 'しばらくお待ち下さい...',
|
|
),
|
|
);
|
|
}
|