<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
 * handles creation of VIEWs
 *
 * @todo js error when view name is empty (strFormEmpty)
 * @todo (also validate if js is disabled, after form submission?)
 * @package phpMyAdmin
 */

/**
 * do not import request variable into global scope
 * @ignore
 */
if (! defined('PMA_NO_VARIABLES_IMPORT')) {
    
define('PMA_NO_VARIABLES_IMPORT'true);
}

/**
 *
 */
require_once './libraries/common.inc.php';

/**
 * Runs common work
 */
require './libraries/db_common.inc.php';
$url_params['goto'] = $cfg['DefaultTabDatabase'];
$url_params['back'] = 'view_create.php';

$view_algorithm_options = array(
    
'UNDEFINED',
    
'MERGE',
    
'TEMPTABLE',
);

$view_with_options = array(
    
'CASCADED CHECK OPTION',
    
'LOCAL CHECK OPTION'
);

if (isset(
$_REQUEST['createview'])) {
    
/**
     * Creates the view
     */
    
$sep "\r\n";

    
$sql_query 'CREATE';

    if (isset(
$_REQUEST['view']['or_replace'])) {
        
$sql_query .= ' OR REPLACE';
    }

    if (
PMA_isValid($_REQUEST['view']['algorithm'], $view_algorithm_options)) {
        
$sql_query .= $sep ' ALGORITHM = ' $_REQUEST['view']['algorithm'];
    }

    
$sql_query .= $sep ' VIEW ' PMA_backquote($_REQUEST['view']['name']);

    if (! empty(
$_REQUEST['view']['column_names'])) {
        
$sql_query .= $sep ' (' $_REQUEST['view']['column_names'] . ')';
    }

    
$sql_query .= $sep ' AS ' $_REQUEST['view']['as'];

    if (isset(
$_REQUEST['view']['with'])) {
        
$options array_intersect($_REQUEST['view']['with'], $view_with_options);
        if (
count($options)) {
            
$sql_query .= $sep ' WITH ' implode(' '$options);
        }
    }

    if (
PMA_DBI_try_query($sql_query)) {
        
$message PMA_Message::success();
        require 
'./' $cfg['DefaultTabDatabase'];
        exit();
    } else {
        
$message PMA_Message::rawError(PMA_DBI_getError());
    }
}

// prefill values if not already filled from former submission
$view = array(
    
'or_replace' => '',
    
'algorithm' => '',
    
'name' => '',
    
'column_names' => '',
    
'as' => $sql_query,
    
'with' => array(),
);

if (
PMA_isValid($_REQUEST['view'], 'array')) {
    
$view array_merge($view$_REQUEST['view']);
}

/**
 * Displays top menu links
 * We use db links because a VIEW is not necessarily on a single table
 */
$num_tables 0;
require_once 
'./libraries/db_links.inc.php';

$url_params['db'] = $GLOBALS['db'];
$url_params['reload'] = 1;

/**
 * Displays the page
 */
?>
<!-- CREATE VIEW options -->
<div id="div_view_options">
<form method="post" action="view_create.php">
<?php echo PMA_generate_common_hidden_inputs($url_params); ?>
<fieldset>
    <legend>CREATE VIEW</legend>

    <table>
    <tr><td><label for="or_replace">OR REPLACE</label></td>
        <td><input type="checkbox" name="view[or_replace]" id="or_replace"
                <?php if ($view['or_replace']) { ?>
                checked="checked"
                <?php ?>
                value="1" />
        </td>
    </tr>
    <tr>
        <td><label for="algorithm">ALGORITHM</label></td>
        <td><select name="view[algorithm]" id="algorithm">
            <?php
            
foreach ($view_algorithm_options as $option) {
                echo 
'<option value="' htmlspecialchars($option) . '"';
                if (
$view['algorithm'] === $option) {
                    echo 
'selected="selected"';
                }
                echo 
'>' htmlspecialchars($option) . '</option>';
            }
            
?>
            </select>
        </td>
    </tr>
    <tr><td><?php echo __('VIEW name'); ?></td>
        <td><input type="text" size="20" name="view[name]" onfocus="this.select()"
                value="<?php echo htmlspecialchars($view['name']); ?>" />
        </td>
    </tr>

    <tr><td><?php echo __('Column names'); ?></td>
        <td><input type="text" maxlength="100" size="50" name="view[column_names]"
                onfocus="this.select()"
                value="<?php echo htmlspecialchars($view['column_names']); ?>" />
        </td>
    </tr>

    <tr><td>AS</td>
        <td>
            <textarea name="view[as]" rows="<?php echo $cfg['TextareaRows']; ?>"
                cols="<?php echo $cfg['TextareaCols']; ?>"
                dir="<?php echo $text_dir?>" onfocus="this.select();"
                ><?php echo htmlspecialchars($view['as']); ?></textarea>
        </td>
    </tr>
    <tr><td>WITH</td>
        <td>
            <?php
            
foreach ($view_with_options as $option) {
                echo 
'<input type="checkbox" name="view[with][]"';
                if (
in_array($option$view['with'])) {
                    echo 
' checked="checked"';
                }
                echo 
' id="view_with_' str_replace(' ''_'htmlspecialchars($option)) . '"';
                echo 
' value="' htmlspecialchars($option) . '" />';
                echo 
'<label for="view_with_' str_replace(' ''_'htmlspecialchars($option)) . '">';
                echo 
htmlspecialchars($option) . '</label>&nbsp;';
            }
            
?>
        </td>
    </tr>
    </table>
</fieldset>
<fieldset class="tblFooters">
    <input type="submit" name="createview" value="<?php echo __('Go'); ?>" />
</fieldset>
</form>
</div>
<?php
/**
 * Displays the footer
 */
require './libraries/footer.inc.php';

?>