Subversion Repositories oidplus

Rev

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

Rev Author Line No. Line
54 daniel-mar 1
#!/usr/bin/php
239 daniel-mar 2
-- This file (wellknown_other_mysql.sql) contains ASN.1 and IRI names of OIDs which are either
54 daniel-mar 3
-- a) Root OIDs
4
-- b) Unicode labels which are long arcs
5
-- c) Standardized ASN.1 identifiers
6
-- d) OIDs where potential users of this software can register OIDs in these arcs (e.g. an "identified organization" arc)
239 daniel-mar 7
-- Use the tool dev/generate_wellknown_other_mysql to generate this file
54 daniel-mar 8
 
9
<?php
10
 
511 daniel-mar 11
/*
12
 * OIDplus 2.0
13
 * Copyright 2019 - 2021 Daniel Marschall, ViaThinkSoft
14
 *
15
 * Licensed under the Apache License, Version 2.0 (the "License");
16
 * you may not use this file except in compliance with the License.
17
 * You may obtain a copy of the License at
18
 *
19
 *     http://www.apache.org/licenses/LICENSE-2.0
20
 *
21
 * Unless required by applicable law or agreed to in writing, software
22
 * distributed under the License is distributed on an "AS IS" BASIS,
23
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
24
 * See the License for the specific language governing permissions and
25
 * limitations under the License.
26
 */
27
 
54 daniel-mar 28
require_once __DIR__ . '/../includes/oidplus.inc.php';
29
 
30
OIDplus::init(false);
261 daniel-mar 31
if (!OIDplus::baseConfig()->exists('OIDINFO_API_URL')) {
54 daniel-mar 32
	die("OIDINFO_API_URL not available (API is currently not public)\n");
33
}
34
 
35
$output = array();
36
 
37
function _is_standardized($oid, $asn1id) {
38
	$std = asn1_get_standardized_array();
39
	$x = oid_up($oid) == $oid ? '' : oid_up($oid).".";
40
	return isset( $std[$x.$asn1id]) && ($std[$x.$asn1id] == $oid);
41
}
42
 
43
function _is_long($oid) {
44
	$oid = '/'.str_replace('.', '/', $oid);
45
	return in_array($oid, iri_get_long_arcs());
46
}
47
 
48
function _process_oid($oid) {
49
	global $output;
50
 
51
	if (!isset($output[$oid])) {
52
		if ($oid == '0.0.23') {
53
			// Rec. ITU-T X.660 | ISO/IEC 9834-3, clause A.3.3.1 allows "0.0.w", although it is illegal, since no W-series exist
54
			$data = array();
55
			$data['oid'] = array();
56
			$data['oid']['identifier'] = array('w');
57
			$data['oid']['unicode-label'] = array('W');
58
		} else {
59
			$data = ft_get_oid_data($oid);
60
		}
61
 
62
                $output[$oid] = array();
63
		$output[$oid]['asn1id'] = array();
64
		$output[$oid]['iri'] = array();
239 daniel-mar 65
		$output[$oid]['checksum'] = array();
54 daniel-mar 66
 
67
		if (isset($data['oid']['identifier'])) {
68
			foreach ($data['oid']['identifier'] as $asn1id) {
239 daniel-mar 69
				$output[$oid]['checksum'][] = $oid.'|ASN1|'.$asn1id.'|'.(_is_standardized($oid, $asn1id) ? '1' : '0').'|1||';
70
				$std = _is_standardized($oid, $asn1id) ? "'1'" : "'0'";
71
				$output[$oid]['asn1id'][] = "INSERT INTO `asn1id` (oid, name, standardized, well_known) VALUES ('oid:$oid', '$asn1id', $std, '1');";
54 daniel-mar 72
			}
73
		} else {
111 daniel-mar 74
			//echo "-- Warning: Has no ASN.1 identifier: $oid\n";
54 daniel-mar 75
		}
76
		if (isset($data['oid']['unicode-label'])) {
77
			foreach ($data['oid']['unicode-label'] as $iri) {
239 daniel-mar 78
				$output[$oid]['checksum'][] = $oid.'|IRI|'.$iri.'|'.(_is_long($oid) ? '1' : '0').'|1||';
54 daniel-mar 79
 
239 daniel-mar 80
				$std = _is_long($oid) ? "'1'" : "'0'";
81
 
54 daniel-mar 82
				if (strpos($iri, '&#') !== false) {
83
					$iri = "from_base64('".base64_encode(html_entity_decode($iri, ENT_COMPAT | ENT_HTML401, "UTF-8"))."')";
84
				} else {
85
					$iri = "'$iri'";
86
				}
87
 
239 daniel-mar 88
				$output[$oid]['iri'][] = "INSERT INTO `iri` (oid, name, longarc, well_known) VALUES ('oid:$oid', $iri, $std, '1');";
54 daniel-mar 89
			}
90
		}
91
	}
92
 
93
	return $output[$oid];
94
}
95
 
