-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapiconfig.php
executable file
·89 lines (80 loc) · 4.55 KB
/
apiconfig.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php
/**
* Internet domain Fallout + Class Strata REST Services API
*
* You may not change or alter any portion of this comment or credits
* of supporting developers from this source code or any supporting source code
* which is considered copyrighted (c) material of the original comment or credit authors.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*
* @copyright Chronolabs Cooperative http://syd.au.snails.email
* @license ACADEMIC APL 2 (https://sourceforge.net/u/chronolabscoop/wiki/Academic%20Public%20License%2C%20version%202.0/)
* @license GNU GPL 3 (http://www.gnu.org/licenses/gpl.html)
* @package strata-api
* @since 2.1.11
* @author Dr. Simon Antony Roberts <simon@snails.email>
* @version 2.1.13
* @description An Internet REST API which provides domain fallout + classing strata listing.
* @link http://internetfounder.wordpress.com
* @link https://github.com/Chronolabs-Cooperative/WhoIS-API-PHP
* @link https://sourceforge.net/p/chronolabs-cooperative
* @link https://facebook.com/ChronolabsCoop
* @link https://twitter.com/ChronolabsCoop
*
*/
if (!is_file(__DIR__ . DIRECTORY_SEPARATOR . 'mainfile.php') || !is_file(__DIR__ . DIRECTORY_SEPARATOR . 'include' . DIRECTORY_SEPARATOR . 'license.php'))
{
header('Location: ' . "./install");
exit(0);
}
require_once __DIR__ . DIRECTORY_SEPARATOR . 'mainfile.php';
require_once __DIR__ . DIRECTORY_SEPARATOR . 'include' . DIRECTORY_SEPARATOR . 'functions.php';
/**
* Opens Access Origin Via networking Route NPN
*/
header('Access-Control-Allow-Origin: *');
header('Origin: *');
/**
* Turns of GZ Lib Compression for Document Incompatibility
*/
ini_set("zlib.output_compression", 'Off');
ini_set("zlib.output_compression_level", -1);
/**
* Checks for Database to be Initalised
* @var Ambiguous $sql
*/
$sql = "SELECT count(*) FROM `" . $GLOBALS['APIDB']->prefix('strata_fallouts') . "`";
list($count) = $GLOBALS['APIDB']->fetchRow($GLOBALS['APIDB']->queryF($sql));
if ($count==0) {
$GLOBALS['APIDB']->queryF('START TRANSACTION');
foreach(json_decode(getURIData(API_PLACES_API_URL."/v3/list/list/json.api", 120, 120), true) as $key => $values) {
if (!empty($values['TLD']))
{
if (empty($values['Population']))
$values['Population'] = '0';
if (empty($values['ISON']))
$values['ISON'] = '0';
$sql = "INSERT INTO `" . $GLOBALS['APIDB']->prefix('strata_fallouts') . "` (`Country`, `ISO2`, `FIPS104`, `ISO3`, `ISON`, `TLD`, `Capital`, `Continent`, `NationalitySingular`, `NationalityPlural`, `FiscalNomial`, `FiscalNomialCode`, `Population`) VALUES('" . $GLOBALS['APIDB']->escape($values['Country']) . "', '" . $GLOBALS['APIDB']->escape($values['ISO2']) . "', '" . $GLOBALS['APIDB']->escape($values['FIPS104']) . "', '" . $GLOBALS['APIDB']->escape($values['ISO3']) . "', '" . $GLOBALS['APIDB']->escape($values['ISON']) . "', '" . $GLOBALS['APIDB']->escape($values['TLD']) . "', '" . $GLOBALS['APIDB']->escape($values['Capital']) . "', '" . $GLOBALS['APIDB']->escape($values['Continent']) . "', '" . $GLOBALS['APIDB']->escape($values['NationalitySingular']) . "', '" . $GLOBALS['APIDB']->escape($values['NationalityPlural']) . "', '" . $GLOBALS['APIDB']->escape($values['Currency']) . "', '" . $GLOBALS['APIDB']->escape($values['CurrencyCode']) . "', '" . $GLOBALS['APIDB']->escape($values['Population']) . "')";
if (!$GLOBALS['APIDB']->queryF($sql))
die("SQL Failed: $sql;");
}
}
$GLOBALS['APIDB']->queryF('COMMIT');
}
$sql = "SELECT count(*) FROM `" . $GLOBALS['APIDB']->prefix('strata_realms') . "`";
list($count) = $GLOBALS['APIDB']->fetchRow($GLOBALS['APIDB']->queryF($sql));
if ($count==0) {
$GLOBALS['APIDB']->queryF('START TRANSACTION');
foreach(explode("\n",getURIData(API_REALMS_URL, 120, 120)) as $key => $realm) {
if (!empty($realm) && trim($realm) != '' && substr($realm, 0, 1) != '#')
{
$sql = "INSERT INTO `" . $GLOBALS['APIDB']->prefix('strata_realms') . "` (`uid`, `active`, `realm`, `md5`, `stored`) VALUES('1', 'Yes', '" . $GLOBALS['APIDB']->escape(strtoupper($realm)) . "', MD5('" . $GLOBALS['APIDB']->escape(strtoupper($realm)) . "'), UNIX_TIMESTAMP())";
if (!$GLOBALS['APIDB']->queryF($sql))
die("SQL Failed: $sql;");
}
}
$GLOBALS['APIDB']->queryF('COMMIT');
}
?>