]> git.openstreetmap.org Git - nominatim.git/blob - lib-php/ParameterParser.php
Merge pull request #3397 from lonvia/improve-handling-unlisted-places
[nominatim.git] / lib-php / ParameterParser.php
1 <?php
2 /**
3  * SPDX-License-Identifier: GPL-2.0-only
4  *
5  * This file is part of Nominatim. (https://nominatim.org)
6  *
7  * Copyright (C) 2022 by the Nominatim developer community.
8  * For a full list of authors see the git log.
9  */
10
11 namespace Nominatim;
12
13 class ParameterParser
14 {
15     private $aParams;
16
17
18     public function __construct($aParams = null)
19     {
20         $this->aParams = ($aParams === null) ? $_GET : $aParams;
21     }
22
23     public function getBool($sName, $bDefault = false)
24     {
25         if (!isset($this->aParams[$sName])
26             || !is_string($this->aParams[$sName])
27             || strlen($this->aParams[$sName]) == 0
28         ) {
29             return $bDefault;
30         }
31
32         return (bool) $this->aParams[$sName];
33     }
34
35     public function getInt($sName, $bDefault = false)
36     {
37         if (!isset($this->aParams[$sName]) || is_array($this->aParams[$sName])) {
38             return $bDefault;
39         }
40
41         if (!preg_match('/^[+-]?[0-9]+$/', $this->aParams[$sName])) {
42             userError("Integer number expected for parameter '$sName'");
43         }
44
45         return (int) $this->aParams[$sName];
46     }
47
48     public function getFloat($sName, $bDefault = false)
49     {
50         if (!isset($this->aParams[$sName]) || is_array($this->aParams[$sName])) {
51             return $bDefault;
52         }
53
54         if (!preg_match('/^[+-]?[0-9]*\.?[0-9]+$/', $this->aParams[$sName])) {
55             userError("Floating-point number expected for parameter '$sName'");
56         }
57
58         return (float) $this->aParams[$sName];
59     }
60
61     public function getString($sName, $bDefault = false)
62     {
63         if (!isset($this->aParams[$sName])
64             || !is_string($this->aParams[$sName])
65             || strlen($this->aParams[$sName]) == 0
66         ) {
67             return $bDefault;
68         }
69
70         return $this->aParams[$sName];
71     }
72
73     public function getSet($sName, $aValues, $sDefault = false)
74     {
75         if (!isset($this->aParams[$sName])
76             || !is_string($this->aParams[$sName])
77             || strlen($this->aParams[$sName]) == 0
78         ) {
79             return $sDefault;
80         }
81
82         if (!in_array($this->aParams[$sName], $aValues, true)) {
83             userError("Parameter '$sName' must be one of: ".join(', ', $aValues));
84         }
85
86         return $this->aParams[$sName];
87     }
88
89     public function getStringList($sName, $aDefault = false)
90     {
91         $sValue = $this->getString($sName);
92
93         if ($sValue) {
94             // removes all NULL, FALSE and Empty Strings but leaves 0 (zero) values
95             return array_values(array_filter(explode(',', $sValue), 'strlen'));
96         }
97
98         return $aDefault;
99     }
100
101     public function getPreferredLanguages($sFallback = null)
102     {
103         if ($sFallback === null && isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) {
104             $sFallback = $_SERVER['HTTP_ACCEPT_LANGUAGE'];
105         }
106
107         $aLanguages = array();
108         $sLangString = $this->getString('accept-language', $sFallback);
109
110         if ($sLangString
111             && preg_match_all('/(([a-z]{1,8})([-_][a-z]{1,8})?)\s*(;\s*q\s*=\s*(1|0\.[0-9]+))?/i', $sLangString, $aLanguagesParse, PREG_SET_ORDER)
112         ) {
113             foreach ($aLanguagesParse as $iLang => $aLanguage) {
114                 $aLanguages[$aLanguage[1]] = isset($aLanguage[5])?(float)$aLanguage[5]:1 - ($iLang/100);
115                 if (!isset($aLanguages[$aLanguage[2]])) {
116                     $aLanguages[$aLanguage[2]] = $aLanguages[$aLanguage[1]]/10;
117                 }
118             }
119             arsort($aLanguages);
120         }
121         if (empty($aLanguages) && CONST_Default_Language) {
122             $aLanguages[CONST_Default_Language] = 1;
123         }
124
125         foreach ($aLanguages as $sLanguage => $fLanguagePref) {
126             $this->addNameTag($aLangPrefOrder, 'name:'.$sLanguage);
127         }
128         $this->addNameTag($aLangPrefOrder, 'name');
129         $this->addNameTag($aLangPrefOrder, 'brand');
130         foreach ($aLanguages as $sLanguage => $fLanguagePref) {
131             $this->addNameTag($aLangPrefOrder, 'official_name:'.$sLanguage);
132             $this->addNameTag($aLangPrefOrder, 'short_name:'.$sLanguage);
133         }
134         $this->addNameTag($aLangPrefOrder, 'official_name');
135         $this->addNameTag($aLangPrefOrder, 'short_name');
136         $this->addNameTag($aLangPrefOrder, 'ref');
137         $this->addNameTag($aLangPrefOrder, 'type');
138         return $aLangPrefOrder;
139     }
140
141     private function addNameTag(&$aLangPrefOrder, $sTag)
142     {
143         $aLangPrefOrder[$sTag] = $sTag;
144         $aLangPrefOrder['_place_'.$sTag] = '_place_'.$sTag;
145     }
146
147     public function hasSetAny($aParamNames)
148     {
149         foreach ($aParamNames as $sName) {
150             if ($this->getBool($sName)) {
151                 return true;
152             }
153         }
154
155         return false;
156     }
157 }