Index: tags/extensions/ExternalData/REL_0_9_1/ExternalData.i18n.magic.php |
— | — | @@ -0,0 +1,32 @@ |
| 2 | +<?php |
| 3 | + |
| 4 | +$magicWords = array(); |
| 5 | + |
| 6 | +$magicWords['en'] = array( |
| 7 | + 'get_external_data' => array ( 0, 'get_external_data' ), |
| 8 | + 'get_ldap_data' => array ( 0, 'get_ldap_data' ), |
| 9 | + 'get_db_data' => array ( 0, 'get_db_data' ), |
| 10 | + 'external_value' => array ( 0, 'external_value' ), |
| 11 | + 'for_external_table' => array ( 0, 'for_external_table' ), |
| 12 | +); |
| 13 | + |
| 14 | +$magicWords['ar'] = array( |
| 15 | + 'external_value' => array( '0', 'قيمة_خارجية', 'external_value' ), |
| 16 | + 'for_external_table' => array( '0', 'لجدول_خارجي', 'for_external_table' ), |
| 17 | +); |
| 18 | + |
| 19 | +$magicWords['nl'] = array( |
| 20 | + 'get_external_data' => array( '0', 'externe_gegevens_ophalen', 'get_external_data' ), |
| 21 | + 'get_ldap_data' => array( '0', 'ldap_gegevens_ophalen', 'get_ldap_data' ), |
| 22 | + 'get_db_data' => array( '0', 'db_gegevens_ophalen', 'get_db_data' ), |
| 23 | + 'external_value' => array( '0', 'externe_waarde', 'external_value' ), |
| 24 | + 'for_external_table' => array( '0', 'voor_externe_tabel', 'for_external_table' ), |
| 25 | +); |
| 26 | + |
| 27 | +$magicWords['ru'] = array( |
| 28 | + 'get_external_data' => array( '0', 'получить_внешние_данные', 'get_external_data' ), |
| 29 | + 'get_ldap_data' => array( '0', 'получить_данные_ldap', 'get_ldap_data' ), |
| 30 | + 'get_db_data' => array( '0', 'получить_данные_db', 'get_db_data' ), |
| 31 | + 'external_value' => array( '0', 'внешнее_значение', 'external_value' ), |
| 32 | + 'for_external_table' => array( '0', 'для_внешней_таблицы', 'for_external_table' ), |
| 33 | +); |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ExternalData.i18n.magic.php |
___________________________________________________________________ |
Name: svn:keywords |
1 | 34 | + Id |
Name: svn:eol-style |
2 | 35 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/ExternalData.i18n.php |
— | — | @@ -0,0 +1,621 @@ |
| 2 | +<?php |
| 3 | +/** |
| 4 | + * Internationalization file for the External Data extension |
| 5 | + * |
| 6 | + * @addtogroup Extensions |
| 7 | + */ |
| 8 | + |
| 9 | +$messages = array(); |
| 10 | + |
| 11 | +/** English |
| 12 | + * @author Yaron Koren |
| 13 | + */ |
| 14 | +$messages['en'] = array( |
| 15 | + // user messages |
| 16 | + 'getdata' => 'Get data', |
| 17 | + 'externaldata-desc' => 'Allows for retrieving data in CSV, JSON and XML formats from both external URLs and local wiki pages', |
| 18 | + 'externaldata-ldap-unable-to-connect' => 'Unable to connect to $1', |
| 19 | + 'externaldata-json-decode-not-supported' => 'Error: json_decode() is not supported in this version of PHP', |
| 20 | + 'externaldata-xml-error' => 'XML error: $1 at line $2', |
| 21 | + 'externaldata-db-incomplete-information' => 'Error: Incomplete information for this server ID.', |
| 22 | + 'externaldata-db-could-not-get-url' => 'Could not get URL after $1 {{PLURAL:$1|try|tries}}.', |
| 23 | + 'externaldata-db-unknown-type' => 'Error: Unknown database type.', |
| 24 | + 'externaldata-db-could-not-connect' => 'Error: Could not connect to database.', |
| 25 | + 'externaldata-db-no-return-values' => 'Error: No return values specified.', |
| 26 | + 'externaldata-db-invalid-query' => 'Invalid query.', |
| 27 | +); |
| 28 | + |
| 29 | +/** Message documentation (Message documentation) |
| 30 | + * @author Dead3y3 |
| 31 | + * @author Fryed-peach |
| 32 | + */ |
| 33 | +$messages['qqq'] = array( |
| 34 | + 'externaldata-desc' => '{{desc}}', |
| 35 | +); |
| 36 | + |
| 37 | +/** Arabic (العربية) |
| 38 | + * @author Meno25 |
| 39 | + * @author OsamaK |
| 40 | + */ |
| 41 | +$messages['ar'] = array( |
| 42 | + 'getdata' => 'الحصول على البيانات', |
| 43 | + 'externaldata-desc' => 'يسمح باسترجاع البيانات بصيغة CSV، JSON و XML من مسارات خارجية وصفحات الويكي المحلية', |
| 44 | + 'externaldata-ldap-unable-to-connect' => 'تعذّر الاتصال ب$1', |
| 45 | + 'externaldata-json-decode-not-supported' => 'خطأ: json_decode() غير مدعوم في نسخة PHP هذه', |
| 46 | + 'externaldata-xml-error' => 'خطأ XML: $1 عند السطر $2', |
| 47 | + 'externaldata-db-incomplete-information' => 'خطأ: معلومات غير كاملة عن هوية هذا الخادوم.', |
| 48 | + 'externaldata-db-could-not-get-url' => 'تعذّر الحصول على المسار بعد {{PLURAL:$1||محاولة واحدة|محاوتين|$1 محاولات|$1 محاولة }}.', |
| 49 | + 'externaldata-db-unknown-type' => 'خطأ: نوع قاعدة بيانات غير معروف.', |
| 50 | + 'externaldata-db-could-not-connect' => 'خطأ: تعذّر الاتصال بقاعدة البيانات.', |
| 51 | + 'externaldata-db-no-return-values' => 'خطأ: لم تحدد أي قيم عائدة.', |
| 52 | + 'externaldata-db-invalid-query' => 'استعلام غير صالح.', |
| 53 | +); |
| 54 | + |
| 55 | +/** Egyptian Spoken Arabic (مصرى) |
| 56 | + * @author Meno25 |
| 57 | + */ |
| 58 | +$messages['arz'] = array( |
| 59 | + 'getdata' => 'الحصول على البيانات', |
| 60 | + 'externaldata-desc' => 'يسمح باسترجاع البيانات بصيغة CSV، JSON و XML من مسارات خارجية وصفحات الويكى المحلية', |
| 61 | +); |
| 62 | + |
| 63 | +/** Belarusian (Taraškievica orthography) (Беларуская (тарашкевіца)) |
| 64 | + * @author EugeneZelenko |
| 65 | + * @author Jim-by |
| 66 | + */ |
| 67 | +$messages['be-tarask'] = array( |
| 68 | + 'getdata' => 'Атрымаць зьвесткі', |
| 69 | + 'externaldata-desc' => 'Дазваляе атрымліваць зьвесткі ў фарматах CSV, JSON і XML з вонкавых крыніц і лякальных старонак вікі', |
| 70 | + 'externaldata-ldap-unable-to-connect' => 'Немагчыма далучыцца да $1', |
| 71 | + 'externaldata-json-decode-not-supported' => 'Памылка: json_decode() не падтрымліваецца ў гэтай вэрсіі PHP', |
| 72 | + 'externaldata-xml-error' => 'Памылка XML: $1 у радку $2', |
| 73 | + 'externaldata-db-incomplete-information' => 'Памылка: Няпоўная інфармацыя для гэтага ідэнтыфікатара сэрвэра.', |
| 74 | + 'externaldata-db-could-not-get-url' => 'Немагчыма атрымаць URL-адрас пасьля $1 {{PLURAL:$1|спробы|спробаў|спробаў}}.', |
| 75 | + 'externaldata-db-unknown-type' => 'Памылка: Невядомы тып базы зьвестак.', |
| 76 | + 'externaldata-db-could-not-connect' => 'Памылка: Немагчыма далучыцца да базы зьвестак.', |
| 77 | + 'externaldata-db-no-return-values' => 'Памылка: Не пазначаныя выніковыя значэньні.', |
| 78 | + 'externaldata-db-invalid-query' => 'Няслушны запыт.', |
| 79 | +); |
| 80 | + |
| 81 | +/** Bosnian (Bosanski) |
| 82 | + * @author CERminator |
| 83 | + */ |
| 84 | +$messages['bs'] = array( |
| 85 | + 'getdata' => 'Uzmi podatke', |
| 86 | + 'externaldata-desc' => 'Omogućuje za preuzimanje podataka u formatima CSV, JSON i XML za vanjske URLove i lokalnu wiki', |
| 87 | + 'externaldata-ldap-unable-to-connect' => 'Ne može se spojiti na $1', |
| 88 | + 'externaldata-json-decode-not-supported' => 'Greška: json_decode() nije podržan u ovoj PHP verziji', |
| 89 | + 'externaldata-xml-error' => 'XML greška: $1 na liniji $2', |
| 90 | + 'externaldata-db-incomplete-information' => 'Greška: Nepotpune informacije za ovaj ID servera.', |
| 91 | + 'externaldata-db-could-not-get-url' => 'Nije pronađen URL nakon $1 {{PLURAL:$1|pokušaja|pokušaja}}.', |
| 92 | + 'externaldata-db-unknown-type' => 'Greška: Nepoznat tip baze podataka.', |
| 93 | + 'externaldata-db-could-not-connect' => 'Greška: Ne može se spojiti na bazu podataka.', |
| 94 | + 'externaldata-db-no-return-values' => 'Greška: Nije navedena povratna vrijednost.', |
| 95 | + 'externaldata-db-invalid-query' => 'Nevaljan upit.', |
| 96 | +); |
| 97 | + |
| 98 | +/** Catalan (Català) |
| 99 | + * @author Paucabot |
| 100 | + * @author Solde |
| 101 | + */ |
| 102 | +$messages['ca'] = array( |
| 103 | + 'getdata' => 'Obtenir dades', |
| 104 | + 'externaldata-xml-error' => 'Error XML: $1 a la línia $2', |
| 105 | + 'externaldata-db-unknown-type' => 'Error: Tipus de base de dades desconegut.', |
| 106 | + 'externaldata-db-could-not-connect' => "Error: No s'ha pogut connectar a la base de dades.", |
| 107 | + 'externaldata-db-invalid-query' => 'Consulta no vàlida.', |
| 108 | +); |
| 109 | + |
| 110 | +/** German (Deutsch) |
| 111 | + * @author Imre |
| 112 | + * @author MF-Warburg |
| 113 | + * @author Purodha |
| 114 | + * @author Umherirrender |
| 115 | + */ |
| 116 | +$messages['de'] = array( |
| 117 | + 'getdata' => 'Daten holen', |
| 118 | + 'externaldata-desc' => 'Erlaubt das Einfügen von Daten der Formate CSV, JSON und XML sowohl von externer URL als auch von lokalen Wikiseite', |
| 119 | + 'externaldata-ldap-unable-to-connect' => 'Keine Verbindung zu $1', |
| 120 | + 'externaldata-json-decode-not-supported' => 'Fehler: json_decode() wird nicht von dieser PHP-Version unterstützt', |
| 121 | + 'externaldata-xml-error' => 'XML-Fehler: $1 in Zeile $2', |
| 122 | + 'externaldata-db-incomplete-information' => 'Fehler: Unvollständige Informationen für diese Server-ID.', |
| 123 | + 'externaldata-db-could-not-get-url' => 'URL konnte nach $1 {{PLURAL:$1|Versuch|Versuchen}} nicht abgerufen werden.', |
| 124 | + 'externaldata-db-unknown-type' => 'Fehler: Unbekannter Datenbanktyp.', |
| 125 | + 'externaldata-db-could-not-connect' => 'Fehler: Keine Verbindung zur Datenbank.', |
| 126 | + 'externaldata-db-no-return-values' => 'Fehler: Keine Rückgabewerte festgelegt.', |
| 127 | + 'externaldata-db-invalid-query' => 'Ungültige Abfrage.', |
| 128 | +); |
| 129 | + |
| 130 | +/** Lower Sorbian (Dolnoserbski) |
| 131 | + * @author Michawiki |
| 132 | + */ |
| 133 | +$messages['dsb'] = array( |
| 134 | + 'getdata' => 'Daty wobstaraś', |
| 135 | + 'externaldata-desc' => 'Zmóžnja wótwołanje datow w formatach CSV, JSON a XML ako z eksternych URL tak teke lokalnych wikijowych bokow', |
| 136 | + 'externaldata-ldap-unable-to-connect' => 'Njemóžno z $1 zwězaś', |
| 137 | + 'externaldata-json-decode-not-supported' => 'Zmólka: json_decode() njepódpěra se w toś tej wersiji PHP', |
| 138 | + 'externaldata-xml-error' => 'Zmólka XML: $1 na smužce $2', |
| 139 | + 'externaldata-db-incomplete-information' => "'''Zmólka: Njedopołne informacije za toś ten serwerowy ID.'''", |
| 140 | + 'externaldata-db-could-not-get-url' => 'Njemóžno URL pó $1 {{PLURAL:$1|wopyśe|wopytoma|wopytach|wopytach}} dostaś.', |
| 141 | + 'externaldata-db-unknown-type' => "'''Zmólka: Njeznata datowa banka.'''", |
| 142 | + 'externaldata-db-could-not-connect' => "'''Zmólka: Njemóžno z datoweju banku zwězaś.'''", |
| 143 | + 'externaldata-db-no-return-values' => "'''Zmólka: Žedne gódnoty slědkdaśa pódane.'''", |
| 144 | + 'externaldata-db-invalid-query' => 'Njepłaśiwe napšašowanje.', |
| 145 | +); |
| 146 | + |
| 147 | +/** Greek (Ελληνικά) |
| 148 | + * @author Dead3y3 |
| 149 | + * @author Omnipaedista |
| 150 | + */ |
| 151 | +$messages['el'] = array( |
| 152 | + 'getdata' => 'Πάρε δεδομένα', |
| 153 | + 'externaldata-desc' => 'Επιτρέπει την ανάκτηση δεδομένων σε μορφές CSV, JSON και XML και για εξωτερικά URLs και για σελίδες του τοπικού wiki', |
| 154 | + 'externaldata-xml-error' => 'Σφάλμα XML : $1 στη γραμμή $2', |
| 155 | + 'externaldata-db-invalid-query' => 'Άκυρο αίτημα.', |
| 156 | +); |
| 157 | + |
| 158 | +/** Spanish (Español) |
| 159 | + * @author Crazymadlover |
| 160 | + * @author Sanbec |
| 161 | + */ |
| 162 | +$messages['es'] = array( |
| 163 | + 'getdata' => 'Obtener datos', |
| 164 | + 'externaldata-desc' => 'Permite la recuperación de datos en formatos CSV, JSON y XML a partir de URL externos y de páginas wiki locales', |
| 165 | +); |
| 166 | + |
| 167 | +/** Basque (Euskara) |
| 168 | + * @author Kobazulo |
| 169 | + */ |
| 170 | +$messages['eu'] = array( |
| 171 | + 'getdata' => 'Datuak eskuratu', |
| 172 | +); |
| 173 | + |
| 174 | +/** Finnish (Suomi) |
| 175 | + * @author Silvonen |
| 176 | + * @author Str4nd |
| 177 | + */ |
| 178 | +$messages['fi'] = array( |
| 179 | + 'externaldata-ldap-unable-to-connect' => 'Ei voitu yhdistää palvelimelle $1', |
| 180 | + 'externaldata-json-decode-not-supported' => 'Virhe: json_decode() ei ole tuettu tässä PHP:n versiossa', |
| 181 | + 'externaldata-xml-error' => 'XML-virhe: $1 rivillä $2', |
| 182 | + 'externaldata-db-unknown-type' => 'Virhe: Tuntematon tietokantatyyppi.', |
| 183 | +); |
| 184 | + |
| 185 | +/** French (Français) |
| 186 | + * @author Crochet.david |
| 187 | + * @author IAlex |
| 188 | + */ |
| 189 | +$messages['fr'] = array( |
| 190 | + 'getdata' => 'Obtenir des données', |
| 191 | + 'externaldata-desc' => 'Permet de récupérer des données en CSV, JSON et XML depuis des URL externes et des pages du wiki', |
| 192 | + 'externaldata-ldap-unable-to-connect' => 'Impossible de se connecter à $1', |
| 193 | + 'externaldata-json-decode-not-supported' => "Erreur : json_decode() n'est pas supportée dans cette version de PHP", |
| 194 | + 'externaldata-xml-error' => 'Erreur XML : $1 à la ligne $2', |
| 195 | + 'externaldata-db-incomplete-information' => 'Erreur : Informations incomplètes pour cet identifiant de serveur.', |
| 196 | + 'externaldata-db-could-not-get-url' => "Impossible d'obtenir l'URL après $1 essai{{PLURAL:$1|s|s}}.", |
| 197 | + 'externaldata-db-unknown-type' => 'ERREUR: Type de base de données inconnu.', |
| 198 | + 'externaldata-db-could-not-connect' => 'Erreur : Impossible de se connecteur à la base de données.', |
| 199 | + 'externaldata-db-no-return-values' => "Erreur : Aucune valeur de retour n'a été spécifiée.", |
| 200 | + 'externaldata-db-invalid-query' => 'Requête invalide.', |
| 201 | +); |
| 202 | + |
| 203 | +/** Galician (Galego) |
| 204 | + * @author Toliño |
| 205 | + */ |
| 206 | +$messages['gl'] = array( |
| 207 | + 'getdata' => 'Obter os datos', |
| 208 | + 'externaldata-desc' => 'Permite a recuperación de datos en formatos CSV, JSON e XML a partir dos enderezos URL externos e mais das páxinas wiki locais', |
| 209 | + 'externaldata-ldap-unable-to-connect' => 'Non se pode conectar a $1', |
| 210 | + 'externaldata-json-decode-not-supported' => 'Erro: json_decode() non está soportado nesta versión de PHP', |
| 211 | + 'externaldata-xml-error' => 'Erro XML: $1 na liña $2', |
| 212 | + 'externaldata-db-incomplete-information' => 'Erro: información incompleta para este ID de servidor.', |
| 213 | + 'externaldata-db-could-not-get-url' => 'Non se puido obter o enderezo URL despois de $1 {{PLURAL:$1|intento|intentos}}.', |
| 214 | + 'externaldata-db-unknown-type' => 'Erro: tipo de base de datos descoñecido.', |
| 215 | + 'externaldata-db-could-not-connect' => 'Erro: non se puido conectar á base de datos.', |
| 216 | + 'externaldata-db-no-return-values' => 'Erro: non se especificou ningún valor de retorno.', |
| 217 | + 'externaldata-db-invalid-query' => 'Consulta non válida.', |
| 218 | +); |
| 219 | + |
| 220 | +/** Swiss German (Alemannisch) |
| 221 | + * @author Als-Holder |
| 222 | + */ |
| 223 | +$messages['gsw'] = array( |
| 224 | + 'getdata' => 'Date hole', |
| 225 | + 'externaldata-desc' => 'Erlaubt Daten abzruefe im CSV, JSON un XML Format vu extärne URL un lokale Wikisyte', |
| 226 | + 'externaldata-ldap-unable-to-connect' => 'Cha kei Verbindig härstellen zue $1', |
| 227 | + 'externaldata-json-decode-not-supported' => 'Fähler: json_decode() wird nit unterstitzt in däre Version vu PHP', |
| 228 | + 'externaldata-xml-error' => 'XML-Fähler: $1 in dr Zyyle $2', |
| 229 | + 'externaldata-db-incomplete-information' => 'Fähler: Nit vollständigi Information fir die Server-ID.', |
| 230 | + 'externaldata-db-could-not-get-url' => 'Cha d URL nit finde no $1 {{PLURAL:$1|Versuech|Versuech}}.', |
| 231 | + 'externaldata-db-unknown-type' => 'Fähler: Nit bekannte Datebanktyp.', |
| 232 | + 'externaldata-db-could-not-connect' => 'Fähler: Cha kei Verbindig härstelle zue dr Datebank.', |
| 233 | + 'externaldata-db-no-return-values' => 'Fähler: Kei Ruckgabewärt spezifiziert.', |
| 234 | + 'externaldata-db-invalid-query' => 'Nit giltigi Umfrog.', |
| 235 | +); |
| 236 | + |
| 237 | +/** Gujarati (ગુજરાતી) |
| 238 | + * @author Ashok modhvadia |
| 239 | + */ |
| 240 | +$messages['gu'] = array( |
| 241 | + 'getdata' => 'માહિતી પ્રાપ્ત કરો', |
| 242 | + 'externaldata-desc' => 'બાહ્ય કડીઓ અને સ્થાનિક વિકિ પાનાઓ પરથી CSV, JSON અને XML શૈલીમાં માહિતીની પુન:પ્રાપ્તિની છુટ', |
| 243 | +); |
| 244 | + |
| 245 | +/** Hebrew (עברית) |
| 246 | + * @author Rotemliss |
| 247 | + * @author YaronSh |
| 248 | + */ |
| 249 | +$messages['he'] = array( |
| 250 | + 'getdata' => 'קבלת נתונים', |
| 251 | + 'externaldata-desc' => 'אפשרות לקבלת נתונים בפורמטים: CSV, JSON ו־XML, גם מכתובות חיצוניות וגם מדפי ויקי מקומיים', |
| 252 | + 'externaldata-ldap-unable-to-connect' => 'לא ניתן להתחבר ל־$1', |
| 253 | + 'externaldata-json-decode-not-supported' => 'שגיאה: הפקודה json_decode() אינה נתמכת בגרסה זו של PHP', |
| 254 | + 'externaldata-xml-error' => 'שגיאת XML: $1 בשורה $2', |
| 255 | + 'externaldata-db-incomplete-information' => 'שגיאה: יש רק מידע חלקי על מספר השרת הזה.', |
| 256 | + 'externaldata-db-could-not-get-url' => 'לא ניתן לקבל את כתובת ה־URL לאחר {{PLURAL:$1|נסיון אחד|$1 נסיונות}}.', |
| 257 | + 'externaldata-db-unknown-type' => 'שגיאה: סוג בסיס הנתונים אינו מוכר.', |
| 258 | + 'externaldata-db-could-not-connect' => 'שגיאה: לא ניתן להתחבר אל בסיס הנתונים.', |
| 259 | + 'externaldata-db-no-return-values' => 'שגיאה: לא הוגדרו ערכים להחזרה.', |
| 260 | + 'externaldata-db-invalid-query' => 'שאילתה בלתי תקינה.', |
| 261 | +); |
| 262 | + |
| 263 | +/** Upper Sorbian (Hornjoserbsce) |
| 264 | + * @author Michawiki |
| 265 | + */ |
| 266 | +$messages['hsb'] = array( |
| 267 | + 'getdata' => 'Daty wobstarać', |
| 268 | + 'externaldata-desc' => 'Zmóžnja wotwołanje datow we formatach CSV, JSON a XML z eksternych URL kaž tež lokalnych wikijowych stronow', |
| 269 | + 'externaldata-ldap-unable-to-connect' => 'Njemóžno z $1 zwjazać', |
| 270 | + 'externaldata-json-decode-not-supported' => 'Zmylk: json_decode() so w tutej wersiji PHP njepodpěruje', |
| 271 | + 'externaldata-xml-error' => 'Zmylk XML: $1 na lince $2', |
| 272 | + 'externaldata-db-incomplete-information' => "'''Zmylk: Njedospołne informacije za ID tutoho serwera.'''", |
| 273 | + 'externaldata-db-could-not-get-url' => 'Njebě móžno URL po $1 {{PLURAL:$1|pospyće|pospytomaj|pospytach|pospytach}} dóstać.', |
| 274 | + 'externaldata-db-unknown-type' => "'''Zmylk: Njeznaty typ datoweje banki.'''", |
| 275 | + 'externaldata-db-could-not-connect' => "'''Zmylk: Njemóžno z datowej banku zwjazać.'''", |
| 276 | + 'externaldata-db-no-return-values' => "'''Zmylk: Žane hódnoty wróćenja podate.'''", |
| 277 | + 'externaldata-db-invalid-query' => 'Njepłaćiwe naprašowanje.', |
| 278 | +); |
| 279 | + |
| 280 | +/** Hungarian (Magyar) |
| 281 | + * @author Glanthor Reviol |
| 282 | + */ |
| 283 | +$messages['hu'] = array( |
| 284 | + 'getdata' => 'Adatok lekérése', |
| 285 | + 'externaldata-desc' => 'Adatok lekérése CSV, JSON és XML formátumban külső URL-ekről vagy helyi wiki lapokról egyaránt', |
| 286 | + 'externaldata-ldap-unable-to-connect' => 'Sikertelen csatlakozás a következőhöz: $1', |
| 287 | + 'externaldata-json-decode-not-supported' => 'Hiba: a json_decode() nem támogatott ebben a PHP verzióban', |
| 288 | + 'externaldata-xml-error' => '$1 XML hiba, $2. sor', |
| 289 | + 'externaldata-db-incomplete-information' => 'Hiba: hiányos információ a szerver azonosítóhoz.', |
| 290 | + 'externaldata-db-could-not-get-url' => 'Nem sikerült lekérni az URL-t {{PLURAL:$1|egy|$1}} próbálkozás alatt.', |
| 291 | + 'externaldata-db-unknown-type' => 'Hiba: ismeretlen adatbázis típus.', |
| 292 | + 'externaldata-db-could-not-connect' => 'Hiba: nem sikerült csatlakozni az adatbázishoz.', |
| 293 | + 'externaldata-db-no-return-values' => 'Hiba: nem lettek megadva visszatérési értékek.', |
| 294 | + 'externaldata-db-invalid-query' => 'Érvénytelen lekérdezés.', |
| 295 | +); |
| 296 | + |
| 297 | +/** Interlingua (Interlingua) |
| 298 | + * @author McDutchie |
| 299 | + */ |
| 300 | +$messages['ia'] = array( |
| 301 | + 'getdata' => 'Obtener datos', |
| 302 | + 'externaldata-desc' => 'Permitte recuperar datos in le formatos CSV, JSON e XML, e ab adresses URL externe e ab paginas wiki local', |
| 303 | +); |
| 304 | + |
| 305 | +/** Indonesian (Bahasa Indonesia) |
| 306 | + * @author Bennylin |
| 307 | + */ |
| 308 | +$messages['id'] = array( |
| 309 | + 'getdata' => 'Ambil data', |
| 310 | + 'externaldata-desc' => 'Mengijinkan data untuk diunduh dalam format CSV, JSON, dan XML dari pranala luar maupun dari halaman wiki', |
| 311 | + 'externaldata-ldap-unable-to-connect' => 'Tidak dapat terhubung ke $1', |
| 312 | + 'externaldata-json-decode-not-supported' => 'Galat: json_decode() tidak didukung oleh versi PHP ini', |
| 313 | + 'externaldata-xml-error' => 'Galat XML: $1 pada baris $2', |
| 314 | + 'externaldata-db-incomplete-information' => 'Galat: Informasi tak lengkap untuk ID peladen ini.', |
| 315 | + 'externaldata-db-could-not-get-url' => 'Tidak dapat mengambil URL setelah dicoba {{PLURAL:$1||}}$1 kali.', |
| 316 | + 'externaldata-db-unknown-type' => 'Galat: Jenis basis data tidak diketahui.', |
| 317 | + 'externaldata-db-could-not-connect' => 'Galat: Tidak dapat terhubung ke basis data.', |
| 318 | + 'externaldata-db-no-return-values' => 'Galat: Nilai pengembalian tidak dispesifikasi.', |
| 319 | + 'externaldata-db-invalid-query' => 'Kueri tidak sah.', |
| 320 | +); |
| 321 | + |
| 322 | +/** Italian (Italiano) |
| 323 | + * @author Pietrodn |
| 324 | + */ |
| 325 | +$messages['it'] = array( |
| 326 | + 'getdata' => 'Ottieni dati', |
| 327 | + 'externaldata-desc' => 'Consente di recuperare dati nei formati CSV, XML e JSON sia da URL esterni sia da pagine wiki locali', |
| 328 | +); |
| 329 | + |
| 330 | +/** Japanese (日本語) |
| 331 | + * @author Fryed-peach |
| 332 | + */ |
| 333 | +$messages['ja'] = array( |
| 334 | + 'getdata' => 'データ取得', |
| 335 | + 'externaldata-desc' => '外部URLやローカルのウィキページから、CSV・JSON・XML形式のデータを取得できるようにする', |
| 336 | + 'externaldata-ldap-unable-to-connect' => '$1 に接続できません', |
| 337 | + 'externaldata-json-decode-not-supported' => 'エラー: json_decode() はこのバージョンの PHP ではサポートされていません', |
| 338 | + 'externaldata-xml-error' => 'XMLエラー: 行$2で$1', |
| 339 | + 'externaldata-db-incomplete-information' => 'エラー: このサーバーIDに対する情報が不十分です。', |
| 340 | + 'externaldata-db-could-not-get-url' => '$1回の試行を行いましたが URL を取得できませんでした。', |
| 341 | + 'externaldata-db-unknown-type' => 'エラー: データベースの種類が不明です。', |
| 342 | + 'externaldata-db-could-not-connect' => 'エラー: データベースに接続できませんでした。', |
| 343 | + 'externaldata-db-no-return-values' => 'エラー: 戻り値が指定されていません。', |
| 344 | + 'externaldata-db-invalid-query' => '不正なクエリー', |
| 345 | +); |
| 346 | + |
| 347 | +/** Khmer (ភាសាខ្មែរ) |
| 348 | + * @author វ័ណថារិទ្ធ |
| 349 | + */ |
| 350 | +$messages['km'] = array( |
| 351 | + 'getdata' => 'យកទិន្នន័យ', |
| 352 | +); |
| 353 | + |
| 354 | +/** Ripoarisch (Ripoarisch) |
| 355 | + * @author Purodha |
| 356 | + */ |
| 357 | +$messages['ksh'] = array( |
| 358 | + 'getdata' => 'Date holle!', |
| 359 | + 'externaldata-desc' => 'Äloup, Date em <i lang="en">CSV</i> Fomaat, em <i lang="en">JSON</i> Fomaat, un em <i lang="en">XML</i> Fomaat fun <i lang="en">URLs</i> un vun Wiki-Sigge ze holle.', |
| 360 | + 'externaldata-ldap-unable-to-connect' => 'Kann nit noh $1 verbenge', |
| 361 | + 'externaldata-json-decode-not-supported' => '<span style="text-transform: uppercase">Fähler:</span> De Fungxuhn <code lang="en">json_decode()</code> weedt vun heh dä Version vun <i lang="en">PHP</i> nit ongerschtöz.', |
| 362 | + 'externaldata-xml-error' => 'Fähler em XML, op Reih $2: $1', |
| 363 | + 'externaldata-db-incomplete-information' => '<span style="text-transform: uppercase">Fähler:</span> De Enfomazjuhne vör di ßööver Kännong sin nit kumplätt.', |
| 364 | + 'externaldata-db-could-not-get-url' => 'Kunnt {{PLURAL:$1|noh eimohl Versöhke|och noh $1 Mohl Versöhke|ohne enne Versöhk}} nix vun däm <i lang="en">URL</i> krijje.', |
| 365 | + 'externaldata-db-unknown-type' => '<span style="text-transform: uppercase">Fähler:</span> Di Zoot Datebangk es unbikannt.', |
| 366 | + 'externaldata-db-could-not-connect' => '<span style="text-transform: uppercase">Fähler:</span> Kunnt kein Verbendung noh dä Datebangk krijje.', |
| 367 | + 'externaldata-db-no-return-values' => '<span style="text-transform: uppercase">Fähler:</span> Kein Wääte för Zerökzeävve aanjejovve.', |
| 368 | + 'externaldata-db-invalid-query' => 'Onjöltesch Frooch aan de Datebangk.', |
| 369 | +); |
| 370 | + |
| 371 | +/** Luxembourgish (Lëtzebuergesch) |
| 372 | + * @author Robby |
| 373 | + */ |
| 374 | +$messages['lb'] = array( |
| 375 | + 'getdata' => 'Donnéeë kréien', |
| 376 | + 'externaldata-desc' => 'Erlaabt et Donnéeën an de Formater CSV, JSON an XML vun externen URLen a lokale Wiki-Säiten ze verschaffen', |
| 377 | + 'externaldata-ldap-unable-to-connect' => 'Onméiglech sech op $1 ze connectéieren', |
| 378 | + 'externaldata-xml-error' => 'XML Feeler: $1 an der Linn $2', |
| 379 | + 'externaldata-db-could-not-get-url' => "D'URL konnt no {{PLURAL:$1|enger Kéier|$1 Versich}} net opgemaach ginn.", |
| 380 | + 'externaldata-db-unknown-type' => 'Feeler: Onbekannten Datebank-Typ.', |
| 381 | + 'externaldata-db-could-not-connect' => "Feeler: D'Verbindung mat der Datebank konnt net opgebaut ginn.", |
| 382 | + 'externaldata-db-invalid-query' => 'Net valabel Ufro.', |
| 383 | +); |
| 384 | + |
| 385 | +/** Dutch (Nederlands) |
| 386 | + * @author Siebrand |
| 387 | + */ |
| 388 | +$messages['nl'] = array( |
| 389 | + 'getdata' => 'Gegevens ophalen', |
| 390 | + 'externaldata-desc' => "Maakt het mogelijk gegevens in CSV, JSON en XML op te halen van zowel externe URL's als lokale wikipagina's", |
| 391 | + 'externaldata-ldap-unable-to-connect' => 'Het was niet mogelijk te verbinden met $1', |
| 392 | + 'externaldata-json-decode-not-supported' => 'Fout: json_decode() wordt niet ondersteund in deze versie van PHP', |
| 393 | + 'externaldata-xml-error' => 'XML-fout: $1 op regel $2', |
| 394 | + 'externaldata-db-incomplete-information' => 'Fout: Onvolledige informatie voor dit servernummer.', |
| 395 | + 'externaldata-db-could-not-get-url' => 'Na $1 {{PLURAL:$1|poging|pogingen}} gaf de URL geen resultaat.', |
| 396 | + 'externaldata-db-unknown-type' => 'Fout: onbekend databasetype.', |
| 397 | + 'externaldata-db-could-not-connect' => 'Fout: het was niet mogelijk met de database te verbinden.', |
| 398 | + 'externaldata-db-no-return-values' => 'Fout: er zijn geen return-waarden ingesteld.', |
| 399 | + 'externaldata-db-invalid-query' => 'Ongeldige zoekopdracht.', |
| 400 | +); |
| 401 | + |
| 402 | +/** Norwegian Nynorsk (Norsk (nynorsk)) |
| 403 | + * @author Gunnernett |
| 404 | + */ |
| 405 | +$messages['nn'] = array( |
| 406 | + 'getdata' => 'Hent data', |
| 407 | + 'externaldata-desc' => 'Gjev høve til å lasta inn data i formata CSV, JSON og XML frå både eksterne nettadresser og lokale wikisider', |
| 408 | +); |
| 409 | + |
| 410 | +/** Norwegian (bokmål) (Norsk (bokmål)) |
| 411 | + * @author Nghtwlkr |
| 412 | + */ |
| 413 | +$messages['no'] = array( |
| 414 | + 'getdata' => 'Hent data', |
| 415 | + 'externaldata-desc' => 'Gir mulighet til å hente data i formatene CSV, JSON og XML fra både eksterne nettadresser og lokale wikisider', |
| 416 | +); |
| 417 | + |
| 418 | +/** Occitan (Occitan) |
| 419 | + * @author Cedric31 |
| 420 | + */ |
| 421 | +$messages['oc'] = array( |
| 422 | + 'getdata' => 'Obténer de donadas', |
| 423 | + 'externaldata-desc' => "Permet de recuperar de donadas en CSV, JSON e XML dempuèi d'URL extèrnas e de paginas del wiki", |
| 424 | + 'externaldata-ldap-unable-to-connect' => 'Impossible de se connectar a $1', |
| 425 | + 'externaldata-json-decode-not-supported' => 'Error : json_decode() es pas suportada dins aquesta version de PHP', |
| 426 | + 'externaldata-xml-error' => 'Error XML : $1 a la linha $2', |
| 427 | + 'externaldata-db-incomplete-information' => 'Error : Informacions incompletas per aqueste identificant de servidor.', |
| 428 | + 'externaldata-db-could-not-get-url' => "Impossible d'obténer l'URL aprèp $1 {{PLURAL:$1|ensag|ensages}}.", |
| 429 | + 'externaldata-db-unknown-type' => 'ERROR: Tipe de banca de donadas desconegut.', |
| 430 | + 'externaldata-db-could-not-connect' => 'Error : Impossible de se connectar a la banca de donadas.', |
| 431 | + 'externaldata-db-no-return-values' => 'Error : Cap de valor de retorn es pas estada especificada.', |
| 432 | + 'externaldata-db-invalid-query' => 'Requèsta invalida.', |
| 433 | +); |
| 434 | + |
| 435 | +/** Polish (Polski) |
| 436 | + * @author Leinad |
| 437 | + * @author Sp5uhe |
| 438 | + */ |
| 439 | +$messages['pl'] = array( |
| 440 | + 'getdata' => 'Pobierz dane', |
| 441 | + 'externaldata-desc' => 'Umożliwia pobieranie danych w formatach CSV, JSON lub XML zarówno z zewnętrznych adresów URL jak i lokalnych stron wiki', |
| 442 | + 'externaldata-ldap-unable-to-connect' => 'Nie można połączyć się z $1', |
| 443 | + 'externaldata-json-decode-not-supported' => 'Błąd – json_decode() nie jest obsługiwana w tej wersji PHP', |
| 444 | + 'externaldata-xml-error' => 'Błąd XML – $1 w wierszu $2', |
| 445 | + 'externaldata-db-incomplete-information' => 'Błąd – niepełne informacje o tym identyfikatorze serwera.', |
| 446 | + 'externaldata-db-could-not-get-url' => 'Nie można uzyskać adresu URL po $1 {{PLURAL:$1|próbie|próbach}}.', |
| 447 | + 'externaldata-db-unknown-type' => 'Błąd: Nieznany typ bazy danych.', |
| 448 | + 'externaldata-db-could-not-connect' => 'Błąd: Nie można połączyć się z bazą danych.', |
| 449 | + 'externaldata-db-no-return-values' => 'Błąd – nie określono zwracanej wartości.', |
| 450 | + 'externaldata-db-invalid-query' => 'Nieprawidłowe zapytanie.', |
| 451 | +); |
| 452 | + |
| 453 | +/** Piedmontese (Piemontèis) |
| 454 | + * @author Dragonòt |
| 455 | + */ |
| 456 | +$messages['pms'] = array( |
| 457 | + 'getdata' => 'Oten dij dat', |
| 458 | + 'externaldata-desc' => "A përmëtt d'arcuperé dat an formà CSV, JSON e XML da pàgine ëd wiki esterne e locaj", |
| 459 | + 'externaldata-ldap-unable-to-connect' => 'A peul pa coleghesse a $1', |
| 460 | + 'externaldata-json-decode-not-supported' => "Eror: json_decode() a l'é pa suportà an sta vërsion ëd PHP", |
| 461 | + 'externaldata-xml-error' => 'Eror XML: $1 a la linia $2', |
| 462 | + 'externaldata-db-incomplete-information' => 'Eror: Anformassion pa completa për sto server ID-sì.', |
| 463 | + 'externaldata-db-could-not-get-url' => "A peul pa oten-e l'URL d'apress ëd $1 {{PLURAL:$1|preuva|preuve}}.", |
| 464 | + 'externaldata-db-unknown-type' => 'Eror: Sòrt ëd database pa conossùa', |
| 465 | + 'externaldata-db-could-not-connect' => 'Eror: a peul pa coleghesse al database.', |
| 466 | + 'externaldata-db-no-return-values' => "Eror: Pa gnun valor d'artorn spessifià.", |
| 467 | + 'externaldata-db-invalid-query' => 'Ciamà pa bon-a.', |
| 468 | +); |
| 469 | + |
| 470 | +/** Portuguese (Português) |
| 471 | + * @author Giro720 |
| 472 | + * @author Waldir |
| 473 | + */ |
| 474 | +$messages['pt'] = array( |
| 475 | + 'getdata' => 'Obter dados', |
| 476 | + 'externaldata-desc' => 'Permite a obtenção de dados em CSV, JSON e XML tanto a partir de URLs externos como de páginas wiki locais', |
| 477 | + 'externaldata-ldap-unable-to-connect' => 'Não foi possível conectar-se a $1', |
| 478 | + 'externaldata-xml-error' => 'erro no XML: $1 na linha $2', |
| 479 | + 'externaldata-db-could-not-get-url' => 'Não foi possível obter o URL após $1 {{PLURAL:$1|tentativa|tentativas}}.', |
| 480 | + 'externaldata-db-could-not-connect' => 'Erro: Não foi possível conectar-se ao banco de dados.', |
| 481 | +); |
| 482 | + |
| 483 | +/** Brazilian Portuguese (Português do Brasil) |
| 484 | + * @author Eduardo.mps |
| 485 | + */ |
| 486 | +$messages['pt-br'] = array( |
| 487 | + 'getdata' => 'Obter dados', |
| 488 | + 'externaldata-desc' => 'Permite a obtenção de dados em CSV, JSON e XML tanto a partir de URLs externos como de páginas wiki locais', |
| 489 | + 'externaldata-ldap-unable-to-connect' => 'Não foi possível conectar-se a $1', |
| 490 | + 'externaldata-json-decode-not-supported' => 'Erro: json_decode() não é suportado nesta versão do PHP', |
| 491 | + 'externaldata-xml-error' => 'Erro no XML: $1 na linha $2', |
| 492 | + 'externaldata-db-incomplete-information' => 'Erro: Informação incompleta para o ID deste servidor</P>', |
| 493 | + 'externaldata-db-could-not-get-url' => 'Não foi possível obter o URL após $1 {{PLURAL:$1|tentativa|tentativas}}.', |
| 494 | + 'externaldata-db-unknown-type' => 'Erro: Tipo de base de dados desconhecido.', |
| 495 | + 'externaldata-db-could-not-connect' => 'Erro: Não foi possível conectar-se a base de dados.', |
| 496 | + 'externaldata-db-no-return-values' => 'Erro: Nenhum valor de retorno especificado.', |
| 497 | + 'externaldata-db-invalid-query' => 'Consulta inválida.', |
| 498 | +); |
| 499 | + |
| 500 | +/** Romanian (Română) |
| 501 | + * @author Firilacroco |
| 502 | + * @author KlaudiuMihaila |
| 503 | + */ |
| 504 | +$messages['ro'] = array( |
| 505 | + 'getdata' => 'Obţine date', |
| 506 | + 'externaldata-desc' => 'Permite obţinerea datelor în format CSV, JSON şi XML din atât adrese URL externe, cât şi pagini wiki locale', |
| 507 | + 'externaldata-xml-error' => 'Eroare XML: $1 la linia $2', |
| 508 | + 'externaldata-db-unknown-type' => 'Eroare: Tipul bazei de date necunoscut.', |
| 509 | + 'externaldata-db-invalid-query' => 'Interogare invalidă.', |
| 510 | +); |
| 511 | + |
| 512 | +/** Tarandíne (Tarandíne) |
| 513 | + * @author Joetaras |
| 514 | + */ |
| 515 | +$messages['roa-tara'] = array( |
| 516 | + 'getdata' => 'Pigghie le date', |
| 517 | + 'externaldata-desc' => "Permette de repigghià le data jndr'à le formate CSV, JSON e XML da URL fore a Uicchipèdie e da pàggene locale de Uicchipèdie", |
| 518 | +); |
| 519 | + |
| 520 | +/** Russian (Русский) |
| 521 | + * @author Ferrer |
| 522 | + * @author Александр Сигачёв |
| 523 | + */ |
| 524 | +$messages['ru'] = array( |
| 525 | + 'getdata' => 'Получить данные', |
| 526 | + 'externaldata-desc' => 'Позволяет получение данных в форматах CSV, JSON и XML, как с внешних адресов, так и с локальных вики-страниц.', |
| 527 | + 'externaldata-ldap-unable-to-connect' => 'Не удаётся подключиться к $1', |
| 528 | + 'externaldata-json-decode-not-supported' => 'Ошибка. json_decode() не поддерживается в данной версии PHP', |
| 529 | + 'externaldata-xml-error' => 'Ошибка XML. $1 в строке $2', |
| 530 | + 'externaldata-db-incomplete-information' => 'ОШИБКА. Неполная информация для этого ID сервера.', |
| 531 | + 'externaldata-db-could-not-get-url' => 'Не удалось получить URL после $1 {{PLURAL:$1|попытки|попыток|попыток}}.', |
| 532 | + 'externaldata-db-unknown-type' => 'ОШИБКА. Неизвестный тип базы данных.', |
| 533 | + 'externaldata-db-could-not-connect' => 'ОШИБКА. Не удаётся подключиться к базе данных.', |
| 534 | + 'externaldata-db-no-return-values' => 'ОШИБКА. Не указаны возвращаемые значение.', |
| 535 | + 'externaldata-db-invalid-query' => 'Ошибочный запрос.', |
| 536 | +); |
| 537 | + |
| 538 | +/** Slovak (Slovenčina) |
| 539 | + * @author Helix84 |
| 540 | + */ |
| 541 | +$messages['sk'] = array( |
| 542 | + 'getdata' => 'Získať dáta', |
| 543 | + 'externaldata-desc' => 'Umožňuje získavanie údajov vo formátoch CSV, JSON a XML z externých URL aj z lokálnych wiki stránok', |
| 544 | + 'externaldata-ldap-unable-to-connect' => 'Nepodarilo sa pripojiť k $1', |
| 545 | + 'externaldata-json-decode-not-supported' => 'Chyba: táto verzia PHP nepodporuje json_decode()', |
| 546 | + 'externaldata-xml-error' => 'Chyba XML: $1 na riadku $2', |
| 547 | + 'externaldata-db-incomplete-information' => 'Chyba: Nekompletné informácie s týmto ID servera.', |
| 548 | + 'externaldata-db-could-not-get-url' => 'Nepodarilo sa získať URL po $1 {{PLURAL:$1|pokuse|pokusoch}}.', |
| 549 | + 'externaldata-db-unknown-type' => 'Chyba: Neznámy typ databázy.', |
| 550 | + 'externaldata-db-could-not-connect' => 'Chyba: Nepodarilo sa pripojiť k databáze.', |
| 551 | + 'externaldata-db-no-return-values' => 'Chyba: Neboli zadané žiadne návratové hodnoty.', |
| 552 | + 'externaldata-db-invalid-query' => 'Neplatná požiadavka.', |
| 553 | +); |
| 554 | + |
| 555 | +/** Serbian Cyrillic ekavian (Српски (ћирилица)) |
| 556 | + * @author Михајло Анђелковић |
| 557 | + */ |
| 558 | +$messages['sr-ec'] = array( |
| 559 | + 'getdata' => 'Преузми податке', |
| 560 | + 'externaldata-desc' => 'Омогућава преузимање података у CSV, JSON и XML форматима, како преко спољашњих веза, тако и са локалних вики-страна', |
| 561 | +); |
| 562 | + |
| 563 | +/** Serbian Latin ekavian (Srpski (latinica)) |
| 564 | + * @author Michaello |
| 565 | + */ |
| 566 | +$messages['sr-el'] = array( |
| 567 | + 'getdata' => 'Preuzmi podatke', |
| 568 | + 'externaldata-desc' => 'Omogućava preuzimanje podataka u CSV, JSON i XML formatima, kako preko spoljašnjih veza, tako i sa lokalnih viki-strana', |
| 569 | +); |
| 570 | + |
| 571 | +/** Swedish (Svenska) |
| 572 | + * @author Najami |
| 573 | + */ |
| 574 | +$messages['sv'] = array( |
| 575 | + 'getdata' => 'Hämta data', |
| 576 | + 'externaldata-desc' => 'Tillåter att hämta data i formaten CSV, JSON och XML från både externa URL:er och lokala wikisidor', |
| 577 | +); |
| 578 | + |
| 579 | +/** Telugu (తెలుగు) |
| 580 | + * @author Kiranmayee |
| 581 | + */ |
| 582 | +$messages['te'] = array( |
| 583 | + 'getdata' => 'విషయములు తీసుకునిరా', |
| 584 | +); |
| 585 | + |
| 586 | +/** Tagalog (Tagalog) |
| 587 | + * @author AnakngAraw |
| 588 | + */ |
| 589 | +$messages['tl'] = array( |
| 590 | + 'getdata' => 'Kunin ang dato', |
| 591 | + 'externaldata-desc' => 'Nagpapahintulot sa muling pagkuha ng datong nasa mga anyong CSV, JSON at XML na kapwa mula sa panlabas na mga URL at pampook na mga pahina ng wiki', |
| 592 | +); |
| 593 | + |
| 594 | +/** Turkish (Türkçe) |
| 595 | + * @author Karduelis |
| 596 | + */ |
| 597 | +$messages['tr'] = array( |
| 598 | + 'getdata' => 'Veri al', |
| 599 | +); |
| 600 | + |
| 601 | +/** Veps (Vepsan kel') |
| 602 | + * @author Игорь Бродский |
| 603 | + */ |
| 604 | +$messages['vep'] = array( |
| 605 | + 'getdata' => 'Sada andmused', |
| 606 | +); |
| 607 | + |
| 608 | +/** Vietnamese (Tiếng Việt) |
| 609 | + * @author Vinhtantran |
| 610 | + */ |
| 611 | +$messages['vi'] = array( |
| 612 | + 'getdata' => 'Lấy dữ liệu', |
| 613 | + 'externaldata-desc' => 'Cho phép truy xuất dữ liệu theo định dạng CSV, JSON và XML từ cả URL bên ngoài lẫn các trang wiki bên trong', |
| 614 | +); |
| 615 | + |
| 616 | +/** Yiddish (ייִדיש) |
| 617 | + * @author פוילישער |
| 618 | + */ |
| 619 | +$messages['yi'] = array( |
| 620 | + 'getdata' => 'באַקומען דאַטן', |
| 621 | +); |
| 622 | + |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ExternalData.i18n.php |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 623 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/ExternalData.php |
— | — | @@ -0,0 +1,69 @@ |
| 2 | +<?php |
| 3 | +/** |
| 4 | + * Initialization file for the External Data extension |
| 5 | + * |
| 6 | + * @file |
| 7 | + * @ingroup ExternalData |
| 8 | + * @author Yaron Koren |
| 9 | + */ |
| 10 | + |
| 11 | +if (!defined('MEDIAWIKI')) die(); |
| 12 | + |
| 13 | +$wgExtensionCredits['parserhook'][]= array( |
| 14 | + 'path' => __FILE__, |
| 15 | + 'name' => 'External Data', |
| 16 | + 'version' => '0.9.1', |
| 17 | + 'author' => array( 'Yaron Koren', 'Michael Dale', 'David Macdonald' ), |
| 18 | + 'url' => 'http://www.mediawiki.org/wiki/Extension:External_Data', |
| 19 | + 'description' => 'Allows for retrieving data in CSV, JSON and XML formats from both external URLs and local wiki pages', |
| 20 | + 'descriptionmsg' => 'externaldata-desc', |
| 21 | +); |
| 22 | +$edgIP = $IP . '/extensions/ExternalData'; |
| 23 | + |
| 24 | +$wgHooks['ParserFirstCallInit'][] = 'edgRegisterParser'; |
| 25 | +$wgExtensionMessagesFiles['ExternalData'] = $edgIP . '/ExternalData.i18n.php'; |
| 26 | + |
| 27 | +if( version_compare( $wgVersion, '1.16alpha', '>=' ) ) { |
| 28 | + $wgExtensionMessagesFiles['ExternalDataMagic'] = $edgIP . '/ExternalData.i18n.magic.php'; |
| 29 | +} else { |
| 30 | + // Pre 1.16alpha backward compatibility for magic words |
| 31 | + $wgHooks['LanguageGetMagic'][] = 'edgLanguageGetMagic'; |
| 32 | +} |
| 33 | + |
| 34 | +// register all special pages and other classes |
| 35 | +$wgAutoloadClasses['EDUtils'] = $edgIP . '/ED_Utils.php'; |
| 36 | +$wgAutoloadClasses['EDParserFunctions'] = $edgIP . '/ED_ParserFunctions.php'; |
| 37 | +$wgSpecialPages['GetData'] = 'EDGetData'; |
| 38 | +$wgAutoloadClasses['EDGetData'] = $edgIP . '/ED_GetData.php'; |
| 39 | +$wgSpecialPageGroups['GetData'] = 'pagetools'; |
| 40 | + |
| 41 | +$edgValues = array(); |
| 42 | +$edgStringReplacements = array(); |
| 43 | +$edgCacheTable = null; |
| 44 | +$edgAllowSSL = false; |
| 45 | + |
| 46 | +//(in seconds) set to one week: |
| 47 | +$edgCacheExpireTime = 60*60*24 * 7; |
| 48 | + |
| 49 | +function edgRegisterParser(&$parser) { |
| 50 | + $parser->setFunctionHook( 'get_external_data', array('EDParserFunctions','doGetExternalData') ); |
| 51 | + $parser->setFunctionHook( 'get_ldap_data', array('EDParserFunctions','doGetLDAPData') ); |
| 52 | + $parser->setFunctionHook( 'get_db_data', array('EDParserFunctions','doGetDBData') ); |
| 53 | + $parser->setFunctionHook( 'external_value', array('EDParserFunctions','doExternalValue') ); |
| 54 | + $parser->setFunctionHook( 'for_external_table', array('EDParserFunctions','doForExternalTable') ); |
| 55 | + |
| 56 | + return true; // always return true, in order not to stop MW's hook processing! |
| 57 | +} |
| 58 | + |
| 59 | +// Pre 1.16alpha backward compatibility for magic words |
| 60 | +function edgLanguageGetMagic( &$magicWords, $langCode = "en" ) { |
| 61 | + switch ( $langCode ) { |
| 62 | + default: |
| 63 | + $magicWords['get_external_data'] = array ( 0, 'get_external_data' ); |
| 64 | + $magicWords['get_ldap_data'] = array ( 0, 'get_ldap_data' ); |
| 65 | + $magicWords['get_db_data'] = array ( 0, 'get_db_data' ); |
| 66 | + $magicWords['external_value'] = array ( 0, 'external_value' ); |
| 67 | + $magicWords['for_external_table'] = array ( 0, 'for_external_table' ); |
| 68 | + } |
| 69 | + return true; |
| 70 | +} |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ExternalData.php |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 71 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/ED_ParserFunctions.php |
— | — | @@ -0,0 +1,250 @@ |
| 2 | +<?php |
| 3 | +/** |
| 4 | + * Class for handling the parser functions for External Data |
| 5 | + */ |
| 6 | + |
| 7 | +if ( !defined( 'MEDIAWIKI' ) ) { |
| 8 | + die( 'This file is a MediaWiki extension; it is not a valid entry point' ); |
| 9 | +} |
| 10 | + |
| 11 | +class EDParserFunctions { |
| 12 | + |
| 13 | + /** |
| 14 | + * Render the #get_external_data parser function |
| 15 | + */ |
| 16 | + static function doGetExternalData( &$parser ) { |
| 17 | + global $wgTitle, $edgCurPageName, $edgValues; |
| 18 | + |
| 19 | + // if we're handling multiple pages, reset $edgValues |
| 20 | + // when we move from one page to another |
| 21 | + $cur_page_name = $wgTitle->getText(); |
| 22 | + if (! isset($edgCurPageName) || $edgCurPageName != $cur_page_name) { |
| 23 | + $edgValues = array(); |
| 24 | + $edgCurPageName = $cur_page_name; |
| 25 | + } |
| 26 | + |
| 27 | + $params = func_get_args(); |
| 28 | + array_shift( $params ); // we already know the $parser ... |
| 29 | + $url = array_shift( $params ); |
| 30 | + $url = str_replace( ' ', '%20', $url ); // do some minor URL-encoding |
| 31 | + // check whether this URL is allowed - code based on |
| 32 | + // Parser::maybeMakeExternalImage() |
| 33 | + global $edgAllowExternalDataFrom; |
| 34 | + $data_from = $edgAllowExternalDataFrom; |
| 35 | + $text = false; |
| 36 | + if ( empty($data_from) ) { |
| 37 | + $url_match = true; |
| 38 | + } elseif ( is_array( $data_from ) ) { |
| 39 | + $url_match = false; |
| 40 | + foreach( $data_from as $match ) { |
| 41 | + if( strpos( $url, $match ) === 0 ) { |
| 42 | + $url_match = true; |
| 43 | + break; |
| 44 | + } |
| 45 | + } |
| 46 | + } else { |
| 47 | + $url_match = (strpos( $url, $data_from ) === 0); |
| 48 | + } |
| 49 | + if ( ! $url_match ) |
| 50 | + return; |
| 51 | + |
| 52 | + // now, get the contents of the URL - exit if there's nothing |
| 53 | + // there |
| 54 | + $url_contents = EDUtils::fetchURL( $url ); |
| 55 | + if ( empty( $url_contents ) ) |
| 56 | + return; |
| 57 | + |
| 58 | + $format = strtolower( array_shift( $params ) ); // make case-insensitive |
| 59 | + $external_values = array(); |
| 60 | + if ( $format == 'xml' ) { |
| 61 | + $external_values = EDUtils::getXMLData( $url_contents ); |
| 62 | + } elseif ( $format == 'csv' ) { |
| 63 | + $external_values = EDUtils::getCSVData( $url_contents, false ); |
| 64 | + } elseif ( $format == 'csv with header' ) { |
| 65 | + $external_values = EDUtils::getCSVData( $url_contents, true ); |
| 66 | + } elseif ( $format == 'json' ) { |
| 67 | + $external_values = EDUtils::getJSONData( $url_contents ); |
| 68 | + } |
| 69 | + // get set of filters and set of mappings, determining each |
| 70 | + // one by whether there's a double or single equals sign, |
| 71 | + // respectively |
| 72 | + $filters = array(); |
| 73 | + $mappings = array(); |
| 74 | + foreach ( $params as $param ) { |
| 75 | + if ( strpos( $param, '==' ) ) { |
| 76 | + list( $external_var, $value ) = explode( '==', $param ); |
| 77 | + // set to all lowercase to avoid casing issues |
| 78 | + $external_var = strtolower( $external_var ); |
| 79 | + $filters[$external_var] = $value; |
| 80 | + } elseif ( strpos( $param, '=' ) ) { |
| 81 | + list( $local_var, $external_var ) = explode( '=', $param ); |
| 82 | + // set to all lowercase to avoid casing issues |
| 83 | + $external_var = strtolower( $external_var ); |
| 84 | + $mappings[$local_var] = $external_var; |
| 85 | + } else { |
| 86 | + // if the parameter contains no equals signs, |
| 87 | + // do nothing |
| 88 | + } |
| 89 | + } |
| 90 | + foreach ( $filters as $filter_var => $filter_value ) { |
| 91 | + // find the entry of $external_values that matches |
| 92 | + // the filter variable; if none exists, just ignore |
| 93 | + // the filter |
| 94 | + if ( array_key_exists( $filter_var, $external_values ) ) { |
| 95 | + if ( is_array( $external_values[$filter_var] ) ) { |
| 96 | + $column_values = $external_values[$filter_var]; |
| 97 | + foreach ( $column_values as $i => $single_value ) { |
| 98 | + // if a value doesn't match |
| 99 | + // the filter value, remove |
| 100 | + // the value from this row for |
| 101 | + // all columns |
| 102 | + if ( $single_value != $filter_value ) { |
| 103 | + foreach ( $external_values as $external_var => $external_value ) { |
| 104 | + unset( $external_values[$external_var][$i] ); |
| 105 | + } |
| 106 | + } |
| 107 | + } |
| 108 | + } else { |
| 109 | + // if we have only one row of values, |
| 110 | + // and the filter doesn't match, just |
| 111 | + // keep the results array blank and |
| 112 | + // return |
| 113 | + if ( $external_values[$filter_var] != $filter_value ) { |
| 114 | + return; |
| 115 | + } |
| 116 | + } |
| 117 | + } |
| 118 | + } |
| 119 | + // for each external variable name specified in the function |
| 120 | + // call, get its value or values (if any exist), and attach it |
| 121 | + // or them to the local variable name |
| 122 | + foreach ( $mappings as $local_var => $external_var ) { |
| 123 | + if ( array_key_exists( $external_var, $external_values ) ) { |
| 124 | + if ( is_array( $external_values[$external_var] ) ) |
| 125 | + // array_values() restores regular |
| 126 | + // 1, 2, 3 indexes to array, after unset() |
| 127 | + // in filtering may have removed some |
| 128 | + $edgValues[$local_var] = array_values( $external_values[$external_var] ); |
| 129 | + else |
| 130 | + $edgValues[$local_var][] = $external_values[$external_var]; |
| 131 | + } |
| 132 | + } |
| 133 | + return; |
| 134 | + } |
| 135 | + |
| 136 | + /** |
| 137 | + * Render the #get_ldap_data parser function |
| 138 | + */ |
| 139 | + static function doGetLDAPData( &$parser ) { |
| 140 | + global $wgTitle, $edgCurPageName, $edgValues; |
| 141 | + |
| 142 | + // if we're handling multiple pages, reset $edgValues |
| 143 | + // when we move from one page to another |
| 144 | + $cur_page_name = $wgTitle->getText(); |
| 145 | + if (! isset($edgCurPageName) || $edgCurPageName != $cur_page_name) { |
| 146 | + $edgValues = array(); |
| 147 | + $edgCurPageName = $cur_page_name; |
| 148 | + } |
| 149 | + |
| 150 | + $params = func_get_args(); |
| 151 | + array_shift( $params ); // we already know the $parser ... |
| 152 | + $args = EDUtils::parseParams($params); // parse params into name-value pairs |
| 153 | + $mappings = EDUtils::parseMappings($args['data']); // parse the data arg into mappings |
| 154 | + |
| 155 | + $external_values = EDUtils::getLDAPData( $args['filter'], $args['domain'], array_values($mappings) ); |
| 156 | + |
| 157 | + // Build $edgValues |
| 158 | + foreach ( $mappings as $local_var => $external_var ) { |
| 159 | + $edgValues[$local_var][] = $external_values[0][$external_var][0]; |
| 160 | + } |
| 161 | + return; |
| 162 | + } |
| 163 | + |
| 164 | + /** |
| 165 | + * Render the #get_db_data parser function |
| 166 | + */ |
| 167 | + static function doGetDBData( &$parser ) { |
| 168 | + global $wgTitle, $edgCurPageName, $edgValues; |
| 169 | + |
| 170 | + // if we're handling multiple pages, reset $edgValues |
| 171 | + // when we move from one page to another |
| 172 | + $cur_page_name = $wgTitle->getText(); |
| 173 | + if (! isset($edgCurPageName) || $edgCurPageName != $cur_page_name) { |
| 174 | + $edgValues = array(); |
| 175 | + $edgCurPageName = $cur_page_name; |
| 176 | + } |
| 177 | + |
| 178 | + $params = func_get_args(); |
| 179 | + array_shift( $params ); // we already know the $parser ... |
| 180 | + $args = EDUtils::parseParams($params); // parse params into name-value pairs |
| 181 | + $mappings = EDUtils::parseMappings($args['data']); // parse the data arg into mappings |
| 182 | + |
| 183 | + $external_values = EDUtils::getDBData( $args['server'], $args['from'], $args['where'], array_values($mappings) ); |
| 184 | + // handle error cases |
| 185 | + if (is_null($external_values)) |
| 186 | + return; |
| 187 | + |
| 188 | + // Build $edgValues |
| 189 | + foreach ( $mappings as $local_var => $external_var ) { |
| 190 | + if ( array_key_exists( $external_var, $external_values ) ) { |
| 191 | + foreach ($external_values[$external_var] as $value) { |
| 192 | + $edgValues[$local_var][] = $value; |
| 193 | + } |
| 194 | + } |
| 195 | + } |
| 196 | + return; |
| 197 | + } |
| 198 | + |
| 199 | + /** |
| 200 | + * Get the specified index of the array for the specified local |
| 201 | + * variable retrieved by #get_external_data |
| 202 | + */ |
| 203 | + static function getIndexedValue( $var, $i ) { |
| 204 | + global $edgValues; |
| 205 | + if ( array_key_exists( $var, $edgValues ) && count( $edgValues[$var] > $i ) ) |
| 206 | + return $edgValues[$var][$i]; |
| 207 | + else |
| 208 | + return ''; |
| 209 | + } |
| 210 | + |
| 211 | + /** |
| 212 | + * Render the #external_value parser function |
| 213 | + */ |
| 214 | + static function doExternalValue( &$parser, $local_var = '' ) { |
| 215 | + global $edgValues; |
| 216 | + if ( ! array_key_exists( $local_var, $edgValues ) ) |
| 217 | + return ''; |
| 218 | + elseif ( is_array( $edgValues[$local_var] ) ) |
| 219 | + return $edgValues[$local_var][0]; |
| 220 | + else |
| 221 | + return $edgValues[$local_var]; |
| 222 | + } |
| 223 | + |
| 224 | + /** |
| 225 | + * Render the #for_external_table parser function |
| 226 | + */ |
| 227 | + static function doForExternalTable( &$parser, $expression = '' ) { |
| 228 | + global $edgValues; |
| 229 | + |
| 230 | + // get the variables used in this expression, get the number |
| 231 | + // of values for each, and loop through |
| 232 | + $matches = array(); |
| 233 | + preg_match_all( '/{{{([^}]*)}}}/', $expression, $matches ); |
| 234 | + $variables = $matches[1]; |
| 235 | + $num_loops = 0; |
| 236 | + foreach ($variables as $variable) { |
| 237 | + if ( array_key_exists( $variable, $edgValues ) ) { |
| 238 | + $num_loops = max( $num_loops, count( $edgValues[$variable] ) ); |
| 239 | + } |
| 240 | + } |
| 241 | + $text = ""; |
| 242 | + for ($i = 0; $i < $num_loops; $i++) { |
| 243 | + $cur_expression = $expression; |
| 244 | + foreach ($variables as $variable) { |
| 245 | + $cur_expression = str_replace( '{{{' . $variable . '}}}', self::getIndexedValue( $variable , $i ), $cur_expression ); |
| 246 | + } |
| 247 | + $text .= $cur_expression; |
| 248 | + } |
| 249 | + return $text; |
| 250 | + } |
| 251 | +} |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ED_ParserFunctions.php |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 252 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/ED_GetData.php |
— | — | @@ -0,0 +1,71 @@ |
| 2 | +<?php |
| 3 | +/** |
| 4 | + * A special page for retrieving selected rows of any wiki page that contains |
| 5 | + * data in CSV format |
| 6 | + */ |
| 7 | + |
| 8 | +if (!defined('MEDIAWIKI')) die(); |
| 9 | + |
| 10 | +class EDGetData extends SpecialPage { |
| 11 | + |
| 12 | + /** |
| 13 | + * Constructor |
| 14 | + */ |
| 15 | + function EDGetData() { |
| 16 | + SpecialPage::SpecialPage( 'GetData' ); |
| 17 | + wfLoadExtensionMessages( 'ExternalData' ); |
| 18 | + } |
| 19 | + |
| 20 | + function execute($query) { |
| 21 | + global $wgRequest, $wgOut; |
| 22 | + $wgOut->disable(); |
| 23 | + |
| 24 | + $this->setHeaders(); |
| 25 | + $page_name = $query; |
| 26 | + $title = Title::newFromText( $page_name ); |
| 27 | + if( is_null( $title ) ) |
| 28 | + return; |
| 29 | + if( ! $title->userCanRead() ) |
| 30 | + return; |
| 31 | + $article = new Article( $title ); |
| 32 | + $page_text = $article->fetchContent(); |
| 33 | + // Remove <noinclude> sections and <includeonly> tags from text |
| 34 | + $page_text = StringUtils::delimiterReplace('<noinclude>', '</noinclude>', '', $page_text); |
| 35 | + $page_text = strtr($page_text, array('<includeonly>' => '', '</includeonly>' => '')); |
| 36 | + $orig_lines = split( "\n", $page_text ); |
| 37 | + // ignore lines that are either blank or start with a semicolon |
| 38 | + $page_lines = array(); |
| 39 | + foreach ( $orig_lines as $i => $line ) |
| 40 | + if ( $line != '' && $line[0] != ';' ) |
| 41 | + $page_lines[] = $line; |
| 42 | + $headers = EDUtils::getValuesFromCSVLine( $page_lines[0] ); |
| 43 | + $queried_headers = array(); |
| 44 | + foreach( $wgRequest->getValues() as $key => $value ) { |
| 45 | + foreach( $headers as $header_index => $header_value ) { |
| 46 | + $header_value = str_replace( ' ', '_', $header_value ); |
| 47 | + if( $key == $header_value ) { |
| 48 | + $queried_headers[$header_index] = $value; |
| 49 | + } |
| 50 | + } |
| 51 | + } |
| 52 | + // include header in output |
| 53 | + $text = $page_lines[0]; |
| 54 | + foreach( $page_lines as $i => $line) { |
| 55 | + if ($i == 0) continue; |
| 56 | + $row_values = EDUtils::getValuesFromCSVLine( $line ); |
| 57 | + $found_match = true; |
| 58 | + foreach( $queried_headers as $i => $query_value ) { |
| 59 | + $single_value = str_replace( ' ', '_', $row_values[$i] ); |
| 60 | + if ( $single_value != $query_value ) { |
| 61 | + $found_match = false; |
| 62 | + } |
| 63 | + } |
| 64 | + if( $found_match ) { |
| 65 | + if ($text != '') $text .= "\n"; |
| 66 | + $text .= $line; |
| 67 | + } |
| 68 | + } |
| 69 | + print $text; |
| 70 | + } |
| 71 | + |
| 72 | +} |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ED_GetData.php |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 73 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/ExternalData.sql |
— | — | @@ -0,0 +1,9 @@ |
| 2 | +CREATE TABLE IF NOT EXISTS `ed_url_cache` ( |
| 3 | + `id` int(10) unsigned NOT NULL auto_increment, |
| 4 | + `url` varchar(255) NOT NULL, |
| 5 | + `post_vars` text, |
| 6 | + `req_time` int(11) NOT NULL, |
| 7 | + `result` longtext character set utf8 collate utf8_unicode_ci, |
| 8 | + UNIQUE KEY `id` (`id`), |
| 9 | + KEY `url` (`url`) |
| 10 | +) ENGINE=MyISAM DEFAULT CHARSET=latin1; |
\ No newline at end of file |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ExternalData.sql |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 11 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/README |
— | — | @@ -0,0 +1,84 @@ |
| 2 | +External Data extension |
| 3 | + |
| 4 | + Version 0.9.1 |
| 5 | + Yaron Koren, Michael Dale and David Macdonald |
| 6 | + |
| 7 | +This is free software licensed under the GNU General Public License. Please |
| 8 | +see http://www.gnu.org/copyleft/gpl.html for further details, including the |
| 9 | +full text and terms of the license. |
| 10 | + |
| 11 | +== Overview == |
| 12 | + |
| 13 | +External Data is an extension to MediaWiki that allows for retrieving data |
| 14 | +from various sources: external URLs and local wiki pages (in CSV, JSON and |
| 15 | +XML formats), database tables, and LDAP servers |
| 16 | + |
| 17 | +The extension defines five parser functions - #get_external_data, |
| 18 | +#get_db_data, #get_ldap_data, #external_value and #for_external_table: |
| 19 | + |
| 20 | +#get_external_data retrieves the data from a URL that holds XML, CSV or |
| 21 | +JSON, and assigns it to local variables or arrays. |
| 22 | + |
| 23 | +#get_db_data retrieves data from a database, using a SQL query, and assigns |
| 24 | +it to local variables or arrays. |
| 25 | + |
| 26 | +#get_ldap_data retrieves data from an LDAP server and assigns it to |
| 27 | +local variables. |
| 28 | + |
| 29 | +#external_value displays the value of any retrieved variable, or the |
| 30 | +first value if it's an array. |
| 31 | + |
| 32 | +#for_external_table applies processing onto multiple rows retrieved by |
| 33 | +#get_external_data. |
| 34 | + |
| 35 | +In addition, the extension defines a new special page, 'GetData', that |
| 36 | +exports selected rows from a wiki page that holds CSV data, in a format that |
| 37 | +is readable by #get_external_data. |
| 38 | + |
| 39 | +For more information, see the extension homepage at: |
| 40 | +http://www.mediawiki.org/wiki/Extension:External_Data |
| 41 | + |
| 42 | +== Requirements == |
| 43 | + |
| 44 | +This version of the External Data extension requires MediaWiki 1.8 or higher. |
| 45 | + |
| 46 | +== Installation == |
| 47 | + |
| 48 | +To install the extension, place the entire 'ExternalData' directory |
| 49 | +within your MediaWiki 'extensions' directory, then add the following |
| 50 | +line to your 'LocalSettings.php' file: |
| 51 | + |
| 52 | + require_once( "$IP/extensions/ExternalData/ExternalData.php" ); |
| 53 | + |
| 54 | +To cache the data from the URLs being accessed, you can call the contents |
| 55 | +of ExternalData.sql in your database, then add the following to |
| 56 | +LocalSettings.php: |
| 57 | + |
| 58 | + $edgCacheTable = 'ed_url_cache'; |
| 59 | + |
| 60 | +You should also add a line like the following, to set the expiration time |
| 61 | +of the cache, in seconds; this line will cache data for a week: |
| 62 | + |
| 63 | + $edgCacheExpireTime = 7 * 24 * 60 * 60; |
| 64 | + |
| 65 | +You can also set for string replacements to be done on the URLs you call, |
| 66 | +for instance to hide API keys: |
| 67 | + |
| 68 | + $edgStringReplacements['MY_API_KEY'] = 'abcd1324'; |
| 69 | + |
| 70 | +You can create a "whitelist" to allow retrieval of data only from trusted |
| 71 | +sites, in the manner of MediaWiki's $wgAllowExternalImagesFrom - if you |
| 72 | +are hiding API keys, it is very much recommended to create such a |
| 73 | +whitelist, to prevent users from being able to discover theire values: |
| 74 | + |
| 75 | + $edgAllowExternalDataFrom = array('http://example.com/api'); |
| 76 | + |
| 77 | +Finally, to use the database or LDAP retrieval capabilities, you need to |
| 78 | +set connection settings as well - see the online documentation for more |
| 79 | +information. |
| 80 | + |
| 81 | +== Contact == |
| 82 | + |
| 83 | +Comments, questions, suggestions and bug reports are welcome, and can |
| 84 | +be placed on the Talk page for the extension, or sent to Yaron at |
| 85 | +yaron57@gmail.com. |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/README |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 86 | + native |
Index: tags/extensions/ExternalData/REL_0_9_1/ED_Utils.php |
— | — | @@ -0,0 +1,329 @@ |
| 2 | +<?php |
| 3 | +/** |
| 4 | + * Utility functions for External Data |
| 5 | + */ |
| 6 | + |
| 7 | +if ( !defined( 'MEDIAWIKI' ) ) { |
| 8 | + die( 'This file is a MediaWiki extension; it is not a valid entry point' ); |
| 9 | +} |
| 10 | + |
| 11 | +class EDUtils { |
| 12 | + // how many times to try an HTTP request |
| 13 | + private static $http_number_of_tries=3; |
| 14 | + |
| 15 | + // XML-handling functions based on code found at |
| 16 | + // http://us.php.net/xml_set_element_handler |
| 17 | + static function startElement( $parser, $name, $attrs ) { |
| 18 | + global $edgCurrentXMLTag, $edgXMLValues; |
| 19 | + // set to all lowercase to avoid casing issues |
| 20 | + $edgCurrentXMLTag = strtolower( $name ); |
| 21 | + foreach( $attrs as $attr => $value ) { |
| 22 | + $attr = strtolower( $attr ); |
| 23 | + if ( array_key_exists( $attr, $edgXMLValues ) ) |
| 24 | + $edgXMLValues[$attr][] = $value; |
| 25 | + else |
| 26 | + $edgXMLValues[$attr] = array( $value ); |
| 27 | + } |
| 28 | + } |
| 29 | + |
| 30 | + static function endElement( $parser, $name ) { |
| 31 | + global $edgCurrentXMLTag; |
| 32 | + $edgCurrentXMLTag = ""; |
| 33 | + } |
| 34 | + |
| 35 | + static function getContent ( $parser, $content ) { |
| 36 | + global $edgCurrentXMLTag, $edgXMLValues; |
| 37 | + if ( array_key_exists( $edgCurrentXMLTag, $edgXMLValues ) ) |
| 38 | + $edgXMLValues[$edgCurrentXMLTag][] = $content; |
| 39 | + else |
| 40 | + $edgXMLValues[$edgCurrentXMLTag] = array( $content ); |
| 41 | + } |
| 42 | + |
| 43 | + static function parseParams( $params ) { |
| 44 | + $args = Array(); |
| 45 | + foreach ($params as $param) { |
| 46 | + $param = preg_replace ( "/\s\s+/" , " " , $param ); //whitespace |
| 47 | + list($name, $value) = split("=", $param, 2); |
| 48 | + $args[$name] = $value; |
| 49 | + } |
| 50 | + return $args; |
| 51 | + } |
| 52 | + |
| 53 | + // This function parses the data argument |
| 54 | + static function parseMappings( $dataArg ) { |
| 55 | + $dataArg = preg_replace ( "/\s\s+/" , " " , $dataArg ); //whitespace |
| 56 | + $rawMappings = split(",", $dataArg); |
| 57 | + $mappings = Array(); |
| 58 | + foreach ($rawMappings as $rawMapping) { |
| 59 | + $vals = split("=", $rawMapping, 2); |
| 60 | + if (count($vals) == 2) { |
| 61 | + $intValue = trim($vals[0]); |
| 62 | + $extValue = trim($vals[1]); |
| 63 | + $mappings[$intValue] = $extValue; |
| 64 | + } |
| 65 | + } |
| 66 | + return $mappings; |
| 67 | + } |
| 68 | + |
| 69 | + static function getLDAPData ($filter, $domain, $params) { |
| 70 | + global $edgLDAPServer; |
| 71 | + global $edgLDAPUser; |
| 72 | + global $edgLDAPPass; |
| 73 | + |
| 74 | + $ds = EDUtils::connectLDAP($edgLDAPServer[$domain], $edgLDAPUser[$domain], $edgLDAPPass[$domain]); |
| 75 | + $results = EDUtils::searchLDAP($ds, $domain, $filter, $params); |
| 76 | + |
| 77 | + return $results; |
| 78 | + } |
| 79 | + |
| 80 | + static function connectLDAP($server, $username, $password) { |
| 81 | + $ds = ldap_connect($server); |
| 82 | + if ($ds) { |
| 83 | + // these options for Active Directory only? |
| 84 | + ldap_set_option($ds, LDAP_OPT_PROTOCOL_VERSION,3); |
| 85 | + ldap_set_option($ds, LDAP_OPT_REFERRALS, 0); |
| 86 | + |
| 87 | + if ($username) { |
| 88 | + $r = ldap_bind($ds, $username, $password); |
| 89 | + } else { |
| 90 | + # no username, so do anonymous bind |
| 91 | + $r = ldap_bind($ds); |
| 92 | + } |
| 93 | + |
| 94 | + # should check the result of the bind here |
| 95 | + return $ds; |
| 96 | + } else { |
| 97 | + echo ( wfMsgExt( "externaldata-ldap-unable-to-connect", array( 'parse', 'escape' ), $server ) ); |
| 98 | + } |
| 99 | + } |
| 100 | + |
| 101 | + static function searchLDAP($ds, $domain, $filter, $attributes) { |
| 102 | + global $edgLDAPBaseDN; |
| 103 | + |
| 104 | + $sr = ldap_search($ds, $edgLDAPBaseDN[$domain], $filter, $attributes); |
| 105 | + $results = ldap_get_entries($ds, $sr); |
| 106 | + return $results; |
| 107 | + } |
| 108 | + |
| 109 | + static function getDBData ($server_id, $from, $where, $columns) { |
| 110 | + global $edgDBServerType; |
| 111 | + global $edgDBServer; |
| 112 | + global $edgDBName; |
| 113 | + global $edgDBUser; |
| 114 | + global $edgDBPass; |
| 115 | + |
| 116 | + if ((! array_key_exists($server_id, $edgDBServerType)) || |
| 117 | + (! array_key_exists($server_id, $edgDBServer)) || |
| 118 | + (! array_key_exists($server_id, $edgDBName)) || |
| 119 | + (! array_key_exists($server_id, $edgDBUser)) || |
| 120 | + (! array_key_exists($server_id, $edgDBPass))) { |
| 121 | + echo ( wfMsgExt( "externaldata-db-incomplete-information", array( 'parse', 'escape' ) ) ); |
| 122 | + return; |
| 123 | + } |
| 124 | + |
| 125 | + |
| 126 | + $db_type = $edgDBServerType[$server_id]; |
| 127 | + $db_server = $edgDBServer[$server_id]; |
| 128 | + $db_name = $edgDBName[$server_id]; |
| 129 | + $db_username = $edgDBUser[$server_id]; |
| 130 | + $db_password = $edgDBPass[$server_id]; |
| 131 | + |
| 132 | + if ($db_type == "mysql") { |
| 133 | + $db = new Database($db_server, $db_username, $db_password, $db_name); |
| 134 | + } elseif ($db_type == "postgres") { |
| 135 | + $db = new DatabasePostgres($db_server, $db_username, $db_password, $db_name); |
| 136 | + } elseif ($db_type == "mssql") { |
| 137 | + $db = new DatabaseMssql($db_server, $db_username, $db_password, $db_name); |
| 138 | + } else { |
| 139 | + echo ( wfMsgExt( "externaldata-db-unknown-type", array( 'parse', 'escape' ) ) ); |
| 140 | + return; |
| 141 | + } |
| 142 | + if (! $db->isOpen()) { |
| 143 | + echo ( wfMsgExt( "externaldata-db-could-not-connect", array( 'parse', 'escape' ) ) ); |
| 144 | + return; |
| 145 | + } |
| 146 | + |
| 147 | + if (count($columns) == 0) { |
| 148 | + echo ( wfMsgExt( "externaldata-db-no-return-values", array( 'parse', 'escape' ) ) ); |
| 149 | + return; |
| 150 | + } |
| 151 | + |
| 152 | + $rows = EDUtils::searchDB($db, $from, $where, $columns); |
| 153 | + $db->close(); |
| 154 | + |
| 155 | + $values = Array(); |
| 156 | + foreach ($rows as $row) { |
| 157 | + foreach ($columns as $column) { |
| 158 | + $values[$column][] = $row[$column]; |
| 159 | + } |
| 160 | + } |
| 161 | + |
| 162 | + return $values; |
| 163 | + } |
| 164 | + |
| 165 | + static function searchDB ($db, $from, $where, $columns) { |
| 166 | + $sql = "SELECT " . implode(",", $columns) . " "; |
| 167 | + $sql .= "FROM " . $from . " "; |
| 168 | + $sql .= "WHERE " . $where; |
| 169 | + |
| 170 | + $result = $db->query($sql); |
| 171 | + if (!$result) { |
| 172 | + echo ( wfMsgExt( "externaldata-db-invalid-query", array( 'parse', 'escape' ) ) ); |
| 173 | + return false; |
| 174 | + } else { |
| 175 | + $rows = Array(); |
| 176 | + while ($row = $db->fetchRow($result)) { |
| 177 | + $rows[] = $row; |
| 178 | + } |
| 179 | + return $rows; |
| 180 | + } |
| 181 | + } |
| 182 | + |
| 183 | + static function getXMLData ( $xml ) { |
| 184 | + global $edgXMLValues; |
| 185 | + $edgXMLValues = array(); |
| 186 | + |
| 187 | + $xml_parser = xml_parser_create(); |
| 188 | + xml_set_element_handler( $xml_parser, array( 'EDUtils', 'startElement' ), array( 'EDUtils', 'endElement' ) ); |
| 189 | + xml_set_character_data_handler( $xml_parser, array( 'EDUtils', 'getContent' ) ); |
| 190 | + if (!xml_parse($xml_parser, $xml, true)) { |
| 191 | + echo ( wfMsgExt( 'externaldata-xml-error', |
| 192 | + xml_error_string(xml_get_error_code($xml_parser)), |
| 193 | + xml_get_current_line_number($xml_parser), array( 'parse', 'escape' ) ) ); |
| 194 | + } |
| 195 | + xml_parser_free( $xml_parser ); |
| 196 | + return $edgXMLValues; |
| 197 | + } |
| 198 | + |
| 199 | + static function getValuesFromCSVLine( $csv_line ) { |
| 200 | + // regular expression copied from http://us.php.net/fgetcsv |
| 201 | + $vals = preg_split( '/,(?=(?:[^\"]*\"[^\"]*\")*(?![^\"]*\"))/', $csv_line ); |
| 202 | + $vals2 = array(); |
| 203 | + foreach( $vals as $val ) |
| 204 | + $vals2[] = trim( $val, '"' ); |
| 205 | + return $vals2; |
| 206 | + } |
| 207 | + |
| 208 | + static function getCSVData( $csv, $has_header ) { |
| 209 | + // from http://us.php.net/manual/en/function.str-getcsv.php#88311 |
| 210 | + // str_getcsv() is a function that was only added in PHP 5.3.0, |
| 211 | + // so use the much older fgetcsv() if it's not there |
| 212 | + if (function_exists('str_getcsv')) { |
| 213 | + $table = str_getcsv( $csv ); |
| 214 | + } else { |
| 215 | + $fiveMBs = 5 * 1024 * 1024; |
| 216 | + $fp = fopen("php://temp/maxmemory:$fiveMBs", 'r+'); |
| 217 | + fputs( $fp, $csv ); |
| 218 | + rewind( $fp ); |
| 219 | + $table = array(); |
| 220 | + while ($line = fgetcsv( $fp )) { |
| 221 | + array_push( $table, $line ); |
| 222 | + } |
| 223 | + fclose($fp); |
| 224 | + } |
| 225 | + // now "flip" the data, turning it into a column-by-column |
| 226 | + // array, instead of row-by-row |
| 227 | + if ( $has_header ) { |
| 228 | + $header_vals = array_shift( $table ); |
| 229 | + } |
| 230 | + $values = array(); |
| 231 | + foreach( $table as $line ) { |
| 232 | + foreach( $line as $i => $row_val ) { |
| 233 | + if ($has_header) { |
| 234 | + $column = strtolower( $header_vals[$i] ); |
| 235 | + } else { |
| 236 | + // start with an index of 1 instead of 0 |
| 237 | + $column = $i + 1; |
| 238 | + } |
| 239 | + if( array_key_exists( $column, $values ) ) |
| 240 | + $values[$column][] = $row_val; |
| 241 | + else |
| 242 | + $values[$column] = array( $row_val ); |
| 243 | + } |
| 244 | + } |
| 245 | + return $values; |
| 246 | + } |
| 247 | + |
| 248 | + /** |
| 249 | + * Recursive function for use by getJSONData() |
| 250 | + */ |
| 251 | + static function parseTree( $tree, &$retrieved_values ) { |
| 252 | + foreach ($tree as $key => $val) { |
| 253 | + if (is_array( $val )) { |
| 254 | + self::parseTree( $val, $retrieved_values ); |
| 255 | + } else { |
| 256 | + if( array_key_exists( $key, $retrieved_values ) ) |
| 257 | + $retrieved_values[$key][] = $val; |
| 258 | + else |
| 259 | + $retrieved_values[$key] = array( $val ); |
| 260 | + } |
| 261 | + } |
| 262 | + } |
| 263 | + |
| 264 | + static function getJSONData( $json ) { |
| 265 | + // escape if json_decode() isn't supported |
| 266 | + if ( ! function_exists( 'json_decode' ) ) { |
| 267 | + echo ( wfMsgExt( "externaldata-json-decode-not-supported", array( 'parse', 'escape' ) ) ); |
| 268 | + return array(); |
| 269 | + } |
| 270 | + $json_tree = json_decode($json, true); |
| 271 | + $values = array(); |
| 272 | + if ( is_array( $json_tree ) ) { |
| 273 | + self::parseTree( $json_tree, $values ); |
| 274 | + } |
| 275 | + return $values; |
| 276 | + } |
| 277 | + |
| 278 | + static function fetchURL( $url, $post_vars = array(), $get_fresh=false, $try_count=1 ) { |
| 279 | + $dbr = wfGetDB( DB_SLAVE ); |
| 280 | + global $edgStringReplacements, $edgCacheTable, |
| 281 | + $edgCacheExpireTime, $edgAllowSSL; |
| 282 | + |
| 283 | + // do any special variable replacements in the URLs, for |
| 284 | + // secret API keys and the like |
| 285 | + foreach ( $edgStringReplacements as $key => $value ) { |
| 286 | + $url = str_replace( $key, $value, $url ); |
| 287 | + } |
| 288 | + |
| 289 | + if( !isset( $edgCacheTable ) || is_null( $edgCacheTable ) ) { |
| 290 | + if ($edgAllowSSL) { |
| 291 | + return Http::get( $url, 'default', array(CURLOPT_SSL_VERIFYPEER => false) ); |
| 292 | + } else { |
| 293 | + return Http::get( $url ); |
| 294 | + } |
| 295 | + } |
| 296 | + |
| 297 | + // check the cache (only the first 254 chars of the url) |
| 298 | + $row = $dbr->selectRow( $edgCacheTable, '*', array( 'url' => substr($url,0,254) ), 'EDUtils::fetchURL' ); |
| 299 | + |
| 300 | + if($row && ( (time() - $row->req_time) > $edgCacheExpireTime )){ |
| 301 | + $get_fresh = true; |
| 302 | + } |
| 303 | + |
| 304 | + if ( !$row || $get_fresh) { |
| 305 | + if ($edgAllowSSL) { |
| 306 | + $page = Http::get( $url, 'default', array(CURLOPT_SSL_VERIFYPEER => false) ); |
| 307 | + } else { |
| 308 | + $page = Http::get( $url ); |
| 309 | + } |
| 310 | + if ( $page === false ) { |
| 311 | + sleep( 1 ); |
| 312 | + if( $try_count >= self::$http_number_of_tries ){ |
| 313 | + echo ( wfMsgExt( 'externaldata-db-could-not-get-url', array('parsemag', 'escape'), self::$http_number_of_tries ) ); |
| 314 | + return ''; |
| 315 | + } |
| 316 | + $try_count++; |
| 317 | + return self::fetchURL( $url, $post_vars, $get_fresh, $try_count ); |
| 318 | + } |
| 319 | + if ( $page != '' ) { |
| 320 | + $dbw = wfGetDB( DB_MASTER ); |
| 321 | + // insert contents into the cache table |
| 322 | + $dbw->insert( $edgCacheTable, array( 'url' => substr($url,0,254), 'result' => $page, 'req_time' => time() ) ); |
| 323 | + return $page; |
| 324 | + } |
| 325 | + } else { |
| 326 | + $row = $dbr->fetchObject( $res ); |
| 327 | + return $row->result; |
| 328 | + } |
| 329 | + } |
| 330 | +} |
Property changes on: tags/extensions/ExternalData/REL_0_9_1/ED_Utils.php |
___________________________________________________________________ |
Name: svn:eol-style |
1 | 331 | + native |