Subversion Repositories oidplus

Rev

Rev 273 | Rev 277 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 daniel-mar 1
<?php
2
 
3
/*
4
 * OIDplus 2.0
5
 * Copyright 2019 Daniel Marschall, ViaThinkSoft
6
 *
7
 * Licensed under the Apache License, Version 2.0 (the "License");
8
 * you may not use this file except in compliance with the License.
9
 * You may obtain a copy of the License at
10
 *
11
 *     http://www.apache.org/licenses/LICENSE-2.0
12
 *
13
 * Unless required by applicable law or agreed to in writing, software
14
 * distributed under the License is distributed on an "AS IS" BASIS,
15
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
 * See the License for the specific language governing permissions and
17
 * limitations under the License.
18
 */
19
 
274 daniel-mar 20
include_once __DIR__ . '/../includes/oidplus.inc.php';
21
 
2 daniel-mar 22
$prefix = isset($_REQUEST['prefix']) ? $_REQUEST['prefix'] : '';
78 daniel-mar 23
$database = isset($_REQUEST['database']) ? $_REQUEST['database'] : '';
239 daniel-mar 24
$slang = isset($_REQUEST['slang']) ? $_REQUEST['slang'] : 'mysql';
2 daniel-mar 25
 
274 daniel-mar 26
$ary = glob(__DIR__ . '/../plugins/sql_slang/'.'*'.'/plugin.inc.php');
27
foreach ($ary as $a) include $a;
223 daniel-mar 28
 
274 daniel-mar 29
$slang_plugin = null;
30
foreach (get_declared_classes() as $c) {
31
        if (is_subclass_of($c, 'OIDplusSqlSlangPlugin')) {
32
                $obj = new $c();
33
                if ($obj::id() === $slang) {
34
                        $slang_plugin = $obj;
35
                        break;
36
                }
37
        }
38
}
39
if (is_null($slang_plugin)) {
40
        die('Unknown slang');
41
}
42
 
239 daniel-mar 43
$cont = trim(file_get_contents(__DIR__.'/sql/struct_'.$slang.'.sql'))."\n\n".
44
        trim(file_get_contents(__DIR__.'/sql/wellknown_country_'.$slang.'.sql'))."\n\n".
45
        trim(file_get_contents(__DIR__.'/sql/wellknown_other_'.$slang.'.sql'))."\n\n".
46
        trim(file_get_contents(__DIR__.'/sql/example_'.$slang.'.sql'))."\n\n";
2 daniel-mar 47
 
158 daniel-mar 48
$table_names = array('objects', 'asn1id', 'iri', 'ra', 'config', 'log', 'log_user', 'log_object');
2 daniel-mar 49
foreach ($table_names as $table) {
274 daniel-mar 50
        $cont = $slang_plugin->setupSetTablePrefix($cont, $table, $prefix);
2 daniel-mar 51
}
52
 
50 daniel-mar 53
if (php_sapi_name() != 'cli') {
54
        header('Content-Type:text/sql');
111 daniel-mar 55
        header('Content-Disposition: inline; filename="struct_with_examples.sql"');
50 daniel-mar 56
}
78 daniel-mar 57
 
111 daniel-mar 58
if (!empty($database)) {
274 daniel-mar 59
        echo $slang_plugin->setupCreateDbIfNotExists($database);
60
        echo $slang_plugin->setupUseDatabase($database);
111 daniel-mar 61
}
2 daniel-mar 62
echo $cont;