3 // vim: expandtab sw=4 ts=4 sts=4:
7 * This script imports relation infos from docSQL (www.databay.de)
12 * Get the values of the variables posted or sent to this script and display
15 require('./libraries/read_dump.lib.php3');
16 require('./libraries/grab_globals.lib.php3');
17 require('./header.inc.php3');
19 //require common added for string importing - Robbat2, 15 January 2003 9.34PM
20 //all hardcoded strings converted by Robbat2, 15 January 2003 9.34PM
21 require('./libraries/common.lib.php3');
24 PMA_checkParameters(array('db'));
27 * Imports docSQL files
29 * @param string the basepath
30 * @param string the filename
31 * @param string the complete filename
32 * @param string the content of a file
35 * @return boolean always true
37 * @global array GLOBAL variables
39 function docsql_check($docpath = '', $file = '', $filename = '', $content = 'none') {
42 if (eregi('^(.*)_field_comment\.(txt|zip|bz2|bzip).*$', $filename)) {
43 $tab = eregi_replace('^(.*)_field_comment\.(txt|zip|bz2|bzip).*', '\1', $filename);
44 //echo '<h1>Working on Table ' . $_tab . '</h1>';
45 if ($content == 'none') {
47 $fd = fopen($docpath . $file, 'r');
50 $lines[] = fgets($fd, 4096);
54 $content = str_replace("\r\n", "\n", $content);
55 $content = str_replace("\r", "\n", $content);
56 $lines = explode("\n", $content);
59 if (isset($lines) && is_array($lines) && count($lines) > 0) {
61 while(list($lkey, $line) = each($lines)) {
62 //echo '<p>' . $line . '</p>';
63 $inf = explode('|',$line);
64 if (!empty($inf[1]) && strlen(trim($inf[1])) > 0) {
65 $qry = 'INSERT INTO ' . PMA_backquote($GLOBALS['cfgRelation']['column_info'])
66 . ' (db_name, table_name, column_name, ' . PMA_backquote('comment') . ') '
68 . '\'' . PMA_sqlAddslashes($GLOBALS['db']) . '\','
69 . '\'' . PMA_sqlAddslashes(trim($tab)) . '\','
70 . '\'' . PMA_sqlAddslashes(trim($inf[0])) . '\','
71 . '\'' . PMA_sqlAddslashes(trim($inf[1])) . '\')';
72 if (PMA_query_as_cu($qry)) {
73 echo '<p>' . $GLOBALS['strAddedColumnComment'] . ' ' . htmlspecialchars($tab) . '.' . htmlspecialchars($inf[0]) . '</p>';
75 echo '<p>' . $GLOBALS['strWritingCommentNotPossible'] . '</p>';
78 } // end inf[1] exists
79 if (!empty($inf[2]) && strlen(trim($inf[2])) > 0) {
80 $for = explode('->', $inf[2]);
81 $qry = 'INSERT INTO ' . PMA_backquote($GLOBALS['cfgRelation']['relation'])
82 . '(master_db, master_table, master_field, foreign_db, foreign_table, foreign_field)'
84 . '\'' . PMA_sqlAddslashes($GLOBALS['db']) . '\', '
85 . '\'' . PMA_sqlAddslashes(trim($tab)) . '\', '
86 . '\'' . PMA_sqlAddslashes(trim($inf[0])) . '\', '
87 . '\'' . PMA_sqlAddslashes($GLOBALS['db']) . '\', '
88 . '\'' . PMA_sqlAddslashes(trim($for[0])) . '\','
89 . '\'' . PMA_sqlAddslashes(trim($for[1])) . '\')';
90 if (PMA_query_as_cu($qry)) {
91 echo '<p>' . $GLOBALS['strAddedColumnRelation'] . ' ' . htmlspecialchars($tab) . '.' . htmlspecialchars($inf[0]) . ' to ' . htmlspecialchars($inf[2]) . '</p>';
93 echo '<p>' . $GLOBALS['strWritingRelationNotPossible'] . '</p>';
96 } // end inf[2] exists
98 echo '<p><font color="green">' . $GLOBALS['strImportFinished'] . '</font></p>' . "\n";
100 echo '<p><font color="red">' . $GLOBALS['strFileCouldNotBeRead'] . '</font></p>' . "\n";
105 if ($content != 'none') {
106 echo '<p><font color="orange">' . sprintf($GLOBALS['strIgnoringFile'], ' ' . htmlspecialchars($file)) . '</font></p>' . "\n";
108 // garvin: disabled. Shouldn't impose ANY non-submitted files ever.
109 echo '<p><font color="orange">' . sprintf($GLOBALS['strIgnoringFile'], ' ' . '...') . '</font></p>' . "\n";
112 } // end working on table
116 * Try to get the "$DOCUMENT_ROOT" variable whatever is the register_globals
119 if (empty($DOCUMENT_ROOT)) {
120 if (!empty($_SERVER) && isset($_SERVER['DOCUMENT_ROOT'])) {
121 $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT'];
123 else if (!empty($HTTP_SERVER_VARS) && isset($HTTP_SERVER_VARS['DOCUMENT_ROOT'])) {
124 $DOCUMENT_ROOT = $HTTP_SERVER_VARS['DOCUMENT_ROOT'];
126 else if (!empty($_ENV) && isset($_ENV['DOCUMENT_ROOT'])) {
127 $DOCUMENT_ROOT = $_ENV['DOCUMENT_ROOT'];
129 else if (!empty($HTTP_ENV_VARS) && isset($HTTP_ENV_VARS['DOCUMENT_ROOT'])) {
130 $DOCUMENT_ROOT = $HTTP_ENV_VARS['DOCUMENT_ROOT'];
132 else if (@getenv
('DOCUMENT_ROOT')) {
133 $DOCUMENT_ROOT = getenv('DOCUMENT_ROOT');
136 $DOCUMENT_ROOT = '.';
141 * Executes import if required
143 if (isset($do) && $do == 'import') {
144 $orig_docpath = $docpath;
146 if (empty($sql_file)) {
150 // Get relation settings
151 include('./libraries/relation.lib.php3');
152 $cfgRelation = PMA_getRelationsParam();
154 // Gets the query from a file if required
155 if ($sql_file != 'none') {
156 if (file_exists($sql_file)
157 && is_uploaded_file($sql_file)) {
160 if (PMA_PHP_INT_VERSION
>= 40000) {
161 $open_basedir = @ini_get
('open_basedir');
163 if (empty($open_basedir)) {
164 $open_basedir = @get_cfg_var
('open_basedir');
167 // If we are on a server with open_basedir, we must move the file
168 // before opening it. The doc explains how to create the "./tmp"
171 if (!empty($open_basedir)) {
173 $tmp_subdir = (PMA_IS_WINDOWS ?
'.\\tmp\\' : './tmp/');
175 // function is_writeable() is valid on PHP3 and 4
176 if (!is_writeable($tmp_subdir)) {
177 $docsql_text = PMA_readFile($sql_file, $sql_file_compression);
178 if ($docsql_text == FALSE) {
179 echo $strFileCouldNotBeRead;
184 $sql_file_new = $tmp_subdir . basename($sql_file);
185 if (PMA_PHP_INT_VERSION
< 40003) {
186 copy($sql_file, $sql_file_new);
188 move_uploaded_file($sql_file, $sql_file_new);
190 $docsql_text = PMA_readFile($sql_file_new, $sql_file_compression);
191 unlink($sql_file_new);
195 // read from the normal upload dir
196 $docsql_text = PMA_readFile($sql_file, $sql_file_compression);
199 // Convert the file's charset if necessary
200 if ($cfg['AllowAnywhereRecoding'] && $allow_recoding
201 && isset($charset_of_file) && $charset_of_file != $charset) {
202 $docsql_text = PMA_convert_string($charset_of_file, $charset, $docsql_text);
205 if (!isset($docsql_text) ||
$docsql_text == FALSE ||
$docsql_text == '') {
206 echo '<p><font color="red">' . $GLOBALS['strFileCouldNotBeRead'] . '</font></p>' . "\n";
208 docsql_check('', $sql_file_name, $sql_file_name, $docsql_text);
210 } // end uploaded file stuff
213 // echo '<h1>Starting Import</h1>';
214 $docpath = $DOCUMENT_ROOT . dirname($PHP_SELF) . '/docSQL/' . eregi_replace('\.\.*', '.', $docpath);
215 if (substr($docpath, strlen($docpath) - 2, 1) != '/') {
216 $docpath = $docpath . '/';
221 if (is_dir($docpath)) {
223 $handle = opendir($docpath);
224 while ($file = @readdir
($handle)) {
225 $filename = basename($file);
226 // echo '<p>Working on file ' . $filename . '</p>';
227 $matched_files +
= docsql_check($docpath, $file, $filename);
230 echo '<p><font color="red">' .$docpath . ': ' . $strThisNotDirectory . "</font></p>\n";
241 <form method
="post" action
="db_details_importdocsql.php3" <?php
if ($is_upload) echo ' enctype="multipart/form-data"'; ?
>>
242 <?php
echo PMA_generate_common_hidden_inputs($db); ?
>
243 <input type
="hidden" name
="submit_show" value
="true" />
244 <input type
="hidden" name
="do" value
="import" />
245 <b
><?php
echo $strAbsolutePathToDocSqlDir; ?
>:</b
>
247 <?php
echo dirname($PHP_SELF) . '/docSQL'; ?
>/<input
class="textfield" type
="text" name
="docpath" size
="15" value
="<?php echo (isset($orig_docpath) ? $orig_docpath : ''); ?>" />
249 // garvin: displays import dump feature only if file upload available
252 echo ' <i>' . $strOr . '</i> ' . $strLocationTextfile . ' :<br />' . "\n";
254 <div style
="margin-bottom: 5px">
255 <input type
="file" name
="sql_file" class="textfield" /><br
/>
257 if ($cfg['AllowAnywhereRecoding'] && $allow_recoding) {
258 $temp_charset = reset($cfg['AvailableCharsets']);
259 echo $strCharsetOfFile . "\n"
260 . ' <select name="charset_of_file" size="1">' . "\n"
261 . ' <option value="' . $temp_charset . '"';
262 if ($temp_charset == $charset) {
263 echo ' selected="selected"';
265 echo '>' . $temp_charset . '</option>' . "\n";
266 while ($temp_charset = next($cfg['AvailableCharsets'])) {
267 echo ' <option value="' . $temp_charset . '"';
268 if ($temp_charset == $charset) {
269 echo ' selected="selected"';
271 echo '>' . $temp_charset . '</option>' . "\n";
273 echo ' </select><br />' . "\n" . ' ';
275 $is_gzip = ($cfg['GZipDump'] && @function_exists
('gzopen'));
276 $is_bzip = ($cfg['BZipDump'] && @function_exists
('bzdecompress'));
277 if ($is_bzip ||
$is_gzip) {
278 echo ' ' . $strCompression . ':' . "\n"
279 . ' <input type="radio" id="radio_sql_file_compression_auto" name="sql_file_compression" value="" checked="checked" />' . "\n"
280 . ' <label for="radio_sql_file_compression_auto">' . $strAutodetect . '</label> ' . "\n"
281 . ' <input type="radio" id="radio_sql_file_compression_plain" name="sql_file_compression" value="text/plain" />' . "\n"
282 . ' <label for="radio_sql_file_compression_plain">' . $strNone . '</label> ' . "\n";
284 echo ' <input type="radio" id="radio_sql_file_compression_gzip" name="sql_file_compression" value="application/x-gzip" />' . "\n"
285 . ' <label for="radio_sql_file_compression_gzip">' . $strGzip . '</label> ' . "\n";
288 echo ' <input type="radio" id="radio_sql_file_compression_bzip" name="sql_file_compression" value="application/x-bzip" />' . "\n"
289 . ' <label for="radio_sql_file_compression_bzip">' . $strBzip . '</label> ' . "\n";
292 echo ' <input type="hidden" name="sql_file_compression" value="text/plain" />' . "\n";
301  
;<input type
="submit" value
="<?php echo $strImportFiles; ?>" />
306 * Displays the footer
309 require('./footer.inc.php3');