'strOpenDocumentText', 'extension' => 'odt', 'mime_type' => 'application/vnd.oasis.opendocument.text', 'force_file' => true, 'options' => array(), /* Filled later */ 'options_text' => 'strOptions', ); /* Structure options */ if (!$hide_structure) { $plugin_list['odt']['options'][] = array('type' => 'bgroup', 'name' => 'structure', 'text' => 'strStructure', 'force' => 'data'); if (!empty($GLOBALS['cfgRelation']['relation'])) { $plugin_list['odt']['options'][] = array('type' => 'bool', 'name' => 'relation', 'text' => 'strRelations'); } $plugin_list['odt']['options'][] = array('type' => 'bool', 'name' => 'comments', 'text' => 'strComments'); if (!empty($GLOBALS['cfgRelation']['mimework'])) { $plugin_list['odt']['options'][] = array('type' => 'bool', 'name' => 'mime', 'text' => 'strMIME_MIMEtype'); } $plugin_list['odt']['options'][] = array('type' => 'egroup'); } /* Data */ $plugin_list['odt']['options'][] = array('type' => 'bgroup', 'name' => 'data', 'text' => 'strData', 'force' => 'structure'); $plugin_list['odt']['options'][] = array('type' => 'bool', 'name' => 'columns', 'text' => 'strPutColNames'); $plugin_list['odt']['options'][] = array('type' => 'text', 'name' => 'null', 'text' => 'strReplaceNULLBy'); $plugin_list['odt']['options'][] = array('type' => 'egroup'); } else { $GLOBALS['odt_buffer'] = ''; require_once './libraries/opendocument.lib.php'; /** * Outputs comment * * @param string Text of comment * * @return bool Whether it suceeded */ function PMA_exportComment($text) { return TRUE; } /** * Outputs export footer * * @return bool Whether it suceeded * * @access public */ function PMA_exportFooter() { $GLOBALS['odt_buffer'] .= '' . '' . ''; if (!PMA_exportOutputHandler(PMA_createOpenDocument('application/vnd.oasis.opendocument.text', $GLOBALS['odt_buffer']))) { return FALSE; } return TRUE; } /** * Outputs export header * * @return bool Whether it suceeded * * @access public */ function PMA_exportHeader() { $GLOBALS['odt_buffer'] .= '' . '' . '' . ''; return TRUE; } /** * Outputs database header * * @param string Database name * * @return bool Whether it suceeded * * @access public */ function PMA_exportDBHeader($db) { $GLOBALS['odt_buffer'] .= '' . htmlspecialchars($GLOBALS['strDatabase'] . ' ' . $db) . ''; return TRUE; } /** * Outputs database footer * * @param string Database name * * @return bool Whether it suceeded * * @access public */ function PMA_exportDBFooter($db) { return TRUE; } /** * Outputs create database database * * @param string Database name * * @return bool Whether it suceeded * * @access public */ function PMA_exportDBCreate($db) { return TRUE; } /** * Outputs the content of a table in CSV format * * @param string the database name * @param string the table name * @param string the end of line sequence * @param string the url to go back in case of error * @param string SQL query for obtaining data * * @return bool Whether it suceeded * * @access public */ function PMA_exportData($db, $table, $crlf, $error_url, $sql_query) { global $what; // Gets the data from the database $result = PMA_DBI_query($sql_query, null, PMA_DBI_QUERY_UNBUFFERED); $fields_cnt = PMA_DBI_num_fields($result); $fields_meta = PMA_DBI_get_fields_meta($result); $field_flags = array(); for ($j = 0; $j < $fields_cnt; $j++) { $field_flags[$j] = PMA_DBI_field_flags($result, $j); } $GLOBALS['odt_buffer'] .= '' . htmlspecialchars($GLOBALS['strDumpingData'] . ' ' . $table) . ''; $GLOBALS['odt_buffer'] .= ''; $GLOBALS['odt_buffer'] .= ''; // If required, get fields name at the first line if (isset($GLOBALS[$what . '_columns'])) { $GLOBALS['odt_buffer'] .= ''; for ($i = 0; $i < $fields_cnt; $i++) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars(stripslashes(PMA_DBI_field_name($result, $i))) . '' . ''; } // end for $GLOBALS['odt_buffer'] .= ''; } // end if // Format the data while ($row = PMA_DBI_fetch_row($result)) { $GLOBALS['odt_buffer'] .= ''; for ($j = 0; $j < $fields_cnt; $j++) { if (!isset($row[$j]) || is_null($row[$j])) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS[$what . '_null']) . '' . ''; // ignore BLOB } elseif (stristr($field_flags[$j], 'BINARY') && $fields_meta[$j]->blob) { $GLOBALS['odt_buffer'] .= '' . '' . ''; } elseif ($fields_meta[$j]->numeric && $fields_meta[$j]->type != 'timestamp' && ! $fields_meta[$j]->blob) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($row[$j]) . '' . ''; } else { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($row[$j]) . '' . ''; } } // end for $GLOBALS['odt_buffer'] .= ''; } // end while PMA_DBI_free_result($result); $GLOBALS['odt_buffer'] .= ''; return TRUE; } /** * Returns $table's structure as Open Document Text * * @param string the database name * @param string the table name * @param string the end of line sequence * @param string the url to go back in case of error * @param boolean whether to include relation comments * @param boolean whether to include column comments * @param boolean whether to include mime comments * @param string future feature: support view dependencies * * @return bool Whether it suceeded * * @access public */ // @@@ $strTableStructure function PMA_exportStructure($db, $table, $crlf, $error_url, $do_relation = false, $do_comments = false, $do_mime = false, $dates = false, $dummy) { global $cfgRelation; /* Heading */ $GLOBALS['odt_buffer'] .= '' . htmlspecialchars($GLOBALS['strTableStructure'] . ' ' . $table) . ''; /** * Get the unique keys in the table */ $keys_query = 'SHOW KEYS FROM ' . PMA_backquote($table) . ' FROM '. PMA_backquote($db); $keys_result = PMA_DBI_query($keys_query); $unique_keys = array(); while ($key = PMA_DBI_fetch_assoc($keys_result)) { if ($key['Non_unique'] == 0) { $unique_keys[] = $key['Column_name']; } } PMA_DBI_free_result($keys_result); /** * Gets fields properties */ PMA_DBI_select_db($db); $local_query = 'SHOW FIELDS FROM ' . PMA_backquote($db) . '.' . PMA_backquote($table); $result = PMA_DBI_query($local_query); $fields_cnt = PMA_DBI_num_rows($result); // Check if we can use Relations (Mike Beck) if ($do_relation && !empty($cfgRelation['relation'])) { // Find which tables are related with the current one and write it in // an array $res_rel = PMA_getForeigners($db, $table); if ($res_rel && count($res_rel) > 0) { $have_rel = TRUE; } else { $have_rel = FALSE; } } else { $have_rel = FALSE; } // end if /** * Displays the table structure */ $GLOBALS['odt_buffer'] .= ''; $columns_cnt = 4; if ($do_relation && $have_rel) { $columns_cnt++; } if ($do_comments) { $columns_cnt++; } if ($do_mime && $cfgRelation['mimework']) { $columns_cnt++; } $GLOBALS['odt_buffer'] .= ''; /* Header */ $GLOBALS['odt_buffer'] .= ''; $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strField']) . '' . ''; $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strType']) . '' . ''; $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strNull']) . '' . ''; $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strDefault']) . '' . ''; if ($do_relation && $have_rel) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strLinksTo']) . '' . ''; } if ($do_comments) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strComments']) . '' . ''; $comments = PMA_getComments($db, $table); } if ($do_mime && $cfgRelation['mimework']) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($GLOBALS['strMIME_MIMEtype']) . '' . ''; $mime_map = PMA_getMIME($db, $table, true); } $GLOBALS['odt_buffer'] .= ''; while ($row = PMA_DBI_fetch_assoc($result)) { $GLOBALS['odt_buffer'] .= ''; $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($row['Field']) . '' . ''; // reformat mysql query output - staybyte - 9. June 2001 // loic1: set or enum types: slashes single quotes inside options $field_name = $row['Field']; $type = $row['Type']; if (preg_match('/^(set|enum)\((.+)\)$/i', $type, $tmp)) { $tmp[2] = substr(preg_replace('/([^,])\'\'/', '\\1\\\'', ',' . $tmp[2]), 1); $type = $tmp[1] . '(' . str_replace(',', ', ', $tmp[2]) . ')'; $type_nowrap = ''; $binary = 0; $unsigned = 0; $zerofill = 0; } else { $type_nowrap = ' nowrap="nowrap"'; $type = preg_replace('/BINARY/i', '', $type); $type = preg_replace('/ZEROFILL/i', '', $type); $type = preg_replace('/UNSIGNED/i', '', $type); if (empty($type)) { $type = ' '; } $binary = preg_match('/BINARY/i', $row['Type']); $unsigned = preg_match('/UNSIGNED/i', $row['Type']); $zerofill = preg_match('/ZEROFILL/i', $row['Type']); } $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($type) . '' . ''; if (!isset($row['Default'])) { if ($row['Null'] != 'NO') { $row['Default'] = 'NULL'; } else { $row['Default'] = ''; } } else { $row['Default'] = $row['Default']; } $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars(($row['Null'] == '' || $row['Null'] == 'NO') ? $GLOBALS['strNo'] : $GLOBALS['strYes']) . '' . ''; $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($row['Default']) . '' . ''; if ($do_relation && $have_rel) { if (isset($res_rel[$field_name])) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($res_rel[$field_name]['foreign_table'] . ' (' . $res_rel[$field_name]['foreign_field'] . ')') . '' . ''; } } if ($do_comments) { if (isset($comments[$field_name])) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars($comments[$field_name]) . '' . ''; } else { $GLOBALS['odt_buffer'] .= '' . '' . ''; } } if ($do_mime && $cfgRelation['mimework']) { if (isset($mime_map[$field_name])) { $GLOBALS['odt_buffer'] .= '' . '' . htmlspecialchars(str_replace('_', '/', $mime_map[$field_name]['mimetype'])) . '' . ''; } else { $GLOBALS['odt_buffer'] .= '' . '' . ''; } } $GLOBALS['odt_buffer'] .= ''; } // end while PMA_DBI_free_result($result); $GLOBALS['odt_buffer'] .= ''; return TRUE; } // end of the 'PMA_exportStructure' function } // end else ?>