123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378 |
- <?php
- /*
- FusionPBX
- Version: MPL 1.1
- The contents of this file are subject to the Mozilla Public License Version
- 1.1 (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
- http://www.mozilla.org/MPL/
- Software distributed under the License is distributed on an "AS IS" basis,
- WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- for the specific language governing rights and limitations under the
- License.
- The Original Code is FusionPBX
- The Initial Developer of the Original Code is
- Mark J Crane <[email protected]>
- Portions created by the Initial Developer are Copyright (C) 2008-2024
- the Initial Developer. All Rights Reserved.
- Contributor(s):
- Mark J Crane <[email protected]>
- James Rose <[email protected]>
- */
- //includes files
- require_once dirname(__DIR__, 2) . "/resources/require.php";
- require_once "resources/check_auth.php";
- //permissions
- if (permission_exists('sql_query')) {
- //access granted
- }
- else {
- echo "access denied";
- exit;
- }
- //add multi-lingual support
- $language = new text;
- $text = $language->get();
- //load editor preferences/defaults
- $setting_size = (!empty($_SESSION["editor"]["font_size"]["text"])) ? $_SESSION["editor"]["font_size"]["text"] : '12px';
- $setting_theme = (!empty($_SESSION["editor"]["theme"]["text"])) ? $_SESSION["editor"]["theme"]["text"] : 'cobalt';
- $setting_invisibles = (!empty($_SESSION["editor"]["invisibles"]["boolean"])) ? $_SESSION["editor"]["invisibles"]["boolean"] : 'false';
- $setting_indenting = (!empty($_SESSION["editor"]["indent_guides"]["boolean"])) ? $_SESSION["editor"]["indent_guides"]["boolean"] : 'false';
- $setting_numbering = (!empty($_SESSION["editor"]["line_numbers"]["boolean"])) ? $_SESSION["editor"]["line_numbers"]["boolean"] : 'true';
- //get the html values and set them as variables
- $code = trim($_POST["code"] ?? '');
- $command = trim($_POST["command"] ?? '');
- //set editor moder
- $mode = 'sql';
- //show the header
- require_once "resources/header.php";
- $document['title'] = $text['title-sql_query'];
- //pdo database connection
- require_once "sql_query_pdo.php";
- //scripts and styles
- ?>
- <script language="JavaScript" type="text/javascript">
- function submit_check() {
- document.getElementById('command').value = editor.getSession().getValue();
- if (document.getElementById('mode').value == 'sql') {
- $('#frm').prop('target', 'iframe').prop('action', 'sql_query_result.php?code='+ document.getElementById('code').value);
- }
- else {
- if (document.getElementById('command').value == '') {
- focus_editor();
- return false;
- }
- $('#frm').prop('target', '').prop('action', '');
- }
- return true;
- }
- function toggle_option(opt) {
- switch (opt) {
- case 'numbering': toggle_option_do('showLineNumbers'); toggle_option_do('fadeFoldWidgets'); break;
- case 'invisibles': toggle_option_do('showInvisibles'); break;
- case 'indenting': toggle_option_do('displayIndentGuides'); break;
- }
- focus_editor();
- }
- function toggle_option_do(opt_name) {
- var opt_val = editor.getOption(opt_name);
- editor.setOption(opt_name, ((opt_val) ? false : true));
- }
- function insert_clip(before, after) {
- var selected_text = editor.session.getTextRange(editor.getSelectionRange());
- editor.insert(before + selected_text + after);
- focus_editor();
- }
- function focus_editor() {
- editor.focus();
- }
- function set_handler(handler) {
- switch (handler) {
- case 'sql':
- document.getElementById('description').innerHTML = "<?php echo $text['description-sql'];?>";
- editor.getSession().setMode('ace/mode/sql');
- $('#mode option[value=sql]').prop('selected',true);
- $('#response').hide();
- break;
- default:
- break;
- }
- focus_editor();
- }
- function reset_editor() {
- editor.getSession().setValue('');
- $('#iframe').prop('src','sql_query_result.php');
- focus_editor();
- }
- </script>
- <style>
- div#editor {
- box-shadow: 0 3px 10px #333;
- text-align: left;
- width: 100%;
- height: calc(100% - 30px);
- font-size: 12px;
- }
- i.ace_control {
- cursor: pointer;
- margin-right: 5px;
- opacity: 0.5;
- }
- i.ace_control:hover {
- opacity: 1.0;
- }
- </style>
- <?php
- //create token
- $object = new token;
- $token = $object->create('/app/sql_query/sql_query.php');
- //show the header
- echo "<form method='post' name='frm' id='frm' action='sql_query_result.php' style='margin: 0;' target='iframe' onsubmit='return submit_check();'>\n";
- echo "<table cellpadding='0' cellspacing='0' border='0' width='100%'>";
- echo " <tr>";
- echo " <td valign='top' align='left' width='50%'>";
- echo " <b>".$text['title-sql_query']."</b>\n";
- echo " </td>";
- echo " <td valign='top' align='right' nowrap='nowrap'>";
- //sql controls
- echo " <span class='sql_controls'>";
- //echo " ".$text['label-table']."<br />";
- echo " <select name='table_name' id='table_name' class='formfld'>\n";
- echo " <option value=''></option>\n";
- switch ($db_type) {
- case 'sqlite': $sql = "select name from sqlite_master where type='table' order by name;"; break;
- case 'pgsql': $sql = "select table_name as name from information_schema.tables where table_schema='public' and (table_type='BASE TABLE' or table_type='VIEW') order by table_type, table_name"; break;
- case 'mysql': $sql = "show tables"; break;
- }
- $database = new database;
- $result = $database->select($sql, null, 'all');
- if (is_array($result) && @sizeof($result) != 0) {
- foreach ($result as &$row) {
- $row = array_values($row);
- echo " <option value='".escape($row[0])."'>".escape($row[0])."</option>\n";
- }
- }
- unset($sql, $result, $row);
- echo " </select>\n";
- //echo " <br /><br />\n";
- //echo " ".$text['label-result_type']."<br />";
- echo " <select name='sql_type' id='sql_type' class='formfld'>\n";
- echo " <option value=''>".$text['option-result_type_view']."</option>\n";
- echo " <option value='csv'>".$text['option-result_type_csv']."</option>\n";
- echo " <option value='inserts'>".$text['option-result_type_insert']."</option>\n";
- echo " </select>\n";
- echo " </span>";
- echo " <input type='submit' class='btn' style='margin-top: 0px;' title=\"".$text['button-execute']." [Ctrl+Enter]\" value=\" ".$text['button-execute']." \" >"; //onclick=\"$('form#frm').submit();\"
- echo " <input type='button' class='btn' style='margin-top: 0px;' title=\"\" value=\" ".$text['button-reset']." \" onclick=\"reset_editor();\">";
- echo " </td>\n";
- echo " </tr>\n";
- echo " <tr>\n";
- echo " <td colspan='2'>\n";
- echo $text['description-sql_query']."\n";
- echo " </td>\n";
- echo " </tr>\n";
- echo "</table>";
- echo "<br>";
- //html form
- echo "<div class='card'>\n";
- echo " <input type='hidden' name='id' value='".escape($_REQUEST['id'] ?? '')."'>\n"; //sql db id
- echo " <input type='hidden' name='".$token['name']."' value='".$token['hash']."'>\n";
- echo " <textarea name='command' id='command' style='display: none;'></textarea>";
- echo " <table cellpadding='0' cellspacing='0' border='0' style='width: 100%;'>\n";
- echo " <tr>";
- echo " <td style='width: 280px;' valign='top' nowrap>";
- echo " <table cellpadding='0' cellspacing='0' border='0' width='100%' height='100%'>";
- if (permission_exists('edit_view')) {
- echo " <tr>";
- echo " <td valign='top' height='100%'>";
- echo " <iframe id='clip_list' src='clip_list.php' style='border: none; border-top: 1px solid #ccc; border-bottom: 1px solid #ccc; height: calc(100% - 2px); width: calc(100% - 15px);'></iframe>\n";
- echo " </td>";
- echo " </tr>";
- }
- echo " </table>";
- echo " </td>";
- echo " <td valign='top' style='height: 400px;'>"
- ?>
- <table cellpadding='0' cellspacing='0' border='0' style='width: 100%;'>
- <tr>
- <td valign='middle' style='padding: 0 6px;' width='100%'><span id='description'><?php echo !empty($text['description-'.!empty($handler)]); ?></span></td>
- <td valign='middle' style='padding: 0;'><img src='resources/images/blank.gif' style='width: 1px; height: 30px; border: none;'></td>
- <td valign='middle' style='padding-left: 6px;'><i class='fas fa-list-ul fa-lg ace_control' title="<?php echo $text['label-toggle_line_numbers']; ?>" onclick="toggle_option('numbering');"></i></td>
- <td valign='middle' style='padding-left: 6px;'><i class='fas fa-eye-slash fa-lg ace_control' title="<?php echo $text['label-toggle_invisibles']; ?>" onclick="toggle_option('invisibles');"></i></td>
- <td valign='middle' style='padding-left: 6px;'><i class='fas fa-indent fa-lg ace_control' title="<?php echo $text['label-toggle_indent_guides']; ?>" onclick="toggle_option('indenting');"></i></td>
- <td valign='middle' style='padding-left: 6px;'><i class='fas fa-search fa-lg ace_control' title="<?php echo $text['label-find_replace']; ?>" onclick="editor.execCommand('replace');"></i></td>
- <td valign='middle' style='padding-left: 6px;'><i class='fas fa-chevron-down fa-lg ace_control' title="<?php echo $text['label-go_to_line']; ?>" onclick="editor.execCommand('gotoline');"></i></td>
- <td valign='middle' style='padding-left: 15px;'>
- <select id='mode' style='height: 23px;' onchange="editor.getSession().setMode((this.options[this.selectedIndex].value == 'php') ? {path:'ace/mode/php', inline:true} : 'ace/mode/' + this.options[this.selectedIndex].value); focus_editor();">
- <?php
- $modes['php'] = 'PHP';
- $modes['css'] = 'CSS';
- $modes['html'] = 'HTML';
- $modes['javascript'] = 'JS';
- $modes['json'] = 'JSON';
- $modes['ini'] = 'Conf';
- $modes['lua'] = 'Lua';
- $modes['text'] = 'Text';
- $modes['xml'] = 'XML';
- $modes['sql'] = 'SQL';
- foreach ($modes as $value => $label) {
- $selected = $value == $mode ? 'selected' : null;
- echo "<option value='".$value."' ".$selected.">".escape($label)."</option>\n";
- }
- ?>
- </select>
- </td>
- <td valign='middle' style='padding-left: 4px;'>
- <select id='size' style='height: 23px;' onchange="document.getElementById('editor').style.fontSize = this.options[this.selectedIndex].value; focus_editor();">
- <?php
- $sizes = explode(',','9px,10px,11px,12px,14px,16px,18px,20px');
- if (!in_array($setting_size, $sizes)) {
- echo "<option value='".$setting_size."'>".escape($setting_size)."</option>\n";
- echo "<option value='' disabled='disabled'></option>\n";
- }
- foreach ($sizes as $size) {
- $selected = ($size == $setting_size) ? 'selected' : null;
- echo "<option value='".$size."' ".$selected.">".escape($size)."</option>\n";
- }
- ?>
- </select>
- </td>
- <td valign='middle' style='padding-left: 4px; padding-right: 0px;'>
- <select id='theme' style='height: 23px;' onchange="editor.setTheme('ace/theme/' + this.options[this.selectedIndex].value); focus_editor();">
- <?php
- $themes['Light']['chrome']= 'Chrome';
- $themes['Light']['clouds']= 'Clouds';
- $themes['Light']['crimson_editor']= 'Crimson Editor';
- $themes['Light']['dawn']= 'Dawn';
- $themes['Light']['dreamweaver']= 'Dreamweaver';
- $themes['Light']['eclipse']= 'Eclipse';
- $themes['Light']['github']= 'GitHub';
- $themes['Light']['iplastic']= 'IPlastic';
- $themes['Light']['solarized_light']= 'Solarized Light';
- $themes['Light']['textmate']= 'TextMate';
- $themes['Light']['tomorrow']= 'Tomorrow';
- $themes['Light']['xcode']= 'XCode';
- $themes['Light']['kuroir']= 'Kuroir';
- $themes['Light']['katzenmilch']= 'KatzenMilch';
- $themes['Light']['sqlserver']= 'SQL Server';
- $themes['Dark']['ambiance']= 'Ambiance';
- $themes['Dark']['chaos']= 'Chaos';
- $themes['Dark']['clouds_midnight']= 'Clouds Midnight';
- $themes['Dark']['cobalt']= 'Cobalt';
- $themes['Dark']['idle_fingers']= 'idle Fingers';
- $themes['Dark']['kr_theme']= 'krTheme';
- $themes['Dark']['merbivore']= 'Merbivore';
- $themes['Dark']['merbivore_soft']= 'Merbivore Soft';
- $themes['Dark']['mono_industrial']= 'Mono Industrial';
- $themes['Dark']['monokai']= 'Monokai';
- $themes['Dark']['pastel_on_dark']= 'Pastel on dark';
- $themes['Dark']['solarized_dark']= 'Solarized Dark';
- $themes['Dark']['terminal']= 'Terminal';
- $themes['Dark']['tomorrow_night']= 'Tomorrow Night';
- $themes['Dark']['tomorrow_night_blue']= 'Tomorrow Night Blue';
- $themes['Dark']['tomorrow_night_bright']= 'Tomorrow Night Bright';
- $themes['Dark']['tomorrow_night_eighties']= 'Tomorrow Night 80s';
- $themes['Dark']['twilight']= 'Twilight';
- $themes['Dark']['vibrant_ink']= 'Vibrant Ink';
- foreach ($themes as $optgroup => $theme) {
- echo "<optgroup label='".$optgroup."'>\n";
- foreach ($theme as $value => $label) {
- $selected = strtolower($label) == strtolower($setting_theme) ? 'selected' : null;
- echo "<option value='".$value."' ".$selected.">".escape($label)."</option>\n";
- }
- echo "</optgroup>\n";
- }
- ?>
- </select>
- </td>
- </tr>
- </table>
- <div id='editor' style='resize:vertical; overflow:auto;'><?php echo $command; ?></div>
- <?php
- echo " </td>";
- echo " </tr>\n";
- echo " </table>";
- echo " </form>";
- echo " <br /><br />";
- ?>
- <script type="text/javascript" src="<?php echo PROJECT_PATH; ?>/resources/ace/ace.js" charset="utf-8"></script>
- <script type="text/javascript">
- //load ace editor
- var editor = ace.edit("editor");
- editor.setOptions({
- mode: 'ace/mode/<?php echo $mode;?>',
- theme: 'ace/theme/'+document.getElementById('theme').options[document.getElementById('theme').selectedIndex].value,
- selectionStyle: 'text',
- cursorStyle: 'smooth',
- showInvisibles: <?php echo $setting_invisibles;?>,
- displayIndentGuides: <?php echo $setting_indenting;?>,
- showLineNumbers: <?php echo $setting_numbering;?>,
- showGutter: true,
- scrollPastEnd: true,
- fadeFoldWidgets: <?php echo $setting_numbering;?>,
- showPrintMargin: false,
- highlightGutterLine: false,
- useSoftTabs: false
- });
- <?php if ($mode == 'php') { ?>
- editor.getSession().setMode({path:'ace/mode/php', inline:true});
- <?php } ?>
- document.getElementById('editor').style.fontSize='<?php echo escape($setting_size);?>';
- focus_editor();
- //keyboard shortcut to execute command
- <?php key_press('ctrl+enter', 'down', 'window', null, null, "$('form#frm').submit();", false); ?>
- //remove certain keyboard shortcuts
- editor.commands.bindKey("Ctrl-T", null); //disable transpose letters - prefer new browser tab
- editor.commands.bindKey("Ctrl-F", null); //disable find - control broken with bootstrap
- editor.commands.bindKey("Ctrl-H", null); //disable replace - control broken with bootstrap
- </script>
- <?php
- //sql result
- echo " <span id='sql_response'>";
- //echo " <b>".$text['label-results']."</b>\n";
- //echo " <br /><br />\n";
- echo " <iframe name='iframe' id='iframe' style='width: calc(100% - 3px); height: 500px; background-color: #fff; border: 0px solid #c0c0c0;' src='sql_query_result.php'></iframe>\n";
- echo " </span>";
- echo "</div>\n";
- //show the footer
- require_once "resources/footer.php";
- ?>
|