From 1e9cd56403a35e33d2fcf561c7a7a8a396396378 Mon Sep 17 00:00:00 2001 From: thomascube Date: Thu, 18 Sep 2008 13:13:08 +0000 Subject: Script to dump the current database schema using MDB2_Schema (for development only) --- bin/dumpschema.php | 65 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 bin/dumpschema.php (limited to 'bin') diff --git a/bin/dumpschema.php b/bin/dumpschema.php new file mode 100644 index 000000000..683e2719e --- /dev/null +++ b/bin/dumpschema.php @@ -0,0 +1,65 @@ +get('devel_mode') && $_SERVER['REMOTE_ADDR']) { + header("HTTP/1.0 401 Access denied"); + die("Access denied!"); +} + +$options = array( + 'use_transactions' => false, + 'log_line_break' => "\n", + 'idxname_format' => '%s', + 'debug' => false, + 'quote_identifier' => true, + 'force_defaults' => false, + 'portability' => false +); + +$schema =& MDB2_Schema::factory($config->get('db_dsnw'), $options); +$schema->db->supported['transactions'] = false; + +// send as text/xml when opened in browser +if ($_SERVER['REMOTE_ADDR']) + header('Content-Type: text/xml'); + + +if (PEAR::isError($schema)) { + $error = $schema->getMessage() . ' ' . $schema->getUserInfo(); +} +else { + $dump_config = array( + // 'output_mode' => 'file', + 'output' => 'print_schema', + ); + + $definition = $schema->getDefinitionFromDatabase(); + if (PEAR::isError($definition)) { + $error = $definition->getMessage() . ' ' . $definition->getUserInfo(); + } + else { + $operation = $schema->dumpDatabase($definition, $dump_config, MDB2_SCHEMA_DUMP_STRUCTURE); + if (PEAR::isError($operation)) { + $error = $operation->getMessage() . ' ' . $operation->getUserInfo(); + } + } +} + +$schema->disconnect(); + +//if ($error) +// fputs(STDERR, $error); + +?> -- cgit v1.2.3