96
// ---
97
 
98
$interesting_oids = array();
99
 
100
foreach (asn1_get_standardized_array() as $tmp => $oid) {
101
	$interesting_oids[] = $oid;
102
}
103
 
104
foreach (iri_get_long_arcs() as $tmp => $oid) {
105
	$oid = substr(str_replace('/', '.', $oid),1);
106
	$interesting_oids[] = $oid;
107
}
108
 
62 daniel-mar 109
// ----------------------------------------------------------------
54 daniel-mar 110
 
62 daniel-mar 111
$interesting_oids[] = '0'; // itu-t
112
	$interesting_oids[] = '0.2'; // telecom operators
113
	$interesting_oids[] = '0.3'; // network-operator
114
	$interesting_oids[] = '0.4'; // identified-organization
115
		$interesting_oids[] = '0.4.0'; // etsi
116
			$interesting_oids[] = '0.4.0.127'; // reserved
117
				$interesting_oids[] = '0.4.0.127.0'; // etsi-identified-organization
118
$interesting_oids[] = '1'; // iso
119
	$interesting_oids[] = '1.1'; // registration-authority
120
		$interesting_oids[] = '1.1.19785'; // cbeff
121
			$interesting_oids[] = '1.1.19785.0'; // organization
122
	$interesting_oids[] = '1.2'; // member-body
123
		// country_getter defines the country OIDs
111 daniel-mar 124
		//$interesting_oids[] = '1.2.158'; // tw
62 daniel-mar 125
			$interesting_oids[] = '1.2.158.1'; // organization
111 daniel-mar 126
		//$interesting_oids[] = '1.2.276'; // de
62 daniel-mar 127
			$interesting_oids[] = '1.2.276.0'; // din-certco
111 daniel-mar 128
		//$interesting_oids[] = '1.2.344'; // hk
62 daniel-mar 129
			$interesting_oids[] = '1.2.344.1'; // organization
111 daniel-mar 130
		//$interesting_oids[] = '1.2.616'; // pl
62 daniel-mar 131
			$interesting_oids[] = '1.2.616.1'; // organization
111 daniel-mar 132
		//$interesting_oids[] = '1.2.826'; // gb
62 daniel-mar 133
			$interesting_oids[] = '1.2.826.0'; // national
134
				$interesting_oids[] = '1.2.826.0.1'; // eng-ltd
135
					$interesting_oids[] = '1.2.826.0.1.3680043'; // Medical Connections ( https://www.medicalconnections.co.uk/FreeUID/ )
111 daniel-mar 136
		//$interesting_oids[] = '1.2.840'; // us
62 daniel-mar 137
			$interesting_oids[] = '1.2.840.1'; // organization
138
				$interesting_oids[] = '1.2.840.113556'; // microsoft
139
					$interesting_oids[] = '1.2.840.113556.1'; // Microsoft Active Directory
140
						$interesting_oids[] = '1.2.840.113556.1.8000'; // companies
141
							$interesting_oids[] = '1.2.840.113556.1.8000.2554'; // customer usage
142
					$interesting_oids[] = '1.2.840.113556.2'; // DICOM
143
	$interesting_oids[] = '1.3'; // identified-organization
144
		$interesting_oids[] = '1.3.6'; // dod
145
			$interesting_oids[] = '1.3.6.1'; // internet
146
				$interesting_oids[] = '1.3.6.1.2'; // mgmt
147
					$interesting_oids[] = '1.3.6.1.2.1'; // mib-2
148
						$interesting_oids[] = '1.3.6.1.4'; // private
149
							$interesting_oids[] = '1.3.6.1.4.1'; // enterprise
150
								$interesting_oids[] = '1.3.6.1.4.1.19376'; // Integrating the Healthcare Enterprise International
151
									$interesting_oids[] = '1.3.6.1.4.1.19376.3'; // Organizations (not in Repo!)
152
									$interesting_oids[] = '1.3.6.1.4.1.19376.3.276'; // IHE Deutschland
153
										$interesting_oids[] = '1.3.6.1.4.1.19376.3.276.1'; // OID für das OID Konzept Version 1
154
											$interesting_oids[] = '1.3.6.1.4.1.19376.3.276.1.4'; // Identifikation des ID-Pools für Institutionen (Organisationen, Einheiten, etc.)
155
													$interesting_oids[] = '1.3.6.1.4.1.19376.3.276.1.4.1'; // Krankenhäuser
156
													$interesting_oids[] = '1.3.6.1.4.1.19376.3.276.1.4.2'; // Praxen niedergelassener Ärzte
157
													$interesting_oids[] = '1.3.6.1.4.1.19376.3.276.1.4.3'; // Systeme
158
								$interesting_oids[] = '1.3.6.1.4.1.12798'; // Members of Internet-Käyttäjät Ikuisesti (IKI)
