organic: Add pdf endpoint
This commit is contained in:
154
www/organic/external/easy-cert/operators.php
vendored
154
www/organic/external/easy-cert/operators.php
vendored
@@ -1,12 +1,5 @@
|
||||
<?php
|
||||
|
||||
$info = $_SERVER['PATH_INFO'];
|
||||
if ($info !== '') {
|
||||
header('Status: 404');
|
||||
header('Content-Length: 0');
|
||||
exit;
|
||||
}
|
||||
|
||||
header('Access-Control-Allow-Origin: *');
|
||||
|
||||
if ($_SERVER['REQUEST_METHOD'] !== 'GET' && $_SERVER['REQUEST_METHOD'] !== 'HEAD') {
|
||||
@@ -16,6 +9,122 @@ if ($_SERVER['REQUEST_METHOD'] !== 'GET' && $_SERVER['REQUEST_METHOD'] !== 'HEAD
|
||||
exit;
|
||||
}
|
||||
|
||||
function jenc($data): string {
|
||||
return json_encode($data, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE);
|
||||
}
|
||||
|
||||
$info = $_SERVER['PATH_INFO'];
|
||||
if ($info !== '') {
|
||||
$parts = explode(':', substr($info, 1), 2);
|
||||
if (sizeof($parts) !== 2) {
|
||||
$url = "https://elwig.at/organic/external/easy-cert/operators?idNr=" . substr($info, 1);
|
||||
$s = curl_init($url);
|
||||
curl_setopt($s, CURLOPT_RETURNTRANSFER, true);
|
||||
if (($json = curl_exec($s)) === false) {
|
||||
header('Status: 500');
|
||||
header('Content-Length: 0');
|
||||
exit;
|
||||
}
|
||||
$json = json_decode($json);
|
||||
if ($json->{'totalCount'} !== 1) {
|
||||
header('Status: 404');
|
||||
header('Content-Length: 0');
|
||||
exit;
|
||||
}
|
||||
header('Status: 303');
|
||||
header('Location: ./' . $json->{'data'}[0]->{'db'} . ':' . $json->{'data'}[0]->{'id'});
|
||||
exit;
|
||||
}
|
||||
|
||||
|
||||
$refDate = $_GET['referenceDate'] ?? null;
|
||||
if ($refDate !== null) {
|
||||
$refDate = explode('-', $refDate);
|
||||
$refDate = $refDate[2] . '.' . $refDate[1] . '.' . $refDate[0];
|
||||
}
|
||||
$url = "https://www.easy-cert.com/htm/suchresultat-detail.htm?sprache=de&db=" . urlencode($parts[0]) . "&id=" . urlencode(str_replace('-', '_', $parts[1])) . "&historyDate=" . urlencode($refDate);
|
||||
$s = curl_init($url);
|
||||
curl_setopt($s, CURLOPT_RETURNTRANSFER, true);
|
||||
if (($html = curl_exec($s)) === false) {
|
||||
header('Status: 500');
|
||||
header('Content-Length: 0');
|
||||
exit;
|
||||
}
|
||||
|
||||
$html = preg_replace('/<!--.*?-->/s', ' ', $html);
|
||||
preg_match_all('@<tr>\s*<th[^>]*>([^<]*)</th>\s*<td[^>]*>([^<]*)</td>\s*</tr>@', $html, $matches, PREG_SET_ORDER);
|
||||
|
||||
$data = [];
|
||||
foreach ($matches as $m) {
|
||||
$data[$m[1]] = trim(html_entity_decode($m[2]));
|
||||
if ($data[$m[1]] === '') {
|
||||
$data[$m[1]] = null;
|
||||
}
|
||||
}
|
||||
$plzOrt = $data['PLZ / Ort'] ?? null;
|
||||
if ($plzOrt === null) {
|
||||
$postalCode = null;
|
||||
$city = null;
|
||||
} else {
|
||||
$p = explode(' ', $plzOrt, 2);
|
||||
$postalCode = trim($p[0]);
|
||||
$city = trim($p[1]);
|
||||
}
|
||||
|
||||
if ($data['Name'] === null) {
|
||||
header('Status: 404');
|
||||
header('Content-Length: 0');
|
||||
exit;
|
||||
}
|
||||
|
||||
if (preg_match('@name="historydate_input" value="([^"]*)"@', $html, $matches) === 1) {
|
||||
$refDate = $matches[1];
|
||||
$refDate = explode('.', $refDate);
|
||||
$refDate = $refDate[2] . '-' . $refDate[1] . '-' . $refDate[0];
|
||||
} else {
|
||||
$refDate = null;
|
||||
}
|
||||
|
||||
$certs = [];
|
||||
preg_match_all('@<tr>\s*<td nowrap>([^<]*)</td>\s*<td[^>]*>([^<]*)</td>\s*<td[^>]*>\s*([^<]*)\s*.*?</td>\s*<td [^\']*\'(https?://[^\']*)\'[^>]*>[^<]*</td>\s*</tr>@', $html, $matches, PREG_SET_ORDER);
|
||||
foreach ($matches as $m) {
|
||||
$certs[] = [
|
||||
'nr' => $m[1],
|
||||
'validUntil' => implode('-', array_reverse(explode('.', $m[2]))),
|
||||
'type' => $m[3] === '' ? null : $m[3],
|
||||
'pdfUrl' => str_replace('http://', 'https://', $m[4]),
|
||||
];
|
||||
}
|
||||
|
||||
$labels = [];
|
||||
preg_match_all('@<tr>\s*<td>([^<]*)</td>\s*<td[^>]*>([^<]*)</td>\s*<td[^>]*>\s*([^<]*)\s*.*?</td>\s*<td [^\']*\'(https?://[^\']*)\'[^>]*>[^<]*</td>\s*</tr>@', $html, $matches, PREG_SET_ORDER);
|
||||
foreach ($matches as $m) {
|
||||
$labels[] = [
|
||||
'nr' => $m[1],
|
||||
'validUntil' => implode('-', array_reverse(explode('.', $m[2]))),
|
||||
'type' => $m[3] === '' ? null : $m[3],
|
||||
'pdfUrl' => str_replace('http://', 'https://', $m[4]),
|
||||
];
|
||||
}
|
||||
|
||||
header("Content-Type: application/json; charset=UTF-8");
|
||||
|
||||
echo '{"db":' . jenc($parts[0]) .
|
||||
',"id":' . jenc($parts[1]) .
|
||||
",\n \"idNr\":" . jenc($data['ID-Nummer'] ?? null) .
|
||||
',"name":' . jenc($data['Name']) .
|
||||
',"address":' . jenc($data['Strasse'] ?? null) .
|
||||
',"postalCode":' . jenc($postalCode) .
|
||||
',"city":' . jenc($city) .
|
||||
',"countryCode":' . jenc($data['Land'] ?? null) .
|
||||
",\n \"referenceDate\":" . jenc($refDate) .
|
||||
",\n \"certificates\":" . jenc($certs) .
|
||||
",\n \"privateStandardApprovals\":" . jenc($labels) .
|
||||
'}';
|
||||
|
||||
exit;
|
||||
}
|
||||
|
||||
$search_url = null;
|
||||
$url = null;
|
||||
$query_id = null;
|
||||
@@ -43,9 +152,10 @@ if (isset($_GET['queryId'])) {
|
||||
$country = $_GET['country'] ?? null;
|
||||
$postalCode = $_GET['postalCode'] ?? null;
|
||||
$name = $_GET['name'] ?? null;
|
||||
$idNr = $_GET['idNr'] ?? null;
|
||||
$renew = ($_GET['renew'] ?? 'false') === 'true';
|
||||
|
||||
$search_url = "https://www.easy-cert.com/htm/suchergebnis.htm?suchtyp=einfach&CountryCode=$country&PostalCode=$postalCode&Name=$name";
|
||||
$search_url = "https://www.easy-cert.com/htm/suchergebnis.htm?suchtyp=einfach&CountryCode=$country&PostalCode=$postalCode&Name=$name&CustomerNumber=$idNr";
|
||||
|
||||
if (!$renew && $cache = fopen('.cache.csv', 'r')) {
|
||||
while (($line = fgets($cache)) !== false) {
|
||||
@@ -111,15 +221,28 @@ $sed = [
|
||||
's/^/ /',
|
||||
's/}$/},/',
|
||||
];
|
||||
$replace = [
|
||||
'"DB":' => '"db":',
|
||||
'"Name":' => '"name":',
|
||||
'"PostalCode":' => '"postalCode":',
|
||||
'"Town":' => '"city":',
|
||||
'"CustomerNumber":' => '"idNr":',
|
||||
'"ID":' => '"id":',
|
||||
'"CountryCode":' => '"countryCode":',
|
||||
'"xx"' => 'null',
|
||||
'"XX"' => 'null',
|
||||
'""' => 'null',
|
||||
];
|
||||
$replaceSed = array_map(fn($v, $k): string => "s/$k/$v/", $replace, array_keys($replace));
|
||||
|
||||
header("Content-Type: application/json; charset=UTF-8");
|
||||
|
||||
echo '{"searchUrl":' . json_encode($search_url) .
|
||||
',"queryId":' . json_encode($query_id) .
|
||||
',"rawFileUrl":' . json_encode($url) .
|
||||
',"timestamp":' . json_encode(gmdate('Y-m-d\TH:i:s\Z', $timestamp)) .
|
||||
',"limit":' . json_encode($limit) .
|
||||
',"offset":' . json_encode($offset) . ",\"data\":[\n";
|
||||
echo '{"searchUrl":' . jenc($search_url) .
|
||||
',"queryId":' . jenc($query_id) .
|
||||
',"rawFileUrl":' . jenc($url) .
|
||||
',"timestamp":' . jenc(gmdate('Y-m-d\TH:i:s\Z', $timestamp)) .
|
||||
',"limit":' . jenc($limit) .
|
||||
',"offset":' . jenc($offset) . ",\"data\":[\n";
|
||||
|
||||
$fd_spec = [
|
||||
0 => ["pipe", "r"], // stdin
|
||||
@@ -138,6 +261,7 @@ $process = proc_open(
|
||||
"tee >(wc -l 1>&3) | " . // copy stdout into wc and write result into fd 3
|
||||
"tail -n +$offset | " . // apply offset
|
||||
($limit !== null ? " head -n $limit | " : "") . // optionally apply limit
|
||||
"sed '" . implode(';', $replaceSed) . "' | " . // replace strings in json
|
||||
"sed '\$s/.$//'"], // remove last comma of last line
|
||||
$fd_spec,
|
||||
$pipes
|
||||
@@ -153,4 +277,4 @@ $count = intval(trim(stream_get_contents($pipes[3])));
|
||||
fclose($pipes[3]);
|
||||
$return_value = proc_close($process);
|
||||
|
||||
echo '],"totalCount":' . json_encode($count) . "}\n";
|
||||
echo '],"totalCount":' . jenc($count) . "}\n";
|
||||
|
Reference in New Issue
Block a user