159
									$interesting_oids[] = '1.3.6.1.4.1.12798.1'; // member
160
								$interesting_oids[] = '1.3.6.1.4.1.37476'; // ViaThinkSoft
161
									$interesting_oids[] = '1.3.6.1.4.1.37476.9000'; // freeoid
205 daniel-mar 162
								$interesting_oids[] = '1.3.6.1.4.1.37553'; // frdlweb
163
									$interesting_oids[] = '1.3.6.1.4.1.37553.8'; // WEID
164
										$interesting_oids[] = '1.3.6.1.4.1.37553.8.8'; // private
165
										$interesting_oids[] = '1.3.6.1.4.1.37553.8.9'; // ns
166
											$interesting_oids[] = '1.3.6.1.4.1.37553.8.9.17704'; // dns
167
											$interesting_oids[] = '1.3.6.1.4.1.37553.8.9.1439221'; // uuid
62 daniel-mar 168
$interesting_oids[] = '2'; // joint-iso-itu-t
169
	$interesting_oids[] = '2.16'; // country
170
		// country_getter defines the country OIDs
111 daniel-mar 171
		//$interesting_oids[] = '2.16.158'; // tw
62 daniel-mar 172
			$interesting_oids[] = '2.16.158.1'; // organization
111 daniel-mar 173
		//$interesting_oids[] = '2.16.344'; // hk
62 daniel-mar 174
			$interesting_oids[] = '2.16.344.1'; // organization
111 daniel-mar 175
		//$interesting_oids[] = '2.16.616'; // pl
62 daniel-mar 176
			$interesting_oids[] = '2.16.616.1'; // organization
111 daniel-mar 177
		//$interesting_oids[] = '2.16.840'; // us
62 daniel-mar 178
			$interesting_oids[] = '2.16.840.1'; // organization
179
				$interesting_oids[] = '2.16.840.1.113883'; // hl7
180
					$interesting_oids[] = '2.16.840.1.113883.3'; // externalUseRoots
181
					$interesting_oids[] = '2.16.840.1.113883.6'; // externalCodeSystems
182
					$interesting_oids[] = '2.16.840.1.113883.13'; // externalValueSets
183
	$interesting_oids[] = '2.23'; // international-organizations
184
	$interesting_oids[] = '2.25'; // uuid
185
	$interesting_oids[] = '2.40'; // upu
186
		$interesting_oids[] = '2.40.2'; // member-body
187
		$interesting_oids[] = '2.40.3'; // identified-organization
188
	$interesting_oids[] = '2.49'; // alerting
189
		$interesting_oids[] = '2.49.0'; // wmo
190
			$interesting_oids[] = '2.49.0.0'; // authority (Countries)
111 daniel-mar 191
				// country_getter defines the country OIDs beneath 2.49.0.0
62 daniel-mar 192
			$interesting_oids[] = '2.49.0.1'; // country-msg
111 daniel-mar 193
				// country_getter defines the country OIDs beneath 2.49.0.1
62 daniel-mar 194
			$interesting_oids[] = '2.49.0.2'; // org
195
			$interesting_oids[] = '2.49.0.3'; // org-msg
196
 
197
// ----------------------------------------------------------------
198
 
54 daniel-mar 199
$interesting_oids = array_unique($interesting_oids);
200
natsort($interesting_oids);
201
 
202
$output = array();
203
foreach ($interesting_oids as $oid) {
204
	_process_oid($oid);
205
}
206
 
207
$check_sum = '';
208
foreach ($output as $oid => $data) {
111 daniel-mar 209
	if (count($data['asn1id']) + count($data['iri']) == 0) continue;
210
 
54 daniel-mar 211
	echo "-- $oid\n";
212
	foreach ($data['asn1id'] as $line_asn1) {
213
		echo "$line_asn1\n";
214
	}
215
	foreach ($data['iri'] as $line_iri) {
216
		echo "$line_iri\n";
217
	}
239 daniel-mar 218
	foreach ($data['checksum'] as $chunk) {
219
		$check_sum .= $chunk;
220
	}
54 daniel-mar 221
	echo "\n";
222
}
239 daniel-mar 223
echo '-- Generator "generate_wellknown_other_mysql" checksum '.dechex(crc32($check_sum))."\n";
54 daniel-mar 224
 
225
# ---
226
 
227
function ft_get_oid_data($oid) {
502 daniel-mar 228
	$url = OIDplus::baseConfig()->getValue('OIDINFO_API_URL') . '&oid='.urlencode($oid);
54 daniel-mar 229
	$cont_json = @file_get_contents($url);
230
	if (!$cont_json) {
231
		sleep(5);
232
                $cont_json = @file_get_contents($url);
233
                if (!$cont_json) return false;
234
	}
235
	$data = json_decode($cont_json,true);
236
 
237
	return $data;
238
}