From 5c952421110adf0b04694ce3acefe6410c467155 Mon Sep 17 00:00:00 2001 From: cytopia Date: Fri, 28 Dec 2018 22:38:09 +0100 Subject: [PATCH] Add vendor: phpPgAdmin --- .devilbox/www/htdocs/credits.php | 19 +- .../htdocs/vendor/phppgadmin-5.6.0/CREDITS | 108 + .../htdocs/vendor/phppgadmin-5.6.0/DEVELOPERS | 155 + .../www/htdocs/vendor/phppgadmin-5.6.0/FAQ | 217 + .../htdocs/vendor/phppgadmin-5.6.0/HISTORY | 818 ++ .../htdocs/vendor/phppgadmin-5.6.0/INSTALL | 73 + .../htdocs/vendor/phppgadmin-5.6.0/LICENSE | 12 + .../www/htdocs/vendor/phppgadmin-5.6.0/TODO | 242 + .../vendor/phppgadmin-5.6.0/TRANSLATORS | 55 + .../htdocs/vendor/phppgadmin-5.6.0/admin.php | 753 ++ .../vendor/phppgadmin-5.6.0/aggregates.php | 462 + .../phppgadmin-5.6.0/ajax-ac-insert.php | 92 + .../htdocs/vendor/phppgadmin-5.6.0/all_db.php | 532 ++ .../vendor/phppgadmin-5.6.0/browser.php | 84 + .../htdocs/vendor/phppgadmin-5.6.0/casts.php | 103 + .../classes/ArrayRecordSet.php | 32 + .../vendor/phppgadmin-5.6.0/classes/Gui.php | 48 + .../vendor/phppgadmin-5.6.0/classes/Misc.php | 2655 ++++++ .../phppgadmin-5.6.0/classes/Plugin.php | 68 + .../classes/PluginManager.php | 137 + .../phppgadmin-5.6.0/classes/class.select.php | 217 + .../classes/database/ADODB_base.php | 359 + .../classes/database/Connection.php | 121 + .../classes/database/Postgres.php | 8013 +++++++++++++++++ .../classes/database/Postgres10.php | 30 + .../classes/database/Postgres11.php | 30 + .../classes/database/Postgres74.php | 635 ++ .../classes/database/Postgres80.php | 354 + .../classes/database/Postgres81.php | 296 + .../classes/database/Postgres82.php | 359 + .../classes/database/Postgres83.php | 363 + .../classes/database/Postgres84.php | 231 + .../classes/database/Postgres90.php | 33 + .../classes/database/Postgres91.php | 98 + .../classes/database/Postgres92.php | 30 + .../classes/database/Postgres93.php | 30 + .../classes/database/Postgres94.php | 30 + .../classes/database/Postgres95.php | 55 + .../classes/database/Postgres96.php | 57 + .../vendor/phppgadmin-5.6.0/colproperties.php | 346 + .../vendor/phppgadmin-5.6.0/composer.json | 13 + .../vendor/phppgadmin-5.6.0/conf/.gitignore | 1 + .../phppgadmin-5.6.0/conf/config.inc.php-dist | 172 + .../vendor/phppgadmin-5.6.0/constraints.php | 640 ++ .../vendor/phppgadmin-5.6.0/conversions.php | 88 + .../vendor/phppgadmin-5.6.0/database.php | 698 ++ .../vendor/phppgadmin-5.6.0/dataexport.php | 345 + .../vendor/phppgadmin-5.6.0/dataimport.php | 298 + .../vendor/phppgadmin-5.6.0/dbexport.php | 139 + .../vendor/phppgadmin-5.6.0/display.php | 879 ++ .../vendor/phppgadmin-5.6.0/domains.php | 587 ++ .../vendor/phppgadmin-5.6.0/fulltext.php | 1120 +++ .../vendor/phppgadmin-5.6.0/functions.js | 204 + .../vendor/phppgadmin-5.6.0/functions.php | 1038 +++ .../htdocs/vendor/phppgadmin-5.6.0/groups.php | 330 + .../htdocs/vendor/phppgadmin-5.6.0/help.php | 88 + .../phppgadmin-5.6.0/help/PostgresDoc10.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc11.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc12.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc74.php | 160 + .../phppgadmin-5.6.0/help/PostgresDoc80.php | 28 + .../phppgadmin-5.6.0/help/PostgresDoc81.php | 18 + .../phppgadmin-5.6.0/help/PostgresDoc82.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc83.php | 27 + .../phppgadmin-5.6.0/help/PostgresDoc84.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc90.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc91.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc92.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc93.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc94.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc95.php | 13 + .../phppgadmin-5.6.0/help/PostgresDoc96.php | 13 + .../vendor/phppgadmin-5.6.0/history.php | 226 + .../images/themes/bootstrap/Favicon.ico | Bin 0 -> 1406 bytes .../images/themes/bootstrap/Introduction.png | Bin 0 -> 516 bytes .../images/themes/bootstrap/title.png | Bin 0 -> 5388 bytes .../images/themes/cappuccino/Lminus.png | Bin 0 -> 191 bytes .../images/themes/cappuccino/Lplus.png | Bin 0 -> 202 bytes .../images/themes/cappuccino/Tminus.png | Bin 0 -> 192 bytes .../images/themes/cappuccino/Tplus.png | Bin 0 -> 204 bytes .../images/themes/cappuccino/inputbckg.png | Bin 0 -> 129 bytes .../images/themes/cappuccino/openListe.png | Bin 0 -> 252 bytes .../images/themes/cappuccino/title.png | Bin 0 -> 3815 bytes .../images/themes/default/AddArguments.png | Bin 0 -> 141 bytes .../images/themes/default/Admin.png | Bin 0 -> 535 bytes .../images/themes/default/Aggregate.png | Bin 0 -> 247 bytes .../images/themes/default/Aggregates.png | Bin 0 -> 254 bytes .../images/themes/default/AllUsers.png | Bin 0 -> 384 bytes .../default/AvailableReplicationSet.png | Bin 0 -> 404 bytes .../themes/default/AvailableSubscription.png | Bin 0 -> 374 bytes .../images/themes/default/Backup.png | Bin 0 -> 611 bytes .../images/themes/default/Cast.png | Bin 0 -> 298 bytes .../images/themes/default/Casts.png | Bin 0 -> 284 bytes .../images/themes/default/CheckConstraint.png | Bin 0 -> 295 bytes .../images/themes/default/Cluster.png | Bin 0 -> 456 bytes .../images/themes/default/Column.png | Bin 0 -> 296 bytes .../images/themes/default/Columns.png | Bin 0 -> 282 bytes .../images/themes/default/Constraints.png | Bin 0 -> 187 bytes .../images/themes/default/Conversion.png | Bin 0 -> 234 bytes .../images/themes/default/Conversions.png | Bin 0 -> 237 bytes .../images/themes/default/Copy.png | Bin 0 -> 347 bytes .../themes/default/CorruptedDatabase.png | Bin 0 -> 701 bytes .../images/themes/default/Cut.png | Bin 0 -> 415 bytes .../images/themes/default/Database.png | Bin 0 -> 527 bytes .../images/themes/default/Databases.png | Bin 0 -> 613 bytes .../images/themes/default/Definition.png | Bin 0 -> 310 bytes .../images/themes/default/Delete.png | Bin 0 -> 590 bytes .../images/themes/default/DisabledJob.png | Bin 0 -> 467 bytes .../themes/default/DisconnectedDatabase.png | Bin 0 -> 663 bytes .../themes/default/DisconnectedServer.png | Bin 0 -> 506 bytes .../images/themes/default/Domain.png | Bin 0 -> 320 bytes .../images/themes/default/Domains.png | Bin 0 -> 389 bytes .../images/themes/default/EnableArgument.png | Bin 0 -> 690 bytes .../images/themes/default/Erase.png | Bin 0 -> 451 bytes .../images/themes/default/Execute.png | Bin 0 -> 276 bytes .../images/themes/default/ExecuteSave.png | Bin 0 -> 472 bytes .../images/themes/default/Explain.png | Bin 0 -> 341 bytes .../images/themes/default/Export.png | Bin 0 -> 401 bytes .../images/themes/default/Favicon.ico | Bin 0 -> 1406 bytes .../images/themes/default/Filter.png | Bin 0 -> 381 bytes .../images/themes/default/ForeignKey.png | Bin 0 -> 250 bytes .../images/themes/default/Fts.png | Bin 0 -> 675 bytes .../images/themes/default/FtsCfg.png | Bin 0 -> 612 bytes .../images/themes/default/FtsDict.png | Bin 0 -> 597 bytes .../images/themes/default/FtsParser.png | Bin 0 -> 601 bytes .../images/themes/default/Function.png | Bin 0 -> 202 bytes .../images/themes/default/Functions.png | Bin 0 -> 226 bytes .../images/themes/default/GurusHint.png | Bin 0 -> 609 bytes .../images/themes/default/Help.png | Bin 0 -> 480 bytes .../images/themes/default/Histories.png | Bin 0 -> 398 bytes .../images/themes/default/History.png | Bin 0 -> 529 bytes .../images/themes/default/I.png | Bin 0 -> 89 bytes .../images/themes/default/Import.png | Bin 0 -> 482 bytes .../images/themes/default/Index.png | Bin 0 -> 344 bytes .../images/themes/default/Indexes.png | Bin 0 -> 349 bytes .../images/themes/default/Introduction.png | Bin 0 -> 516 bytes .../images/themes/default/Job.png | Bin 0 -> 551 bytes .../images/themes/default/Jobs.png | Bin 0 -> 396 bytes .../images/themes/default/Key.png | Bin 0 -> 323 bytes .../images/themes/default/L.png | Bin 0 -> 90 bytes .../images/themes/default/Language.png | Bin 0 -> 352 bytes .../images/themes/default/Languages.png | Bin 0 -> 380 bytes .../images/themes/default/Listen.png | Bin 0 -> 244 bytes .../images/themes/default/Listens.png | Bin 0 -> 275 bytes .../images/themes/default/Lminus.png | Bin 0 -> 114 bytes .../images/themes/default/Loading.gif | Bin 0 -> 2090 bytes .../images/themes/default/LowerArgument.png | Bin 0 -> 172 bytes .../images/themes/default/Lplus.png | Bin 0 -> 127 bytes .../images/themes/default/Node.png | Bin 0 -> 484 bytes .../images/themes/default/Nodes.png | Bin 0 -> 381 bytes .../images/themes/default/ObjectNotFound.png | Bin 0 -> 508 bytes .../themes/default/OfferedReplicationSet.png | Bin 0 -> 492 bytes .../themes/default/OfferedSubscription.png | Bin 0 -> 495 bytes .../images/themes/default/Open.png | Bin 0 -> 518 bytes .../images/themes/default/Operator.png | Bin 0 -> 192 bytes .../images/themes/default/OperatorClass.png | Bin 0 -> 479 bytes .../images/themes/default/OperatorClasses.png | Bin 0 -> 373 bytes .../images/themes/default/Operators.png | Bin 0 -> 201 bytes .../images/themes/default/Paste.png | Bin 0 -> 500 bytes .../images/themes/default/Path.png | Bin 0 -> 413 bytes .../images/themes/default/Paths.png | Bin 0 -> 424 bytes .../images/themes/default/PrimaryKey.png | Bin 0 -> 313 bytes .../images/themes/default/Privileges.png | Bin 0 -> 431 bytes .../images/themes/default/Processes.png | Bin 0 -> 499 bytes .../images/themes/default/Property.png | Bin 0 -> 357 bytes .../images/themes/default/RaiseArgument.png | Bin 0 -> 176 bytes .../images/themes/default/Record.png | Bin 0 -> 287 bytes .../images/themes/default/Records.png | Bin 0 -> 294 bytes .../images/themes/default/Redo.png | Bin 0 -> 489 bytes .../images/themes/default/Refresh.png | Bin 0 -> 652 bytes .../images/themes/default/RemoveArgument.png | Bin 0 -> 736 bytes .../images/themes/default/Replication.png | Bin 0 -> 543 bytes .../images/themes/default/ReplicationSets.png | Bin 0 -> 320 bytes .../images/themes/default/Restore.png | Bin 0 -> 709 bytes .../images/themes/default/Roles.png | Bin 0 -> 465 bytes .../images/themes/default/Rule.png | Bin 0 -> 217 bytes .../images/themes/default/Rules.png | Bin 0 -> 223 bytes .../images/themes/default/Save.png | Bin 0 -> 432 bytes .../images/themes/default/Schedule.png | Bin 0 -> 543 bytes .../images/themes/default/Schedules.png | Bin 0 -> 511 bytes .../images/themes/default/Schema.png | Bin 0 -> 227 bytes .../images/themes/default/Schemas.png | Bin 0 -> 237 bytes .../images/themes/default/Search.png | Bin 0 -> 488 bytes .../images/themes/default/Sequence.png | Bin 0 -> 280 bytes .../images/themes/default/Sequences.png | Bin 0 -> 241 bytes .../images/themes/default/Server.png | Bin 0 -> 404 bytes .../images/themes/default/Servers.png | Bin 0 -> 360 bytes .../images/themes/default/SqlEditor.png | Bin 0 -> 588 bytes .../images/themes/default/Statistics.png | Bin 0 -> 629 bytes .../images/themes/default/Step.png | Bin 0 -> 306 bytes .../images/themes/default/Steps.png | Bin 0 -> 374 bytes .../images/themes/default/Stop.png | Bin 0 -> 282 bytes .../images/themes/default/Subscriptions.png | Bin 0 -> 277 bytes .../images/themes/default/T.png | Bin 0 -> 92 bytes .../images/themes/default/Table.png | Bin 0 -> 394 bytes .../images/themes/default/Tables.png | Bin 0 -> 415 bytes .../images/themes/default/Tablespace.png | Bin 0 -> 253 bytes .../images/themes/default/Tablespaces.png | Bin 0 -> 192 bytes .../images/themes/default/Tminus.png | Bin 0 -> 115 bytes .../images/themes/default/Tplus.png | Bin 0 -> 127 bytes .../images/themes/default/Trigger.png | Bin 0 -> 190 bytes .../images/themes/default/TriggerFunction.png | Bin 0 -> 215 bytes .../themes/default/TriggerFunctions.png | Bin 0 -> 242 bytes .../images/themes/default/Triggers.png | Bin 0 -> 229 bytes .../images/themes/default/Type.png | Bin 0 -> 160 bytes .../images/themes/default/Types.png | Bin 0 -> 205 bytes .../images/themes/default/Undo.png | Bin 0 -> 470 bytes .../themes/default/UniqueConstraint.png | Bin 0 -> 291 bytes .../images/themes/default/User.png | Bin 0 -> 435 bytes .../images/themes/default/UserGroup.png | Bin 0 -> 639 bytes .../images/themes/default/UserGroups.png | Bin 0 -> 593 bytes .../images/themes/default/Users.png | Bin 0 -> 364 bytes .../images/themes/default/Variables.png | Bin 0 -> 380 bytes .../images/themes/default/View.png | Bin 0 -> 279 bytes .../images/themes/default/Views.png | Bin 0 -> 286 bytes .../images/themes/default/blank.png | Bin 0 -> 77 bytes .../images/themes/default/title.png | Bin 0 -> 3523 bytes .../htdocs/vendor/phppgadmin-5.6.0/index.php | 42 + .../htdocs/vendor/phppgadmin-5.6.0/indexes.js | 70 + .../vendor/phppgadmin-5.6.0/indexes.php | 422 + .../htdocs/vendor/phppgadmin-5.6.0/info.php | 339 + .../htdocs/vendor/phppgadmin-5.6.0/intro.php | 70 + .../phppgadmin-5.6.0/js/ac_insert_row.js | 229 + .../vendor/phppgadmin-5.6.0/js/database.js | 64 + .../vendor/phppgadmin-5.6.0/js/display.js | 90 + .../vendor/phppgadmin-5.6.0/lang/README | 14 + .../phppgadmin-5.6.0/lang/afrikaans.php | 621 ++ .../vendor/phppgadmin-5.6.0/lang/arabic.php | 581 ++ .../vendor/phppgadmin-5.6.0/lang/catalan.php | 897 ++ .../phppgadmin-5.6.0/lang/chinese-sim.php | 359 + .../phppgadmin-5.6.0/lang/chinese-tr.php | 583 ++ .../lang/chinese-utf8-zh_CN.php | 902 ++ .../lang/chinese-utf8-zh_TW.php | 863 ++ .../vendor/phppgadmin-5.6.0/lang/czech.php | 897 ++ .../vendor/phppgadmin-5.6.0/lang/danish.php | 617 ++ .../vendor/phppgadmin-5.6.0/lang/dutch.php | 467 + .../vendor/phppgadmin-5.6.0/lang/english.php | 905 ++ .../vendor/phppgadmin-5.6.0/lang/french.php | 899 ++ .../vendor/phppgadmin-5.6.0/lang/galician.php | 909 ++ .../vendor/phppgadmin-5.6.0/lang/german.php | 852 ++ .../vendor/phppgadmin-5.6.0/lang/greek.php | 744 ++ .../vendor/phppgadmin-5.6.0/lang/hebrew.php | 615 ++ .../phppgadmin-5.6.0/lang/hungarian.php | 901 ++ .../vendor/phppgadmin-5.6.0/lang/italian.php | 720 ++ .../vendor/phppgadmin-5.6.0/lang/japanese.php | 855 ++ .../vendor/phppgadmin-5.6.0/lang/langcheck | 71 + .../phppgadmin-5.6.0/lang/lithuanian.php | 898 ++ .../vendor/phppgadmin-5.6.0/lang/mongol.php | 527 ++ .../vendor/phppgadmin-5.6.0/lang/polish.php | 745 ++ .../phppgadmin-5.6.0/lang/portuguese-br.php | 898 ++ .../phppgadmin-5.6.0/lang/portuguese-pt.php | 608 ++ .../vendor/phppgadmin-5.6.0/lang/romanian.php | 758 ++ .../phppgadmin-5.6.0/lang/russian-utf8.php | 894 ++ .../vendor/phppgadmin-5.6.0/lang/russian.php | 586 ++ .../vendor/phppgadmin-5.6.0/lang/slovak.php | 648 ++ .../vendor/phppgadmin-5.6.0/lang/spanish.php | 905 ++ .../vendor/phppgadmin-5.6.0/lang/swedish.php | 565 ++ .../htdocs/vendor/phppgadmin-5.6.0/lang/synch | 71 + .../phppgadmin-5.6.0/lang/translations.php | 86 + .../vendor/phppgadmin-5.6.0/lang/turkish.php | 641 ++ .../phppgadmin-5.6.0/lang/ukrainian.php | 584 ++ .../vendor/phppgadmin-5.6.0/languages.php | 79 + .../libraries/adodb/adodb-csvlib.inc.php | 318 + .../libraries/adodb/adodb-datadict.inc.php | 1032 +++ .../libraries/adodb/adodb-error.inc.php | 258 + .../libraries/adodb/adodb-iterator.inc.php | 30 + .../libraries/adodb/adodb-lib.inc.php | 1197 +++ .../libraries/adodb/adodb-time.inc.php | 1432 +++ .../libraries/adodb/adodb.inc.php | 4416 +++++++++ .../adodb/drivers/adodb-postgres.inc.php | 14 + .../adodb/drivers/adodb-postgres64.inc.php | 1074 +++ .../adodb/drivers/adodb-postgres7.inc.php | 313 + .../adodb/drivers/adodb-postgres8.inc.php | 12 + .../libraries/adodb/lang/adodb-ar.inc.php | 33 + .../libraries/adodb/lang/adodb-bg.inc.php | 37 + .../libraries/adodb/lang/adodb-bgutf8.inc.php | 37 + .../libraries/adodb/lang/adodb-ca.inc.php | 34 + .../libraries/adodb/lang/adodb-cn.inc.php | 35 + .../libraries/adodb/lang/adodb-cz.inc.php | 40 + .../libraries/adodb/lang/adodb-da.inc.php | 33 + .../libraries/adodb/lang/adodb-de.inc.php | 33 + .../libraries/adodb/lang/adodb-en.inc.php | 33 + .../libraries/adodb/lang/adodb-es.inc.php | 33 + .../adodb/lang/adodb-esperanto.inc.php | 35 + .../libraries/adodb/lang/adodb-fa.inc.php | 35 + .../libraries/adodb/lang/adodb-fr.inc.php | 33 + .../libraries/adodb/lang/adodb-hu.inc.php | 34 + .../libraries/adodb/lang/adodb-it.inc.php | 34 + .../libraries/adodb/lang/adodb-nl.inc.php | 33 + .../libraries/adodb/lang/adodb-pl.inc.php | 35 + .../libraries/adodb/lang/adodb-pt-br.inc.php | 35 + .../libraries/adodb/lang/adodb-ro.inc.php | 35 + .../libraries/adodb/lang/adodb-ru1251.inc.php | 35 + .../libraries/adodb/lang/adodb-sv.inc.php | 33 + .../libraries/adodb/lang/adodb-uk1251.inc.php | 35 + .../libraries/adodb/lang/adodb_th.inc.php | 33 + .../libraries/adodb/license.txt | 182 + .../libraries/adodb/readme.txt | 62 + .../libraries/adodb/toexport.inc.php | 134 + .../libraries/adodb/tohtml.inc.php | 201 + .../libraries/decorator.inc.php | 215 + .../libraries/errorhandler.inc.php | 78 + .../phppgadmin-5.6.0/libraries/highlight.php | 1114 +++ .../phppgadmin-5.6.0/libraries/js/jquery.js | 2 + .../phppgadmin-5.6.0/libraries/lib.inc.php | 271 + .../htdocs/vendor/phppgadmin-5.6.0/links.js | 16 + .../htdocs/vendor/phppgadmin-5.6.0/login.php | 70 + .../htdocs/vendor/phppgadmin-5.6.0/logout.php | 18 + .../phppgadmin-5.6.0/multiactionform.js | 9 + .../vendor/phppgadmin-5.6.0/opclasses.php | 91 + .../vendor/phppgadmin-5.6.0/operators.php | 246 + .../htdocs/vendor/phppgadmin-5.6.0/plugin.php | 5 + .../plugins/GuiControl/conf/config.inc.php | 484 + .../plugins/GuiControl/plugin.php | 145 + .../phppgadmin-5.6.0/plugins/Report/INSTALL | 13 + .../phppgadmin-5.6.0/plugins/Report/README | 24 + .../plugins/Report/classes/Reports.php | 128 + .../plugins/Report/conf/config.inc.php | 12 + .../plugins/Report/images/Report.png | Bin 0 -> 405 bytes .../plugins/Report/images/Reports.png | Bin 0 -> 339 bytes .../plugins/Report/lang/afrikaans.php | 23 + .../plugins/Report/lang/arabic.php | 23 + .../plugins/Report/lang/catalan.php | 23 + .../plugins/Report/lang/chinese-sim.php | 22 + .../plugins/Report/lang/chinese-tr.php | 23 + .../Report/lang/chinese-utf8-zh_CN.php | 23 + .../Report/lang/chinese-utf8-zh_TW.php | 23 + .../plugins/Report/lang/czech.php | 23 + .../plugins/Report/lang/danish.php | 25 + .../plugins/Report/lang/dutch.php | 21 + .../plugins/Report/lang/english.php | 24 + .../plugins/Report/lang/french.php | 24 + .../plugins/Report/lang/galician.php | 23 + .../plugins/Report/lang/german.php | 23 + .../plugins/Report/lang/greek.php | 24 + .../plugins/Report/lang/hebrew.php | 23 + .../plugins/Report/lang/hungarian.php | 23 + .../plugins/Report/lang/italian.php | 23 + .../plugins/Report/lang/japanese.php | 23 + .../plugins/Report/lang/lithuanian.php | 23 + .../plugins/Report/lang/mongol.php | 22 + .../plugins/Report/lang/polish.php | 23 + .../plugins/Report/lang/portuguese-br.php | 23 + .../plugins/Report/lang/portuguese-pt.php | 23 + .../plugins/Report/lang/romanian.php | 23 + .../plugins/Report/lang/russian.php | 23 + .../plugins/Report/lang/slovak.php | 23 + .../plugins/Report/lang/spanish.php | 23 + .../plugins/Report/lang/swedish.php | 25 + .../plugins/Report/lang/turkish.php | 23 + .../plugins/Report/lang/ukrainian.php | 23 + .../plugins/Report/plugin.php | 807 ++ .../plugins/Report/sql/reports-pgsql.sql | 27 + .../vendor/phppgadmin-5.6.0/privileges.php | 354 + .../vendor/phppgadmin-5.6.0/redirect.php | 29 + .../htdocs/vendor/phppgadmin-5.6.0/robots.txt | 8 + .../htdocs/vendor/phppgadmin-5.6.0/roles.php | 743 ++ .../htdocs/vendor/phppgadmin-5.6.0/rules.php | 232 + .../vendor/phppgadmin-5.6.0/schemas.php | 480 + .../vendor/phppgadmin-5.6.0/sequences.php | 728 ++ .../vendor/phppgadmin-5.6.0/servers.php | 175 + .../htdocs/vendor/phppgadmin-5.6.0/sql.php | 263 + .../vendor/phppgadmin-5.6.0/sqledit.php | 156 + .../htdocs/vendor/phppgadmin-5.6.0/tables.js | 18 + .../htdocs/vendor/phppgadmin-5.6.0/tables.php | 1052 +++ .../vendor/phppgadmin-5.6.0/tablespaces.php | 326 + .../vendor/phppgadmin-5.6.0/tblproperties.php | 782 ++ .../themes/bootstrap/global.css | 321 + .../themes/bootstrap/title.png | Bin 0 -> 5388 bytes .../themes/cappuccino/global.css | 197 + .../themes/default/global.css | 266 + .../vendor/phppgadmin-5.6.0/themes/global.css | 111 + .../phppgadmin-5.6.0/themes/gotar/global.css | 262 + .../vendor/phppgadmin-5.6.0/themes/themes.php | 16 + .../vendor/phppgadmin-5.6.0/triggers.php | 448 + .../htdocs/vendor/phppgadmin-5.6.0/types.php | 714 ++ .../htdocs/vendor/phppgadmin-5.6.0/users.php | 415 + .../phppgadmin-5.6.0/viewproperties.php | 564 ++ .../htdocs/vendor/phppgadmin-5.6.0/views.php | 787 ++ .../phppgadmin-5.6.0/xloadtree/xloadtree2.js | 507 ++ .../phppgadmin-5.6.0/xloadtree/xtree2.js | 1621 ++++ .devilbox/www/include/lib/Html.php | 8 + .tests/intra-tests/vendor-phppgadmin.sh | 215 + 383 files changed, 78448 insertions(+), 7 deletions(-) create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/CREDITS create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/DEVELOPERS create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/FAQ create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/HISTORY create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/INSTALL create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/LICENSE create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TODO create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TRANSLATORS create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/admin.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/aggregates.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/ajax-ac-insert.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/all_db.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/browser.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/casts.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/ArrayRecordSet.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Gui.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Misc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Plugin.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/PluginManager.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/class.select.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/ADODB_base.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Connection.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres10.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres11.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres74.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres80.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres81.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres82.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres83.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres84.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres90.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres91.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres92.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres93.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres94.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres95.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres96.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/colproperties.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/composer.json create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/.gitignore create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/config.inc.php-dist create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/constraints.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conversions.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/database.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataexport.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataimport.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dbexport.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/display.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/domains.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/fulltext.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/functions.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/functions.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/groups.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc10.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc11.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc12.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc74.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc80.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc81.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc82.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc83.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc84.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc90.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc91.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc92.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc93.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc94.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc95.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc96.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/history.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/Favicon.ico create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/Introduction.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/title.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Lminus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Lplus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Tminus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Tplus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/inputbckg.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/openListe.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/title.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AddArguments.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Admin.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Aggregate.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Aggregates.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AllUsers.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AvailableReplicationSet.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AvailableSubscription.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Backup.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cast.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Casts.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/CheckConstraint.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cluster.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Column.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Columns.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Constraints.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Conversion.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Conversions.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Copy.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/CorruptedDatabase.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cut.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Database.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Databases.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Definition.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Delete.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisabledJob.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisconnectedDatabase.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisconnectedServer.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Domain.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Domains.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/EnableArgument.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Erase.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Execute.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ExecuteSave.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Explain.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Export.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Favicon.ico create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Filter.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ForeignKey.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Fts.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsCfg.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsDict.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsParser.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Function.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Functions.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/GurusHint.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Help.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Histories.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/History.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/I.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Import.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Index.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Indexes.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Introduction.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Job.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Jobs.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Key.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/L.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Language.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Languages.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Listen.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Listens.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Lminus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Loading.gif create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/LowerArgument.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Lplus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Node.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Nodes.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ObjectNotFound.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OfferedReplicationSet.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OfferedSubscription.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Open.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Operator.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OperatorClass.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OperatorClasses.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Operators.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Paste.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Path.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Paths.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/PrimaryKey.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Privileges.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Processes.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Property.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/RaiseArgument.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Record.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Records.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Redo.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Refresh.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/RemoveArgument.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Replication.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ReplicationSets.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Restore.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Roles.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Rule.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Rules.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Save.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Schedule.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Schedules.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Schema.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Schemas.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Search.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Sequence.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Sequences.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Server.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Servers.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/SqlEditor.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Statistics.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Step.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Steps.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Stop.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Subscriptions.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/T.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Table.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tables.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tablespace.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tablespaces.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tminus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tplus.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Trigger.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/TriggerFunction.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/TriggerFunctions.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Triggers.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Type.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Types.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Undo.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/UniqueConstraint.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/User.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/UserGroup.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/UserGroups.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Users.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Variables.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/View.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Views.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/blank.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/title.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/index.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/info.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/intro.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/ac_insert_row.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/database.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/display.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/README create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/afrikaans.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/arabic.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/catalan.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-sim.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-tr.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_CN.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_TW.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/czech.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/danish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/dutch.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/english.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/french.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/galician.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/german.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/greek.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hebrew.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hungarian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/italian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/japanese.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/langcheck create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/lithuanian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/mongol.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/polish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-br.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-pt.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/romanian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian-utf8.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/slovak.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/spanish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/swedish.php create mode 100755 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/synch create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/translations.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/turkish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/ukrainian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/languages.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-csvlib.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-datadict.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-error.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-iterator.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-lib.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-time.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres64.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres7.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres8.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ar.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bg.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bgutf8.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ca.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cn.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cz.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-da.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-de.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-en.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-es.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-esperanto.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fa.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fr.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-hu.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-it.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-nl.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pl.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pt-br.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ro.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ru1251.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-sv.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-uk1251.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb_th.inc.php create mode 100755 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/license.txt create mode 100755 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/readme.txt create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/toexport.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/tohtml.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/decorator.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/errorhandler.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/highlight.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/js/jquery.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/lib.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/links.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/login.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/logout.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/multiactionform.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/opclasses.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/operators.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugin.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/conf/config.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/plugin.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/INSTALL create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/README create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/classes/Reports.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/conf/config.inc.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/images/Report.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/images/Reports.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/afrikaans.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/arabic.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/catalan.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-sim.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-tr.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_CN.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_TW.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/czech.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/danish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/dutch.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/english.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/french.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/galician.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/german.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/greek.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hebrew.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hungarian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/italian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/japanese.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/lithuanian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/mongol.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/polish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-br.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-pt.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/romanian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/russian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/slovak.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/spanish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/swedish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/turkish.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/ukrainian.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/plugin.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/sql/reports-pgsql.sql create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/privileges.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/redirect.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/robots.txt create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/roles.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/rules.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/schemas.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sequences.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/servers.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sql.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sqledit.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tables.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tables.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tablespaces.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tblproperties.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/global.css create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/title.png create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/cappuccino/global.css create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/default/global.css create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/global.css create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/gotar/global.css create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/themes.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/triggers.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/types.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/users.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/viewproperties.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/views.php create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xloadtree2.js create mode 100644 .devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xtree2.js create mode 100755 .tests/intra-tests/vendor-phppgadmin.sh diff --git a/.devilbox/www/htdocs/credits.php b/.devilbox/www/htdocs/credits.php index 0325b2ec..7e762129 100644 --- a/.devilbox/www/htdocs/credits.php +++ b/.devilbox/www/htdocs/credits.php @@ -60,37 +60,42 @@ Adminer Apache License 2.0 or GPL 2 - vrana/adminer + vrana/adminer Bootstrap MIT - twbs/bootstrap + twbs/bootstrap Font Awesome (css) MIT - FortAwesome/Font-Awesome + FortAwesome/Font-Awesome Font Awesome (fonts) SIL OFL 1.1 - FortAwesome/Font-Awesome + FortAwesome/Font-Awesome Opcache GUI MIT - amnuts/opcache-gui + amnuts/opcache-gui phpMyAdmin GPL 2.0 - phpmyadmin/phpmyadmin + phpmyadmin/phpmyadmin + + + phpPgAdmin + GPL 2.0 + phppgadmin/phppgadmin PHPRedMin BSD 3-Clause License - sasanrose/phpredmin + sasanrose/phpredmin diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/CREDITS b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/CREDITS new file mode 100644 index 00000000..b823ebc2 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/CREDITS @@ -0,0 +1,108 @@ +CREDITS +------- + +Project Administration & Major Projects + +- Robert Treat (xzilla) + +Translators + +- Kuo Chaoyi (Chinese Utf8) +- Angelo Rigo (Brazilan Portuguese) +- Chan Min Wai (Chinese) +- He Wei Ping (Chinese) +- Chih-Hsin Lee (Trad. Chinese) +- Hugo Jonker (Dutch) +- Pascal Peyre (French) +- Guillaume Lelarge (French) +- ioguix (French) +- H. Etzel, Markus Bertheau (German) +- Kalef (Italian) +- Tadashi Jokagi (Japanese) +- Rafal Slubowski (Polish) +- Alexander Khodorisky (Russian) +- Martin Marqués (Spanish) +- Andrej Misovic (Slovak) +- Devrim Gunduz (Turkish) +- Libor Vanek (Czech) +- Marek Cernocký (Czech) +- Stefan Malmqvist (Swedish) +- Nicola Soranzo (Italian) +- Petri Jooste (Afrikaans) +- Sulyok Péter (Hungarian) +- Zaki Almuallim (Arabic) +- Erdenemandal Bat-Erdene (Mongolian) +- Alex Rootoff (Ukrainian) +- Jonatan (Hebrew) +- Alin Vaida (Romanian) +- Arne Eckmann (Danish) +- Francisco Cabrita (Portuguese) +- Bernat Pegueroles (Catalan) +- Fernando Wendt (Brazilan Portuguese) +- Adamantios Diamantidis (Greek) +- Marek ¿ernocký (Czech) +- Alexey Baturin (Russian UTF8) +- Adrián Chaves Fernández (Galician) + +Look & Feel + +- Davey (CSS) +- ioguix (Cappuccino theme) +- Tomasz Pala (Gotar theme) +- Felipe Figueroa (Bootstrap theme) + +Contributors + +- Dan Wilson +- Christopher Kings-Lynne +- Jehan-Guillaume (ioguix) De Rorthais +- Felix Meinhold +- Jean-Michel Poure +- Rafal Slubowski +- Brett Toolin +- Mark Gibson (Pop-up SQL window) +- Nicola Soranzo +- Oliver Meyer & Sven Kiera (Table icons link to browse table) +- Bryan Encina (SQL window improvements, bug fixes, admin) +- Dan Boren (Object comments) +- Adrian Nida (Fix time outs) +- Russell Smith +- Guillaume Lelarge +- Ian Barwick +- Javier Carlos +- Eric Kinolik +- John Jawed +- Karl O. Pinc +- Tomasz Pala +- Ivan Zolotukhin +- Kristoffer `spq` Janke +- Leonardo Augusto Sapiras (Improve phpPgAdmin ergonomy during the GSoC 2010, with ioguix as mentor) +- Julien Rouhaud, aka. rjuju (nested groups) +- Felipe Figueroa aka. amenadiel + + +Third Party Libraries + +- Highlight.php (Jacob D. Cohen of rafb.net) +- XLoadTree2 (Erik Arvidsson & Emil A Eklund of webfx.eae.net) +- jQuery (http://jquery.com/) + +Corporate Sponsors + +Project resources: +- github.com - Official project home +- Kattare Internet (http://www.kattare.com/) - Hosting the demo server +- Sourceforge.net - Hosting, Source Package Provider, Legacy project services (Bug/Feature Tracker, mailing lists, code repository) + +Ongoing contributors: + +- OmniTI ( https://omniti.com ) - sponsors developpment as Robert Treat employer + +Feature contributors: + +- SpikeSource (www.spikesource.com) - Slony support +- Google Summer of Code (http://code.google.com/soc/2006/pgsql/appinfo.html?csaid=DB096D908B948D89) - phpPgAdmin Improvements +- Google Summer of Code (http://code.google.com/soc/2007/postgres/appinfo.html?csaid=E89B3D5E2DC4170A) - Full Text Search in PostgreSQL GUI Tools +- Google Summer of Code (http://code.google.com/p/google-summer-of-code-2010-postgres/downloads/detail?name=Leonardo_Augusto_Sapiras.tar.gz) - Improve phpPgAdmin ergonomy +- Dalibo ( http://dalibo.com ) - sponsored development as Jehan-Guillaume (ioguix) de Rorthais employer + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/DEVELOPERS b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/DEVELOPERS new file mode 100644 index 00000000..b88c170f --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/DEVELOPERS @@ -0,0 +1,155 @@ +DEVELOPER INFO +-------------- + +phpPgAdmin is Free/Open Source software and contributions are welcome from +everyone. Please be sure to join the developers' mailing list: + + https://lists.sourceforge.net/lists/listinfo/phppgadmin-devel + +SOURCE REPOSITORY +----------------- + +phpPgAdmin uses git for source control management. The phpPgAdmin git repository +is hosted at github: + + https://github.com/phppgadmin/phppgadmin + +To clone the phpPgAdmin source to your development system, execute the following +command: + + git clone git://github.com/phppgadmin/phppgadmin.git + +After making changes, generate a patch using "git format-patch" and submit it +to the phpPgAdmin devel mailing list. + +Alternatively you can clone the phppgadmin repository on github and make a pull +request. For details on how to make pull requests, see: + + https://help.github.com/articles/using-pull-requests + +Please note that submitting code is considered a transfer of copyright to the +phpPgAdmin project. phpPgAdmin is made available under the GPL v2 license. + +Push access to the main phpPgAdmin git repository can be granted to developers +with a track record of useful contributions to phpPgAdmin at the discretion +of the phpPgAdmin development team. + +TIPS FOR DEVELOPERS +------------------- + +When you submit code to phpPgAdmin, we do expect it to adhere to the existing +coding standards in the source. So, instead of using your personal favourite +code layout style, please format it to look like surrounding code. +In general, we want the code to be portable, standard compliant (e.g. to W3C +(X)HTML and CSS) and independent of specific configurations of PHP, the web +server, PostgreSQL or the user browser. We also try to support as many versions +as possible of these applications. + +Test your code properly! For example, if you are developing a feature to create +domains, try naming your domain all of the following: + + * " + * ' + * \ + * words with spaces + *


+ +Don't forget to make sure your changes still pass the existing Selenium test +suite. Additionally, you should add or update the test suite as needed to +cover your new features. + +If you are adding a new class function, be sure to use the "clean", +"fieldClean", "arrayClean" and "fieldArrayClean" functions to properly escape +odd characters in user input. Examine existing functions that do similar +things to yours to get yours right. + +When writing data to the display, you should always urlencode() variables in +HREFs and htmlspecialchars() variables in forms. Rather than use action="" +attributes in HTML form elements use action="thisformname.php". This +ensures that browsers remove query strings when expanding the given +relative URL into a full URL. + +When working on database classes, always schema qualify your SQL where it is +possible with the current schema ($data->_schema) for pg73+ classes. Then don't +forget to write your method for older classes which don't support schemas. + +When working with git, always make sure to do a 'git pull' both before you +start; so you have the latest code to work with; and also again before you +create your patch; to minimize the chance of having conflicts. If you plan to +submit your code via github pull requests, we strongly recommend doing your +work in a feature specific branch. If you want to submit multiple patches, +they should all live in their own branch. Remember, smaller changes are easier +to review, approve, and merge. + + +COMMON VARIABLES +---------------- + +$data - A data connection to the current or default database. +$misc - Contains miscellaneous functions. eg. printing headers & footers, etc. +$lang - Global array containing translated strings. The strings in this array + have already been converted to HTML, so you should not + htmlspecialchars() them. +$conf - Global array of configuration options. + +WORKING WITH RECORDSETS +----------------------- + +phpPgAdmin uses the ADODB database library for all its database access. We have +also written our own wrapper around the ADODB library to make it more object +oriented (ADODB_base.pclass). + +This is the general form for looping over a recordset: + +$rs = $class->getResults(); +if (is_object($rs) && $rs->recordCount() > 0) { + while (!$rs->EOF) { + echo $rs->fields['field']; + $rs->moveNext(); + } +} +else echo "No results."; + +UPDATING LANGUAGE FILES FOR THE MONO-LINGUAL +-------------------------------------------- + +If you need to add or modify language strings for a new feature, the preferred +method is: + +* cd into lang/ subdirectory +* modify english.php file only! + +If you've done it correctly, when you create your patch, it should only have +diffs of the lang/english.php file. For more information on how the language +system works, please see the TRANSLATORS file. + + +UNDERSTANDING THE WORK/BRANCH/TAG/RELEASE PROCESS +------------------------------------------------- + +All new work for phpPgAdmin is done against the git master branch. When we feel +we are ready to do a new release, we create a branch (ex. REL_4-1). This +becomes the stable branch for all future 4.1.x releases, and any bugfixes needed +for 4.1 would go in that branch. + +When we release a new revision, we tag that at release time (REL_4-1-1), so a +checkout of any tag should give you the same files that downloading the release +would have given you. As a general rule, we do not introduce new features into +existing stable branches, only bugfixes and language updates. This means if you +want to work on new features, you should be working against the git master. +Eventually we will call for another release, and that will be branched (REL_4-2) +and the cycle will start over. + +On occasion we have created out-of-band branches, typically labeled as DEV_foo. +These were used for temporary, concurrent development of large features, and +should not be used by other developers. When development of those features is +completed, the branches get merged in as appropriate, so no further development +should occur on those branches. + +GETTING HELP +------------ + +We prefer most discussion of development to take place on the phpPgAdmin +devel mailing list, so that discussions can be archived and be searchable. +However, if you are into IRC, a couple of us hang out on #phppgadmin on +freenode, and occasionally discuss things there. diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/FAQ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/FAQ new file mode 100644 index 00000000..8f1ae6cc --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/FAQ @@ -0,0 +1,217 @@ +phpPgAdmin Frequently Asked Questions +------------------------------------- + +Installation errors +------------------- + +Q: I've installed phpPgAdmin but when I try to use it I get an error message + telling me that I have not compiled proper database support into my + PHP installation. + +A: This means that you have not properly compiled Postgres support into + your PHP. The correct configure flag to use is '--with-pgsql'. Read the + PHP manual and website for more help with this. + + Postgres support can be also compiled into PHP as a dynamic extension, + so if you have precompiled version (Linux RPM, or Windows binary), there + are still chances, that only thing you should do is to enable loading it + automagically. + + It can be done by editing your php.ini file (under Windows, usually in + C:\WINDOWS or C:\WINNT, under Linux /etc/php.ini) and uncommenting this + line: + + ;extension=php_pgsql.dll ;under Windows + ;extension=pgsql.so ;under Linux + + so it would look like that: + + extension=php_pgsql.dll ;under Windows + extension=pgsql.so ;under Linux + + In Linux distributions based on Red Hat or Fedora, PHP extensions are + automatically configured in /etc/php.d/pgsql.ini, simply install the + php-pgsql package. + + See http://www.php.net/manual/en/pgsql.setup.php for more information + on setting up Postgres support in PHP. + +Q: I get a warning like this when using phpPgAdmin on Windows: + + "Warning: session_start() [function.session-start]: + open(/tmp\sess_5a401ef1e67fb7a176a95236116fe348, O_RDWR) failed" + +A: You need to edit your PHP.INI file (usually in c:\windows) and change this + line: + + session.save_path = "/tmp" + + to: + + session.save_path = "c:\windows\temp" + + And make sure that the folder c:\windows\temp actually exists. + + +Login errors +------------ + +Q: I always get "Login failed" even though I'm _sure_ I'm using the right + username and password. + +A: There are a number of reasons why you might not be able to connect, typically + having nothing to do with phpPgAdmin itself. First check the Postgres log + on your server, it should contain a FATAL error message detailing the exact + reason why the login is failing. You will probably need to either adjust the + username or password, add LOGIN permissions to the role, or adjust your + pg_hba.conf file in your Postgres data dir; so follow the directions laid + out in the FATAL message. + + If you do not have any FATAL error messages, and you have verified that you + are looking at the properly configured logfile, then this means you are not + connecting to your database. If you are connecting via TCP/IP sockets (for + example if you have installed phpPgAdmin on a different computer than your + database) make sure that Postgres is accepting connection over TCP/IP. On + older versions of Postgres, you need to change this line in your + postgresql.conf file: + + #tcpip_socket = false + + to: + + tcpip_socket = true + + on newer versions of Postgres, this setting has been replaced by the + listen_addresses setting, so you will need to change that setting instead + (likely changing it to "*"). Be sure to restart Postgres after changing + either of these settings! + + If that still doesn't get you connected, then there is likely something + interfering between PHP and Postgres. Check to make sure that you don't have + a firewall preventing connectivity, or that you don't have some other + security setup (ie. SELinux policy) that prevents PHP from connecting. + +Q: For some users I get a "Login disallowed for security" message. + +A: Logins via phpPgAdmin with no password or certain usernames (pgsql, + postgres, root, administrator) are denied by default. Before changing this + behaviour (setting $conf['extra_login_security'] to false in the + config.inc.php file) please read the Postgres documentation about client + authentication and understand how to change Postgres's pg_hba.conf to + enable passworded local connections. + +Q: I can use any password to log in! + +A: Postgres, by default, runs in trust mode. That means that it doesn't + ask for passwords for local connections. We highly recommend that you + edit your pg_hba.conf file, and change the login type to 'md5'. Note + that if you change the 'local' login type to 'md5', then you might need + to enter a password to start Postgres. Get around this by using a + .pgpass file - explained in the Postgres documentation. + + +Other errors +------------ + +Q: When I enter non-ASCII data into the database via a form, it's inserted + as hexadecimal or Ӓ format! + +A: You have not created your database in the correct encoding. This problem + will occur when you try to enter an umlaut into an SQL_ASCII database, or + SJIS Japanese into an EUC-JP database, etc. + +Q: When I drop and re-create a table with the same name, it fails. + +A: You need to drop the sequence attached to the SERIAL column of the table + as well. Postgres 7.3 and above do this automatically. If you have + upgraded to Postgres 7.3 from an earlier version, you need to run the + contrib/adddepend script to record all dependencies. + +Q: When browsing a table, the 'edit' and 'delete' links do not appear. + +A: In order, phpPgAdmin will prefer the following as unique row identifiers: + + 1. Primary keys + 2. Unique keys (cannot be parital or expressional indexes) + 3. OID column (will require a sequential scan to update, unless you + index the OID column) + + Furthermore, any NULL values in the unique index will mean that that row + will be uneditable. Also, since OIDs can become duplicated in a table, + phpPgAdmin will alter the row, and then check to ensure that exactly one + row has been modified - otherwise rollback will occur. + + +Questions on dumps +------------------ + +Q: What happened to the database dump feature? + +A: You need to configure phpPgAdmin (in the config.inc.php file) to point + to the location of the pg_dump and pg_dumpall utilities on your web server. + Once you have done that, the database export feature will appear. + +Q: I would like to use the pg_dump integration for database and table + dumps on Windows. How do I get pg_dump.exe on Windows? + +A: To get the pg_dump utilities on Windows, you need to install Postgres 8.0 + or higher (we recommend the latest release) for Windows, available for + download from the + Postgres web site. + Once you have installed that, set the pg_dump and pg_dumpall locations + in the config.inc.php file to + 'C:\\Program Files\\Postgres\\8.0\\bin\\pg_dump.exe' and + 'C:\\Program Files\\Postgres\\8.0\\bin\\pg_dumpall.exe', or wherever you + installed them. + +Q: Why can't I reload the SQL script I dumped in the SQL window? + +A: The following limitations currently exist in SQL script execution: + + * Only uploaded SQL scripts can contain COPY commands and for + this to work, you must have PHP 4.2 or higher. + + * 'psql' commands such as '\connect' will not work at all. + + * Multiline SQL statements will not work, eg: + + CREATE TABLE example ( + a INTEGER + ); + + * You cannot change the current database or current user during + the execution of the script. + + We do intend to work on some of these limitations in the future, but + some of them are Postgres restrictions and we recommend using the + 'psql' utility to restore your full SQL dumps. + + +Other questions +--------------- + +Q: When inserting a row, what does the 'Value' or 'Expression' box mean? + +A: Choosing 'Expression' means that you can use functions, operators, other + field names, etc. in your value - you need to properly quote any literal + values yourself. 'Value' on the other hand, means that no matter what you + enter as the value, it will be inserted as-is into the database. + +Q: Why is there never any information on the 'Info' page of a table? + +A: The Info page will show you what other tables have foreign keys to the + current table and some data from the Postgres statistics collector. + In older versions of Postgres, the stats collector is not enabled by default. + To enable it, look in your postgresql.conf file for the stats_* options. + Just make them all 'true' and restart Postgres. + +Q: Why can't I download data from queries executed in the SQL window? + +A: You need to check the 'Paginate results' option to allow downloads. + +Q: I would like to help out with the development of phpPgAdmin. How should I + proceed? + +A: We really would like your help! Please read the DEVELOPERS and TRANSLATORS + files. + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/HISTORY b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/HISTORY new file mode 100644 index 00000000..e1e490b4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/HISTORY @@ -0,0 +1,818 @@ +phpPgAdmin History +------------------ + +Version 5.6 +----------- + +Released: 12th November, 2018 + +Features +* Add support for PostgreSQL 9.3, 9.4, 9.5, 9.6, 10, 11 +* Development support for PostgreSQL 12 +* Add support for brows/select navigation tabs (firzen) +* Add new theme, "bootstrap" (amenadiel) +* Improved support for json/jsonb + +Bugs +* Fix bug in Turkish translation which caused failed ajax responses +* Account for Blocked field in admin processes Selenium test +* Properly handle column comments +* Fix background css issue +* Additional language updates + +Incompatabilities +* Dropped testing of pre-9.3 versions of Postgres, which are now EOL + + +Version 5.1 +----------- + +Released: 14th April 2013 + +Features +* Full support for PostgreSQL 9.1 and 9.2 +* New plugin architecture, including addition of several new hooks (asleonardo, ioguix) +* Support nested groups of servers (Julien Rouhaud & ioguix) +* Expanded test coverage in Selenium test suite +* Highlight referencing fields on hovering Foriegn Key values when browsing tables (asleonardo) +* Simplified translation system implementation (ioguix) +* Don't show cancel/kill options in process page to non-superusers +* Add download ability from the History window (ioguix) +* User queries now paginate by default + +Bugs +* Fix several bugs with bytea support, including possible data corruption bugs when updating rows that have bytea fields +* Numeruous fixes for running under PHP Strict Standards +* Fix an issue with autocompletion of text based Foreign Keys +* Fix a bug when browsing tables with no unique key + +Translations +* Lithuanian (artvras) + +Incompatabilities +* We have stopped testing against Postgres versions < 8.4, which are EOL +* phpPgAdmin core is now UTF-8 only + + +Version 5.0 +----------- + +Released: 29th November 2010 + +Features +* Support for PostgreSQL 8.4 and 9.0 +* Support for database level collation for 8.4+ +* Support for schema level export +* Add ability to alter schema ownership +* Clean up domain support and improve interface +* Add support for commenting on functions +* Allow user to rename role/users and set new passwords at the same time +* Greatly enhanced Full-Text-Search capabilities (ioguix, Loomis_K) +* Overhauled Selenium Test suite to support multiple database versions +* Optimized application graphics (Limo Driver) +* Support for Column Level Privileges +* Allow users to specify a template database at database creation time +* Support killing processes +* Add ability to create indexes concurrently +* Much better support of autovacuum configuration +* Add an admin page for table level +* Refactored autocompletion: + * fix support for cross-schema objects + * support multi-field FK + * support for pagination of values in the auto-complete list +* Allow user to logicaly group their server under custom named node in the browser tree +* New themes (Cappuccino and Gotar) and a theme switcher on the introduction page +* Auto refresh Locks page +* Auto refresh Processes page +* Link in the bottom of the page to go to top of page +* Browsing on Foreign Keys (When browsing a table, clicking on a FK value, jump to the PK row) + + +Bugs +* Fix problems with query tracking on overly long queries +* Ensure pg_dump paths are valid +* Fix multiple bugs about quoting and escaping database objects names with special chars +* Fix multiple bugs in the browser tree +* Fix multiple bugs on the SQL and script file import form +* Three security fix about code injection +* Don't allow inserting on a table without fields +* Some fix about commenting databases +* removed deprecated functions from PHP 5.3 +* Lot of code cleanup +* Many other small minor bugs found on our way +* Fix the operator property page + +Translations +* Czech (Marek Cernocky) +* Greek (Adamantios Diamantidis) +* Brazillian Portuguese (Fernando Wendt) +* Galician (Adrián Chaves Fernández) + +Incompatabilities +* No longer support PHP < 5.0 +* No longer support Postgres < 7.4 + + +Version 4.2 +----------- + +Features +* Add Analyze to Table Level Actions (ioguix) +* Add support for multiple actions on main pages (ioguix, Robert Treat) +* Added favicon for Mozilla and a backwards compatible version for IE. +* Allow browsers to save different usernames and passwords for different servers. +* Pagination selection available for reports +* You can configure reports db, schema and table names +* Add support for creating a table using an exsting one (ioguix) +* Auto-expand a node in the tree browser if there are no other nodes (Tomasz Pala) +* Add column about fields constraints type + links in table properties page (ioguix) +* Support for built-in Full Text Search (Ivan Zolotukhin) +* Add alter name, owner & comment on views (ioguix) +* Add column about called procedure + links to their definition in the triggers + properties page (ioguix) +* Add Support for Enum type creation (ioguix,xzilla) +* Add alter name, owner, comment and properties for sequences (ioguix) +* Add function costing options (xzilla) +* Add alter owner & schema on function (xzilla) +* Add a popup window for the session requests history (karl, ioguix) +* Add alter table, view, sequence schema (ioguix) + +Bugs +* Fix inability to assign a field type/domain of a different schema +* Can't edit a report and set its comment to empty +* Fix PHP5 Strict mode complaints +* Fix IN/NOT IN to accept text input lists 'a','b' +* Fix bytea doesn't display as NULL when NULL +* Schema qualifing every object to avoid non wanted behaviour about users' rights + and schema_path +* Remove shared credentials when logging out of single server, to prevent automatic re-login +* Improved SSL connection handling, fix problems with connections from older php builds +* Fix bug with long role name truncation +* Fix bug with DELETE FROM when dropping a row (spq) +* Fix problems when deleteing PUBLIC schema +* Fix several bugs in aggregate support +* Improve autocompletion support +* Tighten up use of global scope variables + +Translations +* utf traditional chinese (Kuo Chaoyi) +* utf simplified chinese (Kuo Chaoyi) +* Italian (Nicola Soranzo) +* Catalan (Bernat Pegueroles) +* French (ioguix) +* German (Albe Laurenz, spq) +* Japanese (Tadashi Jokagi) +* Hungarian (Sulyok Peti) + +Version 4.1.3 +------------- + +Bugs +* Eliminate use of $_SERVER['PHP_SELF']. This fixes a regression in 4.1.2 for + non-mainstream locales (including SQL_ASCII) +* Validate client supplied server against entries in config.inc.php +* Fix undefined variable when altering a field in a table on PostgreSQL < 8.0 + +Version 4.1.2 +------------- + +Bugs +* Fix inability to assign a field type/domain of a different schema +* Fix PHP5 Strict mode complaints +* Fix IN/NOT IN to accept text input lists 'a','b'. +* Fix bytea doesn't display as NULL when NULL +* Fix bug in view creation wizard +* Fix XSS vulnerability: + http://www.securityfocus.com/bid/24115/ + Escape HTML special characters before using $_SERVER['PHP_SELF'] + +Version 4.1.1 +------------- + +Bugs +* Fix problem where failed update would report as duplicate update error and + fail to return edit screen +* Fix error when using $conf[owned_only] on 8.1 & 8.2 +* Fix error displaying schema names for parents of inherited tables +* Clean up non-standard escape warnings for PostgreSQL 8.2 +* Fix improper text quoting for droping roles and aggregates +* Fix bug when dumping mixed case table names in PostgreSQL 8.2 + +Version 4.1 +----------- + +Features +* New icons by Niko , from the graphics repository on pgFoundry. +* Added icons to bread crumb trail and tabs. +* Send encrypted passwords over the wire wherever possible. +* Alter sequence, nextval and setval (Guillaume) +* Auto-select 'WITHOUT OIDS' if 'default_with_oids' setting is false (Guillaume) +* Autovacuum configuration support (Robert Treat) +* Basic ROLE support (Chris Kings-Lynne, Javier Carlos) +* Add support for SSL connections (Eric Kinolik) +* Display content of pg_locks view (Javier Carlos) +* Add labels for checkboxes/radio buttons for improved usability (Guillaume) +* Display Prepared Transactions (Javier Carlos) +* Re-enable table browsing from tree icons (ioguix) +* Add Support For IN/OUT Parameters (John Jawed) +* Add column level information into the tree browser (ioguix) +* Promote column level interaction into its own page (ioguix) +* Add automatic lookup of foreign key values in insert/update fields (John Jawed) +* Add ability to create/drop/alter custom aggregates (Javier Carlos) +* Add enable/disable trigger (John Jawed) +* Add global comments for databases and tablespaces + +Translations +* Catalan from Bernat +* Romanian from Alin Vaida + +Version 4.0 +----------- + +Features +* Slony replication support (Thanks to sponsorship from SpikeSource) +* Allow current database to be at the top +* Allow base URL of PostgreSQL documentation to be configured +* Allow variable size textarea when editing values (Juergen Weigert) +* Allow SQL script upload to parse arbitrary SQL, including multiline + SQL statements. Improve output to show every command as its executed + and SELECT results. +* Add rudimentary support for PostgreSQL 8.1 and 8.2 +* primary key and unique key at table creation (Andreas Huber) +* Add row|statement level options to create trigger for >= 7.4 (Robert Treat) +* Allow altering name (for >= 7.4) and owner (for >= 8.0) of a database (Bryan Encina) +* Allow login to several servers simultaneously +* Rearrange frame layout to suit multi-server support +* New browser tree with dynamically loading branches + (Using XLoadTree2 from http://webfx.eae.net/) +* Allow language change from the intro page at any time +* Avoid getting and setting encoding queries if possible +* Avoid version query in PHP 5 / PostgreSQL 7.4+ +* Avoid query for superuser status in PHP 5 / PostgreSQL 7.4+ +* Put PostgreSQL 7.4+ in read only mode for pagination of results + to avoid executing selects that have write side effects. +* Allow re-using username and password for all servers - saves re-entering + username and password for every server in a pool. +* Make default language 'auto' indicating auto detect. If a language is + deliberately specifed, then that will always be used and no detection will + occur. +* ADOdb library updated to version 4.65 + +Bugs +* Tree Icons are displayed middle instead of top +* Ensure login frame is always at top level (Russell Smith) +* Fix non-ASCII characters inserted in Unicode databases as HTML entities with + non-UTF8 web servers (Markus Bertheau) +* Fix export to work with release candidates and beta releases as well as finals + (Russell Smith) +* Fix port selection for local connections +* Fix timeouts on long running operations (Adrian Nida) +* Allow Multiline character and character varying editing and inserting +* Add automatic browser language selection for all languages +* Stop duplicate insert on re-POST of data +* Fix bug with exporting schema for servers < 7.3 +* Fix opclasses on 7.2 and below +* Fix listing of opaque functions in 7.2 +* Actually fix PHP 4.4.0's new strict references + +Translations +* Japanese from Tadashi Jokagi +* Danish from Arne Eckmann +* Arabic from Zaki +* Romanian from Alin +* Afrikaans from Petri +* Polish from Rafal (utf-8 encoding) +* Slovak from Andrej +* German from Markus +* Spanish From Martin +* Hungarian from Sulyok +* Turkish from Devrim + +Version 3.5.6 +------------- + +Bugs +* Actually fix PHP 4.4.0's new strict references + +Version 3.5.5 +------------- + +Bugs +* Fix for PHP 4.4.0's new strict references +* Small improvement to Opera browser detection in the tree +* Fix listing of opaque functions in 7.2 +* Fix listing of opclasses and functions pre 7.3 + +Version 3.5.4 +------------- + +Bugs +* Fix security hole in include() of language file: + http://secunia.com/advisories/15941/ + Check now requires that the language filename be in the list + of known allowed filenames. +* Fix that functions returning cstring were not being listed +* Make parsing of PostgreSQL 1-dimensional arrays correct. Makes + named function parameter use more reliable. +* Fix downloading of the results of multiline queries. + +Version 3.5.3 +------------- + +Bugs +* Fix using schema enabled dump on non-schema enabled backend +* Don't try setting no timeout when in safe mode +* Reload browser after executing arbitrary SQL +* Fix browser in RTL languages +* Fix inability to drop database using the drop link +* Fix last internal oid value for PostgreSQL 8.0 +* Fix (again) dumping on v8 for windows, exclude dumping some objects. + +Translations +* Portuguese from Francisco + +Version 3.5.2 +------------- + +Bugs +* Fix export to work with release candidates and beta releases as well as finals + (Russell Smith) +* Fix port selection for local connections (Russell Smith) +* Fix timeouts on long running operations (Adrian Nida) +* Allow Multiline character and character varying editing and inserting +* Do browser language detection for all languages + +Translations +* Japanese from Tadashi +* Danish from Arne + +Version 3.5.1 +------------- + +Bugs +* Support 8.0beta5 schema tablespace changes +* Help link fixes +* Estimated row count in 7.0 and 7.1 fixes +* Priviliges nav fix +* Function privileges fix +* Search path fix +* pg_dump on win32 8.0 native fix + +Translations +* Romanian from Alin +* Italian updates from Nicola + +Version 3.5 +----------- + +Features +* Context-sensitive online help system +* Use language preferencies from browser (Markus Bertheau, Nicola Soranzo) +* Tablespace support for 8.0 +* Support cancelling backend processes in 8.0 +* Allow setting privileges on databases +* Allow setting schema search path in SQL window +* Allow filtering find results by object type +* Show function arguments in find results +* Support 8.0's named function arguments +* "Sticky" navigation. phpPgAdmin will now remember while tab you are + looking at (eg. 'Indexes') when you change which table you are viewing. +* New fast navigation bar. A breadcrumb style navigation bar for fast + jumping between areas. +* Much improved grant/revoke feature +* Allow creating and viewing composite types +* pg_dumpall integration. Now you can download the entire cluster via + phpPgAdmin. +* Show line numbers when viewing functions +* Syntax highlighting for PL/SQL, PL/PgSQL, PL/PHP, PL/Ruby, PL/Java, + PL/J, PL/Python and PL/Perl functions, thanks to Jacob D. Cohen's + BSD-licensed highlighting code on rafb.net +* Add page navigation links at the bottom as well as the top of the page + when browsing results. +* Support for 8.0's alter column type +* Support for 8.0's add columns with defaults and not null + +Translations +* Romanian from Alin +* Arabic from Zaki +* Japanese from Tadashi +* Spanish from Robert & Martin +* Mongolian from Erdenemandal +* Ukrainian from Alex Rootoff +* Hebrew from jonatan +* Hungarian from Sulyok +* French from Pascal +* Afrikaans from Petri +* Turkish from Devrim +* Slovak from Andrej +* German from Markus +* Italian from Nicola +* Polish from Rafal + +Bugs +* Fix that non-Auto mode import didn't work (Adrian Nida) +* Fix inability to drop constraints when using a non-english translation +* Work around MSIE's failure to handle downloads in SSL mode +* Allow insert, update, delete, references and trigger to be granted + and revoked on views. + +Version 3.4.1 +------------- + +Bugs +* Fix export of mixed case tables pre 7.4 +* Fix table export problems pre 7.3 +* Fix join clause created by view wizard for pre 7.3 +* Fix reindex of mixed case indexes +* Show domains in type lists in appropriate places +* Fix for multiline CDATA parsing in XML import +* Fix missing _schema notice in reports + +Version 3.4 +----------- + +Features +* Add CACHE and CYCLE parameters in sequence creation +* View, add, edit and delete comments on tables, views, schemas, + aggregates, conversions, operators, functions, types, + opclasses, sequences and columns (Dan Boren & ChrisKL) +* Add config file option for turning off the display of comments +* Allow creating array columns in tables +* Allow adding array columns to tables +* Allow creating domains with type length and arrays +* Show domain base type and comment in domains list +* Allow import of CSV, Tabbed and XML data. "Auto" mode chooses + import mode based on the file extension. +* Allow upload and execution of _basic_ SQL scripts +* More admin features available: vacuum, analyze, cluster all and reindex + (with all options) (Bryan Encina) +* Fix SQL popup window to reload when the database is changed so + that the correct page encoding is used. +* Create view wizard (Bryan Encina) +* Allow specification of MATCH, DEFERRABLE and INITIALLY DEFERRED on + foreign keys. +* Automatically uncheck the NULL checkbox when data is typed in the value + field while editing data. +* Show query runtime when executing arbitrary SQL +* Allow renaming functions when backend supports it +* Views are now more like tables. They are listed in the browser, + you can view the virtual columns of the view and its column defaults. + Columns in view can also be renamed and have defaults set. +* Allow viewing, dropping and creation of rules on views. +* Support for 8.0-dev ALTER COLUMN TYPE, adding of SERIAL and BIGSERIAL + columns, adding NOT NULL columns and adding columns with defaults. + +Bugs +* Fix pg_dump output for PostgreSQL 7.0.x and 7.1.x +* In 7.4 pg_dump, specify schema when dumping tables +* Fix bug in displaying array types in 7.0.x +* Fix bug where views appeared as tables in 7.0.x search results +* Fix bug where find object SQL on < 7.2 was broken +* Fix Find for domain constraints +* Fix popup SQL window so that two different phpPgAdmin instances should + not want to use the same pop-up. +* Fix create table if you don't supply as many fields as you originally + specified. +* Fix schema support for views + +Translations +* Trad. Chinese from Chih-Hsin Lee +* Italian from Nicola +* Spanish from Martin +* Slovak from Andrej +* German from Markus +* Turkish from Devrim +* Hungarian from Sulyok +* French from Pascal +* Polish from Rafal +* Russian from Alex + +Version 3.3.1 +------------- + +Bugs +* Fix table stats for <= 7.2 + +Translations +* Spanish from Martin + +Version 3.3 +----------- + +Features +* Database dump feature, which uses pg_dump +* Large speed improvements by reducing number of database + connections and using external style sheet. +* SQL pop-up window now defaults to the current database +* Display aggregates and operator classes +* Integration with the PostgreSQL statistics collector. See + table and index performance and usage information. +* Display user session defaults for PostgreSQL >= 7.3 +* Rename user feature for PostgreSQL >= 7.4 +* Create functions returning arrays and table types +* Allow editing Select results by oid +* Allow pagination of queries entered in the SQL box +* Allow EXPLAIN ANALYZE of SQL queries (in both SQL boxes) +* Default cursor conveniently in SQL box and Find + +Bugs +* Object browser fixed for databases with no schemas +* Properly detect that reports database is missing +* Fix for alter column on PostgreSQL 7.1 +* phpPgAdmin now works without '.' in the include_path +* Can now remove expire dates on user accounts +* Properties of mixed case named views work in 7.4 + +Translations +* Spanish from Martin Marques +* Japanese from Tadashi Jokagi +* Swedish from Stefan Malmqvist +* Slovak from Andrej Misovik +* Hungarian from Sulyok Peter +* Trad. Chinese from Chih-Hsin Lee +* Italian from Nicola Soranzo +* Afrikaans from Petri Jooste +* Turkish from Devrim Gunduz +* German from Markus Bertheau +* Czech from Libor Vanek +* Russian from Alex Khodorivsky + +Version 3.2.1 +------------- + +Bugs +* Trailing newline problem in chinese-sim translation fixed + +Translations +* French from Pascal +* Russian from Step + +Version 3.2 +----------- + +Features +* PostgreSQL 8.0 CVS support +* Option to dump table structure, data or structure and data +* Set datestyle and extra_float_digits when dumping data +* Results of table browse, table select, view browsing and report browsing + can now ALL be sorted by column +* Result rows of table selects can now be edited and deleted +* Extra login security to prevent logging into servers as postgres and + no password - a VERY common newbie error. +* Cluster indexes and indexed constraints (with analyze) +* Display clustered status of indexes and indexed constraints +* Table info - shows tables that reference the table, parent tables, + and child tables. +* Choice of operator when performing a Select +* 'Select All' feature of table selects now available on view + selects. +* Removed any trace of MySQL support +* Show casts +* Show conversions +* Show languages +* Make table icon link to browse table +* New show_advanced option that allows the hiding or display of + "advanced" objects such as conversions, types, operators, casts and + languages. +* Find Object feature can now find conversions, languages, domains, + constraints, indexes, rules and triggers. +* Better language Makefile for translators +* The SQL box now remembers your query when you click 'Back'. + +Bugs +* Added legal DOCTYPE +* Allow creating foreign keys to tables not in current schema +* Always add brackets around CHECK () constraints +* Never display an index in both Indexes and Constraints +* BIGSERIAL missing from PostgreSQL 7.2 +* Types lengths (eg. varchar(255)) weren't being displayed properly + in PostgreSQL 7.0.x +* Resetting sequence on 7.1+ now restarts at 1, not 2 +* Remove deprecated column default 'now' from SQL script +* Properly escape pg_ in internal queries + +Translations +* Afrikaans from Petri Jooste +* Hungarian from Sulyok Péter +* German update from Markus Bertheau +* Trad. Chinese from Chih-Hsin Lee +* Hungarian from Peti +* Spanish update from Martin Marques +* Slovak update from Andrej Misovic +* Turkish update from Devrim +* Swedish update from Stefan +* Italian update from Nicola + +Version 3.1 +----------- + +Bug Fixes: +* Table browsing for 7.4 fixed +* Synch script for translators disabled due to bugginess. If you want + to use it, just comment out the warning lines from the script itself. +* Change HTML download to XHTML and make it a 100% conforming document, with DTD +* Alter XML format to allow future features + +Translations: +* Trad. Chinese +* Dutch +* Spanish +* Swedish +* Turkish +* French +* Japanese + +Version 3.1-rc-1 +---------------- + +Bug Fixes +* Table browsing for != 7.3 +* SQL window improvements +* Translation improvements + +Version 3.1-beta-1 +------------------ + +Features: +* Add first & last links to nav. Double number of pages shown. +* Allow granting privileges WITH GRANT OPTION for 7.4 +* Allow revoking GRANT OPTION with CASCADE option for 7.4 +* Display new PostgreSQL 7.4 grant options and grantor in privileges +* Find object feature +* Support for domains in 7.3 and domain constraints and alter domain in 7.4 +* Add/drop users to/from groups +* Alter (rename) triggers +* Pop-up SQL window from Mark Gibson +* Superusers can always see all databases +* Default database encoding for languages +* Convert our images to PNG format +* Allow creating tables WITHOUT OIDS +* Show boolean values as TRUE or FALSE when viewing data +* Allow renaming table and changing table owner +* Refresh feature on table browse +* Support better formatted view dumps in 7.4 +* When browsing data, numeric types are aligned right +* Ability to create unique and partial indexes +* View and edit table comments +* Changed XML format significantly. Now doesn't use field names as + tag names, outputs column type information, and is in correct XML format! +* Save result sets as views and reports in most cases +* Download the results of selects and reports +* Tick all box on Select feature +* Export in HTML format +* Allow listing of operators +* Add a robots.txt file to prevent search engine indexation +* Can now safely edit row based on OID. Guards are in place against duplicate OIDs. +* Works properly if you have cookies disabled + +Bug Fixes: +* Lots of NULL value in table dump fixes (XML format changed slightly) +* Boolean default values and general boolean field handling fixes +* Support zero column tables +* Correctly display the contents of bytea fields +* Consider information_schema to be a system object +* Remember fields if index creation fails +* Fix saving and loading function volatility +* Don't list domains under types +* Lots of reports fixes (titles, page reloads, etc.) +* Selecting for NULL values in Select feature + +Translations: +* Italian translation update from Nicola Soranzo +* German update from Markus Bertheau +* Spanish update from Martin Marques +* Trad. Chinese update from Chih-Hsin Lee +* Russian update from Step +* Slovak update from Andrej +* Polish update from Rafal +* Swedish translation from Stefan Malqvist +* Turkish update from Devrim Gunduz +* German update from Markus Bertheau +* Traditional Chinese update from Chih-Hsin Lee +* Spanish update from Martin + +Version 3.0.1 +------------- + +Bug Fixes +* Lots of NULL value in table dump fixes (XML format changed slightly) +* Support zero column tables +* Correctly display the contents of bytea fields +* Error in ADODB_base.php +* Fix saving and loading function volatility +* Don't list domains under types + +Version 3.0 +----------- + +* German update from Markus Bertheau +* Russian update from Alexander Khodorivsky + +Version 3.0-rc-2 +---------------- + +* Slovak update from Andrej Misovic +* Japanese update from Tadashi Jokagi +* Added 'defaultdb' per-connection variable + for installations where connection to template1 + is disabled. +* Removed uses of call time pass by reference, + since it is a deprecated feature of PHP. + +Version 3.0-rc-1 +---------------- + +* Fix drop database reload browser bug +* Look & Feel upgrade from Davey +* Value & expression on edit row +* Chinese update from Chih-Hsin Lee +* Fixed support for functions and sequences + containing bizarre characters + +Version 3.0-beta-1 +------------------- + +* Cascade drop on columns and constraints +* Czech translation +* Preserve spaces when displaying data +* Greatly improved PostgreSQL 7.2, 7.1 and 7.0 support +* Italian translation +* Show database version in top bar +* Many features useful for PostgreSQL hosting: + - Hide reports + - Filter for owned reports + - Hide admin for non-super users + - Easy for a user to change their own password + - Enforceable minimum password length +* Switched to PEAR's HTML_TreeMenu to avoid license issue +* Function editor can handle setof functions, and all + function properties for volatility, etc. +* Manage permissions on functions +* Massive table browsing improvements: + - Sort ascending and descending by clicking + on field name + - Trim long strings. Use 'expand' and 'collapse' to + see full strings or trimmed strings. +* Revoke on objects. Grant or revoke to multiple groups + and users at once. +* Brazilian Portuguese translation from Angelo Rigo + +Version 3.0.0-dev-4 +------------------- + +* Sort on a column when browsing a table +* Slovak translation +* Turkish translation +* German translation +* Reload browser after create/drop of database, schemas and tables +* Select on views +* Add foreign key constraint, with actions +* Cascade drop on all objects + +Version 3.0.0-dev-3 +------------------- + +* French translation +* Russian translations +* Japanese translations +* Trigger definitions +* ADODB upgrade +* Allow editing of non-null unique + +Version 3.0.0-dev-2 +------------------- + +* Language files now use an array of strings +* Almost complete Chinese translation +* Create sequence +* Create trigger +* Create index +* Add check constraint +* Lots of small fixes +* Add column + +Version 3.0.0-dev-1 +------------------- + +* Renamed to phpPgAdmin from WebDB +* Heaps of other stuff + +Version 0.6 - 24-Dec-2002 +------------------------- + +* Support short_tags off +* Fix browsing tables, pagination, etc. +* Fix all error handling +* Fix problems with apostrophes in database, usernames or passwords + +Version 0.5 - 20-Dec-2002 +------------------------- + +* Initial public release +* Still many problems making it unsuitable for production. + +Version 0.1 - Early 2002 +------------------------ + +* Initial development version + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/INSTALL b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/INSTALL new file mode 100644 index 00000000..0375b3ae --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/INSTALL @@ -0,0 +1,73 @@ +phpPgAdmin Installation Guide +----------------------------- + +1. Unpack your download + + If you've downloaded a tar.gz package, execute from a terminal: + + gunzip phpPgAdmin-*.tar.gz + tar -xvf phpPgAdmin-*.tar + + Else, if you've downloaded a tar.bz2 package, execute from a terminal: + + bunzip2 phpPgAdmin-*.tar.bz2 + tar -xvf phpPgAdmin-*.tar + + Else, if you've downloaded a zip package, execute from a terminal: + + unzip phpPgAdmin-*.zip + +2. Configure phpPgAdmin + + edit phpPgAdmin/conf/config.inc.php + + If you mess up the configuration file, you can recover it from the + config.inc.php-dist file. + +3. If you run your PHP installation in safe mode, in order that the database + dump feature can work correctly, you need to set the 'safe_mode_allowed_env_vars' + php.ini variable to include the PGPASSWORD and PGUSER environmental variables + and the safe_mode_exec_dir to include /usr/bin (or wherever the pg_dump + binaries are found). + + eg. safe_mode_allowed_env_vars = PHP_,PG + safe_mode_exec_dir = /usr/bin + + Given that you usually don't want to allow everything in /usr/bin to + be executed, you might want to copy the pg_dump and pg_dumpall utilities + to a directory by themselves. + + Also, you will need to ensure that your 'pg_dump' and 'pg_dumpall' utilities + are executable by the PHP process, if you want dump support in phpPgAdmin. + + Lastly, if you run phpPgAdmin in safe mode, very long running imports, + exports and transactions may time out and be aborted. + +4. Ensure the statistics collector is enabled in PostgreSQL. phpPgAdmin will + display table, index performance, and usage statistics if you have enabled + the PostgreSQL statistics collector. While this is normally enabled by + default, to ensure it is running, make sure the following lines in your + postgresql.conf are uncommented: + + track_activities + track_counts + +5. Browse to the phpPgAdmin installation using a web browser. You might + need cookies enabled for phpPgAdmin to work. + +6. IMPORTANT - SECURITY + + PostgreSQL by default does not require you to use a password to log in. + We STRONGLY recommend that you enable md5 passwords for local connections + in your pg_hba.conf, and set a password for the default superuser account. + + Due to the large number of phpPgAdmin installations that have not set + passwords on local connections, there is now a configuration file + option called 'extra_login_security', which is TRUE by default. While + this option is enabled, you will be unable to log in to phpPgAdmin as + the 'root', 'administrator', 'pgsql' or 'postgres' users and empty passwords + will not work. + + Once you are certain you have properly secured your database server, you + can then disable 'extra_login_security' so that you can log in as your + database administrator using the administrator password. diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/LICENSE b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/LICENSE new file mode 100644 index 00000000..d2efe073 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/LICENSE @@ -0,0 +1,12 @@ +Copyright (c) 2002, 2003, 2004, 2005 The phpPgAdmin Project + +This program is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2 of the License, or +(at your option) any later version. +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License +for more details. + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TODO b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TODO new file mode 100644 index 00000000..dae0774c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TODO @@ -0,0 +1,242 @@ +PHPPGADMIN TODO LIST FOR DEVELOPERS +----------------------------------- + +phpPgAdmin is an open source project which means that if you see something on +this list that you would like to implement, just send us a patch. You can find +our project page here: + + https://github.com/phppgadmin/phppgadmin + +An item is marked 'claimed' when a username in brackets is put after the TODO +item. If you want to work a claimed item, please contact the developers list. + +An item is marked with a '-' if it has been completed. + +Cluster +------- +* Allow reading of postgresql.conf and pg_hba.conf per pg_read_file() in 8.1 +* Support pg_reload_conf(), pg_rotate_logfile() 8.1 commands +* Add support for default db to connect to on login page (we had several users complaining about that lately) + + +Export +------ + +* Switch to SPARQL format: + http://www.w3.org/TR/2005/WD-rdf-sparql-XMLres-20050801/ + + Actually...SQL/XML is maybe better. + +Import +------ + +* Allow import of data via compressed (bzip/gzip/zip) files + +Users +----- + +* user variables (eg. ALTER USER SET .. TO ...) + + +Groups +------ + + +Roles +----- + + +Permissions +----------- + +* Grant ... on all tables, views, ... to user, group, public + + +Databases +--------- + +* Add alter database variables +* Add database stats +* REASSIGN OWNED & DROP OWNED support for 8.2+ + - http://www.postgresql.org/docs/8.2/interactive/sql-reassign-owned.html + - http://www.postgresql.org/docs/8.2/interactive/sql-drop-owned.html + + +Schemas +------- + + +Large Objects +------------- + +* Add support for large objects + (review patch from Dmitry Koterov https://github.com/DmitryKoterov/phppgadmin/commit/3072e666bd2b291feb91823b41f1fdb8ec7f492d ) + +Tables +------ + +* Rewrite WITHOUT OIDs with more natural WITH OIDS +* Allow FKs during create table (Jawed) +* When adding a column or creating a table, prevent size on non-size types (eg. integer(2)). You can find these by looking at format_type in the postgresql source code. +* Add WITH storage_parameter option to create table [8.2] +* Add last vacuum and analyze information from statistics tables [8.2] +* Restrict operators (from $selectOps array) to appropriate types (ie. no LIKE for int4 fields) +* Alter column should handle types with implicit cast types distinctly from those requiring a USING clause +* Where ENUM types are an option, restrict choice to enum values [8.3] + +Columns +------- + +* Add column constraints during creation and altering of columns + + +Views +----- + +* Support temporary views per 8.1? +* Support updateable views, see http://gerrybthunkings.blogspot.com/2010/01/how-should-postgresql-pgadmin-iii-deal.html +* Support Materialized Views + +Sequences +--------- + + +Functions +--------- + +* Remove options for OUT/INOUT params in older servers +* Clean up javascript html spec warnings +* GUC settings [8.3] +* Default param values + +Indexes +------- + +* Support 8.1 Reindex System commands +* Expressional indexes +* Create Index Asc/Desc, Nulls First/Last [8.3] + + +Types +----- + +* Suppres psuedo-type options in type list for creating composite types. (done ?) + + +Operators +--------- + +* Create +* Create/Alter/Drop Operator Family + + +Operator Classes +---------------- + +* Create + + +Triggers +-------- + +* Allow functions from other schemas. +* Support replica trigger modes (8.3) + + +Aggregates +---------- + +* Allow for multi-column aggregates [8.2] +* Rewrite the aggregate edition page ! It is using input tetxt everywhere presently, even for owner and schéma ! + + +Languages +--------- + +* Drop +* Create +* Alter owner [8.3] +* Alter name [8.3] + + +Domains +------- + +* Alter DOMAIN SET SCHEMA support + +Conversions +----------- + +* Properties +* Drop +* Create + + +Casts +----- + +* Properties +* Drop +* Create + + +Full Text Search (8.3) +---------------------- + +* Create/Alter/Drop parser +* Alter Owner + + +Miscellaneous +------------- + +* Audit for PHP 5.3.x compatability +* Support 8.1 standard compliant strings (E'') +* Support per-database connection limits per 8.1 +* Put a 'What's blocking this query' on Processes view +* Show prepared statements on database view [8.2] +* Show cursors on database view [8.2] +* Show NOTICES on queries in SQL window/file +* Printable view of things +* Show comments for all objects (Dan Boren) +* Allow setting/dropping comments for all objects (Dan Boren) +* Show owner for all objects +* Allow changing owner for objects that have this feature [7.4+ generally] +* Add CASCADE option to Truncate [8.2] +* Add ONLY option to Truncate [8.4] +* Add information about synch tool to TRANSLATORS +* Translated FAQ +* Pull FAQ/HISTORY/CREDITS/etc... from CVS for website. +* Add support for csvlogs [8.3] +* Add executed file scripts in history + +Exotic +------ + +* Pivot reports (ADODB has a feature for this) +* Parameterized reports (use prepared queries) +* Full web accessability conformance + +Principles +---------- + +* register_globals off support +* maximum error_reporting support - enforces code quality, reduces bugs and + improves security +* PHP 5.0 features used +* No HTML font, colour, layout tags. Use CSS for everything +* One day we should make it all XHTML +* everything properly escaped - prevent sql injection and cross-site scripting + probs +* everything properly schema qualified +* Support Postgres 8.4 and upwards +* psql -E is a cool way of seeing how to do schema queries +* Checking out older versions of describe.c in src/bin/psql in the postgres + distro is a good way of seeing how to query older versions of postgres for + schema information +* Put functions in the highest class possible. For instance, simple selects + should be in Postgres, whereas something that works for < 8.2 should be in the + 8.1 class. This will minimise bugs and duplicated code. +* Adhere to current coding standards +* Avoid using global variables if possible + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TRANSLATORS b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TRANSLATORS new file mode 100644 index 00000000..d763c301 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/TRANSLATORS @@ -0,0 +1,55 @@ +Translator Info +--------------- + +If you like phpPgAdmin, then why not translate it into your native language? + +There are quite a large number of strings to be translated. Partial +translations are better than no translations at all, and a rough guide is that +the strings are in the order from most important to least important in the +language file. You can ask the developers list if you don't know what a +certain string means. + +We tried keeping translation easy in phpPgAdmin by using ONLY the UTF-8 charset. +Make sure to always work on UTF-8 files when creating a new translation or +editing an existing one. + +To Create a new translation: + +1. Go to the lang/ subdirectory + +2. Copy english.php to yourlanguage.php + +3. Update the comment at the top of the file. Put yourself as the language + maintainer. Edit the 'applang' variable and put your language's name in it, + in your language. + Edit the 'applocale' and put your language code according to the standart: + http://www.ietf.org/rfc/rfc1766.txt + + Basicaly, you just need to put your language code [1] and optionnaly country + code [2] separated by a '-'. As instance for french canadian, it is: fr-CA + [1]: http://www.w3.org/WAI/ER/IG/ert/iso639.htm + [2]: http://www.iso.org/iso/country_codes/iso_3166_code_lists/country_names_and_code_elements.htm + +4. Go through as much of the rest of the file as you wish, replacing the + English strings with strings in your native language. + +At this point, you can send the yourlanguage.php file to us and we will take +care of testing and recoding the translation. Please only do that if you +find the rest of these steps too difficult. + +5. To add your language to phpPgAdmin, edit the lang/translations.php file + and add your language to the $appLangFiles array. + Also, add your language to the $availableLanguages array for + browser auto detection. + +6. Send your contribution to us. We need the lang/translations.php entry as + well as the lang/yourlanguage.php file. Email to the developers list: + phppgadmin-devel@lists.sourceforge.net + +7. There exists a tool named 'langcheck' in the lang/ directory. To run it, + just type 'php langcheck '. It will give you a report about + which strings are missing from your language file and which need to be + deleted. + +Thank you for your contribution! You have just made phpPgAdmin accessible +to thousands more users! diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/admin.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/admin.php new file mode 100644 index 00000000..a8740a28 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/admin.php @@ -0,0 +1,753 @@ +printTrail('schema'); + $misc->printTitle($lang['strclusterindex'], 'pg.index.cluster'); + + echo "
\n"; + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfclustertable'], $misc->printVal($a['table'])), "

\n"; + echo "\n"; + } + } // END if multi cluster + else { + $misc->printTrail($type); + $misc->printTitle($lang['strclusterindex'], 'pg.index.cluster'); + + echo "\n"; + + if ($type == 'table') { + echo "

", sprintf($lang['strconfclustertable'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + else { + echo "

", sprintf($lang['strconfclusterdatabase'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + } + echo "\n"; + + echo $misc->form; + + echo "\n"; //TODO + echo "\n"; + echo "
\n"; + } // END single cluster + else { + //If multi table cluster + if ($type == 'table') { // cluster one or more table + if (is_array($_REQUEST['table'])) { + $msg=''; + foreach($_REQUEST['table'] as $o) { + $status = $data->clusterIndex($o); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($o, ENT_QUOTES, 'UTF-8'), $lang['strclusteredgood']); + else { + doDefault($type, sprintf('%s%s: %s
', $msg, htmlentities($o, ENT_QUOTES, 'UTF-8'), $lang['strclusteredbad'])); + return; + } + } + // Everything went fine, back to the Default page.... + doDefault($msg); + } + else { + $status = $data->clusterIndex($_REQUEST['object']); + if ($status == 0) { + doAdmin($type, $lang['strclusteredgood']); + } + else + doAdmin($type, $lang['strclusteredbad']); + } + } + else { // Cluster all tables in database + $status = $data->clusterIndex(); + if ($status == 0) { + doAdmin($type, $lang['strclusteredgood']); + } + else + doAdmin($type, $lang['strclusteredbad']); + } + } + } + + /** + * Show confirmation of reindex and perform reindex + */ + function doReindex($type, $confirm=false) { + global $script, $data, $misc, $lang, $_reload_browser; + + if (($type == 'table') && empty($_REQUEST['table']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifytabletoreindex']); + return; + } + + if ($confirm) { + if (isset($_REQUEST['ma'])) { + $misc->printTrail('schema'); + $misc->printTitle($lang['strreindex'], 'pg.reindex'); + + echo "
\n"; + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfreindextable'], $misc->printVal($a['table'])), "

\n"; + echo "\n"; + } + } // END if multi reindex + else { + $misc->printTrail($type); + $misc->printTitle($lang['strreindex'], 'pg.reindex'); + + echo "\n"; + + if ($type == 'table') { + echo "

", sprintf($lang['strconfreindextable'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + else { + echo "

", sprintf($lang['strconfreindexdatabase'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + } + echo "\n"; + + if ($data->hasForceReindex()) + echo "

\n"; + + echo $misc->form; + + echo "\n"; //TODO + echo "\n"; + echo "
\n"; + } // END single reindex + else { + //If multi table reindex + if (($type == 'table') && is_array($_REQUEST['table'])) { + $msg=''; + foreach($_REQUEST['table'] as $o) { + $status = $data->reindex(strtoupper($type), $o, isset($_REQUEST['reindex_force'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($o, ENT_QUOTES, 'UTF-8'), $lang['strreindexgood']); + else { + doDefault($type, sprintf('%s%s: %s
', $msg, htmlentities($o, ENT_QUOTES, 'UTF-8'), $lang['strreindexbad'])); + return; + } + } + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else { + $status = $data->reindex(strtoupper($type), $_REQUEST['object'], isset($_REQUEST['reindex_force'])); + if ($status == 0) { + $_reload_browser = true; + doAdmin($type, $lang['strreindexgood']); + } + else + doAdmin($type, $lang['strreindexbad']); + } + } + } + + /** + * Show confirmation of analyze and perform analyze + */ + function doAnalyze($type, $confirm=false) { + global $script, $data, $misc, $lang, $_reload_browser; + + if (($type == 'table') && empty($_REQUEST['table']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifytabletoanalyze']); + return; + } + + if ($confirm) { + if (isset($_REQUEST['ma'])) { + $misc->printTrail('schema'); + $misc->printTitle($lang['stranalyze'], 'pg.analyze'); + + echo "
\n"; + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfanalyzetable'], $misc->printVal($a['table'])), "

\n"; + echo "\n"; + } + } // END if multi analyze + else { + $misc->printTrail($type); + $misc->printTitle($lang['stranalyze'], 'pg.analyze'); + + echo "\n"; + + if ($type == 'table') { + echo "

", sprintf($lang['strconfanalyzetable'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + else { + echo "

", sprintf($lang['strconfanalyzedatabase'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + } + echo "\n"; + echo $misc->form; + + echo "\n"; //TODO + echo "\n"; + echo "
\n"; + } // END single analyze + else { + //If multi table analyze + if (($type == 'table') && is_array($_REQUEST['table'])) { + $msg=''; + foreach($_REQUEST['table'] as $o) { + $status = $data->analyzeDB($o); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($o, ENT_QUOTES, 'UTF-8'), $lang['stranalyzegood']); + else { + doDefault($type, sprintf('%s%s: %s
', $msg, htmlentities($o, ENT_QUOTES, 'UTF-8'), $lang['stranalyzebad'])); + return; + } + } + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else { + //we must pass table here. When empty, analyze the whole db + $status = $data->analyzeDB($_REQUEST['table']); + if ($status == 0) { + $_reload_browser = true; + doAdmin($type, $lang['stranalyzegood']); + } + else + doAdmin($type, $lang['stranalyzebad']); + } + } + } + + /** + * Show confirmation of vacuum and perform actual vacuum + */ + function doVacuum($type, $confirm = false) { + global $script, $data, $misc, $lang, $_reload_browser; + + if (($type == 'table') && empty($_REQUEST['table']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifytabletovacuum']); + return; + } + + if ($confirm) { + if (isset($_REQUEST['ma'])) { + $misc->printTrail('schema'); + $misc->printTitle($lang['strvacuum'], 'pg.vacuum'); + + echo "
\n"; + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfvacuumtable'], $misc->printVal($a['table'])), "

\n"; + echo "\n"; + } + } // END if multi vacuum + else { + $misc->printTrail($type); + $misc->printTitle($lang['strvacuum'], 'pg.vacuum'); + + echo "\n"; + + if ($type == 'table') { + echo "

", sprintf($lang['strconfvacuumtable'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + else { + echo "

", sprintf($lang['strconfvacuumdatabase'], $misc->printVal($_REQUEST['object'])), "

\n"; + echo "\n"; + } + } + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } // END single vacuum + else { + //If multi drop + if (is_array($_REQUEST['table'])) { + $msg=''; + foreach($_REQUEST['table'] as $t) { + $status = $data->vacuumDB($t, isset($_REQUEST['vacuum_analyze']), isset($_REQUEST['vacuum_full']), isset($_REQUEST['vacuum_freeze'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($t, ENT_QUOTES, 'UTF-8'), $lang['strvacuumgood']); + else { + doDefault($type, sprintf('%s%s: %s
', $msg, htmlentities($t, ENT_QUOTES, 'UTF-8'), $lang['strvacuumbad'])); + return; + } + } + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else { + //we must pass table here. When empty, vacuum the whole db + $status = $data->vacuumDB($_REQUEST['table'], isset($_REQUEST['vacuum_analyze']), isset($_REQUEST['vacuum_full']), isset($_REQUEST['vacuum_freeze'])); + if ($status == 0) { + $_reload_browser = true; + doAdmin($type, $lang['strvacuumgood']); + } + else + doAdmin($type, $lang['strvacuumbad']); + } + } + } + + /** + * Add or Edit autovacuum params and save them + */ + function doEditAutovacuum($type, $confirm, $msg='') { + global $script, $data, $misc, $lang; + + if (empty($_REQUEST['table'])) { + doAdmin($type, '', $lang['strspecifyeditvacuumtable']); + return; + } + + $script = ($type == 'database')? 'database.php' : 'tables.php'; + + if ($confirm) { + $misc->printTrail($type); + $misc->printTitle(sprintf($lang['streditvacuumtable'], $misc->printVal($_REQUEST['table']))); + $misc->printMsg(sprintf($msg, $misc->printVal($_REQUEST['table']))); + + if (empty($_REQUEST['table'])) { + doAdmin($type, '', $lang['strspecifyeditvacuumtable']); + return; + } + + $old_val = $data->getTableAutovacuum($_REQUEST['table']); + $defaults = $data->getAutovacuum(); + $old_val = $old_val->fields; + + if (isset($old_val['autovacuum_enabled']) and ($old_val['autovacuum_enabled'] == 'off')) { + $enabled = ''; + $disabled = 'checked="checked"'; + } + else { + $enabled = 'checked="checked"'; + $disabled = ''; + } + + if (!isset($old_val['autovacuum_vacuum_threshold'])) $old_val['autovacuum_vacuum_threshold'] = ''; + if (!isset($old_val['autovacuum_vacuum_scale_factor'])) $old_val['autovacuum_vacuum_scale_factor'] = ''; + if (!isset($old_val['autovacuum_analyze_threshold'])) $old_val['autovacuum_analyze_threshold'] = ''; + if (!isset($old_val['autovacuum_analyze_scale_factor'])) $old_val['autovacuum_analyze_scale_factor'] = ''; + if (!isset($old_val['autovacuum_vacuum_cost_delay'])) $old_val['autovacuum_vacuum_cost_delay'] = ''; + if (!isset($old_val['autovacuum_vacuum_cost_limit'])) $old_val['autovacuum_vacuum_cost_limit'] = ''; + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + + echo "
\n
\n\n"; + echo "\t\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "\t\n"; + echo "\n"; + echo "\n"; + echo "
 {$lang['strnewvalues']}{$lang['strdefaultvalues']}
{$lang['strenable']}\n"; + echo "\n"; + echo "{$defaults['autovacuum']}
{$lang['strvacuumbasethreshold']}{$defaults['autovacuum_vacuum_threshold']}
{$lang['strvacuumscalefactor']}{$defaults['autovacuum_vacuum_scale_factor']}
{$lang['stranalybasethreshold']}{$defaults['autovacuum_analyze_threshold']}
{$lang['stranalyzescalefactor']}{$defaults['autovacuum_analyze_scale_factor']}
{$lang['strvacuumcostdelay']}{$defaults['autovacuum_vacuum_cost_delay']}
{$lang['strvacuumcostlimit']}{$defaults['autovacuum_vacuum_cost_limit']}
\n"; + echo "
"; + echo "
"; + echo "\n"; + echo "

\n"; + + echo "
\n"; + } + else { + $status = $data->saveAutovacuum($_REQUEST['table'], $_POST['autovacuum_enabled'], $_POST['autovacuum_vacuum_threshold'], + $_POST['autovacuum_vacuum_scale_factor'], $_POST['autovacuum_analyze_threshold'], $_POST['autovacuum_analyze_scale_factor'], + $_POST['autovacuum_vacuum_cost_delay'], $_POST['autovacuum_vacuum_cost_limit']); + + if ($status == 0) + doAdmin($type, '', sprintf($lang['strsetvacuumtablesaved'], $_REQUEST['table'])); + else + doEditAutovacuum($type, true, $lang['strsetvacuumtablefail']); + } + } + + /** + * confirm drop autovacuum params for a table and drop it + */ + function doDropAutovacuum($type, $confirm) { + global $script, $data, $misc, $lang; + + if (empty($_REQUEST['table'])) { + doAdmin($type, '', $lang['strspecifydelvacuumtable']); + return; + } + + if ($confirm) { + $misc->printTrail($type); + $misc->printTabs($type,'admin'); + + $script = ($type == 'database')? 'database.php' : 'tables.php'; + + printf("

{$lang['strdelvacuumtable']}

\n", + $misc->printVal("\"{$_GET['schema']}\".\"{$_GET['table']}\"")); + + echo "
\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "
\n"; + } + else { + + $status = $data->dropAutovacuum($_POST['table']); + + if ($status == 0) { + doAdmin($type, '', sprintf($lang['strvacuumtablereset'], $misc->printVal($_POST['table']))); + } + else + doAdmin($type, '', sprintf($lang['strdelvacuumtablefail'], $misc->printVal($_POST['table']))); + } + } + + /** + * database/table administration and tuning tasks + * + * $Id: admin.php + */ + + function doAdmin($type, $msg = '') { + global $script, $data, $misc, $lang; + + $misc->printTrail($type); + $misc->printTabs($type,'admin'); + $misc->printMsg($msg); + + if ($type == 'database') + printf("

{$lang['stradminondatabase']}

\n", $misc->printVal($_REQUEST['object'])); + else + printf("

{$lang['stradminontable']}

\n", $misc->printVal($_REQUEST['object'])); + + echo "\n"; + echo "\n"; + echo "\n"; + echo ""; + echo ""; + if ($data->hasRecluster()){ + echo ""; + } + echo ""; + echo ""; + + // Vacuum + echo "\n"; + echo "\n"; + + // Analyze + echo "\n"; + + // Cluster + if ($data->hasRecluster()){ + $disabled = ''; + echo "\n"; + } + + // Reindex + echo "\n"; + echo "\n"; + echo "
"; + $misc->printHelp($lang['strvacuum'],'pg.admin.vacuum').""; + $misc->printHelp($lang['stranalyze'],'pg.admin.analyze'); + echo ""; + $misc->printHelp($lang['strclusterindex'],'pg.index.cluster'); + echo ""; + $misc->printHelp($lang['strreindex'],'pg.index.reindex'); + echo "
\n"; + echo "
\n"; + + echo "

\n"; + echo $misc->form; + if ($type == 'table') { + echo "\n"; + echo "\n"; + } + echo "

\n"; + echo "
\n"; + echo "
\n"; + echo "
\n"; + echo "

\n"; + echo $misc->form; + if ($type == 'table') { + echo "\n"; + echo "\n"; + } + echo "

\n"; + echo "
\n"; + echo "
\n"; + echo "
\n"; + echo $misc->form; + if ($type == 'table') { + echo "\n"; + echo "\n"; + if (!$data->alreadyClustered($_REQUEST['object'])) { + $disabled = 'disabled="disabled" '; + echo "{$lang['strnoclusteravailable']}
"; + } + } + echo "

\n"; + echo "

\n"; + echo "
\n"; + echo "
\n"; + echo "
\n"; + echo "

\n"; + echo $misc->form; + if ($type == 'table') { + echo "\n"; + echo "\n"; + } + echo "

\n"; + echo "
\n"; + echo "
\n"; + + // Autovacuum + if($data->hasAutovacuum()) { + // get defaults values for autovacuum + $defaults = $data->getAutovacuum(); + // Fetch the autovacuum properties from the database or table if != '' + if ($type == 'table') $autovac = $data->getTableAutovacuum($_REQUEST['table']); + else $autovac = $data->getTableAutovacuum(); + + echo "

{$lang['strvacuumpertable']}

"; + echo '

' . (($defaults['autovacuum'] == 'on') ? $lang['strturnedon'] : $lang['strturnedoff'] ) . '

'; + echo "

{$lang['strnotdefaultinred']}

"; + + function enlight($f, $p) { + if ( isset($f[$p[0]]) and ($f[$p[0]] != $p[1])) + return "". htmlspecialchars($f[$p[0]]) .""; + return htmlspecialchars($p[1]); + } + + $columns = array( + 'namespace' => array( + 'title' => $lang['strschema'], + 'field' => field('nspname'), + 'url' => "redirect.php?subject=schema&{$misc->href}&", + 'vars' => array('schema' => 'nspname'), + ), + 'relname' => array( + 'title' => $lang['strtable'], + 'field' => field('relname'), + 'url' => "redirect.php?subject=table&{$misc->href}&", + 'vars' => array('table' => 'relname', 'schema' => 'nspname'), + ), + 'autovacuum_enabled' => array( + 'title' => $lang['strenabled'], + 'field' => callback('enlight', array('autovacuum_enabled', $defaults['autovacuum'])), + 'type' => 'verbatim' + ), + 'autovacuum_vacuum_threshold' => array( + 'title' => $lang['strvacuumbasethreshold'], + 'field' => callback('enlight', array('autovacuum_vacuum_threshold', $defaults['autovacuum_vacuum_threshold'])), + 'type' => 'verbatim' + ), + 'autovacuum_vacuum_scale_factor' => array( + 'title' => $lang['strvacuumscalefactor'], + 'field' => callback('enlight', array('autovacuum_vacuum_scale_factor', $defaults['autovacuum_vacuum_scale_factor'])), + 'type' => 'verbatim' + ), + 'autovacuum_analyze_threshold' => array( + 'title' => $lang['stranalybasethreshold'], + 'field' => callback('enlight', array('autovacuum_analyze_threshold', $defaults['autovacuum_analyze_threshold'])), + 'type' => 'verbatim' + ), + 'autovacuum_analyze_scale_factor' => array( + 'title' => $lang['stranalyzescalefactor'], + 'field' => callback('enlight', array('autovacuum_analyze_scale_factor', $defaults['autovacuum_analyze_scale_factor'])), + 'type' => 'verbatim' + ), + 'autovacuum_vacuum_cost_delay' => array( + 'title' => $lang['strvacuumcostdelay'], + 'field' => concat(callback('enlight', array('autovacuum_vacuum_cost_delay', $defaults['autovacuum_vacuum_cost_delay'])), 'ms'), + 'type' => 'verbatim' + ), + 'autovacuum_vacuum_cost_limit' => array( + 'title' => $lang['strvacuumcostlimit'], + 'field' => callback('enlight', array('autovacuum_vacuum_cost_limit', $defaults['autovacuum_vacuum_cost_limit'])), + 'type' => 'verbatim' + ), + ); + + // Maybe we need to check permissions here? + $columns['actions'] = array('title' => $lang['stractions']); + + $actions = array( + 'edit' => array( + 'content' => $lang['stredit'], + 'attr'=> array ( + 'href' => array ( + 'url' => $script, + 'urlvars' => array ( + 'subject' => $type, + 'action' => 'confeditautovac', + 'schema' => field('nspname'), + 'table' => field('relname') + ) + ) + ) + ), + 'delete' => array( + 'content' => $lang['strdelete'], + 'attr'=> array ( + 'href' => array ( + 'url' => $script, + 'urlvars' => array ( + 'subject' => $type, + 'action' => 'confdelautovac', + 'schema' => field('nspname'), + 'table' => field('relname') + ) + ) + ) + ) + ); + + if ($type == 'table') { + unset($actions['edit']['vars']['schema'], + $actions['delete']['vars']['schema'], + $columns['namespace'], + $columns['relname'] + ); + } + + $misc->printTable($autovac, $columns, $actions, 'admin-admin', $lang['strnovacuumconf']); + + if (($type == 'table') and ($autovac->recordCount() == 0)) { + echo "
"; + echo "href}&table=", htmlspecialchars($_REQUEST['table']) + ,"\">{$lang['straddvacuumtable']}"; + } + } + } + + function adminActions($action, $type) { + global $script; + + if ($type == 'database') { + $_REQUEST['object'] = $_REQUEST['database']; + $script = 'database.php'; + } + else { + // $_REQUEST['table'] is no set if we are in the schema page + $_REQUEST['object'] = (isset($_REQUEST['table']) ? $_REQUEST['table']:''); + $script = 'tables.php'; + } + + switch ($action) { + case 'confirm_cluster': + doCluster($type, true); + break; + case 'confirm_reindex': + doReindex($type, true); + break; + case 'confirm_analyze': + doAnalyze($type, true); + break; + case 'confirm_vacuum': + doVacuum($type, true); + break; + case 'cluster': + if (isset($_POST['cluster'])) doCluster($type); + // if multi-action from table canceled: back to the schema default page + else if (($type == 'table') && is_array($_REQUEST['object']) ) doDefault(); + else doAdmin($type); + break; + case 'reindex': + if (isset($_POST['reindex'])) doReindex($type); + // if multi-action from table canceled: back to the schema default page + else if (($type == 'table') && is_array($_REQUEST['object']) ) doDefault(); + else doAdmin($type); + break; + case 'analyze': + if (isset($_POST['analyze'])) doAnalyze($type); + // if multi-action from table canceled: back to the schema default page + else if (($type == 'table') && is_array($_REQUEST['object']) ) doDefault(); + else doAdmin($type); + break; + case 'vacuum': + if (isset($_POST['vacuum'])) doVacuum($type); + // if multi-action from table canceled: back to the schema default page + else if (($type == 'table') && is_array($_REQUEST['object']) ) doDefault(); + else doAdmin($type); + break; + case 'admin': + doAdmin($type); + break; + case 'confeditautovac': + doEditAutovacuum($type, true); + break; + case 'confdelautovac': + doDropAutovacuum($type, true); + break; + case 'confaddautovac': + doAddAutovacuum(true); + break; + case 'editautovac': + if (isset($_POST['save'])) doEditAutovacuum($type, false); + else doAdmin($type); + break; + case 'delautovac': + doDropAutovacuum($type, false); + break; + default: + return false; + } + return true; + } + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/aggregates.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/aggregates.php new file mode 100644 index 00000000..5356e02c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/aggregates.php @@ -0,0 +1,462 @@ +createAggregate($_REQUEST['name'], $_REQUEST['basetype'], $_REQUEST['sfunc'], $_REQUEST['stype'], + $_REQUEST['ffunc'], $_REQUEST['initcond'], $_REQUEST['sortop'], $_REQUEST['aggrcomment']); + + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['straggrcreated']); + } + else { + doCreate($lang['straggrcreatedbad']); + } + } + + /** + * Displays a screen for create a new aggregate function + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_REQUEST['name'])) $_REQUEST['name'] = ''; + if (!isset($_REQUEST['basetype'])) $_REQUEST['basetype'] = ''; + if (!isset($_REQUEST['sfunc'])) $_REQUEST['sfunc'] = ''; + if (!isset($_REQUEST['stype'])) $_REQUEST['stype'] = ''; + if (!isset($_REQUEST['ffunc'])) $_REQUEST['ffunc'] = ''; + if (!isset($_REQUEST['initcond'])) $_REQUEST['initcond'] = ''; + if (!isset($_REQUEST['sortop'])) $_REQUEST['sortop'] = ''; + if (!isset($_REQUEST['aggrcomment'])) $_REQUEST['aggrcomment'] = ''; + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreateaggregate'], 'pg.aggregate.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['name']), "\" />
{$lang['straggrbasetype']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['basetype']), "\" />
{$lang['straggrsfunc']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['sfunc']), "\" />
{$lang['straggrstype']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['stype']), "\" />
{$lang['straggrffunc']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['ffunc']), "\" />
{$lang['straggrinitcond']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['initcond']), "\" />
{$lang['straggrsortop']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['sortop']), "\" />
{$lang['strcomment']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Function to save after altering an aggregate + */ + function doSaveAlter() { + global $data, $lang; + + // Check inputs + if (trim($_REQUEST['aggrname']) == '') { + doAlter($lang['straggrneedsname']); + return; + } + + $status = $data->alterAggregate($_REQUEST['aggrname'], $_REQUEST['aggrtype'], $_REQUEST['aggrowner'], + $_REQUEST['aggrschema'], $_REQUEST['aggrcomment'], $_REQUEST['newaggrname'], $_REQUEST['newaggrowner'], + $_REQUEST['newaggrschema'], $_REQUEST['newaggrcomment']); + if ($status == 0) + doDefault($lang['straggraltered']); + else { + doAlter($lang['straggralteredbad']); + return; + } + } + + + /** + * Function to allow editing an aggregate function + */ + function doAlter($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('aggregate'); + $misc->printTitle($lang['stralter'], 'pg.aggregate.alter'); + $misc->printMsg($msg); + + echo "
\n"; + $aggrdata = $data->getAggregate($_REQUEST['aggrname'], $_REQUEST['aggrtype']); + if($aggrdata->recordCount() > 0 ) { + // Output table header + echo "\n"; + echo "\t\n\t\t"; + echo ""; + echo "\n\t\n"; + + // Display aggregate's name, owner and schema + echo "\t\n\t\t"; + echo ""; + echo "\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strname']}{$lang['strowner']}{$lang['strschema']}
fields['usename']), "\" />
{$lang['strcomment']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "fields['usename']), "\" />\n"; + echo "\n"; + echo "fields['aggrcomment']), "\" />\n"; + echo "\n"; + echo "

\n"; + } else { + echo "

{$lang['strnodata']}

\n"; + echo "

\n"; + } + echo "
\n"; + } + + /** + * Show confirmation of drop and perform actual drop of the aggregate function selected + */ + function doDrop($confirm) { + global $data, $misc; + global $lang, $_reload_browser; + + if ($confirm) { + $misc->printTrail('aggregate'); + $misc->printTitle($lang['strdrop'], 'pg.aggregate.drop'); + + echo "

", sprintf($lang['strconfdropaggregate'], htmlspecialchars($_REQUEST['aggrname'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropAggregate($_POST['aggrname'], $_POST['aggrtype'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['straggregatedropped']); + } + else + doDefault($lang['straggregatedroppedbad']); + } + } + + /** + * Show the properties of an aggregate + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('aggregate'); + $misc->printTitle($lang['strproperties'],'pg.aggregate'); + $misc->printMsg($msg); + + $aggrdata = $data->getAggregate($_REQUEST['aggrname'], $_REQUEST['aggrtype']); + + if($aggrdata->recordCount() > 0 ) { + // Display aggregate's info + echo "\n"; + echo "\n\t\n"; + echo "\t\n\n"; + echo "\n\t\n"; + echo "\t\n\n"; + echo "\n\t\n"; + echo "\t\n\n"; + echo "\n\t\n"; + echo "\t\n\n"; + echo "\n\t\n"; + echo "\t\n\n"; + echo "\n\t\n"; + echo "\t\n\n"; + if($data->hasAggregateSortOp()) { + echo "\n\t\n"; + echo "\t\n\n"; + } + echo "\n\t\n"; + echo "\t\n\n"; + echo "\n\t\n"; + echo "\t\n\n"; + echo "
{$lang['strname']}", htmlspecialchars($_REQUEST['aggrname']), "
{$lang['straggrbasetype']}", htmlspecialchars($_REQUEST['aggrtype']), "
{$lang['straggrsfunc']}", htmlspecialchars($aggrdata->fields['aggtransfn']), "
{$lang['straggrstype']}", htmlspecialchars($aggrdata->fields['aggstype']), "
{$lang['straggrffunc']}", htmlspecialchars($aggrdata->fields['aggfinalfn']), "
{$lang['straggrinitcond']}", htmlspecialchars($aggrdata->fields['agginitval']), "
{$lang['straggrsortop']}", htmlspecialchars($aggrdata->fields['aggsortop']), "
{$lang['strowner']}", htmlspecialchars($aggrdata->fields['usename']), "
{$lang['strcomment']}", $misc->printVal($aggrdata->fields['aggrcomment']), "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + + $navlinks = array ( + 'showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'aggregates.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['straggrshowall'] + ) + ); + + if ($data->hasAlterAggregate()) { + $navlinks['alter'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'aggregates.php', + 'urlvars' => array ( + 'action' => 'alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'aggrname' => $_REQUEST['aggrname'], + 'aggrtype' => $_REQUEST['aggrtype'] + ) + ) + ), + 'content' => $lang['stralter'] + ); + } + + $navlinks['drop'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'aggregates.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'aggrname' => $_REQUEST['aggrname'], + 'aggrtype' => $_REQUEST['aggrtype'] + ) + ) + ), + 'content' => $lang['strdrop'] + ); + + $misc->printNavLinks($navlinks, 'aggregates-properties', get_defined_vars()); + } + + + /** + * Show default list of aggregate functions in the database + */ + function doDefault($msg = '') { + global $data, $conf, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema', 'aggregates'); + $misc->printMsg($msg); + + $aggregates = $data->getAggregates(); + + $columns = array( + 'aggrname' => array( + 'title' => $lang['strname'], + 'field' => field('proname'), + 'url' => "redirect.php?subject=aggregate&action=properties&{$misc->href}&", + 'vars' => array('aggrname' => 'proname', 'aggrtype' => 'proargtypes'), + ), + 'aggrtype' => array( + 'title' => $lang['strtype'], + 'field' => field('proargtypes'), + ), + 'aggrtransfn' => array( + 'title' => $lang['straggrsfunc'], + 'field' => field('aggtransfn'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('usename'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('aggrcomment'), + ), + ); + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'aggregates.php', + 'urlvars' => array ( + 'action' => 'alter', + 'aggrname' => field('proname'), + 'aggrtype' => field('proargtypes') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'aggregates.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'aggrname' => field('proname'), + 'aggrtype' => field('proargtypes') + ) + ) + ) + ) + ); + + if (!$data->hasAlterAggregate()) unset($actions['alter']); + $misc->printTable($aggregates, $columns, $actions, 'aggregates-aggregates', $lang['strnoaggregates']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'aggregates.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + ) + ) + ), + 'content' => $lang['strcreateaggregate'] + ) + ); + $misc->printNavLinks($navlinks, 'aggregates-aggregates', get_defined_vars()); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $aggregates = $data->getAggregates(); + + $proto = concat(field('proname'), ' (', field('proargtypes'), ')'); + $reqvars = $misc->getRequestVars('aggregate'); + + $attrs = array( + 'text' => $proto, + 'icon' => 'Aggregate', + 'toolTip' => field('aggcomment'), + 'action' => url('redirect.php', + $reqvars, + array( + 'action' => 'properties', + 'aggrname' => field('proname'), + 'aggrtype' => field('proargtypes') + ) + ) + ); + + $misc->printTree($aggregates, $attrs, 'aggregates'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['straggregates']); + $misc->printBody(); + + switch ($action) { + case 'create': + doCreate(); + break; + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'alter': + doAlter(); + break; + case 'save_alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doProperties(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + doDefault(); + break; + case 'properties': + doProperties(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/ajax-ac-insert.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/ajax-ac-insert.php new file mode 100644 index 00000000..20afbc75 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/ajax-ac-insert.php @@ -0,0 +1,92 @@ + $v) { + $fkeynames[$k] = html_entity_decode($v, ENT_QUOTES); + } + + $keyspos = array_combine($fkeynames, $_POST['keys']); + + $f_schema = html_entity_decode($_POST['f_schema'], ENT_QUOTES); + $data->fieldClean($f_schema); + $f_table = html_entity_decode($_POST['f_table'], ENT_QUOTES); + $data->fieldClean($f_table); + $f_attname = $fkeynames[$_POST['fattpos'][0]]; + $data->fieldClean($f_attname); + + $q = "SELECT * + FROM \"{$f_schema}\".\"{$f_table}\" + WHERE \"{$f_attname}\"::text LIKE '{$_POST['fvalue']}%' + ORDER BY \"{$f_attname}\" LIMIT 12 {$offset};"; + + $res = $data->selectSet($q); + + if (!$res->EOF) { + echo ""; + echo ''; + foreach (array_keys($res->fields) as $h) { + echo ''; + + } + echo "\n"; + $i=0; + while ((!$res->EOF) && ($i < 11)) { + $j=0; + echo ""; + foreach ($res->fields as $n => $v) { + $finfo = $res->fetchField($j++); + if (in_array($n, $fkeynames)) + echo ""; + else + echo ""; + } + echo "\n"; + $i++; + $res->moveNext(); + } + echo "
'; + + if (in_array($h, $fkeynames)) + echo '[referenced key]'; + + echo htmlentities($h, ENT_QUOTES, 'UTF-8'), '
", + $misc->printVal($v, $finfo->type, array('clip' => 'collapsed')), + "", + $misc->printVal($v, $finfo->type, array('clip' => 'collapsed')), + "
\n"; + + $page_tests=''; + + $js = ""; + } + else { + printf("

{$lang['strnofkref']}

", "\"{$_POST['f_schema']}\".\"{$_POST['f_table']}\".\"{$fkeynames[$_POST['fattpos']]}\""); + + if ($_POST['offset']) + echo "Prev <<"; + } +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/all_db.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/all_db.php new file mode 100644 index 00000000..181263ec --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/all_db.php @@ -0,0 +1,532 @@ +printTrail('database'); + $misc->printTitle($lang['stralter'], 'pg.database.alter'); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + if ($data->hasAlterDatabaseOwner() && $data->isSuperUser()) { + // Fetch all users + + $rs = $data->getDatabaseOwner($_REQUEST['alterdatabase']); + $owner = isset($rs->fields['usename']) ? $rs->fields['usename'] : ''; + $users = $data->getUsers(); + + echo "\n"; + echo "\n"; + } + if ($data->hasSharedComments()){ + $rs = $data->getDatabaseComment($_REQUEST['alterdatabase']); + $comment = isset($rs->fields['description']) ? $rs->fields['description'] : ''; + echo "\n"; + echo "\n"; + } + echo "
{$lang['strname']}"; + echo "_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['alterdatabase']), "\" />
{$lang['strowner']}
{$lang['strcomment']}"; + echo "
\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + if (!isset($_POST['owner'])) $_POST['owner'] = ''; + if (!isset($_POST['dbcomment'])) $_POST['dbcomment'] = ''; + if ($data->alterDatabase($_POST['oldname'], $_POST['newname'], $_POST['owner'], $_POST['dbcomment']) == 0) { + $_reload_browser = true; + doDefault($lang['strdatabasealtered']); + } + else + doDefault($lang['strdatabasealteredbad']); + } + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang, $_reload_drop_database; + + if (empty($_REQUEST['dropdatabase']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifydatabasetodrop']); + exit(); + } + + if ($confirm) { + + $misc->printTrail('database'); + $misc->printTitle($lang['strdrop'], 'pg.database.drop'); + + echo "
\n"; + //If multi drop + if (isset($_REQUEST['ma'])) { + + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfdropdatabase'], $misc->printVal($a['database'])), "

\n"; + printf('', htmlspecialchars($a['database'])); + } + + } else { + echo "

", sprintf($lang['strconfdropdatabase'], $misc->printVal($_REQUEST['dropdatabase'])), "

\n"; + echo "\n"; + }// END if multi drop + + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } // END confirm + else { + //If multi drop + if (is_array($_REQUEST['dropdatabase'])) { + $msg = ''; + foreach($_REQUEST['dropdatabase'] as $d) { + $status = $data->dropDatabase($d); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($d, ENT_QUOTES, 'UTF-8'), $lang['strdatabasedropped']); + else { + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($d, ENT_QUOTES, 'UTF-8'), $lang['strdatabasedroppedbad'])); + return; + } + }// Everything went fine, back to Default page... + $_reload_drop_database = true; + doDefault($msg); + } else { + $status = $data->dropDatabase($_POST['dropdatabase']); + if ($status == 0) { + $_reload_drop_database = true; + doDefault($lang['strdatabasedropped']); + } + else + doDefault($lang['strdatabasedroppedbad']); + } + }//END DROP + }// END FUNCTION + + + /** + * Displays a screen where they can enter a new database + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('server'); + $misc->printTitle($lang['strcreatedatabase'], 'pg.database.create'); + $misc->printMsg($msg); + + if (!isset($_POST['formName'])) $_POST['formName'] = ''; + // Default encoding is that in language file + if (!isset($_POST['formEncoding'])) { + $_POST['formEncoding'] = ''; + } + if (!isset($_POST['formTemplate'])) $_POST['formTemplate'] = 'template1'; + if (!isset($_POST['formSpc'])) $_POST['formSpc'] = ''; + if (!isset($_POST['formComment'])) $_POST['formComment'] = ''; + + // Fetch a list of databases in the cluster + $templatedbs = $data->getDatabases(false); + + // Fetch all tablespaces from the database + if ($data->hasTablespaces()) $tablespaces = $data->getTablespaces(); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // ENCODING + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + if ($data->hasDatabaseCollation()) { + if (!isset($_POST['formCollate'])) $_POST['formCollate'] = ''; + if (!isset($_POST['formCType'])) $_POST['formCType'] = ''; + + // LC_COLLATE + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // LC_CTYPE + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + // Tablespace (if there are any) + if ($data->hasTablespaces() && $tablespaces->recordCount() > 0) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + // Comments (if available) + if ($data->hasSharedComments()) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formName']), "\" />
{$lang['strtemplatedb']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['strencoding']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['strcollation']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['strctype']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['strtablespace']}\n\t\t\t\n\t\t
{$lang['strcomment']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new view in the database + */ + function doSaveCreate() { + global $data, $lang, $_reload_browser; + + // Default tablespace to null if it isn't set + if (!isset($_POST['formSpc'])) $_POST['formSpc'] = null; + + // Default comment to blank if it isn't set + if (!isset($_POST['formComment'])) $_POST['formComment'] = null; + + // Default collate to blank if it isn't set + if (!isset($_POST['formCollate'])) $_POST['formCollate'] = null; + + // Default ctype to blank if it isn't set + if (!isset($_POST['formCType'])) $_POST['formCType'] = null; + + // Check that they've given a name and a definition + if ($_POST['formName'] == '') doCreate($lang['strdatabaseneedsname']); + else { + $status = $data->createDatabase($_POST['formName'], $_POST['formEncoding'], $_POST['formSpc'], + $_POST['formComment'], $_POST['formTemplate'], $_POST['formCollate'], $_POST['formCType']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strdatabasecreated']); + } + else + doCreate($lang['strdatabasecreatedbad']); + } + } + + /** + * Displays options for cluster download + */ + function doExport($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('server'); + $misc->printTabs('server','export'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + // Data only + echo "\n"; + echo "\n\n"; + echo "\n\n"; + // Structure only + echo "\n"; + echo "\n\n"; + // Structure and data + echo "\n"; + echo "\n\n"; + echo "\n\n"; + echo "\n\n"; + echo "
{$lang['strformat']}{$lang['stroptions']}
"; + echo "{$lang['strformat']}\n"; + echo "\n
"; + echo "{$lang['strformat']}\n"; + echo "\n
\n"; + + echo "

{$lang['stroptions']}

\n"; + echo "

\n"; + echo "

\n"; + + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "
\n"; + } + + /** + * Show default list of databases in the server + */ + function doDefault($msg = '') { + global $data, $conf, $misc; + global $lang; + + $misc->printTrail('server'); + $misc->printTabs('server','databases'); + $misc->printMsg($msg); + + $databases = $data->getDatabases(); + + $columns = array( + 'database' => array( + 'title' => $lang['strdatabase'], + 'field' => field('datname'), + 'url' => "redirect.php?subject=database&{$misc->href}&", + 'vars' => array('database' => 'datname'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('datowner'), + ), + 'encoding' => array( + 'title' => $lang['strencoding'], + 'field' => field('datencoding'), + ), + 'lc_collate' => array( + 'title' => $lang['strcollation'], + 'field' => field('datcollate'), + ), + 'lc_ctype' => array( + 'title' => $lang['strctype'], + 'field' => field('datctype'), + ), + 'tablespace' => array( + 'title' => $lang['strtablespace'], + 'field' => field('tablespace'), + ), + 'dbsize' => array( + 'title' => $lang['strsize'], + 'field' => field('dbsize'), + 'type' => 'prettysize', + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('datcomment'), + ), + ); + + $actions = array( + 'multiactions' => array( + 'keycols' => array('database' => 'datname'), + 'url' => 'all_db.php', + 'default' => null, + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'all_db.php', + 'urlvars' => array ( + 'subject' => 'database', + 'action' => 'confirm_drop', + 'dropdatabase' => field('datname') + ) + ) + ), + 'multiaction' => 'confirm_drop', + ), + 'privileges' => array( + 'content' => $lang['strprivileges'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array ( + 'subject' => 'database', + 'database' => field('datname') + ) + ) + ) + ) + ); + if ($data->hasAlterDatabase() ) { + $actions['alter'] = array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'all_db.php', + 'urlvars' => array ( + 'subject' => 'database', + 'action' => 'confirm_alter', + 'alterdatabase' => field('datname') + ) + ) + ) + ); + } + + if (!$data->hasTablespaces()) unset($columns['tablespace']); + if (!$data->hasServerAdminFuncs()) unset($columns['dbsize']); + if (!$data->hasDatabaseCollation()) unset($columns['lc_collate'], $columns['lc_ctype']); + if (!isset($data->privlist['database'])) unset($actions['privileges']); + + $misc->printTable($databases, $columns, $actions, 'all_db-databases', $lang['strnodatabases']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'all_db.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strcreatedatabase'] + ) + ); + $misc->printNavLinks($navlinks, 'all_db-databases', get_defined_vars()); + } + + function doTree() { + global $misc, $data, $lang; + + $databases = $data->getDatabases(); + + $reqvars = $misc->getRequestVars('database'); + + $attrs = array( + 'text' => field('datname'), + 'icon' => 'Database', + 'toolTip'=> field('datcomment'), + 'action' => url('redirect.php', + $reqvars, + array('database' => field('datname')) + ), + 'branch' => url('database.php', + $reqvars, + array( + 'action' => 'tree', + 'database' => field('datname') + ) + ), + ); + + $misc->printTree($databases, $attrs, 'databases'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strdatabases']); + $misc->printBody(); + + switch ($action) { + case 'export': + doExport(); + break; + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_REQUEST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'alter': + if (isset($_POST['oldname']) && isset($_POST['newname']) && !isset($_POST['cancel']) ) doAlter(false); + else doDefault(); + break; + case 'confirm_alter': + doAlter(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/browser.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/browser.php new file mode 100644 index 00000000..3b7a5480 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/browser.php @@ -0,0 +1,84 @@ +printHeader('', ' + + + '); + + $misc->printBody('browser'); + echo "
\n"; +?> + + +
<?php echo $lang['strrefresh']; ?>
+ + +\n"; + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/casts.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/casts.php new file mode 100644 index 00000000..2be86b4f --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/casts.php @@ -0,0 +1,103 @@ +printTrail('database'); + $misc->printTabs('database','casts'); + $misc->printMsg($msg); + + $casts = $data->getCasts(); + + $columns = array( + 'source_type' => array( + 'title' => $lang['strsourcetype'], + 'field' => field('castsource'), + ), + 'target_type' => array( + 'title' => $lang['strtargettype'], + 'field' => field('casttarget'), + ), + 'function' => array( + 'title' => $lang['strfunction'], + 'field' => field('castfunc'), + 'params'=> array('null' => $lang['strbinarycompat']), + ), + 'implicit' => array( + 'title' => $lang['strimplicit'], + 'field' => field('castcontext'), + 'type' => 'callback', + 'params'=> array('function' => 'renderCastContext', 'align' => 'center'), + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('castcomment'), + ), + ); + + $actions = array(); + + $misc->printTable($casts, $columns, $actions, 'casts-casts', $lang['strnocasts']); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $casts = $data->getCasts(); + + $proto = concat(field('castsource'), ' AS ', field('casttarget')); + + $attrs = array( + 'text' => $proto, + 'icon' => 'Cast' + ); + + $misc->printTree($casts, $attrs, 'casts'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strcasts']); + $misc->printBody(); + + switch ($action) { + case 'tree': + doTree(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/ArrayRecordSet.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/ArrayRecordSet.php new file mode 100644 index 00000000..b2a37547 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/ArrayRecordSet.php @@ -0,0 +1,32 @@ +_array = $data; + $this->_count = count($this->_array); + $this->fields = reset($this->_array); + if ($this->fields === false) $this->EOF = true; + } + + function recordCount() { + return $this->_count; + } + + function moveNext() { + $this->fields = next($this->_array); + if ($this->fields === false) $this->EOF = true; + } +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Gui.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Gui.php new file mode 100644 index 00000000..6d0fe215 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Gui.php @@ -0,0 +1,48 @@ + Value + * @param $szName string to specify the name of the form element + * @param (optional) $bBlankEntry bool to specify whether or not we want a blank selection + * @param (optional) $szDefault string to specify the default VALUE selected + * @param (optional) $bMultiple bool to specify whether or not we want a multi select combo box + * @param (optional) $iSize int to specify the size IF a multi select combo + * @return string with the generated HTML select box + */ + function printCombo(&$arrOptions, $szName, $bBlankEntry = true, $szDefault = '', $bMultiple = false, $iSize = 10) { + $htmlOut = ''; + if ($bMultiple) // If multiple select combo + $htmlOut .= "\n"; + if ($bBlankEntry) + $htmlOut .= "\n"; + + foreach ($arrOptions as $curKey => $curVal) { + $curVal = htmlspecialchars($curVal); + $curKey = htmlspecialchars($curKey); + if ($curVal == $szDefault) { + $htmlOut .= "\n"; + } + else { + $htmlOut .= "\n"; + } + } + $htmlOut .= "\n"; + + return $htmlOut; + } + } +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Misc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Misc.php new file mode 100644 index 00000000..6714bb48 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Misc.php @@ -0,0 +1,2655 @@ +getServerInfo(); + return !empty($info[$all ? 'pg_dumpall_path' : 'pg_dump_path']); + } + + /** + * Sets the href tracking variable + */ + function setHREF() { + $this->href = $this->getHREF(); + } + + /** + * Get a href query string, excluding objects below the given object type (inclusive) + */ + function getHREF($exclude_from = null) { + $href = ''; + if (isset($_REQUEST['server']) && $exclude_from != 'server') { + $href .= 'server=' . urlencode($_REQUEST['server']); + if (isset($_REQUEST['database']) && $exclude_from != 'database') { + $href .= '&database=' . urlencode($_REQUEST['database']); + if (isset($_REQUEST['schema']) && $exclude_from != 'schema') { + $href .= '&schema=' . urlencode($_REQUEST['schema']); + } + } + } + return htmlentities($href); + } + + function getSubjectParams($subject) { + global $plugin_manager; + + $vars = array(); + + switch($subject) { + case 'root': + $vars = array ( + 'params' => array( + 'subject' => 'root' + ) + ); + break; + case 'server': + $vars = array ('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'server' + )); + break; + case 'role': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'role', + 'action' => 'properties', + 'rolename' => $_REQUEST['rolename'] + )); + break; + case 'database': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'database', + 'database' => $_REQUEST['database'], + )); + break; + case 'schema': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'schema', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + )); + break; + case 'table': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'table', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + )); + break; + case 'selectrows': + $vars = array( + 'url' => 'tables.php', + 'params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'table', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'], + 'action' => 'confselectrows' + )); + break; + case 'view': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'view', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'] + )); + break; + case 'fulltext': + case 'ftscfg': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'fulltext', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'action' => 'viewconfig', + 'ftscfg' => $_REQUEST['ftscfg'] + )); + break; + case 'function': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'function', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'function' => $_REQUEST['function'], + 'function_oid' => $_REQUEST['function_oid'] + )); + break; + case 'aggregate': + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'aggregate', + 'action' => 'properties', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'aggrname' => $_REQUEST['aggrname'], + 'aggrtype' => $_REQUEST['aggrtype'] + )); + break; + case 'column': + if (isset($_REQUEST['table'])) + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'column', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'], + 'column' => $_REQUEST['column'] + )); + else + $vars = array('params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'column', + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'], + 'column' => $_REQUEST['column'] + )); + break; + case 'plugin': + $vars = array( + 'url' => 'plugin.php', + 'params' => array( + 'server' => $_REQUEST['server'], + 'subject' => 'plugin', + 'plugin' => $_REQUEST['plugin'], + )); + + if (!is_null($plugin_manager->getPlugin($_REQUEST['plugin']))) + $vars['params'] = array_merge($vars['params'], $plugin_manager->getPlugin($_REQUEST['plugin'])->get_subject_params()); + break; + default: + return false; + } + + if (!isset($vars['url'])) + $vars['url'] = 'redirect.php'; + + return $vars; + } + + function getHREFSubject($subject) { + $vars = $this->getSubjectParams($subject); + return "{$vars['url']}?". http_build_query($vars['params'], '', '&'); + } + + /** + * Sets the form tracking variable + */ + function setForm() { + $this->form = ''; + if (isset($_REQUEST['server'])) { + $this->form .= "\n"; + if (isset($_REQUEST['database'])) { + $this->form .= "\n"; + if (isset($_REQUEST['schema'])) { + $this->form .= "\n"; + } + } + } + } + + /** + * Render a value into HTML using formatting rules specified + * by a type name and parameters. + * + * @param $str The string to change + * + * @param $type Field type (optional), this may be an internal PostgreSQL type, or: + * yesno - same as bool, but renders as 'Yes' or 'No'. + * pre - render in a
 block.
+		 *			nbsp     - replace all spaces with  's
+		 *			verbatim - render exactly as supplied, no escaping what-so-ever.
+		 *			callback - render using a callback function supplied in the 'function' param.
+		 *
+		 * @param $params Type parameters (optional), known parameters:
+		 *			null     - string to display if $str is null, or set to TRUE to use a default 'NULL' string,
+		 *			           otherwise nothing is rendered.
+		 *			clip     - if true, clip the value to a fixed length, and append an ellipsis...
+		 *			cliplen  - the maximum length when clip is enabled (defaults to $conf['max_chars'])
+		 *			ellipsis - the string to append to a clipped value (defaults to $lang['strellipsis'])
+		 *			tag      - an HTML element name to surround the value.
+		 *			class    - a class attribute to apply to any surrounding HTML element.
+		 *			align    - an align attribute ('left','right','center' etc.)
+		 *			true     - (type='bool') the representation of true.
+		 *			false    - (type='bool') the representation of false.
+		 *			function - (type='callback') a function name, accepts args ($str, $params) and returns a rendering.
+		 *			lineno   - prefix each line with a line number.
+		 *			map      - an associative array.
+		 *
+		 * @return The HTML rendered value
+		 */
+		function printVal($str, $type = null, $params = array()) {
+			global $lang, $conf, $data;
+
+			// Shortcircuit for a NULL value
+			if (is_null($str))
+				return isset($params['null'])
+						? ($params['null'] === true ? 'NULL' : $params['null'])
+						: '';
+
+			if (isset($params['map']) && isset($params['map'][$str])) $str = $params['map'][$str];
+
+			// Clip the value if the 'clip' parameter is true.
+			if (isset($params['clip']) && $params['clip'] === true) {
+				$maxlen = isset($params['cliplen']) && is_integer($params['cliplen']) ? $params['cliplen'] : $conf['max_chars'];
+				$ellipsis = isset($params['ellipsis']) ? $params['ellipsis'] : $lang['strellipsis'];
+				if (strlen($str) > $maxlen) {
+					$str = substr($str, 0, $maxlen-1) . $ellipsis;
+				}
+			}
+
+			$out = '';
+
+			switch ($type) {
+				case 'int2':
+				case 'int4':
+				case 'int8':
+				case 'float4':
+				case 'float8':
+				case 'money':
+				case 'numeric':
+				case 'oid':
+				case 'xid':
+				case 'cid':
+				case 'tid':
+					$align = 'right';
+					$out = nl2br(htmlspecialchars($str));
+					break;
+				case 'yesno':
+					if (!isset($params['true'])) $params['true'] = $lang['stryes'];
+					if (!isset($params['false'])) $params['false'] = $lang['strno'];
+					// No break - fall through to boolean case.
+				case 'bool':
+				case 'boolean':
+					if (is_bool($str)) $str = $str ? 't' : 'f';
+					switch ($str) {
+						case 't':
+							$out = (isset($params['true']) ? $params['true'] : $lang['strtrue']);
+							$align = 'center';
+							break;
+						case 'f':
+							$out = (isset($params['false']) ? $params['false'] : $lang['strfalse']);
+							$align = 'center';
+							break;
+						default:
+							$out = htmlspecialchars($str);
+					}
+					break;
+				case 'bytea':
+					$tag = 'div';
+					$class = 'pre';
+					$out = $data->escapeBytea($str);
+					break;
+				case 'errormsg':
+					$tag = 'pre';
+					$class = 'error';
+					$out = htmlspecialchars($str);
+					break;
+				case 'pre':
+					$tag = 'pre';
+					$out = htmlspecialchars($str);
+					break;
+				case 'prenoescape':
+					$tag = 'pre';
+					$out = $str;
+					break;
+				case 'nbsp':
+					$out = nl2br(str_replace(' ', ' ', htmlspecialchars($str)));
+					break;
+				case 'verbatim':
+					$out = $str;
+					break;
+				case 'callback':
+					$out = $params['function']($str, $params);
+					break;
+				case 'prettysize':
+					if ($str == -1) 
+						$out = $lang['strnoaccess'];
+					else
+					{
+						$limit = 10 * 1024;
+						$mult = 1;
+						if ($str < $limit * $mult)
+							$out = $str.' '.$lang['strbytes'];
+						else
+						{
+							$mult *= 1024;
+							if ($str < $limit * $mult)
+								$out = floor(($str + $mult / 2) / $mult).' '.$lang['strkb'];
+							else
+							{
+								$mult *= 1024;
+								if ($str < $limit * $mult)
+									$out = floor(($str + $mult / 2) / $mult).' '.$lang['strmb'];
+								else
+								{
+									$mult *= 1024;
+									if ($str < $limit * $mult)
+										$out = floor(($str + $mult / 2) / $mult).' '.$lang['strgb'];
+									else
+									{
+										$mult *= 1024;
+										if ($str < $limit * $mult)
+											$out = floor(($str + $mult / 2) / $mult).' '.$lang['strtb'];
+									}
+								}
+							}
+						}
+					}
+					break;
+				default:
+					// If the string contains at least one instance of >1 space in a row, a tab
+					// character, a space at the start of a line, or a space at the start of
+					// the whole string then render within a pre-formatted element (
).
+					if (preg_match('/(^ |  |\t|\n )/m', $str)) {
+						$tag = 'pre';
+						$class = 'data';
+						$out = htmlspecialchars($str);
+					} else {
+						$out = nl2br(htmlspecialchars($str));
+					}
+			}
+
+			if (isset($params['class'])) $class = $params['class'];
+			if (isset($params['align'])) $align = $params['align'];
+
+			if (!isset($tag) && (isset($class) || isset($align))) $tag = 'div';
+
+			if (isset($tag)) {
+				$alignattr = isset($align) ? " style=\"text-align: {$align}\"" : '';
+				$classattr = isset($class) ? " class=\"{$class}\"" : '';
+				$out = "<{$tag}{$alignattr}{$classattr}>{$out}";
+			}
+
+			// Add line numbers if 'lineno' param is true
+			if (isset($params['lineno']) && $params['lineno'] === true) {
+				$lines = explode("\n", $str);
+				$num = count($lines);
+				if ($num > 0) {
+					$temp = "\n
";
+					for ($i = 1; $i <= $num; $i++) {
+						$temp .= $i . "\n";
+					}
+					$temp .= "
{$out}
\n"; + $out = $temp; + } + unset($lines); + } + + return $out; + } + + /** + * A function to recursively strip slashes. Used to + * enforce magic_quotes_gpc being off. + * @param &var The variable to strip + */ + function stripVar(&$var) { + if (is_array($var)) { + foreach($var as $k => $v) { + $this->stripVar($var[$k]); + + /* magic_quotes_gpc escape keys as well ...*/ + if (is_string($k)) { + $ek = stripslashes($k); + if ($ek !== $k) { + $var[$ek] = $var[$k]; + unset($var[$k]); + } + } + } + } + else + $var = stripslashes($var); + } + + /** + * Print out the page heading and help link + * @param $title Title, already escaped + * @param $help (optional) The identifier for the help link + */ + function printTitle($title, $help = null) { + global $data, $lang; + + echo "

"; + $this->printHelp($title, $help); + echo "

\n"; + } + + /** + * Print out a message + * @param $msg The message to print + */ + function printMsg($msg) { + if ($msg != '') echo "

{$msg}

\n"; + } + + /** + * Creates a database accessor + */ + function getDatabaseAccessor($database, $server_id = null) { + global $lang, $conf, $misc, $_connection; + + $server_info = $this->getServerInfo($server_id); + + // Perform extra security checks if this config option is set + if ($conf['extra_login_security']) { + // Disallowed logins if extra_login_security is enabled. + // These must be lowercase. + $bad_usernames = array('pgsql', 'postgres', 'root', 'administrator'); + + $username = strtolower($server_info['username']); + + if ($server_info['password'] == '' || in_array($username, $bad_usernames)) { + unset($_SESSION['webdbLogin'][$_REQUEST['server']]); + $msg = $lang['strlogindisallowed']; + include('./login.php'); + exit; + } + } + + // Create the connection object and make the connection + $_connection = new Connection( + $server_info['host'], + $server_info['port'], + $server_info['sslmode'], + $server_info['username'], + $server_info['password'], + $database + ); + + // Get the name of the database driver we need to use. + // The description of the server is returned in $platform. + $_type = $_connection->getDriver($platform); + if ($_type === null) { + printf($lang['strpostgresqlversionnotsupported'], $postgresqlMinVer); + exit; + } + $this->setServerInfo('platform', $platform, $server_id); + $this->setServerInfo('pgVersion', $_connection->conn->pgVersion, $server_id); + + // Create a database wrapper class for easy manipulation of the + // connection. + include_once('./classes/database/' . $_type . '.php'); + $data = new $_type($_connection->conn); + $data->platform = $_connection->platform; + + /* we work on UTF-8 only encoding */ + $data->execute("SET client_encoding TO 'UTF-8'"); + + if ($data->hasByteaHexDefault()) { + $data->execute("SET bytea_output TO escape"); + } + + return $data; + } + + + /** + * Prints the page header. If global variable $_no_output is + * set then no header is drawn. + * @param $title The title of the page + * @param $script script tag + */ + function printHeader($title = '', $script = null, $frameset = false) { + global $appName, $lang, $_no_output, $conf, $plugin_manager; + + if (!isset($_no_output)) { + header("Content-Type: text/html; charset=utf-8"); + // Send XHTML headers, or regular XHTML strict headers + echo "\n"; + if ($frameset == true) { + echo "\n"; + } else if (isset($conf['use_xhtml_strict']) && $conf['use_xhtml_strict']) { + echo "\n"; + } else { + echo "\n"; + } + echo "\n"; + + echo "\n"; + echo "\n"; + // Theme + echo "\n"; + echo "\n"; + echo "\n"; + echo ""; + echo "\n"; + echo "", htmlspecialchars($appName); + if ($title != '') echo htmlspecialchars(" - {$title}"); + echo "\n"; + + if ($script) echo "{$script}\n"; + + $plugins_head = array(); + $_params = array('heads' => &$plugins_head); + + $plugin_manager->do_hook('head', $_params); + + foreach($plugins_head as $tag) { + echo $tag; + } + + echo "\n"; + } + } + + /** + * Prints the page footer + * @param $doBody True to output body tag, false otherwise + */ + function printFooter($doBody = true) { + global $_reload_browser, $_reload_drop_database; + global $lang, $_no_bottom_link; + + if ($doBody) { + if (isset($_reload_browser)) $this->printReload(false); + elseif (isset($_reload_drop_database)) $this->printReload(true); + if (!isset($_no_bottom_link)) + echo "".$lang['strgotoppage'].""; + + echo "\n"; + } + echo "\n"; + } + + /** + * Prints the page body. + * @param $doBody True to output body tag, false otherwise + * @param $bodyClass - name of body class + */ + function printBody($bodyClass = '', $doBody = true ) { + global $_no_output; + + if (!isset($_no_output)) { + if ($doBody) { + $bodyClass = htmlspecialchars($bodyClass); + echo "\n"; + } + } + } + + /** + * Outputs JavaScript code that will reload the browser + * @param $database True if dropping a database, false otherwise + */ + function printReload($database) { + echo "\n"; + } + + /** + * Display a link + * @param $link An associative array of link parameters to print + * link = array( + * 'attr' => array( // list of A tag attribute + * 'attrname' => attribute value + * ... + * ), + * 'content' => The link text + * 'fields' => (optionnal) the data from which content and attr's values are obtained + * ); + * the special attribute 'href' might be a string or an array. If href is an array it + * will be generated by getActionUrl. See getActionUrl comment for array format. + */ + function printLink($link) { + + if (! isset($link['fields'])) + $link['fields'] = $_REQUEST; + + $tag = " $value) { + if ($attr == 'href' and is_array($value)) { + $tag.= 'href="'. htmlentities($this->getActionUrl($value, $link['fields'])).'" '; + } + else { + $tag.= htmlentities($attr).'="'. value($value, $link['fields'], 'html') .'" '; + } + } + $tag.= ">". value($link['content'], $link['fields'], 'html') ."\n"; + echo $tag; + } + + /** + * Display a list of links + * @param $links An associative array of links to print. See printLink function for + * the links array format. + * @param $class An optional class or list of classes seprated by a space + * WARNING: This field is NOT escaped! No user should be able to inject something here, use with care. + */ + function printLinksList($links, $class='') { + echo "
    \n"; + foreach ($links as $link) { + echo "\t
  • "; + $this->printLink($link); + echo "
  • \n"; + } + echo "
\n"; + } + + /** + * Display navigation tabs + * @param $tabs The name of current section (Ex: intro, server, ...), or an array with tabs (Ex: sqledit.php doFind function) + * @param $activetab The name of the tab to be highlighted. + */ + function printTabs($tabs, $activetab) { + global $misc, $conf, $data, $lang; + + if (is_string($tabs)) { + $_SESSION['webdbLastTab'][$tabs] = $activetab; + $tabs = $this->getNavTabs($tabs); + } + + echo "\n"; + #echo "
\n"; + + if (count($tabs) > 0) + $width = (int)(100 / count($tabs)).'%'; + else + $width = 1; + + foreach ($tabs as $tab_id => $tab) { + $active = ($tab_id == $activetab) ? ' active' : ''; + + if (!isset($tab['hide']) || $tab['hide'] !== true) { + + $tablink = ''; + + if (isset($tab['icon']) && $icon = $this->icon($tab['icon'])) + $tablink .= "\"{$tab['title']}\""; + + $tablink .= "{$tab['title']}"; + + echo "
\n"; + #echo "\n"; + } + } + + echo "
"; + #echo ""; + + if (isset($tab['help'])) + $this->printHelp($tablink, $tab['help']); + else + echo $tablink; + + echo "
\n"; + #echo "
\n"; + } + + /** + * Retrieve the tab info for a specific tab bar. + * @param $section The name of the tab bar. + */ + function getNavTabs($section) { + global $data, $lang, $conf, $plugin_manager; + + $hide_advanced = ($conf['show_advanced'] === false); + $tabs = array(); + + switch ($section) { + case 'root': + $tabs = array ( + 'intro' => array ( + 'title' => $lang['strintroduction'], + 'url' => "intro.php", + 'icon' => 'Introduction', + ), + 'servers' => array ( + 'title' => $lang['strservers'], + 'url' => "servers.php", + 'icon' => 'Servers', + ), + ); + break; + + case 'server': + $hide_users = !$data->isSuperUser(); + $tabs = array ( + 'databases' => array ( + 'title' => $lang['strdatabases'], + 'url' => 'all_db.php', + 'urlvars' => array('subject' => 'server'), + 'help' => 'pg.database', + 'icon' => 'Databases', + ) + ); + if ($data->hasRoles()) { + $tabs = array_merge($tabs, array( + 'roles' => array ( + 'title' => $lang['strroles'], + 'url' => 'roles.php', + 'urlvars' => array('subject' => 'server'), + 'hide' => $hide_users, + 'help' => 'pg.role', + 'icon' => 'Roles', + ) + )); + } + else { + $tabs = array_merge($tabs, array( + 'users' => array ( + 'title' => $lang['strusers'], + 'url' => 'users.php', + 'urlvars' => array('subject' => 'server'), + 'hide' => $hide_users, + 'help' => 'pg.user', + 'icon' => 'Users', + ), + 'groups' => array ( + 'title' => $lang['strgroups'], + 'url' => 'groups.php', + 'urlvars' => array('subject' => 'server'), + 'hide' => $hide_users, + 'help' => 'pg.group', + 'icon' => 'UserGroups', + ) + )); + } + + $tabs = array_merge($tabs, array( + 'account' => array ( + 'title' => $lang['straccount'], + 'url' => $data->hasRoles() ? 'roles.php' : 'users.php', + 'urlvars' => array('subject' => 'server', 'action' => 'account'), + 'hide' => !$hide_users, + 'help' => 'pg.role', + 'icon' => 'User', + ), + 'tablespaces' => array ( + 'title' => $lang['strtablespaces'], + 'url' => 'tablespaces.php', + 'urlvars' => array('subject' => 'server'), + 'hide' => (!$data->hasTablespaces()), + 'help' => 'pg.tablespace', + 'icon' => 'Tablespaces', + ), + 'export' => array ( + 'title' => $lang['strexport'], + 'url' => 'all_db.php', + 'urlvars' => array('subject' => 'server', 'action' => 'export'), + 'hide' => (!$this->isDumpEnabled()), + 'icon' => 'Export', + ), + )); + break; + case 'database': + $tabs = array ( + 'schemas' => array ( + 'title' => $lang['strschemas'], + 'url' => 'schemas.php', + 'urlvars' => array('subject' => 'database'), + 'help' => 'pg.schema', + 'icon' => 'Schemas', + ), + 'sql' => array ( + 'title' => $lang['strsql'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'sql', 'new' => 1), + 'help' => 'pg.sql', + 'tree' => false, + 'icon' => 'SqlEditor' + ), + 'find' => array ( + 'title' => $lang['strfind'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'find'), + 'tree' => false, + 'icon' => 'Search' + ), + 'variables' => array ( + 'title' => $lang['strvariables'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'variables'), + 'help' => 'pg.variable', + 'tree' => false, + 'icon' => 'Variables', + ), + 'processes' => array ( + 'title' => $lang['strprocesses'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'processes'), + 'help' => 'pg.process', + 'tree' => false, + 'icon' => 'Processes', + ), + 'locks' => array ( + 'title' => $lang['strlocks'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'locks'), + 'help' => 'pg.locks', + 'tree' => false, + 'icon' => 'Key', + ), + 'admin' => array ( + 'title' => $lang['stradmin'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'admin'), + 'tree' => false, + 'icon' => 'Admin', + ), + 'privileges' => array ( + 'title' => $lang['strprivileges'], + 'url' => 'privileges.php', + 'urlvars' => array('subject' => 'database'), + 'hide' => (!isset($data->privlist['database'])), + 'help' => 'pg.privilege', + 'tree' => false, + 'icon' => 'Privileges', + ), + 'languages' => array ( + 'title' => $lang['strlanguages'], + 'url' => 'languages.php', + 'urlvars' => array('subject' => 'database'), + 'hide' => $hide_advanced, + 'help' => 'pg.language', + 'icon' => 'Languages', + ), + 'casts' => array ( + 'title' => $lang['strcasts'], + 'url' => 'casts.php', + 'urlvars' => array('subject' => 'database'), + 'hide' => ($hide_advanced), + 'help' => 'pg.cast', + 'icon' => 'Casts', + ), + 'export' => array ( + 'title' => $lang['strexport'], + 'url' => 'database.php', + 'urlvars' => array('subject' => 'database', 'action' => 'export'), + 'hide' => (!$this->isDumpEnabled()), + 'tree' => false, + 'icon' => 'Export', + ), + ); + break; + + case 'schema': + $tabs = array ( + 'tables' => array ( + 'title' => $lang['strtables'], + 'url' => 'tables.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.table', + 'icon' => 'Tables', + ), + 'views' => array ( + 'title' => $lang['strviews'], + 'url' => 'views.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.view', + 'icon' => 'Views', + ), + 'sequences' => array ( + 'title' => $lang['strsequences'], + 'url' => 'sequences.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.sequence', + 'icon' => 'Sequences', + ), + 'functions' => array ( + 'title' => $lang['strfunctions'], + 'url' => 'functions.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.function', + 'icon' => 'Functions', + ), + 'fulltext' => array ( + 'title' => $lang['strfulltext'], + 'url' => 'fulltext.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.fts', + 'tree' => true, + 'icon' => 'Fts', + ), + 'domains' => array ( + 'title' => $lang['strdomains'], + 'url' => 'domains.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.domain', + 'icon' => 'Domains', + ), + 'aggregates' => array ( + 'title' => $lang['straggregates'], + 'url' => 'aggregates.php', + 'urlvars' => array('subject' => 'schema'), + 'hide' => $hide_advanced, + 'help' => 'pg.aggregate', + 'icon' => 'Aggregates', + ), + 'types' => array ( + 'title' => $lang['strtypes'], + 'url' => 'types.php', + 'urlvars' => array('subject' => 'schema'), + 'hide' => $hide_advanced, + 'help' => 'pg.type', + 'icon' => 'Types', + ), + 'operators' => array ( + 'title' => $lang['stroperators'], + 'url' => 'operators.php', + 'urlvars' => array('subject' => 'schema'), + 'hide' => $hide_advanced, + 'help' => 'pg.operator', + 'icon' => 'Operators', + ), + 'opclasses' => array ( + 'title' => $lang['stropclasses'], + 'url' => 'opclasses.php', + 'urlvars' => array('subject' => 'schema'), + 'hide' => $hide_advanced, + 'help' => 'pg.opclass', + 'icon' => 'OperatorClasses', + ), + 'conversions' => array ( + 'title' => $lang['strconversions'], + 'url' => 'conversions.php', + 'urlvars' => array('subject' => 'schema'), + 'hide' => $hide_advanced, + 'help' => 'pg.conversion', + 'icon' => 'Conversions', + ), + 'privileges' => array ( + 'title' => $lang['strprivileges'], + 'url' => 'privileges.php', + 'urlvars' => array('subject' => 'schema'), + 'help' => 'pg.privilege', + 'tree' => false, + 'icon' => 'Privileges', + ), + 'export' => array ( + 'title' => $lang['strexport'], + 'url' => 'schemas.php', + 'urlvars' => array('subject' => 'schema', 'action' => 'export'), + 'hide' => (!$this->isDumpEnabled()), + 'tree' => false, + 'icon' => 'Export', + ), + ); + if (!$data->hasFTS()) unset($tabs['fulltext']); + break; + + case 'table': + $tabs = array ( + 'columns' => array ( + 'title' => $lang['strcolumns'], + 'url' => 'tblproperties.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'icon' => 'Columns', + 'branch'=> true, + ), + 'browse' => array( + 'title' => $lang['strbrowse'], + 'icon'=>'Columns', + 'url' => 'display.php', + 'urlvars' => array ('subject' => 'table','table' => field('table')), + 'return' => 'table', + 'branch'=> true, + ), + 'select' => array( + 'title' => $lang['strselect'], + 'icon' => 'Search', + 'url' => 'tables.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table'),'action' => 'confselectrows',), + 'help' => 'pg.sql.select', + ), + 'insert'=>array( + 'title' => $lang['strinsert'], + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confinsertrow', + 'table' => field('table') + ), + 'help' => 'pg.sql.insert', + 'icon'=>'Operator' + ), + 'indexes' => array ( + 'title' => $lang['strindexes'], + 'url' => 'indexes.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'help' => 'pg.index', + 'icon' => 'Indexes', + 'branch'=> true, + ), + 'constraints' => array ( + 'title' => $lang['strconstraints'], + 'url' => 'constraints.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'help' => 'pg.constraint', + 'icon' => 'Constraints', + 'branch'=> true, + ), + 'triggers' => array ( + 'title' => $lang['strtriggers'], + 'url' => 'triggers.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'help' => 'pg.trigger', + 'icon' => 'Triggers', + 'branch'=> true, + ), + 'rules' => array ( + 'title' => $lang['strrules'], + 'url' => 'rules.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'help' => 'pg.rule', + 'icon' => 'Rules', + 'branch'=> true, + ), + 'admin' => array ( + 'title' => $lang['stradmin'], + 'url' => 'tables.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table'), 'action' => 'admin'), + 'icon' => 'Admin', + ), + 'info' => array ( + 'title' => $lang['strinfo'], + 'url' => 'info.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'icon' => 'Statistics', + ), + 'privileges' => array ( + 'title' => $lang['strprivileges'], + 'url' => 'privileges.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table')), + 'help' => 'pg.privilege', + 'icon' => 'Privileges', + ), + 'import' => array ( + 'title' => $lang['strimport'], + 'url' => 'tblproperties.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table'), 'action' => 'import'), + 'icon' => 'Import', + 'hide' => false, + ), + 'export' => array ( + 'title' => $lang['strexport'], + 'url' => 'tblproperties.php', + 'urlvars' => array('subject' => 'table', 'table' => field('table'), 'action' => 'export'), + 'icon' => 'Export', + 'hide' => false, + ), + ); + break; + + case 'view': + $tabs = array ( + 'columns' => array ( + 'title' => $lang['strcolumns'], + 'url' => 'viewproperties.php', + 'urlvars' => array('subject' => 'view', 'view' => field('view')), + 'icon' => 'Columns', + 'branch'=> true, + ), + 'browse' => array( + 'title' => $lang['strbrowse'], + 'icon'=>'Columns', + 'url' => 'display.php', + 'urlvars' => array ( + 'action' => 'confselectrows', + 'return' => 'schema', + 'subject' => 'view', + 'view' => field('view') + ), + 'branch'=> true, + ), + 'select' => array( + 'title' => $lang['strselect'], + 'icon' => 'Search', + 'url' => 'views.php', + 'urlvars' => array('action' => 'confselectrows', 'view' => field('view'),), + 'help' => 'pg.sql.select', + ), + 'definition' => array ( + 'title' => $lang['strdefinition'], + 'url' => 'viewproperties.php', + 'urlvars' => array('subject' => 'view', 'view' => field('view'), 'action' => 'definition'), + 'icon' => 'Definition' + ), + 'rules' => array ( + 'title' => $lang['strrules'], + 'url' => 'rules.php', + 'urlvars' => array('subject' => 'view', 'view' => field('view')), + 'help' => 'pg.rule', + 'icon' => 'Rules', + 'branch'=> true, + ), + 'privileges' => array ( + 'title' => $lang['strprivileges'], + 'url' => 'privileges.php', + 'urlvars' => array('subject' => 'view', 'view' => field('view')), + 'help' => 'pg.privilege', + 'icon' => 'Privileges', + ), + 'export' => array ( + 'title' => $lang['strexport'], + 'url' => 'viewproperties.php', + 'urlvars' => array('subject' => 'view', 'view' => field('view'), 'action' => 'export'), + 'icon' => 'Export', + 'hide' => false, + ), + ); + break; + + case 'function': + $tabs = array ( + 'definition' => array ( + 'title' => $lang['strdefinition'], + 'url' => 'functions.php', + 'urlvars' => array( + 'subject' => 'function', + 'function' => field('function'), + 'function_oid' => field('function_oid'), + 'action' => 'properties', + ), + 'icon' => 'Definition', + ), + 'privileges' => array ( + 'title' => $lang['strprivileges'], + 'url' => 'privileges.php', + 'urlvars' => array( + 'subject' => 'function', + 'function' => field('function'), + 'function_oid' => field('function_oid'), + ), + 'icon' => 'Privileges', + ), + ); + break; + + case 'aggregate': + $tabs = array ( + 'definition' => array ( + 'title' => $lang['strdefinition'], + 'url' => 'aggregates.php', + 'urlvars' => array( + 'subject' => 'aggregate', + 'aggrname' => field('aggrname'), + 'aggrtype' => field('aggrtype'), + 'action' => 'properties', + ), + 'icon' => 'Definition', + ), + ); + break; + + case 'role': + $tabs = array ( + 'definition' => array ( + 'title' => $lang['strdefinition'], + 'url' => 'roles.php', + 'urlvars' => array( + 'subject' => 'role', + 'rolename' => field('rolename'), + 'action' => 'properties', + ), + 'icon' => 'Definition', + ), + ); + break; + + case 'popup': + $tabs = array ( + 'sql' => array ( + 'title' => $lang['strsql'], + 'url' => 'sqledit.php', + 'urlvars' => array('subject' => 'schema', 'action' => 'sql'), + 'help' => 'pg.sql', + 'icon' => 'SqlEditor', + ), + 'find' => array ( + 'title' => $lang['strfind'], + 'url' => 'sqledit.php', + 'urlvars' => array('subject' => 'schema', 'action' => 'find'), + 'icon' => 'Search', + ), + ); + break; + + case 'column': + $tabs = array( + 'properties' => array ( + 'title' => $lang['strcolprop'], + 'url' => 'colproperties.php', + 'urlvars' => array( + 'subject' => 'column', + 'table' => field('table'), + 'column' => field('column') + ), + 'icon' => 'Column' + ), + 'privileges' => array ( + 'title' => $lang['strprivileges'], + 'url' => 'privileges.php', + 'urlvars' => array( + 'subject' => 'column', + 'table' => field('table'), + 'column' => field('column') + ), + 'help' => 'pg.privilege', + 'icon' => 'Privileges', + ) + ); + break; + + case 'fulltext': + $tabs = array ( + 'ftsconfigs' => array ( + 'title' => $lang['strftstabconfigs'], + 'url' => 'fulltext.php', + 'urlvars' => array('subject' => 'schema'), + 'hide' => !$data->hasFTS(), + 'help' => 'pg.ftscfg', + 'tree' => true, + 'icon' => 'FtsCfg', + ), + 'ftsdicts' => array ( + 'title' => $lang['strftstabdicts'], + 'url' => 'fulltext.php', + 'urlvars' => array('subject' => 'schema', 'action' => 'viewdicts'), + 'hide' => !$data->hasFTS(), + 'help' => 'pg.ftsdict', + 'tree' => true, + 'icon' => 'FtsDict', + ), + 'ftsparsers' => array ( + 'title' => $lang['strftstabparsers'], + 'url' => 'fulltext.php', + 'urlvars' => array('subject' => 'schema', 'action' => 'viewparsers'), + 'hide' => !$data->hasFTS(), + 'help' => 'pg.ftsparser', + 'tree' => true, + 'icon' => 'FtsParser', + ), + ); + break; + } + + // Tabs hook's place + $plugin_functions_parameters = array( + 'tabs' => &$tabs, + 'section' => $section + ); + $plugin_manager->do_hook('tabs', $plugin_functions_parameters); + + return $tabs; + } + + /** + * Get the URL for the last active tab of a particular tab bar. + */ + function getLastTabURL($section) { + global $data; + + $tabs = $this->getNavTabs($section); + + if (isset($_SESSION['webdbLastTab'][$section]) && isset($tabs[$_SESSION['webdbLastTab'][$section]])) + $tab = $tabs[$_SESSION['webdbLastTab'][$section]]; + else + $tab = reset($tabs); + + return isset($tab['url']) ? $tab : null; + } + + function printTopbar() { + global $lang, $conf, $plugin_manager, $appName, $appVersion, $appLangFiles; + + $server_info = $this->getServerInfo(); + $reqvars = $this->getRequestVars('table'); + + echo "
"; + + /* top right informations when connected */ + + $toplinks = array ( + 'sql' => array ( + 'attr' => array ( + 'href' => array ( + 'url' => 'sqledit.php', + 'urlvars' => array_merge($reqvars, array ( + 'action' => 'sql' + )) + ), + 'target' => "sqledit", + 'id' => 'toplink_sql', + ), + 'content' => $lang['strsql'] + ), + 'history' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'history.php', + 'urlvars' => array_merge($reqvars, array ( + 'action' => 'pophistory' + )) + ), + 'id' => 'toplink_history', + ), + 'content' => $lang['strhistory'] + ), + 'find' => array ( + 'attr' => array ( + 'href' => array ( + 'url' => 'sqledit.php', + 'urlvars' => array_merge($reqvars, array ( + 'action' => 'find' + )) + ), + 'target' => "sqledit", + 'id' => 'toplink_find', + ), + 'content' => $lang['strfind'] + ), + 'logout' => array( + 'attr' => array ( + 'href' => array ( + 'url' => 'servers.php', + 'urlvars' => array ( + 'action' => 'logout', + 'logoutServer' => "{$server_info['host']}:{$server_info['port']}:{$server_info['sslmode']}" + ) + ), + 'id' => 'toplink_logout', + ), + 'content' => $lang['strlogout'] + ) + ); + + // Toplink hook's place + $plugin_functions_parameters = array( + 'toplinks' => &$toplinks + ); + + $plugin_manager->do_hook('toplinks', $plugin_functions_parameters); + + echo ""; + + $sql_window_id = htmlentities('sqledit:'.$_REQUEST['server']); + $history_window_id = htmlentities('history:'.$_REQUEST['server']); + + echo ""; + } + else { + echo "{$appName}{$appVersion}"; + } +/* + echo ""; +*/ + echo "
"; + + if ($server_info && isset($server_info['platform']) && isset($server_info['username'])) { + /* top left informations when connected */ + echo sprintf($lang['strtopbar'], + ''.htmlspecialchars($server_info['platform']).'', + ''.htmlspecialchars((empty($server_info['host'])) ? 'localhost':$server_info['host']).'', + ''.htmlspecialchars($server_info['port']).'', + ''.htmlspecialchars($server_info['username']).''); + + echo ""; + $this->printLinksList($toplinks, 'toplink'); + echo " "; + + echo "
\n"; + echo "\n"; + foreach ($_GET as $key => $val) { + if ($key == 'language') continue; + echo "\n"; + } + echo "
\n"; + + echo "
\n"; + } + + /** + * Display a bread crumb trail. + */ + function printTrail($trail = array()) { + global $lang; + + $this->printTopbar(); + + if (is_string($trail)) { + $trail = $this->getTrail($trail); + } + + echo "
"; + + foreach ($trail as $crumb) { + echo ""; + } + + echo "
"; + $crumblink = "icon($crumb['icon'])) + $crumblink .= "\"{$iconalt}\""; + + $crumblink .= "" . htmlspecialchars($crumb['text']) . ""; + + if (isset($crumb['help'])) + $this->printHelp($crumblink, $crumb['help']); + else + echo $crumblink; + + echo "{$lang['strseparator']}"; + echo "
\n"; + } + + /** + * Create a bread crumb trail of the object hierarchy. + * @param $object The type of object at the end of the trail. + */ + function getTrail($subject = null) { + global $lang, $conf, $data, $appName, $plugin_manager; + + $trail = array(); + $vars = ''; + $done = false; + + $trail['root'] = array( + 'text' => $appName, + 'url' => 'redirect.php?subject=root', + 'icon' => 'Introduction' + ); + + if ($subject == 'root') $done = true; + + if (!$done) { + $server_info = $this->getServerInfo(); + $trail['server'] = array( + 'title' => $lang['strserver'], + 'text' => $server_info['desc'], + 'url' => $this->getHREFSubject('server'), + 'help' => 'pg.server', + 'icon' => 'Server' + ); + } + if ($subject == 'server') $done = true; + + if (isset($_REQUEST['database']) && !$done) { + $trail['database'] = array( + 'title' => $lang['strdatabase'], + 'text' => $_REQUEST['database'], + 'url' => $this->getHREFSubject('database'), + 'help' => 'pg.database', + 'icon' => 'Database' + ); + } elseif (isset($_REQUEST['rolename']) && !$done) { + $trail['role'] = array( + 'title' => $lang['strrole'], + 'text' => $_REQUEST['rolename'], + 'url' => $this->getHREFSubject('role'), + 'help' => 'pg.role', + 'icon' => 'Roles' + ); + } + if ($subject == 'database' || $subject == 'role') $done = true; + + if (isset($_REQUEST['schema']) && !$done) { + $trail['schema'] = array( + 'title' => $lang['strschema'], + 'text' => $_REQUEST['schema'], + 'url' => $this->getHREFSubject('schema'), + 'help' => 'pg.schema', + 'icon' => 'Schema' + ); + } + if ($subject == 'schema') $done = true; + + if (isset($_REQUEST['table']) && !$done) { + $trail['table'] = array( + 'title' => $lang['strtable'], + 'text' => $_REQUEST['table'], + 'url' => $this->getHREFSubject('table'), + 'help' => 'pg.table', + 'icon' => 'Table' + ); + } elseif (isset($_REQUEST['view']) && !$done) { + $trail['view'] = array( + 'title' => $lang['strview'], + 'text' => $_REQUEST['view'], + 'url' => $this->getHREFSubject('view'), + 'help' => 'pg.view', + 'icon' => 'View' + ); + } elseif (isset($_REQUEST['ftscfg']) && !$done) { + $trail['ftscfg'] = array( + 'title' => $lang['strftsconfig'], + 'text' => $_REQUEST['ftscfg'], + 'url' => $this->getHREFSubject('ftscfg'), + 'help' => 'pg.ftscfg.example', + 'icon' => 'Fts' + ); + } + if ($subject == 'table' || $subject == 'view' || $subject == 'ftscfg') $done = true; + + if (!$done && !is_null($subject)) { + switch ($subject) { + case 'function': + $trail[$subject] = array( + 'title' => $lang['str'.$subject], + 'text' => $_REQUEST[$subject], + 'url' => $this->getHREFSubject('function'), + 'help' => 'pg.function', + 'icon' => 'Function' + ); + break; + case 'aggregate': + $trail[$subject] = array( + 'title' => $lang['straggregate'], + 'text' => $_REQUEST['aggrname'], + 'url' => $this->getHREFSubject('aggregate'), + 'help' => 'pg.aggregate', + 'icon' => 'Aggregate' + ); + break; + case 'column': + $trail['column'] = array ( + 'title' => $lang['strcolumn'], + 'text' => $_REQUEST['column'], + 'icon' => 'Column', + 'url' => $this->getHREFSubject('column') + ); + break; + default: + if (isset($_REQUEST[$subject])) { + switch ($subject) { + case 'domain': $icon = 'Domain'; break; + case 'sequence': $icon = 'Sequence'; break; + case 'type': $icon = 'Type'; break; + case 'operator': $icon = 'Operator'; break; + default: $icon = null; break; + } + $trail[$subject] = array( + 'title' => $lang['str'.$subject], + 'text' => $_REQUEST[$subject], + 'help' => 'pg.'.$subject, + 'icon' => $icon, + ); + } + } + } + + // Trail hook's place + $plugin_functions_parameters = array( + 'trail' => &$trail, + 'section' => $subject + ); + + $plugin_manager->do_hook('trail', $plugin_functions_parameters); + + return $trail; + } + + /** + * Display the navlinks + * + * @param $navlinks - An array with the the attributes and values that will be shown. See printLinksList for array format. + * @param $place - Place where the $navlinks are displayed. Like 'display-browse', where 'display' is the file (display.php) + * @param $env - Associative array of defined variables in the scope of the caller. + * Allows to give some environnement details to plugins. + * and 'browse' is the place inside that code (doBrowse). + */ + function printNavLinks($navlinks, $place, $env = array()) { + global $plugin_manager; + + // Navlinks hook's place + $plugin_functions_parameters = array( + 'navlinks' => &$navlinks, + 'place' => $place, + 'env' => $env + ); + $plugin_manager->do_hook('navlinks', $plugin_functions_parameters); + + if (count($navlinks) > 0) { + $this->printLinksList($navlinks, 'navlink'); + } + } + + + /** + * Do multi-page navigation. Displays the prev, next and page options. + * @param $page - the page currently viewed + * @param $pages - the maximum number of pages + * @param $gets - the parameters to include in the link to the wanted page + * @param $max_width - the number of pages to make available at any one time (default = 20) + */ + function printPages($page, $pages, $gets, $max_width = 20) { + global $lang; + + $window = 10; + + if ($page < 0 || $page > $pages) return; + if ($pages < 0) return; + if ($max_width <= 0) return; + + unset ($gets['page']); + $url = http_build_query($gets); + + if ($pages > 1) { + echo "

\n"; + if ($page != 1) { + echo "{$lang['strfirst']}\n"; + $temp = $page - 1; + echo "{$lang['strprev']}\n"; + } + + if ($page <= $window) { + $min_page = 1; + $max_page = min(2 * $window, $pages); + } + elseif ($page > $window && $pages >= $page + $window) { + $min_page = ($page - $window) + 1; + $max_page = $page + $window; + } + else { + $min_page = ($page - (2 * $window - ($pages - $page))) + 1; + $max_page = $pages; + } + + // Make sure min_page is always at least 1 + // and max_page is never greater than $pages + $min_page = max($min_page, 1); + $max_page = min($max_page, $pages); + + for ($i = $min_page; $i <= $max_page; $i++) { + #if ($i != $page) echo "$i\n"; + if ($i != $page) echo "$i\n"; + else echo "$i\n"; + } + if ($page != $pages) { + $temp = $page + 1; + echo "{$lang['strnext']}\n"; + echo "{$lang['strlast']}\n"; + } + echo "

\n"; + } + } + + /** + * Displays link to the context help. + * @param $str - the string that the context help is related to (already escaped) + * @param $help - help section identifier + */ + function printHelp($str, $help) { + global $lang, $data; + + echo $str; + if ($help) { + echo "{$lang['strhelpicon']}"; + } + } + + /** + * Outputs JavaScript to set default focus + * @param $object eg. forms[0].username + */ + function setFocus($object) { + echo "\n"; + } + + /** + * Outputs JavaScript to set the name of the browser window. + * @param $name the window name + * @param $addServer if true (default) then the server id is + * attached to the name. + */ + function setWindowName($name, $addServer = true) { + echo "\n"; + } + + /** + * Converts a PHP.INI size variable to bytes. Taken from publically available + * function by Chris DeRose, here: http://www.php.net/manual/en/configuration.directives.php#ini.file-uploads + * @param $strIniSize The PHP.INI variable + * @return size in bytes, false on failure + */ + function inisizeToBytes($strIniSize) { + // This function will take the string value of an ini 'size' parameter, + // and return a double (64-bit float) representing the number of bytes + // that the parameter represents. Or false if $strIniSize is unparseable. + $a_IniParts = array(); + + if (!is_string($strIniSize)) + return false; + + if (!preg_match ('/^(\d+)([bkm]*)$/i', $strIniSize,$a_IniParts)) + return false; + + $nSize = (double) $a_IniParts[1]; + $strUnit = strtolower($a_IniParts[2]); + + switch($strUnit) { + case 'm': + return ($nSize * (double) 1048576); + case 'k': + return ($nSize * (double) 1024); + case 'b': + default: + return $nSize; + } + } + + /** + * Returns URL given an action associative array. + * NOTE: this function does not html-escape, only url-escape + * @param $action An associative array of the follow properties: + * 'url' => The first part of the URL (before the ?) + * 'urlvars' => Associative array of (URL variable => field name) + * these are appended to the URL + * @param $fields Field data from which 'urlfield' and 'vars' are obtained. + */ + function getActionUrl(&$action, &$fields) { + $url = value($action['url'], $fields); + + if ($url === false) return ''; + + if (!empty($action['urlvars'])) { + $urlvars = value($action['urlvars'], $fields); + } else { + $urlvars = array(); + } + + /* set server, database and schema parameter if not presents */ + if (isset($urlvars['subject'])) + $subject = value($urlvars['subject'], $fields); + else + $subject = ''; + + if (isset($_REQUEST['server']) and !isset($urlvars['server']) and $subject != 'root') { + $urlvars['server'] = $_REQUEST['server']; + if (isset($_REQUEST['database']) and !isset($urlvars['database']) and $subject != 'server') { + $urlvars['database'] = $_REQUEST['database']; + if (isset($_REQUEST['schema']) and !isset($urlvars['schema']) and $subject != 'database') { + $urlvars['schema'] = $_REQUEST['schema']; + } + } + } + + $sep = '?'; + foreach ($urlvars as $var => $varfield) { + $url .= $sep . value_url($var, $fields) . '=' . value_url($varfield, $fields); + $sep = '&'; + } + + return $url; + } + + function getRequestVars($subject = '') { + $v = array(); + if (!empty($subject)) + $v['subject'] = $subject; + if (isset($_REQUEST['server']) && $subject != 'root') { + $v['server'] = $_REQUEST['server']; + if (isset($_REQUEST['database']) && $subject != 'server') { + $v['database'] = $_REQUEST['database']; + if (isset($_REQUEST['schema']) && $subject != 'database') { + $v['schema'] = $_REQUEST['schema']; + } + } + } + return $v; + } + + function printUrlVars(&$vars, &$fields) { + foreach ($vars as $var => $varfield) { + echo "{$var}=", urlencode($fields[$varfield]), "&"; + } + } + + /** + * Display a table of data. + * @param $tabledata A set of data to be formatted, as returned by $data->getDatabases() etc. + * @param $columns An associative array of columns to be displayed: + * $columns = array( + * column_id => array( + * 'title' => Column heading, + * 'class' => The class to apply on the column cells, + * 'field' => Field name for $tabledata->fields[...], + * 'help' => Help page for this column, + * ), ... + * ); + * @param $actions Actions that can be performed on each object: + * $actions = array( + * * multi action support + * * parameters are serialized for each entries and given in $_REQUEST['ma'] + * 'multiactions' => array( + * 'keycols' => Associative array of (URL variable => field name), // fields included in the form + * 'url' => URL submission, + * 'default' => Default selected action in the form. + * if null, an empty action is added & selected + * ), + * * actions * + * action_id => array( + * 'title' => Action heading, + * 'url' => Static part of URL. Often we rely + * relative urls, usually the page itself (not '' !), or just a query string, + * 'vars' => Associative array of (URL variable => field name), + * 'multiaction' => Name of the action to execute. + * Add this action to the multi action form + * ), ... + * ); + * @param $place Place where the $actions are displayed. Like 'display-browse', where 'display' is the file (display.php) + * and 'browse' is the place inside that code (doBrowse). + * @param $nodata (optional) Message to display if data set is empty. + * @param $pre_fn (optional) Name of a function to call for each row, + * it will be passed two params: $rowdata and $actions, + * it may be used to derive new fields or modify actions. + * It can return an array of actions specific to the row, + * or if nothing is returned then the standard actions are used. + * (see tblproperties.php and constraints.php for examples) + * The function must not must not store urls because + * they are relative and won't work out of context. + */ + function printTable(&$tabledata, &$columns, &$actions, $place, $nodata = null, $pre_fn = null) { + global $data, $conf, $misc, $lang, $plugin_manager; + + // Action buttons hook's place + $plugin_functions_parameters = array( + 'actionbuttons' => &$actions, + 'place' => $place + ); + $plugin_manager->do_hook('actionbuttons', $plugin_functions_parameters); + + if ($has_ma = isset($actions['multiactions'])) + $ma = $actions['multiactions']; + unset($actions['multiactions']); + + if ($tabledata->recordCount() > 0) { + + // Remove the 'comment' column if they have been disabled + if (!$conf['show_comments']) { + unset($columns['comment']); + } + + if (isset($columns['comment'])) { + // Uncomment this for clipped comments. + // TODO: This should be a user option. + //$columns['comment']['params']['clip'] = true; + } + + if ($has_ma) { + echo "\n"; + echo "
\n"; + if (isset($ma['vars'])) + foreach ($ma['vars'] as $k => $v) + echo ""; + } + + echo "\n"; + echo "\n"; + + // Handle cases where no class has been passed + if (isset($column['class'])) { + $class = $column['class'] !== '' ? " class=\"{$column['class']}\"":''; + } else { + $class = ''; + } + + // Display column headings + if ($has_ma) echo ""; + foreach ($columns as $column_id => $column) { + switch ($column_id) { + case 'actions': + if (sizeof($actions) > 0) echo "\n"; + break; + default: + echo "\n"; + break; + } + } + echo "\n"; + + // Display table rows + $i = 0; + while (!$tabledata->EOF) { + $id = ($i % 2) + 1; + + unset($alt_actions); + if (!is_null($pre_fn)) $alt_actions = $pre_fn($tabledata, $actions); + if (!isset($alt_actions)) $alt_actions =& $actions; + + echo "\n"; + if ($has_ma) { + foreach ($ma['keycols'] as $k => $v) + $a[$k] = $tabledata->fields[$v]; + echo "\n"; + } + + foreach ($columns as $column_id => $column) { + + // Apply default values for missing parameters + if (isset($column['url']) && !isset($column['vars'])) $column['vars'] = array(); + + switch ($column_id) { + case 'actions': + foreach ($alt_actions as $action) { + if (isset($action['disable']) && $action['disable'] === true) { + echo "\n"; + } else { + echo "\n"; + } + } + break; + case 'comment': + echo ""; + break; + default: + echo ""; + $val = value($column['field'], $tabledata->fields); + if (!is_null($val)) { + if (isset($column['url'])) { + echo "printUrlVars($column['vars'], $tabledata->fields); + echo "\">"; + } + $type = isset($column['type']) ? $column['type'] : null; + $params = isset($column['params']) ? $column['params'] : array(); + echo $misc->printVal($val, $type, $params); + if (isset($column['url'])) echo ""; + } + + echo "\n"; + break; + } + } + echo "\n"; + + $tabledata->moveNext(); + $i++; + } + echo "
{$column['title']}"; + if (isset($column['help'])) + $this->printHelp($column['title'], $column['help']); + else + echo $column['title']; + echo "
"; + echo ""; + echo ""; + $action['fields'] = $tabledata->fields; + $this->printLink($action); + echo ""; + $val = value($column['field'], $tabledata->fields); + if (!is_null($val)) { + echo htmlentities($val); + } + echo "
\n"; + + // Multi action table footer w/ options & [un]check'em all + if ($has_ma) { + // if default is not set or doesn't exist, set it to null + if (!isset($ma['default']) || !isset($actions[$ma['default']])) + $ma['default'] = null; + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['stractionsonmultiplelines']}
"; + echo "{$lang['strselectall']} / "; + echo "{$lang['strunselectall']} ---> \n"; + echo "\t\n"; + echo "\n"; + echo $misc->form; + echo "
\n"; + echo '
'; + }; + + return true; + } else { + if (!is_null($nodata)) { + echo "

{$nodata}

\n"; + } + return false; + } + } + + /** Produce XML data for the browser tree + * @param $treedata A set of records to populate the tree. + * @param $attrs Attributes for tree items + * 'text' - the text for the tree node + * 'icon' - an icon for node + * 'openIcon' - an alternative icon when the node is expanded + * 'toolTip' - tool tip text for the node + * 'action' - URL to visit when single clicking the node + * 'iconAction' - URL to visit when single clicking the icon node + * 'branch' - URL for child nodes (tree XML) + * 'expand' - the action to return XML for the subtree + * 'nodata' - message to display when node has no children + * @param $section The section where the branch is linked in the tree + */ + function printTree(&$_treedata, &$attrs, $section) { + global $plugin_manager; + + $treedata = array(); + + if ($_treedata->recordCount() > 0) { + while (!$_treedata->EOF) { + $treedata[] = $_treedata->fields; + $_treedata->moveNext(); + } + } + + $tree_params = array( + 'treedata' => &$treedata, + 'attrs' => &$attrs, + 'section' => $section + ); + + $plugin_manager->do_hook('tree', $tree_params); + + $this->printTreeXML($treedata, $attrs); + } + + /** Produce XML data for the browser tree + * @param $treedata A set of records to populate the tree. + * @param $attrs Attributes for tree items + * 'text' - the text for the tree node + * 'icon' - an icon for node + * 'openIcon' - an alternative icon when the node is expanded + * 'toolTip' - tool tip text for the node + * 'action' - URL to visit when single clicking the node + * 'iconAction' - URL to visit when single clicking the icon node + * 'branch' - URL for child nodes (tree XML) + * 'expand' - the action to return XML for the subtree + * 'nodata' - message to display when node has no children + */ + function printTreeXML(&$treedata, &$attrs) { + global $conf, $lang; + + header("Content-Type: text/xml; charset=UTF-8"); + header("Cache-Control: no-cache"); + + echo "\n"; + + echo "\n"; + + if (count($treedata) > 0) { + foreach($treedata as $rec) { + + echo "icon(value($attrs['icon'], $rec)); + echo value_xml_attr('icon', $icon, $rec); + echo value_xml_attr('iconaction', $attrs['iconAction'], $rec); + + if (!empty($attrs['openicon'])) { + $icon = $this->icon(value($attrs['openIcon'], $rec)); + } + echo value_xml_attr('openicon', $icon, $rec); + + echo value_xml_attr('tooltip', $attrs['toolTip'], $rec); + + echo " />\n"; + } + } else { + $msg = isset($attrs['nodata']) ? $attrs['nodata'] : $lang['strnoobjects']; + echo "icon('ObjectNotFound'), "\" />\n"; + } + + echo "\n"; + } + + function adjustTabsForTree(&$tabs) { + include_once('./classes/ArrayRecordSet.php'); + + foreach ($tabs as $i => $tab) { + if ((isset($tab['hide']) && $tab['hide'] === true) || (isset($tab['tree']) && $tab['tree'] === false)) { + unset($tabs[$i]); + } + } + return new ArrayRecordSet($tabs); + } + + function icon($icon) { + if (is_string($icon)) { + global $conf; + $path = "images/themes/{$conf['theme']}/{$icon}"; + if (file_exists($path.'.png')) return $path.'.png'; + if (file_exists($path.'.gif')) return $path.'.gif'; + $path = "images/themes/default/{$icon}"; + if (file_exists($path.'.png')) return $path.'.png'; + if (file_exists($path.'.gif')) return $path.'.gif'; + } + else { + // Icon from plugins + $path = "plugins/{$icon[0]}/images/{$icon[1]}"; + if (file_exists($path.'.png')) return $path.'.png'; + if (file_exists($path.'.gif')) return $path.'.gif'; + } + return ''; + } + + /** + * Function to escape command line parameters + * @param $str The string to escape + * @return The escaped string + */ + function escapeShellArg($str) { + global $data, $lang; + + if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') { + // Due to annoying PHP bugs, shell arguments cannot be escaped + // (command simply fails), so we cannot allow complex objects + // to be dumped. + if (preg_match('/^[_.[:alnum:]]+$/', $str)) + return $str; + else { + echo $lang['strcannotdumponwindows']; + exit; + } + } + else + return escapeshellarg($str); + } + + /** + * Function to escape command line programs + * @param $str The string to escape + * @return The escaped string + */ + function escapeShellCmd($str) { + global $data; + + if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') { + $data->fieldClean($str); + return '"' . $str . '"'; + } + else + return escapeshellcmd($str); + } + + /** + * Get list of servers' groups if existing in the conf + * @return a recordset of servers' groups + */ + function getServersGroups($recordset = false, $group_id = false) { + global $conf, $lang; + $grps = array(); + + if (isset($conf['srv_groups'])) { + foreach ($conf['srv_groups'] as $i => $group) { + if ( + (($group_id === false) and (! isset($group['parents']))) /* root */ + or ( + ($group_id !== false) + and isset($group['parents']) + and in_array($group_id,explode(',', + preg_replace('/\s/', '', $group['parents']) + )) + ) /* nested group */ + ) + $grps[$i] = array( + 'id' => $i, + 'desc' => $group['desc'], + 'icon' => 'Servers', + 'action' => url('servers.php', + array( + 'group' => field('id') + ) + ), + 'branch' => url('servers.php', + array( + 'action' => 'tree', + 'group' => $i + ) + ) + ); + } + + if ($group_id === false) + $grps['all'] = array( + 'id' => 'all', + 'desc' => $lang['strallservers'], + 'icon' => 'Servers', + 'action' => url('servers.php', + array( + 'group' => field('id') + ) + ), + 'branch' => url('servers.php', + array( + 'action' => 'tree', + 'group' => 'all' + ) + ) + ); + } + + if ($recordset) { + include_once('./classes/ArrayRecordSet.php'); + return new ArrayRecordSet($grps); + } + + return $grps; + } + + + /** + * Get list of servers + * @param $recordset return as RecordSet suitable for printTable if true, + * otherwise just return an array. + * @param $group a group name to filter the returned servers using $conf[srv_groups] + */ + function getServers($recordset = false, $group = false) { + global $conf; + + $logins = isset($_SESSION['webdbLogin']) && is_array($_SESSION['webdbLogin']) ? $_SESSION['webdbLogin'] : array(); + $srvs = array(); + + if (($group !== false) and ($group !== 'all')) + if (isset($conf['srv_groups'][$group]['servers'])) + $group = array_fill_keys(explode(',', preg_replace('/\s/', '', + $conf['srv_groups'][$group]['servers'])), 1); + else + $group = ''; + + foreach($conf['servers'] as $idx => $info) { + $server_id = $info['host'].':'.$info['port'].':'.$info['sslmode']; + if (($group === false) + or (isset($group[$idx])) + or ($group === 'all') + ) { + $server_id = $info['host'].':'.$info['port'].':'.$info['sslmode']; + + if (isset($logins[$server_id])) $srvs[$server_id] = $logins[$server_id]; + else $srvs[$server_id] = $info; + + $srvs[$server_id]['id'] = $server_id; + $srvs[$server_id]['action'] = url('redirect.php', + array( + 'subject' => 'server', + 'server' => field('id') + ) + ); + if (isset($srvs[$server_id]['username'])) { + $srvs[$server_id]['icon'] = 'Server'; + $srvs[$server_id]['branch'] = url('all_db.php', + array( + 'action' => 'tree', + 'subject' => 'server', + 'server' => field('id') + ) + ); + } + else { + $srvs[$server_id]['icon'] = 'DisconnectedServer'; + $srvs[$server_id]['branch'] = false; + } + } + } + + function _cmp_desc($a, $b) { + return strcmp($a['desc'], $b['desc']); + } + uasort($srvs, '_cmp_desc'); + + if ($recordset) { + include_once('./classes/ArrayRecordSet.php'); + return new ArrayRecordSet($srvs); + } + return $srvs; + } + + /** + * Validate and retrieve information on a server. + * If the parameter isn't supplied then the currently + * connected server is returned. + * @param $server_id A server identifier (host:port) + * @return An associative array of server properties + */ + function getServerInfo($server_id = null) { + global $conf, $_reload_browser, $lang; + + if ($server_id === null && isset($_REQUEST['server'])) + $server_id = $_REQUEST['server']; + + // Check for the server in the logged-in list + if (isset($_SESSION['webdbLogin'][$server_id])) + return $_SESSION['webdbLogin'][$server_id]; + + // Otherwise, look for it in the conf file + foreach($conf['servers'] as $idx => $info) { + if ($server_id == $info['host'].':'.$info['port'].':'.$info['sslmode']) { + // Automatically use shared credentials if available + if (!isset($info['username']) && isset($_SESSION['sharedUsername'])) { + $info['username'] = $_SESSION['sharedUsername']; + $info['password'] = $_SESSION['sharedPassword']; + $_reload_browser = true; + $this->setServerInfo(null, $info, $server_id); + } + + return $info; + } + } + + if ($server_id === null){ + return null; + } else { + // Unable to find a matching server, are we being hacked? + echo $lang['strinvalidserverparam']; + exit; + } + } + + /** + * Set server information. + * @param $key parameter name to set, or null to replace all + * params with the assoc-array in $value. + * @param $value the new value, or null to unset the parameter + * @param $server_id the server identifier, or null for current + * server. + */ + function setServerInfo($key, $value, $server_id = null) + { + if ($server_id === null && isset($_REQUEST['server'])) + $server_id = $_REQUEST['server']; + + if ($key === null) { + if ($value === null) + unset($_SESSION['webdbLogin'][$server_id]); + else + $_SESSION['webdbLogin'][$server_id] = $value; + } else { + if ($value === null) + unset($_SESSION['webdbLogin'][$server_id][$key]); + else + $_SESSION['webdbLogin'][$server_id][$key] = $value; + } + } + + /** + * Set the current schema + * @param $schema The schema name + * @return 0 on success + * @return $data->seSchema() on error + */ + function setCurrentSchema($schema) { + global $data; + + $status = $data->setSchema($schema); + if($status != 0) + return $status; + + $_REQUEST['schema'] = $schema; + $this->setHREF(); + return 0; + } + + /** + * Save the given SQL script in the history + * of the database and server. + * @param $script the SQL script to save. + */ + function saveScriptHistory($script) { + list($usec, $sec) = explode(' ', microtime()); + $time = ((float)$usec + (float)$sec); + $_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']]["$time"] = array( + 'query' => $script, + 'paginate' => (!isset($_REQUEST['paginate'])? 'f':'t'), + 'queryid' => $time, + ); + } + + /* + * Output dropdown list to select server and + * databases form the popups windows. + * @param $onchange Javascript action to take when selections change. + */ + function printConnection($onchange) { + global $data, $lang, $misc; + + echo "
\n"; + echo ""; + echo ": \n\n"; + + // Get the list of all databases + $databases = $data->getDatabases(); + + if ($databases->recordCount() > 0) { + + echo "\n"; + } + else { + $server_info = $misc->getServerInfo(); + echo "\n"; + } + + echo "
\n"; + } + + /** + * returns an array representing FKs definition for a table, sorted by fields + * or by constraint. + * @param $table The table to retrieve FK contraints from + * @returns the array of FK definition: + * array( + * 'byconstr' => array( + * constrain id => array( + * confrelid => foreign relation oid + * f_schema => foreign schema name + * f_table => foreign table name + * pattnums => array of parent's fields nums + * pattnames => array of parent's fields names + * fattnames => array of foreign attributes names + * ) + * ), + * 'byfield' => array( + * attribute num => array (constraint id, ...) + * ), + * 'code' => HTML/js code to include in the page for auto-completion + * ) + **/ + function getAutocompleteFKProperties($table) { + global $data; + + $fksprops = array( + 'byconstr' => array(), + 'byfield' => array(), + 'code' => '' + ); + + $constrs = $data->getConstraintsWithFields($table); + + if (!$constrs->EOF) { + $conrelid = $constrs->fields['conrelid']; + while(!$constrs->EOF) { + if ($constrs->fields['contype'] == 'f') { + if (!isset($fksprops['byconstr'][$constrs->fields['conid']])) { + $fksprops['byconstr'][$constrs->fields['conid']] = array ( + 'confrelid' => $constrs->fields['confrelid'], + 'f_table' => $constrs->fields['f_table'], + 'f_schema' => $constrs->fields['f_schema'], + 'pattnums' => array(), + 'pattnames' => array(), + 'fattnames' => array() + ); + } + + $fksprops['byconstr'][$constrs->fields['conid']]['pattnums'][] = $constrs->fields['p_attnum']; + $fksprops['byconstr'][$constrs->fields['conid']]['pattnames'][] = $constrs->fields['p_field']; + $fksprops['byconstr'][$constrs->fields['conid']]['fattnames'][] = $constrs->fields['f_field']; + + if (!isset($fksprops['byfield'][$constrs->fields['p_attnum']])) + $fksprops['byfield'][$constrs->fields['p_attnum']] = array(); + $fksprops['byfield'][$constrs->fields['p_attnum']][] = $constrs->fields['conid']; + } + $constrs->moveNext(); + } + + $fksprops['code'] = "\n"; + + $fksprops['code'] .= '
'; + $fksprops['code'] .= '
'; + $fksprops['code'] .= ''; + } + + else /* we have no foreign keys on this table */ + return false; + + return $fksprops; + } + } +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Plugin.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Plugin.php new file mode 100644 index 00000000..e3bea046 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/Plugin.php @@ -0,0 +1,68 @@ +get_name(); + + if (file_exists("{$plugin_directory}/lang")) { + if (file_exists("{$plugin_directory}/lang/english.php")) { + require_once("{$plugin_directory}/lang/english.php"); + } + + if (file_exists("{$plugin_directory}/lang/{$language}.php")) { + include_once("{$plugin_directory}/lang/{$language}.php"); + } + + $this->lang = $plugin_lang; + } + + if (file_exists("{$plugin_directory}/conf/config.inc.php")) { + include_once("{$plugin_directory}/conf/config.inc.php"); + $this->conf = $plugin_conf; + } + } + + abstract function get_hooks(); + + abstract function get_actions(); + + /** + * In some page (display, sql, ...), a "return" link will show up if + * $_GET['return'] = 'plugin' is given. The "get_subject_params" method + * of the plugin designated by $_GET['plugin'] is then called to add needed + * parameters in the href URL. + * This method can returns parameters based on context from $_REQUEST. See + * plugin Report as example. + * + * @returns an associative of parameter_name => value + */ + function get_subject_params() { + $vars = array(); + return $vars; + } + + /** + * Get the plugin name, that will be used as identification + * @return $name + */ + function get_name() { + return $this->name; + } + + /** + * Returns the structure suitable for the method $misc->icon() to print + * the given icon. + * @param $img - The icon name + * @return the information suitable for the method $misc->icon() + */ + function icon($img) { + return array($this->name, $img); + } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/PluginManager.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/PluginManager.php new file mode 100644 index 00000000..981266e0 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/PluginManager.php @@ -0,0 +1,137 @@ +add_plugin($plugin); + } + catch (Exception $e) { + continue; + } + } else { + printf($lang['strpluginnotfound']."\t\n", $activated_plugin); + exit; + } + } + } + + /** + * Add a plugin in the list of plugins to manage + * @param $plugin - Instance from plugin + */ + function add_plugin($plugin) { + global $lang; + + //The $plugin_name is the identification of the plugin. + //Example: PluginExample is the identification for PluginExample + //It will be used to get a specific plugin from the plugins_list. + $plugin_name = $plugin->get_name(); + $this->plugins_list[$plugin_name] = $plugin; + + //Register the plugin's functions + $hooks = $plugin->get_hooks(); + foreach ($hooks as $hook => $functions) { + if (!in_array($hook, $this->available_hooks)) { + printf($lang['strhooknotfound']."\t\n", $hook); + exit; + } + $this->hooks[$hook][$plugin_name] = $functions; + } + + //Register the plugin's actions + $actions = $plugin->get_actions(); + $this->actions[$plugin_name] = $actions; + } + + function getPlugin($plugin) { + if (isset($this->plugins_list[$plugin])) + return $this->plugins_list[$plugin]; + + return null; + } + + /** + * Execute the plugins hook functions when needed. + * @param $hook - The place where the function will be called + * @param $function_args - An array reference with arguments to give to called function + */ + function do_hook($hook, &$function_args) { + if (isset($this->hooks[$hook])) { + foreach ($this->hooks[$hook] as $plugin_name => $functions) { + $plugin = $this->plugins_list[$plugin_name]; + foreach ($functions as $function) { + if (method_exists($plugin, $function)) { + call_user_func(array($plugin, $function), $function_args); + } + } + } + } + } + + /** + * Execute a plugin's action + * @param $plugin_name - The plugin name. + * @param $action - action that will be executed. + */ + function do_action($plugin_name, $action) { + global $lang; + + if (!isset($this->plugins_list[$plugin_name])) { + // Show an error and stop the application + printf($lang['strpluginnotfound']."\t\n", $plugin_name); + exit; + } + $plugin = $this->plugins_list[$plugin_name]; + + // Check if the plugin's method exists and if this method is an declared action. + if (method_exists($plugin, $action) and in_array($action, $this->actions[$plugin_name])) { + call_user_func(array($plugin, $action)); + } + else { + // Show an error and stop the application + printf($lang['stractionnotfound']."\t\n", $action, $plugin_name); + exit; + } + } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/class.select.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/class.select.php new file mode 100644 index 00000000..057c8d6e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/class.select.php @@ -0,0 +1,217 @@ +_element = $this->is_element(); + + } + + function set_style($style) { + $this->set_attribute('style', $style); + } + + function set_class($class) { + $this->set_attribute('class', $class); + } + + + function is_element() { + return + str_replace('xhtml_', '', strtolower(get_class($this))); + } + + /** + * Private function generates xhtml + * @access private + */ + function _html() { + $this->_htmlcode = "<"; + foreach ($this->_attributeCollection as $attribute => $value) { + if (!empty($value)) $this->_htmlcode .= " {$attribute}=\"{$value}\""; + } + $this->_htmlcode .= "/>"; + + return $this->_htmlcode; + } + + /** + * Returns xhtml code + * + */ + function fetch() { + return $this->_html(); + } + /** + * Echoes xhtml + * + */ + function show() { + echo $this->fetch(); + } + + function set_attribute($attr, $value) { + $this->_attributes[$attr] = $value; + } + + +} + +/** +* XHtmlElement +* +* Used to generate Xhtml-Code for xhtml elements +* that can contain child elements +* +* +*/ +class XHtmlElement extends XHtmlSimpleElement { + var $_text = null; + var $_htmlcode = ""; + var $_siblings = array(); + + function XHtmlElement($text = null) { + XHtmlSimpleElement::XHtmlSimpleElement(); + + if ($text) $this->set_text($text); + } + + /* + * Adds an xhtml child to element + * + * @param XHtmlElement The element to become a child of element + */ + function add(&$object) { + array_push($this->_siblings, $object); + } + + + /* + * The CDATA section of Element + * + * @param string Text + */ + function set_text($text) { + if ($text) $this->_text = htmlspecialchars($text); + } + + function fetch() { + return $this->_html(); + } + + + function _html() { + + $this->_htmlcode = "<{$this->_element}"; + foreach ($this->_attributes as $attribute =>$value) { + if (!empty($value)) $this->_htmlcode .= " {$attribute} =\"{$value}\""; + } + $this->_htmlcode .= ">"; + + + if ($this->_text) { + $this->_htmlcode .= $this->_text; + } + + foreach ($this->_siblings as $obj) { + $this->_htmlcode .= $obj->fetch(); + } + + $this->_htmlcode .= "_element}>"; + + return $this->_htmlcode; + } + + /* + * Returns siblings of Element + * + */ + function get_siblings() { + return $this->_siblings; + } + + function has_siblings() { + return (count($this->_siblings) != 0); + } +} + +class XHTML_Button extends XHtmlElement { + function XHTML_Button ($name, $text = null) { + parent::XHtmlElement(); + + $this->set_attribute("name", $name); + + if ($text) $this->set_text($text); + } +} + + +class XHTML_Option extends XHtmlElement { + function XHTML_Option($text, $value = null) { + XHtmlElement::XHtmlElement(null); + $this->set_text($text); + } +} + + +class XHTML_Select extends XHTMLElement { + var $_data; + + function XHTML_Select ($name, $multiple = false, $size = null) { + XHtmlElement::XHtmlElement(); + + $this->set_attribute("name", $name); + if ($multiple) $this->set_attribute("multiple","multiple"); + if ($size) $this->set_attribute("size",$size); + + + } + + function set_data(&$data, $delim = ",") { + switch (gettype($data)) { + case "string": + $this->_data = explode($delim, $data); + break; + case "array": + $this->_data = $data; + break; + + default: + break; + } + } + + function fetch() { + if (isset($this->_data) && $this->_data) { + foreach ($this->_data as $value) { $this->add(new XHTML_Option($value)); } + } + return parent::fetch(); + } + +} + + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/ADODB_base.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/ADODB_base.php new file mode 100644 index 00000000..816d6930 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/ADODB_base.php @@ -0,0 +1,359 @@ +conn = $conn; + } + + /** + * Turns on or off query debugging + * @param $debug True to turn on debugging, false otherwise + */ + function setDebug($debug) { + $this->conn->debug = $debug; + } + + /** + * Cleans (escapes) a string + * @param $str The string to clean, by reference + * @return The cleaned string + */ + function clean(&$str) { + $str = addslashes($str); + return $str; + } + + /** + * Cleans (escapes) an object name (eg. table, field) + * @param $str The string to clean, by reference + * @return The cleaned string + */ + function fieldClean(&$str) { + $str = str_replace('"', '""', $str); + return $str; + } + + /** + * Cleans (escapes) an array + * @param $arr The array to clean, by reference + * @return The cleaned array + */ + function arrayClean(&$arr) { + reset($arr); + while(list($k, $v) = each($arr)) + $arr[$k] = addslashes($v); + return $arr; + } + + /** + * Executes a query on the underlying connection + * @param $sql The SQL query to execute + * @return A recordset + */ + function execute($sql) { + // Execute the statement + $rs = $this->conn->Execute($sql); + + // If failure, return error value + return $this->conn->ErrorNo(); + } + + /** + * Closes the connection the database class + * relies on. + */ + function close() { + $this->conn->close(); + } + + /** + * Retrieves a ResultSet from a query + * @param $sql The SQL statement to be executed + * @return A recordset + */ + function selectSet($sql) { + // Execute the statement + $rs = $this->conn->Execute($sql); + + if (!$rs) return $this->conn->ErrorNo(); + + return $rs; + } + + /** + * Retrieves a single value from a query + * + * @@ assumes that the query will return only one row - returns field value in the first row + * + * @param $sql The SQL statement to be executed + * @param $field The field name to be returned + * @return A single field value + * @return -1 No rows were found + */ + function selectField($sql, $field) { + // Execute the statement + $rs = $this->conn->Execute($sql); + + // If failure, or no rows returned, return error value + if (!$rs) return $this->conn->ErrorNo(); + elseif ($rs->RecordCount() == 0) return -1; + + return $rs->fields[$field]; + } + + /** + * Delete from the database + * @param $table The name of the table + * @param $conditions (array) A map of field names to conditions + * @param $schema (optional) The table's schema + * @return 0 success + * @return -1 on referential integrity violation + * @return -2 on no rows deleted + */ + function delete($table, $conditions, $schema = '') { + $this->fieldClean($table); + + reset($conditions); + + if (!empty($schema)) { + $this->fieldClean($schema); + $schema = "\"{$schema}\"."; + } + + // Build clause + $sql = ''; + while(list($key, $value) = each($conditions)) { + $this->clean($key); + $this->clean($value); + if ($sql) $sql .= " AND \"{$key}\"='{$value}'"; + else $sql = "DELETE FROM {$schema}\"{$table}\" WHERE \"{$key}\"='{$value}'"; + } + + // Check for failures + if (!$this->conn->Execute($sql)) { + // Check for referential integrity failure + if (stristr($this->conn->ErrorMsg(), 'referential')) + return -1; + } + + // Check for no rows modified + if ($this->conn->Affected_Rows() == 0) return -2; + + return $this->conn->ErrorNo(); + } + + /** + * Insert a set of values into the database + * @param $table The table to insert into + * @param $vars (array) A mapping of the field names to the values to be inserted + * @return 0 success + * @return -1 if a unique constraint is violated + * @return -2 if a referential constraint is violated + */ + function insert($table, $vars) { + $this->fieldClean($table); + + // Build clause + if (sizeof($vars) > 0) { + $fields = ''; + $values = ''; + foreach($vars as $key => $value) { + $this->clean($key); + $this->clean($value); + + if ($fields) $fields .= ", \"{$key}\""; + else $fields = "INSERT INTO \"{$table}\" (\"{$key}\""; + + if ($values) $values .= ", '{$value}'"; + else $values = ") VALUES ('{$value}'"; + } + $sql = $fields . $values . ')'; + } + + // Check for failures + if (!$this->conn->Execute($sql)) { + // Check for unique constraint failure + if (stristr($this->conn->ErrorMsg(), 'unique')) + return -1; + // Check for referential integrity failure + elseif (stristr($this->conn->ErrorMsg(), 'referential')) + return -2; + } + + return $this->conn->ErrorNo(); + } + + /** + * Update a row in the database + * @param $table The table that is to be updated + * @param $vars (array) A mapping of the field names to the values to be updated + * @param $where (array) A mapping of field names to values for the where clause + * @param $nulls (array, optional) An array of fields to be set null + * @return 0 success + * @return -1 if a unique constraint is violated + * @return -2 if a referential constraint is violated + * @return -3 on no rows deleted + */ + function update($table, $vars, $where, $nulls = array()) { + $this->fieldClean($table); + + $setClause = ''; + $whereClause = ''; + + // Populate the syntax arrays + reset($vars); + while(list($key, $value) = each($vars)) { + $this->fieldClean($key); + $this->clean($value); + if ($setClause) $setClause .= ", \"{$key}\"='{$value}'"; + else $setClause = "UPDATE \"{$table}\" SET \"{$key}\"='{$value}'"; + } + + reset($nulls); + while(list(, $value) = each($nulls)) { + $this->fieldClean($value); + if ($setClause) $setClause .= ", \"{$value}\"=NULL"; + else $setClause = "UPDATE \"{$table}\" SET \"{$value}\"=NULL"; + } + + reset($where); + while(list($key, $value) = each($where)) { + $this->fieldClean($key); + $this->clean($value); + if ($whereClause) $whereClause .= " AND \"{$key}\"='{$value}'"; + else $whereClause = " WHERE \"{$key}\"='{$value}'"; + } + + // Check for failures + if (!$this->conn->Execute($setClause . $whereClause)) { + // Check for unique constraint failure + if (stristr($this->conn->ErrorMsg(), 'unique')) + return -1; + // Check for referential integrity failure + elseif (stristr($this->conn->ErrorMsg(), 'referential')) + return -2; + } + + // Check for no rows modified + if ($this->conn->Affected_Rows() == 0) return -3; + + return $this->conn->ErrorNo(); + } + + /** + * Begin a transaction + * @return 0 success + */ + function beginTransaction() { + return !$this->conn->BeginTrans(); + } + + /** + * End a transaction + * @return 0 success + */ + function endTransaction() { + return !$this->conn->CommitTrans(); + } + + /** + * Roll back a transaction + * @return 0 success + */ + function rollbackTransaction() { + return !$this->conn->RollbackTrans(); + } + + /** + * Get the backend platform + * @return The backend platform + */ + function getPlatform() { + //return $this->conn->platform; + return "UNKNOWN"; + } + + // Type conversion routines + + /** + * Change the value of a parameter to database representation depending on whether it evaluates to true or false + * @param $parameter the parameter + */ + function dbBool(&$parameter) { + return $parameter; + } + + /** + * Change a parameter from database representation to a boolean, (others evaluate to false) + * @param $parameter the parameter + */ + function phpBool($parameter) { + return $parameter; + } + + /** + * Change a db array into a PHP array + * @param $arr String representing the DB array + * @return A PHP array + */ + function phpArray($dbarr) { + // Take off the first and last characters (the braces) + $arr = substr($dbarr, 1, strlen($dbarr) - 2); + + // Pick out array entries by carefully parsing. This is necessary in order + // to cope with double quotes and commas, etc. + $elements = array(); + $i = $j = 0; + $in_quotes = false; + while ($i < strlen($arr)) { + // If current char is a double quote and it's not escaped, then + // enter quoted bit + $char = substr($arr, $i, 1); + if ($char == '"' && ($i == 0 || substr($arr, $i - 1, 1) != '\\')) + $in_quotes = !$in_quotes; + elseif ($char == ',' && !$in_quotes) { + // Add text so far to the array + $elements[] = substr($arr, $j, $i - $j); + $j = $i + 1; + } + $i++; + } + // Add final text to the array + $elements[] = substr($arr, $j); + + // Do one further loop over the elements array to remote double quoting + // and escaping of double quotes and backslashes + for ($i = 0; $i < sizeof($elements); $i++) { + $v = $elements[$i]; + if (strpos($v, '"') === 0) { + $v = substr($v, 1, strlen($v) - 2); + $v = str_replace('\\"', '"', $v); + $v = str_replace('\\\\', '\\', $v); + $elements[$i] = $v; + } + } + + return $elements; + } +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Connection.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Connection.php new file mode 100644 index 00000000..eb22cd21 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Connection.php @@ -0,0 +1,121 @@ +conn = ADONewConnection('postgres7'); + $this->conn->setFetchMode($fetchMode); + + // Ignore host if null + if ($host === null || $host == '') + if ($port !== null && $port != '') + $pghost = ':'.$port; + else + $pghost = ''; + else + $pghost = "{$host}:{$port}"; + + // Add sslmode to $pghost as needed + if (($sslmode == 'disable') || ($sslmode == 'allow') || ($sslmode == 'prefer') || ($sslmode == 'require')) { + $pghost .= ':'.$sslmode; + } elseif ($sslmode == 'legacy') { + $pghost .= ' requiressl=1'; + } + + $this->conn->connect($pghost, $user, $password, $database); + } + + /** + * Gets the name of the correct database driver to use. As a side effect, + * sets the platform. + * @param (return-by-ref) $description A description of the database and version + * @return The class name of the driver eg. Postgres84 + * @return null if version is < 7.4 + * @return -3 Database-specific failure + */ + function getDriver(&$description) { + + $v = pg_version($this->conn->_connectionID); + if (isset($v['server'])) $version = $v['server']; + + // If we didn't manage to get the version without a query, query... + if (!isset($version)) { + $adodb = new ADODB_base($this->conn); + + $sql = "SELECT VERSION() AS version"; + $field = $adodb->selectField($sql, 'version'); + + // Check the platform, if it's mingw, set it + if (preg_match('/ mingw /i', $field)) + $this->platform = 'MINGW'; + + $params = explode(' ', $field); + if (!isset($params[1])) return -3; + + $version = $params[1]; // eg. 8.4.4 + } + + $description = "PostgreSQL {$version}"; + + // Detect version and choose appropriate database driver + switch (substr($version,0,2)) { + case '10': return 'Postgres10';break; + case '11': return 'Postgres11';break; + case '12': return 'Postgres';break; + } + + switch (substr($version,0,3)) { + case '9.6': return 'Postgres96'; break; + case '9.5': return 'Postgres95'; break; + case '9.4': return 'Postgres94'; break; + case '9.3': return 'Postgres93'; break; + case '9.2': return 'Postgres92'; break; + case '9.1': return 'Postgres91'; break; + case '9.0': return 'Postgres90'; break; + case '8.4': return 'Postgres84'; break; + case '8.3': return 'Postgres83'; break; + case '8.2': return 'Postgres82'; break; + case '8.1': return 'Postgres81'; break; + case '8.0': + case '7.5': return 'Postgres80'; break; + case '7.4': return 'Postgres74'; break; + } + + /* All <7.4 versions are not supported */ + // if major version is 7 or less and wasn't cought in the + // switch/case block, we have an unsupported version. + if ((int)substr($version, 0, 1) < 8) + return null; + + // If unknown version, then default to latest driver + return 'Postgres'; + + } + + /** + * Get the last error in the connection + * @return Error string + */ + function getLastError() { + return pg_last_error($this->conn->_connectionID); + } +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres.php new file mode 100644 index 00000000..ee19990f --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres.php @@ -0,0 +1,8013 @@ + 'BIG5', + 'EUC_CN' => 'GB2312', + 'EUC_JP' => 'EUC-JP', + 'EUC_KR' => 'EUC-KR', + 'EUC_TW' => 'EUC-TW', + 'GB18030' => 'GB18030', + 'GBK' => 'GB2312', + 'ISO_8859_5' => 'ISO-8859-5', + 'ISO_8859_6' => 'ISO-8859-6', + 'ISO_8859_7' => 'ISO-8859-7', + 'ISO_8859_8' => 'ISO-8859-8', + 'JOHAB' => 'CP1361', + 'KOI8' => 'KOI8-R', + 'LATIN1' => 'ISO-8859-1', + 'LATIN2' => 'ISO-8859-2', + 'LATIN3' => 'ISO-8859-3', + 'LATIN4' => 'ISO-8859-4', + 'LATIN5' => 'ISO-8859-9', + 'LATIN6' => 'ISO-8859-10', + 'LATIN7' => 'ISO-8859-13', + 'LATIN8' => 'ISO-8859-14', + 'LATIN9' => 'ISO-8859-15', + 'LATIN10' => 'ISO-8859-16', + 'SJIS' => 'SHIFT_JIS', + 'SQL_ASCII' => 'US-ASCII', + 'UHC' => 'WIN949', + 'UTF8' => 'UTF-8', + 'WIN866' => 'CP866', + 'WIN874' => 'CP874', + 'WIN1250' => 'CP1250', + 'WIN1251' => 'CP1251', + 'WIN1252' => 'CP1252', + 'WIN1256' => 'CP1256', + 'WIN1258' => 'CP1258' + ); + var $defaultprops = array('', '', ''); + // Extra "magic" types. BIGSERIAL was added in PostgreSQL 7.2. + var $extraTypes = array('SERIAL', 'BIGSERIAL'); + // Foreign key stuff. First element MUST be the default. + var $fkactions = array('NO ACTION', 'RESTRICT', 'CASCADE', 'SET NULL', 'SET DEFAULT'); + var $fkdeferrable = array('NOT DEFERRABLE', 'DEFERRABLE'); + var $fkinitial = array('INITIALLY IMMEDIATE', 'INITIALLY DEFERRED'); + var $fkmatches = array('MATCH SIMPLE', 'MATCH FULL'); + // Function properties + var $funcprops = array( array('', 'VOLATILE', 'IMMUTABLE', 'STABLE'), + array('', 'CALLED ON NULL INPUT', 'RETURNS NULL ON NULL INPUT'), + array('', 'SECURITY INVOKER', 'SECURITY DEFINER')); + // Default help URL + var $help_base; + // Help sub pages + var $help_page; + // Name of id column + var $id = 'oid'; + // Supported join operations for use with view wizard + var $joinOps = array('INNER JOIN' => 'INNER JOIN', 'LEFT JOIN' => 'LEFT JOIN', 'RIGHT JOIN' => 'RIGHT JOIN', 'FULL JOIN' => 'FULL JOIN'); + // Map of internal language name to syntax highlighting name + var $langmap = array( + 'sql' => 'SQL', + 'plpgsql' => 'SQL', + 'php' => 'PHP', + 'phpu' => 'PHP', + 'plphp' => 'PHP', + 'plphpu' => 'PHP', + 'perl' => 'Perl', + 'perlu' => 'Perl', + 'plperl' => 'Perl', + 'plperlu' => 'Perl', + 'java' => 'Java', + 'javau' => 'Java', + 'pljava' => 'Java', + 'pljavau' => 'Java', + 'plj' => 'Java', + 'plju' => 'Java', + 'python' => 'Python', + 'pythonu' => 'Python', + 'plpython' => 'Python', + 'plpythonu' => 'Python', + 'ruby' => 'Ruby', + 'rubyu' => 'Ruby', + 'plruby' => 'Ruby', + 'plrubyu' => 'Ruby' + ); + // Predefined size types + var $predefined_size_types = array('abstime','aclitem','bigserial','boolean','bytea','cid','cidr','circle','date','float4','float8','gtsvector','inet','int2','int4','int8','macaddr','money','oid','path','polygon','refcursor','regclass','regoper','regoperator','regproc','regprocedure','regtype','reltime','serial','smgr','text','tid','tinterval','tsquery','tsvector','varbit','void','xid'); + // List of all legal privileges that can be applied to different types + // of objects. + var $privlist = array( + 'table' => array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'view' => array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'sequence' => array('SELECT', 'UPDATE', 'ALL PRIVILEGES'), + 'database' => array('CREATE', 'TEMPORARY', 'CONNECT', 'ALL PRIVILEGES'), + 'function' => array('EXECUTE', 'ALL PRIVILEGES'), + 'language' => array('USAGE', 'ALL PRIVILEGES'), + 'schema' => array('CREATE', 'USAGE', 'ALL PRIVILEGES'), + 'tablespace' => array('CREATE', 'ALL PRIVILEGES'), + 'column' => array('SELECT', 'INSERT', 'UPDATE', 'REFERENCES','ALL PRIVILEGES') + ); + // List of characters in acl lists and the privileges they + // refer to. + var $privmap = array( + 'r' => 'SELECT', + 'w' => 'UPDATE', + 'a' => 'INSERT', + 'd' => 'DELETE', + 'D' => 'TRUNCATE', + 'R' => 'RULE', + 'x' => 'REFERENCES', + 't' => 'TRIGGER', + 'X' => 'EXECUTE', + 'U' => 'USAGE', + 'C' => 'CREATE', + 'T' => 'TEMPORARY', + 'c' => 'CONNECT' + ); + // Rule action types + var $rule_events = array('SELECT', 'INSERT', 'UPDATE', 'DELETE'); + // Select operators + var $selectOps = array('=' => 'i', '!=' => 'i', '<' => 'i', '>' => 'i', '<=' => 'i', '>=' => 'i', + '<<' => 'i', '>>' => 'i', '<<=' => 'i', '>>=' => 'i', + 'LIKE' => 'i', 'NOT LIKE' => 'i', 'ILIKE' => 'i', 'NOT ILIKE' => 'i', 'SIMILAR TO' => 'i', + 'NOT SIMILAR TO' => 'i', '~' => 'i', '!~' => 'i', '~*' => 'i', '!~*' => 'i', + 'IS NULL' => 'p', 'IS NOT NULL' => 'p', 'IN' => 'x', 'NOT IN' => 'x', + '@@' => 'i', '@@@' => 'i', '@>' => 'i', '<@' => 'i', + '@@ to_tsquery' => 't', '@@@ to_tsquery' => 't', '@> to_tsquery' => 't', '<@ to_tsquery' => 't', + '@@ plainto_tsquery' => 't', '@@@ plainto_tsquery' => 't', '@> plainto_tsquery' => 't', '<@ plainto_tsquery' => 't'); + // Array of allowed trigger events + var $triggerEvents= array('INSERT', 'UPDATE', 'DELETE', 'INSERT OR UPDATE', 'INSERT OR DELETE', + 'DELETE OR UPDATE', 'INSERT OR DELETE OR UPDATE'); + // When to execute the trigger + var $triggerExecTimes = array('BEFORE', 'AFTER'); + // How often to execute the trigger + var $triggerFrequency = array('ROW','STATEMENT'); + // Array of allowed type alignments + var $typAligns = array('char', 'int2', 'int4', 'double'); + // The default type alignment + var $typAlignDef = 'int4'; + // Default index type + var $typIndexDef = 'BTREE'; + // Array of allowed index types + var $typIndexes = array('BTREE', 'RTREE', 'GIST', 'GIN', 'HASH'); + // Array of allowed type storage attributes + var $typStorages = array('plain', 'external', 'extended', 'main'); + // The default type storage + var $typStorageDef = 'plain'; + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres($conn) { + $this->ADODB_base($conn); + } + + // Formatting functions + + /** + * Cleans (escapes) a string + * @param $str The string to clean, by reference + * @return The cleaned string + */ + function clean(&$str) { + if ($str === null) return null; + $str = str_replace("\r\n","\n",$str); + $str = pg_escape_string($str); + return $str; + } + + /** + * Cleans (escapes) an object name (eg. table, field) + * @param $str The string to clean, by reference + * @return The cleaned string + */ + function fieldClean(&$str) { + if ($str === null) return null; + $str = str_replace('"', '""', $str); + return $str; + } + + /** + * Cleans (escapes) an array of field names + * @param $arr The array to clean, by reference + * @return The cleaned array + */ + function fieldArrayClean(&$arr) { + foreach ($arr as $k => $v) { + if ($v === null) continue; + $arr[$k] = str_replace('"', '""', $v); + } + return $arr; + } + + /** + * Cleans (escapes) an array + * @param $arr The array to clean, by reference + * @return The cleaned array + */ + function arrayClean(&$arr) { + foreach ($arr as $k => $v) { + if ($v === null) continue; + $arr[$k] = pg_escape_string($v); + } + return $arr; + } + + /** + * Escapes bytea data for display on the screen + * @param $data The bytea data + * @return Data formatted for on-screen display + */ + function escapeBytea($data) { + return htmlentities($data, ENT_QUOTES, 'UTF-8'); + } + + /** + * Outputs the HTML code for a particular field + * @param $name The name to give the field + * @param $value The value of the field. Note this could be 'numeric(7,2)' sort of thing... + * @param $type The database type of the field + * @param $extras An array of attributes name as key and attributes' values as value + */ + function printField($name, $value, $type, $extras = array()) { + global $lang; + + // Determine actions string + $extra_str = ''; + foreach ($extras as $k => $v) { + $extra_str .= " {$k}=\"" . htmlspecialchars($v) . "\""; + } + + switch (substr($type,0,9)) { + case 'bool': + case 'boolean': + if ($value !== null && $value == '') $value = null; + elseif ($value == 'true') $value = 't'; + elseif ($value == 'false') $value = 'f'; + + // If value is null, 't' or 'f'... + if ($value === null || $value == 't' || $value == 'f') { + echo "\n"; + } + else { + echo "\n"; + } + break; + case 'bytea': + case 'bytea[]': + if (!is_null($value)) { + $value = $this->escapeBytea($value); + } + case 'text': + case 'text[]': + case 'json': + case 'jsonb': + case 'xml': + case 'xml[]': + $n = substr_count($value, "\n"); + $n = $n < 5 ? 5 : $n; + $n = $n > 20 ? 20 : $n; + echo "\n"; + break; + case 'character': + case 'character[]': + $n = substr_count($value, "\n"); + $n = $n < 5 ? 5 : $n; + $n = $n > 20 ? 20 : $n; + echo "\n"; + break; + default: + echo "\n"; + break; + } + } + + /** + * Formats a value or expression for sql purposes + * @param $type The type of the field + * @param $format VALUE or EXPRESSION + * @param $value The actual value entered in the field. Can be NULL + * @return The suitably quoted and escaped value. + */ + function formatValue($type, $format, $value) { + switch ($type) { + case 'bool': + case 'boolean': + if ($value == 't') + return 'TRUE'; + elseif ($value == 'f') + return 'FALSE'; + elseif ($value == '') + return 'NULL'; + else + return $value; + break; + default: + // Checking variable fields is difficult as there might be a size + // attribute... + if (strpos($type, 'time') === 0) { + // Assume it's one of the time types... + if ($value == '') return "''"; + elseif (strcasecmp($value, 'CURRENT_TIMESTAMP') == 0 + || strcasecmp($value, 'CURRENT_TIME') == 0 + || strcasecmp($value, 'CURRENT_DATE') == 0 + || strcasecmp($value, 'LOCALTIME') == 0 + || strcasecmp($value, 'LOCALTIMESTAMP') == 0) { + return $value; + } + elseif ($format == 'EXPRESSION') + return $value; + else { + $this->clean($value); + return "'{$value}'"; + } + } + else { + if ($format == 'VALUE') { + $this->clean($value); + return "'{$value}'"; + } + return $value; + } + } + } + + /** + * Formats a type correctly for display. Postgres 7.0 had no 'format_type' + * built-in function, and hence we need to do it manually. + * @param $typname The name of the type + * @param $typmod The contents of the typmod field + */ + function formatType($typname, $typmod) { + // This is a specific constant in the 7.0 source + $varhdrsz = 4; + + // If the first character is an underscore, it's an array type + $is_array = false; + if (substr($typname, 0, 1) == '_') { + $is_array = true; + $typname = substr($typname, 1); + } + + // Show lengths on bpchar and varchar + if ($typname == 'bpchar') { + $len = $typmod - $varhdrsz; + $temp = 'character'; + if ($len > 1) + $temp .= "({$len})"; + } + elseif ($typname == 'varchar') { + $temp = 'character varying'; + if ($typmod != -1) + $temp .= "(" . ($typmod - $varhdrsz) . ")"; + } + elseif ($typname == 'numeric') { + $temp = 'numeric'; + if ($typmod != -1) { + $tmp_typmod = $typmod - $varhdrsz; + $precision = ($tmp_typmod >> 16) & 0xffff; + $scale = $tmp_typmod & 0xffff; + $temp .= "({$precision}, {$scale})"; + } + } + else $temp = $typname; + + // Add array qualifier if it's an array + if ($is_array) $temp .= '[]'; + + return $temp; + } + + // Help functions + + /** + * Fetch a URL (or array of URLs) for a given help page. + */ + function getHelp($help) { + $this->getHelpPages(); + + if (isset($this->help_page[$help])) { + if (is_array($this->help_page[$help])) { + $urls = array(); + foreach ($this->help_page[$help] as $link) { + $urls[] = $this->help_base . $link; + } + return $urls; + } else + return $this->help_base . $this->help_page[$help]; + } else + return null; + } + + function getHelpPages() { + include_once('./help/PostgresDoc95.php'); + return $this->help_page; + } + + // Database functions + + /** + * Return all information about a particular database + * @param $database The name of the database to retrieve + * @return The database info + */ + function getDatabase($database) { + $this->clean($database); + $sql = "SELECT * FROM pg_database WHERE datname='{$database}'"; + return $this->selectSet($sql); + } + + /** + * Return all database available on the server + * @param $currentdatabase database name that should be on top of the resultset + * + * @return A list of databases, sorted alphabetically + */ + function getDatabases($currentdatabase = NULL) { + global $conf, $misc; + + $server_info = $misc->getServerInfo(); + + if (isset($conf['owned_only']) && $conf['owned_only'] && !$this->isSuperUser()) { + $username = $server_info['username']; + $this->clean($username); + $clause = " AND pr.rolname='{$username}'"; + } + else $clause = ''; + + if ($currentdatabase != NULL) { + $this->clean($currentdatabase); + $orderby = "ORDER BY pdb.datname = '{$currentdatabase}' DESC, pdb.datname"; + } + else + $orderby = "ORDER BY pdb.datname"; + + if (!$conf['show_system']) + $where = ' AND NOT pdb.datistemplate'; + else + $where = ' AND pdb.datallowconn'; + + $sql = " + SELECT pdb.datname AS datname, pr.rolname AS datowner, pg_encoding_to_char(encoding) AS datencoding, + (SELECT description FROM pg_catalog.pg_shdescription pd WHERE pdb.oid=pd.objoid AND pd.classoid='pg_database'::regclass) AS datcomment, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=pdb.dattablespace) AS tablespace, + CASE WHEN pg_catalog.has_database_privilege(current_user, pdb.oid, 'CONNECT') + THEN pg_catalog.pg_database_size(pdb.oid) + ELSE -1 -- set this magic value, which we will convert to no access later + END as dbsize, pdb.datcollate, pdb.datctype + FROM pg_catalog.pg_database pdb + LEFT JOIN pg_catalog.pg_roles pr ON (pdb.datdba = pr.oid) + WHERE true + {$where} + {$clause} + {$orderby}"; + + return $this->selectSet($sql); + } + + /** + * Return the database comment of a db from the shared description table + * @param string $database the name of the database to get the comment for + * @return recordset of the db comment info + */ + function getDatabaseComment($database) { + $this->clean($database); + $sql = "SELECT description FROM pg_catalog.pg_database JOIN pg_catalog.pg_shdescription ON (oid=objoid AND classoid='pg_database'::regclass) WHERE pg_database.datname = '{$database}' "; + return $this->selectSet($sql); + } + + /** + * Return the database owner of a db + * @param string $database the name of the database to get the owner for + * @return recordset of the db owner info + */ + function getDatabaseOwner($database) { + $this->clean($database); + $sql = "SELECT usename FROM pg_user, pg_database WHERE pg_user.usesysid = pg_database.datdba AND pg_database.datname = '{$database}' "; + return $this->selectSet($sql); + } + + /** + * Returns the current database encoding + * @return The encoding. eg. SQL_ASCII, UTF-8, etc. + */ + function getDatabaseEncoding() { + return pg_parameter_status($this->conn->_connectionID, 'server_encoding'); + } + + /** + * Returns the current default_with_oids setting + * @return default_with_oids setting + */ + function getDefaultWithOid() { + + $sql = "SHOW default_with_oids"; + + return $this->selectField($sql, 'default_with_oids'); + } + + /** + * Creates a database + * @param $database The name of the database to create + * @param $encoding Encoding of the database + * @param $tablespace (optional) The tablespace name + * @return 0 success + * @return -1 tablespace error + * @return -2 comment error + */ + function createDatabase($database, $encoding, $tablespace = '', $comment = '', $template = 'template1', + $lc_collate = '', $lc_ctype = '') + { + $this->fieldClean($database); + $this->clean($encoding); + $this->fieldClean($tablespace); + $this->fieldClean($template); + $this->clean($lc_collate); + $this->clean($lc_ctype); + + $sql = "CREATE DATABASE \"{$database}\" WITH TEMPLATE=\"{$template}\""; + + if ($encoding != '') $sql .= " ENCODING='{$encoding}'"; + if ($lc_collate != '') $sql .= " LC_COLLATE='{$lc_collate}'"; + if ($lc_ctype != '') $sql .= " LC_CTYPE='{$lc_ctype}'"; + + if ($tablespace != '' && $this->hasTablespaces()) $sql .= " TABLESPACE \"{$tablespace}\""; + + $status = $this->execute($sql); + if ($status != 0) return -1; + + if ($comment != '' && $this->hasSharedComments()) { + $status = $this->setComment('DATABASE',$database,'',$comment); + if ($status != 0) return -2; + } + + return 0; + } + + /** + * Renames a database, note that this operation cannot be + * performed on a database that is currently being connected to + * @param string $oldName name of database to rename + * @param string $newName new name of database + * @return int 0 on success + */ + function alterDatabaseRename($oldName, $newName) { + $this->fieldClean($oldName); + $this->fieldClean($newName); + + if ($oldName != $newName) { + $sql = "ALTER DATABASE \"{$oldName}\" RENAME TO \"{$newName}\""; + return $this->execute($sql); + } + else //just return success, we're not going to do anything + return 0; + } + + /** + * Drops a database + * @param $database The name of the database to drop + * @return 0 success + */ + function dropDatabase($database) { + $this->fieldClean($database); + $sql = "DROP DATABASE \"{$database}\""; + return $this->execute($sql); + } + + /** + * Changes ownership of a database + * This can only be done by a superuser or the owner of the database + * @param string $dbName database to change ownership of + * @param string $newOwner user that will own the database + * @return int 0 on success + */ + function alterDatabaseOwner($dbName, $newOwner) { + $this->fieldClean($dbName); + $this->fieldClean($newOwner); + + $sql = "ALTER DATABASE \"{$dbName}\" OWNER TO \"{$newOwner}\""; + return $this->execute($sql); + } + + /** + * Alters a database + * the multiple return vals are for postgres 8+ which support more functionality in alter database + * @param $dbName The name of the database + * @param $newName new name for the database + * @param $newOwner The new owner for the database + * @return 0 success + * @return -1 transaction error + * @return -2 owner error + * @return -3 rename error + * @return -4 comment error + */ + function alterDatabase($dbName, $newName, $newOwner = '', $comment = '') { + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + if ($dbName != $newName) { + $status = $this->alterDatabaseRename($dbName, $newName); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + $dbName = $newName; + } + + if ($newOwner != '') { + $status = $this->alterDatabaseOwner($newName, $newOwner); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + } + + $this->fieldClean($dbName); + $status = $this->setComment('DATABASE', $dbName, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + return $this->endTransaction(); + } + + /** + * Returns prepared transactions information + * @param $database (optional) Find only prepared transactions executed in a specific database + * @return A recordset + */ + function getPreparedXacts($database = null) { + if ($database === null) + $sql = "SELECT * FROM pg_prepared_xacts"; + else { + $this->clean($database); + $sql = "SELECT transaction, gid, prepared, owner FROM pg_prepared_xacts + WHERE database='{$database}' ORDER BY owner"; + } + + return $this->selectSet($sql); + } + + /** + * Searches all system catalogs to find objects that match a certain name. + * @param $term The search term + * @param $filter The object type to restrict to ('' means no restriction) + * @return A recordset + */ + function findObject($term, $filter) { + global $conf; + + /*about escaping: + * SET standard_conforming_string is not available before 8.2 + * So we must use PostgreSQL specific notation :/ + * E'' notation is not available before 8.1 + * $$ is available since 8.0 + * Nothing specific from 7.4 + **/ + + // Escape search term for ILIKE match + $this->clean($term); + $this->clean($filter); + $term = str_replace('_', '\_', $term); + $term = str_replace('%', '\%', $term); + + // Exclude system relations if necessary + if (!$conf['show_system']) { + // XXX: The mention of information_schema here is in the wrong place, but + // it's the quickest fix to exclude the info schema from 7.4 + $where = " AND pn.nspname NOT LIKE \$_PATERN_\$pg\_%\$_PATERN_\$ AND pn.nspname != 'information_schema'"; + $lan_where = "AND pl.lanispl"; + } + else { + $where = ''; + $lan_where = ''; + } + + // Apply outer filter + $sql = ''; + if ($filter != '') { + $sql = "SELECT * FROM ("; + } + + $term = "\$_PATERN_\$%{$term}%\$_PATERN_\$"; + + $sql .= " + SELECT 'SCHEMA' AS type, oid, NULL AS schemaname, NULL AS relname, nspname AS name + FROM pg_catalog.pg_namespace pn WHERE nspname ILIKE {$term} {$where} + UNION ALL + SELECT CASE WHEN relkind='r' THEN 'TABLE' WHEN relkind='v' THEN 'VIEW' WHEN relkind='S' THEN 'SEQUENCE' END, pc.oid, + pn.nspname, NULL, pc.relname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn + WHERE pc.relnamespace=pn.oid AND relkind IN ('r', 'v', 'S') AND relname ILIKE {$term} {$where} + UNION ALL + SELECT CASE WHEN pc.relkind='r' THEN 'COLUMNTABLE' ELSE 'COLUMNVIEW' END, NULL, pn.nspname, pc.relname, pa.attname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_attribute pa WHERE pc.relnamespace=pn.oid AND pc.oid=pa.attrelid + AND pa.attname ILIKE {$term} AND pa.attnum > 0 AND NOT pa.attisdropped AND pc.relkind IN ('r', 'v') {$where} + UNION ALL + SELECT 'FUNCTION', pp.oid, pn.nspname, NULL, pp.proname || '(' || pg_catalog.oidvectortypes(pp.proargtypes) || ')' FROM pg_catalog.pg_proc pp, pg_catalog.pg_namespace pn + WHERE pp.pronamespace=pn.oid AND NOT pp.proisagg AND pp.proname ILIKE {$term} {$where} + UNION ALL + SELECT 'INDEX', NULL, pn.nspname, pc.relname, pc2.relname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_index pi, pg_catalog.pg_class pc2 WHERE pc.relnamespace=pn.oid AND pc.oid=pi.indrelid + AND pi.indexrelid=pc2.oid + AND NOT EXISTS ( + SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pc2.tableoid AND d.objid = pc2.oid AND d.deptype = 'i' AND c.contype IN ('u', 'p') + ) + AND pc2.relname ILIKE {$term} {$where} + UNION ALL + SELECT 'CONSTRAINTTABLE', NULL, pn.nspname, pc.relname, pc2.conname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_constraint pc2 WHERE pc.relnamespace=pn.oid AND pc.oid=pc2.conrelid AND pc2.conrelid != 0 + AND CASE WHEN pc2.contype IN ('f', 'c') THEN TRUE ELSE NOT EXISTS ( + SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pc2.tableoid AND d.objid = pc2.oid AND d.deptype = 'i' AND c.contype IN ('u', 'p') + ) END + AND pc2.conname ILIKE {$term} {$where} + UNION ALL + SELECT 'CONSTRAINTDOMAIN', pt.oid, pn.nspname, pt.typname, pc.conname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn, + pg_catalog.pg_constraint pc WHERE pt.typnamespace=pn.oid AND pt.oid=pc.contypid AND pc.contypid != 0 + AND pc.conname ILIKE {$term} {$where} + UNION ALL + SELECT 'TRIGGER', NULL, pn.nspname, pc.relname, pt.tgname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_trigger pt WHERE pc.relnamespace=pn.oid AND pc.oid=pt.tgrelid + AND ( pt.tgconstraint = 0 OR NOT EXISTS + (SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pt.tableoid AND d.objid = pt.oid AND d.deptype = 'i' AND c.contype = 'f')) + AND pt.tgname ILIKE {$term} {$where} + UNION ALL + SELECT 'RULETABLE', NULL, pn.nspname AS schemaname, c.relname AS tablename, r.rulename FROM pg_catalog.pg_rewrite r + JOIN pg_catalog.pg_class c ON c.oid = r.ev_class + LEFT JOIN pg_catalog.pg_namespace pn ON pn.oid = c.relnamespace + WHERE c.relkind='r' AND r.rulename != '_RETURN' AND r.rulename ILIKE {$term} {$where} + UNION ALL + SELECT 'RULEVIEW', NULL, pn.nspname AS schemaname, c.relname AS tablename, r.rulename FROM pg_catalog.pg_rewrite r + JOIN pg_catalog.pg_class c ON c.oid = r.ev_class + LEFT JOIN pg_catalog.pg_namespace pn ON pn.oid = c.relnamespace + WHERE c.relkind='v' AND r.rulename != '_RETURN' AND r.rulename ILIKE {$term} {$where} + "; + + // Add advanced objects if show_advanced is set + if ($conf['show_advanced']) { + $sql .= " + UNION ALL + SELECT CASE WHEN pt.typtype='d' THEN 'DOMAIN' ELSE 'TYPE' END, pt.oid, pn.nspname, NULL, + pt.typname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn + WHERE pt.typnamespace=pn.oid AND typname ILIKE {$term} + AND (pt.typrelid = 0 OR (SELECT c.relkind = 'c' FROM pg_catalog.pg_class c WHERE c.oid = pt.typrelid)) + {$where} + UNION ALL + SELECT 'OPERATOR', po.oid, pn.nspname, NULL, po.oprname FROM pg_catalog.pg_operator po, pg_catalog.pg_namespace pn + WHERE po.oprnamespace=pn.oid AND oprname ILIKE {$term} {$where} + UNION ALL + SELECT 'CONVERSION', pc.oid, pn.nspname, NULL, pc.conname FROM pg_catalog.pg_conversion pc, + pg_catalog.pg_namespace pn WHERE pc.connamespace=pn.oid AND conname ILIKE {$term} {$where} + UNION ALL + SELECT 'LANGUAGE', pl.oid, NULL, NULL, pl.lanname FROM pg_catalog.pg_language pl + WHERE lanname ILIKE {$term} {$lan_where} + UNION ALL + SELECT DISTINCT ON (p.proname) 'AGGREGATE', p.oid, pn.nspname, NULL, p.proname FROM pg_catalog.pg_proc p + LEFT JOIN pg_catalog.pg_namespace pn ON p.pronamespace=pn.oid + WHERE p.proisagg AND p.proname ILIKE {$term} {$where} + UNION ALL + SELECT DISTINCT ON (po.opcname) 'OPCLASS', po.oid, pn.nspname, NULL, po.opcname FROM pg_catalog.pg_opclass po, + pg_catalog.pg_namespace pn WHERE po.opcnamespace=pn.oid + AND po.opcname ILIKE {$term} {$where} + "; + } + // Otherwise just add domains + else { + $sql .= " + UNION ALL + SELECT 'DOMAIN', pt.oid, pn.nspname, NULL, + pt.typname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn + WHERE pt.typnamespace=pn.oid AND pt.typtype='d' AND typname ILIKE {$term} + AND (pt.typrelid = 0 OR (SELECT c.relkind = 'c' FROM pg_catalog.pg_class c WHERE c.oid = pt.typrelid)) + {$where} + "; + } + + if ($filter != '') { + // We use like to make RULE, CONSTRAINT and COLUMN searches work + $sql .= ") AS sub WHERE type LIKE '{$filter}%' "; + } + + $sql .= "ORDER BY type, schemaname, relname, name"; + + return $this->selectSet($sql); + } + + /** + * Returns all available variable information. + * @return A recordset + */ + function getVariables() { + $sql = "SHOW ALL"; + + return $this->selectSet($sql); + } + + // Schema functons + + /** + * Return all schemas in the current database. + * @return All schemas, sorted alphabetically + */ + function getSchemas() { + global $conf; + + if (!$conf['show_system']) { + $where = "WHERE nspname NOT LIKE 'pg@_%' ESCAPE '@' AND nspname != 'information_schema'"; + + } + else $where = "WHERE nspname !~ '^pg_t(emp_[0-9]+|oast)$'"; + $sql = " + SELECT pn.nspname, pu.rolname AS nspowner, + pg_catalog.obj_description(pn.oid, 'pg_namespace') AS nspcomment + FROM pg_catalog.pg_namespace pn + LEFT JOIN pg_catalog.pg_roles pu ON (pn.nspowner = pu.oid) + {$where} + ORDER BY nspname"; + + return $this->selectSet($sql); + } + + /** + * Return all information relating to a schema + * @param $schema The name of the schema + * @return Schema information + */ + function getSchemaByName($schema) { + $this->clean($schema); + $sql = " + SELECT nspname, nspowner, r.rolname AS ownername, nspacl, + pg_catalog.obj_description(pn.oid, 'pg_namespace') as nspcomment + FROM pg_catalog.pg_namespace pn + LEFT JOIN pg_roles as r ON pn.nspowner = r.oid + WHERE nspname='{$schema}'"; + return $this->selectSet($sql); + } + + /** + * Sets the current working schema. Will also set Class variable. + * @param $schema The the name of the schema to work in + * @return 0 success + */ + function setSchema($schema) { + // Get the current schema search path, including 'pg_catalog'. + $search_path = $this->getSearchPath(); + // Prepend $schema to search path + array_unshift($search_path, $schema); + $status = $this->setSearchPath($search_path); + if ($status == 0) { + $this->_schema = $schema; + return 0; + } + else return $status; + } + + /** + * Sets the current schema search path + * @param $paths An array of schemas in required search order + * @return 0 success + * @return -1 Array not passed + * @return -2 Array must contain at least one item + */ + function setSearchPath($paths) { + if (!is_array($paths)) return -1; + elseif (sizeof($paths) == 0) return -2; + elseif (sizeof($paths) == 1 && $paths[0] == '') { + // Need to handle empty paths in some cases + $paths[0] = 'pg_catalog'; + } + + // Loop over all the paths to check that none are empty + $temp = array(); + foreach ($paths as $schema) { + if ($schema != '') $temp[] = $schema; + } + $this->fieldArrayClean($temp); + + $sql = 'SET SEARCH_PATH TO "' . implode('","', $temp) . '"'; + + return $this->execute($sql); + } + + /** + * Creates a new schema. + * @param $schemaname The name of the schema to create + * @param $authorization (optional) The username to create the schema for. + * @param $comment (optional) If omitted, defaults to nothing + * @return 0 success + */ + function createSchema($schemaname, $authorization = '', $comment = '') { + $this->fieldClean($schemaname); + $this->fieldClean($authorization); + + $sql = "CREATE SCHEMA \"{$schemaname}\""; + if ($authorization != '') $sql .= " AUTHORIZATION \"{$authorization}\""; + + if ($comment != '') { + $status = $this->beginTransaction(); + if ($status != 0) return -1; + } + + // Create the new schema + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Set the comment + if ($comment != '') { + $status = $this->setComment('SCHEMA', $schemaname, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + return $this->endTransaction(); + } + + return 0; + } + + /** + * Updates a schema. + * @param $schemaname The name of the schema to drop + * @param $comment The new comment for this schema + * @param $owner The new owner for this schema + * @return 0 success + */ + function updateSchema($schemaname, $comment, $name, $owner) { + $this->fieldClean($schemaname); + $this->fieldClean($name); + $this->fieldClean($owner); + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $status = $this->setComment('SCHEMA', $schemaname, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $schema_rs = $this->getSchemaByName($schemaname); + /* Only if the owner change */ + if ($schema_rs->fields['ownername'] != $owner) { + $sql = "ALTER SCHEMA \"{$schemaname}\" OWNER TO \"{$owner}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + // Only if the name has changed + if ($name != $schemaname) { + $sql = "ALTER SCHEMA \"{$schemaname}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + } + + /** + * Drops a schema. + * @param $schemaname The name of the schema to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropSchema($schemaname, $cascade) { + $this->fieldClean($schemaname); + + $sql = "DROP SCHEMA \"{$schemaname}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Return the current schema search path + * @return Array of schema names + */ + function getSearchPath() { + $sql = 'SELECT current_schemas(false) AS search_path'; + + return $this->phpArray($this->selectField($sql, 'search_path')); + } + + // Table functions + + /** + * Checks to see whether or not a table has a unique id column + * @param $table The table name + * @return True if it has a unique id, false otherwise + * @return null error + **/ + function hasObjectID($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT relhasoids FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}')"; + + $rs = $this->selectSet($sql); + if ($rs->recordCount() != 1) return null; + else { + $rs->fields['relhasoids'] = $this->phpBool($rs->fields['relhasoids']); + return $rs->fields['relhasoids']; + } + } + + /** + * Returns table information + * @param $table The name of the table + * @return A recordset + */ + function getTable($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = " + SELECT + c.relname, n.nspname, u.usename AS relowner, + pg_catalog.obj_description(c.oid, 'pg_class') AS relcomment, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=c.reltablespace) AS tablespace + FROM pg_catalog.pg_class c + LEFT JOIN pg_catalog.pg_user u ON u.usesysid = c.relowner + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace + WHERE c.relkind = 'r' + AND n.nspname = '{$c_schema}' + AND n.oid = c.relnamespace + AND c.relname = '{$table}'"; + + return $this->selectSet($sql); + } + + /** + * Return all tables in current database (and schema) + * @param $all True to fetch all tables, false for just in current schema + * @return All tables, sorted alphabetically + */ + function getTables($all = false) { + $c_schema = $this->_schema; + $this->clean($c_schema); + if ($all) { + // Exclude pg_catalog and information_schema tables + $sql = "SELECT schemaname AS nspname, tablename AS relname, tableowner AS relowner + FROM pg_catalog.pg_tables + WHERE schemaname NOT IN ('pg_catalog', 'information_schema', 'pg_toast') + ORDER BY schemaname, tablename"; + } else { + $sql = "SELECT c.relname, pg_catalog.pg_get_userbyid(c.relowner) AS relowner, + pg_catalog.obj_description(c.oid, 'pg_class') AS relcomment, + reltuples::bigint, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=c.reltablespace) AS tablespace + FROM pg_catalog.pg_class c + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace + WHERE c.relkind = 'r' + AND nspname='{$c_schema}' + ORDER BY c.relname"; + } + + return $this->selectSet($sql); + } + + /** + * Retrieve the attribute definition of a table + * @param $table The name of the table + * @param $field (optional) The name of a field to return + * @return All attributes in order + */ + function getTableAttributes($table, $field = '') { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + $this->clean($field); + + if ($field == '') { + // This query is made much more complex by the addition of the 'attisserial' field. + // The subquery to get that field checks to see if there is an internally dependent + // sequence on the field. + $sql = " + SELECT + a.attname, a.attnum, + pg_catalog.format_type(a.atttypid, a.atttypmod) as type, + a.atttypmod, + a.attnotnull, a.atthasdef, pg_catalog.pg_get_expr(adef.adbin, adef.adrelid, true) as adsrc, + a.attstattarget, a.attstorage, t.typstorage, + ( + SELECT 1 FROM pg_catalog.pg_depend pd, pg_catalog.pg_class pc + WHERE pd.objid=pc.oid + AND pd.classid=pc.tableoid + AND pd.refclassid=pc.tableoid + AND pd.refobjid=a.attrelid + AND pd.refobjsubid=a.attnum + AND pd.deptype='i' + AND pc.relkind='S' + ) IS NOT NULL AS attisserial, + pg_catalog.col_description(a.attrelid, a.attnum) AS comment + FROM + pg_catalog.pg_attribute a LEFT JOIN pg_catalog.pg_attrdef adef + ON a.attrelid=adef.adrelid + AND a.attnum=adef.adnum + LEFT JOIN pg_catalog.pg_type t ON a.atttypid=t.oid + WHERE + a.attrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE + nspname = '{$c_schema}')) + AND a.attnum > 0 AND NOT a.attisdropped + ORDER BY a.attnum"; + } + else { + $sql = " + SELECT + a.attname, a.attnum, + pg_catalog.format_type(a.atttypid, a.atttypmod) as type, + pg_catalog.format_type(a.atttypid, NULL) as base_type, + a.atttypmod, + a.attnotnull, a.atthasdef, pg_catalog.pg_get_expr(adef.adbin, adef.adrelid, true) as adsrc, + a.attstattarget, a.attstorage, t.typstorage, + pg_catalog.col_description(a.attrelid, a.attnum) AS comment + FROM + pg_catalog.pg_attribute a LEFT JOIN pg_catalog.pg_attrdef adef + ON a.attrelid=adef.adrelid + AND a.attnum=adef.adnum + LEFT JOIN pg_catalog.pg_type t ON a.atttypid=t.oid + WHERE + a.attrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE + nspname = '{$c_schema}')) + AND a.attname = '{$field}'"; + } + + return $this->selectSet($sql); + } + + /** + * Finds the names and schemas of parent tables (in order) + * @param $table The table to find the parents for + * @return A recordset + */ + function getTableParents($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = " + SELECT + pn.nspname, relname + FROM + pg_catalog.pg_class pc, pg_catalog.pg_inherits pi, pg_catalog.pg_namespace pn + WHERE + pc.oid=pi.inhparent + AND pc.relnamespace=pn.oid + AND pi.inhrelid = (SELECT oid from pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname = '{$c_schema}')) + ORDER BY + pi.inhseqno + "; + + return $this->selectSet($sql); + } + + /** + * Finds the names and schemas of child tables + * @param $table The table to find the children for + * @return A recordset + */ + function getTableChildren($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = " + SELECT + pn.nspname, relname + FROM + pg_catalog.pg_class pc, pg_catalog.pg_inherits pi, pg_catalog.pg_namespace pn + WHERE + pc.oid=pi.inhrelid + AND pc.relnamespace=pn.oid + AND pi.inhparent = (SELECT oid from pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname = '{$c_schema}')) + "; + + return $this->selectSet($sql); + } + + /** + * Returns the SQL definition for the table. + * @pre MUST be run within a transaction + * @param $table The table to define + * @param $clean True to issue drop command, false otherwise + * @return A string containing the formatted SQL code + * @return null On error + */ + function getTableDefPrefix($table, $clean = false) { + // Fetch table + $t = $this->getTable($table); + if (!is_object($t) || $t->recordCount() != 1) { + $this->rollbackTransaction(); + return null; + } + $this->fieldClean($t->fields['relname']); + $this->fieldClean($t->fields['nspname']); + + // Fetch attributes + $atts = $this->getTableAttributes($table); + if (!is_object($atts)) { + $this->rollbackTransaction(); + return null; + } + + // Fetch constraints + $cons = $this->getConstraints($table); + if (!is_object($cons)) { + $this->rollbackTransaction(); + return null; + } + + // Output a reconnect command to create the table as the correct user + $sql = $this->getChangeUserSQL($t->fields['relowner']) . "\n\n"; + + // Set schema search path + $sql .= "SET search_path = \"{$t->fields['nspname']}\", pg_catalog;\n\n"; + + // Begin CREATE TABLE definition + $sql .= "-- Definition\n\n"; + // DROP TABLE must be fully qualified in case a table with the same name exists + // in pg_catalog. + if (!$clean) $sql .= "-- "; + $sql .= "DROP TABLE "; + $sql .= "\"{$t->fields['nspname']}\".\"{$t->fields['relname']}\";\n"; + $sql .= "CREATE TABLE \"{$t->fields['nspname']}\".\"{$t->fields['relname']}\" (\n"; + + // Output all table columns + $col_comments_sql = ''; // Accumulate comments on columns + $num = $atts->recordCount() + $cons->recordCount(); + $i = 1; + while (!$atts->EOF) { + $this->fieldClean($atts->fields['attname']); + $sql .= " \"{$atts->fields['attname']}\""; + // Dump SERIAL and BIGSERIAL columns correctly + if ($this->phpBool($atts->fields['attisserial']) && + ($atts->fields['type'] == 'integer' || $atts->fields['type'] == 'bigint')) { + if ($atts->fields['type'] == 'integer') + $sql .= " SERIAL"; + else + $sql .= " BIGSERIAL"; + } + else { + $sql .= " " . $this->formatType($atts->fields['type'], $atts->fields['atttypmod']); + + // Add NOT NULL if necessary + if ($this->phpBool($atts->fields['attnotnull'])) + $sql .= " NOT NULL"; + // Add default if necessary + if ($atts->fields['adsrc'] !== null) + $sql .= " DEFAULT {$atts->fields['adsrc']}"; + } + + // Output comma or not + if ($i < $num) $sql .= ",\n"; + else $sql .= "\n"; + + // Does this column have a comment? + if ($atts->fields['comment'] !== null) { + $this->clean($atts->fields['comment']); + $col_comments_sql .= "COMMENT ON COLUMN \"{$t->fields['relname']}\".\"{$atts->fields['attname']}\" IS '{$atts->fields['comment']}';\n"; + } + + $atts->moveNext(); + $i++; + } + // Output all table constraints + while (!$cons->EOF) { + $this->fieldClean($cons->fields['conname']); + $sql .= " CONSTRAINT \"{$cons->fields['conname']}\" "; + // Nasty hack to support pre-7.4 PostgreSQL + if ($cons->fields['consrc'] !== null) + $sql .= $cons->fields['consrc']; + else { + switch ($cons->fields['contype']) { + case 'p': + $keys = $this->getAttributeNames($table, explode(' ', $cons->fields['indkey'])); + $sql .= "PRIMARY KEY (" . join(',', $keys) . ")"; + break; + case 'u': + $keys = $this->getAttributeNames($table, explode(' ', $cons->fields['indkey'])); + $sql .= "UNIQUE (" . join(',', $keys) . ")"; + break; + default: + // Unrecognised constraint + $this->rollbackTransaction(); + return null; + } + } + + // Output comma or not + if ($i < $num) $sql .= ",\n"; + else $sql .= "\n"; + + $cons->moveNext(); + $i++; + } + + $sql .= ")"; + + // @@@@ DUMP CLUSTERING INFORMATION + + // Inherits + /* + * XXX: This is currently commented out as handling inheritance isn't this simple. + * You also need to make sure you don't dump inherited columns and defaults, as well + * as inherited NOT NULL and CHECK constraints. So for the time being, we just do + * not claim to support inheritance. + $parents = $this->getTableParents($table); + if ($parents->recordCount() > 0) { + $sql .= " INHERITS ("; + while (!$parents->EOF) { + $this->fieldClean($parents->fields['relname']); + // Qualify the parent table if it's in another schema + if ($parents->fields['schemaname'] != $this->_schema) { + $this->fieldClean($parents->fields['schemaname']); + $sql .= "\"{$parents->fields['schemaname']}\"."; + } + $sql .= "\"{$parents->fields['relname']}\""; + + $parents->moveNext(); + if (!$parents->EOF) $sql .= ', '; + } + $sql .= ")"; + } + */ + + // Handle WITHOUT OIDS + if ($this->hasObjectID($table)) + $sql .= " WITH OIDS"; + else + $sql .= " WITHOUT OIDS"; + + $sql .= ";\n"; + + // Column storage and statistics + $atts->moveFirst(); + $first = true; + while (!$atts->EOF) { + $this->fieldClean($atts->fields['attname']); + // Statistics first + if ($atts->fields['attstattarget'] >= 0) { + if ($first) { + $sql .= "\n"; + $first = false; + } + $sql .= "ALTER TABLE ONLY \"{$t->fields['nspname']}\".\"{$t->fields['relname']}\" ALTER COLUMN \"{$atts->fields['attname']}\" SET STATISTICS {$atts->fields['attstattarget']};\n"; + } + // Then storage + if ($atts->fields['attstorage'] != $atts->fields['typstorage']) { + switch ($atts->fields['attstorage']) { + case 'p': + $storage = 'PLAIN'; + break; + case 'e': + $storage = 'EXTERNAL'; + break; + case 'm': + $storage = 'MAIN'; + break; + case 'x': + $storage = 'EXTENDED'; + break; + default: + // Unknown storage type + $this->rollbackTransaction(); + return null; + } + $sql .= "ALTER TABLE ONLY \"{$t->fields['nspname']}\".\"{$t->fields['relname']}\" ALTER COLUMN \"{$atts->fields['attname']}\" SET STORAGE {$storage};\n"; + } + + $atts->moveNext(); + } + + // Comment + if ($t->fields['relcomment'] !== null) { + $this->clean($t->fields['relcomment']); + $sql .= "\n-- Comment\n\n"; + $sql .= "COMMENT ON TABLE \"{$t->fields['nspname']}\".\"{$t->fields['relname']}\" IS '{$t->fields['relcomment']}';\n"; + } + + // Add comments on columns, if any + if ($col_comments_sql != '') $sql .= $col_comments_sql; + + // Privileges + $privs = $this->getPrivileges($table, 'table'); + if (!is_array($privs)) { + $this->rollbackTransaction(); + return null; + } + + if (sizeof($privs) > 0) { + $sql .= "\n-- Privileges\n\n"; + /* + * Always start with REVOKE ALL FROM PUBLIC, so that we don't have to + * wire-in knowledge about the default public privileges for different + * kinds of objects. + */ + $sql .= "REVOKE ALL ON TABLE \"{$t->fields['nspname']}\".\"{$t->fields['relname']}\" FROM PUBLIC;\n"; + foreach ($privs as $v) { + // Get non-GRANT OPTION privs + $nongrant = array_diff($v[2], $v[4]); + + // Skip empty or owner ACEs + if (sizeof($v[2]) == 0 || ($v[0] == 'user' && $v[1] == $t->fields['relowner'])) continue; + + // Change user if necessary + if ($this->hasGrantOption() && $v[3] != $t->fields['relowner']) { + $grantor = $v[3]; + $this->clean($grantor); + $sql .= "SET SESSION AUTHORIZATION '{$grantor}';\n"; + } + + // Output privileges with no GRANT OPTION + $sql .= "GRANT " . join(', ', $nongrant) . " ON TABLE \"{$t->fields['relname']}\" TO "; + switch ($v[0]) { + case 'public': + $sql .= "PUBLIC;\n"; + break; + case 'user': + $this->fieldClean($v[1]); + $sql .= "\"{$v[1]}\";\n"; + break; + case 'group': + $this->fieldClean($v[1]); + $sql .= "GROUP \"{$v[1]}\";\n"; + break; + default: + // Unknown privilege type - fail + $this->rollbackTransaction(); + return null; + } + + // Reset user if necessary + if ($this->hasGrantOption() && $v[3] != $t->fields['relowner']) { + $sql .= "RESET SESSION AUTHORIZATION;\n"; + } + + // Output privileges with GRANT OPTION + + // Skip empty or owner ACEs + if (!$this->hasGrantOption() || sizeof($v[4]) == 0) continue; + + // Change user if necessary + if ($this->hasGrantOption() && $v[3] != $t->fields['relowner']) { + $grantor = $v[3]; + $this->clean($grantor); + $sql .= "SET SESSION AUTHORIZATION '{$grantor}';\n"; + } + + $sql .= "GRANT " . join(', ', $v[4]) . " ON \"{$t->fields['relname']}\" TO "; + switch ($v[0]) { + case 'public': + $sql .= "PUBLIC"; + break; + case 'user': + $this->fieldClean($v[1]); + $sql .= "\"{$v[1]}\""; + break; + case 'group': + $this->fieldClean($v[1]); + $sql .= "GROUP \"{$v[1]}\""; + break; + default: + // Unknown privilege type - fail + return null; + } + $sql .= " WITH GRANT OPTION;\n"; + + // Reset user if necessary + if ($this->hasGrantOption() && $v[3] != $t->fields['relowner']) { + $sql .= "RESET SESSION AUTHORIZATION;\n"; + } + + } + } + + // Add a newline to separate data that follows (if any) + $sql .= "\n"; + + return $sql; + } + + /** + * Returns extra table definition information that is most usefully + * dumped after the table contents for speed and efficiency reasons + * @param $table The table to define + * @return A string containing the formatted SQL code + * @return null On error + */ + function getTableDefSuffix($table) { + $sql = ''; + + // Indexes + $indexes = $this->getIndexes($table); + if (!is_object($indexes)) { + $this->rollbackTransaction(); + return null; + } + + if ($indexes->recordCount() > 0) { + $sql .= "\n-- Indexes\n\n"; + while (!$indexes->EOF) { + $sql .= $indexes->fields['inddef'] . ";\n"; + + $indexes->moveNext(); + } + } + + // Triggers + $triggers = $this->getTriggers($table); + if (!is_object($triggers)) { + $this->rollbackTransaction(); + return null; + } + + if ($triggers->recordCount() > 0) { + $sql .= "\n-- Triggers\n\n"; + while (!$triggers->EOF) { + + $sql .= $triggers->fields['tgdef']; + $sql .= ";\n"; + + $triggers->moveNext(); + } + } + + // Rules + $rules = $this->getRules($table); + if (!is_object($rules)) { + $this->rollbackTransaction(); + return null; + } + + if ($rules->recordCount() > 0) { + $sql .= "\n-- Rules\n\n"; + while (!$rules->EOF) { + $sql .= $rules->fields['definition'] . "\n"; + + $rules->moveNext(); + } + } + + return $sql; + } + + /** + * Creates a new table in the database + * @param $name The name of the table + * @param $fields The number of fields + * @param $field An array of field names + * @param $type An array of field types + * @param $array An array of '' or '[]' for each type if it's an array or not + * @param $length An array of field lengths + * @param $notnull An array of not null + * @param $default An array of default values + * @param $withoutoids True if WITHOUT OIDS, false otherwise + * @param $colcomment An array of comments + * @param $comment Table comment + * @param $tablespace The tablespace name ('' means none/default) + * @param $uniquekey An Array indicating the fields that are unique (those indexes that are set) + * @param $primarykey An Array indicating the field used for the primarykey (those indexes that are set) + * @return 0 success + * @return -1 no fields supplied + */ + function createTable($name, $fields, $field, $type, $array, $length, $notnull, + $default, $withoutoids, $colcomment, $tblcomment, $tablespace, + $uniquekey, $primarykey) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $found = false; + $first = true; + $comment_sql = ''; //Accumulate comments for the columns + $sql = "CREATE TABLE \"{$f_schema}\".\"{$name}\" ("; + for ($i = 0; $i < $fields; $i++) { + $this->fieldClean($field[$i]); + $this->clean($type[$i]); + $this->clean($length[$i]); + $this->clean($colcomment[$i]); + + // Skip blank columns - for user convenience + if ($field[$i] == '' || $type[$i] == '') continue; + // If not the first column, add a comma + if (!$first) $sql .= ", "; + else $first = false; + + switch ($type[$i]) { + // Have to account for weird placing of length for with/without + // time zone types + case 'timestamp with time zone': + case 'timestamp without time zone': + $qual = substr($type[$i], 9); + $sql .= "\"{$field[$i]}\" timestamp"; + if ($length[$i] != '') $sql .= "({$length[$i]})"; + $sql .= $qual; + break; + case 'time with time zone': + case 'time without time zone': + $qual = substr($type[$i], 4); + $sql .= "\"{$field[$i]}\" time"; + if ($length[$i] != '') $sql .= "({$length[$i]})"; + $sql .= $qual; + break; + default: + $sql .= "\"{$field[$i]}\" {$type[$i]}"; + if ($length[$i] != '') $sql .= "({$length[$i]})"; + } + // Add array qualifier if necessary + if ($array[$i] == '[]') $sql .= '[]'; + // Add other qualifiers + if (!isset($primarykey[$i])) { + if (isset($uniquekey[$i])) $sql .= " UNIQUE"; + if (isset($notnull[$i])) $sql .= " NOT NULL"; + } + if ($default[$i] != '') $sql .= " DEFAULT {$default[$i]}"; + + if ($colcomment[$i] != '') $comment_sql .= "COMMENT ON COLUMN \"{$name}\".\"{$field[$i]}\" IS '{$colcomment[$i]}';\n"; + + $found = true; + } + + if (!$found) return -1; + + // PRIMARY KEY + $primarykeycolumns = array(); + for ($i = 0; $i < $fields; $i++) { + if (isset($primarykey[$i])) { + $primarykeycolumns[] = "\"{$field[$i]}\""; + } + } + if (count($primarykeycolumns) > 0) { + $sql .= ", PRIMARY KEY (" . implode(", ", $primarykeycolumns) . ")"; + } + + $sql .= ")"; + + // WITHOUT OIDS + if ($withoutoids) + $sql .= ' WITHOUT OIDS'; + else + $sql .= ' WITH OIDS'; + + // Tablespace + if ($this->hasTablespaces() && $tablespace != '') { + $this->fieldClean($tablespace); + $sql .= " TABLESPACE \"{$tablespace}\""; + } + + $status = $this->execute($sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + + if ($tblcomment != '') { + $status = $this->setComment('TABLE', '', $name, $tblcomment, true); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + + if ($comment_sql != '') { + $status = $this->execute($comment_sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + return $this->endTransaction(); + } + + /** + * Creates a new table in the database copying attribs and other properties from another table + * @param $name The name of the table + * @param $like an array giving the schema ans the name of the table from which attribs are copying from: + * array( + * 'table' => table name, + * 'schema' => the schema name, + * ) + * @param $defaults if true, copy the defaults values as well + * @param $constraints if true, copy the constraints as well (CHECK on table & attr) + * @param $tablespace The tablespace name ('' means none/default) + */ + function createTableLike($name, $like, $defaults = false, $constraints = false, $idx = false, $tablespace = '') { + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + $this->fieldClean($like['schema']); + $this->fieldClean($like['table']); + $like = "\"{$like['schema']}\".\"{$like['table']}\""; + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $sql = "CREATE TABLE \"{$f_schema}\".\"{$name}\" (LIKE {$like}"; + + if ($defaults) $sql .= " INCLUDING DEFAULTS"; + if ($this->hasCreateTableLikeWithConstraints() && $constraints) $sql .= " INCLUDING CONSTRAINTS"; + if ($this->hasCreateTableLikeWithIndexes() && $idx) $sql .= " INCLUDING INDEXES"; + + $sql .= ")"; + + if ($this->hasTablespaces() && $tablespace != '') { + $this->fieldClean($tablespace); + $sql .= " TABLESPACE \"{$tablespace}\""; + } + + $status = $this->execute($sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + + return $this->endTransaction(); + } + + /** + * Alter a table's name + * /!\ this function is called from _alterTable which take care of escaping fields + * @param $tblrs The table RecordSet returned by getTable() + * @param $name The new table's name + * @return 0 success + */ + function alterTableName($tblrs, $name = null) { + /* vars cleaned in _alterTable */ + // Rename (only if name has changed) + if (!empty($name) && ($name != $tblrs->fields['relname'])) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$tblrs->fields['relname']}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status == 0) + $tblrs->fields['relname'] = $name; + else + return $status; + } + return 0; + } + + /** + * Alter a table's owner + * /!\ this function is called from _alterTable which take care of escaping fields + * @param $tblrs The table RecordSet returned by getTable() + * @param $name The new table's owner + * @return 0 success + */ + function alterTableOwner($tblrs, $owner = null) { + /* vars cleaned in _alterTable */ + if (!empty($owner) && ($tblrs->fields['relowner'] != $owner)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + // If owner has been changed, then do the alteration. We are + // careful to avoid this generally as changing owner is a + // superuser only function. + $sql = "ALTER TABLE \"{$f_schema}\".\"{$tblrs->fields['relname']}\" OWNER TO \"{$owner}\""; + + return $this->execute($sql); + } + return 0; + } + + /** + * Alter a table's tablespace + * /!\ this function is called from _alterTable which take care of escaping fields + * @param $tblrs The table RecordSet returned by getTable() + * @param $name The new table's tablespace + * @return 0 success + */ + function alterTableTablespace($tblrs, $tablespace = null) { + /* vars cleaned in _alterTable */ + if (!empty($tablespace) && ($tblrs->fields['tablespace'] != $tablespace)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + + // If tablespace has been changed, then do the alteration. We + // don't want to do this unnecessarily. + $sql = "ALTER TABLE \"{$f_schema}\".\"{$tblrs->fields['relname']}\" SET TABLESPACE \"{$tablespace}\""; + + return $this->execute($sql); + } + return 0; + } + + /** + * Alter a table's schema + * /!\ this function is called from _alterTable which take care of escaping fields + * @param $tblrs The table RecordSet returned by getTable() + * @param $name The new table's schema + * @return 0 success + */ + function alterTableSchema($tblrs, $schema = null) { + /* vars cleaned in _alterTable */ + if (!empty($schema) && ($tblrs->fields['nspname'] != $schema)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + // If tablespace has been changed, then do the alteration. We + // don't want to do this unnecessarily. + $sql = "ALTER TABLE \"{$f_schema}\".\"{$tblrs->fields['relname']}\" SET SCHEMA \"{$schema}\""; + + return $this->execute($sql); + } + return 0; + } + + /** + * Protected method which alter a table + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $tblrs The table recordSet returned by getTable() + * @param $name The new name for the table + * @param $owner The new owner for the table + * @param $schema The new schema for the table + * @param $comment The comment on the table + * @param $tablespace The new tablespace for the table ('' means leave as is) + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + * @return -6 tablespace error + * @return -7 schema error + */ + protected + function _alterTable($tblrs, $name, $owner, $schema, $comment, $tablespace) { + + $this->fieldArrayClean($tblrs->fields); + + // Comment + $status = $this->setComment('TABLE', '', $tblrs->fields['relname'], $comment); + if ($status != 0) return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterTableOwner($tblrs, $owner); + if ($status != 0) return -5; + + // Tablespace + $this->fieldClean($tablespace); + $status = $this->alterTableTablespace($tblrs, $tablespace); + if ($status != 0) return -6; + + // Rename + $this->fieldClean($name); + $status = $this->alterTableName($tblrs, $name); + if ($status != 0) return -3; + + // Schema + $this->fieldClean($schema); + $status = $this->alterTableSchema($tblrs, $schema); + if ($status != 0) return -7; + + return 0; + } + + /** + * Alter table properties + * @param $table The name of the table + * @param $name The new name for the table + * @param $owner The new owner for the table + * @param $schema The new schema for the table + * @param $comment The comment on the table + * @param $tablespace The new tablespace for the table ('' means leave as is) + * @return 0 success + * @return -1 transaction error + * @return -2 get existing table error + * @return $this->_alterTable error code + */ + function alterTable($table, $name, $owner, $schema, $comment, $tablespace) { + + $data = $this->getTable($table); + + if ($data->recordCount() != 1) + return -2; + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $status = $this->_alterTable($data, $name, $owner, $schema, $comment, $tablespace); + + if ($status != 0) { + $this->rollbackTransaction(); + return $status; + } + + return $this->endTransaction(); + } + + /** + * Returns the SQL for changing the current user + * @param $user The user to change to + * @return The SQL + */ + function getChangeUserSQL($user) { + $this->clean($user); + return "SET SESSION AUTHORIZATION '{$user}';"; + } + + /** + * Given an array of attnums and a relation, returns an array mapping + * attribute number to attribute name. + * @param $table The table to get attributes for + * @param $atts An array of attribute numbers + * @return An array mapping attnum to attname + * @return -1 $atts must be an array + * @return -2 wrong number of attributes found + */ + function getAttributeNames($table, $atts) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + $this->arrayClean($atts); + + if (!is_array($atts)) return -1; + + if (sizeof($atts) == 0) return array(); + + $sql = "SELECT attnum, attname FROM pg_catalog.pg_attribute WHERE + attrelid=(SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' AND + relnamespace=(SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}')) + AND attnum IN ('" . join("','", $atts) . "')"; + + $rs = $this->selectSet($sql); + if ($rs->recordCount() != sizeof($atts)) { + return -2; + } + else { + $temp = array(); + while (!$rs->EOF) { + $temp[$rs->fields['attnum']] = $rs->fields['attname']; + $rs->moveNext(); + } + return $temp; + } + } + + /** + * Empties a table in the database + * @param $table The table to be emptied + * @return 0 success + */ + function emptyTable($table) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + $sql = "DELETE FROM \"{$f_schema}\".\"{$table}\""; + + return $this->execute($sql); + } + + /** + * Removes a table from the database + * @param $table The table to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropTable($table, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + $sql = "DROP TABLE \"{$f_schema}\".\"{$table}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Add a new column to a table + * @param $table The table to add to + * @param $column The name of the new column + * @param $type The type of the column + * @param $array True if array type, false otherwise + * @param $notnull True if NOT NULL, false otherwise + * @param $default The default for the column. '' for none. + * @param $length The optional size of the column (ie. 30 for varchar(30)) + * @return 0 success + */ + function addColumn($table, $column, $type, $array, $length, $notnull, $default, $comment) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($column); + $this->clean($type); + $this->clean($length); + + if ($length == '') + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD COLUMN \"{$column}\" {$type}"; + else { + switch ($type) { + // Have to account for weird placing of length for with/without + // time zone types + case 'timestamp with time zone': + case 'timestamp without time zone': + $qual = substr($type, 9); + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD COLUMN \"{$column}\" timestamp({$length}){$qual}"; + break; + case 'time with time zone': + case 'time without time zone': + $qual = substr($type, 4); + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD COLUMN \"{$column}\" time({$length}){$qual}"; + break; + default: + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD COLUMN \"{$column}\" {$type}({$length})"; + } + } + + // Add array qualifier, if requested + if ($array) $sql .= '[]'; + + // If we have advanced column adding, add the extra qualifiers + if ($this->hasCreateFieldWithConstraints()) { + // NOT NULL clause + if ($notnull) $sql .= ' NOT NULL'; + + // DEFAULT clause + if ($default != '') $sql .= ' DEFAULT ' . $default; + } + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $status = $this->setComment('COLUMN', $column, $table, $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + return $this->endTransaction(); + } + + /** + * Alters a column in a table + * @param $table The table in which the column resides + * @param $column The column to alter + * @param $name The new name for the column + * @param $notnull (boolean) True if not null, false otherwise + * @param $oldnotnull (boolean) True if column is already not null, false otherwise + * @param $default The new default for the column + * @param $olddefault The old default for the column + * @param $type The new type for the column + * @param $array True if array type, false otherwise + * @param $length The optional size of the column (ie. 30 for varchar(30)) + * @param $oldtype The old type for the column + * @param $comment Comment for the column + * @return 0 success + * @return -1 batch alteration failed + * @return -4 rename column error + * @return -5 comment error + * @return -6 transaction error + */ + function alterColumn($table, $column, $name, $notnull, $oldnotnull, $default, $olddefault, + $type, $length, $array, $oldtype, $comment) + { + // Begin transaction + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -6; + } + + // Rename the column, if it has been changed + if ($column != $name) { + $status = $this->renameColumn($table, $column, $name); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + } + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + $this->fieldClean($table); + $this->fieldClean($column); + + $toAlter = array(); + // Create the command for changing nullability + if ($notnull != $oldnotnull) { + $toAlter[] = "ALTER COLUMN \"{$name}\" ". (($notnull) ? 'SET' : 'DROP') . " NOT NULL"; + } + + // Add default, if it has changed + if ($default != $olddefault) { + if ($default == '') { + $toAlter[] = "ALTER COLUMN \"{$name}\" DROP DEFAULT"; + } + else { + $toAlter[] = "ALTER COLUMN \"{$name}\" SET DEFAULT {$default}"; + } + } + + // Add type, if it has changed + if ($length == '') + $ftype = $type; + else { + switch ($type) { + // Have to account for weird placing of length for with/without + // time zone types + case 'timestamp with time zone': + case 'timestamp without time zone': + $qual = substr($type, 9); + $ftype = "timestamp({$length}){$qual}"; + break; + case 'time with time zone': + case 'time without time zone': + $qual = substr($type, 4); + $ftype = "time({$length}){$qual}"; + break; + default: + $ftype = "{$type}({$length})"; + } + } + + // Add array qualifier, if requested + if ($array) $ftype .= '[]'; + + if ($ftype != $oldtype) { + $toAlter[] = "ALTER COLUMN \"{$name}\" TYPE {$ftype}"; + } + + // Attempt to process the batch alteration, if anything has been changed + if (!empty($toAlter)) { + // Initialise an empty SQL string + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" " + . implode(',', $toAlter); + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + // Update the comment on the column + $status = $this->setComment('COLUMN', $name, $table, $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -5; + } + + return $this->endTransaction(); + } + + /** + * Renames a column in a table + * @param $table The table containing the column to be renamed + * @param $column The column to be renamed + * @param $newName The new name for the column + * @return 0 success + */ + function renameColumn($table, $column, $newName) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($column); + $this->fieldClean($newName); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" RENAME COLUMN \"{$column}\" TO \"{$newName}\""; + + return $this->execute($sql); + } + + /** + * Sets default value of a column + * @param $table The table from which to drop + * @param $column The column name to set + * @param $default The new default value + * @return 0 success + */ + function setColumnDefault($table, $column, $default) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($column); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ALTER COLUMN \"{$column}\" SET DEFAULT {$default}"; + + return $this->execute($sql); + } + + /** + * Sets whether or not a column can contain NULLs + * @param $table The table that contains the column + * @param $column The column to alter + * @param $state True to set null, false to set not null + * @return 0 success + */ + function setColumnNull($table, $column, $state) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($column); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ALTER COLUMN \"{$column}\" " . (($state) ? 'DROP' : 'SET') . " NOT NULL"; + + return $this->execute($sql); + } + + /** + * Drops a column from a table + * @param $table The table from which to drop a column + * @param $column The column to be dropped + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropColumn($table, $column, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($column); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" DROP COLUMN \"{$column}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Drops default value of a column + * @param $table The table from which to drop + * @param $column The column name to drop default + * @return 0 success + */ + function dropColumnDefault($table, $column) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($column); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ALTER COLUMN \"{$column}\" DROP DEFAULT"; + + return $this->execute($sql); + } + + /** + * Sets up the data object for a dump. eg. Starts the appropriate + * transaction, sets variables, etc. + * @return 0 success + */ + function beginDump() { + // Begin serializable transaction (to dump consistent data) + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + // Set serializable + $sql = "SET TRANSACTION ISOLATION LEVEL SERIALIZABLE"; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Set datestyle to ISO + $sql = "SET DATESTYLE = ISO"; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Set extra_float_digits to 2 + $sql = "SET extra_float_digits TO 2"; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + return 0; + } + + /** + * Ends the data object for a dump. + * @return 0 success + */ + function endDump() { + return $this->endTransaction(); + } + + /** + * Returns a recordset of all columns in a relation. Used for data export. + * @@ Note: Really needs to use a cursor + * @param $relation The name of a relation + * @return A recordset on success + * @return -1 Failed to set datestyle + */ + function dumpRelation($relation, $oids) { + $this->fieldClean($relation); + + // Actually retrieve the rows + if ($oids) $oid_str = $this->id . ', '; + else $oid_str = ''; + + return $this->selectSet("SELECT {$oid_str}* FROM \"{$relation}\""); + } + + /** + * Returns all available autovacuum per table information. + * @param $table if given, return autovacuum info for the given table or return all informations for all table + * + * @return A recordset + */ + function getTableAutovacuum($table='') { + + $sql = ''; + + if ($table !== '') { + $this->clean($table); + $c_schema = $this->_schema; + $this->clean($c_schema); + + $sql = "SELECT c.oid, nspname, relname, pg_catalog.array_to_string(reloptions, E',') AS reloptions + FROM pg_class c + LEFT JOIN pg_namespace n ON n.oid = c.relnamespace + WHERE c.relkind = 'r'::\"char\" + AND n.nspname NOT IN ('pg_catalog','information_schema') + AND c.reloptions IS NOT NULL + AND c.relname = '{$table}' AND n.nspname = '{$c_schema}' + ORDER BY nspname, relname"; + } + else { + $sql = "SELECT c.oid, nspname, relname, pg_catalog.array_to_string(reloptions, E',') AS reloptions + FROM pg_class c + LEFT JOIN pg_namespace n ON n.oid = c.relnamespace + WHERE c.relkind = 'r'::\"char\" + AND n.nspname NOT IN ('pg_catalog','information_schema') + AND c.reloptions IS NOT NULL + ORDER BY nspname, relname"; + + } + + /* tmp var to parse the results */ + $_autovacs = $this->selectSet($sql); + + /* result aray to return as RS */ + $autovacs = array(); + while (!$_autovacs->EOF) { + $_ = array( + 'nspname' => $_autovacs->fields['nspname'], + 'relname' => $_autovacs->fields['relname'] + ); + + foreach (explode(',', $_autovacs->fields['reloptions']) as $var) { + list($o, $v) = explode('=', $var); + $_[$o] = $v; + } + + $autovacs[] = $_; + + $_autovacs->moveNext(); + } + + include_once('./classes/ArrayRecordSet.php'); + return new ArrayRecordSet($autovacs); + } + + // Row functions + + /** + * Get the fields for uniquely identifying a row in a table + * @param $table The table for which to retrieve the identifier + * @return An array mapping attribute number to attribute name, empty for no identifiers + * @return -1 error + */ + function getRowIdentifier($table) { + $oldtable = $table; + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + // Get the first primary or unique index (sorting primary keys first) that + // is NOT a partial index. + $sql = " + SELECT indrelid, indkey + FROM pg_catalog.pg_index + WHERE indisunique AND indrelid=( + SELECT oid FROM pg_catalog.pg_class + WHERE relname='{$table}' AND relnamespace=( + SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}' + ) + ) AND indpred IS NULL AND indexprs IS NULL + ORDER BY indisprimary DESC LIMIT 1"; + $rs = $this->selectSet($sql); + + // If none, check for an OID column. Even though OIDs can be duplicated, the edit and delete row + // functions check that they're only modiying a single row. Otherwise, return empty array. + if ($rs->recordCount() == 0) { + // Check for OID column + $temp = array(); + if ($this->hasObjectID($table)) { + $temp = array('oid'); + } + $this->endTransaction(); + return $temp; + } + // Otherwise find the names of the keys + else { + $attnames = $this->getAttributeNames($oldtable, explode(' ', $rs->fields['indkey'])); + if (!is_array($attnames)) { + $this->rollbackTransaction(); + return -1; + } + else { + $this->endTransaction(); + return $attnames; + } + } + } + + /** + * Adds a new row to a table + * @param $table The table in which to insert + * @param $fields Array of given field in values + * @param $values Array of new values for the row + * @param $nulls An array mapping column => something if it is to be null + * @param $format An array of the data type (VALUE or EXPRESSION) + * @param $types An array of field types + * @return 0 success + * @return -1 invalid parameters + */ + function insertRow($table, $fields, $values, $nulls, $format, $types) { + + if (!is_array($fields) || !is_array($values) || !is_array($nulls) + || !is_array($format) || !is_array($types) + || (count($fields) != count($values)) + ) { + return -1; + } + else { + // Build clause + if (count($values) > 0) { + // Escape all field names + $fields = array_map(array('Postgres','fieldClean'), $fields); + $f_schema = $this->_schema; + $this->fieldClean($table); + $this->fieldClean($f_schema); + + $sql = ''; + foreach($values as $i => $value) { + + // Handle NULL values + if (isset($nulls[$i])) + $sql .= ',NULL'; + else + $sql .= ',' . $this->formatValue($types[$i], $format[$i], $value); + } + + $sql = "INSERT INTO \"{$f_schema}\".\"{$table}\" (\"". implode('","', $fields) ."\") + VALUES (". substr($sql, 1) .")"; + + return $this->execute($sql); + } + } + + return -1; + } + + /** + * Updates a row in a table + * @param $table The table in which to update + * @param $vars An array mapping new values for the row + * @param $nulls An array mapping column => something if it is to be null + * @param $format An array of the data type (VALUE or EXPRESSION) + * @param $types An array of field types + * @param $keyarr An array mapping column => value to update + * @return 0 success + * @return -1 invalid parameters + */ + function editRow($table, $vars, $nulls, $format, $types, $keyarr) { + if (!is_array($vars) || !is_array($nulls) || !is_array($format) || !is_array($types)) + return -1; + else { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + // Build clause + if (sizeof($vars) > 0) { + + foreach($vars as $key => $value) { + $this->fieldClean($key); + + // Handle NULL values + if (isset($nulls[$key])) $tmp = 'NULL'; + else $tmp = $this->formatValue($types[$key], $format[$key], $value); + + if (isset($sql)) $sql .= ", \"{$key}\"={$tmp}"; + else $sql = "UPDATE \"{$f_schema}\".\"{$table}\" SET \"{$key}\"={$tmp}"; + } + $first = true; + foreach ($keyarr as $k => $v) { + $this->fieldClean($k); + $this->clean($v); + if ($first) { + $sql .= " WHERE \"{$k}\"='{$v}'"; + $first = false; + } + else $sql .= " AND \"{$k}\"='{$v}'"; + } + } + + // Begin transaction. We do this so that we can ensure only one row is + // edited + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $status = $this->execute($sql); + if ($status != 0) { // update failed + $this->rollbackTransaction(); + return -1; + } elseif ($this->conn->Affected_Rows() != 1) { // more than one row could be updated + $this->rollbackTransaction(); + return -2; + } + + // End transaction + return $this->endTransaction(); + } + } + + /** + * Delete a row from a table + * @param $table The table from which to delete + * @param $key An array mapping column => value to delete + * @return 0 success + */ + function deleteRow($table, $key, $schema=false) { + if (!is_array($key)) return -1; + else { + // Begin transaction. We do this so that we can ensure only one row is + // deleted + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + if ($schema === false) $schema = $this->_schema; + + $status = $this->delete($table, $key, $schema); + if ($status != 0 || $this->conn->Affected_Rows() != 1) { + $this->rollbackTransaction(); + return -2; + } + + // End transaction + return $this->endTransaction(); + } + } + + // Sequence functions + + /** + * Returns properties of a single sequence + * @param $sequence Sequence name + * @return A recordset + */ + function getSequence($sequence) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $c_sequence = $sequence; + $this->fieldClean($sequence); + $this->clean($c_sequence); + + $sql = " + SELECT + c.relname AS seqname, s.*, + m.seqstart AS start_value, m.seqincrement AS increment_by, m.seqmax AS max_value, m.seqmin AS min_value, + m.seqcache AS cache_value, m.seqcycle AS is_cycled, + pg_catalog.obj_description(m.seqrelid, 'pg_class') AS seqcomment, + u.usename AS seqowner, n.nspname + FROM + \"{$sequence}\" AS s, pg_catalog.pg_sequence m, + pg_catalog.pg_class c, pg_catalog.pg_user u, pg_catalog.pg_namespace n + WHERE + c.relowner=u.usesysid AND c.relnamespace=n.oid + AND c.oid = m.seqrelid AND c.relname = '{$c_sequence}' AND c.relkind = 'S' AND n.nspname='{$c_schema}' + AND n.oid = c.relnamespace"; + + return $this->selectSet( $sql ); + } + + /** + * Returns all sequences in the current database + * @return A recordset + */ + function getSequences($all = false) { + if ($all) { + // Exclude pg_catalog and information_schema tables + $sql = "SELECT n.nspname, c.relname AS seqname, u.usename AS seqowner + FROM pg_catalog.pg_class c, pg_catalog.pg_user u, pg_catalog.pg_namespace n + WHERE c.relowner=u.usesysid AND c.relnamespace=n.oid + AND c.relkind = 'S' + AND n.nspname NOT IN ('pg_catalog', 'information_schema', 'pg_toast') + ORDER BY nspname, seqname"; + } else { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = "SELECT c.relname AS seqname, u.usename AS seqowner, pg_catalog.obj_description(c.oid, 'pg_class') AS seqcomment, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=c.reltablespace) AS tablespace + FROM pg_catalog.pg_class c, pg_catalog.pg_user u, pg_catalog.pg_namespace n + WHERE c.relowner=u.usesysid AND c.relnamespace=n.oid + AND c.relkind = 'S' AND n.nspname='{$c_schema}' ORDER BY seqname"; + } + + return $this->selectSet( $sql ); + } + + /** + * Execute nextval on a given sequence + * @param $sequence Sequence name + * @return 0 success + * @return -1 sequence not found + */ + function nextvalSequence($sequence) { + /* This double-cleaning is deliberate */ + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->clean($f_schema); + $this->fieldClean($sequence); + $this->clean($sequence); + + $sql = "SELECT pg_catalog.NEXTVAL('\"{$f_schema}\".\"{$sequence}\"')"; + + return $this->execute($sql); + } + + /** + * Execute setval on a given sequence + * @param $sequence Sequence name + * @param $nextvalue The next value + * @return 0 success + * @return -1 sequence not found + */ + function setvalSequence($sequence, $nextvalue) { + /* This double-cleaning is deliberate */ + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->clean($f_schema); + $this->fieldClean($sequence); + $this->clean($sequence); + $this->clean($nextvalue); + + $sql = "SELECT pg_catalog.SETVAL('\"{$f_schema}\".\"{$sequence}\"', '{$nextvalue}')"; + + return $this->execute($sql); + } + + /** + * Restart a given sequence to its start value + * @param $sequence Sequence name + * @return 0 success + * @return -1 sequence not found + */ + function restartSequence($sequence) { + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($sequence); + + $sql = "ALTER SEQUENCE \"{$f_schema}\".\"{$sequence}\" RESTART;"; + + return $this->execute($sql); + } + + /** + * Resets a given sequence to min value of sequence + * @param $sequence Sequence name + * @return 0 success + * @return -1 sequence not found + */ + function resetSequence($sequence) { + // Get the minimum value of the sequence + $seq = $this->getSequence($sequence); + if ($seq->recordCount() != 1) return -1; + $minvalue = $seq->fields['min_value']; + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + /* This double-cleaning is deliberate */ + $this->fieldClean($sequence); + $this->clean($sequence); + + $sql = "SELECT pg_catalog.SETVAL('\"{$f_schema}\".\"{$sequence}\"', {$minvalue})"; + + return $this->execute($sql); + } + + /** + * Creates a new sequence + * @param $sequence Sequence name + * @param $increment The increment + * @param $minvalue The min value + * @param $maxvalue The max value + * @param $startvalue The starting value + * @param $cachevalue The cache value + * @param $cycledvalue True if cycled, false otherwise + * @return 0 success + */ + function createSequence($sequence, $increment, $minvalue, $maxvalue, + $startvalue, $cachevalue, $cycledvalue) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($sequence); + $this->clean($increment); + $this->clean($minvalue); + $this->clean($maxvalue); + $this->clean($startvalue); + $this->clean($cachevalue); + + $sql = "CREATE SEQUENCE \"{$f_schema}\".\"{$sequence}\""; + if ($increment != '') $sql .= " INCREMENT {$increment}"; + if ($minvalue != '') $sql .= " MINVALUE {$minvalue}"; + if ($maxvalue != '') $sql .= " MAXVALUE {$maxvalue}"; + if ($startvalue != '') $sql .= " START {$startvalue}"; + if ($cachevalue != '') $sql .= " CACHE {$cachevalue}"; + if ($cycledvalue) $sql .= " CYCLE"; + + return $this->execute($sql); + } + + /** + * Rename a sequence + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $name The new name for the sequence + * @return 0 success + */ + function alterSequenceName($seqrs, $name) { + /* vars are cleaned in _alterSequence */ + if (!empty($name) && ($seqrs->fields['seqname'] != $name)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER SEQUENCE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status == 0) + $seqrs->fields['seqname'] = $name; + else + return $status; + } + return 0; + } + + /** + * Alter a sequence's owner + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $name The new owner for the sequence + * @return 0 success + */ + function alterSequenceOwner($seqrs, $owner) { + // If owner has been changed, then do the alteration. We are + // careful to avoid this generally as changing owner is a + // superuser only function. + /* vars are cleaned in _alterSequence */ + if (!empty($owner) && ($seqrs->fields['seqowner'] != $owner)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER SEQUENCE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" OWNER TO \"{$owner}\""; + return $this->execute($sql); + } + return 0; + } + + /** + * Alter a sequence's schema + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $name The new schema for the sequence + * @return 0 success + */ + function alterSequenceSchema($seqrs, $schema) { + /* vars are cleaned in _alterSequence */ + if (!empty($schema) && ($seqrs->fields['nspname'] != $schema)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER SEQUENCE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" SET SCHEMA {$schema}"; + return $this->execute($sql); + } + return 0; + } + + /** + * Alter a sequence's properties + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $increment The sequence incremental value + * @param $minvalue The sequence minimum value + * @param $maxvalue The sequence maximum value + * @param $restartvalue The sequence current value + * @param $cachevalue The sequence cache value + * @param $cycledvalue Sequence can cycle ? + * @param $startvalue The sequence start value when issueing a restart + * @return 0 success + */ + function alterSequenceProps($seqrs, $increment, $minvalue, $maxvalue, + $restartvalue, $cachevalue, $cycledvalue, $startvalue) { + + $sql = ''; + /* vars are cleaned in _alterSequence */ + if (!empty($increment) && ($increment != $seqrs->fields['increment_by'])) $sql .= " INCREMENT {$increment}"; + if (!empty($minvalue) && ($minvalue != $seqrs->fields['min_value'])) $sql .= " MINVALUE {$minvalue}"; + if (!empty($maxvalue) && ($maxvalue != $seqrs->fields['max_value'])) $sql .= " MAXVALUE {$maxvalue}"; + if (!empty($restartvalue) && ($restartvalue != $seqrs->fields['last_value'])) $sql .= " RESTART {$restartvalue}"; + if (!empty($cachevalue) && ($cachevalue != $seqrs->fields['cache_value'])) $sql .= " CACHE {$cachevalue}"; + if (!empty($startvalue) && ($startvalue != $seqrs->fields['start_value'])) $sql .= " START {$startvalue}"; + // toggle cycle yes/no + if (!is_null($cycledvalue)) $sql .= (!$cycledvalue ? ' NO ' : '') . " CYCLE"; + if ($sql != '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER SEQUENCE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" {$sql}"; + return $this->execute($sql); + } + return 0; + } + + /** + * Protected method which alter a sequence + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $seqrs The sequence recordSet returned by getSequence() + * @param $name The new name for the sequence + * @param $comment The comment on the sequence + * @param $owner The new owner for the sequence + * @param $schema The new schema for the sequence + * @param $increment The increment + * @param $minvalue The min value + * @param $maxvalue The max value + * @param $restartvalue The starting value + * @param $cachevalue The cache value + * @param $cycledvalue True if cycled, false otherwise + * @param $startvalue The sequence start value when issueing a restart + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + * @return -6 get sequence props error + * @return -7 schema error + */ + protected + function _alterSequence($seqrs, $name, $comment, $owner, $schema, $increment, + $minvalue, $maxvalue, $restartvalue, $cachevalue, $cycledvalue, $startvalue) { + + $this->fieldArrayClean($seqrs->fields); + + // Comment + $status = $this->setComment('SEQUENCE', $seqrs->fields['seqname'], '', $comment); + if ($status != 0) + return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterSequenceOwner($seqrs, $owner); + if ($status != 0) + return -5; + + // Props + $this->clean($increment); + $this->clean($minvalue); + $this->clean($maxvalue); + $this->clean($restartvalue); + $this->clean($cachevalue); + $this->clean($cycledvalue); + $this->clean($startvalue); + $status = $this->alterSequenceProps($seqrs, $increment, $minvalue, + $maxvalue, $restartvalue, $cachevalue, $cycledvalue, $startvalue); + if ($status != 0) + return -6; + + // Rename + $this->fieldClean($name); + $status = $this->alterSequenceName($seqrs, $name); + if ($status != 0) + return -3; + + // Schema + $this->clean($schema); + $status = $this->alterSequenceSchema($seqrs, $schema); + if ($status != 0) + return -7; + + return 0; + } + + /** + * Alters a sequence + * @param $sequence The name of the sequence + * @param $name The new name for the sequence + * @param $comment The comment on the sequence + * @param $owner The new owner for the sequence + * @param $schema The new schema for the sequence + * @param $increment The increment + * @param $minvalue The min value + * @param $maxvalue The max value + * @param $restartvalue The starting value + * @param $cachevalue The cache value + * @param $cycledvalue True if cycled, false otherwise + * @param $startvalue The sequence start value when issueing a restart + * @return 0 success + * @return -1 transaction error + * @return -2 get existing sequence error + * @return $this->_alterSequence error code + */ + function alterSequence($sequence, $name, $comment, $owner=null, $schema=null, $increment=null, + $minvalue=null, $maxvalue=null, $restartvalue=null, $cachevalue=null, $cycledvalue=null, $startvalue=null) { + + $this->fieldClean($sequence); + + $data = $this->getSequence($sequence); + + if ($data->recordCount() != 1) + return -2; + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $status = $this->_alterSequence($data, $name, $comment, $owner, $schema, $increment, + $minvalue, $maxvalue, $restartvalue, $cachevalue, $cycledvalue, $startvalue); + + if ($status != 0) { + $this->rollbackTransaction(); + return $status; + } + + return $this->endTransaction(); + } + + /** + * Drops a given sequence + * @param $sequence Sequence name + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropSequence($sequence, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($sequence); + + $sql = "DROP SEQUENCE \"{$f_schema}\".\"{$sequence}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + // View functions + + /** + * Returns all details for a particular view + * @param $view The name of the view to retrieve + * @return View info + */ + function getView($view) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($view); + + $sql = " + SELECT c.relname, n.nspname, pg_catalog.pg_get_userbyid(c.relowner) AS relowner, + pg_catalog.pg_get_viewdef(c.oid, true) AS vwdefinition, + pg_catalog.obj_description(c.oid, 'pg_class') AS relcomment + FROM pg_catalog.pg_class c + LEFT JOIN pg_catalog.pg_namespace n ON (n.oid = c.relnamespace) + WHERE (c.relname = '{$view}') AND n.nspname='{$c_schema}'"; + + return $this->selectSet($sql); + } + + /** + * Returns a list of all views in the database + * @return All views + */ + function getViews() { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT c.relname, pg_catalog.pg_get_userbyid(c.relowner) AS relowner, + pg_catalog.obj_description(c.oid, 'pg_class') AS relcomment + FROM pg_catalog.pg_class c + LEFT JOIN pg_catalog.pg_namespace n ON (n.oid = c.relnamespace) + WHERE (n.nspname='{$c_schema}') AND (c.relkind = 'v'::\"char\") + ORDER BY relname"; + + return $this->selectSet($sql); + } + + /** + * Updates a view. + * @param $viewname The name fo the view to update + * @param $definition The new definition for the view + * @return 0 success + * @return -1 transaction error + * @return -2 drop view error + * @return -3 create view error + */ + function setView($viewname, $definition,$comment) { + return $this->createView($viewname, $definition, true, $comment); + } + + /** + * Creates a new view. + * @param $viewname The name of the view to create + * @param $definition The definition for the new view + * @param $replace True to replace the view, false otherwise + * @return 0 success + */ + function createView($viewname, $definition, $replace, $comment) { + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($viewname); + + // Note: $definition not cleaned + + $sql = "CREATE "; + if ($replace) $sql .= "OR REPLACE "; + $sql .= "VIEW \"{$f_schema}\".\"{$viewname}\" AS {$definition}"; + + $status = $this->execute($sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + + if ($comment != '') { + $status = $this->setComment('VIEW', $viewname, '', $comment); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + } + + /** + * Rename a view + * @param $vwrs The view recordSet returned by getView() + * @param $name The new view's name + * @return 0 success + */ + function alterViewName($vwrs, $name) { + // Rename (only if name has changed) + /* $vwrs and $name are cleaned in _alterView */ + if (!empty($name) && ($name != $vwrs->fields['relname'])) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER VIEW \"{$f_schema}\".\"{$vwrs->fields['relname']}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status == 0) + $vwrs->fields['relname'] = $name; + else + return $status; + } + return 0; + } + + /** + * Alter a view's owner + * @param $vwrs The view recordSet returned by getView() + * @param $name The new view's owner + * @return 0 success + */ + function alterViewOwner($vwrs, $owner = null) { + /* $vwrs and $owner are cleaned in _alterView */ + if ((!empty($owner)) && ($vwrs->fields['relowner'] != $owner)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + // If owner has been changed, then do the alteration. We are + // careful to avoid this generally as changing owner is a + // superuser only function. + $sql = "ALTER TABLE \"{$f_schema}\".\"{$vwrs->fields['relname']}\" OWNER TO \"{$owner}\""; + return $this->execute($sql); + } + return 0; + } + + /** + * Alter a view's schema + * @param $vwrs The view recordSet returned by getView() + * @param $name The new view's schema + * @return 0 success + */ + function alterViewSchema($vwrs, $schema) { + /* $vwrs and $schema are cleaned in _alterView */ + if (!empty($schema) && ($vwrs->fields['nspname'] != $schema)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + // If tablespace has been changed, then do the alteration. We + // don't want to do this unnecessarily. + $sql = "ALTER TABLE \"{$f_schema}\".\"{$vwrs->fields['relname']}\" SET SCHEMA \"{$schema}\""; + return $this->execute($sql); + } + return 0; + } + + /** + * Protected method which alter a view + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $vwrs The view recordSet returned by getView() + * @param $name The new name for the view + * @param $owner The new owner for the view + * @param $comment The comment on the view + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + * @return -6 schema error + */ + protected + function _alterView($vwrs, $name, $owner, $schema, $comment) { + + $this->fieldArrayClean($vwrs->fields); + + // Comment + if ($this->setComment('VIEW', $vwrs->fields['relname'], '', $comment) != 0) + return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterViewOwner($vwrs, $owner); + if ($status != 0) return -5; + + // Rename + $this->fieldClean($name); + $status = $this->alterViewName($vwrs, $name); + if ($status != 0) return -3; + + // Schema + $this->fieldClean($schema); + $status = $this->alterViewSchema($vwrs, $schema); + if ($status != 0) return -6; + + return 0; + } + + /** + * Alter view properties + * @param $view The name of the view + * @param $name The new name for the view + * @param $owner The new owner for the view + * @param $schema The new schema for the view + * @param $comment The comment on the view + * @return 0 success + * @return -1 transaction error + * @return -2 get existing view error + * @return $this->_alterView error code + */ + function alterView($view, $name, $owner, $schema, $comment) { + + $data = $this->getView($view); + if ($data->recordCount() != 1) + return -2; + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $status = $this->_alterView($data, $name, $owner, $schema, $comment); + + if ($status != 0) { + $this->rollbackTransaction(); + return $status; + } + + return $this->endTransaction(); + } + + /** + * Drops a view. + * @param $viewname The name of the view to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropView($viewname, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($viewname); + + $sql = "DROP VIEW \"{$f_schema}\".\"{$viewname}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + // Index functions + + /** + * Grabs a list of indexes for a table + * @param $table The name of a table whose indexes to retrieve + * @param $unique Only get unique/pk indexes + * @return A recordset + */ + function getIndexes($table = '', $unique = false) { + $this->clean($table); + + $sql = " + SELECT c2.relname AS indname, i.indisprimary, i.indisunique, i.indisclustered, + pg_catalog.pg_get_indexdef(i.indexrelid, 0, true) AS inddef + FROM pg_catalog.pg_class c, pg_catalog.pg_class c2, pg_catalog.pg_index i + WHERE c.relname = '{$table}' AND pg_catalog.pg_table_is_visible(c.oid) + AND c.oid = i.indrelid AND i.indexrelid = c2.oid + "; + if ($unique) $sql .= " AND i.indisunique "; + $sql .= " ORDER BY c2.relname"; + + return $this->selectSet($sql); + } + + /** + * test if a table has been clustered on an index + * @param $table The table to test + * + * @return true if the table has been already clustered + */ + function alreadyClustered($table) { + + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT i.indisclustered + FROM pg_catalog.pg_class c, pg_catalog.pg_index i + WHERE c.relname = '{$table}' + AND c.oid = i.indrelid AND i.indisclustered + AND c.relnamespace = (SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}') + "; + + $v = $this->selectSet($sql); + + if ($v->recordCount() == 0) + return false; + + return true; + } + + /** + * Creates an index + * @param $name The index name + * @param $table The table on which to add the index + * @param $columns An array of columns that form the index + * or a string expression for a functional index + * @param $type The index type + * @param $unique True if unique, false otherwise + * @param $where Index predicate ('' for none) + * @param $tablespace The tablespaces ('' means none/default) + * @return 0 success + */ + function createIndex($name, $table, $columns, $type, $unique, $where, $tablespace, $concurrently) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + $this->fieldClean($table); + + $sql = "CREATE"; + if ($unique) $sql .= " UNIQUE"; + $sql .= " INDEX"; + if ($concurrently) $sql .= " CONCURRENTLY"; + $sql .= " \"{$name}\" ON \"{$f_schema}\".\"{$table}\" USING {$type} "; + + if (is_array($columns)) { + $this->arrayClean($columns); + $sql .= "(\"" . implode('","', $columns) . "\")"; + } else { + $sql .= "(" . $columns .")"; + } + + // Tablespace + if ($this->hasTablespaces() && $tablespace != '') { + $this->fieldClean($tablespace); + $sql .= " TABLESPACE \"{$tablespace}\""; + } + + // Predicate + if (trim($where) != '') { + $sql .= " WHERE ({$where})"; + } + + return $this->execute($sql); + } + + /** + * Removes an index from the database + * @param $index The index to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropIndex($index, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($index); + + $sql = "DROP INDEX \"{$f_schema}\".\"{$index}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Rebuild indexes + * @param $type 'DATABASE' or 'TABLE' or 'INDEX' + * @param $name The name of the specific database, table, or index to be reindexed + * @param $force If true, recreates indexes forcedly in PostgreSQL 7.0-7.1, forces rebuild of system indexes in 7.2-7.3, ignored in >=7.4 + */ + function reindex($type, $name, $force = false) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + switch($type) { + case 'DATABASE': + $sql = "REINDEX {$type} \"{$name}\""; + if ($force) $sql .= ' FORCE'; + break; + case 'TABLE': + case 'INDEX': + $sql = "REINDEX {$type} \"{$f_schema}\".\"{$name}\""; + if ($force) $sql .= ' FORCE'; + break; + default: + return -1; + } + + return $this->execute($sql); + } + + /** + * Clusters an index + * @param $index The name of the index + * @param $table The table the index is on + * @return 0 success + */ + function clusterIndex($table='', $index='') { + + $sql = 'CLUSTER'; + + // We don't bother with a transaction here, as there's no point rolling + // back an expensive cluster if a cheap analyze fails for whatever reason + + if (!empty($table)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $sql .= " \"{$f_schema}\".\"{$table}\""; + + if (!empty($index)) { + $this->fieldClean($index); + $sql .= " USING \"{$index}\""; + } + } + + return $this->execute($sql); + } + + // Constraint functions + + /** + * Returns a list of all constraints on a table + * @param $table The table to find rules for + * @return A recordset + */ + function getConstraints($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + // This SQL is greatly complicated by the need to retrieve + // index clustering information for primary and unique constraints + $sql = "SELECT + pc.conname, + pg_catalog.pg_get_constraintdef(pc.oid, true) AS consrc, + pc.contype, + CASE WHEN pc.contype='u' OR pc.contype='p' THEN ( + SELECT + indisclustered + FROM + pg_catalog.pg_depend pd, + pg_catalog.pg_class pl, + pg_catalog.pg_index pi + WHERE + pd.refclassid=pc.tableoid + AND pd.refobjid=pc.oid + AND pd.objid=pl.oid + AND pl.oid=pi.indexrelid + ) ELSE + NULL + END AS indisclustered + FROM + pg_catalog.pg_constraint pc + WHERE + pc.conrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}')) + ORDER BY + 1 + "; + + return $this->selectSet($sql); + } + + /** + * Returns a list of all constraints on a table, + * including constraint name, definition, related col and referenced namespace, + * table and col if needed + * @param $table the table where we are looking for fk + * @return a recordset + */ + function getConstraintsWithFields($table) { + + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + // get the max number of col used in a constraint for the table + $sql = "SELECT DISTINCT + max(SUBSTRING(array_dims(c.conkey) FROM \$patern\$^\\[.*:(.*)\\]$\$patern\$)) as nb + FROM pg_catalog.pg_constraint AS c + JOIN pg_catalog.pg_class AS r ON (c.conrelid=r.oid) + JOIN pg_catalog.pg_namespace AS ns ON (r.relnamespace=ns.oid) + WHERE + r.relname = '{$table}' AND ns.nspname='{$c_schema}'"; + + $rs = $this->selectSet($sql); + + if ($rs->EOF) $max_col = 0; + else $max_col = $rs->fields['nb']; + + $sql = ' + SELECT + c.oid AS conid, c.contype, c.conname, pg_catalog.pg_get_constraintdef(c.oid, true) AS consrc, + ns1.nspname as p_schema, r1.relname as p_table, ns2.nspname as f_schema, + r2.relname as f_table, f1.attname as p_field, f1.attnum AS p_attnum, f2.attname as f_field, + f2.attnum AS f_attnum, pg_catalog.obj_description(c.oid, \'pg_constraint\') AS constcomment, + c.conrelid, c.confrelid + FROM + pg_catalog.pg_constraint AS c + JOIN pg_catalog.pg_class AS r1 ON (c.conrelid=r1.oid) + JOIN pg_catalog.pg_attribute AS f1 ON (f1.attrelid=r1.oid AND (f1.attnum=c.conkey[1]'; + for ($i = 2; $i <= $rs->fields['nb']; $i++) { + $sql.= " OR f1.attnum=c.conkey[$i]"; + } + $sql.= ')) + JOIN pg_catalog.pg_namespace AS ns1 ON r1.relnamespace=ns1.oid + LEFT JOIN ( + pg_catalog.pg_class AS r2 JOIN pg_catalog.pg_namespace AS ns2 ON (r2.relnamespace=ns2.oid) + ) ON (c.confrelid=r2.oid) + LEFT JOIN pg_catalog.pg_attribute AS f2 ON + (f2.attrelid=r2.oid AND ((c.confkey[1]=f2.attnum AND c.conkey[1]=f1.attnum)'; + for ($i = 2; $i <= $rs->fields['nb']; $i++) + $sql.= " OR (c.confkey[$i]=f2.attnum AND c.conkey[$i]=f1.attnum)"; + + $sql .= sprintf(")) + WHERE + r1.relname = '%s' AND ns1.nspname='%s' + ORDER BY 1", $table, $c_schema); + + return $this->selectSet($sql); + } + + /** + * Adds a primary key constraint to a table + * @param $table The table to which to add the primery key + * @param $fields (array) An array of fields over which to add the primary key + * @param $name (optional) The name to give the key, otherwise default name is assigned + * @param $tablespace (optional) The tablespace for the schema, '' indicates default. + * @return 0 success + * @return -1 no fields given + */ + function addPrimaryKey($table, $fields, $name = '', $tablespace = '') { + if (!is_array($fields) || sizeof($fields) == 0) return -1; + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldArrayClean($fields); + $this->fieldClean($name); + $this->fieldClean($tablespace); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD "; + if ($name != '') $sql .= "CONSTRAINT \"{$name}\" "; + $sql .= "PRIMARY KEY (\"" . join('","', $fields) . "\")"; + + if ($tablespace != '' && $this->hasTablespaces()) + $sql .= " USING INDEX TABLESPACE \"{$tablespace}\""; + + return $this->execute($sql); + } + + /** + * Adds a unique constraint to a table + * @param $table The table to which to add the unique key + * @param $fields (array) An array of fields over which to add the unique key + * @param $name (optional) The name to give the key, otherwise default name is assigned + * @param $tablespace (optional) The tablespace for the schema, '' indicates default. + * @return 0 success + * @return -1 no fields given + */ + function addUniqueKey($table, $fields, $name = '', $tablespace = '') { + if (!is_array($fields) || sizeof($fields) == 0) return -1; + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldArrayClean($fields); + $this->fieldClean($name); + $this->fieldClean($tablespace); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD "; + if ($name != '') $sql .= "CONSTRAINT \"{$name}\" "; + $sql .= "UNIQUE (\"" . join('","', $fields) . "\")"; + + if ($tablespace != '' && $this->hasTablespaces()) + $sql .= " USING INDEX TABLESPACE \"{$tablespace}\""; + + return $this->execute($sql); + } + + /** + * Adds a check constraint to a table + * @param $table The table to which to add the check + * @param $definition The definition of the check + * @param $name (optional) The name to give the check, otherwise default name is assigned + * @return 0 success + */ + function addCheckConstraint($table, $definition, $name = '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($name); + // @@ How the heck do you clean a definition??? + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD "; + if ($name != '') $sql .= "CONSTRAINT \"{$name}\" "; + $sql .= "CHECK ({$definition})"; + + return $this->execute($sql); + } + + /** + * Drops a check constraint from a table + * @param $table The table from which to drop the check + * @param $name The name of the check to be dropped + * @return 0 success + * @return -2 transaction error + * @return -3 lock error + * @return -4 check drop error + */ + function dropCheckConstraint($table, $name) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $c_schema = $this->_schema; + $this->clean($c_schema); + $c_table = $table; + $this->fieldClean($table); + $this->clean($c_table); + $this->clean($name); + + // Begin transaction + $status = $this->beginTransaction(); + if ($status != 0) return -2; + + // Properly lock the table + $sql = "LOCK TABLE \"{$f_schema}\".\"{$table}\" IN ACCESS EXCLUSIVE MODE"; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + + // Delete the check constraint + $sql = "DELETE FROM pg_relcheck WHERE rcrelid=(SELECT oid FROM pg_catalog.pg_class WHERE relname='{$c_table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE + nspname = '{$c_schema}')) AND rcname='{$name}'"; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + + // Update the pg_class catalog to reflect the new number of checks + $sql = "UPDATE pg_class SET relchecks=(SELECT COUNT(*) FROM pg_relcheck WHERE + rcrelid=(SELECT oid FROM pg_catalog.pg_class WHERE relname='{$c_table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE + nspname = '{$c_schema}'))) + WHERE relname='{$c_table}'"; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + + // Otherwise, close the transaction + return $this->endTransaction(); + } + + /** + * Adds a foreign key constraint to a table + * @param $targschema The schema that houses the target table to which to add the foreign key + * @param $targtable The table to which to add the foreign key + * @param $target The table that contains the target columns + * @param $sfields (array) An array of source fields over which to add the foreign key + * @param $tfields (array) An array of target fields over which to add the foreign key + * @param $upd_action The action for updates (eg. RESTRICT) + * @param $del_action The action for deletes (eg. RESTRICT) + * @param $match The match type (eg. MATCH FULL) + * @param $deferrable The deferrability (eg. NOT DEFERRABLE) + * @param $intially The initial deferrability (eg. INITIALLY IMMEDIATE) + * @param $name (optional) The name to give the key, otherwise default name is assigned + * @return 0 success + * @return -1 no fields given + */ + function addForeignKey($table, $targschema, $targtable, $sfields, $tfields, $upd_action, $del_action, + $match, $deferrable, $initially, $name = '') { + if (!is_array($sfields) || sizeof($sfields) == 0 || + !is_array($tfields) || sizeof($tfields) == 0) return -1; + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($targschema); + $this->fieldClean($targtable); + $this->fieldArrayClean($sfields); + $this->fieldArrayClean($tfields); + $this->fieldClean($name); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ADD "; + if ($name != '') $sql .= "CONSTRAINT \"{$name}\" "; + $sql .= "FOREIGN KEY (\"" . join('","', $sfields) . "\") "; + // Target table needs to be fully qualified + $sql .= "REFERENCES \"{$targschema}\".\"{$targtable}\"(\"" . join('","', $tfields) . "\") "; + if ($match != $this->fkmatches[0]) $sql .= " {$match}"; + if ($upd_action != $this->fkactions[0]) $sql .= " ON UPDATE {$upd_action}"; + if ($del_action != $this->fkactions[0]) $sql .= " ON DELETE {$del_action}"; + if ($deferrable != $this->fkdeferrable[0]) $sql .= " {$deferrable}"; + if ($initially != $this->fkinitial[0]) $sql .= " {$initially}"; + + return $this->execute($sql); + } + + /** + * Removes a constraint from a relation + * @param $constraint The constraint to drop + * @param $relation The relation from which to drop + * @param $type The type of constraint (c, f, u or p) + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropConstraint($constraint, $relation, $type, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($constraint); + $this->fieldClean($relation); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$relation}\" DROP CONSTRAINT \"{$constraint}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * A function for getting all columns linked by foreign keys given a group of tables + * @param $tables multi dimensional assoc array that holds schema and table name + * @return A recordset of linked tables and columns + * @return -1 $tables isn't an array + */ + function getLinkingKeys($tables) { + if (!is_array($tables)) return -1; + + $this->clean($tables[0]['tablename']); + $this->clean($tables[0]['schemaname']); + $tables_list = "'{$tables[0]['tablename']}'"; + $schema_list = "'{$tables[0]['schemaname']}'"; + $schema_tables_list = "'{$tables[0]['schemaname']}.{$tables[0]['tablename']}'"; + + for ($i = 1; $i < sizeof($tables); $i++) { + $this->clean($tables[$i]['tablename']); + $this->clean($tables[$i]['schemaname']); + $tables_list .= ", '{$tables[$i]['tablename']}'"; + $schema_list .= ", '{$tables[$i]['schemaname']}'"; + $schema_tables_list .= ", '{$tables[$i]['schemaname']}.{$tables[$i]['tablename']}'"; + } + + $maxDimension = 1; + + $sql = " + SELECT DISTINCT + array_dims(pc.conkey) AS arr_dim, + pgc1.relname AS p_table + FROM + pg_catalog.pg_constraint AS pc, + pg_catalog.pg_class AS pgc1 + WHERE + pc.contype = 'f' + AND (pc.conrelid = pgc1.relfilenode OR pc.confrelid = pgc1.relfilenode) + AND pgc1.relname IN ($tables_list) + "; + + //parse our output to find the highest dimension of foreign keys since pc.conkey is stored in an array + $rs = $this->selectSet($sql); + while (!$rs->EOF) { + $arrData = explode(':', $rs->fields['arr_dim']); + $tmpDimension = intval(substr($arrData[1], 0, strlen($arrData[1] - 1))); + $maxDimension = $tmpDimension > $maxDimension ? $tmpDimension : $maxDimension; + $rs->MoveNext(); + } + + //we know the highest index for foreign keys that conkey goes up to, expand for us in an IN query + $cons_str = '( (pfield.attnum = conkey[1] AND cfield.attnum = confkey[1]) '; + for ($i = 2; $i <= $maxDimension; $i++) { + $cons_str .= "OR (pfield.attnum = conkey[{$i}] AND cfield.attnum = confkey[{$i}]) "; + } + $cons_str .= ') '; + + $sql = " + SELECT + pgc1.relname AS p_table, + pgc2.relname AS f_table, + pfield.attname AS p_field, + cfield.attname AS f_field, + pgns1.nspname AS p_schema, + pgns2.nspname AS f_schema + FROM + pg_catalog.pg_constraint AS pc, + pg_catalog.pg_class AS pgc1, + pg_catalog.pg_class AS pgc2, + pg_catalog.pg_attribute AS pfield, + pg_catalog.pg_attribute AS cfield, + (SELECT oid AS ns_id, nspname FROM pg_catalog.pg_namespace WHERE nspname IN ($schema_list) ) AS pgns1, + (SELECT oid AS ns_id, nspname FROM pg_catalog.pg_namespace WHERE nspname IN ($schema_list) ) AS pgns2 + WHERE + pc.contype = 'f' + AND pgc1.relnamespace = pgns1.ns_id + AND pgc2.relnamespace = pgns2.ns_id + AND pc.conrelid = pgc1.relfilenode + AND pc.confrelid = pgc2.relfilenode + AND pfield.attrelid = pc.conrelid + AND cfield.attrelid = pc.confrelid + AND $cons_str + AND pgns1.nspname || '.' || pgc1.relname IN ($schema_tables_list) + AND pgns2.nspname || '.' || pgc2.relname IN ($schema_tables_list) + "; + return $this->selectSet($sql); + } + + /** + * Finds the foreign keys that refer to the specified table + * @param $table The table to find referrers for + * @return A recordset + */ + function getReferrers($table) { + $this->clean($table); + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $c_schema = $this->_schema; + $this->clean($c_schema); + + $sql = " + SELECT + pn.nspname, + pl.relname, + pc.conname, + pg_catalog.pg_get_constraintdef(pc.oid) AS consrc + FROM + pg_catalog.pg_constraint pc, + pg_catalog.pg_namespace pn, + pg_catalog.pg_class pl + WHERE + pc.connamespace = pn.oid + AND pc.conrelid = pl.oid + AND pc.contype = 'f' + AND confrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace = (SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}')) + ORDER BY 1,2,3 + "; + + return $this->selectSet($sql); + } + + // Domain functions + + /** + * Gets all information for a single domain + * @param $domain The name of the domain to fetch + * @return A recordset + */ + function getDomain($domain) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($domain); + + $sql = " + SELECT + t.typname AS domname, + pg_catalog.format_type(t.typbasetype, t.typtypmod) AS domtype, + t.typnotnull AS domnotnull, + t.typdefault AS domdef, + pg_catalog.pg_get_userbyid(t.typowner) AS domowner, + pg_catalog.obj_description(t.oid, 'pg_type') AS domcomment + FROM + pg_catalog.pg_type t + WHERE + t.typtype = 'd' + AND t.typname = '{$domain}' + AND t.typnamespace = (SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname = '{$c_schema}')"; + + return $this->selectSet($sql); + } + + /** + * Return all domains in current schema. Excludes domain constraints. + * @return All tables, sorted alphabetically + */ + function getDomains() { + $c_schema = $this->_schema; + $this->clean($c_schema); + + $sql = " + SELECT + t.typname AS domname, + pg_catalog.format_type(t.typbasetype, t.typtypmod) AS domtype, + t.typnotnull AS domnotnull, + t.typdefault AS domdef, + pg_catalog.pg_get_userbyid(t.typowner) AS domowner, + pg_catalog.obj_description(t.oid, 'pg_type') AS domcomment + FROM + pg_catalog.pg_type t + WHERE + t.typtype = 'd' + AND t.typnamespace = (SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}') + ORDER BY t.typname"; + + return $this->selectSet($sql); + } + + /** + * Get domain constraints + * @param $domain The name of the domain whose constraints to fetch + * @return A recordset + */ + function getDomainConstraints($domain) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($domain); + + $sql = " + SELECT + conname, + contype, + pg_catalog.pg_get_constraintdef(oid, true) AS consrc + FROM + pg_catalog.pg_constraint + WHERE + contypid = ( + SELECT oid FROM pg_catalog.pg_type + WHERE typname='{$domain}' + AND typnamespace = ( + SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname = '{$c_schema}') + ) + ORDER BY conname"; + + return $this->selectSet($sql); + } + + /** + * Creates a domain + * @param $domain The name of the domain to create + * @param $type The base type for the domain + * @param $length Optional type length + * @param $array True for array type, false otherwise + * @param $notnull True for NOT NULL, false otherwise + * @param $default Default value for domain + * @param $check A CHECK constraint if there is one + * @return 0 success + */ + function createDomain($domain, $type, $length, $array, $notnull, $default, $check) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($domain); + + $sql = "CREATE DOMAIN \"{$f_schema}\".\"{$domain}\" AS "; + + if ($length == '') + $sql .= $type; + else { + switch ($type) { + // Have to account for weird placing of length for with/without + // time zone types + case 'timestamp with time zone': + case 'timestamp without time zone': + $qual = substr($type, 9); + $sql .= "timestamp({$length}){$qual}"; + break; + case 'time with time zone': + case 'time without time zone': + $qual = substr($type, 4); + $sql .= "time({$length}){$qual}"; + break; + default: + $sql .= "{$type}({$length})"; + } + } + + // Add array qualifier, if requested + if ($array) $sql .= '[]'; + + if ($notnull) $sql .= ' NOT NULL'; + if ($default != '') $sql .= " DEFAULT {$default}"; + if ($this->hasDomainConstraints() && $check != '') $sql .= " CHECK ({$check})"; + + return $this->execute($sql); + } + + /** + * Alters a domain + * @param $domain The domain to alter + * @param $domdefault The domain default + * @param $domnotnull True for NOT NULL, false otherwise + * @param $domowner The domain owner + * @return 0 success + * @return -1 transaction error + * @return -2 default error + * @return -3 not null error + * @return -4 owner error + */ + function alterDomain($domain, $domdefault, $domnotnull, $domowner) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($domain); + $this->fieldClean($domowner); + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Default + if ($domdefault == '') + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" DROP DEFAULT"; + else + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" SET DEFAULT {$domdefault}"; + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + + // NOT NULL + if ($domnotnull) + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" SET NOT NULL"; + else + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" DROP NOT NULL"; + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + + // Owner + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" OWNER TO \"{$domowner}\""; + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + + return $this->endTransaction(); + } + + /** + * Drops a domain. + * @param $domain The name of the domain to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropDomain($domain, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($domain); + + $sql = "DROP DOMAIN \"{$f_schema}\".\"{$domain}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Adds a check constraint to a domain + * @param $domain The domain to which to add the check + * @param $definition The definition of the check + * @param $name (optional) The name to give the check, otherwise default name is assigned + * @return 0 success + */ + function addDomainCheckConstraint($domain, $definition, $name = '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($domain); + $this->fieldClean($name); + + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" ADD "; + if ($name != '') $sql .= "CONSTRAINT \"{$name}\" "; + $sql .= "CHECK ({$definition})"; + + return $this->execute($sql); + } + + /** + * Drops a domain constraint + * @param $domain The domain from which to remove the constraint + * @param $constraint The constraint to remove + * @param $cascade True to cascade, false otherwise + * @return 0 success + */ + function dropDomainConstraint($domain, $constraint, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($domain); + $this->fieldClean($constraint); + + $sql = "ALTER DOMAIN \"{$f_schema}\".\"{$domain}\" DROP CONSTRAINT \"{$constraint}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + // Function functions + + /** + * Returns all details for a particular function + * @param $func The name of the function to retrieve + * @return Function info + */ + function getFunction($function_oid) { + $this->clean($function_oid); + + $sql = " + SELECT + pc.oid AS prooid, proname, + pg_catalog.pg_get_userbyid(proowner) AS proowner, + nspname as proschema, lanname as prolanguage, procost, prorows, + pg_catalog.format_type(prorettype, NULL) as proresult, prosrc, + probin, proretset, proisstrict, provolatile, prosecdef, + pg_catalog.oidvectortypes(pc.proargtypes) AS proarguments, + proargnames AS proargnames, + pg_catalog.obj_description(pc.oid, 'pg_proc') AS procomment, + proconfig, + (select array_agg( (select typname from pg_type pt + where pt.oid = p.oid) ) from unnest(proallargtypes) p) + AS proallarguments, + proargmodes + FROM + pg_catalog.pg_proc pc, pg_catalog.pg_language pl, + pg_catalog.pg_namespace pn + WHERE + pc.oid = '{$function_oid}'::oid AND pc.prolang = pl.oid + AND pc.pronamespace = pn.oid + "; + + return $this->selectSet($sql); + } + + /** + * Returns a list of all functions in the database + * @param $all If true, will find all available functions, if false just those in search path + * @param $type If not null, will find all functions with return value = type + * + * @return All functions + */ + function getFunctions($all = false, $type = null) { + if ($all) { + $where = 'pg_catalog.pg_function_is_visible(p.oid)'; + $distinct = 'DISTINCT ON (p.proname)'; + + if ($type) { + $where .= " AND p.prorettype = (select oid from pg_catalog.pg_type p where p.typname = 'trigger') "; + } + } + else { + $c_schema = $this->_schema; + $this->clean($c_schema); + $where = "n.nspname = '{$c_schema}'"; + $distinct = ''; + } + + $sql = " + SELECT + {$distinct} + p.oid AS prooid, + p.proname, + p.proretset, + pg_catalog.format_type(p.prorettype, NULL) AS proresult, + pg_catalog.oidvectortypes(p.proargtypes) AS proarguments, + pl.lanname AS prolanguage, + pg_catalog.obj_description(p.oid, 'pg_proc') AS procomment, + p.proname || ' (' || pg_catalog.oidvectortypes(p.proargtypes) || ')' AS proproto, + CASE WHEN p.proretset THEN 'setof ' ELSE '' END || pg_catalog.format_type(p.prorettype, NULL) AS proreturns, + u.usename AS proowner + FROM pg_catalog.pg_proc p + INNER JOIN pg_catalog.pg_namespace n ON n.oid = p.pronamespace + INNER JOIN pg_catalog.pg_language pl ON pl.oid = p.prolang + LEFT JOIN pg_catalog.pg_user u ON u.usesysid = p.proowner + WHERE NOT p.proisagg + AND {$where} + ORDER BY p.proname, proresult + "; + + return $this->selectSet($sql); + } + + /** + * Returns an array containing a function's properties + * @param $f The array of data for the function + * @return An array containing the properties + */ + function getFunctionProperties($f) { + $temp = array(); + + // Volatility + if ($f['provolatile'] == 'v') + $temp[] = 'VOLATILE'; + elseif ($f['provolatile'] == 'i') + $temp[] = 'IMMUTABLE'; + elseif ($f['provolatile'] == 's') + $temp[] = 'STABLE'; + else + return -1; + + // Null handling + $f['proisstrict'] = $this->phpBool($f['proisstrict']); + if ($f['proisstrict']) + $temp[] = 'RETURNS NULL ON NULL INPUT'; + else + $temp[] = 'CALLED ON NULL INPUT'; + + // Security + $f['prosecdef'] = $this->phpBool($f['prosecdef']); + if ($f['prosecdef']) + $temp[] = 'SECURITY DEFINER'; + else + $temp[] = 'SECURITY INVOKER'; + + return $temp; + } + + /** + * Updates (replaces) a function. + * @param $function_oid The OID of the function + * @param $funcname The name of the function to create + * @param $newname The new name for the function + * @param $args The array of argument types + * @param $returns The return type + * @param $definition The definition for the new function + * @param $language The language the function is written for + * @param $flags An array of optional flags + * @param $setof True if returns a set, false otherwise + * @param $comment The comment on the function + * @return 0 success + * @return -1 transaction error + * @return -3 create function error + * @return -4 comment error + * @return -5 rename function error + * @return -6 alter owner error + * @return -7 alter schema error + */ + function setFunction($function_oid, $funcname, $newname, $args, $returns, $definition, $language, $flags, $setof, $funcown, $newown, $funcschema, $newschema, $cost, $rows, $comment) { + // Begin a transaction + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Replace the existing function + $status = $this->createFunction($funcname, $args, $returns, $definition, $language, $flags, $setof, $cost, $rows, $comment, true); + if ($status != 0) { + $this->rollbackTransaction(); + return $status; + } + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + + // Rename the function, if necessary + $this->fieldClean($newname); + /* $funcname is escaped in createFunction */ + if ($funcname != $newname) { + $sql = "ALTER FUNCTION \"{$f_schema}\".\"{$funcname}\"({$args}) RENAME TO \"{$newname}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -5; + } + + $funcname = $newname; + } + + // Alter the owner, if necessary + if ($this->hasFunctionAlterOwner()) { + $this->fieldClean($newown); + if ($funcown != $newown) { + $sql = "ALTER FUNCTION \"{$f_schema}\".\"{$funcname}\"({$args}) OWNER TO \"{$newown}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -6; + } + } + + } + + // Alter the schema, if necessary + if ($this->hasFunctionAlterSchema()) { + $this->fieldClean($newschema); + /* $funcschema is escaped in createFunction */ + if ($funcschema != $newschema) { + $sql = "ALTER FUNCTION \"{$f_schema}\".\"{$funcname}\"({$args}) SET SCHEMA \"{$newschema}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -7; + } + } + } + + return $this->endTransaction(); + } + + /** + * Creates a new function. + * @param $funcname The name of the function to create + * @param $args A comma separated string of types + * @param $returns The return type + * @param $definition The definition for the new function + * @param $language The language the function is written for + * @param $flags An array of optional flags + * @param $setof True if it returns a set, false otherwise + * @param $rows number of rows planner should estimate will be returned + * @param $cost cost the planner should use in the function execution step + * @param $comment Comment for the function + * @param $replace (optional) True if OR REPLACE, false for normal + * @return 0 success + * @return -3 create function failed + * @return -4 set comment failed + */ + function createFunction($funcname, $args, $returns, $definition, $language, $flags, $setof, $cost, $rows, $comment, $replace = false) { + + // Begin a transaction + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $this->fieldClean($funcname); + $this->clean($args); + $this->fieldClean($language); + $this->arrayClean($flags); + $this->clean($cost); + $this->clean($rows); + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + + $sql = "CREATE"; + if ($replace) $sql .= " OR REPLACE"; + $sql .= " FUNCTION \"{$f_schema}\".\"{$funcname}\" ("; + + if ($args != '') + $sql .= $args; + + // For some reason, the returns field cannot have quotes... + $sql .= ") RETURNS "; + if ($setof) $sql .= "SETOF "; + $sql .= "{$returns} AS "; + + if (is_array($definition)) { + $this->arrayClean($definition); + $sql .= "'" . $definition[0] . "'"; + if ($definition[1]) { + $sql .= ",'" . $definition[1] . "'"; + } + } else { + $this->clean($definition); + $sql .= "'" . $definition . "'"; + } + + $sql .= " LANGUAGE \"{$language}\""; + + // Add costs + if (!empty($cost)) + $sql .= " COST {$cost}"; + + if ($rows <> 0 ){ + $sql .= " ROWS {$rows}"; + } + + // Add flags + foreach ($flags as $v) { + // Skip default flags + if ($v == '') continue; + else $sql .= "\n{$v}"; + } + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + + /* set the comment */ + $status = $this->setComment('FUNCTION', "\"{$funcname}\"({$args})", null, $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + + return $this->endTransaction(); + } + + /** + * Drops a function. + * @param $function_oid The OID of the function to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropFunction($function_oid, $cascade) { + // Function comes in with $object as function OID + $fn = $this->getFunction($function_oid); + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($fn->fields['proname']); + + $sql = "DROP FUNCTION \"{$f_schema}\".\"{$fn->fields['proname']}\"({$fn->fields['proarguments']})"; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + // Type functions + + /** + * Returns all details for a particular type + * @param $typname The name of the view to retrieve + * @return Type info + */ + function getType($typname) { + $this->clean($typname); + + $sql = "SELECT typtype, typbyval, typname, typinput AS typin, typoutput AS typout, typlen, typalign + FROM pg_type WHERE typname='{$typname}'"; + + return $this->selectSet($sql); + } + + /** + * Returns a list of all types in the database + * @param $all If true, will find all available types, if false just those in search path + * @param $tabletypes If true, will include table types + * @param $domains If true, will include domains + * @return A recordet + */ + function getTypes($all = false, $tabletypes = false, $domains = false) { + if ($all) + $where = '1 = 1'; + else { + $c_schema = $this->_schema; + $this->clean($c_schema); + $where = "n.nspname = '{$c_schema}'"; + } + // Never show system table types + $where2 = "AND c.relnamespace NOT IN (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname LIKE 'pg@_%' ESCAPE '@')"; + + // Create type filter + $tqry = "'c'"; + if ($tabletypes) + $tqry .= ", 'r', 'v'"; + + // Create domain filter + if (!$domains) + $where .= " AND t.typtype != 'd'"; + + $sql = "SELECT + t.typname AS basename, + pg_catalog.format_type(t.oid, NULL) AS typname, + pu.usename AS typowner, + t.typtype, + pg_catalog.obj_description(t.oid, 'pg_type') AS typcomment + FROM (pg_catalog.pg_type t + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = t.typnamespace) + LEFT JOIN pg_catalog.pg_user pu ON t.typowner = pu.usesysid + WHERE (t.typrelid = 0 OR (SELECT c.relkind IN ({$tqry}) FROM pg_catalog.pg_class c WHERE c.oid = t.typrelid {$where2})) + AND t.typname !~ '^_' + AND {$where} + ORDER BY typname + "; + + return $this->selectSet($sql); + } + + /** + * Creates a new type + * @param ... + * @return 0 success + */ + function createType($typname, $typin, $typout, $typlen, $typdef, + $typelem, $typdelim, $typbyval, $typalign, $typstorage) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($typname); + $this->fieldClean($typin); + $this->fieldClean($typout); + + $sql = " + CREATE TYPE \"{$f_schema}\".\"{$typname}\" ( + INPUT = \"{$typin}\", + OUTPUT = \"{$typout}\", + INTERNALLENGTH = {$typlen}"; + if ($typdef != '') $sql .= ", DEFAULT = {$typdef}"; + if ($typelem != '') $sql .= ", ELEMENT = {$typelem}"; + if ($typdelim != '') $sql .= ", DELIMITER = {$typdelim}"; + if ($typbyval) $sql .= ", PASSEDBYVALUE, "; + if ($typalign != '') $sql .= ", ALIGNMENT = {$typalign}"; + if ($typstorage != '') $sql .= ", STORAGE = {$typstorage}"; + + $sql .= ")"; + + return $this->execute($sql); + } + + /** + * Drops a type. + * @param $typname The name of the type to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropType($typname, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($typname); + + $sql = "DROP TYPE \"{$f_schema}\".\"{$typname}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Creates a new enum type in the database + * @param $name The name of the type + * @param $values An array of values + * @param $typcomment Type comment + * @return 0 success + * @return -1 transaction error + * @return -2 no values supplied + */ + function createEnumType($name, $values, $typcomment) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + + if (empty($values)) return -2; + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $values = array_unique($values); + + $nbval = count($values); + + for ($i = 0; $i < $nbval; $i++) + $this->clean($values[$i]); + + $sql = "CREATE TYPE \"{$f_schema}\".\"{$name}\" AS ENUM ('"; + $sql.= implode("','", $values); + $sql .= "')"; + + $status = $this->execute($sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + + if ($typcomment != '') { + $status = $this->setComment('TYPE', $name, '', $typcomment, true); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + + } + + /** + * Get defined values for a given enum + * @return A recordset + */ + function getEnumValues($name) { + $this->clean($name); + + $sql = "SELECT enumlabel AS enumval + FROM pg_catalog.pg_type t JOIN pg_catalog.pg_enum e ON (t.oid=e.enumtypid) + WHERE t.typname = '{$name}' ORDER BY e.oid"; + return $this->selectSet($sql); + } + + /** + * Creates a new composite type in the database + * @param $name The name of the type + * @param $fields The number of fields + * @param $field An array of field names + * @param $type An array of field types + * @param $array An array of '' or '[]' for each type if it's an array or not + * @param $length An array of field lengths + * @param $colcomment An array of comments + * @param $typcomment Type comment + * @return 0 success + * @return -1 no fields supplied + */ + function createCompositeType($name, $fields, $field, $type, $array, $length, $colcomment, $typcomment) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + $found = false; + $first = true; + $comment_sql = ''; // Accumulate comments for the columns + $sql = "CREATE TYPE \"{$f_schema}\".\"{$name}\" AS ("; + for ($i = 0; $i < $fields; $i++) { + $this->fieldClean($field[$i]); + $this->clean($type[$i]); + $this->clean($length[$i]); + $this->clean($colcomment[$i]); + + // Skip blank columns - for user convenience + if ($field[$i] == '' || $type[$i] == '') continue; + // If not the first column, add a comma + if (!$first) $sql .= ", "; + else $first = false; + + switch ($type[$i]) { + // Have to account for weird placing of length for with/without + // time zone types + case 'timestamp with time zone': + case 'timestamp without time zone': + $qual = substr($type[$i], 9); + $sql .= "\"{$field[$i]}\" timestamp"; + if ($length[$i] != '') $sql .= "({$length[$i]})"; + $sql .= $qual; + break; + case 'time with time zone': + case 'time without time zone': + $qual = substr($type[$i], 4); + $sql .= "\"{$field[$i]}\" time"; + if ($length[$i] != '') $sql .= "({$length[$i]})"; + $sql .= $qual; + break; + default: + $sql .= "\"{$field[$i]}\" {$type[$i]}"; + if ($length[$i] != '') $sql .= "({$length[$i]})"; + } + // Add array qualifier if necessary + if ($array[$i] == '[]') $sql .= '[]'; + + if ($colcomment[$i] != '') $comment_sql .= "COMMENT ON COLUMN \"{$f_schema}\".\"{$name}\".\"{$field[$i]}\" IS '{$colcomment[$i]}';\n"; + + $found = true; + } + + if (!$found) return -1; + + $sql .= ")"; + + $status = $this->execute($sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + + if ($typcomment != '') { + $status = $this->setComment('TYPE', $name, '', $typcomment, true); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + + if ($comment_sql != '') { + $status = $this->execute($comment_sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + return $this->endTransaction(); + } + + /** + * Returns a list of all casts in the database + * @return All casts + */ + function getCasts() { + global $conf; + + if ($conf['show_system']) + $where = ''; + else + $where = ' + AND n1.nspname NOT LIKE $$pg\_%$$ + AND n2.nspname NOT LIKE $$pg\_%$$ + AND n3.nspname NOT LIKE $$pg\_%$$ + '; + + $sql = " + SELECT + c.castsource::pg_catalog.regtype AS castsource, + c.casttarget::pg_catalog.regtype AS casttarget, + CASE WHEN c.castfunc=0 THEN NULL + ELSE c.castfunc::pg_catalog.regprocedure END AS castfunc, + c.castcontext, + obj_description(c.oid, 'pg_cast') as castcomment + FROM + (pg_catalog.pg_cast c LEFT JOIN pg_catalog.pg_proc p ON c.castfunc=p.oid JOIN pg_catalog.pg_namespace n3 ON p.pronamespace=n3.oid), + pg_catalog.pg_type t1, + pg_catalog.pg_type t2, + pg_catalog.pg_namespace n1, + pg_catalog.pg_namespace n2 + WHERE + c.castsource=t1.oid + AND c.casttarget=t2.oid + AND t1.typnamespace=n1.oid + AND t2.typnamespace=n2.oid + {$where} + ORDER BY 1, 2 + "; + + return $this->selectSet($sql); + } + + /** + * Returns a list of all conversions in the database + * @return All conversions + */ + function getConversions() { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT + c.conname, + pg_catalog.pg_encoding_to_char(c.conforencoding) AS conforencoding, + pg_catalog.pg_encoding_to_char(c.contoencoding) AS contoencoding, + c.condefault, + pg_catalog.obj_description(c.oid, 'pg_conversion') AS concomment + FROM pg_catalog.pg_conversion c, pg_catalog.pg_namespace n + WHERE n.oid = c.connamespace + AND n.nspname='{$c_schema}' + ORDER BY 1; + "; + + return $this->selectSet($sql); + } + + // Rule functions + + /** + * Returns a list of all rules on a table OR view + * @param $table The table to find rules for + * @return A recordset + */ + function getRules($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = " + SELECT * + FROM pg_catalog.pg_rules + WHERE + schemaname='{$c_schema}' AND tablename='{$table}' + ORDER BY rulename + "; + + return $this->selectSet($sql); + } + + /** + * Edits a rule on a table OR view + * @param $name The name of the new rule + * @param $event SELECT, INSERT, UPDATE or DELETE + * @param $table Table on which to create the rule + * @param $where When to execute the rule, '' indicates always + * @param $instead True if an INSTEAD rule, false otherwise + * @param $type NOTHING for a do nothing rule, SOMETHING to use given action + * @param $action The action to take + * @return 0 success + * @return -1 invalid event + */ + function setRule($name, $event, $table, $where, $instead, $type, $action) { + return $this->createRule($name, $event, $table, $where, $instead, $type, $action, true); + } + + /** + * Creates a rule + * @param $name The name of the new rule + * @param $event SELECT, INSERT, UPDATE or DELETE + * @param $table Table on which to create the rule + * @param $where When to execute the rule, '' indicates always + * @param $instead True if an INSTEAD rule, false otherwise + * @param $type NOTHING for a do nothing rule, SOMETHING to use given action + * @param $action The action to take + * @param $replace (optional) True to replace existing rule, false otherwise + * @return 0 success + * @return -1 invalid event + */ + function createRule($name, $event, $table, $where, $instead, $type, $action, $replace = false) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + $this->fieldClean($table); + if (!in_array($event, $this->rule_events)) return -1; + + $sql = "CREATE"; + if ($replace) $sql .= " OR REPLACE"; + $sql .= " RULE \"{$name}\" AS ON {$event} TO \"{$f_schema}\".\"{$table}\""; + // Can't escape WHERE clause + if ($where != '') $sql .= " WHERE {$where}"; + $sql .= " DO"; + if ($instead) $sql .= " INSTEAD"; + if ($type == 'NOTHING') + $sql .= " NOTHING"; + else $sql .= " ({$action})"; + + return $this->execute($sql); + } + + /** + * Removes a rule from a table OR view + * @param $rule The rule to drop + * @param $relation The relation from which to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropRule($rule, $relation, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($rule); + $this->fieldClean($relation); + + $sql = "DROP RULE \"{$rule}\" ON \"{$f_schema}\".\"{$relation}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + // Trigger functions + + /** + * Grabs a single trigger + * @param $table The name of a table whose triggers to retrieve + * @param $trigger The name of the trigger to retrieve + * @return A recordset + */ + function getTrigger($table, $trigger) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + $this->clean($trigger); + + $sql = " + SELECT * FROM pg_catalog.pg_trigger t, pg_catalog.pg_class c + WHERE t.tgrelid=c.oid AND c.relname='{$table}' AND t.tgname='{$trigger}' + AND c.relnamespace=( + SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}')"; + + return $this->selectSet($sql); + } + + /** + * Grabs a list of triggers on a table + * @param $table The name of a table whose triggers to retrieve + * @return A recordset + */ + function getTriggers($table = '') { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT + t.tgname, pg_catalog.pg_get_triggerdef(t.oid) AS tgdef, + CASE WHEN t.tgenabled = 'D' THEN FALSE ELSE TRUE END AS tgenabled, p.oid AS prooid, + p.proname || ' (' || pg_catalog.oidvectortypes(p.proargtypes) || ')' AS proproto, + ns.nspname AS pronamespace + FROM pg_catalog.pg_trigger t, pg_catalog.pg_proc p, pg_catalog.pg_namespace ns + WHERE t.tgrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace=(SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}')) + AND ( tgconstraint = 0 OR NOT EXISTS + (SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = t.tableoid AND d.objid = t.oid AND d.deptype = 'i' AND c.contype = 'f')) + AND p.oid=t.tgfoid + AND p.pronamespace = ns.oid"; + + return $this->selectSet($sql); + } + + /** + * A helper function for getTriggers that translates + * an array of attribute numbers to an array of field names. + * Note: Only needed for pre-7.4 servers, this function is deprecated + * @param $trigger An array containing fields from the trigger table + * @return The trigger definition string + */ + function getTriggerDef($trigger) { + + $this->fieldArrayClean($trigger); + // Constants to figure out tgtype + if (!defined('TRIGGER_TYPE_ROW')) define ('TRIGGER_TYPE_ROW', (1 << 0)); + if (!defined('TRIGGER_TYPE_BEFORE')) define ('TRIGGER_TYPE_BEFORE', (1 << 1)); + if (!defined('TRIGGER_TYPE_INSERT')) define ('TRIGGER_TYPE_INSERT', (1 << 2)); + if (!defined('TRIGGER_TYPE_DELETE')) define ('TRIGGER_TYPE_DELETE', (1 << 3)); + if (!defined('TRIGGER_TYPE_UPDATE')) define ('TRIGGER_TYPE_UPDATE', (1 << 4)); + + $trigger['tgisconstraint'] = $this->phpBool($trigger['tgisconstraint']); + $trigger['tgdeferrable'] = $this->phpBool($trigger['tgdeferrable']); + $trigger['tginitdeferred'] = $this->phpBool($trigger['tginitdeferred']); + + // Constraint trigger or normal trigger + if ($trigger['tgisconstraint']) + $tgdef = 'CREATE CONSTRAINT TRIGGER '; + else + $tgdef = 'CREATE TRIGGER '; + + $tgdef .= "\"{$trigger['tgname']}\" "; + + // Trigger type + $findx = 0; + if (($trigger['tgtype'] & TRIGGER_TYPE_BEFORE) == TRIGGER_TYPE_BEFORE) + $tgdef .= 'BEFORE'; + else + $tgdef .= 'AFTER'; + + if (($trigger['tgtype'] & TRIGGER_TYPE_INSERT) == TRIGGER_TYPE_INSERT) { + $tgdef .= ' INSERT'; + $findx++; + } + if (($trigger['tgtype'] & TRIGGER_TYPE_DELETE) == TRIGGER_TYPE_DELETE) { + if ($findx > 0) + $tgdef .= ' OR DELETE'; + else { + $tgdef .= ' DELETE'; + $findx++; + } + } + if (($trigger['tgtype'] & TRIGGER_TYPE_UPDATE) == TRIGGER_TYPE_UPDATE) { + if ($findx > 0) + $tgdef .= ' OR UPDATE'; + else + $tgdef .= ' UPDATE'; + } + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + // Table name + $tgdef .= " ON \"{$f_schema}\".\"{$trigger['relname']}\" "; + + // Deferrability + if ($trigger['tgisconstraint']) { + if ($trigger['tgconstrrelid'] != 0) { + // Assume constrelname is not null + $tgdef .= " FROM \"{$trigger['tgconstrrelname']}\" "; + } + if (!$trigger['tgdeferrable']) + $tgdef .= 'NOT '; + $tgdef .= 'DEFERRABLE INITIALLY '; + if ($trigger['tginitdeferred']) + $tgdef .= 'DEFERRED '; + else + $tgdef .= 'IMMEDIATE '; + } + + // Row or statement + if ($trigger['tgtype'] & TRIGGER_TYPE_ROW == TRIGGER_TYPE_ROW) + $tgdef .= 'FOR EACH ROW '; + else + $tgdef .= 'FOR EACH STATEMENT '; + + // Execute procedure + $tgdef .= "EXECUTE PROCEDURE \"{$trigger['tgfname']}\"("; + + // Parameters + // Escape null characters + $v = addCSlashes($trigger['tgargs'], "\0"); + // Split on escaped null characters + $params = explode('\\000', $v); + for ($findx = 0; $findx < $trigger['tgnargs']; $findx++) { + $param = "'" . str_replace('\'', '\\\'', $params[$findx]) . "'"; + $tgdef .= $param; + if ($findx < ($trigger['tgnargs'] - 1)) + $tgdef .= ', '; + } + + // Finish it off + $tgdef .= ')'; + + return $tgdef; + } + + /** + * Returns a list of all functions that can be used in triggers + */ + function getTriggerFunctions() { + return $this->getFunctions(true, 'trigger'); + } + + /** + * Creates a trigger + * @param $tgname The name of the trigger to create + * @param $table The name of the table + * @param $tgproc The function to execute + * @param $tgtime BEFORE or AFTER + * @param $tgevent Event + * @param $tgargs The function arguments + * @return 0 success + */ + function createTrigger($tgname, $table, $tgproc, $tgtime, $tgevent, $tgfrequency, $tgargs) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($tgname); + $this->fieldClean($table); + $this->fieldClean($tgproc); + + /* No Statement Level Triggers in PostgreSQL (by now) */ + $sql = "CREATE TRIGGER \"{$tgname}\" {$tgtime} + {$tgevent} ON \"{$f_schema}\".\"{$table}\" + FOR EACH {$tgfrequency} EXECUTE PROCEDURE \"{$tgproc}\"({$tgargs})"; + + return $this->execute($sql); + } + + /** + * Alters a trigger + * @param $table The name of the table containing the trigger + * @param $trigger The name of the trigger to alter + * @param $name The new name for the trigger + * @return 0 success + */ + function alterTrigger($table, $trigger, $name) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $this->fieldClean($trigger); + $this->fieldClean($name); + + $sql = "ALTER TRIGGER \"{$trigger}\" ON \"{$f_schema}\".\"{$table}\" RENAME TO \"{$name}\""; + + return $this->execute($sql); + } + + /** + * Drops a trigger + * @param $tgname The name of the trigger to drop + * @param $table The table from which to drop the trigger + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropTrigger($tgname, $table, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($tgname); + $this->fieldClean($table); + + $sql = "DROP TRIGGER \"{$tgname}\" ON \"{$f_schema}\".\"{$table}\""; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Enables a trigger + * @param $tgname The name of the trigger to enable + * @param $table The table in which to enable the trigger + * @return 0 success + */ + function enableTrigger($tgname, $table) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($tgname); + $this->fieldClean($table); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" ENABLE TRIGGER \"{$tgname}\""; + + return $this->execute($sql); + } + + /** + * Disables a trigger + * @param $tgname The name of the trigger to disable + * @param $table The table in which to disable the trigger + * @return 0 success + */ + function disableTrigger($tgname, $table) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($tgname); + $this->fieldClean($table); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" DISABLE TRIGGER \"{$tgname}\""; + + return $this->execute($sql); + } + + // Operator functions + + /** + * Returns a list of all operators in the database + * @return All operators + */ + function getOperators() { + $c_schema = $this->_schema; + $this->clean($c_schema); + // We stick with the subselects here, as you cannot ORDER BY a regtype + $sql = " + SELECT + po.oid, po.oprname, + (SELECT pg_catalog.format_type(oid, NULL) FROM pg_catalog.pg_type pt WHERE pt.oid=po.oprleft) AS oprleftname, + (SELECT pg_catalog.format_type(oid, NULL) FROM pg_catalog.pg_type pt WHERE pt.oid=po.oprright) AS oprrightname, + po.oprresult::pg_catalog.regtype AS resultname, + pg_catalog.obj_description(po.oid, 'pg_operator') AS oprcomment + FROM + pg_catalog.pg_operator po + WHERE + po.oprnamespace = (SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}') + ORDER BY + po.oprname, oprleftname, oprrightname + "; + + return $this->selectSet($sql); + } + + /** + * Returns all details for a particular operator + * @param $operator_oid The oid of the operator + * @return Function info + */ + function getOperator($operator_oid) { + $this->clean($operator_oid); + + $sql = " + SELECT + po.oid, po.oprname, + oprleft::pg_catalog.regtype AS oprleftname, + oprright::pg_catalog.regtype AS oprrightname, + oprresult::pg_catalog.regtype AS resultname, + po.oprcanhash, + oprcanmerge, + oprcom::pg_catalog.regoperator AS oprcom, + oprnegate::pg_catalog.regoperator AS oprnegate, + po.oprcode::pg_catalog.regproc AS oprcode, + po.oprrest::pg_catalog.regproc AS oprrest, + po.oprjoin::pg_catalog.regproc AS oprjoin + FROM + pg_catalog.pg_operator po + WHERE + po.oid='{$operator_oid}' + "; + + return $this->selectSet($sql); + } + + /** + * Drops an operator + * @param $operator_oid The OID of the operator to drop + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropOperator($operator_oid, $cascade) { + // Function comes in with $object as operator OID + $opr = $this->getOperator($operator_oid); + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($opr->fields['oprname']); + + $sql = "DROP OPERATOR \"{$f_schema}\".{$opr->fields['oprname']} ("; + // Quoting or formatting here??? + if ($opr->fields['oprleftname'] !== null) $sql .= $opr->fields['oprleftname'] . ', '; + else $sql .= "NONE, "; + if ($opr->fields['oprrightname'] !== null) $sql .= $opr->fields['oprrightname'] . ')'; + else $sql .= "NONE)"; + + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + // Operator Class functions + + /** + * Gets all opclasses + * + * @return A recordset + */ + + function getOpClasses() { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT + pa.amname, po.opcname, + po.opcintype::pg_catalog.regtype AS opcintype, + po.opcdefault, + pg_catalog.obj_description(po.oid, 'pg_opclass') AS opccomment + FROM + pg_catalog.pg_opclass po, pg_catalog.pg_am pa, pg_catalog.pg_namespace pn + WHERE + po.opcmethod=pa.oid + AND po.opcnamespace=pn.oid + AND pn.nspname='{$c_schema}' + ORDER BY 1,2 + "; + + return $this->selectSet($sql); + } + + // FTS functions + + /** + * Creates a new FTS configuration. + * @param string $cfgname The name of the FTS configuration to create + * @param string $parser The parser to be used in new FTS configuration + * @param string $locale Locale of the FTS configuration + * @param string $template The existing FTS configuration to be used as template for the new one + * @param string $withmap Should we copy whole map of existing FTS configuration to the new one + * @param string $makeDefault Should this configuration be the default for locale given + * @param string $comment If omitted, defaults to nothing + * + * @return 0 success + */ + function createFtsConfiguration($cfgname, $parser = '', $template = '', $comment = '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($cfgname); + + $sql = "CREATE TEXT SEARCH CONFIGURATION \"{$f_schema}\".\"{$cfgname}\" ("; + if ($parser != '') { + $this->fieldClean($parser['schema']); + $this->fieldClean($parser['parser']); + $parser = "\"{$parser['schema']}\".\"{$parser['parser']}\""; + $sql .= " PARSER = {$parser}"; + } + if ($template != '') { + $this->fieldClean($template['schema']); + $this->fieldClean($template['name']); + $sql .= " COPY = \"{$template['schema']}\".\"{$template['name']}\""; + } + $sql .= ")"; + + if ($comment != '') { + $status = $this->beginTransaction(); + if ($status != 0) return -1; + } + + // Create the FTS configuration + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Set the comment + if ($comment != '') { + $status = $this->setComment('TEXT SEARCH CONFIGURATION', $cfgname, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + return $this->endTransaction(); + } + + return 0; + } + + /** + * Returns available FTS configurations + * @param $all if false, returns schema qualified FTS confs + * + * @return A recordset + */ + function getFtsConfigurations($all = true) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT + n.nspname as schema, + c.cfgname as name, + pg_catalog.obj_description(c.oid, 'pg_ts_config') as comment + FROM + pg_catalog.pg_ts_config c + JOIN pg_catalog.pg_namespace n ON n.oid = c.cfgnamespace + WHERE + pg_catalog.pg_ts_config_is_visible(c.oid)"; + + if (!$all) + $sql.= " AND n.nspname='{$c_schema}'\n"; + + $sql.= "ORDER BY name"; + + return $this->selectSet($sql); + } + + /** + * Return all information related to a FTS configuration + * @param $ftscfg The name of the FTS configuration + * + * @return FTS configuration information + */ + function getFtsConfigurationByName($ftscfg) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($ftscfg); + $sql = " + SELECT + n.nspname as schema, + c.cfgname as name, + p.prsname as parser, + c.cfgparser as parser_id, + pg_catalog.obj_description(c.oid, 'pg_ts_config') as comment + FROM pg_catalog.pg_ts_config c + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.cfgnamespace + LEFT JOIN pg_catalog.pg_ts_parser p ON p.oid = c.cfgparser + WHERE pg_catalog.pg_ts_config_is_visible(c.oid) + AND c.cfgname = '{$ftscfg}' + AND n.nspname='{$c_schema}'"; + + return $this->selectSet($sql); + } + + /** + * Returns the map of FTS configuration given + * (list of mappings (tokens) and their processing dictionaries) + * @param string $ftscfg Name of the FTS configuration + * + * @return RecordSet + */ + function getFtsConfigurationMap($ftscfg) { + + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->fieldClean($ftscfg); + + $oidSet = $this->selectSet("SELECT c.oid + FROM pg_catalog.pg_ts_config AS c + LEFT JOIN pg_catalog.pg_namespace n ON (n.oid = c.cfgnamespace) + WHERE c.cfgname = '{$ftscfg}' + AND n.nspname='{$c_schema}'"); + + $oid = $oidSet->fields['oid']; + + $sql = " + SELECT + (SELECT t.alias FROM pg_catalog.ts_token_type(c.cfgparser) AS t WHERE t.tokid = m.maptokentype) AS name, + (SELECT t.description FROM pg_catalog.ts_token_type(c.cfgparser) AS t WHERE t.tokid = m.maptokentype) AS description, + c.cfgname AS cfgname, n.nspname ||'.'|| d.dictname as dictionaries + FROM + pg_catalog.pg_ts_config AS c, pg_catalog.pg_ts_config_map AS m, pg_catalog.pg_ts_dict d, + pg_catalog.pg_namespace n + WHERE + c.oid = {$oid} + AND m.mapcfg = c.oid + AND m.mapdict = d.oid + AND d.dictnamespace = n.oid + ORDER BY name + "; + return $this->selectSet($sql); + } + + /** + * Returns FTS parsers available + * @param $all if false, return only Parsers from the current schema + * + * @return RecordSet + */ + function getFtsParsers($all = true) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT + n.nspname as schema, + p.prsname as name, + pg_catalog.obj_description(p.oid, 'pg_ts_parser') as comment + FROM pg_catalog.pg_ts_parser p + LEFT JOIN pg_catalog.pg_namespace n ON (n.oid = p.prsnamespace) + WHERE pg_catalog.pg_ts_parser_is_visible(p.oid)"; + + if (!$all) + $sql.= " AND n.nspname='{$c_schema}'\n"; + + $sql.= "ORDER BY name"; + + return $this->selectSet($sql); + } + + /** + * Returns FTS dictionaries available + * @param $all if false, return only Dics from the current schema + * + * @returns RecordSet + */ + function getFtsDictionaries($all = true) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT + n.nspname as schema, d.dictname as name, + pg_catalog.obj_description(d.oid, 'pg_ts_dict') as comment + FROM pg_catalog.pg_ts_dict d + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = d.dictnamespace + WHERE pg_catalog.pg_ts_dict_is_visible(d.oid)"; + + if (!$all) + $sql.= " AND n.nspname='{$c_schema}'\n"; + + $sql.= "ORDER BY name;"; + + return $this->selectSet($sql); + } + + /** + * Returns all FTS dictionary templates available + */ + function getFtsDictionaryTemplates() { + + $sql = " + SELECT + n.nspname as schema, + t.tmplname as name, + ( SELECT COALESCE(np.nspname, '(null)')::pg_catalog.text || '.' || p.proname + FROM pg_catalog.pg_proc p + LEFT JOIN pg_catalog.pg_namespace np ON np.oid = p.pronamespace + WHERE t.tmplinit = p.oid ) AS init, + ( SELECT COALESCE(np.nspname, '(null)')::pg_catalog.text || '.' || p.proname + FROM pg_catalog.pg_proc p + LEFT JOIN pg_catalog.pg_namespace np ON np.oid = p.pronamespace + WHERE t.tmpllexize = p.oid ) AS lexize, + pg_catalog.obj_description(t.oid, 'pg_ts_template') as comment + FROM pg_catalog.pg_ts_template t + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = t.tmplnamespace + WHERE pg_catalog.pg_ts_template_is_visible(t.oid) + ORDER BY name;"; + + return $this->selectSet($sql); + } + + /** + * Drops FTS coniguration + * @param $ftscfg The configuration's name + * @param $cascade Cascade to dependenced objects + * + * @return 0 on success + */ + function dropFtsConfiguration($ftscfg, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($ftscfg); + + $sql = "DROP TEXT SEARCH CONFIGURATION \"{$f_schema}\".\"{$ftscfg}\""; + if ($cascade) $sql .= ' CASCADE'; + + return $this->execute($sql); + } + + /** + * Drops FTS dictionary + * @param $ftsdict The dico's name + * @param $cascade Cascade to dependenced objects + * + * @todo Support of dictionary templates dropping + * @return 0 on success + */ + function dropFtsDictionary($ftsdict, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($ftsdict); + + $sql = "DROP TEXT SEARCH DICTIONARY"; + $sql .= " \"{$f_schema}\".\"{$ftsdict}\""; + if ($cascade) $sql .= ' CASCADE'; + + return $this->execute($sql); + } + + /** + * Alters FTS configuration + * @param $cfgname The conf's name + * @param $comment A comment on for the conf + * @param $name The new conf name + * + * @return 0 on success + */ + function updateFtsConfiguration($cfgname, $comment, $name) { + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $this->fieldClean($cfgname); + + $status = $this->setComment('TEXT SEARCH CONFIGURATION', $cfgname, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Only if the name has changed + if ($name != $cfgname) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + + $sql = "ALTER TEXT SEARCH CONFIGURATION \"{$f_schema}\".\"{$cfgname}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + } + + /** + * Creates a new FTS dictionary or FTS dictionary template. + * @param string $dictname The name of the FTS dictionary to create + * @param boolean $isTemplate Flag whether we create usual dictionary or dictionary template + * @param string $template The existing FTS dictionary to be used as template for the new one + * @param string $lexize The name of the function, which does transformation of input word + * @param string $init The name of the function, which initializes dictionary + * @param string $option Usually, it stores various options required for the dictionary + * @param string $comment If omitted, defaults to nothing + * + * @return 0 success + */ + function createFtsDictionary($dictname, $isTemplate = false, $template = '', $lexize = '', + $init = '', $option = '', $comment = '') { + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($dictname); + $this->fieldClean($template); + $this->fieldClean($lexize); + $this->fieldClean($init); + $this->fieldClean($option); + + $sql = "CREATE TEXT SEARCH"; + if ($isTemplate) { + $sql .= " TEMPLATE \"{$f_schema}\".\"{$dictname}\" ("; + if ($lexize != '') $sql .= " LEXIZE = {$lexize}"; + if ($init != '') $sql .= ", INIT = {$init}"; + $sql .= ")"; + $whatToComment = 'TEXT SEARCH TEMPLATE'; + } else { + $sql .= " DICTIONARY \"{$f_schema}\".\"{$dictname}\" ("; + if ($template != '') { + $this->fieldClean($template['schema']); + $this->fieldClean($template['name']); + $template = "\"{$template['schema']}\".\"{$template['name']}\""; + + $sql .= " TEMPLATE = {$template}"; + } + if ($option != '') $sql .= ", {$option}"; + $sql .= ")"; + $whatToComment = 'TEXT SEARCH DICTIONARY'; + } + + /* if comment, begin a transaction to + * run both commands */ + if ($comment != '') { + $status = $this->beginTransaction(); + if ($status != 0) return -1; + } + + // Create the FTS dictionary + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Set the comment + if ($comment != '') { + $status = $this->setComment($whatToComment, $dictname, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + } + + /** + * Alters FTS dictionary or dictionary template + * @param $dictname The dico's name + * @param $comment The comment + * @param $name The new dico's name + * + * @return 0 on success + */ + function updateFtsDictionary($dictname, $comment, $name) { + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $this->fieldClean($dictname); + $status = $this->setComment('TEXT SEARCH DICTIONARY', $dictname, '', $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + // Only if the name has changed + if ($name != $dictname) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + + $sql = "ALTER TEXT SEARCH DICTIONARY \"{$f_schema}\".\"{$dictname}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + } + + /** + * Return all information relating to a FTS dictionary + * @param $ftsdict The name of the FTS dictionary + * + * @return RecordSet of FTS dictionary information + */ + function getFtsDictionaryByName($ftsdict) { + + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($ftsdict); + + $sql = "SELECT + n.nspname as schema, + d.dictname as name, + ( SELECT COALESCE(nt.nspname, '(null)')::pg_catalog.text || '.' || t.tmplname FROM + pg_catalog.pg_ts_template t + LEFT JOIN pg_catalog.pg_namespace nt ON nt.oid = t.tmplnamespace + WHERE d.dicttemplate = t.oid ) AS template, + d.dictinitoption as init, + pg_catalog.obj_description(d.oid, 'pg_ts_dict') as comment + FROM pg_catalog.pg_ts_dict d + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = d.dictnamespace + WHERE d.dictname = '{$ftsdict}' + AND pg_catalog.pg_ts_dict_is_visible(d.oid) + AND n.nspname='{$c_schema}' + ORDER BY name"; + + return $this->selectSet($sql); + } + + /** + * Creates/updates/deletes FTS mapping. + * @param string $cfgname The name of the FTS configuration to alter + * @param array $mapping Array of tokens' names + * @param string $action What to do with the mapping: add, alter or drop + * @param string $dictname Dictionary that will process tokens given or null in case of drop action + * + * @return 0 success + */ + function changeFtsMapping($ftscfg, $mapping, $action, $dictname = null) { + + if (count($mapping) > 0) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($ftscfg); + $this->fieldClean($dictname); + $this->arrayClean($mapping); + + switch ($action) { + case 'alter': + $whatToDo = "ALTER"; + break; + case 'drop': + $whatToDo = "DROP"; + break; + default: + $whatToDo = "ADD"; + break; + } + + $sql = "ALTER TEXT SEARCH CONFIGURATION \"{$f_schema}\".\"{$ftscfg}\" {$whatToDo} MAPPING FOR "; + $sql .= implode(",", $mapping); + if ($action != 'drop' && !empty($dictname)) { + $sql .= " WITH {$dictname}"; + } + + return $this->execute($sql); + } + else { + return -1; + } + } + + /** + * Return all information related to a given FTS configuration's mapping + * @param $ftscfg The name of the FTS configuration + * @param $mapping The name of the mapping + * + * @return FTS configuration information + */ + function getFtsMappingByName($ftscfg, $mapping) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($ftscfg); + $this->clean($mapping); + + $oidSet = $this->selectSet("SELECT c.oid, cfgparser + FROM pg_catalog.pg_ts_config AS c + LEFT JOIN pg_catalog.pg_namespace AS n ON n.oid = c.cfgnamespace + WHERE c.cfgname = '{$ftscfg}' + AND n.nspname='{$c_schema}'"); + + $oid = $oidSet->fields['oid']; + $cfgparser = $oidSet->fields['cfgparser']; + + $tokenIdSet = $this->selectSet("SELECT tokid + FROM pg_catalog.ts_token_type({$cfgparser}) + WHERE alias = '{$mapping}'"); + + $tokid = $tokenIdSet->fields['tokid']; + + $sql = "SELECT + (SELECT t.alias FROM pg_catalog.ts_token_type(c.cfgparser) AS t WHERE t.tokid = m.maptokentype) AS name, + d.dictname as dictionaries + FROM pg_catalog.pg_ts_config AS c, pg_catalog.pg_ts_config_map AS m, pg_catalog.pg_ts_dict d + WHERE c.oid = {$oid} AND m.mapcfg = c.oid AND m.maptokentype = {$tokid} AND m.mapdict = d.oid + LIMIT 1;"; + + return $this->selectSet($sql); + } + + /** + * Return list of FTS mappings possible for given parser + * (specified by given configuration since configuration can only have 1 parser) + * @param $ftscfg The config's name that use the parser + * + * @return 0 on success + */ + function getFtsMappings($ftscfg) { + + $cfg = $this->getFtsConfigurationByName($ftscfg); + + $sql = "SELECT alias AS name, description + FROM pg_catalog.ts_token_type({$cfg->fields['parser_id']}) + ORDER BY name"; + + return $this->selectSet($sql); + } + + // Language functions + + /** + * Gets all languages + * @param $all True to get all languages, regardless of show_system + * @return A recordset + */ + function getLanguages($all = false) { + global $conf; + + if ($conf['show_system'] || $all) + $where = ''; + else + $where = 'WHERE lanispl'; + + $sql = " + SELECT + lanname, lanpltrusted, + lanplcallfoid::pg_catalog.regproc AS lanplcallf + FROM + pg_catalog.pg_language + {$where} + ORDER BY lanname + "; + + return $this->selectSet($sql); + } + + // Aggregate functions + + /** + * Creates a new aggregate in the database + * @param $name The name of the aggregate + * @param $basetype The input data type of the aggregate + * @param $sfunc The name of the state transition function for the aggregate + * @param $stype The data type for the aggregate's state value + * @param $ffunc The name of the final function for the aggregate + * @param $initcond The initial setting for the state value + * @param $sortop The sort operator for the aggregate + * @param $comment Aggregate comment + * @return 0 success + * @return -1 error + */ + function createAggregate($name, $basetype, $sfunc, $stype, $ffunc, $initcond, $sortop, $comment) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($name); + $this->fieldClean($basetype); + $this->fieldClean($sfunc); + $this->fieldClean($stype); + $this->fieldClean($ffunc); + $this->fieldClean($initcond); + $this->fieldClean($sortop); + + $this->beginTransaction(); + + $sql = "CREATE AGGREGATE \"{$f_schema}\".\"{$name}\" (BASETYPE = \"{$basetype}\", SFUNC = \"{$sfunc}\", STYPE = \"{$stype}\""; + if(trim($ffunc) != '') $sql .= ", FINALFUNC = \"{$ffunc}\""; + if(trim($initcond) != '') $sql .= ", INITCOND = \"{$initcond}\""; + if(trim($sortop) != '') $sql .= ", SORTOP = \"{$sortop}\""; + $sql .= ")"; + + $status = $this->execute($sql); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + + if (trim($comment) != '') { + $status = $this->setComment('AGGREGATE', $name, '', $comment, $basetype); + if ($status) { + $this->rollbackTransaction(); + return -1; + } + } + + return $this->endTransaction(); + } + + /** + * Renames an aggregate function + * @param $aggrname The actual name of the aggregate + * @param $aggrtype The actual input data type of the aggregate + * @param $newaggrname The new name of the aggregate + * @return 0 success + */ + function renameAggregate($aggrschema, $aggrname, $aggrtype, $newaggrname) { + /* this function is called from alterAggregate where params are cleaned */ + $sql = "ALTER AGGREGATE \"{$aggrschema}\"" . '.' . "\"{$aggrname}\" (\"{$aggrtype}\") RENAME TO \"{$newaggrname}\""; + return $this->execute($sql); + } + + /** + * Removes an aggregate function from the database + * @param $aggrname The name of the aggregate + * @param $aggrtype The input data type of the aggregate + * @param $cascade True to cascade drop, false to restrict + * @return 0 success + */ + function dropAggregate($aggrname, $aggrtype, $cascade) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($aggrname); + $this->fieldClean($aggrtype); + + $sql = "DROP AGGREGATE \"{$f_schema}\".\"{$aggrname}\" (\"{$aggrtype}\")"; + if ($cascade) $sql .= " CASCADE"; + + return $this->execute($sql); + } + + /** + * Gets all information for an aggregate + * @param $name The name of the aggregate + * @param $basetype The input data type of the aggregate + * @return A recordset + */ + function getAggregate($name, $basetype) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->fieldclean($name); + $this->fieldclean($basetype); + + $sql = " + SELECT p.proname, CASE p.proargtypes[0] + WHEN 'pg_catalog.\"any\"'::pg_catalog.regtype THEN NULL + ELSE pg_catalog.format_type(p.proargtypes[0], NULL) END AS proargtypes, + a.aggtransfn, format_type(a.aggtranstype, NULL) AS aggstype, a.aggfinalfn, + a.agginitval, a.aggsortop, u.usename, pg_catalog.obj_description(p.oid, 'pg_proc') AS aggrcomment + FROM pg_catalog.pg_proc p, pg_catalog.pg_namespace n, pg_catalog.pg_user u, pg_catalog.pg_aggregate a + WHERE n.oid = p.pronamespace AND p.proowner=u.usesysid AND p.oid=a.aggfnoid + AND p.proisagg AND n.nspname='{$c_schema}' + AND p.proname='" . $name . "' + AND CASE p.proargtypes[0] + WHEN 'pg_catalog.\"any\"'::pg_catalog.regtype THEN '' + ELSE pg_catalog.format_type(p.proargtypes[0], NULL) + END ='" . $basetype . "'"; + + return $this->selectSet($sql); + } + + /** + * Gets all aggregates + * @return A recordset + */ + function getAggregates() { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = "SELECT p.proname, CASE p.proargtypes[0] WHEN 'pg_catalog.\"any\"'::pg_catalog.regtype THEN NULL ELSE + pg_catalog.format_type(p.proargtypes[0], NULL) END AS proargtypes, a.aggtransfn, u.usename, + pg_catalog.obj_description(p.oid, 'pg_proc') AS aggrcomment + FROM pg_catalog.pg_proc p, pg_catalog.pg_namespace n, pg_catalog.pg_user u, pg_catalog.pg_aggregate a + WHERE n.oid = p.pronamespace AND p.proowner=u.usesysid AND p.oid=a.aggfnoid + AND p.proisagg AND n.nspname='{$c_schema}' ORDER BY 1, 2"; + + return $this->selectSet($sql); + } + + /** + * Changes the owner of an aggregate function + * @param $aggrname The name of the aggregate + * @param $aggrtype The input data type of the aggregate + * @param $newaggrowner The new owner of the aggregate + * @return 0 success + */ + function changeAggregateOwner($aggrname, $aggrtype, $newaggrowner) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($aggrname); + $this->fieldClean($newaggrowner); + $sql = "ALTER AGGREGATE \"{$f_schema}\".\"{$aggrname}\" (\"{$aggrtype}\") OWNER TO \"{$newaggrowner}\""; + return $this->execute($sql); + } + + /** + * Changes the schema of an aggregate function + * @param $aggrname The name of the aggregate + * @param $aggrtype The input data type of the aggregate + * @param $newaggrschema The new schema for the aggregate + * @return 0 success + */ + function changeAggregateSchema($aggrname, $aggrtype, $newaggrschema) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($aggrname); + $this->fieldClean($newaggrschema); + $sql = "ALTER AGGREGATE \"{$f_schema}\".\"{$aggrname}\" (\"{$aggrtype}\") SET SCHEMA \"{$newaggrschema}\""; + return $this->execute($sql); + } + + /** + * Alters an aggregate + * @param $aggrname The actual name of the aggregate + * @param $aggrtype The actual input data type of the aggregate + * @param $aggrowner The actual owner of the aggregate + * @param $aggrschema The actual schema the aggregate belongs to + * @param $aggrcomment The actual comment for the aggregate + * @param $newaggrname The new name of the aggregate + * @param $newaggrowner The new owner of the aggregate + * @param $newaggrschema The new schema where the aggregate will belong to + * @param $newaggrcomment The new comment for the aggregate + * @return 0 success + * @return -1 change owner error + * @return -2 change comment error + * @return -3 change schema error + * @return -4 change name error + */ + function alterAggregate($aggrname, $aggrtype, $aggrowner, $aggrschema, $aggrcomment, $newaggrname, $newaggrowner, $newaggrschema, $newaggrcomment) { + // Clean fields + $this->fieldClean($aggrname); + $this->fieldClean($aggrtype); + $this->fieldClean($aggrowner); + $this->fieldClean($aggrschema); + $this->fieldClean($newaggrname); + $this->fieldClean($newaggrowner); + $this->fieldClean($newaggrschema); + + $this->beginTransaction(); + + // Change the owner, if it has changed + if($aggrowner != $newaggrowner) { + $status = $this->changeAggregateOwner($aggrname, $aggrtype, $newaggrowner); + if($status != 0) { + $this->rollbackTransaction(); + return -1; + } + } + + // Set the comment, if it has changed + if($aggrcomment != $newaggrcomment) { + $status = $this->setComment('AGGREGATE', $aggrname, '', $newaggrcomment, $aggrtype); + if ($status) { + $this->rollbackTransaction(); + return -2; + } + } + + // Change the schema, if it has changed + if($aggrschema != $newaggrschema) { + $status = $this->changeAggregateSchema($aggrname, $aggrtype, $newaggrschema); + if($status != 0) { + $this->rollbackTransaction(); + return -3; + } + } + + // Rename the aggregate, if it has changed + if($aggrname != $newaggrname) { + $status = $this->renameAggregate($newaggrschema, $aggrname, $aggrtype, $newaggrname); + if($status != 0) { + $this->rollbackTransaction(); + return -4; + } + } + + return $this->endTransaction(); + } + + // Role, User/Group functions + + /** + * Returns all roles in the database cluster + * @param $rolename (optional) The role name to exclude from the select + * @return All roles + */ + function getRoles($rolename = '') { + $sql = ' + SELECT rolname, rolsuper, rolcreatedb, rolcreaterole, rolinherit, + rolcanlogin, rolconnlimit, rolvaliduntil, rolconfig + FROM pg_catalog.pg_roles'; + if($rolename) $sql .= " WHERE rolname!='{$rolename}'"; + $sql .= ' ORDER BY rolname'; + + return $this->selectSet($sql); + } + + /** + * Returns information about a single role + * @param $rolename The name of the role to retrieve + * @return The role's data + */ + function getRole($rolename) { + $this->clean($rolename); + + $sql = " + SELECT rolname, rolsuper, rolcreatedb, rolcreaterole, rolinherit, + rolcanlogin, rolconnlimit, rolvaliduntil, rolconfig + FROM pg_catalog.pg_roles WHERE rolname='{$rolename}'"; + + return $this->selectSet($sql); + } + + /** + * Grants membership in a role + * @param $role The name of the target role + * @param $rolename The name of the role that will belong to the target role + * @param $admin (optional) Flag to grant the admin option + * @return 0 success + */ + function grantRole($role, $rolename, $admin=0) { + $this->fieldClean($role); + $this->fieldClean($rolename); + + $sql = "GRANT \"{$role}\" TO \"{$rolename}\""; + if($admin == 1) $sql .= ' WITH ADMIN OPTION'; + + return $this->execute($sql); + } + + /** + * Revokes membership in a role + * @param $role The name of the target role + * @param $rolename The name of the role that will not belong to the target role + * @param $admin (optional) Flag to revoke only the admin option + * @param $type (optional) Type of revoke: RESTRICT | CASCADE + * @return 0 success + */ + function revokeRole($role, $rolename, $admin = 0, $type = 'RESTRICT') { + $this->fieldClean($role); + $this->fieldClean($rolename); + + $sql = "REVOKE "; + if($admin == 1) $sql .= 'ADMIN OPTION FOR '; + $sql .= "\"{$role}\" FROM \"{$rolename}\" {$type}"; + + return $this->execute($sql); + } + + /** + * Returns all users in the database cluster + * @return All users + */ + function getUsers() { + $sql = "SELECT usename, usesuper, usecreatedb, valuntil AS useexpires, useconfig + FROM pg_user + ORDER BY usename"; + + return $this->selectSet($sql); + } + + /** + * Returns information about a single user + * @param $username The username of the user to retrieve + * @return The user's data + */ + function getUser($username) { + $this->clean($username); + + $sql = "SELECT usename, usesuper, usecreatedb, valuntil AS useexpires, useconfig + FROM pg_user + WHERE usename='{$username}'"; + + return $this->selectSet($sql); + } + + /** + * Creates a new role + * @param $rolename The name of the role to create + * @param $password A password for the role + * @param $superuser Boolean whether or not the role is a superuser + * @param $createdb Boolean whether or not the role can create databases + * @param $createrole Boolean whether or not the role can create other roles + * @param $inherits Boolean whether or not the role inherits the privileges from parent roles + * @param $login Boolean whether or not the role will be allowed to login + * @param $connlimit Number of concurrent connections the role can make + * @param $expiry String Format 'YYYY-MM-DD HH:MM:SS'. '' means never expire + * @param $memberof (array) Roles to which the new role will be immediately added as a new member + * @param $members (array) Roles which are automatically added as members of the new role + * @param $adminmembers (array) Roles which are automatically added as admin members of the new role + * @return 0 success + */ + function createRole($rolename, $password, $superuser, $createdb, $createrole, $inherits, $login, $connlimit, $expiry, $memberof, $members, $adminmembers) { + $enc = $this->_encryptPassword($rolename, $password); + $this->fieldClean($rolename); + $this->clean($enc); + $this->clean($connlimit); + $this->clean($expiry); + $this->fieldArrayClean($memberof); + $this->fieldArrayClean($members); + $this->fieldArrayClean($adminmembers); + + $sql = "CREATE ROLE \"{$rolename}\""; + if ($password != '') $sql .= " WITH ENCRYPTED PASSWORD '{$enc}'"; + $sql .= ($superuser) ? ' SUPERUSER' : ' NOSUPERUSER'; + $sql .= ($createdb) ? ' CREATEDB' : ' NOCREATEDB'; + $sql .= ($createrole) ? ' CREATEROLE' : ' NOCREATEROLE'; + $sql .= ($inherits) ? ' INHERIT' : ' NOINHERIT'; + $sql .= ($login) ? ' LOGIN' : ' NOLOGIN'; + if ($connlimit != '') $sql .= " CONNECTION LIMIT {$connlimit}"; else $sql .= ' CONNECTION LIMIT -1'; + if ($expiry != '') $sql .= " VALID UNTIL '{$expiry}'"; else $sql .= " VALID UNTIL 'infinity'"; + if (is_array($memberof) && sizeof($memberof) > 0) $sql .= ' IN ROLE "' . join('", "', $memberof) . '"'; + if (is_array($members) && sizeof($members) > 0) $sql .= ' ROLE "' . join('", "', $members) . '"'; + if (is_array($adminmembers) && sizeof($adminmembers) > 0) $sql .= ' ADMIN "' . join('", "', $adminmembers) . '"'; + + return $this->execute($sql); + } + + /** + * Adjusts a role's info + * @param $rolename The name of the role to adjust + * @param $password A password for the role + * @param $superuser Boolean whether or not the role is a superuser + * @param $createdb Boolean whether or not the role can create databases + * @param $createrole Boolean whether or not the role can create other roles + * @param $inherits Boolean whether or not the role inherits the privileges from parent roles + * @param $login Boolean whether or not the role will be allowed to login + * @param $connlimit Number of concurrent connections the role can make + * @param $expiry string Format 'YYYY-MM-DD HH:MM:SS'. '' means never expire + * @param $memberof (array) Roles to which the role will be immediately added as a new member + * @param $members (array) Roles which are automatically added as members of the role + * @param $adminmembers (array) Roles which are automatically added as admin members of the role + * @param $memberofold (array) Original roles whose the role belongs to + * @param $membersold (array) Original roles that are members of the role + * @param $adminmembersold (array) Original roles that are admin members of the role + * @return 0 success + */ + function setRole($rolename, $password, $superuser, $createdb, $createrole, $inherits, $login, $connlimit, $expiry, $memberof, $members, $adminmembers, $memberofold, $membersold, $adminmembersold) { + $enc = $this->_encryptPassword($rolename, $password); + $this->fieldClean($rolename); + $this->clean($enc); + $this->clean($connlimit); + $this->clean($expiry); + $this->fieldArrayClean($memberof); + $this->fieldArrayClean($members); + $this->fieldArrayClean($adminmembers); + + $sql = "ALTER ROLE \"{$rolename}\""; + if ($password != '') $sql .= " WITH ENCRYPTED PASSWORD '{$enc}'"; + $sql .= ($superuser) ? ' SUPERUSER' : ' NOSUPERUSER'; + $sql .= ($createdb) ? ' CREATEDB' : ' NOCREATEDB'; + $sql .= ($createrole) ? ' CREATEROLE' : ' NOCREATEROLE'; + $sql .= ($inherits) ? ' INHERIT' : ' NOINHERIT'; + $sql .= ($login) ? ' LOGIN' : ' NOLOGIN'; + if ($connlimit != '') $sql .= " CONNECTION LIMIT {$connlimit}"; else $sql .= ' CONNECTION LIMIT -1'; + if ($expiry != '') $sql .= " VALID UNTIL '{$expiry}'"; else $sql .= " VALID UNTIL 'infinity'"; + + $status = $this->execute($sql); + + if ($status != 0) return -1; + + //memberof + $old = explode(',', $memberofold); + foreach ($memberof as $m) { + if (!in_array($m, $old)) { + $status = $this->grantRole($m, $rolename); + if ($status != 0) return -1; + } + } + if($memberofold) + { + foreach ($old as $o) { + if (!in_array($o, $memberof)) { + $status = $this->revokeRole($o, $rolename, 0, 'CASCADE'); + if ($status != 0) return -1; + } + } + } + + //members + $old = explode(',', $membersold); + foreach ($members as $m) { + if (!in_array($m, $old)) { + $status = $this->grantRole($rolename, $m); + if ($status != 0) return -1; + } + } + if($membersold) + { + foreach ($old as $o) { + if (!in_array($o, $members)) { + $status = $this->revokeRole($rolename, $o, 0, 'CASCADE'); + if ($status != 0) return -1; + } + } + } + + //adminmembers + $old = explode(',', $adminmembersold); + foreach ($adminmembers as $m) { + if (!in_array($m, $old)) { + $status = $this->grantRole($rolename, $m, 1); + if ($status != 0) return -1; + } + } + if($adminmembersold) + { + foreach ($old as $o) { + if (!in_array($o, $adminmembers)) { + $status = $this->revokeRole($rolename, $o, 1, 'CASCADE'); + if ($status != 0) return -1; + } + } + } + + return $status; + } + + /** + * Renames a role + * @param $rolename The name of the role to rename + * @param $newrolename The new name of the role + * @return 0 success + */ + function renameRole($rolename, $newrolename){ + $this->fieldClean($rolename); + $this->fieldClean($newrolename); + + $sql = "ALTER ROLE \"{$rolename}\" RENAME TO \"{$newrolename}\""; + + return $this->execute($sql); + } + + /** + * Adjusts a role's info and renames it + * @param $rolename The name of the role to adjust + * @param $password A password for the role + * @param $superuser Boolean whether or not the role is a superuser + * @param $createdb Boolean whether or not the role can create databases + * @param $createrole Boolean whether or not the role can create other roles + * @param $inherits Boolean whether or not the role inherits the privileges from parent roles + * @param $login Boolean whether or not the role will be allowed to login + * @param $connlimit Number of concurrent connections the role can make + * @param $expiry string Format 'YYYY-MM-DD HH:MM:SS'. '' means never expire + * @param $memberof (array) Roles to which the role will be immediately added as a new member + * @param $members (array) Roles which are automatically added as members of the role + * @param $adminmembers (array) Roles which are automatically added as admin members of the role + * @param $memberofold (array) Original roles whose the role belongs to + * @param $membersold (array) Original roles that are members of the role + * @param $adminmembersold (array) Original roles that are admin members of the role + * @param $newrolename The new name of the role + * @return 0 success + * @return -1 transaction error + * @return -2 set role attributes error + * @return -3 rename error + */ + function setRenameRole($rolename, $password, $superuser, $createdb, $createrole, + $inherits, $login, $connlimit, $expiry, $memberof, $members, $adminmembers, + $memberofold, $membersold, $adminmembersold, $newrolename) { + + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + if ($rolename != $newrolename){ + $status = $this->renameRole($rolename, $newrolename); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + $rolename = $newrolename; + } + + $status = $this->setRole($rolename, $password, $superuser, $createdb, $createrole, $inherits, $login, $connlimit, $expiry, $memberof, $members, $adminmembers, $memberofold, $membersold, $adminmembersold); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + + return $this->endTransaction(); + } + + /** + * Removes a role + * @param $rolename The name of the role to drop + * @return 0 success + */ + function dropRole($rolename) { + $this->fieldClean($rolename); + + $sql = "DROP ROLE \"{$rolename}\""; + + return $this->execute($sql); + } + + /** + * Creates a new user + * @param $username The username of the user to create + * @param $password A password for the user + * @param $createdb boolean Whether or not the user can create databases + * @param $createuser boolean Whether or not the user can create other users + * @param $expiry string Format 'YYYY-MM-DD HH:MM:SS'. '' means never expire + * @param $group (array) The groups to create the user in + * @return 0 success + */ + function createUser($username, $password, $createdb, $createuser, $expiry, $groups) { + $enc = $this->_encryptPassword($username, $password); + $this->fieldClean($username); + $this->clean($enc); + $this->clean($expiry); + $this->fieldArrayClean($groups); + + $sql = "CREATE USER \"{$username}\""; + if ($password != '') $sql .= " WITH ENCRYPTED PASSWORD '{$enc}'"; + $sql .= ($createdb) ? ' CREATEDB' : ' NOCREATEDB'; + $sql .= ($createuser) ? ' CREATEUSER' : ' NOCREATEUSER'; + if (is_array($groups) && sizeof($groups) > 0) $sql .= " IN GROUP \"" . join('", "', $groups) . "\""; + if ($expiry != '') $sql .= " VALID UNTIL '{$expiry}'"; + else $sql .= " VALID UNTIL 'infinity'"; + + return $this->execute($sql); + } + + /** + * Renames a user + * @param $username The username of the user to rename + * @param $newname The new name of the user + * @return 0 success + */ + function renameUser($username, $newname){ + $this->fieldClean($username); + $this->fieldClean($newname); + + $sql = "ALTER USER \"{$username}\" RENAME TO \"{$newname}\""; + + return $this->execute($sql); + } + + /** + * Adjusts a user's info + * @param $username The username of the user to modify + * @param $password A new password for the user + * @param $createdb boolean Whether or not the user can create databases + * @param $createuser boolean Whether or not the user can create other users + * @param $expiry string Format 'YYYY-MM-DD HH:MM:SS'. '' means never expire. + * @return 0 success + */ + function setUser($username, $password, $createdb, $createuser, $expiry) { + $enc = $this->_encryptPassword($username, $password); + $this->fieldClean($username); + $this->clean($enc); + $this->clean($expiry); + + $sql = "ALTER USER \"{$username}\""; + if ($password != '') $sql .= " WITH ENCRYPTED PASSWORD '{$enc}'"; + $sql .= ($createdb) ? ' CREATEDB' : ' NOCREATEDB'; + $sql .= ($createuser) ? ' CREATEUSER' : ' NOCREATEUSER'; + if ($expiry != '') $sql .= " VALID UNTIL '{$expiry}'"; + else $sql .= " VALID UNTIL 'infinity'"; + + return $this->execute($sql); + } + + /** + * Adjusts a user's info and renames the user + * @param $username The username of the user to modify + * @param $password A new password for the user + * @param $createdb boolean Whether or not the user can create databases + * @param $createuser boolean Whether or not the user can create other users + * @param $expiry string Format 'YYYY-MM-DD HH:MM:SS'. '' means never expire. + * @param $newname The new name of the user + * @return 0 success + * @return -1 transaction error + * @return -2 set user attributes error + * @return -3 rename error + */ + function setRenameUser($username, $password, $createdb, $createuser, $expiry, $newname) { + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + if ($username != $newname){ + $status = $this->renameUser($username, $newname); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + $username = $newname; + } + + $status = $this->setUser($username, $password, $createdb, $createuser, $expiry); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + + return $this->endTransaction(); + } + + /** + * Removes a user + * @param $username The username of the user to drop + * @return 0 success + */ + function dropUser($username) { + $this->fieldClean($username); + + $sql = "DROP USER \"{$username}\""; + + return $this->execute($sql); + } + + /** + * Determines whether or not a user is a super user + * @param $username The username of the user + * @return True if is a super user, false otherwise + */ + function isSuperUser($username = '') { + $this->clean($username); + + if (empty($usename)) { + $val = pg_parameter_status($this->conn->_connectionID, 'is_superuser'); + if ($val !== false) return $val == 'on'; + } + + $sql = "SELECT usesuper FROM pg_user WHERE usename='{$username}'"; + + $usesuper = $this->selectField($sql, 'usesuper'); + if ($usesuper == -1) return false; + else return $usesuper == 't'; + } + + /** + * Changes a role's password + * @param $rolename The role name + * @param $password The new password + * @return 0 success + */ + function changePassword($rolename, $password) { + $enc = $this->_encryptPassword($rolename, $password); + $this->fieldClean($rolename); + $this->clean($enc); + + $sql = "ALTER ROLE \"{$rolename}\" WITH ENCRYPTED PASSWORD '{$enc}'"; + + return $this->execute($sql); + } + + /** + * Adds a group member + * @param $groname The name of the group + * @param $user The name of the user to add to the group + * @return 0 success + */ + function addGroupMember($groname, $user) { + $this->fieldClean($groname); + $this->fieldClean($user); + + $sql = "ALTER GROUP \"{$groname}\" ADD USER \"{$user}\""; + + return $this->execute($sql); + } + + /** + * Returns all role names which the role belongs to + * @param $rolename The role name + * @return All role names + */ + function getMemberOf($rolename) { + $this->clean($rolename); + + $sql = " + SELECT rolname FROM pg_catalog.pg_roles R, pg_auth_members M + WHERE R.oid=M.roleid + AND member IN ( + SELECT oid FROM pg_catalog.pg_roles + WHERE rolname='{$rolename}') + ORDER BY rolname"; + + return $this->selectSet($sql); + } + + /** + * Returns all role names that are members of a role + * @param $rolename The role name + * @param $admin (optional) Find only admin members + * @return All role names + */ + function getMembers($rolename, $admin = 'f') { + $this->clean($rolename); + + $sql = " + SELECT rolname FROM pg_catalog.pg_roles R, pg_auth_members M + WHERE R.oid=M.member AND admin_option='{$admin}' + AND roleid IN (SELECT oid FROM pg_catalog.pg_roles + WHERE rolname='{$rolename}') + ORDER BY rolname"; + + return $this->selectSet($sql); + } + + /** + * Removes a group member + * @param $groname The name of the group + * @param $user The name of the user to remove from the group + * @return 0 success + */ + function dropGroupMember($groname, $user) { + $this->fieldClean($groname); + $this->fieldClean($user); + + $sql = "ALTER GROUP \"{$groname}\" DROP USER \"{$user}\""; + + return $this->execute($sql); + } + + /** + * Return users in a specific group + * @param $groname The name of the group + * @return All users in the group + */ + function getGroup($groname) { + $this->clean($groname); + + $sql = " + SELECT s.usename FROM pg_catalog.pg_user s, pg_catalog.pg_group g + WHERE g.groname='{$groname}' AND s.usesysid = ANY (g.grolist) + ORDER BY s.usename"; + + return $this->selectSet($sql); + } + + /** + * Returns all groups in the database cluser + * @return All groups + */ + function getGroups() { + $sql = "SELECT groname FROM pg_group ORDER BY groname"; + + return $this->selectSet($sql); + } + + /** + * Creates a new group + * @param $groname The name of the group + * @param $users An array of users to add to the group + * @return 0 success + */ + function createGroup($groname, $users) { + $this->fieldClean($groname); + + $sql = "CREATE GROUP \"{$groname}\""; + + if (is_array($users) && sizeof($users) > 0) { + $this->fieldArrayClean($users); + $sql .= ' WITH USER "' . join('", "', $users) . '"'; + } + + return $this->execute($sql); + } + + /** + * Removes a group + * @param $groname The name of the group to drop + * @return 0 success + */ + function dropGroup($groname) { + $this->fieldClean($groname); + + $sql = "DROP GROUP \"{$groname}\""; + + return $this->execute($sql); + } + + /** + * Internal function used for parsing ACLs + * @param $acl The ACL to parse (of type aclitem[]) + * @return Privileges array + */ + function _parseACL($acl) { + // Take off the first and last characters (the braces) + $acl = substr($acl, 1, strlen($acl) - 2); + + // Pick out individual ACE's by carefully parsing. This is necessary in order + // to cope with usernames and stuff that contain commas + $aces = array(); + $i = $j = 0; + $in_quotes = false; + while ($i < strlen($acl)) { + // If current char is a double quote and it's not escaped, then + // enter quoted bit + $char = substr($acl, $i, 1); + if ($char == '"' && ($i == 0 || substr($acl, $i - 1, 1) != '\\')) + $in_quotes = !$in_quotes; + elseif ($char == ',' && !$in_quotes) { + // Add text so far to the array + $aces[] = substr($acl, $j, $i - $j); + $j = $i + 1; + } + $i++; + } + // Add final text to the array + $aces[] = substr($acl, $j); + + // Create the array to be returned + $temp = array(); + + // For each ACE, generate an entry in $temp + foreach ($aces as $v) { + + // If the ACE begins with a double quote, strip them off both ends + // and unescape backslashes and double quotes + $unquote = false; + if (strpos($v, '"') === 0) { + $v = substr($v, 1, strlen($v) - 2); + $v = str_replace('\\"', '"', $v); + $v = str_replace('\\\\', '\\', $v); + } + + // Figure out type of ACE (public, user or group) + if (strpos($v, '=') === 0) + $atype = 'public'; + else if ($this->hasRoles()) { + $atype = 'role'; + } + else if (strpos($v, 'group ') === 0) { + $atype = 'group'; + // Tear off 'group' prefix + $v = substr($v, 6); + } + else + $atype = 'user'; + + // Break on unquoted equals sign... + $i = 0; + $in_quotes = false; + $entity = null; + $chars = null; + while ($i < strlen($v)) { + // If current char is a double quote and it's not escaped, then + // enter quoted bit + $char = substr($v, $i, 1); + $next_char = substr($v, $i + 1, 1); + if ($char == '"' && ($i == 0 || $next_char != '"')) { + $in_quotes = !$in_quotes; + } + // Skip over escaped double quotes + elseif ($char == '"' && $next_char == '"') { + $i++; + } + elseif ($char == '=' && !$in_quotes) { + // Split on current equals sign + $entity = substr($v, 0, $i); + $chars = substr($v, $i + 1); + break; + } + $i++; + } + + // Check for quoting on entity name, and unescape if necessary + if (strpos($entity, '"') === 0) { + $entity = substr($entity, 1, strlen($entity) - 2); + $entity = str_replace('""', '"', $entity); + } + + // New row to be added to $temp + // (type, grantee, privileges, grantor, grant option? + $row = array($atype, $entity, array(), '', array()); + + // Loop over chars and add privs to $row + for ($i = 0; $i < strlen($chars); $i++) { + // Append to row's privs list the string representing + // the privilege + $char = substr($chars, $i, 1); + if ($char == '*') + $row[4][] = $this->privmap[substr($chars, $i - 1, 1)]; + elseif ($char == '/') { + $grantor = substr($chars, $i + 1); + // Check for quoting + if (strpos($grantor, '"') === 0) { + $grantor = substr($grantor, 1, strlen($grantor) - 2); + $grantor = str_replace('""', '"', $grantor); + } + $row[3] = $grantor; + break; + } + else { + if (!isset($this->privmap[$char])) + return -3; + else + $row[2][] = $this->privmap[$char]; + } + } + + // Append row to temp + $temp[] = $row; + } + + return $temp; + } + + /** + * Grabs an array of users and their privileges for an object, + * given its type. + * @param $object The name of the object whose privileges are to be retrieved + * @param $type The type of the object (eg. database, schema, relation, function or language) + * @param $table Optional, column's table if type = column + * @return Privileges array + * @return -1 invalid type + * @return -2 object not found + * @return -3 unknown privilege type + */ + function getPrivileges($object, $type, $table = null) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($object); + + switch ($type) { + case 'column': + $this->clean($table); + $sql = " + SELECT E'{' || pg_catalog.array_to_string(attacl, E',') || E'}' as acl + FROM pg_catalog.pg_attribute a + LEFT JOIN pg_catalog.pg_class c ON (a.attrelid = c.oid) + LEFT JOIN pg_catalog.pg_namespace n ON (c.relnamespace=n.oid) + WHERE n.nspname='{$c_schema}' + AND c.relname='{$table}' + AND a.attname='{$object}'"; + break; + case 'table': + case 'view': + case 'sequence': + $sql = " + SELECT relacl AS acl FROM pg_catalog.pg_class + WHERE relname='{$object}' + AND relnamespace=(SELECT oid FROM pg_catalog.pg_namespace + WHERE nspname='{$c_schema}')"; + break; + case 'database': + $sql = "SELECT datacl AS acl FROM pg_catalog.pg_database WHERE datname='{$object}'"; + break; + case 'function': + // Since we fetch functions by oid, they are already constrained to + // the current schema. + $sql = "SELECT proacl AS acl FROM pg_catalog.pg_proc WHERE oid='{$object}'"; + break; + case 'language': + $sql = "SELECT lanacl AS acl FROM pg_catalog.pg_language WHERE lanname='{$object}'"; + break; + case 'schema': + $sql = "SELECT nspacl AS acl FROM pg_catalog.pg_namespace WHERE nspname='{$object}'"; + break; + case 'tablespace': + $sql = "SELECT spcacl AS acl FROM pg_catalog.pg_tablespace WHERE spcname='{$object}'"; + break; + default: + return -1; + } + + // Fetch the ACL for object + $acl = $this->selectField($sql, 'acl'); + if ($acl == -1) return -2; + elseif ($acl == '' || $acl == null) return array(); + else return $this->_parseACL($acl); + } + + /** + * Grants a privilege to a user, group or public + * @param $mode 'GRANT' or 'REVOKE'; + * @param $type The type of object + * @param $object The name of the object + * @param $public True to grant to public, false otherwise + * @param $usernames The array of usernames to grant privs to. + * @param $groupnames The array of group names to grant privs to. + * @param $privileges The array of privileges to grant (eg. ('SELECT', 'ALL PRIVILEGES', etc.) ) + * @param $grantoption True if has grant option, false otherwise + * @param $cascade True for cascade revoke, false otherwise + * @param $table the column's table if type=column + * @return 0 success + * @return -1 invalid type + * @return -2 invalid entity + * @return -3 invalid privileges + * @return -4 not granting to anything + * @return -4 invalid mode + */ + function setPrivileges($mode, $type, $object, $public, $usernames, $groupnames, + $privileges, $grantoption, $cascade, $table + ) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldArrayClean($usernames); + $this->fieldArrayClean($groupnames); + + // Input checking + if (!is_array($privileges) || sizeof($privileges) == 0) return -3; + if (!is_array($usernames) || !is_array($groupnames) || + (!$public && sizeof($usernames) == 0 && sizeof($groupnames) == 0)) return -4; + if ($mode != 'GRANT' && $mode != 'REVOKE') return -5; + + $sql = $mode; + + // Grant option + if ($this->hasGrantOption() && $mode == 'REVOKE' && $grantoption) { + $sql .= ' GRANT OPTION FOR'; + } + + if (in_array('ALL PRIVILEGES', $privileges)) { + $sql .= ' ALL PRIVILEGES'; + } + else { + if ($type == 'column') { + $this->fieldClean($object); + $sql .= ' ' . join(" (\"{$object}\"), ", $privileges); + } + else { + $sql .= ' ' . join(', ', $privileges); + } + } + + switch ($type) { + case 'column': + $sql .= " (\"{$object}\")"; + $object = $table; + case 'table': + case 'view': + case 'sequence': + $this->fieldClean($object); + $sql .= " ON \"{$f_schema}\".\"{$object}\""; + break; + case 'database': + $this->fieldClean($object); + $sql .= " ON DATABASE \"{$object}\""; + break; + case 'function': + // Function comes in with $object as function OID + $fn = $this->getFunction($object); + $this->fieldClean($fn->fields['proname']); + $sql .= " ON FUNCTION \"{$f_schema}\".\"{$fn->fields['proname']}\"({$fn->fields['proarguments']})"; + break; + case 'language': + $this->fieldClean($object); + $sql .= " ON LANGUAGE \"{$object}\""; + break; + case 'schema': + $this->fieldClean($object); + $sql .= " ON SCHEMA \"{$object}\""; + break; + case 'tablespace': + $this->fieldClean($object); + $sql .= " ON TABLESPACE \"{$object}\""; + break; + default: + return -1; + } + + // Dump PUBLIC + $first = true; + $sql .= ($mode == 'GRANT') ? ' TO ' : ' FROM '; + if ($public) { + $sql .= 'PUBLIC'; + $first = false; + } + // Dump users + foreach ($usernames as $v) { + if ($first) { + $sql .= "\"{$v}\""; + $first = false; + } + else { + $sql .= ", \"{$v}\""; + } + } + // Dump groups + foreach ($groupnames as $v) { + if ($first) { + $sql .= "GROUP \"{$v}\""; + $first = false; + } + else { + $sql .= ", GROUP \"{$v}\""; + } + } + + // Grant option + if ($this->hasGrantOption() && $mode == 'GRANT' && $grantoption) { + $sql .= ' WITH GRANT OPTION'; + } + + // Cascade revoke + if ($this->hasGrantOption() && $mode == 'REVOKE' && $cascade) { + $sql .= ' CASCADE'; + } + + return $this->execute($sql); + } + + /** + * Helper function that computes encypted PostgreSQL passwords + * @param $username The username + * @param $password The password + */ + function _encryptPassword($username, $password) { + return 'md5' . md5($password . $username); + } + + // Tablespace functions + + /** + * Retrieves information for all tablespaces + * @param $all Include all tablespaces (necessary when moving objects back to the default space) + * @return A recordset + */ + function getTablespaces($all = false) { + global $conf; + + $sql = "SELECT spcname, pg_catalog.pg_get_userbyid(spcowner) AS spcowner, pg_catalog.pg_tablespace_location(oid) as spclocation, + (SELECT description FROM pg_catalog.pg_shdescription pd WHERE pg_tablespace.oid=pd.objoid AND pd.classoid='pg_tablespace'::regclass) AS spccomment + FROM pg_catalog.pg_tablespace"; + + if (!$conf['show_system'] && !$all) { + $sql .= ' WHERE spcname NOT LIKE $$pg\_%$$'; + } + + $sql .= " ORDER BY spcname"; + + return $this->selectSet($sql); + } + + /** + * Retrieves a tablespace's information + * @return A recordset + */ + function getTablespace($spcname) { + $this->clean($spcname); + + $sql = "SELECT spcname, pg_catalog.pg_get_userbyid(spcowner) AS spcowner, pg_catalog.pg_tablespace_location(oid) as spclocation, + (SELECT description FROM pg_catalog.pg_shdescription pd WHERE pg_tablespace.oid=pd.objoid AND pd.classoid='pg_tablespace'::regclass) AS spccomment + FROM pg_catalog.pg_tablespace WHERE spcname='{$spcname}'"; + + return $this->selectSet($sql); + } + + /** + * Creates a tablespace + * @param $spcname The name of the tablespace to create + * @param $spcowner The owner of the tablespace. '' for current + * @param $spcloc The directory in which to create the tablespace + * @return 0 success + */ + function createTablespace($spcname, $spcowner, $spcloc, $comment='') { + $this->fieldClean($spcname); + $this->clean($spcloc); + + $sql = "CREATE TABLESPACE \"{$spcname}\""; + + if ($spcowner != '') { + $this->fieldClean($spcowner); + $sql .= " OWNER \"{$spcowner}\""; + } + + $sql .= " LOCATION '{$spcloc}'"; + + $status = $this->execute($sql); + if ($status != 0) return -1; + + if ($comment != '' && $this->hasSharedComments()) { + $status = $this->setComment('TABLESPACE',$spcname,'',$comment); + if ($status != 0) return -2; + } + + return 0; + } + + /** + * Alters a tablespace + * @param $spcname The name of the tablespace + * @param $name The new name for the tablespace + * @param $owner The new owner for the tablespace + * @return 0 success + * @return -1 transaction error + * @return -2 owner error + * @return -3 rename error + * @return -4 comment error + */ + function alterTablespace($spcname, $name, $owner, $comment='') { + $this->fieldClean($spcname); + $this->fieldClean($name); + $this->fieldClean($owner); + + // Begin transaction + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + // Owner + $sql = "ALTER TABLESPACE \"{$spcname}\" OWNER TO \"{$owner}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + + // Rename (only if name has changed) + if ($name != $spcname) { + $sql = "ALTER TABLESPACE \"{$spcname}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + + $spcname = $name; + } + + // Set comment if it has changed + if (trim($comment) != '' && $this->hasSharedComments()) { + $status = $this->setComment('TABLESPACE',$spcname,'',$comment); + if ($status != 0) return -4; + } + + return $this->endTransaction(); + } + + /** + * Drops a tablespace + * @param $spcname The name of the domain to drop + * @return 0 success + */ + function dropTablespace($spcname) { + $this->fieldClean($spcname); + + $sql = "DROP TABLESPACE \"{$spcname}\""; + + return $this->execute($sql); + } + + // Administration functions + + /** + * Analyze a database + * @param $table (optional) The table to analyze + */ + function analyzeDB($table = '') { + if ($table != '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + $sql = "ANALYZE \"{$f_schema}\".\"{$table}\""; + } + else + $sql = "ANALYZE"; + + return $this->execute($sql); + } + + /** + * Vacuums a database + * @param $table The table to vacuum + * @param $analyze If true, also does analyze + * @param $full If true, selects "full" vacuum + * @param $freeze If true, selects aggressive "freezing" of tuples + */ + function vacuumDB($table = '', $analyze = false, $full = false, $freeze = false) { + + $sql = "VACUUM"; + if ($full) $sql .= " FULL"; + if ($freeze) $sql .= " FREEZE"; + if ($analyze) $sql .= " ANALYZE"; + if ($table != '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + $sql .= " \"{$f_schema}\".\"{$table}\""; + } + + return $this->execute($sql); + } + + /** + * Returns all autovacuum global configuration + * @return associative array array( param => value, ...) + */ + function getAutovacuum() { + + $_defaults = $this->selectSet("SELECT name, setting + FROM pg_catalog.pg_settings + WHERE + name = 'autovacuum' + OR name = 'autovacuum_vacuum_threshold' + OR name = 'autovacuum_vacuum_scale_factor' + OR name = 'autovacuum_analyze_threshold' + OR name = 'autovacuum_analyze_scale_factor' + OR name = 'autovacuum_vacuum_cost_delay' + OR name = 'autovacuum_vacuum_cost_limit' + OR name = 'vacuum_freeze_min_age' + OR name = 'autovacuum_freeze_max_age' + " + ); + + $ret = array(); + while (!$_defaults->EOF) { + $ret[$_defaults->fields['name']] = $_defaults->fields['setting']; + $_defaults->moveNext(); + } + + return $ret; + } + + /** + * Returns all available autovacuum per table information. + * @return A recordset + */ + function saveAutovacuum($table, $vacenabled, $vacthreshold, $vacscalefactor, $anathresold, + $anascalefactor, $vaccostdelay, $vaccostlimit) + { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + $sql = "ALTER TABLE \"{$f_schema}\".\"{$table}\" SET ("; + + if (!empty($vacenabled)) { + $this->clean($vacenabled); + $params[] = "autovacuum_enabled='{$vacenabled}'"; + } + if (!empty($vacthreshold)) { + $this->clean($vacthreshold); + $params[] = "autovacuum_vacuum_threshold='{$vacthreshold}'"; + } + if (!empty($vacscalefactor)) { + $this->clean($vacscalefactor); + $params[] = "autovacuum_vacuum_scale_factor='{$vacscalefactor}'"; + } + if (!empty($anathresold)) { + $this->clean($anathresold); + $params[] = "autovacuum_analyze_threshold='{$anathresold}'"; + } + if (!empty($anascalefactor)) { + $this->clean($anascalefactor); + $params[] = "autovacuum_analyze_scale_factor='{$anascalefactor}'"; + } + if (!empty($vaccostdelay)) { + $this->clean($vaccostdelay); + $params[] = "autovacuum_vacuum_cost_delay='{$vaccostdelay}'"; + } + if (!empty($vaccostlimit)) { + $this->clean($vaccostlimit); + $params[] = "autovacuum_vacuum_cost_limit='{$vaccostlimit}'"; + } + + $sql = $sql . implode(',', $params) . ');'; + + return $this->execute($sql); + } + + function dropAutovacuum($table) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + return $this->execute(" + ALTER TABLE \"{$f_schema}\".\"{$table}\" RESET (autovacuum_enabled, autovacuum_vacuum_threshold, + autovacuum_vacuum_scale_factor, autovacuum_analyze_threshold, autovacuum_analyze_scale_factor, + autovacuum_vacuum_cost_delay, autovacuum_vacuum_cost_limit + );" + ); + } + + /** + * Returns all available process information. + * @param $database (optional) Find only connections to specified database + * @return A recordset + */ + function getProcesses($database = null) { + if ($database === null) + $sql = "SELECT datname, usename, pid, + case when wait_event is null then 'false' else wait_event_type || '::' || wait_event end as waiting, + query_start, application_name, client_addr, + case when state='idle in transaction' then ' in transaction' when state = 'idle' then '' else query end as query + FROM pg_catalog.pg_stat_activity + ORDER BY datname, usename, pid"; + else { + $this->clean($database); + $sql = "SELECT datname, usename, pid, + case when wait_event is null then 'false' else wait_event_type || '::' || wait_event end as waiting, + query_start, application_name, client_addr, + case when state='idle in transaction' then ' in transaction' when state = 'idle' then '' else query end as query + FROM pg_catalog.pg_stat_activity + WHERE datname='{$database}' + ORDER BY usename, pid"; + } + + return $this->selectSet($sql); + } + + /** + * Returns table locks information in the current database + * @return A recordset + */ + + function getLocks() { + global $conf; + + if (!$conf['show_system']) + $where = 'AND pn.nspname NOT LIKE $$pg\_%$$'; + else + $where = "AND nspname !~ '^pg_t(emp_[0-9]+|oast)$'"; + + $sql = " + SELECT + pn.nspname, pc.relname AS tablename, pl.pid, pl.mode, pl.granted, pl.virtualtransaction, + (select transactionid from pg_catalog.pg_locks l2 where l2.locktype='transactionid' + and l2.mode='ExclusiveLock' and l2.virtualtransaction=pl.virtualtransaction) as transaction + FROM + pg_catalog.pg_locks pl, + pg_catalog.pg_class pc, + pg_catalog.pg_namespace pn + WHERE + pl.relation = pc.oid AND pc.relnamespace=pn.oid + {$where} + ORDER BY pid,nspname,tablename"; + + return $this->selectSet($sql); + } + + /** + * Sends a cancel or kill command to a process + * @param $pid The ID of the backend process + * @param $signal 'CANCEL' + * @return 0 success + * @return -1 invalid signal type + */ + function sendSignal($pid, $signal) { + // Clean + $pid = (int)$pid; + + if ($signal == 'CANCEL') + $sql = "SELECT pg_catalog.pg_cancel_backend({$pid}) AS val"; + elseif ($signal == 'KILL') + $sql = "SELECT pg_catalog.pg_terminate_backend({$pid}) AS val"; + else + return -1; + + + // Execute the query + $val = $this->selectField($sql, 'val'); + + if ($val === 'f') return -1; + elseif ($val === 't') return 0; + else return -1; + } + + // Misc functions + + /** + * Sets the comment for an object in the database + * @pre All parameters must already be cleaned + * @param $obj_type One of 'TABLE' | 'COLUMN' | 'VIEW' | 'SCHEMA' | 'SEQUENCE' | 'TYPE' | 'FUNCTION' | 'AGGREGATE' + * @param $obj_name The name of the object for which to attach a comment. + * @param $table Name of table that $obj_name belongs to. Ignored unless $obj_type is 'TABLE' or 'COLUMN'. + * @param $comment The comment to add. + * @return 0 success + */ + function setComment($obj_type, $obj_name, $table, $comment, $basetype = NULL) { + $sql = "COMMENT ON {$obj_type} " ; + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->clean($comment); // Passing in an already cleaned comment will lead to double escaped data + // So, while counter-intuitive, it is important to not clean comments before + // calling setComment. We will clean it here instead. +/* + $this->fieldClean($table); + $this->fieldClean($obj_name); +*/ + + switch ($obj_type) { + case 'TABLE': + $sql .= "\"{$f_schema}\".\"{$table}\" IS "; + break; + case 'COLUMN': + $sql .= "\"{$f_schema}\".\"{$table}\".\"{$obj_name}\" IS "; + break; + case 'SEQUENCE': + case 'VIEW': + case 'TEXT SEARCH CONFIGURATION': + case 'TEXT SEARCH DICTIONARY': + case 'TEXT SEARCH TEMPLATE': + case 'TEXT SEARCH PARSER': + case 'TYPE': + $sql .= "\"{$f_schema}\"."; + case 'DATABASE': + case 'ROLE': + case 'SCHEMA': + case 'TABLESPACE': + $sql .= "\"{$obj_name}\" IS "; + break; + case 'FUNCTION': + $sql .= "\"{$f_schema}\".{$obj_name} IS "; + break; + case 'AGGREGATE': + $sql .= "\"{$f_schema}\".\"{$obj_name}\" (\"{$basetype}\") IS "; + break; + default: + // Unknown object type + return -1; + } + + if ($comment != '') + $sql .= "'{$comment}';"; + else + $sql .= 'NULL;'; + + return $this->execute($sql); + + } + + /** + * A private helper method for executeScript that advances the + * character by 1. In psql this is careful to take into account + * multibyte languages, but we don't at the moment, so this function + * is someone redundant, since it will always advance by 1 + * @param &$i The current character position in the line + * @param &$prevlen Length of previous character (ie. 1) + * @param &$thislen Length of current character (ie. 1) + */ + private + function advance_1(&$i, &$prevlen, &$thislen) { + $prevlen = $thislen; + $i += $thislen; + $thislen = 1; + } + + /** + * Private helper method to detect a valid $foo$ quote delimiter at + * the start of the parameter dquote + * @return True if valid, false otherwise + */ + private + function valid_dolquote($dquote) { + // XXX: support multibyte + return (preg_match('/^[$][$]/', $dquote) || preg_match('/^[$][_[:alpha:]][_[:alnum:]]*[$]/', $dquote)); + } + + /** + * Executes an SQL script as a series of SQL statements. Returns + * the result of the final step. This is a very complicated lexer + * based on the REL7_4_STABLE src/bin/psql/mainloop.c lexer in + * the PostgreSQL source code. + * XXX: It does not handle multibyte languages properly. + * @param $name Entry in $_FILES to use + * @param $callback (optional) Callback function to call with each query, + its result and line number. + * @return True for general success, false on any failure. + */ + function executeScript($name, $callback = null) { + global $data; + + // This whole function isn't very encapsulated, but hey... + $conn = $data->conn->_connectionID; + if (!is_uploaded_file($_FILES[$name]['tmp_name'])) return false; + + $fd = fopen($_FILES[$name]['tmp_name'], 'r'); + if (!$fd) return false; + + // Build up each SQL statement, they can be multiline + $query_buf = null; + $query_start = 0; + $in_quote = 0; + $in_xcomment = 0; + $bslash_count = 0; + $dol_quote = null; + $paren_level = 0; + $len = 0; + $i = 0; + $prevlen = 0; + $thislen = 0; + $lineno = 0; + + // Loop over each line in the file + while (!feof($fd)) { + $line = fgets($fd); + $lineno++; + + // Nothing left on line? Then ignore... + if (trim($line) == '') continue; + + $len = strlen($line); + $query_start = 0; + + /* + * Parse line, looking for command separators. + * + * The current character is at line[i], the prior character at line[i + * - prevlen], the next character at line[i + thislen]. + */ + $prevlen = 0; + $thislen = ($len > 0) ? 1 : 0; + + for ($i = 0; $i < $len; $this->advance_1($i, $prevlen, $thislen)) { + + /* was the previous character a backslash? */ + if ($i > 0 && substr($line, $i - $prevlen, 1) == '\\') + $bslash_count++; + else + $bslash_count = 0; + + /* + * It is important to place the in_* test routines before the + * in_* detection routines. i.e. we have to test if we are in + * a quote before testing for comments. + */ + + /* in quote? */ + if ($in_quote !== 0) + { + /* + * end of quote if matching non-backslashed character. + * backslashes don't count for double quotes, though. + */ + if (substr($line, $i, 1) == $in_quote && + ($bslash_count % 2 == 0 || $in_quote == '"')) + $in_quote = 0; + } + + /* in or end of $foo$ type quote? */ + else if ($dol_quote) { + if (strncmp(substr($line, $i), $dol_quote, strlen($dol_quote)) == 0) { + $this->advance_1($i, $prevlen, $thislen); + while(substr($line, $i, 1) != '$') + $this->advance_1($i, $prevlen, $thislen); + $dol_quote = null; + } + } + + /* start of extended comment? */ + else if (substr($line, $i, 2) == '/*') + { + $in_xcomment++; + if ($in_xcomment == 1) + $this->advance_1($i, $prevlen, $thislen); + } + + /* in or end of extended comment? */ + else if ($in_xcomment) + { + if (substr($line, $i, 2) == '*/' && !--$in_xcomment) + $this->advance_1($i, $prevlen, $thislen); + } + + /* start of quote? */ + else if (substr($line, $i, 1) == '\'' || substr($line, $i, 1) == '"') { + $in_quote = substr($line, $i, 1); + } + + /* + * start of $foo$ type quote? + */ + else if (!$dol_quote && $this->valid_dolquote(substr($line, $i))) { + $dol_end = strpos(substr($line, $i + 1), '$'); + $dol_quote = substr($line, $i, $dol_end + 1); + $this->advance_1($i, $prevlen, $thislen); + while (substr($line, $i, 1) != '$') { + $this->advance_1($i, $prevlen, $thislen); + } + + } + + /* single-line comment? truncate line */ + else if (substr($line, $i, 2) == '--') + { + $line = substr($line, 0, $i); /* remove comment */ + break; + } + + /* count nested parentheses */ + else if (substr($line, $i, 1) == '(') { + $paren_level++; + } + + else if (substr($line, $i, 1) == ')' && $paren_level > 0) { + $paren_level--; + } + + /* semicolon? then send query */ + else if (substr($line, $i, 1) == ';' && !$bslash_count && !$paren_level) + { + $subline = substr(substr($line, 0, $i), $query_start); + /* is there anything else on the line? */ + if (strspn($subline, " \t\n\r") != strlen($subline)) + { + /* + * insert a cosmetic newline, if this is not the first + * line in the buffer + */ + if (strlen($query_buf) > 0) + $query_buf .= "\n"; + /* append the line to the query buffer */ + $query_buf .= $subline; + $query_buf .= ';'; + + // Execute the query. PHP cannot execute + // empty queries, unlike libpq + $res = @pg_query($conn, $query_buf); + + // Call the callback function for display + if ($callback !== null) $callback($query_buf, $res, $lineno); + // Check for COPY request + if (pg_result_status($res) == 4) { // 4 == PGSQL_COPY_FROM + while (!feof($fd)) { + $copy = fgets($fd, 32768); + $lineno++; + pg_put_line($conn, $copy); + if ($copy == "\\.\n" || $copy == "\\.\r\n") { + pg_end_copy($conn); + break; + } + } + } + } + + $query_buf = null; + $query_start = $i + $thislen; + } + + /* + * keyword or identifier? + * We grab the whole string so that we don't + * mistakenly see $foo$ inside an identifier as the start + * of a dollar quote. + */ + // XXX: multibyte here + else if (preg_match('/^[_[:alpha:]]$/', substr($line, $i, 1))) { + $sub = substr($line, $i, $thislen); + while (preg_match('/^[\$_A-Za-z0-9]$/', $sub)) { + /* keep going while we still have identifier chars */ + $this->advance_1($i, $prevlen, $thislen); + $sub = substr($line, $i, $thislen); + } + // Since we're now over the next character to be examined, it is necessary + // to move back one space. + $i-=$prevlen; + } + } // end for + + /* Put the rest of the line in the query buffer. */ + $subline = substr($line, $query_start); + if ($in_quote || $dol_quote || strspn($subline, " \t\n\r") != strlen($subline)) + { + if (strlen($query_buf) > 0) + $query_buf .= "\n"; + $query_buf .= $subline; + } + + $line = null; + + } // end while + + /* + * Process query at the end of file without a semicolon, so long as + * it's non-empty. + */ + if (strlen($query_buf) > 0 && strspn($query_buf, " \t\n\r") != strlen($query_buf)) + { + // Execute the query + $res = @pg_query($conn, $query_buf); + + // Call the callback function for display + if ($callback !== null) $callback($query_buf, $res, $lineno); + // Check for COPY request + if (pg_result_status($res) == 4) { // 4 == PGSQL_COPY_FROM + while (!feof($fd)) { + $copy = fgets($fd, 32768); + $lineno++; + pg_put_line($conn, $copy); + if ($copy == "\\.\n" || $copy == "\\.\r\n") { + pg_end_copy($conn); + break; + } + } + } + } + + fclose($fd); + + return true; + } + + /** + * Generates the SQL for the 'select' function + * @param $table The table from which to select + * @param $show An array of columns to show. Empty array means all columns. + * @param $values An array mapping columns to values + * @param $ops An array of the operators to use + * @param $orderby (optional) An array of column numbers or names (one based) + * mapped to sort direction (asc or desc or '' or null) to order by + * @return The SQL query + */ + function getSelectSQL($table, $show, $values, $ops, $orderby = array()) { + $this->fieldArrayClean($show); + + // If an empty array is passed in, then show all columns + if (sizeof($show) == 0) { + if ($this->hasObjectID($table)) + $sql = "SELECT \"{$this->id}\", * FROM "; + else + $sql = "SELECT * FROM "; + } + else { + // Add oid column automatically to results for editing purposes + if (!in_array($this->id, $show) && $this->hasObjectID($table)) + $sql = "SELECT \"{$this->id}\", \""; + else + $sql = "SELECT \""; + + $sql .= join('","', $show) . "\" FROM "; + } + + $this->fieldClean($table); + + if (isset($_REQUEST['schema'])) { + $f_schema = $_REQUEST['schema']; + $this->fieldClean($f_schema); + $sql .= "\"{$f_schema}\"."; + } + $sql .= "\"{$table}\""; + + // If we have values specified, add them to the WHERE clause + $first = true; + if (is_array($values) && sizeof($values) > 0) { + foreach ($values as $k => $v) { + if ($v != '' || $this->selectOps[$ops[$k]] == 'p') { + $this->fieldClean($k); + if ($first) { + $sql .= " WHERE "; + $first = false; + } else { + $sql .= " AND "; + } + // Different query format depending on operator type + switch ($this->selectOps[$ops[$k]]) { + case 'i': + // Only clean the field for the inline case + // this is because (x), subqueries need to + // to allow 'a','b' as input. + $this->clean($v); + $sql .= "\"{$k}\" {$ops[$k]} '{$v}'"; + break; + case 'p': + $sql .= "\"{$k}\" {$ops[$k]}"; + break; + case 'x': + $sql .= "\"{$k}\" {$ops[$k]} ({$v})"; + break; + case 't': + $sql .= "\"{$k}\" {$ops[$k]}('{$v}')"; + break; + default: + // Shouldn't happen + } + } + } + } + + // ORDER BY + if (is_array($orderby) && sizeof($orderby) > 0) { + $sql .= " ORDER BY "; + $first = true; + foreach ($orderby as $k => $v) { + if ($first) $first = false; + else $sql .= ', '; + if (preg_match('/^[0-9]+$/', $k)) { + $sql .= $k; + } + else { + $this->fieldClean($k); + $sql .= '"' . $k . '"'; + } + if (strtoupper($v) == 'DESC') $sql .= " DESC"; + } + } + + return $sql; + } + + /** + * Returns a recordset of all columns in a query. Supports paging. + * @param $type Either 'QUERY' if it is an SQL query, or 'TABLE' if it is a table identifier, + * or 'SELECT" if it's a select query + * @param $table The base table of the query. NULL for no table. + * @param $query The query that is being executed. NULL for no query. + * @param $sortkey The column number to sort by, or '' or null for no sorting + * @param $sortdir The direction in which to sort the specified column ('asc' or 'desc') + * @param $page The page of the relation to retrieve + * @param $page_size The number of rows per page + * @param &$max_pages (return-by-ref) The max number of pages in the relation + * @return A recordset on success + * @return -1 transaction error + * @return -2 counting error + * @return -3 page or page_size invalid + * @return -4 unknown type + * @return -5 failed setting transaction read only + */ + function browseQuery($type, $table, $query, $sortkey, $sortdir, $page, $page_size, &$max_pages) { + // Check that we're not going to divide by zero + if (!is_numeric($page_size) || $page_size != (int)$page_size || $page_size <= 0) return -3; + + // If $type is TABLE, then generate the query + switch ($type) { + case 'TABLE': + if (preg_match('/^[0-9]+$/', $sortkey) && $sortkey > 0) $orderby = array($sortkey => $sortdir); + else $orderby = array(); + $query = $this->getSelectSQL($table, array(), array(), array(), $orderby); + break; + case 'QUERY': + case 'SELECT': + // Trim query + $query = trim($query); + // Trim off trailing semi-colon if there is one + if (substr($query, strlen($query) - 1, 1) == ';') + $query = substr($query, 0, strlen($query) - 1); + break; + default: + return -4; + } + + // Generate count query + $count = "SELECT COUNT(*) AS total FROM ($query) AS sub"; + + // Open a transaction + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + // If backend supports read only queries, then specify read only mode + // to avoid side effects from repeating queries that do writes. + if ($this->hasReadOnlyQueries()) { + $status = $this->execute("SET TRANSACTION READ ONLY"); + if ($status != 0) { + $this->rollbackTransaction(); + return -5; + } + } + + + // Count the number of rows + $total = $this->browseQueryCount($query, $count); + if ($total < 0) { + $this->rollbackTransaction(); + return -2; + } + + // Calculate max pages + $max_pages = ceil($total / $page_size); + + // Check that page is less than or equal to max pages + if (!is_numeric($page) || $page != (int)$page || $page > $max_pages || $page < 1) { + $this->rollbackTransaction(); + return -3; + } + + // Set fetch mode to NUM so that duplicate field names are properly returned + // for non-table queries. Since the SELECT feature only allows selecting one + // table, duplicate fields shouldn't appear. + if ($type == 'QUERY') $this->conn->setFetchMode(ADODB_FETCH_NUM); + + // Figure out ORDER BY. Sort key is always the column number (based from one) + // of the column to order by. Only need to do this for non-TABLE queries + if ($type != 'TABLE' && preg_match('/^[0-9]+$/', $sortkey) && $sortkey > 0) { + $orderby = " ORDER BY {$sortkey}"; + // Add sort order + if ($sortdir == 'desc') + $orderby .= ' DESC'; + else + $orderby .= ' ASC'; + } + else $orderby = ''; + + // Actually retrieve the rows, with offset and limit + $rs = $this->selectSet("SELECT * FROM ({$query}) AS sub {$orderby} LIMIT {$page_size} OFFSET " . ($page - 1) * $page_size); + $status = $this->endTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + return $rs; + } + + /** + * Finds the number of rows that would be returned by a + * query. + * @param $query The SQL query + * @param $count The count query + * @return The count of rows + * @return -1 error + */ + function browseQueryCount($query, $count) { + return $this->selectField($count, 'total'); + } + + /** + * Returns a recordset of all columns in a table + * @param $table The name of a table + * @param $key The associative array holding the key to retrieve + * @return A recordset + */ + function browseRow($table, $key) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + $sql = "SELECT * FROM \"{$f_schema}\".\"{$table}\""; + if (is_array($key) && sizeof($key) > 0) { + $sql .= " WHERE true"; + foreach ($key as $k => $v) { + $this->fieldClean($k); + $this->clean($v); + $sql .= " AND \"{$k}\"='{$v}'"; + } + } + + return $this->selectSet($sql); + } + + // Type conversion routines + + /** + * Change the value of a parameter to 't' or 'f' depending on whether it evaluates to true or false + * @param $parameter the parameter + */ + function dbBool(&$parameter) { + if ($parameter) $parameter = 't'; + else $parameter = 'f'; + + return $parameter; + } + + /** + * Change a parameter from 't' or 'f' to a boolean, (others evaluate to false) + * @param $parameter the parameter + */ + function phpBool($parameter) { + $parameter = ($parameter == 't'); + return $parameter; + } + + // interfaces Statistics collector functions + + /** + * Fetches statistics for a database + * @param $database The database to fetch stats for + * @return A recordset + */ + function getStatsDatabase($database) { + $this->clean($database); + + $sql = "SELECT * FROM pg_stat_database WHERE datname='{$database}'"; + + return $this->selectSet($sql); + } + + /** + * Fetches tuple statistics for a table + * @param $table The table to fetch stats for + * @return A recordset + */ + function getStatsTableTuples($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT * FROM pg_stat_all_tables + WHERE schemaname='{$c_schema}' AND relname='{$table}'"; + + return $this->selectSet($sql); + } + + /** + * Fetches I/0 statistics for a table + * @param $table The table to fetch stats for + * @return A recordset + */ + function getStatsTableIO($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT * FROM pg_statio_all_tables + WHERE schemaname='{$c_schema}' AND relname='{$table}'"; + + return $this->selectSet($sql); + } + + /** + * Fetches tuple statistics for all indexes on a table + * @param $table The table to fetch index stats for + * @return A recordset + */ + function getStatsIndexTuples($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT * FROM pg_stat_all_indexes + WHERE schemaname='{$c_schema}' AND relname='{$table}' ORDER BY indexrelname"; + + return $this->selectSet($sql); + } + + /** + * Fetches I/0 statistics for all indexes on a table + * @param $table The table to fetch index stats for + * @return A recordset + */ + function getStatsIndexIO($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT * FROM pg_statio_all_indexes + WHERE schemaname='{$c_schema}' AND relname='{$table}' + ORDER BY indexrelname"; + + return $this->selectSet($sql); + } + + // Capabilities + + function hasAggregateSortOp() { return true; } + function hasAlterAggregate() { return true; } + function hasAlterColumnType() { return true; } + function hasAlterDatabaseOwner() { return true; } + function hasAlterDatabaseRename() { return true; } + function hasAlterSchema() { return true; } + function hasAlterSchemaOwner() { return true; } + function hasAlterSequenceSchema() { return true; } + function hasAlterSequenceStart() { return true; } + function hasAlterTableSchema() { return true; } + function hasAutovacuum() { return true; } + function hasCreateTableLike() { return true; } + function hasCreateTableLikeWithConstraints() { return true; } + function hasCreateTableLikeWithIndexes() { return true; } + function hasCreateFieldWithConstraints() { return true; } + function hasDisableTriggers() { return true; } + function hasAlterDomains() { return true; } + function hasDomainConstraints() { return true; } + function hasEnumTypes() { return true; } + function hasFTS() { return true; } + function hasFunctionAlterOwner() { return true; } + function hasFunctionAlterSchema() { return true; } + function hasFunctionCosting() { return true; } + function hasFunctionGUC() { return true; } + function hasGrantOption() { return true; } + function hasNamedParams() { return true; } + function hasPrepare() { return true; } + function hasPreparedXacts() { return true; } + function hasReadOnlyQueries() { return true; } + function hasRecluster() { return true; } + function hasRoles() { return true; } + function hasServerAdminFuncs() { return true; } + function hasSharedComments() { return true; } + function hasQueryCancel() { return true; } + function hasTablespaces() { return true; } + function hasUserRename() { return true; } + function hasUserSignals() { return true; } + function hasVirtualTransactionId() { return true; } + function hasAlterDatabase() { return $this->hasAlterDatabaseRename(); } + function hasDatabaseCollation() { return true; } + function hasMagicTypes() { return true; } + function hasQueryKill() { return true; } + function hasConcurrentIndexBuild() { return true; } + function hasForceReindex() { return false; } + function hasByteaHexDefault() { return true; } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres10.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres10.php new file mode 100644 index 00000000..5f851d80 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres10.php @@ -0,0 +1,30 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc10.php'); + return $this->help_page; + } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres11.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres11.php new file mode 100644 index 00000000..2a3ae84b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres11.php @@ -0,0 +1,30 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc11.php'); + return $this->help_page; + } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres74.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres74.php new file mode 100644 index 00000000..4310eb64 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres74.php @@ -0,0 +1,635 @@ + array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'RULE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'view' => array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'RULE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'sequence' => array('SELECT', 'UPDATE', 'ALL PRIVILEGES'), + 'database' => array('CREATE', 'TEMPORARY', 'ALL PRIVILEGES'), + 'function' => array('EXECUTE', 'ALL PRIVILEGES'), + 'language' => array('USAGE', 'ALL PRIVILEGES'), + 'schema' => array('CREATE', 'USAGE', 'ALL PRIVILEGES') + ); + + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres74($conn) { + $this->Postgres80($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc74.php'); + return $this->help_page; + } + + // Database functions + + /** + * Alters a database + * the multiple return vals are for postgres 8+ which support more functionality in alter database + * @param $dbName The name of the database + * @param $newName new name for the database + * @param $newOwner The new owner for the database + * @return 0 success + * @return -1 transaction error + * @return -2 owner error + * @return -3 rename error + */ + function alterDatabase($dbName, $newName, $newOwner = '', $comment = '') { + //ignore $newowner, not supported pre 8.0 + //ignore $comment, not supported pre 8.2 + $this->clean($dbName); + $this->clean($newName); + + $status = $this->alterDatabaseRename($dbName, $newName); + if ($status != 0) return -3; + else return 0; + } + + /** + * Return all database available on the server + * @return A list of databases, sorted alphabetically + */ + function getDatabases($currentdatabase = NULL) { + global $conf, $misc; + + $server_info = $misc->getServerInfo(); + + if (isset($conf['owned_only']) && $conf['owned_only'] && !$this->isSuperUser()) { + $username = $server_info['username']; + $this->clean($username); + $clause = " AND pu.usename='{$username}'"; + } + else $clause = ''; + + if ($currentdatabase != NULL) { + $this->clean($currentdatabase); + $orderby = "ORDER BY pdb.datname = '{$currentdatabase}' DESC, pdb.datname"; + } + else + $orderby = "ORDER BY pdb.datname"; + + if (!$conf['show_system']) + $where = ' AND NOT pdb.datistemplate'; + else + $where = ' AND pdb.datallowconn'; + + $sql = "SELECT pdb.datname AS datname, pu.usename AS datowner, pg_encoding_to_char(encoding) AS datencoding, + (SELECT description FROM pg_description pd WHERE pdb.oid=pd.objoid) AS datcomment + FROM pg_database pdb, pg_user pu + WHERE pdb.datdba = pu.usesysid + {$where} + {$clause} + {$orderby}"; + + return $this->selectSet($sql); + } + + /** + * Searches all system catalogs to find objects that match a certain name. + * @param $term The search term + * @param $filter The object type to restrict to ('' means no restriction) + * @return A recordset + */ + function findObject($term, $filter) { + global $conf; + + /*about escaping: + * SET standard_conforming_string is not available before 8.2 + * So we must use PostgreSQL specific notation :/ + * E'' notation is not available before 8.1 + * $$ is available since 8.0 + * Nothing specific from 7.4 + **/ + + // Escape search term for ILIKE match + $term = str_replace('_', '\\_', $term); + $term = str_replace('%', '\\%', $term); + $this->clean($term); + $this->clean($filter); + + // Exclude system relations if necessary + if (!$conf['show_system']) { + // XXX: The mention of information_schema here is in the wrong place, but + // it's the quickest fix to exclude the info schema from 7.4 + $where = " AND pn.nspname NOT LIKE 'pg\\\\_%' AND pn.nspname != 'information_schema'"; + $lan_where = "AND pl.lanispl"; + } + else { + $where = ''; + $lan_where = ''; + } + + // Apply outer filter + $sql = ''; + if ($filter != '') { + $sql = "SELECT * FROM ("; + } + + $sql .= " + SELECT 'SCHEMA' AS type, oid, NULL AS schemaname, NULL AS relname, nspname AS name + FROM pg_catalog.pg_namespace pn WHERE nspname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT CASE WHEN relkind='r' THEN 'TABLE' WHEN relkind='v' THEN 'VIEW' WHEN relkind='S' THEN 'SEQUENCE' END, pc.oid, + pn.nspname, NULL, pc.relname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn + WHERE pc.relnamespace=pn.oid AND relkind IN ('r', 'v', 'S') AND relname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT CASE WHEN pc.relkind='r' THEN 'COLUMNTABLE' ELSE 'COLUMNVIEW' END, NULL, pn.nspname, pc.relname, pa.attname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_attribute pa WHERE pc.relnamespace=pn.oid AND pc.oid=pa.attrelid + AND pa.attname ILIKE '%{$term}%' AND pa.attnum > 0 AND NOT pa.attisdropped AND pc.relkind IN ('r', 'v') {$where} + UNION ALL + SELECT 'FUNCTION', pp.oid, pn.nspname, NULL, pp.proname || '(' || pg_catalog.oidvectortypes(pp.proargtypes) || ')' FROM pg_catalog.pg_proc pp, pg_catalog.pg_namespace pn + WHERE pp.pronamespace=pn.oid AND NOT pp.proisagg AND pp.proname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'INDEX', NULL, pn.nspname, pc.relname, pc2.relname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_index pi, pg_catalog.pg_class pc2 WHERE pc.relnamespace=pn.oid AND pc.oid=pi.indrelid + AND pi.indexrelid=pc2.oid + AND NOT EXISTS ( + SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pc2.tableoid AND d.objid = pc2.oid AND d.deptype = 'i' AND c.contype IN ('u', 'p') + ) + AND pc2.relname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'CONSTRAINTTABLE', NULL, pn.nspname, pc.relname, pc2.conname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_constraint pc2 WHERE pc.relnamespace=pn.oid AND pc.oid=pc2.conrelid AND pc2.conrelid != 0 + AND CASE WHEN pc2.contype IN ('f', 'c') THEN TRUE ELSE NOT EXISTS ( + SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pc2.tableoid AND d.objid = pc2.oid AND d.deptype = 'i' AND c.contype IN ('u', 'p') + ) END + AND pc2.conname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'CONSTRAINTDOMAIN', pt.oid, pn.nspname, pt.typname, pc.conname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn, + pg_catalog.pg_constraint pc WHERE pt.typnamespace=pn.oid AND pt.oid=pc.contypid AND pc.contypid != 0 + AND pc.conname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'TRIGGER', NULL, pn.nspname, pc.relname, pt.tgname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_trigger pt WHERE pc.relnamespace=pn.oid AND pc.oid=pt.tgrelid + AND ( pt.tgisconstraint = 'f' OR NOT EXISTS + (SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pt.tableoid AND d.objid = pt.oid AND d.deptype = 'i' AND c.contype = 'f')) + AND pt.tgname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'RULETABLE', NULL, pn.nspname AS schemaname, c.relname AS tablename, r.rulename FROM pg_catalog.pg_rewrite r + JOIN pg_catalog.pg_class c ON c.oid = r.ev_class + LEFT JOIN pg_catalog.pg_namespace pn ON pn.oid = c.relnamespace + WHERE c.relkind='r' AND r.rulename != '_RETURN' AND r.rulename ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'RULEVIEW', NULL, pn.nspname AS schemaname, c.relname AS tablename, r.rulename FROM pg_catalog.pg_rewrite r + JOIN pg_catalog.pg_class c ON c.oid = r.ev_class + LEFT JOIN pg_catalog.pg_namespace pn ON pn.oid = c.relnamespace + WHERE c.relkind='v' AND r.rulename != '_RETURN' AND r.rulename ILIKE '%{$term}%' {$where} + "; + + // Add advanced objects if show_advanced is set + if ($conf['show_advanced']) { + $sql .= " + UNION ALL + SELECT CASE WHEN pt.typtype='d' THEN 'DOMAIN' ELSE 'TYPE' END, pt.oid, pn.nspname, NULL, + pt.typname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn + WHERE pt.typnamespace=pn.oid AND typname ILIKE '%{$term}%' + AND (pt.typrelid = 0 OR (SELECT c.relkind = 'c' FROM pg_catalog.pg_class c WHERE c.oid = pt.typrelid)) + {$where} + UNION ALL + SELECT 'OPERATOR', po.oid, pn.nspname, NULL, po.oprname FROM pg_catalog.pg_operator po, pg_catalog.pg_namespace pn + WHERE po.oprnamespace=pn.oid AND oprname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'CONVERSION', pc.oid, pn.nspname, NULL, pc.conname FROM pg_catalog.pg_conversion pc, + pg_catalog.pg_namespace pn WHERE pc.connamespace=pn.oid AND conname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT 'LANGUAGE', pl.oid, NULL, NULL, pl.lanname FROM pg_catalog.pg_language pl + WHERE lanname ILIKE '%{$term}%' {$lan_where} + UNION ALL + SELECT DISTINCT ON (p.proname) 'AGGREGATE', p.oid, pn.nspname, NULL, p.proname FROM pg_catalog.pg_proc p + LEFT JOIN pg_catalog.pg_namespace pn ON p.pronamespace=pn.oid + WHERE p.proisagg AND p.proname ILIKE '%{$term}%' {$where} + UNION ALL + SELECT DISTINCT ON (po.opcname) 'OPCLASS', po.oid, pn.nspname, NULL, po.opcname FROM pg_catalog.pg_opclass po, + pg_catalog.pg_namespace pn WHERE po.opcnamespace=pn.oid + AND po.opcname ILIKE '%{$term}%' {$where} + "; + } + // Otherwise just add domains + else { + $sql .= " + UNION ALL + SELECT 'DOMAIN', pt.oid, pn.nspname, NULL, + pt.typname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn + WHERE pt.typnamespace=pn.oid AND pt.typtype='d' AND typname ILIKE '%{$term}%' + AND (pt.typrelid = 0 OR (SELECT c.relkind = 'c' FROM pg_catalog.pg_class c WHERE c.oid = pt.typrelid)) + {$where} + "; + } + + if ($filter != '') { + // We use like to make RULE, CONSTRAINT and COLUMN searches work + $sql .= ") AS sub WHERE type LIKE '{$filter}%' "; + } + + $sql .= "ORDER BY type, schemaname, relname, name"; + + return $this->selectSet($sql); + } + + /** + * Returns table locks information in the current database + * @return A recordset + */ + function getLocks() { + global $conf; + + if (!$conf['show_system']) + $where = "AND pn.nspname NOT LIKE 'pg\\\\_%'"; + else + $where = "AND nspname !~ '^pg_t(emp_[0-9]+|oast)$'"; + + $sql = "SELECT pn.nspname, pc.relname AS tablename, pl.transaction, pl.pid, pl.mode, pl.granted + FROM pg_catalog.pg_locks pl, pg_catalog.pg_class pc, pg_catalog.pg_namespace pn + WHERE pl.relation = pc.oid AND pc.relnamespace=pn.oid {$where} + ORDER BY nspname,tablename"; + + return $this->selectSet($sql); + } + + /** + * Returns the current database encoding + * @return The encoding. eg. SQL_ASCII, UTF-8, etc. + */ + function getDatabaseEncoding() { + $sql = "SELECT getdatabaseencoding() AS encoding"; + + return $this->selectField($sql, 'encoding'); + } + + // Table functions + + /** + * Protected method which alter a table + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $tblrs The table recordSet returned by getTable() + * @param $name The new name for the table + * @param $owner The new owner for the table + * @param $schema The new schema for the table + * @param $comment The comment on the table + * @param $tablespace The new tablespace for the table ('' means leave as is) + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + */ + protected + function _alterTable($tblrs, $name, $owner, $schema, $comment, $tablespace) { + + /* $schema and tablespace not supported in pg74- */ + $this->fieldArrayClean($tblrs->fields); + + // Comment + $status = $this->setComment('TABLE', '', $tblrs->fields['relname'], $comment); + if ($status != 0) return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterTableOwner($tblrs, $owner); + if ($status != 0) return -5; + + // Rename + $this->fieldClean($name); + $status = $this->alterTableName($tblrs, $name); + if ($status != 0) return -3; + + return 0; + } + + /** + * Alters a column in a table OR view + * @param $table The table in which the column resides + * @param $column The column to alter + * @param $name The new name for the column + * @param $notnull (boolean) True if not null, false otherwise + * @param $oldnotnull (boolean) True if column is already not null, false otherwise + * @param $default The new default for the column + * @param $olddefault The old default for the column + * @param $type The new type for the column + * @param $array True if array type, false otherwise + * @param $length The optional size of the column (ie. 30 for varchar(30)) + * @param $oldtype The old type for the column + * @param $comment Comment for the column + * @return 0 success + * @return -2 set not null error + * @return -3 set default error + * @return -4 rename column error + * @return -5 comment error + * @return -6 transaction error + */ + function alterColumn($table, $column, $name, $notnull, $oldnotnull, $default, $olddefault, + $type, $length, $array, $oldtype, $comment) + { + $status = $this->beginTransaction(); + if ($status != 0) return -1; + + // @@ NEED TO HANDLE "NESTED" TRANSACTION HERE + if ($notnull != $oldnotnull) { + $status = $this->setColumnNull($table, $column, !$notnull); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + } + + // Set default, if it has changed + if ($default != $olddefault) { + if ($default == '') + $status = $this->dropColumnDefault($table, $column); + else + $status = $this->setColumnDefault($table, $column, $default); + + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + } + + // Rename the column, if it has been changed + if ($column != $name) { + $status = $this->renameColumn($table, $column, $name); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + } + + // The $name and $table parameters must be cleaned for the setComment function. + // It's ok to do that here since this is the last time these variables are used. + $this->fieldClean($name); + $this->fieldClean($table); + $status = $this->setComment('COLUMN', $name, $table, $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -5; + } + + return $this->endTransaction(); + } + + /** + * Returns table information + * @param $table The name of the table + * @return A recordset + */ + function getTable($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = " + SELECT + c.relname, n.nspname, u.usename AS relowner, + pg_catalog.obj_description(c.oid, 'pg_class') AS relcomment + FROM pg_catalog.pg_class c + LEFT JOIN pg_catalog.pg_user u ON u.usesysid = c.relowner + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace + WHERE c.relkind = 'r' + AND n.nspname = '{$c_schema}' + AND c.relname = '{$table}'"; + + return $this->selectSet($sql); + } + + /** + * Return all tables in current database (and schema) + * @param $all True to fetch all tables, false for just in current schema + * @return All tables, sorted alphabetically + */ + function getTables($all = false) { + $c_schema = $this->_schema; + $this->clean($c_schema); + if ($all) { + // Exclude pg_catalog and information_schema tables + $sql = "SELECT schemaname AS nspname, tablename AS relname, tableowner AS relowner + FROM pg_catalog.pg_tables + WHERE schemaname NOT IN ('pg_catalog', 'information_schema', 'pg_toast') + ORDER BY schemaname, tablename"; + } else { + $sql = "SELECT c.relname, pg_catalog.pg_get_userbyid(c.relowner) AS relowner, + pg_catalog.obj_description(c.oid, 'pg_class') AS relcomment, + reltuples::bigint + FROM pg_catalog.pg_class c + LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace + WHERE c.relkind = 'r' + AND nspname='{$c_schema}' + ORDER BY c.relname"; + } + + return $this->selectSet($sql); + } + + /** + * Returns the current default_with_oids setting + * @return default_with_oids setting + */ + function getDefaultWithOid() { + // 8.0 is the first release to have this setting + // Prior releases don't have this setting... oids always activated + return 'on'; + } + + // Constraint functions + + /** + * Returns a list of all constraints on a table, + * including constraint name, definition, related col and referenced namespace, + * table and col if needed + * @param $table the table where we are looking for fk + * @return a recordset + */ + function getConstraintsWithFields($table) { + + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + // get the max number of col used in a constraint for the table + $sql = "SELECT DISTINCT + max(SUBSTRING(array_dims(c.conkey) FROM '^\\\\[.*:(.*)\\\\]$')) as nb + FROM pg_catalog.pg_constraint AS c + JOIN pg_catalog.pg_class AS r ON (c.conrelid=r.oid) + JOIN pg_catalog.pg_namespace AS ns ON (r.relnamespace=ns.oid) + WHERE + r.relname = '{$table}' AND ns.nspname='{$c_schema}'"; + + $rs = $this->selectSet($sql); + + if ($rs->EOF) $max_col = 0; + else $max_col = $rs->fields['nb']; + + $sql = ' + SELECT + c.oid AS conid, c.contype, c.conname, pg_catalog.pg_get_constraintdef(c.oid, true) AS consrc, + ns1.nspname as p_schema, r1.relname as p_table, ns2.nspname as f_schema, + r2.relname as f_table, f1.attname as p_field, f1.attnum AS p_attnum, f2.attname as f_field, + f2.attnum AS f_attnum, pg_catalog.obj_description(c.oid, \'pg_constraint\') AS constcomment, + c.conrelid, c.confrelid + FROM + pg_catalog.pg_constraint AS c + JOIN pg_catalog.pg_class AS r1 ON (c.conrelid=r1.oid) + JOIN pg_catalog.pg_attribute AS f1 ON (f1.attrelid=r1.oid AND (f1.attnum=c.conkey[1]'; + for ($i = 2; $i <= $rs->fields['nb']; $i++) { + $sql.= " OR f1.attnum=c.conkey[$i]"; + } + $sql.= ')) + JOIN pg_catalog.pg_namespace AS ns1 ON r1.relnamespace=ns1.oid + LEFT JOIN ( + pg_catalog.pg_class AS r2 JOIN pg_catalog.pg_namespace AS ns2 ON (r2.relnamespace=ns2.oid) + ) ON (c.confrelid=r2.oid) + LEFT JOIN pg_catalog.pg_attribute AS f2 ON + (f2.attrelid=r2.oid AND ((c.confkey[1]=f2.attnum AND c.conkey[1]=f1.attnum)'; + for ($i = 2; $i <= $rs->fields['nb']; $i++) + $sql.= " OR (c.confkey[$i]=f2.attnum AND c.conkey[$i]=f1.attnum)"; + + $sql .= sprintf(")) + WHERE + r1.relname = '%s' AND ns1.nspname='%s' + ORDER BY 1", $table, $c_schema); + + return $this->selectSet($sql); + } + + // Sequence functions + + /** + * Returns all sequences in the current database + * @return A recordset + */ + function getSequences($all = false) { + $c_schema = $this->_schema; + $this->clean($c_schema); + if ($all) { + // Exclude pg_catalog and information_schema tables + $sql = "SELECT n.nspname, c.relname AS seqname, u.usename AS seqowner + FROM pg_catalog.pg_class c, pg_catalog.pg_user u, pg_catalog.pg_namespace n + WHERE c.relowner=u.usesysid AND c.relnamespace=n.oid + AND c.relkind = 'S' + AND n.nspname NOT IN ('pg_catalog', 'information_schema', 'pg_toast') + ORDER BY nspname, seqname"; + } else { + $sql = "SELECT c.relname AS seqname, u.usename AS seqowner, pg_catalog.obj_description(c.oid, 'pg_class') AS seqcomment + FROM pg_catalog.pg_class c, pg_catalog.pg_user u, pg_catalog.pg_namespace n + WHERE c.relowner=u.usesysid AND c.relnamespace=n.oid + AND c.relkind = 'S' AND n.nspname='{$c_schema}' ORDER BY seqname"; + } + + return $this->selectSet( $sql ); + } + + // Function functions + + /** + * Returns all details for a particular function + * @param $func The name of the function to retrieve + * @return Function info + */ + function getFunction($function_oid) { + $this->clean($function_oid); + + $sql = " + SELECT + pc.oid AS prooid, + proname, + pg_catalog.pg_get_userbyid(proowner) AS proowner, + nspname as proschema, + lanname as prolanguage, + pg_catalog.format_type(prorettype, NULL) as proresult, + prosrc, + probin, + proretset, + proisstrict, + provolatile, + prosecdef, + pg_catalog.oidvectortypes(pc.proargtypes) AS proarguments, + pg_catalog.obj_description(pc.oid, 'pg_proc') AS procomment + FROM + pg_catalog.pg_proc pc, pg_catalog.pg_language pl, pg_catalog.pg_namespace n + WHERE + pc.oid = '$function_oid'::oid + AND pc.prolang = pl.oid + AND n.oid = pc.pronamespace + "; + + return $this->selectSet($sql); + } + + /** + * Returns a list of all casts in the database + * @return All casts + */ + function getCasts() { + global $conf; + + if ($conf['show_system']) + $where = ''; + else + $where = " + AND n1.nspname NOT LIKE 'pg\\\\_%' + AND n2.nspname NOT LIKE 'pg\\\\_%' + AND n3.nspname NOT LIKE 'pg\\\\_%' + "; + + $sql = " + SELECT + c.castsource::pg_catalog.regtype AS castsource, + c.casttarget::pg_catalog.regtype AS casttarget, + CASE WHEN c.castfunc=0 THEN NULL + ELSE c.castfunc::pg_catalog.regprocedure END AS castfunc, + c.castcontext, + obj_description(c.oid, 'pg_cast') as castcomment + FROM + (pg_catalog.pg_cast c LEFT JOIN pg_catalog.pg_proc p ON c.castfunc=p.oid JOIN pg_catalog.pg_namespace n3 ON p.pronamespace=n3.oid), + pg_catalog.pg_type t1, + pg_catalog.pg_type t2, + pg_catalog.pg_namespace n1, + pg_catalog.pg_namespace n2 + WHERE + c.castsource=t1.oid + AND c.casttarget=t2.oid + AND t1.typnamespace=n1.oid + AND t2.typnamespace=n2.oid + {$where} + ORDER BY 1, 2 + "; + + return $this->selectSet($sql); + } + + // Capabilities + + function hasAlterColumnType() { return false; } + function hasCreateFieldWithConstraints() { return false; } + function hasAlterDatabaseOwner() { return false; } + function hasAlterSchemaOwner() { return false; } + function hasFunctionAlterOwner() { return false; } + function hasNamedParams() { return false; } + function hasQueryCancel() { return false; } + function hasTablespaces() { return false; } + function hasMagicTypes() { return false; } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres80.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres80.php new file mode 100644 index 00000000..1f29c1cf --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres80.php @@ -0,0 +1,354 @@ + 'CP866', + 'EUC_CN' => 'GB2312', + 'EUC_JP' => 'EUC-JP', + 'EUC_KR' => 'EUC-KR', + 'EUC_TW' => 'EUC-TW', + 'ISO_8859_5' => 'ISO-8859-5', + 'ISO_8859_6' => 'ISO-8859-6', + 'ISO_8859_7' => 'ISO-8859-7', + 'ISO_8859_8' => 'ISO-8859-8', + 'JOHAB' => 'CP1361', + 'KOI8' => 'KOI8-R', + 'LATIN1' => 'ISO-8859-1', + 'LATIN2' => 'ISO-8859-2', + 'LATIN3' => 'ISO-8859-3', + 'LATIN4' => 'ISO-8859-4', + // The following encoding map is a known error in PostgreSQL < 7.2 + // See the constructor for Postgres72. + 'LATIN5' => 'ISO-8859-5', + 'LATIN6' => 'ISO-8859-10', + 'LATIN7' => 'ISO-8859-13', + 'LATIN8' => 'ISO-8859-14', + 'LATIN9' => 'ISO-8859-15', + 'LATIN10' => 'ISO-8859-16', + 'SQL_ASCII' => 'US-ASCII', + 'TCVN' => 'CP1258', + 'UNICODE' => 'UTF-8', + 'WIN' => 'CP1251', + 'WIN874' => 'CP874', + 'WIN1256' => 'CP1256' + ); + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres80($conn) { + $this->Postgres81($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc80.php'); + return $this->help_page; + } + + // Database functions + + /** + * Return all database available on the server + * @return A list of databases, sorted alphabetically + */ + function getDatabases($currentdatabase = NULL) { + global $conf, $misc; + + $server_info = $misc->getServerInfo(); + + if (isset($conf['owned_only']) && $conf['owned_only'] && !$this->isSuperUser()) { + $username = $server_info['username']; + $this->clean($username); + $clause = " AND pu.usename='{$username}'"; + } + else $clause = ''; + + if ($currentdatabase != NULL) { + $this->clean($currentdatabase); + $orderby = "ORDER BY pdb.datname = '{$currentdatabase}' DESC, pdb.datname"; + } + else + $orderby = "ORDER BY pdb.datname"; + + if (!$conf['show_system']) + $where = ' AND NOT pdb.datistemplate'; + else + $where = ' AND pdb.datallowconn'; + + $sql = "SELECT pdb.datname AS datname, pu.usename AS datowner, pg_encoding_to_char(encoding) AS datencoding, + (SELECT description FROM pg_description pd WHERE pdb.oid=pd.objoid) AS datcomment, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=pdb.dattablespace) AS tablespace + FROM pg_database pdb, pg_user pu + WHERE pdb.datdba = pu.usesysid + {$where} + {$clause} + {$orderby}"; + + return $this->selectSet($sql); + } + + // Schema functions + + /** + * Return all schemas in the current database. + * @return All schemas, sorted alphabetically + */ + function getSchemas() { + global $conf; + + if (!$conf['show_system']) { + $where = "WHERE nspname NOT LIKE 'pg@_%' ESCAPE '@' AND nspname != 'information_schema'"; + } + else $where = "WHERE nspname !~ '^pg_t(emp_[0-9]+|oast)$'"; + $sql = " + SELECT pn.nspname, pu.usename AS nspowner, + pg_catalog.obj_description(pn.oid, 'pg_namespace') AS nspcomment + FROM pg_catalog.pg_namespace pn + LEFT JOIN pg_catalog.pg_user pu ON (pn.nspowner = pu.usesysid) + {$where} + ORDER BY nspname"; + + return $this->selectSet($sql); + } + + /** + * Return all information relating to a schema + * @param $schema The name of the schema + * @return Schema information + */ + function getSchemaByName($schema) { + $this->clean($schema); + $sql = " + SELECT nspname, nspowner, u.usename AS ownername, nspacl, + pg_catalog.obj_description(pn.oid, 'pg_namespace') as nspcomment + FROM pg_catalog.pg_namespace pn + LEFT JOIN pg_shadow as u ON pn.nspowner = u.usesysid + WHERE nspname='{$schema}'"; + return $this->selectSet($sql); + } + + // Table functions + + /** + * Protected method which alter a table + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $tblrs The table recordSet returned by getTable() + * @param $name The new name for the table + * @param $owner The new owner for the table + * @param $schema The new schema for the table + * @param $comment The comment on the table + * @param $tablespace The new tablespace for the table ('' means leave as is) + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + * @return -6 tablespace error + */ + protected + function _alterTable($tblrs, $name, $owner, $schema, $comment, $tablespace) { + + /* $schema not supported in pg80- */ + + // Comment + $status = $this->setComment('TABLE', '', $tblrs->fields['relname'], $comment); + if ($status != 0) return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterTableOwner($tblrs, $owner); + if ($status != 0) return -5; + + // Tablespace + $this->fieldClean($tablespace); + $status = $this->alterTableTablespace($tblrs, $tablespace); + if ($status != 0) return -6; + + // Rename + $this->fieldClean($name); + $status = $this->alterTableName($tblrs, $name); + if ($status != 0) return -3; + + return 0; + } + + // View functions + + /** + * Protected method which alter a view + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $vwrs The view recordSet returned by getView() + * @param $name The new name for the view + * @param $owner The new owner for the view + * @param $comment The comment on the view + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + */ + protected + function _alterView($vwrs, $name, $owner, $schema, $comment) { + + /* $schema not supported in pg80- */ + $this->fieldArrayClean($vwrs->fields); + + // Comment + if ($this->setComment('VIEW', $vwrs->fields['relname'], '', $comment) != 0) + return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterViewOwner($vwrs, $owner); + if ($status != 0) return -5; + + // Rename + $this->fieldClean($name); + $status = $this->alterViewName($vwrs, $name); + if ($status != 0) return -3; + + return 0; + } + + // Sequence functions + + /** + * Protected method which alter a sequence + * SHOULDN'T BE CALLED OUTSIDE OF A TRANSACTION + * @param $seqrs The sequence recordSet returned by getSequence() + * @param $name The new name for the sequence + * @param $comment The comment on the sequence + * @param $owner The new owner for the sequence + * @param $schema The new schema for the sequence + * @param $increment The increment + * @param $minvalue The min value + * @param $maxvalue The max value + * @param $restartvalue The starting value + * @param $cachevalue The cache value + * @param $cycledvalue True if cycled, false otherwise + * @param $startvalue The sequence start value when issueing a restart + * @return 0 success + * @return -3 rename error + * @return -4 comment error + * @return -5 owner error + * @return -6 get sequence props error + * @return -7 schema error + */ + protected + function _alterSequence($seqrs, $name, $comment, $owner, $schema, $increment, + $minvalue, $maxvalue, $restartvalue, $cachevalue, $cycledvalue, $startvalue) { + + /* $schema not supported in pg80- */ + $this->fieldArrayClean($seqrs->fields); + + // Comment + $status = $this->setComment('SEQUENCE', $seqrs->fields['seqname'], '', $comment); + if ($status != 0) + return -4; + + // Owner + $this->fieldClean($owner); + $status = $this->alterSequenceOwner($seqrs, $owner); + if ($status != 0) + return -5; + + // Props + $this->clean($increment); + $this->clean($minvalue); + $this->clean($maxvalue); + $this->clean($restartvalue); + $this->clean($cachevalue); + $this->clean($cycledvalue); + $this->clean($startvalue); + $status = $this->alterSequenceProps($seqrs, $increment, $minvalue, + $maxvalue, $restartvalue, $cachevalue, $cycledvalue, null); + if ($status != 0) + return -6; + + // Rename + $this->fieldClean($name); + $status = $this->alterSequenceName($seqrs, $name); + if ($status != 0) + return -3; + + return 0; + } + + // Role, User/group functions + + /** + * Changes a user's password + * @param $username The username + * @param $password The new password + * @return 0 success + */ + function changePassword($username, $password) { + $enc = $this->_encryptPassword($username, $password); + $this->fieldClean($username); + $this->clean($enc); + + $sql = "ALTER USER \"{$username}\" WITH ENCRYPTED PASSWORD '{$enc}'"; + + return $this->execute($sql); + } + + // Aggregate functions + + /** + * Gets all information for an aggregate + * @param $name The name of the aggregate + * @param $basetype The input data type of the aggregate + * @return A recordset + */ + function getAggregate($name, $basetype) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($name); + $this->clean($basetype); + + $sql = " + SELECT p.proname, + CASE p.proargtypes[0] + WHEN 'pg_catalog.\"any\"'::pg_catalog.regtype THEN NULL + ELSE pg_catalog.format_type(p.proargtypes[0], NULL) + END AS proargtypes, a.aggtransfn, format_type(a.aggtranstype, NULL) AS aggstype, + a.aggfinalfn, a.agginitval, u.usename, pg_catalog.obj_description(p.oid, 'pg_proc') AS aggrcomment + FROM pg_catalog.pg_proc p, pg_catalog.pg_namespace n, pg_catalog.pg_user u, pg_catalog.pg_aggregate a + WHERE n.oid = p.pronamespace AND p.proowner=u.usesysid AND p.oid=a.aggfnoid + AND p.proisagg AND n.nspname='{$c_schema}' + AND p.proname='{$name}' + AND CASE p.proargtypes[0] + WHEN 'pg_catalog.\"any\"'::pg_catalog.regtype THEN '' + ELSE pg_catalog.format_type(p.proargtypes[0], NULL) + END ='{$basetype}'"; + + return $this->selectSet($sql); + } + + // Capabilities + + function hasAggregateSortOp() { return false; } + function hasAlterTableSchema() { return false; } + function hasAutovacuum() { return false; } + function hasDisableTriggers() { return false; } + function hasFunctionAlterSchema() { return false; } + function hasPreparedXacts() { return false; } + function hasRoles() { return false; } + function hasAlterSequenceSchema() { return false; } + function hasServerAdminFuncs() { return false; } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres81.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres81.php new file mode 100644 index 00000000..70d40b82 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres81.php @@ -0,0 +1,296 @@ + array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'RULE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'view' => array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'RULE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'sequence' => array('SELECT', 'UPDATE', 'ALL PRIVILEGES'), + 'database' => array('CREATE', 'TEMPORARY', 'ALL PRIVILEGES'), + 'function' => array('EXECUTE', 'ALL PRIVILEGES'), + 'language' => array('USAGE', 'ALL PRIVILEGES'), + 'schema' => array('CREATE', 'USAGE', 'ALL PRIVILEGES'), + 'tablespace' => array('CREATE', 'ALL PRIVILEGES') + ); + // List of characters in acl lists and the privileges they + // refer to. + var $privmap = array( + 'r' => 'SELECT', + 'w' => 'UPDATE', + 'a' => 'INSERT', + 'd' => 'DELETE', + 'R' => 'RULE', + 'x' => 'REFERENCES', + 't' => 'TRIGGER', + 'X' => 'EXECUTE', + 'U' => 'USAGE', + 'C' => 'CREATE', + 'T' => 'TEMPORARY' + ); + // Array of allowed index types + var $typIndexes = array('BTREE', 'RTREE', 'GIST', 'HASH'); + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres81($conn) { + $this->Postgres82($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc81.php'); + return $this->help_page; + } + + // Database functions + + /** + * Returns all databases available on the server + * @return A list of databases, sorted alphabetically + */ + function getDatabases($currentdatabase = NULL) { + global $conf, $misc; + + $server_info = $misc->getServerInfo(); + + if (isset($conf['owned_only']) && $conf['owned_only'] && !$this->isSuperUser()) { + $username = $server_info['username']; + $this->clean($username); + $clause = " AND pr.rolname='{$username}'"; + } + else $clause = ''; + + if ($currentdatabase != NULL) { + $this->clean($currentdatabase); + $orderby = "ORDER BY pdb.datname = '{$currentdatabase}' DESC, pdb.datname"; + } + else + $orderby = "ORDER BY pdb.datname"; + + if (!$conf['show_system']) + $where = ' AND NOT pdb.datistemplate'; + else + $where = ' AND pdb.datallowconn'; + + $sql = "SELECT pdb.datname AS datname, pr.rolname AS datowner, pg_encoding_to_char(encoding) AS datencoding, + (SELECT description FROM pg_catalog.pg_description pd WHERE pdb.oid=pd.objoid) AS datcomment, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=pdb.dattablespace) AS tablespace, + pg_catalog.pg_database_size(pdb.oid) as dbsize + FROM pg_catalog.pg_database pdb LEFT JOIN pg_catalog.pg_roles pr ON (pdb.datdba = pr.oid) + WHERE true + {$where} + {$clause} + {$orderby}"; + + return $this->selectSet($sql); + } + + /** + * Alters a database + * the multiple return vals are for postgres 8+ which support more functionality in alter database + * @param $dbName The name of the database + * @param $newName new name for the database + * @param $newOwner The new owner for the database + * @return 0 success + * @return -1 transaction error + * @return -2 owner error + * @return -3 rename error + */ + function alterDatabase($dbName, $newName, $newOwner = '', $comment = '') { + $this->clean($dbName); + $this->clean($newName); + $this->clean($newOwner); + //ignore $comment, not supported pre 8.2 + + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + if ($dbName != $newName) { + $status = $this->alterDatabaseRename($dbName, $newName); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + } + + $status = $this->alterDatabaseOwner($newName, $newOwner); + if ($status != 0) { + $this->rollbackTransaction(); + return -2; + } + return $this->endTransaction(); + } + + // Autovacuum functions + + function saveAutovacuum($table, $vacenabled, $vacthreshold, $vacscalefactor, + $anathresold, $anascalefactor, $vaccostdelay, $vaccostlimit) + { + $defaults = $this->getAutovacuum(); + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $rs = $this->selectSet(" + SELECT c.oid + FROM pg_catalog.pg_class AS c + LEFT JOIN pg_catalog.pg_namespace AS n ON (n.oid=c.relnamespace) + WHERE + c.relname = '{$table}' AND n.nspname = '{$c_schema}' + "); + + if ($rs->EOF) + return -1; + + $toid = $rs->fields('oid'); + unset ($rs); + + if (empty($_POST['autovacuum_vacuum_threshold'])) + $_POST['autovacuum_vacuum_threshold'] = $defaults['autovacuum_vacuum_threshold']; + + if (empty($_POST['autovacuum_vacuum_scale_factor'])) + $_POST['autovacuum_vacuum_scale_factor'] = $defaults['autovacuum_vacuum_scale_factor']; + + if (empty($_POST['autovacuum_analyze_threshold'])) + $_POST['autovacuum_analyze_threshold'] = $defaults['autovacuum_analyze_threshold']; + + if (empty($_POST['autovacuum_analyze_scale_factor'])) + $_POST['autovacuum_analyze_scale_factor'] = $defaults['autovacuum_analyze_scale_factor']; + + if (empty($_POST['autovacuum_vacuum_cost_delay'])) + $_POST['autovacuum_vacuum_cost_delay'] = $defaults['autovacuum_vacuum_cost_delay']; + + if (empty($_POST['autovacuum_vacuum_cost_limit'])) + $_POST['autovacuum_vacuum_cost_limit'] = $defaults['autovacuum_vacuum_cost_limit']; + + $rs = $this->selectSet("SELECT vacrelid + FROM \"pg_catalog\".\"pg_autovacuum\" + WHERE vacrelid = {$toid};"); + + $status = -1; // ini + if ($rs->recordCount() and ($rs->fields['vacrelid'] == $toid)) { + // table exists in pg_autovacuum, UPDATE + $sql = sprintf("UPDATE \"pg_catalog\".\"pg_autovacuum\" SET + enabled = '%s', + vac_base_thresh = %s, + vac_scale_factor = %s, + anl_base_thresh = %s, + anl_scale_factor = %s, + vac_cost_delay = %s, + vac_cost_limit = %s + WHERE vacrelid = {$toid}; + ", + ($_POST['autovacuum_enabled'] == 'on')? 't':'f', + $_POST['autovacuum_vacuum_threshold'], + $_POST['autovacuum_vacuum_scale_factor'], + $_POST['autovacuum_analyze_threshold'], + $_POST['autovacuum_analyze_scale_factor'], + $_POST['autovacuum_vacuum_cost_delay'], + $_POST['autovacuum_vacuum_cost_limit'] + ); + $status = $this->execute($sql); + } + else { + // table doesn't exists in pg_autovacuum, INSERT + $sql = sprintf("INSERT INTO \"pg_catalog\".\"pg_autovacuum\" + VALUES (%s, '%s', %s, %s, %s, %s, %s, %s)", + $toid, + ($_POST['autovacuum_enabled'] == 'on')? 't':'f', + $_POST['autovacuum_vacuum_threshold'], + $_POST['autovacuum_vacuum_scale_factor'], + $_POST['autovacuum_analyze_threshold'], + $_POST['autovacuum_analyze_scale_factor'], + $_POST['autovacuum_vacuum_cost_delay'], + $_POST['autovacuum_vacuum_cost_limit'] + ); + $status = $this->execute($sql); + } + + return $status; + } + + /** + * Returns all available process information. + * @param $database (optional) Find only connections to specified database + * @return A recordset + */ + function getProcesses($database = null) { + if ($database === null) + $sql = "SELECT datname, usename, procpid AS pid, current_query AS query, query_start, + case when (select count(*) from pg_locks where pid=pg_stat_activity.procpid and granted is false) > 0 then 't' else 'f' end as waiting + FROM pg_catalog.pg_stat_activity + ORDER BY datname, usename, procpid"; + else { + $this->clean($database); + $sql = "SELECT datname, usename, procpid AS pid, current_query AS query, query_start + case when (select count(*) from pg_locks where pid=pg_stat_activity.procpid and granted is false) > 0 then 't' else 'f' end as waiting + FROM pg_catalog.pg_stat_activity + WHERE datname='{$database}' + ORDER BY usename, procpid"; + } + + $rc = $this->selectSet($sql); + + return $rc; + } + + // Tablespace functions + + /** + * Retrieves a tablespace's information + * @return A recordset + */ + function getTablespace($spcname) { + $this->clean($spcname); + + $sql = "SELECT spcname, pg_catalog.pg_get_userbyid(spcowner) AS spcowner, spclocation + FROM pg_catalog.pg_tablespace WHERE spcname='{$spcname}'"; + + return $this->selectSet($sql); + } + + /** + * Retrieves information for all tablespaces + * @param $all Include all tablespaces (necessary when moving objects back to the default space) + * @return A recordset + */ + function getTablespaces($all = false) { + global $conf; + + $sql = "SELECT spcname, pg_catalog.pg_get_userbyid(spcowner) AS spcowner, spclocation + FROM pg_catalog.pg_tablespace"; + + if (!$conf['show_system'] && !$all) { + $sql .= ' WHERE spcname NOT LIKE $$pg\_%$$'; + } + + $sql .= " ORDER BY spcname"; + + return $this->selectSet($sql); + } + + // Capabilities + + function hasCreateTableLikeWithConstraints() {return false;} + function hasSharedComments() {return false;} + function hasConcurrentIndexBuild() {return false;} +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres82.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres82.php new file mode 100644 index 00000000..e30cd673 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres82.php @@ -0,0 +1,359 @@ + 'i', '!=' => 'i', '<' => 'i', '>' => 'i', '<=' => 'i', '>=' => 'i', '<<' => 'i', '>>' => 'i', '<<=' => 'i', '>>=' => 'i', + 'LIKE' => 'i', 'NOT LIKE' => 'i', 'ILIKE' => 'i', 'NOT ILIKE' => 'i', 'SIMILAR TO' => 'i', + 'NOT SIMILAR TO' => 'i', '~' => 'i', '!~' => 'i', '~*' => 'i', '!~*' => 'i', + 'IS NULL' => 'p', 'IS NOT NULL' => 'p', 'IN' => 'x', 'NOT IN' => 'x'); + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres82($conn) { + $this->Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc82.php'); + return $this->help_page; + } + + // Database functions + + /** + * Returns table locks information in the current database + * @return A recordset + */ + function getLocks() { + global $conf; + + if (!$conf['show_system']) + $where = 'AND pn.nspname NOT LIKE $$pg\_%$$'; + else + $where = "AND nspname !~ '^pg_t(emp_[0-9]+|oast)$'"; + + $sql = "SELECT pn.nspname, pc.relname AS tablename, pl.transaction, pl.pid, pl.mode, pl.granted + FROM pg_catalog.pg_locks pl, pg_catalog.pg_class pc, pg_catalog.pg_namespace pn + WHERE pl.relation = pc.oid AND pc.relnamespace=pn.oid {$where} + ORDER BY nspname,tablename"; + + return $this->selectSet($sql); + } + + // Sequence functions + + /** + * Rename a sequence + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $name The new name for the sequence + * @return 0 success + */ + function alterSequenceName($seqrs, $name) { + /* vars are cleaned in _alterSequence */ + if (!empty($name) && ($seqrs->fields['seqname'] != $name)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER TABLE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status == 0) + $seqrs->fields['seqname'] = $name; + else + return $status; + } + return 0; + } + + // View functions + + /** + * Rename a view + * @param $vwrs The view recordSet returned by getView() + * @param $name The new view's name + * @return -1 Failed + * @return 0 success + */ + function alterViewName($vwrs, $name) { + // Rename (only if name has changed) + /* $vwrs and $name are cleaned in _alterView */ + if (!empty($name) && ($name != $vwrs->fields['relname'])) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER TABLE \"{$f_schema}\".\"{$vwrs->fields['relname']}\" RENAME TO \"{$name}\""; + $status = $this->execute($sql); + if ($status == 0) + $vwrs->fields['relname'] = $name; + else + return $status; + } + return 0; + } + + // Trigger functions + + /** + * Grabs a list of triggers on a table + * @param $table The name of a table whose triggers to retrieve + * @return A recordset + */ + function getTriggers($table = '') { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT + t.tgname, pg_catalog.pg_get_triggerdef(t.oid) AS tgdef, t.tgenabled, p.oid AS prooid, + p.proname || ' (' || pg_catalog.oidvectortypes(p.proargtypes) || ')' AS proproto, + ns.nspname AS pronamespace + FROM pg_catalog.pg_trigger t, pg_catalog.pg_proc p, pg_catalog.pg_namespace ns + WHERE t.tgrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace=(SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}')) + AND (NOT tgisconstraint OR NOT EXISTS + (SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = t.tableoid AND d.objid = t.oid AND d.deptype = 'i' AND c.contype = 'f')) + AND p.oid=t.tgfoid + AND p.pronamespace = ns.oid"; + + return $this->selectSet($sql); + } + + // Function functions + + /** + * Returns all details for a particular function + * @param $func The name of the function to retrieve + * @return Function info + */ + function getFunction($function_oid) { + $this->clean($function_oid); + + $sql = "SELECT + pc.oid AS prooid, + proname, + pg_catalog.pg_get_userbyid(proowner) AS proowner, + nspname as proschema, + lanname as prolanguage, + pg_catalog.format_type(prorettype, NULL) as proresult, + prosrc, + probin, + proretset, + proisstrict, + provolatile, + prosecdef, + pg_catalog.oidvectortypes(pc.proargtypes) AS proarguments, + proargnames AS proargnames, + pg_catalog.obj_description(pc.oid, 'pg_proc') AS procomment + FROM + pg_catalog.pg_proc pc, pg_catalog.pg_language pl, pg_catalog.pg_namespace pn + WHERE + pc.oid = '{$function_oid}'::oid + AND pc.prolang = pl.oid + AND pc.pronamespace = pn.oid + "; + + return $this->selectSet($sql); + } + + /** + * Creates a new function. + * @param $funcname The name of the function to create + * @param $args A comma separated string of types + * @param $returns The return type + * @param $definition The definition for the new function + * @param $language The language the function is written for + * @param $flags An array of optional flags + * @param $setof True if it returns a set, false otherwise + * @param $rows number of rows planner should estimate will be returned + * @param $cost cost the planner should use in the function execution step + * @param $comment The comment on the function + * @param $replace (optional) True if OR REPLACE, false for normal + * @return 0 success + * @return -1 create function failed + * @return -4 set comment failed + */ + function createFunction($funcname, $args, $returns, $definition, $language, $flags, $setof, $cost, $rows, $comment, $replace = false) { + + // Begin a transaction + $status = $this->beginTransaction(); + if ($status != 0) { + $this->rollbackTransaction(); + return -1; + } + + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($funcname); + $this->clean($args); + $this->fieldClean($language); + $this->arrayClean($flags); + + $sql = "CREATE"; + if ($replace) $sql .= " OR REPLACE"; + $sql .= " FUNCTION \"{$f_schema}\".\"{$funcname}\" ("; + + if ($args != '') + $sql .= $args; + + // For some reason, the returns field cannot have quotes... + $sql .= ") RETURNS "; + if ($setof) $sql .= "SETOF "; + $sql .= "{$returns} AS "; + + if (is_array($definition)) { + $this->arrayClean($definition); + $sql .= "'" . $definition[0] . "'"; + if ($definition[1]) { + $sql .= ",'" . $definition[1] . "'"; + } + } else { + $this->clean($definition); + $sql .= "'" . $definition . "'"; + } + + $sql .= " LANGUAGE \"{$language}\""; + + // Add flags + foreach ($flags as $v) { + // Skip default flags + if ($v == '') continue; + else $sql .= "\n{$v}"; + } + + $status = $this->execute($sql); + if ($status != 0) { + $this->rollbackTransaction(); + return -3; + } + + /* set the comment */ + $status = $this->setComment('FUNCTION', "\"{$funcname}\"({$args})", null, $comment); + if ($status != 0) { + $this->rollbackTransaction(); + return -4; + } + + return $this->endTransaction(); + } + + // Index functions + + /** + * Clusters an index + * @param $index The name of the index + * @param $table The table the index is on + * @return 0 success + */ + function clusterIndex($table='', $index='') { + + $sql = 'CLUSTER'; + + // We don't bother with a transaction here, as there's no point rolling + // back an expensive cluster if a cheap analyze fails for whatever reason + + if (!empty($table)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $this->fieldClean($table); + + if (!empty($index)) { + $this->fieldClean($index); + $sql .= " \"{$index}\" ON \"{$f_schema}\".\"{$table}\""; + } + else { + $sql .= " \"{$f_schema}\".\"{$table}\""; + } + } + + return $this->execute($sql); + } + + // Operator functions + + /** + * Returns all details for a particular operator + * @param $operator_oid The oid of the operator + * @return Function info + */ + function getOperator($operator_oid) { + $this->clean($operator_oid); + + $sql = " + SELECT + po.oid, po.oprname, + oprleft::pg_catalog.regtype AS oprleftname, + oprright::pg_catalog.regtype AS oprrightname, + oprresult::pg_catalog.regtype AS resultname, + po.oprcanhash, + oprcom::pg_catalog.regoperator AS oprcom, + oprnegate::pg_catalog.regoperator AS oprnegate, + oprlsortop::pg_catalog.regoperator AS oprlsortop, + oprrsortop::pg_catalog.regoperator AS oprrsortop, + oprltcmpop::pg_catalog.regoperator AS oprltcmpop, + oprgtcmpop::pg_catalog.regoperator AS oprgtcmpop, + po.oprcode::pg_catalog.regproc AS oprcode, + po.oprrest::pg_catalog.regproc AS oprrest, + po.oprjoin::pg_catalog.regproc AS oprjoin + FROM + pg_catalog.pg_operator po + WHERE + po.oid='{$operator_oid}' + "; + + return $this->selectSet($sql); + } + + // Operator Class functions + + /** + * Gets all opclasses + * @return A recordset + */ + function getOpClasses() { + $c_schema = $this->_schema; + $this->clean($c_schema); + $sql = " + SELECT + pa.amname, + po.opcname, + po.opcintype::pg_catalog.regtype AS opcintype, + po.opcdefault, + pg_catalog.obj_description(po.oid, 'pg_opclass') AS opccomment + FROM + pg_catalog.pg_opclass po, pg_catalog.pg_am pa, pg_catalog.pg_namespace pn + WHERE + po.opcamid=pa.oid + AND po.opcnamespace=pn.oid + AND pn.nspname='{$c_schema}' + ORDER BY 1,2 + "; + + return $this->selectSet($sql); + } + + // Capabilities + + function hasCreateTableLikeWithIndexes() {return false;} + function hasEnumTypes() {return false;} + function hasFTS() {return false;} + function hasFunctionCosting() {return false;} + function hasFunctionGUC() {return false;} + function hasVirtualTransactionId() {return false;} + +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres83.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres83.php new file mode 100644 index 00000000..ce0416b9 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres83.php @@ -0,0 +1,363 @@ + array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'view' => array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'sequence' => array('SELECT', 'UPDATE', 'ALL PRIVILEGES'), + 'database' => array('CREATE', 'TEMPORARY', 'CONNECT', 'ALL PRIVILEGES'), + 'function' => array('EXECUTE', 'ALL PRIVILEGES'), + 'language' => array('USAGE', 'ALL PRIVILEGES'), + 'schema' => array('CREATE', 'USAGE', 'ALL PRIVILEGES'), + 'tablespace' => array('CREATE', 'ALL PRIVILEGES') + ); + // List of characters in acl lists and the privileges they + // refer to. + var $privmap = array( + 'r' => 'SELECT', + 'w' => 'UPDATE', + 'a' => 'INSERT', + 'd' => 'DELETE', + 'R' => 'RULE', + 'x' => 'REFERENCES', + 't' => 'TRIGGER', + 'X' => 'EXECUTE', + 'U' => 'USAGE', + 'C' => 'CREATE', + 'T' => 'TEMPORARY', + 'c' => 'CONNECT' + ); + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres83($conn) { + $this->Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc83.php'); + return $this->help_page; + } + + // Databse functions + + /** + * Return all database available on the server + * @param $currentdatabase database name that should be on top of the resultset + * + * @return A list of databases, sorted alphabetically + */ + function getDatabases($currentdatabase = NULL) { + global $conf, $misc; + + $server_info = $misc->getServerInfo(); + + if (isset($conf['owned_only']) && $conf['owned_only'] && !$this->isSuperUser()) { + $username = $server_info['username']; + $this->clean($username); + $clause = " AND pr.rolname='{$username}'"; + } + else $clause = ''; + + if ($currentdatabase != NULL) { + $this->clean($currentdatabase); + $orderby = "ORDER BY pdb.datname = '{$currentdatabase}' DESC, pdb.datname"; + } + else + $orderby = "ORDER BY pdb.datname"; + + if (!$conf['show_system']) + $where = ' AND NOT pdb.datistemplate'; + else + $where = ' AND pdb.datallowconn'; + + $sql = " + SELECT pdb.datname AS datname, pr.rolname AS datowner, pg_encoding_to_char(encoding) AS datencoding, + (SELECT description FROM pg_catalog.pg_shdescription pd WHERE pdb.oid=pd.objoid AND pd.classoid='pg_database'::regclass) AS datcomment, + (SELECT spcname FROM pg_catalog.pg_tablespace pt WHERE pt.oid=pdb.dattablespace) AS tablespace, + pg_catalog.pg_database_size(pdb.oid) as dbsize + FROM pg_catalog.pg_database pdb LEFT JOIN pg_catalog.pg_roles pr ON (pdb.datdba = pr.oid) + WHERE true + {$where} + {$clause} + {$orderby}"; + + return $this->selectSet($sql); + } + + // Administration functions + + /** + * Returns all available autovacuum per table information. + * @return A recordset + */ + function getTableAutovacuum($table='') { + $sql = ''; + + if ($table !== '') { + $this->clean($table); + $c_schema = $this->_schema; + $this->clean($c_schema); + + $sql = " + SELECT vacrelid, nspname, relname, + CASE enabled + WHEN 't' THEN 'on' + ELSE 'off' + END AS autovacuum_enabled, vac_base_thresh AS autovacuum_vacuum_threshold, + vac_scale_factor AS autovacuum_vacuum_scale_factor, anl_base_thresh AS autovacuum_analyze_threshold, + anl_scale_factor AS autovacuum_analyze_scale_factor, vac_cost_delay AS autovacuum_vacuum_cost_delay, + vac_cost_limit AS autovacuum_vacuum_cost_limit + FROM pg_autovacuum AS a + join pg_class AS c on (c.oid=a.vacrelid) + join pg_namespace AS n on (n.oid=c.relnamespace) + WHERE c.relname = '{$table}' AND n.nspname = '{$c_schema}' + ORDER BY nspname, relname + "; + } + else { + $sql = " + SELECT vacrelid, nspname, relname, + CASE enabled + WHEN 't' THEN 'on' + ELSE 'off' + END AS autovacuum_enabled, vac_base_thresh AS autovacuum_vacuum_threshold, + vac_scale_factor AS autovacuum_vacuum_scale_factor, anl_base_thresh AS autovacuum_analyze_threshold, + anl_scale_factor AS autovacuum_analyze_scale_factor, vac_cost_delay AS autovacuum_vacuum_cost_delay, + vac_cost_limit AS autovacuum_vacuum_cost_limit + FROM pg_autovacuum AS a + join pg_class AS c on (c.oid=a.vacrelid) + join pg_namespace AS n on (n.oid=c.relnamespace) + ORDER BY nspname, relname + "; + } + + return $this->selectSet($sql); + } + + function saveAutovacuum($table, $vacenabled, $vacthreshold, $vacscalefactor, $anathresold, + $anascalefactor, $vaccostdelay, $vaccostlimit) + { + $defaults = $this->getAutovacuum(); + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $rs = $this->selectSet(" + SELECT c.oid + FROM pg_catalog.pg_class AS c + LEFT JOIN pg_catalog.pg_namespace AS n ON (n.oid=c.relnamespace) + WHERE + c.relname = '{$table}' AND n.nspname = '{$c_schema}' + "); + + if ($rs->EOF) + return -1; + + $toid = $rs->fields('oid'); + unset ($rs); + + if (empty($_POST['autovacuum_vacuum_threshold'])) + $_POST['autovacuum_vacuum_threshold'] = $defaults['autovacuum_vacuum_threshold']; + + if (empty($_POST['autovacuum_vacuum_scale_factor'])) + $_POST['autovacuum_vacuum_scale_factor'] = $defaults['autovacuum_vacuum_scale_factor']; + + if (empty($_POST['autovacuum_analyze_threshold'])) + $_POST['autovacuum_analyze_threshold'] = $defaults['autovacuum_analyze_threshold']; + + if (empty($_POST['autovacuum_analyze_scale_factor'])) + $_POST['autovacuum_analyze_scale_factor'] = $defaults['autovacuum_analyze_scale_factor']; + + if (empty($_POST['autovacuum_vacuum_cost_delay'])) + $_POST['autovacuum_vacuum_cost_delay'] = $defaults['autovacuum_vacuum_cost_delay']; + + if (empty($_POST['autovacuum_vacuum_cost_limit'])) + $_POST['autovacuum_vacuum_cost_limit'] = $defaults['autovacuum_vacuum_cost_limit']; + + if (empty($_POST['vacuum_freeze_min_age'])) + $_POST['vacuum_freeze_min_age'] = $defaults['vacuum_freeze_min_age']; + + if (empty($_POST['autovacuum_freeze_max_age'])) + $_POST['autovacuum_freeze_max_age'] = $defaults['autovacuum_freeze_max_age']; + + + $rs = $this->selectSet("SELECT vacrelid + FROM \"pg_catalog\".\"pg_autovacuum\" + WHERE vacrelid = {$toid};"); + + $status = -1; // ini + if ($rs->recordCount() and ($rs->fields['vacrelid'] == $toid)) { + // table exists in pg_autovacuum, UPDATE + $sql = sprintf("UPDATE \"pg_catalog\".\"pg_autovacuum\" SET + enabled = '%s', + vac_base_thresh = %s, + vac_scale_factor = %s, + anl_base_thresh = %s, + anl_scale_factor = %s, + vac_cost_delay = %s, + vac_cost_limit = %s, + freeze_min_age = %s, + freeze_max_age = %s + WHERE vacrelid = {$toid}; + ", + ($_POST['autovacuum_enabled'] == 'on')? 't':'f', + $_POST['autovacuum_vacuum_threshold'], + $_POST['autovacuum_vacuum_scale_factor'], + $_POST['autovacuum_analyze_threshold'], + $_POST['autovacuum_analyze_scale_factor'], + $_POST['autovacuum_vacuum_cost_delay'], + $_POST['autovacuum_vacuum_cost_limit'], + $_POST['vacuum_freeze_min_age'], + $_POST['autovacuum_freeze_max_age'] + ); + $status = $this->execute($sql); + } + else { + // table doesn't exists in pg_autovacuum, INSERT + $sql = sprintf("INSERT INTO \"pg_catalog\".\"pg_autovacuum\" + VALUES (%s, '%s', %s, %s, %s, %s, %s, %s, %s, %s )", + $toid, + ($_POST['autovacuum_enabled'] == 'on')? 't':'f', + $_POST['autovacuum_vacuum_threshold'], + $_POST['autovacuum_vacuum_scale_factor'], + $_POST['autovacuum_analyze_threshold'], + $_POST['autovacuum_analyze_scale_factor'], + $_POST['autovacuum_vacuum_cost_delay'], + $_POST['autovacuum_vacuum_cost_limit'], + $_POST['vacuum_freeze_min_age'], + $_POST['autovacuum_freeze_max_age'] + ); + $status = $this->execute($sql); + } + + return $status; + } + + function dropAutovacuum($table) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $rs = $this->selectSet(" + SELECT c.oid + FROM pg_catalog.pg_class AS c + LEFT JOIN pg_catalog.pg_namespace AS n ON (n.oid=c.relnamespace) + WHERE + c.relname = '{$table}' AND n.nspname = '{$c_schema}' + "); + + return $this->deleteRow('pg_autovacuum', array('vacrelid' => $rs->fields['oid']), 'pg_catalog'); + } + + // Sequence functions + + /** + * Alter a sequence's properties + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $increment The sequence incremental value + * @param $minvalue The sequence minimum value + * @param $maxvalue The sequence maximum value + * @param $restartvalue The sequence current value + * @param $cachevalue The sequence cache value + * @param $cycledvalue Sequence can cycle ? + * @param $startvalue The sequence start value when issueing a restart (ignored) + * @return 0 success + */ + function alterSequenceProps($seqrs, $increment, $minvalue, $maxvalue, + $restartvalue, $cachevalue, $cycledvalue, $startvalue) { + + $sql = ''; + /* vars are cleaned in _alterSequence */ + if (!empty($increment) && ($increment != $seqrs->fields['increment_by'])) $sql .= " INCREMENT {$increment}"; + if (!empty($minvalue) && ($minvalue != $seqrs->fields['min_value'])) $sql .= " MINVALUE {$minvalue}"; + if (!empty($maxvalue) && ($maxvalue != $seqrs->fields['max_value'])) $sql .= " MAXVALUE {$maxvalue}"; + if (!empty($restartvalue) && ($restartvalue != $seqrs->fields['last_value'])) $sql .= " RESTART {$restartvalue}"; + if (!empty($cachevalue) && ($cachevalue != $seqrs->fields['cache_value'])) $sql .= " CACHE {$cachevalue}"; + // toggle cycle yes/no + if (!is_null($cycledvalue)) $sql .= (!$cycledvalue ? ' NO ' : '') . " CYCLE"; + if ($sql != '') { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER SEQUENCE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" {$sql}"; + return $this->execute($sql); + } + return 0; + } + + /** + * Alter a sequence's owner + * @param $seqrs The sequence RecordSet returned by getSequence() + * @param $name The new owner for the sequence + * @return 0 success + */ + function alterSequenceOwner($seqrs, $owner) { + // If owner has been changed, then do the alteration. We are + // careful to avoid this generally as changing owner is a + // superuser only function. + /* vars are cleaned in _alterSequence */ + if (!empty($owner) && ($seqrs->fields['seqowner'] != $owner)) { + $f_schema = $this->_schema; + $this->fieldClean($f_schema); + $sql = "ALTER TABLE \"{$f_schema}\".\"{$seqrs->fields['seqname']}\" OWNER TO \"{$owner}\""; + return $this->execute($sql); + } + return 0; + } + + // Function functions + + /** + * Returns all details for a particular function + * @param $func The name of the function to retrieve + * @return Function info + */ + function getFunction($function_oid) { + $this->clean($function_oid); + + $sql = " + SELECT + pc.oid AS prooid, proname, pg_catalog.pg_get_userbyid(proowner) AS proowner, + nspname as proschema, lanname as prolanguage, procost, prorows, + pg_catalog.format_type(prorettype, NULL) as proresult, prosrc, + probin, proretset, proisstrict, provolatile, prosecdef, + pg_catalog.oidvectortypes(pc.proargtypes) AS proarguments, + proargnames AS proargnames, + pg_catalog.obj_description(pc.oid, 'pg_proc') AS procomment, + proconfig + FROM + pg_catalog.pg_proc pc, pg_catalog.pg_language pl, + pg_catalog.pg_namespace pn + WHERE + pc.oid = '{$function_oid}'::oid AND pc.prolang = pl.oid + AND pc.pronamespace = pn.oid + "; + + return $this->selectSet($sql); + } + + + // Capabilities + function hasQueryKill() { return false; } + function hasDatabaseCollation() { return false; } + function hasAlterSequenceStart() { return false; } +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres84.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres84.php new file mode 100644 index 00000000..bc2b2b34 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres84.php @@ -0,0 +1,231 @@ + array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'view' => array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'REFERENCES', 'TRIGGER', 'ALL PRIVILEGES'), + 'sequence' => array('SELECT', 'UPDATE', 'ALL PRIVILEGES'), + 'database' => array('CREATE', 'TEMPORARY', 'CONNECT', 'ALL PRIVILEGES'), + 'function' => array('EXECUTE', 'ALL PRIVILEGES'), + 'language' => array('USAGE', 'ALL PRIVILEGES'), + 'schema' => array('CREATE', 'USAGE', 'ALL PRIVILEGES'), + 'tablespace' => array('CREATE', 'ALL PRIVILEGES'), + 'column' => array('SELECT', 'INSERT', 'UPDATE', 'REFERENCES','ALL PRIVILEGES') + ); + + /** + * Constructor + * @param $conn The database connection + */ + function Postgres84($conn) { + $this->Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc84.php'); + return $this->help_page; + } + + // Database functions + + /** + * Grabs a list of triggers on a table + * @param $table The name of a table whose triggers to retrieve + * @return A recordset + */ + function getTriggers($table = '') { + $c_schema = $this->_schema; + $this->clean($c_schema); + $this->clean($table); + + $sql = "SELECT + t.tgname, pg_catalog.pg_get_triggerdef(t.oid) AS tgdef, + CASE WHEN t.tgenabled = 'D' THEN FALSE ELSE TRUE END AS tgenabled, p.oid AS prooid, + p.proname || ' (' || pg_catalog.oidvectortypes(p.proargtypes) || ')' AS proproto, + ns.nspname AS pronamespace + FROM pg_catalog.pg_trigger t, pg_catalog.pg_proc p, pg_catalog.pg_namespace ns + WHERE t.tgrelid = (SELECT oid FROM pg_catalog.pg_class WHERE relname='{$table}' + AND relnamespace=(SELECT oid FROM pg_catalog.pg_namespace WHERE nspname='{$c_schema}')) + AND (NOT tgisconstraint OR NOT EXISTS + (SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = t.tableoid AND d.objid = t.oid AND d.deptype = 'i' AND c.contype = 'f')) + AND p.oid=t.tgfoid + AND p.pronamespace = ns.oid"; + + return $this->selectSet($sql); + } + + /** + * Searches all system catalogs to find objects that match a certain name. + * @param $term The search term + * @param $filter The object type to restrict to ('' means no restriction) + * @return A recordset + */ + function findObject($term, $filter) { + global $conf; + + /*about escaping: + * SET standard_conforming_string is not available before 8.2 + * So we must use PostgreSQL specific notation :/ + * E'' notation is not available before 8.1 + * $$ is available since 8.0 + * Nothing specific from 7.4 + **/ + + // Escape search term for ILIKE match + $this->clean($term); + $this->clean($filter); + $term = str_replace('_', '\_', $term); + $term = str_replace('%', '\%', $term); + + // Exclude system relations if necessary + if (!$conf['show_system']) { + // XXX: The mention of information_schema here is in the wrong place, but + // it's the quickest fix to exclude the info schema from 7.4 + $where = " AND pn.nspname NOT LIKE \$_PATERN_\$pg\_%\$_PATERN_\$ AND pn.nspname != 'information_schema'"; + $lan_where = "AND pl.lanispl"; + } + else { + $where = ''; + $lan_where = ''; + } + + // Apply outer filter + $sql = ''; + if ($filter != '') { + $sql = "SELECT * FROM ("; + } + + $term = "\$_PATERN_\$%{$term}%\$_PATERN_\$"; + + $sql .= " + SELECT 'SCHEMA' AS type, oid, NULL AS schemaname, NULL AS relname, nspname AS name + FROM pg_catalog.pg_namespace pn WHERE nspname ILIKE {$term} {$where} + UNION ALL + SELECT CASE WHEN relkind='r' THEN 'TABLE' WHEN relkind='v' THEN 'VIEW' WHEN relkind='S' THEN 'SEQUENCE' END, pc.oid, + pn.nspname, NULL, pc.relname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn + WHERE pc.relnamespace=pn.oid AND relkind IN ('r', 'v', 'S') AND relname ILIKE {$term} {$where} + UNION ALL + SELECT CASE WHEN pc.relkind='r' THEN 'COLUMNTABLE' ELSE 'COLUMNVIEW' END, NULL, pn.nspname, pc.relname, pa.attname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_attribute pa WHERE pc.relnamespace=pn.oid AND pc.oid=pa.attrelid + AND pa.attname ILIKE {$term} AND pa.attnum > 0 AND NOT pa.attisdropped AND pc.relkind IN ('r', 'v') {$where} + UNION ALL + SELECT 'FUNCTION', pp.oid, pn.nspname, NULL, pp.proname || '(' || pg_catalog.oidvectortypes(pp.proargtypes) || ')' FROM pg_catalog.pg_proc pp, pg_catalog.pg_namespace pn + WHERE pp.pronamespace=pn.oid AND NOT pp.proisagg AND pp.proname ILIKE {$term} {$where} + UNION ALL + SELECT 'INDEX', NULL, pn.nspname, pc.relname, pc2.relname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_index pi, pg_catalog.pg_class pc2 WHERE pc.relnamespace=pn.oid AND pc.oid=pi.indrelid + AND pi.indexrelid=pc2.oid + AND NOT EXISTS ( + SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pc2.tableoid AND d.objid = pc2.oid AND d.deptype = 'i' AND c.contype IN ('u', 'p') + ) + AND pc2.relname ILIKE {$term} {$where} + UNION ALL + SELECT 'CONSTRAINTTABLE', NULL, pn.nspname, pc.relname, pc2.conname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_constraint pc2 WHERE pc.relnamespace=pn.oid AND pc.oid=pc2.conrelid AND pc2.conrelid != 0 + AND CASE WHEN pc2.contype IN ('f', 'c') THEN TRUE ELSE NOT EXISTS ( + SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pc2.tableoid AND d.objid = pc2.oid AND d.deptype = 'i' AND c.contype IN ('u', 'p') + ) END + AND pc2.conname ILIKE {$term} {$where} + UNION ALL + SELECT 'CONSTRAINTDOMAIN', pt.oid, pn.nspname, pt.typname, pc.conname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn, + pg_catalog.pg_constraint pc WHERE pt.typnamespace=pn.oid AND pt.oid=pc.contypid AND pc.contypid != 0 + AND pc.conname ILIKE {$term} {$where} + UNION ALL + SELECT 'TRIGGER', NULL, pn.nspname, pc.relname, pt.tgname FROM pg_catalog.pg_class pc, pg_catalog.pg_namespace pn, + pg_catalog.pg_trigger pt WHERE pc.relnamespace=pn.oid AND pc.oid=pt.tgrelid + AND ( NOT pt.tgisconstraint OR NOT EXISTS + (SELECT 1 FROM pg_catalog.pg_depend d JOIN pg_catalog.pg_constraint c + ON (d.refclassid = c.tableoid AND d.refobjid = c.oid) + WHERE d.classid = pt.tableoid AND d.objid = pt.oid AND d.deptype = 'i' AND c.contype = 'f')) + AND pt.tgname ILIKE {$term} {$where} + UNION ALL + SELECT 'RULETABLE', NULL, pn.nspname AS schemaname, c.relname AS tablename, r.rulename FROM pg_catalog.pg_rewrite r + JOIN pg_catalog.pg_class c ON c.oid = r.ev_class + LEFT JOIN pg_catalog.pg_namespace pn ON pn.oid = c.relnamespace + WHERE c.relkind='r' AND r.rulename != '_RETURN' AND r.rulename ILIKE {$term} {$where} + UNION ALL + SELECT 'RULEVIEW', NULL, pn.nspname AS schemaname, c.relname AS tablename, r.rulename FROM pg_catalog.pg_rewrite r + JOIN pg_catalog.pg_class c ON c.oid = r.ev_class + LEFT JOIN pg_catalog.pg_namespace pn ON pn.oid = c.relnamespace + WHERE c.relkind='v' AND r.rulename != '_RETURN' AND r.rulename ILIKE {$term} {$where} + "; + + // Add advanced objects if show_advanced is set + if ($conf['show_advanced']) { + $sql .= " + UNION ALL + SELECT CASE WHEN pt.typtype='d' THEN 'DOMAIN' ELSE 'TYPE' END, pt.oid, pn.nspname, NULL, + pt.typname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn + WHERE pt.typnamespace=pn.oid AND typname ILIKE {$term} + AND (pt.typrelid = 0 OR (SELECT c.relkind = 'c' FROM pg_catalog.pg_class c WHERE c.oid = pt.typrelid)) + {$where} + UNION ALL + SELECT 'OPERATOR', po.oid, pn.nspname, NULL, po.oprname FROM pg_catalog.pg_operator po, pg_catalog.pg_namespace pn + WHERE po.oprnamespace=pn.oid AND oprname ILIKE {$term} {$where} + UNION ALL + SELECT 'CONVERSION', pc.oid, pn.nspname, NULL, pc.conname FROM pg_catalog.pg_conversion pc, + pg_catalog.pg_namespace pn WHERE pc.connamespace=pn.oid AND conname ILIKE {$term} {$where} + UNION ALL + SELECT 'LANGUAGE', pl.oid, NULL, NULL, pl.lanname FROM pg_catalog.pg_language pl + WHERE lanname ILIKE {$term} {$lan_where} + UNION ALL + SELECT DISTINCT ON (p.proname) 'AGGREGATE', p.oid, pn.nspname, NULL, p.proname FROM pg_catalog.pg_proc p + LEFT JOIN pg_catalog.pg_namespace pn ON p.pronamespace=pn.oid + WHERE p.proisagg AND p.proname ILIKE {$term} {$where} + UNION ALL + SELECT DISTINCT ON (po.opcname) 'OPCLASS', po.oid, pn.nspname, NULL, po.opcname FROM pg_catalog.pg_opclass po, + pg_catalog.pg_namespace pn WHERE po.opcnamespace=pn.oid + AND po.opcname ILIKE {$term} {$where} + "; + } + // Otherwise just add domains + else { + $sql .= " + UNION ALL + SELECT 'DOMAIN', pt.oid, pn.nspname, NULL, + pt.typname FROM pg_catalog.pg_type pt, pg_catalog.pg_namespace pn + WHERE pt.typnamespace=pn.oid AND pt.typtype='d' AND typname ILIKE {$term} + AND (pt.typrelid = 0 OR (SELECT c.relkind = 'c' FROM pg_catalog.pg_class c WHERE c.oid = pt.typrelid)) + {$where} + "; + } + + if ($filter != '') { + // We use like to make RULE, CONSTRAINT and COLUMN searches work + $sql .= ") AS sub WHERE type LIKE '{$filter}%' "; + } + + $sql .= "ORDER BY type, schemaname, relname, name"; + + return $this->selectSet($sql); + } + + + // Capabilities + + function hasByteaHexDefault() { return false; } + +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres90.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres90.php new file mode 100644 index 00000000..9f7b3a09 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres90.php @@ -0,0 +1,33 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc90.php'); + return $this->help_page; + } + + // Capabilities + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres91.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres91.php new file mode 100644 index 00000000..fb6d952c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres91.php @@ -0,0 +1,98 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc91.php'); + return $this->help_page; + } + + // Administration functions + /** + * Returns all available process information. + * @param $database (optional) Find only connections to specified database + * @return A recordset + */ + function getProcesses($database = null) { + if ($database === null) + $sql = "SELECT datname, usename, procpid AS pid, waiting, current_query AS query, query_start + FROM pg_catalog.pg_stat_activity + ORDER BY datname, usename, procpid"; + else { + $this->clean($database); + $sql = "SELECT datname, usename, procpid AS pid, waiting, current_query AS query, query_start + FROM pg_catalog.pg_stat_activity + WHERE datname='{$database}' + ORDER BY usename, procpid"; + } + + $rc = $this->selectSet($sql); + + return $rc; + } + + // Tablespace functions + + /** + * Retrieves information for all tablespaces + * @param $all Include all tablespaces (necessary when moving objects back to the default space) + * @return A recordset + */ + function getTablespaces($all = false) { + global $conf; + + $sql = "SELECT spcname, pg_catalog.pg_get_userbyid(spcowner) AS spcowner, spclocation, + (SELECT description FROM pg_catalog.pg_shdescription pd WHERE pg_tablespace.oid=pd.objoid AND pd.classoid='pg_tablespace'::regclass) AS spccomment + FROM pg_catalog.pg_tablespace"; + + if (!$conf['show_system'] && !$all) { + $sql .= ' WHERE spcname NOT LIKE $$pg\_%$$'; + } + + $sql .= " ORDER BY spcname"; + + return $this->selectSet($sql); + } + + /** + * Retrieves a tablespace's information + * @return A recordset + */ + function getTablespace($spcname) { + $this->clean($spcname); + + $sql = "SELECT spcname, pg_catalog.pg_get_userbyid(spcowner) AS spcowner, spclocation, + (SELECT description FROM pg_catalog.pg_shdescription pd WHERE pg_tablespace.oid=pd.objoid AND pd.classoid='pg_tablespace'::regclass) AS spccomment + FROM pg_catalog.pg_tablespace WHERE spcname='{$spcname}'"; + + return $this->selectSet($sql); + } + + + // Capabilities + function hasUserSignals() { return false; } + + + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres92.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres92.php new file mode 100644 index 00000000..d20b188a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres92.php @@ -0,0 +1,30 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc92.php'); + return $this->help_page; + } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres93.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres93.php new file mode 100644 index 00000000..24ee22d6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres93.php @@ -0,0 +1,30 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc93.php'); + return $this->help_page; + } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres94.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres94.php new file mode 100644 index 00000000..619b238b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres94.php @@ -0,0 +1,30 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc94.php'); + return $this->help_page; + } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres95.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres95.php new file mode 100644 index 00000000..0120e550 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres95.php @@ -0,0 +1,55 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc95.php'); + return $this->help_page; + } + + + /** + * Returns all available process information. + * @param $database (optional) Find only connections to specified database + * @return A recordset + */ + function getProcesses($database = null) { + if ($database === null) + $sql = "SELECT datname, usename, pid, waiting, state_change as query_start, + case when state='idle in transaction' then ' in transaction' when state = 'idle' then '' else query end as query + FROM pg_catalog.pg_stat_activity + ORDER BY datname, usename, pid"; + else { + $this->clean($database); + $sql = "SELECT datname, usename, pid, waiting, state_change as query_start, + case when state='idle in transaction' then ' in transaction' when state = 'idle' then '' else query end as query + FROM pg_catalog.pg_stat_activity + WHERE datname='{$database}' + ORDER BY usename, pid"; + } + + return $this->selectSet($sql); + } + + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres96.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres96.php new file mode 100644 index 00000000..19397e15 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/classes/database/Postgres96.php @@ -0,0 +1,57 @@ +Postgres($conn); + } + + // Help functions + + function getHelpPages() { + include_once('./help/PostgresDoc96.php'); + return $this->help_page; + } + + // Sequence functions + + /** + * Returns properties of a single sequence + * @param $sequence Sequence name + * @return A recordset + */ + function getSequence($sequence) { + $c_schema = $this->_schema; + $this->clean($c_schema); + $c_sequence = $sequence; + $this->fieldClean($sequence); + $this->clean($c_sequence); + + $sql = " + SELECT c.relname AS seqname, s.*, + pg_catalog.obj_description(s.tableoid, 'pg_class') AS seqcomment, + u.usename AS seqowner, n.nspname + FROM \"{$sequence}\" AS s, pg_catalog.pg_class c, pg_catalog.pg_user u, pg_catalog.pg_namespace n + WHERE c.relowner=u.usesysid AND c.relnamespace=n.oid + AND c.relname = '{$c_sequence}' AND c.relkind = 'S' AND n.nspname='{$c_schema}' + AND n.oid = c.relnamespace"; + + return $this->selectSet( $sql ); + } + + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/colproperties.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/colproperties.php new file mode 100644 index 00000000..2bf137b8 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/colproperties.php @@ -0,0 +1,346 @@ +printTrail('column'); + $misc->printTitle($lang['stralter'], 'pg.column.alter'); + $misc->printMsg($msg); + + echo ""; + echo "
\n"; + + // Output table header + echo "\n"; + echo "\n"; + if ($data->hasAlterColumnType()) { + echo "\n"; + echo "\n"; + } + else { + echo "\n"; + } + echo "\n\n\n"; + + $column = $data->getTableAttributes($_REQUEST['table'], $_REQUEST['column']); + $column->fields['attnotnull'] = $data->phpBool($column->fields['attnotnull']); + + // Upon first drawing the screen, load the existing column information + // from the database. + if (!isset($_REQUEST['default'])) { + $_REQUEST['field'] = $column->fields['attname']; + $_REQUEST['type'] = $column->fields['base_type']; + // Check to see if its' an array type... + // XXX: HACKY + if (substr($column->fields['base_type'], strlen($column->fields['base_type']) - 2) == '[]') { + $_REQUEST['type'] = substr($column->fields['base_type'], 0, strlen($column->fields['base_type']) - 2); + $_REQUEST['array'] = '[]'; + } + else { + $_REQUEST['type'] = $column->fields['base_type']; + $_REQUEST['array'] = ''; + } + // To figure out the length, look in the brackets :( + // XXX: HACKY + if ($column->fields['type'] != $column->fields['base_type'] && preg_match('/\\(([0-9, ]*)\\)/', $column->fields['type'], $bits)) { + $_REQUEST['length'] = $bits[1]; + } + else + $_REQUEST['length'] = ''; + $_REQUEST['default'] = $_REQUEST['olddefault'] = $column->fields['adsrc']; + if ($column->fields['attnotnull']) $_REQUEST['notnull'] = 'YES'; + $_REQUEST['comment'] = $column->fields['comment']; + } + + // Column name + echo "\n"; + + // Column type + $escaped_predef_types = array(); // the JS escaped array elements + if ($data->hasAlterColumnType()) { + // Fetch all available types + $types = $data->getTypes(true, false, true); + $types_for_js = array(); + + echo "\n"; + + // Output array type selector + echo "\n"; + $predefined_size_types = array_intersect($data->predefined_size_types, $types_for_js); + foreach($predefined_size_types as $value) { + $escaped_predef_types[] = "'{$value}'"; + } + + echo "\n"; + } else { + // Otherwise draw the read-only type name + echo "\n"; + } + + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}{$lang['strtype']}{$lang['strlength']}{$lang['strtype']}{$lang['strnotnull']}{$lang['strdefault']}{$lang['strcomment']}
_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['field']), "\" />", $misc->printVal($data->formatType($column->fields['type'], $column->fields['atttypmod'])), "
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + if ($column->fields['attnotnull']) echo "\n"; + echo "formatType($column->fields['type'], $column->fields['atttypmod'])), "\" />\n"; + // Add hidden variables to suppress error notices if we don't support altering column type + if (!$data->hasAlterColumnType()) { + echo "\n"; + echo "\n"; + echo "\n"; + } + echo "\n"; + echo "

\n"; + echo "
\n"; + echo "\n"; + break; + case 2: + // Check inputs + if (trim($_REQUEST['field']) == '') { + $_REQUEST['stage'] = 1; + doAlter($lang['strcolneedsname']); + return; + } + if (!isset($_REQUEST['length'])) $_REQUEST['length'] = ''; + $status = $data->alterColumn($_REQUEST['table'], $_REQUEST['column'], $_REQUEST['field'], + isset($_REQUEST['notnull']), isset($_REQUEST['oldnotnull']), + $_REQUEST['default'], $_REQUEST['olddefault'], + $_REQUEST['type'], $_REQUEST['length'], $_REQUEST['array'], $_REQUEST['oldtype'], + $_REQUEST['comment']); + if ($status == 0) { + if ($_REQUEST['column'] != $_REQUEST['field']) { + $_REQUEST['column'] = $_REQUEST['field']; + $_reload_browser = true; + } + doDefault($lang['strcolumnaltered']); + } + else { + $_REQUEST['stage'] = 1; + doAlter($lang['strcolumnalteredbad']); + return; + } + break; + default: + echo "

{$lang['strinvalidparam']}

\n"; + } + } + + /** + * Show default list of columns in the table + */ + function doDefault($msg = '', $isTable = true) { + global $data, $conf, $misc, $tableName; + global $lang; + + function attPre(&$rowdata) { + global $data; + $rowdata->fields['+type'] = $data->formatType($rowdata->fields['type'], $rowdata->fields['atttypmod']); + } + + if (empty($_REQUEST['column'])) + $msg.= "
{$lang['strnoobjects']}"; + + $misc->printTrail('column'); + //$misc->printTitle($lang['strcolprop']); + $misc->printTabs('column','properties'); + $misc->printMsg($msg); + + if (! empty($_REQUEST['column'])) { + // Get table + $tdata = $data->getTable($tableName); + // Get columns + $attrs = $data->getTableAttributes($tableName, $_REQUEST['column']); + + // Show comment if any + if ($attrs->fields['comment'] !== null) + echo "

", $misc->printVal($attrs->fields['comment']), "

\n"; + + $column = array( + 'column' => array( + 'title' => $lang['strcolumn'], + 'field' => field('attname'), + ), + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('+type'), + ) + ); + + if ($isTable) { + $column['notnull'] = array( + 'title' => $lang['strnotnull'], + 'field' => field('attnotnull'), + 'type' => 'bool', + 'params'=> array('true' => 'NOT NULL', 'false' => '') + ); + $column['default'] = array( + 'title' => $lang['strdefault'], + 'field' => field('adsrc'), + ); + } + + $actions=array(); + $misc->printTable($attrs, $column, $actions, 'colproperties-colproperties', null, 'attPre'); + + echo "
\n"; + + $f_attname = $_REQUEST['column']; + $f_table = $tableName; + $f_schema = $data->_schema; + $data->fieldClean($f_attname); + $data->fieldClean($f_table); + $data->fieldClean($f_schema); + $query = "SELECT \"{$f_attname}\", count(*) AS \"count\" FROM \"{$f_schema}\".\"{$f_table}\" GROUP BY \"{$f_attname}\" ORDER BY \"{$f_attname}\""; + + if ($isTable) { + + /* Browse link */ + /* FIXME browsing a col should somehow be a action so we don't + * send an ugly SQL in the URL */ + + $navlinks = array ( + 'browse' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'subject' => 'column', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $tableName, + 'column' => $_REQUEST['column'], + 'return' => 'column', + 'query' => $query + ) + ) + ), + 'content' => $lang['strbrowse'], + ), + 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'colproperties.php', + 'urlvars' => array ( + 'action' => 'properties', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $tableName, + 'column' => $_REQUEST['column'], + ) + ) + ), + 'content' => $lang['stralter'], + ), + 'drop' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $tableName, + 'column' => $_REQUEST['column'], + ) + ) + ), + 'content' => $lang['strdrop'], + ) + ); + } + else { + /* Browse link */ + $navlinks = array ( + 'browse' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'subject' => 'column', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $tableName, + 'column' => $_REQUEST['column'], + 'return' => 'column', + 'query' => $query + ) + ) + ), + 'content' => $lang['strbrowse'] + ) + ); + } + + $misc->printNavLinks($navlinks, 'colproperties-colproperties', get_defined_vars()); + } + } + + $misc->printHeader($lang['strtables'] . ' - ' . $tableName); + $misc->printBody(); + + if (isset($_REQUEST['view'])) + doDefault(null, false); + else + switch ($action) { + case 'properties': + if (isset($_POST['cancel'])) doDefault(); + else doAlter(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/composer.json b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/composer.json new file mode 100644 index 00000000..d25bfc18 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/composer.json @@ -0,0 +1,13 @@ +{ + "name": "phppgadmin/phppgadmin", + "description": "phpPgAdmin is a web-based administration tool for PostgreSQL. It is perfect for PostgreSQL DBAs, newbies, and hosting services.", + "type": "Application", + "license": "GPL-2.0+", + "require": { + "php": ">=5.0" + }, + "minimum-stability": "stable", + "autoload": { + } +} + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/.gitignore b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/.gitignore new file mode 100644 index 00000000..7e9e3afe --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/.gitignore @@ -0,0 +1 @@ +config.inc.php diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/config.inc.php-dist b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/config.inc.php-dist new file mode 100644 index 00000000..ba927d40 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conf/config.inc.php-dist @@ -0,0 +1,172 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/constraints.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/constraints.php new file mode 100644 index 00000000..cc1591c9 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/constraints.php @@ -0,0 +1,640 @@ +printTrail('table'); + $misc->printTitle($lang['straddfk'],'pg.constraint.foreign_key'); + $misc->printMsg($msg); + + // Unserialize target and fetch appropriate table. This is a bit messy + // because the table could be in another schema. + $data->setSchema($_REQUEST['target']['schemaname']); + $attrs = $data->getTableAttributes($_REQUEST['target']['tablename']); + $data->setSchema($_REQUEST['schema']); + + $selColumns = new XHTML_select('TableColumnList', true, 10); + $selColumns->set_style('width: 15em;'); + + if ($attrs->recordCount() > 0) { + while (!$attrs->EOF) { + $selColumns->add(new XHTML_Option($attrs->fields['attname'])); + $attrs->moveNext(); + } + } + + $selIndex = new XHTML_select('IndexColumnList[]', true, 10); + $selIndex->set_style('width: 15em;'); + $selIndex->set_attribute('id', 'IndexColumnList'); + $buttonAdd = new XHTML_Button('add', '>>'); + $buttonAdd->set_attribute('onclick', 'buttonPressed(this);'); + $buttonAdd->set_attribute('type', 'button'); + + $buttonRemove = new XHTML_Button('remove', '<<'); + $buttonRemove->set_attribute('onclick', 'buttonPressed(this);'); + $buttonRemove->set_attribute('type', 'button'); + + echo "
\n"; + + echo "\n"; + echo ""; + echo "\n"; + echo "\n"; + echo ""; + echo "\n"; + echo ""; + echo ""; + echo "\n"; + echo "
{$lang['strfktarget']}
{$lang['strtablecolumnlist']} {$lang['strfkcolumnlist']}
" . $selColumns->fetch() . "" . $buttonRemove->fetch() . $buttonAdd->fetch() . "" . $selIndex->fetch() . "
{$lang['stractions']}
\n"; + // ON SELECT actions + echo "{$lang['stronupdate']}
\n"; + + // ON DELETE actions + echo "{$lang['strondelete']}
\n"; + + // MATCH options + echo "
\n"; + + // DEFERRABLE options + echo "
\n"; + + // INITIALLY options + echo "\n"; + echo "
\n"; + + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + break; + case 3: + // Unserialize target + $_POST['target'] = unserialize($_POST['target']); + + // Check that they've given at least one column + if (isset($_POST['SourceColumnList'])) $temp = unserialize($_POST['SourceColumnList']); + if (!isset($_POST['IndexColumnList']) || !is_array($_POST['IndexColumnList']) + || sizeof($_POST['IndexColumnList']) == 0 || !isset($temp) + || !is_array($temp) || sizeof($temp) == 0) addForeignKey(2, $lang['strfkneedscols']); + else { + $status = $data->addForeignKey($_POST['table'], $_POST['target']['schemaname'], $_POST['target']['tablename'], + unserialize($_POST['SourceColumnList']), $_POST['IndexColumnList'], $_POST['upd_action'], $_POST['del_action'], + $_POST['match'], $_POST['deferrable'], $_POST['initially'], $_POST['name']); + if ($status == 0) + doDefault($lang['strfkadded']); + else + addForeignKey(2, $lang['strfkaddedbad']); + } + break; + default: + $misc->printTrail('table'); + $misc->printTitle($lang['straddfk'],'pg.constraint.foreign_key'); + $misc->printMsg($msg); + + $attrs = $data->getTableAttributes($_REQUEST['table']); + $tables = $data->getTables(true); + + $selColumns = new XHTML_select('TableColumnList', true, 10); + $selColumns->set_style('width: 15em;'); + + if ($attrs->recordCount() > 0) { + while (!$attrs->EOF) { + $selColumns->add(new XHTML_Option($attrs->fields['attname'])); + $attrs->moveNext(); + } + } + + $selIndex = new XHTML_select('IndexColumnList[]', true, 10); + $selIndex->set_style('width: 15em;'); + $selIndex->set_attribute('id', 'IndexColumnList'); + $buttonAdd = new XHTML_Button('add', '>>'); + $buttonAdd->set_attribute('onclick', 'buttonPressed(this);'); + $buttonAdd->set_attribute('type', 'button'); + + $buttonRemove = new XHTML_Button('remove', '<<'); + $buttonRemove->set_attribute('onclick', 'buttonPressed(this);'); + $buttonRemove->set_attribute('type', 'button'); + + echo "
\n"; + + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo ""; + echo ""; + echo ""; + echo "
{$lang['strname']}
_maxNameLen}\" />
{$lang['strtablecolumnlist']} {$lang['strfkcolumnlist']}
" . $selColumns->fetch() . "" . $buttonRemove->fetch() . $buttonAdd->fetch() . "" . $selIndex->fetch() . "
{$lang['strfktarget']}
\n"; + echo "
\n"; + + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + break; + } + + } + + /** + * Confirm and then actually add a PRIMARY KEY or UNIQUE constraint + */ + function addPrimaryOrUniqueKey($type, $confirm, $msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['name'])) $_POST['name'] = ''; + + if ($confirm) { + if (!isset($_POST['name'])) $_POST['name'] = ''; + if (!isset($_POST['tablespace'])) $_POST['tablespace'] = ''; + + $misc->printTrail('table'); + + switch ($type) { + case 'primary': + $misc->printTitle($lang['straddpk'],'pg.constraint.primary_key'); + break; + case 'unique': + $misc->printTitle($lang['stradduniq'],'pg.constraint.unique_key'); + break; + default: + doDefault($lang['strinvalidparam']); + return; + } + + $misc->printMsg($msg); + + $attrs = $data->getTableAttributes($_REQUEST['table']); + // Fetch all tablespaces from the database + if ($data->hasTablespaces()) $tablespaces = $data->getTablespaces(); + + + $selColumns = new XHTML_select('TableColumnList', true, 10); + $selColumns->set_style('width: 15em;'); + + if ($attrs->recordCount() > 0) { + while (!$attrs->EOF) { + $selColumns->add(new XHTML_Option($attrs->fields['attname'])); + $attrs->moveNext(); + } + } + + $selIndex = new XHTML_select('IndexColumnList[]', true, 10); + $selIndex->set_style('width: 15em;'); + $selIndex->set_attribute('id', 'IndexColumnList'); + $buttonAdd = new XHTML_Button('add', '>>'); + $buttonAdd->set_attribute('onclick', 'buttonPressed(this);'); + $buttonAdd->set_attribute('type', 'button'); + + $buttonRemove = new XHTML_Button('remove', '<<'); + $buttonRemove->set_attribute('onclick', 'buttonPressed(this);'); + $buttonRemove->set_attribute('type', 'button'); + + echo "
\n"; + + echo "\n"; + echo ""; + echo ""; + echo ""; + echo "\n"; + echo "\n"; + echo ""; + echo "\n"; + + // Tablespace (if there are any) + if ($data->hasTablespaces() && $tablespaces->recordCount() > 0) { + echo ""; + echo "\n"; + } + + echo "
{$lang['strname']}
_maxNameLen}\" />
{$lang['strtablecolumnlist']} {$lang['strindexcolumnlist']}
" . $selColumns->fetch() . "" . $buttonRemove->fetch() . $buttonAdd->fetch() . "" . $selIndex->fetch() . "
{$lang['strtablespace']}
\n"; + + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + // Default tablespace to empty if it isn't set + if (!isset($_POST['tablespace'])) $_POST['tablespace'] = ''; + + if ($_POST['type'] == 'primary') { + // Check that they've given at least one column + if (!isset($_POST['IndexColumnList']) || !is_array($_POST['IndexColumnList']) + || sizeof($_POST['IndexColumnList']) == 0) addPrimaryOrUniqueKey($_POST['type'], true, $lang['strpkneedscols']); + else { + $status = $data->addPrimaryKey($_POST['table'], $_POST['IndexColumnList'], $_POST['name'], $_POST['tablespace']); + if ($status == 0) + doDefault($lang['strpkadded']); + else + addPrimaryOrUniqueKey($_POST['type'], true, $lang['strpkaddedbad']); + } + } + elseif ($_POST['type'] == 'unique') { + // Check that they've given at least one column + if (!isset($_POST['IndexColumnList']) || !is_array($_POST['IndexColumnList']) + || sizeof($_POST['IndexColumnList']) == 0) addPrimaryOrUniqueKey($_POST['type'], true, $lang['struniqneedscols']); + else { + $status = $data->addUniqueKey($_POST['table'], $_POST['IndexColumnList'], $_POST['name'], $_POST['tablespace']); + if ($status == 0) + doDefault($lang['struniqadded']); + else + addPrimaryOrUniqueKey($_POST['type'], true, $lang['struniqaddedbad']); + } + } + else doDefault($lang['strinvalidparam']); + } + } + + /** + * Confirm and then actually add a CHECK constraint + */ + function addCheck($confirm, $msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['name'])) $_POST['name'] = ''; + if (!isset($_POST['definition'])) $_POST['definition'] = ''; + + if ($confirm) { + $misc->printTrail('table'); + $misc->printTitle($lang['straddcheck'],'pg.constraint.check'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + echo "\n"; + + echo "\n"; + echo "
{$lang['strname']}{$lang['strdefinition']}
_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />()
\n"; + + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "

\n"; + echo "
\n"; + + } + else { + if (trim($_POST['definition']) == '') + addCheck(true, $lang['strcheckneedsdefinition']); + else { + $status = $data->addCheckConstraint($_POST['table'], + $_POST['definition'], $_POST['name']); + if ($status == 0) + doDefault($lang['strcheckadded']); + else + addCheck(true, $lang['strcheckaddedbad']); + } + } + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('constraint'); + $misc->printTitle($lang['strdrop'],'pg.constraint.drop'); + + echo "

", sprintf($lang['strconfdropconstraint'], $misc->printVal($_REQUEST['constraint']), + $misc->printVal($_REQUEST['table'])), "

\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropConstraint($_POST['constraint'], $_POST['table'], $_POST['type'], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['strconstraintdropped']); + else + doDefault($lang['strconstraintdroppedbad']); + } + } + + /** + * List all the constraints on the table + */ + function doDefault($msg = '') { + global $data, $misc, $lang; + + function cnPre(&$rowdata) { + global $data; + if (is_null($rowdata->fields['consrc'])) { + $atts = $data->getAttributeNames($_REQUEST['table'], explode(' ', $rowdata->fields['indkey'])); + $rowdata->fields['+definition'] = ($rowdata->fields['contype'] == 'u' ? "UNIQUE (" : "PRIMARY KEY (") . join(',', $atts) . ')'; + } else { + $rowdata->fields['+definition'] = $rowdata->fields['consrc']; + } + } + + $misc->printTrail('table'); + $misc->printTabs('table','constraints'); + $misc->printMsg($msg); + + $constraints = $data->getConstraints($_REQUEST['table']); + + $columns = array( + 'constraint' => array( + 'title' => $lang['strname'], + 'field' => field('conname'), + ), + 'definition' => array( + 'title' => $lang['strdefinition'], + 'field' => field('+definition'), + 'type' => 'pre', + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('constcomment'), + ), + ); + + $actions = array( + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'constraints.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'table' => $_REQUEST['table'], + 'constraint' => field('conname'), + 'type' => field('contype') + ) + ) + ) + ) + ); + + $misc->printTable($constraints, $columns, $actions, 'constraints-constraints', $lang['strnoconstraints'], 'cnPre'); + + $navlinks = array ( + 'addcheck' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'constraints.php', + 'urlvars' => array ( + 'action' => 'add_check', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['straddcheck'], + ), + 'adduniq' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'constraints.php', + 'urlvars' => array ( + 'action' => 'add_unique_key', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['stradduniq'], + ), + 'addpk' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'constraints.php', + 'urlvars' => array ( + 'action' => 'add_primary_key', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['straddpk'], + ), + 'addfk' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'constraints.php', + 'urlvars' => array ( + 'action' => 'add_foreign_key', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['straddfk'] + ) + ); + $misc->printNavLinks($navlinks, 'constraints-constraints', get_defined_vars()); + } + + function doTree() { + global $misc, $data; + + $constraints = $data->getConstraints($_REQUEST['table']); + + $reqvars = $misc->getRequestVars('schema'); + + function getIcon($f) { + switch($f['contype']) { + case 'u': + return 'UniqueConstraint'; + case 'c': + return 'CheckConstraint'; + case 'f': + return 'ForeignKey'; + case 'p': + return 'PrimaryKey'; + + } + } + + $attrs = array( + 'text' => field('conname'), + 'icon' => callback('getIcon'), + ); + + $misc->printTree($constraints, $attrs, 'constraints'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strtables'] . ' - ' . $_REQUEST['table'] . ' - ' . $lang['strconstraints'], + ""); + + if ($action == 'add_unique_key' || $action == 'save_add_unique_key' + || $action == 'add_primary_key' || $action == 'save_add_primary_key' + || $action == 'add_foreign_key' || $action == 'save_add_foreign_key') + echo ""; + else + $misc->printBody(); + + switch ($action) { + case 'add_foreign_key': + addForeignKey(1); + break; + case 'save_add_foreign_key': + if (isset($_POST['cancel'])) doDefault(); + else addForeignKey($_REQUEST['stage']); + break; + case 'add_unique_key': + addPrimaryOrUniqueKey('unique', true); + break; + case 'save_add_unique_key': + if (isset($_POST['cancel'])) doDefault(); + else addPrimaryOrUniqueKey('unique', false); + break; + case 'add_primary_key': + addPrimaryOrUniqueKey('primary', true); + break; + case 'save_add_primary_key': + if (isset($_POST['cancel'])) doDefault(); + else addPrimaryOrUniqueKey('primary', false); + break; + case 'add_check': + addCheck(true); + break; + case 'save_add_check': + if (isset($_POST['cancel'])) doDefault(); + else addCheck(false); + break; + case 'save_create': + doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conversions.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conversions.php new file mode 100644 index 00000000..32def8d7 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/conversions.php @@ -0,0 +1,88 @@ +printTrail('schema'); + $misc->printTabs('schema', 'conversions'); + $misc->printMsg($msg); + + $conversions = $data->getconversions(); + + $columns = array( + 'conversion' => array( + 'title' => $lang['strname'], + 'field' => field('conname'), + ), + 'source_encoding' => array( + 'title' => $lang['strsourceencoding'], + 'field' => field('conforencoding'), + ), + 'target_encoding' => array( + 'title' => $lang['strtargetencoding'], + 'field' => field('contoencoding'), + ), + 'default' => array( + 'title' => $lang['strdefault'], + 'field' => field('condefault'), + 'type' => 'yesno', + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('concomment'), + ), + ); + + $actions = array(); + + $misc->printTable($conversions, $columns, $actions, 'conversions-conversions', $lang['strnoconversions']); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $conversions = $data->getconversions(); + + $attrs = array( + 'text' => field('conname'), + 'icon' => 'Conversion', + 'toolTip'=> field('concomment') + ); + + $misc->printTree($conversions, $attrs, 'conversions'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strconversions']); + $misc->printBody(); + + switch ($action) { + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/database.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/database.php new file mode 100644 index 00000000..cdd53c60 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/database.php @@ -0,0 +1,698 @@ +{$term}", $string); + } + + /** + * Sends a signal to a process + */ + function doSignal() { + global $data, $lang; + + $status = $data->sendSignal($_REQUEST['pid'], $_REQUEST['signal']); + if ($status == 0) + doProcesses($lang['strsignalsent']); + else + doProcesses($lang['strsignalsentbad']); + } + + /** + * Searches for a named database object + */ + function doFind($confirm = true, $msg = '') { + global $data, $misc; + global $lang, $conf; + + if (!isset($_REQUEST['term'])) $_REQUEST['term'] = ''; + if (!isset($_REQUEST['filter'])) $_REQUEST['filter'] = ''; + + $misc->printTrail('database'); + $misc->printTabs('database','find'); + $misc->printMsg($msg); + + echo "
\n"; + echo "

_maxNameLen}\" />\n"; + // Output list of filters. This is complex due to all the 'has' and 'conf' feature possibilities + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "
\n"; + + // Default focus + $misc->setFocus('forms[0].term'); + + // If a search term has been specified, then perform the search + // and display the results, grouped by object type + if ($_REQUEST['term'] != '') { + $rs = $data->findObject($_REQUEST['term'], $_REQUEST['filter']); + if ($rs->recordCount() > 0) { + $curr = ''; + while (!$rs->EOF) { + // Output a new header if the current type has changed, but not if it's just changed the rule type + if ($rs->fields['type'] != $curr) { + // Short-circuit in the case of changing from table rules to view rules; table cols to view cols; + // table constraints to domain constraints + if ($rs->fields['type'] == 'RULEVIEW' && $curr == 'RULETABLE') { + $curr = $rs->fields['type']; + } + elseif ($rs->fields['type'] == 'COLUMNVIEW' && $curr == 'COLUMNTABLE') { + $curr = $rs->fields['type']; + } + elseif ($rs->fields['type'] == 'CONSTRAINTTABLE' && $curr == 'CONSTRAINTDOMAIN') { + $curr = $rs->fields['type']; + } + else { + if ($curr != '') echo "\n"; + $curr = $rs->fields['type']; + echo "

"; + switch ($curr) { + case 'SCHEMA': + echo $lang['strschemas']; + break; + case 'TABLE': + echo $lang['strtables']; + break; + case 'VIEW': + echo $lang['strviews']; + break; + case 'SEQUENCE': + echo $lang['strsequences']; + break; + case 'COLUMNTABLE': + case 'COLUMNVIEW': + echo $lang['strcolumns']; + break; + case 'INDEX': + echo $lang['strindexes']; + break; + case 'CONSTRAINTTABLE': + case 'CONSTRAINTDOMAIN': + echo $lang['strconstraints']; + break; + case 'TRIGGER': + echo $lang['strtriggers']; + break; + case 'RULETABLE': + case 'RULEVIEW': + echo $lang['strrules']; + break; + case 'FUNCTION': + echo $lang['strfunctions']; + break; + case 'TYPE': + echo $lang['strtypes']; + break; + case 'DOMAIN': + echo $lang['strdomains']; + break; + case 'OPERATOR': + echo $lang['stroperators']; + break; + case 'CONVERSION': + echo $lang['strconversions']; + break; + case 'LANGUAGE': + echo $lang['strlanguages']; + break; + case 'AGGREGATE': + echo $lang['straggregates']; + break; + case 'OPCLASS': + echo $lang['stropclasses']; + break; + } + echo "

"; + echo "\n"; + + echo "

", $rs->recordCount(), " ", $lang['strobjects'], "

\n"; + } + else echo "

{$lang['strnoobjects']}

\n"; + } + } + + /** + * Displays options for database download + */ + function doExport($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('database'); + $misc->printTabs('database','export'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + // Data only + echo "\n"; + echo "\n"; + echo "\n\n"; + echo "\n\n"; + // Structure only + echo "\n"; + echo "\n\n"; + // Structure and data + echo "\n"; + echo "\n"; + echo "\n\n"; + echo "\n\n"; + echo "\n\n"; + echo "
{$lang['strformat']}{$lang['stroptions']}
"; + echo "{$lang['strformat']}\n
"; + echo "{$lang['strformat']}\n
\n"; + + echo "

{$lang['stroptions']}

\n"; + echo "

\n"; + echo "
\n"; + // MSIE cannot download gzip in SSL mode - it's just broken + if (!(strstr($_SERVER['HTTP_USER_AGENT'], 'MSIE') && isset($_SERVER['HTTPS']))) { + echo "
\n"; + } + echo "

\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "
\n"; + } + + /** + * Show the current status of all database variables + */ + function doVariables() { + global $data, $misc; + global $lang; + + // Fetch the variables from the database + $variables = $data->getVariables(); + $misc->printTrail('database'); + $misc->printTabs('database','variables'); + + $columns = array( + 'variable' => array( + 'title' => $lang['strname'], + 'field' => field('name'), + ), + 'value' => array( + 'title' => $lang['strsetting'], + 'field' => field('setting'), + ), + ); + + $actions = array(); + + $misc->printTable($variables, $columns, $actions, 'database-variables', $lang['strnodata']); + } + + /** + * Show all current database connections and any queries they + * are running. + */ + function doProcesses($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('database'); + $misc->printTabs('database','processes'); + $misc->printMsg($msg); + + if (strlen($msg) === 0) { + echo "
icon('Refresh')."\" alt=\"{$lang['strrefresh']}\" title=\"{$lang['strrefresh']}\"/> {$lang['strrefresh']}"; + } + + echo "
"; + currentProcesses(); + echo "
"; + } + + function currentProcesses($isAjax = false) { + global $data, $misc, $lang; + + // Display prepared transactions + if($data->hasPreparedXacts()) { + echo "

{$lang['strpreparedxacts']}

\n"; + $prep_xacts = $data->getPreparedXacts($_REQUEST['database']); + + $columns = array( + 'transaction' => array( + 'title' => $lang['strxactid'], + 'field' => field('transaction'), + ), + 'gid' => array( + 'title' => $lang['strgid'], + 'field' => field('gid'), + ), + 'prepared' => array( + 'title' => $lang['strstarttime'], + 'field' => field('prepared'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('owner'), + ), + ); + + $actions = array(); + + $misc->printTable($prep_xacts, $columns, $actions, 'database-processes-preparedxacts', $lang['strnodata']); + } + + // Fetch the processes from the database + echo "

{$lang['strprocesses']}

\n"; + $processes = $data->getProcesses($_REQUEST['database']); + + $columns = array( + 'user' => array( + 'title' => $lang['strusername'], + 'field' => field('usename'), + ), + 'process' => array( + 'title' => $lang['strprocess'], + 'field' => field('pid'), + ), + 'blocked' => array( + 'title' => $lang['strblocked'], + 'field' => field('waiting'), + ), + 'query' => array( + 'title' => $lang['strsql'], + 'field' => field('query'), + ), + 'start_time' => array( + 'title' => $lang['strstarttime'], + 'field' => field('query_start'), + ), + ); + + // Build possible actions for our process list + $columns['actions'] = array('title' => $lang['stractions']); + + $actions = array(); + if ($data->hasUserSignals() || $data->isSuperUser()) { + $actions = array( + 'cancel' => array( + 'content' => $lang['strcancel'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'database.php', + 'urlvars' => array ( + 'action' => 'signal', + 'signal' => 'CANCEL', + 'pid' => field('pid') + ) + ) + ) + ), + 'kill' => array( + 'content' => $lang['strkill'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'database.php', + 'urlvars' => array ( + 'action' => 'signal', + 'signal' => 'KILL', + 'pid' => field('pid') + ) + ) + ) + ) + ); + + // Remove actions where not supported + if (!$data->hasQueryKill()) unset($actions['kill']); + if (!$data->hasQueryCancel()) unset($actions['cancel']); + } + + if (count($actions) == 0) unset($columns['actions']); + + $misc->printTable($processes, $columns, $actions, 'database-processes', $lang['strnodata']); + + if ($isAjax) exit; + } + + function currentLocks($isAjax = false) { + global $data, $misc, $lang; + + // Get the info from the pg_locks view + $variables = $data->getLocks(); + + $columns = array( + 'namespace' => array( + 'title' => $lang['strschema'], + 'field' => field('nspname'), + ), + 'tablename' => array( + 'title' => $lang['strtablename'], + 'field' => field('tablename'), + ), + 'vxid' => array( + 'title' => $lang['strvirtualtransaction'], + 'field' => field('virtualtransaction'), + ), + 'transactionid' => array( + 'title' => $lang['strtransaction'], + 'field' => field('transaction'), + ), + 'processid' => array( + 'title' => $lang['strprocessid'], + 'field' => field('pid'), + ), + 'mode' => array( + 'title' => $lang['strmode'], + 'field' => field('mode'), + ), + 'granted' => array( + 'title' => $lang['strislockheld'], + 'field' => field('granted'), + 'type' => 'yesno', + ), + ); + + if (!$data->hasVirtualTransactionId()) unset($columns['vxid']); + + $actions = array(); + $misc->printTable($variables, $columns, $actions, 'database-locks', $lang['strnodata']); + + if ($isAjax) exit; + } + + /** + * Show the existing table locks in the current database + */ + function doLocks() { + global $data, $misc; + global $lang; + + $misc->printTrail('database'); + $misc->printTabs('database','locks'); + + echo "
icon('Refresh')."\" alt=\"{$lang['strrefresh']}\" title=\"{$lang['strrefresh']}\"/> {$lang['strrefresh']}"; + + echo "
"; + currentLocks(); + echo "
"; + } + + /** + * Allow execution of arbitrary SQL statements on a database + */ + function doSQL() { + global $data, $misc; + global $lang; + + if ((!isset($_SESSION['sqlquery'])) || isset($_REQUEST['new'])) { + $_SESSION['sqlquery'] = ''; + $_REQUEST['paginate'] = 'on'; + } + + $misc->printTrail('database'); + $misc->printTabs('database','sql'); + echo "

{$lang['strentersql']}

\n"; + echo "
\n"; + echo "

{$lang['strsql']}
\n"; + echo "

\n"; + + // Check that file uploads are enabled + if (ini_get('file_uploads')) { + // Don't show upload option if max size of uploads is zero + $max_size = $misc->inisizeToBytes(ini_get('upload_max_filesize')); + if (is_double($max_size) && $max_size > 0) { + echo "

\n"; + echo "

\n"; + } + } + + echo "

\n"; + echo "

\n"; + echo $misc->form; + echo "

\n"; + echo "
\n"; + + // Default focus + $misc->setFocus('forms[0].query'); + } + + function doTree() { + global $misc, $data, $lang; + + $reqvars = $misc->getRequestVars('database'); + + $tabs = $misc->getNavTabs('database'); + + $items = $misc->adjustTabsForTree($tabs); + + $attrs = array( + 'text' => field('title'), + 'icon' => field('icon'), + 'action' => url(field('url'), + $reqvars, + field('urlvars', array()) + ), + 'branch' => url(field('url'), + $reqvars, + field('urlvars'), + array('action' => 'tree') + ), + ); + + $misc->printTree($items, $attrs, 'database'); + + exit; + } + + require('./admin.php'); + + /* shortcuts: these functions exit the script */ + if ($action == 'tree') doTree(); + if ($action == 'refresh_locks') currentLocks(true); + if ($action == 'refresh_processes') currentProcesses(true); + + /* normal flow */ + if ($action == 'locks' or $action == 'processes') { + $scripts .= ""; + + $refreshTime = $conf['ajax_refresh'] * 1000; + + $scripts .= "\n"; + } + + $misc->printHeader($lang['strdatabase'], $scripts); + $misc->printBody(); + + switch ($action) { + case 'find': + if (isset($_REQUEST['term'])) doFind(false); + else doFind(true); + break; + case 'sql': + doSQL(); + break; + case 'variables': + doVariables(); + break; + case 'processes': + doProcesses(); + break; + case 'locks': + doLocks(); + break; + case 'export': + doExport(); + break; + case 'signal': + doSignal(); + break; + default: + if (adminActions($action, 'database') === false) doSQL(); + break; + } + + $misc->printFooter(); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataexport.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataexport.php new file mode 100644 index 00000000..84db24f8 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataexport.php @@ -0,0 +1,345 @@ + 'sql', + 'copy' => 'sql', + 'csv' => 'csv', + 'tab' => 'txt', + 'html' => 'html', + 'xml' => 'xml' + ); + + // Prevent timeouts on large exports (non-safe mode only) + if (!ini_get('safe_mode')) set_time_limit(0); + + // if (!isset($_REQUEST['table']) && !isset($_REQUEST['query'])) + // What must we do in this case? Maybe redirect to the homepage? + + // If format is set, then perform the export + if (isset($_REQUEST['what'])) { + + // Include application functions + $_no_output = true; + include_once('./libraries/lib.inc.php'); + + switch ($_REQUEST['what']) { + case 'dataonly': + // Check to see if they have pg_dump set up and if they do, use that + // instead of custom dump code + if ($misc->isDumpEnabled() + && ($_REQUEST['d_format'] == 'copy' || $_REQUEST['d_format'] == 'sql')) { + include('./dbexport.php'); + exit; + } + else { + $format = $_REQUEST['d_format']; + $oids = isset($_REQUEST['d_oids']); + } + break; + case 'structureonly': + // Check to see if they have pg_dump set up and if they do, use that + // instead of custom dump code + if ($misc->isDumpEnabled()) { + include('./dbexport.php'); + exit; + } + else $clean = isset($_REQUEST['s_clean']); + break; + case 'structureanddata': + // Check to see if they have pg_dump set up and if they do, use that + // instead of custom dump code + if ($misc->isDumpEnabled()) { + include('./dbexport.php'); + exit; + } + else { + $format = $_REQUEST['sd_format']; + $clean = isset($_REQUEST['sd_clean']); + $oids = isset($_REQUEST['sd_oids']); + } + break; + } + + // Make it do a download, if necessary + if ($_REQUEST['output'] == 'download') { + // Set headers. MSIE is totally broken for SSL downloading, so + // we need to have it download in-place as plain text + if (strstr($_SERVER['HTTP_USER_AGENT'], 'MSIE') && isset($_SERVER['HTTPS'])) { + header('Content-Type: text/plain'); + } + else { + header('Content-Type: application/download'); + + if (isset($extensions[$format])) + $ext = $extensions[$format]; + else + $ext = 'txt'; + + header('Content-Disposition: attachment; filename=dump.' . $ext); + } + } + else { + header('Content-Type: text/plain'); + } + + if (isset($_REQUEST['query'])) $_REQUEST['query'] = trim(urldecode($_REQUEST['query'])); + + // Set the schema search path + if (isset($_REQUEST['search_path'])) { + $data->setSearchPath(array_map('trim',explode(',',$_REQUEST['search_path']))); + } + + // Set up the dump transaction + $status = $data->beginDump(); + + // If the dump is not dataonly then dump the structure prefix + if ($_REQUEST['what'] != 'dataonly') + echo $data->getTableDefPrefix($_REQUEST['table'], $clean); + + // If the dump is not structureonly then dump the actual data + if ($_REQUEST['what'] != 'structureonly') { + // Get database encoding + $dbEncoding = $data->getDatabaseEncoding(); + + // Set fetch mode to NUM so that duplicate field names are properly returned + $data->conn->setFetchMode(ADODB_FETCH_NUM); + + // Execute the query, if set, otherwise grab all rows from the table + if (isset($_REQUEST['table'])) + $rs = $data->dumpRelation($_REQUEST['table'], $oids); + else + $rs = $data->conn->Execute($_REQUEST['query']); + + if ($format == 'copy') { + $data->fieldClean($_REQUEST['table']); + echo "COPY \"{$_REQUEST['table']}\""; + if ($oids) echo " WITH OIDS"; + echo " FROM stdin;\n"; + while (!$rs->EOF) { + $first = true; + while(list($k, $v) = each($rs->fields)) { + // Escape value + $v = $data->escapeBytea($v); + + // We add an extra escaping slash onto octal encoded characters + $v = preg_replace('/\\\\([0-7]{3})/', '\\\\\1', $v); + if ($first) { + echo (is_null($v)) ? '\\N' : $v; + $first = false; + } + else echo "\t", (is_null($v)) ? '\\N' : $v; + } + echo "\n"; + $rs->moveNext(); + } + echo "\\.\n"; + } + elseif ($format == 'html') { + echo "\r\n"; + echo "\r\n"; + echo "\r\n"; + echo "\t\r\n"; + echo "\t\r\n"; + echo "\r\n"; + echo "\r\n"; + echo "\r\n"; + echo "\t\r\n"; + if (!$rs->EOF) { + // Output header row + $j = 0; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($j++); + if ($finfo->name == $data->id && !$oids) continue; + echo "\t\t\r\n"; + } + } + echo "\t\r\n"; + while (!$rs->EOF) { + echo "\t\r\n"; + $j = 0; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($j++); + if ($finfo->name == $data->id && !$oids) continue; + echo "\t\t\r\n"; + } + echo "\t\r\n"; + $rs->moveNext(); + } + echo "
", $misc->printVal($finfo->name, true), "
", $misc->printVal($v, true, $finfo->type), "
\r\n"; + echo "\r\n"; + echo "\r\n"; + } + elseif ($format == 'xml') { + echo "\n"; + echo "\n"; + if (!$rs->EOF) { + // Output header row + $j = 0; + echo "\t
\n"; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($j++); + $name = htmlspecialchars($finfo->name); + $type = htmlspecialchars($finfo->type); + echo "\t\t\n"; + } + echo "\t
\n"; + } + echo "\t\n"; + while (!$rs->EOF) { + $j = 0; + echo "\t\t\n"; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($j++); + $name = htmlspecialchars($finfo->name); + if (!is_null($v)) $v = htmlspecialchars($v); + echo "\t\t\t{$v}\n"; + } + echo "\t\t\n"; + $rs->moveNext(); + } + echo "\t\n"; + echo "
\n"; + } + elseif ($format == 'sql') { + $data->fieldClean($_REQUEST['table']); + while (!$rs->EOF) { + echo "INSERT INTO \"{$_REQUEST['table']}\" ("; + $first = true; + $j = 0; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($j++); + $k = $finfo->name; + // SQL (INSERT) format cannot handle oids + // if ($k == $data->id) continue; + // Output field + $data->fieldClean($k); + if ($first) echo "\"{$k}\""; + else echo ", \"{$k}\""; + + if (!is_null($v)) { + // Output value + // addCSlashes converts all weird ASCII characters to octal representation, + // EXCEPT the 'special' ones like \r \n \t, etc. + $v = addCSlashes($v, "\0..\37\177..\377"); + // We add an extra escaping slash onto octal encoded characters + $v = preg_replace('/\\\\([0-7]{3})/', '\\\1', $v); + // Finally, escape all apostrophes + $v = str_replace("'", "''", $v); + } + if ($first) { + $values = (is_null($v) ? 'NULL' : "'{$v}'"); + $first = false; + } + else $values .= ', ' . ((is_null($v) ? 'NULL' : "'{$v}'")); + } + echo ") VALUES ({$values});\n"; + $rs->moveNext(); + } + } + else { + switch ($format) { + case 'tab': + $sep = "\t"; + break; + case 'csv': + default: + $sep = ','; + break; + } + if (!$rs->EOF) { + // Output header row + $first = true; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($k); + $v = $finfo->name; + if (!is_null($v)) $v = str_replace('"', '""', $v); + if ($first) { + echo "\"{$v}\""; + $first = false; + } + else echo "{$sep}\"{$v}\""; + } + echo "\r\n"; + } + while (!$rs->EOF) { + $first = true; + foreach ($rs->fields as $k => $v) { + if (!is_null($v)) $v = str_replace('"', '""', $v); + if ($first) { + echo (is_null($v)) ? "\"\\N\"" : "\"{$v}\""; + $first = false; + } + else echo is_null($v) ? "{$sep}\"\\N\"" : "{$sep}\"{$v}\""; + } + echo "\r\n"; + $rs->moveNext(); + } + } + } + + // If the dump is not dataonly then dump the structure suffix + if ($_REQUEST['what'] != 'dataonly') { + // Set fetch mode back to ASSOC for the table suffix to work + $data->conn->setFetchMode(ADODB_FETCH_ASSOC); + echo $data->getTableDefSuffix($_REQUEST['table']); + } + + // Finish the dump transaction + $status = $data->endDump(); + } + else { + // Include application functions + include_once('./libraries/lib.inc.php'); + + if ( !isset($_REQUEST['query']) or empty($_REQUEST['query']) ) + $_REQUEST['query'] = $_SESSION['sqlquery']; + + $misc->printHeader($lang['strexport']); + $misc->printBody(); + $misc->printTrail(isset($_REQUEST['subject']) ? $_REQUEST['subject'] : 'database'); + $misc->printTitle($lang['strexport']); + if (isset($msg)) $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo ""; + echo "
{$lang['strformat']}:
\n"; + + echo "

{$lang['stroptions']}

\n"; + echo "

\n"; + echo "

\n"; + + echo "

\n"; + echo "\n"; + if (isset($_REQUEST['table'])) { + echo "\n"; + } + echo "\n"; + if (isset($_REQUEST['search_path'])) { + echo "\n"; + } + echo $misc->form; + echo "

\n"; + echo "
\n"; + + $misc->printFooter(); + } + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataimport.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataimport.php new file mode 100644 index 00000000..ff81cd96 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dataimport.php @@ -0,0 +1,298 @@ +rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + $state = 'DATA'; + break; + case 'HEADER': + if ($state != 'DATA') { + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + $state = 'HEADER'; + break; + case 'RECORDS': + if ($state != 'READ_HEADER') { + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + $state = 'RECORDS'; + break; + case 'ROW': + if ($state != 'RECORDS') { + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + $state = 'ROW'; + $curr_row = array(); + break; + case 'COLUMN': + // We handle columns in rows + if ($state == 'ROW') { + $state = 'COLUMN'; + $curr_col_name = $attrs['NAME']; + $curr_col_null = isset($attrs['NULL']); + } + // And we ignore columns in headers and fail in any other context + elseif ($state != 'HEADER') { + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + break; + default: + // An unrecognised tag means failure + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + } + + /** + * Close tag handler for XML import feature + */ + function _endElement($parser, $name) { + global $data, $misc, $lang; + global $state, $curr_row, $curr_col_name, $curr_col_val, $curr_col_null; + + switch ($name) { + case 'DATA': + $state = 'READ_DATA'; + break; + case 'HEADER': + $state = 'READ_HEADER'; + break; + case 'RECORDS': + $state = 'READ_RECORDS'; + break; + case 'ROW': + // Build value map in order to insert row into table + $fields = array(); + $vars = array(); + $nulls = array(); + $format = array(); + $types = array(); + $i = 0; + foreach ($curr_row as $k => $v) { + $fields[$i] = $k; + // Check for nulls + if ($v === null) $nulls[$i] = 'on'; + // Add to value array + $vars[$i] = $v; + // Format is always VALUE + $format[$i] = 'VALUE'; + // Type is always text + $types[$i] = 'text'; + $i++; + } + $status = $data->insertRow($_REQUEST['table'], $fields, $vars, $nulls, $format, $types); + if ($status != 0) { + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + $curr_row = array(); + $state = 'RECORDS'; + break; + case 'COLUMN': + $curr_row[$curr_col_name] = ($curr_col_null ? null : $curr_col_val); + $curr_col_name = null; + $curr_col_val = null; + $curr_col_null = false; + $state = 'ROW'; + break; + default: + // An unrecognised tag means failure + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror']); + exit; + } + } + + /** + * Character data handler for XML import feature + */ + function _charHandler($parser, $cdata) { + global $data, $misc, $lang; + global $state, $curr_col_val; + + if ($state == 'COLUMN') { + $curr_col_val .= $cdata; + } + } + + function loadNULLArray() { + $array = array(); + if (isset($_POST['allowednulls'])) { + foreach ($_POST['allowednulls'] as $null_char) + $array[] = $null_char; + } + return $array; + } + + function determineNull($field, $null_array) { + return in_array($field, $null_array); + } + + $misc->printHeader($lang['strimport']); + $misc->printTrail('table'); + $misc->printTabs('table','import'); + + // Check that file is specified and is an uploaded file + if (isset($_FILES['source']) && is_uploaded_file($_FILES['source']['tmp_name']) && is_readable($_FILES['source']['tmp_name'])) { + + $fd = fopen($_FILES['source']['tmp_name'], 'r'); + // Check that file was opened successfully + if ($fd !== false) { + $null_array = loadNULLArray(); + $status = $data->beginTransaction(); + if ($status != 0) { + $misc->printMsg($lang['strimporterror']); + exit; + } + + // If format is set to 'auto', then determine format automatically from file name + if ($_REQUEST['format'] == 'auto') { + $extension = substr(strrchr($_FILES['source']['name'], '.'), 1); + switch ($extension) { + case 'csv': + $_REQUEST['format'] = 'csv'; + break; + case 'txt': + $_REQUEST['format'] = 'tab'; + break; + case 'xml': + $_REQUEST['format'] = 'xml'; + break; + default: + $data->rollbackTransaction(); + $misc->printMsg($lang['strimporterror-fileformat']); + exit; + } + } + + // Do different import technique depending on file format + switch ($_REQUEST['format']) { + case 'csv': + case 'tab': + // XXX: Length of CSV lines limited to 100k + $csv_max_line = 100000; + // Set delimiter to tabs or commas + if ($_REQUEST['format'] == 'csv') $csv_delimiter = ','; + else $csv_delimiter = "\t"; + // Get first line of field names + $fields = fgetcsv($fd, $csv_max_line, $csv_delimiter); + $row = 2; //We start on the line AFTER the field names + while ($line = fgetcsv($fd, $csv_max_line, $csv_delimiter)) { + // Build value map + $t_fields = array(); + $vars = array(); + $nulls = array(); + $format = array(); + $types = array(); + $i = 0; + foreach ($fields as $f) { + // Check that there is a column + if (!isset($line[$i])) { + $misc->printMsg(sprintf($lang['strimporterrorline-badcolumnnum'], $row)); + exit; + } + $t_fields[$i] = $f; + + // Check for nulls + if (determineNull($line[$i], $null_array)) { + $nulls[$i] = 'on'; + } + // Add to value array + $vars[$i] = $line[$i]; + // Format is always VALUE + $format[$i] = 'VALUE'; + // Type is always text + $types[$i] = 'text'; + $i++; + } + + $status = $data->insertRow($_REQUEST['table'], $t_fields, $vars, $nulls, $format, $types); + if ($status != 0) { + $data->rollbackTransaction(); + $misc->printMsg(sprintf($lang['strimporterrorline'], $row)); + exit; + } + $row++; + } + break; + case 'xml': + $parser = xml_parser_create(); + xml_set_element_handler($parser, '_startElement', '_endElement'); + xml_set_character_data_handler($parser, '_charHandler'); + + while (!feof($fd)) { + $line = fgets($fd, 4096); + xml_parse($parser, $line); + } + + xml_parser_free($parser); + break; + default: + // Unknown type + $data->rollbackTransaction(); + $misc->printMsg($lang['strinvalidparam']); + exit; + } + + $status = $data->endTransaction(); + if ($status != 0) { + $misc->printMsg($lang['strimporterror']); + exit; + } + fclose($fd); + + $misc->printMsg($lang['strfileimported']); + } + else { + // File could not be opened + $misc->printMsg($lang['strimporterror']); + } + } + else { + // Upload went wrong + $misc->printMsg($lang['strimporterror-uploadedfile']); + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dbexport.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dbexport.php new file mode 100644 index 00000000..d7320817 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/dbexport.php @@ -0,0 +1,139 @@ +isDumpEnabled($dumpall)) { + + $server_info = $misc->getServerInfo(); + + // Get the path of the pg_dump/pg_dumpall executable + $exe = $misc->escapeShellCmd($server_info[$dumpall ? 'pg_dumpall_path' : 'pg_dump_path']); + + // Obtain the pg_dump version number and check if the path is good + $version = array(); + preg_match("/(\d+(?:\.\d+)?)(?:\.\d+)?.*$/", exec($exe . " --version"), $version); + + if (empty($version)) { + if ($dumpall) + printf($lang['strbadpgdumpallpath'], $server_info['pg_dumpall_path']); + else + printf($lang['strbadpgdumppath'], $server_info['pg_dump_path']); + exit; + } + + // Make it do a download, if necessary + switch($_REQUEST['output']){ + case 'show': + header('Content-Type: text/plain'); + break; + case 'download': + // Set headers. MSIE is totally broken for SSL downloading, so + // we need to have it download in-place as plain text + if (strstr($_SERVER['HTTP_USER_AGENT'], 'MSIE') && isset($_SERVER['HTTPS'])) { + header('Content-Type: text/plain'); + } + else { + header('Content-Type: application/download'); + header('Content-Disposition: attachment; filename=dump.sql'); + } + break; + case 'gzipped': + // MSIE in SSL mode cannot do this - it should never get to this point + header('Content-Type: application/download'); + header('Content-Disposition: attachment; filename=dump.sql.gz'); + break; + } + + // Set environmental variables that pg_dump uses + putenv('PGPASSWORD=' . $server_info['password']); + putenv('PGUSER=' . $server_info['username']); + $hostname = $server_info['host']; + if ($hostname !== null && $hostname != '') { + putenv('PGHOST=' . $hostname); + } + $port = $server_info['port']; + if ($port !== null && $port != '') { + putenv('PGPORT=' . $port); + } + + // Build command for executing pg_dump. + $cmd = $exe; + + // we are PG 7.4+, so we always have a schema + if (isset($_REQUEST['schema'])) { + $f_schema = $_REQUEST['schema']; + $data->fieldClean($f_schema); + } + + // Check for a specified table/view + switch ($_REQUEST['subject']) { + case 'schema': + // This currently works for 8.2+ (due to the orthoganl -t -n issue introduced then) + $cmd .= " -n " . $misc->escapeShellArg("\"{$f_schema}\""); + break; + case 'table': + case 'view': + $f_object = $_REQUEST[$_REQUEST['subject']]; + $data->fieldClean($f_object); + + // Starting in 8.2, -n and -t are orthagonal, so we now schema qualify + // the table name in the -t argument and quote both identifiers + if ( ((float) $version[1]) >= 8.2 ) { + $cmd .= " -t " . $misc->escapeShellArg("\"{$f_schema}\".\"{$f_object}\""); + } + else { + // If we are 7.4 or higher, assume they are using 7.4 pg_dump and + // set dump schema as well. Also, mixed case dumping has been fixed + // then.. + $cmd .= " -t " . $misc->escapeShellArg($f_object) + . " -n " . $misc->escapeShellArg($f_schema); + } + } + + // Check for GZIP compression specified + if ($_REQUEST['output'] == 'gzipped' && !$dumpall) { + $cmd .= " -Z 9"; + } + + switch ($_REQUEST['what']) { + case 'dataonly': + $cmd .= ' -a'; + if ($_REQUEST['d_format'] == 'sql') $cmd .= ' --inserts'; + elseif (isset($_REQUEST['d_oids'])) $cmd .= ' -o'; + break; + case 'structureonly': + $cmd .= ' -s'; + if (isset($_REQUEST['s_clean'])) $cmd .= ' -c'; + break; + case 'structureanddata': + if ($_REQUEST['sd_format'] == 'sql') $cmd .= ' --inserts'; + elseif (isset($_REQUEST['sd_oids'])) $cmd .= ' -o'; + if (isset($_REQUEST['sd_clean'])) $cmd .= ' -c'; + break; + } + + if (!$dumpall) { + putenv('PGDATABASE=' . $_REQUEST['database']); + } + + // Execute command and return the output to the screen + passthru($cmd); + } + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/display.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/display.php new file mode 100644 index 00000000..f87a2153 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/display.php @@ -0,0 +1,879 @@ +printTrail($_REQUEST['subject']); + $misc->printTitle($lang['streditrow']); + $misc->printMsg($msg); + + $attrs = $data->getTableAttributes($_REQUEST['table']); + $rs = $data->browseRow($_REQUEST['table'], $key); + + if (($conf['autocomplete'] != 'disable')) { + $fksprops = $misc->getAutocompleteFKProperties($_REQUEST['table']); + if ($fksprops !== false) + echo $fksprops['code']; + } + else $fksprops = false; + + echo "
\n"; + $elements = 0; + $error = true; + if ($rs->recordCount() == 1 && $attrs->recordCount() > 0) { + echo "\n"; + + // Output table header + echo ""; + echo "\n"; + echo ""; + + $i = 0; + while (!$attrs->EOF) { + + $attrs->fields['attnotnull'] = $data->phpBool($attrs->fields['attnotnull']); + $id = (($i % 2) == 0 ? '1' : '2'); + + // Initialise variables + if (!isset($_REQUEST['format'][$attrs->fields['attname']])) + $_REQUEST['format'][$attrs->fields['attname']] = 'VALUE'; + + echo "\n"; + echo ""; + echo ""; + $elements++; + echo "\n"; + $elements++; + echo "\n"; + $elements++; + } + else + echo " "; + + echo ""; + $elements++; + echo "\n"; + $i++; + $attrs->moveNext(); + } + echo "
{$lang['strcolumn']}{$lang['strtype']}{$lang['strformat']}{$lang['strnull']}{$lang['strvalue']}
", $misc->printVal($attrs->fields['attname']), "\n"; + echo $misc->printVal($data->formatType($attrs->fields['type'], $attrs->fields['atttypmod'])); + echo "fields['attname']), "]\" value=\"", + htmlspecialchars($attrs->fields['type']), "\" />\n"; + echo "\n"; + // Output null box if the column allows nulls (doesn't look at CHECKs or ASSERTIONS) + if (!$attrs->fields['attnotnull']) { + // Set initial null values + if ($_REQUEST['action'] == 'confeditrow' && $rs->fields[$attrs->fields['attname']] === null) { + $_REQUEST['nulls'][$attrs->fields['attname']] = 'on'; + } + echo "fields['attnum']}\" style=\"white-space:nowrap;\">"; + + $extras = array(); + + // If the column allows nulls, then we put a JavaScript action on the data field to unset the + // NULL checkbox as soon as anything is entered in the field. We use the $elements variable to + // keep track of which element offset we're up to. We can't refer to the null checkbox by name + // as it contains '[' and ']' characters. + if (!$attrs->fields['attnotnull']) { + $extras['onChange'] = 'elements[' . ($elements - 1) . '].checked = false;'; + } + + if (($fksprops !== false) && isset($fksprops['byfield'][$attrs->fields['attnum']])) { + $extras['id'] = "attr_{$attrs->fields['attnum']}"; + $extras['autocomplete'] = 'off'; + } + + echo $data->printField("values[{$attrs->fields['attname']}]", $rs->fields[$attrs->fields['attname']], $attrs->fields['type'], $extras); + + echo "
\n"; + + $error = false; + } + elseif ($rs->recordCount() != 1) { + echo "

{$lang['strrownotunique']}

\n"; + } + else { + echo "

{$lang['strinvalidparam']}

\n"; + } + + echo "\n"; + echo $misc->form; + if (isset($_REQUEST['table'])) + echo "\n"; + if (isset($_REQUEST['subject'])) + echo "\n"; + if (isset($_REQUEST['query'])) + echo "\n"; + if (isset($_REQUEST['count'])) + echo "\n"; + if (isset($_REQUEST['return'])) + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

"; + if (!$error) echo "\n"; + echo "\n"; + + if($fksprops !== false) { + if ($conf['autocomplete'] != 'default off') + echo "\n"; + else + echo "\n"; + } + + echo "

\n"; + echo "
\n"; + } + else { + if (!isset($_POST['values'])) $_POST['values'] = array(); + if (!isset($_POST['nulls'])) $_POST['nulls'] = array(); + + $status = $data->editRow($_POST['table'], $_POST['values'], $_POST['nulls'], + $_POST['format'], $_POST['types'], $key); + if ($status == 0) + doBrowse($lang['strrowupdated']); + elseif ($status == -2) + doEditRow(true, $lang['strrownotunique']); + else + doEditRow(true, $lang['strrowupdatedbad']); + } + + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDelRow($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail($_REQUEST['subject']); + $misc->printTitle($lang['strdeleterow']); + + $rs = $data->browseRow($_REQUEST['table'], $_REQUEST['key']); + + echo "
\n"; + echo $misc->form; + + if ($rs->recordCount() == 1) { + echo "

{$lang['strconfdeleterow']}

\n"; + + $fkinfo = array(); + echo ""; + printTableHeaderCells($rs, false, true); + echo ""; + echo "\n"; + printTableRowCells($rs, $fkinfo, true); + echo "\n"; + echo "
\n"; + echo "
\n"; + + echo "\n"; + echo "\n"; + echo "\n"; + } + elseif ($rs->recordCount() != 1) { + echo "

{$lang['strrownotunique']}

\n"; + echo "\n"; + } + else { + echo "

{$lang['strinvalidparam']}

\n"; + echo "\n"; + } + if (isset($_REQUEST['table'])) + echo "\n"; + if (isset($_REQUEST['subject'])) + echo "\n"; + if (isset($_REQUEST['query'])) + echo "\n"; + if (isset($_REQUEST['count'])) + echo "\n"; + if (isset($_REQUEST['return'])) + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->deleteRow($_POST['table'], unserialize(urldecode($_POST['key']))); + if ($status == 0) + doBrowse($lang['strrowdeleted']); + elseif ($status == -2) + doBrowse($lang['strrownotunique']); + else + doBrowse($lang['strrowdeletedbad']); + } + + } + + /* build & return the FK information data structure + * used when deciding if a field should have a FK link or not*/ + function &getFKInfo() { + global $data, $misc, $lang; + + // Get the foreign key(s) information from the current table + $fkey_information = array('byconstr' => array(), 'byfield' => array()); + + if (isset($_REQUEST['table'])) { + $constraints = $data->getConstraintsWithFields($_REQUEST['table']); + if ($constraints->recordCount() > 0) { + + $fkey_information['common_url'] = $misc->getHREF('schema') .'&subject=table'; + + /* build the FK constraints data structure */ + while (!$constraints->EOF) { + $constr =& $constraints->fields; + if ($constr['contype'] == 'f') { + + if (!isset($fkey_information['byconstr'][$constr['conid']])) { + $fkey_information['byconstr'][$constr['conid']] = array ( + 'url_data' => 'table='. urlencode($constr['f_table']) .'&schema='. urlencode($constr['f_schema']), + 'fkeys' => array(), + 'consrc' => $constr['consrc'] + ); + } + + $fkey_information['byconstr'][$constr['conid']]['fkeys'][$constr['p_field']] = $constr['f_field']; + + if (!isset($fkey_information['byfield'][$constr['p_field']])) + $fkey_information['byfield'][$constr['p_field']] = array(); + + $fkey_information['byfield'][$constr['p_field']][] = $constr['conid']; + } + $constraints->moveNext(); + } + } + } + + return $fkey_information; + } + + /* Print table header cells + * @param $args - associative array for sort link parameters + * */ + function printTableHeaderCells(&$rs, $args, $withOid) { + global $misc, $data, $conf; + $j = 0; + + foreach ($rs->fields as $k => $v) { + + if (($k === $data->id) && ( !($withOid && $conf['show_oids']) )) { + $j++; + continue; + } + $finfo = $rs->fetchField($j); + + if ($args === false) { + echo "", $misc->printVal($finfo->name), "\n"; + } + else { + $args['page'] = $_REQUEST['page']; + $args['sortkey'] = $j + 1; + // Sort direction opposite to current direction, unless it's currently '' + $args['sortdir'] = ( + $_REQUEST['sortdir'] == 'asc' + and $_REQUEST['sortkey'] == ($j + 1) + ) ? 'desc' : 'asc'; + + $sortLink = http_build_query($args); + + echo "" + , $misc->printVal($finfo->name); + if($_REQUEST['sortkey'] == ($j + 1)) { + if($_REQUEST['sortdir'] == 'asc') + echo 'asc'; + else echo 'desc'; + } + echo "\n"; + } + $j++; + } + + reset($rs->fields); + } + + /* Print data-row cells */ + function printTableRowCells(&$rs, &$fkey_information, $withOid) { + global $data, $misc, $conf; + $j = 0; + + if (!isset($_REQUEST['strings'])) $_REQUEST['strings'] = 'collapsed'; + + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($j++); + + if (($k === $data->id) && ( !($withOid && $conf['show_oids']) )) continue; + elseif ($v !== null && $v == '') echo " "; + else { + echo ""; + + if (($v !== null) && isset($fkey_information['byfield'][$k])) { + foreach ($fkey_information['byfield'][$k] as $conid) { + + $query_params = $fkey_information['byconstr'][$conid]['url_data']; + + foreach ($fkey_information['byconstr'][$conid]['fkeys'] as $p_field => $f_field) { + $query_params .= '&'. urlencode("fkey[{$f_field}]") .'='. urlencode($rs->fields[$p_field]); + } + + /* $fkey_information['common_url'] is already urlencoded */ + $query_params .= '&'. $fkey_information['common_url']; + echo ""; + } + echo $misc->printVal($v, $finfo->type, array('null' => true, 'clip' => ($_REQUEST['strings']=='collapsed'), 'class' => 'fk_value')); + } else { + echo $misc->printVal($v, $finfo->type, array('null' => true, 'clip' => ($_REQUEST['strings']=='collapsed'))); + } + echo ""; + } + } + } + + /* Print the FK row, used in ajax requests */ + function doBrowseFK() { + global $data, $misc, $lang; + + $ops = array(); + foreach($_REQUEST['fkey'] as $x => $y) { + $ops[$x] = '='; + } + $query = $data->getSelectSQL($_REQUEST['table'], array(), $_REQUEST['fkey'], $ops); + $_REQUEST['query'] = $query; + + $fkinfo =& getFKInfo(); + + $max_pages = 1; + // Retrieve page from query. $max_pages is returned by reference. + $rs = $data->browseQuery('SELECT', $_REQUEST['table'], $_REQUEST['query'], + null, null, 1, 1, $max_pages); + + echo "\"[delete]\"icon('Delete') ."\" />\n"; + echo "
"; + + if (is_object($rs) && $rs->recordCount() > 0) { + /* we are browsing a referenced table here + * we should show OID if show_oids is true + * so we give true to withOid in functions bellow + * as 3rd paramter */ + + echo ""; + printTableHeaderCells($rs, false, true); + echo ""; + echo "\n"; + printTableRowCells($rs, $fkinfo, true); + echo "\n"; + echo "
\n"; + } + else + echo $lang['strnodata']; + + echo "
"; + + exit; + } + + /** + * Displays requested data + */ + function doBrowse($msg = '') { + global $data, $conf, $misc, $lang, $plugin_manager; + + $save_history = false; + // If current page is not set, default to first page + if (!isset($_REQUEST['page'])) + $_REQUEST['page'] = 1; + if (!isset($_REQUEST['nohistory'])) + $save_history = true; + + if (isset($_REQUEST['subject'])) { + $subject = $_REQUEST['subject']; + if (isset($_REQUEST[$subject])) $object = $_REQUEST[$subject]; + } + else { + $subject = ''; + } + + $misc->printTrail(isset($subject) ? $subject : 'database'); + $misc->printTabs($subject,'browse'); + + /* This code is used when browsing FK in pure-xHTML (without js) */ + if (isset($_REQUEST['fkey'])) { + $ops = array(); + foreach($_REQUEST['fkey'] as $x => $y) { + $ops[$x] = '='; + } + $query = $data->getSelectSQL($_REQUEST['table'], array(), $_REQUEST['fkey'], $ops); + $_REQUEST['query'] = $query; + } + + if (isset($object)) { + if (isset($_REQUEST['query'])) { + $_SESSION['sqlquery'] = $_REQUEST['query']; + $misc->printTitle($lang['strselect']); + $type = 'SELECT'; + } + else { + $type = 'TABLE'; + } + } else { + $misc->printTitle($lang['strqueryresults']); + /*we comes from sql.php, $_SESSION['sqlquery'] has been set there */ + $type = 'QUERY'; + } + + $misc->printMsg($msg); + + // If 'sortkey' is not set, default to '' + if (!isset($_REQUEST['sortkey'])) $_REQUEST['sortkey'] = ''; + + // If 'sortdir' is not set, default to '' + if (!isset($_REQUEST['sortdir'])) $_REQUEST['sortdir'] = ''; + + // If 'strings' is not set, default to collapsed + if (!isset($_REQUEST['strings'])) $_REQUEST['strings'] = 'collapsed'; + + // Fetch unique row identifier, if this is a table browse request. + if (isset($object)) + $key = $data->getRowIdentifier($object); + else + $key = array(); + + // Set the schema search path + if (isset($_REQUEST['search_path'])) { + if ($data->setSearchPath(array_map('trim',explode(',',$_REQUEST['search_path']))) != 0) { + return; + } + } + + // Retrieve page from query. $max_pages is returned by reference. + $rs = $data->browseQuery($type, + isset($object) ? $object : null, + isset($_SESSION['sqlquery']) ? $_SESSION['sqlquery'] : null, + $_REQUEST['sortkey'], $_REQUEST['sortdir'], $_REQUEST['page'], + $conf['max_rows'], $max_pages); + + $fkey_information =& getFKInfo(); + + // Build strings for GETs in array + $_gets = array( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'] + ); + + if (isset($_REQUEST['schema'])) $_gets['schema'] = $_REQUEST['schema']; + if (isset($object)) $_gets[$subject] = $object; + if (isset($subject)) $_gets['subject'] = $subject; + if (isset($_REQUEST['query'])) $_gets['query'] = $_REQUEST['query']; + if (isset($_REQUEST['count'])) $_gets['count'] = $_REQUEST['count']; + if (isset($_REQUEST['return'])) $_gets['return'] = $_REQUEST['return']; + if (isset($_REQUEST['search_path'])) $_gets['search_path'] = $_REQUEST['search_path']; + if (isset($_REQUEST['table'])) $_gets['table'] = $_REQUEST['table']; + if (isset($_REQUEST['sortkey'])) $_gets['sortkey'] = $_REQUEST['sortkey']; + if (isset($_REQUEST['sortdir'])) $_gets['sortdir'] = $_REQUEST['sortdir']; + if (isset($_REQUEST['nohistory'])) $_gets['nohistory'] = $_REQUEST['nohistory']; + $_gets['strings'] = $_REQUEST['strings']; + + if ($save_history && is_object($rs) && ($type == 'QUERY')) //{ + $misc->saveScriptHistory($_REQUEST['query']); + + echo '

'; + + if (is_object($rs) && $rs->recordCount() > 0) { + // Show page navigation + $misc->printPages($_REQUEST['page'], $max_pages, $_gets); + + echo "\n"; + + // Check that the key is actually in the result set. This can occur for select + // operations where the key fields aren't part of the select. XXX: We should + // be able to support this, somehow. + foreach ($key as $v) { + // If a key column is not found in the record set, then we + // can't use the key. + if (!in_array($v, array_keys($rs->fields))) { + $key = array(); + break; + } + } + + $buttons = array( + 'edit' => array ( + 'content' => $lang['stredit'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array_merge(array ( + 'action' => 'confeditrow', + 'strings' => $_REQUEST['strings'], + 'page' => $_REQUEST['page'], + ), $_gets) + ) + ) + ), + 'delete' => array ( + 'content' => $lang['strdelete'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array_merge(array ( + 'action' => 'confdelrow', + 'strings' => $_REQUEST['strings'], + 'page' => $_REQUEST['page'], + ), $_gets) + ) + ) + ), + ); + $actions = array( + 'actionbuttons' => &$buttons, + 'place' => 'display-browse' + ); + $plugin_manager->do_hook('actionbuttons', $actions); + + foreach (array_keys($actions['actionbuttons']) as $action) { + $actions['actionbuttons'][$action]['attr']['href']['urlvars'] = array_merge( + $actions['actionbuttons'][$action]['attr']['href']['urlvars'], + $_gets + ); + } + + $edit_params = isset($actions['actionbuttons']['edit'])? + $actions['actionbuttons']['edit']:array(); + $delete_params = isset($actions['actionbuttons']['delete'])? + $actions['actionbuttons']['delete']:array(); + + // Display edit and delete actions if we have a key + $colspan = count($buttons); + if ($colspan > 0 and count($key) > 0) + echo "\n"; + + /* we show OIDs only if we are in TABLE or SELECT type browsing */ + printTableHeaderCells($rs, $_gets, isset($object)); + + echo "\n"; + + $i = 0; + reset($rs->fields); + while (!$rs->EOF) { + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + // Display edit and delete links if we have a key + if ($colspan > 0 and count($key) > 0) { + $keys_array = array(); + $has_nulls = false; + foreach ($key as $v) { + if ($rs->fields[$v] === null) { + $has_nulls = true; + break; + } + $keys_array["key[{$v}]"] = $rs->fields[$v]; + } + if ($has_nulls) { + echo "\n"; + } else { + + if (isset($actions['actionbuttons']['edit'])) { + $actions['actionbuttons']['edit'] = $edit_params; + $actions['actionbuttons']['edit']['attr']['href']['urlvars'] = array_merge( + $actions['actionbuttons']['edit']['attr']['href']['urlvars'], + $keys_array + ); + } + + if (isset($actions['actionbuttons']['delete'])) { + $actions['actionbuttons']['delete'] = $delete_params; + $actions['actionbuttons']['delete']['attr']['href']['urlvars'] = array_merge( + $actions['actionbuttons']['delete']['attr']['href']['urlvars'], + $keys_array + ); + } + + foreach ($actions['actionbuttons'] as $action) { + echo "\n"; + } + } + } + + print printTableRowCells($rs, $fkey_information, isset($object)); + + echo "\n"; + $rs->moveNext(); + $i++; + } + echo "
{$lang['stractions']}
 "; + $misc->printLink($action); + echo "
\n"; + + echo "

", $rs->recordCount(), " {$lang['strrows']}

\n"; + // Show page navigation + $misc->printPages($_REQUEST['page'], $max_pages, $_gets); + } + else echo "

{$lang['strnodata']}

\n"; + + // Navigation links + $navlinks = array(); + + $fields = array( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + ); + + if (isset($_REQUEST['schema'])) + $fields['schema'] = $_REQUEST['schema']; + + // Return + if (isset($_REQUEST['return'])) { + $urlvars = $misc->getSubjectParams($_REQUEST['return']); + + $navlinks['back'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => $urlvars['url'], + 'urlvars' => $urlvars['params'] + ) + ), + 'content' => $lang['strback'] + ); + } + + // Edit SQL link + if ($type == 'QUERY') + $navlinks['edit'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'database.php', + 'urlvars' => array_merge($fields, array ( + 'action' => 'sql', + 'paginate' => 'on', + )) + ) + ), + 'content' => $lang['streditsql'] + ); + + // Expand/Collapse + if ($_REQUEST['strings'] == 'expanded') + $navlinks['collapse'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array_merge( + $_gets, + array ( + 'strings' => 'collapsed', + 'page' => $_REQUEST['page'] + )) + ) + ), + 'content' => $lang['strcollapse'] + ); + else + $navlinks['collapse'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array_merge( + $_gets, + array ( + 'strings' => 'expanded', + 'page' => $_REQUEST['page'] + )) + ) + ), + 'content' => $lang['strexpand'] + ); + + // Create view and download + if (isset($_REQUEST['query']) && isset($rs) && is_object($rs) && $rs->recordCount() > 0) { + + + // Report views don't set a schema, so we need to disable create view in that case + if (isset($_REQUEST['schema'])) { + + $navlinks['createview'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array_merge($fields, array( + 'action' => 'create', + 'formDefinition' => $_REQUEST['query'] + )) + ) + ), + 'content' => $lang['strcreateview'] + ); + } + + $urlvars = array(); + if (isset($_REQUEST['search_path'])) + $urlvars['search_path'] = $_REQUEST['search_path']; + + $navlinks['download'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'dataexport.php', + 'urlvars' => array_merge($fields, $urlvars) + ) + ), + 'content' => $lang['strdownload'] + ); + } + + // Insert + if (isset($object) && (isset($subject) && $subject == 'table')) + $navlinks['insert'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array_merge($fields, array( + 'action' => 'confinsertrow', + 'table' => $object + )) + ) + ), + 'content' => $lang['strinsert'] + ); + + // Refresh + $navlinks['refresh'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array_merge( + $_gets, + array( + 'strings' => $_REQUEST['strings'], + 'page' => $_REQUEST['page'] + )) + ) + ), + 'content' => $lang['strrefresh'] + ); + + $misc->printNavLinks($navlinks, 'display-browse', get_defined_vars()); + } + + + /* shortcuts: this function exit the script for ajax purpose */ + if ($action == 'dobrowsefk') { + doBrowseFK(); + } + + $scripts = ""; + + $scripts .= "\n"; + + // Set the title based on the subject of the request + if (isset($_REQUEST['subject']) && isset($_REQUEST[$_REQUEST['subject']])) { + if ($_REQUEST['subject'] == 'table') { + $misc->printHeader( + $lang['strtables'].': '.$_REQUEST[$_REQUEST['subject']], + $scripts + ); + } + else if ($_REQUEST['subject'] == 'view') { + $misc->printHeader( + $lang['strviews'].': '.$_REQUEST[$_REQUEST['subject']], + $scripts + ); + } + else if ($_REQUEST['subject'] == 'column') { + $misc->printHeader( + $lang['strcolumn'].': '.$_REQUEST[$_REQUEST['subject']], + $scripts + ); + } + } + else + $misc->printHeader($lang['strqueryresults']); + + $misc->printBody(); + + switch ($action) { + case 'editrow': + if (isset($_POST['save'])) doEditRow(false); + else doBrowse(); + break; + case 'confeditrow': + doEditRow(true); + break; + case 'delrow': + if (isset($_POST['yes'])) doDelRow(false); + else doBrowse(); + break; + case 'confdelrow': + doDelRow(true); + break; + default: + doBrowse(); + break; + } + + $misc->printFooter(); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/domains.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/domains.php new file mode 100644 index 00000000..a9b7e992 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/domains.php @@ -0,0 +1,587 @@ +alterDomain($_POST['domain'], $_POST['domdefault'], + isset($_POST['domnotnull']), $_POST['domowner']); + if ($status == 0) + doProperties($lang['strdomainaltered']); + else + doAlter($lang['strdomainalteredbad']); + } + + /** + * Allow altering a domain + */ + function doAlter($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('domain'); + $misc->printTitle($lang['stralter'],'pg.domain.alter'); + $misc->printMsg($msg); + + // Fetch domain info + $domaindata = $data->getDomain($_REQUEST['domain']); + // Fetch all users + $users = $data->getUsers(); + + if ($domaindata->recordCount() > 0) { + if (!isset($_POST['domname'])) { + $_POST['domtype'] = $domaindata->fields['domtype']; + $_POST['domdefault'] = $domaindata->fields['domdef']; + $domaindata->fields['domnotnull'] = $data->phpBool($domaindata->fields['domnotnull']); + if ($domaindata->fields['domnotnull']) $_POST['domnotnull'] = 'on'; + $_POST['domowner'] = $domaindata->fields['domowner']; + } + + // Display domain info + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}", $misc->printVal($domaindata->fields['domname']), "
{$lang['strtype']}", $misc->printVal($domaindata->fields['domtype']), "
{$lang['strdefault']}
{$lang['strowner']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Confirm and then actually add a CHECK constraint + */ + function addCheck($confirm, $msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['name'])) $_POST['name'] = ''; + if (!isset($_POST['definition'])) $_POST['definition'] = ''; + + if ($confirm) { + $misc->printTrail('domain'); + $misc->printTitle($lang['straddcheck'],'pg.constraint.check'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + echo "\n"; + + echo "\n"; + echo "
{$lang['strname']}{$lang['strdefinition']}
_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />()
\n"; + + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + + } + else { + if (trim($_POST['definition']) == '') + addCheck(true, $lang['strcheckneedsdefinition']); + else { + $status = $data->addDomainCheckConstraint($_POST['domain'], + $_POST['definition'], $_POST['name']); + if ($status == 0) + doProperties($lang['strcheckadded']); + else + addCheck(true, $lang['strcheckaddedbad']); + } + } + } + + /** + * Show confirmation of drop constraint and perform actual drop + */ + function doDropConstraint($confirm, $msg = '') { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('domain'); + $misc->printTitle($lang['strdrop'],'pg.constraint.drop'); + $misc->printMsg($msg); + + echo "

", sprintf($lang['strconfdropconstraint'], $misc->printVal($_REQUEST['constraint']), + $misc->printVal($_REQUEST['domain'])), "

\n"; + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropDomainConstraint($_POST['domain'], $_POST['constraint'], isset($_POST['cascade'])); + if ($status == 0) + doProperties($lang['strconstraintdropped']); + else + doDropConstraint(true, $lang['strconstraintdroppedbad']); + } + + } + + /** + * Show properties for a domain. Allow manipulating constraints as well. + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('domain'); + $misc->printTitle($lang['strproperties'],'pg.domain'); + $misc->printMsg($msg); + + $domaindata = $data->getDomain($_REQUEST['domain']); + + if ($domaindata->recordCount() > 0) { + // Show comment if any + if ($domaindata->fields['domcomment'] !== null) + echo "

", $misc->printVal($domaindata->fields['domcomment']), "

\n"; + + // Display domain info + $domaindata->fields['domnotnull'] = $data->phpBool($domaindata->fields['domnotnull']); + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}", $misc->printVal($domaindata->fields['domname']), "
{$lang['strtype']}", $misc->printVal($domaindata->fields['domtype']), "
{$lang['strnotnull']}", ($domaindata->fields['domnotnull'] ? 'NOT NULL' : ''), "
{$lang['strdefault']}", $misc->printVal($domaindata->fields['domdef']), "
{$lang['strowner']}", $misc->printVal($domaindata->fields['domowner']), "
\n"; + + // Display domain constraints + echo "

{$lang['strconstraints']}

\n"; + if ($data->hasDomainConstraints()) { + $domaincons = $data->getDomainConstraints($_REQUEST['domain']); + + $columns = array ( + 'name' => array ( + 'title' => $lang['strname'], + 'field' => field('conname') + ), + 'definition' => array ( + 'title' => $lang['strdefinition'], + 'field' => field('consrc'), + ), + 'actions' => array ( + 'title' => $lang['stractions'], + ) + ); + + $actions = array ( + 'drop' => array ( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'confirm_drop_con', + 'domain' => $_REQUEST['domain'], + 'constraint' => field('conname'), + 'type' => field('contype'), + ) + ) + ) + ) + ); + + $misc->printTable($domaincons, $columns, $actions, 'domains-properties', $lang['strnodata']); + } + } + else echo "

{$lang['strnodata']}

\n"; + + $navlinks = array ( + 'drop' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'domain' => $_REQUEST['domain'] + ) + ) + ), + 'content' => $lang['strdrop'] + ) + ); + if ($data->hasAlterDomains()) { + $navlinks['addcheck'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'add_check', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'domain' => $_REQUEST['domain'] + ) + ) + ), + 'content' => $lang['straddcheck'] + ); + $navlinks['alter'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'domain' => $_REQUEST['domain'] + ) + ) + ), + 'content' => $lang['stralter'] + ); + } + + $misc->printNavLinks($navlinks, 'domains-properties', get_defined_vars()); + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('domain'); + $misc->printTitle($lang['strdrop'],'pg.domain.drop'); + + echo "

", sprintf($lang['strconfdropdomain'], $misc->printVal($_REQUEST['domain'])), "

\n"; + echo "
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropDomain($_POST['domain'], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['strdomaindropped']); + else + doDefault($lang['strdomaindroppedbad']); + } + + } + + /** + * Displays a screen where they can enter a new domain + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['domname'])) $_POST['domname'] = ''; + if (!isset($_POST['domtype'])) $_POST['domtype'] = ''; + if (!isset($_POST['domlength'])) $_POST['domlength'] = ''; + if (!isset($_POST['domarray'])) $_POST['domarray'] = ''; + if (!isset($_POST['domdefault'])) $_POST['domdefault'] = ''; + if (!isset($_POST['domcheck'])) $_POST['domcheck'] = ''; + + $types = $data->getTypes(true); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatedomain'],'pg.domain.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + if ($data->hasDomainConstraints()) { + echo "\n"; + echo "\n"; + } + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['domname']), "\" />
{$lang['strtype']}\n"; + // Output return type list + echo "\n"; + + // Type length + echo ""; + + // Output array type selector + echo "
{$lang['strdefault']}
{$lang['strconstraints']}CHECK ()
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new domain in the database + */ + function doSaveCreate() { + global $data, $lang; + + if (!isset($_POST['domcheck'])) $_POST['domcheck'] = ''; + + // Check that they've given a name and a definition + if ($_POST['domname'] == '') doCreate($lang['strdomainneedsname']); + else { + $status = $data->createDomain($_POST['domname'], $_POST['domtype'], $_POST['domlength'], $_POST['domarray'] != '', + isset($_POST['domnotnull']), $_POST['domdefault'], $_POST['domcheck']); + if ($status == 0) + doDefault($lang['strdomaincreated']); + else + doCreate($lang['strdomaincreatedbad']); + } + } + + /** + * Show default list of domains in the database + */ + function doDefault($msg = '') { + global $data, $conf, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','domains'); + $misc->printMsg($msg); + + $domains = $data->getDomains(); + + $columns = array( + 'domain' => array( + 'title' => $lang['strdomain'], + 'field' => field('domname'), + 'url' => "domains.php?action=properties&{$misc->href}&", + 'vars' => array('domain' => 'domname'), + ), + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('domtype'), + ), + 'notnull' => array( + 'title' => $lang['strnotnull'], + 'field' => field('domnotnull'), + 'type' => 'bool', + 'params'=> array('true' => 'NOT NULL', 'false' => ''), + ), + 'default' => array( + 'title' => $lang['strdefault'], + 'field' => field('domdef'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('domowner'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('domcomment'), + ), + ); + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'alter', + 'domain' => field('domname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'domain' => field('domname') + ) + ) + ) + ), + ); + + if (!$data->hasAlterDomains()) unset($actions['alter']); + + $misc->printTable($domains, $columns, $actions, 'domains-domains', $lang['strnodomains']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'domains.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + ) + ) + ), + 'content' => $lang['strcreatedomain'] + ) + ); + $misc->printNavLinks($navlinks, 'domains-domains', get_defined_vars()); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $domains = $data->getDomains(); + + $reqvars = $misc->getRequestVars('domain'); + + $attrs = array( + 'text' => field('domname'), + 'icon' => 'Domain', + 'toolTip'=> field('domcomment'), + 'action' => url('domains.php', + $reqvars, + array( + 'action' => 'properties', + 'domain' => field('domname') + ) + ) + ); + + $misc->printTree($domains, $attrs, 'domains'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strdomains']); + $misc->printBody(); + + switch ($action) { + case 'add_check': + addCheck(true); + break; + case 'save_add_check': + if (isset($_POST['cancel'])) doProperties(); + else addCheck(false); + break; + case 'drop_con': + if (isset($_POST['drop'])) doDropConstraint(false); + else doProperties(); + break; + case 'confirm_drop_con': + doDropConstraint(true); + break; + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'save_alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doProperties(); + break; + case 'alter': + doAlter(); + break; + case 'properties': + doProperties(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/fulltext.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/fulltext.php new file mode 100644 index 00000000..da8b92b0 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/fulltext.php @@ -0,0 +1,1120 @@ +printTrail('schema'); + $misc->printTabs('schema','fulltext'); + $misc->printTabs('fulltext','ftsconfigs'); + $misc->printMsg($msg); + + $cfgs = $data->getFtsConfigurations(false); + + $columns = array( + 'configuration' => array( + 'title' => $lang['strftsconfig'], + 'field' => field('name'), + 'url' => "fulltext.php?action=viewconfig&{$misc->href}&", + 'vars' => array('ftscfg' => 'name'), + ), + 'schema' => array( + 'title' => $lang['strschema'], + 'field' => field('schema'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('comment'), + ), + ); + + $actions = array( + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'dropconfig', + 'ftscfg' => field('name') + ) + ) + ) + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'alterconfig', + 'ftscfg' => field('name') + ) + ) + ) + ), + ); + + $misc->printTable($cfgs, $columns, $actions, 'fulltext-fulltext', $lang['strftsnoconfigs']); + + $navlinks = array( + 'createconf' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'createconfig', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strftscreateconfig'] + ) + ); + + $misc->printNavLinks($navlinks, 'fulltext-fulltext', get_defined_vars()); + } + + function doDropConfig($confirm) { + global $data, $data, $misc; + global $lang, $_reload_browser; + + if ($confirm) { + $misc->printTrail('ftscfg'); + $misc->printTitle($lang['strdrop'], 'pg.ftscfg.drop'); + + echo "

", sprintf($lang['strconfdropftsconfig'], $misc->printVal($_REQUEST['ftscfg'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropFtsConfiguration($_POST['ftscfg'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strftsconfigdropped']); + } + else + doDefault($lang['strftsconfigdroppedbad']); + } + + } + + function doDropDict($confirm) { + global $data, $data, $misc; + global $lang, $_reload_browser; + + if ($confirm) { + $misc->printTrail('ftscfg'); // TODO: change to smth related to dictionary + $misc->printTitle($lang['strdrop'], 'pg.ftsdict.drop'); + + echo "

", sprintf($lang['strconfdropftsdict'], $misc->printVal($_REQUEST['ftsdict'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + //echo "\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropFtsDictionary($_POST['ftsdict'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doViewDicts($lang['strftsdictdropped']); + } + else + doViewDicts($lang['strftsdictdroppedbad']); + } + + } + + /** + * Displays a screen where one can enter a new FTS configuration + */ + function doCreateConfig($msg = '') { + global $data, $misc; + global $lang; + + include_once('./classes/Gui.php'); + + $server_info = $misc->getServerInfo(); + + if (!isset($_POST['formName'])) $_POST['formName'] = ''; + if (!isset($_POST['formParser'])) $_POST['formParser'] = ''; + if (!isset($_POST['formTemplate'])) $_POST['formTemplate'] = ''; + if (!isset($_POST['formWithMap'])) $_POST['formWithMap'] = ''; + if (!isset($_POST['formComment'])) $_POST['formComment'] = ''; + + // Fetch all FTS configurations from the database + $ftscfgs = $data->getFtsConfigurations(); + // Fetch all FTS parsers from the database + $ftsparsers = $data->getFtsParsers(); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strftscreateconfig'], 'pg.ftscfg.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + /* conf name */ + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Template + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Parser + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Comment + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formName']), "\" />
{$lang['strftstemplate']}"; + + $tpls = array(); + $tplsel = ''; + while (!$ftscfgs->EOF) { + $data->fieldClean($ftscfgs->fields['schema']); + $data->fieldClean($ftscfgs->fields['name']); + $tplname = $ftscfgs->fields['schema'] .'.'. $ftscfgs->fields['name']; + $tpls[$tplname] = serialize(array( + 'name' => $ftscfgs->fields['name'], + 'schema' => $ftscfgs->fields['schema'] + )); + if ($_POST['formTemplate'] == $tpls[$tplname]) { + $tplsel = htmlspecialchars($tpls[$tplname]); + } + $ftscfgs->moveNext(); + } + echo GUI::printCombo($tpls, 'formTemplate', true, $tplsel, false); + echo "\n\t\t
{$lang['strftsparser']}\n"; + $ftsparsers_ = array(); + $ftsparsel = ''; + while (!$ftsparsers->EOF) { + $data->fieldClean($ftsparsers->fields['schema']); + $data->fieldClean($ftsparsers->fields['name']); + $parsername = $ftsparsers->fields['schema'] .'.'. $ftsparsers->fields['name']; + + $ftsparsers_[$parsername] = serialize(array( + 'parser' => $ftsparsers->fields['name'], + 'schema' => $ftsparsers->fields['schema'] + )); + if ($_POST['formParser'] == $ftsparsers_[$parsername]) { + $ftsparsel = htmlspecialchars($ftsparsers_[$parsername]); + } + $ftsparsers->moveNext(); + } + echo GUI::printCombo($ftsparsers_, 'formParser', true, $ftsparsel, false); + echo "\n\t\t
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new FTS configuration in the database + */ + function doSaveCreateConfig() { + global $data, $lang, $_reload_browser; + + $err = ''; + // Check that they've given a name + if ($_POST['formName'] == '') $err .= "{$lang['strftsconfigneedsname']}
"; + if (($_POST['formParser'] != '') && ($_POST['formTemplate'] != '')) $err .= "{$lang['strftscantparsercopy']}
"; + + if ($err != '') return doCreateConfig($err); + + if ($_POST['formParser'] != '') $formParser = unserialize($_POST['formParser']); + else $formParser = ''; + if ($_POST['formTemplate'] != '') $formTemplate = unserialize($_POST['formTemplate']); + else $formTemplate = ''; + + $status = $data->createFtsConfiguration($_POST['formName'], $formParser, $formTemplate, $_POST['formComment']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strftsconfigcreated']); + } + else + doCreateConfig($lang['strftsconfigcreatedbad']); + } + + /** + * Display a form to permit editing FTS configuration properies. + */ + function doAlterConfig($msg = '') { + global $data, $misc, $lang; + + $misc->printTrail('ftscfg'); + $misc->printTitle($lang['stralter'], 'pg.ftscfg.alter'); + $misc->printMsg($msg); + + $ftscfg = $data->getFtsConfigurationByName($_REQUEST['ftscfg']); + if ($ftscfg->recordCount() > 0) { + if (!isset($_POST['formComment'])) $_POST['formComment'] = $ftscfg->fields['comment']; + if (!isset($_POST['ftscfg'])) $_POST['ftscfg'] = $_REQUEST['ftscfg']; + if (!isset($_POST['formName'])) $_POST['formName'] = $_REQUEST['ftscfg']; + if (!isset($_POST['formParser'])) $_POST['formParser'] = ''; + + // Fetch all FTS parsers from the database + $ftsparsers = $data->getFtsParsers(); + + echo "
\n"; + echo "\n"; + + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + // Comment + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + echo "
{$lang['strname']}"; + echo "\t\t\t_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formName']), "\" />\n"; + echo "\t\t
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } else { + echo "

{$lang['strnodata']}

\n"; + } + } + + /** + * Save the form submission containing changes to a FTS configuration + */ + function doSaveAlterConfig() { + global $data, $misc, $lang; + + $status = $data->updateFtsConfiguration($_POST['ftscfg'], $_POST['formComment'], $_POST['formName']); + if ($status == 0) + doDefault($lang['strftsconfigaltered']); + else + doAlterConfig($lang['strftsconfigalteredbad']); + } + + /** + * View list of FTS parsers + */ + function doViewParsers($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','fulltext'); + $misc->printTabs('fulltext','ftsparsers'); + $misc->printMsg($msg); + + $parsers = $data->getFtsParsers(false); + + $columns = array( + 'schema' => array( + 'title' => $lang['strschema'], + 'field' => field('schema'), + ), + 'name' => array( + 'title' => $lang['strname'], + 'field' => field('name'), + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('comment'), + ), + ); + + $actions = array(); + + $misc->printTable($parsers, $columns, $actions, 'fulltext-viewparsers', $lang['strftsnoparsers']); + + //TODO: navlink to "create parser" + } + + + /** + * View list of FTS dictionaries + */ + function doViewDicts($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','fulltext'); + $misc->printTabs('fulltext','ftsdicts'); + $misc->printMsg($msg); + + $dicts = $data->getFtsDictionaries(false); + + $columns = array( + 'schema' => array( + 'title' => $lang['strschema'], + 'field' => field('schema'), + ), + 'name' => array( + 'title' => $lang['strname'], + 'field' => field('name'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('comment'), + ), + ); + + $actions = array( + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'dropdict', + 'ftsdict' => field('name') + ) + ) + ) + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'alterdict', + 'ftsdict' => field('name') + ) + ) + ) + ), + ); + + $misc->printTable($dicts, $columns, $actions, 'fulltext-viewdicts', $lang['strftsnodicts']); + + $navlinks = array( + 'createdict' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'createdict', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + ) + ) + ), + 'content' => $lang['strftscreatedict'] + ) + ); + + $misc->printNavLinks($navlinks, 'fulltext-viewdicts', get_defined_vars()); + } + + + /** + * View details of FTS configuration given + */ + function doViewConfig($ftscfg, $msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('ftscfg'); + $misc->printTabs('schema','fulltext'); + $misc->printTabs('fulltext','ftsconfigs'); + $misc->printMsg($msg); + + echo "

{$lang['strftsconfigmap']}

\n"; + + $map = $data->getFtsConfigurationMap($ftscfg); + + $columns = array( + 'name' => array( + 'title' => $lang['strftsmapping'], + 'field' => field('name'), + ), + 'dictionaries' => array( + 'title' => $lang['strftsdicts'], + 'field' => field('dictionaries'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('description'), + ), + ); + + $actions = array( + 'drop' => array( + 'multiaction' => 'dropmapping', + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'dropmapping', + 'mapping' => field('name'), + 'ftscfg' => field('cfgname') + ) + ) + ) + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'altermapping', + 'mapping' => field('name'), + 'ftscfg' => field('cfgname') + ) + ) + ) + ), + 'multiactions' => array( + 'keycols' => array('mapping' => 'name'), + 'url' => 'fulltext.php', + 'default' => null, + 'vars' => array('ftscfg' => $ftscfg), + ), + + ); + + $misc->printTable($map, $columns, $actions, 'fulltext-viewconfig', $lang['strftsemptymap']); + + $navlinks = array( + 'addmapping' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'fulltext.php', + 'urlvars' => array ( + 'action' => 'addmapping', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'ftscfg' => $ftscfg + ) + ) + ), + 'content' => $lang['strftsaddmapping'] + ) + ); + + $misc->printNavLinks($navlinks, 'fulltext-viewconfig', get_defined_vars()); + } + + /** + * Displays a screen where one can enter a details of a new FTS dictionary + */ + function doCreateDict($msg = '') { + global $data, $misc; + global $lang; + + include_once('./classes/Gui.php'); + + $server_info = $misc->getServerInfo(); + + if (!isset($_POST['formName'])) $_POST['formName'] = ''; + if(!isset($_POST['formIsTemplate'])) $_POST['formIsTemplate'] = false; + if (!isset($_POST['formTemplate'])) $_POST['formTemplate'] = ''; + if (!isset($_POST['formLexize'])) $_POST['formLexize'] = ''; + if (!isset($_POST['formInit'])) $_POST['formInit'] = ''; + if (!isset($_POST['formOption'])) $_POST['formOption'] = ''; + if (!isset($_POST['formComment'])) $_POST['formComment'] = ''; + + // Fetch all FTS dictionaries from the database + $ftstpls = $data->getFtsDictionaryTemplates(); + + $misc->printTrail('schema'); + // TODO: create doc links + $misc->printTitle($lang['strftscreatedict'], 'pg.ftsdict.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Template + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // TODO: what about maxlengths? + // Lexize + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Init + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Option + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Comment + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formName']), "\" /> ", + "\n", + "
{$lang['strftstemplate']}"; + $tpls = array(); + $tplsel = ''; + while (!$ftstpls->EOF) { + $data->fieldClean($ftstpls->fields['schema']); + $data->fieldClean($ftstpls->fields['name']); + $tplname = $ftstpls->fields['schema'] .'.'. $ftstpls->fields['name']; + $tpls[$tplname] = serialize(array( + 'name' => $ftstpls->fields['name'], + 'schema' => $ftstpls->fields['schema'] + )); + if ($_POST['formTemplate'] == $tpls[$tplname]) { + $tplsel = htmlspecialchars($tpls[$tplname]); + } + $ftstpls->moveNext(); + } + echo GUI::printCombo($tpls, 'formTemplate', true, $tplsel, false); + echo "\n\t\t
{$lang['strftslexize']}
{$lang['strftsinit']}
{$lang['strftsoptionsvalues']}
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n", + "\n"; + } + + /** + * Actually creates the new FTS dictionary in the database + */ + function doSaveCreateDict() { + global $data, $lang, $_reload_browser; + + // Check that they've given a name + if ($_POST['formName'] == '') doCreateDict($lang['strftsdictneedsname']); + else { + + if(!isset($_POST['formIsTemplate'])) $_POST['formIsTemplate'] = false; + if(isset($_POST['formTemplate'])) + $formTemplate = unserialize($_POST['formTemplate']); + else + $formTemplate = ''; + if(!isset($_POST['formLexize'])) $_POST['formLexize'] = ''; + if(!isset($_POST['formInit'])) $_POST['formInit'] = ''; + if(!isset($_POST['formOption'])) $_POST['formOption'] = ''; + + $status = $data->createFtsDictionary($_POST['formName'], $_POST['formIsTemplate'], + $formTemplate, $_POST['formLexize'], + $_POST['formInit'], $_POST['formOption'], $_POST['formComment'] + ); + + if ($status == 0) { + $_reload_browser = true; + doViewDicts($lang['strftsdictcreated']); + } + else + doCreateDict($lang['strftsdictcreatedbad']); + } + } + + /** + * Display a form to permit editing FTS dictionary properies. + */ + function doAlterDict($msg = '') { + global $data, $misc, $lang; + + $misc->printTrail('ftscfg'); // TODO: change to smth related to dictionary + $misc->printTitle($lang['stralter'], 'pg.ftsdict.alter'); + $misc->printMsg($msg); + + $ftsdict = $data->getFtsDictionaryByName($_REQUEST['ftsdict']); + if ($ftsdict->recordCount() > 0) { + if (!isset($_POST['formComment'])) $_POST['formComment'] = $ftsdict->fields['comment']; + if (!isset($_POST['ftsdict'])) $_POST['ftsdict'] = $_REQUEST['ftsdict']; + if (!isset($_POST['formName'])) $_POST['formName'] = $_REQUEST['ftsdict']; + + echo "
\n"; + echo "\n"; + + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + // Comment + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + echo "
{$lang['strname']}"; + echo "\t\t\t_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formName']), "\" />\n"; + echo "\t\t
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } else { + echo "

{$lang['strnodata']}

\n"; + } + } + + /** + * Save the form submission containing changes to a FTS dictionary + */ + function doSaveAlterDict() { + global $data, $misc, $lang; + + $status = $data->updateFtsDictionary($_POST['ftsdict'], $_POST['formComment'], $_POST['formName']); + if ($status == 0) + doViewDicts($lang['strftsdictaltered']); + else + doAlterDict($lang['strftsdictalteredbad']); + } + + /** + * Show confirmation of drop and perform actual drop of FTS mapping + */ + function doDropMapping($confirm) { + global $data, $misc; + global $lang, $_reload_drop_database; + + if (empty($_REQUEST['mapping']) && empty($_REQUEST['ma'])) { + doDefault($lang['strftsspecifymappingtodrop']); + return; + } + + if (empty($_REQUEST['ftscfg'])) { + doDefault($lang['strftsspecifyconfigtoalter']); + return; + } + + if ($confirm) { + $misc->printTrail('ftscfg'); // TODO: proper breadcrumbs + $misc->printTitle($lang['strdrop'], 'pg.ftscfg.alter'); + + echo "
\n"; + + // Case of multiaction drop + if (isset($_REQUEST['ma'])) { + + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfdropftsmapping'], $misc->printVal($a['mapping']), $misc->printVal($_REQUEST['ftscfg'])), "

\n"; + printf('', htmlspecialchars($a['mapping'])); + } + + } else { + echo "

", sprintf($lang['strconfdropftsmapping'], $misc->printVal($_REQUEST['mapping']), $misc->printVal($_REQUEST['ftscfg'])), "

\n"; + echo "\n"; + } + + echo "\n"; + echo "\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } else { + // Case of multiaction drop + if (is_array($_REQUEST['mapping'])) { + $status = $data->changeFtsMapping($_REQUEST['ftscfg'], $_REQUEST['mapping'], 'drop'); + if ($status != 0) { + doViewConfig($_REQUEST['ftscfg'], $lang['strftsmappingdroppedbad']); + return; + } + doViewConfig($_REQUEST['ftscfg'], $lang['strftsmappingdropped']); + } else { + $status = $data->changeFtsMapping($_REQUEST['ftscfg'], array($_REQUEST['mapping']), 'drop'); + if ($status == 0) { + doViewConfig($_REQUEST['ftscfg'], $lang['strftsmappingdropped']); + } else { + doViewConfig($_REQUEST['ftscfg'], $lang['strftsmappingdroppedbad']); + } + } + } + } + + function doAlterMapping($msg = '') { + global $data, $misc, $lang; + + $misc->printTrail('ftscfg'); + $misc->printTitle($lang['stralter'], 'pg.ftscfg.alter'); + $misc->printMsg($msg); + + $ftsdicts = $data->getFtsDictionaries(); + if ($ftsdicts->recordCount() > 0) { + if (!isset($_POST['formMapping'])) $_POST['formMapping'] = @$_REQUEST['mapping']; + if (!isset($_POST['formDictionary'])) $_POST['formDictionary'] = ''; + if (!isset($_POST['ftscfg'])) $_POST['ftscfg'] = $_REQUEST['ftscfg']; + + echo "
\n"; + + echo "\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + + // Dictionary + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + echo "
{$lang['strftsmapping']}"; + + // Case of multiaction drop + if (isset($_REQUEST['ma'])) { + $ma_mappings = array(); + $ma_mappings_names = array(); + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + printf('', htmlspecialchars($a['mapping'])); + $ma_mappings[] = $data->getFtsMappingByName($_POST['ftscfg'], $a['mapping']); + $ma_mappings_names[] = $a['mapping']; + } + echo implode(", ", $ma_mappings_names); + } else { + $mapping = $data->getFtsMappingByName($_POST['ftscfg'], $_POST['formMapping']); + echo $mapping->fields['name']; + echo "\n"; + } + + echo "\t\t
{$lang['strftsdict']}"; + echo "\t\t\t
\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } else { + echo "

{$lang['strftsnodictionaries']}

\n"; + } + } + + /** + * Save the form submission containing changes to a FTS mapping + */ + function doSaveAlterMapping() { + global $data, $misc, $lang; + + $mappingArray = (is_array($_POST['formMapping']) ? $_POST['formMapping'] : array($_POST['formMapping'])); + $status = $data->changeFtsMapping($_POST['ftscfg'], $mappingArray, 'alter', $_POST['formDictionary']); + if ($status == 0) + doViewConfig($_POST['ftscfg'], $lang['strftsmappingaltered']); + else + doAlterMapping($lang['strftsmappingalteredbad']); + } + + /** + * Show the form to enter parameters of a new FTS mapping + */ + function doAddMapping($msg = '') { + global $data, $misc, $lang; + + $misc->printTrail('ftscfg'); + $misc->printTitle($lang['stralter'], 'pg.ftscfg.alter'); + $misc->printMsg($msg); + + $ftsdicts = $data->getFtsDictionaries(); + if ($ftsdicts->recordCount() > 0) { + if (!isset($_POST['formMapping'])) $_POST['formMapping'] = ''; + if (!isset($_POST['formDictionary'])) $_POST['formDictionary'] = ''; + if (!isset($_POST['ftscfg'])) $_POST['ftscfg'] = $_REQUEST['ftscfg']; + $mappings = $data->getFtsMappings($_POST['ftscfg']); + + echo "
\n"; + echo "\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + + // Dictionary + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + echo "
{$lang['strftsmapping']}"; + echo "\t\t\t
{$lang['strftsdict']}"; + echo "\t\t\t
\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } else { + echo "

{$lang['strftsnodictionaries']}

\n"; + } + } + + /** + * Save the form submission containing parameters of a new FTS mapping + */ + function doSaveAddMapping() { + global $data, $misc, $lang; + + $mappingArray = (is_array($_POST['formMapping']) ? $_POST['formMapping'] : array($_POST['formMapping'])); + $status = $data->changeFtsMapping($_POST['ftscfg'], $mappingArray, 'add', $_POST['formDictionary']); + if ($status == 0) + doViewConfig($_POST['ftscfg'], $lang['strftsmappingadded']); + else + doAddMapping($lang['strftsmappingaddedbad']); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data, $lang; + + $tabs = $misc->getNavTabs('fulltext'); + $items = $misc->adjustTabsForTree($tabs); + + $reqvars = $misc->getRequestVars('ftscfg'); + + $attrs = array( + 'text' => field('title'), + 'icon' => field('icon'), + 'action' => url('fulltext.php', + $reqvars, + field('urlvars') + ), + 'branch' => url('fulltext.php', + $reqvars, + array( + 'action' => 'subtree', + 'what' => field('icon') // IZ: yeah, it's ugly, but I do not want to change navigation tabs arrays + ) + ), + ); + + $misc->printTree($items, $attrs, 'fts'); + + exit; + } + + function doSubTree($what) { + global $misc, $data, $lang; + + switch($what) { + case 'FtsCfg': + $items = $data->getFtsConfigurations(false); + $urlvars = array('action' => 'viewconfig', 'ftscfg' => field('name')); + break; + case 'FtsDict': + $items = $data->getFtsDictionaries(false); + $urlvars = array('action' => 'viewdicts'); + break; + case 'FtsParser': + $items = $data->getFtsParsers(false); + $urlvars = array('action' => 'viewparsers'); + break; + default: + exit; + } + + $reqvars = $misc->getRequestVars('ftscfg'); + + $attrs = array( + 'text' => field('name'), + 'icon' => $what, + 'toolTip'=> field('comment'), + 'action' => url('fulltext.php', + $reqvars, + $urlvars + ), + 'branch' => ifempty(field('branch'), + '', + url('fulltext.php', + $reqvars, + array( + 'action' => 'subtree', + 'ftscfg' => field('name') + ) + ) + ), + ); + + $misc->printTree($items, $attrs, strtolower($what)); + exit; + } + + + if ($action == 'tree') doTree(); + if ($action == 'subtree') doSubTree($_REQUEST['what']); + + $misc->printHeader($lang['strschemas']); + $misc->printBody(); + + if (isset($_POST['cancel'])) { + if (isset($_POST['prev_action'])) { + $action = $_POST['prev_action']; + } else { + $action = ''; + } + } + + switch ($action) { + case 'createconfig': + if (isset($_POST['create'])) doSaveCreateConfig(); + else doCreateConfig(); + break; + case 'alterconfig': + if (isset($_POST['alter'])) doSaveAlterConfig(); + else doAlterConfig(); + break; + case 'dropconfig': + if (isset($_POST['drop'])) doDropConfig(false); + else doDropConfig(true); + break; + case 'viewconfig': + doViewConfig($_REQUEST['ftscfg']); + break; + case 'viewparsers': + doViewParsers(); + break; + case 'viewdicts': + doViewDicts(); + break; + case 'createdict': + if (isset($_POST['create'])) doSaveCreateDict(); + else doCreateDict(); + break; + case 'alterdict': + if (isset($_POST['alter'])) doSaveAlterDict(); + else doAlterDict(); + break; + case 'dropdict': + if (isset($_POST['drop'])) doDropDict(false); + else doDropDict(true); + break; + case 'dropmapping': + if (isset($_POST['drop'])) doDropMapping(false); + else doDropMapping(true); + break; + case 'altermapping': + if (isset($_POST['alter'])) doSaveAlterMapping(); + else doAlterMapping(); + break; + case 'addmapping': + if (isset($_POST['add'])) doSaveAddMapping(); + else doAddMapping(); + break; + + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/functions.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/functions.js new file mode 100644 index 00000000..3a93bf87 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/functions.js @@ -0,0 +1,204 @@ +var g_args = 0; +var g_no_args = new Boolean(false); +/* +function for adding arguments +*/ + +function addArg() { + var baseTR = baseArgTR(); + if(document.getElementById("args_table").insertBefore(baseTR,document.getElementById("parent_add_tr"))) { + g_args++; + return baseTR; + } +} + +function buildArgImages(orig_td) { + var table = document.createElement("table"); + var tbody = document.createElement("tbody"); + var tr = document.createElement("tr"); + var td = document.createElement("td"); + var img = document.createElement("img"); + img.src="images/themes/default/RaiseArgument.png"; + td.onmouseover=function() { this.style.cursor='pointer';this.title=g_lang_strargraise; } + td.onclick=function() { swapArgTR(this.parentNode.parentNode.parentNode.parentNode.parentNode.previousSibling,this.parentNode.parentNode.parentNode.parentNode.parentNode); } + img.className='arg_icon'; + td.appendChild(img); + td.className="data1"; + tr.appendChild(td); + var img = document.createElement("img"); + var td = document.createElement("td"); + img.src="images/themes/default/LowerArgument.png"; + img.className='arg_icon'; + td.appendChild(img); + td.className="data1"; + td.onmouseover=function() { this.style.cursor='pointer';this.title=g_lang_strarglower; } + td.onclick=function() { swapArgTR(this.parentNode.parentNode.parentNode.parentNode.parentNode,this.parentNode.parentNode.parentNode.parentNode.parentNode.nextSibling); } + tr.appendChild(td); + var img = document.createElement("img"); + var td = document.createElement("td"); + img.src="images/themes/default/RemoveArgument.png"; + img.title=g_lang_strargremove; + img.className='arg_icon'; + td.appendChild(img); + td.className="data1"; + td.onmouseover=function() { this.style.cursor='pointer';this.title='Remove'; } + td.onclick=function() { if(g_args>1) { if(confirm(g_lang_strargremoveconfirm)) document.getElementById("args_table").removeChild(this.parentNode.parentNode.parentNode.parentNode.parentNode);g_args--; } else { + if(g_no_args==false) { + disableArgTR(this.parentNode.parentNode.parentNode.parentNode.parentNode); + this.childNodes[0].src='images/themes/default/EnableArgument.png'; + this.childNodes[0].title=g_lang_strargenableargs; + this.childNodes[0].id="1st_arg_iag"; + alert(g_lang_strargnoargs); + g_no_args = true; + g_args--; + } else { + enableArgTR(this.parentNode.parentNode.parentNode.parentNode.parentNode); + this.childNodes[0].src='images/themes/default/RemoveArgument.png'; + this.childNodes[0].title=g_lang_strargremove; + g_args++; + g_no_args = false; + } + } + } + td.onmouseout=function() { } + if(g_args==0) { + td.id="1st_arg_td"; + } + tr.className='arg_tr_pc'; + tr.appendChild(td); + tbody.appendChild(tr); + table.appendChild(tbody); + orig_td.appendChild(table); + return orig_td; +} + +function noArgsRebuild(tr) { + disableArgTR(tr); + var td = document.getElementById("1st_arg_td"); + td.childNodes[0].src='images/themes/default/EnableArgument.png'; + td.childNodes[0].title=g_lang_strargenableargs; + td.childNodes[0].id="1st_arg_iag"; + g_no_args = true; + g_args--; +} + +function swapArgTR(first,second) { + var tmp = null; + tmp = second; + second = first; + first = tmp; + if(first.className=='arg_tr_pc' && second.className=='arg_tr_pc') { + document.getElementById("args_table").insertBefore(first,second); + } else if(first.className=='arg_tr_pc' && second.className!='arg_tr_pc') { + alert(g_lang_strargnorowabove); + } else if(first.className!='arg_tr_pc' && second.className=='arg_tr_pc') { + alert(g_lang_strargnorowbelow); + } +} + +function disableArgTR(tr) { + var children = (tr.childNodes); + for(i in children) { + var secondary_children = children[i].childNodes; + for(i2 in secondary_children) { + secondary_children[i2].disabled=true; + } + } +} + +function enableArgTR(tr) { + var children = (tr.childNodes); + for(i in children) { + var secondary_children = children[i].childNodes; + for(i2 in secondary_children) { + secondary_children[i2].disabled=false; + } + } +} + +function RebuildArgTR(mode,arg_name,arg_type,arg_array) { + var tr = document.createElement("tr"); + var td = document.createElement("td"); + var modes_select = buildSelect("formArgModes[]",g_main_modes,mode); + modes_select.style.width='100%'; + td.appendChild(modes_select); + tr.appendChild(td); + var arg_txt = document.createElement("input"); + arg_txt.type='text'; + arg_txt.name='formArgName[]'; + arg_txt.style.width='100%'; + arg_txt.value=arg_name; + var td = document.createElement("td"); + td.appendChild(arg_txt); + tr.appendChild(td); + var td = document.createElement("td"); + td.appendChild(buildSelect("formArgType[]",g_main_types,arg_type)); + if(arg_array==true) { + var szArr = "[]"; + } else { + var szArr = ""; + } + td.appendChild(buildSelect("formArgArray[]",new Array("","[]"),szArr)); + tr.appendChild(td); + var td = document.createElement("td"); + td = buildArgImages(td); + td.className="data3"; + tr.className='arg_tr_pc'; + tr.appendChild(td); + if(document.getElementById("args_table").insertBefore(tr,document.getElementById("parent_add_tr"))) { + g_args++; + } +} + +function buildSelect(name,options,selected) { + var s = document.createElement('select'); + for(i=0;ihasFunctionAlterSchema()) $_POST['formFuncSchema'] = ''; + + $status = $data->setFunction($_POST['function_oid'], $_POST['original_function'], $_POST['formFunction'], + $_POST['original_arguments'], $_POST['original_returns'], $def, + $_POST['original_lang'], $_POST['formProperties'], isset($_POST['original_setof']), + $_POST['original_owner'], $_POST['formFuncOwn'], $_POST['original_schema'], + $_POST['formFuncSchema'], isset($_POST['formCost']) ? $_POST['formCost'] : null, + isset($_POST['formRows']) ? $_POST['formRows'] : 0, $_POST['formComment']); + + if ($status == 0) { + // If function has had schema altered, need to change to the new schema + // and reload the browser frame. + if (!empty($_POST['formFuncSchema']) && ($_POST['formFuncSchema'] != $_POST['original_schema'])) { + // Jump them to the new function schema + $misc->setCurrentSchema($_POST['formFuncSchema']); + // Force a browser reload + $_reload_browser = true; + } + doProperties($lang['strfunctionupdated']); + } else { + doEdit($lang['strfunctionupdatedbad']); + } + } + + /** + * Function to allow editing of a Function + */ + function doEdit($msg = '') { + global $data, $misc; + global $lang; + $misc->printTrail('function'); + $misc->printTitle($lang['stralter'],'pg.function.alter'); + $misc->printMsg($msg); + + $fndata = $data->getFunction($_REQUEST['function_oid']); + + if ($fndata->recordCount() > 0) { + $fndata->fields['proretset'] = $data->phpBool($fndata->fields['proretset']); + + // Initialise variables + if (!isset($_POST['formDefinition'])) $_POST['formDefinition'] = $fndata->fields['prosrc']; + if (!isset($_POST['formProperties'])) $_POST['formProperties'] = $data->getFunctionProperties($fndata->fields); + if (!isset($_POST['formFunction'])) $_POST['formFunction'] = $fndata->fields['proname']; + if (!isset($_POST['formComment'])) $_POST['formComment'] = $fndata->fields['procomment']; + if (!isset($_POST['formObjectFile'])) $_POST['formObjectFile'] = $fndata->fields['probin']; + if (!isset($_POST['formLinkSymbol'])) $_POST['formLinkSymbol'] = $fndata->fields['prosrc']; + if (!isset($_POST['formFuncOwn'])) $_POST['formFuncOwn'] = $fndata->fields['proowner']; + if (!isset($_POST['formFuncSchema'])) $_POST['formFuncSchema'] = $fndata->fields['proschema']; + + if ($data->hasFunctionCosting()) { + if (!isset($_POST['formCost'])) $_POST['formCost'] = $fndata->fields['procost']; + if (!isset($_POST['formRows'])) $_POST['formRows'] = $fndata->fields['prorows']; + } + + // Deal with named parameters + if ($data->hasNamedParams()) { + if ( isset($fndata->fields['proallarguments']) ) { + $args_arr = $data->phpArray($fndata->fields['proallarguments']); + } else { + $args_arr = explode(', ', $fndata->fields['proarguments']); + } + $names_arr = $data->phpArray($fndata->fields['proargnames']); + $modes_arr = $data->phpArray($fndata->fields['proargmodes']); + $args = ''; + $i = 0; + for ($i = 0; $i < sizeof($args_arr); $i++) { + if ($i != 0) $args .= ', '; + if (isset($modes_arr[$i])) { + switch($modes_arr[$i]) { + case 'i' : $args .= " IN "; break; + case 'o' : $args .= " OUT "; break; + case 'b' : $args .= " INOUT "; break; + case 'v' : $args .= " VARIADIC "; break; + case 't' : $args .= " TABLE "; break; + } + } + if (isset($names_arr[$i]) && $names_arr[$i] != '') { + $data->fieldClean($names_arr[$i]); + $args .= '"' . $names_arr[$i] . '" '; + } + $args .= $args_arr[$i]; + } + } + else { + $args = $fndata->fields['proarguments']; + } + + $func_full = $fndata->fields['proname'] . "(". $fndata->fields['proarguments'] .")"; + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + echo "\n"; + + echo "\n"; + + echo "\n"; + + echo "\n"; + echo "\n"; + + $fnlang = strtolower($fndata->fields['prolanguage']); + if ($fnlang == 'c') { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + } else if ($fnlang == 'internal') { + echo "\n"; + echo "\n"; + } else { + echo "\n"; + echo "\n"; + } + + // Display function comment + echo "\n"; + echo "\n"; + + // Display function cost options + if ($data->hasFunctionCosting()) { + echo "\n"; + echo ""; + echo ""; + } + + // Display function properties + if (is_array($data->funcprops) && sizeof($data->funcprops) > 0) { + echo "\n"; + echo "\n"; + } + + // function owner + if ($data->hasFunctionAlterOwner()) { + $users = $data->getUsers(); + echo "\n"; + } + echo "
{$lang['strschema']}{$lang['strfunction']}{$lang['strarguments']}{$lang['strreturns']}{$lang['strproglanguage']}
"; + echo "fields['proschema']),"\" />\n"; + if ($data->hasFunctionAlterSchema()) { + $schemas = $data->getSchemas(); + echo "\n"; + } + else echo $fndata->fields['proschema']; + echo ""; + echo "fields['proname']),"\" />\n"; + echo "_maxNameLen}\" value=\"", htmlspecialchars($_POST['formFunction']), "\" />"; + echo "", $misc->printVal($args), "\n"; + echo "\n"; + echo ""; + if ($fndata->fields['proretset']) echo "setof "; + echo $misc->printVal($fndata->fields['proresult']), "\n"; + echo "fields['proresult']), "\" />\n"; + if ($fndata->fields['proretset']) + echo "\n"; + echo "", $misc->printVal($fndata->fields['prolanguage']), "\n"; + echo "fields['prolanguage']), "\" />\n"; + echo "
{$lang['strobjectfile']}{$lang['strlinksymbol']}
{$lang['strlinksymbol']}
{$lang['strdefinition']}
{$lang['strcomment']}
{$lang['strfunctioncosting']}
{$lang['strexecutioncost']}: {$lang['strresultrows']}: fields['proretset']) ? 'disabled' : '', "/>
{$lang['strproperties']}
\n"; + $i = 0; + foreach ($data->funcprops as $k => $v) { + echo "
\n"; + $i++; + } + echo "
{$lang['strowner']}: \n"; + echo "fields['proowner']),"\" />\n"; + echo "
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Show read only properties of a function + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('function'); + $misc->printTitle($lang['strproperties'],'pg.function'); + $misc->printMsg($msg); + + $funcdata = $data->getFunction($_REQUEST['function_oid']); + + if ($funcdata->recordCount() > 0) { + // Deal with named parameters + if ($data->hasNamedParams()) { + if ( isset($funcdata->fields['proallarguments']) ) { + $args_arr = $data->phpArray($funcdata->fields['proallarguments']); + } else { + $args_arr = explode(', ', $funcdata->fields['proarguments']); + } + $names_arr = $data->phpArray($funcdata->fields['proargnames']); + $modes_arr = $data->phpArray($funcdata->fields['proargmodes']); + $args = ''; + $i = 0; + for ($i = 0; $i < sizeof($args_arr); $i++) { + if ($i != 0) $args .= ', '; + if (isset($modes_arr[$i])) { + switch($modes_arr[$i]) { + case 'i' : $args .= " IN "; break; + case 'o' : $args .= " OUT "; break; + case 'b' : $args .= " INOUT "; break; + case 'v' : $args .= " VARIADIC "; break; + case 't' : $args .= " TABLE "; break; + } + } + if (isset($names_arr[$i]) && $names_arr[$i] != '') { + $data->fieldClean($names_arr[$i]); + $args .= '"' . $names_arr[$i] . '" '; + } + $args .= $args_arr[$i]; + } + } + else { + $args = $funcdata->fields['proarguments']; + } + + // Show comment if any + if ($funcdata->fields['procomment'] !== null) + echo "

", $misc->printVal($funcdata->fields['procomment']), "

\n"; + + $funcdata->fields['proretset'] = $data->phpBool($funcdata->fields['proretset']); + $func_full = $funcdata->fields['proname'] . "(". $funcdata->fields['proarguments'] .")"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + $fnlang = strtolower($funcdata->fields['prolanguage']); + if ($fnlang == 'c') { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + } else if ($fnlang == 'internal') { + echo "\n"; + echo "\n"; + } else { + include_once('./libraries/highlight.php'); + echo "\n"; + // Check to see if we have syntax highlighting for this language + if (isset($data->langmap[$funcdata->fields['prolanguage']])) { + $temp = syntax_highlight(htmlspecialchars($funcdata->fields['prosrc']), $data->langmap[$funcdata->fields['prolanguage']]); + $tag = 'prenoescape'; + } + else { + $temp = $funcdata->fields['prosrc']; + $tag = 'pre'; + } + echo "\n"; + } + + // Display function cost options + if ($data->hasFunctionCosting()) { + echo "\n"; + echo ""; + echo ""; + } + + // Show flags + if (is_array($data->funcprops) && sizeof($data->funcprops) > 0) { + // Fetch an array of the function properties + $funcprops = $data->getFunctionProperties($funcdata->fields); + echo "\n"; + echo "\n"; + } + + echo "\n"; + echo "
{$lang['strfunction']}{$lang['strarguments']}{$lang['strreturns']}{$lang['strproglanguage']}
", $misc->printVal($funcdata->fields['proname']), "", $misc->printVal($args), ""; + if ($funcdata->fields['proretset']) echo "setof "; + echo $misc->printVal($funcdata->fields['proresult']), "", $misc->printVal($funcdata->fields['prolanguage']), "
{$lang['strobjectfile']}{$lang['strlinksymbol']}
", $misc->printVal($funcdata->fields['probin']), "", $misc->printVal($funcdata->fields['prosrc']), "
{$lang['strlinksymbol']}
", $misc->printVal($funcdata->fields['prosrc']), "
{$lang['strdefinition']}
", $misc->printVal($temp, $tag, array('lineno' => true, 'class' => 'data1')), "
{$lang['strfunctioncosting']}
{$lang['strexecutioncost']}: ", $misc->printVal($funcdata->fields['procost']), " {$lang['strresultrows']}: ", $misc->printVal($funcdata->fields['prorows']), "
{$lang['strproperties']}
\n"; + foreach ($funcprops as $v) { + echo $misc->printVal($v), "
\n"; + } + echo "
{$lang['strowner']}: ", htmlspecialchars($funcdata->fields['proowner']),"\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + + $navlinks = array( + 'showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + ) + ) + ), + 'content' => $lang['strshowallfunctions'] + ), + 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'edit', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'function' => $_REQUEST['function'], + 'function_oid' => $_REQUEST['function_oid'] + ) + ) + ), + 'content' => $lang['stralter'] + ), + 'drop' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'function' => $func_full, + 'function_oid' => $_REQUEST['function_oid'] + ) + ) + ), + 'content' => $lang['strdrop'] + ) + ); + + $misc->printNavLinks($navlinks, 'functions-properties', get_defined_vars()); + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang, $_reload_browser; + + if (empty($_REQUEST['function']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifyfunctiontodrop']); + exit(); + } + + if ($confirm) { + $misc->printTrail('schema'); + $misc->printTitle($lang['strdrop'],'pg.function.drop'); + + echo "
\n"; + + //If multi drop + if (isset($_REQUEST['ma'])) { + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfdropfunction'], $misc->printVal($a['function'])), "

\n"; + echo '\n"; + echo "\n"; + } + } + else { + echo "

", sprintf($lang['strconfdropfunction'], $misc->printVal($_REQUEST['function'])), "

\n"; + echo "\n"; + echo "\n"; + } + + echo "\n"; + + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + if (is_array($_POST['function_oid'])) { + $msg = ''; + $status = $data->beginTransaction(); + if ($status == 0) { + foreach($_POST['function_oid'] as $k => $s) { + $status = $data->dropFunction($s, isset($_POST['cascade'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($_POST['function'][$k], ENT_QUOTES, 'UTF-8'), $lang['strfunctiondropped']); + else { + $data->endTransaction(); + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($_POST['function'][$k], ENT_QUOTES, 'UTF-8'), $lang['strfunctiondroppedbad'])); + return; + } + } + } + if($data->endTransaction() == 0) { + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else doDefault($lang['strfunctiondroppedbad']); + } + else{ + $status = $data->dropFunction($_POST['function_oid'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strfunctiondropped']); + } + else { + doDefault($lang['strfunctiondroppedbad']); + } + } + } + + } + + /** + * Displays a screen where they can enter a new function + */ + function doCreate($msg = '',$szJS="") { + global $data, $misc; + global $lang; + + $misc->printTrail('schema'); + if (!isset($_POST['formFunction'])) $_POST['formFunction'] = ''; + if (!isset($_POST['formArguments'])) $_POST['formArguments'] = ''; + if (!isset($_POST['formReturns'])) $_POST['formReturns'] = ''; + if (!isset($_POST['formLanguage'])) $_POST['formLanguage'] = isset($_REQUEST['language']) ? $_REQUEST['language'] : 'sql'; + if (!isset($_POST['formDefinition'])) $_POST['formDefinition'] = ''; + if (!isset($_POST['formObjectFile'])) $_POST['formObjectFile'] = ''; + if (!isset($_POST['formLinkSymbol'])) $_POST['formLinkSymbol'] = ''; + if (!isset($_POST['formProperties'])) $_POST['formProperties'] = $data->defaultprops; + if (!isset($_POST['formSetOf'])) $_POST['formSetOf'] = ''; + if (!isset($_POST['formArray'])) $_POST['formArray'] = ''; + if (!isset($_POST['formCost'])) $_POST['formCost'] = ''; + if (!isset($_POST['formRows'])) $_POST['formRows'] = ''; + if (!isset($_POST['formComment'])) $_POST['formComment'] = ''; + + $types = $data->getTypes(true, true, true); + $langs = $data->getLanguages(true); + $fnlang = strtolower($_POST['formLanguage']); + + switch ($fnlang) { + case 'c': + $misc->printTitle($lang['strcreatecfunction'],'pg.function.create.c'); + break; + case 'internal': + $misc->printTitle($lang['strcreateinternalfunction'],'pg.function.create.internal'); + break; + default: + $misc->printTitle($lang['strcreateplfunction'],'pg.function.create.pl'); + break; + } + $misc->printMsg($msg); + + // Create string for return type list + $szTypes = ""; + while (!$types->EOF) { + $szSelected = ""; + if($types->fields['typname'] == $_POST['formReturns']) { + $szSelected = " selected=\"selected\""; + } + /* this variable is include in the JS code bellow, so we need to ENT_QUOTES */ + $szTypes .= ""; + $types->moveNext(); + } + + $szFunctionName = "_maxNameLen}\" value=\"". + htmlspecialchars($_POST['formFunction']) ."\" />"; + + $szArguments = ""; + + $szSetOfSelected = ""; + $szNotSetOfSelected = ""; + if($_POST['formSetOf'] == '') { + $szNotSetOfSelected = " selected=\"selected\""; + } else if($_POST['formSetOf'] == 'SETOF') { + $szSetOfSelected = " selected=\"selected\""; + } + $szReturns = ""; + $szReturns .= ""; + + $szReturns .= ""; + + // Create string array type selector + + $szArraySelected = ""; + $szNotArraySelected = ""; + if($_POST['formArray'] == '') { + $szNotArraySelected = " selected=\"selected\""; + } else if($_POST['formArray'] == '[]') { + $szArraySelected = " selected=\"selected\""; + } + + $szReturns .= "\n"; + + // Create string for language + $szLanguage = ""; + if ($fnlang == 'c' || $fnlang == 'internal') { + $szLanguage .= $_POST['formLanguage'] . "\n"; + $szLanguage .= "\n"; + } + else { + $szLanguage .= "\n"; + } + + $szLanguage .= ""; + $szJSArguments = "{$lang['strarguments']}"; + $arrayModes = array("IN","OUT","INOUT"); + $szModes = ""; + $szArgReturns = ""; + if(!empty($conf['theme'])) { + $szImgPath = "images/themes/{$conf['theme']}"; + } else { + $szImgPath = "images/themes/default"; + } + if(empty($msg)) { + $szJSTRArg = "\n"; + } else { + $szJSTRArg = ""; + } + $szJSAddTR = "\n
\"Add{$lang['strargadd']}
\n\n"; + + echo " + + "; + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "{$szFunctionName}\n"; + echo "{$szReturns}\n"; + echo "{$szLanguage}\n"; + echo "\n"; + echo "{$szJSArguments}\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "{$szJSAddTR}\n"; + + if ($fnlang == 'c') { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + } else if ($fnlang == 'internal') { + echo "\n"; + echo "\n"; + } else { + echo "\n"; + echo "\n"; + } + + // Display function comment + echo "\n"; + echo "\n"; + + // Display function cost options + if ($data->hasFunctionCosting()) { + echo "\n"; + echo ""; + echo ""; + } + + // Display function properties + if (is_array($data->funcprops) && sizeof($data->funcprops) > 0) { + echo "\n"; + echo "\n"; + } + echo "
{$lang['strname']}{$lang['strreturns']}{$lang['strproglanguage']}
{$lang['strargmode']}{$lang['strname']}{$lang['strargtype']}
{$lang['strobjectfile']}{$lang['strlinksymbol']}
{$lang['strlinksymbol']}
{$lang['strdefinition']}
{$lang['strcomment']}
{$lang['strfunctioncosting']}
{$lang['strexecutioncost']}: {$lang['strresultrows']}:
{$lang['strproperties']}
\n"; + $i = 0; + foreach ($data->funcprops as $k => $v) { + echo "
\n"; + $i++; + } + echo "
\n"; + echo $szJSTRArg; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + echo $szJS; + } + + /** + * Actually creates the new function in the database + */ + function doSaveCreate() { + global $data, $lang; + + $fnlang = strtolower($_POST['formLanguage']); + + if ($fnlang == 'c') { + $def = array($_POST['formObjectFile'], $_POST['formLinkSymbol']); + } else if ($fnlang == 'internal'){ + $def = $_POST['formLinkSymbol']; + } else { + $def = $_POST['formDefinition']; + } + + $szJS = ''; + + echo ""; + echo "'; + if(!empty($_POST['formArgName'])) { + $szJS = buildJSRows(buildFunctionArguments($_POST)); + } else { + $szJS = ""; + } + + $cost = (isset($_POST['formCost'])) ? $_POST['formCost'] : null; + if ($cost == '' || !is_numeric($cost) || $cost != (int)$cost || $cost < 0) { + $cost = null; + } + + $rows = (isset($_POST['formRows'])) ? $_POST['formRows'] : null; + if ($rows == '' || !is_numeric($rows) || $rows != (int)$rows ) { + $rows = null; + } + + // Check that they've given a name and a definition + if ($_POST['formFunction'] == '') doCreate($lang['strfunctionneedsname'],$szJS); + elseif ($fnlang != 'internal' && !$def) doCreate($lang['strfunctionneedsdef'],$szJS); + else { + // Append array symbol to type if chosen + $status = $data->createFunction($_POST['formFunction'], empty($_POST['nojs'])? buildFunctionArguments($_POST) : $_POST['formArguments'], + $_POST['formReturns'] . $_POST['formArray'] , $def , $_POST['formLanguage'], + $_POST['formProperties'], $_POST['formSetOf'] == 'SETOF', + $cost, $rows, $_POST['formComment'], false); + if ($status == 0) + doDefault($lang['strfunctioncreated']); + else { + doCreate($lang['strfunctioncreatedbad'],$szJS); + } + } + } + + /** + * Build out the function arguments string + */ + function buildFunctionArguments($arrayVars) { + if(isset($_POST['formArgName'])) { + $arrayArgs = array(); + foreach($arrayVars['formArgName'] as $pK => $pV) { + $arrayArgs[] = $arrayVars['formArgModes'][$pK] .' '. trim($pV) .' '. trim($arrayVars['formArgType'][$pK]) . $arrayVars['formArgArray'][$pK]; + } + return implode(",", $arrayArgs); + } + return ''; + } + + /** + * Build out JS to re-create table rows for arguments + */ + function buildJSRows($szArgs) { + $arrayModes = array('IN','OUT','INOUT'); + $arrayArgs = explode(',',$szArgs); + $arrayProperArgs = array(); + $nC = 0; + $szReturn = ''; + foreach($arrayArgs as $pV) { + $arrayWords = explode(' ',$pV); + if(in_array($arrayWords[0],$arrayModes)===true) { + $szMode = $arrayWords[0]; + array_shift($arrayWords); + } + $szArgName = array_shift($arrayWords); + if(strpos($arrayWords[count($arrayWords)-1],'[]')===false) { + $szArgType = implode(" ",$arrayWords); + $bArgIsArray = "false"; + } else { + $szArgType = str_replace('[]','',implode(' ',$arrayWords)); + $bArgIsArray = "true"; + } + $arrayProperArgs[] = array($szMode,$szArgName,$szArgType,$bArgIsArray); + $szReturn .= ""; + $nC++; + } + return $szReturn; + } + + + function buildJSData() { + global $data; + $arrayModes = array('IN','OUT','INOUT'); + $arrayTypes = $data->getTypes(true, true, true); + $arrayPTypes = array(); + $arrayPModes = array(); + $szTypes = ''; + + while (!$arrayTypes->EOF) { + $arrayPTypes[] = "'". $arrayTypes->fields['typname'] ."'"; + $arrayTypes->moveNext(); + } + + foreach($arrayModes as $pV) { + $arrayPModes[] = "'{$pV}'"; + } + + $szTypes = 'g_main_types = new Array('. implode(',', $arrayPTypes) .');'; + $szModes = 'g_main_modes = new Array('. implode(',', $arrayPModes) .');'; + return $szTypes . $szModes; + } + + /** + * Show default list of functions in the database + */ + function doDefault($msg = '') { + global $data, $conf, $misc, $func; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','functions'); + $misc->printMsg($msg); + + $funcs = $data->getFunctions(); + + $columns = array( + 'function' => array( + 'title' => $lang['strfunction'], + 'field' => field('proproto'), + 'url' => "redirect.php?subject=function&action=properties&{$misc->href}&", + 'vars' => array('function' => 'proproto', 'function_oid' => 'prooid'), + ), + 'returns' => array( + 'title' => $lang['strreturns'], + 'field' => field('proreturns'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('proowner'), + ), + 'proglanguage' => array( + 'title' => $lang['strproglanguage'], + 'field' => field('prolanguage'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('procomment'), + ), + ); + + $actions = array( + 'multiactions' => array( + 'keycols' => array('function' => 'proproto', 'function_oid' => 'prooid'), + 'url' => 'functions.php', + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'edit', + 'function' => field('proproto'), + 'function_oid' => field('prooid') + ) + ) + ) + ), + 'drop' => array( + 'multiaction' => 'confirm_drop', + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'function' => field('proproto'), + 'function_oid' => field('prooid') + ) + ) + ) + ), + 'privileges' => array( + 'content' => $lang['strprivileges'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array ( + 'subject' => 'function', + 'function' => field('proproto'), + 'function_oid' => field('prooid') + ) + ) + ) + ), + ); + + $misc->printTable($funcs, $columns, $actions, 'functions-functions', $lang['strnofunctions']); + + $navlinks = array( + 'createpl' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreateplfunction'] + ), + 'createinternal' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'create', + 'language' => 'internal', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreateinternalfunction'] + ), + 'createc' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'functions.php', + 'urlvars' => array ( + 'action' => 'create', + 'language' => 'C', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreatecfunction'] + ) + ); + + $misc->printNavLinks($navlinks, 'functions-functions', get_defined_vars()); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $funcs = $data->getFunctions(); + + $proto = concat(field('proname'),' (',field('proarguments'),')'); + + $reqvars = $misc->getRequestVars('function'); + + $attrs = array( + 'text' => $proto, + 'icon' => 'Function', + 'toolTip' => field('procomment'), + 'action' => url('redirect.php', + $reqvars, + array( + 'action' => 'properties', + 'function' => $proto, + 'function_oid' => field('prooid') + ) + ) + ); + + $misc->printTree($funcs, $attrs, 'functions'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strfunctions']); + $misc->printBody(); + + switch ($action) { + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'save_edit': + if (isset($_POST['cancel'])) doDefault(); + else doSaveEdit(); + break; + case 'edit': + doEdit(); + break; + case 'properties': + doProperties(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/groups.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/groups.php new file mode 100644 index 00000000..b6e65249 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/groups.php @@ -0,0 +1,330 @@ +addGroupMember($_REQUEST['group'], $_REQUEST['user']); + if ($status == 0) + doProperties($lang['strmemberadded']); + else + doProperties($lang['strmemberaddedbad']); + } + + /** + * Show confirmation of drop user from group and perform actual drop + */ + function doDropMember($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('group'); + $misc->printTitle($lang['strdropmember'],'pg.group.alter'); + + echo "

", sprintf($lang['strconfdropmember'], $misc->printVal($_REQUEST['user']), $misc->printVal($_REQUEST['group'])), "

\n"; + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropGroupMember($_REQUEST['group'], $_REQUEST['user']); + if ($status == 0) + doProperties($lang['strmemberdropped']); + else + doDropMember(true, $lang['strmemberdroppedbad']); + } + } + + /** + * Show read only properties for a group + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['user'])) $_POST['user'] = ''; + + $misc->printTrail('group'); + $misc->printTitle($lang['strproperties'],'pg.group'); + $misc->printMsg($msg); + + $groupdata = $data->getGroup($_REQUEST['group']); + $users = $data->getUsers(); + + if ($groupdata->recordCount() > 0) { + $columns = array ( + 'members' => array ( + 'title' => $lang['strmembers'], + 'field' => field('usename') + ), + 'actions' => array ( + 'title' => $lang['stractions'], + ) + ); + + $actions = array ( + 'drop' => array ( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'groups.php', + 'urlvars' => array ( + 'action' => 'confirm_drop_member', + 'group' => $_REQUEST['group'], + 'user' => field('usename') + ) + ) + ) + ) + ); + + $misc->printTable($groupdata, $columns, $actions, 'groups-members', $lang['strnousers']); + } + + // Display form for adding a user to the group + echo "
\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + + $misc->printNavLinks(array ('showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'groups.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strshowallgroups'] + )), 'groups-properties', get_defined_vars()); + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('group'); + $misc->printTitle($lang['strdrop'],'pg.group.drop'); + + echo "

", sprintf($lang['strconfdropgroup'], $misc->printVal($_REQUEST['group'])), "

\n"; + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropGroup($_REQUEST['group']); + if ($status == 0) + doDefault($lang['strgroupdropped']); + else + doDefault($lang['strgroupdroppedbad']); + } + } + + /** + * Displays a screen where they can enter a new group + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['name'])) $_POST['name'] = ''; + if (!isset($_POST['members'])) $_POST['members'] = array(); + + // Fetch a list of all users in the cluster + $users = $data->getUsers(); + + $misc->printTrail('server'); + $misc->printTitle($lang['strcreategroup'],'pg.group.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + if ($users->recordCount() > 0) { + echo "\t\n\t\t\n"; + + echo "\t\t\n\t\n"; + } + echo "
{$lang['strname']}_maxNameLen}\" name=\"name\" value=\"", htmlspecialchars($_POST['name']), "\" />
{$lang['strmembers']}\n"; + echo "\t\t\t\n"; + echo "\t\t
\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new group in the database + */ + function doSaveCreate() { + global $data; + global $lang; + + if (!isset($_POST['members'])) $_POST['members'] = array(); + + // Check form vars + if (trim($_POST['name']) == '') + doCreate($lang['strgroupneedsname']); + else { + $status = $data->createGroup($_POST['name'], $_POST['members']); + if ($status == 0) + doDefault($lang['strgroupcreated']); + else + doCreate($lang['strgroupcreatedbad']); + } + } + + /** + * Show default list of groups in the database + */ + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('server'); + $misc->printTabs('server','groups'); + $misc->printMsg($msg); + + $groups = $data->getGroups(); + + $columns = array( + 'group' => array( + 'title' => $lang['strgroup'], + 'field' => field('groname'), + 'url' => "groups.php?action=properties&{$misc->href}&", + 'vars' => array('group' => 'groname'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $actions = array( + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'groups.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'group' => field('groname') + ) + ) + ) + ), + ); + + $misc->printTable($groups, $columns, $actions, 'groups-properties', $lang['strnogroups']); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'groups.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strcreategroup'] + )), 'groups-groups', get_defined_vars()); + + } + + $misc->printHeader($lang['strgroups']); + $misc->printBody(); + + switch ($action) { + case 'add_member': + doAddMember(); + break; + case 'drop_member': + if (isset($_REQUEST['drop'])) doDropMember(false); + else doProperties(); + break; + case 'confirm_drop_member': + doDropMember(true); + break; + case 'save_create': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_REQUEST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'save_edit': + doSaveEdit(); + break; + case 'edit': + doEdit(); + break; + case 'properties': + doProperties(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help.php new file mode 100644 index 00000000..9dbde0eb --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help.php @@ -0,0 +1,88 @@ +getHelp($_REQUEST['help']); + + if (is_array($url)) { + doChoosePage($url); + return; + } + + if ($url) { + header("Location: $url"); + exit; + } + } + + doBrowse($lang['strinvalidhelppage']); + } + + function doBrowse($msg = '') { + global $misc, $data, $lang; + + $misc->printHeader($lang['strhelppagebrowser']); + $misc->printBody(); + + $misc->printTitle($lang['strselecthelppage']); + + echo $misc->printMsg($msg); + + echo "
\n"; + + $pages = $data->getHelpPages(); + foreach ($pages as $page => $dummy) { + echo "
{$page}
\n"; + + $urls = $data->getHelp($page); + if (!is_array($urls)) $urls = array($urls); + foreach ($urls as $url) { + echo "
{$url}
\n"; + } + } + + echo "
\n"; + + $misc->printFooter(); + } + + function doChoosePage($urls) { + global $misc, $lang; + + $misc->printHeader($lang['strhelppagebrowser']); + $misc->printBody(); + + $misc->printTitle($lang['strselecthelppage']); + + echo "
    \n"; + foreach($urls as $url) { + echo "
  • {$url}
  • \n"; + } + echo "
\n"; + + $misc->printFooter(); + } + + switch ($action) { + case 'browse': + doBrowse(); + break; + default: + doDefault(); + break; + } +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc10.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc10.php new file mode 100644 index 00000000..79fb627a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc10.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '10'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc11.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc11.php new file mode 100644 index 00000000..36e768f9 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc11.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '11'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc12.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc12.php new file mode 100644 index 00000000..154953d7 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc12.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '12'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc74.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc74.php new file mode 100644 index 00000000..b8458283 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc74.php @@ -0,0 +1,160 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '7.4'); + +# TODO: Check and fix links + +$this->help_page = array( + + 'pg.database' => 'managing-databases.html', + 'pg.database.create' => array('sql-createdatabase.html', 'manage-ag-createdb.html'), + 'pg.database.alter' => 'sql-alterdatabase.html', + 'pg.database.drop' => array('sql-dropdatabase.html', 'manage-ag-dropdb.html'), + + 'pg.admin.analyze' => 'sql-analyze.html', + 'pg.admin.vacuum' => 'sql-vacuum.html', + + 'pg.cast' => array('sql-expressions.html#SQL-SYNTAX-TYPE-CASTS','sql-createcast.html'), + 'pg.cast.create' => 'sql-createcast.html', + 'pg.cast.drop' => 'sql-dropcast.html', + + 'pg.column.add' => array('ddl-alter.html#AEN2115', 'sql-altertable.html'), + 'pg.column.alter' => array('ddl-alter.html','sql-altertable.html'), + 'pg.column.drop' => array('ddl-alter.html#AEN2124', 'sql-altertable.html'), + + 'pg.constraint' => 'ddl-constraints.html', + 'pg.constraint.add' => 'ddl-alter.html#AEN2131', + 'pg.constraint.check' => 'ddl-constraints.html#AEN1895', + 'pg.constraint.drop' => 'ddl-alter.html#AEN2140', + 'pg.constraint.foreign_key' => 'ddl-constraints.html#DDL-CONSTRAINTS-FK', + 'pg.constraint.primary_key' => 'ddl-constraints.html#AEN1972', + 'pg.constraint.unique_key' => 'ddl-constraints.html#AEN1950', + + 'pg.conversion' => 'multibyte.html', + 'pg.conversion.alter' => 'sql-alterconversion.html', + 'pg.conversion.create' => 'sql-createconversion.html', + 'pg.conversion.drop' => 'sql-dropconversion.html', + + 'pg.domain' => 'extend-type-system.html#AEN28657', + 'pg.domain.alter' => 'sql-alterdomain.html', + 'pg.domain.create' => 'sql-createdomain.html', + 'pg.domain.drop' => 'sql-dropdomain.html', + + 'pg.function' => array('xfunc.html', 'functions.html', 'sql-expressions.html#AEN1599'), + 'pg.function.alter' => 'sql-alterfunction.html', + 'pg.function.create' => 'sql-createfunction.html', + 'pg.function.create.c' => array('xfunc-c.html','sql-createfunction.html'), + 'pg.function.create.internal' => array('xfunc-internal.html','sql-createfunction.html'), + 'pg.function.create.pl' => array('xfunc-sql.html','xfunc-pl.html','sql-createfunction.html'), + 'pg.function.drop' => 'sql-dropfunction.html', + + 'pg.group' => 'groups.html', + 'pg.group.alter' => array('sql-altergroup.html','groups.html'), + 'pg.group.create' => 'sql-creategroup.html', + 'pg.group.drop' => 'sql-dropgroup.html', + + 'pg.index' => 'indexes.html', + 'pg.index.cluster' => 'sql-cluster.html', + 'pg.index.drop' => 'sql-dropindex.html', + 'pg.index.create' => 'sql-createindex.html', + 'pg.index.reindex' => 'sql-reindex.html', + + 'pg.language' => 'xplang.html', + 'pg.language.alter' => 'sql-alterlanguage.html', + 'pg.language.create' => 'sql-createlanguage.html', + 'pg.language.drop' => 'sql-droplanguage.html', + + 'pg.opclass' => 'indexes-opclass.html', + 'pg.opclass.alter' => 'sql-alteropclass.html', + 'pg.opclass.create' => 'sql-createopclass.html', + 'pg.opclass.drop' => 'sql-dropopclass.html', + + 'pg.operator' => array('xoper.html', 'functions.html', 'sql-expressions.html#AEN1570'), + 'pg.operator.alter' => 'sql-alteroperator.html', + 'pg.operator.create' => 'sql-createoperator.html', + 'pg.operator.drop' => 'sql-dropoperator.html', + + 'pg.pl' => 'xplang.html', + 'pg.pl.plperl' => 'plperl.html', + 'pg.pl.plpgsql' => 'plpgsql.html', + 'pg.pl.plpython' => 'plpython.html', + 'pg.pl.pltcl' => 'pltcl.html', + + 'pg.privilege' => array('privileges.html','ddl-priv.html'), + 'pg.privilege.grant' => 'sql-grant.html', + 'pg.privilege.revoke' => 'sql-revoke.html', + + 'pg.process' => 'monitoring.html', + + 'pg.rule' => 'rules.html', + 'pg.rule.create' => 'sql-createrule.html', + 'pg.rule.drop' => 'sql-droprule.html', + + 'pg.schema' => 'ddl-schemas.html', + 'pg.schema.alter' => 'sql-alterschema.html', + 'pg.schema.create' => array( 'sql-createschema.html','ddl-schemas.html#DDL-SCHEMAS-CREATE'), + 'pg.schema.drop' => 'sql-dropschema.html', + 'pg.schema.search_path' => 'ddl-schemas.html#DDL-SCHEMAS-PATH', + + 'pg.sequence' => 'functions-sequence.html', + 'pg.sequence.alter' => 'sql-altersequence.html', + 'pg.sequence.create' => 'sql-createsequence.html', + 'pg.sequence.drop' => 'sql-dropsequence.html', + + 'pg.sql' => array('sql.html','sql-commands.html'), + 'pg.sql.insert' => 'sql-insert.html', + 'pg.sql.select' => 'sql-select.html', + 'pg.sql.update' => 'sql-update.html', + + 'pg.table' => 'ddl.html#DDL-BASICS', + 'pg.table.alter' => 'sql-altertable.html', + 'pg.table.create' => 'sql-createtable.html', + 'pg.table.drop' => 'sql-droptable.html', + 'pg.table.empty' => 'sql-truncate.html', + + 'pg.tablespace' => 'manage-ag-tablespaces.html', + 'pg.tablespace.alter' => 'sql-altertablespace.html', + 'pg.tablespace.create' => 'sql-createtablespace.html', + 'pg.tablespace.drop' => 'sql-droptablespace.html', + + 'pg.trigger' => 'triggers.html', + 'pg.trigger.alter' => 'sql-altertrigger.html', + 'pg.trigger.create' => 'sql-createtrigger.html', + 'pg.trigger.drop' => 'sql-droptrigger.html', + + 'pg.type' => array('xtypes.html','datatype.html','extend-type-system.html'), + 'pg.type.alter' => 'sql-altertype.html', + 'pg.type.create' => 'sql-createtype.html', + 'pg.type.drop' => 'sql-droptype.html', + + 'pg.user.alter' => array('sql-alteruser.html','user-attributes.html'), + 'pg.user.create' => array('sql-createuser.html','user-manag.html#DATABASE-USERS'), + 'pg.user.drop' => array('sql-dropuser.html','user-manag.html#DATABASE-USERS'), + + 'pg.variable' => 'runtime-config.html', + + 'pg.view' => 'tutorial-views.html', + 'pg.view.alter' => array('sql-createview.html','sql-altertable.html'), + 'pg.view.create' => 'sql-createview.html', + 'pg.view.drop' => 'sql-dropview.html', + + 'pg.aggregate' => array('xaggr.html', 'tutorial-agg.html', 'functions-aggregate.html', 'sql-expressions.html#SYNTAX-AGGREGATES'), + 'pg.aggregate.create' => 'sql-createaggregate.html', + 'pg.aggregate.drop' => 'sql-dropaggregate.html', + 'pg.aggregate.alter' => 'sql-alteraggregate.html', + + 'pg.server' => 'admin.html', + + 'pg.user' => 'user-manag.html', + + 'pg.locks' => 'view-pg-locks.html' +); + + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc80.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc80.php new file mode 100644 index 00000000..f0bd19ad --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc80.php @@ -0,0 +1,28 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '8.0'); + +$this->help_page['pg.column.add'][0] = 'ddl-alter.html#AEN2217'; +$this->help_page['pg.column.drop'][0] = 'ddl-alter.html#AEN2226'; + +$this->help_page['pg.constraint.add'] = 'ddl-alter.html#AEN2217'; +$this->help_page['pg.constraint.check'] = 'ddl-constraints.html#AEN1978'; +$this->help_page['pg.constraint.drop'] = 'ddl-alter.html#AEN2226'; +$this->help_page['pg.constraint.primary_key'] = 'ddl-constraints.html#AEN2055'; +$this->help_page['pg.constraint.unique_key'] = 'ddl-constraints.html#AEN2033'; + +$this->help_page['pg.domain'] = 'extend-type-system.html#AEN27940'; + +$this->help_page['pg.function'][2] = 'sql-expressions.html#AEN1652'; + +$this->help_page['pg.operator'][2] = 'sql-expressions.html#AEN1623'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc81.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc81.php new file mode 100644 index 00000000..29307e37 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc81.php @@ -0,0 +1,18 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '8.1'); + +$this->help_page['pg.role'] = 'user-manag.html'; +$this->help_page['pg.role.create'] = array('sql-createrole.html','user-manag.html#DATABASE-ROLES'); +$this->help_page['pg.role.alter'] = array('sql-alterrole.html','role-attributes.html'); +$this->help_page['pg.role.drop'] = array('sql-droprole.html','user-manag.html#DATABASE-ROLES'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc82.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc82.php new file mode 100644 index 00000000..7b956f0c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc82.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '8.2'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc83.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc83.php new file mode 100644 index 00000000..3684ad28 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc83.php @@ -0,0 +1,27 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '8.3'); + +$this->help_page['pg.fts'] = 'textsearch.html'; + +$this->help_page['pg.ftscfg'] = 'textsearch-intro.html#TEXTSEARCH-INTRO-CONFIGURATIONS'; +$this->help_page['pg.ftscfg.example'] = 'textsearch-configuration.html'; +$this->help_page['pg.ftscfg.drop'] = 'sql-droptsconfig.html'; +$this->help_page['pg.ftscfg.create'] = 'sql-createtsconfig.html'; +$this->help_page['pg.ftscfg.alter'] = 'sql-altertsconfig.html'; + +$this->help_page['pg.ftsdict'] = 'textsearch-dictionaries.html'; +$this->help_page['pg.ftsdict.drop'] = 'sql-droptsdictionary.html'; +$this->help_page['pg.ftsdict.create'] = array('sql-createtsdictionary.html', 'sql-createtstemplate.html'); +$this->help_page['pg.ftsdict.alter'] = 'sql-altertsdictionary.html'; + +$this->help_page['pg.ftsparser'] = 'textsearch-parsers.html'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc84.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc84.php new file mode 100644 index 00000000..91c8b204 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc84.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '8.4'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc90.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc90.php new file mode 100644 index 00000000..519a7db7 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc90.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.0'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc91.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc91.php new file mode 100644 index 00000000..74e4fea4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc91.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.1'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc92.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc92.php new file mode 100644 index 00000000..7cfdfdec --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc92.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.2'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc93.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc93.php new file mode 100644 index 00000000..014b0c84 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc93.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.3'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc94.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc94.php new file mode 100644 index 00000000..94a1dedc --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc94.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.4'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc95.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc95.php new file mode 100644 index 00000000..5ef261ab --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc95.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.5'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc96.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc96.php new file mode 100644 index 00000000..7bfaca3b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/help/PostgresDoc96.php @@ -0,0 +1,13 @@ +help_base = sprintf($GLOBALS['conf']['help_base'], '9.6'); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/history.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/history.php new file mode 100644 index 00000000..1dab1db8 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/history.php @@ -0,0 +1,226 @@ +printHeader($lang['strhistory']); + + // Bring to the front always + echo "\n"; + + echo "
\n"; + $misc->printConnection($onchange); + echo "

"; + + if (!isset($_REQUEST['database'])) { + echo "

{$lang['strnodatabaseselected']}

\n"; + return; + } + + if (isset($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']])) { + include_once('classes/ArrayRecordSet.php'); + + $history = new ArrayRecordSet($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']]); + + $columns = array( + 'query' => array( + 'title' => $lang['strsql'], + 'field' => field('query'), + ), + 'paginate' => array( + 'title' => $lang['strpaginate'], + 'field' => field('paginate'), + 'type' => 'yesno', + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $actions = array( + 'run' => array( + 'content' => $lang['strexecute'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'sql.php', + 'urlvars' => array ( + 'subject' => 'history', + 'nohistory' => 't', + 'queryid' => field('queryid'), + 'paginate' => field('paginate') + ) + ), + 'target' => 'detail' + ) + ), + 'remove' => array( + 'content' => $lang['strdelete'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'history.php', + 'urlvars' => array ( + 'action' => 'confdelhistory', + 'queryid' => field('queryid'), + ) + ) + ) + ) + ); + + $misc->printTable($history, $columns, $actions, 'history-history', $lang['strnohistory']); + } + else echo "

{$lang['strnohistory']}

\n"; + + $navlinks = array ( + 'refresh' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'history.php', + 'urlvars' => array ( + 'action' => 'history', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + ) + ) + ), + 'content' => $lang['strrefresh'] + ) + ); + + if (isset($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']]) + && count($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']])) { + $navlinks['download'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'history.php', + 'urlvars' => array ( + 'action' => 'download', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'] + ) + ) + ), + 'content' => $lang['strdownload'] + ); + $navlinks['clear'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'history.php', + 'urlvars' => array( + 'action' => 'confclearhistory', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'] + ) + ) + ), + 'content' => $lang['strclearhistory'] + ); + } + + $misc->printNavLinks($navlinks, 'history-history', get_defined_vars()); + } + + function doDelHistory($qid, $confirm) { + global $misc, $lang; + + if ($confirm) { + $misc->printHeader($lang['strhistory']); + + // Bring to the front always + echo "\n"; + + echo "

{$lang['strdelhistory']}

\n"; + echo "

{$lang['strconfdelhistory']}

\n"; + + echo "
", htmlentities($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']][$qid]['query'], ENT_QUOTES, 'UTF-8'), "
"; + echo "
\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else + unset($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']][$qid]); + } + + function doClearHistory($confirm) { + global $misc, $lang; + + if ($confirm) { + $misc->printHeader($lang['strhistory']); + + // Bring to the front always + echo "\n"; + + echo "

{$lang['strclearhistory']}

\n"; + echo "

{$lang['strconfclearhistory']}

\n"; + + echo "
\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else + unset($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']]); + } + + function doDownloadHistory() { + header('Content-Type: application/download'); + $datetime = date('YmdHis'); + header("Content-Disposition: attachment; filename=history{$datetime}.sql"); + + foreach ($_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']] as $queries) { + $query = rtrim($queries['query']); + echo $query; + if (substr($query, -1) != ';') + echo ';'; + echo "\n"; + } + + exit; + } + + switch ($action) { + case 'confdelhistory': + doDelHistory($_REQUEST['queryid'], true); + break; + case 'delhistory': + if (isset($_POST['yes'])) doDelHistory($_REQUEST['queryid'], false); + doDefault(); + break; + case 'confclearhistory': + doClearHistory(true); + break; + case 'clearhistory': + if (isset($_POST['yes'])) doClearHistory(false); + doDefault(); + break; + case 'download': + doDownloadHistory(); + break; + default: + doDefault(); + } + + // Set the name of the window + $misc->setWindowName('history'); + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/Favicon.ico b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/Favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..6a188d538076f52875fd4748fde3d29f6b537b14 GIT binary patch literal 1406 zcmeHHyJ`YK6g|5->L$DHuKQjy`{?o+`3Awp!W1IJ(n7G21XBotU}I%vC4!Y;VIzr! zg@yiyRmzYeW>&+JVEQ!9aPHi5xHEG(#RWLF6$QujKme0vw+xXKFmTAQ2;6bU<18Ew z2eeu(ESF0Z3Iz;@L+tl^)M_>Cb~{X`Q}lX0l*?tz=X0#rYt-v?bUGc3Mk5Rc15_#% zG@DI~$78hHZIntSY&ILLRx2zP3lxh*%w{t*8Vz*2UG)2XRI61?CKGJ8+q0f7!o`7$ z1OMg#&;S0K(x2P~QQ^jl%lU-(Tr9XLO(9w;=J2kZyzG6~%VLhVZAZMx3DKj5qvRCH zPB`kdDjI-5sA*eF5KOA%0a2DsJ84Nt(e#MTxWW5+CbT4yRu#r|S(Xo z(lm7(S1(gy;B#H!75v1thL+t+LJ8Wm?+%=Q;di$fD zI(6sXd(PZn^8(<7P!#2>4o$~i$3%zn6jL6)w+B=muZ$T9)l#X1e!q{&WFiOz0?_^6 ziC{2@)oO*!W`q5Hk4~qVh z9*4){kuMqK^ZAV9@rXvF0iVx@N~MBkvnj2RD*`N&6(o~M*laclTCG--Y_V7{olYfI zEEc7TXMxsWFc4=xpNHLUm+}nqZnwjFy~b!X5&_Pp-EPY}xfJ-q@|VjcTCEn`ZZ|Yd zdq?I5%H=W~4u`ZbpUR$z(gf!!{Y5y+oPXa10lN+J^KLW3h-`4zfKf_OUc%biCVOF{T0000Fmw` literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/title.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/bootstrap/title.png new file mode 100644 index 0000000000000000000000000000000000000000..44f5c7a18f9ef396503ae728c360e42a3ae8e01d GIT binary patch literal 5388 zcmeHLX;f3!8jXk=0V_p(MN~*50-})8*MFXsrGo5xFFU74L(|$?Xq>}}pDdI}Y%VSj_&&a8AzG_e)q43xwbWoAa>!(j zb&s_o|3qY4K!E=Rr7_h6?@|T(uEfY0V;ddnjT@b%_1_^(bF7sN{hN0V8?&|z3`$W(YQM zGb0kP?69B^fWVP9&WF~q#*>hXw`RyM<7P-{Cw7z?1%kP{!#wL z3rcFQ(l8;HWjrit6Q`e;DW33L>(r8FD`QyHEZ1zN;cj!ONYg6G^Dyy{B9yNwqcPu5 z+;`6NTp8+7voaM5a#2ghW+l$*NBu`zYoe;E*xX(T4#}-xvm0Mmb!TOr?jDB7S}FeH z#k6G39RNq&acaVd-Dar%?LFh;6TOXIkV6eY7Rs`JuErp!mr5|%cn#0LtXi7?oVViqO`&zr(sk;7W zwdL#%JaYG1i_2-6+^?ZzWuUql1hy7;+a{lYNi4`c?)NxweiVOS+YA+2adwlkETnHz zp{gLbv^4K@>Iih%)gPPBrESbvkn=Ml`GvE+RhHB#KpvHuI4>B}eJlMm+${|z75WZZ zt8?&<^~D$0^-VtTy2*-9Aos0v2*R87?Fv#8^YcP!OL^-uYwpZV{FYUnU+Joy6u)Np zIgBrJ!?aTrWQ2QrDwH;~HZgYh)(BF~u1YoDxS-uaJ@Z$soOktM=JQo`v2B%%r4XHb z{WtY*-4~`>uTk2;nR>|x@&$10Os!yk^}}V7@rPYcJGz!YxapoW5fOWO9M~W0Tun3V@r!|KQR2zNxyj?^Vi?L$bpAbp-sq z=$l7=qP4$IX=DUCk&0SdDe^Z1eyH54++cInM`sx%4mPbPOr;EJ1e;we_TC`qXceu_ zMwwcv_=r?YJ%e~2#ER+ml`@e1IQ8(+KUR8qxilr#uuX&bG@C+K~7mmA& zTbbLFLX5Tb=*Nx!DsKhp@Ke5f>kh{c(Wsc?AKQs2)L03vFtACM+oA8LnFzwp(fp6Z z1+`ArW(??|l*dJ6cUAS*RRxMY%oRUOu4UiR=<+$;y+IdFC#|q|=!g z*@d!xWrFq_jpe&$ZMq)by1qrwT`TE(JUZU^!`>0me6~T&6Ybt&A7plC^{zTt%xn!? zv^6+ONzSOZt1TiZFcbn|f-ua&gdL*e*3>Hznf|l$+cP&Nm$?SMy%Tn`CNjI>));TS zCEj!H?mdxLgR@I0X8N(6S$g0FAEPva!viFX-(JHw85-5s2Z+MbkFT!nY08YEwp|}=vsZ_z0fxRV(v0Xd@*w{>2;G? zi#^Y~t+QK*=KeWWFbK}`SARG9yfx`uBR39qcUabn+k=(}yD+>-Ng>c^#?99{?0suZ z%lvSiWNNd;`7aJ_n9^WfN^S5juB#rt<}%kodvs`-{Y ztCl}o3hVC{>-Q<^MF9g|F6s`wj`rFYUcW!%yt@5_NS|(e-s76{cWn}O9in5>ryvAe znvzg)n&u01HtbMgSJ`^;(h=Nhgb#n7BPxC1V#!GLb zz{;SAVAqx$6>h#rNlmW?ZC?7st}!S+GN==-p@+lIo(OYR*d~z0>_-1}6`e6$gofEPX; z@2$&JAy_OcO+{?GQy!cao!sAZyzVi_^eo3H^W8{$If=2Ia& zqy5WQ(ya1>X*r$Mx5EU2y`|zxPHQYlS}C#eY|zDG4LP6#%eRRjnc^_jqDjr2ATz&ablf1r^WA=ZVBHEW-i4k1YLA-NTe;hYx~Ds3dJfLHY8|cV=(voFVA1QM=XQz? z=QM3P<MJHd%f;AY3~3e#umGOGmpfL;7DQ#L>>x_KNkMxc>qdJ=JRf literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Lminus.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Lminus.png new file mode 100644 index 0000000000000000000000000000000000000000..b5e489822d12a43277e47074423530264fc86949 GIT binary patch literal 191 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE-VV{wqX6T`Z5GB1G~wj^(N7X~v1 zV+Mok*XG&)MK}vQB8wRqxP?KOkzv*x37{Z*iKnkC`z>}M20oqzCEGoKLiV06jv*GO zlM@z*XJlsmJa4e#;0o?eww@(BRxDfBHZdzs#f)Rdinpn^q;Fih@=0Dc`LmT?6-%4q g=?ka!D>E}N6fe=&tZVGI1scWR>FVdQ&MBb@0Mk@Ag8%>k literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Lplus.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Lplus.png new file mode 100644 index 0000000000000000000000000000000000000000..ef51c7e30b8343f2efb561d1dad21956307bb75f GIT binary patch literal 202 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE-VV{wqX6T`Z5GB1G~wj^(N7X~v1 zV+Mok*XG&)MK}vQB8wRqxP?KOkzv*x37{Z*iKnkC`z>}M20no;rLWn6LSCLOjv*GO zlM@z*XJlsmJa4e#;0o?eww@(BRxDfBHZdzs#f)Rd3fVTFD}2ssIeN`I`DXUMD~d7k r(-(TgKWF+$FC~wL)QqS1Co(czpJ%MO^m}Fx&{PIbS3j3^P6}M20nhv+Gn4DLJpoTjv*GO zlM@z*XJlsmJa4e#;0o?eww@(BRxDfBHZdzs#f)Rdinpn^q;Fih@=0Dc`LmT?6-%4q h=?ka!D=*%{$e@^NVx6%-XCu%o22WQ%mvv4FO#nujIQIYm literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Tplus.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/Tplus.png new file mode 100644 index 0000000000000000000000000000000000000000..c54f5c80ad67408010b2da5c01fce03339604bf0 GIT binary patch literal 204 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE-VV{wqX6T`Z5GB1G~wj^(N7X~v1 zV+Mok*XG&)MK}vQB8wRqxP?KOkzv*x37{Z*iKnkC`z>}M20p>VMYkscg?v0+978Nl zCnqcr&&bUBdEQ{f!4=${Y&}bMtXQ_LZDLlOiW$d@6|!wUSNNROa`c*a^3CjhR}^F7 tr!Vw~f6nxiUP>MfsToi2PYk@pz|b0RVJ-gR^JAd744$rjF6*2UngGmTJthDE literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/inputbckg.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/inputbckg.png new file mode 100644 index 0000000000000000000000000000000000000000..35815c5e83c7e6c9087b62a6c24cb10c448c73c4 GIT binary patch literal 129 zcmeAS@N?(olHy`uVBq!ia0vp^tUxTx!3HEF9vn{wQjEnx?oJHr&dIz4a;!aF977~7 zC)fOc_OG7J>F4|LN}>Ohqg0os cC4CfR_$Oi+b6xD{9-uJ{p00i_>zopr04g&tQUCw| literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/openListe.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/cappuccino/openListe.png new file mode 100644 index 0000000000000000000000000000000000000000..0d132d36486f1a070da2fa332c28c8db5b55b006 GIT binary patch literal 252 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE-VOS+@4BLl<6e(pbstUx|nlDE4H z!+#K5uy^@npa^GyM`SSr1K$x4W}K?cCk+(r@pN$vu{fQ)r##h|*_2V3dFsIxjm}3M zRR6wU0O6QfA5K0lco@&d*7m>ghKb{mf9y_I5}4d#IHNu7l^PlwH77j$zhC#(r}*oJ z1_lN(wI^hc960gh@PQBcfA@B4n@vbjSheu~euog_PY;ZH5|%ia{EI$+;KT{%oPx#24YJ`L;(K){{a7>y{D4^000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2igY` z0S*%^zR-#Q01jtKL_t(|+U=ZMbKAxhfOjEEvL%W(Xvx;aPGZop;-pQTK)JhVAIOLF zoqTT}$jN&<#4l*UUyvbwKsqB#oJ^bPWQOP^nL4*IF}`qjBxD=RAm3kGk8CnBb4R!y^7 zt3RTV3HV6u#6-351lGuGS|!}X%f(2wB83`Yxgup+=;pnZxtlk;7~InxfYWUssK+G% zpQ>FmQ8uqHD;sx60)*Ahn@k&r85(Wk)&RtxL1+Ksif zHG~jN)qW8ltj=8?@-R`Bhly&Bl*9KuC{N_-S!z5&pD)sq(?v8c&vo%kwZ%Bn)Z2f4WzI;Quh|_)$8@1?f~jyo{S+4_&j;?M46-ZF3&xXYWhB} z@Vrwl+NVvU@)n+$rq^=|q-;p(#mcQa_ZF8Hd%6RG zC&ffPrC@pG3rJS8B@*9^r;TKitBG<8q(ITq!}5)vZkLLM&7vpAFR!#Tr=)0 z>9)eLA@*Q**KTRE$>C6NDA?<|xN}+G8O`{~LKd?0LS^+qf!22XXt+0kZBZ0~$+VDm zXW4f4qoF=J)p_&wooZ#hO@mDftrdz)bMp^l+;{N6J_W1mo!4G@JXB3h&tBK&`hvkq ztp=YfGc$#9W#~w_yF+*2s?GMfGBfk9&%gL#R_hH89A!fr#t9+Ud;#%O;Hu7l`dOh= z3Wh>8!>Ad?*WZ4-`e5yuv5`Q4!3bjp!%z5UT1dOQ{P}+`3=SQw*6Y=JePL|C2uG);q3tpD~m{P;-%)27bu{HLD{4i4sW zIgaC?M3N*y5dQtO`rf;5Y=q%WB7rKN=X1FnlqiZK2*Tg~@!7M_obZbGTRb1btgWrx zTU>T3nVG$IihIttST3?stSqnU@4fdsQ4}>zQ&m;dG=xw*9-p6|zjfag~SU@2-4*`SQh!7degt{VdC#J9my{*^fW@j zJ^q4I$;aoG-L{Utq(+HspUw(xU zIyN+f5IQwFxIJx7;W$nd#dtiP&1S*mAcR7}pe+nK66~b|?RkA|`s&qaGzzvV7K>?` zmP{tI*=#%>7X;zb^vpYF&j3}Ws(E*5)v~Nl{{Cq+8bt`Hsv3*MqR}W=okF2-UAuAm z6jv;jA@fNRrw4j_s?{o{aI2%(eDo_OlOy70d%00$A4WqF=Eb4 zs%o3VVM-nrONyd|LZM&&;-#Hvqy1nak;rDV$z)O#MM;wW^Z6GX#}V&FY#Wgi$H#hm zd#~rUKmSDpPo!xY$8oYOi=xP~Y%-br;DZl(dwX9y6Zz*im(;0C&^G9Ts}u@_sqel= z2=P46vMdy;s;cWc-56ch>HbEeQPO2#YiW7KIS#>K@Wt^{PbOGERXUxf!yR4M$sm$B zc0HUviiAYl(3VUl<2+s;N{;Q50gU6h%>0)k_JC!}QF| z-ehYRvU4^L;F{BQ9mWNwiUg$2AyyPcQ52|_&1Sc!jpMjzQ(FLJQRpVYP-HS0 z`dly$z*eD9cq)Q-Ns?%L0MnVv<>;UR#*3Z?P191TR5Ti;z24Tf*&Hh!iV@S5NF->x zBFnPV%z)p7=7D_zyaYjzBq z3cdiu;J5`rfOUq~sOq|&PN!Lxg)vDa68U_d<2at@5i*`wi$%|UGMQXmUCrn7F#Wo& zXEGV56BI?!vMd-KC;>aM4Q*giKr)#OF&@ovMnt>wpW1x@1{~ z`eXqJRORz|Q4~c{^m6yaeW%mu$;nALT$bfrE(ZrrPEHaV=_R_ZL;Z9*eevQ&=rZ)k zb}8;xurRXV<5dA-1(s#$V8}UYJkP`RN`htE;;18Sk|f2NA_xL8MZ^YxBLhzdQ=3kw zo&J=}I)Tht4!{x52q7RiGQy%W3?+vUE6DRa^cPB;eYZ7?)Q4r`ribiNu)F|*eO%Lm z$I&e3ng!;ATuj7gk*Rg9=GBZXYIEf~m&=h@nA8V_VDnrTiD3L7%aCabOd$#3ZInoo z1b=dM(4?GhGbm|qrCc>^+VQ;-W6@7q+5rM+utk?5YEKP$Z(%|I>Ew;8$g=D;869b( z(+yiWuWK?4S^~^L?!(EPBuP%Qq$moUu2Zk%^u_H(Rn;~blf4C&X|}x< zbu*;XV!_1?tMr|>Z;RSUplzE5K@e=A53Csh4x1|hrv{5thA8nvfehlpoTr1Z-Bo`k zlOgGNPzd=GDi*rC@QY_&fDK@nY~m;dK>$7yiG-5_@Pj0MKo$hxv!ER6ko6+qpMa{y#TZr~`W1h;11U zX#$SpwzoF!R9m@RCg1z}4u%GTWF-Z8Aeeie=O-s8>3H9kWl&XBRn?QvJ$qtoEW(`x zu;4x%l5c}76y()1nG9@4`bcd*^S*H}lE*s)Add$=g3f9}xzpab7H(VHMmsUa7{}xB zXfz7G%vRs#3bWZP$$QDN91I4Bj__E zrGIs;-zFKm4-%vp;l_uSCQZ2Qdvxe~KVTmQcDrn`wrk-|v>hKE-sl^{kmkv<9En6Q z#;_}AOSIZTbx<`je2kQg3?GBNMN*PVrJw=MyIfFnzt2Xwt<7*2TQz#u67C?i)sMwu z^z~r-bx-B7u)FOcOF#y<6kj_eS{@wx&A42GL{_Gxgg)QjNi3Ut{)v_D7P2Yc{ zD9YP!z1f8f=y|=m?i>QTaDHLwr`vbhXd4|F?(gp(KmGinfqsM#ZJb=B`Q!pgSY)$V zxc7lhTfp8hod@@tr{kl;u4jCxHy+OE+QJ+=D|Cv*iLsFrV#@BhA?KiSORm8$h`F8!e2e?V`!XqvWO zE*%N8Gzzu4;iQ(llm$*^n8xyo-rdt{(^julhmQ{Ku(#K=o8&18TDhVqg+k$#mtS%o z(#0^wK76L{XP02#K@4wA-c-s}W4&5kE0#^uER;&MTCGy4tgo-v>vh90N@cst>pOTL z5C}N^Ci#_VFy(TtdfliShH09nX~O$9gZ+KG(&1vMj9TB}+2(0ujPX_;3G~J3c?J)M z0wjs@pj5Fet5!GGE7eN1R;gBi9{A}x?(j1Z2!sZLZ5Xm!DG#1D+;gBS5a@aoeeUl& zxb@0DRofKH!WiQ>UgKT4@ru)3Blm4Hv1D3z2_T`a)<%=&qSibmR d`SMiD{{dI6bVEQ817iRH002ovPDHLkV1irJL|6a- literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AddArguments.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AddArguments.png new file mode 100644 index 0000000000000000000000000000000000000000..3ac45e18a0edc80abd0ae1125ae3fef2d8b5b7f1 GIT binary patch literal 141 zcmeAS@N?(olHy`uVBq!ia0vp^93afX3?$7I7w-U4(g8jpt_&eH|NsAI$eitQ=s&~c zn+$ckCfxe3vhBY|>;FAs{Q*E_x}GkMAsn*F0wD=*Sbx{(dgl)CBD(h4H_+8_;V*@_aBpdx`JAPEA6&;?pTM70}L5Ftz` zNvlv(Mc&RVZdgS{2`|dod7d-Qjs}3{KY9D1)oM8wsU5DfNT<^oS$r%Nmi12p0_?UG z#N~6A0PMC^s1gQ3}5kP3QDnV=|e#XQnLJvaVoud<3(j!`R@LFk`Vmuh*m5Y@$>uA(zV`o6RDf zP9qkJAruOcz(<0yW7iIvr@N?a&!b|SM%l53BT+yw7(}sHL@Jd+I2?xG?}yjxg)GaU z+0cwg5J;UIqPDYu^1=`vC;L&F7{t}~CImr1B9TyFnngSwha^cVEGk1}f@;OPhw}26 z0^bj4QRwT%-6{{W*{s|~tup}aJ)nIszP&~!KqGjDvQxnGh7}LiWfT|Z@N}>bdX~v# zRM_$5CbA+26@C?$%k?e%Zk1V)luRb!@p#~NyOrVn1b-B8s)X_z_?@6r(hm0%{7LYa ZyaHMXz-Z}srnUe8002ovPDHLkV1l=r>v#YF literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Aggregate.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Aggregate.png new file mode 100644 index 0000000000000000000000000000000000000000..6fe42013bff18afd5d7617a5ef287484a0b60a64 GIT binary patch literal 247 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%``#fD7LoEE4PPXMbgZ1H|_ z_8ZQiO0nwZMI9XiDxHSUwtFtxc7ARvduAC&RE@#WbKjTUbZ}u3XiH3)*y?hNJB{h) zvS#INZ#Fr8yQ$G$GiCA968WbwK1G#2evd@gm}{Tfs?t=^sF28HCOtiHpKW{{&@wqOL>KeRuhAKmX5EeMZ6G%cS`>wgY{_;OXk;vd$@?2>`r#VSE4p literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Aggregates.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Aggregates.png new file mode 100644 index 0000000000000000000000000000000000000000..4641859871886bb95d9829e8599a34796b407dcf GIT binary patch literal 254 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbL!eSlAh>;M1%^TD8LLTpDz$DDmG zC+~keegEUx2OrNr{B-Hjr>l=Y-+1!*_S4Vzo_~4x;>(klU!T4D`ttR+*RQ|5dGqZ( z%X%N6QA{O4e!&dW^8f$#1oCn`T^vIs!b8t?b2TXNv_33$dJ*^j|GY`AM~Z@zI~Uaa zxy&H6&E*Y8!o6KV%nvlLpPR)aa$n<*6!U$N74=_oU8H3fHYX_amdKI;Vst0Fg^| As{jB1 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AllUsers.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/AllUsers.png new file mode 100644 index 0000000000000000000000000000000000000000..bbfadb50130308c1da8b5be1c8939149d64f020e GIT binary patch literal 384 zcmV-`0e}99P)72InUazfQ$QY;Q!*6^36JrQA1O6X+(+$?V`*{nBA=q4o(*--9HT~cE zxbFXk2bFL`K=ka3$zVQC1CR|_d$$a%c=5GtFg@dZ!vD#qqfrg;XxcXoi2q~5aou(Q z7hK8sKkGu$|EXtU|4%p>{=fTZ5QYK&OHMraUwr)j|DvP!{}&v-_doyO-T%4!?|=;f zDV}sH>VNO?kpCTr{r@)~@WwQt_!vTS9#C`6zB_Oi^q&a(-*qJLf9pZt|Bd@R{@3ny z!8D){ruhJ>=AL80|Jx7w{cqmy^}l|v+yClaPX8-**kc+{a0sC}YxnK{89Q&m4S~i0 zI-Z7NKrTr0UWm=QJoO3)DGXap;Q@#EJ* yG{>yG45o=r%E*R9Lp9@d0WJx2myv7$u^0dus=UWF|MLd`0000t2WrXD&$nHdQ&f&TEGVgUhNwRrYH(181l1jhTvWj zs<6Q~5KKqW{rm7s7wQ^&hodD&0Ef(jX- z0w8Qq6oz;iov6$8n*K$v2qI$;ogn~d>sF(TYN^k8Ef5Qv^>y7FYruQAX zhMBY7zRXlmwE@uCnPT2tU9MN3@G#kA3uW!}G*fqbjXl&rjRUQ z7X(^h0NGV`7hzfA+q*BcvZ&+XJJ0O%zR&0R^={AX_}N~fOGH+p&qO;!2VL4}pIO^? zdja%l>LDLvPFo*>uA5*s9wQfj4?gdMCH686yhH6+!D#Wg^C!1s+OsmO%+u+k9|HuK&vSJ zS=1_k0gz1uAQz)Rjex5Hn(|M`r3LJ!C&5J@A;p-GWJXCF6UcKj#{;ASV*r?6dvNB4 z?=(&505KnH0qT1cpk1(q)6|Me1DvFQE!U8#sMKc<<)}3R>N21RfYbuqTi&Kt3wAgh zRH5A}^^LevCj~sJWzc6{J<@x>DFn+rX9Un8 zY86nxW(%;$;_}-t2Hr$4_-YG-FMr|6i)~ze9)o4B3m_JcwlM68qklMP$bRAOHw=xl zu*_x;0UO?j?ROv=08hVg`W8~6qHkd6NgNM89ByH3e(F2|bJxKJpMg&-K+5?sVt4CV xOVtJ)Vq9tsPz#>+^E%+f-}%~|QT4Qk^bab>12emjpfdmf002ovPDHLkV1mn*5EB3Z literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cast.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cast.png new file mode 100644 index 0000000000000000000000000000000000000000..d7666e59aba60707a39b9e10fb1fe507ea746c45 GIT binary patch literal 298 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbK}a)3{W>;M1%BmH+R?Xy`p`^K65 z6MEXtAKX|05xM_RKXKy!lc)9gKz6g11o;IsOq;fS zdu)8tZJCJ|OWt+p#STv{qv(u4glAD|GaqHu&%8m)C u?-d;%reVU>SwdzFD!rH(wMrT?m`|FNQs=E-9ehSK28E_u34ZA(j1Ht1|ZE{ zn+*TYIqv#@@p&JxQ$bD!;WgJI{vZBW@V|bsI)-MfE@)q?|9|7X7_gJ)9ryfy`d8)u zse9}}nj49V1&}Qur-Gb(GmDKLI&UvF@f>$U2GHoV`5wu%D)N` znJPKow3#C3KuC$U?IV7*)nx#)8O)n9H#->idFc8FMyiA!sX-RftSJMS&0yY?3_73> zYUojDllP%nKSD={%m4zPh1|G@+I_V&F@Vf5z&pPH5F3wBztBK7Z!j_S#VklWjB4J6d~z32|N879mC}b_ yGnfEOOv|3KGZxsuL(~POac5~-_L=_moj(DbCqBaAv2Sc1#I>_55Diq*o0xS u@4H%Xj6Dnk#&MJ>*v#-5!DF}aFMI$MARXeY9aaYb0000sjaQ8uCA`HudlGMu(7eRwASvpxVYWj-QM2b;Nall;o;@w z<>uz*=jZ3?>FMg~>g((4?Ck9A?d|aJ@b>oh_xJbyV^&N60007XQchCiwe*-!* zFlGi!W;n2^mZPB**i=}zTL`N&lObb5AZL&WW7wTRUI-F^jbC~RoA$EG#^6lXD|LVV gvmd9uKjA&W1MRy8G?F2Q_W%F@07*qoM6N<$f(o96$^ZZW literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Constraints.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Constraints.png new file mode 100644 index 0000000000000000000000000000000000000000..76df5ed79055c9218fa82abb71f22f686f3be21a GIT binary patch literal 187 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`O`a}}Ar_~TfBgS%lu|Q(O zeYX@Tf&c6mTTB+LZsq(}zc2k7fLm)`FV4RjSd@wsj|0{ zbkn+@k+mXX%o9}RKizdmRA5rOw!`!z&zNTX*({-~!}j1pPa;RaXXE%(Ap2rZV#j8d kHpVGSn-eF9YaC>7e7kSK52sreK-VyMy85}Sb4q9e0GYT(oB#j- literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Conversion.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Conversion.png new file mode 100644 index 0000000000000000000000000000000000000000..bc6db85faa8ece1a50b145553e983622ace3f3f1 GIT binary patch literal 234 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbL!eSlAh>;M1%YnIw9^51o8_KmG) zCP3KFcKly^FJaN;(6^`l-=6k=f7|&h|NEC7thnC&f9I>5S*LwJ-THs*d*y>=|EHKL z+XIbaEeY}qW|%f@`}WxQq}xD&P)`@fkczn26UTWE7;rE+#2irF`^G+7z>VqoJa(;w z2F|$s2d_Ol7`58Zp>UJo4++UTGEYwIo@{yPl?tDg%%hGi5==9vPwX&QHpMBSqDnro eIQxc6FTb!k>(Q@5!I?k{7(8A5T-G@yGywoMgJf<1 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Conversions.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Conversions.png new file mode 100644 index 0000000000000000000000000000000000000000..2e37247469b2fe447287e6a2c16a4aa4a21a9f7d GIT binary patch literal 237 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbL!O@L2`>;M1%7y0k1S!x4BKt@Mr z3WRZY-v6Dia;|s(pLN=I`HiS&JO20W^60OsZkZg`-(7h2U&Dv1|CwH%O9Pt2RubeF z%rI@*l`F5>5Bxm=6p8Y5aSW-5OYMmiYf#`h!gXrO)vy1`Ll0bB{>=Dnh?H1ZoI)+n zrxwSEa3&$%ZO1O}sH`-Xdat(qyj!@LVo9)cla%pg z{LGn?Flhm3Z9=^mhSBC=1?_bNSS-JgmP;h%C!*p5;rx9qNh4rMXSALj-8<-w z5?xSbi3MVj%C#Hm0zWTsOBuS}&o>Z@j)yJ|2LuQGXY6+^TsVOy(5|vrq+${(3slsi tE1q1PdQN3@Ygm05n*mS{Yi1L1Y1;kcLjNRfa`ruw_c1g3%I+Y7ij=Gg2k|)W;$M24Fx*DH28BvT7x> zRZbO2HLd1chWqcFns@Hr>AiPb+iFke%qgx*0uP7t=lz}Meb0H*0HnRVeKMoqR88GOa>;V37L|()rGl)dY2(Aocl{3Q6bYo%R1?D|Z;dXao)Yw1)gPQ?7 z<1uUien+f`hD{K~QE*&8Shkly2FN&0*6d`ThyHPuuo(cay$_7z16Xe_x%oSSycMz7 zYC`dN3}JBzE9?{jeS&Z9BXxijz=CrKqHhNHMZjSWanSQULstbqx>=Bmj)= zE~avG5o~FJ*wh3;qXA!6ht*4J%$1f>K$jE{6@dr`2o~6yFTh<^2C=abED56a9mT~6 z)YgJ2FQ;?oe*x41XL^!Ifd+owy9<+9S@74?fUB;CEkB>GYqv~+)_@k#+IA6^oE!vH zDsWX*u*qcTE!#~2xzZw12MK_A?G?Q3Fsn=8BG%c;O1SqQfccC9y4we(ufY3KQxKSU z@c(=W>mxP3C}oLMOs9`xw(FMkA50kUB>w@w0a$nNRatR%K{|00000NkvXXu0mjf*~m2; literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cut.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Cut.png new file mode 100644 index 0000000000000000000000000000000000000000..8fdf56530731f50dbc7b70dd0e920c2d75426cc1 GIT binary patch literal 415 zcmV;Q0bu@#P)CbV$;(D2jMfReu2U^9zpaA{-85G#WvwH+%t#l2nK1c@P8voo*NT zJbg~_R6vkrSy+|@!!S^jB!ogC0tlW2Sa(sWR3OXBvidEpPB!8PfPt=~D%Kz?3JQe+ z4r$?#h|p}ckj-W>91daIHthKv*YWrsWGgw7$xzYsHEmg4q@c-U0&<>6Ch^*o_qMUs zw(Gj!c^=VNY_mGYan|jl^!RcdFr7{}msPb#{bI2IpGbg>#E`qYKMo+GiA1BcgAemp zzNvH?O8*_jhbLTIULBtS$8q%Snx-M0N?|qB&0u|P;n4TpwI3iE+-!{IpaTE^002ov JPDHLkV1mvIx%U77 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Database.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Database.png new file mode 100644 index 0000000000000000000000000000000000000000..e998bc5b8a2f4084c6ee42af898becb6cdb56515 GIT binary patch literal 527 zcmV+q0`UEbP)F@ccPYj4XyMJm(j9%P6X#e;Tti;H$CfgQSxsTv8MYg9l+`DE{~Tu}b%W&dOH50r@zw-^bn)vr z{I*1Nx~&|o)*5>|@7cAIG>jQ4l_|>FV^np5<>Yk_NCyGi(B=+-U#&dt<`-Od8OvJ4 zG#3Q&R$N!ay@GgdlX!IA2?FSa6oxX7sV|5xud`?8>2!Aebh{mzZj~MLn}FU?+kE3S zAOuv38QfY9emc;!=(<_l#w>MBLeJf0L%xkFk5JaesOnSy1{^~U0sB^hx-Ow9BR=3= zePH7Vz^>*GfcAC>&`WpvfO<>=A85PKvcSoTMz0Ql;1<-A8uWm}84Na1q!StpZb9n< ze;d>)#|_bI-~(&@28A$ibc0%W3*HPGKgJ?MG|Eq-z-n^1_aE4i8EneKfd&$v(l;Z( z=*#i5WL{jMu=EhKIE%Bjh*O`&&>o4-;{VlGH#;tCRaqU(UP26aVCN-MYF1oNLR%0QxiE-ETW}r<=xQZ2&S}cW> z+rR+BGz?{?H3uBb)lxfNqB}1wImCSH$ zdboG2UuzlyW~}p9;9tLsc9ad{I3{v!@T(+Ilm!?|)3YvzmS*XRM> z^qvLiDii@dEe=f!qjvHY6~&3NWQ8a$p^*Cko}Wj+d9M%f>H$p3ZJq);S^}-cPpE1D zisFVWI|$;TZ;<|_Xq{nw;aXJ>fRJ!N;_Q$G2b~;6jU~`-R|e_z+GwanoXGnG+D0k6 z)xQBo0IBdQ)KVO161btDr$(TbH*l0QLx{gXHaQMHIYrNS2R^o71cbLO*mJ*z7_or~ z0o2QW0$5SX&w-0hAin#A_KYLwc#6oEmqvh)aG?;hBO6*m)HjQO?HN9=JcM`o0d|~| zhy~3ka8`Oo44qB`w)a;@0b- z?{;U~?e4aRd1t#zwpS!xoJ`-DJw((RWeuk;t6*Ju-;mP6+CE z8SGmW?5hO!B?6WVbG?N2aUR;?3p5XdD6c)ipW(9vN;rUAEh(e1KZn%nJbp+LQn4V^ z?Euux39$HGq?ezG{fs<==EfbccQXXYIRKt{$u*ZsC9$So&w*{6nCtbr4OyB-`~9S7 z#|2QybXYEzkIB{aKHh zvN{7JGs!Rv5g&!`!&1PT%(1S1U;6ws+(!8h2L*xFcVj4>u!Xk%lgLBxIV z+VFJb-1XuDY?S2e$=qdT&YgQ#I6OKo4GaIQ5&%J80=?kB!57dOKGfa-^==rLBL&V zpOJ4XO(rm0E73ajkpOolGWFvHHzTXXBI|^&$_<<>uP|JT$H7IIz~r78xln+b&!d&g zF?_k3*2u9K-*hnT( zOC+G|>_84|L2|n>l>v7qvOak}i4q}l0Fui!Mji?1ohfY!jPF^AL?HY9kep6@uC1eL zvrSLHoryf=91cVF`5-!+3|CiI@nN;1VzG>8pm)A_t83&?2$I(e(e7aQJfQ_yS+d~W zY)08+8lA$_*T~OX+_1AwnAXqCi%*2h^QPYkCa)&1$s1?1{tbpGsr}D2ztjK#002ov JPDHLkV1j6?*mM8@ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisconnectedDatabase.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisconnectedDatabase.png new file mode 100644 index 0000000000000000000000000000000000000000..b81a1715b9c61ae2badf8637626d56ee5339751b GIT binary patch literal 663 zcmV;I0%-k-P)K#$=Ec3UwL}^s zGtpb3ZKCvF+Ah`1rMxcCaJ>`IT|LP?0gCz>0kaZ!OT|+9qhy-gzEHaHy=sEUwo*)pIg2Q@41k9HM z_{h%eZ@~Ag8@bFU2!aDFI|qib5Xc7-m&ux!)OpN2mM6;r2zqUZ_}+mDTFA+pNbzpu z^9ia#A&-m@Mx0qEpan#C--{if0ub`sAw*rkHv-PE@D1v*NXlFNEeN`9nnT$!UJj(155+hKN*JJ%bhNtV3kTR zt!)*r5IG}7xULTS5=q4?OuU&q5BsaD@GjlQmO({}%*9q3oq8EIJ`Ta5K1K8Wlai_q xs(xon)A2mLD~aX5^W5oUPH}zV=#fXF_b0CvyqJBP6 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisconnectedServer.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/DisconnectedServer.png new file mode 100644 index 0000000000000000000000000000000000000000..6badaecc7378730ee210015c9d8502560779e0d0 GIT binary patch literal 506 zcmVX(8Zz*VyHwQ{mE5He`&--(lB7?fI%eGVj>b15fY2QQjic@hL*GjB>KLg#d?Zv&)Et?g-$_e}sK^fCtR3VRFF90S<)#xI8#x z6Wp_aD<0qpd?j#=&5>&e0)oChJSCryeoG_uxxT00k&H9Ay$t;iaN67qANwe1ZGd-S z6|Uh4tc*^>r`3^tww!+g0tPcV^xD>)NtOu>p5ItW|EIx&kOl*@0Oic}FwHlA*6^NCTh$q-ks(G`~ z2u7zvT*d2{T#jf_5h5~~_!JTb189muT&W^@TuG5Nk}tzUULL|ysrVG)3ME;+8VW6r w5sa(&k0_ig6;8kv*QiXxvVY~wes&K&0C@nQz-4*1`2YX_07*qoM6N<$f`Dh@ZvX%Q literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Domain.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Domain.png new file mode 100644 index 0000000000000000000000000000000000000000..15ab7d7efbaf624d00b69c2db5126b409fff1c27 GIT binary patch literal 320 zcmV-G0l)rc4lu&te$H7hKAx-g&|63ruza^?YA} z7Q`=$0uE1B0RnN`qJYCAJ3t_wSrl-1XnSgbcwwS|!vjk#DAVE(DF^c0@~Exd>H8ngKKOY4;ipTF zK3#qM`I>*wwe5#*Jo$WU=i%Fr-rs)u`QGy{_jez8ux;;yod+K-TKRCv>W6!dJbd!u z;fpVicO81X_vn+CU!OjD^Yq!rXRp2<7du)2bQ@nukY6wZE0<+z`?Tc;pMLxK=ikIA z_Z2{yX`U{QArj%fXJ3moDG0b-R6MhVN5lB4(Zb!CU;pJ_KjWeLf8XA7QVa|&b37UU ztEbF4rhG70Z*`@CBrt#5xn_Z@2=FG@X0JSk#8%?&o7Sr5Wi~a zvg)tjn>$q-53`lOp0&4=L&q%t&bDgTe~DWM4fW|+PA literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/EnableArgument.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/EnableArgument.png new file mode 100644 index 0000000000000000000000000000000000000000..4ba0a0a5e1066ef42482ae0f452fae5730e79f62 GIT binary patch literal 690 zcmV;j0!{siP)5}X;SOrJItDzI#*3xkEz{^#$ z-D5Nu*#|?*_|gVl&*8%x=&B;kG$TurLH{Cqo3V^nY0z2(ttHTQ7uwBin(H2~AEtR3 z0)ofcg*ZsA`i(0KRrN7md`$6yN6FB56<%lZE+_WAtG!0+(mL;ao*$+&XH9qceq&YK zJeS=QM#?B@sQL}JSHJ=vr4)v#^Yf`uP?rQXNl=$S#1zN%I=09$o$Ad{y$5RI;o%l2 zjiMzjsLi~?FDGWMi)oCT#@b5b%#l`2+>e9@o1i+DxL}uLt({`EkAnGddpX>WfYNZN zSO%8m@Hi407SnjhrCt3(jW#B#=0kZH-11?2kdAAPmm;_}9&&>qKLGB`fl_~{mBHfMClri^VsEJM=3A~4&HMG~ z_zLTs`g22`VHpNR1}GF{iVz>gsNaYe3F;t2a9xmZ1;qv^H-Nu4uG^)uYrs9MZ|d_k_DLQp5D7d#a-2pR=Vf=co2q=+`^v<945s&tA3mqpJ` z@hMS|EvOeX3t9wC0<-AdD-r^fC&^I*V*Ry`i{gbzUsf1(_C&BAG@C?UvLHi{CHhiD zO|*Ifmgpy24`&62_$gt-G@V~LS*f$Uw82jD)gL%X^3;F$ Y4!0SOnp0Y1m;e9(07*qoM6N<$f*4{uDF6Tf literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Erase.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Erase.png new file mode 100644 index 0000000000000000000000000000000000000000..a9ad128b83cde478e0116a6ebd4cb02a224204f4 GIT binary patch literal 451 zcmV;!0X+VRP)4aar06OFqBH9@BIr7#6%t5kg%A=YPa+6hI|?umB|xIZRX|eQUtQ64RWma@ zd;4akYce*P%HdcK!Z1ls3?jkmlgDS z4uZiTlWct}pg|{sARw2^Vl;Y1x9h-h+Q?=fn1HddR6sutiKld0g6ldM4EpGFI%qbV zuq+d{Z9x>znP7iTKpnfpbs~{~u4{Z&*LBfuw|Uqw45+FKO;aJu1tv&;3FzY@91cTK zikM8^F&qx4V8ir2C)SC@SP^pvhS*!U z2h@3-OkVL_w{07yY0``qg*Bv7w=DQf9Id>{?4~J-Ock_flUj7%83Y2t!p&PH@UinP tm1IOB;%uGUYdt0k91wS`{g>Ccj86+;0MO)>;{^Z!002ovPDHLkV1n~&!7l&+ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Execute.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Execute.png new file mode 100644 index 0000000000000000000000000000000000000000..289805c9eae7629cec062e390bb04fcee37aafb6 GIT binary patch literal 276 zcmV+v0qg#WP)YPRq+ApQ@c$u;2r(ObR$i8TbP0qf5s191vbhF~>d<%zKWQ+DhB-*`5Y zpdnZdSal-mf8Tbs|I_za{NHlE0Iwlf4Oo3L?*D`xI{zo_H2gn%zw`fX7b|cYg4KYv zr<49q+GPy%hQBh+Lx?h9-RboIQ+HebpSIWT|GY!~|94$(B+UgI z&gT4|zSrUZ{6m32&CR5T!KQPC|K}eL{=e%=GkLK9a`LV#t>mYJa}SnNloBb+3l!%@ aQZWE0r_1pX7Vo_P0000h literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ExecuteSave.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ExecuteSave.png new file mode 100644 index 0000000000000000000000000000000000000000..ff2abb9fd4438d77bc3289d8233b2273bfbd3f4f GIT binary patch literal 472 zcmV;}0Vn>6P)Nkl3Qr1BkI|l?suPcn8=dFG*w1WEhnM#+KmOzuM3vFf)y9)z(-A z$`;I4m)%FU7?|qn)Vc2SyYF*Ow@9ka;Nk*{07U6Z#EQ4w1Nbk50L%Nean=0`LV!6z zf)PVDbO()TLkKW0NHMsc36(Jqt4A$qK?tz0TaBTOEGRZ}pth7^?YQmF5CSai)j+}L z#@omPXDq_ZwiL~ydSum`eiKIk?Op?vhJ0|QVoX}gz@PNe0kz#vF%*d*5RSle|BQ== zDCH)EAVmVK95g{?DuKpY9xv{r=QFdz;-bikbvhkMxPGEs&#Es8&>yx!V-tgS_9c2} zW~cd#4qZJ);kbLIVt43;ax%R?31Cm=o&6sM$ILFH8wIkhl->(F1;|$dNx-3RHf8Dr z;5{gxwxdGhfOy;q@z^OURW4L1&mq?)0bl+FW_E9SQP{on;r62TT}Tuj$QLi)0N?GG znZvd~Vhg@dB(VX>kQcr4!CwK~`>i)mF&d&b{5C*VJY~N98SokMjks45;M1%i@@N}WKjqMNY>Of z)R!kWwskZCQG3Va2A|1u7f+eDcPxuo0pyZ!1pau@${J-&p!FjpHIIuxF6pwb#MOD>3q{(m(G=P zdAG+@(&%DgHdo8seye56xD#Ej7#>VqQ*)(|HB-5vWT|e6s=b_TUGvZ}sbP_U(N3?tb>}fcNl<`0$MQ z@sIfNk@@qO`SY6k^ql(ipZoTw`}V2)_pSZ-v=0F8<^TWy19VbOQvjBh!~x$k0001h zNklCPRoB_M1(Q zMd~R7z$^zXuU(RKJIMg%BMj;FxE^EZ`D_ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Favicon.ico b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..6a188d538076f52875fd4748fde3d29f6b537b14 GIT binary patch literal 1406 zcmeHHyJ`YK6g|5->L$DHuKQjy`{?o+`3Awp!W1IJ(n7G21XBotU}I%vC4!Y;VIzr! zg@yiyRmzYeW>&+JVEQ!9aPHi5xHEG(#RWLF6$QujKme0vw+xXKFmTAQ2;6bU<18Ew z2eeu(ESF0Z3Iz;@L+tl^)M_>Cb~{X`Q}lX0l*?tz=X0#rYt-v?bUGc3Mk5Rc15_#% zG@DI~$78hHZIntSY&ILLRx2zP3lxh*%w{t*8Vz*2UG)2XRI61?CKGJ8+q0f7!o`7$ z1OMg#&;S0K(x2P~QQ^jl%lU-(Tr9XLO(9w;=J2kZyzG6~%VLhVZAZMx3DKj5qvRCH zPB`kdDjI-5sA*eF5KOA%0a2DsJ84Nt(e#MTxWW5+CbT4yRu#r|S(Xo z(lm7(SDEnXE~_?U2q95mric-Pn2m&$h=Vbfw@UMlnVDK@Awh35 z9}O5z`CyFkU+E=rw@m{TJ%lPgK(*6q6sw zUk#9pzakawK#sH^iI0ed>c}KoXt#%0Ra)ACij;Cgq{R_p-T}_`y9n+);fSxnz5ak* zTNc}vB(|0%IIIao#WKaT0|1v!Q zKf}l8Dc&%}!LLZT2$d${31A!%Jr#;=#&dWaDcx8X_(56;xYJllC b&I)`3jnVKCv%D#@00000NkvXXu0mjfGM%Ou literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ForeignKey.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ForeignKey.png new file mode 100644 index 0000000000000000000000000000000000000000..d4b99e88f4c400b60d199c36125efd577345e2e5 GIT binary patch literal 250 zcmV;h1fO(#g=Q#o26n_AQRhMOv zi)osmwMNr47{^gyv;=ouhraKzZJWfN0M5AsP*oM`x)wi8Q|T;85=kcP+JTHf025e+ zz%0v-z>7VSPfO(D+P0O-oIec1drN%$jQ_u&UQcW3f6KT1umAu607*qoM6N<$f?pnG Awg3PC literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Fts.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Fts.png new file mode 100644 index 0000000000000000000000000000000000000000..4bbc8a8ecb72c78a8a68f7f28134e3d03b595fff GIT binary patch literal 675 zcmV;U0$lxxP)yzyxCeH3tBx z`#@ZfbaF}o55r%$B4uljg2J|`2{;XKvN98BlJLm?!oUo20fW$!OAH?Uo(yc?KQes! z@`d5`$FB?;&cXAs83Hyy#WCokLXoGZ>H!k$iQ7Vfo|P46pCsWLURj7Xv6v&<$aNnZE1vMTX}O@1ht|!)C}Z z;qi9{rKe{Yyqz2vw(i@{@ag+66hpwVV3AP%{Tu)gtisX~eoAW12YCnP5^iA$hR?uQ z5D^lBYXsSRY+)w@*RPKZI)=um2??7aLXvWD&DZy>Ww?7_9fOgvF@u4{Pi7!zdQ@r$xj|VU^sv3#D_1RKPT=xc4`AwFCYVpn1cELIQSAg zCI2$qzkM5Izygr1K+PZEig0CT7_jvYo)63`_kq{}n>;{(0RZRv60wV`zaans002ov JPDHLkV1j+FD5?Me literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsCfg.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsCfg.png new file mode 100644 index 0000000000000000000000000000000000000000..6d6df98940779a1c6801ffa22e765774ead8ddea GIT binary patch literal 612 zcmV-q0-ODbP)T@pOGG`r-?ub(D-e3&VdnkL`+VMa-uHPK0QNr`Yfz`t*&mO` zzpASGj`2oM>Qj9z01ftfy%+_A!(mW;EP%t|Kq8SqI-UMV0D5M#SrC+swgZX$Xw5sgN70D@e!OaVEwQbw%&97ivgK`SG3{%H?4)Ky{3WHMs+ zhk#!Y3s-*tA<;>Y`Re^m%tfNOQ!IjxFPTh=^WOp34WW%AbMl&wv(X50xg2h)DkMpw z9Kh*x{s|a?P>A3P&0|Sf6y~{52)d>{qeN1eY&P590fRIW#C{@#EBt?DuhjFnW-N4Z yD1}z5Risf|q<=Mn*yYn(+_=FtIr?q)J^2A7E+!+R49ivk0000IqP)nR6Zooa{sZX-AQoUC31pZXh_~Cnx7_OW-)ObRfBssV_aFla>iciQAOOVY7e+|F zcU|lH-)v4g7=sK_pX>6UtJG>g$Z&iHoCo6nApF^d^?y%P$bX9!5&z8>B>gvE5(_p+ zw%_qTTcKq?rni6s2Cg#a*K0xyfZ?0|!vE7UbKnM9tPKHsOSs7v(Ya;XizA40j204cRc9z0m1B{BMfeiq;#B_t_fA%8F|H;$q9T=>u=Iu{jwiy)S z|3zEvz&5B9>iuulWc}}xqy^DjHW3~kAkExm*8gi3PxycA*s=KxK$Fjxt-JVNq|_g5 z2urR7*srFmT){3v)(pZROF)`;9oYNdv@!NQ$bkJI=Y>vP``@Uu2y6%lgPf?n$QA4Y zWX<6d%Rn~&SFH;A4~|}-<^YfZARIky=l}8@NB_&!M8ORbYOn=+3*;)V?p&~D5RDRu zK+Oq2{2pXT$b`-RXPkNWKXS>!|6KXbaD$8*qT!mAihR#wqywO41DGLhEi1r=Og;VL zzs-a?umO@Ko?yT0W80Pgi5YqS<12Ii%M^J27f7-B9~|I+ z9*7lirbwV>0Z`0<4DpUk{NLHp@qgmPiT{(*lmB}K`}7l)pJ0Z73}~pY{~sP2@*Zew j00XJOD>7+4AtwU>bpK;|7W?nJ00000NkvXXu0mjf-T@+8 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsParser.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/FtsParser.png new file mode 100644 index 0000000000000000000000000000000000000000..be510ec43d3bc4bd931edc12e92cc864df0ce09f GIT binary patch literal 601 zcmV-f0;c_mP)$J)KT2OyViy2A(Lfxx(hjb3zp5Z@gz&SxA3%WUBH~0RaaPv3 zUsW(^?4dY8#E7TFYb#^2&V8lws_PiGxvq%`Z{LdrdhJLXI{^fVL1LCDSjp!maDR0V zE@d|%n){#RN9LEooFB=UX`>E+M(D&ev1H|dye;la!E(J~k^sMs?LgnXG58145TDD) zOx;AWa1=l{F-knQGAirbR}NnnBJ4i{vt9v6veHn4G2``vq;mbN?ihjvBN-cqIkj%_1$U7Qg{QmC0xM2(87vKiKmK(eY1c z42B{0D)2?FBJ%JJxPD`55z(&82!-|$cA4>b9F?1ICcv=dVt*2mJMY}brPeSKi3FTZrxb9~ z`OgMHg@k`Z@U^s|r#lK=*OANRpsK1AaF$Be0=JOZSmM=MaI3c$fz$r{DPN;wt-skn nc2kKraAAQ4CkR_*Z@u6zBnnRxe&dCf00000NkvXXu0mjf6zdc5 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Function.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Function.png new file mode 100644 index 0000000000000000000000000000000000000000..a68e1fdeb2baaab776ee09152b1f0d4fd66ce8d1 GIT binary patch literal 202 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`6FprVLo9lefBgS%&#Wr3ye0hN z%}j?s@?Fa(rZD(?zNB4$Kw`e)4xS(XKRm7%={YU1NAJh)|MFbN(m2fiFM3ctzkX3d ziSq-$dqvNUFG}1L*ul7&Z@(&M^Opq@0lS}AUX+;4UC`!Ob>3N|$CRhwsFT-mW|1Ca zu?Zm;M1%y^7Al(b6k_sun(b z|NVd0rWYyg4{|0x`uzLP+~e>1RzAv^db@hz-GfiRE@=4g0o2Y?666=mFzw3Q!bdi2 zKz@{`i(^PdTx_2wUxR_bVXFu4a{kxr8Yr!J5UnFGq{p+tz@g`3a*ybYEe!A6+8!r; zPb)jPsaE>Z literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/GurusHint.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/GurusHint.png new file mode 100644 index 0000000000000000000000000000000000000000..1ee60f11e12e500de5becd2901e9026f8e24a626 GIT binary patch literal 609 zcmV-n0-pVeP)y45y1vnJYVqcG`?IcTT?S?scFTZCim z(2XGIj)sVm4prX7+nkREv~?rka1Q4@?>lF{?^^?~<^<34SM0d;kmL4Mk7s!3cK@QF zntC)NW>K>!z99$#s`)%l0|A)19A@v1Fg<#UGeyR!-^XUe5W8exH{7bKqSNW1S1Msp zC}95Cz)wTRk54D~-aLT$BFSdN5K9_nU>EDzY!;)@2wz$)q=l!r8&0BBEW>KO$L!-F zG<6>vPvVdt35+3@G^8biSGulaI-Mf(ECc2BF~(Di<>E^XT3%i15ko9#NJ|Fa27>`} zy%UP!e7m*e_XX$L-^51OVilicnWj-?=?9B2Cdeloap&cHFzU9PKpULMV66Z82T zmSwSx4!j=FY*Bp9zzHwUf2C`hOeQSq^*Vw)A6vz)G_b!C%w#g?^?K-byX-gY-nIWW v_+zqHE|;AXmoDP|WpJGi(#|(8VkmwCXkFu@iY3`q00000NkvXXu0mjfIaL;y literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Help.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Help.png new file mode 100644 index 0000000000000000000000000000000000000000..916726cb208d144658e6726e37ba0ccd6a85150f GIT binary patch literal 480 zcmV<60U!Q}P))RTof(6^ap+S*aMArKEusQbgdYO`9fY)h|Y%KtxIz8vbjQ zK$Rgnqb=XgH(3m-zyL4vA@e-ndC#Z-ppa(gs6$5yQ6LFNQP#i9A_Y4s-m{Pzv3Do( z-yXbF*YQfvV9o+A(9cA>l(tp^?@h`=z#6g@BT|AMNnsL6eu~a>$W>P13u{D4gMf{9 z7#JYfjf`MGT9_q?l^{Ev&4`yL5G#)(C%CY8-pwTK^#bnhX$8+!2LT2GZ8#07#Qs-N zEfV|;9!q01jTy(mA@;kjUZ7*$uaooCeH-boE%s7|je8MR(*$}%OQR$*H5W*>@2zcJ zginGhqce2RuwPg!!byISZXaZ@v*}lmz)H^Fhpb@#zd6O* zaNzH4_yVm2+-=rEy{8c=jnLDC{mY)Fa4Uf?oOd8oaZv?3B5zIxhnm5y1jgDD|Nh48 zY?LF&Bnlqty-bUHn*C|eOLxMd4u?cfJj WDB1D12`x$h0000d5)go z((XWfpNI62gWwM!Vt3-gY_^REhR`K<+#2EsJcL3KGuC;em3Jf$kBES02}Vl7Qx-_s zJj6l?v(^R7^?1xFL{K&q&?UF)s}TJ`$VwR*wSsK13ONvB7tkf-!XgeQQv5NV@+#zD s2vO%U`womCi^+*3dobF5y~2O^2CmEW0(X04=>Px#07*qoM6N<$f?=SotpET3 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/History.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/History.png new file mode 100644 index 0000000000000000000000000000000000000000..5d9a56ce705793b77307926845da68c9c41d438c GIT binary patch literal 529 zcmV+s0`C2ZP)vN|5a`>)BomQHTd9*mD5sdtt8EruWLSQaW#j7)oI`?4ZzNtnKmXM70v33l z)CndSy>2>X-uZR&5sR~P>}l)b;LIlu^xP%Xboxmq61iO>AT?p&awk_3rq8l8^`6aj zhss0}S#yjtO$`t|&c1=GgqvF~Xpy)-f%LdB_CWVTgIP|0WN&>8&vmgS5XfMVa6=R`Gq=I~$^RrYUQIy=>}iXg0s*hz&H$X;A>eUq{4pr#?`x;>$YHj==W&nL zB7o=bKHvldZor}NIR}v4u?0!r#rSptjl*@dY-G~x*YhhKTL^H4Lr`w9l%587_P;>t zcP`<-3sq29UuA7f5Q;TYQ61%PewGzYUU~KMj$LKh+gSYDt;LzM#@Ujs0K2Jw2Q%+T Tr@O7m00000NkvXXu0mjfp;_=@ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/I.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/I.png new file mode 100644 index 0000000000000000000000000000000000000000..00fd33455766be308a29d24979925fd2522a15ac GIT binary patch literal 89 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE;=f~SjPNJU)o0_lv*te@u{%ne>S l{b~*r@7q;yrFF3$3&X5#$><=j{xd+e44$rjF6*2UngD|g7_9&R literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Import.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Import.png new file mode 100644 index 0000000000000000000000000000000000000000..fe49e63766b8d89f908f900ce5953097e033c7e2 GIT binary patch literal 482 zcmV<80UiE{P)Wpwf8r3kA!1p)bg zy16;s)TU%tFZHv_?4M*dh%qgf+~t6^x!K81c#&K9(?W zn5Qj1nZu60eO>T+R&+q?3t)@@JRQJb4*=e349M@be-W`*4Domzi9`bFbQ+mV2H9+u z{tZW@vxAZPq1WmO>gq0izCE|W=kp<%Oj2_o5I~_&K(SavKA$%LXw@&!)J}D?TQ~1O zE86iQEl~*Tnno&>qR9lnFbsmhAVg8@0-Bl+jmi<~%C>IaKvlA#BFsb0PEiP{Pipf# z50XsGk|cEjjmiOPiW8c=j;d%yS(ww!lSTtlpO{Hz>wQCfuX-9AIJvsp<;1m-3(KAyuvhKO1cuzW(KIu|FGKp z8!9(**K14zCZ;Mebd=>nY=YXBQQOBbrJ)ec2hmZ*T?}*gzQHu0FIf@l=YL@O*B>O? zK{o$^*!~CTodx^fVj9qupuo^mnG3ZEVp~#WFTSDDb@Rf282|ukS2pnRDTNOJ0000gOd>Q)Kh>a75eKL#NF&ydy7&oHqzpW!c%{TC<}UDAaJL}-9yft-cxl9IMb48Q&WZHL;J zT-^(2gVmwO0=i2&%5xe1L2XO{YM$9t1a?70Q5VC!eQ&_(K?FE2pa)QQf&$ofuz!Cc v{0$Uin7j84JW-*z0No|TrbsH}MhXD{M0@~1(gy;B#H!75v1thL+t+LJ8Wm?+%=Q;di$fD zI(6sXd(PZn^8(<7P!#2>4o$~i$3%zn6jL6)w+B=muZ$T9)l#X1e!q{&WFiOz0?_^6 ziC{2@)oO*!W`q5Hk4~qVh z9*4){kuMqK^ZAV9@rXvF0iVx@N~MBkvnj2RD*`N&6(o~M*laclTCG--Y_V7{olYfI zEEc7TXMxsWFc4=xpNHLUm+}nqZnwjFy~b!X5&_Pp-EPY}xfJ-q@|VjcTCEn`ZZ|Yd zdq?I5%H=W~4u`ZbpUR$z(gf!!{Y5y+oPXa10lN+J^KLW3h-`4zfKf_OUc%biCVOF{T0000Fmw` literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Job.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Job.png new file mode 100644 index 0000000000000000000000000000000000000000..b416209e87ad9ddd70d32028643089ed3ab896a9 GIT binary patch literal 551 zcmV+?0@(eDP)dT*s~CeNhH%mVj;5{u^78rT(*513wzpVc2?%F`g=16eJT`|%p*S5-hI*kmItT`X zp|&;3YLm^D7bxa@zVMsF;bk}OPh>>(6he{&b#4X>hH9&qwQsdnE+CuwhnIZVzt*vN5g`~_)n|hX2xl4<9q><$@xX#!iHpm3DGa%N zT*SU8V`tSvFto}~xekOg!90WJ5uWzt>@<#V;#_z)q%-&*{sbcM_SgwVu%bMdfpFfs zieo((!`8k8e}5NG`(%6^2kX1o2!ye{;wgmXU|A`jLeZ~r;YT};8f+qMapyuf_YU4Z p&BCHN)2JwI3XJYdZIiP&^9;Hv_0(z%Dog+X002ovPDHLkV1ih6{7(P? literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Jobs.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Jobs.png new file mode 100644 index 0000000000000000000000000000000000000000..b4dd827686117dac648934be6324ed238d1de641 GIT binary patch literal 396 zcmV;70dxL|P)%G2*-uU3W?CLltyXN4W>bQGe}IRr*om&$qiJHm<@3VZ z=fzn`#_06NpQXp#=*gg^&Fl5ksH)SnuhZ@J)pcptP(0V~_t<`I*s7}9@c7(jTHW#Z z-c~;0vaaFt`QmwH^^{rt@yd!7Yf>B!n-WH4?)e;Q~JZ0000DBTL=4rd6;M4%ky*I zDQTbCpd~0spf?eC?6N!ac9>xmKp6z(j|dhDL#Yror1pv2rxFQd;Bs*c-I(Y0Rj2WC zie}7`DUOgtA_b~Uex^>dcY)JA!wJfqh-oSKjrA`Eq1$Lefi`B`rKZ5rMV zmb-!ZzJh3{5pQYk+`T9^CeV27RieZD;0V)S!}M0My)6zeC$QZd`<3xfut>eV^rHe* zGv>nb&v^(+*quDKpX0bX*$@1-_LE~x9HlH~xNhxo^^~V1rpO!&Cu`!sWBmUM$_L5c V;JM{@0Am0E002ovPDHLkV1khej}rg@ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/L.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/L.png new file mode 100644 index 0000000000000000000000000000000000000000..b67c8375ad29efd2b807e8022ed12393ecded1d6 GIT binary patch literal 90 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE;=qNj^vNJU)o0_lv*te@u{*d!|T mWJ({d;Pza`&MCpVn1SKxTDjbIZl6q`Vg^rFKbLh*2~7Y&m=(; zLFz#2LHb|@%zky-vt~E7^EKA zfZ18-Q%c|GyRF8GvjEh$hPbTo?f5Wc~kRJvS==0000v!(&-}!(36#e~E^6zii z|GyQw9~4gj-NsWAM2tykY>u902?6z}(RaSV|N5A8oF)}$c75FQ|) ze0hsbi1yi2UcdkE=f1YrfSvE~n`FiYg|5jeeM|}!VOt;H2$PIw)t+_yuFT~x6WTIb zD&zLJeKp@7c=%+#%iiN`nOtmZ?(A$cU~0(E{j5~Q%CIo^-jN3_*>*0u?i*h2^9VN* zIq>;&>8xj#%fEhXmfovVwRd^&tNHp4S)3o(zv~Ezmo1!?3UnHSr>mdKI;Vst0NKg7 Ab^rhX literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Listen.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Listen.png new file mode 100644 index 0000000000000000000000000000000000000000..5cf37a4658bc510bc7ac9fbf3b855cf981d9dd10 GIT binary patch literal 244 zcmVDt`bKl|&!7ipPa?aJNSXk4UijpzlzR!OZu`qipyn=gv?sR7Xu=WgTk!{<2 z7>wW5z#JR%8Ud^V=D6!BG)+kZzP5`wPLdc!aU%mT=8d+kp!H*lgCIbjCv;$p(=>%r zYKlG2LzXEzP}h19bIuV(f(~eXU&M~%K*|dp==?8-cP237OUu^Ttp>4F!_!e4no^n4oN`0YAd{&)Gpy1E9%9*L8;t z_*1pRXBO`JHy2=&K)`KVqONm@3RTTC7XqgAjx2i&XQ~<@U<)5KO^Kp-{$S7ZV46ED z)eHg-M^OaBFtDX&5L8tGLI}3hj09cx8g5xzqkM@=HEBx6g2`u;)^H(*UDrh%lUaeZ zM!=5aAPlc+!Biw_C=Hn42+OkI`{!kWtR_haYFVdQ&MBb@0F&P%lmGw# literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Loading.gif b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Loading.gif new file mode 100644 index 0000000000000000000000000000000000000000..874e0db1cc8cea26dec0986940715e969475e093 GIT binary patch literal 2090 zcmaLYeM}Q)90%~b_Ii|3*x435N==SZq`s~coXnTy3Z<68un4WdM4^<5AXr=!bZ+ZA z1)U;vY%)w}$8_PJk!3GzF0L(AH{*2ZqQ-#34b3v08W&BrEMY&mQDhn3KX9Xoda{(Ze(pOKN_@p#l~b#rs`)Xy^)ww=&cI%Rw7=))yvaLmxhN0mru z|DwA`39a6=35~JaZgvG+ed$~_J7`2lNggK~DYG=N+(v^p9LH-T-bLOvx_VSs2X8wM zNim*1F+!rHsDEPc#HI;~E+G#`=T zda1lq&g(tkI_VLWbmAwJ+p&Q_{Gx1Bz?rXy@O#)fv0+ozgU$cpfPLK?=b_ zm`t#dg$L|^Bdr6eeR}x|hBaj&TWWVvfm(&QR5H8Id1V~8(F8~>`(mT*L0=%#l*!^4 z)42qG_IqpAL}Og*3RS9T5y5x*%0~qIgz=J z_sA$Jj_;_}2x+PoQ>i{$qI}C=U1Z%-BWw@f{nRVb=F6yfq<9y3$@s$-6U+T0&(}u| zil0X~e5;g|xK%h$34j`LLJy#^5h~;f+BtJo3#qyxRh?4=b+swH1{F{V$F(}lqi>RP zHu)Z$4CPY_Q>JY=c;c@eysz`9uhPlBke^#gw`@E4ORIVnm$fV#IZ9l^F->LDOEN#2 zGTwJRO@@~UW4H*$vnNs3XXMIYBij~WA=IbGYc|&zEbSCQ1pu2+G?go0In!8y??Jc9 zmjc)irJBcAdOOw?p$Qb(E~S6Bv>Z2xQ&M^Ka=?yvWOXMFWP}C_)$D`s&?q63aZEyP zlmx8!n#yM+%M4be1PqfQL%4I2h252yQ-W^YbO~m#oqZ1yvV9p5Z10Ai@l0AFlF~s1 zDUWjnUalVJv~;qigup8p84i7ce=~xH>nsQoMZXeS?k9=cFUqiI&-};>h+35`#g1JmYN zc$hi{6iyKwS$2LH=iVZ?CvwT+4iR0&-MX+)yW3A@)u5O9l}bX?&aSWKiL@?<#c`RB zORWpyE2vN0*#s&cU5wxRY!9`2V^6^5RJg*W=aWqjovGWK6q)-f6X!jzAWLTVhYkQ2 zprB-kAbxu3r=U<(orhmlx1?KgHK8)o;Fz^?qVSBH*NnFIx5*7D3o MJ+{XIhwIvZ076~XN&o-= literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/LowerArgument.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/LowerArgument.png new file mode 100644 index 0000000000000000000000000000000000000000..9334e9076033a9cc26eeac8df7fb58df479df361 GIT binary patch literal 172 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!60wlNoGJgf6ialK%Lp09soe;>?V8GF~_k7v9 zh0kB^Tz5fIs?QWQ|ajnH>N%c{IgZ-4wL%9 zWou4_adx~E+N53V?BFp|DpAq1M{u(HmygaCq6Zh;_~xX4P{dl~YuUQF^Xz|mTQE3i Wh%rn)&g}!Vp25@A&t;ucLK6T^)j+cV literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Lplus.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Lplus.png new file mode 100644 index 0000000000000000000000000000000000000000..4d5cd78786380cb4e39a0c64a676d6486dd47317 GIT binary patch literal 127 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE;=o2QFoNJU(7$^xSUnF-#(r~l8| zB{fM`W{#drsp28m77^jcNp6SYTuuaMJ*aQ_qhS2O-mEmBvgyl$&qhx-+AzGF5M+?0 Zz~B;*DB8KmQx9k&gQu&X%Q~loCIHiIDHH$z literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Node.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Node.png new file mode 100644 index 0000000000000000000000000000000000000000..c68cd4442971889fe389f808d60ab75190fe09da GIT binary patch literal 484 zcmVr0 z??Eg9#A8kLm2Bh+7IOUz`JpJ1DHmNy1`nO6tc*kV=w2HDql34{7jVbL{oMm7$S!XX zy&9((J7)I~qc}YPhc?s%gHj6n>*p&+)hk7ON|+*Kb-f+BX6{Z8H!qd$(e-vgQF93X a)cybwNCk4{1tGNn0000D6AqDkv%{^8M>y`Eza4W|rBM&-|(PkKskDNR#=m zN#)#Cle3#1l@#`BybFCJwI?k3{0a9Q-}7CEPt16%WWc-LG5ge8OVK+Y7AnpzUG_;T z`eJ%;nwFPTrq#_gAtp2P1Qr^_(zPSJZ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ObjectNotFound.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ObjectNotFound.png new file mode 100644 index 0000000000000000000000000000000000000000..648b0fe87f1e84f25c76a80b9bc8450d257bc6bf GIT binary patch literal 508 zcmV=ItqB#_+N_FJ88RHSw^D z5P#71l$yVpEG+<77aFLPnqg+286!hz+BGUqKPZ!7u3XnK%uLO{zo>zgEmvtD?}B@dci904VM@)bovr z!V`d{e+K?~{56@mEKX|=q}?$q zFAfsz13tZffZN^&+>W6XP3)tuWFB=tC`5pnI0aIKa-+diG&wryvk2nR43#sUV(6R;q0000$?QS^ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OfferedReplicationSet.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OfferedReplicationSet.png new file mode 100644 index 0000000000000000000000000000000000000000..39076e7edc392ae2d7ff33993d819eb3106d1661 GIT binary patch literal 492 zcmVh>~ihP?j*8ZJ6r4 zgnxt-rw)MopWyjfCPRNBgqCTpsUb+bmGFcCoTRX5fZ@qs3Gw3Z6`+} zG+EpU%r{CbUMeu>X=NpJ9X*hcbzDKT#N=ur%~QuRQit~{Ft}5~6{IUy4OAeMa*YBL zhgC4{S37Pl;rxJBKpM*ad4SBD! iIPjkWerSjf)A?OP0cfg^WRe49raiQ83yitZ~iy~ zTbqHYjKj!BpucpZD0LEU^UvU1HgH6p_q@)V*&;SFD%O_zd}~k?JD_A+>ek>-eEeHxp4jiJ`i*P zzXBG4IpC3z-E~rNf>ii6fLT=mgTN9nZebU9gzn>EC(f+S4?PBo98GCzraqej9{_y- z>c!lkT)uUmxbqFsLXa6^ZTX&;kPGyG615*!di=I zlQ`Po;?y;ik=Z%-K3^E+&9gg2;HUr*2Wu)@74~-Pq{ZBu0P{e}3ba_5TD3;5{{j;? zuA`F{kf4acHu7UnP~b;pduHqH6L$pB1`zgk>YN>)rgK%w?_zSb?T)&OLnQ3Q62>z;QUV zW6;yj?$>pIlK+*X&LPc4$iVOz=#~XMOz7Ykr4(8h_*r=m@YH{WU$sA+9-XAO_Y_GG z1FnQ1u@fZ(D#uRw3p$A&nC<^{0!rnL)gr+6&F6HHO`wF!KQ})CD#qEW@Bjb+07*qo IM6N<$g27?u<^TWy literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Operator.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Operator.png new file mode 100644 index 0000000000000000000000000000000000000000..b67679a23f51602da41abf6f6b98f455fbe8068d GIT binary patch literal 192 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!73?$#)eFPHF3h)VW{r~@eJ{Vkj^y$ju&)1%O zzVY<)?WdpbKKpY2`Im<;zC3>U_36v6&tHA@zrJHLP#054kY6yvwEX|SJ%K!DPZ!4! zj+w~`2iRIf7V_M64rn{4rr}&I=+Zjrnu_WKt-F`CZwJqH&?-Bt!EMOoy;5D%ktcw= l=~Yl^lTk>|g|!Z>3^irko6ae%@dg^l;OXk;vd$@?2>?M~QL+F4 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OperatorClass.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OperatorClass.png new file mode 100644 index 0000000000000000000000000000000000000000..7af9217e639fa37fa8e6c8c5e36c76a840cc21a2 GIT binary patch literal 479 zcmV<50U-W~P)&x2d%-iYB)85ZOHqhbn z(MLMc;_}nu^3+Z~)z{$FGkF5_2%mJ=j!#K<^QSx000McQchChf`~#V!ROH3|NjUF-35h?f(C8V+;biV z03pTzkpf@<;&PQb4Ram|7+{-SC+W!Hl`9N!(=T+*X#0Kp{LsR3w~+Fg7uK{cqs3Jx z39P8%b}AN=t{JF~8=8Yf3!U!cOYq!ac0kYbH|^H zg~mMWtKfu-zb{SWt4(YkNaFl1GB7{a+k?CKdyj+x^;0HmG?i~5U;sFl7$8yr{sGoq VkE*wL9ozr_002ovPDHLkV1n~${>T6T literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OperatorClasses.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/OperatorClasses.png new file mode 100644 index 0000000000000000000000000000000000000000..489a57768dabf38f4dc6cdcb4d1aae100713895e GIT binary patch literal 373 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbK}dw@@f>;M1%^D#hCQE^#$MO9UG zb!~lZT|<3+Lw!Tj%=t@a&6z)I{?fV2*3DbEY{8;siU1l?<=i&tL-*gM*RPGTzw@(X5Au&F-wBl*Xp+dz@&o-U3d5|?B9uM0I9h`2Zl zO%tjTcG(s3^Z$Ee1&c@f?pmj(ofmQvITm_Oq^K>*bEnA01;^J$e81Yd@aC_Ni6?*U zFxXSFzGv5iQy&i9m?>~@3fIk}Nx8{!GYr28PS!m%&4+`hVfyE@&i7|jR+RB-m6}iX zVJK;s{IP$voWHWvmaXUcswaMvoAWDeUiXTQPg?E60a2Wnv|3GxeOn3n(lw~rAs$e7*Y)8#&HTJ-Qp2V3Sr{X4Qk->4Qk@ry1c2SrR=N* ucOZlGf_W^Hn7CH5I-U(Hb=oe*!XSNL@YRxM)9(X~X7F_Nb6Mw<&;$S&xljrK literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Paste.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Paste.png new file mode 100644 index 0000000000000000000000000000000000000000..d82c7332edd12cce29b863981da2fd1d439e2046 GIT binary patch literal 500 zcmV z?<+%59LD_<{tNGcAb)_Qf{LN2LSCx8lky5xrc_F)1WFJ9bD2A~LEE+8ciWxaHnTg! zrL4!!S)1J*+O6kyJKyK|obUN@O8}JQOQ+N6(?Wstg}$ulYizhwpB9Gt8)$&zI4Yj! zVYOQ67^x8t@oE6s@XS;%HRgwiWLbuyDD-=JqK|szv>ajQ50OM*83wY$(nDE4C^S_;t4b=byLpw7wF}{9%Bb@w1=v75f`GENH#vCmL z*iJi`wuy;^g-8+)ast-S3rvA19d}2S93-;`#sOTdHEPyO3{pZxS>I7k7v34bT!3#N@sF%W-;MT&v@bB{d!7>&hej z0{#*yx}pi3yPt662x8af!{(hE>lO!=ukGMmf#Lu`j{n<%!66n0gyL_w4Mt!VWthBA qxO7W&=CgFz5q>TT`0KYWl>P^Om$f|ww@h3B00004%P)FLN(%=Z8LOv_k%xhX|Wxkyoz( z=DG~T;$c!z>?j(M(e(X=4BHNzW{E@M?=4? zDOG-M(TkFYL+vn&&!B*})ew0s1elb?rq{xdE^3g@z95A}6x>gU%{mdAapJ@AfV%e` z6()nq!7Gx>0SdE}?SA6Mt!9a00000NkvXX Hu0mjf=~1|J literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Paths.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Paths.png new file mode 100644 index 0000000000000000000000000000000000000000..e61415be065b7a481ebdf2d0088c20c008c9a9b1 GIT binary patch literal 424 zcmV;Z0ayNsP)0xE>5X%c%I(Sl3S1n`Kp741GerLr@>~?uVcnKirSCbW zRY|P|k=u+SG4G&-${>|KU|6q;^0sxUXn)ziRkQ$=N;mTHr-};DgCyxQi#8tJi+8+* zM6`};gH+7l06oYE3zADas5oy>cNOqz&*8-yLvqnYiyrEzF7XG5RC4lEM#EP?-JO-+ zStgXd-vAszWWatN^}VzV(Dnub6d(w`3~KI2-2kb1nnv?P21t4UeH99)oqqu)?bMpW Se0op-0000;K1Bv;Kd6v-tm)w?O&i>6B4rKKfm zBQ~p6YHMqmU-w)$);4uBe6f4{KKGbS13*(xzdleDMN9EYbWH#mIM_*up#v!n4%QAe zNGZURaV{A{Hu(S{bVLBYMu3yY*rV20^3=Kvz1M9pC zqh_;KDi+p+&kGEzduC<6?cH=?pkim+daxv+Uf4*CU z;P1lcy9X~Zh76)td+i7Zn^AFtDgZ5Pb|MjB5D)8c?rkHZaVe`(W7R)XIYMrt^!Jxo ZPv4H}&Wn~oB%uHR002ovPDHLkV1ly2w9Wtk literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Processes.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Processes.png new file mode 100644 index 0000000000000000000000000000000000000000..ca2bbe0caba45bb26ae0025b4e8e8cd3300c3886 GIT binary patch literal 499 zcmVPBKvC;2XpI;V!K#S$FNz4>qGy=CT~v}9p%fVM zlHHx`%zGcb7>~y&7K@N&8I#EbgTX+=!#H(f?SP9{ zs}+{ZC1W<5iJ~uzMkDlkJ+#|xCZJp=2^ujk77I>FrBd+ue2io=iDt72(=-tX1X#|Q zz~VNl)v6$vbFp}r1#XX!$)8rMg>*W7@`R_uZj;m0I_agB>9161>F(C!@xU+)lu9M` z$240^!UW{>d_LpWNw3%IbtI_OYRKpFD3{AD=|pgrK*4_h6NyCPLV}_ws8lL=d3m-= zu$mYQ2GQwsP_Ne!kH!9;4syX9Ej`Jjb0DDHaNaY->ve@9zcMH%Yp` pT;*$*$uJuD_^AKwGX3{D{{S;XlcIL^-n0M!002ovPDHLkV1gFB=)?d3 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Property.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Property.png new file mode 100644 index 0000000000000000000000000000000000000000..e616bcbca0f34e5a7bcbe7ff1da032c230b80ffe GIT binary patch literal 357 zcmV-r0h<1aP)YPh$f_n8i;}-m5PO;NUJ6YrMZ}y@!yT6 z12kdwFZjdl12g=8@4>}%ET00000NkvXXu0mjf DAuOMG literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/RaiseArgument.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/RaiseArgument.png new file mode 100644 index 0000000000000000000000000000000000000000..b0ea0e1f7777b4625edbeb39b15410dab5e4a3ae GIT binary patch literal 176 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!60wlNoGJgf6$~|2iLp08xop6x1L4n70H~$&e z1Vix&tO`~Q;$PofT+H_&m(%ge5#!3Aja$}hHah$d&~{pIg7ZmFYm?c;q*Z%Z(q;T) zE(EA8ixNCC{iUq2SfAG^=Ls))mD&0fx>t!#yRB_g)pvfm#`XrzyX>t>8I=*s_HF-k aRa|z5u(JN-eOW*!FnGH9xvXbK#Kp>m>QwOrWH_GOzdHtCIV_xC{BkUai7%i-{lP+q9U(!t;{@~thzWY# zisQ(_9|Q=|5Fm!ZaH+1(DtL&sTSZF%q0=s@t5?xVfJiVJZ`4sBgRk0bW002ovPDHLkV1nu@bNK)O literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Records.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Records.png new file mode 100644 index 0000000000000000000000000000000000000000..ccdae661cc16f01aee28cbe16957512cb66a8382 GIT binary patch literal 294 zcmV+>0oneEP)1OwajET)d<lmnnW6wH8`ELQ~r z{Pn)%SzH3tgT8oNQ)ZH91C^%(l_oy>1m_0dsgC@VLzDGpPq(8sYX1JtFFYFI?ZNV#WdHyG07*qoM6N<$g4(@!<^TWy literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Redo.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Redo.png new file mode 100644 index 0000000000000000000000000000000000000000..ed5a0af9da890462a382fa2d15f88baa72e0bc73 GIT binary patch literal 489 zcmVPuS|3hgI-;JOFKt)MD&HMi6ZhZQ`?8vwOMaO>p&)EO* zf5giB|J@q*fDB8*X#h|%(5GeJ|B~Hr|Cb#2^gn0!yZ>1SKL3x~_UeE5)|dZ%*F601 z3^61SmjSy9fC`KEfA}B2?Dl`(?xX)*s<-|3>^l74d*0RmZfhU^w_kJyGlho-s3 zq4mIji^*sHYb?3*Uv}Bu|Dua;{pVkBU;OGC&5EGfvT>vsfZ_?@i;)`wrZNB+mVCH3z zy8Fn1IK{K=AUN=_#WPS`17w?7)87A_^RE9l1kyl$8G1CD5K6K@HPalbwt+NHBReku fHS^FmGm(Po5WbQ!5EPB_y1+Auc7Ou;5Cts7KagNB;WREdrLVy*_mx(!?-?+a4^m+7aEWCsbpx#SHO+4I5_;Bim|3 zj@g4ek!S^FnqHJ8f}3De;1(@Mk#!zKuDJ?%>n;>7HvSR(i%oHE@FbaRK;E(wh2uL= zbXk52TmcBWw<^FV!He0|6DpD9X~e}bSyEE16iyb< z(DSdAgetuJwhzIzQ|bo)tEdWm%eyhPtj9Ee2oF9VgHp|?;3h0-s}agnL2#`FFUaIq ziCVnokHEiT!;`oLSEJPgJ)SPu5fMC?%M4>7JAp@WE0wUSAo}ARW|Isim+CQ-Y=A#m zhrmw;;dCb=Vi!VU2ZE9V(M&hqtaM{2TtNi}Rq#c+E3bCrV-2R4od~7c@lLQ~Ce@5U zn!$Ui4Y7@W67Ipx*a3Rhr2Pk+rk80bRE~%9X1wKDd`J%--DlseGRnmnr7}0000!!9+Aj+Dc*kl?w9jc>Eak<>o#7LKF;V0N!K&Zeh0s^6_2@nQ}H<1D0k0S12E*ewcKZx^ zdV*(kbl^jBGP;RiA{u0_GFT#iQ%(`humxYUvVit>z~hnsTl=;)Ea-H&Mg$9yB=(+v zbUH)y@{UwVS{mSX1I^7cTrPZ!kH-!69hJ$uLv>2qB?zzAEEb@lK}KU^5P{50Gzr23 zj!}go(@9ZuEL$u~sH+2NYh~2e%c!o#JH39^q*SKuNIt7l)%=W&T?Z=+vl%EU!6H8; zAZb!m1Y~Ce>FHQWN?Ihz`Y-w%1i_$hF@OL9`dAPnhyiOs?{7m1hzVt3MdC&UQVM02)-0;6M{PZ6 z*z4TJ*aA|F%#ZA0x$<_?#S?}xqnd==T4JPK4~qXJU#5Oj9s8lrQvLq@el zLYGs4wa#v%c}C{HMK&rRod^TBSI|y>Ry&iqY-knbqwAe#S2m~Nah!&x@N3`vUqDti$@6vm2@W9We-DqN hUU^7)0MGi&{{kY**#3#xMalpG002ovPDHLkV1m!x`S}0< literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ReplicationSets.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/ReplicationSets.png new file mode 100644 index 0000000000000000000000000000000000000000..89ef45a80ee01a7c87ca010a5287fc68eea47ca8 GIT binary patch literal 320 zcmV-G0l)r}SLvFF3f9&25`zK(ZBBIG3uwJuK!=&o95dt)+ti6v`uzj#UJ2{; SyDh~40000hz1PBBQ=yN2Y6hV~r$uI%~m#R@vk;#kztVmg@nZf{+8m2Q{SSs3Fw%ukM zxv4C(r6QuKy1TjQoKABq@141+^>p?sQ$+(F-h0k@pWiv}Iq!|qDB_}-l9}X8My5%o z-@7!qxhCJtjRp`ERumhQaW$vWqnE_r2f)pnQLjxWQ~hu{6#d7cp2(oF zrsEz~0$%*`4KYwR7N$RiPkHR}h`nvzPn8jX;GF=1BAGroZ{l@#GM=_%Q=$-Bhg%GR zUkYMod5z{&)>(=>0jmMrSHysGWJ1)zZ6R2S?EWuA+PEn;-p+;_k{d!NK^1A(s;H2eWqdr7RG^~K!Cr2VI)1w!{ge+ zIG0;auiz3wkrzmNX2%ot)+>~0t53nwngzb60zO9@#MurMs0=u9M@>nKE9-QLc5&kZ r!{)jUUj(r4?|eP4WbHpqM2++h;VRVP&Lokh00000NkvXXu0mjf*U3Pb literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Roles.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Roles.png new file mode 100644 index 0000000000000000000000000000000000000000..aad272852f3a5a58baceac494e188ab9491edce6 GIT binary patch literal 465 zcmV;?0WSWDP)3nTa`c{2t`RZ0+Iv@VP=KFq(G~h z>5_#so69BU={uWS+fp`o{f6f}&pF%r0HDtphr=;O5+jj1r^ni3j1}HkSz3gvWDGt_ z1#-qAu)YfTzpa2YjV{d3L7mHk%)gKnp~06x;(5uOy(cl;CZN(I21^B0)LPS=Kyjtxx$gMVr%^#@B zEqIffz>43H7i6W!C>VA+o#69&AxKe5(Fzx~Xh@T#5oW4ie*$td=$dfDUibhm9#{w- zMwFrkBc#F1CZ)hP?~*DYKm9m)I}`?n7vQ!cz%^G>irVCy+oQl)*Q5@oDs^2j;-8r{ z!RfLpFg|l`ci#jj%Azh)uQ&ct&sm=GUz^Y4eFss4-w zwvTK1cPU=gogVWs_-@jQ^Rt^4H%2puvz_CSdATbtwjfC~G5x`;(2vE;$Jcbdp1mMe z{7t0mjSXEz2Uq>zTph#{A$nc$j!28h)mM*WSBDnf760KW@LlxZ{-Qk(*cwg#9C*@q RQU>T&22WQ%mvv4FO#nU2Sl9pn literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Rules.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Rules.png new file mode 100644 index 0000000000000000000000000000000000000000..dc9aa0d68d85a31e3b7972f1c58bc3a6c215bf4c GIT binary patch literal 223 zcmV<503iQ~P)Cjw8yWx)UcPv`uH(6b=)lW9qy9C|&$nyUl zwPQ5^#U;po{`aU8tm)sQRtW!L1EvA!EI)4zvxKwR_x--9Z=29T7n7>0gk Z0s!ZL@8&1v7cC5Aq*la5axj}BJ)>5?m5S6%Le+ELOEI&ZGQn^u}B69DF3b|CGz_PRF znA4monn}r1Z)d7^o^P7YC$!f52M3^k>Szs^=5G`)Hb!S8KGU-^-5AbRM>t%`nXtE< zV|QtYoy8%x7qaZF3}Yxv_7Dtou-rVpVR&~H=Lfq)(Uu*@aQjdqz~Lvj3OciSK9u$X zrHZDc@SgqCAe0OXgcg8bygA*E{8^uadD|r{zzPyolFr-&Wu+-=aBV7DlTO%rCHf1f zZ>=Ujcg$}zq>`o^7NDS|D@jX7tzS?ge0o7kh!O}bK}lN@-%c5lMGArm_t!5x-M{k_ zXl$+_lWDTOD1n`3UN)D>+z0a`OI{LAjETZAnRE)F0TYYFl1|1+I==6tq)M91Xa*GO~CIN{|1z>5WZ)UgI)~1HVA_-2!k*PL;loj$bBCLxu?tVe1L_a&P^iW{fV1s z1nHcPc=!a$nj7-a7Z8Tr-6@m>6w5Xkrw{)^yMI6`Z=m{v8>&`7B$LOPXA|N;ALPys zL+NO9mIhdNHc!?HgmnX#xqCCrL2@nu1Lk*l!8c!lnRm?kvf4JkQ+Cuxf0y4WQ5YT;xw}Cd}kTk zVQjMe!&6j`Vre{%)D|b~vnW z?8btf99B3C4uiwsFgOg>*{rY@r}NtY^Unf~uDhV0co5m$0$Z4bIz9w-um@^atIpaQ z+wB9g+5)~m_kpd`Wdn6vUHh zMEriRQmnRK`Huctt^-3u?l^Wh{xSnQ3qsT1~Yq0_e_k zDzRgpNj#w7A@hpJ^NR=w#53^g&+xeq35Hfx>CL?Z+DR0YXL6rN<0kcj>nB45jIRZ7 zbeqK9b&OzW73D@QK!osisUXWF?DHeYVdWu>F;_r@46iEiY`O`CR#xi$5b)U~w6uV; zy97?7DI7$S96rZ(Fb3biFu@3y6w6-%@=d7ii>WD`?i^q@7{&gEJ0DiUMTHLA0L#QY zl~tIfZNcyFz%GD>?o6kmwy7}MnY67x{}}Mwc>{Ev-w2;k`v(93002ovPDHLkV1iY= B^ThxF literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Schema.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Schema.png new file mode 100644 index 0000000000000000000000000000000000000000..e592562b9355e6b4dcf316390a7eccca36f4b9f4 GIT binary patch literal 227 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`t2|vCLo7~D4c6vsFyOiS)q<%l zL4ZSqso6n+gR^Y=!<^Qh+Lx~r7M=W5r@bcBWl6x?(53H{qN6UQo-L7CR;0M8^8Q>y zyVp4l=J~VD6?oVx9_}(q?DJ+lt+Y)mlgaQrXJZ^==2XUIoLh4Xj&JnS`Nwfwkp0e% z#}N%jnGJaU+bdpLwzBsBU*UKuy%$zLB^lfEGo$T11i$4^nXT4SWbt}a>Zwu6~3Q1(L_m>R;wn)va%bHTql|sYJYB9-n;9^gVe;7&7YfwW%d`C2Ra*It^5wM nr!26Q7EE3yh3$14|E%*4*krFi-{FBR00000NkvXXu0mjfm|9{= literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Search.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Search.png new file mode 100644 index 0000000000000000000000000000000000000000..1d3052f39361575c1857e813dc5efa554d549612 GIT binary patch literal 488 zcmVP)KehT1g~7ZVTW39dj0KZV6j+c&1SPY$Rtc~Fp|KK zt<7JU9PXVZ1Gv327#SOdl`gq_e(X@W>9UBeY#wuz+=PF>1BOYMo)`d|WKRWfCEU)x zFR=xu{CXrjeV7_IswUh{r>CwOwBY2j9&v)B^ZnpGpZ^E943P905MLzN)gAn+f{3$w e_|FWwg<0Qlo6~rrUJ!l&0000M literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Sequence.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Sequence.png new file mode 100644 index 0000000000000000000000000000000000000000..9475ff40bcef1924643a72c8750c2b8f5874ce3a GIT binary patch literal 280 zcmV+z0q6dSP)NJjHNKUB{@Nq8c{kYCg z1wbWDt-5Ga5as(j5yIxx(ne89rrEM?I9gZOrdvpo79hNb3_=J3PM#z)0qtiH@&I`K zO(I+a*YV*w0n51dKT0yjM51pz=xZ-djz}W>uS7CaFO0c%e$~ zX`1;HB+YVjhh9X3L+ji%NSeF#ZH7X-5PdXk?I}9Xn9}D!8yHagCML2`?j)uqQ|(m# eF8t*-{=yS_`S?p~daZ^40000;M1%TQZLT(Uh9=b6c;? zYr8(L^?^TRZ*E+UfT;%)5DT2qffm7%CYH+v=@7edzMbO9p%Q nMxL54zcNPQ*ZpI^&h2EJtHQM2Eme^bXcdE}tDnm{r-UW|puBGW literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Server.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Server.png new file mode 100644 index 0000000000000000000000000000000000000000..347802874e0812f35dd9a712a15313cc2cac674c GIT binary patch literal 404 zcmV;F0c-w=P)z|Rs+Rg@Q;Mn2C6}1CrA>UI^d8EAjKrjfB@V! z2L%Y+I$U!cd%{I3rEef$VPq0Kr;f;wu3Vl literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Servers.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Servers.png new file mode 100644 index 0000000000000000000000000000000000000000..dd457a5f2da58a16c75d1e08f68b6f86f8167d74 GIT binary patch literal 360 zcmV-u0hj)XP);L>D08%rPL%|*%bVyhGjr0vL78;+!lktGt(lyGN67ne( zCy4{>ukB)Hc%lIqaRU^Tn2bl`UI4UA5xG>>0mKwUra}!s!3_ZYOyeI^IpE3x>}6XY zY=zgw3|Bz@SVhgMfqgL0udcH?tY?Bd-S7r@F$rvHqjG+Mqxd#P=cDM4?qD{qcmojA z#Cr>nL||D)_vI-D5{I1ui@}8-8Ju21Z+KI*F9&abb#PPEklv7mgTSgU2gGr}0m8vb z@}C?~>s2&k3{_$wr&s(sC?m}$^!b_4bYN5ZJBeP>e)9=}!2Xcm@PWJl00007SVZ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/SqlEditor.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/SqlEditor.png new file mode 100644 index 0000000000000000000000000000000000000000..513559922c08ac85e8190ea8edf4980bc215fa12 GIT binary patch literal 588 zcmV-S0<-;zP)2t!zQ5n6w|;6@=iLq<%JdX-fav9x zwItJ7Q1Zz_DP%8aO5EF93d-FQqFwQ*14wvq{0FzjzDsD!qM!tNM!x~Dt+tYY>u`SX z69>W}g078aDFCcOGmbv`NG6x3+-EcL^*4teejt_2lg>@CulGHf$tk*rzi7{6TS6gn zC}{4i8Qg!DqPDV>bqfOwfBr>#(>%d#y8c#&3IV00fKmp5r4;p{GLA<=Len*r6q1Q_ zj)_bTzt0vD@2wDE5GaLoA5Y~#!R{qhRQp{{B*sZ)|IoU04nbF7+1@iM{%l8`Q2^*{ zUZA^8QsLV2!y2poY^bSVWA_Mel0Ru#T*bi7I&6jD2TL83K(KUIpLW5NH9z2TV{?rZ z&;e%8Eb;Co;}PfpY(4oLPq$Ckv;Igw@w3Z0*!CKLYm8y)MaQaQf}5w7VOd}+rCo7P zhcyKc+9KXrfedj)F#(&74PdJGT!c0Ip91jYLIW%IKE~9m*lL3S#ho)@DP&70C7x(+ zK${TtUs~yP7uQxy(0sU$|Ecd{BjG&>{?*VGgP_dk$V1B<9AlVXYFuyc5t{_D)~oSp akMmzjY?Bzj%U-Mi0000h~o<>K}Sy4w(P^BkE6=a@h5@ovA)NRh0hN3D-Q$-Wm(&o}M&Hd3gno~3& z)gTHLH)U>1=X^H``U1b6XSs4%QUqKl&-+}z`?{a|elviK|IvYi)4JhIAw@_P()Oh8 zon;;h5Ess8SGzIW-_zp@@q8(PV`U-a z)u{2rsGp3{IUT3XvrcZ4Hx2SLwyfMGDz(4;LhWmfD)%mx&K(S6Q7T5Z(GPFY=-$EN z3XoOhBGpa`pvc&=a!t}4qjLP0xoqe&iX%elK!jFL6r*iX0+js#RrcI86~~k^k47nf z5#auyFbiWzf0%o=O^gF!+MMeWpza4~j>QDEle-v&S)VlfG1!lx*p3LDLTAgO#9D~X zs?a?4L;|#Qzn26L4%*erOb3e? zUCl<_xGjLSR1coydQ;(v1B;Z~=;g69z$5oIhJg^py&IH1J<3AF!fdE2X>K0Bz>StX z(;rt^E{V~)h-ExLkGe(uaGiLxf@Ex2dB6Fuf2OMqcb8?)sn~}C{#D-r(ly6jg#)R0 P00000NkvXXu0mjfKBFpd literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Step.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Step.png new file mode 100644 index 0000000000000000000000000000000000000000..897dc138e742c83d27b3599221bc8eb1f4bd8561 GIT binary patch literal 306 zcmV-20nPr2P)ho@c7+PQQq?T<6vRr^!n*;Z|U~??fCredV2DLg7W(O_WS+${r>&_|NsC0 z$-mD}00002bW%=J0G4n6`$+%*0CP!1K~xx5WslbmgD?yLgUu`uMoQWH|NjvZ+ej7n zco*A>Qp&>zPg(Fhk9}LGv2T$D?BHlvNNVUD3uey=?E28-y8r+H07*qoM6N<$ Eg14@jc>n+a literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Steps.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Steps.png new file mode 100644 index 0000000000000000000000000000000000000000..b923faf968d61ff17ed47f70b8b45220df590480 GIT binary patch literal 374 zcmV-+0g3*JP)puU?e^6{LD)w}+3@(=O-|laRNnIW;96SaUtr|)`sHP1 z=xS@}_WSB@aO`w+?fCreczEx8eDQyP@`8f$`uz6${rUa={r>;||Nocv&?5i<00MMU zPE!DuZ~yyA0001uNkl)k&o*Z}N<@(uDKuDm^0{~) z-JN}<6s8;>6VGo24(l)l5IZ>8YX3-v62#FaMfJSFQvyuYV6uTHYjCQA*#hTus|^MP zhH>j}PGw`y>I8p-i^>_h_!X9KP-Q#g@7i)MMA(?pt$F-`;?IJdxB*DWMT(rLhn o>o-73w1&B3Fg?7iHh#_&KiUg((5OqrtpET307*qoM6N<$g2bV#zyJUM literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tables.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tables.png new file mode 100644 index 0000000000000000000000000000000000000000..e5d0d829a7f45dda449a6803a9eeac101496e0e3 GIT binary patch literal 415 zcmV;Q0bu@#P)*89eH-{oNJBMje{2tKo|dedbj&)p7=tg<~?&2Eh)kJa)h=v#)_6fr%F+< zOLw2Z*}aVOM>c3q0C@piJVdy9`mPO>guE2nJbW!g5|x*!xd{mq*wF`QO2P!T^$!58 zMkJ~@M2;_?e=<$7jHl0uAf|PeU zotcH+>3h2iyj6twR57TDTi|!q=|*`+Aqr7|EYL|LmSwR#48xg)G)+<2#5xI~axrSC zTd-}rDo`gO3nDJ%j^oUI6LrxqOC(7SjFZ2`VM`<|(;M1%Pc2n}ps!!*K7B6! z`EBy|ubtn&_Wb%j>*u#=KfX=;_$l+-m)6gp%kLcXd44DA)2G6xw?kgsNw|B=|H*CN zTSx3)+)a6W%l+f0>@#cRB40Fw01am@3GxeOn06)R^8bDyH^S4!F{C1{_nf)V0RSvmLLiikjGrAbd^7cE+#_+R=Kk7mXGMo+H49TVn+EJ(bW^|6() x&$sUo&sj0whi!?w8F{TQsEUjDr}qnq#=Uf8e%m|KPy}cPgQu&X%Q~loCIG)jb$b8+ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tablespaces.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tablespaces.png new file mode 100644 index 0000000000000000000000000000000000000000..57bd8dcc7e573c72431fa1b772295d5ed623bb22 GIT binary patch literal 192 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`?Vc`XI7o@@Ji6s zOou=6y#C5Z8~*R#ci!pX5(y5o2hX>ktT6Q8jbq+d|CZ(P?&E(9a@so|nm%|v-O51i zxOD=vU9BEla?u`Uvj>lt`+$TbE_$pg4`6DMd7mKBaMpT1`N~73lf{y o4(w^>7B*stRy!=u{Um`Q`T|2Q+kEqQppzIpUHx3vIVCg!0J7XhqyPW_ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tminus.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tminus.png new file mode 100644 index 0000000000000000000000000000000000000000..86ed3a6540c02117155e6c792bc6875c827cc3d7 GIT binary patch literal 115 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE;=m8XkiNJU)o0_lv*te^g}ligx1 z9?Y01B7XJCRf9<{Tu(JObn?XW?rHpg(Qw)IjhB^8cp};2-%04^GW_$^>5SJ@Rs)*C N;OXk;vd$@?2>|%nBjf-8 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tplus.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Tplus.png new file mode 100644 index 0000000000000000000000000000000000000000..552d7a09a7c4f0bc5a71a46cf3b91e09f8819fa6 GIT binary patch literal 127 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE;=o2QFoNJU(7$^xSUnF-#(r~l8| zB{fM`W{#drsp28m77^jcNp6SYTuuaMJ*aQ_qhS2O-mEmBvgyl%&qhx-`us2P(3H^4 ZWhl9mDH`hbK?-OhgQu&X%Q~loCIIeoDl`B9 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Trigger.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Trigger.png new file mode 100644 index 0000000000000000000000000000000000000000..a0c781dee35a936f84aeeb5302adbffbe0b1155a GIT binary patch literal 190 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`t)4E9Ar`&KKmPx>XI7PHU2I?Y z(L~{2f6MZTSqJ`4^6!5zL&DjB$KvaMb}qFPjyA^nMxK(M^8!4~eayK>+X^L{5*^;Y zziwe@22|xyTO+B@w(?+h!}U&C3&TJ?gPU78wAHM5c&?v6en91D)8$59jTui$1ZqF4 m$V{Frqi-X?0~<;{J&L}0Qq}aeEKnCyNswPK!?gVWzdeDxC{Gv1 zkcznE24*)`0Vbwp&P)z0No#^wlqQ@w zkB^?7p971Cr+2WIH}lGu8A7izm|osm%i*F>tjEb9ct!t-3<=sci$Id6*zqV^zqZ2M?SD}N-{{!Gf*s#->+Wh->@pi z_V54S|Jk!jiofrz{{Bvsk&Qq6{7i=j2NWJXivt2Cle>paub7IY?C6N@isrgu#qZAF fkz4Rvk%2+dN^X|Tln3{K7BhId`njxgN@xNAcT!?X literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Triggers.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Triggers.png new file mode 100644 index 0000000000000000000000000000000000000000..4989f114d914b23d27fc1107882cc2d4a0a91b7a GIT binary patch literal 229 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!73?$#)eFPFv5AX?b{r~^J{=~&VWUy|Y<@V+7 zN4JJuIg^ECgy{DhcunW|)@$|Fq zED$7=z`)$g=gQ$+y=cScQQ3knADw>ks%Nu7(8p!Mnezj#gn?ag^$>6HCa(wz~0cx Y*kULlEh1*N8fYzpr>mdKI;Vst0FrN3_5c6? literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Type.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Type.png new file mode 100644 index 0000000000000000000000000000000000000000..9c8f53859b3e1b236b6d0856c4f3e1ee2a145c2f GIT binary patch literal 160 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`>7Fi*Ar_~TfBye(&#c$s57p8ZaPJhM#46t~A;%+u!y&z)k()3EHV&aUTf4B;#)%F|{tumG)O@O1Ta JS?83{1OU57IcNX? literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Types.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Types.png new file mode 100644 index 0000000000000000000000000000000000000000..dab729448a9fad52adbb0d9274ae7122b9b53b07 GIT binary patch literal 205 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!73?$#)eFPFv5AX?b{r~@e)ahA3l=pvg<^P@S z{||IM*g5V0iDmyUZux)X(Et1A{y)9;|5fyt$sjFEB|(0{4Ab)e|Mmp(f<0XvLpY*s zPi^EqV8G#WQCK)aGdNAd?X-ZTs&fj<2bKq$bBcKV<4+V8@=o~tQ0-G#Xy%dKlb-k; z@p7?Z?>rQ5WVWX(wMK?zANQJu%Duv7^}iT&i-Qy|R@~eLG@ilJ)z4*}Q$iB}%Pv)j literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Undo.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Undo.png new file mode 100644 index 0000000000000000000000000000000000000000..8c8df1a5686481a214453941d01bcb2051a4eed4 GIT binary patch literal 470 zcmV;{0V)28P)cL%;~FOpMarNGOUBFW8!xy%645tYHg4pjsA{)>4cF z43ZZe_xp#|pG8TjPPgx#d(U^e-~B`YM8ARP&jh$evy3oJ@DT7G*;)3j02Qe++ZRze zb&8thdsM7Epm_co@^L4)HX9RD`4u2CPu{+STFWKWwp%DEmQc(wok2G3M)HIU60b;} zKLM+H<{Z`58z@GPkkPXauE~P5?lq(gJ0PBPAE$ zD59asNhFor5O*UGh)8OgN5}|2heu!HxQr&Qu-zexnmHO6YyQGPKq~D;pjY74muN^Q zYuWVPoY%UR5aVZ0bP28eQ|g3-o@=%+LjTil?UQ!K>Qzyr;%zvN8Z9q|Jx4V`9J5(W3VAa8341@xB0~XqOI5d zhp#;Uzh>8Mk_`C2{L0h+eaG(o&)RhLf9TQ+|7&;NA>9QaoVn!6|A-}*|JQE2OS}O{ z2EA?FdGCMZ!mI!5w%jMnfZavQZ~Tv%fBk>`rUzuYVB3TL(Q|J8Z`kmNJQtKLz4bqC z_U-=->mHLAh-^SY=1dp5oJzhM8H p|7(uD$LbQCF2I4O(I+#Jf&rg9-69(v09F71002ovPDHLkV1j2#|?|9Xve?o}mokdZ2ElGJJ5rl;3)hzVk940G~afP$)gz zB;w29y@>+8h2e+#DSp%!N)M*`N*T~vjU;i{C$S4ezS$0&>O19=CMmK&oFq_qY$w=M zRrFgO7AP))rXy^s-z4a|3Pdi<2{zRsJ)!LSgdn%gh1uczdK0Vh71t7{X2Rid+gupG znaAdv85U@d&o~NbBd{2aVq20So!79Q&SG|c0TD`aGmAp?3gVuOxuqye0{;ZG;1>h| z`BDXUs)m~{4UG>C*Y7$m2RhFBI!<~zjujo5f`n;dh9!QhKuB(+T;Zc<1M-uB*jkDO zf>n^)s>q&T>Cr%X_mBlStDs%IZF_?Ey9V+X6 d$MD$=84 zj_r*lyk_yw*&&KLu)P!i63YTJ!3TTm_`;LsnRVK5QlrMG*@TBK3l`l&un(G`V>MYK z3vzUFD_q-8!!dD{!^ykX@qEFCbjXIxJsWOWj3h805m4JQ{AM=>9~(iXRKg%=F*aaC zEI7j9mtiZS{y`Gtj*LJv%djZuG4Gj1A(LQ9BIuc6H311}7`ccQtAT+(1bVtKzt_&& zCb&^4vXoG-lv&;}i5nBF^;h?=VQRQ#1h(k7aMpme@F=9)SD;pP@snHOdgTN1nJl_R z4Ttqw6$$jRz_Q>P0(K>!I1f{wz}s$x>y=MTumPpI6JwGN-nfX~^GcF*kRX+hPjeUr z52UF}eCAfTUfE+cFNc#qdXV^jnys}Yu#li}xD((o^0QdEbD3Wl%}j06$pnjn2-jnQ z!%q(l2yN*}kRm}7F2$@kV>CiqT*ghe7rp)G(8FSz@xd8>gzkP5A_Wm^jZ=u$1QIlU z2^fs+Nh)B{7eMyoXRN=k;@R6O;^itwZus~B+xVfAYe`zB!ZEAN0mA&0Rw&I?Pa z7stX63N?75S@d1(;_#CL{-1DxgG)AVK&|XVvb=XJ9NDQMw7CzZO3{Rgl|Ljd`Oi3r Z{R!W`#4Vh;WUc@J002ovPDHLkV1hdPAY=dl literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/UserGroups.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/UserGroups.png new file mode 100644 index 0000000000000000000000000000000000000000..2e91dfce8bb8a3a806028726827c318f85d1405d GIT binary patch literal 593 zcmV-X0 zk82Wf7{>hr{P&#huq>f$C^&Vw)b6fTp{dc5N~qa3Dk8SBnM$o%`~D$^R?Ex)3L%~a$9X79@=7bQrs0JN%tKl?ja z*Bdm~tO4~V4_L#|FA7j-;gHPD7kR9g^O%1qK}=p^0edW9iRN`4z&W5 zT%iD!0y^DKPoTfN4xiV9SR@RsS}|{phyteHoPnKEVP=5>Iuvk=scWzPbaKkPHJtL` z7)t-hYhtul_n!7yZ^bc`>U|jLWilJp!|^24Z*5GxZoo>3%r`RLOx^6rzdCebwn!gAzWMfUP?~D}$CY zVp34&8_U?(JH*Ov8;$KYuWn#6C|S*TFQfZ*#H7$^ZXfiS7rq=p+4{j3dXzf7HdgVO f=q-`cMKI^(Dgaw_6N00000NkvXXu0mjfiYyge literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Users.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Users.png new file mode 100644 index 0000000000000000000000000000000000000000..d03e9ee0b88614b3bd977e831f38421b7d67c88a GIT binary patch literal 364 zcmV-y0h9iTP)OM2Iv?<`wqB7I3;JyU%@h z_iYac?){(NJ;(oM0Awh~ak5h0Oj&ilOp&?a?xWxBNC`CDL!^Z$fJgIhFu*kUz*E;J zz|#kl5^4bPZ=MDt3Am2|79~^zc^>j*nj7vB2l5&qF(EHk)^a)Q9@Mc}EMY^cT&rVM zp7Cy3LS7b*Pg{5n#^{g6=zWIphatAAdmMV5bv{crn4m^VDdQp zip=6Y#QJs>X6MpQCH6?|q(wl1fF>bQ&}DWmmMgJGF7JAr6V}gR+seh&O=P}(`$7BV zn}CVUyl5-Bn7U~LShu1&oAWln+*b6?X#jIu(L1LBShu1&oAZCgqrO{=F=5L90000< KMNUMnLSTY}L!i$9 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Variables.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Variables.png new file mode 100644 index 0000000000000000000000000000000000000000..d24bc14c0d685e8b7c8c4b63cd37308f0eb085b4 GIT binary patch literal 380 zcmV-?0fYXDP)>&;93H?p@_Dpz z;@1x~$e#m@x6lb^tjX zKb(9)HnK#ri1PM^4=e_vIGK8dsT%}#vZy**H=v2lK(TPy&AvZc!SVJA$*RiRvzcl- zKtg)_xptH6+sf1pNdKQf@T!MBHvEMA?&`OJ02Av;yFp^40%L^anQ;0iodD}VBLc?(&Wk12GyXl0-@ASETmOJ7E&s-L aw3rV#e(b6G#-&;S0000LPayZ%3ZdGY_#=lB0VfBy9U zvuDr1`0>+Q|8G2B^Z(e3({eSgGHX;mwfq3}6!~cD6%>M6srH9o8 dlw~GLFaR4y(>QKggM9!1002ovPDHLkV1jiUhzbAz literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Views.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/Views.png new file mode 100644 index 0000000000000000000000000000000000000000..a7232d7b21af132b7f41f6748169c024af150b63 GIT binary patch literal 286 zcmV+(0pb3MP)=ABUZ|LD)O|Bt^d|NrRSzW+~NUH<>{`Mv+opFjQo?AbFg ze)RO#|Lf0J{@-#j`v3d)?*&i{0Ga&ge>br%z;FrN0CHV|;sSD9f?)uuE&&_x5X}X| zxMcfFH873U3osfNz-hokEC!(43^(9~I&m%l(Rbdg0s9@*06boJh-Sd)&td z06Zx_BF77`6h(3%!d!r40ESD5ibnL@1vB8mzqbE({?z@y`KuHX1|PluAAaxff8QIk k|GQr4VY&dDONdFz0E9#7J=tYE6#xJL07*qoM6N<$f_Ptu1^@s6 literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/blank.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/blank.png new file mode 100644 index 0000000000000000000000000000000000000000..dae1f43dd8641ff24609e8163eba0a59a7b5fb50 GIT binary patch literal 77 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqCmyPZ!6Kin!zjLK3Wt6GVEN0u8tr Y*g_Z>J@w9O0_7PzUHx3vIVCg!0P>p-{r~^~ literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/title.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/images/themes/default/title.png new file mode 100644 index 0000000000000000000000000000000000000000..10015d679599247be64a52a96f146cecddd90696 GIT binary patch literal 3523 zcmV;!4LtIRP)00093P)t-s&d;3x z|Nj600C#tHySuw0A|eqH5#;2_?(Xi0h=|?Y-7_;Y%*@QHs;XvYW<*3pRaI4KYEb0l z$l>9_K9XrhS^5b)uqr92^xM9vWL)MORotv$TlgCVTYiv=QoOR&fz~ke_YHCp7;lZq}f}EXpXlYNnyN$!d zlyh@ex44V7wu!#Kke;7-baYpMfMK$;hmMbI<>kx4!jiwhk-NN&Z*Nqos({DHmb|@> zdwX4pifD+4XXWL|ZEjPBhh}wlS%ZXQg@$Fgxr>*Wa-pJn;NZc2e_v~BQK+eZqN975 znRA(%bd8N_s;hyCiD!_IZN|rzZ3ItE_@_by$*pCt zmBPc5Utmatg=CYIZ*g)~yS$FT!IH_zuXlH4)YQDm$+Fzs!OP5=y}plqeqYVbo4>%2 zq@;_<%9x6ZaLCD*p`nM4k9EezsBv;wmX>_S$FR%GvBANnkC1kzrj2rQR!d7kT3Ss= zNj9vkl8lXNXJ}4$cwWuUv*Y8+sHl{$ua)BB#y2-AEiEEzYhK~u$aZ&K%FCH}cxTMb znt_61hlg~`&70=t%;4a|YHLx0glcwnS$cb6)z!P=;>XI$u(r0Lh=_N6eQLP4o_u{{ zva^PAb60b8TG-gR;NZoFh;C|YP>G3n*4DSBrhZ#nPh@0Q&MQUa000VpNklbufnR_b^ zDA*Koq@)>cj6^SnC2HU6ox37+ATJ z$Btgncgfn;xvQtvRdr`O7C$=11SGBp@ zz#e{fG!n=YshVQfb-SXaJ`u3OqK-qwWDqY$vz|lE9&!5#i~0My@;>k zgfRx$`1$?rr@!tvwF6Jp0N8O}+R+Fg`#1ops;1af)uw1_>fXHpDnf>fNjMa5@v8m( zd-y{eYKUSrvk>ropRZIy6`g;IVoHx5J#e7(@{lGuMwBvEriwx^_rA8VHiA zl6Z7g4+u_bas7%^nqmbH$AxtKJ=KNg4AZJ;#s5hEhTctrKn_X|zuW-`XQ+mfeBYvf zF$Opq3PLVGR-S!_0FgncR|&ynrGd&+6o;-z>3~v{Fw+Gu?P~GA#Ty6^`5LQu&dL8w z=Yx3PqQN5M4F?e+rqKnC0Kq}WAwY%Crm8v>C+Kv$Bte2OSO$1P;TOLfg9tg19(uVG zBocvN!z5%!qkwRSHgsn=6)PV!5d>@filS*&>Qx5@9@H?G%1NNA&Oa{Vpf?D0F$kc^ z!Zd!)0U+kHx&IRQ*cd!7^Y@3Xe1pI8WThfvD(pD7=zHL8D8oCO!Z4j_C) zUKqy?I!&=+fyvQA-A1dK4iW@-R^rne0>S|4q>&>nSt28pLRg~913%QO2=V3-Y>F;G z?5bfS!7I_8&8EnVfR-|$r1^oMuHP;Q+V}Jyfjd6jez%R5AU2rn0dd3mRpe;V29h9Q z0>p|`NTFSBk4pX^+W&xPw++JWbN>K{&Z((M#O>1e7(~NF)CUPrVL3w?#0o2TYa#!p z&Pu~cIubk(bdUB$|B;dH+v9GjO`FFU#E?nw0|`{&tF$Vw7kD6$G(&Ug9gIwbN@nT zNem({9d>_^K$Q)(ox%?kg|HWdDK3Z(S_mJI6SR6YzK$3{1CjlE5PhfIn^AAf7uamir-4`br4W42#}Ba|HeJYuJw)C0NGTIQ`1uaci(q+^ z|F_US_0Iq~(b2e?BsFjD0a3G7{$}31c@_(P{rbeqFCJGtl|x5M2ayq7doA9+J@)Ql zaTg7&T=yDCqouVxGk@x;4#`zz-MgJ0`1BvQ_1!urJNG<&_7k6)8dual`ey+ABqf!X zM_97t$Mmc>=0Trcedp~z;M<$W`G#p5-9 z@T|IJeacdZ;<-oe+i~yQAukDv#>arZ{1OPF{|F0IUXISQz~5 zBfiSIQ40b_ptaNjqZEEjR4y)bGprvwZsY6~%lppBuE;1kX@+T}F!SW!%esSNC{c7_ z3YZZ*3W)l?2V#JIkDmDA)Z5oz3$NY4s%3&vEd~KW#9_?R($d41FPDs&+`IRBHsZ?6 zt@D>utesxavFF6;gASLJ96WgN{@6u`#n2uD`h$WeD##SjJ>P!&=A&<&c<0nB*S~`l zumiBbOF)4ZX`oTM7RNqF1{m>R#)Lhst8*t#YkAk;SsgG>oC+GK{yVztoI8Z9V2WU3 zK(c$E{sF)qNCIC3oJ8P<>yyLK05=I0^V1ks&SA*|Tx9;l#Gu+TiZ7wvQZ5`aBm zf?-~S(Ib!t$uOhiE;eH7szqK1%oAlBR`^mh3%<}icaQd|e>flkBmoZ+BftjA17@j! z8CJsxOw+Qeb(>SVc_6wFL{klvS7;vHQ~TUMJHP-Qf{n9>!v#hl8(LTQ++FBpfDs}S z3?Ua(lMR$t)I9(BF+tqF01zGs0)(L=gAjxbJWG-RMhwJ`MJA*ZzNu(Rp?U6}+86zA zB!DZ+x4{EJu%`en03j0yu%V7-NivWT6zn?+!9w%sp4;dCXKw2|XMQ%OC}YC(83i4Q zpfGcFJ|Qdu!h$~QHq$II12!y-kiljM8SSPQHIMEwK<@t60st25>bV;pFaZq`To4H3 zkq7p{%Rs@tb52NQFL@B%Q~P^h0Q%1*00bcq9)N&NC=&?SOR&L*!OsXl+({L*c6VP` xNd4#M!2tl&B_}Va@)8X6Ly$g5Bkni^^j}c3NjgN9{J{VK002ovPDHLkV1mlixD@~Z literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/index.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/index.php new file mode 100644 index 00000000..f9177b7f --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/index.php @@ -0,0 +1,42 @@ +printHeader('', null, true); + + $rtl = (strcasecmp($lang['applangdir'], 'rtl') == 0); + + $cols = $rtl ? '*,'.$conf['left_width'] : $conf['left_width'].',*'; + $mainframe = '' +?> + + + + + + + + + + <body> + <?php echo $lang['strnoframes'] ?><br /> + <a href="intro.php"><?php echo $lang['strnoframeslink'] ?></a> + </body> + + + + +printFooter(false); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.js new file mode 100644 index 00000000..27160f2f --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.js @@ -0,0 +1,70 @@ + // Globals + // + + + /* + * Multiple Selection lists in HTML Document + */ + var tableColumnList; + var indexColumnList; + + /* + * Two Array vars + */ + + var indexColumns, tableColumns; + + + function buttonPressed(object) { + + if (object.name == "add") { + from = tableColumnList; + to = indexColumnList; + } + else { + to = tableColumnList; + from = indexColumnList; + } + + var selectedOptions = getSelectedOptions(from); + + for (i = 0; i < selectedOptions.length; i++) { + option = new Option(selectedOptions[i].text); + addToArray(to, option); + removeFromArray(from, selectedOptions[i].index); + } + } + + function doSelectAll() { + for(var x = 0; x < indexColumnList.options.length; x++){ + indexColumnList.options[x].selected = true; + } + } + + function init() { + tableColumnList = document.formIndex.TableColumnList; + indexColumnList = document.getElementById("IndexColumnList"); + indexColumns = indexColumnList.options; + tableColumns = tableColumnList.options; + } + + + function getSelectedOptions(obj) { + var selectedOptions = new Array(); + + for (i = 0; i < obj.options.length; i++) { + if (obj.options[i].selected) { + selectedOptions.push(obj.options[i]); + } + } + + return selectedOptions; + } + + function removeFromArray(obj, index) { + obj.remove(index); + } + + function addToArray(obj, item) { + obj.options[obj.options.length] = item; + } \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.php new file mode 100644 index 00000000..5c6ebdbf --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/indexes.php @@ -0,0 +1,422 @@ +printTrail('index'); + $misc->printTitle($lang['strclusterindex'],'pg.index.cluster'); + + echo "

", sprintf($lang['strconfcluster'], $misc->printVal($_REQUEST['index'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->clusterIndex($_POST['table'], $_POST['index']); + if ($status == 0) + if (isset($_POST['analyze'])){ + $status = $data->analyzeDB($_POST['table']); + if ($status == 0) + doDefault($lang['strclusteredgood'] . ' ' . $lang['stranalyzegood']); + else + doDefault($lang['stranalyzebad']); + } else + doDefault($lang['strclusteredgood']); + else + doDefault($lang['strclusteredbad']); + } + + } + + function doReindex() { + global $data, $lang; + + $status = $data->reindex('INDEX', $_REQUEST['index']); + if ($status == 0) + doDefault($lang['strreindexgood']); + else + doDefault($lang['strreindexbad']); + } + + /** + * Displays a screen where they can enter a new index + */ + function doCreateIndex($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['formIndexName'])) $_POST['formIndexName'] = ''; + if (!isset($_POST['formIndexType'])) $_POST['formIndexType'] = null; + if (!isset($_POST['formCols'])) $_POST['formCols'] = ''; + if (!isset($_POST['formWhere'])) $_POST['formWhere'] = ''; + if (!isset($_POST['formSpc'])) $_POST['formSpc'] = ''; + + $attrs = $data->getTableAttributes($_REQUEST['table']); + // Fetch all tablespaces from the database + if ($data->hasTablespaces()) $tablespaces = $data->getTablespaces(); + + $misc->printTrail('table'); + $misc->printTitle($lang['strcreateindex'],'pg.index.create'); + $misc->printMsg($msg); + + $selColumns = new XHTML_select("TableColumnList",true,10); + $selColumns->set_style("width: 10em;"); + + if ($attrs->recordCount() > 0) { + while (!$attrs->EOF) { + $selColumns->add(new XHTML_Option($attrs->fields['attname'])); + $attrs->moveNext(); + } + } + + $selIndex = new XHTML_select("IndexColumnList[]", true, 10); + $selIndex->set_style("width: 10em;"); + $selIndex->set_attribute("id", "IndexColumnList"); + $buttonAdd = new XHTML_Button("add", ">>"); + $buttonAdd->set_attribute("onclick", "buttonPressed(this);"); + $buttonAdd->set_attribute("type", "button"); + + $buttonRemove = new XHTML_Button("remove", "<<"); + $buttonRemove->set_attribute("onclick", "buttonPressed(this);"); + $buttonRemove->set_attribute("type", "button"); + + echo "
\n"; + + + echo "\n"; + echo ""; + echo ""; + echo ""; + echo ""; + echo "\n"; + echo "\n"; + echo ""; + echo "\n"; + echo "
{$lang['strindexname']}
_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formIndexName']), "\" />
{$lang['strtablecolumnlist']} {$lang['strindexcolumnlist']}
" . $selColumns->fetch() . "" . $buttonRemove->fetch() . $buttonAdd->fetch() . "" . $selIndex->fetch() . "
\n"; + + echo " \n"; + echo ""; + echo ""; + echo "\n"; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + + // Tablespace (if there are any) + if ($data->hasTablespaces() && $tablespaces->recordCount() > 0) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + if ($data->hasConcurrentIndexBuild()) { + echo ""; + echo ""; + echo ""; + echo ""; + } + + echo "
{$lang['strindextype']}
{$lang['strwhere']}(_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formWhere']), "\" />)
{$lang['strtablespace']}\n\t\t\t\n\t\t
"; + + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new index in the database + * @@ Note: this function can't handle columns with commas in them + */ + function doSaveCreateIndex() { + global $data; + global $lang; + + // Handle databases that don't have partial indexes + if (!isset($_POST['formWhere'])) $_POST['formWhere'] = ''; + // Default tablespace to null if it isn't set + if (!isset($_POST['formSpc'])) $_POST['formSpc'] = null; + + // Check that they've given a name and at least one column + if ($_POST['formIndexName'] == '') doCreateIndex($lang['strindexneedsname']); + elseif (!isset($_POST['IndexColumnList']) || $_POST['IndexColumnList'] == '') doCreateIndex($lang['strindexneedscols']); + else { + $status = $data->createIndex($_POST['formIndexName'], $_POST['table'], $_POST['IndexColumnList'], + $_POST['formIndexType'], isset($_POST['formUnique']), $_POST['formWhere'], $_POST['formSpc'], + isset($_POST['formConcur'])); + if ($status == 0) + doDefault($lang['strindexcreated']); + else + doCreateIndex($lang['strindexcreatedbad']); + } + } + + /** + * Show confirmation of drop index and perform actual drop + */ + function doDropIndex($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('index'); + $misc->printTitle($lang['strdrop'],'pg.index.drop'); + + echo "

", sprintf($lang['strconfdropindex'], $misc->printVal($_REQUEST['index'])), "

\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropIndex($_POST['index'], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['strindexdropped']); + else + doDefault($lang['strindexdroppedbad']); + } + + } + + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + function indPre(&$rowdata, $actions) { + global $data, $lang; + + if ($data->phpBool($rowdata->fields['indisprimary'])) { + $rowdata->fields['+constraints'] = $lang['strprimarykey']; + $actions['drop']['disable'] = true; + } + elseif ($data->phpBool($rowdata->fields['indisunique'])) { + $rowdata->fields['+constraints'] = $lang['struniquekey']; + $actions['drop']['disable'] = true; + } + else + $rowdata->fields['+constraints'] = ''; + + return $actions; + } + + $misc->printTrail('table'); + $misc->printTabs('table','indexes'); + $misc->printMsg($msg); + + $indexes = $data->getIndexes($_REQUEST['table']); + + $columns = array( + 'index' => array( + 'title' => $lang['strname'], + 'field' => field('indname'), + ), + 'definition' => array( + 'title' => $lang['strdefinition'], + 'field' => field('inddef'), + ), + 'constraints' => array( + 'title' => $lang['strconstraints'], + 'field' => field('+constraints'), + 'type' => 'verbatim', + 'params'=> array('align' => 'center'), + ), + 'clustered' => array( + 'title' => $lang['strclustered'], + 'field' => field('indisclustered'), + 'type' => 'yesno', + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('idxcomment'), + ), + ); + + $actions = array( + 'cluster' => array( + 'content' => $lang['strclusterindex'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'indexes.php', + 'urlvars' => array ( + 'action' => 'confirm_cluster_index', + 'table' => $_REQUEST['table'], + 'index' => field('indname') + ) + ) + ) + ), + 'reindex' => array( + 'content' => $lang['strreindex'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'indexes.php', + 'urlvars' => array ( + 'action' => 'reindex', + 'table' => $_REQUEST['table'], + 'index' => field('indname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'indexes.php', + 'urlvars' => array ( + 'action' => 'confirm_drop_index', + 'table' => $_REQUEST['table'], + 'index' => field('indname') + ) + ) + ) + ) + ); + + $misc->printTable($indexes, $columns, $actions, 'indexes-indexes', $lang['strnoindexes'], 'indPre'); + + $misc->printNavLinks(array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'indexes.php', + 'urlvars' => array ( + 'action' => 'create_index', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['strcreateindex'] + ) + ), 'indexes-indexes', get_defined_vars()); + } + + function doTree() { + global $misc, $data; + + $indexes = $data->getIndexes($_REQUEST['table']); + + $reqvars = $misc->getRequestVars('table'); + + function getIcon($f) { + if ($f['indisprimary'] == 't') + return 'PrimaryKey'; + if ($f['indisunique'] == 't') + return 'UniqueConstraint'; + return 'Index'; + } + + $attrs = array( + 'text' => field('indname'), + 'icon' => callback('getIcon'), + ); + + $misc->printTree($indexes, $attrs, 'indexes'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strindexes'], ""); + + if ($action == 'create_index' || $action == 'save_create_index') + echo ""; + else + $misc->printBody(); + + switch ($action) { + case 'cluster_index': + if (isset($_POST['cluster'])) doClusterIndex(false); + else doDefault(); + break; + case 'confirm_cluster_index': + doClusterIndex(true); + break; + case 'reindex': + doReindex(); + break; + case 'save_create_index': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreateIndex(); + break; + case 'create_index': + doCreateIndex(); + break; + case 'drop_index': + if (isset($_POST['drop'])) doDropIndex(false); + else doDefault(); + break; + case 'confirm_drop_index': + doDropIndex(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/info.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/info.php new file mode 100644 index 00000000..cfb6e8d3 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/info.php @@ -0,0 +1,339 @@ +printTrail('table'); + $misc->printTabs('table','info'); + $misc->printMsg($msg); + + // common params for printVal + $shownull = array('null' => true); + + // Fetch info + $referrers = $data->getReferrers($_REQUEST['table']); + $parents = $data->getTableParents($_REQUEST['table']); + $children = $data->getTableChildren($_REQUEST['table']); + $tablestatstups = $data->getStatsTableTuples($_REQUEST['table']); + $tablestatsio = $data->getStatsTableIO($_REQUEST['table']); + $indexstatstups = $data->getStatsIndexTuples($_REQUEST['table']); + $indexstatsio = $data->getStatsIndexIO($_REQUEST['table']); + + // Check that there is some info + if (($referrers === -99 || ($referrers !== -99 && $referrers->recordCount() == 0)) + && $parents->recordCount() == 0 && $children->recordCount() == 0 + && ($tablestatstups->recordCount() == 0 && $tablestatsio->recordCount() == 0 + && $indexstatstups->recordCount() == 0 && $indexstatsio->recordCount() == 0)) { + $misc->printMsg($lang['strnoinfo']); + } + else { + // Referring foreign tables + if ($referrers !== -99 && $referrers->recordCount() > 0) { + echo "

{$lang['strreferringtables']}

\n"; + + $columns = array ( + 'schema' => array ( + 'title' => $lang['strschema'], + 'field' => field('nspname') + ), + 'table' => array ( + 'title' => $lang['strtable'], + 'field' => field('relname'), + ), + 'name' => array ( + 'title' => $lang['strname'], + 'field' => field('conname'), + ), + 'definition' => array ( + 'title' => $lang['strdefinition'], + 'field' => field('consrc'), + ), + 'actions' => array ( + 'title' => $lang['stractions'], + ) + ); + + $actions = array ( + 'properties' => array ( + 'content' => $lang['strproperties'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'constraints.php', + 'urlvars' => array ( + 'schema' => field('nspname'), + 'table' => field('relname') + ) + ) + ) + ) + ); + + $misc->printTable($referrers, $columns, $actions, 'info-referrers', $lang['strnodata']); + } + + // Parent tables + if ($parents->recordCount() > 0) { + echo "

{$lang['strparenttables']}

\n"; + + $columns = array ( + 'schema' => array ( + 'title' => $lang['strschema'], + 'field' => field('nspname') + ), + 'table' => array ( + 'title' => $lang['strtable'], + 'field' => field('relname'), + ), + 'actions' => array ( + 'title' => $lang['stractions'], + ) + ); + + $actions = array ( + 'properties' => array ( + 'content' => $lang['strproperties'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'schema' => field('nspname'), + 'table' => field('relname') + ) + ) + ) + ) + ); + + $misc->printTable($parents, $columns, $actions, 'info-parents', $lang['strnodata']); + } + + // Child tables + if ($children->recordCount() > 0) { + echo "

{$lang['strchildtables']}

\n"; + + $columns = array ( + 'schema' => array ( + 'title' => $lang['strschema'], + 'field' => field('nspname') + ), + 'table' => array ( + 'title' => $lang['strtable'], + 'field' => field('relname'), + ), + 'actions' => array ( + 'title' => $lang['stractions'], + ) + ); + + $actions = array ( + 'properties' => array ( + 'content' => $lang['strproperties'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'schema' => field('nspname'), + 'table' => field('relname') + ) + ) + ) + ) + ); + + $misc->printTable($children, $columns, $actions, 'info-children', $lang['strnodata']); + + } + + // Row performance + if ($tablestatstups->recordCount() > 0) { + echo "

{$lang['strrowperf']}

\n"; + + echo "\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $i = 0; + + while (!$tablestatstups->EOF) { + $id = ( ($i % 2 ) == 0 ? '1' : '2' ); + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $tablestatstups->movenext(); + $i++; + } + + echo "
{$lang['strsequential']}{$lang['strindex']}{$lang['strrows2']}
{$lang['strscan']}{$lang['strread']}{$lang['strscan']}{$lang['strfetch']}{$lang['strinsert']}{$lang['strupdate']}{$lang['strdelete']}
", $misc->printVal($tablestatstups->fields['seq_scan'], 'int4', $shownull), "", $misc->printVal($tablestatstups->fields['seq_tup_read'], 'int4', $shownull), "", $misc->printVal($tablestatstups->fields['idx_scan'], 'int4', $shownull), "", $misc->printVal($tablestatstups->fields['idx_tup_fetch'], 'int4', $shownull), "", $misc->printVal($tablestatstups->fields['n_tup_ins'], 'int4', $shownull), "", $misc->printVal($tablestatstups->fields['n_tup_upd'], 'int4', $shownull), "", $misc->printVal($tablestatstups->fields['n_tup_del'], 'int4', $shownull), "
\n"; + } + + // I/O performance + if ($tablestatsio->recordCount() > 0) { + echo "

{$lang['strioperf']}

\n"; + + echo "\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $i = 0; + + while (!$tablestatsio->EOF) { + $id = ( ($i % 2 ) == 0 ? '1' : '2' ); + echo "\t\n"; + + $total = $tablestatsio->fields['heap_blks_hit'] + $tablestatsio->fields['heap_blks_read']; + if ($total > 0) $percentage = round(($tablestatsio->fields['heap_blks_hit'] / $total) * 100); + else $percentage = 0; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + + $total = $tablestatsio->fields['idx_blks_hit'] + $tablestatsio->fields['idx_blks_read']; + if ($total > 0) $percentage = round(($tablestatsio->fields['idx_blks_hit'] / $total) * 100); + else $percentage = 0; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + + $total = $tablestatsio->fields['toast_blks_hit'] + $tablestatsio->fields['toast_blks_read']; + if ($total > 0) $percentage = round(($tablestatsio->fields['toast_blks_hit'] / $total) * 100); + else $percentage = 0; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + + $total = $tablestatsio->fields['tidx_blks_hit'] + $tablestatsio->fields['tidx_blks_read']; + if ($total > 0) $percentage = round(($tablestatsio->fields['tidx_blks_hit'] / $total) * 100); + else $percentage = 0; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $tablestatsio->movenext(); + $i++; + } + + echo "
{$lang['strheap']}{$lang['strindex']}{$lang['strtoast']}{$lang['strtoastindex']}
{$lang['strdisk']}{$lang['strcache']}{$lang['strpercent']}{$lang['strdisk']}{$lang['strcache']}{$lang['strpercent']}{$lang['strdisk']}{$lang['strcache']}{$lang['strpercent']}{$lang['strdisk']}{$lang['strcache']}{$lang['strpercent']}
", $misc->printVal($tablestatsio->fields['heap_blks_read'], 'int4', $shownull), "", $misc->printVal($tablestatsio->fields['heap_blks_hit'], 'int4', $shownull), "({$percentage}{$lang['strpercent']})", $misc->printVal($tablestatsio->fields['idx_blks_read'], 'int4', $shownull), "", $misc->printVal($tablestatsio->fields['idx_blks_hit'], 'int4', $shownull), "({$percentage}{$lang['strpercent']})", $misc->printVal($tablestatsio->fields['toast_blks_read'], 'int4', $shownull), "", $misc->printVal($tablestatsio->fields['toast_blks_hit'], 'int4', $shownull), "({$percentage}{$lang['strpercent']})", $misc->printVal($tablestatsio->fields['tidx_blks_read'], 'int4', $shownull), "", $misc->printVal($tablestatsio->fields['tidx_blks_hit'], 'int4', $shownull), "({$percentage}{$lang['strpercent']})
\n"; + } + + // Index row performance + if ($indexstatstups->recordCount() > 0) { + echo "

{$lang['stridxrowperf']}

\n"; + + echo "\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $i = 0; + + while (!$indexstatstups->EOF) { + $id = ( ($i % 2 ) == 0 ? '1' : '2' ); + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $indexstatstups->movenext(); + $i++; + } + + echo "
{$lang['strindex']}{$lang['strscan']}{$lang['strread']}{$lang['strfetch']}
", $misc->printVal($indexstatstups->fields['indexrelname']), "", $misc->printVal($indexstatstups->fields['idx_scan'], 'int4', $shownull), "", $misc->printVal($indexstatstups->fields['idx_tup_read'], 'int4', $shownull), "", $misc->printVal($indexstatstups->fields['idx_tup_fetch'], 'int4', $shownull), "
\n"; + } + + // Index I/0 performance + if ($indexstatsio->recordCount() > 0) { + echo "

{$lang['stridxioperf']}

\n"; + + echo "\n"; + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $i = 0; + + while (!$indexstatsio->EOF) { + $id = ( ($i % 2 ) == 0 ? '1' : '2' ); + echo "\t\n"; + $total = $indexstatsio->fields['idx_blks_hit'] + $indexstatsio->fields['idx_blks_read']; + if ($total > 0) $percentage = round(($indexstatsio->fields['idx_blks_hit'] / $total) * 100); + else $percentage = 0; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + $indexstatsio->movenext(); + $i++; + } + + echo "
{$lang['strindex']}{$lang['strdisk']}{$lang['strcache']}{$lang['strpercent']}
", $misc->printVal($indexstatsio->fields['indexrelname']), "", $misc->printVal($indexstatsio->fields['idx_blks_read'], 'int4', $shownull), "", $misc->printVal($indexstatsio->fields['idx_blks_hit'], 'int4', $shownull), "({$percentage}{$lang['strpercent']})
\n"; + } + } + } + + $misc->printHeader($lang['strtables'] . ' - ' . $_REQUEST['table'] . ' - ' . $lang['strinfo']); + $misc->printBody(); + + switch ($action) { + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/intro.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/intro.php new file mode 100644 index 00000000..e95916d2 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/intro.php @@ -0,0 +1,70 @@ +printHeader(); + $misc->printBody(); + + $misc->printTrail('root'); + $misc->printTabs('root','intro'); +?> + +

+ +
+ + + + + + + + + +
+ +
+ +
+ +
+ +

+ +
    +
  • +
  • +
  • +
  • +
+ +printFooter(); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/ac_insert_row.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/ac_insert_row.js new file mode 100644 index 00000000..1101a99d --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/ac_insert_row.js @@ -0,0 +1,229 @@ +var fkl_hasnext=false; +var fkl_hasprev=false; + +/* hide the value list */ +function hideAc() { + jQuery.ppa.o=0; + with (jQuery.ppa) { + fklist.hide(); + fkbg.hide(); + } +} + +/* enable/disable auto-complete feature */ +function triggerAc(ac) { + if (ac) { + jQuery.ppa.attrs + .bind('keyup.ac_action', autocomplete) + .bind('focus.ac_action', autocomplete) + .bind('keypress.ac_action', move) + .addClass('ac_field'); + } + else { + jQuery.ppa.attrs + .removeClass('ac_field') + .unbind('.ac_action'); + } +} + +/* select the given index value and highlight it */ +function selectVal(index) { + if (index == jQuery.ppa.i) + return; + + // we catch the header as well so it takes th index 0 + var trs = jQuery.ppa.fklist.find('tr'); + + // change colors for unselected + if (jQuery.ppa.i > 0) + trs.eq(jQuery.ppa.i).find('*').css({ + 'background-color': '#fff', + 'color': '' + }); + + // change colors for newly selected + trs.eq(index).find('*').css({ + 'background-color': '#3d80df', + 'color': '#fff' + }); + + jQuery.ppa.i = index; +} + +function openlist(e) { + var elt = jQuery(e); + var attnum = elt.attr('id').match(/\d+/)[0]; + /* FIXME we only support the first FK constraint of the field */ + var conid = attrs['attr_'+attnum][0]; + + var constr = constrs["constr_" + conid]; + + // get the changed attribute position in the arrays + for (i=0; (constr.pattnums[i] != attnum);i++); + + var datas = { + fattpos: i, + fvalue: e.value, + database: database, + 'keys[]': constr.pattnums, + 'keynames[]': constr.pattnames, + 'fkeynames[]': constr.fattnames, + f_table: constr.f_table, + f_schema: constr.f_schema, + offset: jQuery.ppa.o + }; + + jQuery.ajax({ + url: 'ajax-ac-insert.php?server=' + server, + type: 'post', + data: datas, + dataType: 'html', + cache: false, + contentType: 'application/x-www-form-urlencoded', + success: function (ret) { + jQuery.ppa.i = 0; + jQuery.ppa.fkbg.show(); + with(jQuery.ppa.fklist) { + html(ret); + appendTo('#row_att_'+ attnum); + css('width',elt.css('width')); + show(); + jQuery.ppa.numrow = find('tr').length; + } + } + }); +} + + +/* move the cursor down or up, + * load available next/prev values if going out of bound */ +function move(event) { + /* selecting next value down. + * if the list is closed, it will open next */ + if(event.keyCode == 40) { + if (jQuery.ppa.fklist[0].style.display == 'block') { + if ((jQuery.ppa.i + 1) < jQuery.ppa.numrow) { + selectVal(jQuery.ppa.i + 1); + } + else if (fkl_hasnext == true) { + jQuery.ppa.o+=11; + openlist(this); + } + } + else { + openlist(this); + } + } + /* selecting prev value up */ + else if(event.keyCode == 38) { + if ((jQuery.ppa.i - 1) > 0) { + selectVal(jQuery.ppa.i - 1); + } + else if ((fkl_hasprev == true) && (jQuery.ppa.i == 1)) { + jQuery.ppa.o-=11; + openlist(this); + } + else { + selectVal(jQuery.ppa.numrow -1); + } + } +} + +/* open/update the value list */ +function autocomplete(event) { + + /* if pressing enter, fire a click on the selected line */ + if (event.keyCode == 13) { + if (jQuery.ppa.i > 0) { + jQuery.ppa.fklist.find('tr').eq(jQuery.ppa.i).click(); + } + return false; + } + /* ignoring 38:up and 40:down */ + else if ( event.keyCode == 38 || event.keyCode == 40 ) { + return false; + } + /* ignoring 9:tab, 37:left, 39:right, 16:shift, ctrl: 17, alt:18, 20:lockmaj */ + else if ( event.keyCode == 9 || event.keyCode == 37 || event.keyCode == 39 + || event.keyCode == 16 || event.keyCode == 17 + || event.keyCode == 18 || event.keyCode == 20) { + return true; + } + /* esc */ + else if (event.keyCode == 27) { + hideAc(); + } + /* request the list of possible values asynchronously */ + else { + /* if we refresh because of a value update, + * we reset back to offset 0 so we catch values + * if list is smaller than 11 values */ + if (event.type == 'keyup') + jQuery.ppa.o = 0; + openlist(this); + } + + return true; +} + +/* bind actions on values lines: hover for style change, click for select */ +with(jQuery('tr.acline')) { + live('mouseover', function () { + selectVal(jQuery('table.ac_values tr').index(this)); + }); + + live('click', function () { + var a = jQuery(this).find('td > a.fkval'); + + for (i=0; i < a.length; i++) { + jQuery('input[name="values['+ a[i].name +']"]').val(jQuery(a[i]).text()); + } + hideAc(); + }); +} + +jQuery('#fkprev').live('click', function () { + jQuery.ppa.o -= 11; + /* get the field that is the previous html elt from the #fklist + * and trigger its focus to refresh the list AND actualy + * focus back on the field */ + jQuery('#fklist').prev().focus(); +}); + +jQuery('#fknext').live('click', function () { + jQuery.ppa.o += 11; + /* get the field that is the previous html elt from the #fklist + * and trigger its focus to refresh the list AND actualy + * focus back on the field*/ + jQuery('#fklist').prev().focus(); +}); + +jQuery(document).ready(function () { + /* register some global value in the ppa namespace */ + jQuery.ppa = { + fklist: jQuery('#fklist'), + attrs: jQuery('input[id^=attr_]'), // select fields with FK + fkbg: jQuery('#fkbg'), + i:0, // selected value indice + o:0 // offset when navigating prev/next + }; + + /* close the list when clicking outside of it */ + jQuery.ppa.fkbg.click(function (e) { + hideAc(); + }); + + /* do not submit the form when selecting a value by pressing enter */ + jQuery.ppa.attrs + .keydown(function (e) { + if (e.keyCode == 13 && jQuery.ppa.fklist[0].style.display == 'block') + return false; + }); + + /* enable/disable auto-complete according to the checkbox */ + triggerAc( + jQuery('#no_ac').click(function () { + triggerAc(this.checked); + })[0].checked + ); +}); diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/database.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/database.js new file mode 100644 index 00000000..f70f7078 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/database.js @@ -0,0 +1,64 @@ +$(document).ready(function() { + + var timeid = query = null; + var controlLink = $('#control'); + var errmsg = $('

'+Database.errmsg+'

') + .insertBefore(controlLink) + .hide(); + var loading = $('[loading]') + .insertAfter(controlLink) + .hide(); + + function refreshTable() { + if (Database.ajax_time_refresh > 0) { + loading.show(); + query = $.ajax({ + type: 'GET', + dataType: 'html', + data: {server: Database.server, database: Database.dbname, action: Database.action}, + url: 'database.php', + cache: false, + contentType: 'application/x-www-form-urlencoded', + success: function(html) { + $('#data_block').html(html); + timeid = window.setTimeout(refreshTable, Database.ajax_time_refresh) + }, + error: function() { + controlLink.click(); + errmsg.show(); + }, + complete: function () { + loading.hide(); + } + }); + } + } + + controlLink.toggle( + function() { + $(errmsg).hide(); + timeid = window.setTimeout(refreshTable, Database.ajax_time_refresh); + controlLink.html(' ' + + Database.str_stop.text + '   ' + ); + }, + function() { + $(errmsg).hide(); + $(loading).hide(); + window.clearInterval(timeid); + if (query) query.abort(); + controlLink.html(' ' + + Database.str_start.text + ); + } + ); + + /* preload images */ + $('#control img').hide() + .attr('src', Database.str_start.icon) + .attr('src', Database.str_stop.icon) + .show(); + + /* start refreshing */ + controlLink.click(); +}); diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/display.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/display.js new file mode 100644 index 00000000..bac28ecb --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/js/display.js @@ -0,0 +1,90 @@ +$(document).ready(function() { + + /* init some needed tags and values */ + + $('table#data').wrap('
'); + $('#fkcontainer').append('
'); + + jQuery.ppa = { + root: $('#root') + }; + + $("a.fk").live('click', function (event) { + /* make the cursor being a waiting cursor */ + $('body').css('cursor','wait'); + + query = $.ajax({ + type: 'GET', + dataType: 'html', + data: {action:'dobrowsefk'}, + url: $(this).attr('href'), + cache: false, + context: $(this), + contentType: 'application/x-www-form-urlencoded', + success: function(answer) { + pdiv = this.closest('div.fk'); + divclass = this.attr('class').split(' ')[1]; + + /* if we are clicking on a FK from the original table + (level 0), we are using the #root div as parent-div */ + if (pdiv[0].id == 'fkcontainer') { + /* computing top position, which is the topid as well */ + var top = this.position().top + 2 + this.height(); + /* if the requested top position is different than + the previous topid position of #root, empty and position it */ + if (top != jQuery.ppa.root.topid) + jQuery.ppa.root.empty() + .css({ + left: (pdiv.position().left) +'px', + top: top + 'px' + }) + /* this "topid" allows to track if we are + opening a FK from the same line in the original table */ + .topid = top; + + pdiv = jQuery.ppa.root; + + /* Remove equal rows in the root div */ + jQuery.ppa.root.children('.'+divclass).remove(); + } + else { + /* Remove equal rows in the pdiv */ + pdiv.children('div.'+divclass).remove(); + } + + /* creating the data div */ + newdiv = $('
').html(answer); + + /* highlight referencing fields */ + newdiv.data('ref', this).data('refclass', $(this).attr('class').split(' ')[1]) + .mouseenter(function (event) { + $(this).data('ref').closest('tr').find('a.'+$(this).data('refclass')).closest('div').addClass('highlight'); + }) + .mouseleave(function (event) { + $(this).data('ref').closest('tr').find('a.'+$(this).data('refclass')).closest('div').removeClass('highlight'); + }); + + /* appending it to the level-1 div */ + pdiv.append(newdiv); + }, + + error: function() { + this.closest('div.fk').append('

'+Display.errmsg+'

'); + }, + + complete: function () { + $('body').css('cursor','auto'); + } + }); + + return false; // do not refresh the page + }); + + $(".fk_delete").live('click', function (event) { + with($(this).closest('div')) { + data('ref').closest('tr').find('a.'+data('refclass')).closest('div').removeClass('highlight'); + remove(); + } + return false; // do not refresh the page + }); +}); diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/README b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/README new file mode 100644 index 00000000..a93cab61 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/README @@ -0,0 +1,14 @@ +Translators +----------- + +Please read the TRANSLATORS file in the top directory. + +To check your translation: + +cd lang +php langcheck (eg. 'french'); + +To synchronize your translation with english.php: + +cd lang +./synch (eg. 'polish'); diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/afrikaans.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/afrikaans.php new file mode 100644 index 00000000..30f3e478 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/afrikaans.php @@ -0,0 +1,621 @@ +>'; + $lang['strfailed'] = 'Het misluk'; + $lang['strcreate'] = 'Skep'; + $lang['strcreated'] = 'Geskep'; + $lang['strcomment'] = 'Kommentaar'; + $lang['strlength'] = 'Lengte'; + $lang['strdefault'] = 'Standaard'; + $lang['stralter'] = 'Wysig'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Kanselleer'; + $lang['strsave'] = 'Bewaar'; + $lang['strreset'] = 'Herstel'; + $lang['strinsert'] = 'Voeg in'; + $lang['strselect'] = 'Selekteer'; + $lang['strdelete'] = 'Verwyder'; + $lang['strupdate'] = 'Verfris'; + $lang['strreferences'] = 'Verwysings'; + $lang['stryes'] = 'Ja'; + $lang['strno'] = 'Nee'; + $lang['strtrue'] = 'WAAR'; + $lang['strfalse'] = 'VALS'; + $lang['stredit'] = 'Redigeer'; + $lang['strcolumn'] = 'Kolom'; + $lang['strcolumns'] = 'Kolomme'; + $lang['strrows'] = 'ry(e)'; + $lang['strrowsaff'] = 'ry(e) het verander.'; + $lang['strobjects'] = 'objek(te)'; + $lang['strback'] = 'Terug'; + $lang['strqueryresults'] = 'Navraagresultate'; + $lang['strshow'] = 'Wys'; + $lang['strempty'] = 'Leeg'; + $lang['strlanguage'] = 'Taal'; + $lang['strencoding'] = 'Enkodering'; + $lang['strvalue'] = 'Waarde'; + $lang['strunique'] = 'Uniek'; + $lang['strprimary'] = 'Primêr'; + $lang['strexport'] = 'Eksporteer'; + $lang['strimport'] = 'Importeer'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Stofsuig'; + $lang['stranalyze'] = 'Analiseer'; + $lang['strcluster'] = 'Kluster'; + $lang['strclustered'] = 'In klusters?'; + $lang['strreindex'] = 'Herindekseer'; + $lang['strrun'] = 'Loop'; + $lang['stradd'] = 'Voeg by'; + $lang['strevent'] = 'Gebeurtenis'; + $lang['strwhere'] = 'Waar'; + $lang['strinstead'] = 'Doen eerder'; + $lang['strwhen'] = 'Wanneer'; + $lang['strformat'] = 'Formaat'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'Bevestig'; + $lang['strexpression'] = 'Uitdrukking'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Vou oop'; + $lang['strcollapse'] = 'Vou toe'; + $lang['strexplain'] = 'Verduidelik'; + $lang['strexplainanalyze'] = 'Verduidelik Analise'; + $lang['strfind'] = 'Soek'; + $lang['stroptions'] = 'Opsies'; + $lang['strrefresh'] = 'Verfris'; + $lang['strdownload'] = 'Laai af'; + $lang['strdownloadgzipped'] = 'Laai af ... saamgepers met gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Gevorderd'; + $lang['strvariables'] = 'Veranderlikes'; + $lang['strprocess'] = 'Proses'; + $lang['strprocesses'] = 'Prosesse'; + $lang['strsetting'] = 'Instelling'; + $lang['streditsql'] = 'Redigeer SQL'; + $lang['strruntime'] = 'Totale looptyd: %s ms'; + $lang['strpaginate'] = 'Resultate per bladsy'; + $lang['struploadscript'] = 'of laai \'n SQL skrip in:'; + $lang['strstarttime'] = 'Begintyd'; + $lang['strfile'] = 'Lêer'; + $lang['strfileimported'] = 'Lêer is ingetrek.'; + + // Error handling + $lang['strnoframes'] = 'Hierdie toepassing maak gebruik van HTML-rame. U het \'n blaaier nodig wat rame ondersteun om hierdie toepassing te kan gebruik. '; + $lang['strbadconfig'] = 'Die lêer config.inc.php is verouderd. Jy kan verbeterde weergawe aflei van die lêer config.inc.php-dist.'; + $lang['strnotloaded'] = 'Hierdie PHP-installasie is sonder ondersteuning van hierdie tipe database nie gekompileerd.'; + $lang['strpostgresqlversionnotsupported'] = 'Weergawe van PostgreSQL word nie ondersteun nie. Probeer asb. weergawe %s of later.'; + $lang['strbadschema'] = 'Ongeldige skema gespesifiseer.'; + $lang['strbadencoding'] = 'Die kliëntenkodering kon nie in die databasis geplaas word nie.'; + $lang['strsqlerror'] = 'SQL-fout:'; + $lang['strinstatement'] = 'In stelling:'; + $lang['strinvalidparam'] = 'Ongeldige parameters.'; + $lang['strnodata'] = 'Geen rye gevind.'; + $lang['strnoobjects'] = 'Geen objekte gevind.'; + $lang['strrownotunique'] = 'Geen unieke identifiseerder vir hierdie ry.'; + $lang['strnouploads'] = 'Oplaaiing van lêers is afgeskakel.'; + $lang['strimporterror'] = 'Inleesfout.'; + $lang['strimporterrorline'] = 'Inleesfout op reël %s.'; + $lang['strcannotdumponwindows'] = 'Weergee van komplekse tabel- en skemaname word nie op Windows ondersteun nie. Kyk asb. in die FAQ.'; + + // Tables + $lang['strtable'] = 'Tabel'; + $lang['strtables'] = 'Tabelle'; + $lang['strshowalltables'] = 'Wys alle tabelle'; + $lang['strnotables'] = 'Geen tabelle gevind.'; + $lang['strnotable'] = 'Geen tabel gevind.'; + $lang['strcreatetable'] = 'Skep tabel'; + $lang['strtablename'] = 'Tabelnaam'; + $lang['strtableneedsname'] = 'Jy moet die tabel \'n naam gee.'; + $lang['strtableneedsfield'] = 'Jy moet ten minste een veld spesifiseer.'; + $lang['strtableneedscols'] = 'Jy moet die tabel \'n geldige aantal kolomme gee.'; + $lang['strtablecreated'] = 'Tabel geskep.'; + $lang['strtablecreatedbad'] = 'Die tabel kon nie geskep word nie.'; + $lang['strconfdroptable'] = 'Is jy seker dat dat jy die tabel "%s" wil verwyder?'; + $lang['strtabledropped'] = 'Tabel is verwyder.'; + $lang['strtabledroppedbad'] = 'Die tabel kon nie verwyder word nie.'; + $lang['strconfemptytable'] = 'Is jy seker dat jy alle rye uit tabel "%s" wil verwyder?'; + $lang['strtableemptied'] = 'Alle ryen is uit die tabel verwyder.'; + $lang['strtableemptiedbad'] = 'Die rye kon nie verwyder word nie.'; + $lang['strinsertrow'] = 'Voeg \'n ry by'; + $lang['strrowinserted'] = 'Ry is bygevoeg.'; + $lang['strrowinsertedbad'] = 'Die ry kon nie bygevoeg word nie.'; + $lang['streditrow'] = 'Wysig ry'; + $lang['strrowupdated'] = 'Ry is opgedateer.'; + $lang['strrowupdatedbad'] = 'Die opdatering van die ry het misluk.'; + $lang['strdeleterow'] = 'Verwyder ry'; + $lang['strconfdeleterow'] = 'Is jy seker dat jy hierdie ry wil verwyder?'; + $lang['strrowdeleted'] = 'Ry is verwyder.'; + $lang['strrowdeletedbad'] = 'Die ry kon nie verwyder word nie.'; + $lang['strinsertandrepeat'] = 'Voeg in & Herhaal'; + $lang['strnumcols'] = 'Aantal kolomme'; + $lang['strcolneedsname'] = 'Jy moet die kolom \'n naam gee'; + $lang['strselectallfields'] = 'Selekteer alle velde'; + $lang['strselectneedscol'] = 'Jy moet ten minste één kolom as uitvoer hê'; + $lang['strselectunary'] = 'Unêre operatore kan nie waardes kry nie.'; + $lang['straltercolumn'] = 'Wysig kolom'; + $lang['strcolumnaltered'] = 'Kolom is gewysig.'; + $lang['strcolumnalteredbad'] = 'Die kolom kon nie gewysig word nie.'; + $lang['strconfdropcolumn'] = 'Is jy seker dat jy die kolom "%s" wil verwyder uit tabel "%s"?'; + $lang['strcolumndropped'] = 'Kolom is verwyder.'; + $lang['strcolumndroppedbad'] = 'Die kolom kon nie verwyder word nie.'; + $lang['straddcolumn'] = 'Voeg kolom by'; + $lang['strcolumnadded'] = 'Kolom is bygevoeg.'; + $lang['strcolumnaddedbad'] = 'Die kolom kon nie bygevoeg word nie.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabel is gewysig.'; + $lang['strtablealteredbad'] = 'Tabelwysiging het misluk.'; + $lang['strdataonly'] = 'Slegs data'; + $lang['strstructureonly'] = 'Slegs struktuur'; + $lang['strstructureanddata'] = 'Struktuur en data'; + $lang['strtabbed'] = 'Tabbed'; + $lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Is jy seker jy wil VACUUM "%s"?'; + $lang['strestimatedrowcount'] = 'Geskatte aantal rye'; + + // Users + $lang['struser'] = 'Gebruiker'; + $lang['strusers'] = 'Gebruikers'; + $lang['strusername'] = 'Gebruikersnaam'; + $lang['strpassword'] = 'Wagwoord'; + $lang['strsuper'] = 'Supergebruiker?'; + $lang['strcreatedb'] = 'Skep DB?'; + $lang['strexpires'] = 'Verval'; + $lang['strsessiondefaults'] = 'Verstekwaardes van sessie'; + $lang['strnousers'] = 'Geen gebruikers gevind.'; + $lang['struserupdated'] = 'Gebruiker is opgedateer.'; + $lang['struserupdatedbad'] = 'Gebruiker kon nie opgedateer word nie.'; + $lang['strshowallusers'] = 'Wys alle gebruikers'; + $lang['strcreateuser'] = 'Skep gebruiker'; + $lang['struserneedsname'] = 'Jy moet \'n naam gee vir die gebruiker.'; + $lang['strusercreated'] = 'Gebruiker geskep.'; + $lang['strusercreatedbad'] = 'Die gebruiker kon nie geskep word nie.'; + $lang['strconfdropuser'] = 'Is jy seker dat jy die gebruiker "%s" wil verwyder?'; + $lang['struserdropped'] = 'Gebruiker is verwyder.'; + $lang['struserdroppedbad'] = 'Verwydering van die gebruiker het misluk.'; + $lang['straccount'] = 'Gebruiker'; + $lang['strchangepassword'] = 'Verander wagwoord'; + $lang['strpasswordchanged'] = 'Wagwoord is verander.'; + $lang['strpasswordchangedbad'] = 'Wagwoordverandering het misluk.'; + $lang['strpasswordshort'] = 'Wagwoord is te kort.'; + $lang['strpasswordconfirm'] = 'Wagwoord verskil van bevestigings-wagwoord.'; + + // Groups + $lang['strgroup'] = 'Groep'; + $lang['strgroups'] = 'Groepe'; + $lang['strnogroup'] = 'Groep nie gevind.'; + $lang['strnogroups'] = 'Geen groepe gevind.'; + $lang['strcreategroup'] = 'Skep groep'; + $lang['strshowallgroups'] = 'Wys alle groepe'; + $lang['strgroupneedsname'] = 'Jy moet die groep \'n naam gee.'; + $lang['strgroupcreated'] = 'Groep geskep.'; + $lang['strgroupcreatedbad'] = 'Die groep kon nie geskep word nie.'; + $lang['strconfdropgroup'] = 'Is jy seker dat jy die groep "%s" wil verwyder?'; + $lang['strgroupdropped'] = 'Groep is verwyder.'; + $lang['strgroupdroppedbad'] = 'Verwydering van die groep het misluk.'; + $lang['strmembers'] = 'Lede'; + $lang['straddmember'] = 'Voeg \'n groeplid by'; + $lang['strmemberadded'] = 'Groeplid is bygevoeg.'; + $lang['strmemberaddedbad'] = 'Toevoeging van groeplid het misluk.'; + $lang['strdropmember'] = 'Verwyder groeplid'; + $lang['strconfdropmember'] = 'Is jy seker dat jy "%s" uit groep "%s" wil verwyder?'; + $lang['strmemberdropped'] = 'Groeplid is verwyder.'; + $lang['strmemberdroppedbad'] = 'Verwydering van groeplid het misluk.'; + + // Privileges + $lang['strprivilege'] = 'Voorregte'; + $lang['strprivileges'] = 'Voorregte'; + $lang['strnoprivileges'] = 'Hierdie objek het verstekeienaarvoorregte.'; + $lang['strgrant'] = 'Staan toe'; + $lang['strrevoke'] = 'Ontneem'; + $lang['strgranted'] = 'Voorregte is bygevoeg.'; + $lang['strgrantfailed'] = 'Voorregte kon nie bygevoeg word nie.'; + $lang['strgrantbad'] = 'Jy moet minstens een gebruiker of groep en minstens een voorreg aandui.'; + $lang['strgrantor'] = 'Grantor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Databasis'; + $lang['strdatabases'] = 'Databasisse'; + $lang['strshowalldatabases'] = 'Wys alle databasisse'; + $lang['strnodatabase'] = 'Geen databasis gevind.'; + $lang['strnodatabases'] = 'Geen databasis gevind.'; + $lang['strcreatedatabase'] = 'Skep databasis'; + $lang['strdatabasename'] = 'Databasisnaam'; + $lang['strdatabaseneedsname'] = 'Jy moet die databasis \'n naam gee.'; + $lang['strdatabasecreated'] = 'Databasis is geskep.'; + $lang['strdatabasecreatedbad'] = 'Die databasis kon nie geskep word nie.'; + $lang['strconfdropdatabase'] = 'Is jy seker dat jy die databasis "%s" wil verwyder?'; + $lang['strdatabasedropped'] = 'Databasis is verwyder.'; + $lang['strdatabasedroppedbad'] = 'Databasisverwydering het misluk.'; + $lang['strentersql'] = 'Tik hieronder die SQL in wat uitgevoer moet word:'; + $lang['strsqlexecuted'] = 'SQL uitgevoer.'; + $lang['strvacuumgood'] = 'Vacuum-bewerking is klaar.'; + $lang['strvacuumbad'] = 'Vacuum-bewerking het misluk.'; + $lang['stranalyzegood'] = 'Analise is voltooi.'; + $lang['stranalyzebad'] = 'Analise het misluk.'; + $lang['strreindexgood'] = 'Herindeksering is voltooi.'; + $lang['strreindexbad'] = 'Herindeksering het misluk.'; + $lang['strfull'] = 'Volledig'; + $lang['strfreeze'] = 'Vries'; + $lang['strforce'] = 'Forseer'; + $lang['strsignalsent'] = 'Sein gestuur.'; + $lang['strsignalsentbad'] = 'Stuur van sein het misluk.'; + $lang['strallobjects'] = 'Alle objekte'; + + // Views + $lang['strview'] = 'Aansig'; + $lang['strviews'] = 'Aansigte'; + $lang['strshowallviews'] = 'Wys alle aansigte'; + $lang['strnoview'] = 'Geen aansigte gevind.'; + $lang['strnoviews'] = 'Geen aansigte gevind.'; + $lang['strcreateview'] = 'Skep aansig'; + $lang['strviewname'] = 'Aansignaam'; + $lang['strviewneedsname'] = 'Jy moet die aansig \'n naam gee.'; + $lang['strviewneedsdef'] = 'Jy moet die aansig definieer.'; + $lang['strviewneedsfields'] = 'Jy moet sê watter kolomme gekies moet wees in hierdie aansig.'; + $lang['strviewcreated'] = 'Aansig is geskep.'; + $lang['strviewcreatedbad'] = 'Die aansig kon nie geskep word nie.'; + $lang['strconfdropview'] = 'Is jy seker dat jy die aansig "%s" wil verwyder?'; + $lang['strviewdropped'] = 'Aansig is verwyder.'; + $lang['strviewdroppedbad'] = 'Die aansig kon nie verwyder word nie.'; + $lang['strviewupdated'] = 'Aansig is opgedateer.'; + $lang['strviewupdatedbad'] = 'Opdatering van aansig het misluk.'; + $lang['strviewlink'] = 'Sleutels word verbind'; + $lang['strviewconditions'] = 'Addisionele voorwaardes'; + $lang['strcreateviewwiz'] = 'Skep \'n aansig met behulp van \'n toergids'; + + // Sequences + $lang['strsequence'] = 'Reeks'; + $lang['strsequences'] = 'Reekse'; + $lang['strshowallsequences'] = 'Wys alle reekse'; + $lang['strnosequence'] = 'Geen reeks gevind.'; + $lang['strnosequences'] = 'Geen reekse gevind.'; + $lang['strcreatesequence'] = 'Skep reeks'; + $lang['strlastvalue'] = 'Laaste waarde'; + $lang['strincrementby'] = 'Verhoog met'; + $lang['strstartvalue'] = 'Aanvangswaarde'; + $lang['strmaxvalue'] = 'maks_waarde'; + $lang['strminvalue'] = 'min_waarde'; + $lang['strcachevalue'] = 'Kasgeheue-waarde'; + $lang['strlogcount'] = 'Boekstaaftelling'; + $lang['striscycled'] = 'is_siklies ?'; + $lang['strsequenceneedsname'] = 'Jy moet \'n naam gee vir die reeks.'; + $lang['strsequencecreated'] = 'Reeks is geskep.'; + $lang['strsequencecreatedbad'] = 'Die reeks kon nie geskep word nie.'; + $lang['strconfdropsequence'] = 'Is jy seker dat jy die reeks "%s" wil verwyder?'; + $lang['strsequencedropped'] = 'Reeks is verwyder.'; + $lang['strsequencedroppedbad'] = 'Verwydering van die reeks het misluk.'; + $lang['strsequencereset'] = 'Herstel reeks.'; + $lang['strsequenceresetbad'] = 'Herstel van reeks het misluk.'; + + // Indexes + $lang['strindex'] = 'Indeks'; + $lang['strindexes'] = 'Indekse'; + $lang['strindexname'] = 'Indeksnaam'; + $lang['strshowallindexes'] = 'Wys alle indekse'; + $lang['strnoindex'] = 'Geen indeks gevind.'; + $lang['strnoindexes'] = 'Geen indekse gevind.'; + $lang['strcreateindex'] = 'Skep \'n indeks'; + $lang['strtabname'] = 'Tab-naam'; + $lang['strcolumnname'] = 'Kolomnaam'; + $lang['strindexneedsname'] = 'Jy moet \'n naam gee vir die index.'; + $lang['strindexneedscols'] = 'Indekse moet ten minste uit één kolom bestaan.'; + $lang['strindexcreated'] = 'Indeks is geskep'; + $lang['strindexcreatedbad'] = 'Die indeks kon nie geskep word nie.'; + $lang['strconfdropindex'] = 'Is jy seker dat jy die indeks "%s" wil verwyder?'; + $lang['strindexdropped'] = 'Indeks is verwyder.'; + $lang['strindexdroppedbad'] = 'Verwydering van die indeks het misluk.'; + $lang['strkeyname'] = 'Sleutelnaam'; + $lang['struniquekey'] = 'Unieke sleutel'; + $lang['strprimarykey'] = 'Primêre sleutel'; + $lang['strindextype'] = 'Tipe van die indeks'; + $lang['strtablecolumnlist'] = 'Kolomme in tabel'; + $lang['strindexcolumnlist'] = 'Kolomme in indeks'; + $lang['strconfcluster'] = 'Is jy seker jy wil \'n kluster maak van "%s"?'; + $lang['strclusteredgood'] = 'Kluster is voltooi.'; + $lang['strclusteredbad'] = 'Kluster het misluk.'; + + // Rules + $lang['strrules'] = 'Reëls'; + $lang['strrule'] = 'Reël'; + $lang['strshowallrules'] = 'Wys alle reëls'; + $lang['strnorule'] = 'Geen reël gevind.'; + $lang['strnorules'] = 'Geen reëls gevind.'; + $lang['strcreaterule'] = 'Skep \'n reël'; + $lang['strrulename'] = 'Reëlnaam'; + $lang['strruleneedsname'] = 'Jy moet \'n naam gee vir die reël.'; + $lang['strrulecreated'] = 'Reël is geskep.'; + $lang['strrulecreatedbad'] = 'Die reël kon nie geskep word nie.'; + $lang['strconfdroprule'] = 'Is jy seker dat jy die reël "%s" op "%s" wil verwyder?'; + $lang['strruledropped'] = 'Reël is verwyder.'; + $lang['strruledroppedbad'] = 'Verwydering van die reël het misluk.'; + + // Constraints + $lang['strconstraints'] = 'Beperkings'; + $lang['strshowallconstraints'] = 'Wys alle beperkings'; + $lang['strnoconstraints'] = 'Geen beperkings gevind.'; + $lang['strcreateconstraint'] = 'Skep beperking'; + $lang['strconstraintcreated'] = 'Beperking is geskep.'; + $lang['strconstraintcreatedbad'] = 'Die beperking kon nie geskep word nie.'; + $lang['strconfdropconstraint'] = 'Is jy seker dat jy die beperking "%s" op "%s" wil verwyder?'; + $lang['strconstraintdropped'] = 'Beperking is verwyder.'; + $lang['strconstraintdroppedbad'] = 'Verwydering van die beperking het misluk.'; + $lang['straddcheck'] = 'Voeg \'n kontrole by'; + $lang['strcheckneedsdefinition'] = 'Kontrolebeperking moet gedefinieer wees.'; + $lang['strcheckadded'] = 'Kontrolebeperking is bygevoeg.'; + $lang['strcheckaddedbad'] = 'Kontrolebeperking kon nie bygevoeg word nie.'; + $lang['straddpk'] = 'Voeg primêre sleutel by'; + $lang['strpkneedscols'] = 'Primêre sleutel moet minstens één kolom hê.'; + $lang['strpkadded'] = 'Primêre sleutel bygevoeg.'; + $lang['strpkaddedbad'] = 'Primêre sleutel kon nie bygevoeg word nie.'; + $lang['stradduniq'] = 'Voeg unieke sleutel by.'; + $lang['struniqneedscols'] = 'Unieke sleutel moet minstens één kolom hê.'; + $lang['struniqadded'] = 'Unieke sleutel is bygevoeg.'; + $lang['struniqaddedbad'] = 'Unieke sleutel kon nie bygevoeg word nie.'; + $lang['straddfk'] = 'Voeg vreemdesleutel toe'; + $lang['strfkneedscols'] = 'Vreemdesleutel moet minstens één kolom hê.'; + $lang['strfkneedstarget'] = 'Vreemdesleutel moet \'n doeltabel hê.'; + $lang['strfkadded'] = 'Vreemdesleutel is bygevoeg.'; + $lang['strfkaddedbad'] = 'Vreemdesleutel kon nie bygevoeg word nie.'; + $lang['strfktarget'] = 'Doeltabel'; + $lang['strfkcolumnlist'] = 'Kolomme in sleutel'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Funksie'; + $lang['strfunctions'] = 'Funksies'; + $lang['strshowallfunctions'] = 'Wys alle funksies'; + $lang['strnofunction'] = 'Geen funksies gevind.'; + $lang['strnofunctions'] = 'Geen funksies gevind.'; + $lang['strcreateplfunction'] = 'Skep SQL/PL funksie'; + $lang['strcreateinternalfunction'] = 'Skep interne funksie'; + $lang['strcreatecfunction'] = 'Skep C funksie'; + $lang['strfunctionname'] = 'Funksienaam'; + $lang['strreturns'] = 'Gee terug'; + $lang['strarguments'] = 'Argumente'; + $lang['strproglanguage'] = 'Programmeertaal'; + $lang['strfunctionneedsname'] = 'Jy moet die funksie \'n naam gee.'; + $lang['strfunctionneedsdef'] = 'Jy moet die funksie definieer.'; + $lang['strfunctioncreated'] = 'Funksie is geskep.'; + $lang['strfunctioncreatedbad'] = 'Die funksie kon nie geskep word nie.'; + $lang['strconfdropfunction'] = 'Is jy seker dat jy die funksie "%s" wil verwyder?'; + $lang['strfunctiondropped'] = 'Funksie is verwyder.'; + $lang['strfunctiondroppedbad'] = 'Verwydering van die funksie het misluk.'; + $lang['strfunctionupdated'] = 'Funksie is opgedateer.'; + $lang['strfunctionupdatedbad'] = 'Opdatering van die funksie het misluk.'; + $lang['strobjectfile'] = 'Objeklêer'; + $lang['strlinksymbol'] = 'Skakelsimbool'; + + // Triggers + $lang['strtrigger'] = 'Snellers'; + $lang['strtriggers'] = 'Snellers'; + $lang['strshowalltriggers'] = 'Wys alle snellers'; + $lang['strnotrigger'] = 'Geen sneller gevind.'; + $lang['strnotriggers'] = 'Geen snellers gevind.'; + $lang['strcreatetrigger'] = 'skep trigger'; + $lang['strtriggerneedsname'] = 'Jy moet vir die sneller \'n naam gee.'; + $lang['strtriggerneedsfunc'] = 'Jy moet vir die sneller \'n funksie gee.'; + $lang['strtriggercreated'] = 'Sneller is geskep.'; + $lang['strtriggercreatedbad'] = 'Die sneller kon nie geskep word nie.'; + $lang['strconfdroptrigger'] = 'Is jy seker dat jy die sneller "%s" op "%s" wil verwyder?'; + $lang['strtriggerdropped'] = 'Sneller is verwyder.'; + $lang['strtriggerdroppedbad'] = 'Verwydering van sneller misluk.'; + $lang['strtriggeraltered'] = 'Sneller is gewysig.'; + $lang['strtriggeralteredbad'] = 'Snellerwysiging het misluk.'; + + // Types + $lang['strtype'] = 'Tipe'; + $lang['strtypes'] = 'Tipes'; + $lang['strshowalltypes'] = 'Wys alle tipes'; + $lang['strnotype'] = 'Geen tipe gevind.'; + $lang['strnotypes'] = 'Geen tipes gevind.'; + $lang['strcreatetype'] = 'skep tipe'; + $lang['strcreatecomptype'] = 'Skep saamgestelde tipe'; + $lang['strtypeneedsfield'] = 'Jy moet ten minste een veld spesifiseer.'; + $lang['strtypeneedscols'] = 'Jy \'n geldige aantal velde spesifiseer.'; + $lang['strtypename'] = 'Tipenaam'; + $lang['strinputfn'] = 'Toevoerfunksie'; + $lang['stroutputfn'] = 'Afvoerfunksie'; + $lang['strpassbyval'] = 'Aangestuur per waarde?'; + $lang['stralignment'] = 'Belyning'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Skeidingsteken'; + $lang['strstorage'] = 'Berging'; + $lang['strfield'] = 'Veld'; + $lang['strnumfields'] = 'Aantal velde'; + $lang['strtypeneedsname'] = 'Jy moet die tipe \'n naam gee.'; + $lang['strtypeneedslen'] = 'Jy moet die tipe \'n lengte gee.'; + $lang['strtypecreated'] = 'Tipe geskep'; + $lang['strtypecreatedbad'] = 'Tipeskepping het misluk.'; + $lang['strconfdroptype'] = 'Is jy seker dat jy die tipe \"%s\" wil verwyder?'; + $lang['strtypedropped'] = 'Tipe is verwyder.'; + $lang['strtypedroppedbad'] = 'Verwydering van die tipe het misluk.'; + $lang['strflavor'] = 'Geur'; + $lang['strbasetype'] = 'Basis'; + $lang['strcompositetype'] = 'Saamgestel'; + $lang['strpseudotype'] = 'Pseudo'; + + // Schemas + $lang['strschema'] = 'Skema'; + $lang['strschemas'] = 'Skemas'; + $lang['strshowallschemas'] = 'Wys alle skemas'; + $lang['strnoschema'] = 'Geen skema gevind.'; + $lang['strnoschemas'] = 'Geen skemas gevind.'; + $lang['strcreateschema'] = 'Skep skema'; + $lang['strschemaname'] = 'Skemanaam'; + $lang['strschemaneedsname'] = 'Jy moet \'n naam gee vir die skema.'; + $lang['strschemacreated'] = 'Skema is geskep'; + $lang['strschemacreatedbad'] = 'Die skema kon nie geskep word nie.'; + $lang['strconfdropschema'] = 'Is jy seker dat jy die skema "%s" wil verwyder?'; + $lang['strschemadropped'] = 'Skema is verwyder.'; + $lang['strschemadroppedbad'] = 'Verwydering van die skema het misluk.'; + $lang['strschemaaltered'] = 'Skema is gewysig.'; + $lang['strschemaalteredbad'] = 'Skemawysiging het misluk.'; + $lang['strsearchpath'] = 'Skema-soekpad'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domein'; + $lang['strdomains'] = 'Domeine'; + $lang['strshowalldomains'] = 'Wys alle domeine'; + $lang['strnodomains'] = 'Geen domeine is gevind nie.'; + $lang['strcreatedomain'] = 'Skep domein'; + $lang['strdomaindropped'] = 'Domein is verwyder.'; + $lang['strdomaindroppedbad'] = 'Verwydering van domein het misluk.'; + $lang['strconfdropdomain'] = 'Is jy seker dat jy die domein "%s" wil verwyder?'; + $lang['strdomainneedsname'] = 'Jy moet \'n naam gee vir die domein.'; + $lang['strdomaincreated'] = 'Domein is geskep.'; + $lang['strdomaincreatedbad'] = 'Domeinskepping het misluk.'; + $lang['strdomainaltered'] = 'Domein is gewysig.'; + $lang['strdomainalteredbad'] = 'Wysiging van die domein het misluk.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operatore'; + $lang['strshowalloperators'] = 'Wys alle operators'; + $lang['strnooperator'] = 'Geen operator is gevind nie.'; + $lang['strnooperators'] = 'Geen operators is gevind nie.'; + $lang['strcreateoperator'] = 'Skep operator'; + $lang['strleftarg'] = 'Linkerargumenttipe'; + $lang['strrightarg'] = 'Regterargumenttipe'; + $lang['strcommutator'] = 'Kommutator'; + $lang['strnegator'] = 'Negeerder'; + $lang['strrestrict'] = 'Beperk'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Linkssorteer'; + $lang['strrightsort'] = 'Regssorteer'; + $lang['strlessthan'] = 'Kleiner as'; + $lang['strgreaterthan'] = 'Groter as'; + $lang['stroperatorneedsname'] = 'Jy moet \'n naam gee vir die operator.'; + $lang['stroperatorcreated'] = 'Operator is geskep'; + $lang['stroperatorcreatedbad'] = 'Operatorskepping het misluk.'; + $lang['strconfdropoperator'] = 'Is jy seker dat jy die operator "%s" wil verwyder?'; + $lang['stroperatordropped'] = 'Operator is verwyder.'; + $lang['stroperatordroppedbad'] = 'Verwydering van die operator het misluk.'; + + // Casts + $lang['strcasts'] = 'Ekwivalente'; + $lang['strnocasts'] = 'Geen ekwivalente gevind.'; + $lang['strsourcetype'] = 'Brontipe'; + $lang['strtargettype'] = 'Doeltipe'; + $lang['strimplicit'] = 'Implisiet'; + $lang['strinassignment'] = 'Tydens toekenning'; + $lang['strbinarycompat'] = '(Binêr-versoenbaar)'; + + // Conversions + $lang['strconversions'] = 'Omskakelings'; + $lang['strnoconversions'] = 'Geen omskakelings gevind.'; + $lang['strsourceencoding'] = 'Bron-enkodering'; + $lang['strtargetencoding'] = 'Doel-enkodering'; + + // Languages + $lang['strlanguages'] = 'Tale'; + $lang['strnolanguages'] = 'Geen tale gevind.'; + $lang['strtrusted'] = 'Betroubaar'; + + // Info + $lang['strnoinfo'] = 'Geen inligting beskikbaar.'; + $lang['strreferringtables'] = 'Verwysende tabelle'; + $lang['strparenttables'] = 'Parent-tabelle'; + $lang['strchildtables'] = 'Child-tabelle'; + + // Aggregates + $lang['straggregates'] = 'Opsommers'; + $lang['strnoaggregates'] = 'Geen opsommers gevind.'; + $lang['stralltypes'] = '(Alle tipes)'; + + // Operator Classes + $lang['stropclasses'] = 'Operatorklasse'; + $lang['strnoopclasses'] = 'Geen operatorklasse gevind.'; + $lang['straccessmethod'] = 'Toegangmetode'; + + // Stats and performance + $lang['strrowperf'] = 'Ry werkverrigting'; + $lang['strioperf'] = 'T/A werkverrigting'; + $lang['stridxrowperf'] = 'Indekseer-ry werkverrigting'; + $lang['stridxioperf'] = 'Indeks T/A werkverrigting'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sekwensieel'; + $lang['strscan'] = 'Deursoek'; + $lang['strread'] = 'Lees'; + $lang['strfetch'] = 'Gaan haal'; + $lang['strheap'] = 'Hoop'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST-indeks'; + $lang['strcache'] = 'Kasgeheue'; + $lang['strdisk'] = 'Skyf'; + $lang['strrows2'] = 'Rye'; + + // Tablespaces + $lang['strtablespace'] = 'Tabelruimte'; + $lang['strtablespaces'] = 'Tabelruimtes'; + $lang['strshowalltablespaces'] = 'Wys alle tabelruimtes'; + $lang['strnotablespaces'] = 'Geen tabelruimtes gevind.'; + $lang['strcreatetablespace'] = 'Skep tabelruimte'; + $lang['strlocation'] = 'Plek'; + $lang['strtablespaceneedsname'] = 'Jy moet \'n naam gee vir jou tabelruimte.'; + $lang['strtablespaceneedsloc'] = 'Jy moet \'n gids gee om jou tabelruimte in te skep.'; + $lang['strtablespacecreated'] = 'Tabelruimte geskep.'; + $lang['strtablespacecreatedbad'] = 'Skep van tabelruimte het misluk.'; + $lang['strconfdroptablespace'] = 'Is jy seker jy wil die tabelruimte "%s" uitvee?'; + $lang['strtablespacedropped'] = 'Tabelruimte is uitgevee.'; + $lang['strtablespacedroppedbad'] = 'Uitvee van tabelruimte het misluk.'; + $lang['strtablespacealtered'] = 'Tabelruimte gewysig.'; + $lang['strtablespacealteredbad'] = 'Wysiging van tabelruimte het misluk.'; + + // Miscellaneous + $lang['strtopbar'] = '%s loop op %s:%s -- Jy is aangeteken as gebruiker "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Hulp'; + $lang['strhelpicon'] = '?'; + +?> + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/arabic.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/arabic.php new file mode 100644 index 00000000..cb0203f5 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/arabic.php @@ -0,0 +1,581 @@ +السابق'; + $lang['strnext'] = '<التالي'; + $lang['strfirst'] = '>>الأول'; + $lang['strlast'] = 'الأخير<<'; + $lang['strfailed'] = 'Ùشـل'; + $lang['strcreate'] = 'إنشاء'; + $lang['strcreated'] = 'تم الإنشاء'; + $lang['strcomment'] = 'ملاحظات'; + $lang['strlength'] = 'طول'; + $lang['strdefault'] = 'الإÙتراضي'; + $lang['stralter'] = 'تعديلAlter'; + $lang['strok'] = 'مواÙÙ‚'; + $lang['strcancel'] = 'تراجع'; + $lang['strsave'] = 'Ø­Ùظ'; + $lang['strreset'] = 'إعادة Reset'; + $lang['strinsert'] = 'إدراج Insert'; + $lang['strselect'] = 'إختيار Select'; + $lang['strdelete'] = 'حذ٠Delete'; + $lang['strupdate'] = 'تعديل Update'; + $lang['strreferences'] = 'مراجع'; + $lang['stryes'] = 'نعم'; + $lang['strno'] = 'لا'; + $lang['strtrue'] = 'صحيح TRUE'; + $lang['strfalse'] = 'خاطئ FALSE'; + $lang['stredit'] = 'تحرير'; + $lang['strcolumns'] = 'أعمدة Columns'; + $lang['strrows'] = 'سجل/سجلات'; + $lang['strrowsaff'] = 'سجل تأثر/سجلات تأثرت'; + $lang['strobjects'] = 'object(s)'; + $lang['strexample'] = 'مثلا'; + $lang['strback'] = 'رجوع للخلÙ'; + $lang['strqueryresults'] = 'نتائج الإستعلام'; + $lang['strshow'] = 'اعرض'; + $lang['strempty'] = 'Ø¥Ùراغ Empty'; + $lang['strlanguage'] = 'اللغة'; + $lang['strencoding'] = 'الشيÙرة Encoding'; + $lang['strvalue'] = 'القيمة Value'; + $lang['strunique'] = 'Ùريد Unique'; + $lang['strprimary'] = 'رئيسي Primary'; + $lang['strexport'] = 'تصدير Export'; + $lang['strimport'] = 'إستيراد Import'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = 'Go'; + $lang['stradmin'] = 'إدارة Admin'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analyze'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'Clustered?'; + $lang['strreindex'] = 'Reindex'; + $lang['strrun'] = 'Run'; + $lang['stradd'] = 'إضاÙØ©'; + $lang['strevent'] = 'Event'; + $lang['strwhere'] = 'Where'; + $lang['strinstead'] = 'Do Instead'; + $lang['strwhen'] = 'When'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'تأكيد'; + $lang['strexpression'] = 'تعبير'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Ø¥Ùتح'; + $lang['strcollapse'] = 'سكّر'; + $lang['strexplain'] = 'Explain'; + $lang['strexplainanalyze'] = 'Explain Analyze'; + $lang['strfind'] = 'بحث'; + $lang['stroptions'] = 'خيارات'; + $lang['strrefresh'] = 'تحديث Refresh'; + $lang['strdownload'] = 'تنزيل'; + $lang['strdownloadgzipped'] = 'تنزيل على شكل مل٠مضغوط بـ gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Advanced'; + $lang['strvariables'] = 'Variables'; + $lang['strprocess'] = 'العملية Process'; + $lang['strprocesses'] = 'العمليات Processes'; + $lang['strsetting'] = 'Setting'; + $lang['streditsql'] = 'Edit SQL'; + $lang['strruntime'] = 'Total runtime: %s ms'; + $lang['strpaginate'] = 'Paginate results'; + $lang['struploadscript'] = 'or upload an SQL script:'; + $lang['strstarttime'] = 'Start Time'; + $lang['strfile'] = 'ملÙ'; + $lang['strfileimported'] = 'تم استيراد الملÙ.'; + + // Error handling + $lang['strbadconfig'] = 'إن المل٠config.inc.php الذي لديك اصبح قديما. ستحتاج الى إعادة توليده من المل٠الجديد config.inc.php-dist.'; + $lang['strnotloaded'] = 'إن اعداد PHP الموجود على هذا الخادم لاتدعم PostgreSQL. تحتاج الى اعادة تثبيت PHP بإستخدام الخيار --with-pgsql configure option.'; + $lang['strpostgresqlversionnotsupported'] = 'هذا الاصدار من PostgreSQL غير مدعوم. الرجاء الترقية الى الإصدار %s او أعلى.'; + $lang['strbadschema'] = 'Invalid schema specified.'; + $lang['strbadencoding'] = 'لقد Ùشل ضبط شيÙرة العميل client encoding ÙÙŠ قاعدة البيانات.'; + $lang['strsqlerror'] = 'خطأ SQL:'; + $lang['strinstatement'] = 'ÙÙŠ الجملة statement:'; + $lang['strinvalidparam'] = 'Invalid script parameters.'; + $lang['strnodata'] = 'لم توجد سجلات.'; + $lang['strnoobjects'] = 'لم توجد كائنات.'; + $lang['strrownotunique'] = 'لا يوجد معرّ٠Ùريد unique identifier ÙÙŠ هذا السجل.'; + $lang['strnouploads'] = 'تحميل الملÙات غير Ù…Ùعّل.'; + $lang['strimporterror'] = 'خطأ ÙÙŠ الإستيراد.'; + $lang['strimporterrorline'] = 'خطأ ÙÙŠ الإستيراد عند السطر: %s.'; + + // Tables + $lang['strtable'] = 'جدول Table'; + $lang['strtables'] = 'جداول Tables'; + $lang['strshowalltables'] = 'أعرض جميع الجداول Tables.'; + $lang['strnotables'] = 'لا يوجد جداول.'; + $lang['strnotable'] = 'لا يوجد جدول.'; + $lang['strcreatetable'] = 'إنشاء جدول Table جديد.'; + $lang['strtablename'] = 'إسم الجدول'; + $lang['strtableneedsname'] = 'يجب إعطاء إسم للجدول.'; + $lang['strtableneedsfield'] = 'يجب عليك تحديد على الأقل حقل واحد.'; + $lang['strtableneedscols'] = 'الجداول تتطلب عدد مقبول من الأعمدة.'; + $lang['strtablecreated'] = 'لقد تم إنشاء الجدول بنجاح.'; + $lang['strtablecreatedbad'] = 'لقد Ùشلت عملية إنشاء الجدول.'; + $lang['strconfdroptable'] = 'هل انت متأكد تريد حذ٠الجدول بإسم "%s"ØŸ'; + $lang['strtabledropped'] = 'لقد تم حذ٠الجدول.'; + $lang['strtabledroppedbad'] = 'لقد Ùشلت عملية حذ٠الجدول.'; + $lang['strconfemptytable'] = 'هل انت متأكد تريد اÙراغ محتويات الجدول "%s"ØŸ'; + $lang['strtableemptied'] = 'لقد تم اÙراغ محتويات الجدول بنجاح.'; + $lang['strtableemptiedbad'] = 'لقد Ùشلت عملية Ø¥Ùراغ محتويات الجدول.'; + $lang['strinsertrow'] = 'إدراج سجل.'; + $lang['strrowinserted'] = 'لقد تم إدراج السجل بنجاح.'; + $lang['strrowinsertedbad'] = 'لقد Ùشلت عملية إدراج السجل.'; + $lang['streditrow'] = 'تحرير السجل.'; + $lang['strrowupdated'] = 'تم تعديل السجل بنجاح.'; + $lang['strrowupdatedbad'] = 'لقد Ùشلت عملية تعديل السجل.'; + $lang['strdeleterow'] = 'إحذ٠السجل.'; + $lang['strconfdeleterow'] = 'هل انت متأكد تريد حذ٠هذا السجل؟'; + $lang['strrowdeleted'] = 'لقد تم حذ٠السجل بنجاح.'; + $lang['strrowdeletedbad'] = 'لقد Ùشلت عملية حذ٠السجل.'; + $lang['strinsertandrepeat'] = 'إدراج Ùˆ إعادة'; + $lang['strfield'] = 'الحقل'; + $lang['strnumfields'] = 'عدد الحقول'; + $lang['strselectallfields'] = 'إختيار جميع الحقول'; + $lang['strselectneedscol'] = 'تحتاج عرض على الأقل عمود واحد.'; + $lang['strselectunary'] = 'العمليات الأحادية Unary operators لا يمكن ان يكون لها قيم.'; + $lang['straltercolumn'] = 'تعديل العمود'; + $lang['strcolumnaltered'] = 'لقد تم تعديل العمود بنجاح.'; + $lang['strcolumnalteredbad'] = 'لقد Ùشلت عملية تعديل العمود.'; + $lang['strconfdropcolumn'] = 'هل انت متأكد تريد حذ٠العمود "%s" من الجدول "%s"ØŸ'; + $lang['strcolumndropped'] = 'لقد تم حذ٠العمود بنجاح.'; + $lang['strcolumndroppedbad'] = 'لقد Ùشلت عملية حذ٠العمود.'; + $lang['straddcolumn'] = 'إضاÙØ© عمود.'; + $lang['strcolumnadded'] = 'لقد تمت إضاÙØ© العمود بنجاح.'; + $lang['strcolumnaddedbad'] = 'لقد Ùشلت عملية إضاÙØ© العمود.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'لقد تم تعديل الجدول بنجاح.'; + $lang['strtablealteredbad'] = 'لقد Ùشلت عملية تعديل الجدول.'; + $lang['strdataonly'] = 'البيانات Ùقط'; + $lang['strstructureonly'] = 'الهيكلية Ùقط'; + $lang['strstructureanddata'] = 'الهيكلية والبيانات'; + $lang['strtabbed'] = 'Tabbed'; + $lang['strauto'] = 'Auto'; + + // Users + $lang['struser'] = 'المستخدم'; + $lang['strusers'] = 'المستخدمين'; + $lang['strusername'] = 'إسم المستخدم'; + $lang['strpassword'] = 'كلمة السر'; + $lang['strsuper'] = 'مستخدم ذو صلاحيّات عليا؟'; + $lang['strcreatedb'] = 'إنشاء قاعدة بيانات؟'; + $lang['strexpires'] = 'ينتهي'; + $lang['strsessiondefaults'] = 'Session defaults'; + $lang['strnousers'] = 'لم يوجد مستخدمين.'; + $lang['struserupdated'] = 'تم تعديل المستخدم بنجاح.'; + $lang['struserupdatedbad'] = 'Ùشل تعديل المستخدم.'; + $lang['strshowallusers'] = 'عرض جميع المستخدمين'; + $lang['strcreateuser'] = 'إضاÙØ© مستخدم جديد'; + $lang['struserneedsname'] = 'يجب إعطاء إسم للمستخدم.'; + $lang['strusercreated'] = 'تمت عملية إضاÙØ© المستخدم بنجاح.'; + $lang['strusercreatedbad'] = 'Ùشلت عملية إضاÙØ© المستخدم.'; + $lang['strconfdropuser'] = 'هل انت متأكد تريد حذ٠المستخدم "%s"ØŸ'; + $lang['struserdropped'] = 'تم حذ٠المستخدم بنجاح.'; + $lang['struserdroppedbad'] = 'Ùشلت عملية حذ٠المستخدم.'; + $lang['straccount'] = 'Account'; + $lang['strchangepassword'] = 'تغيير كلمة السر'; + $lang['strpasswordchanged'] = 'تم تغيير كلمة السر بنجاح.'; + $lang['strpasswordchangedbad'] = 'لم ينجح تغيير كلمة السر.'; + $lang['strpasswordshort'] = 'كلمة السر أقصر من الحد الأدنى.'; + $lang['strpasswordconfirm'] = 'كلمة السر المدخلة لم تتطابق مع تأكيد كلمة السر.'; + + // Groups + $lang['strgroup'] = 'المجموعة'; + $lang['strgroups'] = 'المجموعات'; + $lang['strnogroup'] = 'لم توجد المجموعة.'; + $lang['strnogroups'] = 'لم توجد مجموعات.'; + $lang['strcreategroup'] = 'إضاÙØ© مجموعة جديدة'; + $lang['strshowallgroups'] = 'عرض جميع المجموعات'; + $lang['strgroupneedsname'] = 'يجب إعطاء إسم للمجموعة.'; + $lang['strgroupcreated'] = 'لقد تمت إضاÙØ© المجموعة بنجاح.'; + $lang['strgroupcreatedbad'] = 'لقد Ùشلت عملية إضاÙØ© المجموعة.'; + $lang['strconfdropgroup'] = 'هل انت متأكد تريد حذ٠المجموعة "%s"ØŸ'; + $lang['strgroupdropped'] = 'تم حذ٠المجموعة بنجاح.'; + $lang['strgroupdroppedbad'] = 'لقد Ùشلت عملية حذ٠المجموعة.'; + $lang['strmembers'] = 'الأعضاء'; + $lang['straddmember'] = 'إضاÙØ© عضو'; + $lang['strmemberadded'] = 'تمت إضاÙØ© العضو.'; + $lang['strmemberaddedbad'] = 'لقد Ùشلت عملية إضاÙØ© العضو.'; + $lang['strdropmember'] = 'حذ٠عضو'; + $lang['strconfdropmember'] = 'هل أنت متأكد تريد حذ٠العضو "%s" من المجموعة "%s"ØŸ'; + $lang['strmemberdropped'] = 'تم حذ٠العضو.'; + $lang['strmemberdroppedbad'] = 'لقد Ùشل حذ٠العضو.'; + + // Privileges + $lang['strprivilege'] = 'الصلاحيّة'; + $lang['strprivileges'] = 'الصلاحيات'; + $lang['strnoprivileges'] = 'هذا الكائن لديه صلاحيّات المالك الإÙتراضية.'; + $lang['strgrant'] = 'تصريح Grant'; + $lang['strrevoke'] = 'سحب Revoke'; + $lang['strgranted'] = 'تم تغيير الصلاحيات.'; + $lang['strgrantfailed'] = 'لقد Ùشل تغيير الصلاحيات.'; + $lang['strgrantbad'] = 'يجب عليك تحديد على الاقل مستخدم واحد او مجموعة واحدة Ùˆ على الأقل صلاحيّة واحدة.'; + $lang['strgrantor'] = 'المصرّح Grantor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'قاعدة بيانات'; + $lang['strdatabases'] = 'قواعد البيانات'; + $lang['strshowalldatabases'] = 'عرض جميع قواعد البيانات'; + $lang['strnodatabase'] = 'لم يوجد قاعدة بيانات.'; + $lang['strnodatabases'] = 'لم يوجد قواعد بيانات.'; + $lang['strcreatedatabase'] = 'إنشاء قاعدة بيانات جديدة'; + $lang['strdatabasename'] = 'إسم قاعدة البيانات'; + $lang['strdatabaseneedsname'] = 'يجب عليك إعطاء إسم لقاعدة البيانات.'; + $lang['strdatabasecreated'] = 'تم إنشاء قاعدة البيانات بنجاح.'; + $lang['strdatabasecreatedbad'] = 'Ùشل إنشاء قاعدة البيانات.'; + $lang['strconfdropdatabase'] = 'هل أنت متأكد تريد حذ٠قاعدة البيانات بإسم "%s"?'; + $lang['strdatabasedropped'] = 'تم حذ٠قاعدة البيانات.'; + $lang['strdatabasedroppedbad'] = 'لقد Ùشلت عملية حذ٠قاعدة البيانات.'; + $lang['strentersql'] = 'أدخل الـSQL الذي تريد إستدعاءه هنا:'; + $lang['strsqlexecuted'] = 'تم إستدعاء الـSQL.'; + $lang['strvacuumgood'] = 'تمت عملية الـVacuum.'; + $lang['strvacuumbad'] = 'لقد Ùشلت عملية الـVacuum.'; + $lang['stranalyzegood'] = 'تمت عملية الÙحص.'; + $lang['stranalyzebad'] = 'لقد Ùشلت عملية الÙحص.'; + $lang['strreindexgood'] = 'تمت عملية إعادة الÙهرسة بنجاح.'; + $lang['strreindexbad'] = 'لقد Ùشلت عملية إعادة الÙهرسة.'; + $lang['strfull'] = 'Full'; + $lang['strfreeze'] = 'Freeze'; + $lang['strforce'] = 'Force'; + + // Views + $lang['strview'] = 'View عرض'; + $lang['strviews'] = 'عروض Views'; + $lang['strshowallviews'] = 'أعرض جميع العروض Views.'; + $lang['strnoview'] = 'لم يوجد عرض View.'; + $lang['strnoviews'] = 'لم يوجد عروض Views.'; + $lang['strcreateview'] = 'إنشاء عرض View جديد'; + $lang['strviewname'] = 'إسم العرض View'; + $lang['strviewneedsname'] = 'يجب إعطاء إسم للعرض View.'; + $lang['strviewneedsdef'] = 'يجب عليك إعطاء تعري٠للعرض View.'; + $lang['strviewneedsfields'] = 'يجب عليك تحديد الحقول التي تريدها ÙÙŠ العرض View.'; + $lang['strviewcreated'] = 'تم إنشاء العرض View.'; + $lang['strviewcreatedbad'] = 'Ùشلت عملية إنشاء العرض View.'; + $lang['strconfdropview'] = 'هل انت متأكد تريد حذ٠العرض View بإسم "%s"'; + $lang['strviewdropped'] = 'تم حذ٠العرض View.'; + $lang['strviewdroppedbad'] = 'لقد Ùشلت عملية حذ٠العرض View.'; + $lang['strviewupdated'] = 'تم تحديث العرض View بنجاح.'; + $lang['strviewupdatedbad'] = 'لقد Ùشلت عملية تحديث العرض View.'; + $lang['strviewlink'] = 'Linking Keys'; + $lang['strviewconditions'] = 'Additional Conditions'; + $lang['strcreateviewwiz'] = 'إنشاء عرض View بإستخدام الساحر Wizard.'; + + // Sequences + $lang['strsequence'] = 'تسلسل Sequence'; + $lang['strsequences'] = 'تسلسلات Sequences'; + $lang['strshowallsequences'] = 'عرض جميع التسلسلات'; + $lang['strnosequence'] = 'لم يوجد تسلسل.'; + $lang['strnosequences'] = 'لم يوجد تسلسلات.'; + $lang['strcreatesequence'] = 'إنشاء تسلسل جديد'; + $lang['strlastvalue'] = 'آخر قيمة'; + $lang['strincrementby'] = 'مقدار الزيادة Increment by'; + $lang['strstartvalue'] = 'قيمة البداية'; + $lang['strmaxvalue'] = 'القيمة القصوى'; + $lang['strminvalue'] = 'القيمة الدنيا'; + $lang['strcachevalue'] = 'Cache value'; + $lang['strlogcount'] = 'Log count'; + $lang['striscycled'] = 'Is cycled?'; + $lang['strsequenceneedsname'] = 'يجب إعطاء إسم للتسلسل sequence.'; + $lang['strsequencecreated'] = 'تم إنشاء التسلسل بنجاح.'; + $lang['strsequencecreatedbad'] = 'لقد Ùشل إنشاء التسلسل.'; + $lang['strconfdropsequence'] = 'هل أنت متأكد تريد حذ٠التسلسل بإسم "%s"ØŸ'; + $lang['strsequencedropped'] = 'لقد تم حذ٠التسلسل بنجاح.'; + $lang['strsequencedroppedbad'] = 'لقد Ùشلت عملية حذ٠التسلسل.'; + $lang['strsequencereset'] = 'لقد تمت إعادة التسلسل بنجاح.'; + $lang['strsequenceresetbad'] = 'لقد Ùشلت إعادة التسلسل.'; + + // Indexes + $lang['strindex'] = 'ÙهرسIndex'; + $lang['strindexes'] = 'ÙهارسIndexes'; + $lang['strindexname'] = 'إسم الÙهرس Index'; + $lang['strshowallindexes'] = 'عرض جميع الÙهارس indexes'; + $lang['strnoindex'] = 'لم يوجد Ùهرس index.'; + $lang['strnoindexes'] = 'لم توجد Ùهارس indexes.'; + $lang['strcreateindex'] = 'إنشاء Ùهرس index جديد'; + $lang['strtabname'] = 'Tab name'; + $lang['strcolumnname'] = 'إسم العمود'; + $lang['strindexneedsname'] = 'يجب عليك إعطاء إسم للÙهرس index.'; + $lang['strindexneedscols'] = 'الÙهارس تتطلب عدد مقبول من الأعمدة.'; + $lang['strindexcreated'] = 'لقد تم إنشاء الÙهرس بنجاح.'; + $lang['strindexcreatedbad'] = 'Ùشل إنشاء الÙهرس.'; + $lang['strconfdropindex'] = 'هل انت متأكد تريد حذ٠الÙهرس بإسم "%s"ØŸ'; + $lang['strindexdropped'] = 'لقد تم حذ٠الÙهرس بنجاح.'; + $lang['strindexdroppedbad'] = 'Ùشلت عملية حذ٠الÙهرس.'; + $lang['strkeyname'] = 'إسم المÙتاح Key'; + $lang['struniquekey'] = 'Ù…Ùتاح Ùريد Unique key'; + $lang['strprimarykey'] = 'Ù…Ùتاح رئيسي Primary key'; + $lang['strindextype'] = 'نوع الÙهرس'; + $lang['strtablecolumnlist'] = 'الأعمدة ÙÙŠ الجدول'; + $lang['strindexcolumnlist'] = 'الأعمدة ÙÙŠ الÙهرس'; + $lang['strconfcluster'] = 'Are you sure you want to cluster "%s"?'; + $lang['strclusteredgood'] = 'Cluster complete.'; + $lang['strclusteredbad'] = 'Cluster failed.'; + + // Rules + $lang['strrules'] = 'قواعد Rules'; + $lang['strrule'] = 'قاعدة Rule'; + $lang['strshowallrules'] = 'عرض جميع القواعد'; + $lang['strnorule'] = 'لم توجد قاعدة.'; + $lang['strnorules'] = 'لم توجد قواعد.'; + $lang['strcreaterule'] = 'إنشاء قاعدة rule جديدة'; + $lang['strrulename'] = 'إسم القاعدة rule name'; + $lang['strruleneedsname'] = 'يجب عليك إعطاء إسم للقاعدة rule.'; + $lang['strrulecreated'] = 'تم إنشاء القاعدة بنجاح.'; + $lang['strrulecreatedbad'] = 'Ùشل إنشاء القاعدة.'; + $lang['strconfdroprule'] = 'هل أنت متأكد تريد حذ٠القاعدة "%s" على "%s"ØŸ'; + $lang['strruledropped'] = 'تم حذ٠القاعدة.'; + $lang['strruledroppedbad'] = 'Ùشل حذ٠القاعدة.'; + + // Constraints + $lang['strconstraints'] = 'قيود Constraints'; + $lang['strshowallconstraints'] = 'عرض جميع القيود constraints'; + $lang['strnoconstraints'] = 'لم يوجد قيود constraints.'; + $lang['strcreateconstraint'] = 'إنشاء قيد constraint جديد'; + $lang['strconstraintcreated'] = 'تم إنشاء القيد بنجاح.'; + $lang['strconstraintcreatedbad'] = 'Ùشل إنشاء القيد.'; + $lang['strconfdropconstraint'] = 'هل أنت متأكد تريد حذ٠القيد "%s" على "%s"ØŸ'; + $lang['strconstraintdropped'] = 'تم حذ٠القيد بنجاح.'; + $lang['strconstraintdroppedbad'] = 'Ùشل حذ٠القيد.'; + $lang['straddcheck'] = 'إضاÙØ© Ùحص check'; + $lang['strcheckneedsdefinition'] = 'قيد الÙحص يحتاج لتعريÙ.'; + $lang['strcheckadded'] = 'تم إضاÙØ© قيد الÙحص بنحاح.'; + $lang['strcheckaddedbad'] = 'Ùشلت إضاÙØ© قيد الÙحص.'; + $lang['straddpk'] = 'primary key إضاÙØ© Ù…Ùتاح رئيسي.'; + $lang['strpkneedscols'] = 'المÙتاح الرئيسي يتطلب على الأقل عمود واحد.'; + $lang['strpkadded'] = 'تمت إضاÙØ© المÙتاح الرئيسي بنجاح.'; + $lang['strpkaddedbad'] = 'Ùشلت إضاÙØ© المÙتاح الرئيسي.'; + $lang['stradduniq'] = 'unique key إضاÙØ© Ù…Ùتاح Ùريد'; + $lang['struniqneedscols'] = 'المÙتاح الÙريد يتطلب عمود واحد على الأقل.'; + $lang['struniqadded'] = 'تمت إضاÙØ© المÙتاح الÙريد بنجاح.'; + $lang['struniqaddedbad'] = 'Ùشلت إضاÙØ© المÙتاح الÙريد.'; + $lang['straddfk'] = 'إضاÙØ© Ù…Ùتاح خارجيforeign key'; + $lang['strfkneedscols'] = 'المÙتاح الخارجي يتطلب عمود واحد على الأقل.'; + $lang['strfkneedstarget'] = 'المÙتاح الخارجي يحتاج الى جدول هدÙ.'; + $lang['strfkadded'] = 'تمت إضاÙØ© المÙتاح الخارجي بنجاح.'; + $lang['strfkaddedbad'] = 'Ùشلت إضاÙØ© المÙتاح الخارجي.'; + $lang['strfktarget'] = 'الجدول الهد٠Target table'; + $lang['strfkcolumnlist'] = 'الأعمدة ÙÙŠ المÙتاح'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'دالة Function'; + $lang['strfunctions'] = 'دوال Functions'; + $lang['strshowallfunctions'] = 'عرض جميع الدوال functions'; + $lang['strnofunction'] = 'لم توجد دالة function.'; + $lang['strnofunctions'] = 'لم توجد دوال functions.'; + $lang['strfunctionname'] = 'إسم الدالة function name'; + $lang['strreturns'] = 'Returns'; + $lang['strarguments'] = 'Arguments'; + $lang['strproglanguage'] = 'لغة برمجة'; + $lang['strfunctionneedsname'] = 'يجب عليك إعطاء إسم للدالة function.'; + $lang['strfunctionneedsdef'] = 'يجب عليك اعطاء تعري٠للدالة function definition.'; + $lang['strfunctioncreated'] = 'تم إنشاء الدالة function بنجاح.'; + $lang['strfunctioncreatedbad'] = 'لقد Ùشل إنشاء الدالة.'; + $lang['strconfdropfunction'] = 'هل أنت متأكد تريد حذ٠الدالة function بإسم "%s"?'; + $lang['strfunctiondropped'] = 'تم حذ٠الدالة function بنجاح.'; + $lang['strfunctiondroppedbad'] = 'لقد Ùشلت عملية حذ٠الدالة function.'; + $lang['strfunctionupdated'] = 'لقد تم تعديل الدالة function.'; + $lang['strfunctionupdatedbad'] = 'لقد Ùشل تعديل الدالة function.'; + + // Triggers + $lang['strtrigger'] = 'محÙّز Trigger'; + $lang['strtriggers'] = 'محÙّزات Triggers'; + $lang['strshowalltriggers'] = 'عرض جميع المحÙزات triggers'; + $lang['strnotrigger'] = 'لم يوجد المحÙز trigger.'; + $lang['strnotriggers'] = 'لم يوجد محÙزات triggers.'; + $lang['strcreatetrigger'] = 'إنشاء محÙّز trigger جديد'; + $lang['strtriggerneedsname'] = 'يجب إعطاء اسم للمحÙز.'; + $lang['strtriggerneedsfunc'] = 'يجب تحديد دالة function للمحÙز.'; + $lang['strtriggercreated'] = 'تم إنشاء المحÙز بنجاح.'; + $lang['strtriggercreatedbad'] = 'لقد Ùشلت عملية إنشاء المحÙز.'; + $lang['strconfdroptrigger'] = 'هل أنت متأكد تريد حذ٠المحÙّز trigger "%s" على "%s"ØŸ'; + $lang['strtriggerdropped'] = 'تم حذ٠المحÙز.'; + $lang['strtriggerdroppedbad'] = 'Ùشل حذ٠المحÙز، لم يتم الحذÙ.'; + $lang['strtriggeraltered'] = 'تم تعديل المحÙز بنجاح.'; + $lang['strtriggeralteredbad'] = 'Ùشلت عملية تعديل المحÙز. لم يتم التعديل.'; + + // Types + $lang['strtype'] = 'نوع Type'; + $lang['strtypes'] = 'أنواع Types'; + $lang['strshowalltypes'] = 'عرض جميع الأنواع'; + $lang['strnotype'] = 'لم يوجد النوع.'; + $lang['strnotypes'] = 'لم يوجد أنواع.'; + $lang['strcreatetype'] = 'إنشاء نوع جديد.'; + $lang['strtypename'] = 'إسم النوع'; + $lang['strinputfn'] = 'دالة الإدخال Input function'; + $lang['stroutputfn'] = 'دالة الإخراج Output function'; + $lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'Alignment'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Delimiter'; + $lang['strstorage'] = 'Storage'; + $lang['strtypeneedsname'] = 'يجب إعطاء إسم للنوع.'; + $lang['strtypeneedslen'] = 'يجب إعطاء طول للنوع.'; + $lang['strtypecreated'] = 'تم إنشاء النوع'; + $lang['strtypecreatedbad'] = 'Ùشل إنشاء النوع.'; + $lang['strconfdroptype'] = 'هل أنت متأكد تريد حذ٠النوع "%s"ØŸ'; + $lang['strtypedropped'] = 'تم حذ٠النوع.'; + $lang['strtypedroppedbad'] = 'Ùشلت عملية حذ٠النوع.'; + + // Schemas + $lang['strschema'] = 'مخطط Schema'; + $lang['strschemas'] = 'المخططات Schemas'; + $lang['strshowallschemas'] = 'عرض جميع المخططات schemas'; + $lang['strnoschema'] = 'لم يوجد مخطط schema.'; + $lang['strnoschemas'] = 'لم توجد مخططات schemas.'; + $lang['strcreateschema'] = 'إنشاء مخطط schema جديد'; + $lang['strschemaname'] = 'إسم المخطط'; + $lang['strschemaneedsname'] = 'يجب عليك إعطاء إسم للمخطط.'; + $lang['strschemacreated'] = 'لقد تم انشاء المخطط بنجاح.'; + $lang['strschemacreatedbad'] = 'Ùشل إنشاء المخطط.'; + $lang['strconfdropschema'] = 'هل أنت متأكد تريد حذ٠المخطط Schema بإسم "%s"ØŸ'; + $lang['strschemadropped'] = 'تم حذ٠المخطط.'; + $lang['strschemadroppedbad'] = 'Ùشلت عملية الحذ٠للمخطط.'; + $lang['strschemaaltered'] = 'تم تعديل المخطط.'; + $lang['strschemaalteredbad'] = 'Ùشلت عملية تعديل المخطط، لم يتم التعديل.'; + + // Reports + + // Domains + $lang['strdomain'] = 'نطاق Domain'; + $lang['strdomains'] = 'نطاقات Domains'; + $lang['strshowalldomains'] = 'عرض جيع النطاقات'; + $lang['strnodomains'] = 'لم يوجد نطاقات.'; + $lang['strcreatedomain'] = 'إنشاء نطاق جديد'; + $lang['strdomaindropped'] = 'تم حذ٠النطاق.'; + $lang['strdomaindroppedbad'] = 'لقد Ùشل حذ٠النطاق، لم يتم الحذÙ.'; + $lang['strconfdropdomain'] = 'هل أنت متأكد تريد حذ٠النطاق domain بإسم "%s"ØŸ'; + $lang['strdomainneedsname'] = 'يجب إعطاء إسم للنطاق.'; + $lang['strdomaincreated'] = 'تم إنشاء النطاق بنجاح.'; + $lang['strdomaincreatedbad'] = 'لم يتم إنشاء النطاق، Ùشلت العملية.'; + $lang['strdomainaltered'] = 'تم تعديل النطاق.'; + $lang['strdomainalteredbad'] = 'Ùشلت عملية تعديل النطاق.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operators'; + $lang['strshowalloperators'] = 'Show all operators'; + $lang['strnooperator'] = 'No operator found.'; + $lang['strnooperators'] = 'No operators found.'; + $lang['strcreateoperator'] = 'Create operator'; + $lang['strleftarg'] = 'Left Arg Type'; + $lang['strrightarg'] = 'Right Arg Type'; + $lang['strcommutator'] = 'Commutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Left sort'; + $lang['strrightsort'] = 'Right sort'; + $lang['strlessthan'] = 'Less than'; + $lang['strgreaterthan'] = 'Greater than'; + $lang['stroperatorneedsname'] = 'You must give a name for your operator.'; + $lang['stroperatorcreated'] = 'Operator created'; + $lang['stroperatorcreatedbad'] = 'Operator creation failed.'; + $lang['strconfdropoperator'] = 'Are you sure you want to drop the operator "%s"?'; + $lang['stroperatordropped'] = 'Operator dropped.'; + $lang['stroperatordroppedbad'] = 'Operator drop failed.'; + + // Casts + $lang['strcasts'] = 'Casts'; + $lang['strnocasts'] = 'No casts found.'; + $lang['strsourcetype'] = 'Source type'; + $lang['strtargettype'] = 'Target type'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'In assignment'; + $lang['strbinarycompat'] = '(Binary compatible)'; + + // Conversions + $lang['strconversions'] = 'Conversions'; + $lang['strnoconversions'] = 'No conversions found.'; + $lang['strsourceencoding'] = 'Source encoding'; + $lang['strtargetencoding'] = 'Target encoding'; + + // Languages + $lang['strlanguages'] = 'Languages'; + $lang['strnolanguages'] = 'No languages found.'; + $lang['strtrusted'] = 'Trusted'; + + // Info + $lang['strnoinfo'] = 'No information available.'; + $lang['strreferringtables'] = 'Referring tables'; + $lang['strparenttables'] = 'Parent tables'; + $lang['strchildtables'] = 'Child tables'; + + // Aggregates + $lang['straggregates'] = 'Aggregates'; + $lang['strnoaggregates'] = 'No aggregates found.'; + $lang['stralltypes'] = '(All types)'; + + // Operator Classes + $lang['stropclasses'] = 'Op Classes'; + $lang['strnoopclasses'] = 'No operator classes found.'; + $lang['straccessmethod'] = 'Access method'; + + // Stats and performance + $lang['strrowperf'] = 'Row Performance'; + $lang['strioperf'] = 'I/O Performance'; + $lang['stridxrowperf'] = 'Index Row Performance'; + $lang['stridxioperf'] = 'Index I/O Performance'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequential'; + $lang['strscan'] = 'Scan'; + $lang['strread'] = 'Read'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Rows'; + + // Miscellaneous + $lang['strtopbar'] = '%s يعمل على %s:%s -- You are logged in as user "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'مساعدة'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/catalan.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/catalan.php new file mode 100644 index 00000000..02fed655 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/catalan.php @@ -0,0 +1,897 @@ + + * + * $Id: catalan.php,v 1.4 2008/03/14 03:31:43 xzilla Exp $ + */ + + // Language and character set + $lang['applang'] = 'Català'; + $lang['applocale'] = 'ca-ES'; + $lang['applangdir'] = 'ltr'; + + // Welcome + $lang['strintro'] = 'Benvingut a phpPgAdmin.'; + $lang['strppahome'] = 'Pàgina web de phpPgAdmin'; + $lang['strpgsqlhome'] = 'Pàgina web de PostgreSQL'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'Documentació PostgreSQL (local)'; + $lang['strreportbug'] = 'Reportar un Bug'; + $lang['strviewfaq'] = 'Veure FAQ online'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'Entrada'; + $lang['strloginfailed'] = 'Entrada fallida'; + $lang['strlogindisallowed'] = 'Entrada rebutjada per raons de seguretat.'; + $lang['strserver'] = 'Servidor'; + $lang['strservers'] = 'Servidors'; + $lang['strgroupservers'] = 'Servidors en el grup "%s"'; + $lang['strallservers'] = 'Tots els servidors'; + $lang['strintroduction'] = 'Introducció'; + $lang['strhost'] = 'Host'; + $lang['strport'] = 'Port'; + $lang['strlogout'] = 'Sortida'; + $lang['strowner'] = 'Propietari'; + $lang['straction'] = 'Acció'; + $lang['stractions'] = 'Accions'; + $lang['strname'] = 'Nom'; + $lang['strdefinition'] = 'Definició'; + $lang['strproperties'] = 'Propietats'; + $lang['strbrowse'] = 'Navega'; + $lang['strenable'] = 'Habilita'; + $lang['strdisable'] = 'Inhabilita'; + $lang['strdrop'] = 'Elimina'; + $lang['strdropped'] = 'Eliminat'; + $lang['strnull'] = 'Nul'; + $lang['strnotnull'] = 'No Nul'; + $lang['strprev'] = '< Previ'; + $lang['strnext'] = 'Següent >'; + $lang['strfirst'] = '<< Primer'; + $lang['strlast'] = 'Últim >>'; + $lang['strfailed'] = 'Fallat'; + $lang['strcreate'] = 'Crea'; + $lang['strcreated'] = 'Creat'; + $lang['strcomment'] = 'Comentari'; + $lang['strlength'] = 'Longitud'; + $lang['strdefault'] = 'Predeterminat'; + $lang['stralter'] = 'Modifica'; + $lang['strok'] = 'D\'acord'; + $lang['strcancel'] = 'Cancel·la'; + $lang['strkill'] = 'Mata'; + $lang['strac'] = 'Habilita AutoCompletat'; + $lang['strsave'] = 'Desa'; + $lang['strreset'] = 'Restableix'; + $lang['strrestart'] = 'Reinicia'; + $lang['strinsert'] = 'Inserta'; + $lang['strselect'] = 'Selecciona'; + $lang['strdelete'] = 'Elimina'; + $lang['strupdate'] = 'Actualitza'; + $lang['strreferences'] = 'Referències'; + $lang['stryes'] = 'Sí'; + $lang['strno'] = 'No'; + $lang['strtrue'] = 'Cert'; + $lang['strfalse'] = 'Fals'; + $lang['stredit'] = 'Edita'; + $lang['strcolumn'] = 'Columna'; + $lang['strcolumns'] = 'Columnes'; + $lang['strrows'] = 'fila(es)'; + $lang['strrowsaff'] = 'fila/es afectada/es.'; + $lang['strobjects'] = 'objecte(s)'; + $lang['strback'] = 'Enrere'; + $lang['strqueryresults'] = 'Resultat de la Consulta'; + $lang['strshow'] = 'Mostra'; + $lang['strempty'] = 'Buida'; + $lang['strlanguage'] = 'Idioma'; + $lang['strencoding'] = 'Codificació'; + $lang['strvalue'] = 'Valor'; + $lang['strunique'] = 'Únic'; + $lang['strprimary'] = 'Primari'; + $lang['strexport'] = 'Exporta'; + $lang['strimport'] = 'Importa'; + $lang['strallowednulls'] = 'Caràcters NULL Permesos'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Cadena o camp buit'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analyze'; + $lang['strclusterindex'] = 'Clúster'; + $lang['strclustered'] = 'Clusteritzat?'; + $lang['strreindex'] = 'Reindex'; + $lang['strexecute'] = 'Executa'; + $lang['stradd'] = 'Agrega'; + $lang['strevent'] = 'Event'; + $lang['strwhere'] = 'On'; + $lang['strinstead'] = 'Fes en el seu lloc'; + $lang['strwhen'] = 'Quan'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Dades'; + $lang['strconfirm'] = 'Confirma'; + $lang['strexpression'] = 'Expressió'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Expandeix'; + $lang['strcollapse'] = 'Colapsa'; + $lang['strfind'] = 'Cerca'; + $lang['stroptions'] = 'Opcions'; + $lang['strrefresh'] = 'Refresca'; + $lang['strdownload'] = 'Baixa'; + $lang['strdownloadgzipped'] = 'Baixa comprimit amb gzip'; + $lang['strinfo'] = 'Informació'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Avançat'; + $lang['strvariables'] = 'Variables'; + $lang['strprocess'] = 'Procés'; + $lang['strprocesses'] = 'Processos'; + $lang['strsetting'] = 'Ajustament'; + $lang['streditsql'] = 'Edita SQL'; + $lang['strruntime'] = 'Total temps d\'execució: %s ms'; + $lang['strpaginate'] = 'Pagina els resultats'; + $lang['struploadscript'] = 'o carrega un script SQL:'; + $lang['strstarttime'] = 'Hora d\'Inici'; + $lang['strfile'] = 'Fitxer'; + $lang['strfileimported'] = 'Fitxer importat.'; + $lang['strtrycred'] = 'Usa aquestes credencials a tots els servidors'; + $lang['strconfdropcred'] = 'Per raons de seguretat, la desconnexió eliminarà la informació d\'entrada compartida. Està segur de voler desconnectar ?'; + $lang['stractionsonmultiplelines'] = 'Accions a múltiples línies'; + $lang['strselectall'] = 'Seleccina\'ls tots'; + $lang['strunselectall'] = 'No en seleccionis cap'; + $lang['strlocale'] = 'Local'; + $lang['strcollation'] = 'Col·lació'; + $lang['strctype'] = 'Tipus de caràcter'; + $lang['strdefaultvalues'] = 'Valors per defecte'; + $lang['strnewvalues'] = 'Valors nous'; + $lang['strstart'] = 'Comença'; + $lang['strstop'] = 'Para'; + $lang['strgotoppage'] = 'Torna al principi'; + $lang['strtheme'] = 'Tema'; + $lang['strcluster'] = 'Clúster'; + + // Admin + $lang['stradminondatabase'] = 'Les següents tasques administratives s\'apliquen a tota la base de dades %s.'; + $lang['stradminontable'] = 'Les següents tasques administratives s\'apliquen a la taula %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'Història'; + $lang['strnohistory'] = 'No hi ha història.'; + $lang['strclearhistory'] = 'Neteja la història'; + $lang['strdelhistory'] = 'Elimina de la història'; + $lang['strconfdelhistory'] = 'Realment vol eliminar aquesta petició de la història?'; + $lang['strconfclearhistory'] = 'Realment vol elimnar la història?'; + $lang['strnodatabaseselected'] = 'Si us plau, seleccioni una base de dades.'; + + // Database Sizes + $lang['strnoaccess'] = 'Sense Accés'; + $lang['strsize'] = 'Tamany'; + $lang['strbytes'] = 'bytes'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Aquesta aplicació treballa millor en un navegador amb suport per frames, però es pot usar sense seguint el link de sota.'; + $lang['strnoframeslink'] = 'Usa sense frames'; + $lang['strbadconfig'] = 'El seu config.inc.php no està actualitzat. Necessitarà regenerar-lo a partir del nou config.inc.php-dist.'; + $lang['strnotloaded'] = 'La seva instal·lació de PHP no suporta la PostgreSQL. Necessita recompilar el PHP usant la opció de configuració --with-pgsql.'; + $lang['strpostgresqlversionnotsupported'] = 'Versió de PostgreSQL no suportada. Si su plau actualitzi a la versió %s o posterior.'; + $lang['strbadschema'] = 'Esquema especificat invàlid.'; + $lang['strbadencoding'] = 'Error al fixar la codificació del client a la base de dades.'; + $lang['strsqlerror'] = 'Error SQL:'; + $lang['strinstatement'] = 'En la sentència:'; + $lang['strinvalidparam'] = 'Paràmetres del script invàlids.'; + $lang['strnodata'] = 'No s\'han trobat files.'; + $lang['strnoobjects'] = 'No s\'han trobat objectes.'; + $lang['strrownotunique'] = 'No hi ha un identificador únic per aquesta fila.'; + $lang['strnouploads'] = 'La pujada de fitxers està deshabilitada.'; + $lang['strimporterror'] = 'Error d\'importació.'; + $lang['strimporterror-fileformat'] = 'Error d\'importació: Error al determinar automàticament el format del fitxer.'; + $lang['strimporterrorline'] = 'Error d\'importació a la línia %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Error d\'importació a la línia %s: La línia no té el número correcte de columnes.'; + $lang['strimporterror-uploadedfile'] = 'Error d\'importació: El fitxer no s\'ha pogut pujar al servidor'; + $lang['strcannotdumponwindows'] = 'El volcat de dades amb noms complexos de taules i esquemes en Windows no és suportada.'; + $lang['strinvalidserverparam'] = 'Intent de connexió amb un paràmetre del servidor invàlid, possiblement algú està provant d\'entrar al sistema.'; + $lang['strnoserversupplied'] = 'No s\'ha proporcionat cap servidor!'; + $lang['strbadpgdumppath'] = 'Error d\'exportació: Fallada en l\'execució de pg_dump (path definit a conf/config.inc.php : %s ). Sisplau, arregli el path en la configuració.'; + $lang['strbadpgdumpallpath'] = 'Error d\'exportació: Fallada en l\'execució de pg_dumpall (path definit a conf/config.inc.php : %s ). Sisplau, arregli el path en la configuració.'; + $lang['strconnectionfail'] = 'No hi ha connexió amb el servidor.'; + + // Tables + $lang['strtable'] = 'Taula'; + $lang['strtables'] = 'Taules'; + $lang['strshowalltables'] = 'Mostra totes les taules'; + $lang['strnotables'] = 'No s\'han trobat taules.'; + $lang['strnotable'] = 'No s\'ha trobat la taula.'; + $lang['strcreatetable'] = 'Crea una taula'; + $lang['strcreatetablelike'] = 'Crea una taula com a'; + $lang['strcreatetablelikeparent'] = 'Taula origen'; + $lang['strcreatelikewithdefaults'] = 'INCLUDE DEFAULTS'; + $lang['strcreatelikewithconstraints'] = 'INCLUDE CONSTRAINTS'; + $lang['strcreatelikewithindexes'] = 'INCLUDE INDEXES'; + $lang['strtablename'] = 'Nom de la taula'; + $lang['strtableneedsname'] = 'Ha d\'anomenar la taula.'; + $lang['strtablelikeneedslike'] = 'Ha de donar una taula d\'on copiar les propietats.'; + $lang['strtableneedsfield'] = 'Ha d\'especificar almenys un camp.'; + $lang['strtableneedscols'] = 'Ha d\'especificar un número vàlid de columnes.'; + $lang['strtablecreated'] = 'Taula creada.'; + $lang['strtablecreatedbad'] = 'No s\'ha pogut crear la taula.'; + $lang['strconfdroptable'] = 'Està segur de voler eliminar la taula "%s"?'; + $lang['strtabledropped'] = 'Taula eliminada.'; + $lang['strtabledroppedbad'] = 'No s\'ha pogut eliminar la taula.'; + $lang['strconfemptytable'] = 'Està segur que vol buidar la taula "%s"?'; + $lang['strtableemptied'] = 'Taula buidada.'; + $lang['strtableemptiedbad'] = 'No s\'ha pogut buidar la taula.'; + $lang['strinsertrow'] = 'Inserta una fila'; + $lang['strrowinserted'] = 'Fila insertada.'; + $lang['strrowinsertedbad'] = 'No s\'ha pogut insertar la taula.'; + $lang['strnofkref'] = 'No hi ha cap valor coincident en la foreign key %s.'; + $lang['strrowduplicate'] = 'Inserció de la taula fallada, intentant fer una inserció duplicada.'; + $lang['streditrow'] = 'Edita la fila'; + $lang['strrowupdated'] = 'Fila actualitzada.'; + $lang['strrowupdatedbad'] = 'No s\'ha pogut actualitzar la fila.'; + $lang['strdeleterow'] = 'Elimina la fila'; + $lang['strconfdeleterow'] = 'Està segur que vol eliminar aquesta fila?'; + $lang['strrowdeleted'] = 'Fila eliminada.'; + $lang['strrowdeletedbad'] = 'No s\'ha pogut eliminar la fila.'; + $lang['strinsertandrepeat'] = 'Inserta & Repeteix'; + $lang['strnumcols'] = 'Nombre de columnes'; + $lang['strcolneedsname'] = 'Ha d\'especificar un nom per la columna'; + $lang['strselectallfields'] = 'Selecciona tots els camps'; + $lang['strselectneedscol'] = 'Ha de mostrar almenys una columna.'; + $lang['strselectunary'] = 'Els operadors unaris no poden tenir valors.'; + $lang['strcolumnaltered'] = 'Columna modificada.'; + $lang['strcolumnalteredbad'] = 'No s\'ha pogut modificar la columna.'; + $lang['strconfdropcolumn'] = 'Està segur d\'eliminar la columna "%s" de la taula "%s"?'; + $lang['strcolumndropped'] = 'Columna eliminada.'; + $lang['strcolumndroppedbad'] = 'No s\'ha pogut eliminar la columna.'; + $lang['straddcolumn'] = 'Agrega una columna'; + $lang['strcolumnadded'] = 'Columna agregada.'; + $lang['strcolumnaddedbad'] = 'No s\'ha pogut agregar la columna.'; + $lang['strcascade'] = 'EN CASCADA'; + $lang['strtablealtered'] = 'Taula modificada.'; + $lang['strtablealteredbad'] = 'No s\'ha pogut modificar la columna.'; + $lang['strdataonly'] = 'Només dades'; + $lang['strstructureonly'] = 'Nomes estructura'; + $lang['strstructureanddata'] = 'Estructura i dades'; + $lang['strtabbed'] = 'Tabulat'; + $lang['strauto'] = 'Automàtic'; + $lang['strconfvacuumtable'] = 'Està segur de voler un vacuum "%s"?'; + $lang['strconfanalyzetable'] = 'Està segur de voler un analyze "%s"?'; + $lang['strconfreindextable'] = 'Està segur de voler un reindex "%s"?'; + $lang['strconfclustertable'] = 'Està sergur de voler un cluster "%s"?'; + $lang['strestimatedrowcount'] = 'Nombre estimat de files'; + $lang['strspecifytabletoanalyze'] = 'Ha d\'especificar almenys una taula per l\'analyze.'; + $lang['strspecifytabletoempty'] = 'Ha d\'especificar almenys una taula per buidar.'; + $lang['strspecifytabletodrop'] = 'Ha d\'especificar almenys una taula per eliminar.'; + $lang['strspecifytabletovacuum'] = 'Ha d\'especificar almenys una taula pel vacuum.'; + $lang['strspecifytabletoreindex'] = 'Ha d\'especifiar almenys una taula pel reindex.'; + $lang['strspecifytabletocluster'] = 'Ha d\'especificar almenys una taula pel cluster.'; + $lang['strnofieldsforinsert'] = 'No es pot insertar una fila a una taula sense cap columna.'; + + // Columns + $lang['strcolprop'] = 'Propietats de la Columna'; + $lang['strnotableprovided'] = 'No s\'ha proporcionat cap taula!'; + + // Users + $lang['struser'] = 'Usuari'; + $lang['strusers'] = 'Usuaris'; + $lang['strusername'] = 'Usuari'; + $lang['strpassword'] = 'Contrasenya'; + $lang['strsuper'] = 'Superusuari?'; + $lang['strcreatedb'] = 'Crear DB?'; + $lang['strexpires'] = 'Expira'; + $lang['strsessiondefaults'] = 'Valors predeterminats de la sessió'; + $lang['strnousers'] = 'No s\'han trobat usuaris.'; + $lang['struserupdated'] = 'Usuari actualitzat.'; + $lang['struserupdatedbad'] = 'L\'actualització de l\'usuari ha fallat.'; + $lang['strshowallusers'] = 'Mostra tots els usuaris'; + $lang['strcreateuser'] = 'Crea un usuari'; + $lang['struserneedsname'] = 'Ha de donar un nom a l\'usuari.'; + $lang['strusercreated'] = 'Usuari creat.'; + $lang['strusercreatedbad'] = 'Error al crear l\'usuari.'; + $lang['strconfdropuser'] = 'Està segur de voler eliminar l\'usuari "%s"?'; + $lang['struserdropped'] = 'Usuari eliminat.'; + $lang['struserdroppedbad'] = 'Error a l\'eliminar l\'usuari.'; + $lang['straccount'] = 'Compte'; + $lang['strchangepassword'] = 'Canvia la contrasenya'; + $lang['strpasswordchanged'] = 'Contrasenya canviada.'; + $lang['strpasswordchangedbad'] = 'Error al canviar la contrasenya.'; + $lang['strpasswordshort'] = 'Contrasenya massa curta.'; + $lang['strpasswordconfirm'] = 'La contrasenya no coincideix amb la confirmació.'; + + // Groups + $lang['strgroup'] = 'Grup'; + $lang['strgroups'] = 'Grups'; + $lang['strshowallgroups'] = 'Mostra tots els grups'; + $lang['strnogroup'] = 'Grup no trobat.'; + $lang['strnogroups'] = 'No s\'han trobat grups.'; + $lang['strcreategroup'] = 'Crea un grup'; + $lang['strgroupneedsname'] = 'Ha de donar un nom al grup.'; + $lang['strgroupcreated'] = 'Grup creat.'; + $lang['strgroupcreatedbad'] = 'No s\'ha pogut crear el grup.'; + $lang['strconfdropgroup'] = 'Està segur de voler eliminar el grup "%s"?'; + $lang['strgroupdropped'] = 'Grup eliminat.'; + $lang['strgroupdroppedbad'] = 'No s\'ha pogut eliminar el grup.'; + $lang['strmembers'] = 'Membres'; + $lang['strmemberof'] = 'Membre de'; + $lang['stradminmembers'] = 'Membres administradors'; + $lang['straddmember'] = 'Afegeix un membre'; + $lang['strmemberadded'] = 'Membre afegit.'; + $lang['strmemberaddedbad'] = 'No s\'ha pogut afegir el membre.'; + $lang['strdropmember'] = 'Elimina el membre'; + $lang['strconfdropmember'] = 'Està segur de voler eliminar el membre "%s" del grup "%s"?'; + $lang['strmemberdropped'] = 'Membre eliminat.'; + $lang['strmemberdroppedbad'] = 'No s\'ha pogut eliminar el membre.'; + + // Roles + $lang['strrole'] = 'Rol'; + $lang['strroles'] = 'Rols'; + $lang['strshowallroles'] = 'Mostra tots els rols'; + $lang['strnoroles'] = 'No s\'han trobat rols.'; + $lang['strinheritsprivs'] = 'Hereda privilegis?'; + $lang['strcreaterole'] = 'Crea un rol'; + $lang['strcancreaterole'] = 'Crear el rol?'; + $lang['strrolecreated'] = 'Rol creat.'; + $lang['strrolecreatedbad'] = 'No s\'ha pogut crear el rol.'; + $lang['strrolealtered'] = 'Rol modificat.'; + $lang['strrolealteredbad'] = 'No s\ha pogut modificar el rol.'; + $lang['strcanlogin'] = 'Pot entrar?'; + $lang['strconnlimit'] = 'Límit de la connexió'; + $lang['strdroprole'] = 'Elimina el rol'; + $lang['strconfdroprole'] = 'Està segur de voler eliminar el rol \'%s\'?'; + $lang['strroledropped'] = 'Rol eliminat.'; + $lang['strroledroppedbad'] = 'No s\'ha pogut eliminar el rol.'; + $lang['strnolimit'] = 'Sense límit'; + $lang['strnever'] = 'Mai'; + $lang['strroleneedsname'] = 'Ha de donar un nom al rol.'; + + // Privileges + $lang['strprivilege'] = 'Privilegi'; + $lang['strprivileges'] = 'Privilegis'; + $lang['strnoprivileges'] = 'Aquest objecte té els privilegis predeterminats.'; + $lang['strgrant'] = 'Concedeix'; + $lang['strrevoke'] = 'Revoca'; + $lang['strgranted'] = 'Privilegis canviats.'; + $lang['strgrantfailed'] = 'Ha fallat el canvi de privilegis.'; + $lang['strgrantbad'] = 'Ha d\'especificar almenys un usuari o grup i almenys un privilegi.'; + $lang['strgrantor'] = 'Cedent'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Base de dades'; + $lang['strdatabases'] = 'Bases de dades'; + $lang['strshowalldatabases'] = 'Mostra totes les bases de dades'; + $lang['strnodatabases'] = 'No s\'han trobat bases de dades.'; + $lang['strcreatedatabase'] = 'Crea una base de dades'; + $lang['strdatabasename'] = 'Nom de la base de dades'; + $lang['strdatabaseneedsname'] = 'Ha de donar un nom a la base de dades.'; + $lang['strdatabasecreated'] = 'Base de dades creada.'; + $lang['strdatabasecreatedbad'] = 'No s\'ha pogut crear la base de dades.'; + $lang['strconfdropdatabase'] = 'Està segur de voler eliminar la base de dades "%s"?'; + $lang['strdatabasedropped'] = 'Base de dades eliminada.'; + $lang['strdatabasedroppedbad'] = 'No s\'ha pogut eliminar la base de dades.'; + $lang['strentersql'] = 'Entri la sentència SQL per executar a sota:'; + $lang['strsqlexecuted'] = 'SQL executat.'; + $lang['strvacuumgood'] = 'Vacuum completat.'; + $lang['strvacuumbad'] = 'Vacuum ha fallat.'; + $lang['stranalyzegood'] = 'Analyze completat.'; + $lang['stranalyzebad'] = 'Analyze ha fallat.'; + $lang['strreindexgood'] = 'Reindex completat.'; + $lang['strreindexbad'] = 'Reindex ha fallat.'; + $lang['strfull'] = 'Ple'; + $lang['strfreeze'] = 'Congelat'; + $lang['strforce'] = 'Força'; + $lang['strsignalsent'] = 'Senyal enviat.'; + $lang['strsignalsentbad'] = 'L\'enviament del senyal ha fallat.'; + $lang['strallobjects'] = 'Tots els objectes'; + $lang['strdatabasealtered'] = 'Base de dades modificada.'; + $lang['strdatabasealteredbad'] = 'No s\'ha pogut modificar la base de dades.'; + $lang['strspecifydatabasetodrop'] = 'Ha d\'especificar almenys una base de dades per eliminar.'; + $lang['strtemplatedb'] = 'Plantilla'; + $lang['strconfanalyzedatabase'] = 'Està segur de voler un analyze de totes les taules de la base de dades "%s"?'; + $lang['strconfvacuumdatabase'] = 'Està segur de voler un vacuum de totes les taules de la base de dades "%s"?'; + $lang['strconfreindexdatabase'] = 'Està segur de voler un reindex de totes les taules de la base de dades "%s"?'; + $lang['strconfclusterdatabase'] = 'Està segur de voler un clúster de totes les taules de la base de dades "%s"?'; + + // Views + $lang['strview'] = 'Vista'; + $lang['strviews'] = 'Vistes'; + $lang['strshowallviews'] = 'Mostra totes les vistes'; + $lang['strnoview'] = 'No s\'ha trobat la vista.'; + $lang['strnoviews'] = 'No s\'han trobat vistes.'; + $lang['strcreateview'] = 'Crea una vista'; + $lang['strviewname'] = 'Nom de la vista'; + $lang['strviewneedsname'] = 'Ha d\'anomenar la vista.'; + $lang['strviewneedsdef'] = 'Ha de donar una definició a la vista.'; + $lang['strviewneedsfields'] = 'Ha de seleccionar les columnes de la vista.'; + $lang['strviewcreated'] = 'Vista creada.'; + $lang['strviewcreatedbad'] = 'No s\'ha pogut crear la vista.'; + $lang['strconfdropview'] = 'Està segur de voler eliminar la vista "%s"?'; + $lang['strviewdropped'] = 'Vista eliminada.'; + $lang['strviewdroppedbad'] = 'No s\'ha pogut eliminar la vista.'; + $lang['strviewupdated'] = 'Vista actualitzada.'; + $lang['strviewupdatedbad'] = 'No s\'ha pogut actualitzar la vista.'; + $lang['strviewlink'] = 'Enllaçant claus'; + $lang['strviewconditions'] = 'Condicions addicionals'; + $lang['strcreateviewwiz'] = 'Crea una vista amb l\'assistent'; + $lang['strrenamedupfields'] = 'Reanomena els camps duplicats'; + $lang['strdropdupfields'] = 'Elimina els camps duplicats'; + $lang['strerrordupfields'] = 'Error en els camps duplicats'; + $lang['strviewaltered'] = 'Vista modificada.'; + $lang['strviewalteredbad'] = 'No s\'ha pogut modificar la vista.'; + $lang['strspecifyviewtodrop'] = 'Ha d\'especificar almenys una vista per eliminar.'; + + // Sequences + $lang['strsequence'] = 'Seqüència'; + $lang['strsequences'] = 'Seqüències'; + $lang['strshowallsequences'] = 'Mostra totes les seqüències'; + $lang['strnosequence'] = 'No s\'ha trobat la seqüencia.'; + $lang['strnosequences'] = 'No s\'han trobat seqüencies.'; + $lang['strcreatesequence'] = 'Crea una seqüència'; + $lang['strlastvalue'] = 'Últim valor'; + $lang['strincrementby'] = 'Incrementar en'; + $lang['strstartvalue'] = 'Valor inicial'; + $lang['strrestartvalue'] = 'Valor al reiniciar'; + $lang['strmaxvalue'] = 'Valor màxim'; + $lang['strminvalue'] = 'Valor mínim'; + $lang['strcachevalue'] = 'Valor de cache'; + $lang['strlogcount'] = 'Compte del registre'; + $lang['strcancycle'] = 'Pot completar un cicle?'; + $lang['striscalled'] = 'Vol incrementar l\últim valor abans de retornar el següent valor (is_called)?'; + $lang['strsequenceneedsname'] = 'Ha d\'especificar un nom per la seqüència.'; + $lang['strsequencecreated'] = 'Seqüència creada.'; + $lang['strsequencecreatedbad'] = 'No s\'ha pogut crear la seqüència.'; + $lang['strconfdropsequence'] = 'Està segur de voler eliminar la seqüència "%s"?'; + $lang['strsequencedropped'] = 'Seqüència eliminada.'; + $lang['strsequencedroppedbad'] = 'No s\'ha pogut eliminar la seqüència.'; + $lang['strsequencerestart'] = 'Seqüència reiniciada.'; + $lang['strsequencerestartbad'] = 'No s\'ha pogut reiniciar la seqüència.'; + $lang['strsequencereset'] = 'Seqüència reiniciada.'; + $lang['strsequenceresetbad'] = 'No s\'ha pogut reiniciar la seqüència.'; + $lang['strsequencealtered'] = 'Seqüència modificada.'; + $lang['strsequencealteredbad'] = 'No s\'ha pogut modificar la seqüència.'; + $lang['strsetval'] = 'Fixa el valor'; + $lang['strsequencesetval'] = 'Valor de la seqüència fixat.'; + $lang['strsequencesetvalbad'] = 'No s\'ha pogut fixar el valor de la seqüencia.'; + $lang['strnextval'] = 'Valor incremental'; + $lang['strsequencenextval'] = 'Seqüència incrementada.'; + $lang['strsequencenextvalbad'] = 'No s\'ha pogut incrementar la seqüència.'; + $lang['strspecifysequencetodrop'] = 'Ha d\'especificar almenys una seqüència per eliminar.'; + + // Indexes + $lang['strindex'] = 'Ãndex'; + $lang['strindexes'] = 'Ãndexs'; + $lang['strindexname'] = 'Nom de l\'índex'; + $lang['strshowallindexes'] = 'Mostra tots els índexs'; + $lang['strnoindex'] = 'No s\'ha trobat l\'índex'; + $lang['strnoindexes'] = 'No s\'han trobat índexs.'; + $lang['strcreateindex'] = 'Crea un índex'; + $lang['strtabname'] = 'Nom de la pestanya'; + $lang['strcolumnname'] = 'Nom de la columna'; + $lang['strindexneedsname'] = 'Ha d\'anomenar l\'índex.'; + $lang['strindexneedscols'] = 'Els índexs requereixen un número vàlid de columnes.'; + $lang['strindexcreated'] = 'Ãndex creat'; + $lang['strindexcreatedbad'] = 'No s\'ha pogut crear l\'índex.'; + $lang['strconfdropindex'] = 'Està segur de voler eliminar l\'índex "%s"?'; + $lang['strindexdropped'] = 'Ãndex eliminat.'; + $lang['strindexdroppedbad'] = 'No s\'ha pogut eliminar l\'índex.'; + $lang['strkeyname'] = 'Nom de la clau'; + $lang['struniquekey'] = 'Clau única'; + $lang['strprimarykey'] = 'Clau primària'; + $lang['strindextype'] = 'Tipus d\'índex'; + $lang['strtablecolumnlist'] = 'Columnes a la taula'; + $lang['strindexcolumnlist'] = 'Columnes a l\'índex'; + $lang['strclusteredgood'] = 'Clúster completat.'; + $lang['strclusteredbad'] = 'No s\'ha pogut crear el clúster.'; + $lang['strconcurrently'] = 'Actualment'; + $lang['strnoclusteravailable'] = 'No hi ha el clúster disponible en l\'índex.'; + + // Rules + $lang['strrules'] = 'Regles'; + $lang['strrule'] = 'Regla'; + $lang['strshowallrules'] = 'Mostra totes les regles'; + $lang['strnorule'] = 'No s\'ha trobat la regla.'; + $lang['strnorules'] = 'No s\'han trobat regles.'; + $lang['strcreaterule'] = 'Crea una regla'; + $lang['strrulename'] = 'Nom de la regla'; + $lang['strruleneedsname'] = 'Ha d\'especificar un nom per la regla'; + $lang['strrulecreated'] = 'Regla creada.'; + $lang['strrulecreatedbad'] = 'No s\'ha pogut crear la regla.'; + $lang['strconfdroprule'] = 'Està segur de voler eliminar la regla "%s" a "%s"?'; + $lang['strruledropped'] = 'Regla eliminada.'; + $lang['strruledroppedbad'] = 'No s\'ha pogut eliminar la regla.'; + + // Constraints + $lang['strconstraint'] = 'Restricció'; + $lang['strconstraints'] = 'Restriccions'; + $lang['strshowallconstraints'] = 'Mostra totes les restriccions'; + $lang['strnoconstraints'] = 'No s\'han trobat restriccions.'; + $lang['strcreateconstraint'] = 'Crea una restricció'; + $lang['strconstraintcreated'] = 'Restricció creada.'; + $lang['strconstraintcreatedbad'] = 'No s\'ha pogut crear la restricció.'; + $lang['strconfdropconstraint'] = 'Està segur de voler eliminar la restricció "%s" de "%s"?'; + $lang['strconstraintdropped'] = 'Restricció eliminada.'; + $lang['strconstraintdroppedbad'] = 'No s\'ha pogut eliminar la restricció.'; + $lang['straddcheck'] = 'Agrega un control'; + $lang['strcheckneedsdefinition'] = 'La restricció de control necessita una definició.'; + $lang['strcheckadded'] = 'Restricció de control agregada.'; + $lang['strcheckaddedbad'] = 'No s\'ha pogut agregar la restricció de control.'; + $lang['straddpk'] = 'Agrega una clau primària'; + $lang['strpkneedscols'] = 'La clau primària requereix almenys una columna.'; + $lang['strpkadded'] = 'Clau primària agregada.'; + $lang['strpkaddedbad'] = 'No s\'ha pogut agregar la clau primària.'; + $lang['stradduniq'] = 'Agrega una clau única'; + $lang['struniqneedscols'] = 'La clau única requereix almenys una columna.'; + $lang['struniqadded'] = 'Clau única agregada.'; + $lang['struniqaddedbad'] = 'No s\'ha pogut agregar la clau única.'; + $lang['straddfk'] = 'Agrega una clau externa'; + $lang['strfkneedscols'] = 'La clau externa requereix almenys una columna.'; + $lang['strfkneedstarget'] = 'La clau externa requereix una taula de referència.'; + $lang['strfkadded'] = 'Clau externa agregada.'; + $lang['strfkaddedbad'] = 'No s\'ha pogut agregar la clau externa.'; + $lang['strfktarget'] = 'Taula de destí'; + $lang['strfkcolumnlist'] = 'Columnes a la clau'; + $lang['strondelete'] = 'A L\'ELIMINAR'; + $lang['stronupdate'] = 'A L\'ACTUALITZAR'; + + // Functions + $lang['strfunction'] = 'Funció'; + $lang['strfunctions'] = 'Funcions'; + $lang['strshowallfunctions'] = 'Mostra totes les funcions'; + $lang['strnofunction'] = 'No s\'ha trobat la funció.'; + $lang['strnofunctions'] = 'No s\'han trobat funcions'; + $lang['strcreateplfunction'] = 'Crea una funció SQL/PL'; + $lang['strcreateinternalfunction'] = 'Crea una funció interna'; + $lang['strcreatecfunction'] = 'Crea una funció C'; + $lang['strfunctionname'] = 'Nom de la funció'; + $lang['strreturns'] = 'Retorna'; + $lang['strproglanguage'] = 'Llenguatge de programació'; + $lang['strfunctionneedsname'] = 'Ha de donar un nom a la funció.'; + $lang['strfunctionneedsdef'] = 'Ha de donar una definició a la funció.'; + $lang['strfunctioncreated'] = 'Funció creada.'; + $lang['strfunctioncreatedbad'] = 'No s\'ha pogut crear la funció.'; + $lang['strconfdropfunction'] = 'Està segur de voler eliminar la funció "%s"?'; + $lang['strfunctiondropped'] = 'Funció eliminada.'; + $lang['strfunctiondroppedbad'] = 'No s\'ha pogut eliminar la funció.'; + $lang['strfunctionupdated'] = 'Funció actualitzada.'; + $lang['strfunctionupdatedbad'] = 'No s\'ha pogut actualitzar la funció.'; + $lang['strobjectfile'] = 'Fitxer objecte'; + $lang['strlinksymbol'] = 'Enllaç simbòlic'; + $lang['strarguments'] = 'Arguments'; + $lang['strargmode'] = 'Mode'; + $lang['strargtype'] = 'Tipus'; + $lang['strargadd'] = 'Afegeix un altre argument'; + $lang['strargremove'] = 'Elimina aquest argument'; + $lang['strargnoargs'] = 'Aquesta funció no tindrà arguments.'; + $lang['strargenableargs'] = 'Habilita els arguments passats a aquesta funció.'; + $lang['strargnorowabove'] = 'Hi ha d\'haver una fila sobre aquesta fila.'; + $lang['strargnorowbelow'] = 'Hi ha d\'haver una fila sota aquesta fila.'; + $lang['strargraise'] = 'Mou amunt.'; + $lang['strarglower'] = 'Mou avall.'; + $lang['strargremoveconfirm'] = 'Està segur de voler eliminar aquest argument? Això NO es pot desfer.'; + $lang['strfunctioncosting'] = 'Funció de Cost'; + $lang['strresultrows'] = 'Files Resultants'; + $lang['strexecutioncost'] = 'Cost de l\'Execució'; + $lang['strspecifyfunctiontodrop'] = 'Ha d\'especificar almenys una funció per eliminar.'; + + // Triggers + $lang['strtrigger'] = 'Disparador'; + $lang['strtriggers'] = 'Disparadors'; + $lang['strshowalltriggers'] = 'Mostrar tots els disparadors'; + $lang['strnotrigger'] = 'No s\'ha trobat el disparador.'; + $lang['strnotriggers'] = 'No s\'han trobat disparadors.'; + $lang['strcreatetrigger'] = 'Crea un disparador'; + $lang['strtriggerneedsname'] = 'Ha de donar un nom al disparador.'; + $lang['strtriggerneedsfunc'] = 'Ha d\'especificar una funció pel disparador.'; + $lang['strtriggercreated'] = 'Disparador creat.'; + $lang['strtriggercreatedbad'] = 'No s\'ha pogut crear el disparador.'; + $lang['strconfdroptrigger'] = 'Està segur de voler eliminar el disparador "%s" de "%s"?'; + $lang['strconfenabletrigger'] = 'Està segur de voler habilitar el disparador "%s" a "%s"?'; + $lang['strconfdisabletrigger'] = 'Està segur de voler inhabilitar el disparador "%s" a "%s"?'; + $lang['strtriggerdropped'] = 'Disparador eliminat.'; + $lang['strtriggerdroppedbad'] = 'No s\'ha pogut eliminar el disparador.'; + $lang['strtriggerenabled'] = 'Disparador habilitat.'; + $lang['strtriggerenabledbad'] = 'No s\'ha pogut habilitar el disparador.'; + $lang['strtriggerdisabled'] = 'Disparador inhabilitat.'; + $lang['strtriggerdisabledbad'] = 'No s\'ha pogut inhabilitar el disparador.'; + $lang['strtriggeraltered'] = 'Disparador modificat.'; + $lang['strtriggeralteredbad'] = 'No s\'ha pogut modificar el disparador.'; + $lang['strforeach'] = 'Per cada'; + + // Types + $lang['strtype'] = 'Tipus'; + $lang['strtypes'] = 'Tipus'; + $lang['strshowalltypes'] = 'Mostrar tots els tipus'; + $lang['strnotype'] = 'No s\'ha trobat el tipus.'; + $lang['strnotypes'] = 'No s\'han trobat els tipus.'; + $lang['strcreatetype'] = 'Crea un tipus'; + $lang['strcreatecomptype'] = 'Crea un tipus compost'; + $lang['strcreateenumtype'] = 'Crea un tipus d\'enumeració'; + $lang['strtypeneedsfield'] = 'Ha d\'especificar almenys un camp.'; + $lang['strtypeneedsvalue'] = 'Ha d\'especificar almenys un valor.'; + $lang['strtypeneedscols'] = 'Ha d\'especificar un número vàlid de camps.'; + $lang['strtypeneedsvals'] = 'Ha d\'especificar un número vàlid de valors.'; + $lang['strinputfn'] = 'Funció d\'entrada'; + $lang['stroutputfn'] = 'Funció de sortida'; + $lang['strpassbyval'] = 'Passat per valor?'; + $lang['stralignment'] = 'Alineament'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Delimitador'; + $lang['strstorage'] = 'Emmagatzemament'; + $lang['strfield'] = 'Camp'; + $lang['strnumfields'] = 'Num. de camps'; + $lang['strnumvalues'] = 'Num. de valors'; + $lang['strtypeneedsname'] = 'Ha de donar un nom al tipus.'; + $lang['strtypeneedslen'] = 'Ha de donar una longitud al tipus.'; + $lang['strtypecreated'] = 'Tipus creat'; + $lang['strtypecreatedbad'] = 'No s\'ha pogut crear el tipus.'; + $lang['strconfdroptype'] = 'Està segur de voler eliminar el tipus "%s"?'; + $lang['strtypedropped'] = 'Tipus eliminat.'; + $lang['strtypedroppedbad'] = 'No s\'ha pogut eliminar el tipus.'; + $lang['strflavor'] = 'Varietat'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Compost'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'Enumeració'; + $lang['strenumvalues'] = 'Valors de l\'enumeració'; + + // Schemas + $lang['strschema'] = 'Esquema'; + $lang['strschemas'] = 'Esquemes'; + $lang['strshowallschemas'] = 'Mostra tots els esquemes'; + $lang['strnoschema'] = 'No s\'ha trobat l\'esquema.'; + $lang['strnoschemas'] = 'No s\'han trobat esquemes.'; + $lang['strcreateschema'] = 'Crea un esquema'; + $lang['strschemaname'] = 'Nom de l\'esquema'; + $lang['strschemaneedsname'] = 'Ha d\'anomenar l\'esquema.'; + $lang['strschemacreated'] = 'Esquema creat'; + $lang['strschemacreatedbad'] = 'No s\'ha pogut crear l\'esquema.'; + $lang['strconfdropschema'] = 'Està segur de voler eliminar l\'esquema "%s"?'; + $lang['strschemadropped'] = 'Esquema eliminat.'; + $lang['strschemadroppedbad'] = 'No s\'ha pogut eliminar l\'esquema.'; + $lang['strschemaaltered'] = 'Esquema modificat.'; + $lang['strschemaalteredbad'] = 'No s\'ha pogut modificar l\'esquema.'; + $lang['strsearchpath'] = 'Camí de cerca de l\'esquema'; + $lang['strspecifyschematodrop'] = 'Ha d\especificar almenys un esquema per eliminar.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domini'; + $lang['strdomains'] = 'Dominis'; + $lang['strshowalldomains'] = 'Mostrar tots els dominis'; + $lang['strnodomains'] = 'No s\'han trobat dominis.'; + $lang['strcreatedomain'] = 'Crea un domini'; + $lang['strdomaindropped'] = 'Domini eliminat.'; + $lang['strdomaindroppedbad'] = 'No s\'ha pogut eliminar el domini.'; + $lang['strconfdropdomain'] = 'Està segur de voler eliminar el domini "%s"?'; + $lang['strdomainneedsname'] = 'Ha d\'anomenar el domini.'; + $lang['strdomaincreated'] = 'Domini creat.'; + $lang['strdomaincreatedbad'] = 'No s\'ha pogut crear el domini.'; + $lang['strdomainaltered'] = 'Domini modificat.'; + $lang['strdomainalteredbad'] = 'No s\'ha pogut modificar el domini.'; + + // Operators + $lang['stroperator'] = 'Operador'; + $lang['stroperators'] = 'Operadors'; + $lang['strshowalloperators'] = 'Mostra tots els operadors'; + $lang['strnooperator'] = 'No s\'ha trobat l\'operador.'; + $lang['strnooperators'] = 'No s\'han trobat operadors.'; + $lang['strcreateoperator'] = 'Crea un operador'; + $lang['strleftarg'] = 'Tipus de l\'arg. esquerre'; + $lang['strrightarg'] = 'Tipus de l\'arg. dret'; + $lang['strcommutator'] = 'Commutador'; + $lang['strnegator'] = 'Negació'; + $lang['strrestrict'] = 'Restringeix'; + $lang['strjoin'] = 'Unieix'; + $lang['strhashes'] = 'Hash'; + $lang['strmerges'] = 'Fussiona'; + $lang['strleftsort'] = 'Sort esquerre'; + $lang['strrightsort'] = 'Sort dret'; + $lang['strlessthan'] = 'Menor que'; + $lang['strgreaterthan'] = 'Major que'; + $lang['stroperatorneedsname'] = 'Ha d\'anomenar l\'operador.'; + $lang['stroperatorcreated'] = 'Operador creat'; + $lang['stroperatorcreatedbad'] = 'No s\'ha pogut crear l\'operador.'; + $lang['strconfdropoperator'] = 'Està segur de voler eliminar l\'operador "%s"?'; + $lang['stroperatordropped'] = 'Operador eliminat.'; + $lang['stroperatordroppedbad'] = 'No s\'ha pogut eliminar l\'operador.'; + + // Casts + $lang['strcasts'] = 'Conversió de tipus'; + $lang['strnocasts'] = 'No s\'han trobat conversions.'; + $lang['strsourcetype'] = 'Tipus inicial'; + $lang['strtargettype'] = 'Tipus final'; + $lang['strimplicit'] = 'Implícit'; + $lang['strinassignment'] = 'En assignació'; + $lang['strbinarycompat'] = '(Compatible amb binari)'; + + // Conversions + $lang['strconversions'] = 'Conversions'; + $lang['strnoconversions'] = 'No s\'han trobat conversions.'; + $lang['strsourceencoding'] = 'Codificació inicial'; + $lang['strtargetencoding'] = 'Codificació final'; + + // Languages + $lang['strlanguages'] = 'Llenguatges'; + $lang['strnolanguages'] = 'No s\'han trobat llenguatges.'; + $lang['strtrusted'] = 'Fiable'; + + // Info + $lang['strnoinfo'] = 'No hi ha informació disponible.'; + $lang['strreferringtables'] = 'Referent a les taules'; + $lang['strparenttables'] = 'Taules pare'; + $lang['strchildtables'] = 'Taules fill'; + + // Aggregates + $lang['straggregate'] = 'Agregat'; + $lang['straggregates'] = 'Agregats'; + $lang['strnoaggregates'] = 'No s\'han trobat agregats'; + $lang['stralltypes'] = '(Tots els tipus)'; + $lang['strcreateaggregate'] = 'Crea un agregat'; + $lang['straggrbasetype'] = 'Tipus de dades d\'entrada'; + $lang['straggrsfunc'] = 'Funció de la transició de l\'estat'; + $lang['straggrstype'] = 'Tipus de dades pel valor de l\'estat'; + $lang['straggrffunc'] = 'Funció final'; + $lang['straggrinitcond'] = 'Condició inicial'; + $lang['straggrsortop'] = 'Operador ordre'; + $lang['strconfdropaggregate'] = 'Està segur de voler elimnar l\'agregat \'%s\'?'; + $lang['straggregatedropped'] = 'Agregat eliminat.'; + $lang['straggregatedroppedbad'] = 'No s\'ha pogut eliminar l\'agregat.'; + $lang['straggraltered'] = 'Agregat modificat.'; + $lang['straggralteredbad'] = 'No s\'ha pogut modificar l\'agregat.'; + $lang['straggrneedsname'] = 'Ha d\'especificar un nom per l\'agregat'; + $lang['straggrneedsbasetype'] = 'Ha d\'especificar el tipus de dades d\'entrada per l\'agregat'; + $lang['straggrneedssfunc'] = 'Ha d\'especificar el nom de la funció de transició de l\'estat per l\'agregat'; + $lang['straggrneedsstype'] = 'Ha d\'especificar el tipus de dades pel valor de l\'estat de l\'agregat'; + $lang['straggrcreated'] = 'Agregat creat.'; + $lang['straggrcreatedbad'] = 'No s\'ha pogut crear l\agregat.'; + $lang['straggrshowall'] = 'Mostra tots els agregats'; + + // Operator Classes + $lang['stropclasses'] = 'Classes d\'operadors'; + $lang['strnoopclasses'] = 'No s\'han trobat classes d\'operadors.'; + $lang['straccessmethod'] = 'Mètode d\'accés'; + + // Stats and performance + $lang['strrowperf'] = 'Row Performance'; + $lang['strioperf'] = 'I/O Performance'; + $lang['stridxrowperf'] = 'Index Row Performance'; + $lang['stridxioperf'] = 'Index I/O Performance'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequential'; + $lang['strscan'] = 'Scan'; + $lang['strread'] = 'Read'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Rows'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaces'; + $lang['strshowalltablespaces'] = 'Mostrar tots els tablespaces'; + $lang['strnotablespaces'] = 'No s\'han trobat tablespaces'; + $lang['strcreatetablespace'] = 'Crea un tablespace'; + $lang['strlocation'] = 'Localització'; + $lang['strtablespaceneedsname'] = 'Ha de donar un nom al tablespace.'; + $lang['strtablespaceneedsloc'] = 'Ha de donar un directori on crear el tablespace.'; + $lang['strtablespacecreated'] = 'Tablespace creat.'; + $lang['strtablespacecreatedbad'] = 'No s\'ha pogut crear el Tablespace.'; + $lang['strconfdroptablespace'] = 'Està segur de voler eliminar el tablespace "%s"?'; + $lang['strtablespacedropped'] = 'Tablespace eliminat.'; + $lang['strtablespacedroppedbad'] = 'No s\'ha pogut eliminar el tablespace.'; + $lang['strtablespacealtered'] = 'Tablespace modificat.'; + $lang['strtablespacealteredbad'] = 'No s\'ha pogut modifcar el tablespace.'; + + // Miscellaneous + $lang['strtopbar'] = '%s corrent a %s:%s -- Ha entrat com a usuari "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Ajuda'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Cercador de pàgines d\'ajuda'; + $lang['strselecthelppage'] = 'Selecciona una pàgina d\'ajuda'; + $lang['strinvalidhelppage'] = 'Pàgina d\'ajuda invàlida.'; + $lang['strlogintitle'] = 'Entrar a %s'; + $lang['strlogoutmsg'] = 'Sortir de %s'; + $lang['strloading'] = 'Carregant...'; + $lang['strerrorloading'] = 'Error Carregant'; + $lang['strclicktoreload'] = 'Clicar per recarregar'; + + // Autovacuum + $lang['strautovacuum'] = 'Autovacuum'; + $lang['strturnedon'] = 'Activat'; + $lang['strturnedoff'] = 'Desactivat'; + $lang['strenabled'] = 'Habilitat'; + $lang['strnovacuumconf'] = 'No s\'ha trobat la configuració de l\'autovacuum.'; + $lang['strvacuumbasethreshold'] = 'Llindar Base del Vacuum'; + $lang['strvacuumscalefactor'] = 'Factor d\'Escala del Vacuum'; + $lang['stranalybasethreshold'] = 'Llindar Base de l\'Analyze'; + $lang['stranalyzescalefactor'] = 'Factor d\'Escala de l\'Analyze'; + $lang['strvacuumcostdelay'] = 'Cost del Retard del Vacuum'; + $lang['strvacuumcostlimit'] = 'Límit de Cost del Vacuum'; + $lang['strvacuumpertable'] = 'Configuració de l\'autovacuum per taula'; + $lang['straddvacuumtable'] = 'Afegeix la configuració de l\'autovacuum per una taula'; + $lang['streditvacuumtable'] = 'Edita la configuració de l\'autovacuum de la taula %s'; + $lang['strdelvacuumtable'] = 'Vol eliminar la configuració de l\'autovacuum de la taula %s ?'; + $lang['strvacuumtablereset'] = 'S\'ha inicialitzat la configuració de l\'autovacuum de la taula %s als valors per defecte'; + $lang['strdelvacuumtablefail'] = 'No s\'ha pogut eliminar la configuració de l\'autovacuum de la taula %s'; + $lang['strsetvacuumtablesaved'] = 'Configuració de l\'autovacuum de la taula %s desada.'; + $lang['strsetvacuumtablefail'] = 'Ha fallat la configuració de l\'autovacuum de la taula %s.'; + $lang['strspecifydelvacuumtable'] = 'Ha d\'especificar la taula d\'on vol eliminar els paràmetres de l\'autovacuum.'; + $lang['strspecifyeditvacuumtable'] = 'Ha d\'especificar la taula d\'on vol editar els paràmetres de l\'autovacuum.'; + $lang['strnotdefaultinred'] = 'Els paràmetres no per defecte en vermell.'; + + // Table-level Locks + $lang['strlocks'] = 'Bloquejos'; + $lang['strtransaction'] = 'ID de la Transacció'; + $lang['strvirtualtransaction'] = 'ID de la Transacció Virtual'; + $lang['strprocessid'] = 'ID del Procés'; + $lang['strmode'] = 'Mode de Bloqueig'; + $lang['strislockheld'] = 'S\'aguanta el bloqueig?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Transaccions preparades'; + $lang['strxactid'] = 'ID de la Transacció'; + $lang['strgid'] = 'ID Global'; + + // Fulltext search + $lang['strfulltext'] = 'Cerca del Text Completa (FTS)'; + $lang['strftsconfig'] = 'Configuració FTS'; + $lang['strftsconfigs'] = 'Configuracions'; + $lang['strftscreateconfig'] = 'Crea una configuració FTS'; + $lang['strftscreatedict'] = 'Crea un diccionari'; + $lang['strftscreatedicttemplate'] = 'Crea una plantilla d\'un diccionari'; + $lang['strftscreateparser'] = 'Crea un analitzador'; + $lang['strftsnoconfigs'] = 'No s\'ha trobat cap configuració FTS.'; + $lang['strftsconfigdropped'] = 'Configuració FTS eliminada.'; + $lang['strftsconfigdroppedbad'] = 'No s\'ha pogut eliminar la configuració FTS.'; + $lang['strconfdropftsconfig'] = 'Està segur de voler eliminar la configuració FTS "%s"?'; + $lang['strconfdropftsdict'] = 'Està segur de voler eliminar el diccionari FTS "%s"?'; + $lang['strconfdropftsmapping'] = 'Està segur de voler eliminar el traçat "%s" de la configuració FTS "%s"?'; + $lang['strftstemplate'] = 'Plantilla'; + $lang['strftsparser'] = 'Analitzador'; + $lang['strftsconfigneedsname'] = 'Ha de donar un nom a la configuració FTS.'; + $lang['strftsconfigcreated'] = 'Configuració FTS creada.'; + $lang['strftsconfigcreatedbad'] = 'No s\'ha pogut crear la configuració FTS.'; + $lang['strftsmapping'] = 'Traçat'; + $lang['strftsdicts'] = 'Diccionaris'; + $lang['strftsdict'] = 'Diccionari'; + $lang['strftsemptymap'] = 'Mapa de la configuració FTS buida.'; + $lang['strftsconfigaltered'] = 'Configuració FTS modificada.'; + $lang['strftsconfigalteredbad'] = 'No s\'ha pogut modificar la configuració FTS.'; + $lang['strftsconfigmap'] = 'Mapa de la configuració FTS'; + $lang['strftsparsers'] = 'Analitzadors FTS'; + $lang['strftsnoparsers'] = 'No hi ha analitzadors FTS disponibles.'; + $lang['strftsnodicts'] = 'No hi ha diccionaris FTS disponibles.'; + $lang['strftsdictcreated'] = 'Diccionari FTS creat.'; + $lang['strftsdictcreatedbad'] = 'No s\ha pogut crear el diccionari FTS.'; + $lang['strftslexize'] = 'Lexize'; + $lang['strftsinit'] = 'Inicialitzador'; + $lang['strftsoptionsvalues'] = 'Opcions i valors'; + $lang['strftsdictneedsname'] = 'Ha de donar un nom al diccionari FTS.'; + $lang['strftsdictdropped'] = 'Diccionari FTS eliminat.'; + $lang['strftsdictdroppedbad'] = 'No s\'ha pogut eliminar el diccionari FTS.'; + $lang['strftsdictaltered'] = 'Diccionari FTS modificat.'; + $lang['strftsdictalteredbad'] = 'No s\'ha pogut modificar el diccionari FTS.'; + $lang['strftsaddmapping'] = 'Afegeix un nou traçat'; + $lang['strftsspecifymappingtodrop'] = 'Ha d\'especificar almenys un traçat per eliminar.'; + $lang['strftsspecifyconfigtoalter'] = 'Ha d\'especificar la configuració FTS per modificar'; + $lang['strftsmappingdropped'] = 'Traçat FTS eliminat.'; + $lang['strftsmappingdroppedbad'] = 'No s\'ha pogut eliminar el traçat FTS.'; + $lang['strftsnodictionaries'] = 'No s\'han trobat diccionaris.'; + $lang['strftsmappingaltered'] = 'Traçat FTS modificat.'; + $lang['strftsmappingalteredbad'] = 'No s\'ha pogut modificar el traçat FTS.'; + $lang['strftsmappingadded'] = 'Traçat FTS afegit.'; + $lang['strftsmappingaddedbad'] = 'No s\'ha pogut afegir el traçat FTS.'; + $lang['strftstabconfigs'] = 'Configuracions'; + $lang['strftstabdicts'] = 'Diccionaris'; + $lang['strftstabparsers'] = 'Analitzadors'; + $lang['strftscantparsercopy'] = 'No es pot especificar alhora un analitzador i una plantilla durant la creació de la configuració de la cerca de text.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-sim.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-sim.php new file mode 100644 index 00000000..49b056e4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-sim.php @@ -0,0 +1,359 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-tr.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-tr.php new file mode 100644 index 00000000..766ccb53 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-tr.php @@ -0,0 +1,583 @@ +'; + $lang['strfirst'] = '<< 第一步'; + $lang['strlast'] = '最後一步 >>'; + $lang['strfailed'] = '失敗'; + $lang['strcreate'] = '建立'; + $lang['strcreated'] = '已建立'; + $lang['strcomment'] = '註釋'; + $lang['strlength'] = '長度'; + $lang['strdefault'] = 'é è¨­å€¼'; + $lang['stralter'] = '修改'; + $lang['strok'] = '確定'; + $lang['strcancel'] = 'å–消'; + $lang['strsave'] = '儲存'; + $lang['strreset'] = 'é‡è¨­'; + $lang['strinsert'] = 'æ’å…¥'; + $lang['strselect'] = 'é¸å–'; + $lang['strdelete'] = '刪除'; + $lang['strupdate'] = 'æ›´æ–°'; + $lang['strreferences'] = 'åƒè€ƒ'; + $lang['stryes'] = '是'; + $lang['strno'] = 'å¦'; + $lang['strtrue'] = '真'; + $lang['strfalse'] = 'å‡'; + $lang['stredit'] = '修改'; + $lang['strcolumns'] = '資料行'; + $lang['strrows'] = '資料列'; + $lang['strrowsaff'] = '資料列å—影響。'; + $lang['strobjects'] = '物件'; + $lang['strexample'] = '例如:'; + $lang['strback'] = '返回'; + $lang['strqueryresults'] = '查詢çµæžœ'; + $lang['strshow'] = '顯示'; + $lang['strempty'] = '空'; + $lang['strlanguage'] = '語言'; + $lang['strencoding'] = '編碼'; + $lang['strvalue'] = '值'; + $lang['strunique'] = 'ç¨ä¸€éµ'; + $lang['strprimary'] = '主索引éµ'; + $lang['strexport'] = '匯出'; + $lang['strimport'] = '匯入'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = '開始'; + $lang['stradmin'] = '管ç†'; + $lang['strvacuum'] = '清ç†(Vacuum)'; + $lang['stranalyze'] = '分æž'; + $lang['strclusterindex'] = 'å¢é›†'; + $lang['strclustered'] = 'å¢é›†?'; + $lang['strreindex'] = 'é‡å»ºç´¢å¼•'; + $lang['strrun'] = '執行'; + $lang['stradd'] = '加入'; + $lang['strevent'] = '事件'; + $lang['strwhere'] = 'Where'; + $lang['strinstead'] = 'Do Instead'; + $lang['strwhen'] = '當'; + $lang['strformat'] = 'æ ¼å¼'; + $lang['strdata'] = '資料'; + $lang['strconfirm'] = '確èª'; + $lang['strexpression'] = '表示å¼'; + $lang['strellipsis'] = '...'; + $lang['strexpand'] = '展開'; + $lang['strcollapse'] = '摺疊'; + $lang['strexplain'] = '闡明'; + $lang['strexplainanalyze'] = '闡明分æž'; + $lang['strfind'] = '尋找'; + $lang['stroptions'] = 'é¸é …'; + $lang['strrefresh'] = 'é‡æ–°æ•´ç†'; + $lang['strdownload'] = '下載'; + $lang['strdownloadgzipped'] = '以gzip壓縮後下載'; + $lang['strinfo'] = '資訊'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = '進階'; + $lang['strvariables'] = '變數'; + $lang['strprocess'] = '程åº'; + $lang['strprocesses'] = '程åº'; + $lang['strsetting'] = '設定'; + $lang['streditsql'] = '編輯SQL'; + $lang['strruntime'] = '總共執行時間: %s ms'; + $lang['strpaginate'] = '分é é¡¯ç¤ºçµæžœ'; + $lang['struploadscript'] = '或是上傳一個SQL指令檔:'; + $lang['strstarttime'] = '開始時間'; + $lang['strfile'] = '檔案'; + $lang['strfileimported'] = '檔案已匯入。'; + + // Error handling + $lang['strbadconfig'] = '您的 config.inc.php 無效。請利用 config.inc.php-dist 建立您的 config.inc.php 檔。'; + $lang['strnotloaded'] = '您的 PHP 環境未安è£å¿…需的資料庫支æ´ã€‚'; + $lang['strbadschema'] = 'æŒ‡å®šäº†ç„¡æ•ˆçš„æ¨¡å¼ (schema)。'; + $lang['strbadencoding'] = '資料庫無法設定用戶端的編碼方å¼ã€‚'; + $lang['strsqlerror'] = 'SQL 錯誤:'; + $lang['strinstatement'] = '於陳述內:'; + $lang['strinvalidparam'] = '無效的 script 變數。'; + $lang['strnodata'] = '找ä¸åˆ°ä»»ä½•è³‡æ–™åˆ—。'; + $lang['strnoobjects'] = '找ä¸åˆ°ä»»ä½•ç‰©ä»¶ã€‚'; + $lang['strrownotunique'] = '此顯料列無ç¨ç‰¹è­˜åˆ¥é …。'; + $lang['strnouploads'] = '上傳檔案功能已åœç”¨ã€‚'; + $lang['strimporterror'] = '匯入錯誤。'; + $lang['strimporterrorline'] = '匯入錯誤發生於第 %s 行。'; + + // Tables + $lang['strtable'] = '資料表'; + $lang['strtables'] = '資料表'; + $lang['strshowalltables'] = '顯示所有的資料表'; + $lang['strnotables'] = '找ä¸åˆ°æ­¤è³‡æ–™è¡¨ã€‚'; + $lang['strnotable'] = '找ä¸åˆ°ä»»ä½•è³‡æ–™è¡¨ã€‚'; + $lang['strcreatetable'] = '建立新資料表'; + $lang['strtablename'] = '資料表å'; + $lang['strtableneedsname'] = '您需為您的資料表命å。'; + $lang['strtableneedsfield'] = '您至少應指定一個欄ä½ã€‚'; + $lang['strtableneedscols'] = '資料表需è¦ä¸€å®šæ•¸ç›®çš„資料行。'; + $lang['strtablecreated'] = 'æˆåŠŸå»ºç«‹è³‡æ–™è¡¨ã€‚'; + $lang['strtablecreatedbad'] = '建立資料表作業失敗。'; + $lang['strconfdroptable'] = '您確定è¦åˆªé™¤è³‡æ–™è¡¨ "%s"?'; + $lang['strtabledropped'] = 'æˆåŠŸåˆªé™¤è³‡æ–™è¡¨ã€‚'; + $lang['strtabledroppedbad'] = '刪除資料表作業失敗。'; + $lang['strconfemptytable'] = '您確定è¦æ¸…空資料表 "%s"?'; + $lang['strtableemptied'] = 'æˆåŠŸæ¸…空資料表。'; + $lang['strtableemptiedbad'] = '清空資料表作業失敗。'; + $lang['strinsertrow'] = 'æ’入資料行'; + $lang['strrowinserted'] = 'æˆåŠŸæ’入資料行。'; + $lang['strrowinsertedbad'] = 'æ’入資料行作業失敗。'; + $lang['streditrow'] = '修改資料行'; + $lang['strrowupdated'] = 'æˆåŠŸæ›´æ–°è³‡æ–™è¡Œã€‚'; + $lang['strrowupdatedbad'] = '更新資料行作業失敗。'; + $lang['strdeleterow'] = '刪除資料行'; + $lang['strconfdeleterow'] = '您確定è¦åˆªé™¤äº›è³‡æ–™è¡Œ?'; + $lang['strrowdeleted'] = 'æˆåŠŸåˆªé™¤è³‡æ–™è¡Œã€‚'; + $lang['strrowdeletedbad'] = '資料行刪除作業失敗。'; + $lang['strsaveandrepeat'] = '儲存並é‡è¦†'; + $lang['strfield'] = '欄ä½'; + $lang['strfields'] = '欄ä½'; + $lang['strnumfields'] = '欄ä½æ•¸ç›®'; + $lang['strfieldneedsname'] = '您需為您的欄ä½å‘½å。'; + $lang['strselectallfields'] = 'é¸æ“‡æ‰€æœ‰æ¬„ä½'; + $lang['strselectneedscol'] = '至少應顯示一資料列。'; + $lang['strselectunary'] = 'ä¸èƒ½ç‚ºä¸€å…ƒé‹ç®—å­æŒ‡å®šæ•¸å€¼ã€‚'; + $lang['straltercolumn'] = '修改資料列'; + $lang['strcolumnaltered'] = 'æˆåŠŸä¿®æ”¹è³‡æ–™åˆ—。'; + $lang['strcolumnalteredbad'] = '修改資料列作業失敗。'; + $lang['strconfdropcolumn'] = '您確定è¦åˆªé™¤è³‡æ–™åˆ— "%s" 於資料表 "%s"?'; + $lang['strcolumndropped'] = 'æˆåŠŸåˆªé™¤è³‡æ–™åˆ—。'; + $lang['strcolumndroppedbad'] = '刪除資料列作業失敗。'; + $lang['straddcolumn'] = '加入新資料欄'; + $lang['strcolumnadded'] = 'æˆåŠŸåŠ å…¥è³‡æ–™æ¬„。'; + $lang['strcolumnaddedbad'] = '加入資料欄作業失敗。'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = '資料表已修改。'; + $lang['strtablealteredbad'] = '資料表修改作業失敗。'; + $lang['strdataonly'] = 'åªé¡¯ç¤ºè³‡æ–™'; + $lang['strstructureonly'] = 'åªæœ‰çµæ§‹'; + $lang['strstructureanddata'] = '資料和çµæ§‹'; + $lang['strtabbed'] = 'Tabbed'; + $lang['strauto'] = '自動'; + + // Users + $lang['struser'] = '用戶'; + $lang['strusers'] = '用戶'; + $lang['strusername'] = '用戶å'; + $lang['strpassword'] = '密碼'; + $lang['strsuper'] = '超級用戶?'; + $lang['strcreatedb'] = 'å…許建立資料庫?'; + $lang['strexpires'] = '失效'; + $lang['strsessiondefaults'] = 'é è¨­Session'; + $lang['strnousers'] = '找ä¸åˆ°æ­¤ç”¨æˆ¶ã€‚'; + $lang['struserupdated'] = 'æˆåŠŸæ›´æ–°ç”¨æˆ¶ã€‚'; + $lang['struserupdatedbad'] = '更新用戶作業失敗。'; + $lang['strshowallusers'] = '顯示所有用戶'; + $lang['strcreateuser'] = '建立新用戶'; + $lang['struserneedsname'] = '請為此用戶命戶'; + $lang['strusercreated'] = 'æˆåŠŸå»ºç«‹æ–°ç”¨æˆ¶ã€‚'; + $lang['strusercreatedbad'] = '建立新用戶作業失敗。'; + $lang['strconfdropuser'] = '您確定è¦åˆªé™¤ç”¨æˆ¶ "%s"?'; + $lang['struserdropped'] = '用戶已刪除。'; + $lang['struserdroppedbad'] = '刪除用戶作業失敗。'; + $lang['straccount'] = '帳戶'; + $lang['strchangepassword'] = '更改密碼'; + $lang['strpasswordchanged'] = 'æˆåŠŸæ›´æ”¹å¯†ç¢¼ã€‚'; + $lang['strpasswordchangedbad'] = '更改密碼作業失敗。'; + $lang['strpasswordshort'] = '密碼太短。'; + $lang['strpasswordconfirm'] = '所輸入的兩組密碼ä¸åŒã€‚'; + + // Groups + $lang['strgroup'] = '群組'; + $lang['strgroups'] = '群組'; + $lang['strnogroup'] = '找ä¸åˆ°æ­¤ç¾¤çµ„。'; + $lang['strnogroups'] = '找ä¸åˆ°ä»»ä½•ç¾¤çµ„。'; + $lang['strcreategroup'] = '建立新群組'; + $lang['strshowallgroups'] = '顯示所有群組'; + $lang['strgroupneedsname'] = '您需為您的群組命å。'; + $lang['strgroupcreated'] = 'æˆåŠŸå»ºç«‹ç¾¤çµ„。'; + $lang['strgroupcreatedbad'] = '群組建立作業失敗。'; + $lang['strconfdropgroup'] = '您確定刪除群組 "%s"?'; + $lang['strgroupdropped'] = 'æˆåŠŸåˆªé™¤ç¾¤çµ„。'; + $lang['strgroupdroppedbad'] = '刪除群組作業失敗。'; + $lang['strmembers'] = '用戶'; + $lang['straddmember'] = '新增用戶'; + $lang['strmemberadded'] = '已加入用戶。'; + $lang['strmemberaddedbad'] = '新增用戶失敗。'; + $lang['strdropmember'] = '刪除用戶'; + $lang['strconfdropmember'] = '您確定è¦åˆªé™¤ç”¨æˆ¶ "%s" 從群組 "%s"中?'; + $lang['strmemberdropped'] = '用戶已刪除。'; + $lang['strmemberdroppedbad'] = '刪除用戶作業失敗。'; + + // Privilges + $lang['strprivilege'] = '特權'; + $lang['strprivileges'] = '特權'; + $lang['strnoprivileges'] = '該物件有é è¨­çš„所屬入特權。'; + $lang['strgrant'] = '賦予'; + $lang['strrevoke'] = '撤回'; + $lang['strgranted'] = 'æˆåŠŸæ›´æ”¹ç‰¹æ¬Šã€‚'; + $lang['strgrantfailed'] = '更改特權作業失敗。'; + $lang['strgrantbad'] = '您應為一å使用者或群組指定至少一個特權。'; + $lang['stralterprivs'] = '更改特權'; + $lang['strgrantor'] = '授權者'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = '資料庫'; + $lang['strdatabases'] = '資料庫'; + $lang['strshowalldatabases'] = '顯示所有資料庫'; + $lang['strnodatabase'] = '找ä¸åˆ°æ­¤è³‡æ–™åº«ã€‚'; + $lang['strnodatabases'] = '找ä¸åˆ°ä»»ä½•è³‡æ–™åº«ã€‚'; + $lang['strcreatedatabase'] = '建立新資料庫'; + $lang['strdatabasename'] = '資料庫å'; + $lang['strdatabaseneedsname'] = '您需為您的資料庫命å。'; + $lang['strdatabasecreated'] = 'æˆåŠŸå»ºç«‹è³‡æ–™åº«ã€‚'; + $lang['strdatabasecreatedbad'] = '建立資料庫作業失敗。'; + $lang['strconfdropdatabase'] = '您確定è¦åˆªé™¤è³‡æ–™åº« "%s"?'; + $lang['strdatabasedropped'] = 'æˆåŠŸåˆªé™¤è³‡æ–™åº«ã€‚'; + $lang['strdatabasedroppedbad'] = '刪除資料庫作業失敗。'; + $lang['strentersql'] = '於下方輸入所è¦åŸ·è¡Œçš„ SQL 陳述å¼ï¼š'; + $lang['strsqlexecuted'] = 'æˆåŠŸåŸ·è¡Œ SQL 。'; + $lang['strvacuumgood'] = '清ç†(Vacuum)作業完æˆã€‚'; + $lang['strvacuumbad'] = '清ç†(Vacuum)作業失敗。'; + $lang['stranalyzegood'] = '分æžä½œæ¥­å®Œæˆã€‚'; + $lang['stranalyzebad'] = '分æžä½œæ¥­å¤±æ•—.'; + $lang['strreindexgood'] = '索引é‡å»ºå®Œæˆã€‚'; + $lang['strreindexbad'] = '索引é‡å»ºå¤±æ•—。'; + $lang['strfull'] = '完整'; + $lang['strfreeze'] = 'å‡çµ'; + $lang['strforce'] = '強制'; + + // Views + $lang['strview'] = '視表'; + $lang['strviews'] = '視表'; + $lang['strshowallviews'] = '顯示所有視表'; + $lang['strnoview'] = '找ä¸åˆ°æ­¤è¦–表。'; + $lang['strnoviews'] = '找ä¸åˆ°ä»»ä½•è¦–表。'; + $lang['strcreateview'] = '建立新視表'; + $lang['strviewname'] = '視表å'; + $lang['strviewneedsname'] = '您需為您的視表命å。'; + $lang['strviewneedsdef'] = '您必須定義你的視表。'; + $lang['strviewneedsfields'] = 'è«‹é¸æ“‡è¦åŠ å…¥è¦–表的資料欄。'; + $lang['strviewcreated'] = 'æˆåŠŸå»ºç«‹æ–°è¦–表。'; + $lang['strviewcreatedbad'] = '建立新視表作業失敗'; + $lang['strconfdropview'] = '您確定è¦åˆªé™¤è¦–表 "%s"?'; + $lang['strviewdropped'] = 'æˆåŠŸåˆªé™¤è¦–表。'; + $lang['strviewdroppedbad'] = '刪除視表作業失敗。'; + $lang['strviewupdated'] = 'æˆåŠŸæ›´æ–°è¦–表。'; + $lang['strviewupdatedbad'] = '更新視表作業失敗。'; + $lang['strviewlink'] = '連çµç´¢å¼•'; + $lang['strviewconditions'] = 'é¡å¤–æ¢ä»¶'; + $lang['strcreateviewwiz'] = '使用視表精éˆ'; + + // Sequences + $lang['strsequence'] = 'åºåˆ—'; + $lang['strsequences'] = 'åºåˆ—'; + $lang['strshowallsequences'] = '顯示所有åºåˆ—'; + $lang['strnosequence'] = '找ä¸åˆ°æ­¤åºåˆ—。'; + $lang['strnosequences'] = '找ä¸åˆ°ä»»ä½•åºåˆ—。'; + $lang['strcreatesequence'] = '建立新åºåˆ—'; + $lang['strlastvalue'] = 'çµæŸå€¼'; + $lang['strincrementby'] = 'å¢žé‡ (加/減) '; + $lang['strstartvalue'] = '啟始值'; + $lang['strmaxvalue'] = '最大值'; + $lang['strminvalue'] = '最少值'; + $lang['strcachevalue'] = 'å¿«å–值'; + $lang['strlogcount'] = '登錄數é‡'; + $lang['striscycled'] = '循環?'; + $lang['strsequenceneedsname'] = '您需為您的åºåˆ—命å。'; + $lang['strsequencecreated'] = 'æˆåŠŸå»ºç«‹æ–°åºåˆ—。'; + $lang['strsequencecreatedbad'] = '建立新åºåˆ—作業失敗。'; + $lang['strconfdropsequence'] = '您確定è¦åˆªé™¤åºåˆ— "%s"?'; + $lang['strsequencedropped'] = 'æˆåŠŸåˆªé™¤åºåˆ—。'; + $lang['strsequencedroppedbad'] = '刪除åºåˆ—作業失敗。'; + $lang['strsequencereset'] = 'å·²é‡è¨­åºåˆ—。'; + $lang['strsequenceresetbad'] = 'é‡è¨­åºåˆ—失敗。'; + + // Indexes + $lang['strindex'] = '索引'; + $lang['strindexes'] = '索引'; + $lang['strindexname'] = '索引å'; + $lang['strshowallindexes'] = '顯示所有的索引'; + $lang['strnoindex'] = '找ä¸åˆ°æ­¤ç´¢å¼•ã€‚'; + $lang['strnoindexes'] = '找ä¸åˆ°ä»»ä½•ç´¢å¼•ã€‚'; + $lang['strcreateindex'] = '建立新索引'; + $lang['strtabname'] = '檢索å'; + $lang['strcolumnname'] = '資料列å'; + $lang['strindexneedsname'] = '您需為您的索引命å。'; + $lang['strindexneedscols'] = '索引應有一定數å•çš„資料列。'; + $lang['strindexcreated'] = 'æˆåŠŸå»ºç«‹æ–°ç´¢å¼•'; + $lang['strindexcreatedbad'] = '建立索引作業失敗。'; + $lang['strconfdropindex'] = '您確定è¦åˆªé™¤ç´¢å¼• "%s"?'; + $lang['strindexdropped'] = 'æˆåŠŸåˆªé™¤ç´¢å¼•ã€‚'; + $lang['strindexdroppedbad'] = '刪除索引作業失敗。'; + $lang['strkeyname'] = 'éµå'; + $lang['struniquekey'] = 'ç¨ä¸€éµ'; + $lang['strprimarykey'] = '主索引éµ'; + $lang['strindextype'] = '索引類型'; + $lang['strtablecolumnlist'] = '資料表所å«çš„資料列'; + $lang['strindexcolumnlist'] = '索引所å«çš„資料列'; + $lang['strconfcluster'] = '您確定è¦å¢é›† "%s"?'; + $lang['strclusteredgood'] = 'å¢é›†å®Œæˆã€‚'; + $lang['strclusteredbad'] = 'å¢é›†å¤±æ•—。'; + + // Rules + $lang['strrules'] = 'è¦å‰‡'; + $lang['strrule'] = 'è¦å‰‡'; + $lang['strshowallrules'] = '顯示所有的è¦å‰‡'; + $lang['strnorule'] = '找ä¸åˆ°æ­¤è¦å‰‡ã€‚'; + $lang['strnorules'] = '找ä¸åˆ°ä»»ä½•è¦å‰‡ã€‚'; + $lang['strcreaterule'] = '建立新è¦å‰‡'; + $lang['strrulename'] = 'è¦å‰‡å'; + $lang['strruleneedsname'] = '您需為您的è¦å‰‡å‘½å。'; + $lang['strrulecreated'] = 'æˆåŠŸå»ºç«‹æ–°è¦å‰‡ã€‚'; + $lang['strrulecreatedbad'] = '建立新è¦å‰‡ä½œæ¥­å¤±æ•—。'; + $lang['strconfdroprule'] = '您確定è¦åˆªé™¤ "%s" æ–¼ "%s"?'; + $lang['strruledropped'] = 'æˆåŠŸåˆªé™¤è¦å‰‡ã€‚'; + $lang['strruledroppedbad'] = '刪除è¦å‰‡ä½œæ¥­å¤±æ•—。'; + + // Constraints + $lang['strconstraints'] = 'ç´„æŸ'; + $lang['strshowallconstraints'] = '顯示所有的約æŸ'; + $lang['strnoconstraints'] = '找ä¸åˆ°æ­¤ç´„æŸã€‚'; + $lang['strcreateconstraint'] = '建立新約æŸ'; + $lang['strconstraintcreated'] = 'æˆåŠŸå»ºç«‹æ–°ç´„æŸã€‚'; + $lang['strconstraintcreatedbad'] = '新建約æŸä½œæ¥­å¤±æ•—。'; + $lang['strconfdropconstraint'] = '您確定è¦åˆªé™¤ç´„æŸ "%s" æ–¼ "%s"?'; + $lang['strconstraintdropped'] = 'æˆåŠŸåˆªé™¤ç´„æŸã€‚'; + $lang['strconstraintdroppedbad'] = '刪除約æŸä½œæ¥­å¤±æ•—。'; + $lang['straddcheck'] = '加入新查驗 (check)'; + $lang['strcheckneedsdefinition'] = '您需定義您的查驗 (check)。'; + $lang['strcheckadded'] = 'æˆåŠŸåŠ å…¥æ–°æŸ¥é©— (check)。'; + $lang['strcheckaddedbad'] = '加入新查驗 (check) 作業失敗。'; + $lang['straddpk'] = '加入主索引éµ'; + $lang['strpkneedscols'] = '主索引éµè‡³å°‘應包å«ä¸€å€‹è³‡æ–™è¡Œã€‚'; + $lang['strpkadded'] = 'æˆåŠŸåŠ å…¥ä¸»ç´¢å¼•éµã€‚'; + $lang['strpkaddedbad'] = '加入主索引éµä½œä½œæ¥­å¤±æ•—。'; + $lang['stradduniq'] = '加入ç¨ä¸€éµ'; + $lang['struniqneedscols'] = 'ç¨ä¸€éµè‡³å°‘應包å«ä¸€å€‹è³‡æ–™è¡Œã€‚'; + $lang['struniqadded'] = 'æˆåŠŸåŠ å…¥ç¨ä¸€éµã€‚'; + $lang['struniqaddedbad'] = '加入ç¨ä¸€éµä½œæ¥­å¤±æ•—。'; + $lang['straddfk'] = '加入外部索引éµ'; + $lang['strfkneedscols'] = '外部索引éµè‡³å°‘應包å«ä¸€å€‹è³‡æ–™è¡Œã€‚'; + $lang['strfkneedstarget'] = '外部索引éµéœ€åƒç…§ç›®æ¨™è³‡æ–™è¡¨ã€‚'; + $lang['strfkadded'] = 'æˆåŠŸåŠ å…¥å¤–部索引éµã€‚'; + $lang['strfkaddedbad'] = '加入外部索引éµä½œæ¥­å¤±æ•—。'; + $lang['strfktarget'] = '目標資料表'; + $lang['strfkcolumnlist'] = 'éµæ‰€å«çš„資料行'; + $lang['strondelete'] = '於刪除時'; + $lang['stronupdate'] = '於更改時'; + + // Functions + $lang['strfunction'] = '函數'; + $lang['strfunctions'] = '函數'; + $lang['strshowallfunctions'] = '顯示所有的函數'; + $lang['strnofunction'] = '找ä¸åˆ°æ­¤å‡½æ•¸ã€‚'; + $lang['strnofunctions'] = '找ä¸åˆ°ä»»ä½•å‡½æ•¸ã€‚'; + $lang['strcreatefunction'] = '建立新函數'; + $lang['strfunctionname'] = '函數å'; + $lang['strreturns'] = '返回'; + $lang['strarguments'] = 'åƒæ•¸'; + $lang['strproglanguage'] = '程å¼èªžè¨€'; + $lang['strfunctionneedsname'] = '您需為您的函數命å。'; + $lang['strfunctionneedsdef'] = '您必須定義您的函數。'; + $lang['strfunctioncreated'] = 'æˆåŠŸå»ºç«‹æ–°å‡½æ•¸ã€‚'; + $lang['strfunctioncreatedbad'] = '新建函數作業失敗。'; + $lang['strconfdropfunction'] = '您確定è¦åˆªé™¤å‡½æ•¸ "%s"?'; + $lang['strfunctiondropped'] = 'æˆåŠŸåˆªé™¤å‡½æ•¸ã€‚'; + $lang['strfunctiondroppedbad'] = '刪除函數作業失敗。'; + $lang['strfunctionupdated'] = 'æˆåŠŸæ›´æ”¹å‡½æ•¸ã€‚'; + $lang['strfunctionupdatedbad'] = '更改函數作業失敗。'; + + // Triggers + $lang['strtrigger'] = '觸發器'; + $lang['strtriggers'] = '觸發器'; + $lang['strshowalltriggers'] = '顯示所有的觸發器'; + $lang['strnotrigger'] = '找ä¸åˆ°æ­¤è§¸ç™¼å™¨ã€‚'; + $lang['strnotriggers'] = '找ä¸åˆ°ä»»ä½•è§¸ç™¼å™¨ã€‚'; + $lang['strcreatetrigger'] = '建立新觸發器'; + $lang['strtriggerneedsname'] = '您需為您的觸發器命å。'; + $lang['strtriggerneedsfunc'] = '您必須為你的觸發器指定一個函數。'; + $lang['strtriggercreated'] = 'æˆåŠŸå»ºç«‹æ–°è§¸ç™¼å™¨ã€‚'; + $lang['strtriggercreatedbad'] = '建立觸發器作業失敗。'; + $lang['strconfdroptrigger'] = '您確定è¦åˆªé™¤è§¸ç™¼å™¨ "%s" æ–¼ "%s"?'; + $lang['strtriggerdropped'] = 'æˆåŠŸåˆªé™¤è§¸ç™¼å™¨ã€‚'; + $lang['strtriggerdroppedbad'] = '刪除觸發器作業失敗。'; + $lang['strtriggeraltered'] = '觸發器已修改。'; + $lang['strtriggeralteredbad'] = '修改觸發器作業失敗。'; + + // Types + $lang['strtype'] = 'é¡žåž‹'; + $lang['strtypes'] = 'é¡žåž‹'; + $lang['strshowalltypes'] = '顯示所有的類型'; + $lang['strnotype'] = '找ä¸åˆ°æ­¤é¡žåž‹ã€‚'; + $lang['strnotypes'] = '找ä¸åˆ°ä»»ä½•é¡žåž‹ã€‚'; + $lang['strcreatetype'] = '建立新類型'; + $lang['strtypename'] = 'é¡žåž‹å'; + $lang['strinputfn'] = '輸入函數'; + $lang['stroutputfn'] = '輸出函數'; + $lang['strpassbyval'] = '以值傳é€?'; + $lang['stralignment'] = '排列'; + $lang['strelement'] = '元素'; + $lang['strdelimiter'] = '分隔符號'; + $lang['strstorage'] = '儲存'; + $lang['strtypeneedsname'] = '您需為您的類型命å。'; + $lang['strtypeneedslen'] = '您必須指定您的類型的長度。'; + $lang['strtypecreated'] = 'æˆåŠŸå»ºç«‹æ–°é¡žåž‹'; + $lang['strtypecreatedbad'] = ' 建立類型作業失敗。'; + $lang['strconfdroptype'] = '您確定è¦åˆªé™¤é¡žåž‹ "%s"?'; + $lang['strtypedropped'] = 'æˆåŠŸåˆªé™¤é¡žåž‹ã€‚'; + $lang['strtypedroppedbad'] = '刪除類型作業失敗。'; + + // Schemas + $lang['strschema'] = '模å¼'; + $lang['strschemas'] = '模å¼'; + $lang['strshowallschemas'] = '顯示所有的模å¼'; + $lang['strnoschema'] = '找ä¸åˆ°æ­¤æ¨¡å¼'; + $lang['strnoschemas'] = '找ä¸åˆ°ä»»ä½•æ¨¡å¼ã€‚'; + $lang['strcreateschema'] = '建立新模å¼'; + $lang['strschemaname'] = '模å¼å'; + $lang['strschemaneedsname'] = '您需為您的模å¼å‘½å。'; + $lang['strschemacreated'] = 'æˆåŠŸå»ºç«‹æ–°æ¨¡å¼ã€‚'; + $lang['strschemacreatedbad'] = '建立模å¼ä½œæ¥­å¤±æ•—。'; + $lang['strconfdropschema'] = '您確定è¦åˆªé™¤æ¨¡å¼ "%s"?'; + $lang['strschemadropped'] = 'æˆåŠŸåˆªé™¤æ¨¡å¼ã€‚ '; + $lang['strschemadroppedbad'] = '刪除模å¼ä½œæ¥­å¤±æ•—。'; + $lang['strschemaaltered'] = 'æˆåŠŸä¿®æ”¹æ¨¡å¼'; + $lang['strschemaalteredbad'] = '修改模å¼å¤±æ•—。'; + + // Reports + + // Domains + $lang['strdomain'] = '領域'; + $lang['strdomains'] = '領域'; + $lang['strshowalldomains'] = '顯示所有領域'; + $lang['strnodomains'] = '找ä¸åˆ°ä»»ä½•é ˜åŸŸã€‚'; + $lang['strcreatedomain'] = '新建領域'; + $lang['strdomaindropped'] = '領域已刪除。'; + $lang['strdomaindroppedbad'] = '領域刪除作業失敗。'; + $lang['strconfdropdomain'] = '您確定è¦åˆªé™¤é ˜åŸŸ "%s"?'; + $lang['strdomainneedsname'] = '您需為此領域命å。'; + $lang['strdomaincreated'] = '領域已建立。'; + $lang['strdomaincreatedbad'] = '新建領域作業失敗。'; + $lang['strdomainaltered'] = '領域已修改。'; + $lang['strdomainalteredbad'] = '修改領域作業失敗。'; + + // Operators + $lang['stroperator'] = 'é‹ç®—å­'; + $lang['stroperators'] = 'é‹ç®—å­'; + $lang['strshowalloperators'] = '顯示所有é‹ç®—å­s'; + $lang['strnooperator'] = '找ä¸åˆ°é‹ç®—å­ã€‚'; + $lang['strnooperators'] = '找ä¸åˆ°ä»»ä½•é‹ç®—å­ã€‚'; + $lang['strcreateoperator'] = '新建é‹ç®—å­'; + $lang['strleftarg'] = '左引數型態'; + $lang['strrightarg'] = 'å³å¼•æ•¸åž‹æ…‹'; + $lang['strcommutator'] = '轉æ›å™¨'; + $lang['strnegator'] = 'å¦å®šå™¨'; + $lang['strrestrict'] = 'é™åˆ¶'; + $lang['strjoin'] = 'çµåˆ'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'åˆä½µ'; + $lang['strleftsort'] = '左排åº'; + $lang['strrightsort'] = 'å³æŽ’åº'; + $lang['strlessthan'] = 'å°æ–¼'; + $lang['strgreaterthan'] = '大於'; + $lang['stroperatorneedsname'] = '您需為您的é‹ç®—å­å‘½å。'; + $lang['stroperatorcreated'] = 'é‹ç®—å­å·²å»ºç«‹'; + $lang['stroperatorcreatedbad'] = 'é‹ç®—å­æ–°å»ºä½œæ¥­å¤±æ•—。'; + $lang['strconfdropoperator'] = '您確定è¦åˆªé™¤é‹ç®—å­ "%s"?'; + $lang['stroperatordropped'] = 'é‹ç®—å­å·²åˆªé™¤ã€‚'; + $lang['stroperatordroppedbad'] = 'é‹ç®—å­åˆªé™¤å¤±æ•—。'; + + // Casts + $lang['strcasts'] = '型別轉æ›'; + $lang['strnocasts'] = '找ä¸åˆ°åž‹åˆ¥è½‰æ›ã€‚'; + $lang['strsourcetype'] = '原始型別'; + $lang['strtargettype'] = '目摽型別'; + $lang['strimplicit'] = 'éš±å«'; + $lang['strinassignment'] = '指派中'; + $lang['strbinarycompat'] = '(二元相符)'; + + // Conversions + $lang['strconversions'] = '轉æ›'; + $lang['strnoconversions'] = '找ä¸åˆ°è½‰æ›ã€‚'; + $lang['strsourceencoding'] = '原始編碼'; + $lang['strtargetencoding'] = '目標編碼'; + + // Languages + $lang['strlanguages'] = '語言'; + $lang['strnolanguages'] = '找ä¸åˆ°èªžè¨€ã€‚'; + $lang['strtrusted'] = 'å—信任的'; + + // Info + $lang['strnoinfo'] = '無法å–得資訊。'; + $lang['strreferringtables'] = 'åƒç…§è³‡æ–™è¡¨'; + $lang['strparenttables'] = '父資料表'; + $lang['strchildtables'] = 'å­è³‡æ–™è¡¨'; + + // Aggregates + $lang['straggregates'] = '匯總'; + $lang['strnoaggregates'] = '找ä¸åˆ°ä»»ä½•åŒ¯ç¸½ã€‚'; + $lang['stralltypes'] = '(全部類型)'; + + // Operator Classes + $lang['stropclasses'] = 'é‹ç®—å­é¡žåˆ¥'; + $lang['strnoopclasses'] = '找ä¸åˆ°ä»»ä½•é‹ç®—類別。'; + $lang['straccessmethod'] = '拒絕存å–'; + + // Stats and performance + $lang['strrowperf'] = '資料行效率'; + $lang['strioperf'] = 'I/O效率'; + $lang['stridxrowperf'] = '索引行效率'; + $lang['stridxioperf'] = '索引I/O效率'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = '循åº'; + $lang['strscan'] = '掃æ'; + $lang['strread'] = '讀å–'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST索引'; + $lang['strcache'] = 'å¿«å–'; + $lang['strdisk'] = 'ç£ç¢Ÿ'; + $lang['strrows2'] = '資料行'; + + // Miscellaneous + $lang['strtopbar'] = '%s 執行於 %s:%s ï¼ æ‚¨æ˜¯ "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = '說明'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_CN.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_CN.php new file mode 100644 index 00000000..d2f2a29a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_CN.php @@ -0,0 +1,902 @@ +>'; + $lang['strfailed'] = '失败'; + $lang['strcreate'] = '创建'; + $lang['strcreated'] = '已创建'; + $lang['strcomment'] = '注释'; + $lang['strlength'] = '长度'; + $lang['strdefault'] = '默认'; + $lang['stralter'] = 'å˜æ›´'; + $lang['strok'] = '确认'; + $lang['strcancel'] = 'å–消'; + $lang['strkill'] = '终止'; + $lang['strac'] = '自动完æˆæœ‰æ•ˆ'; + $lang['strsave'] = 'ä¿å­˜'; + $lang['strreset'] = 'é‡ç½®'; + $lang['strrestart'] = 'é‡å¯'; + $lang['strinsert'] = 'æ’å…¥'; + $lang['strselect'] = '选择'; + $lang['strdelete'] = '删除'; + $lang['strupdate'] = 'æ›´æ–°'; + $lang['strreferences'] = 'å‚考'; + $lang['stryes'] = '是'; + $lang['strno'] = 'å¦'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = '编辑'; + $lang['strcolumn'] = '列'; + $lang['strcolumns'] = '列'; + $lang['strrows'] = 'è¡Œ'; + $lang['strrowsaff'] = '行已影å“(å˜æ›´ï¼‰ã€‚'; + $lang['strobjects'] = '对象'; + $lang['strback'] = '返回'; + $lang['strqueryresults'] = '查询结果'; + $lang['strshow'] = '显示'; + $lang['strempty'] = '清空'; + $lang['strlanguage'] = '语言'; + $lang['strencoding'] = 'ç¼–ç '; + $lang['strvalue'] = '值'; + $lang['strunique'] = '唯一'; + $lang['strprimary'] = '主'; + $lang['strexport'] = '导出'; + $lang['strimport'] = '导入'; + $lang['strallowednulls'] = 'å…许空串'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = '空 字符串/字段'; + $lang['strsql'] = 'SQLç '; + $lang['stradmin'] = '管ç†'; + $lang['strvacuum'] = '清ç†'; + $lang['stranalyze'] = '分æž'; + $lang['strclusterindex'] = '集群'; + $lang['strclustered'] = '集群?'; + $lang['strreindex'] = 'é‡å»ºç´¢å¼•'; + $lang['strexecute'] = '执行'; + $lang['stradd'] = '添加'; + $lang['strevent'] = '事件'; + $lang['strwhere'] = 'Where'; + $lang['strinstead'] = 'Do Instead'; + $lang['strwhen'] = '当'; + $lang['strformat'] = 'æ ¼å¼'; + $lang['strdata'] = 'æ•°æ®'; + $lang['strconfirm'] = '确认'; + $lang['strexpression'] = '表达å¼'; + $lang['strellipsis'] = '。。。'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = '扩展'; + $lang['strcollapse'] = '崩溃'; + $lang['strfind'] = '查找'; + $lang['stroptions'] = '选项'; + $lang['strrefresh'] = '刷新'; + $lang['strdownload'] = '下载'; + $lang['strdownloadgzipped'] = '下载使用gzip压缩的文件'; + $lang['strinfo'] = 'ä¿¡æ¯'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = '高级'; + $lang['strvariables'] = 'å˜é‡'; + $lang['strprocess'] = '进程'; + $lang['strprocesses'] = '进程'; + $lang['strsetting'] = '设置'; + $lang['streditsql'] = '编辑 SQL'; + $lang['strruntime'] = '总执行时间: %s ms'; + $lang['strpaginate'] = '分页结果'; + $lang['struploadscript'] = '或者上传一个 SQL 脚本:'; + $lang['strstarttime'] = '开始时间'; + $lang['strfile'] = '文件'; + $lang['strfileimported'] = '文件已导入。'; + $lang['strtrycred'] = '对所有æœåŠ¡å™¨ä½¿ç”¨è¯¥ç”¨æˆ·å和密ç '; + $lang['strconfdropcred'] = '因为安全原因,中断连接将会销æ¯ä½ çš„登录信æ¯ã€‚你确定è¦ä¸­æ–­è¿žæŽ¥å—?'; + $lang['stractionsonmultiplelines'] = '多行上的æ“作'; + $lang['strselectall'] = '选择所有'; + $lang['strunselectall'] = 'å–消选择所有'; + $lang['strlocale'] = '本地'; + $lang['strcollation'] = '校对'; + $lang['strctype'] = '字符类型'; + $lang['strdefaultvalues'] = '默认值'; + $lang['strnewvalues'] = '新值'; + $lang['strstart'] = 'å¯åŠ¨'; + $lang['strstop'] = 'åœæ­¢'; + $lang['strgotoppage'] = '回到顶端'; + $lang['strtheme'] = '主题'; + $lang['strcluster'] = '集群'; + + // Admin + $lang['stradminondatabase'] = '以下管ç†åŠŸèƒ½å¯åº”用于数æ®åº“ %s.'; + $lang['stradminontable'] = '以下管ç†åŠŸèƒ½å¯åº”用于表 %s.'; + + // User-supplied SQL history + $lang['strhistory'] = '历å²'; + $lang['strnohistory'] = '无历å².'; + $lang['strclearhistory'] = '清空历å²'; + $lang['strdelhistory'] = '从历å²åˆ é™¤'; + $lang['strconfdelhistory'] = '确定è¦ä»ŽåŽ†å²åˆ é™¤å— ?'; + $lang['strconfclearhistory'] = '确定è¦æ¸…空历å²å— ?'; + $lang['strnodatabaseselected'] = '请选择一个数æ®åº“.'; + + // Database sizes + $lang['strnoaccess'] = '无法访问'; + $lang['strsize'] = '大å°'; + $lang['strbytes'] = '字节'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = '该程åºåœ¨å…·æœ‰æ¡†æž¶åŠŸèƒ½çš„æµè§ˆå™¨ä¸Šå·¥ä½œçš„更好,请按下é¢çš„链接在ä¸æ”¯æŒæ¡†æž¶çš„æµè§ˆå™¨ä¸Šå·¥ä½œã€‚'; + $lang['strnoframeslink'] = 'ä¸ä½¿ç”¨æ¡†æž¶'; + $lang['strbadconfig'] = '您的 config.inc.php 已失效。您需è¦è‡ªè¡Œé€šè¿‡ config.inc.php-ist æ¢å¤ã€‚'; + $lang['strnotloaded'] = '您安装的 PHP ä¸æ”¯æŒPostgreSQL。 你需è¦é‡æ–°ç¼–译PHP并使用 --with-pgsql é…置选项。'; + $lang['strpostgresqlversionnotsupported'] = '旧版本的PostgreSQLä¸è¢«æ”¯æŒã€‚ 请更新到版本 %s 或更高版本。'; + $lang['strbadschema'] = '无效的模å¼ã€‚'; + $lang['strbadencoding'] = '设定客户端编ç é”™è¯¯ã€‚'; + $lang['strsqlerror'] = 'SQL:错误'; + $lang['strinstatement'] = '在语å¥ï¼š'; + $lang['strinvalidparam'] = '无效的脚本å‚数。'; + $lang['strnodata'] = '查无数æ®è¡Œã€‚'; + $lang['strnoobjects'] = '查无对象。'; + $lang['strrownotunique'] = '该行无唯一约æŸã€‚'; + $lang['strnouploads'] = '文件上传被ç¦æ­¢ã€‚'; + $lang['strimporterror'] = '导入错误。'; + $lang['strimporterror-fileformat'] = '导入错误: 自动识别文件类型失败。'; + $lang['strimporterrorline'] = '导入错误,出错行 %s。'; + $lang['strimporterrorline-badcolumnnum'] = '导入错误,出错行 %s: 该行列数ä¸æ­£ç¡®ã€‚'; + $lang['strimporterror-uploadedfile'] = '导入错误: 文件ä¸èƒ½ä¸Šä¼ åˆ°æœåŠ¡å™¨'; + $lang['strcannotdumponwindows'] = 'å¤æ‚表和模å¼å称的转储在Windows ä¸è¢«æ”¯æŒã€‚'; + $lang['strinvalidserverparam'] = 'å°è¯•ç”¨æ— æ•ˆçš„æœåŠ¡å™¨å‚数连接,å¯èƒ½æœ‰äººæ­£å°è¯•æ”»å‡»ä½ çš„系统。'; + $lang['strnoserversupplied'] = '没有选择数æ®åº“!'; + $lang['strbadpgdumppath'] = '导出错误:在 conf/config.inc.php 中指定的路径 %s 下执行pg_dump失败。请在é…置中修改路径并é‡æ–°ç™»å½•ã€‚'; + $lang['strbadpgdumpallpath'] = '导出错误:在 conf/config.inc.php 中指定的路径 %s 下执行pg_dumpall失败。请在é…置中修改路径并é‡æ–°ç™»å½•ã€‚'; + $lang['strconnectionfail'] = '无法连接æœåŠ¡å™¨ã€‚'; + + // Tables + $lang['strtable'] = 'æ•°æ®è¡¨'; + $lang['strtables'] = 'æ•°æ®è¡¨'; + $lang['strshowalltables'] = '显示示所有表。'; + $lang['strnotables'] = '查无数æ®è¡¨ã€‚'; + $lang['strnotable'] = '查无此表。'; + $lang['strcreatetable'] = '创建表'; + $lang['strcreatetablelike'] = '创建表(以现有表为模æ¿)'; + $lang['strcreatetablelikeparent'] = 'æºè¡¨'; + $lang['strcreatelikewithdefaults'] = '包å«é»˜è®¤å€¼'; + $lang['strcreatelikewithconstraints'] = '包å«çº¦æŸ'; + $lang['strcreatelikewithindexes'] = '包å«è¡¨å'; + $lang['strtablename'] = '表å'; + $lang['strtableneedsname'] = '必须指定表å。'; + $lang['strtablelikeneedslike'] = '必须指定è¦æ‹·è´çš„属性所属的数æ®è¡¨.'; + $lang['strtableneedsfield'] = '必须至少指定一个字段。'; + $lang['strtableneedscols'] = '必须指定一个有效的列数。'; + $lang['strtablecreated'] = 'æ•°æ®è¡¨å·²åˆ›å»ºã€‚'; + $lang['strtablecreatedbad'] = 'æ•°æ®è¡¨åˆ›å»ºå¤±è´¥'; + $lang['strconfdroptable'] = '确定è¦åˆ é™¤"%s"æ•°æ®è¡¨å—?'; + $lang['strtabledropped'] = 'æ•°æ®è¡¨å·²åˆ é™¤ã€‚'; + $lang['strtabledroppedbad'] = 'æ•°æ®è¡¨åˆ é™¤å¤±è´¥ã€‚'; + $lang['strconfemptytable'] = '确定è¦æ¸…空"%s"æ•°æ®è¡¨å—?'; + $lang['strtableemptied'] = 'æ•°æ®è¡¨å·²æ¸…空。'; + $lang['strtableemptiedbad'] = 'æ•°æ®è¡¨æ¸…空失败。'; + $lang['strinsertrow'] = 'æ’入行'; + $lang['strrowinserted'] = '行已æ’入。'; + $lang['strrowinsertedbad'] = 'è¡Œæ’入失败。'; + $lang['strnofkref'] = '在外键 %s 中找ä¸åˆ°ç›¸åº”的值。'; + $lang['strrowduplicate'] = 'è¡Œæ’入失败, å°è¯•å†æ¬¡æ’入。'; + $lang['streditrow'] = '编辑行'; + $lang['strrowupdated'] = '行已更新。'; + $lang['strrowupdatedbad'] = '行更新失败。'; + $lang['strdeleterow'] = '删除行'; + $lang['strconfdeleterow'] = '确定è¦åˆ é™¤è¯¥è¡Œå—?'; + $lang['strrowdeleted'] = '行已删除。'; + $lang['strrowdeletedbad'] = '行删除失败。'; + $lang['strinsertandrepeat'] = 'æ’å…¥ & 替æ¢'; + $lang['strnumcols'] = '列数目'; + $lang['strcolneedsname'] = '必须指定列å'; + $lang['strselectallfields'] = '选择所有字段'; + $lang['strselectneedscol'] = '必须至少显示一列。'; + $lang['strselectunary'] = 'å•é¡¹æ“作ä¸èƒ½æœ‰å€¼ã€‚'; + $lang['strcolumnaltered'] = '列已å˜æ›´ã€‚'; + $lang['strcolumnalteredbad'] = '列å˜æ›´å¤±è´¥ã€‚'; + $lang['strconfdropcolumn'] = '确定è¦å°†åˆ— "%s" 从表 "%s" 中删除å—?'; + $lang['strcolumndropped'] = '列已删除。'; + $lang['strcolumndroppedbad'] = '列删除失败。'; + $lang['straddcolumn'] = '添加列'; + $lang['strcolumnadded'] = '列已添加。'; + $lang['strcolumnaddedbad'] = '列添加失败。'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'æ•°æ®è¡¨å·²å˜æ›´ã€‚'; + $lang['strtablealteredbad'] = 'æ•°æ®è¡¨å˜æ›´å¤±è´¥ã€‚'; + $lang['strdataonly'] = 'ä»…æ•°æ®'; + $lang['strstructureonly'] = '仅结构'; + $lang['strstructureanddata'] = '结构和数æ®'; + $lang['strtabbed'] = '固定(Tabbed)'; + $lang['strauto'] = '自动'; + $lang['strconfvacuumtable'] = '确定è¦æ¸…ç† "%s" å—?'; + $lang['strconfanalyzetable'] = '确定è¦åˆ†æž "%s" å—?'; + $lang['strconfreindextable'] = '确定è¦é‡æ–°ç´¢å¼• "%s" å—?'; + $lang['strconfclustertable'] = '确定è¦é›†ç¾¤ "%s" å—?'; + $lang['strestimatedrowcount'] = '估计的行数'; + $lang['strspecifytabletoanalyze'] = '必须至少选择一个表æ¥åˆ†æž'; + $lang['strspecifytabletoempty'] = '必须至少选择一个表æ¥æ¸…空'; + $lang['strspecifytabletodrop'] = '必须至少选择一个表æ¥ç§»é™¤'; + $lang['strspecifytabletovacuum'] = '必须至少选择一个表æ¥æ¸…ç†ï¼ˆvacuum)'; + $lang['strspecifytabletoreindex'] = '必须至少选择一个è¦é‡æ–°ç´¢å¼•çš„表。'; + $lang['strspecifytabletocluster'] = '必须至少选择一个è¦é›†ç¾¤çš„表。'; + $lang['strnofieldsforinsert'] = '无法在没有任何列定义的表中æ’入数æ®ã€‚'; + + // Columns + $lang['strcolprop'] = '列属性'; + $lang['strnotableprovided'] = '没有相应的表!'; + + // Users + $lang['struser'] = '用户'; + $lang['strusers'] = '用户'; + $lang['strusername'] = '用å'; + $lang['strpassword'] = '密ç '; + $lang['strsuper'] = '超级用户'; + $lang['strcreatedb'] = '创建数æ®åº“?'; + $lang['strexpires'] = '过期'; + $lang['strsessiondefaults'] = '会è¯é»˜è®¤'; + $lang['strnousers'] = '查无此用户。'; + $lang['struserupdated'] = '用户已更新。'; + $lang['struserupdatedbad'] = '用户更新失败。'; + $lang['strshowallusers'] = '显示所有用户'; + $lang['strcreateuser'] = '创建用户'; + $lang['struserneedsname'] = '必须指定用户å称。'; + $lang['strusercreated'] = '用户已创建。'; + $lang['strusercreatedbad'] = '用户创建失败。'; + $lang['strconfdropuser'] = '确定è¦åˆ é™¤ç”¨æˆ·"%s"å—?'; + $lang['struserdropped'] = '用户已删除。'; + $lang['struserdroppedbad'] = '用户删除失败。'; + $lang['straccount'] = 'å¸æˆ·'; + $lang['strchangepassword'] = '修改密ç '; + $lang['strpasswordchanged'] = '密ç å·²ä¿®æ”¹ã€‚'; + $lang['strpasswordchangedbad'] = '密ç ä¿®æ”¹å¤±è´¥ã€‚'; + $lang['strpasswordshort'] = '密ç å¤ªçŸ­äº†ã€‚'; + $lang['strpasswordconfirm'] = '密ç ä¸åŒ¹é…。'; + + // Groups + $lang['strgroup'] = '群组'; + $lang['strgroups'] = '群组'; + $lang['strgroupgroups'] = '在"%s"中的群组'; + $lang['strshowallgroups'] = '显示所有群组'; + $lang['strnogroup'] = '查无此群组。'; + $lang['strnogroups'] = '查无群组。'; + $lang['strcreategroup'] = '创建群组'; + $lang['strgroupneedsname'] = '必须指定群组å称。'; + $lang['strgroupcreated'] = '群组已创建。'; + $lang['strgroupcreatedbad'] = '群组创建失败。'; + $lang['strconfdropgroup'] = '确定è¦åˆ é™¤ç¾¤ç»„"%s"å—?'; + $lang['strgroupdropped'] = '群组已删除。'; + $lang['strgroupdroppedbad'] = '群组删除失败。'; + $lang['strmembers'] = 'æˆå‘˜'; + $lang['strmemberof'] = '所属æˆå‘˜'; + $lang['stradminmembers'] = '管ç†æˆå‘˜'; + $lang['straddmember'] = '添加æˆå‘˜'; + $lang['strmemberadded'] = 'æˆå‘˜å·²æ·»åŠ ã€‚'; + $lang['strmemberaddedbad'] = 'æˆå‘˜æ·»åŠ å¤±è´¥ã€‚'; + $lang['strdropmember'] = '删除æˆå‘˜'; + $lang['strconfdropmember'] = '确定è¦å°†æˆå‘˜ "%s" 从群组 "%s"中删除å—?'; + $lang['strmemberdropped'] = 'æˆå‘˜å·²åˆ é™¤ã€‚'; + $lang['strmemberdroppedbad'] = 'æˆå‘˜åˆ é™¤å¤±è´¥ã€‚'; + + // Roles + $lang['strrole'] = '角色'; + $lang['strroles'] = '角色'; + $lang['strshowallroles'] = '显示所有角色'; + $lang['strnoroles'] = '查无角色。'; + $lang['strinheritsprivs'] = '继承æƒé™?'; + $lang['strcreaterole'] = '创建角色'; + $lang['strcancreaterole'] = '创建角色?'; + $lang['strrolecreated'] = '角色已创建。'; + $lang['strrolecreatedbad'] = '角色创建失败。'; + $lang['strrolealtered'] = '角色已å˜æ›´ã€‚'; + $lang['strrolealteredbad'] = '角色å˜æ›´å¤±è´¥ã€‚'; + $lang['strcanlogin'] = 'å¯ä»¥ç™»å½•?'; + $lang['strconnlimit'] = '连接é™åˆ¶'; + $lang['strdroprole'] = '删除角色'; + $lang['strconfdroprole'] = '确定è¦åˆ é™¤è§’色 "%s"å—?'; + $lang['strroledropped'] = '角色已删除。'; + $lang['strroledroppedbad'] = '角色删除失败。'; + $lang['strnolimit'] = 'æ— é™åˆ¶'; + $lang['strnever'] = '从ä¸'; + $lang['strroleneedsname'] = '必须指定角色å称。'; + + // Privileges + $lang['strprivilege'] = 'æƒé™'; + $lang['strprivileges'] = 'æƒé™'; + $lang['strnoprivileges'] = '这个对象拥有默认所属人的æƒé™ã€‚'; + $lang['strgrant'] = '赋予'; + $lang['strrevoke'] = '撤回'; + $lang['strgranted'] = 'æƒé™å·²æ”¹å˜'; + $lang['strgrantfailed'] = 'æƒé™æ”¹å˜å¤±è´¥'; + $lang['strgrantbad'] = '必须指定至少一个用户或一个组和一个æƒé™ã€‚'; + $lang['strgrantor'] = '赋予者'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'æ•°æ®åº“'; + $lang['strdatabases'] = 'æ•°æ®åº“'; + $lang['strshowalldatabases'] = '显示所有数æ®åº“'; + $lang['strnodatabases'] = '查无数æ®åº“。'; + $lang['strcreatedatabase'] = '创建数æ®åº“'; + $lang['strdatabasename'] = 'æ•°æ®åº“å称'; + $lang['strdatabaseneedsname'] = '必须指定数æ®åº“å称。'; + $lang['strdatabasecreated'] = 'æ•°æ®åº“已创建。'; + $lang['strdatabasecreatedbad'] = 'æ•°æ®åº“创建失败。'; + $lang['strconfdropdatabase'] = '确定è¦åˆ é™¤æ•°æ®åº“"%s"å—?'; + $lang['strdatabasedropped'] = 'æ•°æ®åº“已删除。'; + $lang['strdatabasedroppedbad'] = 'æ•°æ®åº“删除失败'; + $lang['strentersql'] = '请在下方输入è¦æ‰§è¡Œçš„SQL语å¥ï¼š'; + $lang['strsqlexecuted'] = 'SQL 已执行。'; + $lang['strvacuumgood'] = '清ç†å®Œæˆ'; + $lang['strvacuumbad'] = '清ç†å¤±è´¥'; + $lang['stranalyzegood'] = '分æžå®Œæˆ'; + $lang['stranalyzebad'] = '分æžå¤±è´¥'; + $lang['strreindexgood'] = 'é‡å»ºç´¢å¼•å®Œæˆã€‚'; + $lang['strreindexbad'] = 'é‡å»ºç´¢å¼•å¤±è´¥ã€‚'; + $lang['strfull'] = '完全'; + $lang['strfreeze'] = '冻结'; + $lang['strforce'] = '强制'; + $lang['strsignalsent'] = 'ä¿¡å·å·²å‘é€ã€‚'; + $lang['strsignalsentbad'] = 'ä¿¡å·å‘é€å¤±è´¥ã€‚'; + $lang['strallobjects'] = '所有对象'; + $lang['strdatabasealtered'] = 'æ•°æ®åº“å·²å˜æ›´ã€‚'; + $lang['strdatabasealteredbad'] = 'æ•°æ®åº“å˜æ›´å¤±è´¥ã€‚'; + $lang['strspecifydatabasetodrop'] = '必须至少指定一个è¦ç§»é™¤çš„æ•°æ®åº“'; + $lang['strtemplatedb'] = '模æ¿'; + $lang['strconfanalyzedatabase'] = '你确定è¦åˆ†æžæ•°æ®åº“"%s"中的所有表å—?'; + $lang['strconfvacuumdatabase'] = '你确定è¦æ¸…ç†æ•°æ®åº“"%s"中的所有表å—?'; + $lang['strconfreindexdatabase'] = '你确定è¦é‡æ–°ç´¢å¼•æ•°æ®åº“"%s"中的所有表å—?'; + $lang['strconfclusterdatabase'] = '你确定è¦é›†ç¾¤æ•°æ®åº“"%s"中的所有表å—?'; + + // Views + $lang['strview'] = '视图'; + $lang['strviews'] = '视图'; + $lang['strshowallviews'] = '显示所有视图'; + $lang['strnoview'] = '查无此视图'; + $lang['strnoviews'] = '查无视图。'; + $lang['strcreateview'] = '创建视图'; + $lang['strviewname'] = '视图å称'; + $lang['strviewneedsname'] = '必须指定视图å称。'; + $lang['strviewneedsdef'] = '必须指定视图定义。'; + $lang['strviewneedsfields'] = '必须指定视图里è¦é€‰æ‹©çš„列。'; + $lang['strviewcreated'] = '视图已创建。'; + $lang['strviewcreatedbad'] = '视图创建失败。'; + $lang['strconfdropview'] = '确定è¦åˆ é™¤è§†å›¾"%s"å—?'; + $lang['strviewdropped'] = '视图已删除。'; + $lang['strviewdroppedbad'] = '视图删除失败。'; + $lang['strviewupdated'] = '视图已更新。'; + $lang['strviewupdatedbad'] = '视图更新失败'; + $lang['strviewlink'] = '连接关键字(Linking keys)'; + $lang['strviewconditions'] = '附加æ¡ä»¶'; + $lang['strcreateviewwiz'] = '使用å‘导创建视图'; + $lang['strrenamedupfields'] = 'é‡å‘½åå¤åˆ¶çš„字段'; + $lang['strdropdupfields'] = '移除å¤åˆ¶çš„字段'; + $lang['strerrordupfields'] = 'å¤åˆ¶å­—段时å‘生错误'; + $lang['strviewaltered'] = '视图已å˜æ›´ã€‚'; + $lang['strviewalteredbad'] = '视图å˜æ›´å¤±è´¥ã€‚'; + $lang['strspecifyviewtodrop'] = '必须至少指定一个è¦ç§»é™¤çš„视图'; + + // Sequences + $lang['strsequence'] = 'åºåˆ—'; + $lang['strsequences'] = 'åºåˆ—'; + $lang['strshowallsequences'] = '显示所有åºåˆ—'; + $lang['strnosequence'] = '查无此åºåˆ—'; + $lang['strnosequences'] = '查无åºåˆ—。'; + $lang['strcreatesequence'] = '创建åºåˆ—'; + $lang['strlastvalue'] = '最åŽå€¼'; + $lang['strincrementby'] = '增é‡'; + $lang['strstartvalue'] = '起始值'; + $lang['strrestartvalue'] = 'é‡æ–°è®¡ç®—'; + $lang['strmaxvalue'] = '最大值'; + $lang['strminvalue'] = '最å°å€¼'; + $lang['strcachevalue'] = '缓存值'; + $lang['strlogcount'] = '日志计数(Log count)'; + $lang['strcancycle'] = 'å¯ä»¥å¾ªçŽ¯å—?'; + $lang['striscalled'] = '将在返回下一个值å‰é€’增最åŽçš„值(is_called)å—?'; + $lang['strsequenceneedsname'] = '必须指定åºåˆ—å称。'; + $lang['strsequencecreated'] = 'åºåˆ—已创建。'; + $lang['strsequencecreatedbad'] = 'åºåˆ—创建失败。'; + $lang['strconfdropsequence'] = '确定è¦åˆ é™¤åºåˆ—"%s"å—?'; + $lang['strsequencedropped'] = 'åºåˆ—已删除。'; + $lang['strsequencedroppedbad'] = 'åºåˆ—删除失败。'; + $lang['strsequencerestart'] = 'é‡æ–°è®¡ç®—åºåˆ—。'; + $lang['strsequencerestartbad'] = 'åºåˆ—é‡æ–°è®¡ç®—失败。'; + $lang['strsequencereset'] = 'åºåˆ—å·²é‡ç½®ã€‚'; + $lang['strsequenceresetbad'] = 'åºåˆ—é‡ç½®å¤±è´¥ã€‚'; + $lang['strsequencealtered'] = 'åºåˆ—å·²å˜æ›´ã€‚'; + $lang['strsequencealteredbad'] = 'åºåˆ—å˜æ›´å¤±è´¥ã€‚'; + $lang['strsetval'] = '设定åºåˆ—值'; + $lang['strsequencesetval'] = 'åºåˆ—值已设定。'; + $lang['strsequencesetvalbad'] = 'åºåˆ—值设置失败。'; + $lang['strnextval'] = '递增åºåˆ—值'; + $lang['strsequencenextval'] = 'åºåˆ—值已递增。'; + $lang['strsequencenextvalbad'] = 'åºåˆ—值递增失败。'; + $lang['strspecifysequencetodrop'] = '必须至少指定一个åºåˆ—æ¥åˆ é™¤'; + + // Indexes + $lang['strindex'] = '索引'; + $lang['strindexes'] = '索引'; + $lang['strindexname'] = '索引å'; + $lang['strshowallindexes'] = '显示所有索引'; + $lang['strnoindex'] = '查无此索引'; + $lang['strnoindexes'] = '查无索引'; + $lang['strcreateindex'] = '创建索引'; + $lang['strtabname'] = 'æ•°æ®è¡¨å'; + $lang['strcolumnname'] = '列å'; + $lang['strindexneedsname'] = '必须指定索引å称。'; + $lang['strindexneedscols'] = '必须给索引指定有效的列数。'; + $lang['strindexcreated'] = '索引已创建'; + $lang['strindexcreatedbad'] = '索引创建失败。'; + $lang['strconfdropindex'] = '确定è¦åˆ é™¤"%s"索引?'; + $lang['strindexdropped'] = '索引已删除。'; + $lang['strindexdroppedbad'] = '索引删除失败。'; + $lang['strkeyname'] = 'é”®å'; + $lang['struniquekey'] = '唯一键'; + $lang['strprimarykey'] = '主键'; + $lang['strindextype'] = '索引类型'; + $lang['strtablecolumnlist'] = '表中的列'; + $lang['strindexcolumnlist'] = '索引中的列'; + $lang['strconfcluster'] = '确定è¦é›†ç¾¤ "%s"å—?'; + $lang['strclusteredgood'] = '集群完æˆã€‚'; + $lang['strclusteredbad'] = '集群失败。'; + $lang['strconcurrently'] = '并å‘'; + $lang['strnoclusteravailable'] = '表中没有集群索引。'; + + // Rules + $lang['strrules'] = '规则'; + $lang['strrule'] = '规则'; + $lang['strshowallrules'] = '显示所有规则'; + $lang['strnorule'] = '查无此规则。'; + $lang['strnorules'] = '查无规则'; + $lang['strcreaterule'] = '创建规则'; + $lang['strrulename'] = '规则å称'; + $lang['strruleneedsname'] = '必须指定规则å称。'; + $lang['strrulecreated'] = '规则已创建。'; + $lang['strrulecreatedbad'] = '规则创建失败。'; + $lang['strconfdroprule'] = '确定è¦å°†è§„则"%s"从"%s"中删除å—?'; + $lang['strruledropped'] = '规则已删除。'; + $lang['strruledroppedbad'] = '规则删除失败。'; + + // Constraints + $lang['strconstraint'] = '约æŸ'; + $lang['strconstraints'] = '约æŸ'; + $lang['strshowallconstraints'] = '显示所有约æŸã€‚'; + $lang['strnoconstraints'] = '查无此约æŸã€‚'; + $lang['strcreateconstraint'] = '创建约æŸ'; + $lang['strconstraintcreated'] = '约æŸå·²åˆ›å»ºã€‚'; + $lang['strconstraintcreatedbad'] = '约æŸåˆ›å»ºå¤±è´¥ã€‚'; + $lang['strconfdropconstraint'] = '确定è¦å°†å¼ºåˆ¶"%s"从"%s"中删除å—?'; + $lang['strconstraintdropped'] = '约æŸå·²åˆ é™¤ã€‚'; + $lang['strconstraintdroppedbad'] = '约æŸåˆ é™¤å¤±è´¥ã€‚'; + $lang['straddcheck'] = '添加检查约æŸ'; + $lang['strcheckneedsdefinition'] = '必须指定检查约æŸçš„定义。'; + $lang['strcheckadded'] = '检查约æŸå·²æ·»åŠ ã€‚'; + $lang['strcheckaddedbad'] = '检查约æŸæ·»åŠ å¤±è´¥ã€‚'; + $lang['straddpk'] = '添加主键'; + $lang['strpkneedscols'] = '主键至少需指定一列。'; + $lang['strpkadded'] = '主键已添加。'; + $lang['strpkaddedbad'] = '主键添加失败。'; + $lang['stradduniq'] = '添加唯一键'; + $lang['struniqneedscols'] = '唯一键至少需指定一列。'; + $lang['struniqadded'] = '唯一键已添加。'; + $lang['struniqaddedbad'] = '唯一键添加失败。'; + $lang['straddfk'] = '添加外键'; + $lang['strfkneedscols'] = '外键至少需指定一列。'; + $lang['strfkneedstarget'] = '外键需指定一个目标数æ®è¡¨ã€‚'; + $lang['strfkadded'] = '外键已添加。'; + $lang['strfkaddedbad'] = '外键添加失败。'; + $lang['strfktarget'] = '目标数æ®è¡¨'; + $lang['strfkcolumnlist'] = '键中的列'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = '函数'; + $lang['strfunctions'] = '函数'; + $lang['strshowallfunctions'] = '显示所有函数'; + $lang['strnofunction'] = '查无此函数'; + $lang['strnofunctions'] = '查无函数'; + $lang['strcreateplfunction'] = '创建 SQL/PL 函数'; + $lang['strcreateinternalfunction'] = '创建内部函数'; + $lang['strcreatecfunction'] = '创建 C 函数'; + $lang['strfunctionname'] = '函数å称'; + $lang['strreturns'] = '返回'; + $lang['strproglanguage'] = '过程语言'; + $lang['strfunctionneedsname'] = '必须指定函数å称。'; + $lang['strfunctionneedsdef'] = '必须指定函数定义。'; + $lang['strfunctioncreated'] = '函数已创建'; + $lang['strfunctioncreatedbad'] = '函数创建失败'; + $lang['strconfdropfunction'] = '确定è¦åˆ é™¤å‡½æ•°"%s"å—?'; + $lang['strfunctiondropped'] = '函数已删除。'; + $lang['strfunctiondroppedbad'] = '函数删除失败。'; + $lang['strfunctionupdated'] = '函数已更新。'; + $lang['strfunctionupdatedbad'] = '函数更新失败。'; + $lang['strobjectfile'] = '对象文件'; + $lang['strlinksymbol'] = '连接对象'; + $lang['strarguments'] = 'å‚æ•°'; + $lang['strargmode'] = '模å¼'; + $lang['strargtype'] = '类型'; + $lang['strargadd'] = '新添加一个å‚æ•°'; + $lang['strargremove'] = '移除这个å‚æ•°'; + $lang['strargnoargs'] = '该函数无å‚数。'; + $lang['strargenableargs'] = '使该函数的å‚数有效。'; + $lang['strargnorowabove'] = '在该行上é¢é¡»æœ‰ä¸€è¡Œã€‚'; + $lang['strargnorowbelow'] = '在该行下é¢é¡»æœ‰ä¸€è¡Œã€‚'; + $lang['strargraise'] = '上移。'; + $lang['strarglower'] = '下移。'; + $lang['strargremoveconfirm'] = '确定è¦ç§»é™¤è¿™ä¸ªå‚æ•°å—?这个æ“作ä¸èƒ½æ’¤é”€ã€‚'; + $lang['strfunctioncosting'] = '函数代价(Function Costing)'; + $lang['strresultrows'] = '结果行'; + $lang['strexecutioncost'] = '执行代价'; + $lang['strspecifyfunctiontodrop'] = '必须至少指定一个函数æ¥åˆ é™¤'; + + // Triggers + $lang['strtrigger'] = '触å‘器'; + $lang['strtriggers'] = '触å‘器'; + $lang['strshowalltriggers'] = '显示所有触å‘器'; + $lang['strnotrigger'] = '查无此触å‘器。'; + $lang['strnotriggers'] = '查无触å‘器。'; + $lang['strcreatetrigger'] = '创建触å‘器'; + $lang['strtriggerneedsname'] = '必须指定触å‘器å称。'; + $lang['strtriggerneedsfunc'] = '必须给触å‘器指定一个函数。'; + $lang['strtriggercreated'] = '触å‘器已创建。'; + $lang['strtriggercreatedbad'] = '触å‘器创建失败。'; + $lang['strconfdroptrigger'] = '确定è¦å°†è§¦å‘器"%s"从"%s"中删除å—?'; + $lang['strconfenabletrigger'] = '确定è¦ä½¿è§¦å‘器 "%s" 在 "%s"上有效å—?'; + $lang['strconfdisabletrigger'] = '确定è¦ä½¿è§¦å‘器 "%s" 在 "%s"上无效å—?'; + $lang['strtriggerdropped'] = '触å‘器已删除。'; + $lang['strtriggerdroppedbad'] = '触å‘器删除失败。'; + $lang['strtriggerenabled'] = '触å‘器已有效。'; + $lang['strtriggerenabledbad'] = '触å‘器有效化失败。'; + $lang['strtriggerdisabled'] = '触å‘器已无效。'; + $lang['strtriggerdisabledbad'] = '触å‘器无效化失败。'; + $lang['strtriggeraltered'] = '触å‘器已å˜æ›´ã€‚'; + $lang['strtriggeralteredbad'] = '触å‘器å˜æ›´å¤±è´¥ã€‚'; + $lang['strforeach'] = 'ç»™æ¯ä¸€ä¸ª'; + + // Types + $lang['strtype'] = '类型'; + $lang['strtypes'] = '类型'; + $lang['strshowalltypes'] = '显示所有的类型'; + $lang['strnotype'] = '查无此类型'; + $lang['strnotypes'] = '查无类型。'; + $lang['strcreatetype'] = '创建类型'; + $lang['strcreatecomptype'] = '创建组åˆç±»åž‹'; + $lang['strcreateenumtype'] = '创建枚举类型'; + $lang['strtypeneedsfield'] = '必须至少指定一个字段。'; + $lang['strtypeneedsvalue'] = '必须至少指定一个值'; + $lang['strtypeneedscols'] = '必须指定有效的字段数。'; + $lang['strtypeneedsvals'] = '必须指定一个有效的字段数。'; + $lang['strinputfn'] = '输入函数'; + $lang['stroutputfn'] = '输出函数'; + $lang['strpassbyval'] = '传值?'; + $lang['stralignment'] = 'å‚æ•°'; + $lang['strelement'] = '元素'; + $lang['strdelimiter'] = '分隔符'; + $lang['strstorage'] = 'ç£ç›˜å­˜å‚¨'; + $lang['strfield'] = '字段'; + $lang['strnumfields'] = '列数'; + $lang['strnumvalues'] = '值数'; + $lang['strtypeneedsname'] = '必须指定类型å称。'; + $lang['strtypeneedslen'] = '必须指定类型长度。'; + $lang['strtypecreated'] = '类型已创建。'; + $lang['strtypecreatedbad'] = '类型创建失败。'; + $lang['strconfdroptype'] = '确定è¦åˆ é™¤"%s"类型å—?'; + $lang['strtypedropped'] = '类型已删除。'; + $lang['strtypedroppedbad'] = '类型删除失败。'; + $lang['strflavor'] = '风格(Flavor)'; + $lang['strbasetype'] = '基本'; + $lang['strcompositetype'] = '组åˆ'; + $lang['strpseudotype'] = '伪(Pseudo)'; + $lang['strenum'] = 'Enum'; + $lang['strenumvalues'] = '枚举类型'; + + // Schemas + $lang['strschema'] = '模å¼'; + $lang['strschemas'] = '模å¼'; + $lang['strshowallschemas'] = '显示所有模å¼'; + $lang['strnoschema'] = '查无此模å¼'; + $lang['strnoschemas'] = '查无模å¼'; + $lang['strcreateschema'] = '创建模å¼'; + $lang['strschemaname'] = '模å¼å称'; + $lang['strschemaneedsname'] = '必须指定模å¼å称'; + $lang['strschemacreated'] = '模å¼å·²åˆ›å»º'; + $lang['strschemacreatedbad'] = '模å¼åˆ›å»ºå¤±è´¥'; + $lang['strconfdropschema'] = '确定è¦åˆ é™¤æ¨¡å¼"%s"å—?'; + $lang['strschemadropped'] = '模å¼å·²åˆ é™¤'; + $lang['strschemadroppedbad'] = '模å¼åˆ é™¤å¤±è´¥'; + $lang['strschemaaltered'] = '模å¼å·²å˜æ›´ã€‚'; + $lang['strschemaalteredbad'] = '模å¼å˜æ›´å¤±è´¥ã€‚'; + $lang['strsearchpath'] = '模å¼æŸ¥æ‰¾è·¯å¾„'; + $lang['strspecifyschematodrop'] = '必须至少指定一个模å¼æ¥åˆ é™¤'; + + // Reports + + // Domains + $lang['strdomain'] = '域'; + $lang['strdomains'] = '域'; + $lang['strshowalldomains'] = '显示所有域'; + $lang['strnodomains'] = '查无 域。'; + $lang['strcreatedomain'] = '创建域'; + $lang['strdomaindropped'] = '域已删除。'; + $lang['strdomaindroppedbad'] = '域删除失败。'; + $lang['strconfdropdomain'] = '确定è¦åˆ é™¤åŸŸ "%s"å—?'; + $lang['strdomainneedsname'] = '必须指定域å称。'; + $lang['strdomaincreated'] = '域已创建。'; + $lang['strdomaincreatedbad'] = '域创建失败。'; + $lang['strdomainaltered'] = '域已å˜æ›´ã€‚'; + $lang['strdomainalteredbad'] = '域å˜æ›´å¤±è´¥ã€‚'; + + // Operators + $lang['stroperator'] = 'æ“作符'; + $lang['stroperators'] = 'æ“作符'; + $lang['strshowalloperators'] = '显示所有æ“作符'; + $lang['strnooperator'] = '查无此æ“作符。'; + $lang['strnooperators'] = '查无æ“作符。'; + $lang['strcreateoperator'] = '创建æ“作符'; + $lang['strleftarg'] = 'å·¦å‚数类型'; + $lang['strrightarg'] = 'å³å‚数类型'; + $lang['strcommutator'] = '转æ¢ç¬¦'; + $lang['strnegator'] = 'éžæ“作符'; + $lang['strrestrict'] = 'å—é™'; + $lang['strjoin'] = '连接'; + $lang['strhashes'] = '哈希'; + $lang['strmerges'] = 'åˆå¹¶'; + $lang['strleftsort'] = '左排åº'; + $lang['strrightsort'] = 'å³æŽ’åº'; + $lang['strlessthan'] = 'å°äºŽ'; + $lang['strgreaterthan'] = '大于'; + $lang['stroperatorneedsname'] = '必须指定æ“作符å称。'; + $lang['stroperatorcreated'] = 'æ“作符已创建'; + $lang['stroperatorcreatedbad'] = 'æ“作符创建失败。'; + $lang['strconfdropoperator'] = '确定è¦åˆ é™¤æ“作符 "%s"å—?'; + $lang['stroperatordropped'] = 'æ“作符已删除。'; + $lang['stroperatordroppedbad'] = 'æ“作符删除失败。'; + + // Casts + $lang['strcasts'] = '类型转æ¢'; + $lang['strnocasts'] = '查无类型转æ¢ã€‚'; + $lang['strsourcetype'] = 'æºç±»åž‹'; + $lang['strtargettype'] = '目标类型'; + $lang['strimplicit'] = 'éšå«çš„'; + $lang['strinassignment'] = '委派中'; + $lang['strbinarycompat'] = '(二进制兼容)'; + + // Conversions + $lang['strconversions'] = 'ç¼–ç è½¬æ¢'; + $lang['strnoconversions'] = '查无编ç è½¬æ¢ã€‚'; + $lang['strsourceencoding'] = 'æºç¼–ç '; + $lang['strtargetencoding'] = '目标编ç '; + + // Languages + $lang['strlanguages'] = '过程语言'; + $lang['strnolanguages'] = '查无过程语言。'; + $lang['strtrusted'] = '信任的'; + + // Info + $lang['strnoinfo'] = '无资料(information)å¯ç”¨ã€‚'; + $lang['strreferringtables'] = '查询(Referring)表'; + $lang['strparenttables'] = '父表'; + $lang['strchildtables'] = 'å­è¡¨'; + + // Aggregates + $lang['straggregate'] = 'èšé›†'; + $lang['straggregates'] = 'èšé›†'; + $lang['strnoaggregates'] = '查无èšé›†ã€‚'; + $lang['stralltypes'] = '(所有类型)'; + $lang['strcreateaggregate'] = '创建èšé›†'; + $lang['straggrbasetype'] = '输入数æ®ç±»åž‹'; + $lang['straggrsfunc'] = '状æ€è½¬åŒ–函数'; + $lang['straggrstype'] = '状æ€ç±»åž‹'; + $lang['straggrffunc'] = '最终函数'; + $lang['straggrinitcond'] = 'åˆå§‹å‡½æ•°'; + $lang['straggrsortop'] = '排åºæ“作符'; + $lang['strconfdropaggregate'] = '确定è¦åˆ é™¤èšé›† "%s"å—?'; + $lang['straggregatedropped'] = 'èšé›†å·²åˆ é™¤ã€‚'; + $lang['straggregatedroppedbad'] = 'èšé›†åˆ é™¤å¤±è´¥ã€‚'; + $lang['straggraltered'] = 'èšé›†å·²å˜æ›´ã€‚'; + $lang['straggralteredbad'] = 'èšé›†å˜æ›´å¤±è´¥ã€‚'; + $lang['straggrneedsname'] = '必须指定èšé›†çš„å称'; + $lang['straggrneedsbasetype'] = '必须指定èšé›†çš„输入数æ®ç±»åž‹'; + $lang['straggrneedssfunc'] = '必须指定èšé›†çš„状æ€è½¬æ¢å‡½æ•°'; + $lang['straggrneedsstype'] = '必须指定èšé›†çš„状æ€å€¼çš„æ•°æ®ç±»åž‹'; + $lang['straggrcreated'] = 'èšé›†å·²åˆ›å»ºã€‚'; + $lang['straggrcreatedbad'] = 'èšé›†åˆ›å»ºå¤±è´¥ã€‚'; + $lang['straggrshowall'] = '显示所有èšé›†'; + + // Operator Classes + $lang['stropclasses'] = 'æ“作符类'; + $lang['strnoopclasses'] = '查无此æ“作符类。'; + $lang['straccessmethod'] = 'å­˜å–方法'; + + // Stats and performance + $lang['strrowperf'] = '行性能'; + $lang['strioperf'] = 'I/O 性能'; + $lang['stridxrowperf'] = '索引行性能'; + $lang['stridxioperf'] = '索引 I/O 性能'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = '顺åºæ‰«æ'; + $lang['strscan'] = '扫æ'; + $lang['strread'] = '读å–'; + $lang['strfetch'] = 'å–å¾—'; + $lang['strheap'] = 'å †'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST 索引'; + $lang['strcache'] = '缓存'; + $lang['strdisk'] = '硬盘'; + $lang['strrows2'] = 'è¡Œ'; + + // Tablespaces + $lang['strtablespace'] = '表空间'; + $lang['strtablespaces'] = '表空间'; + $lang['strshowalltablespaces'] = '显示所有表空间'; + $lang['strnotablespaces'] = '查无此表空间。'; + $lang['strcreatetablespace'] = '创建表空间'; + $lang['strlocation'] = 'ä½ç½®'; + $lang['strtablespaceneedsname'] = '必须指定表空间å称。'; + $lang['strtablespaceneedsloc'] = '必须指定创建表空间的文件夹。'; + $lang['strtablespacecreated'] = '表空间已创建。'; + $lang['strtablespacecreatedbad'] = '表空间创建失败。'; + $lang['strconfdroptablespace'] = '确定è¦åˆ é™¤è¡¨ç©ºé—´ "%s"å—?'; + $lang['strtablespacedropped'] = '表空间已删除。'; + $lang['strtablespacedroppedbad'] = '表空间删除失败。'; + $lang['strtablespacealtered'] = '表空间已å˜æ›´ã€‚'; + $lang['strtablespacealteredbad'] = '表空间å˜æ›´å¤±è´¥ã€‚'; + + // Miscellaneous + $lang['strtopbar'] = '%s 架于 %s:%s ï¼ æ‚¨æ˜¯ "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = '帮助'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = '帮助页é¢æµè§ˆ'; + $lang['strselecthelppage'] = '选择一个帮助页é¢'; + $lang['strinvalidhelppage'] = '无效的帮助页é¢ã€‚'; + $lang['strlogintitle'] = '登入 %s'; + $lang['strlogoutmsg'] = '注销 %s'; + $lang['strloading'] = '加载中。。。'; + $lang['strerrorloading'] = '加载错误'; + $lang['strclicktoreload'] = '点击é‡æ–°åŠ è½½'; + + // Autovacuum + $lang['strautovacuum'] = '自动清ç†(Autovacuum)'; + $lang['strturnedon'] = '打开'; + $lang['strturnedoff'] = '关闭'; + $lang['strenabled'] = '有效'; + $lang['strnovacuumconf'] = '没有自动清ç†é…置。'; + $lang['strvacuumbasethreshold'] = '清ç†åŸºæœ¬ä¸´ç•Œå€¼'; + $lang['strvacuumscalefactor'] = '清ç†æ¢ç®—系数'; + $lang['stranalybasethreshold'] = '分æžåŸºæœ¬ä¸´ç•Œå€¼'; + $lang['stranalyzescalefactor'] = '分æžæ¢ç®—系数'; + $lang['strvacuumcostdelay'] = '清ç†æˆæœ¬å»¶è¿Ÿ'; + $lang['strvacuumcostlimit'] = '清ç†æˆæœ¬é™åˆ¶'; + $lang['strvacuumpertable'] = '此表的自动清ç†é…ç½®'; + $lang['straddvacuumtable'] = '为此表增加自动清ç†é…ç½®'; + $lang['streditvacuumtable'] = '编辑表 %s 的自动清ç†é…ç½®'; + $lang['strdelvacuumtable'] = '删除表 %s 的自动清ç†é…ç½®?'; + $lang['strvacuumtablereset'] = '还原表 %s 的自动清ç†é…置为默认值'; + $lang['strdelvacuumtablefail'] = '无法删除表 %s 的自动清ç†é…ç½®'; + $lang['strsetvacuumtablesaved'] = 'å·²ä¿å­˜è¡¨ %s 的自动清ç†é…ç½®'; + $lang['strsetvacuumtablefail'] = '表 %s 的自动清ç†é…置失败'; + $lang['strspecifydelvacuumtable'] = '请指定你希望移除自动清ç†é…置的表。'; + $lang['strspecifyeditvacuumtable'] = '请指定你希望编辑自动清ç†é…置的表。'; + $lang['strnotdefaultinred'] = 'éžé»˜è®¤å€¼è¢«æ ‡æ³¨ä¸ºçº¢è‰²ã€‚'; + + // Table-level Locks + $lang['strlocks'] = 'é”'; + $lang['strtransaction'] = '事务ID'; + $lang['strvirtualtransaction'] = '虚拟事务ID'; + $lang['strprocessid'] = '进程ID'; + $lang['strmode'] = 'é”定模å¼'; + $lang['strislockheld'] = '拥有é”?'; + + // Prepared transactions + $lang['strpreparedxacts'] = '已准备事务'; + $lang['strxactid'] = '事务ID'; + $lang['strgid'] = '全域ID'; + + // Fulltext search + $lang['strfulltext'] = '全文检索'; + $lang['strftsconfig'] = '全文检索é…ç½®'; + $lang['strftsconfigs'] = 'é…ç½®'; + $lang['strftscreateconfig'] = '创建 全文检索é…ç½®'; + $lang['strftscreatedict'] = '创建字典'; + $lang['strftscreatedicttemplate'] = '创建字典模æ¿'; + $lang['strftscreateparser'] = '创建分æžå™¨'; + $lang['strftsnoconfigs'] = '没有找到全文检索é…置。'; + $lang['strftsconfigdropped'] = '全文检索é…置已移除。'; + $lang['strftsconfigdroppedbad'] = '全文检索移除失败。'; + $lang['strconfdropftsconfig'] = '确定è¦ç§»é™¤å…¨æ–‡æ£€ç´¢æ£€ç´¢é…ç½® "%s"å—?'; + $lang['strconfdropftsdict'] = '确定è¦ç§»é™¤å…¨æ–‡æ£€ç´¢å­—å…¸ "%s"å—?'; + $lang['strconfdropftsmapping'] = '确定è¦å°†æ˜ å°„ "%s" 从全文检索é…ç½® "%s"中移除å—?'; + $lang['strftstemplate'] = '模æ¿'; + $lang['strftsparser'] = '分æžå™¨'; + $lang['strftsconfigneedsname'] = '必须指定全文检索é…ç½®å称。'; + $lang['strftsconfigcreated'] = '全文检索é…置已创建'; + $lang['strftsconfigcreatedbad'] = '全文检索é…置创建失败。'; + $lang['strftsmapping'] = '映射'; + $lang['strftsdicts'] = 'å­—å…¸'; + $lang['strftsdict'] = 'å­—å…¸'; + $lang['strftsemptymap'] = '空的全文检索é…置映射。'; + $lang['strftsconfigaltered'] = '全文检索已å˜æ›´ã€‚'; + $lang['strftsconfigalteredbad'] = '全文检索å˜æ›´å¤±è´¥ã€‚'; + $lang['strftsconfigmap'] = '全文检索é…置映射'; + $lang['strftsparsers'] = '全文检索分æžå™¨'; + $lang['strftsnoparsers'] = '无有效的全文检索分æžå™¨ã€‚'; + $lang['strftsnodicts'] = '无有效的全文检索字典。'; + $lang['strftsdictcreated'] = '全文检索字典已创建'; + $lang['strftsdictcreatedbad'] = '全文检索字典创建失败。'; + $lang['strftslexize'] = 'Lexize'; + $lang['strftsinit'] = 'åˆå§‹åŒ–'; + $lang['strftsoptionsvalues'] = '选项和值'; + $lang['strftsdictneedsname'] = '必须指定全文检索字典å称。'; + $lang['strftsdictdropped'] = '全文检索字典已移除。'; + $lang['strftsdictdroppedbad'] = '全文检索字典移除失败。'; + $lang['strftsdictaltered'] = '全文检索字典已å˜æ›´ã€‚'; + $lang['strftsdictalteredbad'] = '全文检索字典å˜æ›´å¤±è´¥ã€‚'; + $lang['strftsaddmapping'] = '添加映射'; + $lang['strftsspecifymappingtodrop'] = '必须最少指定一个映射æ¥ç§»é™¤'; + $lang['strftsspecifyconfigtoalter'] = '必须指定一个全文检索é…ç½®æ¥å˜æ›´'; + $lang['strftsmappingdropped'] = '全文检索映射已删除。'; + $lang['strftsmappingdroppedbad'] = '全文检索映射移除失败。'; + $lang['strftsnodictionaries'] = '查无字典。'; + $lang['strftsmappingaltered'] = '全文检索映射已å˜æ›´ã€‚'; + $lang['strftsmappingalteredbad'] = '全文检索映射å˜æ›´å¤±è´¥ã€‚'; + $lang['strftsmappingadded'] = '全文检索映射已添加。'; + $lang['strftsmappingaddedbad'] = '全文检索映射添加失败。'; + $lang['strftstabconfigs'] = 'é…ç½®'; + $lang['strftstabdicts'] = 'å­—å…¸'; + $lang['strftstabparsers'] = '分æžå™¨'; + $lang['strftscantparsercopy'] = 'ä¸èƒ½åœ¨åˆ›å»ºå…¨æ–‡æ£€ç´¢é…置时指定分æžå™¨å’Œæ¨¡æ¿ã€‚'; + + //Plugins + $lang['strpluginnotfound'] = '错误:没有找到\'%s\'æ’件。请检查该æ’件是å¦åœ¨plugins/目录下,或æ’件是å¦åŒ…å«plugin.php。注æ„æ’件å大å°å†™æ•æ„Ÿã€‚'; + $lang['stractionnotfound'] = '错误:动作\'%s\'ä¸åœ¨æ’件\'%s\'中,或没有被指定为åˆæ³•çš„动作。'; + $lang['strhooknotfound'] = '错误:连接\'%s\'ä¸å¯ç”¨.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_TW.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_TW.php new file mode 100644 index 00000000..4514584c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/chinese-utf8-zh_TW.php @@ -0,0 +1,863 @@ +'; + $lang['strfirst'] = '<< 最å‰ä¸€æ­¥'; + $lang['strlast'] = '最後一步 >>'; + $lang['strfailed'] = '失敗'; + $lang['strcreate'] = '建立'; + $lang['strcreated'] = '已建立'; + $lang['strcomment'] = '註釋'; + $lang['strlength'] = '長度'; + $lang['strdefault'] = 'é è¨­å€¼'; + $lang['stralter'] = '修改'; + $lang['strok'] = '確定'; + $lang['strcancel'] = 'å–消'; + $lang['strac'] = '啟用自動完æˆ'; + $lang['strsave'] = '儲存'; + $lang['strreset'] = 'é‡è¨­'; + $lang['strinsert'] = 'æ’å…¥'; + $lang['strselect'] = 'é¸å–'; + $lang['strdelete'] = '刪除'; + $lang['strupdate'] = 'æ›´æ–°'; + $lang['strreferences'] = 'åƒç…§'; + $lang['stryes'] = '是'; + $lang['strno'] = 'å¦'; + $lang['strtrue'] = '真(TRUE)'; + $lang['strfalse'] = 'å‡(FALSE)'; + $lang['stredit'] = '編輯'; + $lang['strcolumn'] = '欄ä½'; + $lang['strcolumns'] = '欄ä½'; + $lang['strrows'] = '資料列'; + $lang['strrowsaff'] = '資料列å—影響。'; + $lang['strobjects'] = '物件'; + $lang['strback'] = '返回'; + $lang['strqueryresults'] = '查詢çµæžœ'; + $lang['strshow'] = '顯示'; + $lang['strempty'] = '清空'; + $lang['strlanguage'] = '語言'; + $lang['strencoding'] = '字元編碼'; + $lang['strunique'] = '唯一值'; + $lang['strprimary'] = '主éµ(PK)'; + $lang['strexport'] = '匯出'; + $lang['strimport'] = '匯入'; + $lang['strallowednulls'] = 'å…許空字串'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = '空 字串/欄ä½'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = '管ç†'; + $lang['strvacuum'] = '清ç†(Vacuum)'; + $lang['stranalyze'] = '分æž'; + $lang['strclusterindex'] = 'å¢é›†'; + $lang['strclustered'] = 'å·²å¢é›†?'; + $lang['strreindex'] = 'é‡å»ºç´¢å¼•'; + $lang['strrun'] = '執行'; + $lang['stradd'] = '新增'; + $lang['strevent'] = '事件'; + $lang['strwhere'] = 'æ¢ä»¶'; + $lang['strinstead'] = '已被å–代'; + $lang['strwhen'] = '當'; + $lang['strformat'] = 'æ ¼å¼'; + $lang['strdata'] = '資料'; + $lang['strconfirm'] = '確èª'; + $lang['strexpression'] = '表é”å¼'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = '展開'; + $lang['strcollapse'] = '摺疊'; + $lang['strfind'] = '尋找'; + $lang['stroptions'] = 'é¸é …'; + $lang['strrefresh'] = 'é‡æ–°æ•´ç†'; + $lang['strdownload'] = '下載'; + $lang['strdownloadgzipped'] = '以 gzip 壓縮並下載'; + $lang['strinfo'] = '資訊'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = '進階'; + $lang['strvariables'] = '變數'; + $lang['strprocess'] = '進程'; + $lang['strprocesses'] = '進程'; + $lang['strsetting'] = '設定'; + $lang['streditsql'] = '編輯 SQL'; + $lang['strruntime'] = '總共執行時間: %s ms'; + $lang['strpaginate'] = '分é é¡¯ç¤ºçµæžœ'; + $lang['struploadscript'] = '或是上傳一個 SQL 稿本檔: '; + $lang['strstarttime'] = '啟動時間'; + $lang['strfile'] = '檔案'; + $lang['strfileimported'] = '檔案已匯入。'; + $lang['strtrycred'] = '使用這些憑證給全部伺æœå™¨'; + $lang['stractionsonmultiplelines'] = '動作在多個行列上'; + $lang['strcheckall'] = '檢查全部'; + $lang['struncheckall'] = 'ä¸æª¢æŸ¥å…¨éƒ¨'; + $lang['strcluster'] = 'å¢é›†'; + + // User-supplied SQL history + $lang['strhistory'] = '歷程'; + $lang['strnohistory'] = '無歷程。'; + $lang['strclearhistory'] = '清空歷程'; + $lang['strdelhistory'] = '從歷程刪除'; + $lang['strconfdelhistory'] = '確實è¦å¾žæ­·ç¨‹åˆªé™¤å—Ž ?'; + $lang['strconfclearhistory'] = '確實è¦æ¸…空歷程嗎 ?'; + $lang['strnodatabaseselected'] = 'è«‹é¸æ“‡ä¸€å€‹è³‡æ–™åº«ã€‚'; + + // Database sizes + $lang['strsize'] = '容é‡'; + $lang['strbytes'] = 'ä½å…ƒçµ„'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = '這個應用最好以一個能啟用框架é (frame)çš„ç€è¦½å™¨é‹ä½œï¼Œä½†ä¹Ÿèƒ½å¤ è¢«ä½¿ç”¨åœ¨æ²’有框架é ä¸‹æŽ¥ç¹¼é‹ä½œï¼Œè«‹æŒ‰ä¸‹é¢çš„連çµã€‚'; + $lang['strnoframeslink'] = '使用ä¸åŒ…括框架é (frame)'; + $lang['strbadconfig'] = '您的 config.inc.php 是éŽæ™‚的。您將需è¦å¾žæ–°çš„ config.inc.php-dist é‡å»ºå®ƒã€‚'; + $lang['strnotloaded'] = '您的 PHP ç’°å¢ƒæœªå®‰è£ PostgreSQL å¿…è¦çš„支æŒã€‚您必需é‡æ–°ç·¨è­¯ PHP 使用 --with-pgsql 組態é¸é …。'; + $lang['strpostgresqlversionnotsupported'] = '版本的 PostgreSQL 未被支æŒã€‚è«‹å‡ç´šç‰ˆæœ¬åˆ° %s 或是更高者。'; + $lang['strbadschema'] = '無效的架構模å¼è¢«æŒ‡å®šã€‚'; + $lang['strbadencoding'] = '在資料庫中設定客戶端字元編碼失敗。'; + $lang['strsqlerror'] = 'SQL 錯誤: '; + $lang['strinstatement'] = '在å€å¡Šå…§: '; + $lang['strinvalidparam'] = '無效的稿本變數。'; + $lang['strnodata'] = '找ä¸åˆ°è³‡æ–™åˆ—。'; + $lang['strnoobjects'] = '找ä¸åˆ°ç‰©ä»¶ã€‚'; + $lang['strrownotunique'] = '該資料列無唯一約æŸã€‚'; + $lang['strnouploads'] = '上傳檔案功能是已åœç”¨ã€‚'; + $lang['strimporterror'] = '匯入錯誤。'; + $lang['strimporterror-fileformat'] = '匯入錯誤: 自動識別檔案格å¼å·²å¤±æ•—。'; + $lang['strimporterrorline'] = '匯入錯誤發生在第 %s 行。'; + $lang['strimporterrorline-badcolumnnum'] = '匯入錯誤發生在第 %s è¡Œ: 該行ä¸å…·å‚™æ­£ç¢ºçš„欄ä½ç·¨è™Ÿã€‚'; + $lang['strimporterror-uploadedfile'] = '匯入錯誤: 檔案無法被上傳到這伺æœå™¨'; + $lang['strcannotdumponwindows'] = '複雜的資料表與架構模å¼å稱轉儲在 Windows 是未被支æŒçš„。'; + $lang['strinvalidserverparam'] = '試圖用無效的伺æœå™¨åƒæ•¸é€£çµ, å¯èƒ½æœ‰äººæ­£è©¦åœ–攻擊您的系統。'; + $lang['strnoserversupplied'] = '沒有é¸æ“‡è³‡æ–™åº«!'; + + // Tables + $lang['strtable'] = '資料表'; + $lang['strtables'] = '資料表'; + $lang['strshowalltables'] = '顯示全部資料表'; + $lang['strnotables'] = '找ä¸åˆ°è³‡æ–™è¡¨ã€‚'; + $lang['strnotable'] = '找ä¸åˆ°ä»»ä½•è³‡æ–™è¡¨ã€‚'; + $lang['strcreatetable'] = '建立新資料表'; + $lang['strtablename'] = '資料表å'; + $lang['strtableneedsname'] = '您必需為您的資料表命å。'; + $lang['strtableneedsfield'] = '您至少應指定一個欄ä½ã€‚'; + $lang['strtableneedscols'] = '您必需指定一個åˆæ³•çš„欄ä½æ•¸é‡ã€‚'; + $lang['strtablecreated'] = '資料表已建立。'; + $lang['strtablecreatedbad'] = '建立資料表作業已失敗。'; + $lang['strconfdroptable'] = '您確定è¦ç§»é™¤è³‡æ–™è¡¨ "%s"?'; + $lang['strtabledropped'] = '資料表已移除。'; + $lang['strtabledroppedbad'] = '資料表移除已失敗。'; + $lang['strconfemptytable'] = '您確定è¦æ¸…空資料表 "%s"?'; + $lang['strtableemptied'] = '資料表已清空。'; + $lang['strtableemptiedbad'] = '資料表清空已失敗。'; + $lang['strinsertrow'] = 'æ’入資料列'; + $lang['strrowinserted'] = '資料列已æ’入。'; + $lang['strrowinsertedbad'] = '資料列æ’入已失敗。'; + $lang['strrowduplicate'] = '資料列æ’入失敗, 試圖åšè¤‡è£½å“æ’入。'; + $lang['streditrow'] = '編輯資料列'; + $lang['strrowupdated'] = '資料列已更新。'; + $lang['strrowupdatedbad'] = '資料列更新已失敗。'; + $lang['strdeleterow'] = '刪除資料列'; + $lang['strconfdeleterow'] = '您確定è¦åˆªé™¤é€™äº›è³‡æ–™åˆ—??'; + $lang['strrowdeleted'] = '資料列已刪除。'; + $lang['strrowdeletedbad'] = '資料列刪除已失敗。'; + $lang['strinsertandrepeat'] = 'æ’入與é‡ä½œ'; + $lang['strnumcols'] = '欄ä½æ•¸é‡'; + $lang['strcolneedsname'] = '您必需為這個欄ä½ç‰¹å®šä¸€å€‹å稱'; + $lang['strselectallfields'] = 'é¸æ“‡å…¨éƒ¨æ¬„ä½'; + $lang['strselectneedscol'] = '您必需至少顯示一資料列。'; + $lang['strselectunary'] = '一元é‹ç®—å­ä¸èƒ½æœ‰å€¼ã€‚'; + $lang['straltercolumn'] = '修改資料列'; + $lang['strcolumnaltered'] = '資料列已修改。'; + $lang['strcolumnalteredbad'] = '資料列修改已失敗。'; + $lang['strconfdropcolumn'] = '您確定è¦ç§»é™¤æ¬„ä½ "%s" 從資料表 "%s"?'; + $lang['strcolumndropped'] = '欄ä½å·²ç§»é™¤ã€‚'; + $lang['strcolumndroppedbad'] = '欄ä½ç§»é™¤å·²å¤±æ•—。'; + $lang['straddcolumn'] = '新增欄ä½'; + $lang['strcolumnadded'] = '欄ä½å·²æ–°å¢žã€‚'; + $lang['strcolumnaddedbad'] = '欄ä½æ–°å¢žå·²å¤±æ•—。'; + $lang['strcascade'] = '附屬串è¯(CASCADE)'; + $lang['strtablealtered'] = '資料表已修改。'; + $lang['strtablealteredbad'] = '資料表修改已失敗。'; + $lang['strdataonly'] = 'åªæœ‰è³‡æ–™'; + $lang['strstructureonly'] = 'åªæœ‰çµæ§‹'; + $lang['strstructureanddata'] = 'çµæ§‹å’Œè³‡æ–™'; + $lang['strtabbed'] = '固定(Tabbed)'; + $lang['strauto'] = '自動'; + $lang['strconfvacuumtable'] = '您確定將è¦æ¸…ç†(vacuum) "%s" å—Ž?'; + $lang['strconfanalyzetable'] = '確定è¦åˆ†æž "%s" å—Ž?'; + $lang['strestimatedrowcount'] = '已估算的資料列計數'; + $lang['strestimatedrowcount'] = '估計的資料列數'; + $lang['strspecifytabletoanalyze'] = '必須至少é¸æ“‡ä¸€å€‹è³‡æ–™è¡¨ä¾†åˆ†æž'; + $lang['strspecifytabletoempty'] = '必須至少é¸æ“‡ä¸€å€‹è³‡æ–™è¡¨ä¾†æ¸…空'; + $lang['strspecifytabletodrop'] = '必須至少é¸æ“‡ä¸€å€‹è³‡æ–™è¡¨ä¾†ç§»é™¤'; + $lang['strspecifytabletovacuum'] = '必須至少é¸æ“‡ä¸€å€‹è³‡æ–™è¡¨ä¾†æ¸…ç†(vacuum)'; + + // Columns + $lang['strcolprop'] = '欄ä½å±¬æ€§'; + $lang['strnotableprovided'] = '沒有指定資料表!'; + + // Users + $lang['struser'] = '使用者'; + $lang['strusers'] = '使用者'; + $lang['strusername'] = '使用者å稱'; + $lang['strpassword'] = '密碼'; + $lang['strsuper'] = '超級使用者?'; + $lang['strcreatedb'] = '能建立資料庫?'; + $lang['strexpires'] = '失效逾期'; + $lang['strsessiondefaults'] = 'Session é è¨­'; + $lang['strnousers'] = '找ä¸åˆ°æ­¤ä½¿ç”¨è€…。'; + $lang['struserupdated'] = '使用者已更新。'; + $lang['struserupdatedbad'] = '使用者更新已失敗。'; + $lang['strshowallusers'] = '顯示所有使用者'; + $lang['strcreateuser'] = '建立新使用者'; + $lang['struserneedsname'] = '您必需為您的使用者命å。'; + $lang['strusercreated'] = '使用者已建立。'; + $lang['strusercreatedbad'] = '使用者建立已失敗。'; + $lang['strconfdropuser'] = '您確定您è¦ç§»é™¤é€™å€‹ä½¿ç”¨è€… "%s"?'; + $lang['struserdropped'] = '使用者已移除。'; + $lang['struserdroppedbad'] = '使用者移除已失敗。'; + $lang['straccount'] = '帳戶'; + $lang['strchangepassword'] = '變更密碼'; + $lang['strpasswordchanged'] = '密碼已變更。'; + $lang['strpasswordchangedbad'] = '密碼變更已失敗。'; + $lang['strpasswordshort'] = '密碼太簡短。'; + $lang['strpasswordconfirm'] = '所輸入的確èªå¯†ç¢¼ä¸ç¬¦ã€‚'; + + // Groups + $lang['strgroup'] = '群組'; + $lang['strgroups'] = '群組'; + $lang['strshowallgroups'] = '顯示全部群組'; + $lang['strnogroup'] = '找ä¸åˆ°ç¾¤çµ„。'; + $lang['strnogroups'] = '找ä¸åˆ°ä»»ä½•ç¾¤çµ„。'; + $lang['strcreategroup'] = '建立群組'; + $lang['strgroupneedsname'] = '您必需為您的群組命å。'; + $lang['strgroupcreated'] = '群組已建立。'; + $lang['strgroupcreatedbad'] = '群組建立已失敗。'; + $lang['strconfdropgroup'] = '您確定您è¦ç§»é™¤é€™å€‹ç¾¤çµ„ "%s"?'; + $lang['strgroupdropped'] = '群組已移除。'; + $lang['strgroupdroppedbad'] = '群組移除已失敗。'; + $lang['strmembers'] = 'æˆå“¡'; + $lang['strmemberof'] = 'æˆå“¡å±¬æ–¼'; + $lang['stradminmembers'] = '管ç†å“¡æˆå“¡'; + $lang['straddmember'] = '增加æˆå“¡'; + $lang['strmemberadded'] = 'æˆå“¡å·²åŠ å…¥ã€‚'; + $lang['strmemberaddedbad'] = 'æˆå“¡åŠ å…¥å·²å¤±æ•—。'; + $lang['strdropmember'] = '移除æˆå“¡'; + $lang['strconfdropmember'] = '您確定您è¦ç§»é™¤é€™å€‹æˆå“¡ "%s" 從這個群組 "%s"?'; + $lang['strmemberdropped'] = 'æˆå“¡å·²ç§»é™¤ã€‚'; + $lang['strmemberdroppedbad'] = 'æˆå“¡ç§»é™¤å·²å¤±æ•—。'; + + // Roles + $lang['strrole'] = '角色'; + $lang['strroles'] = '角色'; + $lang['strshowallroles'] = '顯示全部角色'; + $lang['strnoroles'] = '找ä¸åˆ°ä»»ä½•è§’色。'; + $lang['strinheritsprivs'] = '繼承特權?'; + $lang['strcreaterole'] = '建立角色'; + $lang['strcancreaterole'] = '能建立角色?'; + $lang['strrolecreated'] = '角色已建立。'; + $lang['strrolecreatedbad'] = '角色建立已失敗。'; + $lang['stralterrole'] = '修改角色'; + $lang['strrolealtered'] = '角色被修改。'; + $lang['strrolealteredbad'] = '角色修改已失敗。'; + $lang['strcanlogin'] = 'å¯ä»¥ç™»å…¥?'; + $lang['strconnlimit'] = '連線é™åˆ¶'; + $lang['strdroprole'] = '移除角色'; + $lang['strconfdroprole'] = '您確定您è¦ç§»é™¤é€™å€‹è§’色 "%s"?'; + $lang['strroledropped'] = '角色已移除。'; + $lang['strroledroppedbad'] = '角色移除已失敗。'; + $lang['strnolimit'] = 'ä¸é™åˆ¶'; + $lang['strnever'] = '從末'; + $lang['strroleneedsname'] = '您必需為這個角色命å。'; + + // Privileges + $lang['strprivilege'] = '特權'; + $lang['strprivileges'] = '特權'; + $lang['strnoprivileges'] = '這個物件有é è¨­çš„æ“有人特權。'; + $lang['strgrant'] = '賦予'; + $lang['strrevoke'] = '撤回'; + $lang['strgranted'] = '特權已變更。'; + $lang['strgrantfailed'] = '特權變更失敗。'; + $lang['strgrantbad'] = '您必需至少在一å使用者或群組中指定至少一項特權。'; + $lang['strgrantor'] = '授權者'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = '資料庫'; + $lang['strdatabases'] = '資料庫'; + $lang['strshowalldatabases'] = '顯示全部資料庫'; + $lang['strnodatabases'] = '找ä¸åˆ°ä»»ä½•è³‡æ–™åº«ã€‚'; + $lang['strcreatedatabase'] = '建立資料庫'; + $lang['strdatabasename'] = '資料庫å稱'; + $lang['strdatabaseneedsname'] = '您必需為您的資料庫給一個å稱。'; + $lang['strdatabasecreated'] = '資料庫已建立。'; + $lang['strdatabasecreatedbad'] = '資料庫建立失敗。'; + $lang['strconfdropdatabase'] = '您確定您è¦ç§»é™¤é€™å€‹è³‡æ–™åº« "%s"?'; + $lang['strdatabasedropped'] = '資料庫已移除。'; + $lang['strdatabasedroppedbad'] = '資料庫移除失敗。'; + $lang['strentersql'] = '在下方輸入 SQL 來執行: '; + $lang['strsqlexecuted'] = 'SQL 已執行。'; + $lang['strvacuumgood'] = '清ç†å®Œæˆã€‚'; + $lang['strvacuumbad'] = '清ç†å¤±æ•—。'; + $lang['stranalyzegood'] = '分æžå®Œæˆã€‚'; + $lang['stranalyzebad'] = '分æžå¤±æ•—。'; + $lang['strreindexgood'] = 'é‡å»ºç´¢å¼•å®Œæˆã€‚'; + $lang['strreindexbad'] = 'é‡å»ºç´¢å¼•å¤±æ•—。'; + $lang['strfull'] = '全部性'; + $lang['strfreeze'] = 'å‡çµ'; + $lang['strforce'] = '強制'; + $lang['strsignalsent'] = '訊號傳éžã€‚'; + $lang['strsignalsentbad'] = '傳éžè¨Šè™Ÿå¤±æ•—。'; + $lang['strallobjects'] = '全部物件'; + $lang['strdatabasealtered'] = '資料庫已修改。'; + $lang['strdatabasealteredbad'] = '資料庫修改已失敗。'; + $lang['strspecifydatabasetodrop'] = '必須至少指定一個資料庫來移除'; + + // Views + $lang['strview'] = '視觀表'; + $lang['strviews'] = '視觀表'; + $lang['strshowallviews'] = '顯示全部視觀表'; + $lang['strnoview'] = '找ä¸åˆ°è¦–觀表。'; + $lang['strnoviews'] = '找ä¸åˆ°ä»»ä½•è¦–觀表。'; + $lang['strcreateview'] = '建立視觀表'; + $lang['strviewname'] = '視觀表å稱'; + $lang['strviewneedsname'] = '您必需為您的視觀表給一個å稱。'; + $lang['strviewneedsdef'] = '您必需為你的視觀表給一個定義。'; + $lang['strviewneedsfields'] = '您必需在您的視觀表中é¸æ“‡çµ¦é€™å€‹æ¬„ä½ã€‚'; + $lang['strviewcreated'] = '視觀表已建立。'; + $lang['strviewcreatedbad'] = '視觀表建立已失敗。'; + $lang['strconfdropview'] = '您確定您è¦ç§»é™¤é€™å€‹è¦–觀表 "%s" å—Ž?'; + $lang['strviewdropped'] = '視觀表已移除。'; + $lang['strviewdroppedbad'] = '視觀表移除已失敗。'; + $lang['strviewlink'] = '連çµéµ(Linking keys)'; + $lang['strviewconditions'] = '附加æ¡ä»¶'; + $lang['strviewconditions'] = '附加的æ¢ä»¶é™åˆ¶'; + $lang['strcreateviewwiz'] = '建立視觀表精éˆ'; + $lang['strrenamedupfields'] = 'é‡æ–°å‘½å複製的字串'; + $lang['strdropdupfields'] = '移除複制的字串'; + $lang['strerrordupfields'] = '複製字串時發生錯誤'; + $lang['strviewupdated'] = '視觀表已更新。'; + $lang['strviewupdatedbad'] = '視觀表更新已失敗。'; + $lang['strspecifyviewtodrop'] = '必须至少指定一个视图æ¥ç§»é™¤'; + + // Sequences + $lang['strsequence'] = 'åºåˆ—數'; + $lang['strsequences'] = 'åºåˆ—數'; + $lang['strshowallsequences'] = '顯示全部åºåˆ—數'; + $lang['strnosequence'] = '找ä¸åˆ°åºåˆ—數。'; + $lang['strnosequences'] = '找ä¸åˆ°ä»»ä½•åºåˆ—數。'; + $lang['strcreatesequence'] = '建立åºåˆ—數'; + $lang['strlastvalue'] = '最後值'; + $lang['strincrementby'] = 'éžå¢žé‡'; + $lang['strstartvalue'] = 'åˆå§‹å€¼'; + $lang['strmaxvalue'] = '最大值'; + $lang['strminvalue'] = '最å°å€¼'; + $lang['strcachevalue'] = 'å¿«å–值'; + $lang['strlogcount'] = '日誌計數'; + $lang['striscycled'] = 'å¯å¾ªç’°?'; + $lang['striscalled'] = '將在返回下一個值å‰éžå¢žæœ€å¾Œçš„值(is_called)嗎?'; + $lang['strsequenceneedsname'] = '您必需為您的åºåˆ—數給一個å稱。'; + $lang['strsequencecreated'] = 'åºåˆ—數已建立。'; + $lang['strsequencecreatedbad'] = 'åºåˆ—數建立失敗。'; + $lang['strconfdropsequence'] = '您確定您è¦ç§»é™¤é€™å€‹åºåˆ—數 "%s"?'; + $lang['strsequencedropped'] = 'åºåˆ—數已移除。'; + $lang['strsequencedroppedbad'] = 'åºåˆ—數移除已失敗。'; + $lang['strsequencereset'] = 'åºåˆ—數é‡ç½®ã€‚'; + $lang['strsequenceresetbad'] = 'åºåˆ—數é‡ç½®å·²å¤±æ•—。'; + $lang['straltersequence'] = '修改åºåˆ—數'; + $lang['strsequencealtered'] = 'åºåˆ—數已修改。'; + $lang['strsequencealteredbad'] = 'åºåˆ—數修改已失敗。'; + $lang['strsetval'] = '設定åºåˆ—數值'; + $lang['strsequencesetval'] = 'åºåˆ—數值已設定。'; + $lang['strsequencesetvalbad'] = 'åºåˆ—數值設定已失敗。'; + $lang['strnextval'] = 'éžå¢žé‡'; + $lang['strsequencenextval'] = 'åºåˆ—數已éžå¢žã€‚'; + $lang['strsequencenextvalbad'] = 'åºåˆ—數已éžå¢žå¤±æ•—。'; + $lang['strspecifysequencetodrop'] = '必須至少指定一個åºåˆ—數來刪除'; + + // Indexes + $lang['strindex'] = '索引'; + $lang['strindexes'] = '索引'; + $lang['strindexname'] = '索引å稱'; + $lang['strshowallindexes'] = '顯示全部索引'; + $lang['strnoindex'] = '找ä¸åˆ°ç´¢å¼•ã€‚'; + $lang['strnoindexes'] = '找ä¸åˆ°ä»»ä½•ç´¢å¼•ã€‚'; + $lang['strcreateindex'] = '建立索引'; + $lang['strtabname'] = '資料表å稱'; + $lang['strcolumnname'] = '欄ä½å稱'; + $lang['strindexneedsname'] = '您必需為您的索引給一個å稱。'; + $lang['strindexneedscols'] = '索引è¦æ±‚一個有效欄ä½æ•¸é‡ã€‚'; + $lang['strindexcreated'] = '索引已建立'; + $lang['strindexcreatedbad'] = '索引建立失敗。'; + $lang['strconfdropindex'] = '您確定您è¦ç§»é™¤é€™å€‹ç´¢å¼• "%s" å—Ž?'; + $lang['strindexdropped'] = '索引已移除。'; + $lang['strindexdroppedbad'] = '索引移除失敗。'; + $lang['strkeyname'] = 'éµå'; + $lang['struniquekey'] = '唯一éµ'; + $lang['strprimarykey'] = '主éµ(pkey)'; + $lang['strindextype'] = '索引類型'; + $lang['strtablecolumnlist'] = '資料表欄ä½'; + $lang['strindexcolumnlist'] = '索引欄ä½'; + $lang['strconfcluster'] = '您確定您è¦å¢é›†åŒ– "%s" å—Ž?'; + $lang['strclusteredgood'] = 'å¢é›†å®Œæˆã€‚'; + $lang['strclusteredbad'] = 'å¢é›†å·²å¤±æ•—。'; + + // Rules + $lang['strrules'] = 'è¦å‰‡'; + $lang['strrule'] = 'è¦å‰‡'; + $lang['strshowallrules'] = '顯示全部è¦å‰‡'; + $lang['strnorule'] = '找ä¸åˆ°è¦å‰‡ã€‚'; + $lang['strnorules'] = '找ä¸åˆ°ä»»ä½•è¦å‰‡ã€‚'; + $lang['strcreaterule'] = '建立è¦å‰‡'; + $lang['strrulename'] = 'è¦å‰‡å稱'; + $lang['strruleneedsname'] = '您必需為您的è¦å‰‡çµ¦ä¸€å€‹å稱。'; + $lang['strrulecreated'] = 'è¦å‰‡å·²å»ºç«‹ã€‚'; + $lang['strrulecreatedbad'] = 'è¦å‰‡å»ºç«‹å·²å¤±æ•—。'; + $lang['strconfdroprule'] = '您確定您è¦ç§»é™¤é€™å€‹è¦å‰‡ "%s" 在 "%s"上嗎?'; + $lang['strruledropped'] = 'è¦å‰‡è¦å‰‡å·²ç§»é™¤ã€‚'; + $lang['strruledroppedbad'] = 'è¦å‰‡ç§»é™¤å·²å¤±æ•—。'; + + // Constraints + $lang['strconstraint'] = 'ç´„æŸé™åˆ¶'; + $lang['strconstraints'] = 'ç´„æŸé™åˆ¶'; + $lang['strshowallconstraints'] = '顯示全部約æŸé™åˆ¶'; + $lang['strnoconstraints'] = '找ä¸åˆ°ä»»ä½•ç´„æŸé™åˆ¶ã€‚'; + $lang['strcreateconstraint'] = '建立約æŸé™åˆ¶'; + $lang['strconstraintcreated'] = 'ç´„æŸé™åˆ¶å·²å»ºç«‹ã€‚'; + $lang['strconstraintcreatedbad'] = 'ç´„æŸé™åˆ¶å»ºç«‹å·²å¤±æ•—。'; + $lang['strconfdropconstraint'] = '您確定您è¦ç§»é™¤é€™ç´„æŸé™åˆ¶ "%s" 在 "%s" 上嗎?'; + $lang['strconstraintdropped'] = 'ç´„æŸé™åˆ¶å·²ç§»é™¤ã€‚'; + $lang['strconstraintdroppedbad'] = 'ç´„æŸé™åˆ¶ç§»é™¤å·²å¤±æ•—。'; + $lang['straddcheck'] = '增加約æŸæª¢æŸ¥(Check)'; + $lang['strcheckneedsdefinition'] = 'ç´„æŸæª¢æŸ¥(Check)é™åˆ¶éœ€è¦å®šç¾©ã€‚'; + $lang['strcheckadded'] = 'ç´„æŸæª¢æŸ¥é™åˆ¶å·²å¢žåŠ ã€‚'; + $lang['strcheckaddedbad'] = '增加約æŸæª¢æŸ¥é™åˆ¶å·²å¤±æ•—。'; + $lang['straddpk'] = '增加主éµ(pkey)'; + $lang['strpkneedscols'] = '主éµ(pkey)è¦æ±‚最少一個欄ä½ã€‚'; + $lang['strpkadded'] = '主éµ(pkey)已增加。'; + $lang['strpkaddedbad'] = '增加主éµ(pkey)已失敗。'; + $lang['stradduniq'] = '增加唯一約æŸé™åˆ¶'; + $lang['struniqneedscols'] = '唯一約æŸé™åˆ¶è¦æ±‚最少一個欄ä½ã€‚'; + $lang['struniqadded'] = '唯一約æŸé™åˆ¶å·²å¢žåŠ ã€‚'; + $lang['struniqaddedbad'] = '增加唯一約æŸé™åˆ¶å·²å¤±æ•—。'; + $lang['straddfk'] = '增加外部éµ(fkey)'; + $lang['strfkneedscols'] = '外部éµ(fkey)è¦æ±‚最少一個欄ä½ã€‚'; + $lang['strfkneedstarget'] = '外部éµ(fkey)è¦æ±‚一個資料表。'; + $lang['strfkadded'] = '外部éµ(fkey)已增加。'; + $lang['strfkaddedbad'] = '增加外部éµ(fkey)已失敗。'; + $lang['strfktarget'] = '目標資料表'; + $lang['strfkcolumnlist'] = 'éµæ¬„ä½'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = '函數'; + $lang['strfunctions'] = '函數'; + $lang['strshowallfunctions'] = '顯示全部函數'; + $lang['strnofunction'] = '找ä¸åˆ°å‡½æ•¸ã€‚'; + $lang['strnofunctions'] = '找ä¸åˆ°ä»»ä½•å‡½æ•¸ã€‚'; + $lang['strcreateplfunction'] = '建立 SQL/PL 函數'; + $lang['strcreateinternalfunction'] = '建立內部函數'; + $lang['strcreatecfunction'] = '建立 C 函數'; + $lang['strfunctionname'] = '函數å稱'; + $lang['strreturns'] = 'éžå›ž'; + $lang['strproglanguage'] = '程åºèªžè¨€'; + $lang['strfunctionneedsname'] = '您必需為您的函數給一個å稱。'; + $lang['strfunctionneedsdef'] = '您必需為您的函數給一個定義。'; + $lang['strfunctioncreated'] = '函數已建立。'; + $lang['strfunctioncreatedbad'] = '函數建立已失敗。'; + $lang['strconfdropfunction'] = '您確定您è¦ç§»é™¤é€™å€‹å‡½æ•¸ "%s"?'; + $lang['strfunctiondropped'] = '函數已移除。'; + $lang['strfunctiondroppedbad'] = '函數移除已失敗。'; + $lang['strfunctionupdated'] = '函數已更新。'; + $lang['strfunctionupdatedbad'] = '函數更新已失敗。'; + $lang['strobjectfile'] = '物件檔案'; + $lang['strlinksymbol'] = '連çµç‰©ä»¶æ¨™è¨˜'; + $lang['strarguments'] = '引數'; + $lang['strargmode'] = 'æ–¹å¼'; + $lang['strargtype'] = 'é¡žåž‹'; + $lang['strargadd'] = '增加作者引數'; + $lang['strargremove'] = '移除這個引數'; + $lang['strargnoargs'] = '這個函數將ä¸èƒ½å·¥ä½œä»»ä½•å¼•æ•¸ã€‚'; + $lang['strargenableargs'] = '啟用引數已被傳éžåˆ°é€™å€‹å‡½æ•¸ã€‚'; + $lang['strargnorowabove'] = '需è¦è³‡æ–™åˆ—在這資料列之上。'; + $lang['strargnorowbelow'] = '需è¦è³‡æ–™åˆ—在這資料列之å‰ã€‚'; + $lang['strargraise'] = 'å‘上移。'; + $lang['strarglower'] = 'å‘下移。'; + $lang['strargremoveconfirm'] = '您確定你è¦ç§»é™¤é€™å€‹å¼•æ•¸? 這個作業未能完æˆã€‚'; + $lang['strfunctioncosting'] = '函數æˆæœ¬'; + $lang['strresultrows'] = '结果集資料行數'; + $lang['strexecutioncost'] = '執行æˆæœ¬'; + $lang['strspecifyfunctiontodrop'] = '必須至少指定一個函數來刪除'; + + // Triggers + $lang['strtrigger'] = '觸發器'; + $lang['strtriggers'] = '觸發器'; + $lang['strshowalltriggers'] = '顯示全部觸發器'; + $lang['strnotrigger'] = '找ä¸åˆ°è§¸ç™¼å™¨ã€‚'; + $lang['strnotriggers'] = '找ä¸åˆ°ä»»ä½•è§¸ç™¼å™¨ã€‚'; + $lang['strcreatetrigger'] = '建立觸發器'; + $lang['strtriggerneedsname'] = '您必需為您的觸發器明確指定一個å稱。'; + $lang['strtriggerneedsfunc'] = '您必需為您的觸發器明確指定一個函數。'; + $lang['strtriggercreated'] = '觸發器已建立。'; + $lang['strtriggercreatedbad'] = '觸發器建立已失敗。'; + $lang['strconfdroptrigger'] = '您確定您è¦ç§»é™¤é€™å€‹è§¸ç™¼å™¨ "%s" on "%s"?'; + $lang['strconfenabletrigger'] = '您確定您è¦å•Ÿç”¨é€™å€‹è§¸ç™¼å™¨è§¸ç™¼å™¨ "%s" 在 "%s" 上?'; + $lang['strconfdisabletrigger'] = '您確定您è¦åœç”¨é€™å€‹è§¸ç™¼å™¨è§¸ç™¼å™¨ "%s" on "%s" 上?'; + $lang['strtriggerdropped'] = '觸發器已移除。'; + $lang['strtriggerdroppedbad'] = '觸發器移除已失敗。'; + $lang['strtriggerenabled'] = '觸發器啟用。'; + $lang['strtriggerenabledbad'] = '觸發器啟用已失敗。'; + $lang['strtriggerdisabled'] = '觸發器åœç”¨ã€‚'; + $lang['strtriggerdisabledbad'] = '觸發器åœç”¨å·²å¤±æ•—。'; + $lang['strtriggeraltered'] = '觸發器已修改。'; + $lang['strtriggeralteredbad'] = '觸發器修改已失敗。'; + $lang['strforeach'] = '給æ¯å€‹'; + + // Types + $lang['strtype'] = 'é¡žåž‹'; + $lang['strtypes'] = 'é¡žåž‹'; + $lang['strshowalltypes'] = '顯示全部類型'; + $lang['strnotype'] = '找ä¸åˆ°é¡žåž‹ã€‚'; + $lang['strnotypes'] = '找ä¸åˆ°ä»»ä½•é¡žåž‹ã€‚'; + $lang['strcreatetype'] = '建立類型'; + $lang['strcreatecomptype'] = '建立åˆæˆé¡žåž‹'; + $lang['strcreateenumtype'] = '建立列舉類型'; + $lang['strtypeneedsfield'] = '您必須明確指定最少一個欄ä½ã€‚'; + $lang['strtypeneedsvalue'] = '您必須明確指定最少一個值。'; + $lang['strtypeneedscols'] = '您必須明確指定有效的欄ä½æ•¸ã€‚'; + $lang['strtypeneedsvals'] = '您必須明確指定一個有效的欄ä½æ•¸ã€‚'; + $lang['strinputfn'] = '輸入類型'; + $lang['stroutputfn'] = '輸出類型'; + $lang['strpassbyval'] = '以值傳é€?'; + $lang['stralignment'] = '列隊組åˆ'; + $lang['strelement'] = '元素'; + $lang['strdelimiter'] = '分隔符號'; + $lang['strstorage'] = '儲è—所'; + $lang['strfield'] = '欄ä½'; + $lang['strvalue'] = '值'; + $lang['strnumfields'] = '欄ä½æ•¸. '; + $lang['strnumvalues'] = '值數'; + $lang['strtypeneedsname'] = '您必需為您的類型給一個å稱。'; + $lang['strtypeneedslen'] = '您必需為您的類型給一個長度。'; + $lang['strtypecreated'] = '類型已建立'; + $lang['strtypecreatedbad'] = '類型建立已失敗。'; + $lang['strconfdroptype'] = '您確定您è¦ç§»é™¤é€™å€‹é¡žåž‹ "%s" å—Ž?'; + $lang['strtypedropped'] = '類型已移除。'; + $lang['strtypedroppedbad'] = '類型移除已失敗。'; + $lang['strflavor'] = '風格(Flavor)'; + $lang['strbasetype'] = '基礎'; + $lang['strcompositetype'] = 'åˆæˆ'; + $lang['strpseudotype'] = 'å½(Pseudo)'; + $lang['strenum'] = 'Enum'; + $lang['strenumvalues'] = '列舉類型'; + + // Schemas + $lang['strschema'] = '架構模å¼'; + $lang['strschemas'] = '架構模å¼'; + $lang['strshowallschemas'] = '顯示全部架構模å¼'; + $lang['strnoschema'] = '找ä¸åˆ°æž¶æ§‹æ¨¡å¼ã€‚'; + $lang['strnoschemas'] = '找ä¸åˆ°ä»»ä½•æž¶æ§‹æ¨¡å¼ã€‚'; + $lang['strcreateschema'] = '建立架構模å¼'; + $lang['strschemaname'] = '架構模å¼å稱'; + $lang['strschemaneedsname'] = '您必需為您的架構模å¼çµ¦ä¸€å€‹å稱。'; + $lang['strschemacreated'] = '架構模å¼å·²å»ºç«‹'; + $lang['strschemacreatedbad'] = '架構模å¼å»ºç«‹å·²å¤±æ•—。'; + $lang['strconfdropschema'] = '您確定您è¦ç§»é™¤é€™å€‹æž¶æ§‹æ¨¡å¼ "%s" å—Ž?'; + $lang['strschemadropped'] = '架構模å¼å·²ç§»é™¤ã€‚'; + $lang['strschemadroppedbad'] = '架構模å¼ç§»é™¤å¤±æ•—。'; + $lang['strschemaaltered'] = '架構模å¼å·²ä¿®æ”¹ã€‚'; + $lang['strschemaalteredbad'] = '架構模å¼ä¿®æ”¹å·²å¤±æ•—。'; + $lang['strsearchpath'] = '架構模å¼æœå°‹è·¯å¾‘'; + $lang['strspecifyschematodrop'] = '您必須至少指定一個架構模å¼ä¾†åˆªé™¤'; + + // Reports + + // Domains + $lang['strdomain'] = 'å…±åŒå€¼åŸŸ'; + $lang['strdomains'] = 'å…±åŒå€¼åŸŸ'; + $lang['strshowalldomains'] = '顯示全部共åŒå€¼åŸŸ'; + $lang['strnodomains'] = '找ä¸åˆ°ä»»ä½•å…±åŒå€¼åŸŸã€‚'; + $lang['strcreatedomain'] = '建立共åŒå€¼åŸŸ'; + $lang['strdomaindropped'] = 'å…±åŒå€¼åŸŸå·²ç§»é™¤ã€‚'; + $lang['strdomaindroppedbad'] = 'å…±åŒå€¼åŸŸç§»é™¤å·²å¤±æ•—。'; + $lang['strconfdropdomain'] = '您確定您è¦ç§»é™¤é€™å€‹å…±åŒå€¼åŸŸ "%s"?'; + $lang['strdomainneedsname'] = '您必需為您的共åŒå€¼åŸŸçµ¦ä¸€å€‹å稱。。'; + $lang['strdomaincreated'] = 'å…±åŒå€¼åŸŸå·²å»ºç«‹ã€‚'; + $lang['strdomaincreatedbad'] = 'å…±åŒå€¼åŸŸå»ºç«‹å·²å¤±æ•—。'; + $lang['strdomainaltered'] = 'å…±åŒå€¼åŸŸå·²ä¿®æ”¹ã€‚'; + $lang['strdomainalteredbad'] = 'å…±åŒå€¼åŸŸä¿®æ”¹å·²å¤±æ•—。'; + + // Operators + $lang['stroperator'] = 'é‹ç®—å­'; + $lang['stroperators'] = 'é‹ç®—å­'; + $lang['strshowalloperators'] = '顯示全部é‹ç®—å­'; + $lang['strnooperator'] = '找ä¸åˆ°é‹ç®—å­ã€‚'; + $lang['strnooperators'] = '找ä¸åˆ°ä»»ä½•é‹ç®—å­ã€‚'; + $lang['strcreateoperator'] = '建立é‹ç®—å­'; + $lang['strleftarg'] = '左引數類型'; + $lang['strrightarg'] = 'å³å¼•æ•¸é¡žåž‹'; + $lang['strcommutator'] = '轉æ›å™¨'; + $lang['strnegator'] = 'å¦å®šå™¨'; + $lang['strrestrict'] = 'é™åˆ¶'; + $lang['strjoin'] = 'çµåˆ'; + $lang['strhashes'] = '雜湊(Hashes)'; + $lang['strmerges'] = 'åˆä½µ'; + $lang['strleftsort'] = '左排åº'; + $lang['strrightsort'] = 'å³æŽ’åº'; + $lang['strlessthan'] = 'å°æ–¼'; + $lang['strgreaterthan'] = '大於'; + $lang['stroperatorneedsname'] = '您必需為您的é‹ç®—å­çµ¦ä¸€å€‹å稱。'; + $lang['stroperatorcreated'] = 'é‹ç®—å­å·²å»ºç«‹'; + $lang['stroperatorcreatedbad'] = 'é‹ç®—å­å»ºç«‹å·²å¤±æ•—。'; + $lang['strconfdropoperator'] = '您確定您è¦ç§»é™¤é€™å€‹é‹ç®—å­ "%s" å—Ž?'; + $lang['stroperatordropped'] = 'é‹ç®—å­å·²ç§»é™¤ã€‚'; + $lang['stroperatordroppedbad'] = 'é‹ç®—å­ç§»é™¤å·²å¤±æ•—。'; + + // Casts + $lang['strcasts'] = '類型轉æ›'; + $lang['strnocasts'] = '找ä¸åˆ°ä»»ä½•é¡žåž‹è½‰æ›ã€‚'; + $lang['strsourcetype'] = '來æºé¡žåž‹'; + $lang['strtargettype'] = '目標類型'; + $lang['strimplicit'] = 'éš±å«'; + $lang['strinassignment'] = '在指派中'; + $lang['strbinarycompat'] = '(二進制碼相容)'; + + // Conversions + $lang['strconversions'] = '編碼轉æ›'; + $lang['strnoconversions'] = '找ä¸åˆ°ä»»ä½•ç·¨ç¢¼è½‰æ›ã€‚'; + $lang['strsourceencoding'] = '來æºç·¨ç¢¼'; + $lang['strtargetencoding'] = '目標編碼'; + + // Languages + $lang['strlanguages'] = '程åºèªžè¨€'; + $lang['strnolanguages'] = '找ä¸åˆ°ä»»ä½•ç¨‹åºèªžè¨€ã€‚'; + $lang['strtrusted'] = '被信任的'; + + // Info + $lang['strnoinfo'] = '無資訊å¯ç”¨ã€‚'; + $lang['strreferringtables'] = 'åƒç…§ä¸­è³‡æ–™è¡¨'; + $lang['strparenttables'] = '父資料表'; + $lang['strchildtables'] = 'å­è³‡æ–™è¡¨'; + + // Aggregates + $lang['straggregate'] = 'èšé›†å‡½æ•¸'; + $lang['straggregates'] = 'èšé›†å‡½æ•¸'; + $lang['strnoaggregates'] = '找ä¸åˆ°ä»»ä½•èšé›†å‡½æ•¸ã€‚'; + $lang['stralltypes'] = '(全部類型)'; + $lang['strcreateaggregate'] = '建立èšé›†å‡½æ•¸'; + $lang['straggrbasetype'] = '輸入資料類型'; + $lang['straggrsfunc'] = '狀態éŽæ¸¡å‡½æ•¸'; + $lang['straggrstype'] = '狀態類型'; + $lang['straggrffunc'] = '最終函數'; + $lang['straggrinitcond'] = '最åˆæ¢ä»¶'; + $lang['straggrsortop'] = '排åºé‹ç®—å­'; + $lang['strconfdropaggregate'] = '您確定您è¦ç§»é™¤é€™å€‹èšé›†å‡½æ•¸ "%s" å—Ž?'; + $lang['straggregatedropped'] = 'èšé›†å‡½æ•¸å·²ç§»é™¤ã€‚'; + $lang['straggregatedroppedbad'] = 'èšé›†å‡½æ•¸ç§»é™¤å·²å¤±æ•—。'; + $lang['straggraltered'] = 'èšé›†å‡½æ•¸å·²ä¿®æ”¹ã€‚'; + $lang['straggralteredbad'] = 'èšé›†å‡½æ•¸ä¿®æ”¹å·²å¤±æ•—。'; + $lang['straggrneedsname'] = '您必需具體指定一個å稱給這個èšé›†å‡½æ•¸ã€‚'; + $lang['straggrneedsbasetype'] = '您必需具體指定這èšé›†å‡½æ•¸çš„進入資料類型。'; + $lang['straggrneedssfunc'] = '您必需具體指定這這èšé›†å‡½æ•¸çš„狀態éŽæ¸¡å‡½æ•¸å稱。'; + $lang['straggrneedsstype'] = '您必需具體指定這èšé›†å‡½æ•¸ç¾¤ç‹€æ…‹å€¼çš„資料類型'; + $lang['straggrcreated'] = 'èšé›†å‡½æ•¸å·²å»ºç«‹ã€‚'; + $lang['straggrcreatedbad'] = 'èšé›†å‡½æ•¸å»ºç«‹å·²å¤±æ•—。'; + $lang['straggrshowall'] = '顯示全部èšé›†å‡½æ•¸'; + + // Operator Classes + $lang['stropclasses'] = 'é‹ç®—å­é¡žåˆ¥'; + $lang['strnoopclasses'] = '找ä¸åˆ°ä»»ä½•é‹ç®—å­é¡žåˆ¥ã€‚'; + $lang['straccessmethod'] = 'å­˜å–方法'; + + // Stats and performance + $lang['strrowperf'] = '資料列性能'; + $lang['strioperf'] = 'I/O 性能'; + $lang['stridxrowperf'] = '索引資料列性能'; + $lang['stridxioperf'] = '索引 I/O 性能'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'é †åºæ€§'; + $lang['strscan'] = '掃æ'; + $lang['strread'] = '讀å–'; + $lang['strfetch'] = 'å–å¾—'; + $lang['strheap'] = '堆疊'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST 索引'; + $lang['strcache'] = 'å¿«å–'; + $lang['strdisk'] = 'ç£ç¢Ÿ'; + $lang['strrows2'] = '資料列'; + + // Tablespaces + $lang['strtablespace'] = '表空間'; + $lang['strtablespaces'] = '表空間'; + $lang['strshowalltablespaces'] = '顯示全部表空間'; + $lang['strnotablespaces'] = '找ä¸åˆ°ä»»ä½•è¡¨ç©ºé–“。'; + $lang['strcreatetablespace'] = '建立表空間'; + $lang['strlocation'] = '所在ä½ç½®'; + $lang['strtablespaceneedsname'] = '您必需為您的表空間給一個å稱。'; + $lang['strtablespaceneedsloc'] = '您必需給一個目錄夾來建立表空間。'; + $lang['strtablespacecreated'] = '表空間已建立。'; + $lang['strtablespacecreatedbad'] = '表空間建立已失敗。'; + $lang['strconfdroptablespace'] = '您確定您è¦ç§»é™¤é€™å€‹è¡¨ç©ºé–“ "%s"?'; + $lang['strtablespacedropped'] = '表空間已移除。'; + $lang['strtablespacedroppedbad'] = '表空間移除已失敗。'; + $lang['strtablespacealtered'] = '表空間已修改。'; + $lang['strtablespacealteredbad'] = '表空間修改已失敗。'; + + // Miscellaneous + $lang['strtopbar'] = '%s é‹ä½œæ–¼ %s: %s -- 您是已登入的使用者 "%s"'; + $lang['strtimefmt'] = 'jS M, Y g: iA'; + $lang['strhelp'] = '說明'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = '說明é ç€è¦½å™¨'; + $lang['strselecthelppage'] = 'é¸æ“‡ä¸€å€‹èªªæ˜Žé '; + $lang['strinvalidhelppage'] = '無效說明é ã€‚'; + $lang['strlogintitle'] = '登入到 %s'; + $lang['strlogoutmsg'] = '登出 %s'; + $lang['strloading'] = '載入中...'; + $lang['strerrorloading'] = '載入中錯誤'; + $lang['strclicktoreload'] = '點擊到é‡æ–°è¼‰å…¥'; + + // Autovacuum + $lang['strautovacuum'] = '自動清ç†(Autovacuum)'; + $lang['strturnedon'] = '已轉動 - é–‹å•Ÿ'; + $lang['strturnedoff'] = '已轉動 - 關閉'; + $lang['strenabled'] = '啟用'; + $lang['strvacuumbasethreshold'] = 'Vacuum 基本門檻'; + $lang['strvacuumscalefactor'] = 'Vacuum æ›ç®—係數'; + $lang['stranalybasethreshold'] = 'Analyze 基本門檻'; + $lang['stranalyzescalefactor'] = 'Analyze æ›ç®—係數'; + $lang['strvacuumcostdelay'] = 'Vacuum æˆæœ¬å»¶é²'; + $lang['strvacuumcostlimit'] = 'Vacuum æˆæœ¬é™åˆ¶'; + + // Table-level Locks + $lang['strlocks'] = '鎖定'; + $lang['strtransaction'] = '事務交易 ID'; + $lang['strvirtualtransaction'] = '虛擬事務交易 ID'; + $lang['strprocessid'] = '進程 ID'; + $lang['strmode'] = '鎖定模å¼'; + $lang['strislockheld'] = '是鎖定執(held)?'; + + // Prepared transactions + $lang['strpreparedxacts'] = '已準備事務交易'; + $lang['strxactid'] = '事務交易 ID'; + $lang['strgid'] = 'Global ID'; + + // Fulltext search + $lang['strfulltext'] = '全文檢索'; + $lang['strftsconfig'] = '全文檢索組態'; + $lang['strftsconfigs'] = '組態'; + $lang['strftscreateconfig'] = '新建全文檢索組態'; + $lang['strftscreatedict'] = '新建字典'; + $lang['strftscreatedicttemplate'] = '新建字典模æ¿'; + $lang['strftscreateparser'] = '新建分æžå™¨'; + $lang['strftsnoconfigs'] = '沒有找到全文檢索組態。'; + $lang['strftsconfigdropped'] = '全文檢索組態已移除。'; + $lang['strftsconfigdroppedbad'] = '全文檢索移除失敗。'; + $lang['strconfdropftsconfig'] = '確定è¦ç§»é™¤å…¨æ–‡æª¢ç´¢æª¢ç´¢çµ„æ…‹ "%s" å—Ž?'; + $lang['strconfdropftsdict'] = '確定è¦ç§»é™¤å…¨æ–‡æª¢ç´¢å­—å…¸ "%s" å—Ž?'; + $lang['strconfdropftsmapping'] = '確定è¦å°‡æ˜ å°„ "%s" 從全文檢索組態 "%s" 中移除嗎?'; + $lang['strftstemplate'] = '模æ¿'; + $lang['strftsparser'] = '分æžå™¨'; + $lang['strftsconfigneedsname'] = '必須指定全文檢索組態å稱。'; + $lang['strftsconfigcreated'] = '全文檢索組態已創建'; + $lang['strftsconfigcreatedbad'] = '全文檢索組態創建失敗。'; + $lang['strftsmapping'] = '映射'; + $lang['strftsdicts'] = 'å­—å…¸'; + $lang['strftsdict'] = 'å­—å…¸'; + $lang['strftsemptymap'] = '空的全文檢索組態映射。'; + $lang['strftswithmap'] = '附帶映射(With map)'; + $lang['strftsmakedefault'] = '為本地化作æˆé»˜èªå€¼'; + $lang['strftsconfigaltered'] = '全文檢索已修改。'; + $lang['strftsconfigalteredbad'] = '全文檢索修改失敗。'; + $lang['strftsconfigmap'] = '全文檢索組態映射'; + $lang['strftsparsers'] = '全文檢索分æžå™¨'; + $lang['strftsnoparsers'] = '無有效的全文檢索分æžå™¨ã€‚'; + $lang['strftsnodicts'] = '無有效的全文檢索字典。'; + $lang['strftsdictcreated'] = '全文檢索字典已創建'; + $lang['strftsdictcreatedbad'] = '全文檢索字典創建失敗。'; + $lang['strftslexize'] = 'è©žå½™'; + $lang['strftsinit'] = 'åˆå§‹åŒ–'; + $lang['strftsoptionsvalues'] = 'é¸é …和值'; + $lang['strftsdictneedsname'] = '必須指定全文檢索字典å稱。'; + $lang['strftsdictdropped'] = '全文檢索字典已移除。'; + $lang['strftsdictdroppedbad'] = '全文檢索字典移除失敗。'; + $lang['strftsdictaltered'] = '全文檢索字典已修改。'; + $lang['strftsdictalteredbad'] = '全文檢索字典修改失敗。'; + $lang['strftsaddmapping'] = '增加映射'; + $lang['strftsspecifymappingtodrop'] = '必須最少指定一個映射來移除'; + $lang['strftsspecifyconfigtoalter'] = '必須指定一個全文檢索é…置來修改'; + $lang['strftsmappingdropped'] = '全文檢索映射已刪除。'; + $lang['strftsmappingdroppedbad'] = '全文檢索映射移除失敗。'; + $lang['strftsnodictionaries'] = '查無字典。'; + $lang['strftsmappingaltered'] = '全文檢索映射已修改。'; + $lang['strftsmappingalteredbad'] = '全文檢索映射修改失敗。'; + $lang['strftsmappingadded'] = '全文檢索映射已增加。'; + $lang['strftsmappingaddedbad'] = '全文檢索映射增加失敗。'; + $lang['strftstabconfigs'] = '組態'; + $lang['strftstabdicts'] = 'å­—å…¸'; + $lang['strftstabparsers'] = '分æžå™¨'; + $lang['strftsaddmapping'] = '增加映射'; + $lang['strftsspecifymappingtodrop'] = '必须最少指定一个映射æ¥ç§»é™¤'; + $lang['strftsspecifyconfigtoalter'] = '必须指定一个全文检索組態æ¥ä¿®æ”¹'; + $lang['strftsmappingdropped'] = '全文检索映射已删除。'; + $lang['strftsmappingdroppedbad'] = '全文检索映射移除失败。'; + $lang['strftsnodictionaries'] = '查无字典。'; + $lang['strftsmappingaltered'] = '全文检索映射已修改。'; + $lang['strftsmappingalteredbad'] = '全文检索映射修改失败。'; + $lang['strftsmappingadded'] = '全文检索映射已增加。'; + $lang['strftsmappingaddedbad'] = '全文检索映射增加失败。'; + $lang['strftsmappingdropped'] = '全文检索映射已删除。'; + $lang['strftsmappingdroppedbad'] = '全文检索映射移除失败。'; + $lang['strftstabconfigs'] = '組態'; + $lang['strftstabdicts'] = 'å­—å…¸'; + $lang['strftstabparsers'] = '分æžå™¨'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/czech.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/czech.php new file mode 100644 index 00000000..c8f79866 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/czech.php @@ -0,0 +1,897 @@ +'; + $lang['strfirst'] = '<< První'; + $lang['strlast'] = 'Poslední >>'; + $lang['strfailed'] = 'NezdaÅ™ilo se'; + $lang['strcreate'] = 'VytvoÅ™it'; + $lang['strcreated'] = 'VytvoÅ™eno'; + $lang['strcomment'] = 'Komentář'; + $lang['strlength'] = 'Délka'; + $lang['strdefault'] = 'Výchozí'; + $lang['stralter'] = 'ZmÄ›nit'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Storno'; + $lang['strkill'] = 'Zabít'; + $lang['strac'] = 'Povolit automatické dokonÄení'; + $lang['strsave'] = 'Uložit'; + $lang['strreset'] = 'Resetovat'; + $lang['strrestart'] = 'Restartovat'; + $lang['strinsert'] = 'Vložit'; + $lang['strselect'] = 'Vybrat'; + $lang['strdelete'] = 'Smazat'; + $lang['strupdate'] = 'Aktualizovat'; + $lang['strreferences'] = 'Odkazy'; + $lang['stryes'] = 'Ano'; + $lang['strno'] = 'Ne'; + $lang['strtrue'] = 'PRAVDA'; + $lang['strfalse'] = 'NEPRAVDA'; + $lang['stredit'] = 'Upravit'; + $lang['strcolumn'] = 'Sloupec'; + $lang['strcolumns'] = 'Sloupce'; + $lang['strrows'] = 'řádků'; + $lang['strrowsaff'] = 'řádků zmÄ›nÄ›no.'; + $lang['strobjects'] = 'objektů'; + $lang['strback'] = 'ZpÄ›t'; + $lang['strqueryresults'] = 'Výsledky dotazu'; + $lang['strshow'] = 'Zobrazit'; + $lang['strempty'] = 'Vyprázdnit'; + $lang['strlanguage'] = 'Jazyk'; + $lang['strencoding'] = 'Kódování'; + $lang['strvalue'] = 'Hodnota'; + $lang['strunique'] = 'JedineÄný'; + $lang['strprimary'] = 'Primární'; + $lang['strexport'] = 'Export'; + $lang['strimport'] = 'Import'; + $lang['strallowednulls'] = 'Povolené nulové znaky'; + $lang['strbackslashn'] = '\n'; + $lang['stremptystring'] = 'Prázdné Å™etÄ›zce/pole'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Správa'; + $lang['strvacuum'] = 'Uklidit'; + $lang['stranalyze'] = 'Analyzovat'; + $lang['strclusterindex'] = 'PÅ™eskupit'; + $lang['strclustered'] = 'PÅ™eskupeno?'; + $lang['strreindex'] = 'PÅ™eindexovat'; + $lang['strexecute'] = 'Provést'; + $lang['stradd'] = 'PÅ™idat'; + $lang['strevent'] = 'Událost'; + $lang['strwhere'] = 'Kde'; + $lang['strinstead'] = 'Místo původního'; + $lang['strwhen'] = 'Kdy'; + $lang['strformat'] = 'Formát'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'Potvrzení'; + $lang['strexpression'] = 'Výraz'; + $lang['strellipsis'] = '…'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Rozbalit'; + $lang['strcollapse'] = 'Sbalit'; + $lang['strfind'] = 'Hledat'; + $lang['stroptions'] = 'Volby'; + $lang['strrefresh'] = 'ObÄerstvit'; + $lang['strdownload'] = 'Stáhnout'; + $lang['strdownloadgzipped'] = 'Stáhnout komprimované pomocí gzip'; + $lang['strinfo'] = 'Informace'; + $lang['stroids'] = 'OID'; + $lang['stradvanced'] = 'PokroÄilé'; + $lang['strvariables'] = 'PromÄ›nné'; + $lang['strprocess'] = 'Proces'; + $lang['strprocesses'] = 'Procesy'; + $lang['strsetting'] = 'Nastavení'; + $lang['streditsql'] = 'Upravit SQL'; + $lang['strruntime'] = 'Celková doba bÄ›hu: %s ms'; + $lang['strpaginate'] = 'Stránkovat výsledky'; + $lang['struploadscript'] = 'nebo nahrajte skript SQL:'; + $lang['strstarttime'] = 'ÄŒas spuÅ¡tÄ›ní'; + $lang['strfile'] = 'Soubor'; + $lang['strfileimported'] = 'Soubor byl importován.'; + $lang['strtrycred'] = 'Použít tato prověření pro vÅ¡echny servery'; + $lang['strconfdropcred'] = 'Odpojením se z bezpeÄnostních důvodů smažou vaÅ¡e sdílené pÅ™ipojovací informace. Opravdu se chcete odpojit?'; + $lang['stractionsonmultiplelines'] = 'Akce pro víc řádků'; + $lang['strselectall'] = 'Vybrat vÅ¡e'; + $lang['strunselectall'] = 'ZruÅ¡it výbÄ›r'; + $lang['strlocale'] = 'Místní nastavení'; + $lang['strcollation'] = 'Řazení'; + $lang['strctype'] = 'Typ znaku'; + $lang['strdefaultvalues'] = 'Výchozí hodnoty'; + $lang['strnewvalues'] = 'Nové hodnoty'; + $lang['strstart'] = 'Spustit'; + $lang['strstop'] = 'Zastavit'; + $lang['strgotoppage'] = 'zpÄ›t nahoru'; + $lang['strtheme'] = 'Motiv'; + $lang['strcluster'] = 'Klastr'; + + // Admin + $lang['stradminondatabase'] = 'Následující úlohy správy použít na celou databázi %s.'; + $lang['stradminontable'] = 'Následující úlohy správy použít na tabulku %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'Historie'; + $lang['strnohistory'] = 'Bez historie.'; + $lang['strclearhistory'] = 'Smazat historii'; + $lang['strdelhistory'] = 'Odebrat z historie'; + $lang['strconfdelhistory'] = 'Opravdu tento požadavek odebrat z historie?'; + $lang['strconfclearhistory'] = 'SkuteÄnÄ› smazat historii?'; + $lang['strnodatabaseselected'] = 'Zvolte prosím databázi.'; + + // Database sizes + $lang['strnoaccess'] = 'Bez přístupu'; + $lang['strsize'] = 'Velikost'; + $lang['strbytes'] = 'B'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Tato aplikace pracuje nejlépe, pokud jsou v prohlížeÄi povolené rámy. Může ale pracovat i bez rámů, staÄí kliknout na následující odkaz.'; + $lang['strnoframeslink'] = 'Použít bez rámů'; + $lang['strbadconfig'] = 'Váš config.inc.php je zastaralý. PotÅ™ebujete jej vygenerovat znovu z nového config.inc.php-dist.'; + $lang['strnotloaded'] = 'VaÅ¡e instalace PHP nepodporuje PostgreSQL. PotÅ™ebujete znovu pÅ™eložit PHP s použitím volby --with-pgsql.'; + $lang['strpostgresqlversionnotsupported'] = 'Verze PostgreSQL není podporovaná. PÅ™ejdÄ›te prosím na verzi %s nebo novÄ›jší.'; + $lang['strbadschema'] = 'Zadáno neplatné schéma.'; + $lang['strbadencoding'] = 'NezdaÅ™ilo se nastavit kódování klienta v databázi.'; + $lang['strsqlerror'] = 'Chyba SQL:'; + $lang['strinstatement'] = 'Ve výrazu:'; + $lang['strinvalidparam'] = 'Neplatné parametry skriptu.'; + $lang['strnodata'] = 'Nenalezen žádný řádek.'; + $lang['strnoobjects'] = 'Nenalezen žádný objekt.'; + $lang['strrownotunique'] = 'Pro tento řádek neexistuje jedineÄný identifikátor.'; + $lang['strnouploads'] = 'Je zakázané nahrávání souborů.'; + $lang['strimporterror'] = 'Chyba pÅ™i importu.'; + $lang['strimporterror-fileformat'] = 'Chyba pÅ™i importu: NezdaÅ™ilo se automaticky zjistit formát souboru.'; + $lang['strimporterrorline'] = 'Chyba pÅ™i importu na řádku %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Chyba pÅ™i importu na řádku %s: Řádek nemá správný poÄet sloupců.'; + $lang['strimporterror-uploadedfile'] = 'Chyba pÅ™i importu: Soubor nelze nahrát na server'; + $lang['strcannotdumponwindows'] = 'Ve Windows není podporovaný výpis názvů komplexních tabulek a schémat.'; + $lang['strinvalidserverparam'] = 'Pokus o pÅ™ipojení s neplatnými parametry serveru, možná se nÄ›kdo snaží neoprávnÄ›nÄ› napojit do vaÅ¡eho systému.'; + $lang['strnoserversupplied'] = 'Není nabízen žádný server!'; + $lang['strbadpgdumppath'] = 'Chyba pÅ™i exportu: NezdaÅ™ilo se spustit pg_dump (s cestou danou ve vaÅ¡em conf/config.inc.php: %s). Opravte prosím cestu ve svém nastavení a zkuste to znovu.'; + $lang['strbadpgdumpallpath'] = 'Chyba pÅ™i exportu: NezdaÅ™ilo se spustit pg_dumpall (s cestou danou ve vaÅ¡em conf/config.inc.php: %s). Opravte prosím cestu ve svém nastavení a zkuste to znovu.'; + $lang['strconnectionfail'] = 'Nelze se pÅ™ipojit k serveru.'; + + // Tables + $lang['strtable'] = 'Tabulka'; + $lang['strtables'] = 'Tabulky'; + $lang['strshowalltables'] = 'Zobrazit vÅ¡echny tabulky'; + $lang['strnotables'] = 'Nenalezeny žádné tabulky.'; + $lang['strnotable'] = 'Nenalezena žádná tabulka.'; + $lang['strcreatetable'] = 'VytvoÅ™it tabulku'; + $lang['strcreatetablelike'] = 'VytvoÅ™it tabulku podle'; + $lang['strcreatetablelikeparent'] = 'Zdrojová tabulka'; + $lang['strcreatelikewithdefaults'] = 'VÄetnÄ› výchozích'; + $lang['strcreatelikewithconstraints'] = 'VÄetnÄ› omezení'; + $lang['strcreatelikewithindexes'] = 'VÄetnÄ› indexů'; + $lang['strtablename'] = 'Název tabulky'; + $lang['strtableneedsname'] = 'Musíte zadat název pro tabulku.'; + $lang['strtablelikeneedslike'] = 'Musíte zvolit, z které tabulky se budou vlastnosti kopírovat.'; + $lang['strtableneedsfield'] = 'Musíte zadat nejménÄ› jedno pole.'; + $lang['strtableneedscols'] = 'Musíte zadat platný poÄet sloupců.'; + $lang['strtablecreated'] = 'Tabulka byla vytvoÅ™ena.'; + $lang['strtablecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it tabulku.'; + $lang['strconfdroptable'] = 'Opravdu chcete odstranit tabulku „%s“?'; + $lang['strtabledropped'] = 'Tabulka byla odstranÄ›na.'; + $lang['strtabledroppedbad'] = 'NezdaÅ™ilo se odstranit tabulku.'; + $lang['strconfemptytable'] = 'Opravdu chcete vyprázdnit tabulku „%s“?'; + $lang['strtableemptied'] = 'Tabulka byla vyprázdnÄ›na.'; + $lang['strtableemptiedbad'] = 'NezdaÅ™ilo se vyprázdnit tabulku.'; + $lang['strinsertrow'] = 'Vložit řádek'; + $lang['strrowinserted'] = 'Řádek byl vložen.'; + $lang['strrowinsertedbad'] = 'NezdaÅ™ilo se vložit řádek.'; + $lang['strnofkref'] = 'Cizímu klíÄi %s neodpovídá žádná hodnota.'; + $lang['strrowduplicate'] = 'NezdaÅ™ilo se vložení řádku, pokus o duplicitní vložení.'; + $lang['streditrow'] = 'Upravit řádek'; + $lang['strrowupdated'] = 'Řádek byl aktualizován.'; + $lang['strrowupdatedbad'] = 'NezdaÅ™ilo se aktualizovat řádek.'; + $lang['strdeleterow'] = 'Smazat řádek'; + $lang['strconfdeleterow'] = 'Opravdu chcete smazat tento řádek?'; + $lang['strrowdeleted'] = 'Řádek byl smazán.'; + $lang['strrowdeletedbad'] = 'NezdaÅ™ilo se smazat řádek.'; + $lang['strinsertandrepeat'] = 'Vloži a opakovat'; + $lang['strnumcols'] = 'PoÄet sloupců'; + $lang['strcolneedsname'] = 'Musíte zadat název pro sloupec'; + $lang['strselectallfields'] = 'Vybrat vÅ¡echna pole'; + $lang['strselectneedscol'] = 'Musíte zvolit alespoň jeden sloupec, který se má zobrazit.'; + $lang['strselectunary'] = 'Unární operátory nemohou mít hodnoty.'; + $lang['strcolumnaltered'] = 'ZmÄ›ny v sloupci byly provedeny.'; + $lang['strcolumnalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v sloupci.'; + $lang['strconfdropcolumn'] = 'Opravdu chcete odstranit sloupec „%s“ z tabulky „%s“?'; + $lang['strcolumndropped'] = 'Sloupec byl odstranÄ›n.'; + $lang['strcolumndroppedbad'] = 'NezdaÅ™ilo se odstranit sloupec.'; + $lang['straddcolumn'] = 'PÅ™idat sloupec'; + $lang['strcolumnadded'] = 'Sloupec byl pÅ™idán.'; + $lang['strcolumnaddedbad'] = 'NezdaÅ™ilo se pÅ™idat sloupec.'; + $lang['strcascade'] = 'KaskádovitÄ›'; + $lang['strtablealtered'] = 'ZmÄ›ny v tabulce byly provedeny.'; + $lang['strtablealteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v tabulce.'; + $lang['strdataonly'] = 'Pouze data'; + $lang['strstructureonly'] = 'Pouze strukturu'; + $lang['strstructureanddata'] = 'Strukturu a data'; + $lang['strtabbed'] = 'S tabulátory'; + $lang['strauto'] = 'Automaticky'; + $lang['strconfvacuumtable'] = 'Opravdu chcete provést úklid „%s“?'; + $lang['strconfanalyzetable'] = 'Opravdu chcete analyzovat „%s“?'; + $lang['strconfreindextable'] = 'Opravdu chcete pÅ™eindexovat „%s“?'; + $lang['strconfclustertable'] = 'Opravdu chcete pÅ™eskupit "%s"?'; + $lang['strestimatedrowcount'] = 'Odhadnutý poÄet řádků'; + $lang['strspecifytabletoanalyze'] = 'Pokud chcete analyzovat tabulky, tak musíte nejménÄ› jednu vybrat.'; + $lang['strspecifytabletoempty'] = 'Pokud chcete vyprázdnit tabulky, tak musíte nejménÄ› jednu vybrat.'; + $lang['strspecifytabletodrop'] = 'Pokud chcete odstranit tabulky, tak musíte nejménÄ› jednu vybrat.'; + $lang['strspecifytabletovacuum'] = 'Pokud chcete provést úklid tabulek, tak musíte nejménÄ› jednu vybrat.'; + $lang['strspecifytabletoreindex'] = 'Pokud chcete pÅ™eindexovat tabulku, tak musíte nejménÄ› jednu vybrat.'; + $lang['strspecifytabletocluster'] = 'Pokud chcete pÅ™eskupit tabulku, tak musíte nejménÄ› jednu vybrat.'; + $lang['strnofieldsforinsert'] = 'Nemůžete vložit řádek do tabulky, která nemá žádné sloupce.'; + + // Columns + $lang['strcolprop'] = 'Vlastnosti sloupce'; + $lang['strnotableprovided'] = 'Není k dispozici žádná tabulka!'; + + // Users + $lang['struser'] = 'Uživatel'; + $lang['strusers'] = 'Uživatelé'; + $lang['strusername'] = 'Jméno uživatele'; + $lang['strpassword'] = 'Heslo'; + $lang['strsuper'] = 'Superuživatel?'; + $lang['strcreatedb'] = 'Vytvářet DB?'; + $lang['strexpires'] = 'Ztratí platnost'; + $lang['strsessiondefaults'] = 'Výchozí hodnoty sezení'; + $lang['strnousers'] = 'Nenalezeni žádní uživatelé.'; + $lang['struserupdated'] = 'Uživatel byl aktualizován'; + $lang['struserupdatedbad'] = 'NezdaÅ™ilo se aktualizovat uživatele.'; + $lang['strshowallusers'] = 'Zobrazit vÅ¡echny uživatele'; + $lang['strcreateuser'] = 'VytvoÅ™it uživatele'; + $lang['struserneedsname'] = 'Musíte zadat jméno uživatele.'; + $lang['strusercreated'] = 'Uživatel byl vytvoÅ™en.'; + $lang['strusercreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it uživatele.'; + $lang['strconfdropuser'] = 'Opravdu chcete odstranit uživatele „%s“?'; + $lang['struserdropped'] = 'Uživatel byl odstranÄ›n.'; + $lang['struserdroppedbad'] = 'NezdaÅ™ilo se odstranit uživatele.'; + $lang['straccount'] = 'ÚÄet'; + $lang['strchangepassword'] = 'ZmÄ›nit heslo'; + $lang['strpasswordchanged'] = 'Heslo bylo zmÄ›nÄ›no.'; + $lang['strpasswordchangedbad'] = 'NezdaÅ™ilo se zmÄ›nit heslo.'; + $lang['strpasswordshort'] = 'Heslo je příliÅ¡ krátké.'; + $lang['strpasswordconfirm'] = 'Heslo a jeho potvrzení nejsou shodné.'; + + // Groups + $lang['strgroup'] = 'Skupina'; + $lang['strgroups'] = 'Skupiny'; + $lang['strshowallgroups'] = 'Zobrazit vÅ¡echny skupiny'; + $lang['strnogroup'] = 'Skupina nebyla nalezena.'; + $lang['strnogroups'] = 'Nebyly nalezeny žádné skupiny.'; + $lang['strcreategroup'] = 'VytvoÅ™it skupinu'; + $lang['strgroupneedsname'] = 'Musíte zadat název pro skupinu.'; + $lang['strgroupcreated'] = 'Skupina byly vytvoÅ™ena.'; + $lang['strgroupcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it skupinu.'; + $lang['strconfdropgroup'] = 'Opravdu chcete odstranit skupinu „%s“?'; + $lang['strgroupdropped'] = 'Skupiny byla odstranÄ›na.'; + $lang['strgroupdroppedbad'] = 'NezdaÅ™ilo se odstranit skupinu.'; + $lang['strmembers'] = 'ÄŒlenové'; + $lang['strmemberof'] = 'ÄŒlenem v'; + $lang['stradminmembers'] = 'ÄŒlenové správci'; + $lang['straddmember'] = 'PÅ™idat Älena'; + $lang['strmemberadded'] = 'ÄŒlen byl pÅ™idán.'; + $lang['strmemberaddedbad'] = 'NezdaÅ™ilo se pÅ™idat Älena.'; + $lang['strdropmember'] = 'Odebrat Älena'; + $lang['strconfdropmember'] = 'Opravdu chcete odebrat Älena „%s“ ze skupiny „%s“?'; + $lang['strmemberdropped'] = 'ÄŒlen byl odebrán.'; + $lang['strmemberdroppedbad'] = 'NezdaÅ™ilo se odebrat Älena.'; + + // Roles + $lang['strrole'] = 'Role'; + $lang['strroles'] = 'Role'; + $lang['strshowallroles'] = 'Zobrazit vÅ¡echny role'; + $lang['strnoroles'] = 'Nenalezena žádná role.'; + $lang['strinheritsprivs'] = 'DÄ›dit oprávnÄ›ní?'; + $lang['strcreaterole'] = 'VytvoÅ™it roli'; + $lang['strcancreaterole'] = 'Vytvářet role?'; + $lang['strrolecreated'] = 'Role byl vytvoÅ™ena.'; + $lang['strrolecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it roli.'; + $lang['strrolealtered'] = 'ZmÄ›ny v roli byly provedeny.'; + $lang['strrolealteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v roli.'; + $lang['strcanlogin'] = 'PÅ™ihlaÅ¡ovat se?'; + $lang['strconnlimit'] = 'Omezení pÅ™ipojení'; + $lang['strdroprole'] = 'Odstranit roli'; + $lang['strconfdroprole'] = 'Opravdu chcete odstranit roli „%s“?'; + $lang['strroledropped'] = 'Role byla odstranÄ›na.'; + $lang['strroledroppedbad'] = 'NezdaÅ™ilo se odstranit roli.'; + $lang['strnolimit'] = 'Bez omezení'; + $lang['strnever'] = 'Nikdy'; + $lang['strroleneedsname'] = 'Musíte zadat název pro roli.'; + + // Privileges + $lang['strprivilege'] = 'OprávnÄ›ní'; + $lang['strprivileges'] = 'OprávnÄ›ní'; + $lang['strnoprivileges'] = 'Tento objekt má oprávnÄ›ní výchozího vlastníka.'; + $lang['strgrant'] = 'PÅ™idÄ›lit'; + $lang['strrevoke'] = 'Odepřít'; + $lang['strgranted'] = 'OprávnÄ›ní byla zmÄ›nÄ›na.'; + $lang['strgrantfailed'] = 'NezdaÅ™ilo se zmÄ›nit oprávnÄ›ní.'; + $lang['strgrantbad'] = 'Musíte zvolit nejménÄ› jednoho uživatele nebo skupinu a nejménÄ› jedno oprávnÄ›ní.'; + $lang['strgrantor'] = 'PÅ™idÄ›lil'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Databáze'; + $lang['strdatabases'] = 'Databáze'; + $lang['strshowalldatabases'] = 'Zobrazit vÅ¡echny databáze'; + $lang['strnodatabases'] = 'Žádné databáze nenalezeny.'; + $lang['strcreatedatabase'] = 'VytvoÅ™it databázi'; + $lang['strdatabasename'] = 'Název databáze'; + $lang['strdatabaseneedsname'] = 'Musíte zadat název pro databázi.'; + $lang['strdatabasecreated'] = 'Databáze byla vytvoÅ™ena.'; + $lang['strdatabasecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it databázi.'; + $lang['strconfdropdatabase'] = 'Opravdu chcete odstranit databázi „%s“?'; + $lang['strdatabasedropped'] = 'Databáze byla odstranÄ›na.'; + $lang['strdatabasedroppedbad'] = 'NezdaÅ™ilo se odstranit databázi.'; + $lang['strentersql'] = 'Zadejte dotaz SQL, který chcete provést:'; + $lang['strsqlexecuted'] = 'Dotaz SQL byl proveden.'; + $lang['strvacuumgood'] = 'Úklid byl dokonÄen.'; + $lang['strvacuumbad'] = 'Úklid se nezdaÅ™il.'; + $lang['stranalyzegood'] = 'Analýza byla dokonÄena.'; + $lang['stranalyzebad'] = 'Analýza se nezdaÅ™ila.'; + $lang['strreindexgood'] = 'PÅ™eindexace byla dokonÄena.'; + $lang['strreindexbad'] = 'PÅ™eindexace se nezdaÅ™ila.'; + $lang['strfull'] = 'Úplný'; + $lang['strfreeze'] = 'Zmrazit'; + $lang['strforce'] = 'Vynutit'; + $lang['strsignalsent'] = 'Signál byl odeslán.'; + $lang['strsignalsentbad'] = 'Signál se nezdaÅ™ilo odeslat.'; + $lang['strallobjects'] = 'VÅ¡echny objekty'; + $lang['strdatabasealtered'] = 'ZmÄ›ny v databázi byly provedeny.'; + $lang['strdatabasealteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v databázi.'; + $lang['strspecifydatabasetodrop'] = 'Pokud chcete odstranit databáze, tak musíte nejménÄ› jednu vybrat.'; + $lang['strtemplatedb'] = 'Å ablona'; + $lang['strconfanalyzedatabase'] = 'Opravdu chcete analyzovat vÅ¡echny tabulky v databázi „%s“?'; + $lang['strconfvacuumdatabase'] = 'Opravdu chcete uklidit vÅ¡echny tabulky v databázi „%s“?'; + $lang['strconfreindexdatabase'] = 'Opravdu chcete pÅ™eindexovat vÅ¡echny tabulky v databázi „%s“?'; + $lang['strconfclusterdatabase'] = 'Opravdu chcete pÅ™eskupit vÅ¡echny tabulky v databázi „%s“?'; + + // Views + $lang['strview'] = 'Pohled'; + $lang['strviews'] = 'Pohledy'; + $lang['strshowallviews'] = 'Zobrazit vÅ¡echny pohledy'; + $lang['strnoview'] = 'Nenalezen žádný pohled.'; + $lang['strnoviews'] = 'Nenalezeny žádné pohledy.'; + $lang['strcreateview'] = 'VytvoÅ™it pohled'; + $lang['strviewname'] = 'Název pohledu'; + $lang['strviewneedsname'] = 'Musíte zadat název pro pohled.'; + $lang['strviewneedsdef'] = 'Musíte zadat definici pro pohled.'; + $lang['strviewneedsfields'] = 'Musíte zvolit, které sloupce chcete v pohledu mít.'; + $lang['strviewcreated'] = 'Pohled vytvoÅ™en.'; + $lang['strviewcreatedbad'] = 'Pohled se nezdaÅ™ilo vytvoÅ™it.'; + $lang['strconfdropview'] = 'Opravdu chcete odstranit pohled „%s“?'; + $lang['strviewdropped'] = 'Pohled byl odstranÄ›n.'; + $lang['strviewdroppedbad'] = 'Pohled se nezdaÅ™ilo odstranit.'; + $lang['strviewupdated'] = 'Pohled byl aktualizován.'; + $lang['strviewupdatedbad'] = 'Pohled se nezdaÅ™ilo aktualizovat.'; + $lang['strviewlink'] = 'Propojovací klíÄe'; + $lang['strviewconditions'] = 'Doplňující podmínky'; + $lang['strcreateviewwiz'] = 'VytvoÅ™it pohled pomocí průvodce'; + $lang['strrenamedupfields'] = 'Duplicitní pole pÅ™ejmenovat'; + $lang['strdropdupfields'] = 'Duplicitní pole odstranit'; + $lang['strerrordupfields'] = 'V případÄ› duplicitních polí ohlásit chybu'; + $lang['strviewaltered'] = 'ZmÄ›ny v pohledu byly provedeny.'; + $lang['strviewalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v pohledu.'; + $lang['strspecifyviewtodrop'] = 'Pokud chcete odstranit pohledy, tak musíte nejménÄ› jeden vybrat.'; + + // Sequences + $lang['strsequence'] = 'Sekvence'; + $lang['strsequences'] = 'Sekvence'; + $lang['strshowallsequences'] = 'Zobrazit vÅ¡echny sekvence'; + $lang['strnosequence'] = 'Nenalezena žádná sekvence.'; + $lang['strnosequences'] = 'Nenalezeny žádné sekvence.'; + $lang['strcreatesequence'] = 'VytvoÅ™it sekvenci'; + $lang['strlastvalue'] = 'Poslední hodnota'; + $lang['strincrementby'] = 'Přírůstek'; + $lang['strstartvalue'] = 'PoÄáteÄní hodnota'; + $lang['strrestartvalue'] = 'Nová poÄáteÄní hodnota'; + $lang['strmaxvalue'] = 'Max. hodnota'; + $lang['strminvalue'] = 'Min. hodnota'; + $lang['strcachevalue'] = 'PÅ™ipraveno dopÅ™edu'; + $lang['strlogcount'] = 'Dostupných hodnot bez zápisu (log_cnt)'; + $lang['strcancycle'] = 'Cyklicky?'; + $lang['striscalled'] = 'Zvýšit pÅ™ed vrácením následující (is_called)?'; + $lang['strsequenceneedsname'] = 'Musíte zadat název pro sekvenci.'; + $lang['strsequencecreated'] = 'Sekvence byla vytvoÅ™ena.'; + $lang['strsequencecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it sekvenci.'; + $lang['strconfdropsequence'] = 'Opravdu chcete odstranit sekvenci „%s“?'; + $lang['strsequencedropped'] = 'Sekvence byla odstranÄ›na.'; + $lang['strsequencedroppedbad'] = 'NezdaÅ™ilo se odstranit sekvenci.'; + $lang['strsequencerestart'] = 'Sekvence nastavena na novou poÄáteÄní hodnotu.'; + $lang['strsequencerestartbad'] = 'NezdaÅ™ilo se nastavit novou poÄáteÄní hodnotu sekvence.'; + $lang['strsequencereset'] = 'Sekvence byla nastavena na poÄáteÄní hodnotu.'; + $lang['strsequenceresetbad'] = 'NezdaÅ™ilo se nastavit poÄáteÄní hodnotu sekvence.'; + $lang['strsequencealtered'] = 'ZmÄ›ny v sekvenci byly provedeny.'; + $lang['strsequencealteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v sekvenci.'; + $lang['strsetval'] = 'Nastavit hodnotu'; + $lang['strsequencesetval'] = 'Hodnota sekvence byla nastavena.'; + $lang['strsequencesetvalbad'] = 'NezdaÅ™ilo se zmÄ›nit hodnotu sekvence.'; + $lang['strnextval'] = 'Zvýšit hodnotu'; + $lang['strsequencenextval'] = 'Hodnota sekvence byla zvýšena.'; + $lang['strsequencenextvalbad'] = 'NezdaÅ™ilo se zvýšit hodnotu sekvence.'; + $lang['strspecifysequencetodrop'] = 'Pokud chcete odstranit sekvence, tak musíte nejménÄ› jednu vybrat.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indexy'; + $lang['strindexname'] = 'Název indexu'; + $lang['strshowallindexes'] = 'Zobrazit vÅ¡echny indexy'; + $lang['strnoindex'] = 'Nenalezen žádný index.'; + $lang['strnoindexes'] = 'Nenalezeny žádné indexy.'; + $lang['strcreateindex'] = 'VytvoÅ™it index'; + $lang['strtabname'] = 'Název tabulky'; + $lang['strcolumnname'] = 'Název sloupce'; + $lang['strindexneedsname'] = 'Musíte zadat název pro index.'; + $lang['strindexneedscols'] = 'Index musí obsahovat nejménÄ› jeden sloupec.'; + $lang['strindexcreated'] = 'Index byl vytvoÅ™en.'; + $lang['strindexcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it index.'; + $lang['strconfdropindex'] = 'Opravdu chcete odstranit index „%s“?'; + $lang['strindexdropped'] = 'Index byl odstranÄ›n.'; + $lang['strindexdroppedbad'] = 'NezdaÅ™ilo se odstranit index.'; + $lang['strkeyname'] = 'Název klíÄe'; + $lang['struniquekey'] = 'JedineÄný klíÄ'; + $lang['strprimarykey'] = 'Primární klíÄ'; + $lang['strindextype'] = 'Typ indexu'; + $lang['strtablecolumnlist'] = 'Sloupce v tabulce'; + $lang['strindexcolumnlist'] = 'Sloupce v indexu'; + $lang['strclusteredgood'] = 'PÅ™eskupení dokonÄeno.'; + $lang['strclusteredbad'] = 'PÅ™eskupení se nezdaÅ™ilo.'; + $lang['strconcurrently'] = 'SouběžnÄ›'; + $lang['strnoclusteravailable'] = 'Tabulka není pÅ™eskupena podle indexu.'; + + // Rules + $lang['strrules'] = 'Pravidla'; + $lang['strrule'] = 'Pravidlo'; + $lang['strshowallrules'] = 'Zobrazit vÅ¡echna pravidla'; + $lang['strnorule'] = 'Nenalezeno žádné pravidlo.'; + $lang['strnorules'] = 'Nenalezena žádná pravidla.'; + $lang['strcreaterule'] = 'VytvoÅ™it pravidlo'; + $lang['strrulename'] = 'Název pravidla'; + $lang['strruleneedsname'] = 'Musíte zadat název pro pravidlo.'; + $lang['strrulecreated'] = 'Pravidlo bylo vytvoÅ™eno.'; + $lang['strrulecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it pravidlo.'; + $lang['strconfdroprule'] = 'Opravdu chcete odstranit pravidlo „%s“ na „%s“?'; + $lang['strruledropped'] = 'Pravidlo bylo odstranÄ›no.'; + $lang['strruledroppedbad'] = 'NezdaÅ™ilo se odstranit pravidlo.'; + + // Constraints + $lang['strconstraint'] = 'Omezení'; + $lang['strconstraints'] = 'Omezení'; + $lang['strshowallconstraints'] = 'Zobrazit vÅ¡echna omezení'; + $lang['strnoconstraints'] = 'Nenalezena žádná omezení.'; + $lang['strcreateconstraint'] = 'VytvoÅ™it omezení'; + $lang['strconstraintcreated'] = 'Omezení bylo vytvoÅ™eno.'; + $lang['strconstraintcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it omezení.'; + $lang['strconfdropconstraint'] = 'Opravdu chcete odstranit omezení „%s“ na „%s“?'; + $lang['strconstraintdropped'] = 'Omezení bylo odstranÄ›no.'; + $lang['strconstraintdroppedbad'] = 'NezdaÅ™ilo se odstranit omezení.'; + $lang['straddcheck'] = 'PÅ™idat kontrolu'; + $lang['strcheckneedsdefinition'] = 'Musíte zadat definici kontroly.'; + $lang['strcheckadded'] = 'Kontrola byla pÅ™idána.'; + $lang['strcheckaddedbad'] = 'NezdaÅ™ilo se pÅ™idat kontrolu.'; + $lang['straddpk'] = 'PÅ™idat primární klíÄ'; + $lang['strpkneedscols'] = 'Primární klÃ­Ä musí obsahovat nejménÄ› jeden sloupec.'; + $lang['strpkadded'] = 'Primární klÃ­Ä byl pÅ™idán.'; + $lang['strpkaddedbad'] = 'NezdaÅ™ilo se pÅ™idat primární klíÄ.'; + $lang['stradduniq'] = 'PÅ™idat jedineÄný klíÄ'; + $lang['struniqneedscols'] = 'JedineÄný klÃ­Ä musí obsahovat nejménÄ› jeden sloupec.'; + $lang['struniqadded'] = 'JedineÄný klÃ­Ä byl pÅ™idán.'; + $lang['struniqaddedbad'] = 'NezdaÅ™ilo se pÅ™idat jedineÄný klíÄ.'; + $lang['straddfk'] = 'PÅ™idat cizí klíÄ'; + $lang['strfkneedscols'] = 'Cizí klÃ­Ä musí obsahovat nejménÄ› jeden sloupec.'; + $lang['strfkneedstarget'] = 'Musíte zadat cílovou tabulku, na kterou se cizí klÃ­Ä odkazuje.'; + $lang['strfkadded'] = 'Cizí klÃ­Ä byl pÅ™idán.'; + $lang['strfkaddedbad'] = 'NezdaÅ™ilo se pÅ™idat cizí klíÄ.'; + $lang['strfktarget'] = 'Cílová tabulka'; + $lang['strfkcolumnlist'] = 'Sloupce v klíÄi'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Funkce'; + $lang['strfunctions'] = 'Funkce'; + $lang['strshowallfunctions'] = 'Zobrazit vÅ¡echny funkce'; + $lang['strnofunction'] = 'Nenalezena žádná funkce.'; + $lang['strnofunctions'] = 'Nenalezeny žádné funkce.'; + $lang['strcreateplfunction'] = 'VytvoÅ™it funkci SQL/PL'; + $lang['strcreateinternalfunction'] = 'VytvoÅ™it interní funkci'; + $lang['strcreatecfunction'] = 'VytvoÅ™it funkci C'; + $lang['strfunctionname'] = 'Název funkce'; + $lang['strreturns'] = 'Vrací'; + $lang['strproglanguage'] = 'Programovací jazyk'; + $lang['strfunctionneedsname'] = 'Musíte zadat název pro funkci.'; + $lang['strfunctionneedsdef'] = 'Musíte zadat definici pro funkci.'; + $lang['strfunctioncreated'] = 'Funkce byl vytvoÅ™ena.'; + $lang['strfunctioncreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it funkci.'; + $lang['strconfdropfunction'] = 'Opravdu chcete odstranit funkci „%s“?'; + $lang['strfunctiondropped'] = 'Funkce byla odstranÄ›na.'; + $lang['strfunctiondroppedbad'] = 'NezdaÅ™ilo se odstranit funkci.'; + $lang['strfunctionupdated'] = 'Funkce byla aktualizována.'; + $lang['strfunctionupdatedbad'] = 'NezdaÅ™ilo se aktualizovat funkci.'; + $lang['strobjectfile'] = 'Soubor s objektem'; + $lang['strlinksymbol'] = 'Napojený symbol'; + $lang['strarguments'] = 'Argumenty'; + $lang['strargmode'] = 'Režim'; + $lang['strargtype'] = 'Typ'; + $lang['strargadd'] = 'PÅ™idat další argument'; + $lang['strargremove'] = 'Odebrat tento argument'; + $lang['strargnoargs'] = 'Tato funkce nepÅ™ebírá žádné argumenty.'; + $lang['strargenableargs'] = 'Povolit argumentům průchod do této funkce.'; + $lang['strargnorowabove'] = 'Nad tímto řádkem již žádný není.'; + $lang['strargnorowbelow'] = 'Pod tímto řádkem již žádný není.'; + $lang['strargraise'] = 'PÅ™esunout výše.'; + $lang['strarglower'] = 'PÅ™esunout níže.'; + $lang['strargremoveconfirm'] = 'Opravdu chcete odebrat tento argument? Operaci nelze vrátit zpÄ›t.'; + $lang['strfunctioncosting'] = 'Cena funkcí'; + $lang['strresultrows'] = 'PoÄet řádků'; + $lang['strexecutioncost'] = 'Cena provádÄ›ní'; + $lang['strspecifyfunctiontodrop'] = 'Pokud chcete odstranit funkce, tak musíte nejménÄ› jednu vybrat.'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Triggery'; + $lang['strshowalltriggers'] = 'Zobrazit vÅ¡echny triggery'; + $lang['strnotrigger'] = 'Nenalezen žádný trigger.'; + $lang['strnotriggers'] = 'Nenalezeny žádné triggery.'; + $lang['strcreatetrigger'] = 'VytvoÅ™it trigger'; + $lang['strtriggerneedsname'] = 'Musíte zadat název pro trigger.'; + $lang['strtriggerneedsfunc'] = 'Musíte zvolit funkci pro trigger.'; + $lang['strtriggercreated'] = 'Trigger byl vytvoÅ™en.'; + $lang['strtriggercreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it trigger.'; + $lang['strconfdroptrigger'] = 'Opravdu chcete odstranit trigger „%s“ v „%s“?'; + $lang['strconfenabletrigger'] = 'Opravdu chcete povolit trigger „%s“ v „%s“?'; + $lang['strconfdisabletrigger'] = 'Opravdu chcete zakázat trigger „%s“ v „%s“?'; + $lang['strtriggerdropped'] = 'Trigger byl odstranÄ›n.'; + $lang['strtriggerdroppedbad'] = 'NezdaÅ™ilo se odstranit trigger.'; + $lang['strtriggerenabled'] = 'Trigger byl povolen.'; + $lang['strtriggerenabledbad'] = 'NezdaÅ™ilo se povolit trigger.'; + $lang['strtriggerdisabled'] = 'Trigger byl zakázán.'; + $lang['strtriggerdisabledbad'] = 'NezdaÅ™ilo se zakázat trigger.'; + $lang['strtriggeraltered'] = 'ZmÄ›ny v triggeru byly provedeny.'; + $lang['strtriggeralteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v triggeru.'; + $lang['strforeach'] = 'Pro každý'; + + // Types + $lang['strtype'] = 'Typ'; + $lang['strtypes'] = 'Typy'; + $lang['strshowalltypes'] = 'Zobrazit vÅ¡echny typy'; + $lang['strnotype'] = 'Nenalezen žádný typ.'; + $lang['strnotypes'] = 'Nenalezeny žádné typy.'; + $lang['strcreatetype'] = 'VytvoÅ™it externí typ'; + $lang['strcreatecomptype'] = 'VytvoÅ™it složený typ'; + $lang['strcreateenumtype'] = 'VytvoÅ™it výÄtový typ'; + $lang['strtypeneedsfield'] = 'Musíte zadat nejménÄ› jedno pole.'; + $lang['strtypeneedsvalue'] = 'Musíte zadat nejménÄ› jednu hodnotu.'; + $lang['strtypeneedscols'] = 'Musíte zadat platný poÄet polí.'; + $lang['strtypeneedsvals'] = 'Musíte zadat platný poÄet hodnot.'; + $lang['strinputfn'] = 'Vstupní funkce'; + $lang['stroutputfn'] = 'Výstupní funkce'; + $lang['strpassbyval'] = 'PÅ™edávaný hodnotou?'; + $lang['stralignment'] = 'Zarovnání'; + $lang['strelement'] = 'Prvek'; + $lang['strdelimiter'] = 'OddÄ›lovaÄ'; + $lang['strstorage'] = 'Uložení'; + $lang['strfield'] = 'Pole'; + $lang['strnumfields'] = 'PoÄet polí'; + $lang['strnumvalues'] = 'PoÄet hodnot'; + $lang['strtypeneedsname'] = 'Musíte zadat název pro typ.'; + $lang['strtypeneedslen'] = 'Musíte zadat délku pro typ.'; + $lang['strtypecreated'] = 'Typ byl vytvoÅ™en.'; + $lang['strtypecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it typ.'; + $lang['strconfdroptype'] = 'Opravdu chcete odstranit typ „%s“?'; + $lang['strtypedropped'] = 'Typ byl odstranÄ›n.'; + $lang['strtypedroppedbad'] = 'NezdaÅ™ilo se odstranit typ.'; + $lang['strflavor'] = 'Druh'; + $lang['strbasetype'] = 'Základní'; + $lang['strcompositetype'] = 'Složený'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'VýÄtový'; + $lang['strenumvalues'] = 'VýÄtové hodnoty'; + + // Schemas + $lang['strschema'] = 'Schéma'; + $lang['strschemas'] = 'Schémata'; + $lang['strshowallschemas'] = 'Zobrazit vÅ¡echna schémata'; + $lang['strnoschema'] = 'Nebylo nalezeno žádné schéma.'; + $lang['strnoschemas'] = 'Nebyla nalezena žádná schémata.'; + $lang['strcreateschema'] = 'VytvoÅ™it schéma'; + $lang['strschemaname'] = 'Název schématu'; + $lang['strschemaneedsname'] = 'Musíte zadat název pro schéma.'; + $lang['strschemacreated'] = 'Schéma bylo vytvoÅ™eno.'; + $lang['strschemacreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it schéma.'; + $lang['strconfdropschema'] = 'Opravdu chcete odstranit schéma „%s“?'; + $lang['strschemadropped'] = 'Schéma bylo odstranÄ›no.'; + $lang['strschemadroppedbad'] = 'NezdaÅ™ilo se odstranit schéma.'; + $lang['strschemaaltered'] = 'ZmÄ›ny ve schématu byly provedeny.'; + $lang['strschemaalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny ve schématu.'; + $lang['strsearchpath'] = 'Prohledávaná schémata'; + $lang['strspecifyschematodrop'] = 'Pokud chcete odstranit schémata, tak musíte nejménÄ› jedno vybrat.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Doména'; + $lang['strdomains'] = 'Domény'; + $lang['strshowalldomains'] = 'Zobrazit vÅ¡echny domény'; + $lang['strnodomains'] = 'Nebyly nalezeny žádné domény.'; + $lang['strcreatedomain'] = 'VytvoÅ™it doménu'; + $lang['strdomaindropped'] = 'Doména byla odstranÄ›na.'; + $lang['strdomaindroppedbad'] = 'NezdaÅ™ilo se odstranit doménu.'; + $lang['strconfdropdomain'] = 'Opravdu chcete odstranit doménu „%s“?'; + $lang['strdomainneedsname'] = 'Musíte zadat název pro doménu.'; + $lang['strdomaincreated'] = 'Doména byla vytvoÅ™ena.'; + $lang['strdomaincreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it doménu.'; + $lang['strdomainaltered'] = 'ZmÄ›ny v doménÄ› byly provedeny.'; + $lang['strdomainalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v doménÄ›.'; + + // Operators + $lang['stroperator'] = 'Operátor'; + $lang['stroperators'] = 'Operátory'; + $lang['strshowalloperators'] = 'Zobrazit vÅ¡echny operátory'; + $lang['strnooperator'] = 'Nebyl nalezen žádný operátor.'; + $lang['strnooperators'] = 'Nebyly nalezeny žádné operátory.'; + $lang['strcreateoperator'] = 'VytvoÅ™it operátor'; + $lang['strleftarg'] = 'Levý operand'; + $lang['strrightarg'] = 'Pravý operand'; + $lang['strcommutator'] = 'Komutátor'; + $lang['strnegator'] = 'Negátor'; + $lang['strrestrict'] = 'Omezení'; + $lang['strjoin'] = 'Propojení'; + $lang['strhashes'] = 'HeÅ¡e'; + $lang['strmerges'] = 'SluÄování'; + $lang['strleftsort'] = 'Levé Å™azení'; + $lang['strrightsort'] = 'Pravé Å™azení'; + $lang['strlessthan'] = 'Operátor <'; + $lang['strgreaterthan'] = 'Operátor >'; + $lang['stroperatorneedsname'] = 'Musíte zadat název pro operátor.'; + $lang['stroperatorcreated'] = 'Operátor byl vytvoÅ™en.'; + $lang['stroperatorcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it operátor.'; + $lang['strconfdropoperator'] = 'Opravdu chcete odstranit operátor „%s“?'; + $lang['stroperatordropped'] = 'Operátor byl odstranÄ›n.'; + $lang['stroperatordroppedbad'] = 'NezdaÅ™ilo se odstranit operátor.'; + + // Casts + $lang['strcasts'] = 'PÅ™etypování'; + $lang['strnocasts'] = 'Nenalezena žádná pÅ™etypování.'; + $lang['strsourcetype'] = 'Zdrojový typ'; + $lang['strtargettype'] = 'Cílový typ'; + $lang['strimplicit'] = 'Implicitní'; + $lang['strinassignment'] = 'V pÅ™iÅ™azení'; + $lang['strbinarycompat'] = '(BinárnÄ› zamÄ›nitelné)'; + + // Conversions + $lang['strconversions'] = 'Konverze'; + $lang['strnoconversions'] = 'Nenalezeny žádné konverze.'; + $lang['strsourceencoding'] = 'Zdrojové kódování'; + $lang['strtargetencoding'] = 'Cílové kódování'; + + // Languages + $lang['strlanguages'] = 'Jazyky'; + $lang['strnolanguages'] = 'Nenalezeny žádné jazyky.'; + $lang['strtrusted'] = 'DůvÄ›ryhodný'; + + // Info + $lang['strnoinfo'] = 'Nejsou dostupné žádné informace.'; + $lang['strreferringtables'] = 'Odkazující tabulky'; + $lang['strparenttables'] = 'RodiÄovské tabulky'; + $lang['strchildtables'] = 'DceÅ™iné tabulky'; + + // Aggregates + $lang['straggregate'] = 'AgregaÄní funkce'; + $lang['straggregates'] = 'AgregaÄní funkce'; + $lang['strnoaggregates'] = 'Nebyly nalezeny žádné agregaÄní funkce.'; + $lang['stralltypes'] = '(VÅ¡echny typy)'; + $lang['strcreateaggregate'] = 'VytvoÅ™it agregaÄní funkci'; + $lang['straggrbasetype'] = 'Typ vstupních dat'; + $lang['straggrsfunc'] = 'Funkce stavového pÅ™echodu'; + $lang['straggrstype'] = 'Datový typ stavové hodnoty'; + $lang['straggrffunc'] = 'Finální funkce'; + $lang['straggrinitcond'] = 'PoÄáteÄní podmínka'; + $lang['straggrsortop'] = 'Operátor Å™azení'; + $lang['strconfdropaggregate'] = 'Opravdu chcete odstranit agregaÄní funkci „%s“?'; + $lang['straggregatedropped'] = 'AgregaÄní funkce byla odstranÄ›na.'; + $lang['straggregatedroppedbad'] = 'NezdaÅ™ilo se odstranit agregaÄní funkci.'; + $lang['straggraltered'] = 'ZmÄ›ny v agregaÄní funkci byly provedeny.'; + $lang['straggralteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v agregaÄní funkci.'; + $lang['straggrneedsname'] = 'Musíte zadat název pro agregaÄní funkci.'; + $lang['straggrneedsbasetype'] = 'Musíte zadat typ vstupních dat pro agregaÄní funkci.'; + $lang['straggrneedssfunc'] = 'Musíte zadat název funkce stavového pÅ™echodu pro agregaÄní funkci.'; + $lang['straggrneedsstype'] = 'Musíte zadat datový typ stavové hodnoty pro agregaÄní funkci.'; + $lang['straggrcreated'] = 'AgregaÄní funkce byla vytvoÅ™ena.'; + $lang['straggrcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it agregaÄní funkci.'; + $lang['straggrshowall'] = 'Zobrazit vÅ¡echny agregaÄní funkce'; + + // Operator Classes + $lang['stropclasses'] = 'Třídy operátorů'; + $lang['strnoopclasses'] = 'Nebely nalezeny žádné třídy operátorů.'; + $lang['straccessmethod'] = 'Metoda přístupu'; + + // Stats and performance + $lang['strrowperf'] = 'Souhrn řádkových operací'; + $lang['strioperf'] = 'Souhrn V/V operací'; + $lang['stridxrowperf'] = 'Souhrn Indexových řádkových operací'; + $lang['stridxioperf'] = 'Souhrn Indexových V/V operací'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'SekvenÄnÄ›'; + $lang['strscan'] = 'Prohledáno'; + $lang['strread'] = 'ÄŒteno'; + $lang['strfetch'] = 'NaÄteno'; + $lang['strheap'] = 'Hromada'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Mezipaměť'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Řádků'; + + // Tablespaces + $lang['strtablespace'] = 'Prostor tabulek'; + $lang['strtablespaces'] = 'Prostory tabulek'; + $lang['strshowalltablespaces'] = 'Zobrazit vÅ¡echny prostory tabulek'; + $lang['strnotablespaces'] = 'Nebyly nalezeny žádné prostory tabulek.'; + $lang['strcreatetablespace'] = 'VytvoÅ™it prostor tabulek'; + $lang['strlocation'] = 'UmístÄ›ní'; + $lang['strtablespaceneedsname'] = 'Musíte zadat název pro prostor tabulek.'; + $lang['strtablespaceneedsloc'] = 'Musíte zadat složku, ve které se má prostor tabulek vytvoÅ™it.'; + $lang['strtablespacecreated'] = 'Prostor tabulek byl vytvoÅ™en.'; + $lang['strtablespacecreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it prostor tabulek.'; + $lang['strconfdroptablespace'] = 'Opravdu chcete odstranit prostor tabulek „%s“?'; + $lang['strtablespacedropped'] = 'Prostor tabulek byl odstranÄ›n.'; + $lang['strtablespacedroppedbad'] = 'NezdaÅ™ilo se odstranit prostor tabulek.'; + $lang['strtablespacealtered'] = 'ZmÄ›ny v prostoru tabulek byly provedeny.'; + $lang['strtablespacealteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny v prostoru tabulek.'; + + // Miscellaneous + $lang['strtopbar'] = '%s běžící na %s:%s -- Jste pÅ™ihlášený jako uživatel „%s“'; + $lang['strtimefmt'] = 'j. M Y G:i'; + $lang['strhelp'] = 'NápovÄ›da'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'VýbÄ›r stránky s nápovÄ›dou'; + $lang['strselecthelppage'] = 'Zvolte stránku s nápovÄ›dou'; + $lang['strinvalidhelppage'] = 'Neplatná stránka s nápovÄ›dou.'; + $lang['strlogintitle'] = 'PÅ™ihlášení k %s'; + $lang['strlogoutmsg'] = 'Odhlášení od %s'; + $lang['strloading'] = 'NaÄítá se…'; + $lang['strerrorloading'] = 'Chyba pÅ™i naÄítání'; + $lang['strclicktoreload'] = 'KliknÄ›te pro opÄ›tovné naÄtení'; + + // Autovacuum + $lang['strautovacuum'] = 'Automatický úklid'; + $lang['strturnedon'] = 'Zapnuto'; + $lang['strturnedoff'] = 'Vypnuto'; + $lang['strenabled'] = 'Povoleno'; + $lang['strnovacuumconf'] = 'Nebylo nalezeno žádné nastavení automatického úklidu.'; + $lang['strvacuumbasethreshold'] = 'VACUUM - základní práh'; + $lang['strvacuumscalefactor'] = 'VACUUM - Å¡kálovací faktor'; + $lang['stranalybasethreshold'] = 'ANALYZE - základní práh'; + $lang['stranalyzescalefactor'] = 'ANALYZE - Å¡kálovací faktor'; + $lang['strvacuumcostdelay'] = 'VACUUM - délka pÅ™estávky'; + $lang['strvacuumcostlimit'] = 'VACUUM - cenový limit'; + $lang['strvacuumpertable'] = 'Nastavení automatického uklidu jednotlivých tabulek'; + $lang['straddvacuumtable'] = 'PÅ™idat nastavení automatického úklidu pro tabulku'; + $lang['streditvacuumtable'] = 'Upravit nastavení automatického úklidu pro tabulku %s'; + $lang['strdelvacuumtable'] = 'Smazat nastavení automatického úklidu pro tabulku %s ?'; + $lang['strvacuumtablereset'] = 'Autovacuum setup for table %s reset to default values'; + $lang['strdelvacuumtablefail'] = 'NezdaÅ™ilo se odebrat nastavení automatického úklidu pro tabulku %s'; + $lang['strsetvacuumtablesaved'] = 'Nastavení automatického úklidu pro tabulku %s bylo uloženo.'; + $lang['strsetvacuumtablefail'] = 'NezdaÅ™ilo se nastavení automatického úklidu pro tabulku %s.'; + $lang['strspecifydelvacuumtable'] = 'Musíte zadat tabulku, ze které chcete odebrat parametry automatického úklidu.'; + $lang['strspecifyeditvacuumtable'] = 'Musíte zadat tabulku, ze které chcete upravit parametry automatického úklidu.'; + $lang['strnotdefaultinred'] = 'V úÄtu nejsou žádné výchozí hodnoty.'; + + // Table-level Locks + $lang['strlocks'] = 'Zámky'; + $lang['strtransaction'] = 'ID transakce'; + $lang['strvirtualtransaction'] = 'ID virtuální transakce'; + $lang['strprocessid'] = 'ID procesu'; + $lang['strmode'] = 'Režim zámku'; + $lang['strislockheld'] = 'Je zámek držený?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'PÅ™ipravené transakce'; + $lang['strxactid'] = 'TransakÄní ID'; + $lang['strgid'] = 'Globální ID'; + + // Fulltext search + $lang['strfulltext'] = 'PlnÄ› textové vyhledávání'; + $lang['strftsconfig'] = 'Nastavení FTS'; + $lang['strftsconfigs'] = 'Nastavení'; + $lang['strftscreateconfig'] = 'VytvoÅ™it nastavení FTS'; + $lang['strftscreatedict'] = 'VytvoÅ™it slovník'; + $lang['strftscreatedicttemplate'] = 'VytvoÅ™it Å¡ablonu slovníku'; + $lang['strftscreateparser'] = 'VytvoÅ™it analyzátor'; + $lang['strftsnoconfigs'] = 'Nebylo nalezeno žádné nastavení FTS.'; + $lang['strftsconfigdropped'] = 'Nastavení FTS bylo odstranÄ›no.'; + $lang['strftsconfigdroppedbad'] = 'NezdaÅ™ilo se odstranit nastavení FTS.'; + $lang['strconfdropftsconfig'] = 'Opravdu chcete odstranit nastavení FTS „%s“?'; + $lang['strconfdropftsdict'] = 'Opravdu chcete odstranit slovník FTS „%s“?'; + $lang['strconfdropftsmapping'] = 'Opravdu chcete odstranit mapování „%s“ nastavení FTS „%s“?'; + $lang['strftstemplate'] = 'Å ablona'; + $lang['strftsparser'] = 'Analyzátor'; + $lang['strftsconfigneedsname'] = 'Musíte zadat název pro nastavení FTS.'; + $lang['strftsconfigcreated'] = 'Nastavení FTS bylo vytvoÅ™eno.'; + $lang['strftsconfigcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it nastavení FTS.'; + $lang['strftsmapping'] = 'Mapování'; + $lang['strftsdicts'] = 'Slovníky'; + $lang['strftsdict'] = 'Slovník'; + $lang['strftsemptymap'] = 'Vyprázdnit mapu nastavení FTS.'; + $lang['strftsconfigaltered'] = 'Byly provedeny zmÄ›ny nastavení FTS.'; + $lang['strftsconfigalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny nastavení FTS.'; + $lang['strftsconfigmap'] = 'Mapa nastavení FTS'; + $lang['strftsparsers'] = 'Analyzátory FTS'; + $lang['strftsnoparsers'] = 'Nejsou dostupné žádné analyzátory FTS.'; + $lang['strftsnodicts'] = 'Nejsou dostupné žádné slovníky FTS.'; + $lang['strftsdictcreated'] = 'Slovník FTS byl vytvoÅ™en.'; + $lang['strftsdictcreatedbad'] = 'NezdaÅ™ilo se vytvoÅ™it slovník FTS.'; + $lang['strftslexize'] = 'Lexikální funkce'; + $lang['strftsinit'] = 'InicializaÄní funkce'; + $lang['strftsoptionsvalues'] = 'Volby a hodnoty'; + $lang['strftsdictneedsname'] = 'Musíte zadat název pro slovník FTS.'; + $lang['strftsdictdropped'] = 'Slovník FTS byl odstranÄ›n.'; + $lang['strftsdictdroppedbad'] = 'NezdaÅ™ilo se odstranit slovník FTS.'; + $lang['strftsdictaltered'] = 'Byly provedeny zmÄ›ny slovníku FTS.'; + $lang['strftsdictalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny slovníku FTS.'; + $lang['strftsaddmapping'] = 'PÅ™idat nové mapování'; + $lang['strftsspecifymappingtodrop'] = 'Pokud chcete odstranit mapování, tak musíte nejménÄ› jedno vybrat.'; + $lang['strftsspecifyconfigtoalter'] = 'Musíte vybrat, které nastavení FTS chcete zmÄ›nit.'; + $lang['strftsmappingdropped'] = 'Mapování FTS bylo odstranÄ›no.'; + $lang['strftsmappingdroppedbad'] = 'NezdaÅ™ilo se odstranit mapování FTS.'; + $lang['strftsnodictionaries'] = 'Nebyly nalezeny žádné slovníky.'; + $lang['strftsmappingaltered'] = 'Byly provedeny zmÄ›ny mapování FTS.'; + $lang['strftsmappingalteredbad'] = 'NezdaÅ™ilo se provést zmÄ›ny mapování FTS.'; + $lang['strftsmappingadded'] = 'Mapování FTS bylo pÅ™idáno.'; + $lang['strftsmappingaddedbad'] = 'NezdaÅ™ilo se pÅ™idat mapování FTS.'; + $lang['strftstabconfigs'] = 'Nastavení'; + $lang['strftstabdicts'] = 'Slovníky'; + $lang['strftstabparsers'] = 'Analyzátory'; + $lang['strftscantparsercopy'] = 'PÅ™i vytváření nastavení textového vyhledávání nemůžete naráz zadat analyzátor i Å¡ablonu.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/danish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/danish.php new file mode 100644 index 00000000..52527332 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/danish.php @@ -0,0 +1,617 @@ + + */ + + // Language and character set + $lang['applang'] = 'Danish'; + $lang['applocale'] = 'da-DK'; + $lang['applangdir'] = 'ltr'; + + // Welcome + $lang['strintro'] = 'Velkommen til phpPgAdmin.'; + $lang['strppahome'] = 'phpPgAdmins Hjemmeside'; + $lang['strpgsqlhome'] = 'PostgreSQLs Hjemmeside'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'PostgreSQL Dokumentation (lokalt)'; + $lang['strreportbug'] = 'Rapporter fejl'; + $lang['strviewfaq'] = 'Ofte stillede spørgsmÃ¥l'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'Login'; + $lang['strloginfailed'] = 'Login mislykkedes'; + $lang['strlogindisallowed'] = 'Login forbudt'; + $lang['strserver'] = 'Server'; + $lang['strlogout'] = 'Log ud'; + $lang['strowner'] = 'Ejer'; + $lang['straction'] = 'Handling'; + $lang['stractions'] = 'Handlinger'; + $lang['strname'] = 'Navn'; + $lang['strdefinition'] = 'Definition'; + $lang['strproperties'] = 'Egenskaber'; + $lang['strbrowse'] = 'Bladre'; + $lang['strdrop'] = 'Fjern'; + $lang['strdropped'] = 'Fjernet'; + $lang['strnull'] = 'Ingenting'; + $lang['strnotnull'] = 'Ikke ingenting'; + $lang['strfirst'] = '<< Første'; + $lang['strlast'] = 'Sidste >>'; + $lang['strprev'] = 'ForgÃ¥ende'; + $lang['strfailed'] = 'Mislykkedes'; + $lang['strnext'] = 'Næste'; + $lang['strcreate'] = 'Opret'; + $lang['strcreated'] = 'Oprettet'; + $lang['strcomment'] = 'Kommentar'; + $lang['strlength'] = 'Længde'; + $lang['strdefault'] = 'Standardværdi'; + $lang['stralter'] = 'Ændre'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Fortryd'; + $lang['strsave'] = 'Gem'; + $lang['strreset'] = 'Nulstil'; + $lang['strinsert'] = 'Indsæt'; + $lang['strselect'] = 'Vælg'; + $lang['strdelete'] = 'Slet'; + $lang['strupdate'] = 'Opdater'; + $lang['strreferences'] = 'Referencer'; + $lang['stryes'] = 'Ja'; + $lang['strno'] = 'Nej'; + $lang['strtrue'] = 'Sand'; + $lang['strfalse'] = 'Falsk'; + $lang['stredit'] = 'Redigere'; + $lang['strcolumn'] = 'Kolonne'; + $lang['strcolumns'] = 'Kolonner'; + $lang['strrows'] = 'Række(r)'; + $lang['strrowsaff'] = 'Række(r) berørt.'; + $lang['strobjects'] = 'Objekt'; + $lang['strexample'] = 'f.eks.'; + $lang['strback'] = 'Tilbage'; + $lang['strqueryresults'] = 'Søgeresultat'; + $lang['strshow'] = 'Vise'; + $lang['strempty'] = 'Tøm'; + $lang['strlanguage'] = 'Sprog'; + $lang['strencoding'] = 'Kodning'; + $lang['strvalue'] = 'Værdi'; + $lang['strunique'] = 'Unik'; + $lang['strprimary'] = 'Primær'; + $lang['strexport'] = 'Eksportere'; + $lang['strimport'] = 'Importere'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = 'Udfør'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Ryd op'; + $lang['stranalyze'] = 'Analysere'; + $lang['strclusterindex'] = 'Klynge'; + $lang['strclustered'] = 'Klynget?'; + $lang['strreindex'] = 'Genindekser'; + $lang['strrun'] = 'Udfør'; + $lang['stradd'] = 'Tilføj'; + $lang['strevent'] = 'Hændelse'; + $lang['strwhere'] = 'Hvor'; + $lang['strinstead'] = 'Gør i stedet'; + $lang['strwhen'] = 'NÃ¥r'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'Bekræft'; + $lang['strexpression'] = 'Udtryk'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Udvid'; + $lang['strcollapse'] = 'Klap sammen'; + $lang['strexplain'] = 'Forklar'; + $lang['strexplainanalyze'] = 'Forklar analyze'; + $lang['strfind'] = 'Søg'; + $lang['stroptions'] = 'Alternativ'; + $lang['strrefresh'] = 'Opdater'; + $lang['strdownload'] = 'Download'; + $lang['strdownloadgzipped'] = 'Download komprimeret som gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OID´er'; + $lang['stradvanced'] = 'Avanceret'; + $lang['strvariables'] = 'Variable'; + $lang['strprocess'] = 'Proces'; + $lang['strprocesses'] = 'Processer'; + $lang['strsetting'] = 'Indstilling'; + $lang['streditsql'] = 'Rediger SQL'; + $lang['strruntime'] = 'Total runtime: %s ms'; + $lang['strpaginate'] = 'Paginere resultater'; + $lang['struploadscript'] = 'eller upload et SQL script:'; + $lang['strstarttime'] = 'Starttid'; + $lang['strfile'] = 'Fil'; + $lang['strfileimported'] = 'Fil importeret.'; + $lang['strparameters'] = 'Parametrer'; + + // Error handling + $lang['strnotloaded'] = 'Du har ikke ikke indlagt korrekt databaseunderstøttelse i din PHP-installation.'; + $lang['strbadconfig'] = 'Din config.inc.php er ikke opdateret. Du er nødt til at genetablere den fra den nye config.inc.php-dist.'; + $lang['strbadencoding'] = 'Det lykkedes ikke at sætte klientkodning i databasen.'; + $lang['strbadSchema'] = 'Forkert Skema angivet.'; + $lang['strinstatement'] = 'I pÃ¥standen:'; + $lang['strsqlerror'] = 'SQL fejl:'; + $lang['strinvalidparam'] = 'Ugyldig scriptparam.'; + $lang['strnodata'] = 'Ingen rækker fundet.'; + $lang['strnoobjects'] = 'Ingen objekter fundet.'; + $lang['strrownotunique'] = 'Denne række har ingen unik nøgle.'; + + // Tables + $lang['strtable'] = 'Tabel'; + $lang['strtables'] = 'Tabeller'; + $lang['strshowalltables'] = 'Vis alle tabeller'; + $lang['strnotables'] = 'Fandt ingen tabeller.'; + $lang['strnotable'] = 'Fandt ingen tabel.'; + $lang['strcreatetable'] = 'Opret tabel'; + $lang['strtablename'] = 'Tabelnavn'; + $lang['strtableneedsname'] = 'Tabel skal have et navn.'; + $lang['strtableneedsfield'] = 'Der skal mindst være et felt.'; + $lang['strtableneedscols'] = 'tabeller kræver et tilladeligt antal kolonner.'; + $lang['strtablecreated'] = 'Tabel oprettet.'; + $lang['strtablecreatedbad'] = 'Tabeloprettelse mislykkedes.'; + $lang['strconfdroptable'] = 'Er du sikker pÃ¥ at du vil fjerne tabellen "%s"?'; + $lang['strtabledropped'] = 'Tabel fjernet.'; + $lang['strinsertrow'] = 'Indsæt række'; + $lang['strtabledroppedbad'] = 'Det lykkedes ikke at fjerne tabellen.'; + $lang['strrowinserted'] = 'Række indsat.'; + $lang['strconfemptytable'] = 'Er du sikker pÃ¥ at du vil tømme tabellen "%s"?'; + $lang['strrowupdated'] = 'Række opdateret.'; + $lang['strrowinsertedbad'] = 'Det lykkedes ikke indsætte række.'; + $lang['strtableemptied'] = 'Tabellen tømt.'; + $lang['strrowupdatedbad'] = 'Opdatering af række mislykkedes.'; + $lang['streditrow'] = 'Rediger række'; + $lang['strrowdeleted'] = 'Række slettet.'; + $lang['strrowdeletedbad'] = 'Sletning af række mislykkedes.'; + $lang['strfield'] = 'Felt'; + $lang['strconfdeleterow'] = 'Er du sikker pÃ¥ at du vil slette denne række?'; + $lang['strnumfields'] = 'Antal felter'; + $lang['strsaveandrepeat'] = 'Gem & Fortsæt'; + $lang['strtableemptiedbad'] = 'Det lykkedes ikke at tømme tabellen'; + $lang['strdeleterow'] = 'Slet række'; + $lang['strfields'] = 'Felt'; + $lang['strfieldneedsname'] = 'Feltet skal have et navn'; + $lang['strcolumndropped'] = 'Kolonne fjernet.'; + $lang['strselectallfields'] = 'Vælg alle felter'; + $lang['strselectneedscol'] = 'Der skal vælges mindst een kolonne'; + $lang['strselectunary'] = 'Unary operander kan ikke have værdien.'; + $lang['strcolumnaltered'] = 'Kolonne ændret.'; + $lang['straltercolumn'] = 'Ændre kolonne'; + $lang['strcolumnalteredbad'] = 'Det lykkes ikke at ændre kolonne.'; + $lang['strconfdropcolumn'] = 'Er du sikker pÃ¥ at du vil fjerne kolonne "%s" fra tabel "%s"?'; + $lang['strcolumndroppedbad'] = 'Det lykkedes ikke at fjerne kolonne.'; + $lang['straddcolumn'] = 'Tilføj kolonne'; + $lang['strcolumnadded'] = 'Kolonne tiføjet.'; + $lang['strcolumnaddedbad'] = 'Det lykkedes ikke at tilføje kolonne.'; + $lang['strcascade'] = 'KASKAD'; + $lang['strdataonly'] = 'Udelukkende data'; + $lang['strtablealtered'] = 'Tabel ændret.'; + $lang['strtablealteredbad'] = 'Det lykkedes ikke at ændre tabel.'; + $lang['strestimatedrowcount'] = 'AnslÃ¥et antal rækker'; + + // Users + $lang['struser'] = 'Bruger'; + $lang['strusers'] = 'Brugere'; + $lang['strusername'] = 'Brugernavn'; + $lang['strpassword'] = 'Password'; + $lang['strsuper'] = 'Superbruger?'; + $lang['strcreatedb'] = 'Opret database?'; + $lang['strexpires'] = 'Udløber'; + $lang['strsessiondefaults'] = 'Sessionsindstillinger'; + $lang['strnewname'] = 'Nyt navn'; + $lang['strnousers'] = 'Der blev ikke fundet nogen brugere.'; + $lang['strrename'] = 'Omdøb'; + $lang['struserrenamed'] = 'Brugernavn ændret.'; + $lang['struserrenamedbad'] = 'Det lykkedes ikke at omdøbe bruger.'; + $lang['struserupdated'] = 'Bruger opdateret.'; + $lang['struserupdatedbad'] = 'Opdatering af bruger mislykkedes.'; + $lang['strshowallusers'] = 'Vis alle brugere'; + $lang['strcreateuser'] = 'Opret bruger'; + $lang['struserneedsname'] = 'Bruger behøver et navn.'; + $lang['strconfdropuser'] = 'Er du sikker pÃ¥ at du vil slette brugeren "%s"?'; + $lang['strusercreated'] = 'Bruger oprettet.'; + $lang['strusercreatedbad'] = 'Oprettelse af bruger mislykkedes.'; + $lang['struserdropped'] = 'Bruger slettet.'; + $lang['struserdroppedbad'] = 'Sletning af bruger mislykkedes.'; + $lang['straccount'] = 'Konto'; + $lang['strchangepassword'] = 'Ændre password'; + $lang['strpasswordchanged'] = 'Password ændret.'; + $lang['strpasswordchangedbad'] = 'Ændring af password mislykkedes.'; + $lang['strpasswordshort'] = 'Password er for kort.'; + $lang['strpasswordconfirm'] = 'Password er forskellig fra bekræftelsen.'; + + // Groups + $lang['strgroup'] = 'Gruppe'; + $lang['strgroups'] = 'Grupper'; + $lang['strnogroup'] = 'Gruppe blev ikke fundet.'; + $lang['strnogroups'] = 'Ingen grupper blev fundet.'; + $lang['strcreategroup'] = 'Opret gruppe'; + $lang['strshowallgroups'] = 'Vis alle grupper'; + $lang['strgroupneedsname'] = 'Gruppen skal have et navn.'; + $lang['strgroupcreated'] = 'Gruppe oprettet.'; + $lang['strgroupdropped'] = 'Gruppe slettet.'; + $lang['strgroupcreatedbad'] = 'Oprettelse af gruppe mislykkedes.'; + $lang['strconfdropgroup'] = 'Er du sikker pÃ¥ at du vil slette gruppe "%s"?'; + $lang['strgrant'] = 'Tildel'; + $lang['strgranted'] = 'Privilegier ændret.'; + $lang['strgroupdroppedbad'] = 'Det lykkedes ikke at fjerne gruppe.'; + $lang['straddmember'] = 'Tilføj medlem'; + $lang['strmemberadded'] = 'Medlem tilføjet.'; + $lang['strmemberaddedbad'] = 'Det lykkedes ikke at tilføje medlem.'; + $lang['strdropmember'] = 'Fjern medlem'; + $lang['strconfdropmember'] = 'Er du sikker pÃ¥ at du vil fjerne medlem "%s" fra gruppen "%s"?'; + $lang['strmemberdropped'] = 'Medlem fjernet.'; + $lang['strmemberdroppedbad'] = 'Det lykkedes ikke at fjerne medlem.'; + + // Privileges + $lang['strprivilege'] = 'Rettighed'; + $lang['strprivileges'] = 'Rettigheder'; + $lang['strnoprivileges'] = 'Dette objekt har standard ejerrettigheder.'; + $lang['strmembers'] = 'Medlemmer'; + $lang['strrevoke'] = 'Inddrag'; + $lang['strgrantbad'] = 'Du skal angive mindst en bruger eller gruppe og mindst et privilegie.'; + $lang['strgrantfailed'] = 'Ændring af rettigheder mislykkedes.'; + $lang['stralterprivs'] = 'Ændre rettigheder'; + $lang['strdatabase'] = 'Database'; + $lang['strdatabasedropped'] = 'Database fjernet.'; + $lang['strdatabases'] = 'Databaser'; + $lang['strentersql'] = 'Indtast SQL til eksekvering :'; + $lang['strgrantor'] = 'Tilladelsesudsteder'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Database'; + $lang['strdatabases'] = 'Databaser'; + $lang['strshowalldatabases'] = 'Vis alle databaser'; + $lang['strnodatabase'] = 'Database blev ikke fundet.'; + $lang['strnodatabases'] = 'Der blev ikke fundet nogen databaser.'; + $lang['strcreatedatabase'] = 'Opret database'; + $lang['strdatabasename'] = 'Databasenavn'; + $lang['strdatabaseneedsname'] = 'Databasen skal have et navn.'; + $lang['strdatabasecreated'] = 'Database oprettet.'; + $lang['strdatabasecreatedbad'] = 'Oprettelse af database mislykkedes.'; + $lang['strconfdropdatabase'] = 'Er du sikker pÃ¥ at du vil fjerne database "%s"?'; + $lang['strdatabasedroppedbad'] = 'Fjernelse af database mislykkedes.'; + $lang['strentersql'] = 'Enter the SQL to execute below:'; + $lang['strsqlexecuted'] = 'SQL-kommando udført.'; + $lang['strvacuumgood'] = 'Vacuum udført.'; + $lang['strvacuumbad'] = 'Vacuum mislykkedes.'; + $lang['stranalyzegood'] = 'Analysen lykkedes.'; + $lang['stranalyzebad'] = 'Analysen mislykkedes.'; + $lang['strreindexgood'] = 'Reindeksering komplet.'; + $lang['strreindexbad'] = 'Reindeksering slog fejl.'; + $lang['strfull'] = 'Fuld'; + $lang['strfreeze'] = 'Fastfrys'; + $lang['strforce'] = 'Force'; + $lang['strsignalsent'] = 'Signal sendt.'; + $lang['strsignalsentbad'] = 'Afsendelse af signal mislykkedes.'; + $lang['strallobjects'] = 'Alle objekter'; + $lang['strstructureonly'] = 'Kun struktur'; + $lang['strstructureanddata'] = 'Struktur og data'; + + // Views + $lang['strview'] = 'View'; + $lang['strviews'] = 'Views'; + $lang['strshowallviews'] = 'Vis alle views'; + $lang['strnoview'] = 'Ingen view blev fundet.'; + $lang['strnoviews'] = 'Ingen views blev fundet.'; + $lang['strcreateview'] = 'Opret view'; + $lang['strviewname'] = 'Navn pÃ¥ view'; + $lang['strviewneedsname'] = 'View skal have et navn.'; + $lang['strviewneedsdef'] = 'Du skal angive en defintion for view.'; + $lang['strviewcreated'] = 'View oprettet.'; + $lang['strviewcreatedbad'] = 'Oprettelse af View mislykkedes.'; + $lang['strconfdropview'] = 'Er du sikker pÃ¥ at du vil fjerne view "%s"?'; + $lang['strviewdropped'] = 'View fjernet.'; + $lang['strviewdroppedbad'] = 'Fjernelse af view mislykkedes.'; + $lang['strviewupdated'] = 'View opdateret.'; + $lang['strviewupdatedbad'] = 'Opdatering af view mislykkedes.'; + $lang['strviewlink'] = 'Linking Keys'; + $lang['strviewconditions'] = 'Yderligere vilkÃ¥r'; + $lang['strcreateviewwiz'] = 'Opret view med hjælp af wizard'; + + // Sequences + $lang['strsequence'] = 'Sekvens'; + $lang['strsequences'] = 'Sekvenser'; + $lang['strshowallsequences'] = 'Vis alle sekvenser'; + $lang['strnosequence'] = 'Sekvens blev ikke fundet.'; + $lang['strnosequences'] = 'Ingen sekvenser blev fundet.'; + $lang['strcreatesequence'] = 'Opret sekvens'; + $lang['strlastvalue'] = 'Seneste værdi'; + $lang['strincrementby'] = 'Øg med'; + $lang['strstartvalue'] = 'Startværdi'; + $lang['strmaxvalue'] = 'Største værdi'; + $lang['strminvalue'] = 'Mindste værdi'; + $lang['strcachevalue'] = 'Cachens værdi'; + $lang['strlogcount'] = 'Log count'; + $lang['striscycled'] = 'Is cycled?'; + $lang['strsequenceneedsname'] = 'Sekvens skal have et navn.'; + $lang['strsequencecreated'] = 'Sekvens oprettet.'; + $lang['strsequencecreatedbad'] = 'Oprettelse af sekvens mislykkedes.'; + $lang['strconfdropsequence'] = 'Er du sikker pÃ¥ at du vil fjerne sekvensen "%s"?'; + $lang['strsequencedropped'] = 'Sekvensen fjernet.'; + $lang['strsequencedroppedbad'] = 'Fjernelse af sekvens mislykkedes.'; + + // Indexes + $lang['strindex'] = 'Indeks'; + $lang['strindexes'] = 'Indekser'; + $lang['strindexname'] = 'Indeksnavn'; + $lang['strshowallindexes'] = 'Vis alle indeks'; + $lang['strnoindex'] = 'Ingen indeks blev fundet.'; + $lang['strsequencereset'] = 'Nulstil sekvens.'; + $lang['strsequenceresetbad'] = 'Nulstilling af sekvens mislykkedes.'; + $lang['strnoindexes'] = 'Ingen indeks blev fundet.'; + $lang['strcreateindex'] = 'Opret indeks'; + $lang['strindexname'] = 'Indeksnavn'; + $lang['strtabname'] = 'Tabelnavn'; + $lang['strcolumnname'] = 'Kolonnenavn'; + $lang['strindexneedsname'] = 'Indeks skal have et navn'; + $lang['strindexneedscols'] = 'Indeks kræveret gyldigt antal kolonner.'; + $lang['strindexcreated'] = 'Indeks oprettet'; + $lang['strindexcreatedbad'] = 'Oprettelse af indeks mislykkedes.'; + $lang['strconfdropindex'] = 'Er du sikker pÃ¥ at du vil fjerne indeks "%s"?'; + $lang['strindexdropped'] = 'Indeks fjernet.'; + $lang['strindexdroppedbad'] = 'Det lykkedes ikke at fjerne indeks.'; + $lang['strkeyname'] = 'Nøglebetegnelse'; + $lang['struniquekey'] = 'Unik nøgle'; + $lang['strprimarykey'] = 'Primærnøgle'; + $lang['strindextype'] = 'Indekstype'; + $lang['strindexname'] = 'Indeksnavn'; + $lang['strtablecolumnlist'] = 'Tabelkolonner'; + $lang['strindexcolumnlist'] = 'Indekskolonner'; + $lang['strconfcluster'] = 'Are you sure you want to cluster "%s"?'; + $lang['strclusteredgood'] = 'Cluster complete.'; + $lang['strclusteredbad'] = 'Cluster failed.'; + + // Rules + $lang['strrules'] = 'Regler'; + $lang['strrule'] = 'Regel'; + $lang['strshowallrules'] = 'Vis alle regler'; + $lang['strnorule'] = 'Regel blev ikke fundet.'; + $lang['strnorules'] = 'Ingen regler blev fundet.'; + $lang['strcreaterule'] = 'Opret regel'; + $lang['strrulename'] = 'Regelnavn'; + $lang['strruleneedsname'] = 'Regel skal have et navn.'; + $lang['strrulecreated'] = 'Regel oprettet.'; + $lang['strrulecreatedbad'] = 'Oprettelse af regel mislykkedes.'; + $lang['strconfdroprule'] = 'Er du sikker pÃ¥ at du fjerne regel "%s" for "%s"?'; + $lang['strruledropped'] = 'Regel fjernet.'; + $lang['strruledroppedbad'] = 'Det lykkedes ikke at fjerne regel.'; + + // Constraints + $lang['strconstraints'] = 'Afgrænsninger'; + $lang['strshowallconstraints'] = 'Vis alle afgrænsninger'; + $lang['strnoconstraints'] = 'Der blev ikke fundet nogen afgrænsninger.'; + $lang['strcreateconstraint'] = 'Opret afgrænsning'; + $lang['strconstraintcreated'] = 'Afgrænsning oprettet.'; + $lang['strconstraintcreatedbad'] = 'Det lykkedes ikke at oprette afgrænsning.'; + $lang['strconfdropconstraint'] = 'Er du sikker pÃ¥ at du vil fjerne afgrænsning "%s" for "%s"?'; + $lang['strconstraintdropped'] = 'Afgrænsning fjernet.'; + $lang['strconstraintdroppedbad'] = 'Det lykkedes ikke at fjerne afgrænsning.'; + $lang['straddcheck'] = 'Tilføj check'; + $lang['strcheckneedsdefinition'] = 'Check afgrænsning skal defineres.'; + $lang['strcheckadded'] = 'Check tilføjet.'; + $lang['strcheckaddedbad'] = 'Det lykkedes ikke at tilføje check.'; + $lang['straddpk'] = 'Tilføj primærnøgle'; + $lang['strpkneedscols'] = 'Primærnøgle kræver mindst en kolonne.'; + $lang['strpkadded'] = 'Primærnøgle tilføjet.'; + $lang['strpkaddedbad'] = 'Tilføjelse af primærnøgle mislykkedes.'; + $lang['stradduniq'] = 'Tilføj unik nøgle'; + $lang['struniqneedscols'] = 'Unik nøgle kræver mindst een kolonne.'; + $lang['struniqadded'] = 'Unik nøgle tilføjet.'; + $lang['struniqaddedbad'] = 'Tilføjelse af unik nøgle mislykkedes.'; + $lang['straddfk'] = 'Tilføj ekstern nøgle'; + $lang['strfkneedscols'] = 'Ekstern nøgle kræver mindst een kolonne.'; + $lang['strfkneedstarget'] = 'Ekstern nøgle kræver en mÃ¥ltabel.'; + $lang['strfkadded'] = 'Ekstern nøgle tilføjet.'; + $lang['strfkaddedbad'] = 'Tilføjelse af ekstern nøgle mislykkedes.'; + $lang['strfktarget'] = 'MÃ¥ltabel'; + $lang['strfkcolumnlist'] = 'Kolonner i nøgle'; + $lang['strondelete'] = 'VED SLETNING'; + $lang['stronupdate'] = 'VED OPDATERING'; + + // Functions + $lang['strfunction'] = 'Funktion'; + $lang['strfunctions'] = 'Funktioner'; + $lang['strshowallfunctions'] = 'Vis alle funktioner'; + $lang['strnofunction'] = 'Hittade ingen funktion.'; + $lang['strnofunctions'] = 'Hittade inga funktioner.'; + $lang['strcreatefunction'] = 'Opret funktion'; + $lang['strcreateplfunction'] = 'Opret SQL/PL funktion'; + $lang['strcreateinternalfunction'] = 'Opret intern funktion'; + $lang['strcreatecfunction'] = 'Opret C funktion'; + $lang['strfunctionname'] = 'Funktionsnavn'; + $lang['strreturns'] = 'Tilbage'; + $lang['strarguments'] = 'Argumenter'; + $lang['strfunctionneedsname'] = 'Funktionen skal have et navn.'; + $lang['strfunctionneedsdef'] = 'Funktionen skal defineres.'; + $lang['strfunctioncreated'] = 'Funktion oprettet.'; + $lang['strfunctioncreatedbad'] = 'Oprettelse af funktion mislykkedes.'; + $lang['strconfdropfunction'] = 'Er du sikker pÃ¥ at du vil slette funktionen "%s"?'; + $lang['strproglanguage'] = 'Programmeringssprog'; + $lang['strfunctiondropped'] = 'Funktionen fjernet.'; + $lang['strfunctiondroppedbad'] = 'Fjernelse af funktionen mislykkedes.'; + $lang['strfunctionupdated'] = 'Funktion opdateret.'; + $lang['strfunctionupdatedbad'] = 'Opdatering af funktion mislykkedes.'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Triggere'; + $lang['strshowalltriggers'] = 'Vis alle triggere'; + $lang['strnotrigger'] = 'Hittede ingen trigger.'; + $lang['strnotriggers'] = 'Hittede ingen trigger.'; + $lang['strcreatetrigger'] = 'Opret trigger'; + $lang['strtriggerneedsname'] = 'Trigger skal have et navn.'; + $lang['strtriggerneedsfunc'] = 'Du skal specificere en funktion for trigger.'; + $lang['strtriggercreated'] = 'Trigger oprettet.'; + $lang['strtriggerdropped'] = 'Trigger fjernet.'; + $lang['strtriggercreatedbad'] = 'Det lykkedes ikke at oprette trigger.'; + $lang['strconfdroptrigger'] = 'Er du sikker pÃ¥ at du vil fjerne trigger "%s" pÃ¥ "%s"?'; + $lang['strtriggerdroppedbad'] = 'Det lykkedes ikke at fjerne trigger.'; + + + + $lang['strstorage'] = 'Lagring'; + $lang['strtriggeraltered'] = 'Trigger ændret.'; + $lang['strtriggeralteredbad'] = 'Det lykkedes ikke at ændre trigger.'; + + // Types + $lang['strtype'] = 'Type'; + $lang['strtypes'] = 'Typer'; + $lang['strshowalltypes'] = 'Vis alle typer'; + $lang['strnotype'] = 'Typen blev ikke fundet.'; + $lang['strnotypes'] = 'Ingen typer fundet.'; + + $lang['strtypeneedslen'] = 'Du skal angive typens længde.'; + + $lang['strcreatetype'] = 'Opret type'; + $lang['strtypename'] = 'Navn pÃ¥ typen'; + $lang['strinputfn'] = 'Input funktion'; + $lang['stroutputfn'] = 'Output funktion'; + $lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'Justering'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Begrænser'; + $lang['strtypeneedsname'] = 'Typen skal have et navn.'; + $lang['strtypecreated'] = 'Type oprettet'; + $lang['strtypecreatedbad'] = 'Det lykkedes ikke at oprette type.'; + $lang['strconfdroptype'] = 'Er du sikker pÃ¥ at du vil fjerne typen "%s"?'; + $lang['strtypedropped'] = 'Typen fjernet.'; + $lang['strtypedroppedbad'] = 'Det lykkedes ikke at fjerne typen.'; + + // Schemas + $lang['strschema'] = 'Skema'; + $lang['strschemas'] = 'Skemaer'; + $lang['strshowallschemas'] = 'Vis alle skemaer'; + $lang['strnoschema'] = 'Der blev ikke fundet noget skema.'; + $lang['strnoschemas'] = 'Der blev ikke fundet nogen skemaer.'; + $lang['strcreateschema'] = 'Opret skema'; + $lang['strschemaname'] = 'Skemanavn'; + $lang['strschemaneedsname'] = 'Skema skal have et navn.'; + $lang['strschemacreated'] = 'Skema oprettet'; + $lang['strschemacreatedbad'] = 'Det lykkedes ikke at oprette skema.'; + $lang['strconfdropschema'] = 'Er du sikker pÃ¥, at du vil fjerne skemaet "%s"?'; + $lang['strschemadropped'] = 'Skema fjernet.'; + $lang['strschemadroppedbad'] = 'Det lykkedes ikka at fjerne skema.'; + + // Reports + $lang['strtopbar'] = '%s kører pÃ¥ %s:%s -- Du er logged ind som bruger "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + + // Domains + $lang['strdomain'] = 'Domæne'; + $lang['strdomains'] = 'Domæner'; + $lang['strshowalldomains'] = 'Vis alle domæner'; + $lang['strnodomains'] = 'Ingen domæner blev fundet.'; + $lang['strcreatedomain'] = 'Opret domæne'; + $lang['strdomaindropped'] = 'Domæne fjernet.'; + $lang['strdomaindroppedbad'] = 'Det lykkedes ikke at fjerne domæne.'; + $lang['strconfdropdomain'] = 'Er du sikker pÃ¥ at du vil fjerne domænet "%s"?'; + $lang['strdomainneedsname'] = 'Du skal indtaste et domænenavn.'; + $lang['strdomaincreated'] = 'Domæne oprettet.'; + $lang['strdomaincreatedbad'] = 'Det lykkedes ikke at oprette et domæne.'; + $lang['strdomainaltered'] = 'Domæne ændret.'; + $lang['strdomainalteredbad'] = 'Det lykkedes ikke at ændre domæne.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operatorer'; + $lang['strshowalloperators'] = 'Vis alle operatorer'; + $lang['strnooperator'] = 'Operator blev ikke.'; + $lang['strnooperators'] = 'Der blev ikke fundet nogen operatorer.'; + $lang['strcreateoperator'] = 'Opret operator'; + $lang['strleftarg'] = 'Left Arg Type'; + $lang['strrightarg'] = 'Right Arg Type'; + $lang['strcommutator'] = 'Commutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Left sort'; + $lang['strrightsort'] = 'Right sort'; + $lang['strlessthan'] = 'Less than'; + $lang['strgreaterthan'] = 'Greater than'; + $lang['stroperatorneedsname'] = 'Operator skal have et navn.'; + $lang['stroperatorcreated'] = 'Operator oprettet'; + $lang['stroperatorcreatedbad'] = 'Oprettelse af operator mislykkedes.'; + $lang['strconfdropoperator'] = 'Er du sikker pÃ¥, at du vil fjerne operator "%s"?'; + $lang['stroperatordropped'] = 'Operator fjernet.'; + $lang['stroperatordroppedbad'] = 'Fjernelse af operator mislykkedes.'; + + // Casts + $lang['strcasts'] = 'Typekonverteringer'; + $lang['strnocasts'] = 'Ingen typekonverteringer fundet.'; + $lang['strsourcetype'] = 'Kildetype'; + $lang['strtargettype'] = 'MÃ¥ltype'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'Tildelt i'; + $lang['strbinarycompat'] = '(Binært kompatibel)'; + + // Conversions + $lang['strconversions'] = 'Konverteringer'; + $lang['strnoconversions'] = 'Ingen konverteringer fundet.'; + $lang['strsourceencoding'] = 'Kildekodning'; + $lang['strtargetencoding'] = 'MÃ¥lkodning'; + + // Languages + $lang['strlanguages'] = 'Sprog'; + $lang['strnolanguages'] = 'Der blev ikke fundet noget sprog.'; + $lang['strtrusted'] = 'PÃ¥lidelig(e)'; + + // Info + $lang['strnoinfo'] = 'Ingen tilgængelig information.'; + $lang['strreferringtables'] = 'Refererende tabeller'; + $lang['strparenttables'] = 'Overordnede tabeller'; + $lang['strchildtables'] = 'Underordnede tabeller'; + + // Aggregates + $lang['straggregates'] = 'Sammenlægninger'; + $lang['strnoaggregates'] = 'Ingen sammenlægninger fundet.'; + $lang['stralltypes'] = '(Alle typer)'; + + // Operator Classes + $lang['stropclasses'] = 'Operatorklasser'; + $lang['strnoopclasses'] = 'Ingen Operatorklasser fundet.'; + $lang['straccessmethod'] = 'Tilgangsmetode'; + + // Stats and performance + $lang['strrowperf'] = 'Row Performance'; + $lang['strioperf'] = 'I/O Performance'; + $lang['stridxrowperf'] = 'Index Row Performance'; + $lang['stridxioperf'] = 'Index I/O Performance'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequential'; + $lang['strscan'] = 'Scan'; + $lang['strread'] = 'Read'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Rows'; + + // Tablespaces + $lang['strtablespace'] = 'TabelomrÃ¥de'; + $lang['strtablespaces'] = 'TabelomrÃ¥der'; + $lang['strshowalltablespaces'] = 'Vis alle tabelomrÃ¥der'; + $lang['strnotablespaces'] = 'Ingen tabelomrÃ¥der fundet.'; + $lang['strcreatetablespace'] = 'Opret tabelomrÃ¥der'; + $lang['strlocation'] = 'Location'; + $lang['strtablespaceneedsname'] = 'TabelomrÃ¥det skal have et navn.'; + $lang['strtablespaceneedsloc'] = 'Du skal angive hvilken mappe tabelomrÃ¥det skal oprettes i.'; + $lang['strtablespacecreated'] = 'TabelomrÃ¥de oprettet.'; + $lang['strtablespacecreatedbad'] = 'Oprettelse af tabelomrÃ¥de lykkedes ikke.'; + $lang['strconfdroptablespace'] = 'Er du sikker pÃ¥, at du vil fjerne tabelomrÃ¥de "%s"?'; + $lang['strtablespacedropped'] = 'TabelomrÃ¥de fjernet.'; + $lang['strtablespacedroppedbad'] = 'Fjernelse af tabelomrÃ¥de lykkedes ikke.'; + $lang['strtablespacealtered'] = 'TabelomrÃ¥de ændret.'; + $lang['strtablespacealteredbad'] = 'Ændring af tabelomrÃ¥de lykkedes ikke.'; + + // Miscellaneous + $lang['strtopbar'] = '%s Kører pÃ¥ %s:%s -- Du er logged ind som bruger "%s", %s'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Hjælp'; + $lang['strhelpicon'] = '?'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/dutch.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/dutch.php new file mode 100644 index 00000000..998b94c3 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/dutch.php @@ -0,0 +1,467 @@ +>'; + $lang['strexplain'] = 'Verklaring'; + $lang['strfind'] = 'Zoek'; + $lang['stroptions'] = 'Opties'; + $lang['strrefresh'] = 'Ververs'; + $lang['strdownload'] = 'Download'; + $lang['strrownotunique'] = 'Geen unieke identifier voor deze rij.'; + $lang['strselectallfields'] = 'Selecteer alle velden'; + $lang['strtablealtered'] = 'Tabel gewijzigd.'; + $lang['strtablealteredbad'] = 'Tabel wijzigen mislukt.'; + $lang['strcreateuser'] = 'Creëer gebruiker'; + $lang['strusercreatedbad'] = 'Gebruiker creëren mislukt.'; + $lang['straddmember'] = 'Voeg groepslid toe'; + $lang['strmemberadded'] = 'Groepslid toegevoegd.'; + $lang['strmemberaddedbad'] = 'Toevoegen groepslid mislukt.'; + $lang['strdropmember'] = 'Verwijder groepslid'; + $lang['strconfdropmember'] = 'Weet u zeker dat u "%s" uit groep "%s" wilt verwijderen?'; + $lang['strmemberdropped'] = 'Groepslid verwijderd.'; + $lang['strmemberdroppedbad'] = 'Verwijderen van groepslid mislukt.'; + $lang['strgrantor'] = 'Grantor'; + $lang['strasterisk'] = '*'; + $lang['strsequencereset'] = 'Sequence reset.'; + $lang['strsequenceresetbad'] = 'Sequence reset mislukt.'; + $lang['strproglanguage'] = 'Programmeertaal'; + $lang['strtriggeraltered'] = 'Trigger gewijzigd.'; + $lang['strtriggeralteredbad'] = 'Trigger wijziging mislukt.'; + $lang['strdomain'] = 'Domein'; + $lang['strdomains'] = 'Domeinen'; + $lang['strshowalldomains'] = 'Toon alle domeinen'; + $lang['strnodomains'] = 'Geen domeinen gevonden.'; + $lang['strcreatedomain'] = 'Creëer domein'; + $lang['strdomaindropped'] = 'Domein verwijderd.'; + $lang['strdomaindroppedbad'] = 'Verwijderen van domein mislukt.'; + $lang['strconfdropdomain'] = 'Weet u zeker dat u het domein "%s" wilt verwijderen?'; + $lang['strdomainneedsname'] = 'U dient een naam op te geven voor uw domein.'; + $lang['strdomaincreated'] = 'Domein gecreëerd.'; + $lang['strdomaincreatedbad'] = 'Domeincreatie mislukt.'; + $lang['strdomainaltered'] = 'Domein gewijzigd.'; + $lang['strdomainalteredbad'] = 'Wijzigen van het domein mislukt.'; + $lang['stroperator'] = 'Operator'; + $lang['strshowalloperators'] = 'Toon alle operators'; + $lang['strnooperator'] = 'Geen operator gevonden.'; + $lang['strnooperators'] = 'Geen operators gevonden.'; + $lang['strcreateoperator'] = 'Creëer operator'; + $lang['stroperatorname'] = 'Naam van de operator'; + $lang['strleftarg'] = 'Linkerargument type'; + $lang['strrightarg'] = 'Rechterargument type'; + $lang['stroperatorneedsname'] = 'U dient een naam op te geven voor uw operator.'; + $lang['stroperatorcreated'] = 'Operator gecreëerd'; + $lang['stroperatorcreatedbad'] = 'Operator creatie mislukt.'; + $lang['strconfdropoperator'] = 'Weet u zeker dat u de operator "%s" wilt verwijderen?'; + $lang['stroperatordropped'] = 'Operator verwijderd.'; + $lang['stroperatordroppedbad'] = 'Verwijderen van de operator mislukt.'; + $lang['strhelp'] = 'Help'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/english.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/english.php new file mode 100644 index 00000000..c232a752 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/english.php @@ -0,0 +1,905 @@ +'; + $lang['strfirst'] = '<< First'; + $lang['strlast'] = 'Last >>'; + $lang['strfailed'] = 'Failed'; + $lang['strcreate'] = 'Create'; + $lang['strcreated'] = 'Created'; + $lang['strcomment'] = 'Comment'; + $lang['strlength'] = 'Length'; + $lang['strdefault'] = 'Default'; + $lang['stralter'] = 'Alter'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Cancel'; + $lang['strkill'] = 'Kill'; + $lang['strac'] = 'Enable AutoComplete'; + $lang['strsave'] = 'Save'; + $lang['strreset'] = 'Reset'; + $lang['strrestart'] = 'Restart'; + $lang['strinsert'] = 'Insert'; + $lang['strselect'] = 'Select'; + $lang['strdelete'] = 'Delete'; + $lang['strupdate'] = 'Update'; + $lang['strreferences'] = 'References'; + $lang['stryes'] = 'Yes'; + $lang['strno'] = 'No'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = 'Edit'; + $lang['strcolumn'] = 'Column'; + $lang['strcolumns'] = 'Columns'; + $lang['strrows'] = 'row(s)'; + $lang['strrowsaff'] = 'row(s) affected.'; + $lang['strobjects'] = 'object(s)'; + $lang['strback'] = 'Back'; + $lang['strqueryresults'] = 'Query Results'; + $lang['strshow'] = 'Show'; + $lang['strempty'] = 'Empty'; + $lang['strlanguage'] = 'Language'; + $lang['strencoding'] = 'Encoding'; + $lang['strvalue'] = 'Value'; + $lang['strunique'] = 'Unique'; + $lang['strprimary'] = 'Primary'; + $lang['strexport'] = 'Export'; + $lang['strimport'] = 'Import'; + $lang['strallowednulls'] = 'Allowed NULL characters'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Empty string/field'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analyze'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'Clustered?'; + $lang['strreindex'] = 'Reindex'; + $lang['strexecute'] = 'Execute'; + $lang['stradd'] = 'Add'; + $lang['strevent'] = 'Event'; + $lang['strwhere'] = 'Where'; + $lang['strinstead'] = 'Do Instead'; + $lang['strwhen'] = 'When'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'Confirm'; + $lang['strexpression'] = 'Expression'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Expand'; + $lang['strcollapse'] = 'Collapse'; + $lang['strfind'] = 'Find'; + $lang['stroptions'] = 'Options'; + $lang['strrefresh'] = 'Refresh'; + $lang['strdownload'] = 'Download'; + $lang['strdownloadgzipped'] = 'Download compressed with gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Advanced'; + $lang['strvariables'] = 'Variables'; + $lang['strprocess'] = 'Process'; + $lang['strprocesses'] = 'Processes'; + $lang['strblocked'] = 'Blocked'; + $lang['strsetting'] = 'Setting'; + $lang['streditsql'] = 'Edit SQL'; + $lang['strruntime'] = 'Total runtime: %s ms'; + $lang['strpaginate'] = 'Paginate results'; + $lang['struploadscript'] = 'or upload an SQL script:'; + $lang['strstarttime'] = 'Start Time'; + $lang['strfile'] = 'File'; + $lang['strfileimported'] = 'File imported.'; + $lang['strtrycred'] = 'Use these credentials for all servers'; + $lang['strconfdropcred'] = 'For security reason, disconnecting will destroy your shared login information. Are you sure you want to disconnect ?'; + $lang['stractionsonmultiplelines'] = 'Actions on multiple lines'; + $lang['strselectall'] = 'Select all'; + $lang['strunselectall'] = 'Unselect all'; + $lang['strlocale'] = 'Locale'; + $lang['strcollation'] = 'Collation'; + $lang['strctype'] = 'Character Type'; + $lang['strdefaultvalues'] = 'Default values'; + $lang['strnewvalues'] = 'New values'; + $lang['strstart'] = 'Start'; + $lang['strstop'] = 'Stop'; + $lang['strgotoppage'] = 'back to top'; + $lang['strtheme'] = 'Theme'; + $lang['strcluster'] = 'Cluster'; + + // Admin + $lang['stradminondatabase'] = 'The following administrative tasks apply on the whole %s database.'; + $lang['stradminontable'] = 'The following administrative tasks apply on the table %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'History'; + $lang['strnohistory'] = 'No history.'; + $lang['strclearhistory'] = 'Clear history'; + $lang['strdelhistory'] = 'Delete from history'; + $lang['strconfdelhistory'] = 'Really remove this request from history?'; + $lang['strconfclearhistory'] = 'Really clear history?'; + $lang['strnodatabaseselected'] = 'Please, select a database.'; + + // Database sizes + $lang['strnoaccess'] = 'No Access'; + $lang['strsize'] = 'Size'; + $lang['strbytes'] = 'bytes'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'This application works best with a frames-enabled browser, but can be used without frames by following the link below.'; + $lang['strnoframeslink'] = 'Use without frames'; + $lang['strbadconfig'] = 'Your config.inc.php is out of date. You will need to regenerate it from the new config.inc.php-dist.'; + $lang['strnotloaded'] = 'Your PHP installation does not support PostgreSQL. You need to recompile PHP using the --with-pgsql configure option.'; + $lang['strpostgresqlversionnotsupported'] = 'Version of PostgreSQL not supported. Please upgrade to version %s or later.'; + $lang['strbadschema'] = 'Invalid schema specified.'; + $lang['strbadencoding'] = 'Failed to set client encoding in database.'; + $lang['strsqlerror'] = 'SQL error:'; + $lang['strinstatement'] = 'In statement:'; + $lang['strinvalidparam'] = 'Invalid script parameters.'; + $lang['strnodata'] = 'No rows found.'; + $lang['strnoobjects'] = 'No objects found.'; + $lang['strrownotunique'] = 'No unique identifier for this row.'; + $lang['strnouploads'] = 'File uploads are disabled.'; + $lang['strimporterror'] = 'Import error.'; + $lang['strimporterror-fileformat'] = 'Import error: Failed to automatically determine the file format.'; + $lang['strimporterrorline'] = 'Import error on line %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Import error on line %s: Line does not possess the correct number of columns.'; + $lang['strimporterror-uploadedfile'] = 'Import error: File could not be uploaded to the server'; + $lang['strcannotdumponwindows'] = 'Dumping of complex table and schema names on Windows is not supported.'; + $lang['strinvalidserverparam'] = 'Attempt to connect with invalid server parameter, possibly someone is trying to hack your system.'; + $lang['strnoserversupplied'] = 'No server supplied!'; + $lang['strbadpgdumppath'] = 'Export error: Failed to execute pg_dump (given path in your conf/config.inc.php : %s). Please, fix this path in your configuration and relog.'; + $lang['strbadpgdumpallpath'] = 'Export error: Failed to execute pg_dumpall (given path in your conf/config.inc.php : %s). Please, fix this path in your configuration and relog.'; + $lang['strconnectionfail'] = 'Can not connect to server.'; + + // Tables + $lang['strtable'] = 'Table'; + $lang['strtables'] = 'Tables'; + $lang['strshowalltables'] = 'Show all tables'; + $lang['strnotables'] = 'No tables found.'; + $lang['strnotable'] = 'No table found.'; + $lang['strcreatetable'] = 'Create table'; + $lang['strcreatetablelike'] = 'Create table like'; + $lang['strcreatetablelikeparent'] = 'Source table'; + $lang['strcreatelikewithdefaults'] = 'INCLUDE DEFAULTS'; + $lang['strcreatelikewithconstraints'] = 'INCLUDE CONSTRAINTS'; + $lang['strcreatelikewithindexes'] = 'INCLUDE INDEXES'; + $lang['strtablename'] = 'Table name'; + $lang['strtableneedsname'] = 'You must give a name for your table.'; + $lang['strtablelikeneedslike'] = 'You must give a table to copy properties from.'; + $lang['strtableneedsfield'] = 'You must specify at least one field.'; + $lang['strtableneedscols'] = 'You must specify a valid number of columns.'; + $lang['strtablecreated'] = 'Table created.'; + $lang['strtablecreatedbad'] = 'Table creation failed.'; + $lang['strconfdroptable'] = 'Are you sure you want to drop the table "%s"?'; + $lang['strtabledropped'] = 'Table dropped.'; + $lang['strtabledroppedbad'] = 'Table drop failed.'; + $lang['strconfemptytable'] = 'Are you sure you want to empty the table "%s"?'; + $lang['strtableemptied'] = 'Table emptied.'; + $lang['strtableemptiedbad'] = 'Table empty failed.'; + $lang['strinsertrow'] = 'Insert row'; + $lang['strrowinserted'] = 'Row inserted.'; + $lang['strrowinsertedbad'] = 'Row insert failed.'; + $lang['strnofkref'] = 'There is no matching value in the foreign key %s.'; + $lang['strrowduplicate'] = 'Row insert failed, attempted to do duplicate insert.'; + $lang['streditrow'] = 'Edit row'; + $lang['strrowupdated'] = 'Row updated.'; + $lang['strrowupdatedbad'] = 'Row update failed.'; + $lang['strdeleterow'] = 'Delete Row'; + $lang['strconfdeleterow'] = 'Are you sure you want to delete this row?'; + $lang['strrowdeleted'] = 'Row deleted.'; + $lang['strrowdeletedbad'] = 'Row deletion failed.'; + $lang['strinsertandrepeat'] = 'Insert & Repeat'; + $lang['strnumcols'] = 'Number of columns'; + $lang['strcolneedsname'] = 'You must specify a name for the column'; + $lang['strselectallfields'] = 'Select all fields'; + $lang['strselectneedscol'] = 'You must show at least one column.'; + $lang['strselectunary'] = 'Unary operators cannot have values.'; + $lang['strcolumnaltered'] = 'Column altered.'; + $lang['strcolumnalteredbad'] = 'Column alteration failed.'; + $lang['strconfdropcolumn'] = 'Are you sure you want to drop column "%s" from table "%s"?'; + $lang['strcolumndropped'] = 'Column dropped.'; + $lang['strcolumndroppedbad'] = 'Column drop failed.'; + $lang['straddcolumn'] = 'Add column'; + $lang['strcolumnadded'] = 'Column added.'; + $lang['strcolumnaddedbad'] = 'Column add failed.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Table altered.'; + $lang['strtablealteredbad'] = 'Table alteration failed.'; + $lang['strdataonly'] = 'Data only'; + $lang['strstructureonly'] = 'Structure only'; + $lang['strstructureanddata'] = 'Structure and data'; + $lang['strtabbed'] = 'Tabbed'; + $lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Are you sure you want to vacuum "%s"?'; + $lang['strconfanalyzetable'] = 'Are you sure you want to analyze "%s"?'; + $lang['strconfreindextable'] = 'Are you sure you want to reindex "%s"?'; + $lang['strconfclustertable'] = 'Are you sure you want to cluster "%s"?'; + $lang['strestimatedrowcount'] = 'Estimated row count'; + $lang['strspecifytabletoanalyze'] = 'You must specify at least one table to analyze.'; + $lang['strspecifytabletoempty'] = 'You must specify at least one table to empty.'; + $lang['strspecifytabletodrop'] = 'You must specify at least one table to drop.'; + $lang['strspecifytabletovacuum'] = 'You must specify at least one table to vacuum.'; + $lang['strspecifytabletoreindex'] = 'You must specify at least one table to reindex.'; + $lang['strspecifytabletocluster'] = 'You must specify at least one table to cluster.'; + $lang['strnofieldsforinsert'] = 'You cannot insert a row into a table with no column.'; + + // Columns + $lang['strcolprop'] = 'Column properties'; + $lang['strnotableprovided'] = 'No table provided!'; + + // Users + $lang['struser'] = 'User'; + $lang['strusers'] = 'Users'; + $lang['strusername'] = 'Username'; + $lang['strpassword'] = 'Password'; + $lang['strsuper'] = 'Superuser?'; + $lang['strcreatedb'] = 'Create DB?'; + $lang['strexpires'] = 'Expires'; + $lang['strsessiondefaults'] = 'Session defaults'; + $lang['strnousers'] = 'No users found.'; + $lang['struserupdated'] = 'User updated.'; + $lang['struserupdatedbad'] = 'User update failed.'; + $lang['strshowallusers'] = 'Show all users'; + $lang['strcreateuser'] = 'Create user'; + $lang['struserneedsname'] = 'You must give a name for your user.'; + $lang['strusercreated'] = 'User created.'; + $lang['strusercreatedbad'] = 'Failed to create user.'; + $lang['strconfdropuser'] = 'Are you sure you want to drop the user "%s"?'; + $lang['struserdropped'] = 'User dropped.'; + $lang['struserdroppedbad'] = 'Failed to drop user.'; + $lang['straccount'] = 'Account'; + $lang['strchangepassword'] = 'Change password'; + $lang['strpasswordchanged'] = 'Password changed.'; + $lang['strpasswordchangedbad'] = 'Failed to change password.'; + $lang['strpasswordshort'] = 'Password is too short.'; + $lang['strpasswordconfirm'] = 'Password does not match confirmation.'; + + // Groups + $lang['strgroup'] = 'Group'; + $lang['strgroups'] = 'Groups'; + $lang['strgroupgroups'] = 'Groups in group "%s"'; + $lang['strshowallgroups'] = 'Show all groups'; + $lang['strnogroup'] = 'Group not found.'; + $lang['strnogroups'] = 'No groups found.'; + $lang['strcreategroup'] = 'Create group'; + $lang['strgroupneedsname'] = 'You must give a name for your group.'; + $lang['strgroupcreated'] = 'Group created.'; + $lang['strgroupcreatedbad'] = 'Group creation failed.'; + $lang['strconfdropgroup'] = 'Are you sure you want to drop the group "%s"?'; + $lang['strgroupdropped'] = 'Group dropped.'; + $lang['strgroupdroppedbad'] = 'Group drop failed.'; + $lang['strmembers'] = 'Members'; + $lang['strmemberof'] = 'Member of'; + $lang['stradminmembers'] = 'Admin members'; + $lang['straddmember'] = 'Add member'; + $lang['strmemberadded'] = 'Member added.'; + $lang['strmemberaddedbad'] = 'Member add failed.'; + $lang['strdropmember'] = 'Drop member'; + $lang['strconfdropmember'] = 'Are you sure you want to drop the member "%s" from the group "%s"?'; + $lang['strmemberdropped'] = 'Member dropped.'; + $lang['strmemberdroppedbad'] = 'Member drop failed.'; + + // Roles + $lang['strrole'] = 'Role'; + $lang['strroles'] = 'Roles'; + $lang['strshowallroles'] = 'Show all roles'; + $lang['strnoroles'] = 'No roles found.'; + $lang['strinheritsprivs'] = 'Inherits privileges?'; + $lang['strcreaterole'] = 'Create role'; + $lang['strcancreaterole'] = 'Can create role?'; + $lang['strrolecreated'] = 'Role created.'; + $lang['strrolecreatedbad'] = 'Create role failed.'; + $lang['strrolealtered'] = 'Role altered.'; + $lang['strrolealteredbad'] = 'Role alter failed.'; + $lang['strcanlogin'] = 'Can login?'; + $lang['strconnlimit'] = 'Connection limit'; + $lang['strdroprole'] = 'Drop role'; + $lang['strconfdroprole'] = 'Are you sure you want to drop the role "%s"?'; + $lang['strroledropped'] = 'Role dropped.'; + $lang['strroledroppedbad'] = 'Role drop failed.'; + $lang['strnolimit'] = 'No limit'; + $lang['strnever'] = 'Never'; + $lang['strroleneedsname'] = 'You must give a name for the role.'; + + // Privileges + $lang['strprivilege'] = 'Privilege'; + $lang['strprivileges'] = 'Privileges'; + $lang['strnoprivileges'] = 'This object has default owner privileges.'; + $lang['strgrant'] = 'Grant'; + $lang['strrevoke'] = 'Revoke'; + $lang['strgranted'] = 'Privileges changed.'; + $lang['strgrantfailed'] = 'Failed to change privileges.'; + $lang['strgrantbad'] = 'You must specify at least one user or group and at least one privilege.'; + $lang['strgrantor'] = 'Grantor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Database'; + $lang['strdatabases'] = 'Databases'; + $lang['strshowalldatabases'] = 'Show all databases'; + $lang['strnodatabases'] = 'No databases found.'; + $lang['strcreatedatabase'] = 'Create database'; + $lang['strdatabasename'] = 'Database name'; + $lang['strdatabaseneedsname'] = 'You must give a name for your database.'; + $lang['strdatabasecreated'] = 'Database created.'; + $lang['strdatabasecreatedbad'] = 'Database creation failed.'; + $lang['strconfdropdatabase'] = 'Are you sure you want to drop the database "%s"?'; + $lang['strdatabasedropped'] = 'Database dropped.'; + $lang['strdatabasedroppedbad'] = 'Database drop failed.'; + $lang['strentersql'] = 'Enter the SQL to execute below:'; + $lang['strsqlexecuted'] = 'SQL executed.'; + $lang['strvacuumgood'] = 'Vacuum complete.'; + $lang['strvacuumbad'] = 'Vacuum failed.'; + $lang['stranalyzegood'] = 'Analyze complete.'; + $lang['stranalyzebad'] = 'Analyze failed.'; + $lang['strreindexgood'] = 'Reindex complete.'; + $lang['strreindexbad'] = 'Reindex failed.'; + $lang['strfull'] = 'Full'; + $lang['strfreeze'] = 'Freeze'; + $lang['strforce'] = 'Force'; + $lang['strsignalsent'] = 'Signal sent.'; + $lang['strsignalsentbad'] = 'Sending signal failed.'; + $lang['strallobjects'] = 'All objects'; + $lang['strdatabasealtered'] = 'Database altered.'; + $lang['strdatabasealteredbad'] = 'Database alter failed.'; + $lang['strspecifydatabasetodrop'] = 'You must specify at least one database to drop.'; + $lang['strtemplatedb'] = 'Template'; + $lang['strconfanalyzedatabase'] = 'Are you sure you want to analyze all tables in database "%s"?'; + $lang['strconfvacuumdatabase'] = 'Are you sure you want to vacuum all tables in database "%s"?'; + $lang['strconfreindexdatabase'] = 'Are you sure you want to reindex all tables in database "%s"?'; + $lang['strconfclusterdatabase'] = 'Are you sure you want to cluster all tables in database "%s"?'; + + // Views + $lang['strview'] = 'View'; + $lang['strviews'] = 'Views'; + $lang['strshowallviews'] = 'Show all views'; + $lang['strnoview'] = 'No view found.'; + $lang['strnoviews'] = 'No views found.'; + $lang['strcreateview'] = 'Create view'; + $lang['strviewname'] = 'View name'; + $lang['strviewneedsname'] = 'You must give a name for your view.'; + $lang['strviewneedsdef'] = 'You must give a definition for your view.'; + $lang['strviewneedsfields'] = 'You must give the columns you want selected in your view.'; + $lang['strviewcreated'] = 'View created.'; + $lang['strviewcreatedbad'] = 'View creation failed.'; + $lang['strconfdropview'] = 'Are you sure you want to drop the view "%s"?'; + $lang['strviewdropped'] = 'View dropped.'; + $lang['strviewdroppedbad'] = 'View drop failed.'; + $lang['strviewupdated'] = 'View updated.'; + $lang['strviewupdatedbad'] = 'View update failed.'; + $lang['strviewlink'] = 'Linking keys'; + $lang['strviewconditions'] = 'Additional conditions'; + $lang['strcreateviewwiz'] = 'Create view with wizard'; + $lang['strrenamedupfields'] = 'Rename duplicate fields'; + $lang['strdropdupfields'] = 'Drop duplicate fields'; + $lang['strerrordupfields'] = 'Error on duplicate fields'; + $lang['strviewaltered'] = 'View altered.'; + $lang['strviewalteredbad'] = 'View alteration failed.'; + $lang['strspecifyviewtodrop'] = 'You must specify at least one view to drop.'; + + // Sequences + $lang['strsequence'] = 'Sequence'; + $lang['strsequences'] = 'Sequences'; + $lang['strshowallsequences'] = 'Show all sequences'; + $lang['strnosequence'] = 'No sequence found.'; + $lang['strnosequences'] = 'No sequences found.'; + $lang['strcreatesequence'] = 'Create sequence'; + $lang['strlastvalue'] = 'Last value'; + $lang['strincrementby'] = 'Increment by'; + $lang['strstartvalue'] = 'Start value'; + $lang['strrestartvalue'] = 'Restart value'; + $lang['strmaxvalue'] = 'Max value'; + $lang['strminvalue'] = 'Min value'; + $lang['strcachevalue'] = 'Cache value'; + $lang['strlogcount'] = 'Log count'; + $lang['strcancycle'] = 'Can cycle?'; + $lang['striscalled'] = 'Will increment last value before returning next value (is_called)?'; + $lang['strsequenceneedsname'] = 'You must specify a name for your sequence.'; + $lang['strsequencecreated'] = 'Sequence created.'; + $lang['strsequencecreatedbad'] = 'Sequence creation failed.'; + $lang['strconfdropsequence'] = 'Are you sure you want to drop sequence "%s"?'; + $lang['strsequencedropped'] = 'Sequence dropped.'; + $lang['strsequencedroppedbad'] = 'Sequence drop failed.'; + $lang['strsequencerestart'] = 'Sequence restarted.'; + $lang['strsequencerestartbad'] = 'Sequence restart failed.'; + $lang['strsequencereset'] = 'Sequence reset.'; + $lang['strsequenceresetbad'] = 'Sequence reset failed.'; + $lang['strsequencealtered'] = 'Sequence altered.'; + $lang['strsequencealteredbad'] = 'Sequence alteration failed.'; + $lang['strsetval'] = 'Set value'; + $lang['strsequencesetval'] = 'Sequence value set.'; + $lang['strsequencesetvalbad'] = 'Sequence value set failed.'; + $lang['strnextval'] = 'Increment value'; + $lang['strsequencenextval'] = 'Sequence incremented.'; + $lang['strsequencenextvalbad'] = 'Sequence increment failed.'; + $lang['strspecifysequencetodrop'] = 'You must specify at least one sequence to drop.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indexes'; + $lang['strindexname'] = 'Index name'; + $lang['strshowallindexes'] = 'Show all indexes'; + $lang['strnoindex'] = 'No index found.'; + $lang['strnoindexes'] = 'No indexes found.'; + $lang['strcreateindex'] = 'Create index'; + $lang['strtabname'] = 'Tab name'; + $lang['strcolumnname'] = 'Column name'; + $lang['strindexneedsname'] = 'You must give a name for your index.'; + $lang['strindexneedscols'] = 'Indexes require a valid number of columns.'; + $lang['strindexcreated'] = 'Index created.'; + $lang['strindexcreatedbad'] = 'Index creation failed.'; + $lang['strconfdropindex'] = 'Are you sure you want to drop the index "%s"?'; + $lang['strindexdropped'] = 'Index dropped.'; + $lang['strindexdroppedbad'] = 'Index drop failed.'; + $lang['strkeyname'] = 'Key name'; + $lang['struniquekey'] = 'Unique key'; + $lang['strprimarykey'] = 'Primary key'; + $lang['strindextype'] = 'Type of index'; + $lang['strtablecolumnlist'] = 'Columns in table'; + $lang['strindexcolumnlist'] = 'Columns in index'; + $lang['strconfcluster'] = 'Are you sure you want to cluster on "%s"?'; + $lang['strclusteredgood'] = 'Cluster complete.'; + $lang['strclusteredbad'] = 'Cluster failed.'; + $lang['strconcurrently'] = 'Concurrently'; + $lang['strnoclusteravailable'] = 'Table not clustered on an index.'; + + // Rules + $lang['strrules'] = 'Rules'; + $lang['strrule'] = 'Rule'; + $lang['strshowallrules'] = 'Show all rules'; + $lang['strnorule'] = 'No rule found.'; + $lang['strnorules'] = 'No rules found.'; + $lang['strcreaterule'] = 'Create rule'; + $lang['strrulename'] = 'Rule name'; + $lang['strruleneedsname'] = 'You must specify a name for your rule.'; + $lang['strrulecreated'] = 'Rule created.'; + $lang['strrulecreatedbad'] = 'Rule creation failed.'; + $lang['strconfdroprule'] = 'Are you sure you want to drop the rule "%s" on "%s"?'; + $lang['strruledropped'] = 'Rule dropped.'; + $lang['strruledroppedbad'] = 'Rule drop failed.'; + + // Constraints + $lang['strconstraint'] = 'Constraint'; + $lang['strconstraints'] = 'Constraints'; + $lang['strshowallconstraints'] = 'Show all constraints'; + $lang['strnoconstraints'] = 'No constraints found.'; + $lang['strcreateconstraint'] = 'Create constraint'; + $lang['strconstraintcreated'] = 'Constraint created.'; + $lang['strconstraintcreatedbad'] = 'Constraint creation failed.'; + $lang['strconfdropconstraint'] = 'Are you sure you want to drop the constraint "%s" on "%s"?'; + $lang['strconstraintdropped'] = 'Constraint dropped.'; + $lang['strconstraintdroppedbad'] = 'Constraint drop failed.'; + $lang['straddcheck'] = 'Add check'; + $lang['strcheckneedsdefinition'] = 'Check constraint needs a definition.'; + $lang['strcheckadded'] = 'Check constraint added.'; + $lang['strcheckaddedbad'] = 'Failed to add check constraint.'; + $lang['straddpk'] = 'Add primary key'; + $lang['strpkneedscols'] = 'Primary key requires at least one column.'; + $lang['strpkadded'] = 'Primary key added.'; + $lang['strpkaddedbad'] = 'Failed to add primary key.'; + $lang['stradduniq'] = 'Add unique key'; + $lang['struniqneedscols'] = 'Unique key requires at least one column.'; + $lang['struniqadded'] = 'Unique key added.'; + $lang['struniqaddedbad'] = 'Failed to add unique key.'; + $lang['straddfk'] = 'Add foreign key'; + $lang['strfkneedscols'] = 'Foreign key requires at least one column.'; + $lang['strfkneedstarget'] = 'Foreign key requires a target table.'; + $lang['strfkadded'] = 'Foreign key added.'; + $lang['strfkaddedbad'] = 'Failed to add foreign key.'; + $lang['strfktarget'] = 'Target table'; + $lang['strfkcolumnlist'] = 'Columns in key'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Function'; + $lang['strfunctions'] = 'Functions'; + $lang['strshowallfunctions'] = 'Show all functions'; + $lang['strnofunction'] = 'No function found.'; + $lang['strnofunctions'] = 'No functions found.'; + $lang['strcreateplfunction'] = 'Create SQL/PL function'; + $lang['strcreateinternalfunction'] = 'Create internal function'; + $lang['strcreatecfunction'] = 'Create C function'; + $lang['strfunctionname'] = 'Function name'; + $lang['strreturns'] = 'Returns'; + $lang['strproglanguage'] = 'Programming language'; + $lang['strfunctionneedsname'] = 'You must give a name for your function.'; + $lang['strfunctionneedsdef'] = 'You must give a definition for your function.'; + $lang['strfunctioncreated'] = 'Function created.'; + $lang['strfunctioncreatedbad'] = 'Function creation failed.'; + $lang['strconfdropfunction'] = 'Are you sure you want to drop the function "%s"?'; + $lang['strfunctiondropped'] = 'Function dropped.'; + $lang['strfunctiondroppedbad'] = 'Function drop failed.'; + $lang['strfunctionupdated'] = 'Function updated.'; + $lang['strfunctionupdatedbad'] = 'Function update failed.'; + $lang['strobjectfile'] = 'Object File'; + $lang['strlinksymbol'] = 'Link Symbol'; + $lang['strarguments'] = 'Arguments'; + $lang['strargmode'] = 'Mode'; + $lang['strargtype'] = 'Type'; + $lang['strargadd'] = 'Add another argument'; + $lang['strargremove'] = 'Remove this argument'; + $lang['strargnoargs'] = 'This function will not take any arguments.'; + $lang['strargenableargs'] = 'Enable arguments being passed to this function.'; + $lang['strargnorowabove'] = 'There needs to be a row above this row.'; + $lang['strargnorowbelow'] = 'There needs to be a row below this row.'; + $lang['strargraise'] = 'Move up.'; + $lang['strarglower'] = 'Move down.'; + $lang['strargremoveconfirm'] = 'Are you sure you want to remove this argument? This CANNOT be undone.'; + $lang['strfunctioncosting'] = 'Function Costing'; + $lang['strresultrows'] = 'Result Rows'; + $lang['strexecutioncost'] = 'Execution Cost'; + $lang['strspecifyfunctiontodrop'] = 'You must specify at least one function to drop.'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Triggers'; + $lang['strshowalltriggers'] = 'Show all triggers'; + $lang['strnotrigger'] = 'No trigger found.'; + $lang['strnotriggers'] = 'No triggers found.'; + $lang['strcreatetrigger'] = 'Create trigger'; + $lang['strtriggerneedsname'] = 'You must specify a name for your trigger.'; + $lang['strtriggerneedsfunc'] = 'You must specify a function for your trigger.'; + $lang['strtriggercreated'] = 'Trigger created.'; + $lang['strtriggercreatedbad'] = 'Trigger creation failed.'; + $lang['strconfdroptrigger'] = 'Are you sure you want to drop the trigger "%s" on "%s"?'; + $lang['strconfenabletrigger'] = 'Are you sure you want to enable the trigger "%s" on "%s"?'; + $lang['strconfdisabletrigger'] = 'Are you sure you want to disable the trigger "%s" on "%s"?'; + $lang['strtriggerdropped'] = 'Trigger dropped.'; + $lang['strtriggerdroppedbad'] = 'Trigger drop failed.'; + $lang['strtriggerenabled'] = 'Trigger enabled.'; + $lang['strtriggerenabledbad'] = 'Trigger enable failed.'; + $lang['strtriggerdisabled'] = 'Trigger disabled.'; + $lang['strtriggerdisabledbad'] = 'Trigger disable failed.'; + $lang['strtriggeraltered'] = 'Trigger altered.'; + $lang['strtriggeralteredbad'] = 'Trigger alteration failed.'; + $lang['strforeach'] = 'For each'; + + // Types + $lang['strtype'] = 'Type'; + $lang['strtypes'] = 'Types'; + $lang['strshowalltypes'] = 'Show all types'; + $lang['strnotype'] = 'No type found.'; + $lang['strnotypes'] = 'No types found.'; + $lang['strcreatetype'] = 'Create type'; + $lang['strcreatecomptype'] = 'Create composite type'; + $lang['strcreateenumtype'] = 'Create enum type'; + $lang['strtypeneedsfield'] = 'You must specify at least one field.'; + $lang['strtypeneedsvalue'] = 'You must specify at least one value.'; + $lang['strtypeneedscols'] = 'You must specify a valid number of fields.'; + $lang['strtypeneedsvals'] = 'You must specify a valid number of values.'; + $lang['strinputfn'] = 'Input function'; + $lang['stroutputfn'] = 'Output function'; + $lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'Alignment'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Delimiter'; + $lang['strstorage'] = 'Storage'; + $lang['strfield'] = 'Field'; + $lang['strnumfields'] = 'Num. of fields'; + $lang['strnumvalues'] = 'Num. of values'; + $lang['strtypeneedsname'] = 'You must give a name for your type.'; + $lang['strtypeneedslen'] = 'You must give a length for your type.'; + $lang['strtypecreated'] = 'Type created.'; + $lang['strtypecreatedbad'] = 'Type creation failed.'; + $lang['strconfdroptype'] = 'Are you sure you want to drop the type "%s"?'; + $lang['strtypedropped'] = 'Type dropped.'; + $lang['strtypedroppedbad'] = 'Type drop failed.'; + $lang['strflavor'] = 'Flavor'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Composite'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'Enum'; + $lang['strenumvalues'] = 'Enum values'; + + // Schemas + $lang['strschema'] = 'Schema'; + $lang['strschemas'] = 'Schemas'; + $lang['strshowallschemas'] = 'Show all schemas'; + $lang['strnoschema'] = 'No schema found.'; + $lang['strnoschemas'] = 'No schemas found.'; + $lang['strcreateschema'] = 'Create schema'; + $lang['strschemaname'] = 'Schema name'; + $lang['strschemaneedsname'] = 'You must give a name for your schema.'; + $lang['strschemacreated'] = 'Schema created.'; + $lang['strschemacreatedbad'] = 'Schema creation failed.'; + $lang['strconfdropschema'] = 'Are you sure you want to drop the schema "%s"?'; + $lang['strschemadropped'] = 'Schema dropped.'; + $lang['strschemadroppedbad'] = 'Schema drop failed.'; + $lang['strschemaaltered'] = 'Schema altered.'; + $lang['strschemaalteredbad'] = 'Schema alteration failed.'; + $lang['strsearchpath'] = 'Schema search path'; + $lang['strspecifyschematodrop'] = 'You must specify at least one schema to drop.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domain'; + $lang['strdomains'] = 'Domains'; + $lang['strshowalldomains'] = 'Show all domains'; + $lang['strnodomains'] = 'No domains found.'; + $lang['strcreatedomain'] = 'Create domain'; + $lang['strdomaindropped'] = 'Domain dropped.'; + $lang['strdomaindroppedbad'] = 'Domain drop failed.'; + $lang['strconfdropdomain'] = 'Are you sure you want to drop the domain "%s"?'; + $lang['strdomainneedsname'] = 'You must give a name for your domain.'; + $lang['strdomaincreated'] = 'Domain created.'; + $lang['strdomaincreatedbad'] = 'Domain creation failed.'; + $lang['strdomainaltered'] = 'Domain altered.'; + $lang['strdomainalteredbad'] = 'Domain alteration failed.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operators'; + $lang['strshowalloperators'] = 'Show all operators'; + $lang['strnooperator'] = 'No operator found.'; + $lang['strnooperators'] = 'No operators found.'; + $lang['strcreateoperator'] = 'Create operator'; + $lang['strleftarg'] = 'Left Arg Type'; + $lang['strrightarg'] = 'Right Arg Type'; + $lang['strcommutator'] = 'Commutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Left sort'; + $lang['strrightsort'] = 'Right sort'; + $lang['strlessthan'] = 'Less than'; + $lang['strgreaterthan'] = 'Greater than'; + $lang['stroperatorneedsname'] = 'You must give a name for your operator.'; + $lang['stroperatorcreated'] = 'Operator created.'; + $lang['stroperatorcreatedbad'] = 'Operator creation failed.'; + $lang['strconfdropoperator'] = 'Are you sure you want to drop the operator "%s"?'; + $lang['stroperatordropped'] = 'Operator dropped.'; + $lang['stroperatordroppedbad'] = 'Operator drop failed.'; + + // Casts + $lang['strcasts'] = 'Casts'; + $lang['strnocasts'] = 'No casts found.'; + $lang['strsourcetype'] = 'Source type'; + $lang['strtargettype'] = 'Target type'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'In assignment'; + $lang['strbinarycompat'] = '(Binary compatible)'; + + // Conversions + $lang['strconversions'] = 'Conversions'; + $lang['strnoconversions'] = 'No conversions found.'; + $lang['strsourceencoding'] = 'Source encoding'; + $lang['strtargetencoding'] = 'Target encoding'; + + // Languages + $lang['strlanguages'] = 'Languages'; + $lang['strnolanguages'] = 'No languages found.'; + $lang['strtrusted'] = 'Trusted'; + + // Info + $lang['strnoinfo'] = 'No information available.'; + $lang['strreferringtables'] = 'Referring tables'; + $lang['strparenttables'] = 'Parent tables'; + $lang['strchildtables'] = 'Child tables'; + + // Aggregates + $lang['straggregate'] = 'Aggregate'; + $lang['straggregates'] = 'Aggregates'; + $lang['strnoaggregates'] = 'No aggregates found.'; + $lang['stralltypes'] = '(All types)'; + $lang['strcreateaggregate'] = 'Create aggregate'; + $lang['straggrbasetype'] = 'Input data type'; + $lang['straggrsfunc'] = 'State transition function'; + $lang['straggrstype'] = 'Data type for state value'; + $lang['straggrffunc'] = 'Final function'; + $lang['straggrinitcond'] = 'Initial condition'; + $lang['straggrsortop'] = 'Sort operator'; + $lang['strconfdropaggregate'] = 'Are you sure you want to drop the aggregate "%s"?'; + $lang['straggregatedropped'] = 'Aggregate dropped.'; + $lang['straggregatedroppedbad'] = 'Aggregate drop failed.'; + $lang['straggraltered'] = 'Aggregate altered.'; + $lang['straggralteredbad'] = 'Aggregate alteration failed.'; + $lang['straggrneedsname'] = 'You must specify a name for the aggregate.'; + $lang['straggrneedsbasetype'] = 'You must specify the input data type for the aggregate.'; + $lang['straggrneedssfunc'] = 'You must specify the name of the state transition function for the aggregate.'; + $lang['straggrneedsstype'] = 'You must specify the data type for the aggregate\'s state value.'; + $lang['straggrcreated'] = 'Aggregate created.'; + $lang['straggrcreatedbad'] = 'Aggregate creation failed.'; + $lang['straggrshowall'] = 'Show all aggregates'; + + // Operator Classes + $lang['stropclasses'] = 'Op Classes'; + $lang['strnoopclasses'] = 'No operator classes found.'; + $lang['straccessmethod'] = 'Access method'; + + // Stats and performance + $lang['strrowperf'] = 'Row Performance'; + $lang['strioperf'] = 'I/O Performance'; + $lang['stridxrowperf'] = 'Index Row Performance'; + $lang['stridxioperf'] = 'Index I/O Performance'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequential'; + $lang['strscan'] = 'Scan'; + $lang['strread'] = 'Read'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Rows'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaces'; + $lang['strshowalltablespaces'] = 'Show all tablespaces'; + $lang['strnotablespaces'] = 'No tablespaces found.'; + $lang['strcreatetablespace'] = 'Create tablespace'; + $lang['strlocation'] = 'Location'; + $lang['strtablespaceneedsname'] = 'You must give a name for your tablespace.'; + $lang['strtablespaceneedsloc'] = 'You must give a directory in which to create the tablespace.'; + $lang['strtablespacecreated'] = 'Tablespace created.'; + $lang['strtablespacecreatedbad'] = 'Tablespace creation failed.'; + $lang['strconfdroptablespace'] = 'Are you sure you want to drop the tablespace "%s"?'; + $lang['strtablespacedropped'] = 'Tablespace dropped.'; + $lang['strtablespacedroppedbad'] = 'Tablespace drop failed.'; + $lang['strtablespacealtered'] = 'Tablespace altered.'; + $lang['strtablespacealteredbad'] = 'Tablespace alteration failed.'; + + // Miscellaneous + $lang['strtopbar'] = '%s running on %s:%s -- You are logged in as user "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Help'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Help page browser'; + $lang['strselecthelppage'] = 'Select a help page'; + $lang['strinvalidhelppage'] = 'Invalid help page.'; + $lang['strlogintitle'] = 'Login to %s'; + $lang['strlogoutmsg'] = 'Logged out of %s'; + $lang['strloading'] = 'Loading...'; + $lang['strerrorloading'] = 'Error Loading'; + $lang['strclicktoreload'] = 'Click to reload'; + + // Autovacuum + $lang['strautovacuum'] = 'Autovacuum'; + $lang['strturnedon'] = 'Turned On'; + $lang['strturnedoff'] = 'Turned Off'; + $lang['strenabled'] = 'Enabled'; + $lang['strnovacuumconf'] = 'No autovacuum configuration found.'; + $lang['strvacuumbasethreshold'] = 'Vacuum Base Threshold'; + $lang['strvacuumscalefactor'] = 'Vacuum Scale Factor'; + $lang['stranalybasethreshold'] = 'Analyze Base Threshold'; + $lang['stranalyzescalefactor'] = 'Analyze Scale Factor'; + $lang['strvacuumcostdelay'] = 'Vacuum Cost Delay'; + $lang['strvacuumcostlimit'] = 'Vacuum Cost Limit'; + $lang['strvacuumpertable'] = 'Autovacuum setup per table'; + $lang['straddvacuumtable'] = 'Add autovacuum setup for a table'; + $lang['streditvacuumtable'] = 'Edit autovacuum setup for table %s'; + $lang['strdelvacuumtable'] = 'Delete autovacuum setup for table %s ?'; + $lang['strvacuumtablereset'] = 'Autovacuum setup for table %s reset to default values'; + $lang['strdelvacuumtablefail'] = 'Fail to remove the autovacuum setup for table %s'; + $lang['strsetvacuumtablesaved'] = 'Autovacuum setup for table %s saved.'; + $lang['strsetvacuumtablefail'] = 'Autovacuum setup for table %s failed.'; + $lang['strspecifydelvacuumtable'] = 'You must specify the table you want remove the autovacuum parameters from.'; + $lang['strspecifyeditvacuumtable'] = 'You must specify the table you want to edit the autovacuum parameters from.'; + $lang['strnotdefaultinred'] = 'Not default values are in red.'; + + // Table-level Locks + $lang['strlocks'] = 'Locks'; + $lang['strtransaction'] = 'Transaction ID'; + $lang['strvirtualtransaction'] = 'Virtual Transaction ID'; + $lang['strprocessid'] = 'Process ID'; + $lang['strmode'] = 'Lock mode'; + $lang['strislockheld'] = 'Is lock held?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Prepared transactions'; + $lang['strxactid'] = 'Transaction ID'; + $lang['strgid'] = 'Global ID'; + + // Fulltext search + $lang['strfulltext'] = 'Full Text Search'; + $lang['strftsconfig'] = 'FTS configuration'; + $lang['strftsconfigs'] = 'Configurations'; + $lang['strftscreateconfig'] = 'Create FTS configuration'; + $lang['strftscreatedict'] = 'Create dictionary'; + $lang['strftscreatedicttemplate'] = 'Create dictionary template'; + $lang['strftscreateparser'] = 'Create parser'; + $lang['strftsnoconfigs'] = 'No FTS configuration found.'; + $lang['strftsconfigdropped'] = 'FTS configuration dropped.'; + $lang['strftsconfigdroppedbad'] = 'FTS configuration drop failed.'; + $lang['strconfdropftsconfig'] = 'Are you sure you want to drop the FTS configuration "%s"?'; + $lang['strconfdropftsdict'] = 'Are you sure you want to drop the FTS dictionary "%s"?'; + $lang['strconfdropftsmapping'] = 'Are you sure you want to drop mapping "%s" of FTS configuration "%s"?'; + $lang['strftstemplate'] = 'Template'; + $lang['strftsparser'] = 'Parser'; + $lang['strftsconfigneedsname'] = 'You must give a name for your FTS configuration.'; + $lang['strftsconfigcreated'] = 'FTS configuration created.'; + $lang['strftsconfigcreatedbad'] = 'FTS configuration creation failed.'; + $lang['strftsmapping'] = 'Mapping'; + $lang['strftsdicts'] = 'Dictionaries'; + $lang['strftsdict'] = 'Dictionary'; + $lang['strftsemptymap'] = 'Empty FTS configuration map.'; + $lang['strftsconfigaltered'] = 'FTS configuration altered.'; + $lang['strftsconfigalteredbad'] = 'FTS configuration alter failed.'; + $lang['strftsconfigmap'] = 'FTS configuration map'; + $lang['strftsparsers'] = 'FTS parsers'; + $lang['strftsnoparsers'] = 'No FTS parsers available.'; + $lang['strftsnodicts'] = 'No FTS dictionaries available.'; + $lang['strftsdictcreated'] = 'FTS dictionary created.'; + $lang['strftsdictcreatedbad'] = 'FTS dictionary creation failed.'; + $lang['strftslexize'] = 'Lexize'; + $lang['strftsinit'] = 'Init'; + $lang['strftsoptionsvalues'] = 'Options and values'; + $lang['strftsdictneedsname'] = 'You must give a name for your FTS dictionary.'; + $lang['strftsdictdropped'] = 'FTS dictionary dropped.'; + $lang['strftsdictdroppedbad'] = 'FTS dictionary drop failed.'; + $lang['strftsdictaltered'] = 'FTS dictionary altered.'; + $lang['strftsdictalteredbad'] = 'FTS dictionary alter failed.'; + $lang['strftsaddmapping'] = 'Add new mapping'; + $lang['strftsspecifymappingtodrop'] = 'You must specify at least one mapping to drop.'; + $lang['strftsspecifyconfigtoalter'] = 'You must specify a FTS configuration to alter'; + $lang['strftsmappingdropped'] = 'FTS mapping dropped.'; + $lang['strftsmappingdroppedbad'] = 'FTS mapping drop failed.'; + $lang['strftsnodictionaries'] = 'No dictionaries found.'; + $lang['strftsmappingaltered'] = 'FTS mapping altered.'; + $lang['strftsmappingalteredbad'] = 'FTS mapping alter failed.'; + $lang['strftsmappingadded'] = 'FTS mapping added.'; + $lang['strftsmappingaddedbad'] = 'FTS mapping add failed.'; + $lang['strftstabconfigs'] = 'Configurations'; + $lang['strftstabdicts'] = 'Dictionaries'; + $lang['strftstabparsers'] = 'Parsers'; + $lang['strftscantparsercopy'] = 'Can\'t specify both parser and template during text search configuration creation.'; + + //Plugins + $lang['strpluginnotfound'] = 'Error: plugin \'%s\' not found. Check if this plugin exists in the plugins/ directory, or if this plugins has a plugin.php file. Plugin\'s names are case sensitive'; + $lang['stractionnotfound'] = 'Error: action \'%s\' not found in the \'%s\' plugin, or it was not specified as an action.'; + $lang['strhooknotfound'] = 'Error: hook \'%s\' is not avaliable.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/french.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/french.php new file mode 100644 index 00000000..09ff57ad --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/french.php @@ -0,0 +1,899 @@ +>'; + $lang['strfailed'] = 'Échec'; + $lang['strcreate'] = 'Créer'; + $lang['strcreated'] = 'Créé'; + $lang['strcomment'] = 'Commentaire'; + $lang['strlength'] = 'Longueur'; + $lang['strdefault'] = 'Défaut'; + $lang['stralter'] = 'Modifier'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Annuler'; + $lang['strkill'] = 'Tuer'; + $lang['strac'] = 'Activer la complétion automatique'; + $lang['strsave'] = 'Sauvegarder'; + $lang['strreset'] = 'Réinitialiser'; + $lang['strrestart'] = 'Redémarrer'; + $lang['strinsert'] = 'Insérer'; + $lang['strselect'] = 'Sélectionner'; + $lang['strdelete'] = 'Effacer'; + $lang['strupdate'] = 'Modifier'; + $lang['strreferences'] = 'Références'; + $lang['stryes'] = 'Oui'; + $lang['strno'] = 'Non'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = 'Éditer'; + $lang['strcolumn'] = 'Colonne'; + $lang['strcolumns'] = 'Colonnes'; + $lang['strrows'] = 'ligne(s)'; + $lang['strrowsaff'] = 'ligne(s) affectée(s).'; + $lang['strobjects'] = 'objet(s)'; + $lang['strback'] = 'Retour'; + $lang['strqueryresults'] = 'Résultats de la requête'; + $lang['strshow'] = 'Voir'; + $lang['strempty'] = 'Vider'; + $lang['strlanguage'] = 'Langage'; + $lang['strencoding'] = 'Codage'; + $lang['strvalue'] = 'Valeur'; + $lang['strunique'] = 'Unique'; + $lang['strprimary'] = 'Primaire'; + $lang['strexport'] = 'Exporter'; + $lang['strimport'] = 'Importer'; + $lang['strallowednulls'] = 'Autoriser les caractères NULL'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Chaîne/champ vide'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analyze'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'En Cluster ?'; + $lang['strreindex'] = 'Reindex'; + $lang['strexecute'] = 'Lancer'; + $lang['stradd'] = 'Ajouter'; + $lang['strevent'] = 'Événement'; + $lang['strwhere'] = 'Où'; + $lang['strinstead'] = 'Faire à la place'; + $lang['strwhen'] = 'Quand'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Donnée'; + $lang['strconfirm'] = 'Confirmer'; + $lang['strexpression'] = 'Expression'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ' :'; + $lang['strexpand'] = 'Étendre'; + $lang['strcollapse'] = 'Réduire'; + $lang['strfind'] = 'Rechercher'; + $lang['stroptions'] = 'Options'; + $lang['strrefresh'] = 'Rafraichir'; + $lang['strdownload'] = 'Télécharger'; + $lang['strdownloadgzipped'] = 'Télécharger avec compression gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OID'; + $lang['stradvanced'] = 'Avancé'; + $lang['strvariables'] = 'Variables'; + $lang['strprocess'] = 'Processus'; + $lang['strprocesses'] = 'Processus'; + $lang['strsetting'] = 'Paramétrage'; + $lang['streditsql'] = 'Éditer SQL'; + $lang['strruntime'] = 'Temps d\'exécution total : %s ms'; + $lang['strpaginate'] = 'Paginer les résultats'; + $lang['struploadscript'] = 'ou importer un script SQL :'; + $lang['strstarttime'] = 'Heure de début'; + $lang['strfile'] = 'Fichier'; + $lang['strfileimported'] = 'Fichier importé.'; + $lang['strtrycred'] = 'Utilisez ces identifiants pour tous les serveurs'; + $lang['strconfdropcred'] = 'For security reason, disconnecting will destroy your shared login information. Are you sure you want to disconnect ?'; + $lang['strconfdropcred'] = 'Par mesure de sécurité, la déconnexion supprimera le partage de vos identifiants pour tous les serveurs. Êtes-vous certain de vouloir vous déconnecter ?'; + $lang['stractionsonmultiplelines'] = 'Actions sur plusieurs lignes'; + $lang['strselectall'] = 'Sélectionner tout'; + $lang['strunselectall'] = 'Desélectionner tout'; + $lang['strlocale'] = 'Locale'; + $lang['strcollation'] = 'Tri'; + $lang['strctype'] = 'Type de cartactère'; + $lang['strdefaultvalues'] = 'Valeurs par défaut'; + $lang['strnewvalues'] = 'Nouvelles valeurs'; + $lang['strstart'] = 'Démarrer'; + $lang['strstop'] = 'Arrêter'; + $lang['strgotoppage'] = 'Haut de la page'; + $lang['strtheme'] = 'Thème'; + + // Admin + $lang['stradminondatabase'] = 'Les actions d\'administration suivantes s\'appliquent à l\'ensemble de la base de donnée %s.'; + $lang['stradminontable'] = 'Les actions d\'administration suivantes s\'appliquent à la table %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'Historique'; + $lang['strnohistory'] = 'Pas d\'historique.'; + $lang['strclearhistory'] = 'Éffacer l\'historique'; + $lang['strdelhistory'] = 'Supprimer de l\'historique'; + $lang['strconfdelhistory'] = 'Voulez-vous vraiment supprimer cette requête de l\'historique ?'; + $lang['strconfclearhistory'] = 'Voulez-vous vraiment éffacer l\'historique ?'; + $lang['strnodatabaseselected'] = 'Veuillez sélectionner une base de données.'; + + // Database Sizes + $lang['strnoaccess'] = 'Pas d\'Accès'; + $lang['strsize'] = 'Taille'; + $lang['strbytes'] = 'octets'; + $lang['strkb'] = ' Ko'; + $lang['strmb'] = ' Mo'; + $lang['strgb'] = ' Go'; + $lang['strtb'] = ' To'; + + // Error handling + $lang['strnoframes'] = 'Cette application fonctionne mieux avec un navigateur pouvant afficher des frames mais peut être utilisée sans frames en suivant les liens ci-dessous.'; + $lang['strnoframeslink'] = 'Utiliser sans frames'; + $lang['strbadconfig'] = 'Le fichier de configuration config.inc.php est obsolète. Vous avez besoin de le regénérer à partir de config.inc.php-dist.'; + $lang['strnotloaded'] = 'Vous n\'avez pas compilé correctement le support de la base de données dans votre installation de PHP.'; + $lang['strpostgresqlversionnotsupported'] = 'Cette version de PostgreSQL n\'est pas supportée. Merci de mettre à jour PHP à la version %s ou ultérieure.'; + $lang['strbadschema'] = 'Schéma spécifié invalide.'; + $lang['strbadencoding'] = 'Impossible de spécifier l\'encodage de la base de données.'; + $lang['strsqlerror'] = 'Erreur SQL :'; + $lang['strinstatement'] = 'Dans l\'instruction :'; + $lang['strinvalidparam'] = 'Paramètres de script invalides.'; + $lang['strnodata'] = 'Pas de résultats.'; + $lang['strnoobjects'] = 'Aucun objet trouvé.'; + $lang['strrownotunique'] = 'Pas d\'identifiant unique pour cette ligne.'; + $lang['strnouploads'] = 'Importation de fichiers désactivée.'; + $lang['strimporterror'] = 'Erreur d\'importation.'; + $lang['strimporterror-fileformat'] = 'Erreur d\'importation : échec lors de la détermination automatique du format de fichier.'; + $lang['strimporterrorline'] = 'Erreur d\'importation à la ligne %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Erreur d\'importation sur la ligne %s : la ligne ne possède pas le bon nombre de colonnes.'; + $lang['strimporterror-uploadedfile'] = 'Erreur d\'importation : le fichier n\'a pas pû être récupéré sur le serveur.'; + $lang['strcannotdumponwindows'] = 'La sauvegarde de table complexe et des noms de schémas n\'est pas supporté sur Windows.'; + $lang['strinvalidserverparam'] = 'Tentative de connexion avec un serveur invalide, il est possible que quelqu\'un essai de pirater votre système.'; + $lang['strnoserversupplied'] = 'Aucun serveur fournis !'; + $lang['strbadpgdumppath'] = 'Erreur d\'export : n\'a pu exécuter pg_dump (chemin indiqué dans votre conf/config.inc.php : %s). Merci de corriger le chemin dans votre configuration et de vous reconnecter.'; + $lang['strbadpgdumpallpath'] = 'Erreur d\'export : n\'a pu exécuter pg_dumpall (chemin indiqué dans votre conf/config.inc.php : %s). Merci de corriger le chemin dans votre configuration et de vous reconnecter.'; + $lang['strconnectionfail'] = 'Connexion au serveur échouée.'; + + // Tables + $lang['strtable'] = 'Table'; + $lang['strtables'] = 'Tables'; + $lang['strshowalltables'] = 'Voir toutes les tables'; + $lang['strnotables'] = 'Aucune table trouvée.'; + $lang['strnotable'] = 'Aucune table trouvée.'; + $lang['strcreatetable'] = 'Créer une table'; + $lang['strcreatetablelike'] = 'Créer une table d\'après une table existante'; + $lang['strcreatetablelikeparent'] = 'Table modèle'; + $lang['strcreatelikewithdefaults'] = 'inclure les valeurs par défaut.'; + $lang['strcreatelikewithconstraints'] = 'inclure les contraintes.'; + $lang['strcreatelikewithindexes'] = 'inclure les indexes.'; + $lang['strtablename'] = 'Nom de la table'; + $lang['strtableneedsname'] = 'Vous devez donner un nom pour votre table.'; + $lang['strtablelikeneedslike'] = 'Vous devez préciser une table modèle.'; + $lang['strtableneedsfield'] = 'Vous devez spécifier au moins un champ.'; + $lang['strtableneedscols'] = 'Vous devez indiquer un nombre valide de colonnes.'; + $lang['strtablecreated'] = 'Table créée.'; + $lang['strtablecreatedbad'] = 'Échec de la création de table.'; + $lang['strconfdroptable'] = 'Êtes-vous sur de vouloir supprimer la table « %s » ?'; + $lang['strtabledropped'] = 'Table supprimée.'; + $lang['strtabledroppedbad'] = 'Échec lors de la suppression de table.'; + $lang['strconfemptytable'] = 'Êtes-vous sûr de vouloir vider la table « %s » ?'; + $lang['strtableemptied'] = 'Table vide.'; + $lang['strtableemptiedbad'] = 'Échec du vidage de la table.'; + $lang['strinsertrow'] = 'Insérer un enregistrement.'; + $lang['strrowinserted'] = 'Enregistrement inséré.'; + $lang['strrowinsertedbad'] = 'Échec lors de l\'insertion d\'un enregistrement.'; + $lang['strnofkref'] = 'Aucune valeur correspondate pour la clé étrangère %s.'; + $lang['strrowduplicate'] = 'Échec lors de l\'insertion d\'un enregistrement, a tenté de faire une insertion dupliquée.'; + $lang['streditrow'] = 'Éditer l\'enregistrement.'; + $lang['strrowupdated'] = 'Enregistrement mis à jour.'; + $lang['strrowupdatedbad'] = 'Échec de mise à jour de l\'enregistrement.'; + $lang['strdeleterow'] = 'Effacer l\'enregistrement'; + $lang['strconfdeleterow'] = 'Êtes-vous sûr de vouloir supprimer cet enregistrement ?'; + $lang['strrowdeleted'] = 'Enregistrement supprimé.'; + $lang['strrowdeletedbad'] = 'Échec lors de la suppression de l\'enregistrement.'; + $lang['strinsertandrepeat'] = 'Insérer et répéter'; + $lang['strnumcols'] = 'Nombre de colonnes'; + $lang['strcolneedsname'] = 'Vous devez spécifier un nom pour la colonne'; + $lang['strselectallfields'] = 'Sélectionner tous les champs'; + $lang['strselectneedscol'] = 'Vous devez sélectionner au moins une colonne.'; + $lang['strselectunary'] = 'Les opérateurs unaires ne peuvent avoir de valeurs.'; + $lang['strcolumnaltered'] = 'Colonne modifiée.'; + $lang['strcolumnalteredbad'] = 'Échec lors de la modification de la colonne.'; + $lang['strconfdropcolumn'] = 'Êtes-vous sûr de vouloir supprimer la colonne « %s » de la table « %s » ?'; + $lang['strcolumndropped'] = 'Colonne supprimée.'; + $lang['strcolumndroppedbad'] = 'Échec lors de la suppression de la colonne.'; + $lang['straddcolumn'] = 'Ajouter une colonne'; + $lang['strcolumnadded'] = 'Colonne ajoutée.'; + $lang['strcolumnaddedbad'] = 'Échec lors de l\'ajout de la colonne.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Table modifiée.'; + $lang['strtablealteredbad'] = 'Échec lors de la modification de la table.'; + $lang['strdataonly'] = 'Données seulement'; + $lang['strstructureonly'] = 'Structure seulement'; + $lang['strstructureanddata'] = 'Structure et données'; + $lang['strtabbed'] = 'Tabulé'; + $lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Êtes-vous sûr de vouloir faire un vacuum de « %s » ?'; + $lang['strconfanalyzetable'] = 'Êtes-vous sûr de vouloir éffectuer un ANALYZE sur « %s » ?'; + $lang['strconfreindextable'] = 'Êtes-vous sûr de vouloir réindexer « %s » ?'; + $lang['strconfclustertable'] = 'Êtes-vous sûr de vouloir lancer un CLUSTER sur «%s » ?'; + $lang['strestimatedrowcount'] = 'Nombre d\'enregistrements estimés'; + $lang['strspecifytabletoanalyze'] = 'Vous devez spécifier au moins une table à analyzer'; + $lang['strspecifytabletoempty'] = 'Vous devez spécifier au moins une table à vider'; + $lang['strspecifytabletodrop'] = 'Vous devez spécifier au moins une table à supprimer'; + $lang['strspecifytabletovacuum'] = 'Vous devez spécifier au moins une table sur laquelle éffectuer le vacuum'; + $lang['strspecifytabletoreindex'] = 'Vous devez spécifier au moins une table à réindexer.'; + $lang['strspecifytabletocluster'] = 'Vous devez spécifier au moins une table sur laquelle éffectuer la commande CLUSTER.'; + $lang['strnofieldsforinsert'] = 'Vous ne pouvez insérer de données dans une table sans champs.'; + + // Columns + $lang['strcolprop'] = 'Propriétés de la Colonne'; + $lang['strnotableprovided'] = 'Aucune table fournie !'; + + // Users + $lang['struser'] = 'Utilisateur'; + $lang['strusers'] = 'Utilisateurs'; + $lang['strusername'] = 'Utilisateur'; + $lang['strpassword'] = 'Mot de passe'; + $lang['strsuper'] = 'Super utilisateur ?'; + $lang['strcreatedb'] = 'Créer base de données ?'; + $lang['strexpires'] = 'Expiration'; + $lang['strsessiondefaults'] = 'Session par défaut'; + $lang['strnousers'] = 'Aucun utilisateur trouvé.'; + $lang['struserupdated'] = 'Utilisateur mis à jour.'; + $lang['struserupdatedbad'] = 'Échec lors de la mise à jour de l\'utilisateur.'; + $lang['strshowallusers'] = 'Voir tous les utilisateurs'; + $lang['strcreateuser'] = 'Créer un utilisateur'; + $lang['struserneedsname'] = 'Vous devez donner un nom pour votre utilisateur.'; + $lang['strusercreated'] = 'Utilisateur créé.'; + $lang['strusercreatedbad'] = 'Échec lors de la création de l\'utilisateur.'; + $lang['strconfdropuser'] = 'Êtes-vous sûr de vouloir supprimer l\'utilisateur « %s » ?'; + $lang['struserdropped'] = 'Utilisateur supprimé.'; + $lang['struserdroppedbad'] = 'Échec lors de la suppression de l\'utilisateur.'; + $lang['straccount'] = 'Comptes'; + $lang['strchangepassword'] = 'Modifier le mot de passe'; + $lang['strpasswordchanged'] = 'Mot de passe modifié.'; + $lang['strpasswordchangedbad'] = 'Échec lors de la modification du mot de passe.'; + $lang['strpasswordshort'] = 'Le mot de passe est trop court.'; + $lang['strpasswordconfirm'] = 'Le mot de passe de confirmation est différent.'; + + // Groups + $lang['strgroup'] = 'Groupe'; + $lang['strgroups'] = 'Groupes'; + $lang['strgroupgroups'] = 'Groupes du groupe "%s"'; + $lang['strshowallgroups'] = 'Afficher tous les groupes'; + $lang['strnogroup'] = 'Groupe introuvable.'; + $lang['strnogroups'] = 'Aucun groupe trouvé.'; + $lang['strcreategroup'] = 'Créer un groupe'; + $lang['strgroupneedsname'] = 'Vous devez indiquer un nom pour votre groupe.'; + $lang['strgroupcreated'] = 'Groupe créé.'; + $lang['strgroupcreatedbad'] = 'Échec lors de la création du groupe.'; + $lang['strconfdropgroup'] = 'Êtes-vous sûr de vouloir supprimer le groupe « %s » ?'; + $lang['strgroupdropped'] = 'Groupe supprimé.'; + $lang['strgroupdroppedbad'] = 'Échec lors de la suppression du groupe.'; + $lang['strmembers'] = 'Membres'; + $lang['strmemberof'] = 'Membre de'; + $lang['stradminmembers'] = 'Membres admin'; + $lang['straddmember'] = 'Ajouter un membre'; + $lang['strmemberadded'] = 'Membre ajouté.'; + $lang['strmemberaddedbad'] = 'Échec lors de l\'ajout du membre.'; + $lang['strdropmember'] = 'Supprimer un membre'; + $lang['strconfdropmember'] = 'Êtes-vous sûr de vouloir supprimer le membre « %s » du groupe « %s » ?'; + $lang['strmemberdropped'] = 'Membre supprimé.'; + $lang['strmemberdroppedbad'] = 'Échec lors de la suppression du membre.'; + + // Roles + $lang['strrole'] = 'Rôle'; + $lang['strroles'] = 'Rôles'; + $lang['strshowallroles'] = 'Afficher tous les rôles'; + $lang['strnoroles'] = 'Aucun rôle trouvé.'; + $lang['strinheritsprivs'] = 'Hérite des droits ?'; + $lang['strcreaterole'] = 'Créer un rôle'; + $lang['strcancreaterole'] = 'Peut créer un rôle ?'; + $lang['strrolecreated'] = 'Rôle créé.'; + $lang['strrolecreatedbad'] = 'Échec lors de la création du rôle.'; + $lang['strrolealtered'] = 'Rôle modifié.'; + $lang['strrolealteredbad'] = 'Échec lors de la modification du rôle.'; + $lang['strcanlogin'] = 'Peut se connecter ?'; + $lang['strconnlimit'] = 'Limite de connexion'; + $lang['strdroprole'] = 'Supprimer un rôle'; + $lang['strconfdroprole'] = 'Êtes-vous sûr de vouloir supprimer le rôle « %s » ?'; + $lang['strroledropped'] = 'Rôle supprimé.'; + $lang['strroledroppedbad'] = 'Échec lors de la suppression du rôle.'; + $lang['strnolimit'] = 'Aucune limite'; + $lang['strnever'] = 'Jamais'; + $lang['strroleneedsname'] = 'Vous devez donner un nom à ce rôle.'; + + // Privileges + $lang['strprivilege'] = 'Droit'; + $lang['strprivileges'] = 'Droits'; + $lang['strnoprivileges'] = 'Cet objet possède les droits par défault.'; + $lang['strgrant'] = 'Accorder (GRANT)'; + $lang['strrevoke'] = 'Révoquer (REVOKE)'; + $lang['strgranted'] = 'Droits accordés.'; + $lang['strgrantfailed'] = 'Échec lors de l\'octroi des droits.'; + $lang['strgrantbad'] = 'Vous devez spécifier au moins un utilisateur ou groupe et au moins un droit.'; + $lang['strgrantor'] = 'Grantor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Base de données'; + $lang['strdatabases'] = 'Bases de données'; + $lang['strshowalldatabases'] = 'Voir toutes les bases de données'; + $lang['strnodatabases'] = 'Aucune base de données trouvée.'; + $lang['strcreatedatabase'] = 'Créer une base de données'; + $lang['strdatabasename'] = 'Nom de la base de données'; + $lang['strdatabaseneedsname'] = 'Vous devez donner un nom pour votre base de données.'; + $lang['strdatabasecreated'] = 'Base de données créée.'; + $lang['strdatabasecreatedbad'] = 'Échec lors de la création de la base de données.'; + $lang['strconfdropdatabase'] = 'Êtes-vous sûr de vouloir supprimer la base de données « %s » ?'; + $lang['strdatabasedropped'] = 'Base de données supprimée.'; + $lang['strdatabasedroppedbad'] = 'Échec lors de la suppression de la base de données.'; + $lang['strentersql'] = 'Veuillez saisir ci-dessous la requête SQL à exécuter :'; + $lang['strsqlexecuted'] = 'Requête SQL exécutée.'; + $lang['strvacuumgood'] = 'Vacuum exécuté.'; + $lang['strvacuumbad'] = 'Échec du Vacuum.'; + $lang['stranalyzegood'] = 'Analyse effectuée.'; + $lang['stranalyzebad'] = 'Échec de l\'analyse.'; + $lang['strreindexgood'] = 'Réindexation exécutée.'; + $lang['strreindexbad'] = 'Échec de la réindexation.'; + $lang['strfull'] = 'Intégral (FULL)'; + $lang['strfreeze'] = 'Freeze'; + $lang['strforce'] = 'Forcer'; + $lang['strsignalsent'] = 'Signal envoyé.'; + $lang['strsignalsentbad'] = 'Échec lors de l\'envoi du signal.'; + $lang['strallobjects'] = 'Tous les objets'; + $lang['strdatabasealtered'] = 'Base de données modifiée.'; + $lang['strdatabasealteredbad'] = 'Échec lors de la modification de la base de données.'; + $lang['strspecifydatabasetodrop'] = 'Vous devez spécifier au moins une base de données à supprimer'; + $lang['strtemplatedb'] = 'Modèle'; + $lang['strconfanalyzedatabase'] = 'Êtes vous sûr de vouloir éffectuer un ANALYZE sur toutes les tables de la base de données « %s » ?'; + $lang['strconfvacuumdatabase'] = 'Êtes vous sûr de vouloir éffectuer un VACUUM sur toutes les tables de la base de données « %s » ?'; + $lang['strconfreindexdatabase'] = 'Êtes vous sûr de vouloir réindexer toutes les tables de la base de données « %s » ?'; + $lang['strconfclusterdatabase'] = 'Êtes vous sûr de vouloir éffectuer un CLUSTER sur toutes les tables de la base de données « %s » ?'; + + // Views + $lang['strview'] = 'Vue'; + $lang['strviews'] = 'Vues'; + $lang['strshowallviews'] = 'Voir toutes les vues'; + $lang['strnoview'] = 'Aucne vue trouvée.'; + $lang['strnoviews'] = 'Aucune vue trouvée.'; + $lang['strcreateview'] = 'Créer une vue'; + $lang['strviewname'] = 'Nom de la vue'; + $lang['strviewneedsname'] = 'Vous devez indiquer un nom pour votre vue.'; + $lang['strviewneedsdef'] = 'Vous devez indiquer une définition pour votre vue.'; + $lang['strviewneedsfields'] = 'Vous devez préciser les colonnes que vous voulez sélectionner dans votre vue.'; + $lang['strviewcreated'] = 'Vue créée.'; + $lang['strviewcreatedbad'] = 'Échec lors de la création de la vue.'; + $lang['strconfdropview'] = 'Êtes-vous sûr de vouloir supprimer la vue « %s » ?'; + $lang['strviewdropped'] = 'Vue supprimée.'; + $lang['strviewdroppedbad'] = 'Échec lors de la suppression de la vue.'; + $lang['strviewupdated'] = 'Vue mise à jour.'; + $lang['strviewupdatedbad'] = 'Échec lors de la mise à jour de la vue.'; + $lang['strviewlink'] = 'Clés liées'; + $lang['strviewconditions'] = 'Conditions supplémentaires'; + $lang['strcreateviewwiz'] = 'Créer une vue avec l\'assistant'; + $lang['strrenamedupfields'] = 'Renommer les champs dupliqués'; + $lang['strdropdupfields'] = 'Ignorer les champs dupliqués'; + $lang['strerrordupfields'] = 'Erreur en cas de champs dupliqués'; + $lang['strviewaltered'] = 'Vue modifiée.'; + $lang['strviewalteredbad'] = 'Échec lors de la modification de la vue.'; + $lang['strspecifyviewtodrop'] = 'Vous devez spécifier au moins une vue à supprimer.'; + + // Sequences + $lang['strsequence'] = 'Séquence'; + $lang['strsequences'] = 'Séquences'; + $lang['strshowallsequences'] = 'Voir toutes les séquences'; + $lang['strnosequence'] = 'Aucune séquence trouvée.'; + $lang['strnosequences'] = 'Aucune séquence trouvée.'; + $lang['strcreatesequence'] = 'Créer une séquence'; + $lang['strlastvalue'] = 'Dernière valeur'; + $lang['strincrementby'] = 'Incrémenter par '; + $lang['strstartvalue'] = 'Valeur de départ'; + $lang['strrestartvalue'] = 'Valeur de redémarrage'; + $lang['strmaxvalue'] = 'Valeur maximale'; + $lang['strminvalue'] = 'Valeur minimale'; + $lang['strcachevalue'] = 'Valeur de cache'; + $lang['strlogcount'] = 'Comptage'; + $lang['strcancycle'] = 'Peut boucler?'; + $lang['striscalled'] = 'Incrémentera la dernière valeur avant de retourner la prochaine valeur (is_called) ?'; + $lang['strsequenceneedsname'] = 'Vous devez spécifier un nom pour votre séquence.'; + $lang['strsequencecreated'] = 'Séquence créée.'; + $lang['strsequencecreatedbad'] = 'Échec lors de la création de la séquence.'; + $lang['strconfdropsequence'] = 'Êtes-vous sûr de vouloir supprimer la séquence « %s » ?'; + $lang['strsequencedropped'] = 'Séquence supprimée.'; + $lang['strsequencedroppedbad'] = 'Échec lors de la suppression de la séquence.'; + $lang['strsequencerestart'] = 'Séquence redémarrée.'; + $lang['strsequencerestartbad'] = 'Échec tu redémarrage de la séquence.'; + $lang['strsequencereset'] = 'Séquence initialisée.'; + $lang['strsequenceresetbad'] = 'Échec lors de l\'initialisation de la séquence.'; + $lang['strsequencealtered'] = 'Séquence modifiée.'; + $lang['strsequencealteredbad'] = 'Échec lors de la modification de la séquence.'; + $lang['strsetval'] = 'Initialiser à une valeur'; + $lang['strsequencesetval'] = 'Séquence initialisée.'; + $lang['strsequencesetvalbad'] = 'Échec lors de l\'initialisation de la séquence.'; + $lang['strnextval'] = 'Incrémenter la valeur'; + $lang['strsequencenextval'] = 'Séquence incrémentée.'; + $lang['strsequencenextvalbad'] = 'Échec lors de l\'incrémentation de la valeur.'; + $lang['strspecifysequencetodrop'] = 'Vous devez spécifier au moins une séquence à supprimer.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Index'; + $lang['strindexname'] = 'Nom de l\'index'; + $lang['strshowallindexes'] = 'Voir tous les index'; + $lang['strnoindex'] = 'Aucun index trouvé.'; + $lang['strnoindexes'] = 'Aucun index trouvé.'; + $lang['strcreateindex'] = 'Créer un index'; + $lang['strtabname'] = 'Nom de la table'; + $lang['strcolumnname'] = 'Nom de la colonne'; + $lang['strindexneedsname'] = 'Vous devez indiquer un nom pour votre index'; + $lang['strindexneedscols'] = 'Vous devez indiquer un nombre valide de colonnes.'; + $lang['strindexcreated'] = 'Index créé'; + $lang['strindexcreatedbad'] = 'Échec lors de la création de l\'index.'; + $lang['strconfdropindex'] = 'Êtes-vous sûr de vouloir supprimer l\'index « %s » ?'; + $lang['strindexdropped'] = 'Index supprimé.'; + $lang['strindexdroppedbad'] = 'Échec lors de la suppression de l\'index.'; + $lang['strkeyname'] = 'Nom de la clé'; + $lang['struniquekey'] = 'Clé unique'; + $lang['strprimarykey'] = 'Clé primaire'; + $lang['strindextype'] = 'Type d\'index'; + $lang['strtablecolumnlist'] = 'Liste des colonnes'; + $lang['strindexcolumnlist'] = 'Liste des colonnes dans l\'index'; + $lang['strclusteredgood'] = 'Cluster effectué.'; + $lang['strclusteredbad'] = 'Échec du cluster.'; + $lang['strconcurrently'] = 'En parallèle'; + $lang['strnoclusteravailable'] = 'La table n\'est pas encore ordonnée selon un index.'; + $lang['strcluster'] = 'Cluster'; + + // Rules + $lang['strrules'] = 'Règles'; + $lang['strrule'] = 'Règle'; + $lang['strshowallrules'] = 'Voir toutes les règles'; + $lang['strnorule'] = 'Aucune règle trouvée.'; + $lang['strnorules'] = 'Aucune règle trouvée.'; + $lang['strcreaterule'] = 'Créer une règle'; + $lang['strrulename'] = 'Nom de la règle'; + $lang['strruleneedsname'] = 'Vous devez indiquer un nom pour votre règle.'; + $lang['strrulecreated'] = 'Règle créée.'; + $lang['strrulecreatedbad'] = 'Échec lors de la création de la règle.'; + $lang['strconfdroprule'] = 'Êtes-vous sûr de vouloir supprimer la règle « %s » sur « %s » ?'; + $lang['strruledropped'] = 'Règle supprimée.'; + $lang['strruledroppedbad'] = 'Échec lors de la suppression de la règle.'; + + // Constraints + $lang['strconstraint'] = 'Contrainte'; + $lang['strconstraints'] = 'Contraintes'; + $lang['strshowallconstraints'] = 'Voir toutes les contraintes'; + $lang['strnoconstraints'] = 'Aucune contrainte trouvée.'; + $lang['strcreateconstraint'] = 'Créer une contrainte'; + $lang['strconstraintcreated'] = 'Création d\'une contrainte.'; + $lang['strconstraintcreatedbad'] = 'Échec lors de la création de la contrainte.'; + $lang['strconfdropconstraint'] = 'Êtes-vous sûr de vouloir supprimer la contrainte « %s » sur « %s » ?'; + $lang['strconstraintdropped'] = 'Contrainte supprimée.'; + $lang['strconstraintdroppedbad'] = 'Échec lors de la suppression de la contrainte.'; + $lang['straddcheck'] = 'Ajouter une contrainte'; + $lang['strcheckneedsdefinition'] = 'La contrainte a besoin d\'une définition.'; + $lang['strcheckadded'] = 'Contrainte ajoutée.'; + $lang['strcheckaddedbad'] = 'Échec lors de l\'ajout d\'une contrainte de vérification (CHECK).'; + $lang['straddpk'] = 'Ajouter une clé primaire'; + $lang['strpkneedscols'] = 'La clé primaire nécessite au moins une colonne.'; + $lang['strpkadded'] = 'Clé primaire ajoutée.'; + $lang['strpkaddedbad'] = 'Échec lors de l\'ajout de la clé primaire.'; + $lang['stradduniq'] = 'Ajouter une clé unique'; + $lang['struniqneedscols'] = 'Une clé unique nécessite au moins une colonne.'; + $lang['struniqadded'] = 'La clé unique a été ajoutée.'; + $lang['struniqaddedbad'] = 'Échec lors de la création de la clé unique.'; + $lang['straddfk'] = 'Ajouter une clé étrangère'; + $lang['strfkneedscols'] = 'Une clé étrangère nécessite au moins une colonne.'; + $lang['strfkneedstarget'] = 'Une clé étrangère nécessite une table cible.'; + $lang['strfkadded'] = 'La clé étrangère a été ajoutée.'; + $lang['strfkaddedbad'] = 'Échec lors de la création de la clé étrangère.'; + $lang['strfktarget'] = 'Table cible'; + $lang['strfkcolumnlist'] = 'Liste des colonnes de la clé'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Fonction'; + $lang['strfunctions'] = 'Fonctions'; + $lang['strshowallfunctions'] = 'Voir toutes les fonctions'; + $lang['strnofunction'] = 'Aucune fonction trouvée.'; + $lang['strnofunctions'] = 'Aucune fonction trouvée.'; + $lang['strcreateplfunction'] = 'Créer une fonction PL/SQL'; + $lang['strcreateinternalfunction'] = 'Créer une fonction interne'; + $lang['strcreatecfunction'] = 'Créer une fonction C'; + $lang['strfunctionname'] = 'Nom de la fonction'; + $lang['strreturns'] = 'Valeur de sortie'; + $lang['strproglanguage'] = 'Langage'; + $lang['strfunctionneedsname'] = 'Vous devez indiquer un nom pour votre fonction.'; + $lang['strfunctionneedsdef'] = 'Vous devez indiquer une définition pour votre fonction.'; + $lang['strfunctioncreated'] = 'Fonction créée.'; + $lang['strfunctioncreatedbad'] = 'Échec lors de la création de la fonction.'; + $lang['strconfdropfunction'] = 'Êtes-vous sûr de vouloir supprimer la fonction « %s » ?'; + $lang['strfunctiondropped'] = 'Fonction supprimée.'; + $lang['strfunctiondroppedbad'] = 'Échec lors de la suppression de la fonction.'; + $lang['strfunctionupdated'] = 'Fonction mise à jour.'; + $lang['strfunctionupdatedbad'] = 'Échec lors de la mise à jour de la fonction.'; + $lang['strobjectfile'] = 'Fichier objet'; + $lang['strlinksymbol'] = 'Symbole lien'; + $lang['strarguments'] = 'Arguments'; + $lang['strargmode'] = 'Mode'; + $lang['strargtype'] = 'Type'; + $lang['strargadd'] = 'Ajouter un autre argument'; + $lang['strargremove'] = 'Supprimer cet argument'; + $lang['strargnoargs'] = 'Cet fonction ne prend pas d\'arguments.'; + $lang['strargenableargs'] = 'Active les arguments passés à cette fonction.'; + $lang['strargnorowabove'] = 'Il doit y avoir une ligne au-dessus de cette ligne.'; + $lang['strargnorowbelow'] = 'Il doit y avoir une ligne en-dessous de cette ligne.'; + $lang['strargraise'] = 'Monter.'; + $lang['strarglower'] = 'Descendre.'; + $lang['strargremoveconfirm'] = 'Êtes-vous sûr de vouloir supprimer cet argument ? cette opération ne peut pas être annulée.'; + $lang['strfunctioncosting'] = 'Coût de la function'; + $lang['strresultrows'] = 'Lignes de résultat'; + $lang['strexecutioncost'] = 'Coût d\'exécution'; + $lang['strspecifyfunctiontodrop'] = 'Vous devez spécifier au moins une fonction à supprimer.'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Triggers'; + $lang['strshowalltriggers'] = 'Voir tous les triggers'; + $lang['strnotrigger'] = 'Aucun trigger trouvé.'; + $lang['strnotriggers'] = 'Aucun trigger trouvé.'; + $lang['strcreatetrigger'] = 'Créer un trigger'; + $lang['strtriggerneedsname'] = 'Vous devez indiquer un nom pour votre trigger.'; + $lang['strtriggerneedsfunc'] = 'Vous devez indiquer une fonction pour votre trigger.'; + $lang['strtriggercreated'] = 'Trigger créé.'; + $lang['strtriggercreatedbad'] = 'Échec lors de la création du trigger.'; + $lang['strconfdroptrigger'] = 'Êtes-vous sûr de vouloir supprimer le trigger « %s » sur « %s » ?'; + $lang['strconfenabletrigger'] = 'Êtes-vous sûr de vouloir activer le trigger « %s » sur « %s» ?'; + $lang['strconfdisabletrigger'] = 'Êtes-vous sûr de vouloir désactiver le trigger « %s » sur « %s» ?'; + $lang['strtriggerdropped'] = 'Trigger supprimé.'; + $lang['strtriggerdroppedbad'] = 'Échec lors de la suppression du trigger.'; + $lang['strtriggerenabled'] = 'Trigger activé.'; + $lang['strtriggerenabledbad'] = 'Échec lors de l\'activation du trigger.'; + $lang['strtriggerdisabled'] = 'Trigger désactivé.'; + $lang['strtriggerdisabledbad'] = 'Échec lors de la désactivation du trigger.'; + $lang['strtriggeraltered'] = 'Trigger modifié.'; + $lang['strtriggeralteredbad'] = 'Échec lors de la modification du trigger.'; + $lang['strforeach'] = 'Pour chaque'; + + // Types + $lang['strtype'] = 'Type'; + $lang['strtypes'] = 'Types'; + $lang['strshowalltypes'] = 'Voir tous les types'; + $lang['strnotype'] = 'Aucun type trouvé.'; + $lang['strnotypes'] = 'Aucun type trouvé.'; + $lang['strcreatetype'] = 'Créer un type'; + $lang['strcreatecomptype'] = 'Créer un type composé'; + $lang['strcreateenumtype'] = 'Créer un type enum'; + $lang['strtypeneedsfield'] = 'Vous devez spécifier au moins un champ.'; + $lang['strtypeneedsvalue'] = 'Vous devez spécifier au moins une valeur.'; + $lang['strtypeneedscols'] = 'Vous devez spécifier un nombre valide de champs.'; + $lang['strtypeneedsvals'] = 'Vous devez spécifier un nombre valide de valeurs.'; + $lang['strinputfn'] = 'Fonction d\'entrée'; + $lang['stroutputfn'] = 'Fonction de sortie'; + $lang['strpassbyval'] = 'Passée par valeur ?'; + $lang['stralignment'] = 'Alignement'; + $lang['strelement'] = 'Élément'; + $lang['strdelimiter'] = 'Délimiteur'; + $lang['strstorage'] = 'Stockage'; + $lang['strfield'] = 'Champ'; + $lang['strnumfields'] = 'Nombre de champs'; + $lang['strnumvalues'] = 'Nombre de valeurs'; + $lang['strtypeneedsname'] = 'Vous devez indiquer un nom pour votre type.'; + $lang['strtypeneedslen'] = 'Vous devez indiquer une longueur pour votre type.'; + $lang['strtypecreated'] = 'Type créé'; + $lang['strtypecreatedbad'] = 'Échec lors de la création du type.'; + $lang['strconfdroptype'] = 'Êtes-vous sûr de vouloir supprimer le type « %s » ?'; + $lang['strtypedropped'] = 'Type supprimé.'; + $lang['strtypedroppedbad'] = 'Échec lors de la suppression du type.'; + $lang['strflavor'] = 'Genre'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Composite'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'Enum'; + $lang['strenumvalues'] = 'Valeurs de l\'enum'; + + // Schemas + $lang['strschema'] = 'Schéma'; + $lang['strschemas'] = 'Schémas'; + $lang['strshowallschemas'] = 'Voir tous les schémas'; + $lang['strnoschema'] = 'Aucun schéma trouvé.'; + $lang['strnoschemas'] = 'Aucun schéma trouvé.'; + $lang['strcreateschema'] = 'Créer un schéma'; + $lang['strschemaname'] = 'Nom du schéma'; + $lang['strschemaneedsname'] = 'Vous devez indiquer un nom pour votre schéma.'; + $lang['strschemacreated'] = 'Schéma créé'; + $lang['strschemacreatedbad'] = 'Échec lors de la création du schéma.'; + $lang['strconfdropschema'] = 'Êtes-vous sûr de vouloir supprimer le schéma « %s » ?'; + $lang['strschemadropped'] = 'Schéma supprimé.'; + $lang['strschemadroppedbad'] = 'Échec lors de la suppression du schéma.'; + $lang['strschemaaltered'] = 'Schema modifié.'; + $lang['strschemaalteredbad'] = 'Échec lors de la modification du schéma.'; + $lang['strsearchpath'] = 'Chemin de recherche du schéma'; + $lang['strspecifyschematodrop'] = 'Vous devez spécifier au moins un schéma à supprimer.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domaine'; + $lang['strdomains'] = 'Domaines'; + $lang['strshowalldomains'] = 'Voir tous les domaines'; + $lang['strnodomains'] = 'Pas de domaine trouvé.'; + $lang['strcreatedomain'] = 'Créer un domaine'; + $lang['strdomaindropped'] = 'Domaine supprimé.'; + $lang['strdomaindroppedbad'] = 'Échec lors de la suppression.'; + $lang['strconfdropdomain'] = 'Êtes-vous sur de vouloir supprimer le domaine « %s » ?'; + $lang['strdomainneedsname'] = 'Vous devez donner un nom pour votre domaine.'; + $lang['strdomaincreated'] = 'Domaine créé.'; + $lang['strdomaincreatedbad'] = 'Échec lors de la création du domaine.'; + $lang['strdomainaltered'] = 'Domaine modifié.'; + $lang['strdomainalteredbad'] = 'Échec lors de la modification du domaine.'; + + // Operators + $lang['stroperator'] = 'Opérateur'; + $lang['stroperators'] = 'Opérateurs'; + $lang['strshowalloperators'] = 'Voir tous les opérateurs'; + $lang['strnooperator'] = 'Pas d\'opérateur trouvé.'; + $lang['strnooperators'] = 'Pas d\'opérateur trouvé.'; + $lang['strcreateoperator'] = 'Créer un opérateur'; + $lang['strleftarg'] = 'Type de l\'argument de gauche'; + $lang['strrightarg'] = 'Type de l\'argument de droite'; + $lang['strcommutator'] = 'Commutateur'; + $lang['strnegator'] = 'Négation'; + $lang['strrestrict'] = 'Restriction'; + $lang['strjoin'] = 'Jointure'; + $lang['strhashes'] = 'Hachages'; + $lang['strmerges'] = 'Assemblages'; + $lang['strleftsort'] = 'Tri gauche'; + $lang['strrightsort'] = 'Tri droite'; + $lang['strlessthan'] = 'Plus petit que'; + $lang['strgreaterthan'] = 'Plus grand que'; + $lang['stroperatorneedsname'] = 'Vous devez donner un nom pour votre opérateur.'; + $lang['stroperatorcreated'] = 'Opérateur créé'; + $lang['stroperatorcreatedbad'] = 'Échec lors de la création de l\'opérateur.'; + $lang['strconfdropoperator'] = 'Êtes-vous sur de vouloir supprimer l\'opérateur « %s » ?'; + $lang['stroperatordropped'] = 'Opérateur supprimé.'; + $lang['stroperatordroppedbad'] = 'Échec lors de la suppression de l\'opérateur.'; + + // Casts + $lang['strcasts'] = 'Conversions'; + $lang['strnocasts'] = 'Aucune conversion trouvée.'; + $lang['strsourcetype'] = 'Type source'; + $lang['strtargettype'] = 'Type cible'; + $lang['strimplicit'] = 'Implicite'; + $lang['strinassignment'] = 'En affectation'; + $lang['strbinarycompat'] = '(binaire compatible)'; + + // Conversions + $lang['strconversions'] = 'Conversions'; + $lang['strnoconversions'] = 'Aucune conversion trouvée.'; + $lang['strsourceencoding'] = 'Codage source'; + $lang['strtargetencoding'] = 'Codage cible'; + + // Languages + $lang['strlanguages'] = 'Langages'; + $lang['strnolanguages'] = 'Pas de langage trouvé.'; + $lang['strtrusted'] = 'De confiance'; + + // Info + $lang['strnoinfo'] = 'Pas d\'information disponible.'; + $lang['strreferringtables'] = 'Tables référentes'; + $lang['strparenttables'] = 'Tables parents'; + $lang['strchildtables'] = 'Tables enfants'; + + // Aggregates + $lang['straggregate'] = 'Agrégat'; + $lang['straggregates'] = 'Agrégats'; + $lang['strnoaggregates'] = 'Aucun agrégat trouvé.'; + $lang['stralltypes'] = '(tous les types)'; + $lang['strcreateaggregate'] = 'Créer un agrégat'; + $lang['straggrbasetype'] = 'Type de données en entrée'; + $lang['straggrsfunc'] = 'Fonction de transition de l\'état'; + $lang['straggrstype'] = 'Type de la valeur de transition'; + $lang['straggrffunc'] = 'Fonction finale'; + $lang['straggrinitcond'] = 'Condition initiale'; + $lang['straggrsortop'] = 'Opérateur de tri'; + $lang['strconfdropaggregate'] = 'Êtes-vous sûr de vouloir supprimer l\'agrégat « %s »?'; + $lang['straggregatedropped'] = 'Agrégat supprimé.'; + $lang['straggregatedroppedbad'] = 'Échec lors de la suppression de l\'agrégat.'; + $lang['straggraltered'] = 'Agrégat modifié.'; + $lang['straggralteredbad'] = 'Échec lors de la modification de l\'agrégat.'; + $lang['straggrneedsname'] = 'Vous devez indiquer un nom pour l\'agrégat'; + $lang['straggrneedsbasetype'] = 'Vous devez indiquer le type de données en entrée pour l\'agrégat'; + $lang['straggrneedssfunc'] = 'Vous devez indiquer le nom de la fonction de transition de l\'agrégat'; + $lang['straggrneedsstype'] = 'Vous devez indiquer le type de donnée pour la valeur d\'état pour l\'agrégat'; + $lang['straggrcreated'] = 'Agrégat créé.'; + $lang['straggrcreatedbad'] = 'Échec lors de la création de l\'agrégat.'; + $lang['straggrshowall'] = 'Afficher tous les agrégats'; + + // Operator Classes + $lang['stropclasses'] = 'Classes d\'opérateur'; + $lang['strnoopclasses'] = 'Aucune classe d\'opérateur trouvée.'; + $lang['straccessmethod'] = 'Méthode d\'accès'; + + // Stats and performance + $lang['strrowperf'] = 'Performance des enregistrements'; + $lang['strioperf'] = 'Performance en entrée/sortie'; + $lang['stridxrowperf'] = 'Performance des index'; + $lang['stridxioperf'] = 'Performance des index en entrées/sortie'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Séquentiel'; + $lang['strscan'] = 'Parcours'; + $lang['strread'] = 'Lecture'; + $lang['strfetch'] = 'Récupération'; + $lang['strheap'] = 'En-tête'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'Index TOAST'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disque'; + $lang['strrows2'] = 'Enregistrements'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaces'; + $lang['strshowalltablespaces'] = 'Voir tous les tablespaces'; + $lang['strnotablespaces'] = 'Aucun tablespace trouvé.'; + $lang['strcreatetablespace'] = 'Créer un tablespace'; + $lang['strlocation'] = 'Emplacement'; + $lang['strtablespaceneedsname'] = 'Vous devez donner un nom à votre tablespace.'; + $lang['strtablespaceneedsloc'] = 'Vous devez préciser un répertoire dans lequel sera créé le tablespace.'; + $lang['strtablespacecreated'] = 'Tablespace créé.'; + $lang['strtablespacecreatedbad'] = 'Échec lors de la création du tablespace.'; + $lang['strconfdroptablespace'] = 'Êtes-vous sûr de vouloir supprimer le tablespace « %s » ?'; + $lang['strtablespacedropped'] = 'Tablespace supprimé.'; + $lang['strtablespacedroppedbad'] = 'Échec lors de la suppression du tablespace.'; + $lang['strtablespacealtered'] = 'Tablespace modifié.'; + $lang['strtablespacealteredbad'] = 'Échec lors de la modification du tablespace.'; + + // Miscellaneous + $lang['strtopbar'] = '%s lancé sur %s:%s -- Vous êtes connecté avec le profil « %s »'; + $lang['strtimefmt'] = 'j M Y, H:i'; + $lang['strhelp'] = 'Aide'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Navigateur pour l\'aide'; + $lang['strselecthelppage'] = 'Sélectionner une page d\'aide'; + $lang['strinvalidhelppage'] = 'Page d\'aide invalide.'; + $lang['strlogintitle'] = 'Se connecter à %s'; + $lang['strlogoutmsg'] = 'Déconnecté de %s'; + $lang['strloading'] = 'Chargement...'; + $lang['strerrorloading'] = 'Erreur lors du chargement'; + $lang['strclicktoreload'] = 'Cliquer pour recharger'; + + //Autovacuum + $lang['strautovacuum'] = 'Autovacuum'; + $lang['strturnedon'] = 'Activé'; + $lang['strturnedoff'] = 'Désactivé'; + $lang['strenabled'] = 'activé'; + $lang['strnovacuumconf'] = 'Aucune configuration autovacuum trouvée.'; + $lang['strvacuumbasethreshold'] = 'Limite de base pour le Vacuum'; + $lang['strvacuumscalefactor'] = 'Facteur d\'échelle pour le Vacuum'; + $lang['stranalybasethreshold'] = 'Limite de base pour le Analyze'; + $lang['stranalyzescalefactor'] = 'Facteur d\'échelle pour le Analyze'; + $lang['strvacuumcostdelay'] = 'Délai du coût du Vacuum'; + $lang['strvacuumcostlimit'] = 'Limite du coût du Vacuum'; + $lang['strvacuumpertable'] = 'Configuration autovacuum par table'; + $lang['straddvacuumtable'] = 'Configurer autovacuum pour cette table'; + $lang['streditvacuumtable'] = 'Modifier la configuration autovacuum pour la table « %s »'; + $lang['strdelvacuumtable'] = 'Supprimer la configuration autovacuum pour la table « %s » ?'; + $lang['strvacuumtablereset'] = 'Configuration autovacuum par défaut pour la table « %s ».'; + $lang['strdelvacuumtablefail'] = 'Échec lors de la suppression de la configuration autovacuumpour la table « %s »'; + $lang['strsetvacuumtablesaved'] = 'Configuration autovacuum pour la table « %s » enregistrée.'; + $lang['strsetvacuumtablefail'] = 'Échec de la configuration autovacuum pour la table « %s ».'; + $lang['strspecifydelvacuumtable'] = 'Vous devez spécifier la table où supprimer les paramètres autovacuum.'; + $lang['strspecifyeditvacuumtable'] = 'Vous devez spécifier la table où éditer les paramètres autovacuum.'; + $lang['strnotdefaultinred'] = 'Valeurs différentes de celles par défaut en rouge.'; + + //Table-level Locks + $lang['strlocks'] = 'Verrous'; + $lang['strtransaction'] = 'ID de transaction'; + $lang['strvirtualtransaction'] = 'ID Virtuel de Transaction'; + $lang['strprocessid'] = 'ID du processus'; + $lang['strmode'] = 'Mode du verrou'; + $lang['strislockheld'] = 'Verrou détenu ?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Transactions préparées'; + $lang['strxactid'] = 'ID de transaction'; + $lang['strgid'] = 'ID global'; + + // Fulltext search + $lang['strfulltext'] = 'Recherche textuelle'; + $lang['strftsconfig'] = 'Configuration FTS'; + $lang['strftsconfigs'] = 'Configurations'; + $lang['strftscreateconfig'] = 'Créer une configuration FTS'; + $lang['strftscreatedict'] = 'Créer un dictionnaire'; + $lang['strftscreatedicttemplate'] = 'Créer un modèle de dictionnaire'; + $lang['strftscreateparser'] = 'Créer un analyseur syntaxique'; + $lang['strftsnoconfigs'] = 'Aucune configuration FTS trouvée.'; + $lang['strftsconfigdropped'] = 'Configuration FTS supprimée.'; + $lang['strftsconfigdroppedbad'] = 'Échec lors de la suppression de la configuration FTS.'; + $lang['strconfdropftsconfig'] = 'Êtes-vous sûr de vouloir supprimer la configuration FTS « %s » ?'; + $lang['strconfdropftsdict'] = 'Êtes-vous sûr de vouloir supprimer le dictionnaire FTS « %s » ?'; + $lang['strconfdropftsmapping'] = 'Êtes-vous sûr de vouloir supprimer le mapping « %s » de la configuration FTS « %s » ?'; + $lang['strftstemplate'] = 'Modèle'; + $lang['strftsparser'] = 'Analyseur syntaxique'; + $lang['strftsconfigneedsname'] = 'Vous devez donner un nom pour votre configuration FTS.'; + $lang['strftsconfigcreated'] = 'Configuration FTS créée'; + $lang['strftsconfigcreatedbad'] = 'Échec lors de la création de la configuration FTS.'; + $lang['strftsmapping'] = 'Type de jeton'; + $lang['strftsdicts'] = 'Dictionaires'; + $lang['strftsdict'] = 'Dictionaire'; + $lang['strftsemptymap'] = 'Aucune liaisons configurée.'; + $lang['strftsconfigaltered'] = 'Configuration FTS modifiée.'; + $lang['strftsconfigalteredbad'] = 'Échec lors de l\'édition de la configuration FTS.'; + $lang['strftsconfigmap'] = 'Configuration des liaisons type de jeton / dictionnaires'; + $lang['strftsparsers'] = 'Analyseurs syntaxique FTS'; + $lang['strftsnoparsers'] = 'Aucun analyseur syntaxique FTS disponnible.'; + $lang['strftsnodicts'] = 'Aucun dictionnaire FTS disponible.'; + $lang['strftsdictcreated'] = 'Dictionnaire FTS créé'; + $lang['strftsdictcreatedbad'] = 'Échec lors de la création du dictionnaire FTS.'; + $lang['strftslexize'] = 'Lexize'; + $lang['strftsinit'] = 'Init'; + $lang['strftsoptionsvalues'] = 'Options et Valeurs'; + $lang['strftsdictneedsname'] = 'Vous devez donner un nom pour votre dictionnaire FTS.'; + $lang['strftsdictdropped'] = 'Dictionnaire FTS supprimé.'; + $lang['strftsdictdroppedbad'] = 'Échec lors de la suppression du dictionnaire FTS.'; + $lang['strftsdictaltered'] = 'Dictionnaire FTS modifié.'; + $lang['strftsdictalteredbad'] = 'Échec lors de l\'édition du dictionnaire FTS.'; + $lang['strftsaddmapping'] = 'Ajouter une nouvelle liaison'; + $lang['strftsspecifymappingtodrop'] = 'Vous devez spécifier au moins une liaison à suppimer.'; + $lang['strftsspecifyconfigtoalter'] = 'Vous devez spécifier une configuration FTS à modifier'; + $lang['strftsmappingdropped'] = 'Laison supprimée.'; + $lang['strftsmappingdroppedbad'] = 'Échec lors de la suppression de la liaison.'; + $lang['strftsnodictionaries'] = 'Aucun dictionnaire trouvé.'; + $lang['strftsmappingaltered'] = 'Liaison modifiée.'; + $lang['strftsmappingalteredbad'] = 'Échec lors de la modification de la liaison.'; + $lang['strftsmappingadded'] = 'Liaison ajoutée.'; + $lang['strftsmappingaddedbad'] = 'Échec lors de la suppression de la liaison.'; + $lang['strftstabconfigs'] = 'Configurations'; + $lang['strftstabdicts'] = 'Dictionaires'; + $lang['strftstabparsers'] = 'Analyseurs syntaxique'; + $lang['strftscantparsercopy'] = 'Vous ne pouvez spécifier en même temps un modèle et un analyseur lors de la création d\'une configuration FTS.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/galician.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/galician.php new file mode 100644 index 00000000..9ee7a059 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/galician.php @@ -0,0 +1,909 @@ + + * Proxecto Trasno, . + * + * + * Comentarios sobre a tradución: + * - Escolleuse «eliminar» como tradución para “dropâ€, e «borrar» como tradución para + * “deleteâ€. + * - Fixéronse certas escollas de vocabulario: “vacuum†→ «purgación» (aconsellada por + * Leandro Regueiro), “cluster†→ «contentrado». + * + */ + + // Language and character set + $lang['applang'] = 'Galego'; + $lang['applocale'] = 'gl-ES'; + $lang['applangdir'] = 'ltr'; + + // Welcome + $lang['strintro'] = 'Benvida ou benvido ao phpPgAdmin.'; + $lang['strppahome'] = 'Sitio web do phpPgAdmin'; + $lang['strpgsqlhome'] = 'Sitio web de PostgreSQL'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'Documentación de PostgreSQL (local)'; + $lang['strreportbug'] = 'Informar dun erro'; + $lang['strviewfaq'] = 'Ver as preguntas máis frecuentes en liña'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'Identificarse'; + $lang['strloginfailed'] = 'Non se puido levar a cabo a identificación.'; + $lang['strlogindisallowed'] = 'A identificación está desactivada por motivos de seguridade.'; + $lang['strserver'] = 'Servidor'; + $lang['strservers'] = 'Servidores'; + $lang['strgroupservers'] = 'Servidores no grupo «%s»'; + $lang['strallservers'] = 'Todos os servidores'; + $lang['strintroduction'] = 'Introdución'; + $lang['strhost'] = 'Enderezo IP'; + $lang['strport'] = 'Porto'; + $lang['strlogout'] = 'Saír'; + $lang['strowner'] = 'Propietario'; + $lang['straction'] = 'Acción'; + $lang['stractions'] = 'Accións'; + $lang['strname'] = 'Nome'; + $lang['strdefinition'] = 'Definición'; + $lang['strproperties'] = 'Propiedades'; + $lang['strbrowse'] = 'Navegar'; + $lang['strenable'] = 'Activar'; + $lang['strdisable'] = 'Desactivar'; + $lang['strdrop'] = 'Eliminar'; + $lang['strdropped'] = 'Eliminada'; + $lang['strnull'] = 'Nulo'; + $lang['strnotnull'] = 'Non nulo'; + $lang['strprev'] = '< Anterior'; + $lang['strnext'] = 'Seguinte >'; + $lang['strfirst'] = '« Principio'; + $lang['strlast'] = 'Final »'; + $lang['strfailed'] = 'Fallou'; + $lang['strcreate'] = 'Crear'; + $lang['strcreated'] = 'Creada'; + $lang['strcomment'] = 'Comentario'; + $lang['strlength'] = 'Lonxitude'; + $lang['strdefault'] = 'Predeterminado'; + $lang['stralter'] = 'Cambiar'; + $lang['strok'] = 'Aceptar'; + $lang['strcancel'] = 'Cancelar'; + $lang['strkill'] = 'Matar'; + $lang['strac'] = 'Activar o completado automático'; + $lang['strsave'] = 'Gardar'; + $lang['strreset'] = 'Restablecer'; + $lang['strrestart'] = 'Reiniciar'; + $lang['strinsert'] = 'Inserir'; + $lang['strselect'] = 'Seleccionar'; + $lang['strdelete'] = 'Borrar'; + $lang['strupdate'] = 'Actualizar'; + $lang['strreferences'] = 'Fai referencia a'; + $lang['stryes'] = 'Si'; + $lang['strno'] = 'Non'; + $lang['strtrue'] = 'CERTO'; + $lang['strfalse'] = 'FALSO'; + $lang['stredit'] = 'Editar'; + $lang['strcolumn'] = 'Columna'; + $lang['strcolumns'] = 'Columnas'; + $lang['strrows'] = 'fila(s)'; + $lang['strrowsaff'] = 'fila(s) afectadas.'; + $lang['strobjects'] = 'obxecto(s)'; + $lang['strback'] = 'Volver'; + $lang['strqueryresults'] = 'Resultados da consulta'; + $lang['strshow'] = 'Amosar'; + $lang['strempty'] = 'Baleiro'; + $lang['strlanguage'] = 'Lingua'; + $lang['strencoding'] = 'Codificación'; + $lang['strvalue'] = 'Valor'; + $lang['strunique'] = 'Único'; + $lang['strprimary'] = 'Primaria'; + $lang['strexport'] = 'Exportar'; + $lang['strimport'] = 'Importar'; + $lang['strallowednulls'] = 'Permitir valores nulos'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Cadea ou campo baleiro'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Administración'; + $lang['strvacuum'] = 'Purgar'; + $lang['stranalyze'] = 'Analizar'; + $lang['strclusterindex'] = 'Concentrar'; + $lang['strclustered'] = 'Concentrada?'; + $lang['strreindex'] = 'Indexar'; + $lang['strexecute'] = 'Executar'; + $lang['stradd'] = 'Engadir'; + $lang['strevent'] = 'Evento'; + $lang['strwhere'] = 'Onde'; + $lang['strinstead'] = 'En vez de iso'; + $lang['strwhen'] = 'Cando'; + $lang['strformat'] = 'Formato'; + $lang['strdata'] = 'Datos'; + $lang['strconfirm'] = 'Confirmar'; + $lang['strexpression'] = 'Expresión'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Expandir'; + $lang['strcollapse'] = 'Colapsar'; + $lang['strfind'] = 'Buscar'; + $lang['stroptions'] = 'Opcións'; + $lang['strrefresh'] = 'Actualizar'; + $lang['strdownload'] = 'Descargar'; + $lang['strdownloadgzipped'] = 'Descargar comprimida con gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Avanzado'; + $lang['strvariables'] = 'Variables'; + $lang['strprocess'] = 'Proceso'; + $lang['strprocesses'] = 'Procesos'; + $lang['strsetting'] = 'Configuración'; + $lang['streditsql'] = 'Editar SQL'; + $lang['strruntime'] = 'Tempo total funcionando: %s ms'; + $lang['strpaginate'] = 'Amosar os resultados por páxinas'; + $lang['struploadscript'] = 'ou cargue un guión en SQL:'; + $lang['strstarttime'] = 'Hora de inicio'; + $lang['strfile'] = 'Ficheiro'; + $lang['strfileimported'] = 'Importouse o ficheiro.'; + $lang['strtrycred'] = 'Utilizar estas credenciais para todos os servidores'; + $lang['strconfdropcred'] = 'Por motivos de seguridade, ao desconectarse destruirase a información compartida sobre a súa identidade. Está seguro de que quere desconectarse?'; + $lang['stractionsonmultiplelines'] = 'Accións en varias liñas'; + $lang['strselectall'] = 'Marcar todo'; + $lang['strunselectall'] = 'Desmarcar todo'; + $lang['strlocale'] = 'Configuración rexional'; + $lang['strcollation'] = 'Recompilación'; + $lang['strctype'] = 'Tipo de carácter'; + $lang['strdefaultvalues'] = 'Valores predeterminados'; + $lang['strnewvalues'] = 'Valores novos'; + $lang['strstart'] = 'Iniciar'; + $lang['strstop'] = 'Deter'; + $lang['strgotoppage'] = 'Volver arriba'; + $lang['strtheme'] = 'Tema visual'; + $lang['strcluster'] = 'Concentrador'; + + // Admin + $lang['stradminondatabase'] = 'As seguintes tarefas administrativas realizaranse en toda a base de datos «%s».'; + $lang['stradminontable'] = 'As seguintes tarefas administrativas realizaranse na táboa «%s».'; + + // User-supplied SQL history + $lang['strhistory'] = 'Historial'; + $lang['strnohistory'] = 'Sen historial.'; + $lang['strclearhistory'] = 'Borrar o historial'; + $lang['strdelhistory'] = 'Borrar do historial'; + $lang['strconfdelhistory'] = 'Seguro que quere borrar esta solicitude do historial?'; + $lang['strconfclearhistory'] = 'Seguro que quere borrar o historial?'; + $lang['strnodatabaseselected'] = 'Escolla unha base de datos.'; + + // Database sizes + $lang['strnoaccess'] = 'Sen acceso'; + $lang['strsize'] = 'Tamaño'; + $lang['strbytes'] = 'bytes'; + $lang['strkb'] = 'kiB'; + $lang['strmb'] = 'MiB'; + $lang['strgb'] = 'GiB'; + $lang['strtb'] = 'TiB'; + + // Error handling + $lang['strnoframes'] = 'Este aplicativo funciona mellor nos navegadores que permiten o uso de marcos, pero pode usalo sen eles premendo na ligazón que hai máis abaixo.'; + $lang['strnoframeslink'] = 'Utilizar sen marcos'; + $lang['strbadconfig'] = 'O seu ficheiro de configuración «config.inc.php» está obsoleto. Terá que volvelo crear a partires do novo ficheiro «config.inc.php-dist».'; + $lang['strnotloaded'] = 'A súa instalación de PHP non está preparada para utilizar PostgreSQL. Terá que compilar PHP de novo utilizando a opción de configuración «--with-pgsql».'; + $lang['strpostgresqlversionnotsupported'] = 'Este aplicativo non é compatible coa versión de PostgreSQL que está a usar. Actualíceo á versión %s ou outra versión posterior.'; + $lang['strbadschema'] = 'O esquema especificado non era correcto.'; + $lang['strbadencoding'] = 'Non se deu establecida a codificación do cliente na base de datos.'; + $lang['strsqlerror'] = 'Erro de SQL:'; + $lang['strinstatement'] = 'Na instrución:'; + $lang['strinvalidparam'] = 'Os parámetros fornecidos ao guión non son correctos.'; + $lang['strnodata'] = 'Non se atopou fila algunha.'; + $lang['strnoobjects'] = 'Non se atopou obxecto algún.'; + $lang['strrownotunique'] = 'Esta fila non ten ningún identificador único.'; + $lang['strnouploads'] = 'A carga de ficheiros está desactivada.'; + $lang['strimporterror'] = 'Produciuse un erro ao importar.'; + $lang['strimporterror-fileformat'] = 'Produciuse un erro ao importar: non se puido determinar de maneira automática o formato do ficheiro.'; + $lang['strimporterrorline'] = 'Produciuse un erro ao importar, na liña %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Produciuse un erro ao importar, na liña %s: a liña non ten unha cantidade de columnas axeitada.'; + $lang['strimporterror-uploadedfile'] = 'Produciuse un erro ao importar: non se puido cargar o ficheiro no servidor.'; + $lang['strcannotdumponwindows'] = 'O envorcado de táboas complexas e mais nomes de esquemas non pode efectuarse en sistemas Microsoft Windows.'; + $lang['strinvalidserverparam'] = 'Produciuse un intento de conexión cun servidor non permitido como parámetro, é posible que alguén estea intentando atacar o seu sistema.'; + $lang['strnoserversupplied'] = 'Non se forneceu ningún servidor!'; + $lang['strbadpgdumppath'] = 'Produciuse un erro ao exportar: non se conseguiu executar pg_dump (a ruta indicada no seu ficheiro «conf/config.inc.php» é «%s»). Cambie a ruta no ficheiro de configuración e volva intentalo.'; + $lang['strbadpgdumpallpath'] = 'Produciuse un erro ao exportar: non se conseguiu executar pg_dumpall (a ruta indicada no seu ficheiro «conf/config.inc.php» é «%s»). Cambie a ruta no ficheiro de configuración e volva intentalo.'; + $lang['strconnectionfail'] = 'Non se puido establecer a conexión co servidor.'; + + // Tables + $lang['strtable'] = 'Táboa'; + $lang['strtables'] = 'Táboas'; + $lang['strshowalltables'] = 'Amosar todas as táboas'; + $lang['strnotables'] = 'Non se atopou táboa algunha.'; + $lang['strnotable'] = 'Non se atopou táboa algunha.'; + $lang['strcreatetable'] = 'Crear unha táboa'; + $lang['strcreatetablelike'] = 'Crear unha táboa coma'; + $lang['strcreatetablelikeparent'] = 'Táboa orixinal'; + $lang['strcreatelikewithdefaults'] = 'INCLUÃR OS VALORES PREDETERMINADOS'; + $lang['strcreatelikewithconstraints'] = 'INCLUÃR AS RESTRICIÓNS'; + $lang['strcreatelikewithindexes'] = 'INCLUÃR OS ÃNDICES'; + $lang['strtablename'] = 'Nome da táboa'; + $lang['strtableneedsname'] = 'Debe fornecer un nome para a táboa.'; + $lang['strtablelikeneedslike'] = 'Debe fornecer unha táboa á que copiarlle as propiedades.'; + $lang['strtableneedsfield'] = 'Debe indicar polo menos un campo.'; + $lang['strtableneedscols'] = 'Debe indicar un número de columnas correcto.'; + $lang['strtablecreated'] = 'Creouse a táboa.'; + $lang['strtablecreatedbad'] = 'Non se conseguiu crear a táboa.'; + $lang['strconfdroptable'] = 'Está seguro de que quere eliminar a táboa «%s»?'; + $lang['strtabledropped'] = 'Eliminouse a táboa.'; + $lang['strtabledroppedbad'] = 'Non se conseguiu eliminar a táboa.'; + $lang['strconfemptytable'] = 'Está seguro de que quere baleirar a táboa «%s»?'; + $lang['strtableemptied'] = 'Baleirouse a táboa.'; + $lang['strtableemptiedbad'] = 'Non se conseguiu baleirar a táboa.'; + $lang['strinsertrow'] = 'Inserir unha fila'; + $lang['strrowinserted'] = 'Inseriuse unha fila.'; + $lang['strrowinsertedbad'] = 'Non se conseguiu inserir a fila.'; + $lang['strnofkref'] = 'Non existe ningún valor que coincida na clave externa «%s».'; + $lang['strrowduplicate'] = 'Non se conseguiu inserir a fila, intentouse facer unha inxección duplicada.'; + $lang['streditrow'] = 'Modificar a fila'; + $lang['strrowupdated'] = 'Actualizouse a fila.'; + $lang['strrowupdatedbad'] = 'Non se conseguiu actualizar a fila.'; + $lang['strdeleterow'] = 'Borrar a fila'; + $lang['strconfdeleterow'] = 'Está seguro de que quere borrar esta fila?'; + $lang['strrowdeleted'] = 'Borrouse a fila.'; + $lang['strrowdeletedbad'] = 'Non se conseguiu borrar a fila.'; + $lang['strinsertandrepeat'] = 'Inserir e repetir'; + $lang['strnumcols'] = 'Número de columnas'; + $lang['strcolneedsname'] = 'Debe especificar un nome para a columna'; + $lang['strselectallfields'] = 'Marcar todos os campos'; + $lang['strselectneedscol'] = 'Debe amosar polo menos unha columna.'; + $lang['strselectunary'] = 'Os operadores dun só operando non poden ter valores.'; + $lang['strcolumnaltered'] = 'Modificouse a columna.'; + $lang['strcolumnalteredbad'] = 'Non se conseguiu modificar a columna.'; + $lang['strconfdropcolumn'] = 'Está seguro de que quere eliminar a columna «%s» da táboa «%s»?'; + $lang['strcolumndropped'] = 'Eliminouse a columna.'; + $lang['strcolumndroppedbad'] = 'Non se conseguiu eliminar a columna.'; + $lang['straddcolumn'] = 'Engadir unha columna'; + $lang['strcolumnadded'] = 'Engadiuse a columna.'; + $lang['strcolumnaddedbad'] = 'Non se conseguiu engadir a columna.'; + $lang['strcascade'] = 'EN CASCADA'; + $lang['strtablealtered'] = 'Modificouse a táboa.'; + $lang['strtablealteredbad'] = 'Non se conseguiu modificar a táboa.'; + $lang['strdataonly'] = 'Só datos'; + $lang['strstructureonly'] = 'Só estrutura'; + $lang['strstructureanddata'] = 'Estrutura e datos'; + $lang['strtabbed'] = 'Tabulado'; + $lang['strauto'] = 'Detectar'; + $lang['strconfvacuumtable'] = 'Está seguro de que quere purgar «%s»?'; + $lang['strconfanalyzetable'] = 'Está seguro de que quere analizar «%s»?'; + $lang['strconfreindextable'] = 'Está seguro de que quere indexar «%s»?'; + $lang['strconfclustertable'] = 'Está seguro de que quere concentrar «%s»?'; + $lang['strestimatedrowcount'] = 'Número estimado de filas'; + $lang['strspecifytabletoanalyze'] = 'Debe especificar polo menos unha táboa a analizar.'; + $lang['strspecifytabletoempty'] = 'Debe especificar polo menos unha táboa a baleirar.'; + $lang['strspecifytabletodrop'] = 'Debe especificar polo menos unha táboa a eliminar.'; + $lang['strspecifytabletovacuum'] = 'Debe especificar polo menos unha táboa a purgar.'; + $lang['strspecifytabletoreindex'] = 'Debe especificar polo menos unha táboa a indexar.'; + $lang['strspecifytabletocluster'] = 'Debe especificar polo menos unha táboa a concentrar.'; + $lang['strnofieldsforinsert'] = 'Non pode inserir filas nunha táboa sen columnas.'; + + // Columns + $lang['strcolprop'] = 'Propiedades da columna'; + $lang['strnotableprovided'] = 'Non se forneceu ningunha táboa!'; + + // Users + $lang['struser'] = 'Usuario'; + $lang['strusers'] = 'Usuarios'; + $lang['strusername'] = 'Nome'; + $lang['strpassword'] = 'Contrasinal'; + $lang['strsuper'] = 'Administrador?'; + $lang['strcreatedb'] = 'Crear bases de datos?'; + $lang['strexpires'] = 'Caducidade'; + $lang['strsessiondefaults'] = 'Valores predeterminados da sesión'; + $lang['strnousers'] = 'Non se atopou ningún usuario.'; + $lang['struserupdated'] = 'Actualizouse o usuario.'; + $lang['struserupdatedbad'] = 'Non se conseguiu actualizar o usuario.'; + $lang['strshowallusers'] = 'Listar todos os usuarios'; + $lang['strcreateuser'] = 'Crear un usuario'; + $lang['struserneedsname'] = 'Debe fornecer un nome para o usuario.'; + $lang['strusercreated'] = 'Creouse o usuario.'; + $lang['strusercreatedbad'] = 'Non se conseguiu crear o usuario.'; + $lang['strconfdropuser'] = 'Está seguro de que quere eliminar o usuario «%s»?'; + $lang['struserdropped'] = 'Eliminouse o usuario.'; + $lang['struserdroppedbad'] = 'Non se conseguiu eliminar o usuario.'; + $lang['straccount'] = 'Conta'; + $lang['strchangepassword'] = 'Cambiar de contrasinal'; + $lang['strpasswordchanged'] = 'Cambiouse o contrasinal.'; + $lang['strpasswordchangedbad'] = 'Non se conseguiu cambiar o contrasinal.'; + $lang['strpasswordshort'] = 'O contrasinal é curto de máis.'; + $lang['strpasswordconfirm'] = 'Os contrasinais introducidos son distintos.'; + + // Groups + $lang['strgroup'] = 'Grupo'; + $lang['strgroups'] = 'Grupos'; + $lang['strshowallgroups'] = 'Amosar todos os grupos'; + $lang['strnogroup'] = 'Non se atopou o grupo.'; + $lang['strnogroups'] = 'Non se atopou grupo algún.'; + $lang['strcreategroup'] = 'Crear un grupo'; + $lang['strgroupneedsname'] = 'Debe fornecer un nome para o grupo.'; + $lang['strgroupcreated'] = 'Creouse o grupo.'; + $lang['strgroupcreatedbad'] = 'Non se conseguiu crear o grupo.'; + $lang['strconfdropgroup'] = 'está seguro de que quere eliminar o grupo «%s»?'; + $lang['strgroupdropped'] = 'Eliminouse o grupo.'; + $lang['strgroupdroppedbad'] = 'Non se conseguiu eliminar o grupo.'; + $lang['strmembers'] = 'Membros'; + $lang['strmemberof'] = 'Membros de'; + $lang['stradminmembers'] = 'Membros administradores'; + $lang['straddmember'] = 'Engadir un membro'; + $lang['strmemberadded'] = 'Engadiuse o membro.'; + $lang['strmemberaddedbad'] = 'Non se conseguiu engadir o membro.'; + $lang['strdropmember'] = 'Eliminar o membro'; + $lang['strconfdropmember'] = 'Está seguro de que quere eliminar o membro «%s» do grupo «%s»?'; + $lang['strmemberdropped'] = 'Eliminouse o membro.'; + $lang['strmemberdroppedbad'] = 'Non se conseguiu eliminar o membro.'; + + // Roles + $lang['strrole'] = 'Rol'; + $lang['strroles'] = 'Roles'; + $lang['strshowallroles'] = 'Amosar todos os roles'; + $lang['strnoroles'] = 'Non se atopou rol algún.'; + $lang['strinheritsprivs'] = 'Herdar os privilexios?'; + $lang['strcreaterole'] = 'Crear un rol'; + $lang['strcancreaterole'] = 'Pode crear roles?'; + $lang['strrolecreated'] = 'Creouse o rol.'; + $lang['strrolecreatedbad'] = 'Non se conseguiu crear o rol.'; + $lang['strrolealtered'] = 'Modificouse o rol.'; + $lang['strrolealteredbad'] = 'Non se conseguiu modificar o rol.'; + $lang['strcanlogin'] = 'Pode identificarse?'; + $lang['strconnlimit'] = 'Límite da conexión'; + $lang['strdroprole'] = 'Eliminar o rol'; + $lang['strconfdroprole'] = 'Está seguro de que quere eliminar o rol «%s»?'; + $lang['strroledropped'] = 'Eliminouse o rol.'; + $lang['strroledroppedbad'] = 'Non se conseguiu eliminar o rol.'; + $lang['strnolimit'] = 'Sen límite'; + $lang['strnever'] = 'Nunca'; + $lang['strroleneedsname'] = 'Ten que darlle un nome ao rol.'; + + // Privileges + $lang['strprivilege'] = 'Privilexio'; + $lang['strprivileges'] = 'Privilexios'; + $lang['strnoprivileges'] = 'Este obxecto ten os privilexios predeterminados do propietario.'; + $lang['strgrant'] = 'Conceder'; + $lang['strrevoke'] = 'Revogar'; + $lang['strgranted'] = 'Cambiáronse os privilexios.'; + $lang['strgrantfailed'] = 'Non se conseguiu cambiar os privilexios.'; + $lang['strgrantbad'] = 'Ten que especificar polo menos un usuario ou grupo e un privilexio.'; + $lang['strgrantor'] = 'Autor da concesión'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Base de datos'; + $lang['strdatabases'] = 'Bases de datos'; + $lang['strshowalldatabases'] = 'Amosar todas as bases de datos'; + $lang['strnodatabases'] = 'Non se atopou base de datos algunha.'; + $lang['strcreatedatabase'] = 'Crear unha base de datos'; + $lang['strdatabasename'] = 'Nome da base de datos'; + $lang['strdatabaseneedsname'] = 'Debe darlle un nome á base de datos.'; + $lang['strdatabasecreated'] = 'Creouse a base de datos.'; + $lang['strdatabasecreatedbad'] = 'Non se conseguiu crear a base de datos.'; + $lang['strconfdropdatabase'] = 'Está seguro de que quere eliminar a base de datos «%s»?'; + $lang['strdatabasedropped'] = 'Eliminouse a base de datos.'; + $lang['strdatabasedroppedbad'] = 'Non se conseguiu eliminar a base de datos.'; + $lang['strentersql'] = 'Introduza a continuación as instrucións SQL a executar:'; + $lang['strsqlexecuted'] = 'Executáronse as instrucións SQL.'; + $lang['strvacuumgood'] = 'Completouse a purgación.'; + $lang['strvacuumbad'] = 'Non se conseguiu efectuar a purgación.'; + $lang['stranalyzegood'] = 'Completouse a análise.'; + $lang['stranalyzebad'] = 'Non se conseguiu completar a análise.'; + $lang['strreindexgood'] = 'Completouse o indexado.'; + $lang['strreindexbad'] = 'Non se conseguiu completar o indexado.'; + $lang['strfull'] = 'Completo'; + $lang['strfreeze'] = 'Agresivo'; + $lang['strforce'] = 'Forzar'; + $lang['strsignalsent'] = 'Enviouse o sinal.'; + $lang['strsignalsentbad'] = 'Non se conseguiu enviar o sinal.'; + $lang['strallobjects'] = 'Todos os obxectos'; + $lang['strdatabasealtered'] = 'Modificouse a base de datos.'; + $lang['strdatabasealteredbad'] = 'Non se conseguiu modificar a base de datos.'; + $lang['strspecifydatabasetodrop'] = 'Debe especificar polo menos unha base de datos a eliminar.'; + $lang['strtemplatedb'] = 'Modelo'; + $lang['strconfanalyzedatabase'] = 'Está seguro de que quere analizar todas as táboas da base de datos «%s»?'; + $lang['strconfvacuumdatabase'] = 'Está seguro de que quere purgar todas as táboas da base de datos «%s»?'; + $lang['strconfreindexdatabase'] = 'Está seguro de que quere indexar todas as táboas da base de datos «%s»?'; + $lang['strconfclusterdatabase'] = 'Está seguro de que quere concentrar todas as táboas da base de datos «%s»?'; + + // Views + $lang['strview'] = 'Vista'; + $lang['strviews'] = 'Vistas'; + $lang['strshowallviews'] = 'Listar todas as vistas'; + $lang['strnoview'] = 'Non se atopou vista algunha.'; + $lang['strnoviews'] = 'Non se atopou vista algunha.'; + $lang['strcreateview'] = 'Crear unha vista'; + $lang['strviewname'] = 'Nome da vista'; + $lang['strviewneedsname'] = 'Debe fornecer un nome para a vista.'; + $lang['strviewneedsdef'] = 'Debe fornecer unha descrición da vista.'; + $lang['strviewneedsfields'] = 'Debe indicar que columnas quere ter na vista.'; + $lang['strviewcreated'] = 'Creouse a vista.'; + $lang['strviewcreatedbad'] = 'Non se conseguiu crear a vista.'; + $lang['strconfdropview'] = 'Está seguro de que quere eliminar a vista «%s»?'; + $lang['strviewdropped'] = 'Eliminouse a vista.'; + $lang['strviewdroppedbad'] = 'Non se conseguiu eliminar a vista.'; + $lang['strviewupdated'] = 'Actualizouse a vista.'; + $lang['strviewupdatedbad'] = 'Non se conseguiu actualizar a vista.'; + $lang['strviewlink'] = 'Unión de claves'; + $lang['strviewconditions'] = 'Condicións adicionais'; + $lang['strcreateviewwiz'] = 'Crear unha vista co asistente'; + $lang['strrenamedupfields'] = 'Renomear os campos duplicados'; + $lang['strdropdupfields'] = 'Eliminar os campos duplicados'; + $lang['strerrordupfields'] = 'Non permitir que haxa campos duplicados'; + $lang['strviewaltered'] = 'Modificouse a vista.'; + $lang['strviewalteredbad'] = 'Non se conseguiu modificar a vista.'; + $lang['strspecifyviewtodrop'] = 'Debe especificar polo menos unha vista a borrar.'; + + // Sequences + $lang['strsequence'] = 'Secuencia'; + $lang['strsequences'] = 'Secuencias'; + $lang['strshowallsequences'] = 'Amosar todas as secuencias'; + $lang['strnosequence'] = 'Non se atopou secuencia algunha.'; + $lang['strnosequences'] = 'Non se atopou secuencia algunha.'; + $lang['strcreatesequence'] = 'Crear unha secuencia'; + $lang['strlastvalue'] = 'Último valor'; + $lang['strincrementby'] = 'Aumentar en'; + $lang['strstartvalue'] = 'Valor inicial'; + $lang['strrestartvalue'] = 'Valor do reinicio'; + $lang['strmaxvalue'] = 'Valor máximo'; + $lang['strminvalue'] = 'Valor mínimo'; + $lang['strcachevalue'] = 'Valor da caché'; + $lang['strlogcount'] = 'Conta de rexistros'; + $lang['strcancycle'] = 'Pode repetirse?'; + $lang['striscalled'] = 'Aumentará o último valor antes de devolver o seguinte (is_called)?'; + $lang['strsequenceneedsname'] = 'Debe fornecer un nome para a secuencia.'; + $lang['strsequencecreated'] = 'Creouse a secuencia.'; + $lang['strsequencecreatedbad'] = 'Non se conseguiu crear a secuencia.'; + $lang['strconfdropsequence'] = 'Está seguro de que quere eliminar a secuencia «%s»?'; + $lang['strsequencedropped'] = 'Eliminouse a secuencia.'; + $lang['strsequencedroppedbad'] = 'Non se conseguiu eliminar a secuencia.'; + $lang['strsequencerestart'] = 'Reiniciouse a secuencia.'; + $lang['strsequencerestartbad'] = 'Non se conseguiu reiniciar a secuencia.'; + $lang['strsequencereset'] = 'Restableceuse a secuencia.'; + $lang['strsequenceresetbad'] = 'Non se conseguiu restablecer a secuencia.'; + $lang['strsequencealtered'] = 'Modificouse a secuencia.'; + $lang['strsequencealteredbad'] = 'Non se conseguiu modificar a secuencia.'; + $lang['strsetval'] = 'Establecer o valor'; + $lang['strsequencesetval'] = 'Estableceuse o valor da secuencia.'; + $lang['strsequencesetvalbad'] = 'Non se conseguiu establecer o valor da secuencia.'; + $lang['strnextval'] = 'Aumentar o valor'; + $lang['strsequencenextval'] = 'Aumentouse o valor da secuencia.'; + $lang['strsequencenextvalbad'] = 'Non se conseguiu aumentar o valor da secuencia.'; + $lang['strspecifysequencetodrop'] = 'Debe especificar polo menos unha secuencia a eliminar.'; + + // Indexes + $lang['strindex'] = 'Ãndice'; + $lang['strindexes'] = 'Ãndices'; + $lang['strindexname'] = 'Nome do índice'; + $lang['strshowallindexes'] = 'Listar todos os índices'; + $lang['strnoindex'] = 'Non se atopou índice algún.'; + $lang['strnoindexes'] = 'Non se atopou índice algún.'; + $lang['strcreateindex'] = 'Crear un índice'; + $lang['strtabname'] = 'Nome da lapela'; + $lang['strcolumnname'] = 'Nome da columna'; + $lang['strindexneedsname'] = 'Debe fornecer un nome para o índice.'; + $lang['strindexneedscols'] = 'Os índices teñen que ter un número de columnas correcto.'; + $lang['strindexcreated'] = 'Creouse o índice.'; + $lang['strindexcreatedbad'] = 'Non se conseguiu crear o índice.'; + $lang['strconfdropindex'] = 'Está seguro de que quere eliminar o índice «%s»?'; + $lang['strindexdropped'] = 'Eliminouse o índice.'; + $lang['strindexdroppedbad'] = 'Non se conseguiu eliminar o índice.'; + $lang['strkeyname'] = 'Nome da clave'; + $lang['struniquekey'] = 'Clave única'; + $lang['strprimarykey'] = 'Clave primaria'; + $lang['strindextype'] = 'Tipo de índice'; + $lang['strtablecolumnlist'] = 'Columnas na táboa'; + $lang['strindexcolumnlist'] = 'Columnas no índice'; + $lang['strconfcluster'] = 'Está seguro de que quere concentrar «%s»?'; + $lang['strclusteredgood'] = 'Completouse o concentrado.'; + $lang['strclusteredbad'] = 'Non se conseguiu completar o concentrado.'; + $lang['strconcurrently'] = 'Simultaneamente'; + $lang['strnoclusteravailable'] = 'A táboa non está concentrada nun índice.'; + + // Rules + $lang['strrules'] = 'Regras'; + $lang['strrule'] = 'Regra'; + $lang['strshowallrules'] = 'Listar todas as regras'; + $lang['strnorule'] = 'Non se atopou regra algunha.'; + $lang['strnorules'] = 'Non se atopou regra algunha.'; + $lang['strcreaterule'] = 'Crear unha regra'; + $lang['strrulename'] = 'Nome da regra'; + $lang['strruleneedsname'] = 'Debe fornecer un nome para a regra.'; + $lang['strrulecreated'] = 'Creouse a regra.'; + $lang['strrulecreatedbad'] = 'Non se conseguiu crear a regra.'; + $lang['strconfdroprule'] = 'Está seguro de que quere eliminar a regra «%s» en «%s»?'; + $lang['strruledropped'] = 'Eliminouse a regra.'; + $lang['strruledroppedbad'] = 'Non se conseguiu eliminar a regra.'; + + // Constraints + $lang['strconstraint'] = 'Restrición'; + $lang['strconstraints'] = 'Restricións'; + $lang['strshowallconstraints'] = 'Listar todas as restricións'; + $lang['strnoconstraints'] = 'Non se atopou restrición algunha.'; + $lang['strcreateconstraint'] = 'Crear unha restrición'; + $lang['strconstraintcreated'] = 'Creouse a restrición.'; + $lang['strconstraintcreatedbad'] = 'Non se conseguiu crear a restrición.'; + $lang['strconfdropconstraint'] = 'Está seguro de que quere eliminar a restrición «%s» en «%s»?'; + $lang['strconstraintdropped'] = 'Eliminouse a restrición.'; + $lang['strconstraintdroppedbad'] = 'Non se conseguiu eliminar a restrición.'; + $lang['straddcheck'] = 'Engadir unha comprobación'; + $lang['strcheckneedsdefinition'] = 'A comprobación necesita unha definición.'; + $lang['strcheckadded'] = 'Engadiuse a comprobación.'; + $lang['strcheckaddedbad'] = 'Non se conseguiu engadir a comprobación.'; + $lang['straddpk'] = 'Engadir unha clave primaria'; + $lang['strpkneedscols'] = 'A clave primaria necesita polo menos unha columna.'; + $lang['strpkadded'] = 'Engadiuse a clave primaria.'; + $lang['strpkaddedbad'] = 'Non se conseguiu engadir a clave primaria.'; + $lang['stradduniq'] = 'Engadir unha clave única'; + $lang['struniqneedscols'] = 'A clave única necesita polo menos unha columna.'; + $lang['struniqadded'] = 'Engadiuse a clave única.'; + $lang['struniqaddedbad'] = 'Non se conseguiu engadir a clave única.'; + $lang['straddfk'] = 'Engadir unha clave externa'; + $lang['strfkneedscols'] = 'A clave externa necesita polo menos unha columna.'; + $lang['strfkneedstarget'] = 'A clave externa necesita unha táboa externa.'; + $lang['strfkadded'] = 'Engadiuse a clave externa.'; + $lang['strfkaddedbad'] = 'Non se conseguiu engadir a clave externa.'; + $lang['strfktarget'] = 'Táboa externa'; + $lang['strfkcolumnlist'] = 'Columnas na clave'; + $lang['strondelete'] = 'AO ACTUALIZAR'; // Sei que son instrucións cando se usa SQL, pero na + $lang['stronupdate'] = 'AO BORRAR'; // interface paréceme mellor traducilos. + + // Functions + $lang['strfunction'] = 'Función'; + $lang['strfunctions'] = 'Funcións'; + $lang['strshowallfunctions'] = 'Listar todas as funcións'; + $lang['strnofunction'] = 'Non se atopou función algunha.'; + $lang['strnofunctions'] = 'Non se atopou función algunha.'; + $lang['strcreateplfunction'] = 'Crear unha función SQL/PL'; + $lang['strcreateinternalfunction'] = 'Crear unha función interna'; + $lang['strcreatecfunction'] = 'Crear unha función en C'; + $lang['strfunctionname'] = 'Nome da función'; + $lang['strreturns'] = 'Devolve'; + $lang['strproglanguage'] = 'Linguaxe de programación'; + $lang['strfunctionneedsname'] = 'Debe fornecer un nome para a función.'; + $lang['strfunctionneedsdef'] = 'Debe fornecer unha definición para a función.'; + $lang['strfunctioncreated'] = 'Creouse a función.'; + $lang['strfunctioncreatedbad'] = 'Non se conseguiu crear a función.'; + $lang['strconfdropfunction'] = 'Está seguro de que quere eliminar a función «%s»?'; + $lang['strfunctiondropped'] = 'Eliminouse a función.'; + $lang['strfunctiondroppedbad'] = 'Non se conseguiu eliminar a función.'; + $lang['strfunctionupdated'] = 'Actualizouse a función.'; + $lang['strfunctionupdatedbad'] = 'Non se conseguiu actualizar a función.'; + $lang['strobjectfile'] = 'Ficheiro de obxecto'; + $lang['strlinksymbol'] = 'Símbolo da ligazón'; + $lang['strarguments'] = 'Argumentos'; + $lang['strargmode'] = 'Modo'; + $lang['strargtype'] = 'Tipo'; + $lang['strargadd'] = 'Engadir outro argumento'; + $lang['strargremove'] = 'Borrar este argumento'; + $lang['strargnoargs'] = 'Esta función non recibirá argumento ningún.'; + $lang['strargenableargs'] = 'Permitir que se lle fornezan argumentos á función.'; + $lang['strargnorowabove'] = 'Ten que haber unha fila antes desta.'; + $lang['strargnorowbelow'] = 'Ten que haber unha fila despois desta.'; + $lang['strargraise'] = 'Subir.'; + $lang['strarglower'] = 'Baixar.'; + $lang['strargremoveconfirm'] = 'Está seguro de que quere borrar este argumento? Esta acción non se pode desfacer.'; + $lang['strfunctioncosting'] = 'Custo da función'; + $lang['strresultrows'] = 'Filas resultantes'; + $lang['strexecutioncost'] = 'Custo de execución'; + $lang['strspecifyfunctiontodrop'] = 'Debe especificar polo menos unha función a eliminar.'; + + // Triggers + $lang['strtrigger'] = 'Disparador'; + $lang['strtriggers'] = 'Disparadores'; + $lang['strshowalltriggers'] = 'Listar todos os disparadores'; + $lang['strnotrigger'] = 'Non se atopor disparador algún.'; + $lang['strnotriggers'] = 'Non se atopor disparador algún.'; + $lang['strcreatetrigger'] = 'Crear un disparador'; + $lang['strtriggerneedsname'] = 'Debe fornecer un nome para o disparador.'; + $lang['strtriggerneedsfunc'] = 'Debe especificar unha función para o disparador.'; + $lang['strtriggercreated'] = 'Creouse o disparador.'; + $lang['strtriggercreatedbad'] = 'Non se conseguiu crear o disparador.'; + $lang['strconfdroptrigger'] = 'Está seguro de que quere eliminar o disparador «%s» en «%s»?'; + $lang['strconfenabletrigger'] = 'Está seguro de que quere activar o disparador «%s» en «%s»?'; + $lang['strconfdisabletrigger'] = 'Está seguro de que quere desactivar o disparador «%s» en «%s»?'; + $lang['strtriggerdropped'] = 'Eliminouse o disparador.'; + $lang['strtriggerdroppedbad'] = 'Non se conseguiu eliminar o disparador.'; + $lang['strtriggerenabled'] = 'Activouse o disparador.'; + $lang['strtriggerenabledbad'] = 'Non se conseguiu activar o disparador.'; + $lang['strtriggerdisabled'] = 'Desactivouse o disparador.'; + $lang['strtriggerdisabledbad'] = 'Non se conseguiu desactivar o disparador.'; + $lang['strtriggeraltered'] = 'Modificouse o disparador.'; + $lang['strtriggeralteredbad'] = 'Non se conseguiu modificar o disparador.'; + $lang['strforeach'] = 'Por cada'; // «For each [row or instruction]» + + // Types + $lang['strtype'] = 'Tipo'; + $lang['strtypes'] = 'Tipos'; + $lang['strshowalltypes'] = 'Listar todos os tipos'; + $lang['strnotype'] = 'Non se atopou tipo algún.'; + $lang['strnotypes'] = 'Non se atopou tipo algún.'; + $lang['strcreatetype'] = 'Crear un tipo'; + $lang['strcreatecomptype'] = 'Crear un tipo composto'; + $lang['strcreateenumtype'] = 'Crear un tipo de enumeración'; + $lang['strtypeneedsfield'] = 'Debe especificar polo menos un campo.'; + $lang['strtypeneedsvalue'] = 'Debe especificar polo menos un valor.'; + $lang['strtypeneedscols'] = 'Debe especificar un número correcto de campos.'; + $lang['strtypeneedsvals'] = 'Debe especificar un número correcto de valores.'; + $lang['strinputfn'] = 'Función de entrada'; + $lang['stroutputfn'] = 'Función de saída'; + $lang['strpassbyval'] = 'Pasado por valor?'; + $lang['stralignment'] = 'Aliñación'; + $lang['strelement'] = 'Elemento'; + $lang['strdelimiter'] = 'Delimitador'; + $lang['strstorage'] = 'Almacenamento'; + $lang['strfield'] = 'Campo'; + $lang['strnumfields'] = 'Cantidade de campos'; + $lang['strnumvalues'] = 'Cantidade de valores'; + $lang['strtypeneedsname'] = 'Debe fornecer un nome para o tipo.'; + $lang['strtypeneedslen'] = 'Debe fornecer unha lonxitude para o tipo.'; + $lang['strtypecreated'] = 'Creouse o tipo.'; + $lang['strtypecreatedbad'] = 'Non se conseguiu crear o tipo.'; + $lang['strconfdroptype'] = 'Está seguro de que quere eliminar o tipo «%s»?'; + $lang['strtypedropped'] = 'Eliminouse o tipo.'; + $lang['strtypedroppedbad'] = 'Non se conseguiu eliminar o tipo.'; + $lang['strflavor'] = 'Subtipo'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Composto'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'Enumeración'; + $lang['strenumvalues'] = 'Valores da enumeración'; + + // Schemas + $lang['strschema'] = 'Esquema'; + $lang['strschemas'] = 'Esquemas'; + $lang['strshowallschemas'] = 'Listar todos os esquemas'; + $lang['strnoschema'] = 'Non se atopou esquema algún.'; + $lang['strnoschemas'] = 'Non se atopou esquema algún.'; + $lang['strcreateschema'] = 'Crear un esquema'; + $lang['strschemaname'] = 'Nome do esquema'; + $lang['strschemaneedsname'] = 'Debe fornecer un nome para o esquema.'; + $lang['strschemacreated'] = 'Creouse o esquema.'; + $lang['strschemacreatedbad'] = 'Non se conseguiu crear o esquema.'; + $lang['strconfdropschema'] = 'Está seguro de que quere eliminar o esquema «%s»?'; + $lang['strschemadropped'] = 'Eliminouse o esquema.'; + $lang['strschemadroppedbad'] = 'Non se conseguiu eliminar o esquema.'; + $lang['strschemaaltered'] = 'Modificouse o esquema.'; + $lang['strschemaalteredbad'] = 'Non se conseguiu modificar o esquema.'; + $lang['strsearchpath'] = 'Ruta de busca do esquema'; + $lang['strspecifyschematodrop'] = 'Debe especificar polo menos un esquema a eliminar.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Dominio'; + $lang['strdomains'] = 'Dominios'; + $lang['strshowalldomains'] = 'Listar todos os dominios'; + $lang['strnodomains'] = 'Non se atopou dominio algún.'; + $lang['strcreatedomain'] = 'Crear un dominio'; + $lang['strdomaindropped'] = 'Eliminouse o dominio.'; + $lang['strdomaindroppedbad'] = 'Non se conseguiu eliminar o dominio.'; + $lang['strconfdropdomain'] = 'Está seguro de que quere eliminar o dominio «%s»?'; + $lang['strdomainneedsname'] = 'Debe fornecer un nome para o dominio.'; + $lang['strdomaincreated'] = 'Creouse o dominio.'; + $lang['strdomaincreatedbad'] = 'Non se conseguiu crear o dominio.'; + $lang['strdomainaltered'] = 'Modificouse o dominio.'; + $lang['strdomainalteredbad'] = 'Non se conseguiu modificar o dominio.'; + + // Operators + $lang['stroperator'] = 'Operador'; + $lang['stroperators'] = 'Operadores'; + $lang['strshowalloperators'] = 'Listar todos os operadores'; + $lang['strnooperator'] = 'Non se atopou operador algún.'; + $lang['strnooperators'] = 'Non se atopou operador algún.'; + $lang['strcreateoperator'] = 'Crear un operador'; + $lang['strleftarg'] = 'Tipo do argumento esquerdo'; + $lang['strrightarg'] = 'Tipo do argumento dereito'; + $lang['strcommutator'] = 'Conmutador'; + $lang['strnegator'] = 'Negación'; + $lang['strrestrict'] = 'Restrinxir'; + $lang['strjoin'] = 'Unir'; + $lang['strhashes'] = 'Hashes'; // Non sei como traducilo. + $lang['strmerges'] = 'Mesturas'; + $lang['strleftsort'] = 'Ordenar pola esquerda'; + $lang['strrightsort'] = 'Ordenar pola dereita'; + $lang['strlessthan'] = 'Menor que'; + $lang['strgreaterthan'] = 'Maior que'; + $lang['stroperatorneedsname'] = 'Debe fornecer un nome para o operador.'; + $lang['stroperatorcreated'] = 'Creouse o operador.'; + $lang['stroperatorcreatedbad'] = 'Non se conseguiu crear o operador.'; + $lang['strconfdropoperator'] = 'Está seguro de que quere eliminar o operador «%s»?'; + $lang['stroperatordropped'] = 'Eliminouse o operador.'; + $lang['stroperatordroppedbad'] = 'Non se conseguiu eliminar o operador.'; + + // Casts + $lang['strcasts'] = 'Molde'; + $lang['strnocasts'] = 'Non se atopou molde algún.'; + $lang['strsourcetype'] = 'Tipo orixe'; + $lang['strtargettype'] = 'Tipo obxectivo'; + $lang['strimplicit'] = 'Implícito'; + $lang['strinassignment'] = 'Na asignación'; + $lang['strbinarycompat'] = '(Compatible a nivel binario)'; + + // Conversions + $lang['strconversions'] = 'Conversións'; + $lang['strnoconversions'] = 'Non se atopou conversión algunha.'; + $lang['strsourceencoding'] = 'Codificación orixinal'; + $lang['strtargetencoding'] = 'Codificación obxectivo'; + + // Languages + $lang['strlanguages'] = 'Linguas'; + $lang['strnolanguages'] = 'Non se atopou lingua algunha.'; + $lang['strtrusted'] = 'De confianza'; + + // Info + $lang['strnoinfo'] = 'Non hai información dispoñible.'; + $lang['strreferringtables'] = 'Táboas que fan referencia a esta'; + $lang['strparenttables'] = 'Táboas superiores'; + $lang['strchildtables'] = 'Táboas subordinadas'; + + // Aggregates + $lang['straggregate'] = 'Conxunto'; + $lang['straggregates'] = 'Conxuntos'; + $lang['strnoaggregates'] = 'Non se atopou conxunto algún.'; + $lang['stralltypes'] = '(Todos os tipos)'; + $lang['strcreateaggregate'] = 'Crear un conxunto'; + $lang['straggrbasetype'] = 'Tipo de dato de entrada'; + $lang['straggrsfunc'] = 'Función de cambio de estado'; + $lang['straggrstype'] = 'Tipo de dato para o valor do estado'; + $lang['straggrffunc'] = 'Función final'; + $lang['straggrinitcond'] = 'Condición inicial'; + $lang['straggrsortop'] = 'Operador de orde'; + $lang['strconfdropaggregate'] = 'Está seguro de que quere eliminar o conxunto «%s»?'; + $lang['straggregatedropped'] = 'Eliminouse o conxunto.'; + $lang['straggregatedroppedbad'] = 'Non se conseguiu eliminar o conxunto.'; + $lang['straggraltered'] = 'Modificouse o conxunto.'; + $lang['straggralteredbad'] = 'Non se conseguiu eliminar o conxunto.'; + $lang['straggrneedsname'] = 'Debe fornecer un nome para o conxunto.'; + $lang['straggrneedsbasetype'] = 'Debe fornecer un tipo de dato de entrada para o conxunto.'; + $lang['straggrneedssfunc'] = 'Debe fornecer o nome da función de cambio de estado para o conxunto.'; + $lang['straggrneedsstype'] = 'Debe fornecer un tipo de dato para o valor do estado do conxunto.'; + $lang['straggrcreated'] = 'Creouse o conxunto.'; + $lang['straggrcreatedbad'] = 'Non se conseguiu crear o conxunto.'; + $lang['straggrshowall'] = 'Listar todos os conxuntos'; + + // Operator Classes + $lang['stropclasses'] = 'Clases de operador'; + $lang['strnoopclasses'] = 'Non se atopor clase de operador algunha.'; + $lang['straccessmethod'] = 'Método de acceso'; + + // Stats and performance + $lang['strrowperf'] = 'Rendemento das filas'; + $lang['strioperf'] = 'Rendemento da entrada e saída'; + $lang['stridxrowperf'] = 'Rendemento das filas do índice'; + $lang['stridxioperf'] = 'Rendemento da entrada e saída do índice'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Secuencial'; + $lang['strscan'] = 'Explorar'; + $lang['strread'] = 'Ler'; + $lang['strfetch'] = 'Obter'; + $lang['strheap'] = 'Pila'; + $lang['strtoast'] = 'TOAST'; // Non traduzo por se son siglas, que non o teño claro. + $lang['strtoastindex'] = 'Ãndice TOAST'; + $lang['strcache'] = 'Caché'; + $lang['strdisk'] = 'Disco'; + $lang['strrows2'] = 'Filas'; + + // Tablespaces + $lang['strtablespace'] = 'Alias de ruta'; + $lang['strtablespaces'] = 'Alias de ruta'; + $lang['strshowalltablespaces'] = 'Listar todos os alias de ruta'; + $lang['strnotablespaces'] = 'Non se atopou alias de ruta algún.'; + $lang['strcreatetablespace'] = 'Crear un alias de ruta'; + $lang['strlocation'] = 'Lugar'; + $lang['strtablespaceneedsname'] = 'Debe fornecer un nome para o alias de ruta.'; + $lang['strtablespaceneedsloc'] = 'Debe fornecer unha ruta para a que crear o alias.'; + $lang['strtablespacecreated'] = 'Creouse o alias de ruta.'; + $lang['strtablespacecreatedbad'] = 'non se conseguiu crear o alias de ruta.'; + $lang['strconfdroptablespace'] = 'Está seguro de que quere borrar o alias de ruta «%s»?'; + $lang['strtablespacedropped'] = 'Eliminouse o alias de ruta.'; + $lang['strtablespacedroppedbad'] = 'Non se conseguiu eliminar o alias de ruta.'; + $lang['strtablespacealtered'] = 'Modificouse o alias de ruta.'; + $lang['strtablespacealteredbad'] = 'Non se conseguiu modificar o alias de ruta.'; + + // Miscellaneous + $lang['strtopbar'] = '%s, executándose no enderezo %s:%s. Está identificado coma «%s».'; + $lang['strtimefmt'] = 'd/m/Y, G:i:s'; + $lang['strhelp'] = 'Axuda'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Navegador das páxinas de axuda'; + $lang['strselecthelppage'] = 'Escolla unha páxina de axuda'; + $lang['strinvalidhelppage'] = 'Páxina de axuda incorrecta.'; + $lang['strlogintitle'] = 'Identificarse en %s'; + $lang['strlogoutmsg'] = 'Saíu de %s'; + $lang['strloading'] = 'Cargando...'; + $lang['strerrorloading'] = 'Produciuse un erro durante o proceso de carga'; + $lang['strclicktoreload'] = 'Prema aquí para recargar'; + + // Autovacuum + $lang['strautovacuum'] = 'Purgación automática'; + $lang['strturnedon'] = 'Acendido'; + $lang['strturnedoff'] = 'Apagado'; + $lang['strenabled'] = 'Activado'; + $lang['strnovacuumconf'] = 'Non se atopou ningunha configuración para purgacións automáticas.'; + $lang['strvacuumbasethreshold'] = 'Límite da base da purgación'; + $lang['strvacuumscalefactor'] = 'Factores de escala da purgación'; + $lang['stranalybasethreshold'] = 'Límite da base da análise'; + $lang['stranalyzescalefactor'] = 'Factores de escala da análise'; + $lang['strvacuumcostdelay'] = 'Atraso do custo da purgación'; + $lang['strvacuumcostlimit'] = 'Custo límite da purgación'; + $lang['strvacuumpertable'] = 'Configuración da purgación automática por táboa'; + $lang['straddvacuumtable'] = 'Engadir unha configuración de purgación automática dunha táboa'; + $lang['streditvacuumtable'] = 'Modificar a configuración de purgación automática da táboa «%s»'; + $lang['strdelvacuumtable'] = 'Está seguro de que quere eliminar a configuración de purgación automática da táboa «%s»?'; + $lang['strvacuumtablereset'] = 'A configuración de purgación automática da táboa «%s» restableceuse aos seus valores predeterminados'; + $lang['strdelvacuumtablefail'] = 'Non se conseguiu eliminar a configuración de purgación automática da táboa «%s»'; + $lang['strsetvacuumtablesaved'] = 'Gardouse a configuración de purgación automática da táboa «%s».'; + $lang['strsetvacuumtablefail'] = 'Non se conseguiu gardar a configuración de purgación automática da táboa «%s».'; + $lang['strspecifydelvacuumtable'] = 'Debe especificar unha táboa da que borrar os parámetros de purgación.'; + $lang['strspecifyeditvacuumtable'] = 'Debe especificar unha táboa na que modificar os parámetros de purgación.'; + $lang['strnotdefaultinred'] = 'Os valores que non sexan os predeterminados están en cor vermella.'; + + // Table-level Locks + $lang['strlocks'] = 'Bloqueos'; + $lang['strtransaction'] = 'Identificador da transacción'; + $lang['strvirtualtransaction'] = 'Identificador da transacción virtual'; + $lang['strprocessid'] = 'Identificador do proceso'; + $lang['strmode'] = 'Modo de bloqueo'; + $lang['strislockheld'] = 'Está activo o bloqueo?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Transaccións preparadas'; + $lang['strxactid'] = 'Identificador da transacción'; + $lang['strgid'] = 'Identificador global'; + + // Fulltext search + $lang['strfulltext'] = 'Busca de texto completa'; + $lang['strftsconfig'] = 'Configuración de BTC'; + $lang['strftsconfigs'] = 'Configuracións'; + $lang['strftscreateconfig'] = 'Crear unha configuración de BTC'; + $lang['strftscreatedict'] = 'Crear un dicionario'; + $lang['strftscreatedicttemplate'] = 'Crear un modelo de dicionario'; + $lang['strftscreateparser'] = 'Crear un analizador'; + $lang['strftsnoconfigs'] = 'Non se atopou configuración de BTC algunha.'; + $lang['strftsconfigdropped'] = 'Eliminouse a configuración de BTC.'; + $lang['strftsconfigdroppedbad'] = 'Non se conseguiu eliminar a configuración de BTC.'; + $lang['strconfdropftsconfig'] = 'Está seguro de que quere eliminar a configuración de BTC «%s»?'; + $lang['strconfdropftsdict'] = 'Está seguro de que quere eliminar o dicionario de BTC «%s»?'; + $lang['strconfdropftsmapping'] = 'Está seguro de que quere eliminar a aplicación «%s» da configuración de BTC «%s»?'; + $lang['strftstemplate'] = 'Modelo'; + $lang['strftsparser'] = 'Analizador'; + $lang['strftsconfigneedsname'] = 'Debe fornecer un nome para a configuración de BTC.'; + $lang['strftsconfigcreated'] = 'Creouse a configuración de BTC.'; + $lang['strftsconfigcreatedbad'] = 'non se conseguiu crear a configuración de BTC.'; + $lang['strftsmapping'] = 'Aplicación'; + $lang['strftsdicts'] = 'Dicionarios'; + $lang['strftsdict'] = 'Dicionario'; + $lang['strftsemptymap'] = 'Aplicación da configuración de BTC baleira.'; + $lang['strftsconfigaltered'] = 'Modificouse a configuración de BTC.'; + $lang['strftsconfigalteredbad'] = 'Non se conseguiu modificar a configuración de BTC.'; + $lang['strftsconfigmap'] = 'Aplicación da configuración de BTC'; + $lang['strftsparsers'] = 'Analizadores de BTC'; + $lang['strftsnoparsers'] = 'Non hai ningún analizador de BTC dispoñible.'; + $lang['strftsnodicts'] = 'Non hai ningún dicionario de BTC dispoñible.'; + $lang['strftsdictcreated'] = 'Creouse o dicionario de BTC.'; + $lang['strftsdictcreatedbad'] = 'Non se conseguiu crear o dicionario de BTC.'; + $lang['strftslexize'] = 'Análise léxica'; + $lang['strftsinit'] = 'Comezo'; + $lang['strftsoptionsvalues'] = 'Opcións e valores'; + $lang['strftsdictneedsname'] = 'Debe fornecer un nome para o dicionario de BTC.'; + $lang['strftsdictdropped'] = 'Eliminouse o dicionario de BTC.'; + $lang['strftsdictdroppedbad'] = 'Non se conseguiu eliminar o dicionario de BTC.'; + $lang['strftsdictaltered'] = 'Modificouse o dicionario de BTC.'; + $lang['strftsdictalteredbad'] = 'Non se conseguiu modifica o dicionario de BTC.'; + $lang['strftsaddmapping'] = 'Engadir unha nova aplicación'; + $lang['strftsspecifymappingtodrop'] = 'Debe especificar polo menos unha aplicación a eliminar.'; + $lang['strftsspecifyconfigtoalter'] = 'Debe especificar polo menos unha configuración de BTC a modificar'; + $lang['strftsmappingdropped'] = 'Eliminouse a aplicación de BTC.'; + $lang['strftsmappingdroppedbad'] = 'Non se conseguiu eliminar a aplicación de BTC.'; + $lang['strftsnodictionaries'] = 'Non se atopou dicionario algún.'; + $lang['strftsmappingaltered'] = 'Modificouse a aplicación de BTC.'; + $lang['strftsmappingalteredbad'] = 'Non se conseguiu modificar a aplicación de BTC.'; + $lang['strftsmappingadded'] = 'Engadiuse a aplicación de BTC.'; + $lang['strftsmappingaddedbad'] = 'Non se conseguiu engadir a aplicación de BTC.'; + $lang['strftstabconfigs'] = 'Configuracións'; + $lang['strftstabdicts'] = 'Dicionarios'; + $lang['strftstabparsers'] = 'Analizadores'; + $lang['strftscantparsercopy'] = 'Non se pode especificar tanto un analizador coma un modelo durante a creación dunha configuración de busca de texto.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/german.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/german.php new file mode 100644 index 00000000..a1a0a449 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/german.php @@ -0,0 +1,852 @@ + + * + * $Id: german.php,v 1.30 2008/02/18 23:06:51 ioguix Exp $ + */ + + // Language and character set + $lang['applang'] = 'Deutsch'; + $lang['applocale'] = 'de-DE'; + $lang['applangdir'] = 'ltr'; + + // Welcome + $lang['strintro'] = 'Willkommen bei phpPgAdmin.'; + $lang['strppahome'] = 'phpPgAdmin Homepage'; + $lang['strpgsqlhome'] = 'PostgreSQL Homepage'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'PostgreSQL Dokumentation (lokal)'; + $lang['strreportbug'] = 'Fehler melden'; + $lang['strviewfaq'] = 'Online-FAQ ansehen'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'Anmelden'; + $lang['strloginfailed'] = 'Anmeldung fehlgeschlagen'; + $lang['strlogindisallowed'] = 'Anmeldung aus Sicherheitsgründen verweigert.'; + $lang['strserver'] = 'Server'; + $lang['strservers'] = 'Server'; + $lang['strintroduction'] = 'Einführung'; + $lang['strhost'] = 'Host'; + $lang['strport'] = 'Port'; + $lang['strlogout'] = 'Abmelden'; + $lang['strowner'] = 'Besitzer'; + $lang['straction'] = 'Aktion'; + $lang['stractions'] = 'Aktionen'; + $lang['strname'] = 'Name'; + $lang['strdefinition'] = 'Definition'; + $lang['strproperties'] = 'Eigenschaften'; + $lang['strbrowse'] = 'Durchsuchen'; + $lang['strenable'] = 'Einschalten'; + $lang['strdisable'] = 'Ausschalten'; + $lang['strdrop'] = 'Löschen'; + $lang['strdropped'] = 'Gelöscht'; + $lang['strnull'] = 'Null'; + $lang['strnotnull'] = 'Nicht Null'; + $lang['strprev'] = '< Zurück'; + $lang['strnext'] = 'Weiter >'; + $lang['strfirst'] = '<< Anfang'; + $lang['strlast'] = 'Ende >>'; + $lang['strfailed'] = 'Fehlgeschlagen'; + $lang['strcreate'] = 'Erstellen'; + $lang['strcreated'] = 'Erstellt'; + $lang['strcomment'] = 'Kommentar'; + $lang['strlength'] = 'Länge'; + $lang['strdefault'] = 'Standardwert'; + $lang['stralter'] = 'Ändern'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Abbrechen'; + $lang['strac'] = 'Automatische Vervollständigung einschalten'; + $lang['strsave'] = 'Speichern'; + $lang['strreset'] = 'Zurücksetzen'; + $lang['strinsert'] = 'Einfügen'; + $lang['strselect'] = 'Abfrage'; + $lang['strdelete'] = 'Löschen'; + $lang['strupdate'] = 'Ändern'; + $lang['strreferences'] = 'Verweise'; + $lang['stryes'] = 'Ja'; + $lang['strno'] = 'Nein'; + $lang['strtrue'] = 'WAHR'; + $lang['strfalse'] = 'FALSCH'; + $lang['stredit'] = 'Bearbeiten'; + $lang['strcolumn'] = 'Spalte'; + $lang['strcolumns'] = 'Spalten'; + $lang['strrows'] = 'Datensätze'; + $lang['strrowsaff'] = 'Datensätze betroffen.'; + $lang['strobjects'] = 'Objekt(e)'; + $lang['strback'] = 'Zurück'; + $lang['strqueryresults'] = 'Abfrageergebnis'; + $lang['strshow'] = 'Anzeigen'; + $lang['strempty'] = 'Leeren'; + $lang['strlanguage'] = 'Sprache'; + $lang['strencoding'] = 'Zeichenkodierung'; + $lang['strvalue'] = 'Wert'; + $lang['strunique'] = 'Eindeutig'; + $lang['strprimary'] = 'Primär'; + $lang['strexport'] = 'Exportieren'; + $lang['strimport'] = 'Importieren'; + $lang['strallowednulls'] = 'NULL-Zeichen erlaubt'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Leere Zeichenkette / Leere Spalte'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Bereinigen'; + $lang['stranalyze'] = 'Analysieren'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'Geclustert?'; + $lang['strreindex'] = 'Reindexieren'; + $lang['strexecute'] = 'Ausführen'; + $lang['stradd'] = 'Hinzufügen'; + $lang['strevent'] = 'Ereignis'; + $lang['strwhere'] = 'Bedingung'; + $lang['strinstead'] = 'Tu stattdessen'; + $lang['strwhen'] = 'Wann'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Daten'; + $lang['strconfirm'] = 'Bestätigen'; + $lang['strexpression'] = 'Ausdruck'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Aufklappen'; + $lang['strcollapse'] = 'Zuklappen'; + $lang['strfind'] = 'Suchen'; + $lang['stroptions'] = 'Optionen'; + $lang['strrefresh'] = 'Aktualisieren'; + $lang['strdownload'] = 'Herunterladen'; + $lang['strdownloadgzipped'] = 'gzip-komprimiert herunterladen'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Erweitert'; + $lang['strvariables'] = 'Variable'; + $lang['strprocess'] = 'Prozess'; + $lang['strprocesses'] = 'Prozesse'; + $lang['strsetting'] = 'Einstellung'; + $lang['streditsql'] = 'SQL bearbeiten'; + $lang['strruntime'] = 'Laufzeit gesamt: %s ms'; + $lang['strpaginate'] = 'Ergebnisse seitenweise anzeigen'; + $lang['struploadscript'] = 'oder laden Sie ein SQL-Script hoch:'; + $lang['strstarttime'] = 'Beginnzeitpunkt'; + $lang['strfile'] = 'Datei'; + $lang['strfileimported'] = 'Datei importiert.'; + $lang['strtrycred'] = 'Diese Anmeldedaten für alle Server verwenden'; + $lang['strconfdropcred'] = 'Aus Sicherheitsgründen werden gemeinsamme Anmeldedaten beim Abmelden gelöscht. Sind Sie sicher, dass sie sich abmelden wollen?'; + $lang['stractionsonmultiplelines'] = 'Mehrzeilige Aktionen'; + $lang['strselectall'] = 'Alle auswählen'; + $lang['strunselectall'] = 'Alle abwählen'; + $lang['strlocale'] = 'Spracheinstellung'; + $lang['strcluster'] = 'Cluster'; + + // User-supplied SQL history + $lang['strhistory'] = 'Befehlsspeicher'; + $lang['strnohistory'] = 'Kein Befehlsspeicher.'; + $lang['strclearhistory'] = 'Befehlsspeicher löschen'; + $lang['strdelhistory'] = 'Aus dem Befehlsspeicher löschen'; + $lang['strconfdelhistory'] = 'Diese Abfrage wirklich aus dem Befehlsspeicher löschen?'; + $lang['strconfclearhistory'] = 'Befehlsspeicher wirklich löschen?'; + $lang['strnodatabaseselected'] = 'Bitte wählen Sie eine Datenbank aus.'; + + // Database sizes + $lang['strsize'] = 'Größe'; + $lang['strbytes'] = 'Bytes'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Diese Anwendung funktioniert am besten mit einem Browser, der Frames beherrscht, kann aber mit dem untenstehenden Link auch ohne Frames verwendet werden.'; + $lang['strnoframeslink'] = 'Ohne Frames arbeiten'; + $lang['strbadconfig'] = 'Ihre config.inc.php ist nicht aktuell. Sie müssen sie aus der config.inc.php-dist neu erzeugen.'; + $lang['strnotloaded'] = 'Ihre PHP-Installation unterstützt PostgreSQL nicht. Sie müssen PHP unter Verwendung der Konfigurationsoption --with-pgsql neu kompilieren.'; + $lang['strpostgresqlversionnotsupported'] = 'Ihre PostgreSQL-Version wird nicht unterstützt. Bitte stellen Sie Ihre Datenbank auf Version %s oder eine neuere Version um.'; + $lang['strbadschema'] = 'Ungültiges Schema angegeben.'; + $lang['strbadencoding'] = 'Kann die Client-Zeichenkodierung nicht in der Datenbank setzen.'; + $lang['strsqlerror'] = 'SQL-Fehler:'; + $lang['strinstatement'] = 'In der Anweisung:'; + $lang['strinvalidparam'] = 'Unzulässige Script-Parameter.'; + $lang['strnodata'] = 'Keine Datensätze gefunden.'; + $lang['strnoobjects'] = 'Keine Objekte gefunden.'; + $lang['strrownotunique'] = 'Dieser Datensatz hat keine eindeutige Spalte.'; + $lang['strnouploads'] = 'Das Hochladen von Dateien ist ausgeschaltet.'; + $lang['strimporterror'] = 'Importfehler.'; + $lang['strimporterror-fileformat'] = 'Importfehler: Dateiformat konnte nicht automatisch bestimmt werden.'; + $lang['strimporterrorline'] = 'Importfehler in Zeile %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Importfehler in Zeile %s: die Zeile hat nicht die richtige Anzahl von Spalten.'; + $lang['strimporterror-uploadedfile'] = 'Importfehler: die Datei konnte nicht auf den Server geladen werden'; + $lang['strcannotdumponwindows'] = 'Das Ablegen von komplizierten Tabellen- und Schemanamen wird auf Windows nicht unterstützt.'; + $lang['strinvalidserverparam'] = 'Es wurde versucht, mit einem ungültigen Server-Parameter eine Verbindung herzustellen. Möglicherweise versucht jemand, in Ihr System einzubrechen.'; + $lang['strnoserversupplied'] = 'Kein Server angegeben!'; + + // Tables + $lang['strtable'] = 'Tabelle'; + $lang['strtables'] = 'Tabellen'; + $lang['strshowalltables'] = 'Alle Tabellen anzeigen'; + $lang['strnotables'] = 'Keine Tabellen gefunden.'; + $lang['strnotable'] = 'Keine Tabelle gefunden.'; + $lang['strcreatetable'] = 'Neue Tabelle erstellen'; + $lang['strcreatetablelike'] = 'Neue Tabelle als Kopie einer bestehenden anlegen'; + $lang['strcreatetablelikeparent'] = 'Ursprüngliche Tabelle'; + $lang['strcreatelikewithdefaults'] = 'DEFAULT-Werte mitkopieren'; + $lang['strcreatelikewithconstraints'] = 'Constraints mitkopieren'; + $lang['strcreatelikewithindexes'] = 'Indizes mitkopieren'; + $lang['strtablename'] = 'Tabellenname'; + $lang['strtableneedsname'] = 'Sie müssen für die Tabelle einen Namen angeben.'; + $lang['strtablelikeneedslike'] = 'Sie müssen eine Tabelle angeben, deren Spaltendefinitionen kopiert werden sollen.'; + $lang['strtableneedsfield'] = 'Sie müssen mindestens eine Spalte angeben.'; + $lang['strtableneedscols'] = 'Sie müssen eine zulässige Anzahl von Spalten angeben.'; + $lang['strtablecreated'] = 'Tabelle erstellt.'; + $lang['strtablecreatedbad'] = 'Erstellen der Tabelle fehlgeschlagen.'; + $lang['strconfdroptable'] = 'Sind Sie sicher, dass Sie die Tabelle "%s" löschen möchten?'; + $lang['strtabledropped'] = 'Tabelle gelöscht.'; + $lang['strtabledroppedbad'] = 'Löschen der Tabelle fehlgeschlagen.'; + $lang['strconfemptytable'] = 'Sind Sie sicher, dass Sie den Inhalt der Tabelle "%s" löschen möchten?'; + $lang['strtableemptied'] = 'Tabelleninhalt gelöscht.'; + $lang['strtableemptiedbad'] = 'Löschen des Tabelleninhaltes fehlgeschlagen.'; + $lang['strinsertrow'] = 'Datensatz einfügen'; + $lang['strrowinserted'] = 'Datensatz eingefügt.'; + $lang['strrowinsertedbad'] = 'Einfügen des Datensatzes fehlgeschlagen.'; + $lang['strrowduplicate'] = 'Einfügen des Datensatzes fehlgeschlagen: es wurde versucht, ein Duplikat einzufügen.'; + $lang['streditrow'] = 'Datensatz bearbeiten'; + $lang['strrowupdated'] = 'Datensatz geändert.'; + $lang['strrowupdatedbad'] = 'Ändern des Datensatzes fehlgeschlagen.'; + $lang['strdeleterow'] = 'Datensatz löschen'; + $lang['strconfdeleterow'] = 'Sind Sie sicher, dass Sie diesen Datensatz löschen möchten?'; + $lang['strrowdeleted'] = 'Datensatz gelöscht.'; + $lang['strrowdeletedbad'] = 'Löschen des Datensatzes fehlgeschlagen.'; + $lang['strinsertandrepeat'] = 'Einfügen und Wiederholen'; + $lang['strnumcols'] = 'Anzahl der Spalten'; + $lang['strcolneedsname'] = 'Sie müssen einen Namen für die Spalte angeben'; + $lang['strselectallfields'] = 'Alle Felder auswählen'; + $lang['strselectneedscol'] = 'Sie müssen mindestens eine Spalte anzeigen lassen.'; + $lang['strselectunary'] = 'Unäre Operatoren können keine Werte haben.'; + $lang['strcolumnaltered'] = 'Spalte geändert.'; + $lang['strcolumnalteredbad'] = 'Ändern der Spalte fehlgeschlagen.'; + $lang['strconfdropcolumn'] = 'Sind Sie sicher, dass Sie die Spalte "%s" aus der Tabelle "%s" löschen möchten?'; + $lang['strcolumndropped'] = 'Spalte gelöscht.'; + $lang['strcolumndroppedbad'] = 'Löschen der Spalte fehlgschlagen.'; + $lang['straddcolumn'] = 'Spalte hinzufügen'; + $lang['strcolumnadded'] = 'Spalte hinzugefügt.'; + $lang['strcolumnaddedbad'] = 'Hinzufügen der Spalte fehlgeschlagen.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabelle geändert.'; + $lang['strtablealteredbad'] = 'Ändern der Tabelle fehlgeschlagen.'; + $lang['strdataonly'] = 'Nur die Daten'; + $lang['strstructureonly'] = 'Nur die Struktur'; + $lang['strstructureanddata'] = 'Struktur und Daten'; + $lang['strtabbed'] = 'Mit Tabluatoren'; + $lang['strauto'] = 'Automatisch'; + $lang['strconfvacuumtable'] = 'Sind sie sicher, dass Sie VACUUM auf "%s" ausführen wollen?'; + $lang['strconfanalyzetable'] = 'Sind sie sicher, dass Sie ANALYZE auf "%s" ausführen wollen?'; + $lang['strestimatedrowcount'] = 'Geschätzte Anzahl von Datensätzen'; + $lang['strspecifytabletoanalyze'] = 'Sie müssen mindestens eine Tabelle angeben, die analysiert werden soll.'; + $lang['strspecifytabletoempty'] = 'Sie müssen mindestens eine Tabelle angeben, deren Inhalt gelöscht werden soll.'; + $lang['strspecifytabletodrop'] = 'Sie müssen mindestens eine Tabelle angeben, die gelöscht werden soll.'; + $lang['strspecifytabletovacuum'] = 'Sie müssen mindestens eine Tabelle angeben, die bereinigt werden soll.'; + + // Columns + $lang['strcolprop'] = 'Spalteneigenschaften'; + $lang['strnotableprovided'] = 'Keine Tabelle angegeben!'; + + // Users + $lang['struser'] = 'Benutzer'; + $lang['strusers'] = 'Benutzer'; + $lang['strusername'] = 'Benutzername'; + $lang['strpassword'] = 'Passwort'; + $lang['strsuper'] = 'Superuser?'; + $lang['strcreatedb'] = 'Datenbank erstellen?'; + $lang['strexpires'] = 'Gültig bis'; + $lang['strsessiondefaults'] = 'Standardwerte für Datenbanksitzungen'; + $lang['strnousers'] = 'Keine Benutzer gefunden.'; + $lang['struserupdated'] = 'Benutzer geändert.'; + $lang['struserupdatedbad'] = 'Ändern des Benutzers fehlgeschlagen.'; + $lang['strshowallusers'] = 'Alle Benutzer anzeigen'; + $lang['strcreateuser'] = 'Benutzer anlegen'; + $lang['struserneedsname'] = 'Sie müssen einen Namen für den Benutzer angeben.'; + $lang['strusercreated'] = 'Benutzer angelegt.'; + $lang['strusercreatedbad'] = 'Anlegen des Benutzers fehlgeschlagen.'; + $lang['strconfdropuser'] = 'Sind Sie sicher, dass Sie den Benutzer "%s" löschen möchten?'; + $lang['struserdropped'] = 'Benutzer gelöscht.'; + $lang['struserdroppedbad'] = 'Löschen des Benutzers fehlgeschlagen.'; + $lang['straccount'] = 'Benutzerkonto'; + $lang['strchangepassword'] = 'Passwort ändern'; + $lang['strpasswordchanged'] = 'Passwort geändert.'; + $lang['strpasswordchangedbad'] = 'Ändern des Passwortes fehlgeschlagen.'; + $lang['strpasswordshort'] = 'Passwort ist zu kurz.'; + $lang['strpasswordconfirm'] = 'Passwort und Passwortbestätigung stimmen nicht überein.'; + + // Groups + $lang['strgroup'] = 'Gruppe'; + $lang['strgroups'] = 'Gruppen'; + $lang['strshowallgroups'] = 'Alle Gruppen anzeigen'; + $lang['strnogroup'] = 'Gruppe nicht gefunden.'; + $lang['strnogroups'] = 'Keine Gruppe gefunden.'; + $lang['strcreategroup'] = 'Gruppe anlegen'; + $lang['strgroupneedsname'] = 'Sie müssen für die Gruppe einen Namen angeben.'; + $lang['strgroupcreated'] = 'Gruppe angelegt.'; + $lang['strgroupcreatedbad'] = 'Anlegen der Gruppe fehlgeschlagen.'; + $lang['strconfdropgroup'] = 'Sind Sie sicher, dass Sie die Gruppe "%s" löschen möchten?'; + $lang['strgroupdropped'] = 'Gruppe gelöscht.'; + $lang['strgroupdroppedbad'] = 'Löschen der Gruppe fehlgeschlagen.'; + $lang['strmembers'] = 'Mitglieder'; + $lang['strmemberof'] = 'Mitglied von'; + $lang['stradminmembers'] = 'Administrative Mitglieder'; + $lang['straddmember'] = 'Mitglied hinzufügen'; + $lang['strmemberadded'] = 'Mitglied hinzugefügt.'; + $lang['strmemberaddedbad'] = 'Hinzufügen des Mitglieds fehlgeschlagen.'; + $lang['strdropmember'] = 'Mitglied löschen'; + $lang['strconfdropmember'] = 'Sind Sie sicher, dass Sie das Mitglied "%s" aus der Gruppe "%s" löschen wollen?'; + $lang['strmemberdropped'] = 'Mitglied gelöscht.'; + $lang['strmemberdroppedbad'] = 'Löschen des Mitglieds fehlgeschlagen.'; + + // Roles + $lang['strrole'] = 'Rolle'; + $lang['strroles'] = 'Rollen'; + $lang['strshowallroles'] = 'Alle Rollen anzeigen'; + $lang['strnoroles'] = 'Keine Rollen gefunden.'; + $lang['strinheritsprivs'] = 'Rechte vererben?'; + $lang['strcreaterole'] = 'Rolle anlegen'; + $lang['strcancreaterole'] = 'Darf Rollen anlegen?'; + $lang['strrolecreated'] = 'Rolle angelegt.'; + $lang['strrolecreatedbad'] = 'Anlegen der Rolle fehlgeschlagen.'; + $lang['strrolealtered'] = 'Rolle geändert.'; + $lang['strrolealteredbad'] = 'Ändern der Rolle fehlgeschlagen.'; + $lang['strcanlogin'] = 'Darf sich anmelden?'; + $lang['strconnlimit'] = 'Maximalzahl an Datenbankverbindungen'; + $lang['strdroprole'] = 'Rolle löschen'; + $lang['strconfdroprole'] = 'Sind Sie sicher, dass Sie die Rolle "%s" löschen möchten?'; + $lang['strroledropped'] = 'Rolle gelöscht.'; + $lang['strroledroppedbad'] = 'Löschen der Rolle fehlgeschlagen.'; + $lang['strnolimit'] = 'Unbeschränkt'; + $lang['strnever'] = 'Nie'; + $lang['strroleneedsname'] = 'Sie müssen für die Rolle einen Namen angeben.'; + + // Privileges + $lang['strprivilege'] = 'Recht'; + $lang['strprivileges'] = 'Rechte'; + $lang['strnoprivileges'] = 'Für dieses Objekt gelten die Standard-Eigentümerrechte.'; + $lang['strgrant'] = 'Rechte erteilen'; + $lang['strrevoke'] = 'Rechte entziehen'; + $lang['strgranted'] = 'Rechte geändert.'; + $lang['strgrantfailed'] = 'Ändern der Rechte fehlgeschlagen.'; + $lang['strgrantbad'] = 'Sie müssen mindestens einen Benutzer oder eine Gruppe und mindestens ein Recht angeben.'; + $lang['strgrantor'] = 'Recht vergeben von'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Datenbank'; + $lang['strdatabases'] = 'Datenbanken'; + $lang['strshowalldatabases'] = 'Alle Datenbanken anzeigen'; + $lang['strnodatabases'] = 'Keine Datenbanken gefunden.'; + $lang['strcreatedatabase'] = 'Datenbank erstellen'; + $lang['strdatabasename'] = 'Datenbankname'; + $lang['strdatabaseneedsname'] = 'Sie müssen für die Datenbank einen Namen angeben.'; + $lang['strdatabasecreated'] = 'Datenbank erstellt.'; + $lang['strdatabasecreatedbad'] = 'Erstellen der Datenbank fehlgeschlagen.'; + $lang['strconfdropdatabase'] = 'Sind Sie sicher, dass Sie die Datenbank "%s" löschen möchten?'; + $lang['strdatabasedropped'] = 'Datenbank gelöscht.'; + $lang['strdatabasedroppedbad'] = 'Löschen der Datenbank fehlgeschlagen.'; + $lang['strentersql'] = 'Auszuführende SQL-Anweisungen hier eingeben:'; + $lang['strsqlexecuted'] = 'SQL-Anweisungen ausgeführt.'; + $lang['strvacuumgood'] = 'Tabellenbereinigung abgeschlossen.'; + $lang['strvacuumbad'] = 'Tabellenbereinigung fehlgeschlagen.'; + $lang['stranalyzegood'] = 'Analyse abgeschlossen.'; + $lang['stranalyzebad'] = 'Analyse fehlgeschlagen.'; + $lang['strreindexgood'] = 'Neuindexierung abgeschlossen.'; + $lang['strreindexbad'] = 'Neuindexierung fehlgeschlagen.'; + $lang['strfull'] = 'Mit Reorganisation'; + $lang['strfreeze'] = 'Aggressives "Einfrieren"'; + $lang['strforce'] = 'Erzwingen'; + $lang['strsignalsent'] = 'Signal gesendet.'; + $lang['strsignalsentbad'] = 'Senden des Signales fehlgeschlagen.'; + $lang['strallobjects'] = 'Alle Objekte'; + $lang['strdatabasealtered'] = 'Datenbank geändert.'; + $lang['strdatabasealteredbad'] = 'Ändern der Datenbank fehlgeschlagen.'; + $lang['strspecifydatabasetodrop'] = 'Sie müssen mindestens eine Datenbank angeben, die gelöscht werden soll.'; + + // Views + $lang['strview'] = 'Sicht'; + $lang['strviews'] = 'Sichten'; + $lang['strshowallviews'] = 'Alle Sichten anzeigen'; + $lang['strnoview'] = 'Keine Sicht gefunden.'; + $lang['strnoviews'] = 'Keine Sichten gefunden.'; + $lang['strcreateview'] = 'Sicht erstellen'; + $lang['strviewname'] = 'Name der Sicht'; + $lang['strviewneedsname'] = 'Sie müssen für die Sicht einen Namen angeben.'; + $lang['strviewneedsdef'] = 'Sie müssen für die Sicht eine Definition angeben.'; + $lang['strviewneedsfields'] = 'Sie müssen die Spalten angeben, die sie in der Sicht haben wollen.'; + $lang['strviewcreated'] = 'Sicht erstellt.'; + $lang['strviewcreatedbad'] = 'Erstellen der Sicht fehlgeschlagen.'; + $lang['strconfdropview'] = 'Sind Sie sicher, dass Sie die Sicht "%s" löschen möchten?'; + $lang['strviewdropped'] = 'Sicht gelöscht.'; + $lang['strviewdroppedbad'] = 'Löschen der Sicht fehlgeschlagen.'; + $lang['strviewupdated'] = 'Sicht geändert.'; + $lang['strviewupdatedbad'] = 'Ändern der Sicht fehlgeschlagen.'; + $lang['strviewlink'] = 'Verbindende Schlüssel'; + $lang['strviewconditions'] = 'Zusätzliche Bedingungen'; + $lang['strcreateviewwiz'] = 'Sicht mit dem Assistenten erstellen'; + $lang['strrenamedupfields'] = 'Doppelte Spalten umbenennen'; + $lang['strdropdupfields'] = 'Doppelte Spalten entfernen'; + $lang['strerrordupfields'] = 'Fehler bei den doppelten Spalten'; + $lang['strviewaltered'] = 'Sicht geändert.'; + $lang['strviewalteredbad'] = 'Ändern der Sicht fehlgeschlagen.'; + $lang['strspecifyviewtodrop'] = 'Sie müssen mindestens eine Sicht angeben, die gelöscht werden soll.'; + + // Sequences + $lang['strsequence'] = 'Sequenz'; + $lang['strsequences'] = 'Sequenzen'; + $lang['strshowallsequences'] = 'Alle Sequenzen anzeigen'; + $lang['strnosequence'] = 'Keine Sequenz gefunden.'; + $lang['strnosequences'] = 'Keine Sequenzen gefunden.'; + $lang['strcreatesequence'] = 'Sequenz erstellen'; + $lang['strlastvalue'] = 'Letzter Wert'; + $lang['strincrementby'] = 'Erhöhen um'; + $lang['strstartvalue'] = 'Startwert'; + $lang['strmaxvalue'] = 'Maximalwert'; + $lang['strminvalue'] = 'Minimalwert'; + $lang['strcachevalue'] = 'Anzahl Werte im Cache'; + $lang['strlogcount'] = 'WAL-Zähler (log_cnt)'; + $lang['strcancycle'] = 'Zyklisch?'; + $lang['striscalled'] = 'Wird erhöht werden, wenn der nächste Wert angefordert wird (is_called)?'; + $lang['strsequenceneedsname'] = 'Sie müssen für die Sequenz einen Namen angeben.'; + $lang['strsequencecreated'] = 'Sequenz erstellt.'; + $lang['strsequencecreatedbad'] = 'Erstellen der Sequenz fehlgeschlagen.'; + $lang['strconfdropsequence'] = 'Sind Sie sicher, dass die die Sequenz "%s" löschen möchten?'; + $lang['strsequencedropped'] = 'Sequenz gelöscht.'; + $lang['strsequencedroppedbad'] = 'Löschen der Sequenz fehlgeschlagen.'; + $lang['strsequencereset'] = 'Sequenz zurückgesetzt.'; + $lang['strsequenceresetbad'] = 'Rücksetzen der Sequenz fehlgeschlagen.'; + $lang['strsequencealtered'] = 'Sequenz geändert.'; + $lang['strsequencealteredbad'] = 'Ändern der Sequenz fehlgeschlagen.'; + $lang['strsetval'] = 'Wert setzen'; + $lang['strsequencesetval'] = 'Sequenzwert gesetzt.'; + $lang['strsequencesetvalbad'] = 'Setzen des Sequenzwertes fehlgeschlagen.'; + $lang['strnextval'] = 'Wert erhöhen'; + $lang['strsequencenextval'] = 'Sequenzwert erhöht.'; + $lang['strsequencenextvalbad'] = 'Erhöhen des Sequenzwertes fehlgeschlagen.'; + $lang['strspecifysequencetodrop'] = 'Sie müssen mindestens eine Sequenz angeben, die gelöscht werden soll.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indizes'; + $lang['strindexname'] = 'Indexname'; + $lang['strshowallindexes'] = 'Alle Indizes anzeigen'; + $lang['strnoindex'] = 'Kein Index gefunden.'; + $lang['strnoindexes'] = 'Keine Indizes gefunden.'; + $lang['strcreateindex'] = 'Index erstellen'; + $lang['strtabname'] = 'Tabellenname'; + $lang['strcolumnname'] = 'Spaltenname'; + $lang['strindexneedsname'] = 'Sie müssen für den Index einen Namen angeben.'; + $lang['strindexneedscols'] = 'Sie müssen eine zulässige Anzahl an Spalten angeben.'; + $lang['strindexcreated'] = 'Index erstellt.'; + $lang['strindexcreatedbad'] = 'Erstellen des Index fehlgeschlagen.'; + $lang['strconfdropindex'] = 'Sind Sie sicher, dass sie den Index "%s" löschen möchten?'; + $lang['strindexdropped'] = 'Index gelöscht.'; + $lang['strindexdroppedbad'] = 'Löschen des Index fehlgeschlagen.'; + $lang['strkeyname'] = 'Schlüsselname'; + $lang['struniquekey'] = 'Eindeutiger Schlüssel'; + $lang['strprimarykey'] = 'Primärerschlüssel'; + $lang['strindextype'] = 'Typ des Index'; + $lang['strtablecolumnlist'] = 'Spalten in der Tabelle'; + $lang['strindexcolumnlist'] = 'Spalten im Index'; + $lang['strconfcluster'] = 'Sind Sie sicher, dass Sie "%s" clustern wollen?'; + $lang['strclusteredgood'] = 'Clustern abgeschlossen.'; + $lang['strclusteredbad'] = 'Clustern fehlgeschlagen.'; + + // Rules + $lang['strrules'] = 'Regeln'; + $lang['strrule'] = 'Regel'; + $lang['strshowallrules'] = 'Alle Regeln anzeigen'; + $lang['strnorule'] = 'Keine Regel gefunden.'; + $lang['strnorules'] = 'Keine Regeln gefunden.'; + $lang['strcreaterule'] = 'Regel erstellen'; + $lang['strrulename'] = 'Regelname'; + $lang['strruleneedsname'] = 'Sie müssen für die Regel einen Namen angeben.'; + $lang['strrulecreated'] = 'Regel erstellt.'; + $lang['strrulecreatedbad'] = 'Erstellen der Regel fehlgeschlagen.'; + $lang['strconfdroprule'] = 'Sind Sie sicher, dass Sie die Regel "%s" in der Tabelle "%s" löschen möchten?'; + $lang['strruledropped'] = 'Regel gelöscht.'; + $lang['strruledroppedbad'] = 'Löschen der Regel fehlgeschlagen.'; + + // Constraints + $lang['strconstraint'] = 'Constraint'; + $lang['strconstraints'] = 'Constraints'; + $lang['strshowallconstraints'] = 'Alle Constraints anzeigen'; + $lang['strnoconstraints'] = 'Keine Constraints gefunden.'; + $lang['strcreateconstraint'] = 'Constraint erstellen'; + $lang['strconstraintcreated'] = 'Constraint erstellt.'; + $lang['strconstraintcreatedbad'] = 'Erstellen des Constraints fehlgeschlagen.'; + $lang['strconfdropconstraint'] = 'Sind Sie sicher, dass Sie den Constraint "%s" in der Tabelle "%s" löschen möchten?'; + $lang['strconstraintdropped'] = 'Constraint gelöscht.'; + $lang['strconstraintdroppedbad'] = 'Löschen des Constraints fehlgeschlagen.'; + $lang['straddcheck'] = 'Check-Constraint hinzufügen'; + $lang['strcheckneedsdefinition'] = 'Ein Check-Constraint braucht eine Definition.'; + $lang['strcheckadded'] = 'Check-Constraint hinzugefügt.'; + $lang['strcheckaddedbad'] = 'Hinzufügen des Check-Constraints fehlgeschlagen.'; + $lang['straddpk'] = 'Primärschlüssel hinzufügen'; + $lang['strpkneedscols'] = 'Ein Primärschlüssel benötigt mindestens eine Spalte.'; + $lang['strpkadded'] = 'Primärschlüssel hinzugefügt.'; + $lang['strpkaddedbad'] = 'Hinzufügen des Primärschlüssels fehlgeschlagen.'; + $lang['stradduniq'] = 'Eindeutigen Schlüssel hinzufügen'; + $lang['struniqneedscols'] = 'Ein eindeutiger Schlüssel benötigt mindestens eine Spalte.'; + $lang['struniqadded'] = 'Eindeutiger Schlüssel hinzugefügt.'; + $lang['struniqaddedbad'] = 'Hinzufügen eines eindeutigen Schlüssels fehlgeschlagen.'; + $lang['straddfk'] = 'Fremdschlüssel hinzufügen'; + $lang['strfkneedscols'] = 'Ein Fremdschlüssel benötigt mindestens eine Spalte.'; + $lang['strfkneedstarget'] = 'Ein Fremdschlüssel benötigt eine Zieltabelle.'; + $lang['strfkadded'] = 'Fremdschlüssel hinzugefügt.'; + $lang['strfkaddedbad'] = 'Hinzufügen eines Fremdschlüssels fehlgeschlagen.'; + $lang['strfktarget'] = 'Zieltabelle'; + $lang['strfkcolumnlist'] = 'Spalten im Schlüssel'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Funktion'; + $lang['strfunctions'] = 'Funktionen'; + $lang['strshowallfunctions'] = 'Alle Funktionen anzeigen'; + $lang['strnofunction'] = 'Keine Funktion gefunden.'; + $lang['strnofunctions'] = 'Keine Funktionen gefunden.'; + $lang['strcreateplfunction'] = 'SQL/PL-Funktion erstellen'; + $lang['strcreateinternalfunction'] = 'Interne Funktion erstellen'; + $lang['strcreatecfunction'] = 'C-Funktion erstellen'; + $lang['strfunctionname'] = 'Funktionsname'; + $lang['strreturns'] = 'Rückgabetyp'; + $lang['strproglanguage'] = 'Programmiersprache'; + $lang['strfunctionneedsname'] = 'Sie müssen für die Funktion einen Namen angeben.'; + $lang['strfunctionneedsdef'] = 'Sie müssen für die Funktion eine Definition angeben.'; + $lang['strfunctioncreated'] = 'Funktion erstellt.'; + $lang['strfunctioncreatedbad'] = 'Erstellen der Funktion fehlgeschlagen.'; + $lang['strconfdropfunction'] = 'Sind Sie sicher, dass sie die Funktion "%s" löschen möchten?'; + $lang['strfunctiondropped'] = 'Funktion gelöscht.'; + $lang['strfunctiondroppedbad'] = 'Löschen der Funktion fehlgeschlagen.'; + $lang['strfunctionupdated'] = 'Funktion geändert.'; + $lang['strfunctionupdatedbad'] = 'Ändern der Funktion fehlgeschlagen.'; + $lang['strobjectfile'] = 'Objektdatei'; + $lang['strlinksymbol'] = 'Link-Symbol'; + $lang['strarguments'] = 'Funktionsargumente'; + $lang['strargmode'] = 'Richtung'; + $lang['strargtype'] = 'Datentyp'; + $lang['strargadd'] = 'Weiteres Argument hinzufügen'; + $lang['strargremove'] = 'Dieses Argument entfernen'; + $lang['strargnoargs'] = 'Diese Funktion kann nur ohne Argumente aufgerufen werden.'; + $lang['strargenableargs'] = 'Diese Funktion kann mit Argumenten aufgerufen werden.'; + $lang['strargnorowabove'] = 'Oberhalb dieser Spalte muss eine weitere Spalte sein.'; + $lang['strargnorowbelow'] = 'Unterhalb dieser Spalte muss eine weitere Spalte sein.'; + $lang['strargraise'] = 'Hinaufschieben.'; + $lang['strarglower'] = 'Hinunterschieben.'; + $lang['strargremoveconfirm'] = 'Sind Sie sicher, dass Sie dieses Argument entfernen wollen? Das kann nicht rückgängig gemacht werden.'; + $lang['strfunctioncosting'] = 'Ausführungskosten'; + $lang['strresultrows'] = 'Geschätzte Anzahl der Ergebniszeilen'; + $lang['strexecutioncost'] = 'Geschätzte Ausführungskosten'; + $lang['strspecifyfunctiontodrop'] = 'Sie müssen mindestens eine Funktion angeben, die gelöscht werden soll.'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Trigger'; + $lang['strshowalltriggers'] = 'Alle Trigger anzeigen'; + $lang['strnotrigger'] = 'Kein Trigger gefunden.'; + $lang['strnotriggers'] = 'Keine Trigger gefunden.'; + $lang['strcreatetrigger'] = 'Trigger erstellen'; + $lang['strtriggerneedsname'] = 'Sie müssen für den Trigger einen Namen angeben.'; + $lang['strtriggerneedsfunc'] = 'Sie müssen für den Trigger eine Funktion angeben.'; + $lang['strtriggercreated'] = 'Trigger erstellt.'; + $lang['strtriggercreatedbad'] = 'Erstellen des Triggers fehlgeschlagen.'; + $lang['strconfdroptrigger'] = 'Sind Sie sicher, dass Sie den Trigger "%s" auf der Tabelle "%s" löschen möchten?'; + $lang['strconfenabletrigger'] = 'Sind Sie sicher, dass Sie den Trigger "%s" auf der Tabelle "%s" aktivieren möchten?'; + $lang['strconfdisabletrigger'] = 'Sind Sie sicher, dass Sie den Trigger "%s" auf der Tabelle "%s" deaktivieren möchten?'; + $lang['strtriggerdropped'] = 'Trigger gelöscht.'; + $lang['strtriggerdroppedbad'] = 'Löschen des Triggers fehlgeschlagen.'; + $lang['strtriggerenabled'] = 'Trigger aktiviert.'; + $lang['strtriggerenabledbad'] = 'Aktivieren des Triggers fehlgeschlagen.'; + $lang['strtriggerdisabled'] = 'Trigger deaktiviert.'; + $lang['strtriggerdisabledbad'] = 'Deaktivieren des Triggers fehlgeschlagen.'; + $lang['strtriggeraltered'] = 'Trigger geändert.'; + $lang['strtriggeralteredbad'] = 'Ändern des Triggers fehlgeschlagen.'; + $lang['strforeach'] = 'Für alle'; + + // Types + $lang['strtype'] = 'Datentyp'; + $lang['strtypes'] = 'Datentypen'; + $lang['strshowalltypes'] = 'Alle Datentypen anzeigen'; + $lang['strnotype'] = 'Kein Datentyp gefunden.'; + $lang['strnotypes'] = 'Keine Datentypen gefunden.'; + $lang['strcreatetype'] = 'Datentyp erstellen'; + $lang['strcreatecomptype'] = 'Zusammengesetzten Typ erstellen'; + $lang['strcreateenumtype'] = 'Aufzählungstyp erstellen'; + $lang['strtypeneedsfield'] = 'Sie müssen mindestens ein Feld angeben.'; + $lang['strtypeneedsvalue'] = 'Sie müssen mindestens einen Wert angeben.'; + $lang['strtypeneedscols'] = 'Sie müssen eine gültige Anzahl von Spalten angeben.'; + $lang['strtypeneedsvals'] = 'Sie müssen eine gültige Anzahl von Werten angeben.'; + $lang['strinputfn'] = 'Eingabefunktion'; + $lang['stroutputfn'] = 'Ausgabefunktion'; + $lang['strpassbyval'] = 'Ãœbergabe "by value"?'; + $lang['stralignment'] = 'Alignment'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Trennzeichen'; + $lang['strstorage'] = 'Speicherung'; + $lang['strfield'] = 'Spalte'; + $lang['strnumfields'] = 'Anzahl Spalten'; + $lang['strnumvalues'] = 'Anzahl Werte'; + $lang['strtypeneedsname'] = 'Sie müssen einen Namen für den Datentyp angeben.'; + $lang['strtypeneedslen'] = 'Sie müssen eine Länge für den Datentyp angeben.'; + $lang['strtypecreated'] = 'Datentyp erstellt.'; + $lang['strtypecreatedbad'] = 'Erstellen des Datentypen fehlgeschlagen.'; + $lang['strconfdroptype'] = 'Sind Sie sicher, dass Sie den Datentyp "%s" löschen möchten?'; + $lang['strtypedropped'] = 'Datentyp gelöscht.'; + $lang['strtypedroppedbad'] = 'Löschen des Datentyps fehlgeschlagen.'; + $lang['strflavor'] = 'Art'; + $lang['strbasetype'] = 'Basis-Typ'; + $lang['strcompositetype'] = 'Zusammengesetzt'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'Aufzählend'; + $lang['strenumvalues'] = 'Wert'; + + // Schemas + $lang['strschema'] = 'Schema'; + $lang['strschemas'] = 'Schemata'; + $lang['strshowallschemas'] = 'Alle Schemata anzeigen'; + $lang['strnoschema'] = 'Kein Schema gefunden.'; + $lang['strnoschemas'] = 'Keine Schemata gefunden.'; + $lang['strcreateschema'] = 'Schema erstellen'; + $lang['strschemaname'] = 'Name des Schema'; + $lang['strschemaneedsname'] = 'Sie müssen für das Schema einen Namen angeben.'; + $lang['strschemacreated'] = 'Schema erstellt.'; + $lang['strschemacreatedbad'] = 'Erstellen des Schemas fehlgeschlagen.'; + $lang['strconfdropschema'] = 'Sind Sie sicher, dass sie das Schema "%s" löschen möchten?'; + $lang['strschemadropped'] = 'Schema gelöscht.'; + $lang['strschemadroppedbad'] = 'Löschen des Schemas fehlgeschlagen'; + $lang['strschemaaltered'] = 'Schema geändert.'; + $lang['strschemaalteredbad'] = 'Ändern des Schemas fehlgeschlagen.'; + $lang['strsearchpath'] = 'Schemasuchpfad'; + $lang['strspecifyschematodrop'] = 'Sie müssen mindestens ein Schema angeben, das gelöscht werden soll.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domäne'; + $lang['strdomains'] = 'Domänen'; + $lang['strshowalldomains'] = 'Alle Domänen anzeigen'; + $lang['strnodomains'] = 'Keine Domänen gefunden.'; + $lang['strcreatedomain'] = 'Domäne erstellen'; + $lang['strdomaindropped'] = 'Domäne gelöscht.'; + $lang['strdomaindroppedbad'] = 'Löschen der Domäne fehlgeschlagen.'; + $lang['strconfdropdomain'] = 'Sind Sie sicher, dass Sie die Domäne "%s" löschen wollen?'; + $lang['strdomainneedsname'] = 'Sie müssen einen Namen für die Domäne angeben.'; + $lang['strdomaincreated'] = 'Domäne erstellt.'; + $lang['strdomaincreatedbad'] = 'Erstellen der Domäne fehlgeschlagen.'; + $lang['strdomainaltered'] = 'Domäne geändert.'; + $lang['strdomainalteredbad'] = 'Ändern der Domäne fehlgeschlagen.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operatoren'; + $lang['strshowalloperators'] = 'Alle Operatoren anzeigen'; + $lang['strnooperator'] = 'Kein Operator gefunden.'; + $lang['strnooperators'] = 'Keine Operatoren gefunden.'; + $lang['strcreateoperator'] = 'Operator erstellen'; + $lang['strleftarg'] = 'Typ des linken Arguments'; + $lang['strrightarg'] = 'Typ des rechter Arguments'; + $lang['strcommutator'] = 'Kommutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Funktion zur Schätzung der Restriktions-Selektivität'; + $lang['strjoin'] = 'Funktion zur Schätzung der Join-Selektivität'; + $lang['strhashes'] = 'Unterstützt Hash-Joins'; + $lang['strmerges'] = 'Unterstützt Merge-Joins'; + $lang['strleftsort'] = 'Kleiner-Operator zum Sortieren der linken Seite'; + $lang['strrightsort'] = 'Kleiner-Operator zum Sortieren der rechten Seite'; + $lang['strlessthan'] = 'Kleiner-Operator'; + $lang['strgreaterthan'] = 'Größer-Operator'; + $lang['stroperatorneedsname'] = 'Sie müssen einen Namen für den Operator angeben.'; + $lang['stroperatorcreated'] = 'Operator erstellt.'; + $lang['stroperatorcreatedbad'] = 'Erstellen des Operators fehlgeschlagen.'; + $lang['strconfdropoperator'] = 'Sind Sie sicher, dass Sie den Operator "%s" löschen wollen?'; + $lang['stroperatordropped'] = 'Operator gelöscht.'; + $lang['stroperatordroppedbad'] = 'Löschen des Operators fehlgeschlagen.'; + + // Casts + $lang['strcasts'] = 'Typumwandlungen'; + $lang['strnocasts'] = 'Keine Typumwandlungen gefunden.'; + $lang['strsourcetype'] = 'Ursprungs-Datentyp'; + $lang['strtargettype'] = 'Ziel-Datentyp'; + $lang['strimplicit'] = 'Implizit'; + $lang['strinassignment'] = 'Bei Zuweisungen'; + $lang['strbinarycompat'] = '(Binärkompatibel)'; + + // Conversions + $lang['strconversions'] = 'Konvertierungen'; + $lang['strnoconversions'] = 'Keine Konvertierungen gefunden.'; + $lang['strsourceencoding'] = 'Ursprungs-Zeichenkodierung'; + $lang['strtargetencoding'] = 'Ziel-Zeichenkodierung'; + + // Languages + $lang['strlanguages'] = 'Programmiersprachen'; + $lang['strnolanguages'] = 'Keine Sprachen gefunden.'; + $lang['strtrusted'] = 'Vertrauenswürdig'; + + // Info + $lang['strnoinfo'] = 'Keine Informationen vorhanden.'; + $lang['strreferringtables'] = 'Tabellen, die mit Fremdschlüsseln auf diese Tabelle verweisen'; + $lang['strparenttables'] = 'Elterntabellen'; + $lang['strchildtables'] = 'Kindtabellen'; + + // Aggregates + $lang['straggregate'] = 'Aggregatsfunktion'; + $lang['straggregates'] = 'Aggregatsfunktionen'; + $lang['strnoaggregates'] = 'Keine Aggregatsfunktionen gefunden.'; + $lang['stralltypes'] = '(Alle Typen)'; + $lang['strcreateaggregate'] = 'Aggregatsfunktion erstellen'; + $lang['straggrbasetype'] = 'Eingabedatentyp'; + $lang['straggrsfunc'] = 'Zustandsübergangsfunktion'; + $lang['straggrstype'] = 'Datentyp für den Zustandswert'; + $lang['straggrffunc'] = 'Ergebnisfunktion'; + $lang['straggrinitcond'] = 'Zustandswert zu Beginn'; + $lang['straggrsortop'] = 'Operator für Sortierung'; + $lang['strconfdropaggregate'] = 'Sind Sie sicher, dass Sie die Aggregatsfunktion "%s" löschen wollen?'; + $lang['straggregatedropped'] = 'Aggregatsfunktion gelöscht.'; + $lang['straggregatedroppedbad'] = 'Löschen der Aggregatsfunktion fehlgeschlagen.'; + $lang['straggraltered'] = 'Aggregatsfunktion geändert.'; + $lang['straggralteredbad'] = 'Ändern der Aggregatsfunktion fehlgeschlagen.'; + $lang['straggrneedsname'] = 'Sie müssen einen Namen für die Aggregatsfunktion angeben.'; + $lang['straggrneedsbasetype'] = 'Sie müssen den Eingabedatentyp für die Aggregatsfunktion angeben.'; + $lang['straggrneedssfunc'] = 'Sie müssen den Namen der Zustandsübergangsfunktion für die Aggregatsfunktion angeben.'; + $lang['straggrneedsstype'] = 'Sie müssen den Datentyp für den Zustandswert der Aggregatsfunktion angeben.'; + $lang['straggrcreated'] = 'Aggregatsfunktion erstellt.'; + $lang['straggrcreatedbad'] = 'Erstellen der Aggregatsfunktion fehlgeschlagen.'; + $lang['straggrshowall'] = 'Alle Aggregatsfunktionen anzeigen'; + + // Operator Classes + $lang['stropclasses'] = 'Operatorklassen'; + $lang['strnoopclasses'] = 'Keine Operatorklassen gefunden.'; + $lang['straccessmethod'] = 'Zugriffsmethode'; + + // Stats and performance + $lang['strrowperf'] = 'Zeilen-Performance'; + $lang['strioperf'] = 'E/A Performance'; + $lang['stridxrowperf'] = 'Index-Zeilen-Performance'; + $lang['stridxioperf'] = 'Index-E/A-Performance'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequentiell'; + $lang['strscan'] = 'Durchsuchen'; + $lang['strread'] = 'Lesen'; + $lang['strfetch'] = 'Holen'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST-Index'; + $lang['strcache'] = 'Zwischenspeicher'; + $lang['strdisk'] = 'Festplatte'; + $lang['strrows2'] = 'Zeilen'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaces'; + $lang['strshowalltablespaces'] = 'Alle Tablespaces anzeigen'; + $lang['strnotablespaces'] = 'Keine Tablespaces gefunden.'; + $lang['strcreatetablespace'] = 'Tablespace erstellen'; + $lang['strlocation'] = 'Pfad'; + $lang['strtablespaceneedsname'] = 'Sie müssen einen Namen für den Tablespace angeben.'; + $lang['strtablespaceneedsloc'] = 'Sie müssen ein Verzeichnis angeben, in dem Sie den Tablespace erstellen möchten.'; + $lang['strtablespacecreated'] = 'Tablespace erstellt.'; + $lang['strtablespacecreatedbad'] = 'Erstellen des Tablespace fehlgeschlagen.'; + $lang['strconfdroptablespace'] = 'Sind Sie sicher, dass Sie den Tablespace "%s" löschen wollen?'; + $lang['strtablespacedropped'] = 'Tablespace gelöscht.'; + $lang['strtablespacedroppedbad'] = 'Löschen des Tablespace fehlgeschlagen.'; + $lang['strtablespacealtered'] = 'Tablespace geändert.'; + $lang['strtablespacealteredbad'] = 'Ändern des Tablespace fehlgeschlagen.'; + + // Miscellaneous + $lang['strtopbar'] = '%s läuft auf %s:%s -- Sie sind als "%s" angemeldet'; + $lang['strtimefmt'] = 'D, j. n. Y, G:i'; + $lang['strhelp'] = 'Hilfe'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Browser für Hilfeseiten'; + $lang['strselecthelppage'] = 'Hilfeseite auswählen'; + $lang['strinvalidhelppage'] = 'Ungültige Hilfeseite.'; + $lang['strlogintitle'] = 'Bei %s anmelden'; + $lang['strlogoutmsg'] = 'Von %s abgemeldet'; + $lang['strloading'] = 'Lade...'; + $lang['strerrorloading'] = 'Fehler beim Laden'; + $lang['strclicktoreload'] = 'Klicken Sie zum Neuladen'; + + // Autovacuum + $lang['strautovacuum'] = 'Autovacuum'; + $lang['strturnedon'] = 'Eingeschaltet'; + $lang['strturnedoff'] = 'Ausgeschaltet'; + $lang['strenabled'] = 'Aktiviert'; + $lang['strvacuumbasethreshold'] = 'Autovacuum-Schwellwert'; + $lang['strvacuumscalefactor'] = 'Autovacuum-Skalierungsfaktor'; + $lang['stranalybasethreshold'] = 'Analyze-Schwellwert'; + $lang['stranalyzescalefactor'] = 'Analyze-Skalierungsfaktor'; + $lang['strvacuumcostdelay'] = 'Pause nach Erreichen des Autovacuum-Kostenlimits'; + $lang['strvacuumcostlimit'] = 'Autovacuum-Kostenlimits'; + + // Table-level Locks + $lang['strlocks'] = 'Sperren'; + $lang['strtransaction'] = 'Transaktions-ID'; + $lang['strvirtualtransaction'] = 'Virtuelle Transaktions-ID'; + $lang['strprocessid'] = 'Prozess-ID'; + $lang['strmode'] = 'Art der Sperre'; + $lang['strislockheld'] = 'Sperre gewährt?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Vorbereitete verteilte Transaktionen'; + $lang['strxactid'] = 'Transaktions-ID'; + $lang['strgid'] = 'Globale ID'; + + // Fulltext search + $lang['strfulltext'] = 'Volltextsuche'; + $lang['strftsconfig'] = 'Volltextsuch-Konfiguration'; + $lang['strftsconfigs'] = 'Konfigurationen'; + $lang['strftscreateconfig'] = 'Volltextsuch-Konfiguration erstellen'; + $lang['strftscreatedict'] = 'Wörterbuch erstellen'; + $lang['strftscreatedicttemplate'] = 'Wörterbuch-Blaupause erstellen'; + $lang['strftscreateparser'] = 'Parser erstellen'; + $lang['strftsnoconfigs'] = 'Keine Volltextsuch-Konfigurationen gefunden.'; + $lang['strftsconfigdropped'] = 'Volltextsuch-Konfiguration gelöscht.'; + $lang['strftsconfigdroppedbad'] = 'Löschen der Volltextsuch-Konfiguration fehlgeschlagen.'; + $lang['strconfdropftsconfig'] = 'Sind Sie sicher, dass Sie die Volltextsuch-Konfiguration "%s" löschen möchten?'; + $lang['strconfdropftsdict'] = 'Sind Sie sicher, dass Sie das Wörterbuch "%s" löschen möchten?'; + $lang['strconfdropftsmapping'] = 'Sind Sie sicher, dass Sie die Zuordnung "%s" der Volltextsuch-Konfiguration "%s" löschen möchten?'; + $lang['strftstemplate'] = 'Blaupause'; + $lang['strftsparser'] = 'Parser'; + $lang['strftsconfigneedsname'] = 'Sie müssen für die Volltextsuch-Konfiguration einen Namen angeben.'; + $lang['strftsconfigcreated'] = 'Volltextsuch-Konfiguration erstellt.'; + $lang['strftsconfigcreatedbad'] = 'Erstellen der Volltextsuch-Konfiguration fehlgeschlagen.'; + $lang['strftsmapping'] = 'Zuordnung'; + $lang['strftsdicts'] = 'Wörterbücher'; + $lang['strftsdict'] = 'Wörterbuch'; + $lang['strftsemptymap'] = 'Leere Zuordnung für Volltextsuch-Konfiguration.'; + $lang['strftswithmap'] = 'Mit Zuordnung'; + $lang['strftsmakedefault'] = 'Als Standardwert für die angegebene Spracheinstellung festlegen'; + $lang['strftsconfigaltered'] = 'Volltextsuch-Konfiguration geändert.'; + $lang['strftsconfigalteredbad'] = 'Ändern der Volltextsuch-Konfiguration fehlgeschlagen.'; + $lang['strftsconfigmap'] = 'Zuordnung für Volltextsuch-Konfiguration'; + $lang['strftsparsers'] = 'Parsers für Volltextsuch-Konfiguration'; + $lang['strftsnoparsers'] = 'Keine Parsers für Volltextsuch-Konfiguration vorhanden'; + $lang['strftsnodicts'] = 'Keine Wörterbücher für die Volltextsuche vorhanden.'; + $lang['strftsdictcreated'] = 'Wörterbuch für die Volltextsuche erstellt.'; + $lang['strftsdictcreatedbad'] = 'Erstellen des Wörterbuches für die Volltextsuche fehlgeschlagen.'; + $lang['strftslexize'] = 'Funktion zum Zerlegen in Lexeme'; + $lang['strftsinit'] = 'Initialisierungsfunktion'; + $lang['strftsoptionsvalues'] = 'Optionen und Werte'; + $lang['strftsdictneedsname'] = 'Sie müssen für das Volltextsuch-Wörterbuch einen Namen angeben.'; + $lang['strftsdictdropped'] = 'Wörterbuches für die Volltextsuche gelöscht.'; + $lang['strftsdictdroppedbad'] = 'Löschen des Wörterbuches für die Volltextsuche fehlgeschlagen.'; + $lang['strftsdictaltered'] = 'Wörterbuches für die Volltextsuche geändert.'; + $lang['strftsdictalteredbad'] = 'Ändern des Wörterbuches für die Volltextsuche fehlgeschlagen.'; + $lang['strftsaddmapping'] = 'Neue Zuordnung hinzufügen'; + $lang['strftsspecifymappingtodrop'] = 'Sie müssen mindestens eine Zuordnung angeben, die gelöscht werden soll.'; + $lang['strftsspecifyconfigtoalter'] = 'Sie müssen eine Volltextsuch-Konfiguration angeben, die geändert werden soll'; + $lang['strftsmappingdropped'] = 'Volltextsuch-Zuordnung gelöscht.'; + $lang['strftsmappingdroppedbad'] = 'Löschen der Volltextsuch-Zuordnung fehlgeschlagen.'; + $lang['strftsnodictionaries'] = 'Keine Wörterbücher gefunden.'; + $lang['strftsmappingaltered'] = 'Volltextsuch-Zuordnung geändert.'; + $lang['strftsmappingalteredbad'] = 'Ändern der Volltextsuch-Zuordnung fehlgeschlagen.'; + $lang['strftsmappingadded'] = 'Volltextsuch-Zuordnung hinzugefügt.'; + $lang['strftsmappingaddedbad'] = 'Hinzufügen der Volltextsuch-Zuordnung fehlgeschlagen.'; + $lang['strftstabconfigs'] = 'Volltextsuch-Konfigurationen'; + $lang['strftstabdicts'] = 'Wörterbücher'; + $lang['strftstabparsers'] = 'Parser'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/greek.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/greek.php new file mode 100644 index 00000000..89f8f9e6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/greek.php @@ -0,0 +1,744 @@ +'; + $lang['strfirst'] = '<< ΠÏώτη'; + $lang['strlast'] = 'Τελευταία >>'; + $lang['strfailed'] = 'Απέτυχε'; + $lang['strcreate'] = 'ΔημιουÏγία'; + $lang['strcreated'] = 'ΔημιουÏγήθηκε'; + $lang['strcomment'] = 'Σχόλιο'; + $lang['strlength'] = 'Μήκος'; + $lang['strdefault'] = 'ΑÏχική τιμή'; + $lang['stralter'] = 'ΤÏοποποίηση'; + $lang['strok'] = 'Εντάξει'; + $lang['strcancel'] = 'ΑκυÏο'; + $lang['strac'] = 'ΕνεÏγοποίηση Αυτόματης ΣυμπλήÏωσης (AutoComplete)'; + $lang['strsave'] = 'Αποθήκευση'; + $lang['strreset'] = 'ΚαθαÏισμός'; + $lang['strinsert'] = 'Εισαγωγή'; + $lang['strselect'] = 'Επιλογή'; + $lang['strdelete'] = 'ΔιαγÏαφή'; + $lang['strupdate'] = 'ΕνημέÏωση'; + $lang['strreferences'] = 'Σχέσεις'; + $lang['stryes'] = 'Îαι'; + $lang['strno'] = 'Οχι'; + $lang['strtrue'] = 'ΑΛΗΘΕΣ'; + $lang['strfalse'] = 'ΨΕΥΔΕΣ'; + $lang['stredit'] = 'ΠÏοσαÏμογή'; + $lang['strcolumn'] = 'Στήλη'; + $lang['strcolumns'] = 'Στήλες'; + $lang['strrows'] = 'γÏαμμές'; + $lang['strrowsaff'] = 'γÏαμμές επηÏεάστηκαν.'; + $lang['strobjects'] = 'αντικείμενα'; + $lang['strback'] = 'Πίσω'; + $lang['strqueryresults'] = 'Αποτελέσματα ΕÏωτήματος'; + $lang['strshow'] = 'Εμφάνιση'; + $lang['strempty'] = 'Αδειασμα'; + $lang['strlanguage'] = 'Γλώσσα'; + $lang['strencoding'] = 'Κωδικοποίηση'; + $lang['strvalue'] = 'Τιμή'; + $lang['strunique'] = 'Μοναδικό'; + $lang['strprimary'] = 'ΠÏωτεÏον'; + $lang['strexport'] = 'Εξαγωγή'; + $lang['strimport'] = 'Εισαγωγή'; + $lang['strallowednulls'] = 'ΕπιτÏεπόμενοι κενοί χαÏακτήÏες'; + $lang['strbackslashn'] = '\N'; + $lang['strnull'] = 'κενό'; + $lang['stremptystring'] = 'κενή συμβολοσειÏά/κενό πεδίο'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'ΔιαχείÏιση'; + $lang['strvacuum'] = 'Εκκένωση'; + $lang['stranalyze'] = 'Ανάλυση'; + $lang['strclusterindex'] = 'Ομαδοποίηση'; + $lang['strclustered'] = 'Ομαδοποιημένο'; + $lang['strreindex'] = 'Ανανέωση ΕυÏετηÏίου'; + $lang['stradd'] = 'ΠÏοσθήκη'; + $lang['strevent'] = 'ΕνέÏγεια'; + $lang['strwhere'] = 'Οπου'; + $lang['strinstead'] = 'Αντί να'; + $lang['strwhen'] = 'Πότε'; + $lang['strformat'] = 'ΜοÏφή δεδομένων'; + $lang['strdata'] = 'Δεδομένα'; + $lang['strconfirm'] = 'Επιβεβαίωση'; + $lang['strexpression'] = 'ΕκφÏαση'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Ανάπτυξη'; + $lang['strcollapse'] = 'ΣÏμπτυξη'; + $lang['strfind'] = 'Αναζήτηση'; + $lang['stroptions'] = 'Επιλογές'; + $lang['strrefresh'] = 'Ανανέωση'; + $lang['strdownload'] = 'ΚαταφόÏτωση'; + $lang['strdownloadgzipped'] = 'Συμπίεση κατά gzip'; + $lang['strinfo'] = 'ΠληÏοφοÏίες'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'ΠÏοχωÏημένα'; + $lang['strvariables'] = 'Μεταβλητές'; + $lang['strprocess'] = 'ΔιεÏγασία'; + $lang['strprocesses'] = 'ΔιεÏγασίες'; + $lang['strsetting'] = 'Τιμή'; + $lang['streditsql'] = 'ΕπεξεÏγασία SQL'; + $lang['strruntime'] = 'Συνολικός χÏόνος εκτέλεσης: %s ms'; + $lang['strpaginate'] = 'Σελιδοποίηση'; + $lang['struploadscript'] = 'ή ανεβάστε σενάÏιο (script) SQL:'; + $lang['strstarttime'] = 'ΩÏα ΕναÏξης'; + $lang['strfile'] = 'ΑÏχείο'; + $lang['strfileimported'] = 'ΑÏχείο εισήχθη.'; + $lang['strtrycred'] = 'ΧÏήση αυτών των διαπιστευτηÏίων για όλους τους διακομιστές'; + $lang['strexecute'] = 'Εκτέλεση'; + + // Database Sizes + $lang['strsize'] = 'Μέγεθος'; + $lang['strbytes'] = 'bytes'; + $lang['strkb'] = 'KB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Το phpPgAdmin λειτουÏγεί καλÏτεÏα με Ï€ÏογÏάμματα πλοήγησης που υποστηÏίζουν πλαίσια (frames). Εαν επιθυμείτε να συνεχίσετε ακολουθήστε την παÏακάτω σÏνδεση.'; + $lang['strnoframeslink'] = 'ΧÏήση χωÏίς πλαίσια'; + $lang['strbadconfig'] = 'Το αÏχείο config.inc.php είναι παλιό. ΕπαναδημιουÏγήστε το χÏησιμοποιώντας το config.inc.php-dist.'; + $lang['strnotloaded'] = 'Η Ï„Ïέχουσα εγκατάσταση της PHP δεν υποστηÏίζει PostgreSQL. Εγκαταστήστε την πάλι με την επιλογή --with-pgsql (compilation option).'; + $lang['strpostgresqlversionnotsupported'] = 'Η Ï„Ïέχουσα έκδοση της PostgreSQL δεν υποστηÏίζεται από το phpPgAdmin. ΠαÏακαλώ αναβαθμίστε στην έκδοση %s ή νεότεÏη.'; + $lang['strbadschema'] = 'Το σχήμα που δηλώθηκε δεν είναι έγκυÏο.'; + $lang['strbadencoding'] = 'Αποτυχία οÏÎ¹ÏƒÎ¼Î¿Ï ÎºÏ‰Î´Î¹ÎºÎ¿Ï€Î¿Î¯Î·ÏƒÎ·Ï‚ στη βάση δεδομένων.'; + $lang['strsqlerror'] = 'Σφάλμα στην SQL:'; + $lang['strinstatement'] = 'Στη δήλωση:'; + $lang['strinvalidparam'] = 'Λάθος παÏάμετÏοι.'; + $lang['strnodata'] = 'Δε βÏέθηκαν γÏαμμές.'; + $lang['strnoobjects'] = 'Δε βÏέθηκαν αντικείμενα.'; + $lang['strrownotunique'] = 'Δε βÏέθηκε μοναδικό κλειδί στη γÏαμμή.'; + $lang['strnouploads'] = 'Η αποστολή αÏχείων είναι απενεÏγοποιημένη.'; + $lang['strimporterror'] = 'Σφάλμα κατά την εισαγωγή.'; + $lang['strimporterror-fileformat'] = 'Σφάλμα κατά την εισαγωγή: απέτυχε η αυτόματη αναγνώÏιση του Ï„Ïπου του αÏχείου.'; + $lang['strimporterrorline'] = 'Σφάλμα κατά την εισαγωγή της γÏαμμής %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Σφάλμα κατά την εισαγωγή της γÏαμμής %s: δεν πεÏιέχει το σωστό αÏιθμό στηλών.'; + $lang['strimporterror-uploadedfile'] = 'Σφάλμα κατά την εισαγωγή: αποτυχία αποστολής στο διακομιστή.'; + $lang['strcannotdumponwindows'] = 'Η αποτÏπωση (dumping) πεÏίπλοκων πινάκων και σχημάτων (schemas) δεν υποστηÏίζεται στα Windows.'; + + // Tables + $lang['strtable'] = 'Πίνακας'; + $lang['strtables'] = 'Πίνακες'; + $lang['strshowalltables'] = 'Εμφάνιση όλων των πινάκων'; + $lang['strnotables'] = 'Δεν βÏέθηκαν πίνακες.'; + $lang['strnotable'] = 'Δε βÏέθηκε πίνακας.'; + $lang['strcreatetable'] = 'ΔημιουÏγία πίνακα'; + $lang['strtablename'] = 'Ονομα πίνακα'; + $lang['strtableneedsname'] = 'ΠÏέπει να εισάγετε το όνομα του πίνακα.'; + $lang['strtableneedsfield'] = 'ΠÏέπει να εισάγετε τουλάχιστον ένα πεδίο.'; + $lang['strtableneedscols'] = 'ΠÏέπει να εισάγετε έγκυÏο αÏιθμό στηλών.'; + $lang['strtablecreated'] = 'Ο πίνακας δημιουÏγήθηκε.'; + $lang['strtablecreatedbad'] = 'Η δημιουÏγία του πίνακα απέτυχε.'; + $lang['strconfdroptable'] = 'ΔιαγÏαφή του πίνακα "%s"?'; + $lang['strtabledropped'] = 'Ο πίνακας διαγÏάφηκε.'; + $lang['strtabledroppedbad'] = 'Η διαγÏαφή του πίνακα απέτυχε.'; + $lang['strconfemptytable'] = 'ΔιαγÏαφή των πεÏιεχομένων του πίνακα "%s"?'; + $lang['strtableemptied'] = 'Τα πεÏιεχόμενα του πίνακα διαγÏάφηκαν.'; + $lang['strtableemptiedbad'] = 'Η διαγÏαφή των πεÏιεχομένων του πίνακα απέτυχε.'; + $lang['strinsertrow'] = 'Εισαγωγή γÏαμμής'; + $lang['strrowinserted'] = 'Η γÏαμμή εισήχθη.'; + $lang['strrowinsertedbad'] = 'H εισαγωγή της γÏαμμής απέτυχε.'; + $lang['strrowduplicate'] = 'H εισαγωγή της γÏαμμής απέτυχε, διπλή εγγÏαφή.'; + $lang['streditrow'] = 'ΕπεξεÏγασία γÏαμμής'; + $lang['strrowupdated'] = 'Η γÏαμμή ενημεÏώθηκε.'; + $lang['strrowupdatedbad'] = 'Η ενημέÏωση της γÏαμμής απέτυχε.'; + $lang['strdeleterow'] = 'ΔιαγÏαφή γÏαμμής'; + $lang['strconfdeleterow'] = 'ΔιαγÏαφή της γÏαμμής?'; + $lang['strrowdeleted'] = 'Η γÏαμμή διαγÏάφηκε.'; + $lang['strrowdeletedbad'] = 'Η διαγÏαφή της γÏαμμής απέτυχε.'; + $lang['strinsertandrepeat'] = 'Εισαγωγή και επανάληψη'; + $lang['strnumcols'] = 'ΑÏιθμός στηλών'; + $lang['strcolneedsname'] = 'ΠÏέπει να οÏίσετε το όνομα της στήλης'; + $lang['strselectallfields'] = 'Επιλογή όλων των πεδίων'; + $lang['strselectneedscol'] = 'ΠÏέπει να εμφανιστεί τουλάχιστον μία στήλη.'; + $lang['strselectunary'] = 'Οι μονοτελείς τελεστές (unary operators) δεν Ï€Ïέπει να έχουν τιμές.'; + $lang['strcolumnaltered'] = 'Η στήλη Ï„Ïοποποιήθηκε.'; + $lang['strcolumnalteredbad'] = 'Η Ï„Ïοποποίηση της στήλης απέτυχε.'; + $lang['strconfdropcolumn'] = 'ΔιαγÏαφή στήλης "%s" από τον πίνακα "%s"?'; + $lang['strcolumndropped'] = 'Η στήλη διαγÏάφηκε.'; + $lang['strcolumndroppedbad'] = 'Η διαγÏαφή της στήλης απέτυχε.'; + $lang['straddcolumn'] = 'Εισαγωγή στήλης'; + $lang['strcolumnadded'] = 'Η στήλη εισήχθη.'; + $lang['strcolumnaddedbad'] = 'Η εισαγωγή της στήλης απέτυχε.'; + $lang['strcascade'] = 'ΔΙΑΤΑΞΗ'; + $lang['strtablealtered'] = 'Ο πίνακας Ï„Ïοποποιήθηκε.'; + $lang['strtablealteredbad'] = 'Η Ï„Ïοποποίηση του πίνακα απέτυχε.'; + $lang['strdataonly'] = 'Μόνο τα δεδομένα'; + $lang['strstructureonly'] = 'Μόνο τη δομή'; + $lang['strstructureanddata'] = 'Δομή και δεδομένα'; + $lang['strtabbed'] = 'Με στηλοθέτες'; + $lang['strauto'] = 'Αυτόματα'; + $lang['strconfvacuumtable'] = 'Îα εκκενωθεί ο πίνακας "%s"?'; + $lang['strestimatedrowcount'] = 'Εκτιμώμενος αÏιθμός γÏαμμών'; + + // Columns + $lang['strcolprop'] = 'Ιδιότητες Στήλης'; + + // Users + $lang['struser'] = 'ΧÏήστη'; + $lang['strusers'] = 'ΧÏήστες'; + $lang['strusername'] = 'Ονομα χÏήστη'; + $lang['strpassword'] = 'Κωδικός χÏήστη'; + $lang['strsuper'] = 'ΥπεÏχÏήστης?'; + $lang['strcreatedb'] = 'ΔημιουÏγία βάσης?'; + $lang['strexpires'] = 'Λήξη'; + $lang['strsessiondefaults'] = 'Εξ οÏÎ¹ÏƒÎ¼Î¿Ï Ï€Î±ÏάμετÏοι συνεδÏίας'; + $lang['strnousers'] = 'Δε βÏέθηκαν χÏήστες.'; + $lang['struserupdated'] = 'Ο λογαÏιασμός χÏήστη ενημεÏώθηκε.'; + $lang['struserupdatedbad'] = 'Η ενημέÏωση του χÏήστη απέτυχε.'; + $lang['strshowallusers'] = 'Εμφάνιση όλων των χÏηστών'; + $lang['strcreateuser'] = 'ΔημιουÏγία χÏήστη'; + $lang['struserneedsname'] = 'ΠÏέπει να εισάγετε όνομα χÏήστη.'; + $lang['strusercreated'] = 'Ο χÏήστης δημιουÏγήθηκε.'; + $lang['strusercreatedbad'] = 'Η δημιουÏγία του χÏήστη απέτυχε.'; + $lang['strconfdropuser'] = 'ΔιαγÏαφή του χÏήστη "%s"?'; + $lang['struserdropped'] = 'Ο χÏήστης διαγÏάφηκε.'; + $lang['struserdroppedbad'] = 'Η διαγÏαφή του χÏήστη απέτυχε.'; + $lang['straccount'] = 'ΛογαÏιασμός'; + $lang['strchangepassword'] = 'Αλλαγή κωδικοÏ'; + $lang['strpasswordchanged'] = 'Ο κωδικός αλλάχθηκε.'; + $lang['strpasswordchangedbad'] = 'Η αλλαγή του ÎºÏ‰Î´Î¹ÎºÎ¿Ï Î±Ï€Î­Ï„Ï…Ï‡Îµ.'; + $lang['strpasswordshort'] = 'Ο κωδικός έχει Ï€Î¿Î»Ï Î¼Î¹ÎºÏÏŒ μήκος.'; + $lang['strpasswordconfirm'] = 'Σφάλμα στην επιβεβαίωση του κωδικοÏ.'; + + // Groups + $lang['strgroup'] = 'Ομάδα'; + $lang['strgroups'] = 'Ομάδες'; + $lang['strnogroup'] = 'Η ομάδα δε βÏέθηκε.'; + $lang['strnogroups'] = 'Δε βÏέθηκαν ομάδες.'; + $lang['strcreategroup'] = 'ΔημιουÏγία ομάδας'; + $lang['strshowallgroups'] = 'Εμφάνιση όλων των ομάδων'; + $lang['strgroupneedsname'] = 'ΠÏέπει να δώσετε όνομα στην ομάδα.'; + $lang['strgroupcreated'] = 'Η ομάδα δημιουÏγήθηκε.'; + $lang['strgroupcreatedbad'] = 'Η δημιουÏγία ομάδας απέτυχε.'; + $lang['strconfdropgroup'] = 'ΔιαγÏαφή της ομάδας "%s"?'; + $lang['strgroupdropped'] = 'Η ομάδα διαγÏάφηκε.'; + $lang['strgroupdroppedbad'] = 'Η διαγÏαφή της ομάδας απέτυχε.'; + $lang['strmembers'] = 'Μέλη'; + $lang['strmemberof'] = 'Μέλος της ομάδας'; + $lang['stradminmembers'] = 'Μέλη της ομάδας διαχειÏιστών'; + $lang['straddmember'] = 'ΠÏοσθήκη μέλους'; + $lang['strmemberadded'] = 'Το μέλος Ï€Ïοστέθηκε στην ομάδα.'; + $lang['strmemberaddedbad'] = 'Η Ï€Ïοσθήκη του μέλους απέτυχε.'; + $lang['strdropmember'] = 'ΔιαγÏαφή μέλους'; + $lang['strconfdropmember'] = 'ΔιαγÏαφή του μέλους "%s" από την ομάδα "%s"?'; + $lang['strmemberdropped'] = 'Το μέλος διαγÏάφηκε.'; + $lang['strmemberdroppedbad'] = 'Η διαγÏαφή του μέλους απέτυχε.'; + + // Roles + $lang['strrole'] = 'Ρόλος'; + $lang['strroles'] = 'Ρόλοι'; + $lang['strshowallroles'] = 'Εμφάνιση όλων των Ïόλων'; + $lang['strinheritsprivs'] = 'ΚληÏονομεί Ï€Ïονόμια?'; + $lang['strcreaterole'] = 'ΔημιουÏγία Ïόλου'; + $lang['strcancreaterole'] = 'ΔημιουÏγία Ïόλου?'; + $lang['strrolecreated'] = 'Ο Ïόλος δημιουÏγήθηκε.'; + $lang['strrolecreatedbad'] = 'Η δημιουÏγία του Ïόλου απέτυχε.'; + $lang['strcanlogin'] = 'ΕπιτÏέπεται η σÏνδεση?'; + $lang['strconnlimit'] = 'ΟÏιο συνδέσεων'; + $lang['strdroprole'] = 'ΔιαγÏαφή Ïόλου'; + $lang['strconfdroprole'] = 'ΔιαγÏαφή του Ïόλου "%s"?'; + $lang['strroledropped'] = 'Ο Ïόλος διαγÏάφηκε.'; + $lang['strroledroppedbad'] = 'Η διαγÏαφή του Ïόλου απέτυχε.'; + $lang['strnoroles'] = 'Δε βÏέθηκαν Ïόλοι.'; + $lang['strnolimit'] = 'Κανένα ÏŒÏιο'; + $lang['strnever'] = 'Ποτέ'; + $lang['strroleneedsname'] = 'ΠÏέπει να δώσετε όνομα στο Ïόλο.'; + + // Privileges + $lang['strprivilege'] = 'ΠÏονόμιο'; + $lang['strprivileges'] = 'ΠÏονόμια'; + $lang['strnoprivileges'] = 'Αυτό το αντικείμενο έχει τα εξ οÏÎ¹ÏƒÎ¼Î¿Ï Ï€Ïονόμια.'; + $lang['strgrant'] = 'ΠαÏοχή'; + $lang['strrevoke'] = 'Ανάκληση'; + $lang['strgranted'] = 'Τα Ï€Ïονόμια αλλάχθηκαν.'; + $lang['strgrantfailed'] = 'Αποτυχία αλλαγής Ï€Ïονομίων.'; + $lang['strgrantbad'] = 'ΠÏέπει να οÏίσετε τουλάχιστον ένα χÏήστη ή ομάδα και τουλάχιστον ένα Ï€Ïονόμιο.'; + $lang['strgrantor'] = 'ΕκχωÏητής'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Βάση'; + $lang['strdatabases'] = 'Βάσεις'; + $lang['strshowalldatabases'] = 'Εμφάνιση όλων των βάσεων'; + $lang['strnodatabases'] = 'Δε βÏέθηκαν βάσεις.'; + $lang['strcreatedatabase'] = 'ΔημιουÏγία βάσης'; + $lang['strdatabasename'] = 'Ονομα βάσης'; + $lang['strdatabaseneedsname'] = 'ΠÏέπει να δώσετε όνομα βάσης.'; + $lang['strdatabasecreated'] = 'Η βάση δημιουÏγήθηκε.'; + $lang['strdatabasecreatedbad'] = 'Η δημιουÏγία της βάσης απέτυχε.'; + $lang['strconfdropdatabase'] = 'ΔιαγÏαφή της βάσης "%s"?'; + $lang['strdatabasedropped'] = 'Η βάση διαγÏάφηκε.'; + $lang['strdatabasedroppedbad'] = 'Η δημιουÏγία της βάσης απέτυχε.'; + $lang['strentersql'] = 'Εισάγετε SQL Ï€Ïος εκτέλεση:'; + $lang['strsqlexecuted'] = 'H SQL εκτελέστηκε.'; + $lang['strvacuumgood'] = 'Η εκκένωση ολοκληÏώθηκε.'; + $lang['strvacuumbad'] = 'Η εκκένωση απέτυχε.'; + $lang['stranalyzegood'] = 'Η ανάλυση ολοκληÏώθηκε.'; + $lang['stranalyzebad'] = 'Η ανάλυση απέτυχε.'; + $lang['strreindexgood'] = 'Η επαναδεικτοδότηση ολοκληÏώθηκε.'; + $lang['strreindexbad'] = 'Η επαναδεικτοδότηση απέτυχε.'; + $lang['strfull'] = 'Ολα'; + $lang['strfreeze'] = 'Πάγωμα'; + $lang['strforce'] = 'ΥποχÏεωτικά'; + $lang['strsignalsent'] = 'Το σήμα εστάλη.'; + $lang['strsignalsentbad'] = 'Η αποστολή του σήματος απέτυχε.'; + $lang['strallobjects'] = 'Ολα τα αντικείμενα'; + $lang['strdatabasealtered'] = 'Η βάση Ï„Ïοποποιήθηκε.'; + $lang['strdatabasealteredbad'] = 'Η Ï„Ïοποποίηση της βάσης απέτυχε.'; + + // Views + $lang['strview'] = 'Οψη'; + $lang['strviews'] = 'Οψεις'; + $lang['strshowallviews'] = 'Εμφάνιση όλων των όψεων'; + $lang['strnoview'] = 'Δε βÏέθηκε όψη.'; + $lang['strnoviews'] = 'Δε βÏέθηκαν όψεις.'; + $lang['strcreateview'] = 'ΔημιουÏγία όψης'; + $lang['strviewname'] = 'Ονομα όψης'; + $lang['strviewneedsname'] = 'ΠÏέπει να δώσετε όνομα στην όψη.'; + $lang['strviewneedsdef'] = 'ΠÏέπει να δώσετε τον οÏισμό της όψης.'; + $lang['strviewneedsfields'] = 'ΠÏέπει να δώσετε τις στήλες της όψης.'; + $lang['strviewcreated'] = 'Η όψη δημιουÏγήθηκε.'; + $lang['strviewcreatedbad'] = 'Η δημιουÏγία της όψης απέτυχε.'; + $lang['strconfdropview'] = 'ΔιαγÏαφή της όψης "%s"?'; + $lang['strviewdropped'] = 'Η όψη διαγÏάφηκε.'; + $lang['strviewdroppedbad'] = 'Η διαγÏαφή της όψης απέτυχε.'; + $lang['strviewupdated'] = 'Η όψη ενημεÏώθηκε.'; + $lang['strviewupdatedbad'] = 'Η ενημέÏωση της όψης απέτυχε.'; + $lang['strviewlink'] = 'ΣÏζευξη κλειδιών'; + $lang['strviewconditions'] = 'ΠÏόσθετες συνθήκες'; + $lang['strcreateviewwiz'] = 'ΔημιουÏγία όψης με βοηθό'; + + // Sequences + $lang['strsequence'] = 'Ακολουθία'; + $lang['strsequences'] = 'Ακολουθίες'; + $lang['strshowallsequences'] = 'Εμφάνιση όλων των ακολουθιών'; + $lang['strnosequence'] = 'Δε βÏέθηκε ακολουθία.'; + $lang['strnosequences'] = 'Δε βÏέθηκαν ακολουθίες.'; + $lang['strcreatesequence'] = 'ΔημιουÏγία ακολουθίας'; + $lang['strlastvalue'] = 'Τελευταία τιμή'; + $lang['strincrementby'] = 'ΠÏοσαÏξηση κατά'; + $lang['strstartvalue'] = 'Τιμή εκκίνησης'; + $lang['strmaxvalue'] = 'Μέγιστη τιμή'; + $lang['strminvalue'] = 'Ελάχιστη τιμή'; + $lang['strcachevalue'] = 'ΑÏιθμός εγγÏαφών στην κÏυφή μνήμη (cache)'; + $lang['strlogcount'] = 'ΚαταγÏαφή'; + $lang['strcancycle'] = 'Îα μηδενίζεται?'; + $lang['striscalled'] = 'Εχει κληθεί?'; + $lang['strsequenceneedsname'] = 'ΠÏέπει να δώσετε όνομα για την ακολουθία.'; + $lang['strsequencecreated'] = 'Η ακολουθία δημιουÏγήθηκε.'; + $lang['strsequencecreatedbad'] = 'Η δημιουÏγία της ακολουθίας απέτυχε.'; + $lang['strconfdropsequence'] = 'Îα διαγÏαφεί η ακολουθία "%s"?'; + $lang['strsequencedropped'] = 'Η ακολουθία διαγÏάφηκε.'; + $lang['strsequencedroppedbad'] = 'Η διαγÏαφή της ακολουθίας απέτυχε.'; + $lang['strsequencereset'] = 'Η ακολουθία επανεκκινήθηκε.'; + $lang['strsequenceresetbad'] = 'Η επανεκκίνηση της ακολουθίας απέτυχε.'; + $lang['strsequencealtered'] = 'Η ακολουθία Ï„Ïοποποιήθηκε.'; + $lang['strsequencealteredbad'] = 'Η Ï„Ïοποποίηση της ακολουθίας απέτυχε.'; + $lang['strsetval'] = 'Αλλαγή τιμής'; + $lang['strsequencesetval'] = 'Η τιμή της ακολουθίας οÏίσθηκε.'; + $lang['strsequencesetvalbad'] = 'Απέτυχε ο οÏισμός τιμής της ακολουθίας.'; + $lang['strnextval'] = 'ΠÏοσαÏξηση'; + $lang['strsequencenextval'] = 'Η ακολουθία Ï€Ïοσαυξήθηκε.'; + $lang['strsequencenextvalbad'] = 'Η Ï€ÏοσαÏξηση της ακολουθίας απέτυχε.'; + + // Indexes + $lang['strindex'] = 'ΕυÏετήÏιο'; + $lang['strindexes'] = 'ΕυÏετήÏια'; + $lang['strindexname'] = 'Ονομα ευÏετηÏίου'; + $lang['strshowallindexes'] = 'Εμφάνιση όλων των ευÏετηÏίων'; + $lang['strnoindex'] = 'Δε βÏέθηκε ευÏετήÏιο.'; + $lang['strnoindexes'] = 'Δε βÏέθηκαν ευÏετήÏια.'; + $lang['strcreateindex'] = 'ΔημιουÏγία ευÏετηÏίου'; + $lang['strtabname'] = 'Ονομα καÏτέλας'; + $lang['strcolumnname'] = 'Ονομα στήλης'; + $lang['strindexneedsname'] = 'ΠÏέπει να δώσετε όνομα στο ευÏετήÏιο.'; + $lang['strindexneedscols'] = 'Τα ευÏετήÏια απαιτοÏν έναν έγκυÏο αÏιθμό στηλών.'; + $lang['strindexcreated'] = 'Το ευÏετήÏιο δημιουÏγήθηκε.'; + $lang['strindexcreatedbad'] = 'Η δημιουÏγία του ευÏετηÏίου απέτυχε.'; + $lang['strconfdropindex'] = 'Îα διαγÏαφεί το ευÏετήÏιο "%s"?'; + $lang['strindexdropped'] = 'Το ευÏετήÏιο διαγÏάφηκε.'; + $lang['strindexdroppedbad'] = 'Η διαγÏαφή του ευÏετηÏίου απέτυχε.'; + $lang['strkeyname'] = 'Ονομα κλειδιοÏ'; + $lang['struniquekey'] = 'Μοναδικό κλειδί'; + $lang['strprimarykey'] = 'ΠÏωτεÏον κλειδί'; + $lang['strindextype'] = 'ΤÏπος ευÏετηÏίου'; + $lang['strtablecolumnlist'] = 'Στήλες πίνακα'; + $lang['strindexcolumnlist'] = 'Στήλες ευÏετηÏίου'; + $lang['strconfcluster'] = 'Îα ομαδοποιηθοÏν τα "%s"?'; + $lang['strclusteredgood'] = 'Η ομαδοποίηση ολοκληÏώθηκε.'; + $lang['strclusteredbad'] = 'Η ομαδοποίηση απέτυχε.'; + $lang['strcluster'] = 'Συστοιχία'; + + // Rules + $lang['strrules'] = 'Κανόνες'; + $lang['strrule'] = 'Κανόνας'; + $lang['strshowallrules'] = 'Εμφάνιση όλων των κανόνων'; + $lang['strnorule'] = 'Δε βÏέθηκε κανόνας.'; + $lang['strnorules'] = 'Δε βÏέθηκαν κανόνες.'; + $lang['strcreaterule'] = 'ΔημιουÏγία κανόνα'; + $lang['strrulename'] = 'Ονομα κανόνα'; + $lang['strruleneedsname'] = 'ΠÏέπει να δώσετε όνομα στον κανόνα.'; + $lang['strrulecreated'] = 'Ο κανόνας δημιουÏγήθηκε.'; + $lang['strrulecreatedbad'] = 'Η δημιουÏγία του κανόνα απέτυχε.'; + $lang['strconfdroprule'] = 'Îα διαγÏαφεί ο κανόνας "%s" στον "%s"?'; + $lang['strruledropped'] = 'Ο κανόνας διαγÏάφηκε.'; + $lang['strruledroppedbad'] = 'Η διαγÏαφή του κανόνα απέτυχε.'; + + // Constraints + $lang['strconstraint'] = 'ΠεÏιοÏισμός'; + $lang['strconstraints'] = 'ΠεÏιοÏισμοί'; + $lang['strshowallconstraints'] = 'Εμφάνιση όλων των πεÏιοÏισμών'; + $lang['strnoconstraints'] = 'Δε βÏέθηκαν πεÏιοÏισμοί.'; + $lang['strcreateconstraint'] = 'ΔημιουÏγία πεÏιοÏισμοÏ'; + $lang['strconstraintcreated'] = 'Ο πεÏιοÏισμός δημιουÏγήθηκε.'; + $lang['strconstraintcreatedbad'] = 'Η δημιουÏγία του πεÏιοÏÎ¹ÏƒÎ¼Î¿Ï Î±Ï€Î­Ï„Ï…Ï‡Îµ.'; + $lang['strconfdropconstraint'] = 'Îα διαγÏαφεί ο πεÏιοÏισμός "%s" στον "%s"?'; + $lang['strconstraintdropped'] = 'Ο πεÏιοÏισμός διαγÏάφηκε.'; + $lang['strconstraintdroppedbad'] = 'Η διαγÏαφή του πεÏιοÏÎ¹ÏƒÎ¼Î¿Ï Î±Ï€Î­Ï„Ï…Ï‡Îµ.'; + $lang['straddcheck'] = 'ΠÏοσθήκη ελέγχου'; + $lang['strcheckneedsdefinition'] = 'ΠÏέπει να οÏιστεί ο έλεγχος.'; + $lang['strcheckadded'] = 'Ο έλεγχος Ï€Ïοστέθηκε.'; + $lang['strcheckaddedbad'] = 'Η Ï€Ïοσθήκη ελέγχου απέτυχε.'; + $lang['straddpk'] = 'ΠÏοσθήκη Ï€ÏωτεÏοντος κλειδιοÏ'; + $lang['strpkneedscols'] = 'Το Ï€ÏωτεÏον κλειδί χÏειάζεται τουλάχιστον μία στήλη.'; + $lang['strpkadded'] = 'Το Ï€ÏωτεÏον κλειδί Ï€Ïοστέθηκε.'; + $lang['strpkaddedbad'] = 'Αποτυχία Ï€Ïοσθήκης Ï€ÏωτεÏοντος κλειδιοÏ.'; + $lang['stradduniq'] = 'ΠÏοσθήκη Î¼Î¿Î½Î±Î´Î¹ÎºÎ¿Ï ÎºÎ»ÎµÎ¹Î´Î¹Î¿Ï'; + $lang['struniqneedscols'] = 'Το μοναδικό κλειδί χÏειάζεται τουλάχιστον μία στήλη.'; + $lang['struniqadded'] = 'Το μοναδικό κλειδί Ï€Ïοστέθηκε.'; + $lang['struniqaddedbad'] = 'Αποτυχία Ï€Ïοσθήκης Î¼Î¿Î½Î±Î´Î¹ÎºÎ¿Ï ÎºÎ»ÎµÎ¹Î´Î¹Î¿Ï.'; + $lang['straddfk'] = 'ΠÏοσθήση ξένου κλειδιοÏ'; + $lang['strfkneedscols'] = 'Το ξένο κλειδί χÏειάζεται τουλάχιστον μία στήλη.'; + $lang['strfkneedstarget'] = 'Το ξένο κλειδί χÏειάζεται ένα αποδέκτη πίνακα.'; + $lang['strfkadded'] = 'Το ξένο κλειδί Ï€Ïοστέθηκε.'; + $lang['strfkaddedbad'] = 'Αποτυχία Ï€Ïοσθήκης ξένου κλειδιοÏ.'; + $lang['strfktarget'] = 'Αποδέκτης πίνακας'; + $lang['strfkcolumnlist'] = 'Στήλες στο κλειδί'; + $lang['strondelete'] = 'ΚΑΤΑ ΤΗ ΔΙΑΓΡΑΦΗ'; + $lang['stronupdate'] = 'ΚΑΤΑ ΤΗΠΕÎΗΜΕΡΩΣΗ'; + + // Functions + $lang['strfunction'] = 'ΣυνάÏτηση'; + $lang['strfunctions'] = 'ΣυναÏτήσεις'; + $lang['strshowallfunctions'] = 'Εμφάνιση όλων των συναÏτήσεων'; + $lang['strnofunction'] = 'Δε βÏέθηκε συνάÏτηση.'; + $lang['strnofunctions'] = 'Δε βÏέθηκαν συναÏτήσεις.'; + $lang['strcreateplfunction'] = 'ΔημιουÏγία συνάÏτησης σε SQL/PL'; + $lang['strcreateinternalfunction'] = 'ΔημιουÏγία εσωτεÏικής συνάÏτησης'; + $lang['strcreatecfunction'] = 'ΔημιουÏγία συνάÏτησης σε C'; + $lang['strfunctionname'] = 'Ονομα συνάÏτησης'; + $lang['strreturns'] = 'ΕπιστÏέφει'; + $lang['strproglanguage'] = 'Γλώσσα Ï€ÏογÏαμματισμοÏ'; + $lang['strfunctionneedsname'] = 'ΠÏέπει να δώσετε όνομα στη συνάÏτηση.'; + $lang['strfunctionneedsdef'] = 'ΠÏέπει να δώσετε οÏισμό στη συνάÏτηση.'; + $lang['strfunctioncreated'] = 'Η συνάÏτηση δημιουÏγήθηκε.'; + $lang['strfunctioncreatedbad'] = 'Η δημιουÏγία της συνάÏτησης απέτυχε.'; + $lang['strconfdropfunction'] = 'Îα διαγÏαφεί η συνάÏτηση "%s"?'; + $lang['strfunctiondropped'] = 'Η συνάÏτηση διαγÏάφηκε.'; + $lang['strfunctiondroppedbad'] = 'Η διαγÏαφή της συνάÏτησης απέτυχε.'; + $lang['strfunctionupdated'] = 'Η συνάÏτηση ενημεÏώθηκε.'; + $lang['strfunctionupdatedbad'] = 'Η ενημέÏωση της συνάÏτησης απέτυχε.'; + $lang['strobjectfile'] = 'ΑÏχείο αντικειμένου'; + $lang['strlinksymbol'] = 'Ονομα συνάÏτησης στον πηγαίο κώδικα'; + $lang['strarguments'] = 'ΟÏίσματα'; + $lang['strargmode'] = 'Είδος'; + $lang['strargtype'] = 'ΤÏπος'; + $lang['strargadd'] = 'Επιπλέον ÏŒÏισμα'; + $lang['strargremove'] = 'ΔιαγÏαφή οÏίσματος'; + $lang['strargnoargs'] = 'Αυτή η συνάÏτηση δεν έχει οÏίσματα.'; + $lang['strargenableargs'] = 'ΕνεÏγοποίηση οÏισμάτων που Ï„ÏοφοδοτοÏν τη συνάÏτηση.'; + $lang['strargnorowabove'] = 'Δεν υπάÏχει γÏαμμή πάνω από αυτήν.'; + $lang['strargnorowbelow'] = 'Δεν υπάÏχει γÏαμμή κάτω από αυτήν.'; + $lang['strargraise'] = 'Μετακίνηση πάνω.'; + $lang['strarglower'] = 'Μετακίνηση κάτω.'; + $lang['strargremoveconfirm'] = 'Îα διαγÏαφεί το ÏŒÏισμα; Η ενέÏγεια είναι ΜΗ ΑÎΑΣΤΡΕΨΙΜΗ.'; + + + // Triggers + $lang['strtrigger'] = 'Εναυσμα'; + $lang['strtriggers'] = 'ΕναÏσματα'; + $lang['strshowalltriggers'] = 'Εμφάνιση όλων των εναυσμάτων'; + $lang['strnotrigger'] = 'Δε βÏέθηκε έναυσμα.'; + $lang['strnotriggers'] = 'Δε βÏέθηκαν εναÏσματα.'; + $lang['strcreatetrigger'] = 'ΔημιουÏγία εναÏσματος'; + $lang['strtriggerneedsname'] = 'ΠÏέπει να δώσετε όνομα στο έναυσμα.'; + $lang['strtriggerneedsfunc'] = 'Το έναυσμα Ï€Ïέπει να αντιστοιχεί σε μία συνάÏτηση.'; + $lang['strtriggercreated'] = 'Το έναυσμα δημιουÏγήθηκε.'; + $lang['strtriggercreatedbad'] = 'Η δημιουÏγία του εναÏσματος απέτυχε.'; + $lang['strconfdroptrigger'] = 'Îα διαγÏαφεί το έναυσμα "%s" στον "%s"?'; + $lang['strconfenabletrigger'] = 'Îα ενεÏγοποιηθεί το έναυσμα "%s" στον "%s"?'; + $lang['strconfdisabletrigger'] = 'Îα απενεÏγοποιηθεί το έναυσμα "%s" στον "%s"?'; + $lang['strtriggerdropped'] = 'Το έναυσμα διαγÏάφηκε.'; + $lang['strtriggerdroppedbad'] = 'Η διαγÏαφή του εναÏσματος απέτυχε.'; + $lang['strtriggerenabled'] = 'Το έναυσμα ενεÏγοποιήθηκε.'; + $lang['strtriggerenabledbad'] = 'Η ενεÏγοποίηση του εναÏσματος απέτυχε.'; + $lang['strtriggerdisabled'] = 'Το έναυσμα απενεÏγοποιήθηκε.'; + $lang['strtriggerdisabledbad'] = 'Η απενεÏγοποίηση απέτυχε.'; + $lang['strtriggeraltered'] = 'Το έναυσμα Ï„Ïοποποιήθηκε.'; + $lang['strtriggeralteredbad'] = 'Η Ï„Ïοποποίηση του εναÏσματος απέτυχε.'; + $lang['strforeach'] = 'Για κάθε'; + + // Types + $lang['strtype'] = 'ΤÏπος'; + $lang['strtypes'] = 'ΤÏποι'; + $lang['strshowalltypes'] = 'Εμφάνιση όλων των Ï„Ïπων'; + $lang['strnotype'] = 'Δε βÏέθηκε Ï„Ïπος.'; + $lang['strnotypes'] = 'Δε βÏέθηκαν Ï„Ïποι.'; + $lang['strcreatetype'] = 'ΔημιουÏγία Ï„Ïπου'; + $lang['strcreatecomptype'] = 'ΔημιουÏγία σÏνθετου Ï„Ïπου'; + $lang['strtypeneedsfield'] = 'ΠÏέπει να οÏίσετε τουλάχιστον ένα πεδίο.'; + $lang['strtypeneedscols'] = 'ΠÏέπει να οÏίσετε έναν έγκυÏο αÏιθμό πεδίων.'; + $lang['strinputfn'] = 'ΣυνάÏτηση εισόδου'; + $lang['stroutputfn'] = 'ΣυνάÏτηση εξόδου'; + $lang['strpassbyval'] = 'Îα μεταφέÏεται η μεταβλητή?'; + $lang['stralignment'] = 'Στοίχιση'; + $lang['strelement'] = 'Στοιχείο'; + $lang['strdelimiter'] = 'ΔιαχωÏιστής'; + $lang['strstorage'] = 'Αποθήκευση'; + $lang['strfield'] = 'Πεδίο'; + $lang['strnumfields'] = 'ΑÏιθμός πεδίων'; + $lang['strtypeneedsname'] = 'ΠÏέπει να δώσετε όνομα στον Ï„Ïπο.'; + $lang['strtypeneedslen'] = 'ΠÏέπει να οÏίσετε το μήκος του Ï„Ïπου.'; + $lang['strtypecreated'] = 'Ο Ï„Ïπος δημιουÏγήθηκε.'; + $lang['strtypecreatedbad'] = 'Η δημιουÏγία του Ï„Ïπου απέτυχε.'; + $lang['strconfdroptype'] = 'Îα διαγÏαφεί ο Ï„Ïπος "%s"?'; + $lang['strtypedropped'] = 'Ο Ï„Ïπος διαγÏάφηκε.'; + $lang['strtypedroppedbad'] = 'Η διαγÏαφή του Ï„Ïπου απέτυχε.'; + $lang['strflavor'] = 'ΕντÏπωση'; + $lang['strbasetype'] = 'Βάση'; + $lang['strcompositetype'] = 'ΣÏνθεση'; + $lang['strpseudotype'] = 'ΨεÏδο'; + + // Schemas + $lang['strschema'] = 'Σχήμα'; + $lang['strschemas'] = 'Σχήματα'; + $lang['strshowallschemas'] = 'Εμφάνιση όλων των σχημάτων'; + $lang['strnoschema'] = 'Δε βÏέθηκε σχήμα.'; + $lang['strnoschemas'] = 'Δε βÏέθηκαν σχήματα.'; + $lang['strcreateschema'] = 'ΔημιουÏγία σχήματος'; + $lang['strschemaname'] = 'Ονομα σχήματος'; + $lang['strschemaneedsname'] = 'ΠÏέπει να δώσετε όνομα στο σχήμα.'; + $lang['strschemacreated'] = 'Το σχήμα δημιουÏγήθηκε'; + $lang['strschemacreatedbad'] = 'Η δημιουÏγία του σχήματος απέτυχε.'; + $lang['strconfdropschema'] = 'Îα διαγÏαφεί το σχήμα "%s"?'; + $lang['strschemadropped'] = 'Το σχήμα διαγÏάφηκε.'; + $lang['strschemadroppedbad'] = 'Η διαγÏαφή του σχήματος απέτυχε.'; + $lang['strschemaaltered'] = 'Το σχήμα Ï„Ïοποποιήθηκε.'; + $lang['strschemaalteredbad'] = 'Η Ï„Ïοποποίηση του σχήματος απέτυχε.'; + $lang['strsearchpath'] = 'ΠοÏεία αναζήτησης σχήματος'; + + // Reports + + // Domains + $lang['strdomain'] = 'Τομέας'; + $lang['strdomains'] = 'Τομείς'; + $lang['strshowalldomains'] = 'Εμφάνιση όλων των τομέων'; + $lang['strnodomains'] = 'Δε βÏέθηκαν τομείς.'; + $lang['strcreatedomain'] = 'ΔημιουÏγία τομέα'; + $lang['strdomaindropped'] = 'Ο τομέας διαγÏάφηκε.'; + $lang['strdomaindroppedbad'] = 'Η διαγÏαφή του τομέα απέτυχε.'; + $lang['strconfdropdomain'] = 'Îα διαγÏαφεί ο τομέας "%s"?'; + $lang['strdomainneedsname'] = 'ΠÏέπει να δώσετε όνομα στον τομέα.'; + $lang['strdomaincreated'] = 'Ο τομέας δημιουÏγήθηκε.'; + $lang['strdomaincreatedbad'] = 'Η δημιουÏγία του τομέα απέτυχε.'; + $lang['strdomainaltered'] = 'Ο τομέας Ï„Ïοποποιήθηκε.'; + $lang['strdomainalteredbad'] = 'Η Ï„Ïοποποίηση του τομέα απέτυχε.'; + + // Operators + $lang['stroperator'] = 'Τελεστής'; + $lang['stroperators'] = 'Τελεστές'; + $lang['strshowalloperators'] = 'Εμφάνιση όλων των τελεστών'; + $lang['strnooperator'] = 'Δε βÏέθηκε τελεστής.'; + $lang['strnooperators'] = 'Δε βÏέθηκαν τελεστές.'; + $lang['strcreateoperator'] = 'ΔημιουÏγία τελεστή'; + $lang['strleftarg'] = 'Είδος αÏιστεÏής παÏαμέτÏου'; + $lang['strrightarg'] = 'Είδος δεξιάς παÏαμέτÏου'; + $lang['strcommutator'] = 'Αντιμετάθεση'; + $lang['strnegator'] = 'ΑÏνηση'; + $lang['strrestrict'] = 'ΠεÏιοÏισμός'; + $lang['strjoin'] = 'ΣÏζευξη'; + $lang['strhashes'] = 'Κατάτμηση'; + $lang['strmerges'] = 'Ενωση'; + $lang['strleftsort'] = 'ΑÏιστεÏή ταξινόμηση'; + $lang['strrightsort'] = 'Δεξιά ταξινόμηση'; + $lang['strlessthan'] = 'ΜικÏότεÏο από'; + $lang['strgreaterthan'] = 'ΜεγαλÏτεÏο από'; + $lang['stroperatorneedsname'] = 'ΠÏέπει να δώσετε όνομα στον τελεστή.'; + $lang['stroperatorcreated'] = 'Ο τελεστής δημιουÏγήθηκε'; + $lang['stroperatorcreatedbad'] = 'Η δημιουÏγία του τελεστή απέτυχε.'; + $lang['strconfdropoperator'] = 'Îα διαγÏαφεί ο τελεστής "%s"?'; + $lang['stroperatordropped'] = 'Ο τελεστής διαγÏάφηκε.'; + $lang['stroperatordroppedbad'] = 'Η διαγÏαφή του τελεστή απέτυχε.'; + + // Casts + $lang['strcasts'] = 'ΜετατÏοπή Ï„Ïπου'; + $lang['strnocasts'] = 'Δε βÏέθηκαν μετατÏοπές Ï„Ïπου.'; + $lang['strsourcetype'] = 'ΤÏπος εισόδου'; + $lang['strtargettype'] = 'ΤÏπος εξόδου'; + $lang['strimplicit'] = 'Απόλυτη'; + $lang['strinassignment'] = 'Σε ανάθεση'; + $lang['strbinarycompat'] = '(Δυαδική συμβατότητα)'; + + // Conversions + $lang['strconversions'] = 'ΜετατÏοπές'; + $lang['strnoconversions'] = 'Δε βÏέθηκαν μετατÏοπές.'; + $lang['strsourceencoding'] = 'Κωδικοποίηση εισόδου'; + $lang['strtargetencoding'] = 'Κωδικοποίηση εξόδου'; + + // Languages + $lang['strlanguages'] = 'Γλώσσες'; + $lang['strnolanguages'] = 'Δε βÏέθηκαν γλώσσες.'; + $lang['strtrusted'] = 'Αξιόπιστη'; + + // Info + $lang['strnoinfo'] = 'Δε βÏέθηκαν πληÏοφοÏίες.'; + $lang['strreferringtables'] = 'Σχετικοί πίνακες'; + $lang['strparenttables'] = 'Γονικοί πίνακες'; + $lang['strchildtables'] = 'ΘυγατÏικοί πίνακες'; + + // Aggregates + $lang['straggregate'] = 'ΣυγκεντÏωτική συνάÏτηση'; + $lang['straggregates'] = 'ΣυγκεντÏωτικές συναÏτήσεις'; + $lang['strnoaggregates'] = 'Δε βÏέθηκαν συγκεντÏωτικές συναÏτήσεις'; + $lang['stralltypes'] = '(Ολοι οι Ï„Ïποι)'; + $lang['strcreateaggregate'] = 'ΔημιουÏγία συγκεντÏωτικής συνάÏτησης'; + $lang['straggrbasetype'] = 'ΜοÏφή δεδομένων εισόδου'; + $lang['straggrsfunc'] = 'ΣυνάÏτηση μεταβολής κατάστασης'; + $lang['straggrstype'] = 'ΜοÏφή δεδομένων κατάστασης'; + $lang['straggrffunc'] = 'Τελική συνάÏτηση'; + $lang['straggrinitcond'] = 'ΑÏχική συνθήκη'; + $lang['straggrsortop'] = 'Τελεστής ταξινόμησης'; + $lang['strconfdropaggregate'] = 'Îα διαγÏαφεί η συγκεντÏωτική συνάÏτηση "%s"?'; + $lang['straggregatedropped'] = 'Η συγκεντÏωτική συνάÏτηση διαγÏάφηκε.'; + $lang['straggregatedroppedbad'] = 'Η διαγÏαφή της συγκεντÏωτικής συνάÏτησης απέτυχε.'; + $lang['straggraltered'] = 'Η συγκεντÏωτική συνάÏτηση Ï„Ïοποποιήθηκε.'; + $lang['straggralteredbad'] = 'Η Ï„Ïοποποίηση της συγκεντÏωτικής συνάÏτησης απέτυχε.'; + $lang['straggrneedsname'] = 'ΠÏέπει να δώσετε όνομα στη συγκεντÏωτική συνάÏτηση.'; + $lang['straggrneedsbasetype'] = 'ΠÏέπει να δώσετε τη μοÏφή δεδομένων εισόδου της συγκεντÏωτικής συνάÏτησης'; + $lang['straggrneedssfunc'] = 'ΠÏέπει να δώσετε το όνομα της συνάÏτησης μεταβολής κατάστασης'; + $lang['straggrneedsstype'] = 'ΠÏέπει να δώσετε τη μοÏφή δεδομένων της τιμής κατάστασης'; + $lang['straggrcreated'] = 'Η συγκεντÏωτική συνάÏτηση δημιουÏγήθηκε.'; + $lang['straggrcreatedbad'] = 'Η δημιουÏγία της συγκεντÏωτικής συνάÏτησης απέτυχε.'; + $lang['straggrshowall'] = 'Εμφάνιση όλων των συγκεντÏωτικών συναÏτήσεων'; + + // Operator Classes + $lang['stropclasses'] = 'Κλάσεις τελεστών'; + $lang['strnoopclasses'] = 'Δε βÏέθηκαν κλάσεις τελεστών.'; + $lang['straccessmethod'] = 'Μέθοδος Ï€Ïόσβασης'; + + // Stats and performance + $lang['strrowperf'] = 'Επιδόσεις γÏαμμών'; + $lang['strioperf'] = 'Επιδόσεις Εισόδου/Εξόδου'; + $lang['stridxrowperf'] = 'Επιδόσεις γÏαμμών ευÏετηÏίου'; + $lang['stridxioperf'] = 'Επιδόσεις Εισόδου/Εξόδου ευÏετηÏίου'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Αλληλουχία'; + $lang['strscan'] = 'ΣάÏωση'; + $lang['strread'] = 'Ανάγνωση'; + $lang['strfetch'] = 'Απόδοση'; + $lang['strheap'] = 'ΣωÏός'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'ΕυÏετήÏιο TOAST'; + $lang['strcache'] = 'ΚÏυφή μνήμη'; + $lang['strdisk'] = 'Δίσκος'; + $lang['strrows2'] = 'ΓÏαμμές'; + + // Tablespaces + $lang['strtablespace'] = 'Τοποθεσία πίνακα'; + $lang['strtablespaces'] = 'Τοποθεσίες πινάκων'; + $lang['strshowalltablespaces'] = 'Εμφάνιση όλων των τοποθεσιών'; + $lang['strnotablespaces'] = 'Δε βÏέθηκαν τοποθεσίες πινάκων.'; + $lang['strcreatetablespace'] = 'ΔημιουÏγία τοποθεσίας πίνακα'; + $lang['strlocation'] = 'Τοποθεσία'; + $lang['strtablespaceneedsname'] = 'ΠÏέπει να δώσετε όνομα στην τοποθεσία.'; + $lang['strtablespaceneedsloc'] = 'ΠÏέπει να δώσετε την ακÏιβή θέση του καταλόγου όπου θα δημιουÏγηθεί ο πίνακας.'; + $lang['strtablespacecreated'] = 'Η τοποθεσία δημιουÏγήθηκε.'; + $lang['strtablespacecreatedbad'] = 'Η δημιουÏγία της τοποθεσίας απέτυχε.'; + $lang['strconfdroptablespace'] = 'Îα διαγÏαφεί η τοποθεσία "%s"?'; + $lang['strtablespacedropped'] = 'Η τοποθεσία διαγÏάφηκε.'; + $lang['strtablespacedroppedbad'] = 'Η διαγÏαφή της τοποθεσίας απέτυχε.'; + $lang['strtablespacealtered'] = 'Η τοποθεσία Ï„Ïοποποιήθηκε.'; + $lang['strtablespacealteredbad'] = 'Η Ï„Ïοποποίηση της τοποθεσίας απέτυχε.'; + + // Miscellaneous + $lang['strtopbar'] = '%s στο %s:%s -- Είστε συνδεδεμένος ως "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Βοήθεια'; + $lang['strhelpicon'] = '?'; + $lang['strlogintitle'] = 'ΣÏνδεση με %s'; + $lang['strlogoutmsg'] = 'ΑποσÏνδεση από %s'; + $lang['strloading'] = 'ΦόÏτωση...'; + $lang['strerrorloading'] = 'Σφάλμα στη φόÏτωση'; + $lang['strclicktoreload'] = 'Îα ξαναφοÏτωθεί'; + + // Autovacuum + $lang['strautovacuum'] = 'Αυτόματη εκκένωση'; + $lang['strturnedon'] = 'Ανοιχτή'; + $lang['strturnedoff'] = 'Κλειστή'; + $lang['strenabled'] = 'ΕνεÏγοποιημένη'; + $lang['strvacuumbasethreshold'] = 'Βάση κατωφλίου εκκένωσης'; + $lang['strvacuumscalefactor'] = 'Συντελεστής κλίμακας εκκένωσης'; + $lang['stranalybasethreshold'] = 'Ανάλυση βάσης κατωφλίου'; + $lang['stranalyzescalefactor'] = 'Ανάλυση συντελεστή κλίμακας'; + $lang['strvacuumcostdelay'] = 'ΚαθυστέÏηση κόστους εκκένωσης'; + $lang['strvacuumcostlimit'] = 'ΟÏιο κόστους εκκένωσης'; + + // Table-level Locks + $lang['strlocks'] = 'Κλειδώματα'; + $lang['strtransaction'] = 'Ταυτότητα συναλλαγής'; + $lang['strprocessid'] = 'Ταυτότητα διεÏγασίας'; + $lang['strmode'] = 'ΤÏόπος κλειδώματος'; + $lang['strislockheld'] = 'ΔιατηÏείται το κλείδωμα?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Ετοιμες συναλλαγές'; + $lang['strxactid'] = 'Ταυτότητα'; + $lang['strgid'] = 'Γενική ταυτότητα'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hebrew.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hebrew.php new file mode 100644 index 00000000..5b9aea39 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hebrew.php @@ -0,0 +1,615 @@ + + * + * $Id: hebrew.php,v 1.4 2007/04/24 11:42:07 soranzo Exp $ + */ + + // Language and character set + $lang['applang'] = 'Hebrew'; + $lang['applocale'] = 'he-IL'; + $lang['applangdir'] = 'rtl'; + + // Welcome + $lang['strintro'] = '×‘×¨×•×›×™× ×”×‘××™× ×œ phpPgAdmin.'; + $lang['strppahome'] = 'עמוד הבית של phpPgAdmin.'; + $lang['strpgsqlhome'] = 'עמוד הבית של PostgreSQL.'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'תיעוד PostgreSQL (מקומי)'; + $lang['strreportbug'] = 'דווח על ב××’'; + $lang['strviewfaq'] = 'צפה ב FAQ מקוון'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'התחברות'; + $lang['strloginfailed'] = 'התחברות נכשלה'; + $lang['strlogindisallowed'] = 'התחברות מבוטלת בשל בעיות ×בטחה.'; + $lang['strserver'] = 'שרת'; + $lang['strlogout'] = 'התנתקות'; + $lang['strowner'] = 'בעל'; + $lang['straction'] = 'פעולה'; + $lang['stractions'] = 'פעולות'; + $lang['strname'] = 'ש×'; + $lang['strdefinition'] = 'הגדרה'; + $lang['strproperties'] = 'העדפות'; + $lang['strbrowse'] = 'דפדף'; + $lang['strdrop'] = 'מחק'; + $lang['strdropped'] = 'נמחק'; + $lang['strnull'] = 'Null'; + $lang['strnotnull'] = '×œ× null'; + $lang['strprev'] = '×§×•×“× <'; + $lang['strnext'] = '> הב××”'; + $lang['strfirst'] = 'ר×שון <<'; + $lang['strlast'] = '>> ×חרון'; + $lang['strfailed'] = 'נכשל'; + $lang['strcreate'] = 'צור'; + $lang['strcreated'] = 'נוצר'; + $lang['strcomment'] = 'הערה'; + $lang['strlength'] = '×ורך'; + $lang['strdefault'] = 'ברירת מחדל'; + $lang['stralter'] = 'ערוך'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'בטל'; + $lang['strsave'] = 'שמור'; + $lang['strreset'] = 'שחזר'; + $lang['strinsert'] = 'הכנס'; + $lang['strselect'] = 'בחר'; + $lang['strdelete'] = 'מחק'; + $lang['strupdate'] = 'עדכן'; + $lang['strreferences'] = 'תיעודי×'; + $lang['stryes'] = 'כן'; + $lang['strno'] = 'ל×'; + $lang['strtrue'] = '×מת'; + $lang['strfalse'] = 'שקר'; + $lang['stredit'] = 'ערוך'; + $lang['strcolumns'] = 'עמודות'; + $lang['strrows'] = 'שורות'; + $lang['strrowsaff'] = 'שורות מושפעות'; + $lang['strobjects'] = 'נתוני×'; + $lang['strexample'] = 'דוגמה.'; + $lang['strback'] = 'קוד×'; + $lang['strqueryresults'] = 'תוצ×ות הש×ילתה'; + $lang['strshow'] = 'הר××”'; + $lang['strempty'] = 'רוקן'; + $lang['strlanguage'] = 'שפה'; + $lang['strencoding'] = 'קידוד'; + $lang['strvalue'] = 'ערך'; + $lang['strunique'] = 'מיוחד'; + $lang['strprimary'] = 'ר×שי'; + $lang['strexport'] = 'יצו×'; + $lang['strimport'] = 'יבו×'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = 'לך'; + $lang['stradmin'] = 'מנהל'; + $lang['strvacuum'] = 'ריק'; + $lang['stranalyze'] = 'נתח'; + $lang['strclusterindex'] = '×שכול'; + $lang['strclustered'] = 'מ×ושכל?'; + $lang['strreindex'] = '×נדקס מחדש'; + $lang['strrun'] = 'הרץ'; + $lang['stradd'] = 'הוסף'; + $lang['strevent'] = '×ירוע'; + $lang['strwhere'] = '×יפה'; + $lang['strinstead'] = 'תעשה במקו×'; + $lang['strwhen'] = 'כש'; + $lang['strformat'] = 'סוג'; + $lang['strdata'] = 'מידע'; + $lang['strconfirm'] = '×שר'; + $lang['strexpression'] = 'ביטוי'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'הרחב'; + $lang['strcollapse'] = 'צמצ×'; + $lang['strexplain'] = 'הסבק'; + $lang['strexplainanalyze'] = 'הסבר נתיחה'; + $lang['strfind'] = 'מצ×'; + $lang['stroptions'] = '×פשרויות'; + $lang['strrefresh'] = 'רענן'; + $lang['strdownload'] = 'הורד'; + $lang['strdownloadgzipped'] = 'הורד דחוס ב gzip'; + $lang['strinfo'] = 'מידע'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'מתקד×'; + $lang['strvariables'] = 'משתני×'; + $lang['strprocess'] = 'תהליך'; + $lang['strprocesses'] = 'תהליכי×'; + $lang['strsetting'] = 'הגדרות'; + $lang['streditsql'] = 'ערוך SQL'; + $lang['strruntime'] = 'זמן-ריצה כולל: %s ms'; + $lang['strpaginate'] = 'Paginate results'; + $lang['struploadscript'] = '×ו העלה תסריט SQL:'; + $lang['strstarttime'] = 'זמן התחלה'; + $lang['strfile'] = 'קובץ'; + $lang['strfileimported'] = 'קובץ יוב×'; + + // Error handling + $lang['strbadconfig'] = 'קובץ ×” config.inc.php שלך ×ינו מעודכן. ×תה תיצטרך ליצור ×חד חדש יותר מהקובץ config.inc.php-dist החדש'; + $lang['strnotloaded'] = 'התקנת ×” PHP שלך ××™× ×” תומכת ב PostgreSQL. ×תה תיצטרך להדר ×ותה מחדש ×× ×”×¤×§×•×“×” --with-pqlsql בזמן ההגדרה'; + $lang['strphpversionnotsupported'] = 'גירסת ×” PHP שלך ××™× ×” ניתמכת. ×× × ×¢×“×›×Ÿ ×ותה לגירסה %s ×ו חדשה יותר.'; + $lang['strpostgresqlversionnotsupported'] = 'גערסת ×” PostgrSQL שלך ××™× ×” ניתמכת. ×× × ×¢×“×›×Ÿ ×ותה לגירסה %s ×ו חדשה יותר.'; + $lang['strbadschema'] = '×ª×¨×©×™× ×©×’×•×™ צויין'; + $lang['strbadencoding'] = 'נכשל בהת×מת קידוד משתמש למסד הנתוני×.'; + $lang['strsqlerror'] = 'שגי×ת SQL:'; + $lang['strinstatement'] = 'בהצהרה:'; + $lang['strinvalidparam'] = 'ממדי תסריט שגוי.'; + $lang['strnodata'] = '×œ× × ×ž×¦×ו שורות.'; + $lang['strnoobjects'] = '×œ× × ×ž×¦×ו נתוני×.'; + $lang['strrownotunique'] = 'No unique identifier for this row.'; + $lang['strnouploads'] = 'העל×ת ×§×‘×¦×™× ×‘×•×˜×œ×”.'; + $lang['strimporterror'] = 'שגי×ת יבו×.'; + $lang['strimporterrorline'] = 'שגי×ת ×™×‘×•× ×‘×©×•×¨×”: %s.'; + + // Tables + $lang['strtable'] = 'טבלה'; + $lang['strtables'] = 'טבל×ות'; + $lang['strshowalltables'] = 'הר××” ×ת כל הטבל×ות.'; + $lang['strnotables'] = '×œ× × ×ž×¦×ו טבל×ות.'; + $lang['strnotable'] = 'טבלה ×œ× × ×ž×¦××”.'; + $lang['strcreatetable'] = 'צור טבלה'; + $lang['strtablename'] = '×©× ×˜×‘×œ×”'; + $lang['strtableneedsname'] = '×תה חייב לתת ×©× ×œ×˜×‘×œ×” שלך.'; + $lang['strtableneedsfield'] = '×תה חייב לציין לפחות שדה ×חד.'; + $lang['strtableneedscols'] = '×תה חייב לציין מספר תקין של עמודות.'; + $lang['strtablecreated'] = 'טבלה נוצרה.'; + $lang['strtablecreatedbad'] = 'יצירת טבלה נכשלה.'; + $lang['strconfdroptable'] = '×תה בטוח שברצונך למחוק ×ת הטבלה "%s"?'; + $lang['strtabledropped'] = 'טבלה נמחקה.'; + $lang['strtabledroppedbad'] = 'מחיקת טבלה נכשלה.'; + $lang['strconfemptytable'] = '×”×× ×תה בטוח שברצונך לרוקן ×ת הטבלה "%s"?'; + $lang['strtableemptied'] = 'טבלה רוקנה.'; + $lang['strtableemptiedbad'] = 'ריקון טבלה נכשל.'; + $lang['strinsertrow'] = 'הכנס שדה'; + $lang['strrowinserted'] = 'שדה הוכנס.'; + $lang['strrowinsertedbad'] = 'הכנסת שדה נכשלה.'; + $lang['streditrow'] = 'ערוך שדה'; + $lang['strrowupdated'] = 'שדה עודכן.'; + $lang['strrowupdatedbad'] = 'עידכון שדה נכשל.'; + $lang['strdeleterow'] = 'מחק שדה'; + $lang['strconfdeleterow'] = '×”×× ×תה בטוח שברצונך למחוק ×ת השדה ×”×–×”?'; + $lang['strrowdeleted'] = 'שדה נמחק.'; + $lang['strrowdeletedbad'] = 'מחיקת שדה נכשל.'; + $lang['strinsertandrepeat'] = 'חזור &הכנס '; + $lang['strfield'] = 'שדה'; + $lang['strnumfields'] = 'מספר השדות'; + $lang['strselectallfields'] = 'בחר ×ת כל השדות'; + $lang['strselectneedscol'] = '×תה חייב להר×ות לפחות שדה ×חד'; + $lang['strselectunary'] = 'Unary operators cannot have values.'; + $lang['straltercolumn'] = 'ערוך עמודה'; + $lang['strcolumnaltered'] = 'עמודה נערכה'; + $lang['strcolumnalteredbad'] = 'עריכת עמודה נכשלה.'; + $lang['strconfdropcolumn'] = '×”×× ×תה בטוח שברצונך למחוק ×ת העמודה "%s" מהטבלה "%squot;?'; + $lang['strcolumndropped'] = 'עמודה נחמקה.'; + $lang['strcolumndroppedbad'] = 'מחיקת עמודה נכשלה.'; + $lang['straddcolumn'] = 'הוסף עמודה.'; + $lang['strcolumnadded'] = 'עמודה נוספה.'; + $lang['strcolumnaddedbad'] = 'הוספת עמודה נכשלה'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'טבלה נערכה.'; + $lang['strtablealteredbad'] = 'עריכת טבלה נכשלה.'; + $lang['strdataonly'] = 'מידע בלבד'; + $lang['strstructureonly'] = 'מבנה בילבד'; + $lang['strstructureanddata'] = 'מבנה ונתוני×'; + $lang['strtabbed'] = 'תוייק'; + $lang['strauto'] = '×וטומטי'; + + // Users + $lang['struser'] = 'משתמש'; + $lang['strusers'] = 'משתמשי×'; + $lang['strusername'] = '×©× ×ž×©×ª×ž×©'; + $lang['strpassword'] = 'סיסמה'; + $lang['strsuper'] = 'משתמש על?'; + $lang['strcreatedb'] = 'יצירת בסיס נתוני×?'; + $lang['strexpires'] = 'Expires'; + $lang['strsessiondefaults'] = 'הפעלת ברירת מחדל'; + $lang['strnousers'] = '×œ× × ×ž×¦×ו משתמשי×'; + $lang['struserupdated'] = 'משתמש עודכן.'; + $lang['struserupdatedbad'] = 'עדכון משתמש נכשל.'; + $lang['strshowallusers'] = 'הר××” ×ת כל המשתמשי×.'; + $lang['strcreateuser'] = 'צור משתמש'; + $lang['struserneedsname'] = '×תה חייב לתת ×©× ×œ×ž×©×ª×ž×© שלך.'; + $lang['strusercreated'] = 'משתמש נוצר.'; + $lang['strusercreatedbad'] = 'יצירת משתמש נכשל.'; + $lang['strconfdropuser'] = '×תה בטוח שברצונך למחוק ×ת המשתמש "%s"?'; + $lang['struserdropped'] = 'משתמש נמחק.'; + $lang['struserdroppedbad'] = 'מחיקת משתמש נכשל.'; + $lang['straccount'] = 'חשבון'; + $lang['strchangepassword'] = 'שנה סיסמה'; + $lang['strpasswordchanged'] = 'סיסמה שונתה.'; + $lang['strpasswordchangedbad'] = 'נכשל בשינוי סיסמה.'; + $lang['strpasswordshort'] = 'סיסמה קצרה מידי.'; + $lang['strpasswordconfirm'] = 'סיסמה ××™× ×” תו×מת ל×ישורה.'; + + // Groups + $lang['strgroup'] = 'קבוצה'; + $lang['strgroups'] = 'קבוצות'; + $lang['strnogroup'] = 'קבוצה ×œ× × ×ž×¦××”.'; + $lang['strnogroups'] = '×œ× × ×ž×¦×ו קבוצות.'; + $lang['strcreategroup'] = 'צור קבוצה'; + $lang['strshowallgroups'] = 'הר××” ×ת כל הקבוצות'; + $lang['strgroupneedsname'] = '×תה חייב לתת ×©× ×œ×§×‘×•×¦×” שלך.'; + $lang['strgroupcreated'] = 'קבוצה נוצרה.'; + $lang['strgroupcreatedbad'] = 'יצירת קבוצה נכשלה.'; + $lang['strconfdropgroup'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הקבוצה "%s"?'; + $lang['strgroupdropped'] = 'קבוצה נמחקה.'; + $lang['strgroupdroppedbad'] = 'מחיקת קבוצה נכשלה.'; + $lang['strmembers'] = 'חברי×'; + $lang['straddmember'] = 'הוסף חבר'; + $lang['strmemberadded'] = 'חבר נוסף.'; + $lang['strmemberaddedbad'] = 'הוספת חבר נכשלה.'; + $lang['strdropmember'] = 'מחק חבר.'; + $lang['strconfdropmember'] = 'ב×× ×תה בטוח שברצונך למחוק ×ת החבר "%s" מהקבוצה "%s"?'; + $lang['strmemberdropped'] = 'חבר נמחק.'; + $lang['strmemberdroppedbad'] = 'מחיקת חבר נכשלה.'; + + // Privileges + $lang['strprivilege'] = 'זכות'; + $lang['strprivileges'] = 'זכויות'; + $lang['strnoprivileges'] = 'לנתון ×–×” יש זכויות ברירת מחדל של בעלי×.'; + $lang['strgrant'] = 'Grant'; + $lang['strrevoke'] = 'Revoke'; + $lang['strgranted'] = 'זכויות שונו.'; + $lang['strgrantfailed'] = 'שינוי זכויות נכשל.'; + $lang['strgrantbad'] = '×תה חייב לציין לפחות משתמש ×חד ×× ×§×‘×•×¦×” בעלי זכות.'; + $lang['strgrantor'] = 'Grantor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'בסיס נתוני×'; + $lang['strdatabases'] = 'בסיסי נתוני×'; + $lang['strshowalldatabases'] = 'הר××” ×ת כל בסיסי הנתוני×.'; + $lang['strnodatabase'] = 'בסיס × ×ª×•× ×™× ×œ× × ×ž×¦××”.'; + $lang['strnodatabases'] = '×œ× × ×ž×¦×ו בסיסי נתוני×.'; + $lang['strcreatedatabase'] = 'צור בסיס נתוני×.'; + $lang['strdatabasename'] = '×©× ×‘×¡×™×¡ הנתוני×'; + $lang['strdatabaseneedsname'] = '×תה חייב לתת ×©× ×œ×‘×¡×™×¡ ×”× ×ª×•× ×™× ×©×œ×š'; + $lang['strdatabasecreated'] = 'בסיס × ×ª×•× ×™× × ×•×¦×¨'; + $lang['strdatabasecreatedbad'] = 'יצירת בסיס × ×ª×•× ×™× × ×›×©×œ×”.'; + $lang['strconfdropdatabase'] = '×תה בטוח שברצונך למחוק ×ת בסיס ×”× ×ª×•× ×™× "%s"?'; + $lang['strdatabasedropped'] = 'מסד × ×ª×•× ×™× × ×ž×—×§'; + $lang['strdatabasedroppedbad'] = 'מחיקת מסד ×”× ×ª×•× ×™× × ×›×©×œ×”.'; + $lang['strentersql'] = 'הכנס ×ת ×” SQL כד××™ להריץ ×ותו פה:'; + $lang['strsqlexecuted'] = 'SQL הורץ.'; + $lang['strvacuumgood'] = 'ריק הושל×.'; + $lang['strvacuumbad'] = 'ריק נכשל.'; + $lang['stranalyzegood'] = 'ניתוח הושל×.'; + $lang['stranalyzebad'] = 'ניתוח נכשל.'; + $lang['strreindexgood'] = '×נידוקס מחדש הושל×.'; + $lang['strreindexbad'] = '×נידוקס מחדש נכשל.'; + $lang['strfull'] = 'מל×'; + $lang['strfreeze'] = 'Freeze'; + $lang['strforce'] = 'כוח'; + $lang['strsignalsent'] = 'שלח ×ות.'; + $lang['strsignalsentbad'] = 'שליחת ×ות נכשלה.'; + $lang['strallobjects'] = 'כל העצמי×'; + + // Views + $lang['strview'] = 'צפייה'; + $lang['strviews'] = 'צפיות'; + $lang['strshowallviews'] = 'הר××” ×ת כל הצפיות'; + $lang['strnoview'] = 'צפייה ×œ× × ×ž×¦××”.'; + $lang['strnoviews'] = 'צפיות ×œ× × ×ž×¦×ו.'; + $lang['strcreateview'] = 'צור צפייה'; + $lang['strviewname'] = '×©× ×”×¦×¤×™×™×”'; + $lang['strviewneedsname'] = '×תה חייב לתת ×©× ×œ×¦×¤×™×™×”'; + $lang['strviewneedsdef'] = '×תה חייב לציין הגדרה לצפייה.'; + $lang['strviewneedsfields'] = '×תה חייב לתת ×ת העמודה ×שר ×תה רוצה לצפייה.'; + $lang['strviewcreated'] = 'צפייה נוצרה.'; + $lang['strviewcreatedbad'] = 'יצירת צפייה נכשלה.'; + $lang['strconfdropview'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הצפייה "%s"'; + $lang['strviewdropped'] = 'צפייה נמחקה.'; + $lang['strviewdroppedbad'] = 'מחיקת צפייה נכשלה.'; + $lang['strviewupdated'] = 'צפייה עודכנה.'; + $lang['strviewupdatedbad'] = 'עדכון צפייה נכשלה.'; + $lang['strviewlink'] = 'קישורי מפתח'; + $lang['strviewconditions'] = 'Additional Conditions'; + $lang['strcreateviewwiz'] = 'צור צפייה בעזרת ×שף.'; + + // Sequences + $lang['strsequence'] = 'נוסחה'; + $lang['strsequences'] = 'נוסח×ות'; + $lang['strshowallsequences'] = 'הר××” ×ת כל הנוסח×ות.'; + $lang['strnosequence'] = 'נוסחה ×œ× × ×ž×¦××”.'; + $lang['strnosequences'] = '×œ× × ×ž×¦×ו נוסח×ות.'; + $lang['strcreatesequence'] = 'צור נוסחה'; + $lang['strlastvalue'] = 'ערך ×חרון'; + $lang['strincrementby'] = 'Increment by'; + $lang['strstartvalue'] = 'ערך התחלה'; + $lang['strmaxvalue'] = 'ערך מקסימלי'; + $lang['strminvalue'] = 'ערך מינימלי'; + $lang['strcachevalue'] = 'ערך מטמון'; + $lang['strlogcount'] = 'ספירת יומן'; + $lang['striscycled'] = 'Is cycled?'; + $lang['strsequenceneedsname'] = '×תה חייב לציין ×©× ×œ× ×•×¡×—×” שלך.'; + $lang['strsequencecreated'] = 'נוסחה נוצרה.'; + $lang['strsequencecreatedbad'] = 'יצירת נוסחה נכשלה.'; + $lang['strconfdropsequence'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הנוסחה "%s"?'; + $lang['strsequencedropped'] = 'נוסחה נמחקה..'; + $lang['strsequencedroppedbad'] = 'נחיקת נוסחה נכשלה.'; + $lang['strsequencereset'] = 'נוסחה ×ותחלה.'; + $lang['strsequenceresetbad'] = '×יתחול נוסחה נכשלה.'; + + // Indexes + $lang['strindex'] = '×ינדקס'; + $lang['strindexes'] = '×ינדקסי×'; + $lang['strindexname'] = '×©× ×”×ינדקס'; + $lang['strshowallindexes'] = 'צפה בכל ×”×ינדקסי×'; + $lang['strnoindex'] = '×ינדקס ×œ× × ×ž×¦××”.'; + $lang['strnoindexes'] = '×œ× × ×ž×¦×ו ×ינדקסי×.'; + $lang['strcreateindex'] = 'צור ×ינקדס.'; + $lang['strtabname'] = 'תקייה ×ינקדס'; + $lang['strcolumnname'] = '×©× ×”×¢×ž×•×“×”'; + $lang['strindexneedsname'] = '×תה חייב לציין ×©× ×œ×ינדקס.'; + $lang['strindexneedscols'] = '××™× ×“×§×¡×™× ×“×•×¨×©×™× ×ž×¡×¤×¨ תקין של עמודות.'; + $lang['strindexcreated'] = '×ינדקס נוצר.'; + $lang['strindexcreatedbad'] = 'יצירת ×ינקדס נכשלה.'; + $lang['strconfdropindex'] = '×”×× ×תה בטוח שברצונל למחוק ×ת ×”×ינקדס "%s"?'; + $lang['strindexdropped'] = '×ינדקס נמחק.'; + $lang['strindexdroppedbad'] = 'מחיקת ×ינדקס נכשלה.'; + $lang['strkeyname'] = '×©× ×”×ž×¤×ª×—'; + $lang['struniquekey'] = 'מ×תח יחודי'; + $lang['strprimarykey'] = 'מפתח ר×שי'; + $lang['strindextype'] = 'סוג ×”×ינדקס'; + $lang['strtablecolumnlist'] = 'עמודות בטבלה'; + $lang['strindexcolumnlist'] = 'עמודות ב×ינדקס'; + $lang['strconfcluster'] = '×”×× ×תה בטוח שברצונך למחוק ×ת ×”×שכול "%s"?'; + $lang['strclusteredgood'] = '×שכול הושל×.'; + $lang['strclusteredbad'] = '×שכול נכשל.'; + + // Rules + $lang['strrules'] = 'חוקי×'; + $lang['strrule'] = 'חוק'; + $lang['strshowallrules'] = 'הר××” ×ת כל החוקי×'; + $lang['strnorule'] = 'חוק ×œ× × ×ž×¦××”.'; + $lang['strnorules'] = '×œ× × ×ž×¦×ו חוקי×.'; + $lang['strcreaterule'] = 'צור חוק'; + $lang['strrulename'] = '×©× ×”×—×•×§'; + $lang['strruleneedsname'] = '×תה חייב לציין ×©× ×œ×—×•×§.'; + $lang['strrulecreated'] = 'חוק נוצר.'; + $lang['strrulecreatedbad'] = 'יצירת חוק נכשלה.'; + $lang['strconfdroprule'] = '×”×× ×תה בטוח שברצונך למחוק ×ת החוק "%s" מ "l%s"?'; + $lang['strruledropped'] = 'חוק נמחק.'; + $lang['strruledroppedbad'] = 'מחיקת חוק נכשלה.'; + + // Constraints + $lang['strconstraints'] = 'מבני×'; + $lang['strshowallconstraints'] = 'הר××” ×ת כל המבני×.'; + $lang['strnoconstraints'] = '×œ× × ×ž×¦×ו מבני×.'; + $lang['strcreateconstraint'] = 'צור מבנה'; + $lang['strconstraintcreated'] = 'מבנה נוצר.'; + $lang['strconstraintcreatedbad'] = 'יצירת מבנה נכשלה.'; + $lang['strconfdropconstraint'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הבמנה "%s" מ "%s"?'; + $lang['strconstraintdropped'] = 'מבנה נמחק.'; + $lang['strconstraintdroppedbad'] = 'מחיקת מבנה נכשלה.'; + $lang['straddcheck'] = 'הוסף בדיקה'; + $lang['strcheckneedsdefinition'] = 'בדיקת מבנה זקוקה להגדרה.'; + $lang['strcheckadded'] = 'בדיקה מבנה נוספה.'; + $lang['strcheckaddedbad'] = 'בדיקת מבנה נכשלה.'; + $lang['straddpk'] = 'הוסף מפתח ר×שי'; + $lang['strpkneedscols'] = 'מפתח ר×שי דורש לפחות עמודה ×חת.'; + $lang['strpkadded'] = 'מפתח ר×שי נוסף.'; + $lang['strpkaddedbad'] = 'הוספת מפתח ר×שי נכשלה.'; + $lang['stradduniq'] = 'הוסף מפתח מיוחד.'; + $lang['struniqneedscols'] = 'מפתח מיוחד דורש לפחות עמודה ×חת.'; + $lang['struniqadded'] = 'מפתח מיוחד נוסף.'; + $lang['struniqaddedbad'] = 'נוספת מפתח מיוחד נכשלה.'; + $lang['straddfk'] = 'הוסף מפתח זר'; + $lang['strfkneedscols'] = 'מפתח זר דורש לפתוח עמודה ×חת.'; + $lang['strfkneedstarget'] = 'מפתח זר דורש טבלת מטרה.'; + $lang['strfkadded'] = 'מפתח זר נוסף.'; + $lang['strfkaddedbad'] = 'יצירת מפתח זר נכשלה.'; + $lang['strfktarget'] = 'טבלת מטרה'; + $lang['strfkcolumnlist'] = 'עמודות במפתח'; + $lang['strondelete'] = 'DELETE ב'; + $lang['stronupdate'] = 'UPDATE ב'; + + // Functions + $lang['strfunction'] = 'פונקציה'; + $lang['strfunctions'] = 'פונקציות'; + $lang['strshowallfunctions'] = 'הר××” ×ת כל הפונקציות'; + $lang['strnofunction'] = 'פונקציה ×œ× × ×ž×¦××”.'; + $lang['strnofunctions'] = '×œ× × ×ž×¦×ו פונקציות.'; + $lang['strcreateplfunction'] = 'צור פונקצית SQL/PL'; + $lang['strcreateinternalfunction'] = 'צור פונקציה פנימית'; + $lang['strcreatecfunction'] = 'צור פונקצית C'; + $lang['strfunctionname'] = '×©× ×”×¤×•× ×§×¦×™×”'; + $lang['strreturns'] = 'חזרות'; + $lang['strarguments'] = '×רגומנטי×'; + $lang['strproglanguage'] = 'שפת תיכנות'; + $lang['strfunctionneedsname'] = '×תה חייב לתת ×©× ×œ×¤×•× ×§×¦×™×” שלך.'; + $lang['strfunctionneedsdef'] = '×תה חייב לציין הגדרה לפונקציה.'; + $lang['strfunctioncreated'] = 'פונקצייה נוצרה.'; + $lang['strfunctioncreatedbad'] = 'יצירת פונקצייה נכשלה.'; + $lang['strconfdropfunction'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הפונקצייה "%s"?'; + $lang['strfunctiondropped'] = 'פונקצייה נמחקה.'; + $lang['strfunctiondroppedbad'] = 'מחיקת פונקציה נכשלה.'; + $lang['strfunctionupdated'] = 'פונקציה עודכנה.'; + $lang['strfunctionupdatedbad'] = 'עדכון פונקציה נכשל.'; + $lang['strobjectfile'] = 'קובץ ×ובייקט'; + $lang['strlinksymbol'] = 'קישור סימלי'; + + // Triggers + $lang['strtrigger'] = 'זרז'; + $lang['strtriggers'] = 'זרזי×'; + $lang['strshowalltriggers'] = 'הר××” ×ת כל הזרזי×'; + $lang['strnotrigger'] = 'זרז ×œ× × ×™×ž×¦××”.'; + $lang['strnotriggers'] = '×œ× × ×™×ž×¦×ו זרזי×.'; + $lang['strcreatetrigger'] = 'צור זרז'; + $lang['strtriggerneedsname'] = '×תה חייב לציין ×©× ×œ×–×¨×–.'; + $lang['strtriggerneedsfunc'] = '×תה חייב לציין פונקציה לזרז.'; + $lang['strtriggercreated'] = 'זרז נוצר.'; + $lang['strtriggercreatedbad'] = 'יצירת זרז נכשלה.'; + $lang['strconfdroptrigger'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הזרז "%s" מ "%s"?'; + $lang['strtriggerdropped'] = 'זרז נמחק.'; + $lang['strtriggerdroppedbad'] = 'מחיקת זרז נכשלה.'; + $lang['strtriggeraltered'] = 'זרז נערך.'; + $lang['strtriggeralteredbad'] = 'עריכת זרז נכשלה.'; + + // Types + $lang['strtype'] = 'סוג'; + $lang['strtypes'] = 'סוגי×'; + $lang['strshowalltypes'] = 'הר××” ×ת כל הסוגי×.'; + $lang['strnotype'] = 'סוג ×œ× × ×ž×¦××”.'; + $lang['strnotypes'] = '×œ× × ×ž×¦×ו סוגי×.'; + $lang['strcreatetype'] = 'צור סוג'; + $lang['strcreatecomptype'] = 'Create composite type'; + $lang['strtypeneedsfield'] = '×תה חייב לציין לפחות שדה ×חד.'; + $lang['strtypeneedscols'] = '×תה חייב לציין מספר תקין של שדות.'; + $lang['strtypename'] = '×©× ×”×¡×•×’'; + $lang['strinputfn'] = 'פונקצית קלט'; + $lang['stroutputfn'] = 'פונקצית פלט'; + $lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'Alignment'; + $lang['strelement'] = '×למנט'; + $lang['strdelimiter'] = 'Delimiter'; + $lang['strstorage'] = '×חסנה'; + $lang['strtypeneedsname'] = '×תה חייב לציין ×©× ×œ×¡×•×’.'; + $lang['strtypeneedslen'] = '×תה חייב לציין ×ורך לסוג.'; + $lang['strtypecreated'] = 'סוג נוצר.'; + $lang['strtypecreatedbad'] = 'יצירת סוג נכשלה.'; + $lang['strconfdroptype'] = '×”×× ×תה בטוח שברצונך למחוק ×ת הסוג "%s"?'; + $lang['strtypedropped'] = 'סוג נמחק.'; + $lang['strtypedroppedbad'] = 'מחיקת סוג נכשלה.'; + $lang['strflavor'] = 'Flavor'; + $lang['strbasetype'] = 'בסיס'; + $lang['strcompositetype'] = 'Composite'; + $lang['strpseudotype'] = 'פ×סדו'; + + // Schemas + $lang['strschema'] = 'תרשי×'; + $lang['strschemas'] = 'תרשמי×'; + $lang['strshowallschemas'] = 'הר××” ×ת כל התרשימי×'; + $lang['strnoschema'] = '×ª×¨×©×™× ×œ× × ×ž×¦××”.'; + $lang['strnoschemas'] = '×œ× × ×ž×¦×ו תרשימי×.'; + $lang['strcreateschema'] = 'צור תרשי×'; + $lang['strschemaname'] = '×©× ×”×ª×¨×©×™×'; + $lang['strschemaneedsname'] = '×תה חייב לציין ×©× ×œ×ª×¨×©×™×.'; + $lang['strschemacreated'] = '×ª×¨×©×™× × ×•×¦×¨'; + $lang['strschemacreatedbad'] = 'יצירת ×ª×¨×©×™× × ×›×©×œ×”.'; + $lang['strconfdropschema'] = '×”×× ×תה בטוח שברצונך למחוק ×ת ×”×ª×¨×©×™× "?"?'; + $lang['strschemadropped'] = '×ª×¨×©×™× × ×ž×—×§.'; + $lang['strschemadroppedbad'] = 'מחיקת ×ª×¨×©×™× × ×›×©×œ×”.'; + $lang['strschemaaltered'] = '×ª×¨×©×™× × ×¢×¨×š.'; + $lang['strschemaalteredbad'] = 'עריכת ×ª×¨×©×™× × ×›×©×œ×”.'; + $lang['strsearchpath'] = 'חיפוש ×ž×™×§×•× ×”×ª×¨×©×™×.'; + + // Reports + + // Domains + $lang['strdomain'] = 'תחו×'; + $lang['strdomains'] = 'תחומי×'; + $lang['strshowalldomains'] = 'הר××” ×ת כל התחומי×'; + $lang['strnodomains'] = '×œ× × ×ž×¦×ו תחומי×.'; + $lang['strcreatedomain'] = 'צור תחו×'; + $lang['strdomaindropped'] = '×ª×—×•× × ×ž×—×§.'; + $lang['strdomaindroppedbad'] = 'מחיקת ×ª×—×•× × ×›×©×œ×”.'; + $lang['strconfdropdomain'] = '×”×× ×תה בטוח שברצונך למחוק ×ת ×”×ª×—×•× "%s"?'; + $lang['strdomainneedsname'] = '×תה חייב לציין ×©× ×œ×ª×—×•× ×©×œ×š.'; + $lang['strdomaincreated'] = '×ª×—×•× × ×•×¦×¨.'; + $lang['strdomaincreatedbad'] = 'יצירת ×ª×—×•× × ×›×©×œ×”.'; + $lang['strdomainaltered'] = '×ª×—×•× × ×¢×¨×š.'; + $lang['strdomainalteredbad'] = 'עריכת ×ª×—×•× × ×›×©×œ×”.'; + + // Operators + $lang['stroperator'] = 'מפעיל'; + $lang['stroperators'] = 'מפעילי×'; + $lang['strshowalloperators'] = 'הר××” ×ת כל המפעילי×'; + $lang['strnooperator'] = 'מפעיל ×œ× × ×ž×¦××”.'; + $lang['strnooperators'] = '×œ× × ×ž×¦×ו מפעילי×.'; + $lang['strcreateoperator'] = 'צור מפעיל'; + $lang['strleftarg'] = 'סידור סוג לשמ×ל'; + $lang['strrightarg'] = 'סידור שמ×ל לימין'; + $lang['strcommutator'] = 'Commutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'חבר'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'סידור לשמ×ל'; + $lang['strrightsort'] = 'סידור לימין'; + $lang['strlessthan'] = 'פחות מ'; + $lang['strgreaterthan'] = 'גדול מ'; + $lang['stroperatorneedsname'] = '×תה חייב לציין ×©× ×œ×ž×¤×¢×™×œ.'; + $lang['stroperatorcreated'] = 'מפעיל נוצר.'; + $lang['stroperatorcreatedbad'] = 'יצירת מפעיל נכשלה.'; + $lang['strconfdropoperator'] = '×”×× ×תה בטוח שברצונך למחוק ×ת המפעיל "%s"?'; + $lang['stroperatordropped'] = 'מפעיל נמחק.'; + $lang['stroperatordroppedbad'] = 'מחיקת מפעיל נכשלה.'; + + // Casts + $lang['strcasts'] = 'Casts'; + $lang['strnocasts'] = 'No casts found.'; + $lang['strsourcetype'] = 'סוג המקור'; + $lang['strtargettype'] = 'סוג המטרה'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'In assignment'; + $lang['strbinarycompat'] = '(Binary compatible)'; + + // Conversions + $lang['strconversions'] = 'המרה'; + $lang['strnoconversions'] = '×œ× × ×™×ž×¦××” המרה.'; + $lang['strsourceencoding'] = 'סוג הקידוד של המקור'; + $lang['strtargetencoding'] = 'סוג הקידוד של המטרה'; + + // Languages + $lang['strlanguages'] = 'שפות'; + $lang['strnolanguages'] = '×œ× × ×ž×¦×ו שפות'; + $lang['strtrusted'] = 'Trusted'; + + // Info + $lang['strnoinfo'] = '×ין מידע זמין.'; + $lang['strreferringtables'] = 'Referring tables'; + $lang['strparenttables'] = 'Parent tables'; + $lang['strchildtables'] = 'Child tables'; + + // Aggregates + $lang['straggregates'] = 'Aggregates'; + $lang['strnoaggregates'] = 'No aggregates found.'; + $lang['stralltypes'] = '(כל הסוגי×)'; + + // Operator Classes + $lang['stropclasses'] = 'Op Classes'; + $lang['strnoopclasses'] = 'No operator classes found.'; + $lang['straccessmethod'] = 'שיטת גישה'; + + // Stats and performance + $lang['strrowperf'] = 'תפקוד שדות'; + $lang['strioperf'] = 'תפקוד קלט/פלט'; + $lang['stridxrowperf'] = 'תפקוד ×נדוקס שדה'; + $lang['stridxioperf'] = 'תפקוד ×נדוקס קלט/פלט'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequential'; + $lang['strscan'] = 'חיפוש'; + $lang['strread'] = 'קר×'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'מטמון'; + $lang['strdisk'] = 'דיסק'; + $lang['strrows2'] = 'שורה'; + + // Tablespaces + $lang['strtablespace'] = 'מרחבון'; + $lang['strtablespaces'] = 'מרחבוני×'; + $lang['strshowalltablespaces'] = 'הר××” ×ת כל המרחבוני×'; + $lang['strnotablespaces'] = '×œ× × ×ž×¦×ו מרחבוני×.'; + $lang['strcreatetablespace'] = 'צור מרחבון'; + $lang['strlocation'] = 'מיקו×'; + $lang['strtablespaceneedsname'] = '×תה חייב לציין ×©× ×œ×ž×¨×—×‘×•×Ÿ.'; + $lang['strtablespaceneedsloc'] = '×תה חייב לציין תיקיה שבה יבצר המרחבון.'; + $lang['strtablespacecreated'] = 'מרחבון נוצר.'; + $lang['strtablespacecreatedbad'] = 'יצירת מרחבון נכשלה.'; + $lang['strconfdroptablespace'] = '×”×× ×תה בטוח שברצונך למחוק ×ת המרחבון "%s"?'; + $lang['strtablespacedropped'] = 'מרחבון נמחק.'; + $lang['strtablespacedroppedbad'] = 'מחיקת מרחבון נכשלה.'; + $lang['strtablespacealtered'] = 'מרחבון נערך.'; + $lang['strtablespacealteredbad'] = 'עריכת מרחבון מכשלה.'; + + // Miscellaneous + $lang['strtopbar'] = '%s רץ על %s:%s -- ×תה מחובר כמשתמש - "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'עזרה'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hungarian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hungarian.php new file mode 100644 index 00000000..125109b9 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/hungarian.php @@ -0,0 +1,901 @@ + + * + * + */ + + // Language and character set + $lang['applang'] = 'Magyar'; + $lang['applocale'] = 'hu-HU'; + $lang['applangdir'] = 'ltr'; + + // Welcome + $lang['strintro'] = 'Ãœdvözli a phpPgAdmin!'; + $lang['strppahome'] = 'A phpPgAdmin honlapja'; + $lang['strpgsqlhome'] = 'A PostgreSQL honlapja'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'A PostgreSQL (helyi) dokumentációja'; + $lang['strreportbug'] = 'Hibajelentés feladása'; + $lang['strviewfaq'] = 'GYIK megtekintése'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'Bejelentkezés'; + $lang['strloginfailed'] = 'Nem sikerült bejelentkezni'; + $lang['strlogindisallowed'] = 'Biztonsági okból engedélyezettlen a bejelentkezés.'; + $lang['strserver'] = 'Szolgáló'; + $lang['strservers'] = 'Szolgálók'; + $lang['strgroupservers'] = 'Szolgálók „%s†csoportban'; + $lang['strallservers'] = 'Minden szolgáló'; + $lang['strintroduction'] = 'BevezetÅ‘'; + $lang['strhost'] = 'Gazda'; + $lang['strport'] = 'Kapu'; + $lang['strlogout'] = 'Kilépés'; + $lang['strowner'] = 'Tulajdonos'; + $lang['straction'] = 'Művelet'; + $lang['stractions'] = 'Műveletek'; + $lang['strname'] = 'Név'; + $lang['strdefinition'] = 'Definíció'; + $lang['strproperties'] = 'Tulajdonságok'; + $lang['strbrowse'] = 'Tallóz'; + $lang['strenable'] = 'Enged'; + $lang['strdisable'] = 'Tilt'; + $lang['strdrop'] = 'Töröl'; + $lang['strdropped'] = 'Törlölve'; + $lang['strnull'] = 'Null'; + $lang['strnotnull'] = 'Not Null'; + $lang['strprev'] = '< ElÅ‘zÅ‘'; + $lang['strnext'] = 'KövetkezÅ‘ >'; + $lang['strfirst'] = '<< ElsÅ‘'; + $lang['strlast'] = 'Utolsó >>'; + $lang['strfailed'] = 'Sikertelen'; + $lang['strcreate'] = 'Teremt'; + $lang['strcreated'] = 'Megteremtve'; + $lang['strcomment'] = 'Megjegyzés'; + $lang['strlength'] = 'Hossz'; + $lang['strdefault'] = 'Alapértelmezés'; + $lang['stralter'] = 'Módosít'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Mégsem'; + $lang['strkill'] = 'Öl'; + $lang['strac'] = 'ÖnműködÅ‘ kiegészítés engedélyezése'; + $lang['strsave'] = 'Ment'; + $lang['strreset'] = 'Újra'; + $lang['strrestart'] = 'Újraindít'; + $lang['strinsert'] = 'Beszúr'; + $lang['strselect'] = 'Kiválaszt'; + $lang['strdelete'] = 'Töröl'; + $lang['strupdate'] = 'IdÅ‘szerűsít'; + $lang['strreferences'] = 'Hivatkozások'; + $lang['stryes'] = 'Igen'; + $lang['strno'] = 'Nem'; + $lang['strtrue'] = 'IGAZ'; + $lang['strfalse'] = 'HAMIS'; + $lang['stredit'] = 'Szerkeszt'; + $lang['strcolumn'] = 'Oszlop'; + $lang['strcolumns'] = 'Oszlopok'; + $lang['strrows'] = 'sor'; + $lang['strrowsaff'] = 'sor érintett.'; + $lang['strobjects'] = 'objektum'; + $lang['strback'] = 'Vissza'; + $lang['strqueryresults'] = 'Lekérdezés eredményei'; + $lang['strshow'] = 'Megjelenít'; + $lang['strempty'] = 'Ãœrít'; + $lang['strlanguage'] = 'Nyelv'; + $lang['strencoding'] = 'Kódolás'; + $lang['strvalue'] = 'Érték'; + $lang['strunique'] = 'egyedi'; + $lang['strprimary'] = 'ElsÅ‘dleges'; + $lang['strexport'] = 'Kivisz'; + $lang['strimport'] = 'Behoz'; + $lang['strallowednulls'] = 'Engedélyezett NULL betűk'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Ãœres szöveg/mezÅ‘'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Gazda'; + $lang['strvacuum'] = 'Takarít'; + $lang['stranalyze'] = 'Elemez'; + $lang['strclusterindex'] = 'Fürtöz'; + $lang['strclustered'] = 'Fürtözve?'; + $lang['strreindex'] = 'Újraindexel'; + $lang['strexecute'] = 'Végrehajt'; + $lang['stradd'] = 'BÅ‘vít'; + $lang['strevent'] = 'Esemény'; + $lang['strwhere'] = 'Hol'; + $lang['strinstead'] = 'Inkább'; + $lang['strwhen'] = 'Mikor'; + $lang['strformat'] = 'Alak'; + $lang['strdata'] = 'Adatok'; + $lang['strconfirm'] = 'MegerÅ‘sít'; + $lang['strexpression'] = 'Kifejezés'; + $lang['strellipsis'] = '…'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Kinyit'; + $lang['strcollapse'] = 'Összecsuk'; + $lang['strfind'] = 'Keres'; + $lang['stroptions'] = 'Részletek'; + $lang['strrefresh'] = 'Frissít'; + $lang['strdownload'] = 'Letöltés'; + $lang['strdownloadgzipped'] = 'Gzippel tömörített letöltés'; + $lang['strinfo'] = 'Infó'; + $lang['stroids'] = 'OID-k'; + $lang['stradvanced'] = 'Haladó'; + $lang['strvariables'] = 'Változók'; + $lang['strprocess'] = 'Folyamat'; + $lang['strprocesses'] = 'Folyamatok'; + $lang['strsetting'] = 'Beállítás'; + $lang['streditsql'] = 'SQL-szerkesztés'; + $lang['strruntime'] = 'Teljes futási idÅ‘: %s ms'; + $lang['strpaginate'] = 'Oldalakra tördelés'; + $lang['struploadscript'] = 'vagy egy SQL-írás feltöltése:'; + $lang['strstarttime'] = 'Kezdés ideje'; + $lang['strfile'] = 'Fájl'; + $lang['strfileimported'] = 'Fájl behozva.'; + $lang['strtrycred'] = 'Használja minden kiszolgálóhoz e beállításokat'; + $lang['strconfdropcred'] = 'Biztonság okán a szétválás megszünteti a megosztott bejelentkezÅ‘ adatait. Biztosan szét akar válni?'; + $lang['stractionsonmultiplelines'] = 'Több soros műveletek'; + $lang['strselectall'] = 'Mindent kiválaszt'; + $lang['strunselectall'] = 'Semmit sem választ ki'; + $lang['strlocale'] = 'Helyszín'; + $lang['strcollation'] = 'Összerakás'; + $lang['strctype'] = 'Betűtípus'; + $lang['strdefaultvalues'] = 'Alapértékek'; + $lang['strnewvalues'] = 'Új értékek'; + $lang['strstart'] = 'Indít'; + $lang['strstop'] = 'Leállít'; + $lang['strgotoppage'] = 'vissza a tetejére'; + $lang['strtheme'] = 'Téma'; + $lang['strcluster'] = 'Fürt'; + + // Admin + $lang['stradminondatabase'] = 'A következÅ‘ adminisztratív feladatok %s adatbázis egészére vonatkoznak.'; + $lang['stradminontable'] = 'A következÅ‘ adminisztratív feladatok %s táblára vonatkoznak.'; + + // User-supplied SQL history + $lang['strhistory'] = 'ElÅ‘zmények'; + $lang['strnohistory'] = 'Nincs elÅ‘zmény.'; + $lang['strclearhistory'] = 'ElÅ‘zményeket töröl'; + $lang['strdelhistory'] = 'ElÅ‘zményekbÅ‘l töröl'; + $lang['strconfdelhistory'] = 'Tényleg töröli e kérelmet az elÅ‘zményekbÅ‘l?'; + $lang['strconfclearhistory'] = 'Tényleg töröli az elÅ‘zményeket?'; + $lang['strnodatabaseselected'] = 'Ki kell választani az adatbázist.'; + + // Database sizes + $lang['strnoaccess'] = 'Nincs hozzáférés'; + $lang['strsize'] = 'Méret'; + $lang['strbytes'] = 'bájt'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Ez alkalmazás legjobban kereteket támogató böngészÅ‘vel működik, de használható keretek nélkül is az alábbi hivatkozásra kattintva.'; + $lang['strnoframeslink'] = 'Keretek nélküli használat'; + $lang['strbadconfig'] = 'A config.inc.php elavult. Újra kell teremteni az új config.inc.php-dist fájlból.'; + $lang['strnotloaded'] = 'Az ön PHP rendszere nem támogatja a PostgreSQL-t.'; + $lang['strpostgresqlversionnotsupported'] = 'A PostgreSQL e változata nem megfelelÅ‘. Kérem telepítse a %s változatot, vagy újabbat!'; + $lang['strbadschema'] = 'A megadott séma érvénytelen.'; + $lang['strbadencoding'] = 'Az ügyfél oldali kódolás beállítása az adatbázisban nem sikerült.'; + $lang['strsqlerror'] = 'SQL hiba:'; + $lang['strinstatement'] = 'A következÅ‘ kifejezésben:'; + $lang['strinvalidparam'] = 'Érvénytelen paraméterek.'; + $lang['strnodata'] = 'Nincsenek sorok.'; + $lang['strnoobjects'] = 'Nincsenek objektumok.'; + $lang['strrownotunique'] = 'Nincs egyedi azonosító ehhez a sorhoz.'; + $lang['strnouploads'] = 'Fájl feltöltése letiltva.'; + $lang['strimporterror'] = 'Behozatali hiba.'; + $lang['strimporterror-fileformat'] = 'Behozatali hiba: nem sikerült automatikusan megállapítani a fájl formátumát.'; + $lang['strimporterrorline'] = 'Behozatali hiba a %s. sorban.'; + $lang['strimporterrorline-badcolumnnum'] = 'Behozatali hiba a(z) %s. számú sorban: A sor nem tartalmazza a megfelelÅ‘ számú sort.'; + $lang['strimporterror-uploadedfile'] = 'Behozatali hiba: A fájlt nem sikerült feltülteni a kiszolgálóra.'; + $lang['strcannotdumponwindows'] = 'Összetett tábla ömlesztése és séma nevek Windows-on nem támogatottak.'; + $lang['strinvalidserverparam'] = 'Érvénytelen kiszolgáló paraméterrel próbáltak csatlakozni. Lehet, hogy valaki betörni próbál a rendszerbe.'; + $lang['strnoserversupplied'] = 'Nincs megadva kiszolgáló!'; + $lang['strbadpgdumppath'] = 'Kiviteli hiba: Elbukott a pg_dump végrehajtása (conf/config.inc.php fájlban megadott ösvény: %s). Kérem, javítsa ki ezt a beállításban, és ismételjen.'; + $lang['strbadpgdumpallpath'] = 'Kiviteli hiba: Elbukott a pg_dumpall végrehajtása (conf/config.inc.php fájlban megadott ösvény: %s). Kérem, javítsa ki ezt a beállításban, és ismételjen.'; + $lang['strconnectionfail'] = 'Nem csatlakozhatok a szolgálóhoz.'; + + // Tables + $lang['strtable'] = 'Tábla'; + $lang['strtables'] = 'Táblák'; + $lang['strshowalltables'] = 'Minden tábla megjelenítése'; + $lang['strnotables'] = 'Nincsenek táblák.'; + $lang['strnotable'] = 'Nincs tábla.'; + $lang['strcreatetable'] = 'Táblát teremt'; + $lang['strcreatetablelike'] = 'Táblát teremt mint'; + $lang['strcreatetablelikeparent'] = 'Forrás tábla'; + $lang['strcreatelikewithdefaults'] = 'ALAPÉRTELMEZÉSEKKEL'; + $lang['strcreatelikewithconstraints'] = 'MEGSZORÃTÃSOKKAL'; + $lang['strcreatelikewithindexes'] = 'INDEXEKKEL'; + $lang['strtablename'] = 'Tábla neve'; + $lang['strtableneedsname'] = 'Meg kell adni a tábla nevét.'; + $lang['strtablelikeneedslike'] = 'Meg kell adni a tábla nevét, ahonnan tulajdonságokat lehet másolni.'; + $lang['strtableneedsfield'] = 'Legalább egy oszlopot meg kell adni.'; + $lang['strtableneedscols'] = 'A táblának érvényes számú oszlop kell.'; + $lang['strtablecreated'] = 'A tábla megteremtve.'; + $lang['strtablecreatedbad'] = 'Nem sikerült táblát teremteni.'; + $lang['strconfdroptable'] = 'Biztosan törölni kívánja „%s†táblát?'; + $lang['strtabledropped'] = 'A tábla törölve.'; + $lang['strtabledroppedbad'] = 'Nem sikerült a táblát törölni.'; + $lang['strconfemptytable'] = 'Biztosan ki akarja üríteni „%s†táblát?'; + $lang['strtableemptied'] = 'A tábla kiürítve.'; + $lang['strtableemptiedbad'] = 'Nem sikerült a táblát kiüríteni.'; + $lang['strinsertrow'] = 'Sor beszúrása'; + $lang['strrowinserted'] = 'A sor beszúrva.'; + $lang['strrowinsertedbad'] = 'Nem sikerült a sort beszúrni.'; + $lang['strnofkref'] = 'Nincs %s idegen kulcshoz illÅ‘ érték.'; + $lang['strrowduplicate'] = 'Nem sikerült sort beszúrni. Dupla beszúrási kísérlet.'; + $lang['streditrow'] = 'Sor szerkesztése'; + $lang['strrowupdated'] = 'A sor idÅ‘szerűsítve.'; + $lang['strrowupdatedbad'] = 'Nem sikerült a sort idÅ‘szerűsíteni.'; + $lang['strdeleterow'] = 'Sor törlése'; + $lang['strconfdeleterow'] = 'Biztosan törölni kívánja ezt a sort?'; + $lang['strrowdeleted'] = 'A sor törölve.'; + $lang['strrowdeletedbad'] = 'Nem sikerült a sort törölni.'; + $lang['strinsertandrepeat'] = 'Beszúrás & Ismétlés'; + $lang['strnumcols'] = 'Oszlopok száma'; + $lang['strcolneedsname'] = 'Meg kell adnia az oszlop nevét'; + $lang['strselectallfields'] = 'Minden oszlop kijelölése'; + $lang['strselectneedscol'] = 'Ki kell választani egy oszlopot'; + $lang['strselectunary'] = 'Egyváltozós műveleteknek nem lehetnek értékei'; + $lang['strcolumnaltered'] = 'Az oszlop megváltoztatva.'; + $lang['strcolumnalteredbad'] = 'Nem sikerült az oszlopot megváltoztatni.'; + $lang['strconfdropcolumn'] = 'Biztosan törölni kívánja „%s†oszlopot „%s†táblából?'; + $lang['strcolumndropped'] = 'Az oszlop törölve.'; + $lang['strcolumndroppedbad'] = 'Nem sikerült az oszlopot törölni.'; + $lang['straddcolumn'] = 'Oszloppal bÅ‘vítés'; + $lang['strcolumnadded'] = 'Oszloppal bÅ‘vítve.'; + $lang['strcolumnaddedbad'] = 'Nem sikerült az oszloppal bÅ‘víteni.'; + $lang['strcascade'] = 'ZUHATAG'; + $lang['strtablealtered'] = 'A tábla megváltoztatva.'; + $lang['strtablealteredbad'] = 'Nem sikerült a táblát megváltoztatni.'; + $lang['strdataonly'] = 'Csak adatok'; + $lang['strstructureonly'] = 'Csak struktúra'; + $lang['strstructureanddata'] = 'Struktúra és adatok'; + $lang['strtabbed'] = 'Füles'; + $lang['strauto'] = 'Autó'; + $lang['strconfvacuumtable'] = 'Biztosan ki akarja takarítani „%s†táblát?'; + $lang['strconfanalyzetable'] = 'Biztosan elemezzük „%s†táblát?'; + $lang['strconfreindextable'] = 'Biztosan újra akarja indexelni „%s†táblát?'; + $lang['strconfclustertable'] = 'Biztosan fürtözni akarja „%s†táblát?'; + $lang['strestimatedrowcount'] = 'Becsült sorok száma'; + $lang['strspecifytabletoanalyze'] = 'Legalább egy elemzendÅ‘ táblát meg kell adni.'; + $lang['strspecifytabletoempty'] = 'Legalább egy ürítendÅ‘ táblát meg kell adni.'; + $lang['strspecifytabletodrop'] = 'Legalább egy törlendÅ‘ táblát meg kell adni.'; + $lang['strspecifytabletovacuum'] = 'Legalább egy takarítandó táblát meg kell adni.'; + $lang['strspecifytabletoreindex'] = 'Legalább egy indexelendÅ‘ táblát meg kell adni.'; + $lang['strspecifytabletocluster'] = 'Legalább egy fürtözendÅ‘ táblát meg kell adni.'; + $lang['strnofieldsforinsert'] = 'Oszloptalan táblába nem szúrhat be sort.'; + + // Columns + $lang['strcolprop'] = 'Tábla tulajdonságai'; + $lang['strnotableprovided'] = 'Nincs tábla megadva!'; + + // Users + $lang['struser'] = 'Használó'; + $lang['strusers'] = 'Használók'; + $lang['strusername'] = 'Használó neve'; + $lang['strpassword'] = 'Jelszó'; + $lang['strsuper'] = 'Rendszergazda?'; + $lang['strcreatedb'] = 'Létrehozhat AB-t?'; + $lang['strexpires'] = 'Lejár'; + $lang['strsessiondefaults'] = 'Munkamenet alapértékei'; + $lang['strnousers'] = 'Nincsenek használók.'; + $lang['struserupdated'] = 'Használó idÅ‘szerűsítve.'; + $lang['struserupdatedbad'] = 'Nem sikerült a használót idÅ‘szerűsíteni.'; + $lang['strshowallusers'] = 'Minden használó megjelenítése'; + $lang['strcreateuser'] = 'Használó teremtése'; + $lang['struserneedsname'] = 'A használónak nevet kell adni.'; + $lang['strusercreated'] = 'A használó megteremtve.'; + $lang['strusercreatedbad'] = 'Nem sikerült a használót megteremteni.'; + $lang['strconfdropuser'] = 'Biztosan törölni akarja „%s†használót?'; + $lang['struserdropped'] = 'A használó törölve.'; + $lang['struserdroppedbad'] = 'Nem sikerült a használót törölni.'; + $lang['straccount'] = 'Számla'; + $lang['strchangepassword'] = 'Jelszó megváltoztatása'; + $lang['strpasswordchanged'] = 'A jelszó megváltoztatva.'; + $lang['strpasswordchangedbad'] = 'Nem sikerült a jelszót megváltoztatni.'; + $lang['strpasswordshort'] = 'A jelszó túl rövid.'; + $lang['strpasswordconfirm'] = 'A jelszó nem egyezik a megerÅ‘sítéssel.'; + + // Groups + $lang['strgroup'] = 'Csoport'; + $lang['strgroups'] = 'Csoportok'; + $lang['strshowallgroups'] = 'Minden csoportot megjelenít'; + $lang['strnogroup'] = 'Nincs csoport.'; + $lang['strnogroups'] = 'Nincsenek csoportok.'; + $lang['strcreategroup'] = 'Csoportot teremt'; + $lang['strgroupneedsname'] = 'A csoportnak nevet kell adni.'; + $lang['strgroupcreated'] = 'A csoport megteremtve.'; + $lang['strgroupcreatedbad'] = 'Nem sikerült a csoportot megteremteni.'; + $lang['strconfdropgroup'] = 'Biztosan törölni kívánja „%s†csoportot?'; + $lang['strgroupdropped'] = 'A csoport törölve.'; + $lang['strgroupdroppedbad'] = 'Nem sikerült a csoportot törölni.'; + $lang['strmembers'] = 'Tagok'; + $lang['strmemberof'] = 'Tagja '; + $lang['stradminmembers'] = 'Admin tagok'; + $lang['straddmember'] = 'Tagot vesz fel'; + $lang['strmemberadded'] = 'Tag felvéve.'; + $lang['strmemberaddedbad'] = 'Nem sikerült tagot felvenni.'; + $lang['strdropmember'] = 'Tag kicsapása'; + $lang['strconfdropmember'] = 'Biztosan ki akarja csapni „%s†tagot „%s†csoportból?'; + $lang['strmemberdropped'] = 'A tag kicsapva.'; + $lang['strmemberdroppedbad'] = 'Nem sikerült a tagot kicsapni.'; + + // Roles + $lang['strrole'] = 'Szerep'; + $lang['strroles'] = 'Szerepek'; + $lang['strshowallroles'] = 'Minden szerepet megjelenít'; + $lang['strnoroles'] = 'Nincs szerep.'; + $lang['strinheritsprivs'] = 'Jogosultságokat örököl?'; + $lang['strcreaterole'] = 'Szerepet teremt'; + $lang['strcancreaterole'] = 'Teremthet szerepet?'; + $lang['strrolecreated'] = 'Szerep megteremtve.'; + $lang['strrolecreatedbad'] = 'Nem sikerült szerepet teremteni.'; + $lang['strrolealtered'] = 'Szerep megváltoztatva.'; + $lang['strrolealteredbad'] = 'Nem sikerült szerepet változtatni.'; + $lang['strcanlogin'] = 'Beléphet?'; + $lang['strconnlimit'] = 'Kapcsolat korlátja'; + $lang['strdroprole'] = 'Szerepet töröl'; + $lang['strconfdroprole'] = 'Biztosan töröljük „%s†szerepet?'; + $lang['strroledropped'] = 'Szerep törölve.'; + $lang['strroledroppedbad'] = 'Nem sikerült szerepet törölni.'; + $lang['strnolimit'] = 'Nincs korlát'; + $lang['strnever'] = 'Soha'; + $lang['strroleneedsname'] = 'Nevet kell adni a szerepnek.'; + + // Privileges + $lang['strprivilege'] = 'Jogosultság'; + $lang['strprivileges'] = 'Jogosultságok'; + $lang['strnoprivileges'] = 'Ez objektum alap-jogosultságokkal rendelkezik.'; + $lang['strgrant'] = 'Feljogosít'; + $lang['strrevoke'] = 'Jogosultságot megvon'; + $lang['strgranted'] = 'A jogosultságok megváltoztatva.'; + $lang['strgrantfailed'] = 'Nem sikerült a jogosultságokat megváltoztatni.'; + $lang['strgrantbad'] = 'Legalább egy felhasználót és jogosultságot ki kell választani.'; + $lang['strgrantor'] = 'Jogosító'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Adatbázis'; + $lang['strdatabases'] = 'Adatbázisok'; + $lang['strshowalldatabases'] = 'Minden adatbázist megjelenít'; + $lang['strnodatabases'] = 'Nincs adatbázis.'; + $lang['strcreatedatabase'] = 'Adatbázist teremt'; + $lang['strdatabasename'] = 'Adatbázisnév'; + $lang['strdatabaseneedsname'] = 'Meg kell adni az adatbázis nevét.'; + $lang['strdatabasecreated'] = 'Az adatbázis megteremtve.'; + $lang['strdatabasecreatedbad'] = 'Nem sikerült megteremteni az adatbázist.'; + $lang['strconfdropdatabase'] = 'Biztosan törölni akarja „%s†adatbázist?'; + $lang['strdatabasedropped'] = 'Az adatbázis törölve.'; + $lang['strdatabasedroppedbad'] = 'Nem sikerült törölni az adatbázist.'; + $lang['strentersql'] = 'Ãrja be a végrehajtandó SQL-kifejezéseket ide:'; + $lang['strsqlexecuted'] = 'Az SQL-kifejezések végrehajtva.'; + $lang['strvacuumgood'] = 'A takarítás kész.'; + $lang['strvacuumbad'] = 'Nem sikerült kitakarítani.'; + $lang['stranalyzegood'] = 'Az elemzés kész.'; + $lang['stranalyzebad'] = 'Nem sikerült kielemezni.'; + $lang['strreindexgood'] = 'Újraindexelés kész.'; + $lang['strreindexbad'] = 'Nem sikerült az újraindexelés.'; + $lang['strfull'] = 'Teljes'; + $lang['strfreeze'] = 'Befagyaszt'; + $lang['strforce'] = 'Kényszerít'; + $lang['strsignalsent'] = 'Jelzés elküldve.'; + $lang['strsignalsentbad'] = 'Nem sikerült jelzést küldeni.'; + $lang['strallobjects'] = 'Minden objektum'; + $lang['strdatabasealtered'] = 'Adatbázis megváltoztatva.'; + $lang['strdatabasealteredbad'] = 'Nem sikerült az adatbázist megváltoztatni.'; + $lang['strspecifydatabasetodrop'] = 'Meg kell adni a törlendÅ‘ adatbázist'; + $lang['strtemplatedb'] = 'Sablon'; + $lang['strconfanalyzedatabase'] = 'Biztosan elemezni akarja „%s†adatbázis minden tábláját?'; + $lang['strconfvacuumdatabase'] = 'Biztosan takarítani akarja „%s†adatbázis minden tábláját?'; + $lang['strconfreindexdatabase'] = 'Biztosan indexelni akarja „%s†adatbázis minden tábláját?'; + $lang['strconfclusterdatabase'] = 'Biztosan fürtözni akarja „%s†adatbázis minden tábláját?'; + + // Views + $lang['strview'] = 'Nézet'; + $lang['strviews'] = 'Nézetek'; + $lang['strshowallviews'] = 'Minden nézetet megjelenít'; + $lang['strnoview'] = 'Nincs nézet.'; + $lang['strnoviews'] = 'Nincsenek nézetek.'; + $lang['strcreateview'] = 'Nézetet teremt'; + $lang['strviewname'] = 'Nézetnév'; + $lang['strviewneedsname'] = 'Meg kell adni a nézetnevet.'; + $lang['strviewneedsdef'] = 'Meg kell adni a nézet definícióját.'; + $lang['strviewneedsfields'] = 'Meg kell adnia a oszlopokat, amiket ki akar jelölni a nézetben.'; + $lang['strviewcreated'] = 'A nézet megteremtve.'; + $lang['strviewcreatedbad'] = 'Nem sikerült megteremteni a nézetet.'; + $lang['strconfdropview'] = 'Biztosan törölni kívánja „%s†nézetet?'; + $lang['strviewdropped'] = 'A nézet törölve.'; + $lang['strviewdroppedbad'] = 'Nem sikerült törölni a nézetet.'; + $lang['strviewupdated'] = 'A nézet idÅ‘szerűsítve.'; + $lang['strviewupdatedbad'] = 'Nem sikerült idÅ‘szerűsíteni a nézetet.'; + $lang['strviewlink'] = 'Hivatkozások'; + $lang['strviewconditions'] = 'További feltételek'; + $lang['strcreateviewwiz'] = 'Nézetet teremt varázslóval'; + $lang['strrenamedupfields'] = 'Másolt mezÅ‘ket nevez át'; + $lang['strdropdupfields'] = 'Másolt mezÅ‘ket töröl'; + $lang['strerrordupfields'] = 'Hiba a másolt mezÅ‘kben'; + $lang['strviewaltered'] = 'Nézet megváltoztatva.'; + $lang['strviewalteredbad'] = 'Nem sikerült megváltoztatni a nézetet.'; + $lang['strspecifyviewtodrop'] = 'Meg kell adni a törlendÅ‘ nézetet'; + + // Sequences + $lang['strsequence'] = 'Sorozat'; + $lang['strsequences'] = 'Sorozatok'; + $lang['strshowallsequences'] = 'Minden sorozatot megjelenít'; + $lang['strnosequence'] = 'Nincs sorozat.'; + $lang['strnosequences'] = 'Nincsenek sorozatok.'; + $lang['strcreatesequence'] = 'Sorozatot teremt'; + $lang['strlastvalue'] = 'Utolsó érték'; + $lang['strincrementby'] = 'Növekmény'; + $lang['strstartvalue'] = 'KezdÅ‘ érték'; + $lang['strrestartvalue'] = 'ÚjrakezdÅ‘ érték'; + $lang['strmaxvalue'] = 'FelsÅ‘ korlát'; + $lang['strminvalue'] = 'Alsó korlát'; + $lang['strcachevalue'] = 'Gyorstár értéke'; + $lang['strlogcount'] = 'Számláló'; + $lang['strcancycle'] = 'Körbejárhat?'; + $lang['striscalled'] = 'Növekedjék mielÅ‘tt visszatér a következÅ‘ értékkel (is_called)?'; + $lang['strsequenceneedsname'] = 'Meg kell adni a sorozatnevet.'; + $lang['strsequencecreated'] = 'A sorozat megteremtve.'; + $lang['strsequencecreatedbad'] = 'Nem sikerült megteremteni a sorozatot.'; + $lang['strconfdropsequence'] = 'Biztosan törölni kívánja „%s†sorozatot?'; + $lang['strsequencedropped'] = 'A sorozat törölve.'; + $lang['strsequencedroppedbad'] = 'Nem sikerült törölni a sorozatot.'; + $lang['strsequencerestart'] = 'Sorozat újrakezdve.'; + $lang['strsequencerestartbad'] = 'Nem sikerült újrakezdeni a sorozatot.'; + $lang['strsequencereset'] = 'Sorozat nullázása.'; + $lang['strsequenceresetbad'] = 'Nem sikerült nullázni a sorozatot.'; + $lang['strsequencealtered'] = 'Sorozat megváltoztatva.'; + $lang['strsequencealteredbad'] = 'Nem sikerült megváltoztatni a sorozatot.'; + $lang['strsetval'] = 'Értéket ad'; + $lang['strsequencesetval'] = 'Érték megadva.'; + $lang['strsequencesetvalbad'] = 'Nem sikerült az értékadás.'; + $lang['strnextval'] = 'Növekmény'; + $lang['strsequencenextval'] = 'Sorozat megnövelve.'; + $lang['strsequencenextvalbad'] = 'Nem sikerült megnövelni a sorozatot.'; + $lang['strspecifysequencetodrop'] = 'Meg kell adnia a törlendÅ‘ sorozatot'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indexek'; + $lang['strindexname'] = 'Indexnév'; + $lang['strshowallindexes'] = 'Minden indexet megjelenít'; + $lang['strnoindex'] = 'Nincs index.'; + $lang['strnoindexes'] = 'Nincsenek indexek.'; + $lang['strcreateindex'] = 'Indexet teremt'; + $lang['strtabname'] = 'Táblanév'; + $lang['strcolumnname'] = 'Oszlopnév'; + $lang['strindexneedsname'] = 'Meg kell adni az index nevét.'; + $lang['strindexneedscols'] = 'Meg kell adni az oszlopok (érvényes) számát.'; + $lang['strindexcreated'] = 'Az index megteremtve'; + $lang['strindexcreatedbad'] = 'Nem sikerült megteremteni az indexet.'; + $lang['strconfdropindex'] = 'Biztosan törölni kívánja „%s†indexet?'; + $lang['strindexdropped'] = 'Az index törölve.'; + $lang['strindexdroppedbad'] = 'Nem sikerült törölni az indexet.'; + $lang['strkeyname'] = 'Kulcsnév'; + $lang['struniquekey'] = 'Egyedi kulcs'; + $lang['strprimarykey'] = 'ElsÅ‘dleges kulcs'; + $lang['strindextype'] = 'Indextípus'; + $lang['strtablecolumnlist'] = 'A tábla oszlopai'; + $lang['strindexcolumnlist'] = 'Az index oszlopai'; + $lang['strclusteredgood'] = 'Fürtözés kész.'; + $lang['strclusteredbad'] = 'Nem sikerült fürtözni.'; + $lang['strconcurrently'] = 'Egyszerre'; + $lang['strnoclusteravailable'] = 'A tábla nincs indexre fürtözve.'; + + // Rules + $lang['strrules'] = 'Szabályok'; + $lang['strrule'] = 'Szabály'; + $lang['strshowallrules'] = 'Minden szabályt megjelenít'; + $lang['strnorule'] = 'Nincs szabály.'; + $lang['strnorules'] = 'Nincsenek szabályok.'; + $lang['strcreaterule'] = 'Szabályt teremt'; + $lang['strrulename'] = 'Szabálynév'; + $lang['strruleneedsname'] = 'Meg kell adni a szabálynevet.'; + $lang['strrulecreated'] = 'A szabály megteremtve.'; + $lang['strrulecreatedbad'] = 'Nem sikerült megteremteni a szabályt.'; + $lang['strconfdroprule'] = 'Biztosan törölni kívánja „%s†szabályt „%s†táblában?'; + $lang['strruledropped'] = 'A szabály törölve.'; + $lang['strruledroppedbad'] = 'Nem sikerült törölni a szabályt.'; + + // Constraints + $lang['strconstraint'] = 'Megszorítás'; + $lang['strconstraints'] = 'Megszorítások'; + $lang['strshowallconstraints'] = 'Minden megszorítást megjelenít'; + $lang['strnoconstraints'] = 'Nincsenek megszorítások.'; + $lang['strcreateconstraint'] = 'Megszorítást teremt'; + $lang['strconstraintcreated'] = 'A megszorítás megteremtve.'; + $lang['strconstraintcreatedbad'] = 'Nem sikerült megteremteni a megszorítást.'; + $lang['strconfdropconstraint'] = 'Biztosan törölni kívánja „%s†megszorítást „%s†táblában?'; + $lang['strconstraintdropped'] = 'A megszorítás törölve.'; + $lang['strconstraintdroppedbad'] = 'Nem sikerült törölni a megszorítást.'; + $lang['straddcheck'] = 'EllenÅ‘rzést ad hozzá'; + $lang['strcheckneedsdefinition'] = 'Meg kell adni az ellenÅ‘rzés definícióját.'; + $lang['strcheckadded'] = 'Az ellenÅ‘rzés hozzáadva.'; + $lang['strcheckaddedbad'] = 'Nem sikerült hozzáadni az ellenÅ‘rzést.'; + $lang['straddpk'] = 'ElsÅ‘dleges kulcsot ad hozzá'; + $lang['strpkneedscols'] = 'Legalább egy oszlopot meg kell adni elsÅ‘dleges kulcsnak.'; + $lang['strpkadded'] = 'ElsÅ‘dleges kulcs hozzáadva.'; + $lang['strpkaddedbad'] = 'Nem sikerült hozzáadni az elsÅ‘dleges kulcsot.'; + $lang['stradduniq'] = 'Egyedi kulcsot ad hozzá'; + $lang['struniqneedscols'] = 'Legalább egy oszlopot meg kell adni egyedi kulcsnak.'; + $lang['struniqadded'] = 'Az egyedi kulcs hozzáadva.'; + $lang['struniqaddedbad'] = 'Nem sikerült hozzáadni az egyedi kulcsot.'; + $lang['straddfk'] = 'KülsÅ‘ kulcsot ad hozzá'; + $lang['strfkneedscols'] = 'Legalább egy oszlopot meg kell adni külsÅ‘ kulcsnak.'; + $lang['strfkneedstarget'] = 'Meg kell adni a céltáblát a külsÅ‘ kulcsnak.'; + $lang['strfkadded'] = 'A külsÅ‘ kulcs hozzáadva.'; + $lang['strfkaddedbad'] = 'Nem sikerült hozzáadni a külsÅ‘ kulcsot.'; + $lang['strfktarget'] = 'Céltábla'; + $lang['strfkcolumnlist'] = 'Kulcsoszlopok'; + $lang['strondelete'] = 'TÖRLÉSKOR'; + $lang['stronupdate'] = 'VÃLTOZTATÃSKOR'; + + // Functions + $lang['strfunction'] = 'Függvény'; + $lang['strfunctions'] = 'Függvények'; + $lang['strshowallfunctions'] = 'Minden függvényt megjelenít'; + $lang['strnofunction'] = 'Nincs függvény.'; + $lang['strnofunctions'] = 'Nincsenek függvények.'; + $lang['strcreateplfunction'] = 'SQL/PL függvényt teremt'; + $lang['strcreateinternalfunction'] = 'BelsÅ‘ függvényt teremt'; + $lang['strcreatecfunction'] = 'C függvényt teremt'; + $lang['strfunctionname'] = 'Függvénynév'; + $lang['strreturns'] = 'VisszatérÅ‘ érték'; + $lang['strproglanguage'] = 'Programnyelv'; + $lang['strfunctionneedsname'] = 'Meg kell adni a függvény nevét.'; + $lang['strfunctionneedsdef'] = 'Meg kell adni a függvény definícióját.'; + $lang['strfunctioncreated'] = 'A függvény megteremtve.'; + $lang['strfunctioncreatedbad'] = 'Nem sikerült megteremteni a függvényt.'; + $lang['strconfdropfunction'] = 'Biztosan törölni kívánja „%s†függvényt?'; + $lang['strfunctiondropped'] = 'A függvény törölve.'; + $lang['strfunctiondroppedbad'] = 'Nem sikerült törölni a függvényt.'; + $lang['strfunctionupdated'] = 'A függvény idÅ‘szerűsítve.'; + $lang['strfunctionupdatedbad'] = 'Nem sikerült a függvényt idÅ‘szerűsíteni.'; + $lang['strobjectfile'] = 'Célkód fájl'; + $lang['strlinksymbol'] = 'SzerkesztÅ‘ szimbólum'; + $lang['strarguments'] = 'Argumentumok'; + $lang['strargmode'] = 'Mód'; + $lang['strargtype'] = 'Típus'; + $lang['strargadd'] = 'Más argumentumot ad hozzá'; + $lang['strargremove'] = 'Argumentumot töröl'; + $lang['strargnoargs'] = 'E függvénynek nincsenek argumentumai.'; + $lang['strargenableargs'] = 'E függvénynek átadott argumentumok engedélyezése.'; + $lang['strargnorowabove'] = 'Egy sornak kell lennie e fölött.'; + $lang['strargnorowbelow'] = 'Egy sornak kell lennie ez alatt.'; + $lang['strargraise'] = 'Mozgás fel.'; + $lang['strarglower'] = 'Mozgás le.'; + $lang['strargremoveconfirm'] = 'Biztosan töröljük ez argumentumot? Ez VISSZAVONHATATLAN.'; + $lang['strfunctioncosting'] = 'Függvény költségei'; + $lang['strresultrows'] = 'Eredmény sorok'; + $lang['strexecutioncost'] = 'Végrehajtás költsége'; + $lang['strspecifyfunctiontodrop'] = 'Legalább egy törlendÅ‘ függvényt meg kell adni'; + + // Triggers + $lang['strtrigger'] = 'Ravasz'; + $lang['strtriggers'] = 'Ravaszok'; + $lang['strshowalltriggers'] = 'Minden ravaszt megjelenít'; + $lang['strnotrigger'] = 'Nincs ravasz.'; + $lang['strnotriggers'] = 'Nincsenek ravaszok.'; + $lang['strcreatetrigger'] = 'Ravaszt teremt'; + $lang['strtriggerneedsname'] = 'Meg kell adni a ravasz nevét.'; + $lang['strtriggerneedsfunc'] = 'Meg kell adni egy függvény nevét a ravaszhoz.'; + $lang['strtriggercreated'] = 'Ravasz megteremtve.'; + $lang['strtriggercreatedbad'] = 'Nem sikerült megteremteni a ravaszt.'; + $lang['strconfdroptrigger'] = 'Biztosan törölni kívánja „%s†ravaszt „%s†táblában?'; + $lang['strconfenabletrigger'] = 'Biztosan engedélyezzük „%s†ravaszt „%s†elemre?'; + $lang['strconfdisabletrigger'] = 'Biztosan letiltsuk „%s†ravaszt „%s†elemre?'; + $lang['strtriggerdropped'] = 'Ravasz törölve.'; + $lang['strtriggerdroppedbad'] = 'Nem sikerült törölni a ravaszt.'; + $lang['strtriggerenabled'] = 'Ravasz engedélyezve.'; + $lang['strtriggerenabledbad'] = 'Nem sikerült a ravaszt engedélyezni.'; + $lang['strtriggerdisabled'] = 'Ravasz letiltva.'; + $lang['strtriggerdisabledbad'] = 'Nem sikerült a ravaszt letiltani.'; + $lang['strtriggeraltered'] = 'Ravasz megváltoztatva.'; + $lang['strtriggeralteredbad'] = 'Nem sikerült megváltoztatni a triggert.'; + $lang['strforeach'] = 'Mindegyik'; + + // Types + $lang['strtype'] = 'Típus'; + $lang['strtypes'] = 'Típusok'; + $lang['strshowalltypes'] = 'Minden típust megjelenít'; + $lang['strnotype'] = 'Nincs típus.'; + $lang['strnotypes'] = 'Nincsenek típusok.'; + $lang['strcreatetype'] = 'Típust teremt'; + $lang['strcreatecomptype'] = 'Összetett típust teremt'; + $lang['strcreateenumtype'] = 'Felsorolás típust teremt'; + $lang['strtypeneedsfield'] = 'Legalább egy oszlopot meg kell adnia.'; + $lang['strtypeneedsvalue'] = 'Legalább egy értéket meg kell adni.'; + $lang['strtypeneedscols'] = 'Érvényes oszlopszámot kell megadnia.'; + $lang['strtypeneedsvals'] = 'Érvényes értékszámot kell megadni.'; + $lang['strinputfn'] = 'Beviteli függvény'; + $lang['stroutputfn'] = 'Kiviteli függvény'; + $lang['strpassbyval'] = 'Érték szerinti átadás?'; + $lang['stralignment'] = 'Igazít'; + $lang['strelement'] = 'Elem'; + $lang['strdelimiter'] = 'Határoló'; + $lang['strstorage'] = 'Tár'; + $lang['strfield'] = 'Oszlop'; + $lang['strnumfields'] = 'Oszlopok száma'; + $lang['strnumvalues'] = 'Értékek száma'; + $lang['strtypeneedsname'] = 'Típusnevet kell megadni.'; + $lang['strtypeneedslen'] = 'Meg kell adni a típus hosszát.'; + $lang['strtypecreated'] = 'Típus megteremtve'; + $lang['strtypecreatedbad'] = 'Nem sikerült megteremteni a típust.'; + $lang['strconfdroptype'] = 'Biztosan törölni kívánja „%s†típust?'; + $lang['strtypedropped'] = 'Típus törölve.'; + $lang['strtypedroppedbad'] = 'Nem sikerült törölni a típust.'; + $lang['strflavor'] = 'Fajta'; + $lang['strbasetype'] = 'Alap'; + $lang['strcompositetype'] = 'Összetett'; + $lang['strpseudotype'] = 'Ãl'; + $lang['strenum'] = 'Felsorolás'; + $lang['strenumvalues'] = 'Felsorolás értékei'; + + // Schemas + $lang['strschema'] = 'Séma'; + $lang['strschemas'] = 'Sémák'; + $lang['strshowallschemas'] = 'Minden sémát megjelenít'; + $lang['strnoschema'] = 'Nincs séma.'; + $lang['strnoschemas'] = 'Nincsenek sémák.'; + $lang['strcreateschema'] = 'Sémát teremt'; + $lang['strschemaname'] = 'Sémanév'; + $lang['strschemaneedsname'] = 'Meg kell adni a sémanevet.'; + $lang['strschemacreated'] = 'A séma megteremtve'; + $lang['strschemacreatedbad'] = 'Nem sikerült a sémát megteremteni.'; + $lang['strconfdropschema'] = 'Biztosan törölni kívánja „%s†sémát?'; + $lang['strschemadropped'] = 'A séma törölve.'; + $lang['strschemadroppedbad'] = 'Nem sikerült a sémát törölni.'; + $lang['strschemaaltered'] = 'Séma megváltoztatva.'; + $lang['strschemaalteredbad'] = 'Nem sikerült a sémát megváltoztatni.'; + $lang['strsearchpath'] = 'Séma keresési útvonala'; + $lang['strspecifyschematodrop'] = 'Meg kell adni a törlendÅ‘ sémát'; + + // Reports + + // Domains + $lang['strdomain'] = 'Tartomány'; + $lang['strdomains'] = 'Tartományok'; + $lang['strshowalldomains'] = 'Minden tartományt megjelenít'; + $lang['strnodomains'] = 'Nincsnek tartományok.'; + $lang['strcreatedomain'] = 'Tartományt teremt'; + $lang['strdomaindropped'] = 'A tartomány törölve.'; + $lang['strdomaindroppedbad'] = 'Nem sikerült törölni a tartományt.'; + $lang['strconfdropdomain'] = 'Biztosan törölni kívánja „%s†tartományt?'; + $lang['strdomainneedsname'] = 'Meg kell adni a tartománynevet.'; + $lang['strdomaincreated'] = 'A tartomány megteremtve.'; + $lang['strdomaincreatedbad'] = 'Nem sikerült megteremteni a tartományt.'; + $lang['strdomainaltered'] = 'A tartomány megváltoztatva.'; + $lang['strdomainalteredbad'] = 'Nem sikerült megváltoztatni a tartományt.'; + + // Operators + $lang['stroperator'] = 'Operátor'; + $lang['stroperators'] = 'Operátorok'; + $lang['strshowalloperators'] = 'Minden operátort megjelenít'; + $lang['strnooperator'] = 'Nincs operátor.'; + $lang['strnooperators'] = 'Nincsenek operátorok.'; + $lang['strcreateoperator'] = 'Operátort teremt'; + $lang['strleftarg'] = 'Bal arg típus'; + $lang['strrightarg'] = 'Jobb arg típus'; + $lang['strcommutator'] = 'Kommutátor'; + $lang['strnegator'] = 'Tagadó'; + $lang['strrestrict'] = 'Megszorítás'; + $lang['strjoin'] = 'Összekapcsolás'; + $lang['strhashes'] = 'Hasít'; + $lang['strmerges'] = 'Összefésül'; + $lang['strleftsort'] = 'Balrendezés'; + $lang['strrightsort'] = 'Jobbrendezés'; + $lang['strlessthan'] = 'Kisebb mint'; + $lang['strgreaterthan'] = 'Nagyobb mint'; + $lang['stroperatorneedsname'] = 'Meg kell adni az operátornevet.'; + $lang['stroperatorcreated'] = 'Az operátor megteremtve'; + $lang['stroperatorcreatedbad'] = 'Nem sikerült megteremteni az operátort.'; + $lang['strconfdropoperator'] = 'Biztosan törölni kívánja „%s†operátort?'; + $lang['stroperatordropped'] = 'Az operátor törölve.'; + $lang['stroperatordroppedbad'] = 'Nem sikerült törölni az operátort.'; + + // Casts + $lang['strcasts'] = 'Kasztok'; + $lang['strnocasts'] = 'Nincsenek kasztok.'; + $lang['strsourcetype'] = 'Forrástípus'; + $lang['strtargettype'] = 'Céltípus'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'Értékadásban'; + $lang['strbinarycompat'] = '(Binárisan kompatibilis)'; + + // Conversions + $lang['strconversions'] = 'Ãtalakítások'; + $lang['strnoconversions'] = 'Nincsenek átalakítások.'; + $lang['strsourceencoding'] = 'Forráskódolás'; + $lang['strtargetencoding'] = 'Célkódolás'; + + // Languages + $lang['strlanguages'] = 'Nyelvek'; + $lang['strnolanguages'] = 'Nincsenek nyelvek.'; + $lang['strtrusted'] = 'Hiteles'; + + // Info + $lang['strnoinfo'] = 'Nincs elérhetÅ‘ információ.'; + $lang['strreferringtables'] = 'Kapcsolódó táblák'; + $lang['strparenttables'] = 'SzülÅ‘táblák'; + $lang['strchildtables'] = 'Gyerektáblák'; + + // Aggregates + $lang['straggregate'] = 'Aggregálás'; + $lang['straggregates'] = 'Aggregálások'; + $lang['strnoaggregates'] = 'Nincsenek aggregálások.'; + $lang['stralltypes'] = '(Minden típus)'; + $lang['strcreateaggregate'] = 'Aggregálást teremt'; + $lang['straggrbasetype'] = 'BemenÅ‘ adattípus'; + $lang['straggrsfunc'] = 'Ãllapotátmeneti függvény'; + $lang['straggrstype'] = 'Ãllapotérték adattípusa'; + $lang['straggrffunc'] = 'VégsÅ‘ függvény'; + $lang['straggrinitcond'] = 'KezdÅ‘ feltétel'; + $lang['straggrsortop'] = 'RendezÅ‘ művelet'; + $lang['strconfdropaggregate'] = 'Biztosan töröljük „%s†aggregálást?'; + $lang['straggregatedropped'] = 'Aggregálás törölve.'; + $lang['straggregatedroppedbad'] = 'Nem sikerült törölni az aggregálást.'; + $lang['straggraltered'] = 'Aggregálás megváltoztatva.'; + $lang['straggralteredbad'] = 'Nem sikerült az aggregálást megváltoztatni.'; + $lang['straggrneedsname'] = 'Meg kell adni az aggregálás nevét.'; + $lang['straggrneedsbasetype'] = 'Meg kell adni az aggregálás bemenÅ‘ adattípusát.'; + $lang['straggrneedssfunc'] = 'Meg kell adni az aggregálás állapotátmeneti függvényének nevét.'; + $lang['straggrneedsstype'] = 'Meg kell adni az aggregálás állapotértékének adattípusát.'; + $lang['straggrcreated'] = 'Aggregálás megteremtve.'; + $lang['straggrcreatedbad'] = 'Nem sikerült megteremteni az aggregálást.'; + $lang['straggrshowall'] = 'Minden aggregálás megjelenítése'; + + // Operator Classes + $lang['stropclasses'] = 'Operátor-osztályok'; + $lang['strnoopclasses'] = 'Nincsenek operátor-osztályok.'; + $lang['straccessmethod'] = 'Hozzáférés módja'; + + // Stats and performance + $lang['strrowperf'] = 'Sorteljesítmény'; + $lang['strioperf'] = 'I/O-teljesítmény'; + $lang['stridxrowperf'] = 'Indexsor-teljesítmény'; + $lang['stridxioperf'] = 'Index-I/O-teljesítmény'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Szekvenciális'; + $lang['strscan'] = 'Keresés'; + $lang['strread'] = 'Olvasás'; + $lang['strfetch'] = 'Lehívás'; + $lang['strheap'] = 'Kupac'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Gyorstár'; + $lang['strdisk'] = 'Lemez'; + $lang['strrows2'] = 'Sorok'; + + // Tablespaces + $lang['strtablespace'] = 'Táblahely'; + $lang['strtablespaces'] = 'Táblahelyek'; + $lang['strshowalltablespaces'] = 'Minden táblahelyet megjelenít'; + $lang['strnotablespaces'] = 'Nincsenek táblahelyek.'; + $lang['strcreatetablespace'] = 'Táblahelyet teremt'; + $lang['strlocation'] = 'Hely'; + $lang['strtablespaceneedsname'] = 'Nevet kell adnia a táblahelynek.'; + $lang['strtablespaceneedsloc'] = 'Meg kell adnia egy mappát, ahol a táblahelyet teremti.'; + $lang['strtablespacecreated'] = 'Táblahely teremtve.'; + $lang['strtablespacecreatedbad'] = 'Nem sikerült táblahelyet teremteni.'; + $lang['strconfdroptablespace'] = 'Biztosan ki akarja dobni „%s†táblahelyet?'; + $lang['strtablespacedropped'] = 'Táblahely kidobva.'; + $lang['strtablespacedroppedbad'] = 'Nem sikerült kidobni a táblahelyet.'; + $lang['strtablespacealtered'] = 'Táblahely megváltoztatva.'; + $lang['strtablespacealteredbad'] = 'Nem sikerült megváltoztatni a táblahelyet.'; + + // Miscellaneous + $lang['strtopbar'] = '%s fut %s:%s címen — Ön „%s†néven jelentkezett be.'; + $lang['strtimefmt'] = 'Y.m.d. H:i'; + $lang['strhelp'] = 'Súgó'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Súgólap böngészÅ‘'; + $lang['strselecthelppage'] = 'Súgólapot választ'; + $lang['strinvalidhelppage'] = 'Érvénytelen súgólap.'; + $lang['strlogintitle'] = 'Belépett %s helyre'; + $lang['strlogoutmsg'] = 'Kilépett %s helyrÅ‘l'; + $lang['strloading'] = 'Betöltök...'; + $lang['strerrorloading'] = 'Betöltési hiba'; + $lang['strclicktoreload'] = 'Kattintson az újratöltéshez'; + + // Autovacuum + $lang['strautovacuum'] = 'ÖnműködÅ‘ takarítás'; + $lang['strturnedon'] = 'Bekapcsolva'; + $lang['strturnedoff'] = 'Kikapcsolva'; + $lang['strenabled'] = 'Engedélyezve'; + $lang['strnovacuumconf'] = 'Nem találtam önműködÅ‘ takarítást beállítva.'; + $lang['strvacuumbasethreshold'] = 'Takarítás alap küszbértéke'; + $lang['strvacuumscalefactor'] = 'Takarítás méretezÅ‘ tényezÅ‘je'; + $lang['stranalybasethreshold'] = 'Alap küszöbértéket elemez'; + $lang['stranalyzescalefactor'] = 'MéretezÅ‘ tényezÅ‘t elemez'; + $lang['strvacuumcostdelay'] = 'Takarítás költségének késése'; + $lang['strvacuumcostlimit'] = 'Takarítás költségének korlátja'; + $lang['strvacuumpertable'] = 'ÖnműködÅ‘ takarítás beállítása táblánként'; + $lang['straddvacuumtable'] = 'ÖnműködÅ‘ takarítást állít be egy táblára'; + $lang['streditvacuumtable'] = 'ÖnműködÅ‘ takarítást szerkeszt %s táblára'; + $lang['strdelvacuumtable'] = 'Törli az önműködÅ‘ takarítást %s tábláról?'; + $lang['strvacuumtablereset'] = 'Az önműködÅ‘ takarítást %s táblára visszaállítja az alap értékekre'; + $lang['strdelvacuumtablefail'] = 'Nem sikerült törölni az önműködÅ‘ takarítást %s tábláról'; + $lang['strsetvacuumtablesaved'] = 'ÖnműködÅ‘ takarítás %s táblára mentve.'; + $lang['strsetvacuumtablefail'] = 'ÖnműködÅ‘ takarítást %s táblára nem sikerült beállítani.'; + $lang['strspecifydelvacuumtable'] = 'Meg kell adni a táblát, amirÅ‘l törölni akarja az önműködÅ‘ takarítás paramétereit.'; + $lang['strspecifyeditvacuumtable'] = 'Meg kell adni a táblát, amin szerkeszteni akarja az önműködÅ‘ takarítás paramétereit.'; + $lang['strnotdefaultinred'] = 'A nem alap értékek pirosak.'; + + // Table-level Locks + $lang['strlocks'] = 'Zárak'; + $lang['strtransaction'] = 'Tranzakció AZ'; + $lang['strvirtualtransaction'] = 'Látszólagos tranzakció AZ'; + $lang['strprocessid'] = 'Folyamat AZ'; + $lang['strmode'] = 'Zármód'; + $lang['strislockheld'] = 'Zár tartva?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'ElÅ‘készített tranzakciók'; + $lang['strxactid'] = 'Tranzakció AZ'; + $lang['strgid'] = 'Globális AZ'; + + // Fulltext search + $lang['strfulltext'] = 'Teljes szövegben keres'; + $lang['strftsconfig'] = 'TSzK összeállítás'; + $lang['strftsconfigs'] = 'Összeállítások'; + $lang['strftscreateconfig'] = 'TSzK összeállítást teremt'; + $lang['strftscreatedict'] = 'Szótárt teremt'; + $lang['strftscreatedicttemplate'] = 'Szótársablont teremt'; + $lang['strftscreateparser'] = 'ElemzÅ‘t teremt'; + $lang['strftsnoconfigs'] = 'Nincs TSzK összeállítás.'; + $lang['strftsconfigdropped'] = 'TSzK összeállítás törölve.'; + $lang['strftsconfigdroppedbad'] = 'Nem sikerült törölni a TSzK összeállítást.'; + $lang['strconfdropftsconfig'] = 'Biztosan töröljük „%s†TSzK összeállítást?'; + $lang['strconfdropftsdict'] = 'Biztosan töröljük „%s†TSzK szótárt?'; + $lang['strconfdropftsmapping'] = 'Biztosan töröljük „%s†hozzárendelést „%s†TSzK összeállításból?'; + $lang['strftstemplate'] = 'Sablon'; + $lang['strftsparser'] = 'ElemzÅ‘'; + $lang['strftsconfigneedsname'] = 'Meg kell adni a TSzK összeállítás nevét.'; + $lang['strftsconfigcreated'] = 'TSzK összeállítás megteremtve.'; + $lang['strftsconfigcreatedbad'] = 'Nem sikerült megteremteni a TSzK összeállítást.'; + $lang['strftsmapping'] = 'Hozzárendel'; + $lang['strftsdicts'] = 'Szótárak'; + $lang['strftsdict'] = 'Szótár'; + $lang['strftsemptymap'] = 'Ãœres hozzárendelés a TSzK összeállításban.'; + $lang['strftsconfigaltered'] = 'TSzK összeállítás megváltoztatva.'; + $lang['strftsconfigalteredbad'] = 'Nem sikerült a TSzK összeállítást megváltoztatni.'; + $lang['strftsconfigmap'] = 'TSzK összeállítás hozzárendelése'; + $lang['strftsparsers'] = 'TSzK elemzÅ‘k'; + $lang['strftsnoparsers'] = 'Nincs TSzK elemzÅ‘.'; + $lang['strftsnodicts'] = 'Nincs TSzK szótár.'; + $lang['strftsdictcreated'] = 'TSzK szótár megteremtve.'; + $lang['strftsdictcreatedbad'] = 'Nem sikerült a TSzK szótárt megteremteni.'; + $lang['strftslexize'] = 'Szókincs'; + $lang['strftsinit'] = 'Kezdés'; + $lang['strftsoptionsvalues'] = 'Opciók és értékek'; + $lang['strftsdictneedsname'] = 'Meg kell adni a TSzK szótár nevét.'; + $lang['strftsdictdropped'] = 'TSzK szótár törölve.'; + $lang['strftsdictdroppedbad'] = 'Nem sikerült a TSzK szótárt törölni.'; + $lang['strftsdictaltered'] = 'TSzK szótár megváltoztatva.'; + $lang['strftsdictalteredbad'] = 'Nem sikerült a TSzK szótárt megváltoztatni.'; + $lang['strftsaddmapping'] = 'Új hozzárendelés hozzáadása'; + $lang['strftsspecifymappingtodrop'] = 'Meg kell adni legalább egy törlendÅ‘ TSzK hozzárendelést.'; + $lang['strftsspecifyconfigtoalter'] = 'Meg kell adni a megváltoztatandó TSzK összeállítást'; + $lang['strftsmappingdropped'] = 'TSzK hozzárendelés törölve.'; + $lang['strftsmappingdroppedbad'] = 'Nem sikerült a TSzK hozzárendelést törölni.'; + $lang['strftsnodictionaries'] = 'Nincs szótár.'; + $lang['strftsmappingaltered'] = 'TSzK hozzárendelés megváltoztatva.'; + $lang['strftsmappingalteredbad'] = 'Nem sikerült a TSzK hozzárendelést megváltoztatni.'; + $lang['strftsmappingadded'] = 'TSzK hozzárendelés hozzáadva.'; + $lang['strftsmappingaddedbad'] = 'Nem sikerült hozzáadni a TSzK hozzárendeléshez.'; + $lang['strftsmappingdropped'] = 'TSzK hozzárendelés törölve.'; + $lang['strftsmappingdroppedbad'] = 'Nem sikerült a TSzK hozzárendelést törölni.'; + $lang['strftstabconfigs'] = 'Összeállítások'; + $lang['strftstabdicts'] = 'Szótárak'; + $lang['strftstabparsers'] = 'ElemzÅ‘k'; + $lang['strftscantparsercopy'] = 'Nem állíthat be együtt elemzÅ‘t és sablont szövegkeresÅ‘ beállítás közben.'; + + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/italian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/italian.php new file mode 100644 index 00000000..3f2675a4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/italian.php @@ -0,0 +1,720 @@ +'; + $lang['strfirst'] = '<< Primo'; + $lang['strlast'] = 'Ultimo >>'; + $lang['strfailed'] = 'Fallito'; + $lang['strcreate'] = 'Crea'; + $lang['strcreated'] = 'Creato'; + $lang['strcomment'] = 'Commento'; + $lang['strlength'] = 'Lunghezza'; + $lang['strdefault'] = 'Default'; + $lang['stralter'] = 'Modifica'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Annulla'; + $lang['strac'] = 'Abilita autocompletamento'; + $lang['strsave'] = 'Salva'; + $lang['strreset'] = 'Reset'; + $lang['strinsert'] = 'Inserisci'; + $lang['strselect'] = 'Seleziona'; + $lang['strdelete'] = 'Cancella'; + $lang['strupdate'] = 'Aggiorna'; + $lang['strreferences'] = 'Riferimenti'; + $lang['stryes'] = 'Si'; + $lang['strno'] = 'No'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = 'Modifica'; + $lang['strcolumn'] = 'Colonna'; + $lang['strcolumns'] = 'Colonne'; + $lang['strrows'] = 'riga(ghe)'; + $lang['strrowsaff'] = 'riga(ghe) interessata(e).'; + $lang['strobjects'] = 'oggetto(i)'; + $lang['strback'] = 'Indietro'; + $lang['strqueryresults'] = 'Risultato Query'; + $lang['strshow'] = 'Mostra'; + $lang['strempty'] = 'Svuota'; + $lang['strlanguage'] = 'Lingua'; + $lang['strencoding'] = 'Codifica'; + $lang['strvalue'] = 'Valore'; + $lang['strunique'] = 'Univoco'; + $lang['strprimary'] = 'Primaria'; + $lang['strexport'] = 'Esporta'; + $lang['strimport'] = 'Importa'; + $lang['strallowednulls'] = 'Caratteri NULL consentiti'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Stringa vuota'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Amministratore'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analizza'; + $lang['strclusterindex'] = 'Clusterizza'; + $lang['strclustered'] = 'Clusterizzato?'; + $lang['strreindex'] = 'Reindicizza'; + $lang['strexecute'] = 'Esegui'; + $lang['stradd'] = 'Aggiungi'; + $lang['strevent'] = 'Evento'; + $lang['strwhere'] = 'Condizione'; + $lang['strinstead'] = 'Invece fai'; + $lang['strwhen'] = 'Quando'; + $lang['strformat'] = 'Formato'; + $lang['strdata'] = 'Dati'; + $lang['strconfirm'] = 'Conferma'; + $lang['strexpression'] = 'Espressione'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Espandi'; + $lang['strcollapse'] = 'Raccogli'; + $lang['strexplain'] = 'Explain'; + $lang['strexplainanalyze'] = 'Explain Analyze'; + $lang['strfind'] = 'Trova'; + $lang['stroptions'] = 'Opzioni'; + $lang['strrefresh'] = 'Ricarica'; + $lang['strdownload'] = 'Scarica'; + $lang['strdownloadgzipped'] = 'Scarica compresso con gzip'; + $lang['strinfo'] = 'Informazioni'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Avanzato'; + $lang['strvariables'] = 'Variabili'; + $lang['strprocess'] = 'Processo'; + $lang['strprocesses'] = 'Processi'; + $lang['strsetting'] = 'Valore'; + $lang['streditsql'] = 'Modifica SQL'; + $lang['strruntime'] = 'Tempo di esecuzione totale: %s ms'; + $lang['strpaginate'] = 'Dividi in pagine i risultati'; + $lang['struploadscript'] = 'oppure esegui l\'upload di uno script SQL:'; + $lang['strstarttime'] = 'Inizio'; + $lang['strfile'] = 'File'; + $lang['strfileimported'] = 'File importato.'; + $lang['strtrycred'] = 'Usa queste credenziali per tutti i server'; + $lang['stractionsonmultiplelines'] = 'Azioni su righe multiple'; + $lang['strselectall'] = 'Seleziona tutti'; + $lang['strunselectall'] = 'Deseleziona tutti'; + + // Database sizes - Dimensioni dei database + $lang['strsize'] = 'Dimensione'; + $lang['strbytes'] = 'byte'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling - Gestione degli errori + $lang['strnoframes'] = 'Questa applicazione funziona al meglio utilizzando un browser che supporti i frame, ma può essere usata senza frame seguendo il link sottostante.'; + $lang['strnoframeslink'] = 'Usa senza frame'; + $lang['strbadconfig'] = 'Il file config.inc.php è obsoleto. È necessario rigenerarlo utilizzando il nuovo file config.inc.php-dist .'; + $lang['strnotloaded'] = 'La tua installazione di PHP non supporta PostgreSQL. È necessario ricompilare PHP usando l\'opzione di configurazione --with-pgsql .'; + $lang['strpostgresqlversionnotsupported'] = 'Versione di PostgreSQL non supportata. È necessario aggiornarlo alla versione %s o successiva.'; + $lang['strbadschema'] = 'Schema specificato non valido.'; + $lang['strbadencoding'] = 'Impostazione della codifica del client nel database fallito.'; + $lang['strsqlerror'] = 'Errore SQL:'; + $lang['strinstatement'] = 'Nel costrutto:'; + $lang['strinvalidparam'] = 'Parametri di script non validi.'; + $lang['strnodata'] = 'Nessuna riga trovata.'; + $lang['strnoobjects'] = 'Nessun oggetto trovato.'; + $lang['strrownotunique'] = 'Nessun identificatore univoco per questa riga.'; + $lang['strnouploads'] = 'L\'upload dei file è disabilitato.'; + $lang['strimporterror'] = 'Errore durante l\'import.'; + $lang['strimporterror-fileformat'] = 'Errore durante l\'import: determinazione automatica del formato del file fallita.'; + $lang['strimporterrorline'] = 'Errore durante l\'import alla linea %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Errore durante l\'import alla linea %s: la linea non possiede il numero corretto di colonne.'; + $lang['strimporterror-uploadedfile'] = 'Errore durante l\'import: non è stato possibile caricare il file sul server'; + $lang['strcannotdumponwindows'] = 'Il dump di nomi complessi di tabelle o schemi sotto Windows non è supportato.'; + $lang['strinvalidserverparam'] = 'Tentativo di connessione al server con parametri non validi, è possibile che qualcuno stia cercando di forzare il sistema.'; + + // Tables - Tabelle + $lang['strtable'] = 'Tabella'; + $lang['strtables'] = 'Tabelle'; + $lang['strshowalltables'] = 'Mostra tutte le tabelle'; + $lang['strnotables'] = 'Nessuna tabella trovata.'; + $lang['strnotable'] = 'Tabella non trovata.'; + $lang['strcreatetable'] = 'Crea tabella'; + $lang['strtablename'] = 'Nome tabella'; + $lang['strtableneedsname'] = 'È necessario specificare un nome per la tabella.'; + $lang['strtableneedsfield'] = 'È necessario specificare almeno un campo.'; + $lang['strtableneedscols'] = 'È necessario specificare un numero di colonne valido.'; + $lang['strtablecreated'] = 'Tabella creata.'; + $lang['strtablecreatedbad'] = 'Creazione della tabella fallita.'; + $lang['strconfdroptable'] = 'Eliminare la tabella "%s"?'; + $lang['strtabledropped'] = 'Tabella eliminata.'; + $lang['strtabledroppedbad'] = 'Eliminazione della tabella fallita.'; + $lang['strconfemptytable'] = 'Svuotare la tabella "%s"?'; + $lang['strtableemptied'] = 'Tabella svuotata.'; + $lang['strtableemptiedbad'] = 'Svuotamento della tabella fallito.'; + $lang['strinsertrow'] = 'Inserisci riga'; + $lang['strrowinserted'] = 'Riga inserita.'; + $lang['strrowinsertedbad'] = 'Inserimento della riga fallito.'; + $lang['strrowduplicate'] = 'Inserimento della riga fallito, tentativo di eseguire un inserimento duplicato.'; + $lang['streditrow'] = 'Modifica riga'; + $lang['strrowupdated'] = 'Riga aggiornata.'; + $lang['strrowupdatedbad'] = 'Aggiornamento della riga fallito.'; + $lang['strdeleterow'] = 'Cancella riga'; + $lang['strconfdeleterow'] = 'Cancellare questa riga?'; + $lang['strrowdeleted'] = 'Riga cancellata.'; + $lang['strrowdeletedbad'] = 'Cancellazione della riga fallita.'; + $lang['strinsertandrepeat'] = 'Inserisci e ripeti'; + $lang['strnumcols'] = 'Numero di colonne'; + $lang['strcolneedsname'] = 'È necessario specificare un nome per la colonna'; + $lang['strselectallfields'] = 'Seleziona tutti i campi'; + $lang['strselectneedscol'] = 'È necessario scegliere almeno una colonna.'; + $lang['strselectunary'] = 'Gli operatori unari non possono avere un valore.'; + $lang['strcolumnaltered'] = 'Colonna modificata.'; + $lang['strcolumnalteredbad'] = 'Modifica della colonna fallita.'; + $lang['strconfdropcolumn'] = 'Eliminare la colonna "%s" dalla tabella "%s"?'; + $lang['strcolumndropped'] = 'Colonna eliminata.'; + $lang['strcolumndroppedbad'] = 'Eliminazione della colonna fallita.'; + $lang['straddcolumn'] = 'Aggiungi colonna'; + $lang['strcolumnadded'] = 'Colonna aggiunta.'; + $lang['strcolumnaddedbad'] = 'Aggiunta della colonna fallita.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabella modificata.'; + $lang['strtablealteredbad'] = 'Modifica della tabella fallita.'; + $lang['strdataonly'] = 'Solo i dati'; + $lang['strstructureonly'] = 'Solo la struttura'; + $lang['strstructureanddata'] = 'Struttura e dati'; + $lang['strtabbed'] = 'Tabulato'; + $lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Effettuare il vacuum su "%s"?'; + $lang['strestimatedrowcount'] = 'Numero stimato di righe'; + $lang['strspecifytabletoanalyze'] = 'È necessario specificare almeno una tabella da analizzare'; + + // Colonne - Columns + $lang['strcolprop'] = 'Proprietà della colonna'; + + // Users - Utenti + $lang['struser'] = 'Utente'; + $lang['strusers'] = 'Utenti'; + $lang['strusername'] = 'Username'; + $lang['strpassword'] = 'Password'; + $lang['strsuper'] = 'Superuser?'; + $lang['strcreatedb'] = 'Può creare DB?'; + $lang['strexpires'] = 'Scadenza'; + $lang['strsessiondefaults'] = 'Defaults della sessione'; + $lang['strnousers'] = 'Nessun utente trovato'; + $lang['struserupdated'] = 'Utente aggiornato.'; + $lang['struserupdatedbad'] = 'Aggiornamento utente fallito.'; + $lang['strshowallusers'] = 'Mostra tutti gli utenti'; + $lang['strcreateuser'] = 'Crea utente'; + $lang['struserneedsname'] = 'È necessario specificare un nome per l\'utente.'; + $lang['strusercreated'] = 'Utente creato.'; + $lang['strusercreatedbad'] = 'Creazione dell\'utente fallita.'; + $lang['strconfdropuser'] = 'Eliminare l\'utente "%s"?'; + $lang['struserdropped'] = 'Utente eliminato.'; + $lang['struserdroppedbad'] = 'Eliminazione dell\'utente fallita.'; + $lang['straccount'] = 'Account'; + $lang['strchangepassword'] = 'Modifica password'; + $lang['strpasswordchanged'] = 'Password modificata.'; + $lang['strpasswordchangedbad'] = 'Modifica della password fallita.'; + $lang['strpasswordshort'] = 'La password è troppo corta.'; + $lang['strpasswordconfirm'] = 'Le due password non coincidono.'; + + // Groups - Gruppi + $lang['strgroup'] = 'Gruppo'; + $lang['strgroups'] = 'Gruppi'; + $lang['strshowallgroups'] = 'Mostra tutti i gruppi'; + $lang['strnogroup'] = 'Gruppo non trovato.'; + $lang['strnogroups'] = 'Nessun gruppo trovato.'; + $lang['strcreategroup'] = 'Crea gruppo'; + $lang['strgroupneedsname'] = 'È necessario specificare un nome per il gruppo.'; + $lang['strgroupcreated'] = 'Gruppo creato.'; + $lang['strgroupcreatedbad'] = 'Creazione del gruppo fallita.'; + $lang['strconfdropgroup'] = 'Eliminare il gruppo "%s"?'; + $lang['strgroupdropped'] = 'Gruppo eliminato.'; + $lang['strgroupdroppedbad'] = 'Eliminazione del gruppo fallita.'; + $lang['strmembers'] = 'Membri'; + $lang['strmemberof'] = 'Membro di'; + $lang['stradminmembers'] = 'Membri amministratore'; + $lang['straddmember'] = 'Aggiungi membro'; + $lang['strmemberadded'] = 'Membro aggiunto.'; + $lang['strmemberaddedbad'] = 'Aggiunta del membro fallita.'; + $lang['strdropmember'] = 'Elimina membro'; + $lang['strconfdropmember'] = 'Eliminare il membro "%s" dal gruppo "%s"?'; + $lang['strmemberdropped'] = 'Membro eliminato.'; + $lang['strmemberdroppedbad'] = 'Eliminazione del membro fallita.'; + + // Ruoli - Roles + $lang['strrole'] = 'Ruolo'; + $lang['strroles'] = 'Ruoli'; + $lang['strshowallroles'] = 'Mostra tutti i ruoli'; + $lang['strnoroles'] = 'Nessun ruolo trovato.'; + $lang['strinheritsprivs'] = 'Eredita i privilegi?'; + $lang['strcreaterole'] = 'Crea ruolo'; + $lang['strcancreaterole'] = 'Può creare ruoli?'; + $lang['strrolecreated'] = 'Ruolo creato.'; + $lang['strrolecreatedbad'] = 'Creazione del ruolo fallita.'; + $lang['strrolealtered'] = 'Ruolo modificato.'; + $lang['strrolealteredbad'] = 'Modifica del ruolo fallita.'; + $lang['strcanlogin'] = 'Può effettuare login?'; + $lang['strconnlimit'] = 'Limite alle connessioni'; + $lang['strdroprole'] = 'Elimina ruolo'; + $lang['strconfdroprole'] = 'Eliminare il ruolo "%s"?'; + $lang['strroledropped'] = 'Ruolo eliminato.'; + $lang['strroledroppedbad'] = 'Eliminazione del ruolo fallita.'; + $lang['strnolimit'] = 'Nessun limite'; + $lang['strnever'] = 'Mai'; + $lang['strroleneedsname'] = 'È necessario specificare un nome per il ruolo.'; + + // Privileges - Privilegi + $lang['strprivilege'] = 'Privilegio'; + $lang['strprivileges'] = 'Privilegi'; + $lang['strnoprivileges'] = 'Questo oggetto di default ha i privilegi del proprietario.'; + $lang['strgrant'] = 'Concedi'; + $lang['strrevoke'] = 'Revoca'; + $lang['strgranted'] = 'Privilegi concessi.'; + $lang['strgrantfailed'] = 'Concessione dei privilegi fallita.'; + $lang['strgrantbad'] = 'È necessario specificare almeno un utente o gruppo ed almeno un privilegio.'; + $lang['strgrantor'] = 'Concedente'; + $lang['strasterisk'] = '*'; + + // Databases - Database + $lang['strdatabase'] = 'Database'; + $lang['strdatabases'] = 'Database'; + $lang['strshowalldatabases'] = 'Mostra tutti i database'; + $lang['strnodatabases'] = 'Nessun database trovato.'; + $lang['strcreatedatabase'] = 'Crea database'; + $lang['strdatabasename'] = 'Nome del database'; + $lang['strdatabaseneedsname'] = 'È necessario specificare un nome per il database.'; + $lang['strdatabasecreated'] = 'Database creato.'; + $lang['strdatabasecreatedbad'] = 'Creazione del database fallita.'; + $lang['strconfdropdatabase'] = 'Eliminare il database "%s"?'; + $lang['strdatabasedropped'] = 'Database eliminato.'; + $lang['strdatabasedroppedbad'] = 'Eliminazione del database fallita.'; + $lang['strentersql'] = 'Inserire la query SQL da eseguire qui sotto:'; + $lang['strsqlexecuted'] = 'SQL eseguito.'; + $lang['strvacuumgood'] = 'Vacuum completato.'; + $lang['strvacuumbad'] = 'Vacuum fallito.'; + $lang['stranalyzegood'] = 'Analyze completato.'; + $lang['stranalyzebad'] = 'Analyze fallito'; + $lang['strreindexgood'] = 'Reindicizzamento completato.'; + $lang['strreindexbad'] = 'Reindicizzamento fallito.'; + $lang['strfull'] = 'Completo'; + $lang['strfreeze'] = 'Freeze'; + $lang['strforce'] = 'Forza'; + $lang['strsignalsent'] = 'Segnale inviato.'; + $lang['strsignalsentbad'] = 'Invio del segnale fallito.'; + $lang['strallobjects'] = 'Tutti gli oggetti'; + $lang['strdatabasealtered'] = 'Database modificato.'; + $lang['strdatabasealteredbad'] = 'Modifica del database fallita.'; + + // Views - Viste + $lang['strview'] = 'Vista'; + $lang['strviews'] = 'Viste'; + $lang['strshowallviews'] = 'Mostra tutte le viste'; + $lang['strnoview'] = 'Vista non trovata.'; + $lang['strnoviews'] = 'Nessuna vista trovata.'; + $lang['strcreateview'] = 'Crea vista'; + $lang['strviewname'] = 'Nome vista'; + $lang['strviewneedsname'] = 'È necessario specificare un nome per la vista.'; + $lang['strviewneedsdef'] = 'È necessario specificare una definizione per la vista.'; + $lang['strviewneedsfields'] = 'È necessario specificare le colonne da selezionare nella vista.'; + $lang['strviewcreated'] = 'Vista creata.'; + $lang['strviewcreatedbad'] = 'Creazione della vista fallita.'; + $lang['strconfdropview'] = 'Eliminare la vista "%s"?'; + $lang['strviewdropped'] = 'Vista eliminata.'; + $lang['strviewdroppedbad'] = 'Eliminazione della vista fallita.'; + $lang['strviewupdated'] = 'Vista aggiornata.'; + $lang['strviewupdatedbad'] = 'Aggiornamento della vista fallito.'; + $lang['strviewlink'] = 'Chiavi collegate'; + $lang['strviewconditions'] = 'Condizioni aggiuntive'; + $lang['strcreateviewwiz'] = 'Crea vista tramite wizard'; + + // Sequences - Sequenze + $lang['strsequence'] = 'Sequenza'; + $lang['strsequences'] = 'Sequenze'; + $lang['strshowallsequences'] = 'Mostra tutte le sequenze'; + $lang['strnosequence'] = 'Sequenza non trovata.'; + $lang['strnosequences'] = 'Nessuna sequenza trovata.'; + $lang['strcreatesequence'] = 'Crea sequenza'; + $lang['strlastvalue'] = 'Ultimo valore'; + $lang['strincrementby'] = 'Incrementa di'; + $lang['strstartvalue'] = 'Valore iniziale'; + $lang['strmaxvalue'] = 'Valore massimo'; + $lang['strminvalue'] = 'Valore minimo'; + $lang['strcachevalue'] = 'Valori in cache'; + $lang['strcancycle'] = 'Può ricominciare?'; + $lang['striscalled'] = 'Incrementerà l\'ultimo valore prima di ritornare il prossimo valore (is_called)?'; + $lang['strsequenceneedsname'] = 'È necessario specificare un nome per la sequenza.'; + $lang['strsequencecreated'] = 'Sequenza creata.'; + $lang['strsequencecreatedbad'] = 'Creazione della sequenza fallita.'; + $lang['strconfdropsequence'] = 'Eliminare la sequenza "%s"?'; + $lang['strsequencedropped'] = 'Sequenza eliminata.'; + $lang['strsequencedroppedbad'] = 'Eliminazione della sequenza fallita.'; + $lang['strsequencereset'] = 'Reset della sequenza effettuato.'; + $lang['strsequenceresetbad'] = 'Reset della sequenza fallito.'; + $lang['strsequencealtered'] = 'Sequenza modificata.'; + $lang['strsequencealteredbad'] = 'Modifica della sequenza fallita.'; + $lang['strsetval'] = 'Imposta valore'; + $lang['strsequencesetval'] = 'Valore della sequenza impostato.'; + $lang['strsequencesetvalbad'] = 'Impostazione del valore della sequenza fallito.'; + $lang['strnextval'] = 'Incrementa valore'; + $lang['strsequencenextval'] = 'Sequenza incrementata.'; + $lang['strsequencenextvalbad'] = 'Incremento della sequenza fallito.'; + + // Indexes - Indici + $lang['strindex'] = 'Indice'; + $lang['strindexes'] = 'Indici'; + $lang['strindexname'] = 'Nome dell\'indice'; + $lang['strshowallindexes'] = 'Mostra tutti gli indici'; + $lang['strnoindex'] = 'Indice non trovato.'; + $lang['strnoindexes'] = 'Nessun indice trovato.'; + $lang['strcreateindex'] = 'Crea Indice'; + $lang['strtabname'] = 'Nome del tab'; + $lang['strcolumnname'] = 'Nome della colonna'; + $lang['strindexneedsname'] = 'È necessario specificare un nome per l\'indice'; + $lang['strindexneedscols'] = 'Gli indici richiedono di un numero valido di colonne.'; + $lang['strindexcreated'] = 'Indice creato'; + $lang['strindexcreatedbad'] = 'Creazione indice fallita.'; + $lang['strconfdropindex'] = 'Eliminare l\'indice "%s"?'; + $lang['strindexdropped'] = 'Indice eliminato.'; + $lang['strindexdroppedbad'] = 'Eliminazione dell\'indice fallita.'; + $lang['strkeyname'] = 'Nome della chiave'; + $lang['struniquekey'] = 'Chiave Univoca'; + $lang['strprimarykey'] = 'Chiave Primaria'; + $lang['strindextype'] = 'Tipo di indice'; + $lang['strtablecolumnlist'] = 'Colonne nella tabella'; + $lang['strindexcolumnlist'] = 'Colonne nell\'indice'; + $lang['strconfcluster'] = 'Clusterizzare "%s"?'; + $lang['strclusteredgood'] = 'Clusterizzazione completata.'; + $lang['strclusteredbad'] = 'Clusterizzazione fallita.'; + $lang['strcluster'] = 'Cluster'; + + // Rules - Regole + $lang['strrules'] = 'Regole'; + $lang['strrule'] = 'Regola'; + $lang['strshowallrules'] = 'Mostra tutte le regole'; + $lang['strnorule'] = 'Regola non trovata.'; + $lang['strnorules'] = 'Nessuna regola trovata.'; + $lang['strcreaterule'] = 'Crea regola'; + $lang['strrulename'] = 'Nome della regola'; + $lang['strruleneedsname'] = 'È necessario specificare un nome per la regola.'; + $lang['strrulecreated'] = 'Regola creata.'; + $lang['strrulecreatedbad'] = 'Creazione della regola fallita.'; + $lang['strconfdroprule'] = 'Eliminare la regola "%s" su "%s"?'; + $lang['strruledropped'] = 'Regola eliminata.'; + $lang['strruledroppedbad'] = 'Eliminazione della regola fallita.'; + + // Constraints - Vincoli + $lang['strconstraint'] = 'Vincolo'; + $lang['strconstraints'] = 'Vincoli'; + $lang['strshowallconstraints'] = 'Mostra tutti i vincoli'; + $lang['strnoconstraints'] = 'Nessun vincolo trovato.'; + $lang['strcreateconstraint'] = 'Crea vincolo'; + $lang['strconstraintcreated'] = 'Vincolo creato.'; + $lang['strconstraintcreatedbad'] = 'Creazione del vincolo fallita.'; + $lang['strconfdropconstraint'] = 'Eliminare il vincolo "%s" su "%s"?'; + $lang['strconstraintdropped'] = 'Vincolo eliminato.'; + $lang['strconstraintdroppedbad'] = 'Eliminazione vincolo fallita.'; + $lang['straddcheck'] = 'Aggiungi un Check'; + $lang['strcheckneedsdefinition'] = 'Il vincolo Check necessita di una definizione.'; + $lang['strcheckadded'] = 'Vincolo Check aggiunto.'; + $lang['strcheckaddedbad'] = 'Inserimento del vincolo Check fallito.'; + $lang['straddpk'] = 'Aggiungi una chiave primaria'; + $lang['strpkneedscols'] = 'La chiave primaria richiede almeno una colonna.'; + $lang['strpkadded'] = 'Chiave primaria aggiunta.'; + $lang['strpkaddedbad'] = 'Aggiunta della chiave primaria fallita.'; + $lang['stradduniq'] = 'Aggiungi una chiave univoca'; + $lang['struniqneedscols'] = 'La chiave univoca richiede almeno una colonna.'; + $lang['struniqadded'] = 'Chiave univoca aggiunta.'; + $lang['struniqaddedbad'] = 'Aggiunta chiave univoca fallita.'; + $lang['straddfk'] = 'Aggiungi una chiave esterna'; + $lang['strfkneedscols'] = 'La chiave esterna richiede almeno una colonna.'; + $lang['strfkneedstarget'] = 'La chiave esterna richiede una tabella obiettivo.'; + $lang['strfkadded'] = 'Chiave esterna aggiunta.'; + $lang['strfkaddedbad'] = 'Aggiunta della chiave esterna fallita.'; + $lang['strfktarget'] = 'Tabella obiettivo'; + $lang['strfkcolumnlist'] = 'Colonne della chiave'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions - Funzioni + $lang['strfunction'] = 'Funzione'; + $lang['strfunctions'] = 'Funzioni'; + $lang['strshowallfunctions'] = 'Mostra tutte le funzioni'; + $lang['strnofunction'] = 'Funzione non trovata.'; + $lang['strnofunctions'] = 'Nessuna funzione trovata.'; + $lang['strcreateplfunction'] = 'Crea funzione SQL/PL'; + $lang['strcreateinternalfunction'] = 'Crea funzione internal'; + $lang['strcreatecfunction'] = 'Crea funzione C'; + $lang['strfunctionname'] = 'Nome della funzione'; + $lang['strreturns'] = 'Restituisce'; + $lang['strproglanguage'] = 'Linguaggio di programmazione'; + $lang['strfunctionneedsname'] = 'È necessario specificare un nome per la funzione.'; + $lang['strfunctionneedsdef'] = 'È necessario specificare una definizione per la funzione.'; + $lang['strfunctioncreated'] = 'Funzione creata.'; + $lang['strfunctioncreatedbad'] = 'Creazione funzione fallita.'; + $lang['strconfdropfunction'] = 'Eliminare la funzione "%s"?'; + $lang['strfunctiondropped'] = 'Funzione eliminata.'; + $lang['strfunctiondroppedbad'] = 'Eliminazione della funzione fallita.'; + $lang['strfunctionupdated'] = 'Funzione aggiornata.'; + $lang['strfunctionupdatedbad'] = 'Aggiornamento della funzione fallito.'; + $lang['strobjectfile'] = 'File oggetto'; + $lang['strlinksymbol'] = 'Simbolo di collegamento'; + $lang['strarguments'] = 'Argomenti'; + + // Triggers - Trigger + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Trigger'; + $lang['strshowalltriggers'] = 'Mostra tutti i trigger'; + $lang['strnotrigger'] = 'Trigger non trovato.'; + $lang['strnotriggers'] = 'Nessun trigger trovato.'; + $lang['strcreatetrigger'] = 'Crea Trigger'; + $lang['strtriggerneedsname'] = 'È necessario specificare un nome per il trigger.'; + $lang['strtriggerneedsfunc'] = 'È necessario specificare una funzione per il trigger.'; + $lang['strtriggercreated'] = 'Trigger creato.'; + $lang['strtriggercreatedbad'] = 'Creazione del trigger fallita.'; + $lang['strconfdroptrigger'] = 'Eliminare il trigger "%s" su "%s"?'; + $lang['strtriggerdropped'] = 'Trigger eliminato.'; + $lang['strtriggerdroppedbad'] = 'Eliminazione del trigger fallita.'; + $lang['strtriggeraltered'] = 'Trigger modificato.'; + $lang['strtriggeralteredbad'] = 'Modifica del trigger fallita.'; + $lang['strforeach'] = 'Per ogni'; + + // Types - Tipi + $lang['strtype'] = 'Tipo'; + $lang['strtypes'] = 'Tipi'; + $lang['strshowalltypes'] = 'Mostra tutti i tipi'; + $lang['strnotype'] = 'Tipo non trovato.'; + $lang['strnotypes'] = 'Nessun tipo trovato.'; + $lang['strcreatetype'] = 'Crea Tipo'; + $lang['strcreatecomptype'] = 'Crea tipo composto'; + $lang['strtypeneedsfield'] = 'È necessario specificare almeno un campo.'; + $lang['strtypeneedscols'] = 'È necessario specificare un numero di campi valido.'; + $lang['strtypename'] = 'Nome Tipo'; + $lang['strinputfn'] = 'Funzione di input'; + $lang['stroutputfn'] = 'Funzione di output'; + $lang['strpassbyval'] = 'Passato per valore?'; + $lang['stralignment'] = 'Allineamento'; + $lang['strelement'] = 'Elemento'; + $lang['strdelimiter'] = 'Delimitatore'; + $lang['strstorage'] = 'Memorizzazione'; + $lang['strfield'] = 'Campo'; + $lang['strnumfields'] = 'Numero di campi'; + $lang['strtypeneedsname'] = 'È necessario specificare un nome per il tipo.'; + $lang['strtypeneedslen'] = 'È necessario specificare una lunghezza per il tipo.'; + $lang['strtypecreated'] = 'Tipo creato'; + $lang['strtypecreatedbad'] = 'Creazione del tipo fallita.'; + $lang['strconfdroptype'] = 'Eliminare il tipo "%s"?'; + $lang['strtypedropped'] = 'Tipo eliminato.'; + $lang['strtypedroppedbad'] = 'Eliminazione del tipo fallita.'; + $lang['strflavor'] = 'Varietà'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Composto'; + $lang['strpseudotype'] = 'Pseudo-tipo'; + + // Schemas - Schemi + $lang['strschema'] = 'Schema'; + $lang['strschemas'] = 'Schemi'; + $lang['strshowallschemas'] = 'Mostra tutti gli schemi'; + $lang['strnoschema'] = 'Schema non trovato.'; + $lang['strnoschemas'] = 'Nessuno schema trovato.'; + $lang['strcreateschema'] = 'Crea schema'; + $lang['strschemaname'] = 'Nome dello schema'; + $lang['strschemaneedsname'] = 'È necessario specificare un nome per lo schema.'; + $lang['strschemacreated'] = 'Schema creato'; + $lang['strschemacreatedbad'] = 'Creazione dello schema fallita.'; + $lang['strconfdropschema'] = 'Eliminare lo schema "%s"?'; + $lang['strschemadropped'] = 'Schema eliminato.'; + $lang['strschemadroppedbad'] = 'Eliminazione dello schema fallita.'; + $lang['strschemaaltered'] = 'Schema modificato.'; + $lang['strschemaalteredbad'] = 'Modifica dello schema fallita.'; + $lang['strsearchpath'] = 'Ordine di ricerca dello schema'; + + // Reports - Rapporti + + // Domains - Domini + $lang['strdomain'] = 'Dominio'; + $lang['strdomains'] = 'Domini'; + $lang['strshowalldomains'] = 'Mostra tutti i domini'; + $lang['strnodomains'] = 'Nessun dominio trovato.'; + $lang['strcreatedomain'] = 'Crea dominio'; + $lang['strdomaindropped'] = 'Dominio eliminato.'; + $lang['strdomaindroppedbad'] = 'Eliminazione del dominio fallita.'; + $lang['strconfdropdomain'] = 'Eliminare il dominio "%s"?'; + $lang['strdomainneedsname'] = 'È necessario specificare un nome per il dominio.'; + $lang['strdomaincreated'] = 'Dominio creato.'; + $lang['strdomaincreatedbad'] = 'Creazione del dominio fallita.'; + $lang['strdomainaltered'] = 'Dominio modificato.'; + $lang['strdomainalteredbad'] = 'Modifica del dominio fallita.'; + + // Operators - Operatori + $lang['stroperator'] = 'Operatore'; + $lang['stroperators'] = 'Operatori'; + $lang['strshowalloperators'] = 'Mostra tutti gli operatori'; + $lang['strnooperator'] = 'Operatore non trovato.'; + $lang['strnooperators'] = 'Nessun operatore trovato.'; + $lang['strcreateoperator'] = 'Crea operatore'; + $lang['strleftarg'] = 'Tipo dell\'argomento di sinistra'; + $lang['strrightarg'] = 'Tipo dell\'argomento di destra'; + $lang['strcommutator'] = 'Commutatore'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Supporta hash join'; + $lang['strmerges'] = 'Supporta merge join'; + $lang['strleftsort'] = 'Ordinamento sinistro'; + $lang['strrightsort'] = 'Ordinamento destro'; + $lang['strlessthan'] = 'Minore'; + $lang['strgreaterthan'] = 'Maggiore'; + $lang['stroperatorneedsname'] = 'È necessario specificare un nome per l\'operatore.'; + $lang['stroperatorcreated'] = 'Operatore creato'; + $lang['stroperatorcreatedbad'] = 'Creazione dell\'operatore fallita.'; + $lang['strconfdropoperator'] = 'Eliminare l\'operatore "%s"?'; + $lang['stroperatordropped'] = 'Operatore eliminato.'; + $lang['stroperatordroppedbad'] = 'Eliminazione dell\'operatore fallita.'; + + // Casts - Cast + $lang['strcasts'] = 'Cast'; + $lang['strnocasts'] = 'Nessun cast trovato.'; + $lang['strsourcetype'] = 'Tipo sorgente'; + $lang['strtargettype'] = 'Tipo destinazione'; + $lang['strimplicit'] = 'Implicito'; + $lang['strinassignment'] = 'Negli assegnamenti'; + $lang['strbinarycompat'] = '(Compatibile in binario)'; + + // Conversions - Conversioni + $lang['strconversions'] = 'Conversioni'; + $lang['strnoconversions'] = 'Nessuna conversione trovata.'; + $lang['strsourceencoding'] = 'Codifica sorgente'; + $lang['strtargetencoding'] = 'Codifica destinazione'; + + // Languages - Linguaggi + $lang['strlanguages'] = 'Linguaggi'; + $lang['strnolanguages'] = 'Nessun linguaggio trovato.'; + $lang['strtrusted'] = 'Trusted'; + + // Info + $lang['strnoinfo'] = 'Nessuna informazione disponibile.'; + $lang['strreferringtables'] = 'Tabelle referenti'; + $lang['strparenttables'] = 'Tabella padre'; + $lang['strchildtables'] = 'Tabella figlia'; + + // Aggregates - Aggregati + $lang['straggregate'] = 'Aggregato'; + $lang['straggregates'] = 'Aggregati'; + $lang['strnoaggregates'] = 'Nessun aggregato trovato.'; + $lang['stralltypes'] = '(Tutti i tipi)'; + $lang['strcreateaggregate'] = 'Crea aggregato'; + $lang['straggrsfunc'] = 'Funzione di transizione di stato'; + $lang['straggrstype'] = 'Tipo di dato per il valore di stato'; + $lang['straggrffunc'] = 'Funzione finale'; + $lang['straggrinitcond'] = 'Condizione iniziale'; + $lang['straggrsortop'] = 'Operatore di ordinamento'; + $lang['strconfdropaggregate'] = 'Eliminare l\'aggregato "%s"?'; + $lang['straggregatedropped'] = 'Aggregato eliminato.'; + $lang['straggregatedroppedbad'] = 'Eliminazione dell\'aggregato fallita.'; + $lang['straggraltered'] = 'Aggregato modificato.'; + $lang['straggralteredbad'] = 'Modifica dell\'aggregato fallita.'; + $lang['straggrneedsname'] = 'È necessario specificare un nome per l\'aggregato.'; + $lang['straggrneedssfunc'] = 'È necessario specificare il nome della funzione di transizione di stato per l\'aggregato.'; + $lang['straggrneedsstype'] = 'È necessario specificare il tipo di dato per il valore di stato dell\'aggregato.'; + $lang['straggrcreated'] = 'Aggregato creato.'; + $lang['straggrcreatedbad'] = 'Creazione dell\'aggregato fallita.'; + $lang['straggrshowall'] = 'Mostra tutti gli aggregati'; + + // Operator classes - Classi di operatori + $lang['stropclasses'] = 'Classi di operatori'; + $lang['strnoopclasses'] = 'Nessuna classe di operatori trovata.'; + $lang['straccessmethod'] = 'Metodo di accesso'; + + // Stats and performance - Statistiche e performance + $lang['strrowperf'] = 'Performance sulle righe'; + $lang['strioperf'] = 'Performance sull\'I/O'; + $lang['stridxrowperf'] = 'Performance sulle righe per gli indici'; + $lang['stridxioperf'] = 'Performance sull\'I/O per gli indici'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequenziale'; + $lang['strscan'] = 'Scan'; + $lang['strread'] = 'Read'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disco'; + $lang['strrows2'] = 'Righe'; + + // Tablespaces - Tablespace + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespace'; + $lang['strshowalltablespaces'] = 'Mostra tutti i tablespace'; + $lang['strnotablespaces'] = 'Nessun tablespace trovato.'; + $lang['strcreatetablespace'] = 'Crea tablespace'; + $lang['strlocation'] = 'Directory'; + $lang['strtablespaceneedsname'] = 'È necessario specificare un nome per il tablespace.'; + $lang['strtablespaceneedsloc'] = 'È necessario specificare una directory in cui creare il tablespace.'; + $lang['strtablespacecreated'] = 'Tablespace creato.'; + $lang['strtablespacecreatedbad'] = 'Crezione del tablespace fallita.'; + $lang['strconfdroptablespace'] = 'Eliminare il tablespace "%s"?'; + $lang['strtablespacedropped'] = 'Tablespace eliminato.'; + $lang['strtablespacedroppedbad'] = 'Eliminazione del tablespace fallita.'; + $lang['strtablespacealtered'] = 'Tablespace modificato.'; + $lang['strtablespacealteredbad'] = 'Modifica del tablespace fallita.'; + + // Miscellaneous - Varie + $lang['strtopbar'] = '%s in esecuzione su %s:%s -- Utente "%s"'; + $lang['strtimefmt'] = 'j M Y - g:iA'; + $lang['strhelp'] = 'Aiuto'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Browser delle pagine di aiuto'; + $lang['strselecthelppage'] = 'Seleziona una pagina di aiuto'; + $lang['strinvalidhelppage'] = 'Pagina di aiuto non valida.'; + $lang['strlogintitle'] = 'Login su %s'; + $lang['strlogoutmsg'] = 'Logout da %s effettuato'; + $lang['strloading'] = 'Caricamento...'; + $lang['strerrorloading'] = 'Errore nel caricamento di'; + $lang['strclicktoreload'] = 'Clicca per ricaricare'; + + // Autovacuum + $lang['strautovacuum'] = 'Vacuum automatico'; + + // Prepared transactions - Transazioni preparate + $lang['strpreparedxacts'] = 'Transazioni preparate'; + $lang['strxactid'] = 'ID della transazione'; + $lang['strgid'] = 'ID globale'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/japanese.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/japanese.php new file mode 100644 index 00000000..6c72f8ad --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/japanese.php @@ -0,0 +1,855 @@ +>'; + $lang['strfailed'] = '失敗'; + $lang['strcreate'] = '作æˆ'; + $lang['strcreated'] = '作æˆã—ã¾ã—ãŸã€‚'; + $lang['strcomment'] = 'コメント'; + $lang['strlength'] = 'é•·ã•'; + $lang['strdefault'] = 'デフォルト'; + $lang['stralter'] = '変更'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'å–り消ã—'; + $lang['strac'] = '自動補完を有効ã«ã™ã‚‹'; + $lang['strsave'] = 'ä¿å­˜'; + $lang['strreset'] = 'リセット'; + $lang['strinsert'] = '挿入'; + $lang['strselect'] = 'é¸æŠž'; + $lang['strdelete'] = '削除'; + $lang['strupdate'] = 'æ›´æ–°'; + $lang['strreferences'] = 'å‚ç…§'; + $lang['stryes'] = 'ã¯ã„'; + $lang['strno'] = 'ã„ã„ãˆ'; + $lang['strtrue'] = '真'; + $lang['strfalse'] = 'å½'; + $lang['stredit'] = '編集'; + $lang['strcolumn'] = 'カラム'; + $lang['strcolumns'] = 'カラム'; + $lang['strrows'] = 'レコード'; + $lang['strrowsaff'] = '影響をå—ã‘ãŸãƒ¬ã‚³ãƒ¼ãƒ‰'; + $lang['strobjects'] = 'オブジェクト'; + $lang['strback'] = '戻る'; + $lang['strqueryresults'] = 'クエリçµæžœ'; + $lang['strshow'] = '表示'; + $lang['strempty'] = '空ã«ã™ã‚‹'; + $lang['strlanguage'] = '言語'; + $lang['strencoding'] = 'エンコード'; + $lang['strvalue'] = '値'; + $lang['strunique'] = 'ユニーク'; + $lang['strprimary'] = 'プライマリ'; + $lang['strexport'] = 'エクスãƒãƒ¼ãƒˆ'; + $lang['strimport'] = 'インãƒãƒ¼ãƒˆ'; + $lang['strallowednulls'] = 'NULL 文字を許å¯ã™ã‚‹'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = '空ã®æ–‡å­—列/é …ç›®'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = '管ç†'; + $lang['strvacuum'] = 'ãƒã‚­ãƒ¥ãƒ¼ãƒ '; + $lang['stranalyze'] = '解æž'; + $lang['strclusterindex'] = 'クラスター'; +$lang['strclustered'] = 'Clustered?'; + $lang['strreindex'] = 'å†ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹'; + $lang['strexecute'] = '実行ã™ã‚‹'; + $lang['stradd'] = '追加'; + $lang['strevent'] = 'イベント'; + $lang['strwhere'] = 'Where'; + $lang['strinstead'] = '代行'; + $lang['strwhen'] = 'When'; + $lang['strformat'] = 'フォーマット'; + $lang['strdata'] = 'データ'; + $lang['strconfirm'] = '確èª'; + $lang['strexpression'] = '評価å¼'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = '展開'; + $lang['strcollapse'] = 'é–‰ã˜ã‚‹'; + $lang['strfind'] = '検索'; + $lang['stroptions'] = 'オプション'; + $lang['strrefresh'] = 'å†è¡¨ç¤º'; + $lang['strdownload'] = 'ダウンロード'; + $lang['strdownloadgzipped'] = 'gzip ã§åœ§ç¸®ã—ã¦ãƒ€ã‚¦ãƒ³ãƒ­ãƒ¼ãƒ‰'; + $lang['strinfo'] = '情報'; + $lang['stroids'] = 'OID '; + $lang['stradvanced'] = '高度ãª'; + $lang['strvariables'] = '変数'; + $lang['strprocess'] = 'プロセス'; + $lang['strprocesses'] = 'プロセス'; + $lang['strsetting'] = '設定'; + $lang['streditsql'] = 'SQL 編集'; + $lang['strruntime'] = 'ç·å®Ÿè¡Œæ™‚é–“: %s ミリ秒'; + $lang['strpaginate'] = 'çµæžœã®ãƒšãƒ¼ã‚¸åˆ†å‰²å‡¦ç†ã‚’è¡Œã†'; + $lang['struploadscript'] = 'ã¾ãŸã¯ SQL スクリプトをアップロード:'; + $lang['strstarttime'] = '開始時間'; + $lang['strfile'] = 'ファイル'; + $lang['strfileimported'] = 'ファイルをインãƒãƒ¼ãƒˆã—ã¾ã—ãŸã€‚'; + $lang['strtrycred'] = 'ã™ã¹ã¦ã®ã‚µãƒ¼ãƒãƒ¼ã§ã“ã®æƒ…報を使ã†'; + $lang['stractionsonmultiplelines'] = '複数行ã®æ“作'; + $lang['strselectall'] = 'ã™ã¹ã¦é¸æŠžã™ã‚‹'; + $lang['strunselectall'] = 'ã™ã¹ã¦é¸æŠžã‚’解除ã™ã‚‹'; + $lang['strlocale'] = 'ロケール'; + + // User-supplied SQL history + $lang['strhistory'] = '履歴'; + $lang['strnohistory'] = '履歴ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strclearhistory'] = '履歴を消去ã™ã‚‹ã™'; + $lang['strdelhistory'] = '履歴ã‹ã‚‰å‰Šé™¤ã™ã‚‹'; + $lang['strconfdelhistory'] = '本当ã«å±¥æ­´ã‹ã‚‰ã“ã®è¦æ±‚を削除ã—ã¾ã™ã‹?'; + $lang['strconfclearhistory'] = '本当ã«å±¥æ­´ã‚’消去ã—ã¾ã™ã‹?'; + $lang['strnodatabaseselected'] = 'データベースをé¸æŠžã—ã¦ãã ã•ã„。'; + + // Database Sizes + $lang['strsize'] = 'サイズ'; + $lang['strbytes'] = 'ãƒã‚¤ãƒˆ'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'ã“ã®ã‚¢ãƒ—リケーションを使用ã™ã‚‹ãŸã‚ã«ã¯ãƒ•ãƒ¬ãƒ¼ãƒ ãŒä½¿ç”¨å¯èƒ½ãªãƒ–ラウザーãŒå¿…è¦ã§ã™ã€‚'; + $lang['strnoframeslink'] = 'フレームを除外ã—ã¦ä½¿ã†'; + $lang['strbadconfig'] = 'config.inc.php ãŒæ—§å¼ã§ã™ã€‚æ–°ã—ã„ config.inc.php-dist ã‹ã‚‰å†ä½œæˆã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strnotloaded'] = 'データベースをサãƒãƒ¼ãƒˆã™ã‚‹ã‚ˆã†ã« PHP ã®ã‚³ãƒ³ãƒ‘イル・インストールãŒã•ã‚Œã¦ã„ã¾ã›ã‚“。configure ã® --with-pgsql オプションを用ã„㦠PHP ã‚’å†ã‚³ãƒ³ãƒ‘イルã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strpostgresqlversionnotsupported'] = 'ã“ã®ãƒãƒ¼ã‚¸ãƒ§ãƒ³ã® PostgreSQL ã¯ã‚µãƒãƒ¼ãƒˆã—ã¦ã„ã¾ã›ã‚“。ãƒãƒ¼ã‚¸ãƒ§ãƒ³ %s 以上ã«ã‚¢ãƒƒãƒ—グレードã—ã¦ãã ã•ã„。'; + $lang['strbadschema'] = '無効ã®ã‚¹ã‚­ãƒ¼ãƒžãŒæŒ‡å®šã•ã‚Œã¾ã—ãŸã€‚'; + $lang['strbadencoding'] = 'データベースã®ä¸­ã§ã‚¯ãƒ©ã‚¤ã‚¢ãƒ³ãƒˆã‚¨ãƒ³ã‚³ãƒ¼ãƒ‰ã‚’指定ã—ã¾ã›ã‚“ã§ã—ãŸã€‚'; + $lang['strsqlerror'] = 'SQL エラー:'; + $lang['strinstatement'] = 'æ–‡:'; + $lang['strinvalidparam'] = 'スクリプトパラメータãŒç„¡åŠ¹ã§ã™ã€‚'; + $lang['strnodata'] = 'レコードãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strnoobjects'] = 'オブジェクトãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strrownotunique'] = 'ã“ã®ãƒ¬ã‚³ãƒ¼ãƒ‰ã«ã¯ä¸€æ„識別å­ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnouploads'] = 'ファイルアップロードãŒç„¡åŠ¹ã§ã™ã€‚'; + $lang['strimporterror'] = 'インãƒãƒ¼ãƒˆã‚¨ãƒ©ãƒ¼'; + $lang['strimporterror-fileformat'] = 'インãƒãƒ¼ãƒˆã‚¨ãƒ©ãƒ¼: ファイル形å¼ã‚’自動的ã«ç¢ºå®šã§ãã¾ã›ã‚“。.'; + $lang['strimporterrorline'] = '%s 行目ãŒã‚¤ãƒ³ãƒãƒ¼ãƒˆã‚¨ãƒ©ãƒ¼ã§ã™ã€‚'; + $lang['strimporterrorline-badcolumnnum'] = '%s è¡Œã§ã‚¤ãƒ³ãƒãƒ¼ãƒˆã‚¨ãƒ©ãƒ¼: è¡Œã¯æ­£ã—ã„列数をæŒã£ã¦ã„ã¾ã›ã‚“。'; + $lang['strimporterror-uploadedfile'] = 'インãƒãƒ¼ãƒˆã‚¨ãƒ©ãƒ¼: サーãƒãƒ¼ã«ãƒ•ã‚¡ã‚¤ãƒ«ã‚’アップロードã™ã‚‹ã“ã¨ãŒã§ããªã„ã‹ã‚‚ã—ã‚Œã¾ã›ã‚“。'; + $lang['strcannotdumponwindows'] = 'Windows 上ã§ã®è¤‡åˆãƒ†ãƒ¼ãƒ–ルã¨ã‚¹ã‚­ãƒ¼ãƒžåã®ãƒ€ãƒ³ãƒ—ã¯ã‚µãƒãƒ¼ãƒˆã—ã¦ã„ã¾ã›ã‚“。'; +$lang['strinvalidserverparam'] = 'Attempt to connect with invalid server parameter, possibly someone is trying to hack your system.'; + $lang['strnoserversupplied'] = 'サーãƒãƒ¼ãŒæŒ‡å®šã•ã‚Œã¦ã„ã¾ã›ã‚“!'; + + // Tables + $lang['strtable'] = 'テーブル'; + $lang['strtables'] = 'テーブル'; + $lang['strshowalltables'] = 'ã™ã¹ã¦ã®ãƒ†ãƒ¼ãƒ–ルを表示ã™ã‚‹'; + $lang['strnotables'] = 'テーブルãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strnotable'] = 'テーブルãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreatetable'] = 'テーブルを作æˆã™ã‚‹'; + $lang['strcreatetablelike'] = 'ã“ã®ãƒ†ãƒ¼ãƒ–ルを元ã«æ–°ã—ã„テーブルを作æˆã™ã‚‹'; + $lang['strcreatetablelikeparent'] = '元テーブル'; + $lang['strcreatelikewithdefaults'] = 'DEFAULT ã‚’å«ã‚€'; + $lang['strcreatelikewithconstraints'] = 'CONSTRAINTS ã‚’å«ã‚€'; + $lang['strcreatelikewithindexes'] = 'INDEX ã‚’å«ã‚€'; + $lang['strtablename'] = 'テーブルå'; + $lang['strtableneedsname'] = 'テーブルåを指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; +$lang['strtablelikeneedslike'] = 'You must give a table to copy properties from.'; + $lang['strtableneedsfield'] = 'å°‘ãªãã¨ã‚‚一ã¤ã®ãƒ•ã‚£ãƒ¼ãƒ«ãƒ‰ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtableneedscols'] = '有効ãªã‚«ãƒ©ãƒ æ•°ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtablecreated'] = 'テーブルを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strtablecreatedbad'] = 'テーブルã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdroptable'] = 'テーブル「%sã€ã‚’本当ã«ç ´æ£„ã—ã¾ã™ã‹?'; + $lang['strtabledropped'] = 'テーブルを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strtabledroppedbad'] = 'テーブルã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfemptytable'] = '本当ã«ãƒ†ãƒ¼ãƒ–ル「%sã€ã®å†…容を破棄ã—ã¾ã™ã‹?'; + $lang['strtableemptied'] = 'テーブルãŒç©ºã«ãªã‚Šã¾ã—ãŸ.'; + $lang['strtableemptiedbad'] = 'テーブルを空ã«ã§ãã¾ã›ã‚“ã§ã—ãŸã€‚'; + $lang['strinsertrow'] = 'レコードã®æŒ¿å…¥'; + $lang['strrowinserted'] = 'レコードを挿入ã—ã¾ã—ãŸã€‚'; + $lang['strrowinsertedbad'] = 'レコードã®æŒ¿å…¥ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strrowduplicate'] = 'レコードã®æŒ¿å…¥ã«å¤±æ•—ã—ã€æŒ¿å…¥ã®è¤‡è£½ã‚’試ã¿ã¾ã—ãŸã€‚'; + $lang['streditrow'] = 'レコード編集'; + $lang['strrowupdated'] = 'レコードを更新ã—ã¾ã—ãŸã€‚'; + $lang['strrowupdatedbad'] = 'レコードã®æ›´æ–°ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strdeleterow'] = 'レコード削除'; + $lang['strconfdeleterow'] = '本当ã«ã“ã®ãƒ¬ã‚³ãƒ¼ãƒ‰ã‚’削除ã—ã¾ã™ã‹?'; + $lang['strrowdeleted'] = 'レコードを削除ã—ã¾ã—ãŸã€‚'; + $lang['strrowdeletedbad'] = 'レコードã®å‰Šé™¤ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strinsertandrepeat'] = '挿入ã¨ç¹°ã‚Šè¿”ã—'; + $lang['strnumcols'] = 'カラムã®æ•°'; + $lang['strcolneedsname'] = 'カラムã®åå‰ã‚’指定ã—ãªã‘ã‚Œã°ã‚Šã¾ã›ã‚“。'; + $lang['strselectallfields'] = 'ã™ã¹ã¦ã®ãƒ•ã‚£ãƒ¼ãƒ«ãƒ‰ã‚’é¸æŠžã™ã‚‹'; + $lang['strselectneedscol'] = 'å°‘ãªãã¨ã‚‚一カラムã¯å¿…è¦ã§ã™ã€‚'; + $lang['strselectunary'] = 'å˜é …ã®ã‚ªãƒšãƒ¬ãƒ¼ã‚¿ãƒ¼ã¯å€¤ã‚’æŒã¤ã“ã¨ãŒã§ãã¾ã›ã‚“。'; + $lang['strcolumnaltered'] = 'カラムを変更ã—ã¾ã—ãŸã€‚'; + $lang['strcolumnalteredbad'] = 'カラムã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropcolumn'] = '本当ã«ã‚«ãƒ©ãƒ ã€Œ%sã€ã‚’テーブル「%sã€ã‹ã‚‰ç ´æ£„ã—ã¦ã„ã„ã§ã™ã‹?'; + $lang['strcolumndropped'] = 'カラムを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strcolumndroppedbad'] = 'カラムã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straddcolumn'] = 'カラムã®è¿½åŠ '; + $lang['strcolumnadded'] = 'カラムを追加ã—ã¾ã—ãŸã€‚'; + $lang['strcolumnaddedbad'] = 'カラムã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strcascade'] = 'カスケード'; + $lang['strtablealtered'] = 'テーブルを変更ã—ã¾ã—ãŸã€‚'; + $lang['strtablealteredbad'] = 'テーブルã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strdataonly'] = 'データã®ã¿'; + $lang['strstructureonly'] = '構造ã®ã¿'; + $lang['strstructureanddata'] = '構造ã¨ãƒ‡ãƒ¼ã‚¿'; + $lang['strtabbed'] = 'タブ区切り'; + $lang['strauto'] = '自動'; + $lang['strconfvacuumtable'] = '本当ã«ã€Œ%sã€ã‚’ãƒã‚­ãƒ¥ãƒ¼ãƒ ã—ã¾ã™ã‹?'; + $lang['strconfanalyzetable'] = '「%sã€ã‚’本当ã«åˆ†æž(ANALYZE)ã—ã¾ã™ã‹?'; + $lang['strestimatedrowcount'] = '評価済レコード数'; + $lang['strspecifytabletoanalyze'] = 'テーブルを解æžã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['strspecifytabletoempty'] = 'テーブルを空ã«ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['strspecifytabletodrop'] = 'テーブルを破棄ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['strspecifytabletovacuum'] = 'テーブルをãƒã‚­ãƒ¥ãƒ¼ãƒ ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + + // Columns + $lang['strcolprop'] = 'カラムã®ãƒ—ロパティ'; + $lang['strnotableprovided'] = 'テーブルãŒæŒ‡å®šã•ã‚Œã¦ã„ã¾ã›ã‚“!'; + + // Users + $lang['struser'] = 'ユーザー'; + $lang['strusers'] = 'ユーザー'; + $lang['strusername'] = 'ユーザーå'; + $lang['strpassword'] = 'パスワード'; + $lang['strsuper'] = 'スーパーユーザーã§ã™ã‹?'; + $lang['strcreatedb'] = 'データベースを作æˆã—ã¾ã™ã‹?'; + $lang['strexpires'] = '有効期é™'; + $lang['strsessiondefaults'] = 'セッションデフォルト'; + $lang['strnousers'] = 'ユーザーãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['struserupdated'] = 'ユーザーを更新ã—ã¾ã—ãŸã€‚'; + $lang['struserupdatedbad'] = 'ユーザーã®æ›´æ–°ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strshowallusers'] = 'ã™ã¹ã¦ã®ãƒ¦ãƒ¼ã‚¶ãƒ¼ã‚’表示ã™ã‚‹'; + $lang['strcreateuser'] = 'ユーザーを作æˆã™ã‚‹'; + $lang['struserneedsname'] = 'ユーザーã®åå‰ã‚’ãŒå¿…è¦ã§ã™ã€‚'; + $lang['strusercreated'] = 'ユーザーを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strusercreatedbad'] = 'ユーザーã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropuser'] = '本当ã«ãƒ¦ãƒ¼ã‚¶ãƒ¼ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['struserdropped'] = 'ユーザーを破棄ã—ã¾ã—ãŸã€‚'; + $lang['struserdroppedbad'] = 'ユーザーã®å‰Šé™¤ã«ç ´æ£„ã—ã¾ã—ãŸ'; + $lang['straccount'] = 'アカウント'; + $lang['strchangepassword'] = 'パスワード変更'; + $lang['strpasswordchanged'] = 'パスワードã®å¤‰æ›´ã‚’ã—ã¾ã—ãŸã€‚'; + $lang['strpasswordchangedbad'] = 'パスワードã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strpasswordshort'] = 'パスワードãŒçŸ­ã™ãŽã¾ã™ã€‚'; + $lang['strpasswordconfirm'] = 'パスワードã®ç¢ºèªãŒä¸€è‡´ã—ã¾ã›ã‚“ã§ã—ãŸã€‚'; + + // Groups + $lang['strgroup'] = 'グループ'; + $lang['strgroups'] = 'グループ'; + $lang['strshowallgroups'] = 'ã™ã¹ã¦ã®ã‚°ãƒ«ãƒ¼ãƒ—を表示ã™ã‚‹'; + $lang['strnogroup'] = 'グループãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnogroups'] = 'グループãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreategroup'] = 'グループを作æˆã™ã‚‹'; + $lang['strgroupneedsname'] = 'グループåを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strgroupcreated'] = 'グループを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strgroupcreatedbad'] = 'グループã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropgroup'] = '本当ã«ã‚°ãƒ«ãƒ¼ãƒ—「%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strgroupdropped'] = 'グループを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strgroupdroppedbad'] = 'グループã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strmembers'] = 'メンãƒãƒ¼'; + $lang['strmemberof'] = '次ã®ã‚°ãƒ«ãƒ¼ãƒ—ã®ãƒ¡ãƒ³ãƒãƒ¼:'; + $lang['stradminmembers'] = '管ç†ãƒ¡ãƒ³ãƒãƒ¼'; + $lang['straddmember'] = 'メンãƒãƒ¼ã‚’追加ã™ã‚‹'; + $lang['strmemberadded'] = 'メンãƒãƒ¼ã‚’追加ã—ã¾ã—ãŸã€‚'; + $lang['strmemberaddedbad'] = 'メンãƒãƒ¼ã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strdropmember'] = 'メンãƒãƒ¼ç ´æ£„'; + $lang['strconfdropmember'] = '本当ã«ãƒ¡ãƒ³ãƒãƒ¼ã€Œ%sã€ã‚’グループ「%sã€ã‹ã‚‰ç ´æ£„ã—ã¾ã™ã‹?'; + $lang['strmemberdropped'] = 'メンãƒãƒ¼ã‚’破棄ã—ã¾ã—ãŸã€‚'; + $lang['strmemberdroppedbad'] = 'メンãƒãƒ¼ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + + // Roles + $lang['strrole'] = 'ロール'; + $lang['strroles'] = 'ロール'; + $lang['strshowallroles'] = 'ã™ã¹ã¦ã®ãƒ­ãƒ¼ãƒ«ã‚’表示ã™ã‚‹'; + $lang['strnoroles'] = 'ロールãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strinheritsprivs'] = '特権を引ã継ãŽã¾ã™ã‹?'; + $lang['strcreaterole'] = 'ロールを作æˆã™ã‚‹'; + $lang['strcancreaterole'] = 'ロールを作æˆã§ãã¾ã™ã‹?'; + $lang['strrolecreated'] = 'ロールを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strrolecreatedbad'] = 'ロールã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strrolealtered'] = 'ロールを変更ã—ã¾ã—ãŸã€‚'; + $lang['strrolealteredbad'] = 'ロールã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strcanlogin'] = 'ログインã§ãã¾ã™ã‹?'; + $lang['strconnlimit'] = '接続制é™'; + $lang['strdroprole'] = 'ロールを破棄ã™ã‚‹'; + $lang['strconfdroprole'] = '本当ã«ãƒ­ãƒ¼ãƒ«ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strroledropped'] = 'ロールを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strroledroppedbad'] = 'ロールã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strnolimit'] = '制é™ãªã—'; + $lang['strnever'] = 'Never'; + $lang['strroleneedsname'] = 'ロールã®åå‰ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + + // Privileges + $lang['strprivilege'] = '特権'; + $lang['strprivileges'] = '特権'; + $lang['strnoprivileges'] = 'ã“ã®ã‚ªãƒ–ジェクトã¯ç‰¹æ¨©ã‚’æŒã£ã¦ã„ã¾ã›ã‚“。'; + $lang['strgrant'] = '権é™'; + $lang['strrevoke'] = '廃止'; + $lang['strgranted'] = '特権を与ãˆã¾ã—ãŸã€‚'; + $lang['strgrantfailed'] = '特権を与ãˆã‚‹äº‹ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strgrantbad'] = 'å°‘ãªãã¨ã‚‚一人ã®ãƒ¦ãƒ¼ã‚¶ãƒ¼ã‹ã‚°ãƒ«ãƒ¼ãƒ—ã«ã€å°‘ãªãã¨ã‚‚ã²ã¨ã¤ã®ç‰¹æ¨©ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strgrantor'] = '譲与'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'データベース'; + $lang['strdatabases'] = 'データベース'; + $lang['strshowalldatabases'] = 'ã™ã¹ã¦ã®ãƒ‡ãƒ¼ã‚¿ãƒ™ãƒ¼ã‚¹ã‚’表示ã™ã‚‹'; + $lang['strnodatabases'] = 'データベースãŒã¾ã£ãŸãã‚ã‚Šã¾ã›ã‚“。'; + $lang['strcreatedatabase'] = 'データベースを作æˆã™ã‚‹'; + $lang['strdatabasename'] = 'データベースå'; + $lang['strdatabaseneedsname'] = 'データベースåを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strdatabasecreated'] = 'データベースを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strdatabasecreatedbad'] = 'データベースã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropdatabase'] = '本当ã«ãƒ‡ãƒ¼ã‚¿ãƒ™ãƒ¼ã‚¹ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strdatabasedropped'] = 'データベースを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strdatabasedroppedbad'] = 'データベースã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strentersql'] = '下ã«å®Ÿè¡Œã™ã‚‹SQLを入力ã—ã¾ã™:'; + $lang['strsqlexecuted'] = 'SQLを実行ã—ã¾ã—ãŸã€‚'; + $lang['strvacuumgood'] = 'ãƒã‚­ãƒ¥ãƒ¼ãƒ ã‚’完了ã—ã¾ã—ãŸã€‚'; + $lang['strvacuumbad'] = 'ãƒã‚­ãƒ¥ãƒ¼ãƒ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['stranalyzegood'] = '解æžã‚’完了ã—ã¾ã—ãŸã€‚'; + $lang['stranalyzebad'] = '解æžã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strreindexgood'] = 'å†ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹ã‚’完了ã—ã¾ã—ãŸã€‚'; + $lang['strreindexbad'] = 'å†ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strfull'] = 'ã™ã¹ã¦'; + $lang['strfreeze'] = 'フリーズ'; + $lang['strforce'] = '強制'; + $lang['strsignalsent'] = 'シグナルé€ä¿¡'; + $lang['strsignalsentbad'] = 'シグナルé€ä¿¡ã«å¤±æ•—ã—ã¾ã—ãŸ'; + $lang['strallobjects'] = 'ã™ã¹ã¦ã®ã‚ªãƒ–ジェクト'; + $lang['strdatabasealtered'] = 'データベースを変更ã—ã¾ã—ãŸã€‚'; + $lang['strdatabasealteredbad'] = 'データベースã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strspecifydatabasetodrop'] = 'データベースを破棄ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + + // Views + $lang['strview'] = 'ビュー'; + $lang['strviews'] = 'ビュー'; + $lang['strshowallviews'] = 'ã™ã¹ã¦ã®ãƒ“ューを表示ã™ã‚‹'; + $lang['strnoview'] = 'ビューãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnoviews'] = 'ビューãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreateview'] = 'ビューを作æˆã™ã‚‹'; + $lang['strviewname'] = 'ビューå'; + $lang['strviewneedsname'] = 'ビューåを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strviewneedsdef'] = '定義åを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strviewneedsfields'] = 'ビューã®ã®ä¸­ã‹ã‚‰é¸æŠžã—ã€å¸Œæœ›ã®ã‚«ãƒ©ãƒ ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strviewcreated'] = 'ビューを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strviewcreatedbad'] = 'ビューã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropview'] = '本当ã«ãƒ“ュー「%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strviewdropped'] = 'ビューを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strviewdroppedbad'] = 'ビューã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strviewupdated'] = 'ビューを更新ã—ã¾ã—ãŸã€‚'; + $lang['strviewupdatedbad'] = 'ビューã®æ›´æ–°ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strviewlink'] = 'リンクã—ãŸã‚­ãƒ¼'; + $lang['strviewconditions'] = '追加æ¡ä»¶'; + $lang['strcreateviewwiz'] = 'ウィザードã§ãƒ“ューを作æˆã™ã‚‹'; + $lang['strrenamedupfields'] = 'é‡è¤‡é …ç›®ã®åå‰ã‚’変更ã™ã‚‹'; + $lang['strdropdupfields'] = 'é‡è¤‡é …目を破棄ã™ã‚‹'; + $lang['strerrordupfields'] = 'é‡è¤‡é …ç›®ã®ã‚¨ãƒ©ãƒ¼ã§ã™'; + $lang['strviewaltered'] = 'ビューを変更ã—ã¾ã—ãŸã€‚'; + $lang['strviewalteredbad'] = 'ビューã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strspecifyviewtodrop'] = 'ビューを破棄ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + + // Sequences + $lang['strsequence'] = 'シーケンス'; + $lang['strsequences'] = 'シーケンス'; + $lang['strshowallsequences'] = 'ã™ã¹ã¦ã®ã‚·ãƒ¼ã‚±ãƒ³ã‚¹ã‚’表示ã™ã‚‹'; + $lang['strnosequence'] = 'シーケンスãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnosequences'] = 'シーケンスãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreatesequence'] = 'シーケンスを作æˆã™ã‚‹'; + $lang['strlastvalue'] = '最終値'; + $lang['strincrementby'] = '増加数'; + $lang['strstartvalue'] = '開始値'; + $lang['strmaxvalue'] = '最大値'; + $lang['strminvalue'] = '最å°å€¤'; + $lang['strcachevalue'] = 'キャッシュ値'; + $lang['strlogcount'] = 'ログカウント'; +$lang['strcancycle'] = 'Can cycle?'; +$lang['striscalled'] = 'Will increment last value before returning next value (is_called)?'; + $lang['strsequenceneedsname'] = 'シーケンスåを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strsequencecreated'] = 'シーケンスを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strsequencecreatedbad'] = 'シーケンスã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropsequence'] = '本当ã«ã‚·ãƒ¼ã‚±ãƒ³ã‚¹ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strsequencedropped'] = 'シーケンスを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strsequencedroppedbad'] = 'シーケンスã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strsequencereset'] = 'シーケンスリセットを行ã„ã¾ã—ãŸã€‚'; + $lang['strsequenceresetbad'] = 'シーケンスã®ãƒªã‚»ãƒƒãƒˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strsequencealtered'] = 'シーケンスを変更ã—ã¾ã—ãŸã€‚'; + $lang['strsequencealteredbad'] = 'シーケンスã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strsetval'] = '値を設定ã™ã‚‹'; + $lang['strsequencesetval'] = 'シーケンス値を設定ã—ã¾ã—ãŸã€‚'; + $lang['strsequencesetvalbad'] = 'シーケンス値ã®è¨­å®šã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strnextval'] = '値を増加ã™ã‚‹'; + $lang['strsequencenextval'] = '値を増加ã—ã¾ã—ãŸã€‚'; + $lang['strsequencenextvalbad'] = '値ã®å¢—加ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strspecifysequencetodrop'] = 'シーケンスを破棄ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + + // Indexes + $lang['strindex'] = 'インデックス'; + $lang['strindexes'] = 'インデックス'; + $lang['strindexname'] = 'インデックスå'; + $lang['strshowallindexes'] = 'ã™ã¹ã¦ã®ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹ã‚’表示ã™ã‚‹'; + $lang['strnoindex'] = 'インデックスãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnoindexes'] = 'インデックスãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreateindex'] = 'インデックスを作æˆã™ã‚‹'; + $lang['strtabname'] = 'タブå'; + $lang['strcolumnname'] = 'カラムå'; + $lang['strindexneedsname'] = '有効ãªã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹åを指定ã—ãªã‘ã‚Œã°ã„ã‘ã¾ã›ã‚“。'; + $lang['strindexneedscols'] = '有効ãªã‚«ãƒ©ãƒ æ•°ã‚’指定ã—ãªã‘ã‚Œã°ã„ã‘ã¾ã›ã‚“。'; + $lang['strindexcreated'] = 'インデックスを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strindexcreatedbad'] = 'インデックスã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropindex'] = '本当ã«ã‚¤ãƒ³ãƒ‡ãƒƒã‚¯ã‚¹ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strindexdropped'] = 'インデックスを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strindexdroppedbad'] = 'インデックスã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strkeyname'] = 'キーå'; + $lang['struniquekey'] = 'ユニークキー'; + $lang['strprimarykey'] = 'プライマリキー'; + $lang['strindextype'] = 'インデックスタイプ'; + $lang['strtablecolumnlist'] = 'テーブル中ã®ã‚«ãƒ©ãƒ '; + $lang['strindexcolumnlist'] = 'インデックス中ã®ã‚«ãƒ©ãƒ '; + $lang['strconfcluster'] = '本当ã«ã€Œ%sã€ã‚’クラスターã«ã—ã¾ã™ã‹?'; + $lang['strclusteredgood'] = 'クラスター完了ã§ã™ã€‚'; + $lang['strclusteredbad'] = 'クラスターã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strcluster'] = 'クラスター'; + + // Rules + $lang['strrules'] = 'ルール'; + $lang['strrule'] = 'ルール'; + $lang['strshowallrules'] = 'ã™ã¹ã¦ã®ãƒ«ãƒ¼ãƒ«ã‚’表示ã™ã‚‹'; + $lang['strnorule'] = 'ルールãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnorules'] = 'ルールãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreaterule'] = 'ルールを作æˆã™ã‚‹'; + $lang['strrulename'] = 'ルールå'; + $lang['strruleneedsname'] = 'ルールåを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strrulecreated'] = 'ルールを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strrulecreatedbad'] = 'ルールã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdroprule'] = '本当ã«ãƒ«ãƒ¼ãƒ«ã€Œ%sã€ã‚’データベース「%sã€ã‹ã‚‰ç ´æ£„ã—ã¾ã™ã‹?'; + $lang['strruledropped'] = 'ルールを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strruledroppedbad'] = 'ルールã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + + // Constraints + $lang['strconstraint'] = '検査制約'; + $lang['strconstraints'] = '検査制約'; + $lang['strshowallconstraints'] = 'ã™ã¹ã¦ã®æ¤œæŸ»åˆ¶ç´„を表示ã™ã‚‹'; + $lang['strnoconstraints'] = '検査制約ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strcreateconstraint'] = '検査制約を作æˆã™ã‚‹'; + $lang['strconstraintcreated'] = '検査制約を作æˆã—ã¾ã—ãŸã€‚'; + $lang['strconstraintcreatedbad'] = '検査制約ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropconstraint'] = '本当ã«æ¤œæŸ»åˆ¶ç´„「%sã€ã‚’データベース「%sã€ã‹ã‚‰ç ´æ£„ã—ã¾ã™ã‹?'; + $lang['strconstraintdropped'] = '検査制約を破棄ã—ã¾ã—ãŸã€‚'; + $lang['strconstraintdroppedbad'] = '検査制約ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straddcheck'] = '検査を追加ã™ã‚‹'; + $lang['strcheckneedsdefinition'] = '検査制約ã«ã¯å®šç¾©ãŒå¿…è¦ã§ã™ã€‚'; + $lang['strcheckadded'] = '検査制約を追加ã—ã¾ã—ãŸã€‚'; + $lang['strcheckaddedbad'] = '検査制約ã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straddpk'] = 'プライマリキーを追加ã™ã‚‹'; + $lang['strpkneedscols'] = 'プライマリキーã¯å°‘ãªãã¨ã‚‚一カラムを必è¦ã¨ã—ã¾ã™ã€‚'; + $lang['strpkadded'] = 'プライマリキーを追加ã—ã¾ã—ãŸã€‚'; + $lang['strpkaddedbad'] = 'プライマリキーã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['stradduniq'] = 'ユニークキーを追加ã™ã‚‹'; + $lang['struniqneedscols'] = 'ユニークキーã¯å°‘ãªãã¨ã‚‚一カラムを必è¦ã¨ã—ã¾ã™ã€‚'; + $lang['struniqadded'] = 'ユニークキーを追加ã—ã¾ã—ãŸã€‚'; + $lang['struniqaddedbad'] = 'ユニークキーã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straddfk'] = '外部キーを追加ã™ã‚‹'; + $lang['strfkneedscols'] = '外部キーã¯å°‘ãªãã¨ã‚‚一カラムを必è¦ã¨ã—ã¾ã™ã€‚'; + $lang['strfkneedstarget'] = '外部キーã¯ã‚¿ãƒ¼ã‚²ãƒƒãƒˆãƒ†ãƒ¼ãƒ–ルを必è¦ã¨ã—ã¾ã™ã€‚'; + $lang['strfkadded'] = '外部キーを追加ã—ã¾ã—ãŸã€‚'; + $lang['strfkaddedbad'] = '外部キーã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strfktarget'] = '対象テーブル'; + $lang['strfkcolumnlist'] = 'キー中ã®ã‚«ãƒ©ãƒ '; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = '関数'; + $lang['strfunctions'] = '関数'; + $lang['strshowallfunctions'] = 'ã™ã¹ã¦é–¢æ•°ã‚’表示ã™ã‚‹'; + $lang['strnofunction'] = '関数ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnofunctions'] = '関数ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreateplfunction'] = 'SQL/PL 関数を作æˆã™ã‚‹'; + $lang['strcreateinternalfunction'] = '内部関数を作æˆã™ã‚‹'; + $lang['strcreatecfunction'] = 'C 関数を作æˆã™ã‚‹'; + $lang['strfunctionname'] = '関数å'; + $lang['strreturns'] = '返り値'; + $lang['strproglanguage'] = 'プログラミング言語'; + $lang['strfunctionneedsname'] = '関数åを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strfunctionneedsdef'] = '関数ã®å®šç¾©ã‚’ã—ãªã‘ã‚Œã°ãªã‚Šã‚ã›ã‚“。'; + $lang['strfunctioncreated'] = '関数を作æˆã—ã¾ã—ãŸã€‚'; + $lang['strfunctioncreatedbad'] = '関数ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropfunction'] = '本当ã«é–¢æ•°ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strfunctiondropped'] = '関数を破棄ã—ã¾ã—ãŸã€‚'; + $lang['strfunctiondroppedbad'] = '関数ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strfunctionupdated'] = '関数を更新ã—ã¾ã—ãŸã€‚'; + $lang['strfunctionupdatedbad'] = '関数ã®æ›´æ–°ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strobjectfile'] = 'オブジェクトファイル'; + $lang['strlinksymbol'] = 'リンクシンボル'; + $lang['strarguments'] = '引数'; + $lang['strargmode'] = 'モード'; + $lang['strargtype'] = '種類'; + $lang['strargadd'] = 'ä»–ã®å¼•æ•°ã‚’追加ã™ã‚‹'; + $lang['strargremove'] = 'ã“ã®å¼•æ•°ã‚’削除ã™ã‚‹'; + $lang['strargnoargs'] = 'ã“ã®é–¢æ•°ã¯ã„ãã¤ã‹ã®å¼•æ•°ã‚’å–らãªã§ã—ょã†ã€‚'; +$lang['strargenableargs'] = 'Enable arguments being passed to this function.'; + $lang['strargnorowabove'] = 'ã“ã®è¡Œã®ä¸Šã«è¡ŒãŒå¿…è¦ã§ã™ã€‚'; + $lang['strargnorowbelow'] = 'ã“ã®è¡Œã®ä¸‹ã«è¡ŒãŒå¿…è¦ã§ã™ã€‚'; + $lang['strargraise'] = '上ã«ç§»å‹•ã—ã¾ã™ã€‚'; + $lang['strarglower'] = '下ã«ç§»å‹•ã—ã¾ã™ã€‚'; + $lang['strargremoveconfirm'] = '本当ã«ã“ã®å¼•æ•°ã‚’削除ã—ã¾ã™ã‹? ã“ã‚Œã¯æˆ»ã™ã“ã¨ãŒã§ãã¾ã›ã‚“This CANNOT be undone。'; +$lang['strfunctioncosting'] = 'Function Costing'; +$lang['strresultrows'] = 'Result Rows'; +$lang['strexecutioncost'] = 'Execution Cost'; + $lang['strspecifyfunctiontodrop'] = '関数を破棄ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + + // Triggers + $lang['strtrigger'] = 'トリガー'; + $lang['strtriggers'] = 'トリガー'; + $lang['strshowalltriggers'] = 'ã™ã¹ã¦ã®ãƒˆãƒªã‚¬ãƒ¼ã‚’表示ã™ã‚‹'; + $lang['strnotrigger'] = 'トリガーãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnotriggers'] = 'トリガーãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreatetrigger'] = 'トリガーを作æˆã™ã‚‹'; + $lang['strtriggerneedsname'] = 'トリガーåを指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strtriggerneedsfunc'] = 'トリガーã®ãŸã‚ã®é–¢æ•°ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtriggercreated'] = 'トリガーを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strtriggercreatedbad'] = 'トリガーã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdroptrigger'] = '本当ã«ãƒˆãƒªã‚¬ãƒ¼ã€Œ%sã€ã‚’データベース「%sã€ã‹ã‚‰ç ´æ£„ã—ã¾ã™ã‹?'; + $lang['strconfenabletrigger'] = '本当ã«ã€Œ%2$sã€ã®ãƒˆãƒªã‚¬ãƒ¼ã€Œ%1$sã€ã‚’有効ã«ã—ã¾ã™ã‹?'; + $lang['strconfdisabletrigger'] = '本当ã«ã€Œ%2$sã€ã®ãƒˆãƒªã‚¬ãƒ¼ã€Œ%1$sã€ã‚’無効ã«ã—ã¾ã™ã‹?'; + $lang['strtriggerdropped'] = 'トリガーを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strtriggerdroppedbad'] = 'トリガーã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strtriggerenabled'] = 'トリガーを有効ã«ã—ã¾ã—ãŸã€‚'; + $lang['strtriggerenabledbad'] = 'トリガーã®æœ‰åŠ¹åŒ–ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strtriggerdisabled'] = 'トリガーを無効ã«ã—ã¾ã—ãŸã€‚'; + $lang['strtriggerdisabledbad'] = 'トリガーã®ç„¡åŠ¹åŒ–ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strtriggeraltered'] = 'トリガーを変更ã—ã¾ã—ãŸã€‚'; + $lang['strtriggeralteredbad'] = 'トリガーã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; +$lang['strforeach'] = 'For each'; + + // Types + $lang['strtype'] = 'データ型'; + $lang['strtypes'] = 'データ型'; + $lang['strshowalltypes'] = 'ã™ã¹ã¦ã®ãƒ‡ãƒ¼ã‚¿åž‹ã‚’表示ã™ã‚‹'; + $lang['strnotype'] = 'データ型ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnotypes'] = 'データ型ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“ã§ã—ãŸã€‚'; + $lang['strcreatetype'] = 'データ型を作æˆã™ã‚‹'; + $lang['strcreatecomptype'] = '複åˆåž‹ã‚’作æˆã™ã‚‹'; +$lang['strcreateenumtype'] = 'Create enum type'; + $lang['strtypeneedsfield'] = 'å°‘ãªãã¨ã‚‚ 1 ã¤ã®ãƒ•ã‚£ãƒ¼ãƒ«ãƒ‰ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtypeneedsvalue'] = 'å°‘ãªãã¨ã‚‚ 1 ã¤ã®å€¤ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtypeneedscols'] = '有効ãªãƒ•ã‚£ãƒ¼ãƒ«ãƒ‰ã®æ•°ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; +$lang['strtypeneedsvals'] = 'You must specify a valid number of values.'; + $lang['strinputfn'] = '入力関数'; + $lang['stroutputfn'] = '出力関数'; +$lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'アライメント'; + $lang['strelement'] = 'è¦ç´ '; + $lang['strdelimiter'] = 'デミリタ'; + $lang['strstorage'] = 'ストレージ'; + $lang['strfield'] = 'フィールド'; +$lang['strvalue'] = 'Value'; +$lang['strvalue'] = 'Value'; + $lang['strnumfields'] = 'フィールド数'; +$lang['strnumvalues'] = 'Num. of values'; + $lang['strtypeneedsname'] = 'åž‹åを指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtypeneedslen'] = 'データ型ã®é•·ã•ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strtypecreated'] = 'データ型を作æˆã—ã¾ã—ãŸã€‚'; + $lang['strtypecreatedbad'] = 'データ型ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdroptype'] = '本当ã«ãƒ‡ãƒ¼ã‚¿åž‹ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strtypedropped'] = 'データ型を破棄ã—ã¾ã—ãŸã€‚'; + $lang['strtypedroppedbad'] = 'データ型ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strflavor'] = '種類'; + $lang['strbasetype'] = '基本'; + $lang['strcompositetype'] = '複åˆåž‹'; + $lang['strpseudotype'] = '擬似データ'; +$lang['strenum'] = 'Enum'; +$lang['strenumvalues'] = 'Enum Values'; + + // Schemas + $lang['strschema'] = 'スキーマ'; + $lang['strschemas'] = 'スキーマ'; + $lang['strshowallschemas'] = 'ã™ã¹ã¦ã®ã‚¹ã‚­ãƒ¼ãƒžã‚’表示ã™ã‚‹'; + $lang['strnoschema'] = 'スキーマãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strnoschemas'] = 'スキーマãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreateschema'] = 'スキーマを作æˆã™ã‚‹'; + $lang['strschemaname'] = 'スキーマå'; + $lang['strschemaneedsname'] = 'スキーマåを指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strschemacreated'] = 'スキーマを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strschemacreatedbad'] = 'スキーマã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropschema'] = '本当ã«ã‚¹ã‚­ãƒ¼ãƒžã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strschemadropped'] = 'スキーマを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strschemadroppedbad'] = 'スキーマã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strschemaaltered'] = 'スキーマを変更ã—ã¾ã—ãŸã€‚'; + $lang['strschemaalteredbad'] = 'スキーマã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strsearchpath'] = 'スキーマ検索パス'; + $lang['strspecifyschematodrop'] = 'スキーマを破棄ã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + + // Reports + + // Domains + $lang['strdomain'] = 'ドメイン'; + $lang['strdomains'] = 'ドメイン'; + $lang['strshowalldomains'] = 'ã™ã¹ã¦ã®ãƒ‰ãƒ¡ã‚¤ãƒ³ã‚’表示ã™ã‚‹'; + $lang['strnodomains'] = 'ドメインãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strcreatedomain'] = 'ドメイン作æˆ'; + $lang['strdomaindropped'] = 'ドメインを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strdomaindroppedbad'] = 'ドメインã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropdomain'] = '本当ã«ãƒ‰ãƒ¡ã‚¤ãƒ³ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strdomainneedsname'] = 'ドメインåを指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strdomaincreated'] = 'ドメインを作æˆã—ã¾ã—ãŸã€‚'; + $lang['strdomaincreatedbad'] = 'ドメインã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strdomainaltered'] = 'ドメインを変更ã—ã¾ã—ãŸã€‚'; + $lang['strdomainalteredbad'] = 'ドメインã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + + // Operators + $lang['stroperator'] = '演算å­'; + $lang['stroperators'] = '演算å­'; + $lang['strshowalloperators'] = 'ã™ã¹ã¦ã®æ¼”ç®—å­ã‚’表示ã™ã‚‹'; + $lang['strnooperator'] = '演算å­ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strnooperators'] = '演算å­ã‚¯ãƒ©ã‚¹ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreateoperator'] = '演算å­ã‚’作æˆã—ã¾ã—ãŸã€‚'; + $lang['strleftarg'] = '左引数タイプ'; + $lang['strrightarg'] = 'å³å¼•æ•°ã‚¿ã‚¤ãƒ—'; + $lang['strcommutator'] = '交代'; + $lang['strnegator'] = 'å¦å®š'; + $lang['strrestrict'] = '制é™'; + $lang['strjoin'] = 'çµåˆ'; + $lang['strhashes'] = 'ãƒãƒƒã‚·ãƒ¥'; + $lang['strmerges'] = 'ä½µåˆ'; + $lang['strleftsort'] = '左ソート'; + $lang['strrightsort'] = 'å³ã‚½ãƒ¼ãƒˆ'; + $lang['strlessthan'] = '未満'; + $lang['strgreaterthan'] = '以上'; + $lang['stroperatorneedsname'] = '演算å­åを指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['stroperatorcreated'] = '演算å­ã‚’作æˆã—ã¾ã—ãŸã€‚'; + $lang['stroperatorcreatedbad'] = '演算å­ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropoperator'] = '本当ã«æ¼”ç®—å­ã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['stroperatordropped'] = '演算å­ã‚’破棄ã—ã¾ã—ãŸã€‚'; + $lang['stroperatordroppedbad'] = '演算å­ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + + // Casts + $lang['strcasts'] = 'キャスト'; + $lang['strnocasts'] = 'キャストãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strsourcetype'] = 'ソースタイプ'; + $lang['strtargettype'] = 'ターゲットタイプ'; + $lang['strimplicit'] = 'æš—é»™'; +$lang['strinassignment'] = 'In assignment'; + $lang['strbinarycompat'] = '(ãƒã‚¤ãƒŠãƒªãƒ¼äº’æ›)'; + + // Conversions + $lang['strconversions'] = '変æ›'; + $lang['strnoconversions'] = '変æ›ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strsourceencoding'] = '変æ›å…ƒã‚¨ãƒ³ã‚³ãƒ¼ãƒ‰'; + $lang['strtargetencoding'] = '変æ›å…ˆã‚¨ãƒ³ã‚³ãƒ¼ãƒ‰'; + + // Languages + $lang['strlanguages'] = '言語'; + $lang['strnolanguages'] = '言語ãŒå­˜åœ¨ã—ã¾ã›ã‚“。'; +$lang['strtrusted'] = 'Trusted'; + + // Info + $lang['strnoinfo'] = '有効ãªæƒ…å ±ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strreferringtables'] = 'å‚照テーブル'; + $lang['strparenttables'] = '親テーブル'; + $lang['strchildtables'] = 'å­ãƒ†ãƒ¼ãƒ–ル'; + + // Aggregates + $lang['straggregate'] = '集計'; + $lang['straggregates'] = '集計'; + $lang['strnoaggregates'] = '集計ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['stralltypes'] = '(ã™ã¹ã¦ã®ç¨®é¡ž)'; + $lang['strcreateaggregate'] = '集計を作æˆã™ã‚‹'; + $lang['straggrbasetype'] = '入力データã®ç¨®é¡ž'; + $lang['straggrsfunc'] = '状態é·ç§»é–¢æ•°'; + $lang['straggrstype'] = '状態データã®ç¨®é¡ž'; + $lang['straggrffunc'] = '終了関数'; + $lang['straggrinitcond'] = 'åˆæœŸçŠ¶æ…‹'; + $lang['straggrsortop'] = 'ソートæ“作'; + $lang['strconfdropaggregate'] = '本当ã«é›†è¨ˆã€Œ%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['straggregatedropped'] = '集計を破棄ã—ã¾ã—ãŸã€‚'; + $lang['straggregatedroppedbad'] = '集計ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straggraltered'] = '集計を変更ã—ã¾ã—ãŸã€‚'; + $lang['straggralteredbad'] = '集計ã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straggrneedsname'] = '集計ã¯åå‰ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['straggrneedsbasetype'] = '集計ã¯å…¥åŠ›ãƒ‡ãƒ¼ã‚¿ã®ç¨®é¡žã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['straggrneedssfunc'] = '集計ã¯çŠ¶æ…‹é·ç§»é–¢æ•°ã®åå‰ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['straggrneedsstype'] = '集計ã®çŠ¶æ…‹å€¤ã®ãƒ‡ãƒ¼ã‚¿ã®ç¨®é¡žã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['straggrcreated'] = '集計を作æˆã—ã¾ã—ãŸã€‚'; + $lang['straggrcreatedbad'] = '集計ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['straggrshowall'] = 'ã™ã¹ã¦ã®é›†è¨ˆã‚’表示ã™ã‚‹'; + + // Operator Classes + $lang['stropclasses'] = '演算å­ã‚¯ãƒ©ã‚¹'; + $lang['strnoopclasses'] = '演算å­ã‚¯ãƒ©ã‚¹ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['straccessmethod'] = 'アクセス方法'; + + // Stats and performance + $lang['strrowperf'] = '行パフォーマンス'; + $lang['strioperf'] = 'I/O パフォーマンス'; + $lang['stridxrowperf'] = 'インデックス行パフォーマンス'; + $lang['stridxioperf'] = 'インデックス I/O パフォーマンス'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'シーケンシャル'; + $lang['strscan'] = '検索'; + $lang['strread'] = '読込'; + $lang['strfetch'] = 'å–å¾—'; + $lang['strheap'] = 'ヒープ'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST インデックス'; + $lang['strcache'] = 'キャッシュ'; + $lang['strdisk'] = 'ディスク'; + $lang['strrows2'] = 'è¡Œ'; + + // Tablespaces + $lang['strtablespace'] = 'テーブル空間'; + $lang['strtablespaces'] = 'テーブル空間'; + $lang['strshowalltablespaces'] = 'ã™ã¹ã¦ã®ãƒ†ãƒ¼ãƒ–ルスペースを表示ã™ã‚‹'; + $lang['strnotablespaces'] = 'テーブル空間ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strcreatetablespace'] = 'テーブル空間を作æˆã™ã‚‹'; + $lang['strlocation'] = 'ロケーション'; + $lang['strtablespaceneedsname'] = 'テーブル空間åを指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strtablespaceneedsloc'] = 'テーブル空間作æˆã‚’ã™ã‚‹ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªã‚’指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strtablespacecreated'] = 'テーブル空間を作æˆã—ã¾ã—ãŸã€‚'; + $lang['strtablespacecreatedbad'] = 'テーブル空間ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdroptablespace'] = '本当ã«ãƒ†ãƒ¼ãƒ–ル空間「%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strtablespacedropped'] = 'テーブル空間を破棄ã—ã¾ã—ãŸã€‚'; + $lang['strtablespacedroppedbad'] = 'テーブル空間ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strtablespacealtered'] = 'テーブル空間を変更ã—ã¾ã—ãŸã€‚'; + $lang['strtablespacealteredbad'] = 'テーブル空間ã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + + // Miscellaneous + $lang['strtopbar'] = 'サーãƒãƒ¼ %2$s ã®ãƒãƒ¼ãƒˆç•ªå· %3$s ã§å®Ÿè¡Œä¸­ã® %1$s ã«æŽ¥ç¶šä¸­ -- ユーザー「%4$sã€ã¨ã—ã¦ãƒ­ã‚°ã‚¤ãƒ³ä¸­'; + $lang['strtimefmt'] = 'Y å¹´ n 月 j æ—¥ G:i'; + $lang['strhelp'] = 'ヘルプ'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'ヘルプページブラウザー'; + $lang['strselecthelppage'] = 'ヘルプページをé¸ã‚“ã§ãã ã•ã„'; + $lang['strinvalidhelppage'] = '無効ãªãƒ˜ãƒ«ãƒ—ページã§ã™ã€‚'; + $lang['strlogintitle'] = '%s ã«ãƒ­ã‚°ã‚¤ãƒ³'; + $lang['strlogoutmsg'] = '%s をログアウトã—ã¾ã—ãŸã€‚'; + $lang['strloading'] = '読ã¿è¾¼ã¿ä¸­...'; + $lang['strerrorloading'] = '読ã¿è¾¼ã¿ä¸­ã®ã‚¨ãƒ©ãƒ¼ã§ã™ã€‚'; + $lang['strclicktoreload'] = 'クリックã§å†èª­ã¿è¾¼ã¿'; + + // Autovacuum + $lang['strautovacuum'] = 'オートãƒã‚­ãƒ¥ãƒ¼ãƒ '; + $lang['strturnedon'] = 'オンã«ã™ã‚‹'; + $lang['strturnedoff'] = 'オフã«ã™ã‚‹'; +$lang['strenabled'] = 'Enabled'; + $lang['strvacuumbasethreshold'] = '閾値ã«åŸºã¥ã„ãŸãƒã‚­ãƒ¥ãƒ¼ãƒ '; +$lang['strvacuumscalefactor'] = 'Vacuum Scale Factor'; + $lang['stranalybasethreshold'] = '閾値ã«åŸºã¥ã„ãŸè§£æž'; +$lang['stranalyzescalefactor'] = 'Analyze Scale Factor'; +$lang['strvacuumcostdelay'] = 'Vacuum Cost Delay'; +$lang['strvacuumcostlimit'] = 'Vacuum Cost Limit'; + + // Table-level Locks + $lang['strlocks'] = 'ロック'; + $lang['strtransaction'] = 'トランザクション ID'; + $lang['strvirtualtransaction'] = '仮想トランザクション ID'; + $lang['strprocessid'] = 'プロセス ID'; + $lang['strmode'] = 'ロックモード'; +$lang['strislockheld'] = 'Is lock held?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'プリペアを用ã„ãŸãƒˆãƒ©ãƒ³ã‚¶ã‚¯ã‚·ãƒ§ãƒ³'; + $lang['strxactid'] = 'トランザクション ID'; + $lang['strgid'] = '全体 ID'; + + // Fulltext search + $lang['strfulltext'] = '全文テキスト検索'; + $lang['strftsconfig'] = 'FTS 設定'; + $lang['strftsconfigs'] = '設定'; + $lang['strftscreateconfig'] = 'FTS 設定ã®ä½œæˆ'; + $lang['strftscreatedict'] = '辞書を作æˆã™ã‚‹'; + $lang['strftscreatedicttemplate'] = '辞書ã®ãƒ†ãƒ³ãƒ—レートを作æˆã™ã‚‹'; + $lang['strftscreateparser'] = 'パーサーを作æˆã™ã‚‹'; + $lang['strftsnoconfigs'] = 'FTS 設定ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strftsconfigdropped'] = 'FTS 設定を破棄ã—ã¾ã—ãŸã€‚'; + $lang['strftsconfigdroppedbad'] = 'FTS 設定ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strconfdropftsconfig'] = '本当㫠FTS 設定「%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strconfdropftsdict'] = '本当㫠FTS 辞書「%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strconfdropftsmapping'] = '本当㫠FTS 設定「%sã€ã®ãƒžãƒƒãƒ—「%sã€ã‚’破棄ã—ã¾ã™ã‹?'; + $lang['strftstemplate'] = 'テンプレート'; + $lang['strftsparser'] = 'パーサー'; + $lang['strftsconfigneedsname'] = 'FTS 設定ã«ã¯åå‰ã‚’指定ã™ã‚‹å¿…è¦ãŒã‚ã‚Šã¾ã™ã€‚'; + $lang['strftsconfigcreated'] = 'FTS 設定を作æˆã—ã¾ã—ãŸã€‚'; + $lang['strftsconfigcreatedbad'] = 'FTS 設定ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; +$lang['strftsmapping'] = 'Mapping'; + $lang['strftsdicts'] = '辞書'; + $lang['strftsdict'] = '辞書'; + $lang['strftsemptymap'] = 'FTS 設定マップãŒç©ºã§ã™ã€‚'; +$lang['strftswithmap'] = 'With map'; +$lang['strftsmakedefault'] = 'Make default for given locale'; + $lang['strftsconfigaltered'] = 'FTS 設定を変更ã—ã¾ã—ãŸã€‚'; + $lang['strftsconfigalteredbad'] = 'FTS 設定ã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftsconfigmap'] = 'FTS 設定マップ'; + $lang['strftsparsers'] = 'FTS パーサー'; + $lang['strftsnoparsers'] = '利用ã§ãã‚‹ FTS パーサーãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strftsnodicts'] = '利用ã§ãã‚‹ FTS 辞書ãŒã‚ã‚Šã¾ã›ã‚“。'; + $lang['strftsdictcreated'] = 'FTS 辞書を作æˆã—ã¾ã—ãŸã€‚'; + $lang['strftsdictcreatedbad'] = 'FTS 辞書ã®ä½œæˆã«å¤±æ•—ã—ã¾ã—ãŸ'; +$lang['strftslexize'] = 'Lexize'; +$lang['strftsinit'] = 'Init'; + $lang['strftsoptionsvalues'] = 'オプションã¨å€¤'; + $lang['strftsdictneedsname'] = 'FTS 辞書ã®åå‰ã‚’指定ã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“。'; + $lang['strftsdictdropped'] = 'FTS 辞書を破棄ã—ã¾ã—ãŸã€‚'; + $lang['strftsdictdroppedbad'] = 'FTS 辞書ã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftsdictaltered'] = 'FTS 辞書を変更ã—ã¾ã—ãŸã€‚'; + $lang['strftsdictalteredbad'] = 'FTS 辞書ã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftsaddmapping'] = 'æ–°è¦ãƒžãƒƒãƒ—を追加ã™ã‚‹'; + $lang['strftsspecifymappingtodrop'] = 'マップを破棄をã™ã‚‹ã«ã¯å°‘ãªãã¨ã‚‚ 1 ã¤æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['strftsspecifyconfigtoalter'] = 'FTS 設定を変更ã™ã‚‹ã«ã¯æŒ‡å®šã—ãªã‘ã‚Œã°ãªã‚Šã¾ã›ã‚“'; + $lang['strftsmappingdropped'] = 'FTS マップを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strftsmappingdroppedbad'] = 'FTS マップã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftsnodictionaries'] = '辞書ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。'; + $lang['strftsmappingaltered'] = 'FTS マップを変更ã—ã¾ã—ãŸã€‚'; + $lang['strftsmappingalteredbad'] = 'FTS マップã®å¤‰æ›´ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftsmappingadded'] = 'FTS マップを追加ã—ã¾ã—ãŸã€‚'; + $lang['strftsmappingaddedbad'] = 'FTS マップã®è¿½åŠ ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftsmappingdropped'] = 'FTS マップを破棄ã—ã¾ã—ãŸã€‚'; + $lang['strftsmappingdroppedbad'] = 'FTS マップã®ç ´æ£„ã«å¤±æ•—ã—ã¾ã—ãŸã€‚'; + $lang['strftstabconfigs'] = '設定'; + $lang['strftstabdicts'] = '辞書'; + $lang['strftstabparsers'] = 'パーサー'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/langcheck b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/langcheck new file mode 100644 index 00000000..aa95d25d --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/langcheck @@ -0,0 +1,71 @@ +#!/usr/local/bin/php -q +\n\n"; + echo " is the filename without the .php extension\n"; + exit; + } + elseif (!file_exists("{$_SERVER['argv'][1]}.php")) { + echo "Error: File not found.\n"; + exit; + } + + // Include english source file + include('./english.php'); + + $master = $lang; + $master_keys = array_keys($lang); + unset($lang); + + // Include target language file + include("./{$_SERVER['argv'][1]}.php"); + $slave = $lang; + $slave_keys = array_keys($lang); + + echo "Source file: english.php\n"; + echo "Target file: {$_SERVER['argv'][1]}.php\n\n"; + + // Find missing values + $diff = array_diff($master_keys, $slave_keys); + echo "Missing Strings\n"; + echo "---------------\n\n"; + if (sizeof($diff) > 0) { + foreach ($diff as $v) { + echo "\$lang['{$v}'] = '", str_replace("'", "\\'", $master[$v]), "';\n"; + } + echo "\n"; + echo "Translations: ", sizeof($master_keys) - sizeof($diff), "/", sizeof($master_keys), "\n\n"; + + } + else echo "None\n\n"; + + // Find extra values (to be deleted) + $diff = array_diff($slave_keys, $master_keys); + echo "Deleted Strings\n"; + echo "---------------\n\n"; + if (sizeof($diff) > 0) { + foreach ($diff as $v) { + echo "\$lang['{$v}'] = '", str_replace("'", "\\'", $slave[$v]), "';\n"; + } + } + else echo "None\n"; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/lithuanian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/lithuanian.php new file mode 100644 index 00000000..4134644a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/lithuanian.php @@ -0,0 +1,898 @@ +'; + $lang['strfirst'] = '<< Pirmas'; + $lang['strlast'] = 'Paskutinis >>'; + $lang['strfailed'] = 'Nepavyko'; + $lang['strcreate'] = 'Sukurti'; + $lang['strcreated'] = 'Sukurta'; + $lang['strcomment'] = 'Komentaras'; + $lang['strlength'] = 'Ilgis'; + $lang['strdefault'] = 'Numatytoji reikÅ¡mÄ—';//Numatytas(-a) + $lang['stralter'] = 'Pakeisti'; + $lang['strok'] = 'Gerai'; + $lang['strcancel'] = 'Atsisakyti'; + $lang['strkill'] = 'Nutraukti';//Sunaikinti + $lang['strac'] = 'Ä®jungti automatinį baigimÄ…'; + $lang['strsave'] = 'Ä®raÅ¡yti'; + $lang['strreset'] = 'Atstatyti į pradinÄ™ bÅ«senÄ…';//Atkurti + $lang['strrestart'] = 'Paleisti iÅ¡ naujo'; + $lang['strinsert'] = 'Ä®terpti'; + $lang['strselect'] = 'Atrinkti'; + $lang['strdelete'] = 'Å alinti'; + $lang['strupdate'] = 'Atnaujinti'; + $lang['strreferences'] = 'RodyklÄ—s'; + $lang['stryes'] = 'Taip'; + $lang['strno'] = 'Ne'; + $lang['strtrue'] = 'TIESA'; + $lang['strfalse'] = 'NETIESA'; + $lang['stredit'] = 'Taisyti'; + $lang['strcolumn'] = 'Stulpelis'; + $lang['strcolumns'] = 'Stulpeliai'; + $lang['strrows'] = 'įraÅ¡as(-ai)'; + $lang['strrowsaff'] = 'įraÅ¡as(-ai) paveikti.'; + $lang['strobjects'] = 'objektas (-ai)'; + $lang['strback'] = 'Atgal'; + $lang['strqueryresults'] = 'Užklausos rezultatai'; + $lang['strshow'] = 'Rodyti'; + $lang['strempty'] = 'IÅ¡valyti';//Å alinti turinį + $lang['strlanguage'] = 'Kalba'; + $lang['strencoding'] = 'KoduotÄ—'; + $lang['strvalue'] = 'ReikÅ¡mÄ—'; + $lang['strunique'] = 'Unikalus'; + $lang['strprimary'] = 'Pirminis'; + $lang['strexport'] = 'Eksportuoti'; + $lang['strimport'] = 'Importuoti'; + $lang['strallowednulls'] = 'Leidžiami NULL simboliai'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'TuÅ¡Äia eilutÄ—/laukas'; + $lang['strsql'] = 'SQL'; +$lang['stradmin'] = 'Admin';//Administratorius + $lang['strvacuum'] = 'Apvalyti'; + $lang['stranalyze'] = 'Analizuoti'; + $lang['strclusterindex'] = 'Pertvarkyti'; + $lang['strclustered'] = 'Sutvarkyta?'; + $lang['strreindex'] = 'Perindeksuoti'; + $lang['strexecute'] = 'Vykdyti'; + $lang['stradd'] = 'PridÄ—ti'; + $lang['strevent'] = 'Ä®vykis'; + $lang['strwhere'] = 'SÄ…lyga';//Kur + $lang['strinstead'] = 'Atlikti užuot'; + $lang['strwhen'] = 'Kai'; + $lang['strformat'] = 'Formatas'; + $lang['strdata'] = 'Duomenys'; + $lang['strconfirm'] = 'Patvirtinti'; + $lang['strexpression'] = 'IÅ¡raiÅ¡ka'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'IÅ¡skleisti'; + $lang['strcollapse'] = 'Suskleisti'; + $lang['strfind'] = 'IeÅ¡koti'; + $lang['stroptions'] = 'Parinktys'; + $lang['strrefresh'] = 'Atnaujinti'; + $lang['strdownload'] = 'Parsisiųsti'; + $lang['strdownloadgzipped'] = 'Parsisiųsti suspaustÄ… su gzip'; + $lang['strinfo'] = 'Informacija'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'IÅ¡plÄ—stinis(-Ä—)';//papildomas(-a), + $lang['strvariables'] = 'Kintamieji'; + $lang['strprocess'] = 'Procesas'; + $lang['strprocesses'] = 'Procesai'; + $lang['strsetting'] = 'Nuostata';//Parinktis + $lang['streditsql'] = 'Redaguoti SQL'; + $lang['strruntime'] = 'Visa vykdymo trukmÄ—: %s ms'; + $lang['strpaginate'] = 'Rezultatus skaidyti į puslapius'; + $lang['struploadscript'] = 'arba nusiųsti SQL skriptÄ…:'; + $lang['strstarttime'] = 'Pradžios laikas'; + $lang['strfile'] = 'Failas'; + $lang['strfileimported'] = 'Failas importuotas.'; + $lang['strtrycred'] = 'Naudoti Å¡iuos įgaliojimus visiems serveriams'; + $lang['strconfdropcred'] = 'DÄ—l saugumo, ryÅ¡io nutraukimas panaikins jÅ«sų bendrÄ… prisijungimo informacijÄ…. Ar tikrai norite nutraukti ryšį ?'; + $lang['stractionsonmultiplelines'] = 'Veiksmai keliose eilutÄ—se'; + $lang['strselectall'] = 'Visi';//PažymÄ—ti visus + $lang['strunselectall'] = 'Nieko';//Panaikinti žymÄ—jimÄ… visiems + $lang['strlocale'] = 'LokalÄ—'; + $lang['strcollation'] = 'Rikiavimas'; +$lang['strctype'] = 'Character Type';//Simbolių(ženklų) tipas + $lang['strdefaultvalues'] = 'Numatytosios reikÅ¡mÄ—s'; + $lang['strnewvalues'] = 'Naujosios reikÅ¡mÄ—s'; + $lang['strstart'] = 'Paleisti'; + $lang['strstop'] = 'Stabdyti'; + $lang['strgotoppage'] = 'atgal į viršų'; + $lang['strtheme'] = 'Apipavidalinimas'; + $lang['strcluster'] = 'Klasteris'; + + // Admin + $lang['stradminondatabase'] = 'Å ios administracinÄ—s užduotys taikomos visai %s duomenų bazei.'; + $lang['stradminontable'] = 'Å ios administracinÄ—s užduotys taikomos lentelei %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'Praeitis'; + $lang['strnohistory'] = 'NÄ—ra praeities.'; + $lang['strclearhistory'] = 'IÅ¡valyti praeitį'; + $lang['strdelhistory'] = 'Å alinti iÅ¡ praeities sÄ…raÅ¡o'; + $lang['strconfdelhistory'] = 'Ar tikrai paÅ¡alinti Å¡iÄ… užklausÄ… iÅ¡ preities sÄ…raÅ¡o?'; + $lang['strconfclearhistory'] = 'Ar tikrai iÅ¡valyti praeitį?'; + $lang['strnodatabaseselected'] = 'PraÅ¡om pasirinkiti duomenų bazÄ™.'; + + // Database sizes + $lang['strnoaccess'] = 'NÄ—ra prieigos'; + $lang['strsize'] = 'Dydis'; + $lang['strbytes'] = 'baitai'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Å i programa geriausiai veikia su narÅ¡ykle, kurioje palaikomi HTML rÄ—meliai(frames),taÄiau gali bÅ«ti naudojama be rÄ—melių spustelÄ—jus toliau pateiktÄ… nuorodÄ….'; + $lang['strnoframeslink'] = 'Naudoti be rÄ—melių'; + $lang['strbadconfig'] = 'JÅ«sų config.inc.php pasenÄ™s. Reikia atkurti jį iÅ¡ naujo config.inc.php-dist.'; + $lang['strnotloaded'] = 'JÅ«sų PHP įdiegimas nepalaiko PostgreSQL. Reikia perkompiliuoti PHP naudojant --with-pgsql konfigÅ«ravimo parametrÄ….'; + $lang['strpostgresqlversionnotsupported'] = 'PostgreSQL versija nepalaikoma. PraÅ¡om atnaujinti iki %s arba naujesnÄ—s versijos.'; + $lang['strbadschema'] = 'Nurodyta neteisinga schema.'; + $lang['strbadencoding'] = 'Nepavyko nustatyti kliento koduotÄ—s duomenų bazÄ—je.'; + $lang['strsqlerror'] = 'SQL klaida:'; + $lang['strinstatement'] = 'Sakinyje:'; + $lang['strinvalidparam'] = 'Neteisingi skripto parametrai.'; + $lang['strnodata'] = 'Ä®rašų nerasta.'; + $lang['strnoobjects'] = 'Objektų nerasta.'; + $lang['strrownotunique'] = 'Å iame įraÅ¡e nÄ—ra unikalaus identifikatoriaus.'; + $lang['strnouploads'] = 'Failų iÅ¡siuntimai - negalimi.'; + $lang['strimporterror'] = 'Importavimo klaida.'; + $lang['strimporterror-fileformat'] = 'Importavimo klaida: Nepavyko automatiÅ¡kai nustatyti failo formato.'; + $lang['strimporterrorline'] = 'Importavimo klaida eilutÄ—je %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Importavimo klaida eilutÄ—je %s: EilutÄ—je neteisingas stulpelių skaiÄius.'; + $lang['strimporterror-uploadedfile'] = 'Importavimo klaida: Failas negali bÅ«ti nusiųstas į serverį'; + $lang['strcannotdumponwindows'] = 'Atminties iÅ¡klotinÄ—s suformavimas su sudÄ—tingais lentelių ir schemų vardais Windows operacinÄ—je sistemoje nepalaikomas'; + $lang['strinvalidserverparam'] = 'Bandymas prisijungti su negaliojanÄiu serverio parametru, galbÅ«t kas nors bando nulaužti jÅ«sų sistemÄ….'; + $lang['strnoserversupplied'] = 'Nenurodytas serveris!'; + $lang['strbadpgdumppath'] = 'Eksportavimo klaida: nepavyko įvykdyti pg_dump (pateiktas kelias JÅ«sų conf/config.inc.php : %s). Pataisykite šį keliÄ… savo konfigÅ«racijoje ir prisijunkite iÅ¡ naujo.'; + $lang['strbadpgdumpallpath'] = 'Eksportavimo klaida: nepavyko įvykdyti pg_dumpall (pateiktas kelias JÅ«sų conf/config.inc.php : %s). Pataisykite šį keliÄ… savo konfigÅ«racijoje ir prisijunkite iÅ¡ naujo.'; + $lang['strconnectionfail'] = 'Nepavyksta prisijungti prie serverio.'; + + // Tables + $lang['strtable'] = 'LentelÄ—'; + $lang['strtables'] = 'LentelÄ—s'; + $lang['strshowalltables'] = 'Rodyti visas lenteles'; + $lang['strnotables'] = 'Lentelių nerasta.'; + $lang['strnotable'] = 'LentelÄ— nerasta.'; + $lang['strcreatetable'] = 'Sukurti lentelÄ™'; + $lang['strcreatetablelike'] = 'Sukurti lentelÄ™ kaip'; + $lang['strcreatetablelikeparent'] = 'PirminÄ— lentelÄ—'; + $lang['strcreatelikewithdefaults'] = 'Ä®TRAUKTI NUMATYTÄ„SIAS REIKÅ MES'; + $lang['strcreatelikewithconstraints'] = 'Ä®TRAUKTI RIBOJIMUS'; + $lang['strcreatelikewithindexes'] = 'Ä®TRAUKTI INDEKSUS'; + $lang['strtablename'] = 'LentelÄ—s pavadinimas'; + $lang['strtableneedsname'] = 'Turite suteikti lentelei pavadinimÄ….'; + $lang['strtablelikeneedslike'] = 'Turite nurodyti lentelÄ™, kurios savybes reikia kopijuoti.'; + $lang['strtableneedsfield'] = 'Turite nurodyti bent vienÄ… laukÄ….'; + $lang['strtableneedscols'] = 'Turite nurodyti teisingÄ… stulpelių skaiÄių.'; + $lang['strtablecreated'] = 'LentelÄ— sukurta.'; + $lang['strtablecreatedbad'] = 'Nepavyko sukurti lentelÄ—s.'; + $lang['strconfdroptable'] = 'Ar tikrai norite Å¡alinti lentelÄ™ "%s"?'; + $lang['strtabledropped'] = 'LentelÄ— paÅ¡alinta.'; + $lang['strtabledroppedbad'] = 'Nepavyko paÅ¡alinti lentelÄ—s.'; + $lang['strconfemptytable'] = 'Ar tikrai norite iÅ¡valyti lentelÄ™ "%s"?'; + $lang['strtableemptied'] = 'LentelÄ— iÅ¡valyta.'; + $lang['strtableemptiedbad'] = 'Nepavyko iÅ¡valyti lentelÄ—s.'; + $lang['strinsertrow'] = 'Ä®terpti įraÅ¡Ä…'; + $lang['strrowinserted'] = 'Ä®raÅ¡as įterptas.'; + $lang['strrowinsertedbad'] = 'Nepavyko įterpti įraÅ¡o.'; + $lang['strnofkref'] = 'NÄ—ra atitinkamos reikÅ¡mÄ—s iÅ¡oriniame rakte %s.'; + $lang['strrowduplicate'] = 'Nepavyko įterpti įraÅ¡o, bandyta dubliuoti įraÅ¡Ä….'; + $lang['streditrow'] = 'Taisyti įraÅ¡Ä…'; + $lang['strrowupdated'] = 'Ä®raÅ¡as atnaujintas.'; + $lang['strrowupdatedbad'] = 'Nepavyko atnaujinti įraÅ¡o.'; + $lang['strdeleterow'] = 'Å alinti įraÅ¡Ä…'; + $lang['strconfdeleterow'] = 'Ar tikrai norite Å¡alinti šį įraÅ¡Ä…?'; + $lang['strrowdeleted'] = 'Ä®raÅ¡as paÅ¡alintas.'; + $lang['strrowdeletedbad'] = 'Nepavyko paÅ¡alinti įraÅ¡o.'; + $lang['strinsertandrepeat'] = 'Ä®terpti ir kartoti'; + $lang['strnumcols'] = 'Stulpelių skaiÄius'; + $lang['strcolneedsname'] = 'Turite nurodyti stulpelio pavadinimÄ…'; + $lang['strselectallfields'] = 'PažymÄ—ti visus laukus'; + $lang['strselectneedscol'] = 'Turite rodyti bent vienÄ… stulpelį.'; + $lang['strselectunary'] = 'VienvieÄiai operatoriai negali turÄ—ti reikÅ¡mių.'; + $lang['strcolumnaltered'] = 'Stulpelis pakeistas.'; + $lang['strcolumnalteredbad'] = 'Nepavyko pakeisti stulpelio.'; + $lang['strconfdropcolumn'] = 'Ar tikrai norite Å¡alinti stulpelį "%s" iÅ¡ lentelÄ—s "%s"?'; + $lang['strcolumndropped'] = 'Stulpelis paÅ¡alintas.'; + $lang['strcolumndroppedbad'] = 'Nepavyko paÅ¡alinti stulpelio.'; + $lang['straddcolumn'] = 'PridÄ—ti stulpelį'; + $lang['strcolumnadded'] = 'Stulpelis pridÄ—tas.'; + $lang['strcolumnaddedbad'] = 'Nepavyko pridÄ—ti stulpelio.'; +$lang['strcascade'] = 'CASCADE';//Pakopinis + $lang['strtablealtered'] = 'LentelÄ— pakeista.'; + $lang['strtablealteredbad'] = 'Nepavyko pakeisti lentelÄ—s.'; + $lang['strdataonly'] = 'Tik duomenis'; + $lang['strstructureonly'] = 'Tik struktÅ«rÄ…'; + $lang['strstructureanddata'] = 'StruktÅ«rÄ… ir duomenis'; +$lang['strtabbed'] = 'Tabbed';//Atskirtas tabuliavimo žymÄ—mis +$lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Ar tikrai norite apvalyti "%s"?'; + $lang['strconfanalyzetable'] = 'Ar tikrai norite analizuoti "%s"?'; + $lang['strconfreindextable'] = 'Ar tikrai norite perindeksuoti "%s"?'; + $lang['strconfclustertable'] = 'Ar tikrai norite sutvarkyti "%s"?'; + $lang['strestimatedrowcount'] = 'ApskaiÄiuotasis įrašų skaiÄius';//Apytikris + $lang['strspecifytabletoanalyze'] = 'Turite nurodyti bent vienÄ… lentelÄ™, kuri turi bÅ«ti iÅ¡analizuota.'; + $lang['strspecifytabletoempty'] = 'Turite nurodyti bent vienÄ… lentelÄ™, kuri turi bÅ«ti iÅ¡valyta.'; + $lang['strspecifytabletodrop'] = 'Turite nurodyti bent vienÄ… lentelÄ™, kuri turi bÅ«ti paÅ¡alinta.'; + $lang['strspecifytabletovacuum'] = 'Turite nurodyti bent vienÄ… lentelÄ™, kuri turi bÅ«ti apvalyta.'; + $lang['strspecifytabletoreindex'] = 'Turite nurodyti bent vienÄ… lentelÄ™, kuri turi bÅ«ti perindeksuota.'; + $lang['strspecifytabletocluster'] = 'Turite nurodyti bent vienÄ… lentelÄ™, kuri turi bÅ«ti sutvarkyta.'; + $lang['strnofieldsforinsert'] = 'Negalite įterpti įraÅ¡o į lentelÄ™ be stulpelių.'; + + // Columns + $lang['strcolprop'] = 'Stulpelio savybÄ—s'; + $lang['strnotableprovided'] = 'Nenurodyta lentelÄ—!'; + + // Users + $lang['struser'] = 'Naudotojas'; + $lang['strusers'] = 'Naudotojai'; + $lang['strusername'] = 'Naudotojo vardas'; + $lang['strpassword'] = 'Slaptažodis'; +$lang['strsuper'] = 'Superuser?'; + $lang['strcreatedb'] = 'Gali kurti DB?'; + $lang['strexpires'] = 'Baigia galioti'; + $lang['strsessiondefaults'] = 'Seanso numatytosios reikÅ¡mÄ—s'; + $lang['strnousers'] = 'Naudotojų nerasta.'; + $lang['struserupdated'] = 'Naudotojas atnaujintas.'; + $lang['struserupdatedbad'] = 'Nepavyko atnaujinti naudotojo.'; + $lang['strshowallusers'] = 'Rodyti visus naudotojus'; + $lang['strcreateuser'] = 'Kurti naudotojÄ…'; + $lang['struserneedsname'] = 'Turite suteikti naudotojui vardÄ….'; + $lang['strusercreated'] = 'Naudotojas sukurtas.'; + $lang['strusercreatedbad'] = 'Nepavyko sukurti naudotojo.'; + $lang['strconfdropuser'] = 'Ar tikrai norite paÅ¡alinti naudotojÄ… "%s"?'; + $lang['struserdropped'] = 'Naudotojas paÅ¡alintas.'; + $lang['struserdroppedbad'] = 'Nepavyko paÅ¡alinti naudotojo.'; + $lang['straccount'] = 'Paskyra'; + $lang['strchangepassword'] = 'Keisti slaptažodį'; + $lang['strpasswordchanged'] = 'Slaptažodis pakeistas.'; + $lang['strpasswordchangedbad'] = 'Nepavyko pakeisti slaptažodžio.'; + $lang['strpasswordshort'] = 'Slaptažodis per trumpas.'; + $lang['strpasswordconfirm'] = 'Slaptažodis neatitinka patvirtinimo.'; + + // Groups + $lang['strgroup'] = 'GrupÄ—'; + $lang['strgroups'] = 'GrupÄ—s'; + $lang['strshowallgroups'] = 'Rodyti visas grupes'; + $lang['strnogroup'] = 'GrupÄ— nerasta.'; + $lang['strnogroups'] = 'Grupių nerasta.'; + $lang['strcreategroup'] = 'Kurti grupÄ™'; + $lang['strgroupneedsname'] = 'Turite suteikti grupei pavadinimÄ….'; + $lang['strgroupcreated'] = 'GrupÄ— sukurta.'; + $lang['strgroupcreatedbad'] = 'Nepavyko sukurti grupÄ—s.'; + $lang['strconfdropgroup'] = 'Ar tikrai norite Å¡alinti grupÄ™ "%s"?'; + $lang['strgroupdropped'] = 'GrupÄ— paÅ¡alinta.'; + $lang['strgroupdroppedbad'] = 'Nepavyko paÅ¡alinti grupÄ—s.'; + $lang['strmembers'] = 'Nariai'; + $lang['strmemberof'] = 'Yra narys'; + $lang['stradminmembers'] = 'Admin nariai'; + $lang['straddmember'] = 'PridÄ—ti narį'; + $lang['strmemberadded'] = 'Narys pridÄ—tas.'; + $lang['strmemberaddedbad'] = 'Nepavyko pridÄ—ti nario.'; + $lang['strdropmember'] = 'Å alinti narį'; + $lang['strconfdropmember'] = 'Ar tikrai norite Å¡alinti narį "%s" iÅ¡ grupÄ—s "%s"?'; + $lang['strmemberdropped'] = 'Narys paÅ¡alintas.'; + $lang['strmemberdroppedbad'] = 'Nepavyko paÅ¡alinti nario.'; + + // Roles + $lang['strrole'] = 'RolÄ—'; + $lang['strroles'] = 'RolÄ—s'; + $lang['strshowallroles'] = 'Rodyti roles'; + $lang['strnoroles'] = 'Rolių nerasta.'; + $lang['strinheritsprivs'] = 'Paveldi privilegijas?'; + $lang['strcreaterole'] = 'Kurti rolÄ™'; + $lang['strcancreaterole'] = 'Gali kurti rolÄ™?'; + $lang['strrolecreated'] = 'RolÄ— sukurta.'; + $lang['strrolecreatedbad'] = 'Nepavyko sukurti rolÄ—s.'; + $lang['strrolealtered'] = 'RolÄ— pakeista.'; + $lang['strrolealteredbad'] = 'Nepavyko pakeisti rolÄ—s.'; + $lang['strcanlogin'] = 'Gali prisijungti?'; + $lang['strconnlimit'] = 'Sujungimų limitas'; + $lang['strdroprole'] = 'Å alinti rolÄ™'; + $lang['strconfdroprole'] = 'Ar tikrai norite Å¡alinti rolÄ™ "%s"?'; + $lang['strroledropped'] = 'RolÄ— paÅ¡alinta.'; + $lang['strroledroppedbad'] = 'Nepavyko paÅ¡alinti rolÄ—s.'; + $lang['strnolimit'] = 'Be ribojimų'; + $lang['strnever'] = 'Niekada'; + $lang['strroleneedsname'] = 'Turite suteikti rolei pavadinimÄ….'; + + // Privileges + $lang['strprivilege'] = 'Privilegija'; + $lang['strprivileges'] = 'Privilegijos'; + $lang['strnoprivileges'] = 'Å iam objektui taikomos numatytosios valdytojo privilegijos.'; + $lang['strgrant'] = 'Suteikti'; + $lang['strrevoke'] = 'Panaikinti';//AtÅ¡aukti + $lang['strgranted'] = 'Privilegijos pakeistos.'; + $lang['strgrantfailed'] = 'Nepavyko pakeisti privilegijų.'; + $lang['strgrantbad'] = 'Turite nurodyti bent vienÄ… naudotojÄ… arba grupÄ™ ir bent vienÄ… privilegijÄ….'; + $lang['strgrantor'] = 'TeikÄ—jas'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Duomenų bazÄ—'; + $lang['strdatabases'] = 'Duomenų bazÄ—s'; + $lang['strshowalldatabases'] = 'Rodyti duomenų bazes'; + $lang['strnodatabases'] = 'Duomenų bazių nerasta.'; + $lang['strcreatedatabase'] = 'Kurti duomenų bazÄ™'; + $lang['strdatabasename'] = 'Duomenų bazÄ—s pavadinimas'; + $lang['strdatabaseneedsname'] = 'Turite suteikti duomenų bazei pavadinimÄ….'; + $lang['strdatabasecreated'] = 'Duomenų bazÄ— sukurta.'; + $lang['strdatabasecreatedbad'] = 'Nepavyko sukurti duomenų bazÄ—s.'; + $lang['strconfdropdatabase'] = 'Ar tikrai norite Å¡alinti duomenų bazÄ™ "%s"?'; + $lang['strdatabasedropped'] = 'Duomenų bazÄ— paÅ¡alinta.'; + $lang['strdatabasedroppedbad'] = 'Nepavyko paÅ¡alinti duomenų bazÄ—s.'; + $lang['strentersql'] = 'Ä®veskite SQL užklausÄ… žemiau:'; + $lang['strsqlexecuted'] = 'SQL užklausa įvykdyta.'; + $lang['strvacuumgood'] = 'Apvalymas atliktas.'; + $lang['strvacuumbad'] = 'Nepavyko atlikti apvalymo.'; + $lang['stranalyzegood'] = 'AnalizÄ— atlikta.'; + $lang['stranalyzebad'] = 'Nepavyko atlikti analizÄ—s.'; + $lang['strreindexgood'] = 'Perindeksavimas atliktas.'; + $lang['strreindexbad'] = 'Perindeksavimas nepavyko.'; + $lang['strfull'] = 'VisiÅ¡kas'; +$lang['strfreeze'] = 'Freeze'; +$lang['strforce'] = 'Force'; + $lang['strsignalsent'] = 'Signalas iÅ¡siųstas.'; + $lang['strsignalsentbad'] = 'Nepavyko iÅ¡siųsti signalo.'; + $lang['strallobjects'] = 'Visi objektai'; + $lang['strdatabasealtered'] = 'Duomenų bazÄ— pakeista.'; + $lang['strdatabasealteredbad'] = 'Nepavyko pakeisti duomenų bazÄ—s.'; + $lang['strspecifydatabasetodrop'] = 'Turite nurodyti bent vienÄ… duomenų bazÄ™, kuriÄ… reikia Å¡alinti.'; + $lang['strtemplatedb'] = 'Å ablonas'; + $lang['strconfanalyzedatabase'] = 'Ar tikrai norite analizuoti visas lenteles duomenų bazÄ—je "%s"?'; + $lang['strconfvacuumdatabase'] = 'Ar tikrai norite apvalyti visas lenteles duomenų bazÄ—je "%s"?'; + $lang['strconfreindexdatabase'] = 'Ar tikrai norite perindeksuoti visas lenteles duomenų bazÄ—je "%s"?'; + $lang['strconfclusterdatabase'] = 'Ar tikrai norite sutvarkyti visas lenteles duomenų bazÄ—je "%s"?'; + + // Views + $lang['strview'] = 'Rodinys'; + $lang['strviews'] = 'Rodiniai'; + $lang['strshowallviews'] = 'Rodyti visus rodinius'; + $lang['strnoview'] = 'Rodinys nerastas.'; + $lang['strnoviews'] = 'Rodinių nerasta.'; + $lang['strcreateview'] = 'Kurti rodinį'; + $lang['strviewname'] = 'Rodinio pavadinimas'; + $lang['strviewneedsname'] = 'Turite suteikti rodiniui pavadinimÄ….'; + $lang['strviewneedsdef'] = 'Turite pateikti rodinio apibrėžtį.'; + $lang['strviewneedsfields'] = 'Turite nurodyti stulpelius, kurie turi bÅ«ti rodinyje.'; + $lang['strviewcreated'] = 'Rodinys sukurtas.'; + $lang['strviewcreatedbad'] = 'Nepavyko sukurti rodinio.'; + $lang['strconfdropview'] = 'Ar tikrai norite paÅ¡alinti rodinį "%s"?'; + $lang['strviewdropped'] = 'Rodinys paÅ¡alintas.'; + $lang['strviewdroppedbad'] = 'Nepavyko paÅ¡alinti rodinio.'; + $lang['strviewupdated'] = 'Rodinys atnaujintas.'; + $lang['strviewupdatedbad'] = 'Nepavyko atnaujinti rodinio.'; + $lang['strviewlink'] = 'Saistantys raktai'; + $lang['strviewconditions'] = 'Papildomos sÄ…lygos'; + $lang['strcreateviewwiz'] = 'Kurti rodinį su vedikliu'; + $lang['strrenamedupfields'] = 'Pervadinti dubliuojanÄiuosius laukus'; + $lang['strdropdupfields'] = 'PaÅ¡alinti dubliuojanÄiuosius laukus'; + $lang['strerrordupfields'] = 'Klaida dubliuojanÄiuose laukuose'; + $lang['strviewaltered'] = 'Rodinys pakeistas.'; + $lang['strviewalteredbad'] = 'Nepavyko pakeisti rodinio.'; + $lang['strspecifyviewtodrop'] = 'Turite nurodyti bent vienÄ… rodinį, kurį norite paÅ¡alinti.'; + + // Sequences + $lang['strsequence'] = 'Seka'; + $lang['strsequences'] = 'Sekos'; + $lang['strshowallsequences'] = 'Rodyti visas sekas'; + $lang['strnosequence'] = 'Seka nerasta.'; + $lang['strnosequences'] = 'Sekų nerasta.'; + $lang['strcreatesequence'] = 'Kurti sekÄ…'; + $lang['strlastvalue'] = 'PaskutinÄ— reikÅ¡mÄ—'; + $lang['strincrementby'] = 'Prieaugis'; + $lang['strstartvalue'] = 'PradinÄ— reikÅ¡mÄ—'; + $lang['strrestartvalue'] = 'Paleidimo iÅ¡ naujo reikÅ¡mÄ—'; + $lang['strmaxvalue'] = 'Maks. reikÅ¡mÄ—'; + $lang['strminvalue'] = 'Min. reikÅ¡mÄ—'; + $lang['strcachevalue'] = 'ReikÅ¡mÄ— podÄ—lyje'; +$lang['strlogcount'] = 'Log count'; +$lang['strcancycle'] = 'Can cycle?';//Gali kartotis? + $lang['striscalled'] = 'Padidins paskutinÄ™ reikÅ¡mÄ™ prieÅ¡ grąžinant kitÄ… reikÅ¡mÄ™ (is_called)?'; + $lang['strsequenceneedsname'] = 'Turite suteikti sekai vardÄ….'; + $lang['strsequencecreated'] = 'Seka sukurta.'; + $lang['strsequencecreatedbad'] = 'Nepavyko sukurti sekos.'; + $lang['strconfdropsequence'] = 'Ar tikrai norite paÅ¡alinti sekÄ… "%s"?'; + $lang['strsequencedropped'] = 'Seka paÅ¡alinta.'; + $lang['strsequencedroppedbad'] = 'Nepavyko paÅ¡alinti sekos.'; + $lang['strsequencerestart'] = 'Seka paleista iÅ¡ naujo.'; + $lang['strsequencerestartbad'] = 'Nepavyko sekos paleist iÅ¡ naujo.'; + $lang['strsequencereset'] = 'Seka atstatyta į pradinÄ™ bÅ«senÄ….'; + $lang['strsequenceresetbad'] = 'Nepavyko sekos atstatyti į pradinÄ™ bÅ«senÄ….'; + $lang['strsequencealtered'] = 'Seka pakeista.'; + $lang['strsequencealteredbad'] = 'Nepavyko pakeisti sekos.'; + $lang['strsetval'] = 'Nustatyti reikÅ¡mÄ™'; + $lang['strsequencesetval'] = 'Sekos reikÅ¡mÄ— nustatyta.'; + $lang['strsequencesetvalbad'] = 'Nepavyko nustatyti sekos reikÅ¡mÄ—s.'; + $lang['strnextval'] = 'Padidinti reikÅ¡mÄ™'; + $lang['strsequencenextval'] = 'Sekos reikÅ¡mÄ— padidÄ—jo.'; + $lang['strsequencenextvalbad'] = 'Sekos reikÅ¡mÄ—s padidinti nepavyko.'; + $lang['strspecifysequencetodrop'] = 'Turite nurodyti bent vienÄ… sekÄ…, kuriÄ… norite paÅ¡alinti.'; + + // Indexes + $lang['strindex'] = 'Indeksas'; + $lang['strindexes'] = 'Indeksai'; + $lang['strindexname'] = 'Indekso pavadinimas'; + $lang['strshowallindexes'] = 'Rodyti visus indeksus'; + $lang['strnoindex'] = 'Indeksas nerastas.'; + $lang['strnoindexes'] = 'Indeksų nerasta.'; + $lang['strcreateindex'] = 'Kurti indeksÄ…'; + $lang['strtabname'] = 'LentelÄ—s pavadinimas'; + $lang['strcolumnname'] = 'Stulpelio pavadinimas'; + $lang['strindexneedsname'] = 'Turite suteikti indeksui pavadinimÄ….'; + $lang['strindexneedscols'] = 'Turite nurodyti teisingÄ… stulpelių skaiÄių.'; + $lang['strindexcreated'] = 'Indeksas sukurtas.'; + $lang['strindexcreatedbad'] = 'Nepavyko sukurti indekso.'; + $lang['strconfdropindex'] = 'Ar tikrai norite paÅ¡alinti indeksÄ… "%s"?'; + $lang['strindexdropped'] = 'Indeksas paÅ¡alintas.'; + $lang['strindexdroppedbad'] = 'Nepavyko paÅ¡alinti indekso.'; + $lang['strkeyname'] = 'Rakto pavadinimas'; + $lang['struniquekey'] = 'Unikalus raktas'; + $lang['strprimarykey'] = 'Pirminis raktas'; + $lang['strindextype'] = 'Indekso tipas'; + $lang['strtablecolumnlist'] = 'Stulpeliai lentelÄ—je'; + $lang['strindexcolumnlist'] = 'Stulpeliai indekse'; + $lang['strconfcluster'] = 'Ar tikrai norite pertvarkyti "%s"?'; + $lang['strclusteredgood'] = 'Pertvarka atlikta.'; + $lang['strclusteredbad'] = 'Nepavyko atlikti pertvarkos.'; + $lang['strconcurrently'] = 'LygiagreÄiai';//tuo pat metu + $lang['strnoclusteravailable'] = 'LentelÄ— nesutvarkyta pagal indeksÄ….'; + + // Rules + $lang['strrules'] = 'TaisyklÄ—s'; + $lang['strrule'] = 'TaisyklÄ—'; + $lang['strshowallrules'] = 'Rodyti visas taisykles'; + $lang['strnorule'] = 'TaisyklÄ— nerasta.'; + $lang['strnorules'] = 'Taisyklių nerasta.'; + $lang['strcreaterule'] = 'Kurti taisyklÄ™'; + $lang['strrulename'] = 'TaisyklÄ—s pavadinimas'; + $lang['strruleneedsname'] = 'Turite suteikti taisyklei pavadinimÄ….'; + $lang['strrulecreated'] = 'TaisyklÄ— sukurta.'; + $lang['strrulecreatedbad'] = 'Nepavyko sukurti taisyklÄ—s.'; + $lang['strconfdroprule'] = 'Ar tikrai norite Å¡alinti taisyklÄ™ "%s" taikomÄ… "%s"?'; + $lang['strruledropped'] = 'TaisyklÄ— paÅ¡alinta.'; + $lang['strruledroppedbad'] = 'Nepavyko paÅ¡alinti taisyklÄ—s.'; + + // Constraints + $lang['strconstraint'] = 'Ribojimas'; + $lang['strconstraints'] = 'Ribojimai'; + $lang['strshowallconstraints'] = 'Rodyti visus ribojimus'; + $lang['strnoconstraints'] = 'Ribojimų nerasta.'; + $lang['strcreateconstraint'] = 'Kurti ribojimÄ…'; + $lang['strconstraintcreated'] = 'Ribojimas sukurtas.'; + $lang['strconstraintcreatedbad'] = 'Nepavyko sukurti ribojimo.'; + $lang['strconfdropconstraint'] = 'Ar tikrai norite Å¡alinti ribojimÄ… "%s" lentelei "%s"?'; + $lang['strconstraintdropped'] = 'Ribojimas paÅ¡alintas.'; + $lang['strconstraintdroppedbad'] = 'Nepavyko paÅ¡alinti ribojimo.'; + $lang['straddcheck'] = 'PridÄ—ti tikrinimÄ…'; + $lang['strcheckneedsdefinition'] = 'Tikrinimo ribojimui bÅ«tina apibrėžtis.'; + $lang['strcheckadded'] = 'Tikrinimo ribojimas pridÄ—tas.'; + $lang['strcheckaddedbad'] = 'Nepavyko pridÄ—ti tikrinimo ribojimo.'; + $lang['straddpk'] = 'PridÄ—ti pirminį raktÄ…'; + $lang['strpkneedscols'] = 'Pirminiam raktui bÅ«tina priskirti bent vienÄ… stulpelį.'; + $lang['strpkadded'] = 'Pirminis raktas pridÄ—tas.'; + $lang['strpkaddedbad'] = 'Nepavyko pridÄ—ti pirminio rakto.'; + $lang['stradduniq'] = 'PridÄ—ti unikalų raktÄ…'; + $lang['struniqneedscols'] = 'Unikaliam raktui bÅ«tina priskirti bent vienÄ… stulpelį.'; + $lang['struniqadded'] = 'Unikalus raktas pridÄ—tas.'; + $lang['struniqaddedbad'] = 'Nepavyko pridÄ—ti unikalaus rakto.'; + $lang['straddfk'] = 'PridÄ—ti iÅ¡orinį raktÄ…'; + $lang['strfkneedscols'] = 'IÅ¡oriniam raktui bÅ«tina priskirti bent vienÄ… stulpelį.'; + $lang['strfkneedstarget'] = 'BÅ«tina nurodyti iÅ¡orinio rakto paskirties lentelÄ™.'; + $lang['strfkadded'] = 'IÅ¡orinis raktas pridÄ—tas.'; + $lang['strfkaddedbad'] = 'Nepavyko pridÄ—ti iÅ¡orinio rakto.'; + $lang['strfktarget'] = 'Paskirties lentelÄ—'; + $lang['strfkcolumnlist'] = 'Rakto stulpeliai'; + $lang['strondelete'] = 'Å¡alinant'; + $lang['stronupdate'] = 'atnaujinant'; + + // Functions + $lang['strfunction'] = 'Funkcija'; + $lang['strfunctions'] = 'Funkcijos'; + $lang['strshowallfunctions'] = 'Rodyti visas funkcijas'; + $lang['strnofunction'] = 'Funkcija nerasta.'; + $lang['strnofunctions'] = 'Funkcijų nerasta.'; + $lang['strcreateplfunction'] = 'Kurti SQL/PL funkcijÄ…'; + $lang['strcreateinternalfunction'] = 'Kurti vidinÄ™ funkcijÄ…'; + $lang['strcreatecfunction'] = 'Kurti C funkcijÄ…'; + $lang['strfunctionname'] = 'Funkcijos pavadinimas'; + $lang['strreturns'] = 'Grąžina'; + $lang['strproglanguage'] = 'Programavimo kalba'; + $lang['strfunctionneedsname'] = 'Turite suteikti funkcijai pavadinimÄ….'; + $lang['strfunctionneedsdef'] = 'Turite pateikti funkcijos apibrėžtį.'; + $lang['strfunctioncreated'] = 'Funkcija sukurta.'; + $lang['strfunctioncreatedbad'] = 'Nepavyko sukurti funkcijos.'; + $lang['strconfdropfunction'] = 'Ar tikrai norite Å¡alinti funkcijÄ… "%s"?'; + $lang['strfunctiondropped'] = 'Funkcija paÅ¡alinta.'; + $lang['strfunctiondroppedbad'] = 'Nepavyko paÅ¡alinti funkcijos.'; + $lang['strfunctionupdated'] = 'Funkcija atnaujinta.'; + $lang['strfunctionupdatedbad'] = 'Nepavyko atnaujinti funkcijos.'; + $lang['strobjectfile'] = 'Objektinis Failas'; + $lang['strlinksymbol'] = 'SÄ…sajos simbolis (C funkcijos pavadinimas)'; + $lang['strarguments'] = 'Argumentai'; + $lang['strargmode'] = 'Veiksena'; + $lang['strargtype'] = 'Tipas'; + $lang['strargadd'] = 'PridÄ—ti dar vienÄ… argumentÄ…'; + $lang['strargremove'] = 'PaÅ¡alinti šį argumentÄ…'; + $lang['strargnoargs'] = 'Å i funkcija nepriims jokių argumentų.'; + $lang['strargenableargs'] = 'Leisti perduoti argumentus Å¡iai funkcijai.'; + $lang['strargnorowabove'] = 'Turi bÅ«ti eilutÄ— virÅ¡ Å¡ios eilutÄ—s.'; + $lang['strargnorowbelow'] = 'Turi bÅ«ti eilutÄ— žemiau Å¡ios eilutÄ—s.'; + $lang['strargraise'] = 'Pakelti.'; + $lang['strarglower'] = 'Nuleisti.'; + $lang['strargremoveconfirm'] = 'Ar tikrai norite paÅ¡alinti šį argumentÄ…? PaÅ¡alinimas negalÄ—s bÅ«ti atÅ¡auktas.'; +$lang['strfunctioncosting'] = 'Function Costing'; + $lang['strresultrows'] = 'EiluÄių rezultate'; + $lang['strexecutioncost'] = 'Vykdymo sÄ…naudos'; + $lang['strspecifyfunctiontodrop'] = 'Turite nurodyti bent vienÄ… funkcijÄ…, kuriÄ… norite paÅ¡alinti.'; + + // Triggers + $lang['strtrigger'] = 'Trigeris'; + $lang['strtriggers'] = 'Trigeriai'; + $lang['strshowalltriggers'] = 'Rodyti visus trigerius'; + $lang['strnotrigger'] = 'Trigeris nerastas.'; + $lang['strnotriggers'] = 'Trigerių nerasta.'; + $lang['strcreatetrigger'] = 'Kurti trigerį'; + $lang['strtriggerneedsname'] = 'Turite nurodyti trigerio pavadinimÄ….'; + $lang['strtriggerneedsfunc'] = 'Turite priskirti funkcijÄ… trigeriui.'; + $lang['strtriggercreated'] = 'Trigeris sukurtas.'; + $lang['strtriggercreatedbad'] = 'Nepavyko sukurti trigerio.'; + $lang['strconfdroptrigger'] = 'Ar tikrai norite Å¡alinti trigerį "%s" lentelÄ—je "%s"?'; + $lang['strconfenabletrigger'] = 'Ar tikrai norite įjungti trigerį "%s" lentelÄ—je "%s"?'; + $lang['strconfdisabletrigger'] = 'Ar tikrai norite iÅ¡jungti trigerį "%s" lentelÄ—je "%s"?'; + $lang['strtriggerdropped'] = 'Trigeris paÅ¡alintas.'; + $lang['strtriggerdroppedbad'] = 'Nepavyko paÅ¡alinti trigerio.'; + $lang['strtriggerenabled'] = 'Trigeris įjungtas.'; + $lang['strtriggerenabledbad'] = 'Nepavyko įjungti trigerio.'; + $lang['strtriggerdisabled'] = 'Trigeris iÅ¡jungtas.'; + $lang['strtriggerdisabledbad'] = 'Nepavyko iÅ¡jungti trigerio.'; + $lang['strtriggeraltered'] = 'Trigeris pakeistas.'; + $lang['strtriggeralteredbad'] = 'Nepavyko pakeisti trigerio.'; + $lang['strforeach'] = 'Kiekvienam(-ai)'; + + // Types + $lang['strtype'] = 'Duomenų tipas'; + $lang['strtypes'] = 'Duomenų tipai'; + $lang['strshowalltypes'] = 'Rodyti visus duomenų tipus'; + $lang['strnotype'] = 'Duomenų tipas nerastas.'; + $lang['strnotypes'] = 'Duomenų tipų nerasta.'; + $lang['strcreatetype'] = 'Kurti duomenų tipÄ…'; + $lang['strcreatecomptype'] = 'Kurti struktÅ«rinį duomenų tipÄ…'; + $lang['strcreateenumtype'] = 'Kurti enum duomenų tipÄ…'; + $lang['strtypeneedsfield'] = 'Turite nurodyti bent vienÄ… laukÄ….'; + $lang['strtypeneedsvalue'] = 'Turite nurodyti bent vienÄ… reikÅ¡mÄ™.'; + $lang['strtypeneedscols'] = 'Turite nurodyti teisingÄ… laukų skaiÄių.'; + $lang['strtypeneedsvals'] = 'Turite nurodyti teisingÄ… reikÅ¡mių skaiÄių.'; + $lang['strinputfn'] = 'Ä®vesties funkcija'; + $lang['stroutputfn'] = 'IÅ¡vesties funkcija'; + $lang['strpassbyval'] = 'Perdavimas reikÅ¡me?'; + $lang['stralignment'] = 'Lygiavimas'; + $lang['strelement'] = 'Elementas'; + $lang['strdelimiter'] = 'Skirtukas'; + $lang['strstorage'] = 'AtmintinÄ—'; + $lang['strfield'] = 'Laukas'; + $lang['strnumfields'] = 'Laukų sk.'; + $lang['strnumvalues'] = 'ReikÅ¡mių sk.'; + $lang['strtypeneedsname'] = 'Turite suteikti duomenų tipui pavadinimÄ….'; + $lang['strtypeneedslen'] = 'Turite nurodyti duomenų tipo ilgį.'; + $lang['strtypecreated'] = 'Duomenų tipas sukurtas.'; + $lang['strtypecreatedbad'] = 'Nepavyko sukurti duomenų tipo.'; + $lang['strconfdroptype'] = 'Ar tikrai norite Å¡alinti duomenų tipÄ… "%s"?'; + $lang['strtypedropped'] = 'Duomenų tipas paÅ¡alintas.'; + $lang['strtypedroppedbad'] = 'Nepavyko paÅ¡alinti duomenų tipo.'; + $lang['strflavor'] = 'Atmaina'; + $lang['strbasetype'] = 'Bazinis'; + $lang['strcompositetype'] = 'StruktÅ«rinis'; + $lang['strpseudotype'] = 'Pseudo'; +$lang['strenum'] = 'Enum'; + $lang['strenumvalues'] = 'Enum reikÅ¡mÄ—s'; + + // Schemas + $lang['strschema'] = 'Schema'; + $lang['strschemas'] = 'Schemos'; + $lang['strshowallschemas'] = 'Rodyti visas schemas'; + $lang['strnoschema'] = 'Schema nerasta.'; + $lang['strnoschemas'] = 'Schemų nerasta.'; + $lang['strcreateschema'] = 'Kurti schemÄ…'; + $lang['strschemaname'] = 'Schemos pavadinimas'; + $lang['strschemaneedsname'] = 'Turite suteikti schemai pavadinimÄ….'; + $lang['strschemacreated'] = 'Schema sukurta.'; + $lang['strschemacreatedbad'] = 'Nepavyko sukurti schemos.'; + $lang['strconfdropschema'] = 'Ar tikrai norite Å¡alinti schemÄ… "%s"?'; + $lang['strschemadropped'] = 'Schema paÅ¡alinta.'; + $lang['strschemadroppedbad'] = 'Nepavyko paÅ¡alinti schemos.'; + $lang['strschemaaltered'] = 'Schema pakeista.'; + $lang['strschemaalteredbad'] = 'Nepavyko pakeisti schemos.'; + $lang['strsearchpath'] = 'Schemų paieÅ¡kos kelias'; + $lang['strspecifyschematodrop'] = 'Turite nurodyti bent vienÄ… schemÄ…, kuriÄ… norite paÅ¡alinti.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domenas'; + $lang['strdomains'] = 'Domenai'; + $lang['strshowalldomains'] = 'Rodyti visus domenus'; + $lang['strnodomains'] = 'Domenų nerasta.'; + $lang['strcreatedomain'] = 'Kurti domenÄ…'; + $lang['strdomaindropped'] = 'Domenas paÅ¡alintas.'; + $lang['strdomaindroppedbad'] = 'Nepavyko paÅ¡alinti domeno.'; + $lang['strconfdropdomain'] = 'Ar tikrai norite Å¡alinti domenÄ… "%s"?'; + $lang['strdomainneedsname'] = 'Turite suteikti domenui vardÄ….'; + $lang['strdomaincreated'] = 'Domenas sukurtas.'; + $lang['strdomaincreatedbad'] = 'Nepavyko sukurti domeno.'; + $lang['strdomainaltered'] = 'Domenas pakeistas.'; + $lang['strdomainalteredbad'] = 'Nepavyko pakeisti domeno.'; + + // Operators + $lang['stroperator'] = 'Operatorius'; + $lang['stroperators'] = 'Operatoriai'; + $lang['strshowalloperators'] = 'Rodyti visus operatorius'; + $lang['strnooperator'] = 'Operatorius nerastas.'; + $lang['strnooperators'] = 'Operatorių nerasta.'; + $lang['strcreateoperator'] = 'Kurti operatorių'; + $lang['strleftarg'] = 'Kairiojo argumento tipas'; + $lang['strrightarg'] = 'DeÅ¡iniojo argumento tipas'; +$lang['strcommutator'] = 'Commutator';//komutatyvumas, perstatomumas, +$lang['strnegator'] = 'Negator';//inversija,neigimas, neigimo operacija +$lang['strrestrict'] = 'Restrict';//ribojimas +$lang['strjoin'] = 'Join'; +$lang['strhashes'] = 'Hashes'; +$lang['strmerges'] = 'Merges'; +$lang['strleftsort'] = 'Left sort'; +$lang['strrightsort'] = 'Right sort'; + $lang['strlessthan'] = 'Mažiau nei'; + $lang['strgreaterthan'] = 'Daugiau nei'; + $lang['stroperatorneedsname'] = 'Turite suteikti operatoriui pavadinimÄ….'; + $lang['stroperatorcreated'] = 'Operatorius sukurtas.'; + $lang['stroperatorcreatedbad'] = 'Nepavyko sukurti operatoriaus.'; + $lang['strconfdropoperator'] = 'Ar tikrai norite Å¡alinti operatorių "%s"?'; + $lang['stroperatordropped'] = 'Operatorius paÅ¡alintas.'; + $lang['stroperatordroppedbad'] = 'Nepavyko paÅ¡alinti operatoriaus.'; + + // Casts +$lang['strcasts'] = 'Casts';//duomenų tipo keitimas +$lang['strnocasts'] = 'No casts found.'; +$lang['strsourcetype'] = 'Source type'; +$lang['strtargettype'] = 'Target type'; +$lang['strimplicit'] = 'Implicit';//numanomas(-a) +$lang['strinassignment'] = 'In assignment'; +$lang['strbinarycompat'] = '(Binary compatible)';//suderintas(-a) su dvejetainÄ— sistema + + // Conversions + $lang['strconversions'] = 'Konvertavimai'; + $lang['strnoconversions'] = 'Konvertavimai nerasti.'; +$lang['strsourceencoding'] = 'Source encoding';//pradinÄ— koduotÄ— +$lang['strtargetencoding'] = 'Target encoding';//galutinÄ— koduotÄ— + + // Languages + $lang['strlanguages'] = 'Programavimo kalbos'; + $lang['strnolanguages'] = 'Kalbų nerasta.'; + $lang['strtrusted'] = 'Patikima'; + + // Info + $lang['strnoinfo'] = 'NÄ—ra informacijos.'; + $lang['strreferringtables'] = 'Priklausomos lentelÄ—s'; + $lang['strparenttables'] = 'VirÅ¡lentelÄ—s'; + $lang['strchildtables'] = 'PolentelÄ—s'; + + // Aggregates + $lang['straggregate'] = 'Agregavimo funkcija'; + $lang['straggregates'] = 'Agregavimo funkcijos'; + $lang['strnoaggregates'] = 'Agregavimo funkcijų nerasta.'; + $lang['stralltypes'] = '(Visi tipai)'; + $lang['strcreateaggregate'] = 'Kurti agregavimo funkcijÄ…'; + $lang['straggrbasetype'] = 'Pradinių duomenų tipas'; + $lang['straggrsfunc'] = 'BÅ«senos keitimo funkcija'; + $lang['straggrstype'] = 'BÅ«senos reikÅ¡mÄ—s duomenų tipas'; + $lang['straggrffunc'] = 'GalutinÄ— funkcija'; + $lang['straggrinitcond'] = 'PradinÄ— sÄ…lyga'; + $lang['straggrsortop'] = 'Rikiavimo operatorius'; + $lang['strconfdropaggregate'] = 'Ar tikrai norite Å¡alinti agregavimo funkcijÄ… "%s"?'; + $lang['straggregatedropped'] = 'Agregavimo funkcija paÅ¡alinta.'; + $lang['straggregatedroppedbad'] = 'Nepavyko paÅ¡alinti agregavimo funkcijos.'; + $lang['straggraltered'] = 'Agregavimo funkcija pakeista.'; + $lang['straggralteredbad'] = 'Nepavyko pakeisti agregavimo funkcijos.'; + $lang['straggrneedsname'] = 'Turite suteikti agregavimo funkcijai pavadinimÄ….'; + $lang['straggrneedsbasetype'] = 'Turite nurodyti agregavimo funkcijos pradinių duomenų tipÄ….'; + $lang['straggrneedssfunc'] = 'Turite nurodyti agregavimo funkcijos bÅ«senos keitimo funkcijos pavadinimÄ….'; + $lang['straggrneedsstype'] = 'Turite nurodyti agregavimo funkcijos bÅ«senos reikÅ¡mÄ—s duomenų tipÄ….'; + $lang['straggrcreated'] = 'Agregavimo funkcija sukurta.'; + $lang['straggrcreatedbad'] = 'Nepavyko sukurti agregavimo funkcijos.'; + $lang['straggrshowall'] = 'Rodyti visas agregavimo funkcijas'; + + // Operator Classes + $lang['stropclasses'] = 'Operatorių klasÄ—s'; + $lang['strnoopclasses'] = 'Operatorių klasių nerasta.'; + $lang['straccessmethod'] = 'Prieigos metodas'; + + // Stats and performance + $lang['strrowperf'] = 'Ä®rašų NaÅ¡umas'; + $lang['strioperf'] = 'I/O NaÅ¡umas'; + $lang['stridxrowperf'] = 'Indeksų Ä®rašų NaÅ¡umas'; + $lang['stridxioperf'] = 'Indeksų I/O NaÅ¡umas'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Nuoseklus'; + $lang['strscan'] = 'PeržiÅ«rÄ—ti'; + $lang['strread'] = 'Skaityti'; + $lang['strfetch'] = 'Paimti'; + $lang['strheap'] = 'KrÅ«va'; +$lang['strtoast'] = 'TOAST'; +$lang['strtoastindex'] = 'TOAST Indeksas'; + $lang['strcache'] = 'PodÄ—lis'; + $lang['strdisk'] = 'Diskas'; + $lang['strrows2'] = 'Ä®raÅ¡ai'; + + // Tablespaces + $lang['strtablespace'] = 'Lentelių erdvÄ—'; + $lang['strtablespaces'] = 'Lentelių erdvÄ—s'; + $lang['strshowalltablespaces'] = 'Rodyti visas lentelių erdves'; + $lang['strnotablespaces'] = 'Lentelių erdvių nerasta.'; + $lang['strcreatetablespace'] = 'Kurti lentelių erdvÄ™'; + $lang['strlocation'] = 'Vieta'; + $lang['strtablespaceneedsname'] = 'Turite suteikti lentelių erdvei pavadinimÄ….'; + $lang['strtablespaceneedsloc'] = 'Turite nurodyti katalogÄ…, kuriame turi bÅ«ti sukurta lentelių erdvÄ—.'; + $lang['strtablespacecreated'] = 'Lentelių erdvÄ— sukurta.'; + $lang['strtablespacecreatedbad'] = 'Nepavyko sukurti lentelių erdvÄ—s.'; + $lang['strconfdroptablespace'] = 'Ar tikrai norite Å¡alinti lentelių erdvÄ™ "%s"?'; + $lang['strtablespacedropped'] = 'Lentelių erdvÄ— paÅ¡alinta.'; + $lang['strtablespacedroppedbad'] = 'Nepavyko paÅ¡alinti lentelių erdvÄ—s.'; + $lang['strtablespacealtered'] = 'Lentelių erdvÄ— pakeista.'; + $lang['strtablespacealteredbad'] = 'Nepavyko pakeisti lentelių erdvÄ—s.'; + + // Miscellaneous + $lang['strtopbar'] = '%s veikia %s:%s -- JÅ«s esate prisijungÄ™s kaip "%s"'; + $lang['strtimefmt'] = 'j M Y - g:iA'; + $lang['strhelp'] = 'Pagalba'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Pagalbos puslapio narÅ¡yklÄ—'; + $lang['strselecthelppage'] = 'Pasirinkite pagalbos puslapį'; + $lang['strinvalidhelppage'] = 'Netinkamas pagalbos puslapis.'; + $lang['strlogintitle'] = 'Prisijungti prie %s'; + $lang['strlogoutmsg'] = 'Atsijungta nuo %s'; + $lang['strloading'] = 'Ä®keliama...'; + $lang['strerrorloading'] = 'Klaida įkeliant'; + $lang['strclicktoreload'] = 'SpustelÄ—kite, kad bÅ«tų atsiųsta iÅ¡ naujo'; + + // Autovacuum + $lang['strautovacuum'] = 'Automatinis apvalymas'; + $lang['strturnedon'] = 'Ä®jungta'; + $lang['strturnedoff'] = 'IÅ¡jungta'; + $lang['strenabled'] = 'Veiksnus'; + $lang['strnovacuumconf'] = 'Automatinio apvalymo konfigÅ«racijų nerasta.'; + $lang['strvacuumbasethreshold'] = 'Apvalymo bazinÄ— riba'; + $lang['strvacuumscalefactor'] = 'Apvalymo skalÄ—s koeficientas'; + $lang['stranalybasethreshold'] = 'AnalizÄ—s bazinÄ— riba'; + $lang['stranalyzescalefactor'] = 'AnalizÄ—s skalÄ—s koeficientas'; +$lang['strvacuumcostdelay'] = 'Apvalymo Cost Delay'; +$lang['strvacuumcostlimit'] = 'Apvalymo Cost Limit'; + $lang['strvacuumpertable'] = 'Lentelių automatinio apvalymo konfigÅ«racijos'; + $lang['straddvacuumtable'] = 'PridÄ—ti lentelÄ—s automatinio apvalymo konfigÅ«racijÄ…'; + $lang['streditvacuumtable'] = 'Taisyti lentelÄ—s %s automatinio apvalymo konfigÅ«racijÄ…'; + $lang['strdelvacuumtable'] = 'Å alinti lentelÄ—s %s automatinio apvalymo konfigÅ«racijÄ… ?'; + $lang['strvacuumtablereset'] = 'LentelÄ—s %s automatinio apvalymo konfigÅ«racijos reikÅ¡mÄ—s atstatytos į numatytÄ…sias'; + $lang['strdelvacuumtablefail'] = 'Nepavyko panaikinti lentelÄ—s %s automatinio apvalymo konfigÅ«racijos'; + $lang['strsetvacuumtablesaved'] = 'LentelÄ—s %s automatinio apvalymo konfigÅ«racija įraÅ¡yta.'; + $lang['strsetvacuumtablefail'] = 'Nepavyko konfigÅ«ruoti lentelÄ—s %s automatinio apvalymo.'; + $lang['strspecifydelvacuumtable'] = 'Turite nurodyti lentelÄ™, kurios automatinio apvalymo konfigÅ«racijÄ… norite panaikinti.'; + $lang['strspecifyeditvacuumtable'] = 'Turite nurodyti lentelÄ™, kurios automatinio apvalymo konfigÅ«racijÄ… norite taisyti.'; + $lang['strnotdefaultinred'] = 'ReikÅ¡mÄ—s, kitokios nei numatytosios, pažymÄ—tos raudonai.'; + + // Table-level Locks + $lang['strlocks'] = 'BlokuotÄ—s'; + $lang['strtransaction'] = 'Operacijos Identifikatorius'; + $lang['strvirtualtransaction'] = 'Virtualios Operacijos Identifikatorius'; + $lang['strprocessid'] = 'Proceso Identifikatorius'; + $lang['strmode'] = 'BlokuotÄ—s veiksena'; + $lang['strislockheld'] = 'Ar blokuotÄ— veikia?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'ParuoÅ¡tos operacijos'; + $lang['strxactid'] = 'Operacijos identifikatorius'; + $lang['strgid'] = 'Globalus identifikatorius'; + + // Fulltext search +$lang['strfulltext'] = 'Full Text Search'; + $lang['strftsconfig'] = 'FTS konfigÅ«racija'; + $lang['strftsconfigs'] = 'KonfigÅ«racijos'; + $lang['strftscreateconfig'] = 'Kurti FTS konfigÅ«racijÄ…'; + $lang['strftscreatedict'] = 'Kurti žodynÄ…'; + $lang['strftscreatedicttemplate'] = 'Kurti žodyno Å¡ablonÄ…'; + $lang['strftscreateparser'] = 'Kurti analizatorių'; + $lang['strftsnoconfigs'] = 'FTS konfigÅ«racijų nerasta.'; + $lang['strftsconfigdropped'] = 'FTS konfigÅ«racija paÅ¡alinta.'; + $lang['strftsconfigdroppedbad'] = 'Nepavyko paÅ¡alinti FTS konfigÅ«racijos.'; + $lang['strconfdropftsconfig'] = 'Ar tikrai norite Å¡alinti FTS konfigÅ«racijÄ… "%s"?'; + $lang['strconfdropftsdict'] = 'Ar tikrai norite Å¡alinti FTS žodynÄ… "%s"?'; + $lang['strconfdropftsmapping'] = 'Ar tikrai norite Å¡alinti atvaizdį "%s" FTS konfigÅ«racijai "%s"?'; + $lang['strftstemplate'] = 'Å ablonas'; + $lang['strftsparser'] = 'Analizatorius'; + $lang['strftsconfigneedsname'] = 'Turite suteikti FTS konfigÅ«racijai pavadinimÄ….'; + $lang['strftsconfigcreated'] = 'FTS konfigÅ«racija sukurta.'; + $lang['strftsconfigcreatedbad'] = 'Nepavyko sukurti FTS konfigÅ«racijos.'; + $lang['strftsmapping'] = 'Atvaizdis'; + $lang['strftsdicts'] = 'Žodynai'; + $lang['strftsdict'] = 'Žodynas'; + $lang['strftsemptymap'] = 'IÅ¡valyti FTS konfigÅ«racijos atvaizdį.'; + $lang['strftsconfigaltered'] = 'FTS konfigÅ«racija pakeista.'; + $lang['strftsconfigalteredbad'] = 'Nepavyko pakeisti FTS konfigÅ«racijos.'; + $lang['strftsconfigmap'] = 'FTS konfigÅ«racijos atvaizdis'; + $lang['strftsparsers'] = 'FTS analizatoriai'; + $lang['strftsnoparsers'] = 'FTS analizatorių nÄ—ra.'; + $lang['strftsnodicts'] = 'FTS žodynų nÄ—ra.'; + $lang['strftsdictcreated'] = 'FTS žodynas sukurtas.'; + $lang['strftsdictcreatedbad'] = 'Nepavyko sukurti FTS žodyno.'; +$lang['strftslexize'] = 'Lexize'; +$lang['strftsinit'] = 'Init'; + $lang['strftsoptionsvalues'] = 'Parinktys ir reikÅ¡mÄ—s'; + $lang['strftsdictneedsname'] = 'Turite suteikti FTS žodynui pavadinimÄ….'; + $lang['strftsdictdropped'] = 'FTS žodynas paÅ¡alintas.'; + $lang['strftsdictdroppedbad'] = 'Nepavyko paÅ¡alinti FTS žodyno.'; + $lang['strftsdictaltered'] = 'FTS žodynas pakeistas.'; + $lang['strftsdictalteredbad'] = 'Nepavyko pakeisti FTS žodyno.'; + $lang['strftsaddmapping'] = 'PridÄ—ti naujÄ… atvaizdį'; + $lang['strftsspecifymappingtodrop'] = 'Turite nurodyti bent vienÄ… atvaizdį, kurį norite paÅ¡alinti.'; + $lang['strftsspecifyconfigtoalter'] = 'Turite nurodyti bent vienÄ… FTS konfigÅ«racijÄ…, kuriÄ… norite pakeisti.'; + $lang['strftsmappingdropped'] = 'FTS atvaizdis paÅ¡alintas.'; + $lang['strftsmappingdroppedbad'] = 'Nepavyko paÅ¡alinti FTS atvaizdžio.'; + $lang['strftsnodictionaries'] = 'Žodynų nerasta.'; + $lang['strftsmappingaltered'] = 'FTS atvaizdis pakeistas.'; + $lang['strftsmappingalteredbad'] = 'Nepavyko pakeisti FTS atvaizdžio.'; + $lang['strftsmappingadded'] = 'FTS atvaizdis pridÄ—tas.'; + $lang['strftsmappingaddedbad'] = 'Nepavyko pridÄ—ti FTS atvaizdžio.'; + $lang['strftstabconfigs'] = 'KonfigÅ«racijos'; + $lang['strftstabdicts'] = 'Žodynai'; + $lang['strftstabparsers'] = 'Analizatoriai'; + $lang['strftscantparsercopy'] = 'Negalima nurodyti kartu ir analizatoriaus, ir Å¡ablono, teksto paieÅ¡kos konfikÅ«racijos kÅ«rimo metu.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/mongol.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/mongol.php new file mode 100644 index 00000000..e2e9d6c7 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/mongol.php @@ -0,0 +1,527 @@ +'; + $lang['strfirst'] = '<< ќШмЮФ'; + $lang['strlast'] = 'Ñ“??ЬФ >>'; + $lang['strfailed'] = 'ÑЬФСС'; + $lang['strcreate'] = '??гЧмШ'; + $lang['strcreated'] = '??гЧмгмЮ'; + $lang['strcomment'] = 'єСЪЬТСв'; + $lang['strlength'] = 'ѕвд'; + $lang['strdefault'] = 'єЯФЯвШЯЪ Тег'; + $lang['stralter'] = '??воЩЬ?Ш'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'ш?оЩЮЧ?Ъ ТЯЬЧЯШ'; + $lang['strsave'] = 'шСФЧСЬСШ'; + $lang['strreset'] = 'ÑвЩЬЧСШ'; + $lang['strinsert'] = 'ÑвееЬЧС ШЩЪШ'; + $lang['strselect'] = 'ѓЯЮЧЯШ'; + $lang['strdelete'] = 'ѕгдЧСШ'; + $lang['strupdate'] = 'ѓСЪжЩвееЬСШ'; + $lang['strreferences'] = 'шСЭССвСЬ'; + $lang['stryes'] = 'єЩЪЭ'; + $lang['strno'] = '?Ч?Ъ'; + $lang['strtrue'] = '?ЮмЮ'; + $lang['strfalse'] = 'шеФСЬ'; + $lang['stredit'] = 'њСгСШ'; + $lang['strcolumns'] = 'тСЧСЮС'; + $lang['strrows'] = 'Ñ?в'; + $lang['strobjects'] = 'ÑТиХЫд'; + $lang['strexample'] = 'ЧмШ Эмд'; + $lang['strback'] = 'теУСШ'; + $lang['strqueryresults'] = 'ÑгееЬЧйЮ ?в Ф?Ю'; + $lang['strshow'] = '?кмШ'; + $lang['strempty'] = 'шЯЯгЬЯШ'; + $lang['strlanguage'] = 'шмЬ'; + $lang['strencoding'] = 'ыЯФоЩЬЯШ'; + $lang['strvalue'] = 'ѕдЧС'; + $lang['strunique'] = 'ÑЮУЧЯЪ'; + $lang['strprimary'] = '?ЮФгмЮ'; + $lang['strexport'] = 'ќЫгаЯвд'; + $lang['strimport'] = 'щЭаЯвд'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = '?вЧмЬжЬ??Ь'; + $lang['stradmin'] = 'њЯШЩЯЮ ТСЪЧееЬСШ'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Ñ„?Ю лЩЮжЩЬЧмм'; + $lang['strclusterindex'] = 'ыЬСгдХв'; + $lang['strclustered'] = 'ыЬСгдХв'; + $lang['strreindex'] = 'фСШЩЮ ЩЮФХЫгЬмШ'; + $lang['strrun'] = 'ÑжЩЬЬееЬСШ'; + $lang['stradd'] = 'юмЭмШ'; + $lang['strevent'] = 'Ñ”?Ь?з'; + $lang['strwhere'] = 'шССЮС'; + $lang['strinstead'] = 'ÑвЯЮФ Юи '; + $lang['strwhen'] = 'шмкмм'; + $lang['strformat'] = 'цЯвЭСд'; + $lang['strdata'] = '?Ч?ЧФ?Ь'; + $lang['strconfirm'] = 'тСдСЬЧССжееЬСШ'; + $lang['strexpression'] = '?ЪЬФмЬ'; + $lang['strellipsis'] = '...'; + $lang['strexpand'] = '?вЧ?дЧ?Ш'; + $lang['strcollapse'] = 'ѕЮСЬд'; + $lang['strexplain'] = 'єСЪЬТСв'; + $lang['strfind'] = 'ÑЬЯШ'; + $lang['stroptions'] = 'ѓЯЮЧЯЬд'; + $lang['strrefresh'] = 'ѓмвЧммШ'; + $lang['strdownload'] = 'єСдСж СзСШ'; + $lang['strinfo'] = 'ÑмФммЬмЬ'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'юмЭмЬд'; + + // Error handling + $lang['strbadconfig'] = 'єСЮй config.inc.php ШееоЩвгСЮ ТСЪЮС. config.inc.php-dist ?ССг ФСШЩЮ ??гЧм.'; + $lang['strnotloaded'] = 'єСЮй PHP гееЬЧСЬд Юи PostgreSQL ?Ч?ЧФЬЩЪЮ гСЮдСЪ ШСЭдвСЮ СжЭЬЬСШ ТЯЬЯжЧ?Ъ ТСЪЮС. єС PHP ?ЧСС ФСШЩЮ --with-pgsql дЯШЩвЧЯЯдЯЪ гееЬЧС.'; + $lang['strbadschema'] = 'єЯШЩвЧЯЯ Тевее'; + $lang['strbadencoding'] = 'Failed to set client encoding in database.'; + $lang['strsqlerror'] = 'SQL СЬФСС:'; + $lang['strinstatement'] = 'Ñ— ЯаХвСдЯвХ:'; + $lang['strinvalidparam'] = 'юХзХвЮйЪ аСвСЭХдв гЫвЩадС.'; + $lang['strnodata'] = 'фСЮЮйШ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strnoobjects'] = 'ÑТпХЫдЯз ЮХ ЯТЮСвежХЮЯ.'; + $lang['strrownotunique'] = 'юХд еЮЩЫСЬиЮЯЧЯ ЩФХЮдЩЦЩЫСдЯвС ФЬб мдЯЪ кСаЩгЩ.'; + + // Tables + $lang['strtable'] = 'єСТЬЩУС'; + $lang['strtables'] = 'єСТЬЩУй'; + $lang['strshowalltables'] = '№ЯЫСкСди згХ дСТЬЩУй'; + $lang['strnotables'] = 'єСТЬЩУ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strnotable'] = ' єСТЬЩУС ЮХ ЯТЮСвежХЮС.'; + $lang['strcreatetable'] = 'ѓЯкФСди дСТЬЩУе'; + $lang['strtablename'] = 'щЭб дСТЬЩУй'; + $lang['strtableneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ ЯавХФХЬЩди ЩЭб дСТЬЩУй.'; + $lang['strtableneedsfield'] = 'їСЭ ЮХЯТШЯФЩЭЯ ЯавХФХЬЩди аЯ ЫвСЪЮХЪ ЭХвХ ЯФЮЯ аЯЬХ.'; + $lang['strtableneedscols'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ФЯаегдЩЭЯХ оЩгЬЯ СдвЩТедЯз.'; + $lang['strtablecreated'] = 'єСТЬЩУС гЯкФСЮС.'; + $lang['strtablecreatedbad'] = 'ѓЯкФСЮЩХ дСТЬЩУй авХвзСЮЯ.'; + $lang['strconfdroptable'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди дСТЬЩУе "%s"?'; + $lang['strtabledropped'] = 'єСТЬЩУС еФСЬХЮС.'; + $lang['strtabledroppedbad'] = 'ѕФСЬХЮЩХ дСТЬЩУй авХвзСЮЯ.'; + $lang['strconfemptytable'] = 'їй езХвХЮй, одЯ ШЯдЩдХ ЯоЩгдЩди дСТЬЩУе "%s"?'; + $lang['strtableemptied'] = 'єСТЬЩУС ЯоЩнХЮС.'; + $lang['strtableemptiedbad'] = 'ÑоЩгдЫС дСТЬЩУй авХвзСЮС.'; + $lang['strinsertrow'] = 'фЯТСзЩди кСаЩги'; + $lang['strrowinserted'] = 'њСаЩги ФЯТСзЬХЮС.'; + $lang['strrowinsertedbad'] = 'фЯТСзЬХЮЩХ кСаЩгЩ авХвзСЮЯ.'; + $lang['streditrow'] = 'ђХФСЫдЩвЯзСди кСаЩги'; + $lang['strrowupdated'] = 'њСаЩги ЯТЮЯзЬХЮС.'; + $lang['strrowupdatedbad'] = 'ÑТЮЯзЬХЮЩХ кСаЩгЩ авХвзСЮЯ.'; + $lang['strdeleterow'] = 'ѕФСЬЩди кСаЩги'; + $lang['strconfdeleterow'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди кСаЩги?'; + $lang['strrowdeleted'] = 'њСаЩги еФСЬХЮС.'; + $lang['strrowdeletedbad'] = 'ѕФСЬХЮЩХ кСаЩгЩ авХвзСЮЯ.'; + $lang['strsaveandrepeat'] = 'їгдСзЩди Щ аЯздЯвЩди'; + $lang['strfield'] = '№ЯЬХ'; + $lang['strfields'] = '№ЯЬб'; + $lang['strnumfields'] = 'ыЯЬ-зЯ аЯЬХЪ'; + $lang['strfieldneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ ЮСкзСди аЯЬХ'; + $lang['strselectallfields'] = 'їйТвСди згХ аЯЬб'; + $lang['strselectneedscol'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди аЯ ЫвСЪЮХЪ ЭХвХ ЯФЩЮ СдвЩТед'; + $lang['strselectunary'] = 'ѕЮСвЮйЪ ЯаХвСдЯв ЮХ ЭЯжХд ЩЭХди зХЬЩоЩЮе.'; + $lang['straltercolumn'] = 'щкЭХЮЩди СдвЩТед'; + $lang['strcolumnaltered'] = 'ÑдвЩТед ЩкЭХЮХЮ.'; + $lang['strcolumnalteredbad'] = 'щкЭХЮХЮЩХ СдвЩТедС авХвзСЮЯ.'; + $lang['strconfdropcolumn'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди СдвЩТед "%s" дСТЬЩУй "%s"?'; + $lang['strcolumndropped'] = 'ÑдвЩТед еФСЬХЮ.'; + $lang['strcolumndroppedbad'] = 'ѕФСЬХЮЩХ СдвЩТедС авХвзСЮЯ.'; + $lang['straddcolumn'] = 'фЯТСзЩди СдвЩТед'; + $lang['strcolumnadded'] = 'ÑдвЩТед ФЯТСзЬХЮ.'; + $lang['strcolumnaddedbad'] = 'фЯТСзЬХЮЩХ СдвЩТедС авХвзСЮЯ.'; + $lang['strdataonly'] = 'єЯЬиЫЯ ФСЮЮйХ'; + $lang['strcascade'] = 'ыСгЫСФЯЭ'; + $lang['strtablealtered'] = 'єСТЬЩУС ЩкЭХЮХЮС.'; + $lang['strtablealteredbad'] = 'щкЭХЮХЮЩХ дСТЬЩУй авХвзСЮЯ.'; + $lang['strdataonly'] = 'єЯЬиЫЯ ФСЮЮйХ'; + $lang['strstructureonly'] = 'єЯЬиЫЯ гдвеЫдеве'; + $lang['strstructureanddata'] = 'ѓдвеЫдеве Щ ФСЮЮйХ'; + + // Users + $lang['struser'] = '№ЯЬикЯзСдХЬи'; + $lang['strusers'] = '№ЯЬикЯзСдХЬЩ'; + $lang['strusername'] = 'щЭб аЯЬикЯзСдХЬб'; + $lang['strpassword'] = '№СвЯЬи'; + $lang['strsuper'] = 'ѓеаХваЯЬикЯзСдХЬи?'; + $lang['strcreatedb'] = 'ѓЯкФСди ТСке ФСЮЮйШ?'; + $lang['strexpires'] = 'ѓвЯЫ ФХЪгдзЩб'; + $lang['strnousers'] = 'юХд дСЫЩШ аЯЬикЯзСдХЬХЪ.'; + $lang['struserupdated'] = '№ЯЬикЯзСдХЬи ЯТЮЯзЬХЮ.'; + $lang['struserupdatedbad'] = 'ÑТЮЯзЬХЮЩХ аЯЬикЯзСдХЬб авХвзСЮЯ.'; + $lang['strshowallusers'] = '№ЯЫСкСди згХШ аЯЬикЯзСдХЬХЪ'; + $lang['strcreateuser'] = 'ѓЯкФСди аЯЬикЯзСдХЬб'; + $lang['struserneedsname'] = 'їй ФЯЬжЮй ззХгдЩ ЩЭб аЯЬикЯзСдХЬб.'; + $lang['strusercreated'] = '№ЯЬикЯзСдХЬи гЯкФСЮ.'; + $lang['strusercreatedbad'] = 'ѓЯкФСЮЩХ аЯЬикЯзСдХЬб авХвзСЮЯ.'; + $lang['strconfdropuser'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди аЯЬикЯзСдХЬб "%s"?'; + $lang['struserdropped'] = '№ЯЬикЯзСдХЬи еФСЬХЮ.'; + $lang['struserdroppedbad'] = 'ѕФСЬХЮЩХ аЯЬикЯзСдХЬб авХвзСЮЯ.'; + $lang['straccount'] = 'ÑЫЫСеЮд'; + $lang['strchangepassword'] = 'щкЭХЮЩди аСвЯЬи'; + $lang['strpasswordchanged'] = '№СвЯЬи ЩкЭХЮХЮ.'; + $lang['strpasswordchangedbad'] = 'щкЭХЮХЮЩХ аСвЯЬб авХвзСЮЯ.'; + $lang['strpasswordshort'] = '№СвЯЬи гЬЩлЫЯЭ ЫЯвЯдЫЩЪ.'; + $lang['strpasswordconfirm'] = '№СвЯЬи ЮХ гЯЯдзХдгдзеХд аЯФдзХвжФХЮЩР.'; + + // Groups + $lang['strgroup'] = 'чвеааС'; + $lang['strgroups'] = 'чвеаай'; + $lang['strnogroup'] = 'чвеааС ЮХ ЯТЮСвежХЮС.'; + $lang['strnogroups'] = 'юЩ ЯФЮЯЪ Чвеаай ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreategroup'] = 'ѓЯкФСди Чвеаае'; + $lang['strshowallgroups'] = '№ЯЫСкСди згХ Чвеаай'; + $lang['strgroupneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЮСкзСЮЩХ Чвеаай.'; + $lang['strgroupcreated'] = 'чвеааС гЯкФСЮС.'; + $lang['strgroupcreatedbad'] = 'ѓЯкФСЮЩХ Чвеаай авХвзСЮЯ.'; + $lang['strconfdropgroup'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди Чвеаае "%s"?'; + $lang['strgroupdropped'] = 'чвеааС еФСЬХЮС.'; + $lang['strgroupdroppedbad'] = 'ѕФСЬХЮЩХ Чвеаай авХвзСЮЯ.'; + $lang['strmembers'] = 'ѕоСгдЮЩЫЯз'; + $lang['straddmember'] = 'фЯТСзЩди еоСгдЮЩЫС'; + $lang['strmemberadded'] = 'ѕоСгдЮЩЫ ФЯТСзЬХЮ.'; + $lang['strmemberaddedbad'] = 'фЯТСзЬХЮЩХ еоСгдЮЩЫС авХвзСЮЯ.'; + $lang['strdropmember'] = 'ѕФСЬЩди еоСгдЮЩЫС'; + $lang['strconfdropmember'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди еоСгдЮЩЫС "%s" Щк Чвеаай "%s"?'; + $lang['strmemberdropped'] = 'ѕоСгдЮЩЫ еФСЬХЮ.'; + $lang['strmemberdroppedbad'] = 'ѕФСЬХЮЩХ еоСгдЮЩЫС авХвзСЮЯ.'; + + // Privilges + $lang['strprivilege'] = '№вЩзЩЬХЧЩб'; + $lang['strprivileges'] = '№вЩзЩЬХЧЩЩ'; + $lang['strnoprivileges'] = 'ÑТпХЫд ЮХ ЩЭХХд авЩзЩЬХЧЩЪ.'; + $lang['strgrant'] = 'ѕгЩЬЩди'; + $lang['strrevoke'] = 'ÑгЬСТЩди'; + $lang['strgranted'] = '№вЩзЩЬХЧЩЩ ЩкЭХЮХЮй.'; + $lang['strgrantfailed'] = 'щкЭХЮХЮЩХ авЩзЩЬХЧЩЪ авХвзСЮЯ.'; + $lang['strgrantbad'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ШЯдб Тй ЯФЮЯЧЯ аЯЬикЯзСдХЬб ЩЬЩ Чвеаае Щ ШЯдб Тй ЯФЮе авЩзЩЬХЧЩР.'; + $lang['stralterprivs'] = 'щкЭХЮЩди авЩзЩЬХЧЩЩ'; + $lang['strgrantor'] = 'фЯЮЯв'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'тСкС ФСЮЮйШ'; + $lang['strdatabases'] = 'тСкй ФСЮЮйШ'; + $lang['strshowalldatabases'] = '№ЯЫСкСди згХ ТСкй ФСЮЮйШ'; + $lang['strnodatabase'] = 'тСкС ФСЮЮйШ ЮХ ЯТЮСвежХЮС.'; + $lang['strnodatabases'] = 'юЩ ЯФЮЯЪ ТСкй ФСЮЮйШ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreatedatabase'] = 'ѓЯкФСди ТСке ФСЮЮйШ'; + $lang['strdatabasename'] = 'щЭб ТСкй ФСЮЮйШ'; + $lang['strdatabaseneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ авЩгзЯЩди ЩЭб їСлХЪ ТСкХ ФСЮЮйШ.'; + $lang['strdatabasecreated'] = 'тСкС ФСЮЮйШ гЯкФСЮС.'; + $lang['strdatabasecreatedbad'] = 'ѓЯкФСЮЩХ ТСкй ФСЮЮйШ авХвзСЮЯ.'; + $lang['strconfdropdatabase'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди ТСке ФСЮЮйШ "%s"?'; + $lang['strdatabasedropped'] = ' тСкС ФСЮЮйШ еЮЩодЯжХЮС.'; + $lang['strdatabasedroppedbad'] = 'ѕЮЩодЯжХЮЩХ ТСкй ФСЮЮйШ авХвзСЮЯ.'; + $lang['strentersql'] = 'їзХФЩдХ SQL-кСавЯг ЮЩжХ:'; + $lang['strvacuumgood'] = 'ÑаХвСУЩб аХвХгдвЯЪЫЩ кСзХвлХЮС.'; + $lang['strvacuumbad'] = 'ÑаХвСУЩб аХвХгдвЯЪЫЩ авХвзСЮС.'; + $lang['stranalyzegood'] = ' ÑаХвСУЩб СЮСЬЩкС кСзХвлХЮС.'; + $lang['stranalyzebad'] = ' ÑаХвСУЩб СЮСЬЩкС кСзХвлХЮС.'; + + // Views + $lang['strview'] = '№вХФгдСзЬХЮЩХ'; + $lang['strviews'] = '№вХФгдСзЬХЮЩб'; + $lang['strshowallviews'] = '№ЯЫСкСди згХ авХФгдСзЬХЮЩб'; + $lang['strnoview'] = '№вХФгдСзЬХЮЩХ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strnoviews'] = 'юЩ ЯФЮЯЧЯ авХФгдСзЬХЮЩб ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreateview'] = 'ѓЯкФСди авХФгдСзЬХЮЩХ'; + $lang['strviewname'] = 'щЭб авХФгдСзЬХЮЩб'; + $lang['strviewneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб авХФгдСзЬХЮЩб.'; + $lang['strviewneedsdef'] = ' їСЭ ЮХЯТШЯФЩЭЯ ЯавХФХЬЩди СдвЩТедй авХФгдСзЬХЮЩб.'; + $lang['strviewcreated'] = '№вХФгдСзЬХЮЩХ гЯкФСЮЯ.'; + $lang['strviewcreatedbad'] = 'ѓЯкФСЮЩХ авХФгдСзЬХЮЩб авХвзСЮЯ.'; + $lang['strconfdropview'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди авХФгдСзЬХЮЩХ "%s"?'; + $lang['strviewdropped'] = '№вХФгдСзЬХЮЩХ еЮЩодЯжХЮЯ.'; + $lang['strviewdroppedbad'] = 'ѕЮЩодЯжХЮЩХ авХФгдСзЬХЮЩб авХвзСЮЯ.'; + $lang['strviewupdated'] = '№вХФгдСзЬХЮЩХ ЯТЮЯзЬХЮЯ.'; + $lang['strviewupdatedbad'] = 'ÑТЮЯзЬХЮЩХ авХФгдСзЬХЮЩб авХвзСЮЯ.'; + + // Sequences + $lang['strsequence'] = '№ЯгЬХФЯзСдХЬиЮЯгди'; + $lang['strsequences'] = ' №ЯгЬХФЯзСдХЬиЮЯгдЩ'; + $lang['strshowallsequences'] = '№ЯЫСкСди згХ аЯгЬХФЯзСдХЬиЮЯгдЩ'; + $lang['strnosequence'] = '№ЯгЬХФЯзСдХЬиЮЯгди ЮХ ЯТЮСвежХЮС.'; + $lang['strnosequences'] = 'юЩ ЯФЮЯЪ аЯгЬХФЯзСдХЬиЮЯгдЩ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreatesequence'] = 'ѓЯкФСди аЯгЬХФЯзСдХЬиЮЯгди'; + $lang['strlastvalue'] = '№ЯгЬХФЮХХ кЮСоХЮЩХ'; + $lang['strincrementby'] = 'ѕзХЬЩоХЮЩХ ЮС'; + $lang['strstartvalue'] = 'юСоСЬиЮЯХ кЮСоХЮЩХ'; + $lang['strmaxvalue'] = 'ÑСЫг. зХЬЩоЩЮС'; + $lang['strminvalue'] = 'ÑЩЮ. зХЬЩоЩЮС'; + $lang['strcachevalue'] = 'ђСкЭХв ЫмлС'; + $lang['strlogcount'] = 'Log Count'; + $lang['striscycled'] = 'њСУЩЫЬЩди?'; + $lang['strsequenceneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб аЯгЬХФЯзСдХЬиЮЯгдЩ.'; + $lang['strsequencecreated'] = '№ЯгЬХФЯзСдХЬиЮЯгди гЯкФСЮС.'; + $lang['strsequencecreatedbad'] = 'ѓЯкФСЮЩХ аЯгЬХФЯзСдХЬиЮЯгдЩ авХвзСЮЯ.'; + $lang['strconfdropsequence'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди аЯгЬХФЯзСдХЬиЮЯгди "%s"?'; + $lang['strsequencedropped'] = '№ЯгЬХФЯзСдХЬиЮЯгди еЮЩодЯжХЮС.'; + $lang['strsequencedroppedbad'] = 'ѕЮЩодЯжХЮЩХ аЯгЬХФЯзСдХЬиЮЯгдЩ авХвзСЮЯ.'; + $lang['strsequencereset'] = '№ЯгЬХФЯзСдХЬиЮЯгди гТвЯлХЮС.'; + $lang['strsequenceresetbad'] = 'ѓТвЯг аЯгЬХФЯзСдХЬиЮЯгдЩ авХвзСЮ.'; + + // Indexes + $lang['strindexes'] = 'щЮФХЫг'; + $lang['strindexname'] = 'щЭб ЩЮФХЫгС'; + $lang['strshowallindexes'] = '№ЯЫСкСди згХ ЩЮФХЫгй'; + $lang['strnoindex'] = 'щЮФХЫг ЮХ ЯТЮСвежХЮ.'; + $lang['strnoindexes'] = 'юЩ ЯФЮЯЧЯ ЩЮФХЫгС ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreateindex'] = 'ѓЯкФСди ЩЮФХЫг'; + $lang['strtabname'] = 'щЭб дСТЬЩУй'; + $lang['strcolumnname'] = 'щЭб СдвЩТедС'; + $lang['strindexneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб ЩЮФХЫгС'; + $lang['strindexneedscols'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ФЯаегдЩЭЯХ ЫЯЬЩоХгдзЯ СдвЩТедЯз.'; + $lang['strindexcreated'] = 'щЮФХЫг гЯкФСЮ.'; + $lang['strindexcreatedbad'] = 'ѓЯкФСЮЩХ ЩЮФХЫгС авХвзСЮЯ.'; + $lang['strconfdropindex'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди ЩЮФХЫг "%s"?'; + $lang['strindexdropped'] = 'щЮФХЫг еЮЩодЯжХЮ.'; + $lang['strindexdroppedbad'] = 'ѕЮЩодЯжХЮЩХ ЩЮФХЫгС авХвзСЮЯ.'; + $lang['strkeyname'] = 'щЭб ЫЬРоС'; + $lang['struniquekey'] = 'ѕЮЩЫСЬиЮйЪ ЫЬРо'; + $lang['strprimarykey'] = '№ХвзЩоЮйЪ ЫЬРо'; + $lang['strindextype'] = 'їЩФ ЩЮФХЫгС'; + $lang['strindexname'] = 'щЭб ЩЮФХЫгС'; + $lang['strtablecolumnlist'] = 'ÑдвЩТедЯз з дСТЬЩУХ'; + $lang['strindexcolumnlist'] = 'ÑдвЩТедЯз з ЩЮФХЫгХ'; + $lang['strconfcluster'] = 'їй езХвХЮй, одЯ ШЯдЩдХ ЫЬСгдХвЩкЯзСди "%s"?'; + $lang['strclusteredgood'] = 'ыЬСгдХвЩкСУЩб кСзХвлХЮС.'; + $lang['strclusteredbad'] = 'ыЬСгдХвЩкСУЩб авХвзСЮС.'; + + // Rules + $lang['strrules'] = '№вСзЩЬС'; + $lang['strrule'] = '№вСзЩЬЯ'; + $lang['strshowallrules'] = '№ЯЫСкСди згХ авСзЩЬС'; + $lang['strnorule'] = '№вСзЩЬЯ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strnorules'] = 'юЩ ЯФЮЯЧЯ авСзЩЬС ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreaterule'] = 'ѓЯкФСди авСзЩЬЯ'; + $lang['strrulename'] = 'щЭб авСзЩЬС'; + $lang['strruleneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб авСзЩЬС.'; + $lang['strrulecreated'] = '№вСзЩЬЯ гЯкФСЮЯ.'; + $lang['strrulecreatedbad'] = 'ѓЯкФСЮЩХ авСзЩЬС авХвзСЮЯ.'; + $lang['strconfdroprule'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди авСзЩЬЯ "%s" on "%s"?'; + $lang['strruledropped'] = '№вСзЩЬЯ еЮЩодЯжХЮЯ.'; + $lang['strruledroppedbad'] = 'ѕЮЩодЯжХЮЩХ авСзЩЬС авХвзСЮЯ.'; + + // Constraints + $lang['strconstraints'] = 'ÑЧвСЮЩоХЮЩб'; + $lang['strshowallconstraints'] = '№ЯЫСкСди згХ ЯЧвСЮЩоХЮЩб'; + $lang['strnoconstraints'] = 'юЩ ЯФЮЯЧЯ ЯЧвСЮЩоХЮЩб ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreateconstraint'] = 'ѓЯкФСди ЯЧвСЮЩоХЮЩХ'; + $lang['strconstraintcreated'] = 'ÑЧвСЮЩоХЮЩХ гЯкФСЮЯ.'; + $lang['strconstraintcreatedbad'] = 'ѓЯкФСЮЩХ ЯЧвСЮЩоХЮЩб авХвзСЮЯ.'; + $lang['strconfdropconstraint'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди ЯЧвСЮЩоХЮЩХ "%s" on "%s"?'; + $lang['strconstraintdropped'] = 'ÑЧвСЮЩоХЮЩХ еЮЩодЯжХЮЯ.'; + $lang['strconstraintdroppedbad'] = 'ѕЮЩодЯжХЮЩХ ЯЧвСЮЩоХЮЩб авХвзСЮЯ.'; + $lang['straddcheck'] = 'фЯТСзЩди авЯзХвЫе'; + $lang['strcheckneedsdefinition'] = 'ÑЧвСЮЩоХЮЩХ авЯзХвЫЩ ЮежФСХдгб з ЯавХФХЬХЮЩЩ.'; + $lang['strcheckadded'] = 'ÑЧвСЮЩоХЮЩХ авЯзХвЫЩ ФЯТСзЬХЮЯ.'; + $lang['strcheckaddedbad'] = 'фЯТСзЬХЮЩХ ЯЧвСЮЩоХЮЩб авЯзХвЫЩ авХвзСЮЯ.'; + $lang['straddpk'] = 'фЯТСзЩди аХвзЩоЮйЪ ЫЬРо'; + $lang['strpkneedscols'] = '№ХвзЩоЮйЪ ЫЬРо ФЯЬжХЮ зЫЬРоСди ШЯдб Тй ЯФЩЮ СдвЩТед.'; + $lang['strpkadded'] = '№ХвзЩоЮйЪ ЫЬРо ФЯТСзЬХЮ.'; + $lang['strpkaddedbad'] = 'фЯТСзЬХЮЩХ аХвзЩоЮЯЧЯ ЫЬРоС авХвзСЮЯ.'; + $lang['stradduniq'] = 'фЯТСзЩди еЮЩЫСЬиЮйЪ ЫЬРо'; + $lang['struniqneedscols'] = 'ѕЮЩЫСЬиЮйЪ ЫЬРо ФЯЬжХЮ зЫЬРоСди ШЯдб Тй ЯФЩЮ СдвЩТед.'; + $lang['struniqadded'] = 'ѕЮЩЫСЬиЮйЪ ЫЬРо ФЯТСзЬХЮ.'; + $lang['struniqaddedbad'] = 'фЯТСзЬХЮЩХ еЮЩЫСЬиЮЯЧЯ ЫЬРоС авХвзСЮЯ.'; + $lang['straddfk'] = 'фЯТСзЩди зЮХлЮЩЪ ЫЬРо'; + $lang['strfkneedscols'] = 'їЮХлЮЩЪ ЫЬРо ФЯЬжХЮ зЫЬРоСди ШЯдб Тй ЯФЩЮ СдвЩТед.'; + $lang['strfkneedstarget'] = 'їЮХлЮХЭе ЫЬРое ЮХЯТШЯФЩЭЯ еЫСкСди УХЬХзеР дСТЬЩУе.'; + $lang['strfkadded'] = 'їЮХлЮЩЪ ЫЬРо ФЯТСзЬХЮ.'; + $lang['strfkaddedbad'] = 'фЯТСзЬХЮЩХ зЮХлЮХЧЯ ЫЬРоС авХвзСЮЯ.'; + $lang['strfktarget'] = 'уХЬХзСб дСТЬЩУС'; + $lang['strfkcolumnlist'] = 'ÑдвЩТедй з ЫЬРоХ'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'цеЮЫУЩб'; + $lang['strfunctions'] = ' цеЮЫУЩЩ'; + $lang['strshowallfunctions'] = '№ЯЫСкСди згХ ЦеЮЫУЩЩ'; + $lang['strnofunction'] = 'цеЮЫУЩб ЮХ ЯТЮСвежХЮС.'; + $lang['strnofunctions'] = 'юЩ ЯФЮЯЪ ЦеЮЫУЩЩ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreatefunction'] = 'ѓЯкФСди ЦеЮЫУЩР'; + $lang['strfunctionname'] = 'щЭб ЦеЮЫУЩЩ'; + $lang['strreturns'] = 'їЯкзвСнСХЭЯХ кЮСоХЮЩХ'; + $lang['strarguments'] = 'ÑвЧеЭХЮдй'; + $lang['strproglanguage'] = 'ёкйЫ авЯЧвСЭЭЩвЯзСЮЩб'; + $lang['strproglanguage'] = 'ёкйЫ'; + $lang['strfunctionneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб ЦеЮЫУЩЩ.'; + $lang['strfunctionneedsdef'] = 'їСЭ ЮХЯТШЯФЩЭЯ ЯавХФХЬЩди ЦеЮЫУЩР.'; + $lang['strfunctioncreated'] = 'цеЮЫУЩб гЯкФСЮС.'; + $lang['strfunctioncreatedbad'] = 'ѓЯкФСЮЩХ ЦеЮЫУЩЩ авХвзСЮЯ.'; + $lang['strconfdropfunction'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди ЦеЮЫУЩР "%s"?'; + $lang['strfunctiondropped'] = 'цеЮЫУЩб еЮЩодЯжХЮС.'; + $lang['strfunctiondroppedbad'] = 'ѕЮЩодЯжХЮЩХ ЦеЮЫУЩЩ авХвзСЮЯ.'; + $lang['strfunctionupdated'] = 'цеЮЫУЩб ЯТЮЯзЬХЮС.'; + $lang['strfunctionupdatedbad'] = 'ÑТЮЯзЬХЮЩХ ЦеЮЫУЩЩ авХвзСЮЯ.'; + + // Triggers + $lang['strtrigger'] = 'євЩЧЧХв'; + $lang['strtriggers'] = ' євЩЧЧХвй'; + $lang['strshowalltriggers'] = '№ЯЫСкСди згХ двЩЧЧХвй'; + $lang['strnotrigger'] = 'євЩЧЧХв ЮХ ЯТЮСвежХЮ.'; + $lang['strnotriggers'] = 'юЩ ЯФЮЯЧЯ двЩЧЧХвС ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreatetrigger'] = 'ѓЯкФСди двЩЧЧХв'; + $lang['strtriggerneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб двЩЧЧХвС.'; + $lang['strtriggerneedsfunc'] = 'їСЭ ЮХЯТШЯФЩЭЯ ЯавХФХЬЩди ЦеЮЫУЩР двЩЧЧХвС.'; + $lang['strtriggercreated'] = 'євЩЧЧХв гЯкФСЮ.'; + $lang['strtriggercreatedbad'] = 'ѓЯкФСЮЩХ двЩЧЧХвС авХвзСЮЯ.'; + $lang['strconfdroptrigger'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди двЩЧЧХв "%s" ЮС "%s"?'; + $lang['strtriggerdropped'] = 'євЩЧЧХв еЮЩодЯжХЮ.'; + $lang['strtriggerdroppedbad'] = 'ѕЮЩодЯжХЮЩХ двЩЧЧХвС авХвзСЮЯ.'; + $lang['strtriggeraltered'] = 'євЩЧЧХв ЩкЭХЮХЮ.'; + $lang['strtriggeralteredbad'] = 'щкЭХЮХЮЩХ двЩЧЧХвС авХвзСЮЯ.'; + + // Types + $lang['strtype'] = 'єЩа ФСЮЮйШ'; + $lang['strtypes'] = 'єЩай ФСЮЮйШ'; + $lang['strshowalltypes'] = '№ЯЫСкСди згХ дЩай ФСЮЮйШ'; + $lang['strnotype'] = 'єЩа ФСЮЮйШ ЮХ ЯТЮСвежХЮ.'; + $lang['strnotypes'] = 'юЩ ЯФЮЯЧЯ дЩаС ФСЮЮйШ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreatetype'] = 'ѓЯкФСди дЩа ФСЮЮйШ'; + $lang['strtypename'] = 'щЭб дЩаС ФСЮЮйШ'; + $lang['strinputfn'] = 'цеЮЫУЩб ззЯФС'; + $lang['stroutputfn'] = 'цеЮЫУЩб зйзЯФС'; + $lang['strpassbyval'] = '№ХвХФСди аЯ кЮСоХЮЩР?'; + $lang['stralignment'] = 'їйвСзЮЩзСЮЩХ'; + $lang['strelement'] = 'ќЬХЭХЮд'; + $lang['strdelimiter'] = 'ђСкФХЬЩдХЬи'; + $lang['strstorage'] = 'Storage'; + $lang['strtypeneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб дЩаС ФСЮЮйШ.'; + $lang['strtypeneedslen'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди вСкЭХв ФЬб дЩаС ФСЮЮйШ.'; + $lang['strtypecreated'] = 'єЩа ФСЮЮйШ гЯкФСЮ.'; + $lang['strtypecreatedbad'] = 'ѓЯкФСЮЩХ дЩаС ФСЮЮйШ авХвзСЮЯ.'; + $lang['strconfdroptype'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди дЩа ФСЮЮйШ "%s"?'; + $lang['strtypedropped'] = 'єЩа ФСЮЮйШ еЮЩодЯжХЮ.'; + $lang['strtypedroppedbad'] = 'ѕЮЩодЯжХЮЩХ дЩаС ФСЮЮйШ авХвзСЮЯ.'; + + // Schemas + $lang['strschema'] = 'ѓШХЭС'; + $lang['strschemas'] = 'ѓШХЭй'; + $lang['strshowallschemas'] = '№ЯЫСкСди згХ гШХЭй'; + $lang['strnoschema'] = 'ѓШХЭС ЮХ ЯТЮСвежХЮС.'; + $lang['strnoschemas'] = 'юЩ ЯФЮЯЪ гШХЭй ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreateschema'] = 'ѓЯкФСди гШХЭе'; + $lang['strschemaname'] = 'щЭб гШХЭй'; + $lang['strschemaneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб гШХЭй.'; + $lang['strschemacreated'] = 'ѓШХЭС гЯкФСЮС.'; + $lang['strschemacreatedbad'] = 'ѓЯкФСЮЩХ гШХЭй авХвзСЮЯ.'; + $lang['strconfdropschema'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди гШХЭе "%s"?'; + $lang['strschemadropped'] = 'ѓШХЭС еЮЩодЯжХЮС.'; + $lang['strschemadroppedbad'] = 'ѕЮЩодЯжХЮЩХ гШХЭй авХвзСЮЯ.'; + + // Reports + + // Domains + $lang['strdomain'] = 'фЯЭХЮ'; + $lang['strdomains'] = 'фЯЭХЮй'; + $lang['strshowalldomains'] = '№ЯЫСкСди згХ ФЯЭХЮй'; + $lang['strnodomains'] = 'юЩ ЯФЮЯЧЯ ФЯЭХЮС ЮХ ЯТЮСвежХЮЯ.'; + $lang['strcreatedomain'] = 'ѓЯкФСди ФЯЭХЮ'; + $lang['strdomaindropped'] = 'фЯЭХЮ еФСЬХЮ.'; + $lang['strdomaindroppedbad'] = 'ѕФСЬХЮЩХ ФЯЭХЮС авХвзСЮЯ.'; + $lang['strconfdropdomain'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еФСЬЩди ФЯЭХЮ "%s"?'; + $lang['strdomainneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЩЭб ФЯЭХЮС.'; + $lang['strdomaincreated'] = 'фЯЭХЮ гЯкФСЮ.'; + $lang['strdomaincreatedbad'] = 'ѓЯкФСЮЩХ ФЯЭХЮС авХвзСЮЯ.'; + $lang['strdomainaltered'] = 'фЯЭХЮ ЩкЭХЮХЮ.'; + $lang['strdomainalteredbad'] = 'щкЭХЮХЮЩХ ФЯЭХЮС авХвзСЮЯ.'; + + // Operators + $lang['stroperator'] = 'ÑаХвСдЯв'; + $lang['stroperators'] = 'ÑаХвСдЯвй'; + $lang['strshowalloperators'] = '№ЯЫСкСди згХ ЯаХвСдЯвй'; + $lang['strnooperator'] = 'ÑаХвСдЯв ЮХ ЯТЮСвежХЮ.'; + $lang['strnooperators'] = 'ÑаХвСдЯвй ЮХ ЯТЮСвежХЮй.'; + $lang['strcreateoperator'] = 'ѓЯкФСди ЯаХвСдЯв'; + $lang['strleftarg'] = 'єЩа ЬХзЯЧЯ СвЧеЭХЮдС'; + $lang['strrightarg'] = 'єЩа авСзЯЧЯ СвЧеЭХЮдС'; + $lang['strcommutator'] = '№вХЯТвСкЯзСЮЩХ'; + $lang['strnegator'] = 'ÑдвЩУСЮЩХ'; + $lang['strrestrict'] = 'ÑгЬСТЬХЮЩХ'; + $lang['strjoin'] = 'ÑТпХФЩЮХЮЩХ'; + $lang['strhashes'] = 'шХлЩвЯзСЮЩХ'; + $lang['strmerges'] = 'ѓЬЩбЮЩХ'; + $lang['strleftsort'] = 'ѓЯдЩвЯзЫС аЯ ЬХзЯЭе'; + $lang['strrightsort'] = 'ѓЯдЩвЯзЫС аЯ авСзЯЭе'; + $lang['strlessthan'] = 'ÑХЮилХ'; + $lang['strgreaterthan'] = 'тЯЬилХ'; + $lang['stroperatorneedsname'] = 'їСЭ ЮХЯТШЯФЩЭЯ еЫСкСди ЮСкзСЮЩХ ЯаХвСдЯвС.'; + $lang['stroperatorcreated'] = 'ÑаХвСдЯв гЯкФСЮ'; + $lang['stroperatorcreatedbad'] = 'ЯкФСЮЩХ ЯаХвСдЯвС авХвзСЮЯ.'; + $lang['strconfdropoperator'] = 'їй езХвХЮй, одЯ ШЯдЩдХ еЮЩодЯжЩди ЯаХвСдЯв "%s"?'; + $lang['stroperatordropped'] = 'ÑаХвСдЯв еФСЬХЮ.'; + $lang['stroperatordroppedbad'] = 'ѕФСЬХЮЩХ ЯаХвСдЯвС авХвзСЮЯ.'; + + // Casts + $lang['strcasts'] = 'ÑТвСкУй'; + $lang['strnocasts'] = 'ÑТвСкУЯз ЮХ ЯТЮСвежХЮЯ.'; + $lang['strsourcetype'] = 'єЩа ЩгдЯоЮЩЫС'; + $lang['strtargettype'] = 'єЩа авЩХЭЮЩЫС'; + $lang['strimplicit'] = 'юХбзЮйЪ'; + $lang['strinassignment'] = 'Ñ— ЮСкЮСоХЮЩЩ'; + $lang['strbinarycompat'] = '(ФзЯЩоЮЯ гЯзЭХгдЩЭйЪ)'; + + // Conversions + $lang['strconversions'] = '№вХЯТвСкЯзСЮЩХ'; + $lang['strnoconversions'] = '№вХЯТвСкЯзСЮЩЪ ЮХ ЯТЮСвежХЮЯ.'; + $lang['strsourceencoding'] = 'ыЯФЩвЯзЫС ЩгдЯоЮЩЫС'; + $lang['strtargetencoding'] = 'ыЯФЩвЯзЫС авЩХЭЮЩЫС'; + + // Languages + $lang['strlanguages'] = 'ёкйЫЩ'; + $lang['strnolanguages'] = 'ёкйЫЯз ЮХ ЯТЮСвежХЮЯ.'; + $lang['strtrusted'] = '№вЯзХвХЮЯ'; + + // Info + $lang['strnoinfo'] = 'юХд ФЯгдеаЮЯЪ ЩЮЦЯвЭСУЩЩ.'; + $lang['strreferringtables'] = 'ѓгйЬСРнЩХгб дСТЬЩУй'; + $lang['strparenttables'] = 'ђЯФЩдХЬигЫЩХ дСТЬЩУй'; + $lang['strchildtables'] = 'фЯоХвЮЩХ дСТЬЩУй'; + + // Miscellaneous + $lang['strtopbar'] = '%s зйаЯЬЮбХдгб ЮС %s:%s -- їй кСвХЧЩгдвЩвЯзСЮй ЫСЫ "%s"'; + $lang['strtimefmt'] = ' j-m-Y g:i'; + +?> + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/polish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/polish.php new file mode 100644 index 00000000..dc6cc042 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/polish.php @@ -0,0 +1,745 @@ +>'; + $lang['strfailed'] = 'Nieudany'; + $lang['strcreate'] = 'Utwórz'; + $lang['strcreated'] = 'Utworzony'; + $lang['strcomment'] = 'Komentarz'; + $lang['strlength'] = 'DÅ‚ugość'; + $lang['strdefault'] = 'DomyÅ›lny'; + $lang['stralter'] = 'ZmieÅ„'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Anuluj'; + $lang['strac'] = 'WÅ‚Ä…cz autouzupeÅ‚nianie'; + $lang['strsave'] = 'Zapisz'; + $lang['strreset'] = 'Wyczyść'; + $lang['strinsert'] = 'Wstaw'; + $lang['strselect'] = 'Wybierz'; + $lang['strdelete'] = 'UsuÅ„'; + $lang['strupdate'] = 'ZmieÅ„'; + $lang['strreferences'] = 'OdnoÅ›niki'; + $lang['stryes'] = 'Tak'; + $lang['strno'] = 'Nie'; + $lang['strtrue'] = 'Prawda'; + $lang['strfalse'] = 'FaÅ‚sz'; + $lang['stredit'] = 'Edycja'; + $lang['strcolumn'] = 'Kolumna'; + $lang['strcolumns'] = 'Kolumny'; + $lang['strrows'] = 'wiersz(y)'; + $lang['strrowsaff'] = 'wiersz(y) dotyczy.'; + $lang['strobjects'] = 'obiekty'; + $lang['strback'] = 'Wstecz'; + $lang['strqueryresults'] = 'Wyniki zapytania'; + $lang['strshow'] = 'Pokaż'; + $lang['strempty'] = 'Wyczyść'; + $lang['strlanguage'] = 'JÄ™zyk'; + $lang['strencoding'] = 'Kodowanie'; + $lang['strvalue'] = 'Wartość'; + $lang['strunique'] = 'Unikatowy'; + $lang['strprimary'] = 'Główny'; + $lang['strexport'] = 'Eksport'; + $lang['strimport'] = 'Import'; + $lang['strallowednulls'] = 'Dozwolone znaki NULL'; + $lang['strbackslashn'] = '\N'; + $lang['strnull'] = 'Null'; + $lang['stremptystring'] = 'Pusty ciÄ…g znaków/pole'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Administruj'; + $lang['strvacuum'] = 'Przeczyść'; + $lang['stranalyze'] = 'Analizuj'; + $lang['strclusterindex'] = 'Klastruj'; + $lang['strclustered'] = 'Klastrowany?'; + $lang['strreindex'] = 'Przeindeksuj'; + $lang['strrun'] = 'Uruchom'; + $lang['stradd'] = 'Dodaj'; + $lang['strremove'] = 'UsuÅ„'; + $lang['strevent'] = 'Zdarzenie'; + $lang['strwhere'] = 'Gdzie'; + $lang['strinstead'] = 'Wykonaj zamiast'; + $lang['strwhen'] = 'Kiedy'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Dane'; + $lang['strconfirm'] = 'Potwierdź'; + $lang['strexpression'] = 'Wyrażenie'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'RozwiÅ„'; + $lang['strcollapse'] = 'ZwiÅ„'; + $lang['strexplain'] = 'Explain'; + $lang['strexplainanalyze'] = 'Explain Analyze'; + $lang['strfind'] = 'Znajdź'; + $lang['stroptions'] = 'Opcje'; + $lang['strrefresh'] = 'OdÅ›wież'; + $lang['strdownload'] = 'Pobierz'; + $lang['strdownloadgzipped'] = 'Pobierz skompresowane gzip-em'; + $lang['strinfo'] = 'Informacje'; + $lang['stroids'] = 'OIDy'; + $lang['stradvanced'] = 'Zaawansowane'; + $lang['strvariables'] = 'Zmienne'; + $lang['strprocess'] = 'Proces'; + $lang['strprocesses'] = 'Procesy'; + $lang['strsetting'] = 'Ustawienie'; + $lang['streditsql'] = 'Edycja zapytania SQL'; + $lang['strruntime'] = 'CaÅ‚kowity czas pracy: %s ms.'; + $lang['strpaginate'] = 'WyÅ›wietl wyniki stronami'; + $lang['struploadscript'] = 'lub zaÅ‚aduj skrypt SQL:'; + $lang['strstarttime'] = 'Czas poczÄ…tku'; + $lang['strfile'] = 'Plik'; + $lang['strfileimported'] = 'Plik zostaÅ‚ zaimportowany.'; + $lang['strtrycred'] = 'Użyj tych parametrów dla wszystkich serwerów'; + $lang['strexecute'] = 'Wykonaj'; + + // Database Sizes + $lang['strsize'] = 'Rozmiar'; + $lang['strbytes'] = 'bajtów'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Ta aplikacja najlepiej dziaÅ‚a w przeglÄ…darce obsÅ‚ugujÄ…cej ramki, ale możesz jej użyć również bez ramek, klikajÄ…c poniższy link.'; + $lang['strnoframeslink'] = 'Otwórz bez ramek'; + $lang['strbadconfig'] = 'Twój plik config.inc.php jest przestarzaÅ‚y. Musisz go utworzyć ponownie wykorzystujÄ…c nowy config.inc.php-dist.'; + $lang['strnotloaded'] = 'Nie wkompilowaÅ‚eÅ› do PHP obsÅ‚ugi tej bazy danych.'; + $lang['strpostgresqlversionnotsupported'] = 'NieobsÅ‚ugiwana wersja PostgreSQL. Uaktualnij do wersji %s lub nowszej.'; + $lang['strbadschema'] = 'Podano bÅ‚Ä™dny schemat.'; + $lang['strbadencoding'] = 'BÅ‚Ä™dne kodowanie bazy.'; + $lang['strsqlerror'] = 'BÅ‚Ä…d SQL:'; + $lang['strinstatement'] = 'W poleceniu:'; + $lang['strinvalidparam'] = 'BÅ‚Ä™dny parametr.'; + $lang['strnodata'] = 'Nie znaleziono danych.'; + $lang['strnoobjects'] = 'Nie znaleziono obiektów.'; + $lang['strrownotunique'] = 'Brak unikatowego identyfikatora dla tego wiersza.'; + $lang['strnouploads'] = 'Åadowanie plików wyÅ‚Ä…czone.'; + $lang['strimporterror'] = 'BÅ‚Ä…d importu.'; + $lang['strimporterror-fileformat'] = 'BÅ‚Ä…d importu: Nie można automatycznie okreÅ›lić formatu pliku.'; + $lang['strimporterrorline'] = 'BÅ‚Ä…d importu w linii %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'BÅ‚Ä…d importu w linii %s: Linia nie ma wÅ‚aÅ›ciwej liczby kolumn.'; + $lang['strimporterror-uploadedfile'] = 'BÅ‚Ä…d importu: plik nie może być zaÅ‚adowany na serwer.'; + $lang['strcannotdumponwindows'] = 'Zrzucanie zÅ‚ożonych nazw tabel i schematów pod Windows jest nie wspierane.'; + + // Tables + $lang['strtable'] = 'Tabela'; + $lang['strtables'] = 'Tabele'; + $lang['strshowalltables'] = 'Pokaż wszystkie tabele'; + $lang['strnotables'] = 'Nie znaleziono tabel.'; + $lang['strnotable'] = 'Nie znaleziono tabeli.'; + $lang['strcreatetable'] = 'Utwórz tabelÄ™'; + $lang['strtablename'] = 'Nazwa tabeli'; + $lang['strtableneedsname'] = 'Musisz nazwać tabelÄ™.'; + $lang['strtableneedsfield'] = 'Musisz podać przynajmniej jedno pole.'; + $lang['strtableneedscols'] = 'Musisz podać prawidÅ‚owÄ… liczbÄ™ kolumn.'; + $lang['strtablecreated'] = 'Tabela zostaÅ‚a utworzona.'; + $lang['strtablecreatedbad'] = 'Próba utworzenia tabeli siÄ™ nie powiodÅ‚a.'; + $lang['strconfdroptable'] = 'Czy na pewno chcesz usunąć tabelÄ™ "%s"?'; + $lang['strtabledropped'] = 'Tabela zostaÅ‚a usuniÄ™ta.'; + $lang['strtabledroppedbad'] = 'Próba usuniÄ™cia tabeli siÄ™ nie powiodÅ‚a.'; + $lang['strconfemptytable'] = 'Czy na pewno chcesz wyczyÅ›cić tabelÄ™ "%s"?'; + $lang['strtableemptied'] = 'Tabela zostaÅ‚a wyczyszczona.'; + $lang['strtableemptiedbad'] = 'Próba wyczyszczenia tabeli siÄ™ nie powiodÅ‚a.'; + $lang['strinsertrow'] = 'Wstaw wiersz'; + $lang['strrowinserted'] = 'Wiersz zostaÅ‚ wstawiony.'; + $lang['strrowinsertedbad'] = 'Próba wstawienia wiersza siÄ™ nie powiodÅ‚a.'; + $lang['strrowduplicate'] = 'Próba wstawienia zduplikowanego wiersza.'; + $lang['streditrow'] = 'Edycja wiersza'; + $lang['strrowupdated'] = 'Wiersz zostaÅ‚ zaktualizowany.'; + $lang['strrowupdatedbad'] = 'Próba aktualizacji wiersza siÄ™ nie powiodÅ‚a.'; + $lang['strdeleterow'] = 'UsuÅ„ wiersz'; + $lang['strconfdeleterow'] = 'Czy na pewno chcesz usunąć ten wiersz?'; + $lang['strrowdeleted'] = 'Wiersz zostaÅ‚ usuniÄ™ty.'; + $lang['strrowdeletedbad'] = 'Próba usuniÄ™cia wiersza siÄ™ nie powiodÅ‚a.'; + $lang['strinsertandrepeat'] = 'Wstaw i powtórz'; + $lang['strnumcols'] = 'Ilość kolumn'; + $lang['strcolneedsname'] = 'Musisz podać nazwÄ™ kolumny.'; + $lang['strselectallfields'] = 'Wybierz wszystkie pola'; + $lang['strselectneedscol'] = 'Musisz wybrać przynajmniej jednÄ… kolumnÄ™.'; + $lang['strselectunary'] = 'Operatory bezargumentowe (IS NULL/IS NOT NULL) nie mogÄ… mieć podanej wartoÅ›ci.'; + $lang['straltercolumn'] = 'ZmieÅ„ kolumnÄ™'; + $lang['strcolumnaltered'] = 'Kolumna zostaÅ‚a zmodyfikowana.'; + $lang['strcolumnalteredbad'] = 'Próba modyfikacji kolumny siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropcolumn'] = 'Czy na pewno chcesz usunąć kolumnÄ™ "%s" z tabeli "%s"?'; + $lang['strcolumndropped'] = 'Kolumna zostaÅ‚a usuniÄ™ta.'; + $lang['strcolumndroppedbad'] = 'Próba usuniÄ™cia kolumny siÄ™ nie powiodÅ‚a.'; + $lang['straddcolumn'] = 'Dodaj kolumnÄ™'; + $lang['strcolumnadded'] = 'Kolumna zostaÅ‚a dodana.'; + $lang['strcolumnaddedbad'] = 'Próba dodania kolumny siÄ™ nie powiodÅ‚a.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabela zostaÅ‚a zmodyfikowana.'; + $lang['strtablealteredbad'] = 'Próba modyfikacji tabeli siÄ™ nie powiodÅ‚a.'; + $lang['strdataonly'] = 'Tylko dane'; + $lang['strstructureonly'] = 'Tylko struktura'; + $lang['strstructureanddata'] = 'Struktura i dane'; + $lang['strtabbed'] = 'Z tabulacjami'; + $lang['strauto'] = 'Automatyczny'; + $lang['strconfvacuumtable'] = 'Czy na pewno chcesz wykonać vacuum "%s"?'; + $lang['strestimatedrowcount'] = 'Przybliżona ilość wierszy'; + + // Columns + $lang['strcolprop'] = 'WÅ‚aÅ›ciwoÅ›ci kolumny'; + + // Users + $lang['struser'] = 'Użytkownik'; + $lang['strusers'] = 'Użytkownicy'; + $lang['strusername'] = 'Nazwa użytkownika'; + $lang['strpassword'] = 'HasÅ‚o'; + $lang['strsuper'] = 'Administrator?'; + $lang['strcreatedb'] = 'Tworzenie BD?'; + $lang['strexpires'] = 'Wygasa'; + $lang['strsessiondefaults'] = 'WartoÅ›ci domyÅ›lne sesji'; + $lang['strnousers'] = 'Nie znaleziono użytkowników.'; + $lang['struserupdated'] = 'Parametry użytkownika zostaÅ‚y zaktualizowane.'; + $lang['struserupdatedbad'] = 'Próba aktualizacji parametrów użytkownika siÄ™ nie powiodÅ‚a.'; + $lang['strshowallusers'] = 'Pokaż wszystkich użytkowników'; + $lang['strcreateuser'] = 'Utwórz użytkownika'; + $lang['struserneedsname'] = 'Musisz podać nazwÄ™ użytkownika.'; + $lang['strusercreated'] = 'Użytkownik zostaÅ‚ utworzony.'; + $lang['strusercreatedbad'] = 'Próba utworzenia użytkownika siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropuser'] = 'Czy na pewno chcesz usunąć użytkownika "%s"?'; + $lang['struserdropped'] = 'Użytkownik zostaÅ‚ usuniÄ™ty.'; + $lang['struserdroppedbad'] = 'Próba usuniÄ™cia użytkownika siÄ™ nie powiodÅ‚a.'; + $lang['straccount'] = 'Konto'; + $lang['strchangepassword'] = 'ZmieÅ„ hasÅ‚o'; + $lang['strpasswordchanged'] = 'HasÅ‚o zostaÅ‚o zmienione.'; + $lang['strpasswordchangedbad'] = 'Próba zmiany hasÅ‚a siÄ™ nie powiodÅ‚a.'; + $lang['strpasswordshort'] = 'HasÅ‚o jest za krótkie.'; + $lang['strpasswordconfirm'] = 'HasÅ‚o i potwierdzenie muszÄ… być takie same.'; + + // Groups + $lang['strgroup'] = 'Grupa'; + $lang['strgroups'] = 'Grupy'; + $lang['strnogroup'] = 'Nie znaleziono grupy.'; + $lang['strnogroups'] = 'Nie znaleziono grup.'; + $lang['strcreategroup'] = 'Utwórz grupÄ™'; + $lang['strshowallgroups'] = 'Pokaż wszystkie grupy'; + $lang['strgroupneedsname'] = 'Musisz nazwać grupÄ™.'; + $lang['strgroupcreated'] = 'Grupa zostaÅ‚a utworzona.'; + $lang['strgroupcreatedbad'] = 'Próba utworzenia grupy siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropgroup'] = 'Czy na pewno chcesz utworzyć grupÄ™ "%s"?'; + $lang['strgroupdropped'] = 'Grupa zostaÅ‚a usuniÄ™ta.'; + $lang['strgroupdroppedbad'] = 'Próba usuniÄ™cia grupy siÄ™ nie powiodÅ‚a.'; + $lang['strmembers'] = 'CzÅ‚onkowie'; + $lang['straddmember'] = 'Dodaj czÅ‚onka grupy'; + $lang['strmemberadded'] = 'CzÅ‚onek grupy zostaÅ‚ dodany.'; + $lang['strmemberaddedbad'] = 'Próba dodania czÅ‚onka grupy siÄ™ nie powiodÅ‚a.'; + $lang['strdropmember'] = 'UsuÅ„ czÅ‚onka grupy'; + $lang['strconfdropmember'] = 'Czy na pewno chcesz usunąć "%s" z grupy "%s"?'; + $lang['strmemberdropped'] = 'CzÅ‚onek grupy zostaÅ‚ usuniÄ™ty.'; + $lang['strmemberdroppedbad'] = 'Próba usuniÄ™cia czÅ‚onka grupy siÄ™ nie powiodÅ‚a.'; + + // Roles + $lang['strrole'] = 'Rola'; + $lang['strroles'] = 'Role'; + $lang['strinheritsprivs'] = 'Dziedziczyć uprawnienia?'; + $lang['strcreaterole'] = 'Utwórz rolÄ™'; + $lang['strcatupdate'] = 'Modyfikacja katalogów?'; + $lang['strcanlogin'] = 'Może siÄ™ logować?'; + $lang['strmaxconnections'] = 'Maks. ilość poÅ‚Ä…czeÅ„'; + $lang['strconfdroprole'] = 'Czy na pewno chcesz usunąć rolÄ™ "%s"?'; + $lang['strroledropped'] = 'Rola zostaÅ‚a usuniÄ™ta.'; + $lang['strroledroppedbad'] = 'Próba usuniÄ™cia roli siÄ™ nie powiodÅ‚a.'; + + // Privileges + $lang['strprivilege'] = 'Uprawnienie'; + $lang['strprivileges'] = 'Uprawnienia'; + $lang['strnoprivileges'] = 'Ten obiekt nie ma uprawnieÅ„.'; + $lang['strgrant'] = 'Nadaj'; + $lang['strrevoke'] = 'Zabierz'; + $lang['strgranted'] = 'Uprawnienia zostaÅ‚y nadane.'; + $lang['strgrantfailed'] = 'Próba nadania uprawnieÅ„ siÄ™ nie powiodÅ‚a.'; + $lang['strgrantbad'] = 'Musisz podać użytkownika lub grupÄ™, a także uprawnienia, jakie chcesz nadać.'; + $lang['strgrantor'] = 'Kto nadaÅ‚'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Baza danych'; + $lang['strdatabases'] = 'Bazy danych'; + $lang['strshowalldatabases'] = 'Pokaż wszystkie bazy danych'; + $lang['strnodatabase'] = 'Nie znaleziono bazy danych.'; + $lang['strnodatabases'] = 'Nie znaleziono żadnej bazy danych.'; + $lang['strcreatedatabase'] = 'Utwórz bazÄ™ danych'; + $lang['strdatabasename'] = 'Nazwa bazy danych'; + $lang['strdatabaseneedsname'] = 'Musisz nazwać bazÄ™ danych.'; + $lang['strdatabasecreated'] = 'Baza danych zostaÅ‚a utworzona.'; + $lang['strdatabasecreatedbad'] = 'Próba utworzenia bazy danych siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropdatabase'] = 'Czy na pewno chcesz usunąć bazÄ™ danych "%s"?'; + $lang['strdatabasedropped'] = 'Baza danych zostaÅ‚a usuniÄ™ta.'; + $lang['strdatabasedroppedbad'] = 'Próba usuniÄ™cia bazy danych siÄ™ nie powiodÅ‚a.'; + $lang['strentersql'] = 'Podaj polecenie SQL do wykonania:'; + $lang['strsqlexecuted'] = 'Polecenie SQL zostaÅ‚o wykonane.'; + $lang['strvacuumgood'] = 'Czyszczenie bazy zostaÅ‚o zakoÅ„czone.'; + $lang['strvacuumbad'] = 'Próba czyszczenia bazy siÄ™ nie powiodÅ‚a.'; + $lang['stranalyzegood'] = 'Analiza bazy zostaÅ‚a zakoÅ„czona.'; + $lang['stranalyzebad'] = 'Próba analizy siÄ™ nie powiodÅ‚a.'; + $lang['strreindexgood'] = 'Reindeksacja zostaÅ‚a zakoÅ„czona.'; + $lang['strreindexbad'] = 'Próba reindeksacji siÄ™ nie powiodÅ‚a.'; + $lang['strfull'] = 'PeÅ‚ne'; + $lang['strfreeze'] = 'Zamrożenie'; + $lang['strforce'] = 'Wymuszenie'; + $lang['strsignalsent'] = 'SygnaÅ‚ zostaÅ‚ wysÅ‚any.'; + $lang['strsignalsentbad'] = 'Próba wysÅ‚ania sygnaÅ‚u siÄ™ nie powiodÅ‚a.'; + $lang['strallobjects'] = 'Wszystkie obiekty'; + $lang['strdatabasealtered'] = 'Baza danych zostaÅ‚a zmieniona.'; + $lang['strdatabasealteredbad'] = 'Próba modyfikacji bazy danych siÄ™ nie powiodÅ‚a.'; + + // Views + $lang['strview'] = 'Widok'; + $lang['strviews'] = 'Widoki'; + $lang['strshowallviews'] = 'Pokaż wszystkie widoki'; + $lang['strnoview'] = 'Nie znaleziono widoku.'; + $lang['strnoviews'] = 'Nie znaleziono widoków.'; + $lang['strcreateview'] = 'Utwórz widok'; + $lang['strviewname'] = 'Nazwa widoku'; + $lang['strviewneedsname'] = 'Musisz nazwać widok.'; + $lang['strviewneedsdef'] = 'Musisz zdefiniować widok.'; + $lang['strviewneedsfields'] = 'Musisz podać kolumny, które majÄ… być widoczne w widoku.'; + $lang['strviewcreated'] = 'Widok zostaÅ‚ utworzony.'; + $lang['strviewcreatedbad'] = 'Próba utworzenia widoku siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropview'] = 'Czy na pewno chcesz usunąć widok "%s"?'; + $lang['strviewdropped'] = 'Widok zostaÅ‚ usuniÄ™ty.'; + $lang['strviewdroppedbad'] = 'Próba usuniÄ™cia widoku siÄ™ nie powiodÅ‚a.'; + $lang['strviewupdated'] = 'Widok zostaÅ‚ zaktualizowany.'; + $lang['strviewupdatedbad'] = 'Próba aktualizacji widoku siÄ™ nie powiodÅ‚a.'; + $lang['strviewlink'] = 'Klucze Å‚Ä…czÄ…ce'; + $lang['strviewconditions'] = 'Dodatkowe warunki'; + $lang['strcreateviewwiz'] = 'Utwórz widok przy użyciu kreatora widoków'; + + // Sequences + $lang['strsequence'] = 'Sekwencja'; + $lang['strsequences'] = 'Sekwencje'; + $lang['strshowallsequences'] = 'Pokaż wszystkie sekwencje'; + $lang['strnosequence'] = 'Nie znaleziono sekwencji.'; + $lang['strnosequences'] = 'Nie znaleziono sekwencji.'; + $lang['strcreatesequence'] = 'Utwórz sekwencjÄ™'; + $lang['strlastvalue'] = 'Ostatnia wartość'; + $lang['strincrementby'] = 'ZwiÄ™kszana o'; + $lang['strstartvalue'] = 'Wartość poczÄ…tkowa'; + $lang['strmaxvalue'] = 'Wartość maks.'; + $lang['strminvalue'] = 'Wartość min.'; + $lang['strcachevalue'] = 'Wartość keszowana'; + $lang['strlogcount'] = 'log_cnt'; + $lang['striscycled'] = 'czy cykliczna'; + $lang['strsequenceneedsname'] = 'Musisz nazwać sekwencjÄ™.'; + $lang['strsequencecreated'] = 'Sekwencja zostaÅ‚a utworzona.'; + $lang['strsequencecreatedbad'] = 'Próba utworzenia sekwencji siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropsequence'] = 'Czy na pewno chcesz usunąć sekwencjÄ™ "%s"?'; + $lang['strsequencedropped'] = 'Sekwencja zostaÅ‚a usuniÄ™ta.'; + $lang['strsequencedroppedbad'] = 'Próba usuniÄ™cia sekwencji siÄ™ nie powiodÅ‚a.'; + $lang['strsequencereset'] = 'Sekwencja zostaÅ‚a wyzerowana.'; + $lang['strsequenceresetbad'] = 'Próba zerowania sekwencji siÄ™ nie powiodÅ‚a.'; + $lang['straltersequence'] = 'ZmieÅ„ sekwencjÄ™'; + $lang['strsequencealtered'] = 'Sekwencja zostaÅ‚a zmieniona.'; + $lang['strsequencealteredbad'] = 'Próba modyfikacji sekwencji siÄ™ nie powiodÅ‚a.'; + $lang['strsetval'] = 'Ustaw wartość'; + $lang['strsequencesetval'] = 'Wartość sekwencji zostaÅ‚a ustawiona.'; + $lang['strsequencesetvalbad'] = 'Próba ustawienia wartoÅ›ci sekwencji siÄ™ nie powiodÅ‚a.'; + $lang['strnextval'] = 'ZwiÄ™ksz wartość sekwencjÄ™'; + $lang['strsequencenextval'] = 'Wartość sekwencji zostaÅ‚a zwiÄ™kszona.'; + $lang['strsequencenextvalbad'] = 'Próba zwiÄ™kszenia wartoÅ›ci sekwencji siÄ™ nie powiodÅ‚a.'; + + // Indeksy + $lang['strindex'] = 'Indeks'; + $lang['strindexes'] = 'Indeksy'; + $lang['strindexname'] = 'Nazwa indeksu'; + $lang['strshowallindexes'] = 'Pokaż wszystkie indeksy'; + $lang['strnoindex'] = 'Nie znaleziono indeksu.'; + $lang['strnoindexes'] = 'Nie znaleziono indeksów.'; + $lang['strcreateindex'] = 'Utwórz indeks'; + $lang['strtabname'] = 'Tab Name'; + $lang['strcolumnname'] = 'Nazwa kolumny'; + $lang['strindexneedsname'] = 'Musisz nazwać indeks.'; + $lang['strindexneedscols'] = 'W skÅ‚ad indeksu musi wchodzić przynajmniej jedna kolumna.'; + $lang['strindexcreated'] = 'Indeks zostaÅ‚ utworzony.'; + $lang['strindexcreatedbad'] = 'Próba utworzenia indeksu siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropindex'] = 'Czy na pewno chcesz usunąć indeks "%s"?'; + $lang['strindexdropped'] = 'Indeks zostaÅ‚ usuniÄ™ty.'; + $lang['strindexdroppedbad'] = 'Próba usuniÄ™cia indeksu siÄ™ nie powiodÅ‚a.'; + $lang['strkeyname'] = 'Nazwa klucza'; + $lang['struniquekey'] = 'Klucz Unikatowy'; + $lang['strprimarykey'] = 'Klucz Główny'; + $lang['strindextype'] = 'Typ indeksu'; + $lang['strtablecolumnlist'] = 'Kolumny w tabeli'; + $lang['strindexcolumnlist'] = 'Kolumny w indeksie'; + $lang['strconfcluster'] = 'Czy na pewno chcesz zklastrować "%s"?'; + $lang['strclusteredgood'] = 'Klastrowanie zostaÅ‚o zakoÅ„czone.'; + $lang['strclusteredbad'] = 'Próba klastrowania siÄ™ nie powiodÅ‚a.'; + $lang['strcluster'] = 'Klaster'; + + // Rules + $lang['strrules'] = 'ReguÅ‚y'; + $lang['strrule'] = 'ReguÅ‚a'; + $lang['strshowallrules'] = 'Pokaż wszystkie reguÅ‚y'; + $lang['strnorule'] = 'Nie znaleziono reguÅ‚y.'; + $lang['strnorules'] = 'Nie znaleziono reguÅ‚.'; + $lang['strcreaterule'] = 'Utwórz reguÅ‚Ä™'; + $lang['strrulename'] = 'Nazwa reguÅ‚y'; + $lang['strruleneedsname'] = 'Musisz nazwać reguÅ‚Ä™.'; + $lang['strrulecreated'] = 'ReguÅ‚a zostaÅ‚a utworzona.'; + $lang['strrulecreatedbad'] = 'Próba utworzenia reguÅ‚y siÄ™ nie powiodÅ‚a.'; + $lang['strconfdroprule'] = 'Czy na pewno chcesz usunąć reguÅ‚Ä™ "%s" na "%s"?'; + $lang['strruledropped'] = 'ReguÅ‚a zostaÅ‚a usuniÄ™ta.'; + $lang['strruledroppedbad'] = 'Próba usuniÄ™cia reguÅ‚y siÄ™ nie powiodÅ‚a.'; + + // Constraints + $lang['strconstraint'] = 'WiÄ™z integralnoÅ›ci'; + $lang['strconstraints'] = 'WiÄ™zy integralnoÅ›ci'; + $lang['strshowallconstraints'] = 'Pokaż wszystkie wiÄ™zy integralnoÅ›ci'; + $lang['strnoconstraints'] = 'Nie znaleziono wiÄ™zów integralnoÅ›ci.'; + $lang['strcreateconstraint'] = 'Utwórz wiÄ™zy integralnoÅ›ci'; + $lang['strconstraintcreated'] = 'WiÄ™zy integralnoÅ›ci zostaÅ‚y utworzone.'; + $lang['strconstraintcreatedbad'] = 'Próba utworzenia wiÄ™zów integralnoÅ›ci siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropconstraint'] = 'Czy na pewno chcesz usunąć wiÄ™zy integralnoÅ›ci "%s" na "%s"?'; + $lang['strconstraintdropped'] = 'WiÄ™zy integralnoÅ›ci zostaÅ‚y usuniÄ™te.'; + $lang['strconstraintdroppedbad'] = 'Próba usuniÄ™cia wiÄ™zów integralnoÅ›ci siÄ™ nie powiodÅ‚a.'; + $lang['straddcheck'] = 'Dodaj warunek'; + $lang['strcheckneedsdefinition'] = 'Musisz zdefiniować warunek.'; + $lang['strcheckadded'] = 'Warunek zostaÅ‚ dodany.'; + $lang['strcheckaddedbad'] = 'Próba dodania warunku siÄ™ nie powiodÅ‚a.'; + $lang['straddpk'] = 'Dodaj klucz główny'; + $lang['strpkneedscols'] = 'Klucz główny musi zawierać przynajmniej jednÄ… kolumnÄ™.'; + $lang['strpkadded'] = 'Klucz główny zostaÅ‚ dodany.'; + $lang['strpkaddedbad'] = 'Próba dodania klucza głównego siÄ™ nie powiodÅ‚a.'; + $lang['stradduniq'] = 'Dodaj klucz unikatowy'; + $lang['struniqneedscols'] = 'Klucz unikatowy musi zawierać przynajmniej jednÄ… kolumnÄ™.'; + $lang['struniqadded'] = 'Klucz unikatowy zostaÅ‚ dodany.'; + $lang['struniqaddedbad'] = 'Próba dodania klucza unikatowego siÄ™ nie powiodÅ‚a.'; + $lang['straddfk'] = 'Dodaj klucz obcy'; + $lang['strfkneedscols'] = 'Obcy klucz musi zawierać przynajmniej jednÄ… kolumnÄ™.'; + $lang['strfkneedstarget'] = 'Klucz obcy wymaga podania nazwy tabeli docelowej.'; + $lang['strfkadded'] = 'Klucz obcy zostaÅ‚ dodany.'; + $lang['strfkaddedbad'] = 'Próba dodania klucza obcego siÄ™ nie powiodÅ‚a.'; + $lang['strfktarget'] = 'Tabela docelowa'; + $lang['strfkcolumnlist'] = 'Kolumna w kluczu'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Funkcja'; + $lang['strfunctions'] = 'Funkcje'; + $lang['strshowallfunctions'] = 'Pokaż wszystkie funkcje'; + $lang['strnofunction'] = 'Nie znaleziono funkcji.'; + $lang['strnofunctions'] = 'Nie znaleziono funkcji.'; + $lang['strcreateplfunction'] = 'Utwórz funkcjÄ™ SQL/PL'; + $lang['strcreateinternalfunction'] = 'Utwórz funkcjÄ™ wewnÄ™trznÄ…'; + $lang['strcreatecfunction'] = 'Utwórz funkcjÄ™ C'; + $lang['strfunctionname'] = 'Nazwa funkcji'; + $lang['strreturns'] = 'Zwraca'; + $lang['strproglanguage'] = 'JÄ™zyk'; + $lang['strfunctionneedsname'] = 'Musisz nazwać funkcjÄ™.'; + $lang['strfunctionneedsdef'] = 'Musisz zdefiniować funkcjÄ™.'; + $lang['strfunctioncreated'] = 'Funkcja zostaÅ‚a utworzona.'; + $lang['strfunctioncreatedbad'] = 'Próba utworzenia funkcji siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropfunction'] = 'Czy na pewno chcesz usunąć funkcjÄ™ "%s"?'; + $lang['strfunctiondropped'] = 'Funkcja zostaÅ‚a usuniÄ™ta.'; + $lang['strfunctiondroppedbad'] = 'Próba usuniÄ™cia funkcji siÄ™ nie powiodÅ‚a.'; + $lang['strfunctionupdated'] = 'Funkcja zostaÅ‚a zaktualizowana.'; + $lang['strfunctionupdatedbad'] = 'Próba aktualizacji funkcji siÄ™ nie powiodÅ‚a.'; + $lang['strobjectfile'] = 'Plik obiektów'; + $lang['strlinksymbol'] = 'ÅÄ…cz symbol'; + $lang['strarguments'] = 'Argumenty'; + $lang['strargname'] = 'Nazwa'; + $lang['strargmode'] = 'Tryb'; + $lang['strargtype'] = 'Typ'; + $lang['strargadd'] = 'Dodaj nowy argument'; + $lang['strargremove'] = 'UsuÅ„ ten argument'; + $lang['strargnoargs'] = 'Ta funkcja nie bÄ™dzie wymagaÅ‚a żadnych argumentów.'; + $lang['strargenableargs'] = 'WÅ‚Ä…cz podawanie argumentów tej funkcji.'; + $lang['strargnorowabove'] = 'Nad tym wierszem musi być wiersz.'; + $lang['strargnorowbelow'] = 'Pod tym wierszem musi być inny wiersz.'; + $lang['strargraise'] = 'PrzesuÅ„ w górÄ™.'; + $lang['strarglower'] = 'PrzesuÅ„ w dół.'; + $lang['strargremoveconfirm'] = 'Czy na pewno chcesz usunąć ten argument? Tej operacji nie bÄ™dzie można cofnąć.'; + + + // Triggers + $lang['strtrigger'] = 'Procedura wyzwalana'; + $lang['strtriggers'] = 'Procedury wyzwalane'; + $lang['strshowalltriggers'] = 'Pokaż wszystkie procedury wyzwalane'; + $lang['strnotrigger'] = 'Nie znaleziono procedury wyzwalanej.'; + $lang['strnotriggers'] = 'Nie znaleziono procedur wyzwalanych.'; + $lang['strcreatetrigger'] = 'Utwórz procedurÄ™ wyzwalanÄ…'; + $lang['strtriggerneedsname'] = 'Musisz nazwać procedurÄ™ wyzwalanÄ….'; + $lang['strtriggerneedsfunc'] = 'Musisz podać funkcjÄ™ procedury wyzwalanej.'; + $lang['strtriggercreated'] = 'Procedura wyzwalana zostaÅ‚a utworzona.'; + $lang['strtriggercreatedbad'] = 'Próba utworzenia procedury wyzwalanej siÄ™ nie powiodÅ‚a.'; + $lang['strconfdroptrigger'] = 'Czy na pewno chcesz usunąć procedurÄ™ "%s" wyzwalanÄ… przez "%s"?'; + $lang['strconfenabletrigger'] = 'Czy na pewno chcesz wÅ‚Ä…czyć procedurÄ™ wyzwalanÄ… "%s" on "%s"?'; + $lang['strconfdisabletrigger'] = 'Czy na pewno chcesz wyÅ‚Ä…czyć procedurÄ™ wyzwalanÄ… "%s" on "%s"?'; + $lang['strtriggerdropped'] = 'Procedura wyzwalana zostaÅ‚a usuniÄ™ta.'; + $lang['strtriggerdroppedbad'] = 'Próba usuniÄ™cia procedury wyzwalanej siÄ™ nie powiodÅ‚a.'; + $lang['strtriggerenabled'] = 'Procedura wyzwalana zostaÅ‚a wÅ‚Ä…czona.'; + $lang['strtriggerenabledbad'] = 'Próba wÅ‚Ä…czenia procedury wyzwalanej siÄ™ nie powiodÅ‚a.'; + $lang['strtriggerdisabled'] = 'Procedura wyzwalana zostaÅ‚a wyÅ‚Ä…czona.'; + $lang['strtriggerdisabledbad'] = 'Próba wyÅ‚Ä…czenia procedury wyzwalanej siÄ™ nie powiodÅ‚a.'; + $lang['strtriggeraltered'] = 'Procedura wyzwalana zostaÅ‚a zmieniona.'; + $lang['strtriggeralteredbad'] = 'Próba modyfikacji procedury wyzwalanej siÄ™ nie powiodÅ‚a.'; + $lang['strforeach'] = 'Dla wszystkich'; + + // Types + $lang['strtype'] = 'Typ'; + $lang['strtypes'] = 'Typy'; + $lang['strshowalltypes'] = 'Pokaż wszystkie typy'; + $lang['strnotype'] = 'Nie znaleziono typu.'; + $lang['strnotypes'] = 'Nie znaleziono typów.'; + $lang['strcreatetype'] = 'Utwórz typ'; + $lang['strcreatecomptype'] = 'Utwórz typ zÅ‚ożony'; + $lang['strtypeneedsfield'] = 'Musisz podać przynajmniej jedno pole.'; + $lang['strtypeneedscols'] = 'Musisz podać poprawnÄ… ilość pól.'; + $lang['strtypename'] = 'Nazwa typu'; + $lang['strinputfn'] = 'Funkcja wejÅ›ciowa'; + $lang['stroutputfn'] = 'Funkcja wyjÅ›ciowa'; + $lang['strpassbyval'] = 'Przekazywany przez wartość?'; + $lang['stralignment'] = 'Wyrównanie bajtowe'; + $lang['strelement'] = 'Typ elementów'; + $lang['strdelimiter'] = 'Znak oddzielajÄ…cy elementy tabeli'; + $lang['strstorage'] = 'Technika przechowywania'; + $lang['strfield'] = 'Pole'; + $lang['strnumfields'] = 'Ilość pól'; + $lang['strtypeneedsname'] = 'Musisz nazwać typ.'; + $lang['strtypeneedslen'] = 'Musisz podać dÅ‚ugość typu.'; + $lang['strtypecreated'] = 'Typ zostaÅ‚ utworzony.'; + $lang['strtypecreatedbad'] = 'Próba utworzenia typu siÄ™ nie powiodÅ‚a.'; + $lang['strconfdroptype'] = 'Czy na pewno chcesz usunąć typ "%s"?'; + $lang['strtypedropped'] = 'Typ zostaÅ‚ usuniÄ™ty.'; + $lang['strtypedroppedbad'] = 'Próba usuniÄ™cia typu siÄ™ nie powiodÅ‚a.'; + $lang['strflavor'] = 'Flavor'; + $lang['strbasetype'] = 'podstawowy'; + $lang['strcompositetype'] = 'zÅ‚ożony'; + $lang['strpseudotype'] = 'pseudo'; + + // Schemas + $lang['strschema'] = 'Schemat'; + $lang['strschemas'] = 'Schematy'; + $lang['strshowallschemas'] = 'Pokaż wszystkie schematy'; + $lang['strnoschema'] = 'Nie znaleziono schematu.'; + $lang['strnoschemas'] = 'Nie znaleziono schematów.'; + $lang['strcreateschema'] = 'Utwórz schemat'; + $lang['strschemaname'] = 'Nazwa schematu'; + $lang['strschemaneedsname'] = 'Musisz nadać schematowi nazwÄ™.'; + $lang['strschemacreated'] = 'Schemat zostaÅ‚ utworzony.'; + $lang['strschemacreatedbad'] = 'Próba utworzenia schematu siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropschema'] = 'Czy na pewno chcesz usunąć schemat "%s"?'; + $lang['strschemadropped'] = 'Schemat zostaÅ‚ usuniÄ™ty.'; + $lang['strschemadroppedbad'] = 'Próba usuniÄ™cia schematu siÄ™ nie powiodÅ‚a.'; + $lang['strschemaaltered'] = 'Schemat zostaÅ‚ zmieniony.'; + $lang['strschemaalteredbad'] = 'Próba zmiany schematu siÄ™ nie powiodÅ‚a.'; + $lang['strsearchpath'] = 'Åšcieżka wyszukiwania schematu'; + + // Reports + + // Domeny + $lang['strdomain'] = 'Domena'; + $lang['strdomains'] = 'Domeny'; + $lang['strshowalldomains'] = 'Pokaż wszystkie domeny'; + $lang['strnodomains'] = 'Nie znaleziono domen.'; + $lang['strcreatedomain'] = 'Utwórz domenÄ™'; + $lang['strdomaindropped'] = 'Domena zostaÅ‚a usuniÄ™ta.'; + $lang['strdomaindroppedbad'] = 'Próba usuniÄ™cia domeny siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropdomain'] = 'Czy na pewno chcesz usunąć domenÄ™ "%s"?'; + $lang['strdomainneedsname'] = 'Musisz nazwać domenÄ™.'; + $lang['strdomaincreated'] = 'Domena zostaÅ‚a utworzona.'; + $lang['strdomaincreatedbad'] = 'Próba utworzenia domeny siÄ™ nie powiodÅ‚a.'; + $lang['strdomainaltered'] = 'Domena zostaÅ‚a zmieniona.'; + $lang['strdomainalteredbad'] = 'Próba modyfikacji domeny siÄ™ nie powiodÅ‚a.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operatory'; + $lang['strshowalloperators'] = 'Pokaż wszystkie operatory'; + $lang['strnooperator'] = 'Nie znaleziono operatora.'; + $lang['strnooperators'] = 'Nie znaleziono operatorów.'; + $lang['strcreateoperator'] = 'Utwórz operator'; + $lang['strleftarg'] = 'Typ lewego argumentu'; + $lang['strrightarg'] = 'Typ prawego argumentu'; + $lang['strcommutator'] = 'Komutator'; + $lang['strnegator'] = 'Negacja'; + $lang['strrestrict'] = 'Zastrzeżenie'; + $lang['strjoin'] = 'PoÅ‚Ä…czenie'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Lewe sortowanie'; + $lang['strrightsort'] = 'Prawe sortowanie'; + $lang['strlessthan'] = 'Mniej niż'; + $lang['strgreaterthan'] = 'WiÄ™cej niż'; + $lang['stroperatorneedsname'] = 'Musisz nazwać operator.'; + $lang['stroperatorcreated'] = 'Operator zostaÅ‚ utworzony.'; + $lang['stroperatorcreatedbad'] = 'Próba utworzenia operatora siÄ™ nie powiodÅ‚a.'; + $lang['strconfdropoperator'] = 'Czy na pewno chcesz usunąć operator "%s"?'; + $lang['stroperatordropped'] = 'Operator zostaÅ‚ usuniÄ™ty.'; + $lang['stroperatordroppedbad'] = 'Próba usuniÄ™cia operatora siÄ™ nie powiodÅ‚a.'; + + // Casts + $lang['strcasts'] = 'Rzutowania'; + $lang['strnocasts'] = 'Nie znaleziono rzutowaÅ„.'; + $lang['strsourcetype'] = 'Typ źródÅ‚owy'; + $lang['strtargettype'] = 'Typ docelowy'; + $lang['strimplicit'] = 'Domniemany'; + $lang['strinassignment'] = 'W przydziale'; + $lang['strbinarycompat'] = '(Kompatybilny binarnie)'; + + // Conversions + $lang['strconversions'] = 'Konwersje'; + $lang['strnoconversions'] = 'Nie znaleziono konwersji.'; + $lang['strsourceencoding'] = 'Kodowanie źródÅ‚owe'; + $lang['strtargetencoding'] = 'Kodowanie docelowe'; + + // Languages + $lang['strlanguages'] = 'JÄ™zyki'; + $lang['strnolanguages'] = 'Nie znaleziono jÄ™zyków.'; + $lang['strtrusted'] = 'Zaufany'; + + // Info + $lang['strnoinfo'] = 'Brak informacji na ten temat'; + $lang['strreferringtables'] = 'Tabele zależne'; + $lang['strparenttables'] = 'Tabela nadrzÄ™dne'; + $lang['strchildtables'] = 'Tabela podrzÄ™dna'; + + // Aggregates + $lang['straggregate'] = 'Funkcja agregujÄ…ca'; + $lang['straggregates'] = 'Funkcje agregujÄ…ce'; + $lang['strnoaggregates'] = 'Nie znaleziono funkcji agregujÄ…cych.'; + $lang['stralltypes'] = '(Wszystkie typy)'; +$lang['straggrtransfn'] = 'Transition function'; + $lang['strcreateaggregate'] = 'Utwórz funkcjÄ™ agregujÄ…cÄ…'; + $lang['straggrbasetype'] = 'Typ danych wejÅ›ciowych'; +$lang['straggrsfunc'] = 'State transition function'; +$lang['straggrffunc'] = 'Final function'; + $lang['straggrinitcond'] = 'Warunek poczÄ…tkowy'; + $lang['straggrsortop'] = 'Operator sortowania'; + $lang['strconfdropaggregate'] = 'Czy na pewno chcesz usunąć funkcjÄ™ agregujÄ…cÄ… "%s"?'; + $lang['straggregatedropped'] = 'Funkcja agregujÄ…ca zostaÅ‚a usuniÄ™ta.'; + $lang['straggregatedroppedbad'] = 'Próba usuniÄ™cia funkcji agregujÄ…cej siÄ™ nie powiodÅ‚a.'; + $lang['stralteraggregate'] = 'ZmieÅ„ funkcjÄ™ agregujÄ…cÄ…'; + $lang['straggraltered'] = 'Funkcja agregujÄ…ca zostaÅ‚a zmieniona.'; + $lang['straggralteredbad'] = 'Próba zmiany funkcji agregujÄ…cej siÄ™ nie powiodÅ‚a.'; + $lang['straggrneedsname'] = 'Musisz podać nazwÄ™ funkcji agregujÄ…cej'; + $lang['straggrneedsbasetype'] = 'Musisz podać typ danych wejÅ›ciowych funkcji agregujÄ…cej'; +$lang['straggrneedssfunc'] = 'You must specify the name of the state transition function for the aggregate'; +$lang['straggrneedsstype'] = 'You must specify the data type for the aggregate\'s state value'; + $lang['straggrcreated'] = 'Funkcja agregujÄ…ca zostaÅ‚a utworzona.'; + $lang['straggrcreatedbad'] = 'Próba utworzenia funkcji agregujÄ…cej siÄ™ nie powiodÅ‚a.'; + $lang['straggrshowall'] = 'Pokaż wszystkie funkcje agregujÄ…ce'; + + // Operator Classes + $lang['stropclasses'] = 'Klasy operatorów'; + $lang['strnoopclasses'] = 'Nie znaleziono klas operatorów.'; + $lang['straccessmethod'] = 'Metoda dostÄ™pu'; + + // Stats and performance + $lang['strrowperf'] = 'Wydajność wierszowa'; + $lang['strioperf'] = 'Wydajność I/O'; + $lang['stridxrowperf'] = 'Wydajność indeksu wierszowego'; + $lang['stridxioperf'] = 'Wydajność indeksu We/Wy'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sekwencyjny'; + $lang['strscan'] = 'Skanuj'; + $lang['strread'] = 'Czytaj'; + $lang['strfetch'] = 'Pobierz'; + $lang['strheap'] = 'Sterta'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'Indeks TOAST'; + $lang['strcache'] = 'Kesz'; + $lang['strdisk'] = 'Dysk'; + $lang['strrows2'] = 'Wiersze'; + + // Tablespaces + $lang['strtablespace'] = 'PrzestrzeÅ„ tabel'; + $lang['strtablespaces'] = 'Przestrzenie tabel'; + $lang['strshowalltablespaces'] = 'Pokaż wszystkie przestrzenie tabel'; + $lang['strnotablespaces'] = 'Nie znaleziono przestrzeni tabel.'; + $lang['strcreatetablespace'] = 'Utwórz przestrzeÅ„ tabel'; + $lang['strlocation'] = 'PoÅ‚ożenie'; + $lang['strtablespaceneedsname'] = 'Musisz podać nazwÄ™ przestrzeni tabel.'; + $lang['strtablespaceneedsloc'] = 'Musisz podać nazwÄ™ katalogu, w którym chcesz utworzyć przestrzeÅ„ tabel.'; + $lang['strtablespacecreated'] = 'PrzestrzeÅ„ tabel zostaÅ‚a utworzona.'; + $lang['strtablespacecreatedbad'] = 'Próba utworzenia przestrzeni tabel siÄ™ nie powiodÅ‚a.'; + $lang['strconfdroptablespace'] = 'Czy na pewno chcesz usunąć przestrzeÅ„ tabel "%s"?'; + $lang['strtablespacedropped'] = 'PrzestrzeÅ„ tabel zostaÅ‚a usuniÄ™ta.'; + $lang['strtablespacedroppedbad'] = 'Próba usuniÄ™cia przestrzeni tabel siÄ™ nie powiodÅ‚a.'; + $lang['strtablespacealtered'] = 'PrzestrzeÅ„ tabel zostaÅ‚a zmieniona.'; + $lang['strtablespacealteredbad'] = 'Próba modyfikacji przestrzeni tabel siÄ™ nie powiodÅ‚a.'; + + + // Miscellaneous + $lang['strtopbar'] = '%s uruchomiony na %s:%s -- JesteÅ› zalogowany jako "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Pomoc'; + $lang['strhelpicon'] = '?'; + $lang['strlogintitle'] = 'Zaloguj do %s'; + $lang['strlogoutmsg'] = 'Wylogowano z %s'; + $lang['strloading'] = 'ÅadujÄ™...'; + $lang['strerrorloading'] = 'BÅ‚Ä…d Å‚adowania'; + $lang['strclicktoreload'] = 'Kliknij aby odÅ›wieżyć'; + + //Autovacuum + $lang['strautovacuum'] = 'Czyszczenie automatyczne'; + $lang['strturnedon'] = 'WÅ‚Ä…czone'; + $lang['strturnedoff'] = 'WyÅ‚Ä…czone'; + $lang['strenabled'] = 'Aktywne'; + $lang['strvacuumbasethreshold'] = 'Podstawowy próg czyszczenia'; + $lang['strvacuumscalefactor'] = 'Współczynnik czyszczenia'; + $lang['stranalybasethreshold'] = 'Podstawowy próg analizy'; + $lang['stranalyzescalefactor'] = 'Współczynnik analizy'; + $lang['strvacuumcostdelay'] = 'Opóźnienie po przekroczeniu kosztu czyszczenia'; + $lang['strvacuumcostlimit'] = 'Limit kosztu czyszczenia'; + + //Table-level Locks + $lang['strlocks'] = 'Blokady'; + $lang['strtransaction'] = 'ID transakcji'; + $lang['strprocessid'] = 'ID procesu'; + $lang['strmode'] = 'Tryb blokowania'; + $lang['strislockheld'] = 'Czy blokada obowiÄ…zuje?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Przygotowane transakcje'; + $lang['strxactid'] = 'ID transakcji'; + $lang['strgid'] = 'Globalny ID'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-br.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-br.php new file mode 100644 index 00000000..8f956583 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-br.php @@ -0,0 +1,898 @@ +'; + $lang['strfirst'] = '<< Primeiro'; + $lang['strlast'] = 'Último >>'; + $lang['strfailed'] = 'Falhou'; + $lang['strcreate'] = 'Criar'; + $lang['strcreated'] = 'Criado'; + $lang['strcomment'] = 'Comentário'; + $lang['strlength'] = 'Tamanho'; + $lang['strdefault'] = 'Padrão'; + $lang['stralter'] = 'Alterar'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Cancelar'; + $lang['strkill'] = 'Encerrar'; + $lang['strac'] = 'Habilitar AutoComplete'; + $lang['strsave'] = 'Salvar'; + $lang['strreset'] = 'Reiniciar'; + $lang['strrestart'] = 'Reinicializar'; + $lang['strinsert'] = 'Inserir'; + $lang['strselect'] = 'Selecionar'; + $lang['strdelete'] = 'Deletar'; + $lang['strupdate'] = 'Atualizar'; + $lang['strreferences'] = 'Referências'; + $lang['stryes'] = 'Sim'; + $lang['strno'] = 'Não'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = 'Editar'; + $lang['strcolumn'] = 'Coluna'; + $lang['strcolumns'] = 'Colunas'; + $lang['strrows'] = 'linha(s)'; + $lang['strrowsaff'] = 'linha(s) afetadas.'; + $lang['strobjects'] = 'objeto(s)'; + $lang['strback'] = 'Voltar'; + $lang['strqueryresults'] = 'Resultados da consulta'; + $lang['strshow'] = 'Exibir'; + $lang['strempty'] = 'Vazio'; + $lang['strlanguage'] = 'Linguagem'; + $lang['strencoding'] = 'Codificação'; + $lang['strvalue'] = 'Valor'; + $lang['strunique'] = 'Único(a)'; + $lang['strprimary'] = 'Primário(a)'; + $lang['strexport'] = 'Exportar'; + $lang['strimport'] = 'Importar'; + $lang['strallowednulls'] = 'Caracteres NULL permitidos'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Texto/campo vazio'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Administração'; + $lang['strvacuum'] = 'Vácuo'; + $lang['stranalyze'] = 'Analisar'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'Clusterizado?'; + $lang['strreindex'] = 'Reindexar'; + $lang['strexecute'] = 'Executar'; + $lang['stradd'] = 'Adicionar'; + $lang['strevent'] = 'Evento'; + $lang['strwhere'] = 'Onde'; + $lang['strinstead'] = 'Faça preferivelmente'; + $lang['strwhen'] = 'Quando'; + $lang['strformat'] = 'Formato'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'Confirma'; + $lang['strexpression'] = 'Expressão'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Expandir'; + $lang['strcollapse'] = 'Reduzir'; + $lang['strfind'] = 'Encontrar'; + $lang['stroptions'] = 'Opções'; + $lang['strrefresh'] = 'Atualizar'; + $lang['strdownload'] = 'Download'; + $lang['strdownloadgzipped'] = 'Download compactado com gzip'; + $lang['strinfo'] = 'Informações'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Avançado'; + $lang['strvariables'] = 'Variáveis'; + $lang['strprocess'] = 'Processo'; + $lang['strprocesses'] = 'Processos'; + $lang['strsetting'] = 'Valor atribuído'; + $lang['streditsql'] = 'Editar SQL'; + $lang['strruntime'] = 'Tempo de execução total: %s ms'; + $lang['strpaginate'] = 'Paginar resultados'; + $lang['struploadscript'] = 'ou carregue o script SQL de um arquivo:'; + $lang['strstarttime'] = 'Hora de início'; + $lang['strfile'] = 'Arquivo'; + $lang['strfileimported'] = 'Arquivo importado.'; + $lang['strtrycred'] = 'Utilizar estas credenciais para todos os servidores'; + $lang['strconfdropcred'] = 'Por motivos de segurança, a desconexão irá destruir suas informações de login compartilhado. Tem certeza que deseja se desconectar?'; + $lang['stractionsonmultiplelines'] = 'Ações sobre múltiplas linhas'; + $lang['strselectall'] = 'Selecionar tudo'; + $lang['strunselectall'] = 'Desmarcar tudo'; + $lang['strlocale'] = 'Local'; + $lang['strcollation'] = 'Comparação'; + $lang['strctype'] = 'Tipo de codificação'; + $lang['strdefaultvalues'] = 'Valores padrão'; + $lang['strnewvalues'] = 'Novos valores'; + $lang['strstart'] = 'Iniciar'; + $lang['strstop'] = 'Parar'; + $lang['strgotoppage'] = 'Topo da página'; + $lang['strtheme'] = 'Tema'; + + // Admin + $lang['stradminondatabase'] = 'As tarefas administrativas a seguir se aplicam em toda a base de dados %s.'; + $lang['stradminontable'] = 'As tarefas administrativas a seguir se aplicam na tabela %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'Histórico'; + $lang['strnohistory'] = 'Sem histórico.'; + $lang['strclearhistory'] = 'Limpar histórico'; + $lang['strdelhistory'] = 'Deletar do histórico'; + $lang['strconfdelhistory'] = 'Realmente remover esta entrada do histórico?'; + $lang['strconfclearhistory'] = 'Realmente limpar o histórico?'; + $lang['strnodatabaseselected'] = 'Por favor, selecione uma base de dados.'; + + // Database sizes + $lang['strnoaccess'] = 'Sem acesso'; + $lang['strsize'] = 'Tamanho'; + $lang['strbytes'] = 'bytes'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Esta aplicação opera melhor em um navegador com suporte a frames, mas pode ser utilizada sem frames acessando o link abaixo.'; + $lang['strnoframeslink'] = 'Utilizar sem frames'; + $lang['strbadconfig'] = 'Seu arquivo config.inc.php está desatualizado. Você terá que gerá-lo novamente a partir do novo arquivo config.inc.php-dist.'; + $lang['strnotloaded'] = 'Sua instalação do PHP não têm suporte ao PostgreSQL. Você deverá recompilar o PHP utilizando a opção de configuração --with-pgsql (GNU-Linux) ou habilitar a extensão extension=php_pgsql.dll no php.ini (Microsoft Windows).'; + $lang['strpostgresqlversionnotsupported'] = 'Versão do PostgreSQL não suportada. Por favor, atualize para a sua versão %s ou posterior.'; + $lang['strbadschema'] = 'Esquema especificado inválido.'; + $lang['strbadencoding'] = 'Falha ao atribuir a codificação do cliente na base de dados.'; + $lang['strsqlerror'] = 'Erro de SQL:'; + $lang['strinstatement'] = 'No bloco:'; + $lang['strinvalidparam'] = 'Parâmetros de script inválidos.'; + $lang['strnodata'] = 'Nenhuma linha encontrada.'; + $lang['strnoobjects'] = 'Nenhum objeto encontrado.'; + $lang['strrownotunique'] = 'Nenhum identificador único para esta linha.'; + $lang['strnouploads'] = 'O upload de arquivos está desabilitado.'; + $lang['strimporterror'] = 'Erro de importação.'; + $lang['strimporterror-fileformat'] = 'Erro de importação: Falhou ao determinar automáticamente o formato do arquivo.'; + $lang['strimporterrorline'] = 'Erro de importação na linha %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Erro de importação na linha %s: Linha não possui o número correto de colunas.'; + $lang['strimporterror-uploadedfile'] = 'Erro de importação: O arquivo não pode ser carregado para o servidor'; + $lang['strcannotdumponwindows'] = 'O dumping de uma tabela complexa e um nome de esquema não é suportado no Windows.'; + $lang['strinvalidserverparam'] = 'Tentativa de conectar com um parâmetro de servidor inválido, possivelmente alguém está tentando hackear o seu sistema.'; + $lang['strnoserversupplied'] = 'Nenhum servidor informado!'; + $lang['strbadpgdumppath'] = 'Erro de exportação: Falha ao executar pg_dump (caminho apontado no seu conf/config.inc.php : %s). Por favor, ajuste este diretório na sua configuração e relogue no sistema.'; + $lang['strbadpgdumpallpath'] = 'Erro de exportação: Falha ao executar pg_dumpall (caminho apontado no seu conf/config.inc.php : %s). Por favor, este diretório na sua configuração e relogue no sistema.'; + $lang['strconnectionfail'] = 'A conexão falhou.'; + + // Tables + $lang['strtable'] = 'Tabela'; + $lang['strtables'] = 'Tabelas'; + $lang['strshowalltables'] = 'Exibir todas as tabelas'; + $lang['strnotables'] = 'Nenhuma tabela encontrada.'; + $lang['strnotable'] = 'Nenhuma tabela encontrada.'; + $lang['strcreatetable'] = 'Criar tabela'; + $lang['strcreatetablelike'] = 'Criar tabela similar'; + $lang['strcreatetablelikeparent'] = 'Tabela de origem'; + $lang['strcreatelikewithdefaults'] = 'INCLUDE DEFAULTS'; + $lang['strcreatelikewithconstraints'] = 'INCLUDE CONSTRAINTS'; + $lang['strcreatelikewithindexes'] = 'INCLUDE INDEXES'; + $lang['strtablename'] = 'Nome da tabela'; + $lang['strtableneedsname'] = 'Você deve informar um nome para a sua tabela.'; + $lang['strtablelikeneedslike'] = 'Você deve informar uma tabela para copiar suas propriedades.'; + $lang['strtableneedsfield'] = 'Você deve informar ao menos um campo.'; + $lang['strtableneedscols'] = 'Você deve informar um número de colunas válido.'; + $lang['strtablecreated'] = 'Tabela criada.'; + $lang['strtablecreatedbad'] = 'Falha ao criar a tabela.'; + $lang['strconfdroptable'] = 'Você têm certeza que deseja deletar a tabela "%s"?'; + $lang['strtabledropped'] = 'Tabela deletada.'; + $lang['strtabledroppedbad'] = 'Falha ao deletar a tabela.'; + $lang['strconfemptytable'] = 'Você têm certeza que deseja esvaziar a tabela "%s"?'; + $lang['strtableemptied'] = 'Tabela esvaziada.'; + $lang['strtableemptiedbad'] = 'Falha ao esvaziar a tabela.'; + $lang['strinsertrow'] = 'Inserir linha'; + $lang['strrowinserted'] = 'Linha inserida.'; + $lang['strrowinsertedbad'] = 'Falha ao inserir a linha.'; + $lang['strnofkref'] = 'Não há valor correspondendo na chave estrangeira %s.'; + $lang['strrowduplicate'] = 'Falha ao inserir a linha, tentativa de inserção duplicada.'; + $lang['streditrow'] = 'Editar linha'; + $lang['strrowupdated'] = 'Linha atualizada.'; + $lang['strrowupdatedbad'] = 'Falha ao atualizar a linha.'; + $lang['strdeleterow'] = 'Deletar linha'; + $lang['strconfdeleterow'] = 'Você têm certeza que deseja deletar esta linha?'; + $lang['strrowdeleted'] = 'Linha deletada.'; + $lang['strrowdeletedbad'] = 'Falha ao deletar a linha.'; + $lang['strinsertandrepeat'] = 'Inserir & Repetir'; + $lang['strnumcols'] = 'Número de colunas'; + $lang['strcolneedsname'] = 'Você deve informar um nome para a coluna'; + $lang['strselectallfields'] = 'Selecionar todos os campos'; + $lang['strselectneedscol'] = 'Você deve exibir ao menos uma coluna.'; + $lang['strselectunary'] = 'Operadores unários não podem ter valores.'; + $lang['strcolumnaltered'] = 'Coluna alterada.'; + $lang['strcolumnalteredbad'] = 'Falha ao alterar a coluna.'; + $lang['strconfdropcolumn'] = 'Você têm certeza que deseja remover a coluna "%s" da tabela "%s"?'; + $lang['strcolumndropped'] = 'Coluna removida.'; + $lang['strcolumndroppedbad'] = 'Falha ao remover a coluna.'; + $lang['straddcolumn'] = 'Adicionar coluna'; + $lang['strcolumnadded'] = 'Coluna adicionada.'; + $lang['strcolumnaddedbad'] = 'Falha ao adicionar a coluna.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabela alterada.'; + $lang['strtablealteredbad'] = 'Falha ao alterar a tabela.'; + $lang['strdataonly'] = 'Somente dados'; + $lang['strstructureonly'] = 'Somente estrutura'; + $lang['strstructureanddata'] = 'Estrutura e dados'; + $lang['strtabbed'] = 'Tabulado'; + $lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Você têm certeza que deseja realizar vácuo em "%s"?'; + $lang['strconfanalyzetable'] = 'Você têm certeza que deseja analizar "%s"?'; + $lang['strconfreindextable'] = 'Você têm certeza que deseja reindexar "%s"?'; + $lang['strconfclustertable'] = 'Você têm certeza que deseja clusterizar "%s"?'; + $lang['strestimatedrowcount'] = 'Número estimado de linhas'; + $lang['strspecifytabletoanalyze'] = 'Você deve especificar ao menos uma tabela para analisar.'; + $lang['strspecifytabletoempty'] = 'Você deve especificar ao menos uma tabela para esvaziar.'; + $lang['strspecifytabletodrop'] = 'Você deve especificar ao menos uma tabela para deletar.'; + $lang['strspecifytabletovacuum'] = 'Você deve especificar ao menos uma tabela para o vácuo.'; + $lang['strspecifytabletoreindex'] = 'Você deve especificar ao menos uma tabela para reindexar.'; + $lang['strspecifytabletocluster'] = 'Você deve especificar ao menos uma tabela para clusterizar.'; + $lang['strnofieldsforinsert'] = 'Você não pode inserir uma linha em uma tabela sem colunas.'; + + // Columns + $lang['strcolprop'] = 'Propriedades da coluna'; + $lang['strnotableprovided'] = 'Nenhuma tabela informada!'; + + // Users + $lang['struser'] = 'Usuário'; + $lang['strusers'] = 'Usuários'; + $lang['strusername'] = 'Nome de usuário'; + $lang['strpassword'] = 'Senha'; + $lang['strsuper'] = 'Super usuário?'; + $lang['strcreatedb'] = 'Criar DB?'; + $lang['strexpires'] = 'Expira'; + $lang['strsessiondefaults'] = 'Padrões de sessão'; + $lang['strnousers'] = 'Nenhum usuário encontrado.'; + $lang['struserupdated'] = 'Usuário atualizado.'; + $lang['struserupdatedbad'] = 'Falha ao atualizar usuário.'; + $lang['strshowallusers'] = 'Exibir todos os usuários'; + $lang['strcreateuser'] = 'Criar usuário'; + $lang['struserneedsname'] = 'Você deve informar um nome para o seu usuário.'; + $lang['strusercreated'] = 'Usuário criado.'; + $lang['strusercreatedbad'] = 'Falha ao criar usuário.'; + $lang['strconfdropuser'] = 'Você têm certeza que deseja deletar o usuário "%s"?'; + $lang['struserdropped'] = 'Usuário deletado.'; + $lang['struserdroppedbad'] = 'Falha ao deletar usuário.'; + $lang['straccount'] = 'Conta'; + $lang['strchangepassword'] = 'Alterar senha'; + $lang['strpasswordchanged'] = 'Senha alterada.'; + $lang['strpasswordchangedbad'] = 'Falha ao alterar a senha.'; + $lang['strpasswordshort'] = 'A senha é muito curta.'; + $lang['strpasswordconfirm'] = 'A confirmação de senha não confere.'; + + // Groups + $lang['strgroup'] = 'Grupo'; + $lang['strgroups'] = 'Grupos'; + $lang['strshowallgroups'] = 'Exibir todos os grupos'; + $lang['strnogroup'] = 'Grupo não encontrado.'; + $lang['strnogroups'] = 'Nenhum grupo encontrado.'; + $lang['strcreategroup'] = 'Criar grupo'; + $lang['strgroupneedsname'] = 'Você deve informar um nome para o seu grupo.'; + $lang['strgroupcreated'] = 'Grupo criado.'; + $lang['strgroupcreatedbad'] = 'Falha ao criar o grupo.'; + $lang['strconfdropgroup'] = 'Você têm certeza que deseja deletar o grupo "%s"?'; + $lang['strgroupdropped'] = 'Grupo deletado.'; + $lang['strgroupdroppedbad'] = 'Falha ao deletar grupo.'; + $lang['strmembers'] = 'Membros'; + $lang['strmemberof'] = 'Membro de'; + $lang['stradminmembers'] = 'Membros administrativos'; + $lang['straddmember'] = 'Adicionar membros'; + $lang['strmemberadded'] = 'Membro adicionado.'; + $lang['strmemberaddedbad'] = 'Falha ao adicionar membro.'; + $lang['strdropmember'] = 'Deletar membro'; + $lang['strconfdropmember'] = 'Você têm certeza que deseja deletar o membro "%s" do grupo "%s"?'; + $lang['strmemberdropped'] = 'Membro deletado.'; + $lang['strmemberdroppedbad'] = 'Falha ao deletar membro.'; + + // Roles + $lang['strrole'] = 'Papel'; + $lang['strroles'] = 'Papéis'; + $lang['strshowallroles'] = 'Exibir todos os papéis'; + $lang['strnoroles'] = 'Nenhum papel encontrado.'; + $lang['strinheritsprivs'] = 'Herdar privilégios?'; + $lang['strcreaterole'] = 'Criar papel'; + $lang['strcancreaterole'] = 'Pode criar papéis?'; + $lang['strrolecreated'] = 'Papel criado.'; + $lang['strrolecreatedbad'] = 'Falha ao criar o papel.'; + $lang['strrolealtered'] = 'Papel alterado.'; + $lang['strrolealteredbad'] = 'Falha ao alterar o papel.'; + $lang['strcanlogin'] = 'Pode logar?'; + $lang['strconnlimit'] = 'Limite de conexões'; + $lang['strdroprole'] = 'Deletar papel'; + $lang['strconfdroprole'] = 'Você têm certeza que deseja deletar o papel "%s"?'; + $lang['strroledropped'] = 'Papel deletado.'; + $lang['strroledroppedbad'] = 'Falha ao deletar o papel.'; + $lang['strnolimit'] = 'Sem limite'; + $lang['strnever'] = 'Nunca'; + $lang['strroleneedsname'] = 'Você deve informar um nome para o papel.'; + + // Privileges + $lang['strprivilege'] = 'Privilégio'; + $lang['strprivileges'] = 'Privilégios'; + $lang['strnoprivileges'] = 'Este objeto têm os privilégios padrões de proprietário.'; + $lang['strgrant'] = 'Conceder'; + $lang['strrevoke'] = 'Revogar'; + $lang['strgranted'] = 'Privilégios alterados.'; + $lang['strgrantfailed'] = 'Falha ao alterar os privilégios.'; + $lang['strgrantbad'] = 'Você deve informar ao menos um usuário ou grupo e ao menos um privilégio.'; + $lang['strgrantor'] = 'Provedor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Banco de dados'; + $lang['strdatabases'] = 'Bancos de dados'; + $lang['strshowalldatabases'] = 'Exibir todos os bancos de dados'; + $lang['strnodatabases'] = 'Nenhum banco de dados encontrado.'; + $lang['strcreatedatabase'] = 'Criar banco de dados'; + $lang['strdatabasename'] = 'Nome do banco de dados'; + $lang['strdatabaseneedsname'] = 'Você deve informar um nome para o seu banco de dados.'; + $lang['strdatabasecreated'] = 'Banco de dados criado.'; + $lang['strdatabasecreatedbad'] = 'Falha ao criar o banco de dados.'; + $lang['strconfdropdatabase'] = 'Você tem certeza que deseja deletar o banco de dados "%s"?'; + $lang['strdatabasedropped'] = 'Banco de dados deletado.'; + $lang['strdatabasedroppedbad'] = 'Falha ao deletar o banco de dados.'; + $lang['strentersql'] = 'Informe o SQL a executar abaixo:'; + $lang['strsqlexecuted'] = 'SQL executado.'; + $lang['strvacuumgood'] = 'Vácuo completo.'; + $lang['strvacuumbad'] = 'Falha ao realizar o vácuo.'; + $lang['stranalyzegood'] = 'Análise completa.'; + $lang['stranalyzebad'] = 'Falha ao realizar a análise.'; + $lang['strreindexgood'] = 'Reindexação completa.'; + $lang['strreindexbad'] = 'Falha ao executar a reindexação.'; + $lang['strfull'] = 'Completo'; + $lang['strfreeze'] = 'Congelar'; + $lang['strforce'] = 'Forçar'; + $lang['strsignalsent'] = 'Sinal enviado.'; + $lang['strsignalsentbad'] = 'Falha ao enviar o sinal.'; + $lang['strallobjects'] = 'Todos os objetos'; + $lang['strdatabasealtered'] = 'Banco de dados alterado.'; + $lang['strdatabasealteredbad'] = 'Falha ao alterar o banco de dados.'; + $lang['strspecifydatabasetodrop'] = 'Você deve especificar ao menos um banco de dados para deletar.'; + $lang['strtemplatedb'] = 'Modelo'; + $lang['strconfanalyzedatabase'] = 'Você têm certeza que deseja analisar todas as tabelas na base de dados "%s"?'; + $lang['strconfvacuumdatabase'] = 'Você têm certeza que deseja realizar vácuo em todas as tabelas na base de dados "%s"?'; + $lang['strconfreindexdatabase'] = 'Você têm certeza que deseja reindexar todas as tabelas na base de dados "%s"?'; + $lang['strconfclusterdatabase'] = 'Você têm certeza que deseja clusterizar todas as tabelas na base de dados "%s"?'; + + // Views + $lang['strview'] = 'Visão'; + $lang['strviews'] = 'Visões'; + $lang['strshowallviews'] = 'Exibir todas as visões'; + $lang['strnoview'] = 'Nenhuma visão encontrada.'; + $lang['strnoviews'] = 'Nenhuma visão encontrada.'; + $lang['strcreateview'] = 'Criar visão'; + $lang['strviewname'] = 'Nome da visão'; + $lang['strviewneedsname'] = 'Você deve informar o nome da sua visão.'; + $lang['strviewneedsdef'] = 'Você deve informar uma definição para a sua visão.'; + $lang['strviewneedsfields'] = 'Você deve informar as colunas que você deseja selecionar para a sua visão.'; + $lang['strviewcreated'] = 'Visão criada.'; + $lang['strviewcreatedbad'] = 'Falha ao criar a visão.'; + $lang['strconfdropview'] = 'Você têm certeza que deseja deletar a visão "%s"?'; + $lang['strviewdropped'] = 'Visão deletada.'; + $lang['strviewdroppedbad'] = 'Falha ao deletar a visão.'; + $lang['strviewupdated'] = 'Visão atualizada.'; + $lang['strviewupdatedbad'] = 'Falha ao atualizar a visão.'; + $lang['strviewlink'] = 'Chaves de ligação'; + $lang['strviewconditions'] = 'Condições adicionais'; + $lang['strcreateviewwiz'] = 'Criar visão com o assistente'; + $lang['strrenamedupfields'] = 'Renomear campos duplicados'; + $lang['strdropdupfields'] = 'Deletar campos duplicados'; + $lang['strerrordupfields'] = 'Erro quando campos duplicados'; + $lang['strviewaltered'] = 'Visão alterada.'; + $lang['strviewalteredbad'] = 'Falha ao alterar a visão.'; + $lang['strspecifyviewtodrop'] = 'Você deve informar ao menos uma visão para deletar.'; + + // Sequences + $lang['strsequence'] = 'Seqüência'; + $lang['strsequences'] = 'Seqüências'; + $lang['strshowallsequences'] = 'Exibir todas as seqüências'; + $lang['strnosequence'] = 'Nenhuma seqüência encontrada.'; + $lang['strnosequences'] = 'Nenhuma seqüência encontrada.'; + $lang['strcreatesequence'] = 'Criar seqüência'; + $lang['strlastvalue'] = 'Último valor'; + $lang['strincrementby'] = 'Incrementado por'; + $lang['strstartvalue'] = 'Valor inicial'; + $lang['strrestartvalue'] = 'Valor de reinicialização'; + $lang['strmaxvalue'] = 'Valor máximo'; + $lang['strminvalue'] = 'Valor mínimo'; + $lang['strcachevalue'] = 'Valor de cache'; + $lang['strlogcount'] = 'Contador do log'; + $lang['strcancycle'] = 'Pode ser cíclica?'; + $lang['striscalled'] = 'Irá incrementar o último valor antes de retornar o próximo valor (is_called)?'; + $lang['strsequenceneedsname'] = 'Você deve informar um nome para a sua seqüência.'; + $lang['strsequencecreated'] = 'Seqüência criada.'; + $lang['strsequencecreatedbad'] = 'Falha ao criar a seqüência.'; + $lang['strconfdropsequence'] = 'Você têm certeza que deseja deletar a seqüência "%s"?'; + $lang['strsequencedropped'] = 'Seqüência deletada.'; + $lang['strsequencedroppedbad'] = 'Falha ao deletar a seqüência.'; + $lang['strsequencerestart'] = 'Seqüência reinicializada.'; + $lang['strsequencerestartbad'] = 'Falha ao reinicializar a seqüência.'; + $lang['strsequencereset'] = 'Reinicializar a seqüência.'; + $lang['strsequenceresetbad'] = 'Falha ao reinicializar a seqüência.'; + $lang['strsequencealtered'] = 'Seqüência alterada.'; + $lang['strsequencealteredbad'] = 'Falha ao alterar a seqüência.'; + $lang['strsetval'] = 'Atribuir valor'; + $lang['strsequencesetval'] = 'Atribuir valor da seqüência.'; + $lang['strsequencesetvalbad'] = 'Falha ao atribuir valor da seqüência.'; + $lang['strnextval'] = 'Valor de incremento'; + $lang['strsequencenextval'] = 'Seqüência incrementada.'; + $lang['strsequencenextvalbad'] = 'Falha ao incrementar a seqüência.'; + $lang['strspecifysequencetodrop'] = 'Você deve informar ao menos uma seqüência para deletar.'; + + // Indexes + $lang['strindex'] = 'Ãndice'; + $lang['strindexes'] = 'Ãndices'; + $lang['strindexname'] = 'Nome do índice'; + $lang['strshowallindexes'] = 'Exibir todos os índices'; + $lang['strnoindex'] = 'Nenhum índice encontrado.'; + $lang['strnoindexes'] = 'Nenhum índice encontrado.'; + $lang['strcreateindex'] = 'Criar índice'; + $lang['strtabname'] = 'Nome da tabela'; + $lang['strcolumnname'] = 'Nome da coluna'; + $lang['strindexneedsname'] = 'Você deve informar um nome para o seu índice.'; + $lang['strindexneedscols'] = 'Ãndices requerem um número válido de colunas.'; + $lang['strindexcreated'] = 'Ãndice criado.'; + $lang['strindexcreatedbad'] = 'Falha ao criar o índice.'; + $lang['strconfdropindex'] = 'Você têm certeza que deseja deletar o índice "%s"?'; + $lang['strindexdropped'] = 'Ãndice deletado.'; + $lang['strindexdroppedbad'] = 'Falha ao deletar o índice.'; + $lang['strkeyname'] = 'Nome da chave'; + $lang['struniquekey'] = 'Chave única'; + $lang['strprimarykey'] = 'Chave primária'; + $lang['strindextype'] = 'Tipo de índice'; + $lang['strtablecolumnlist'] = 'Colunas na tabela'; + $lang['strindexcolumnlist'] = 'Colunas no índice'; + $lang['strconfcluster'] = 'Você têm certeza que deseja clusterizar "%s"?'; + $lang['strclusteredgood'] = 'Clusterização completa.'; + $lang['strclusteredbad'] = 'Falha ao clusterizar.'; + $lang['strcluster'] = 'Cluster'; + $lang['strconcurrently'] = 'Simultaneamente'; + $lang['strnoclusteravailable'] = 'Tabela não clusterizada em um índice.'; + + // Rules + $lang['strrules'] = 'Regras'; + $lang['strrule'] = 'Regra'; + $lang['strshowallrules'] = 'Exibir todas as regras'; + $lang['strnorule'] = 'Nenhuma regra encontrada.'; + $lang['strnorules'] = 'Nenhuma regra encontrada.'; + $lang['strcreaterule'] = 'Criar regra'; + $lang['strrulename'] = 'Nome da regra'; + $lang['strruleneedsname'] = 'Você deve informar um nome para a sua regra.'; + $lang['strrulecreated'] = 'Regra criada.'; + $lang['strrulecreatedbad'] = 'Falha ao criar a regra.'; + $lang['strconfdroprule'] = 'Você têm certeza que deseja deletar a regra "%s" em "%s"?'; + $lang['strruledropped'] = 'Regra deletada.'; + $lang['strruledroppedbad'] = 'Falha ao deletar a regra.'; + + // Constraints + $lang['strconstraint'] = 'Restrição'; + $lang['strconstraints'] = 'Restrições'; + $lang['strshowallconstraints'] = 'Exibir todas as restrições'; + $lang['strnoconstraints'] = 'Nenhuma restrição encontrada.'; + $lang['strcreateconstraint'] = 'Criar restrição'; + $lang['strconstraintcreated'] = 'Restrição criada.'; + $lang['strconstraintcreatedbad'] = 'Falha ao criar a restrição.'; + $lang['strconfdropconstraint'] = 'Você têm certeza que deseja deletar a restrição "%s" em "%s"?'; + $lang['strconstraintdropped'] = 'Restrição deletada.'; + $lang['strconstraintdroppedbad'] = 'Falha ao deletar a restrição.'; + $lang['straddcheck'] = 'Adicionar checagem'; + $lang['strcheckneedsdefinition'] = 'Checagem de restrição necessita de uma definição.'; + $lang['strcheckadded'] = 'Checagem de restrição adicionada.'; + $lang['strcheckaddedbad'] = 'Falha ao adicionar checagem de restrição.'; + $lang['straddpk'] = 'Adicionar chave primária'; + $lang['strpkneedscols'] = 'Chave primária necessita de ao menos uma coluna.'; + $lang['strpkadded'] = 'Chave primária adicionada.'; + $lang['strpkaddedbad'] = 'Falha ao adicionar chave primária.'; + $lang['stradduniq'] = 'Adicionar chave única'; + $lang['struniqneedscols'] = 'Chave única necessita de ao menos uma coluna.'; + $lang['struniqadded'] = 'Chave única adicionada.'; + $lang['struniqaddedbad'] = 'Falha ao adicionar chave única.'; + $lang['straddfk'] = 'Adicionar chave estrangeira'; + $lang['strfkneedscols'] = 'Chave estrangeira necessita de ao menos uma coluna.'; + $lang['strfkneedstarget'] = 'Chave estrangeira necessita de uma tabela alvo.'; + $lang['strfkadded'] = 'Chave estrangeira adicionada.'; + $lang['strfkaddedbad'] = 'Falha ao adicionar a chave estrangeira.'; + $lang['strfktarget'] = 'Tabela alvo'; + $lang['strfkcolumnlist'] = 'Colunas em chaves'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Função'; + $lang['strfunctions'] = 'Funções'; + $lang['strshowallfunctions'] = 'Exibir todas as funções'; + $lang['strnofunction'] = 'Nenhuma função encontrada.'; + $lang['strnofunctions'] = 'Nenhuma função encontrada.'; + $lang['strcreateplfunction'] = 'Criar função em PL/SQL'; + $lang['strcreateinternalfunction'] = 'Criar função interna'; + $lang['strcreatecfunction'] = 'Criar função em C'; + $lang['strfunctionname'] = 'Nome da função'; + $lang['strreturns'] = 'Retorno'; + $lang['strproglanguage'] = 'Linguagem de programação'; + $lang['strfunctionneedsname'] = 'Você deve informar um nome para a sua função.'; + $lang['strfunctionneedsdef'] = 'Você deve informar uma definição para a sua função.'; + $lang['strfunctioncreated'] = 'Função criada.'; + $lang['strfunctioncreatedbad'] = 'Falha ao criar a função.'; + $lang['strconfdropfunction'] = 'Você têm certeza que deseja deletar a função "%s"?'; + $lang['strfunctiondropped'] = 'Função deletada.'; + $lang['strfunctiondroppedbad'] = 'Falha ao deletar a função.'; + $lang['strfunctionupdated'] = 'Função atualizada.'; + $lang['strfunctionupdatedbad'] = 'Falha ao atualizar a função.'; + $lang['strobjectfile'] = 'Arquivo objeto'; + $lang['strlinksymbol'] = 'Símbolo de link'; + $lang['strarguments'] = 'Argumentos'; + $lang['strargmode'] = 'Modo'; + $lang['strargtype'] = 'Tipo'; + $lang['strargadd'] = 'Adicionar outro argumento'; + $lang['strargremove'] = 'Remover este argumento'; + $lang['strargnoargs'] = 'Esta função não irá utilizar argumentos.'; + $lang['strargenableargs'] = 'Habilitar argumentos passados para esta função.'; + $lang['strargnorowabove'] = 'É preciso ter uma linha acima desta.'; + $lang['strargnorowbelow'] = 'É preciso ter uma linha abaixo desta.'; + $lang['strargraise'] = 'Mover acima.'; + $lang['strarglower'] = 'Mover abaixo.'; + $lang['strargremoveconfirm'] = 'Você têm certeza que deseja remover este argumento? Isto NÃO PODE ser desfeito.'; + $lang['strfunctioncosting'] = 'Custo da função'; + $lang['strresultrows'] = 'Linhas resultantes'; + $lang['strexecutioncost'] = 'Custo de execução'; + $lang['strspecifyfunctiontodrop'] = 'Você deve informar ao menos uma função para deletar.'; + + // Triggers + $lang['strtrigger'] = 'Gatilho'; + $lang['strtriggers'] = 'Gatilhos'; + $lang['strshowalltriggers'] = 'Exibir todos os gatilhos'; + $lang['strnotrigger'] = 'Nenhum gatilho encontrado.'; + $lang['strnotriggers'] = 'Nenhum gatilho encontrado.'; + $lang['strcreatetrigger'] = 'Criar gatilho'; + $lang['strtriggerneedsname'] = 'Você deve informar um nome para o seu gatilho.'; + $lang['strtriggerneedsfunc'] = 'Você deve informar uma função para o seu gatilho.'; + $lang['strtriggercreated'] = 'Gatilho criado.'; + $lang['strtriggercreatedbad'] = 'Falha ao criar o gatilho.'; + $lang['strconfdroptrigger'] = 'Você têm certeza que deseja deletar o gatilho "%s" em "%s"?'; + $lang['strconfenabletrigger'] = 'Você têm certeza que deseja ativar o gatilho "%s" em "%s"?'; + $lang['strconfdisabletrigger'] = 'Você têm certeza que deseja desativar o gatilho "%s" em "%s"?'; + $lang['strtriggerdropped'] = 'Gatilho deletado.'; + $lang['strtriggerdroppedbad'] = 'Falha ao deletar o gatilho.'; + $lang['strtriggerenabled'] = 'Gatilho ativado.'; + $lang['strtriggerenabledbad'] = 'Falha ao ativar o gatilho.'; + $lang['strtriggerdisabled'] = 'Gatilho desativado.'; + $lang['strtriggerdisabledbad'] = 'Falha ao desativar o gatilho.'; + $lang['strtriggeraltered'] = 'Gatilho alterado.'; + $lang['strtriggeralteredbad'] = 'Falha ao alterar o gatilho.'; + $lang['strforeach'] = 'Para cada'; + + // Types + $lang['strtype'] = 'Tipo'; + $lang['strtypes'] = 'Tipos'; + $lang['strshowalltypes'] = 'Exibir todos os tipos'; + $lang['strnotype'] = 'Nenhum tipo encontrado.'; + $lang['strnotypes'] = 'Nenhum tipo encontrado.'; + $lang['strcreatetype'] = 'Criar tipo'; + $lang['strcreatecomptype'] = 'Criar tipo composto'; + $lang['strcreateenumtype'] = 'Criar tipo enumerado'; + $lang['strtypeneedsfield'] = 'Você deve informar ao menos um campo.'; + $lang['strtypeneedsvalue'] = 'Você deve informar ao menos um valor.'; + $lang['strtypeneedscols'] = 'Você deve informar um número válido de campos.'; + $lang['strtypeneedsvals'] = 'Você deve informar um número válido de valores.'; + $lang['strinputfn'] = 'Função de entrada'; + $lang['stroutputfn'] = 'Função de saída'; + $lang['strpassbyval'] = 'Passado por valor?'; + $lang['stralignment'] = 'Alinhamento'; + $lang['strelement'] = 'Elemento'; + $lang['strdelimiter'] = 'Delimitador'; + $lang['strstorage'] = 'Armazenamento'; + $lang['strfield'] = 'Campo'; + $lang['strnumfields'] = 'Num. de campos'; + $lang['strnumvalues'] = 'Num. de valores'; + $lang['strtypeneedsname'] = 'Você deve informar um nome para o seu tipo.'; + $lang['strtypeneedslen'] = 'Você deve informar o tamanho para o seu tipo.'; + $lang['strtypecreated'] = 'Tipo criado.'; + $lang['strtypecreatedbad'] = 'Falha ao criar o tipo.'; + $lang['strconfdroptype'] = 'Você têm certeza que deseja deletar o tipo "%s"?'; + $lang['strtypedropped'] = 'Tipo deletado.'; + $lang['strtypedroppedbad'] = 'Falha ao deletar o tipo.'; + $lang['strflavor'] = 'Sabor'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Composto'; + $lang['strpseudotype'] = 'Pseudo'; + $lang['strenum'] = 'Enum'; + $lang['strenumvalues'] = 'Valores enum'; + + // Schemas + $lang['strschema'] = 'Esquema'; + $lang['strschemas'] = 'Esquemas'; + $lang['strshowallschemas'] = 'Exibir todos os esquemas'; + $lang['strnoschema'] = 'Nenhum esquema encontrado.'; + $lang['strnoschemas'] = 'Nenhum esquema encontrado.'; + $lang['strcreateschema'] = 'Criar esquema'; + $lang['strschemaname'] = 'Nome do esquema'; + $lang['strschemaneedsname'] = 'Você deve informar um nome para o seu esquema.'; + $lang['strschemacreated'] = 'Esquema criado.'; + $lang['strschemacreatedbad'] = 'Falha ao criar o esquema'; + $lang['strconfdropschema'] = 'Você têm certeza que deseja deletar o esquema "%s"?'; + $lang['strschemadropped'] = 'Esquema deletado.'; + $lang['strschemadroppedbad'] = 'Falha ao deletar o esquema.'; + $lang['strschemaaltered'] = 'Esquema alterado.'; + $lang['strschemaalteredbad'] = 'Falha ao alterar o esquema.'; + $lang['strsearchpath'] = 'Diretório de pesquisa do esquema'; + $lang['strspecifyschematodrop'] = 'Você deve informar ao menos um esquema para deletar.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domínio'; + $lang['strdomains'] = 'Domínios'; + $lang['strshowalldomains'] = 'Exibir todos os domínios'; + $lang['strnodomains'] = 'Nenhum domínio encontrado.'; + $lang['strcreatedomain'] = 'Criar domínio'; + $lang['strdomaindropped'] = 'Domínio deletado.'; + $lang['strdomaindroppedbad'] = 'Falha ao deletar o domínio.'; + $lang['strconfdropdomain'] = 'Você têm certeza que deseja deletar o domínio "%s"?'; + $lang['strdomainneedsname'] = 'Você deve informar um nome para o seu domínio.'; + $lang['strdomaincreated'] = 'Domínio criado.'; + $lang['strdomaincreatedbad'] = 'Falha ao criar o domínio.'; + $lang['strdomainaltered'] = 'Domínio alterado.'; + $lang['strdomainalteredbad'] = 'Falha ao alterar o domínio.'; + + // Operators + $lang['stroperator'] = 'Operador'; + $lang['stroperators'] = 'Operadores'; + $lang['strshowalloperators'] = 'Exibir todos os operadores'; + $lang['strnooperator'] = 'Nenhum operador encontrado.'; + $lang['strnooperators'] = 'Nenhum operador encontrado.'; + $lang['strcreateoperator'] = 'Criar operador'; + $lang['strleftarg'] = 'Tipo de Arg Esquerdo'; + $lang['strrightarg'] = 'Tipo de Arg Direito'; + $lang['strcommutator'] = 'Comutador'; + $lang['strnegator'] = 'Negador'; + $lang['strrestrict'] = 'Restrito'; + $lang['strjoin'] = 'Junção'; + $lang['strhashes'] = 'Misturador'; + $lang['strmerges'] = 'Fusão'; + $lang['strleftsort'] = 'Ordenação esquerda'; + $lang['strrightsort'] = 'Ordenação direita'; + $lang['strlessthan'] = 'Menor que'; + $lang['strgreaterthan'] = 'Maior que'; + $lang['stroperatorneedsname'] = 'Você deve informar um nome para o seu operador.'; + $lang['stroperatorcreated'] = 'Operador criado.'; + $lang['stroperatorcreatedbad'] = 'Falha ao criar o operador.'; + $lang['strconfdropoperator'] = 'Você têm certeza que deseja deletar o operador "%s"?'; + $lang['stroperatordropped'] = 'Operador deletado.'; + $lang['stroperatordroppedbad'] = 'Falha ao deletar o operador.'; + + // Casts + $lang['strcasts'] = 'Moldes'; + $lang['strnocasts'] = 'Nenhum molde encontrado.'; + $lang['strsourcetype'] = 'Tipo fonte'; + $lang['strtargettype'] = 'Tipo alvo'; + $lang['strimplicit'] = 'Implícito'; + $lang['strinassignment'] = 'Em atribuição'; + $lang['strbinarycompat'] = '(Compatibilidade binária)'; + + // Conversions + $lang['strconversions'] = 'Conversões'; + $lang['strnoconversions'] = 'Nenhuma conversão encontrada.'; + $lang['strsourceencoding'] = 'Codificação fonte'; + $lang['strtargetencoding'] = 'Codificação alvo'; + + // Languages + $lang['strlanguages'] = 'Linguagens'; + $lang['strnolanguages'] = 'Nenhuma linguagem encontrada.'; + $lang['strtrusted'] = 'Confiado'; + + // Info + $lang['strnoinfo'] = 'Nenhuma informação disponível.'; + $lang['strreferringtables'] = 'Tabelas de referência'; + $lang['strparenttables'] = 'Tabelas pais'; + $lang['strchildtables'] = 'Tabelas filhas'; + + // Aggregates + $lang['straggregate'] = 'Agregação'; + $lang['straggregates'] = 'Agregações'; + $lang['strnoaggregates'] = 'Nenhuma agregação encontrada.'; + $lang['stralltypes'] = '(Todos os tipos)'; + $lang['strcreateaggregate'] = 'Criar agregação'; + $lang['straggrbasetype'] = 'Tipo de dados de entrada'; + $lang['straggrsfunc'] = 'Função de transição de estado'; + $lang['straggrstype'] = 'Tipo de dados para valor de estado'; + $lang['straggrffunc'] = 'Função final'; + $lang['straggrinitcond'] = 'Condição inicial'; + $lang['straggrsortop'] = 'Operador de ordem'; + $lang['strconfdropaggregate'] = 'Você têm certeza que deseja deletar a agregação "%s"?'; + $lang['straggregatedropped'] = 'Agregação deletada.'; + $lang['straggregatedroppedbad'] = 'Falha ao deletar a agregação.'; + $lang['straggraltered'] = 'Agregação alterada.'; + $lang['straggralteredbad'] = 'Falha ao alterar a agregação.'; + $lang['straggrneedsname'] = 'Você deve informar um nome para a sua agregação.'; + $lang['straggrneedsbasetype'] = 'Você deve informar o tipo de entrada de dados para a agregação.'; + $lang['straggrneedssfunc'] = 'Você deve informar o nome da função de transição de estado para a agregação.'; + $lang['straggrneedsstype'] = 'Você deve informar o tipo de dados para o valor de estado da agregação.'; + $lang['straggrcreated'] = 'Agregação criada.'; + $lang['straggrcreatedbad'] = 'Falha ao criar a agregação.'; + $lang['straggrshowall'] = 'Exibir todas as agregações'; + + // Operator Classes + $lang['stropclasses'] = 'Classes Op'; + $lang['strnoopclasses'] = 'Nenhuma classe operador encontrada.'; + $lang['straccessmethod'] = 'Método de acesso'; + + // Stats and performance + $lang['strrowperf'] = 'Performance de linha'; + $lang['strioperf'] = 'Performance de I/O'; + $lang['stridxrowperf'] = 'Ãndice de Performance de linha'; + $lang['stridxioperf'] = 'Ãndice de Performance de I/O'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Seqüêncial'; + $lang['strscan'] = 'Pesquisa'; + $lang['strread'] = 'Leitura'; + $lang['strfetch'] = 'Afetado'; + $lang['strheap'] = 'Pilha'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'Ãndice TOAST'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disco'; + $lang['strrows2'] = 'Linhas'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaces'; + $lang['strshowalltablespaces'] = 'Exibir todos os tablespaces'; + $lang['strnotablespaces'] = 'Nenhum tablespace encontrado.'; + $lang['strcreatetablespace'] = 'Criar tablespace'; + $lang['strlocation'] = 'Localização'; + $lang['strtablespaceneedsname'] = 'Você deve informar um nome para o tablespace.'; + $lang['strtablespaceneedsloc'] = 'Você deve informar um diretório em qual será criado o tablespace.'; + $lang['strtablespacecreated'] = 'Tablespace criado.'; + $lang['strtablespacecreatedbad'] = 'Falha ao criar o tablespace.'; + $lang['strconfdroptablespace'] = 'Você têm certeza que deseja deletar o tablespace "%s"?'; + $lang['strtablespacedropped'] = 'Tablespace deletado.'; + $lang['strtablespacedroppedbad'] = 'Falha ao deletar o tablespace.'; + $lang['strtablespacealtered'] = 'Tablespace alterado.'; + $lang['strtablespacealteredbad'] = 'Falha ao alterar o tablespace.'; + + // Miscellaneous + $lang['strtopbar'] = '%s rodando em %s:%s -- Você está logado como usuário "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Ajuda'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Navegar na página de ajuda'; + $lang['strselecthelppage'] = 'Selecione uma página de ajuda'; + $lang['strinvalidhelppage'] = 'Página de ajuda inválida.'; + $lang['strlogintitle'] = 'Conectado em %s'; + $lang['strlogoutmsg'] = 'Desconectado de %s'; + $lang['strloading'] = 'Carregando...'; + $lang['strerrorloading'] = 'Erro no carregamento'; + $lang['strclicktoreload'] = 'Clique para recarregar'; + + // Autovacuum + $lang['strautovacuum'] = 'Vácuo automático'; + $lang['strturnedon'] = 'Ligado'; + $lang['strturnedoff'] = 'Desligado'; + $lang['strenabled'] = 'Ativado'; + $lang['strnovacuumconf'] = 'Nenhuma configuração de vácuo automático encontrada.'; + $lang['strvacuumbasethreshold'] = 'Vácuo a partir do ponto inicial da base'; + $lang['strvacuumscalefactor'] = 'Vácuo por fator de escala'; + $lang['stranalybasethreshold'] = 'Analisar a partir do ponto inicial da base'; + $lang['stranalyzescalefactor'] = 'Analisar por fator de escala'; + $lang['strvacuumcostdelay'] = 'Custo de retardo do vácuo'; + $lang['strvacuumcostlimit'] = 'Custo máximo do vácuo'; + $lang['strvacuumpertable'] = 'Configuração de vácuo automático por tabela'; + $lang['straddvacuumtable'] = 'Adicionar configuração de vácuo automático para a tabela'; + $lang['streditvacuumtable'] = 'Editar a configuração de vácuo automático para a tabela %s'; + $lang['strdelvacuumtable'] = 'Deletar a configuração de vácuo automático para a tabela %s ?'; + $lang['strvacuumtablereset'] = 'Configuração de vácuo automático para a tabela %s redefinida para os valores padrão'; + $lang['strdelvacuumtablefail'] = 'Falha ao remover a configuração de vácuo automático para a tabela %s'; + $lang['strsetvacuumtablesaved'] = 'Configuração de vácuo automático para a tabela %s salva.'; + $lang['strsetvacuumtablefail'] = 'Configuração de vácuo automático para a tabela %s falhou.'; + $lang['strspecifydelvacuumtable'] = 'Você deve especificar a tabela que deseja remover os parâmetros de vácuo automático.'; + $lang['strspecifyeditvacuumtable'] = 'Você deve especificar a tabela que deseja editar os parâmetros de vácuo automático.'; + $lang['strnotdefaultinred'] = 'Valores não padrão estão em vermelho.'; + + // Table-level Locks + $lang['strlocks'] = 'Travas'; + $lang['strtransaction'] = 'ID de transação'; + $lang['strvirtualtransaction'] = 'ID de transação virtual'; + $lang['strprocessid'] = 'ID do processo'; + $lang['strmode'] = 'Modo de trava'; + $lang['strislockheld'] = 'A trava prendeu?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Transações preparadas'; + $lang['strxactid'] = 'ID da transação'; + $lang['strgid'] = 'ID global'; + + // Fulltext search + $lang['strfulltext'] = 'Busca por Texto Completo'; + $lang['strftsconfig'] = 'Configuração BTC'; + $lang['strftsconfigs'] = 'Configurações'; + $lang['strftscreateconfig'] = 'Criar uma configuração BTC'; + $lang['strftscreatedict'] = 'Criar um dicionário'; + $lang['strftscreatedicttemplate'] = 'Criar um modelo de dicionário'; + $lang['strftscreateparser'] = 'Criar parser'; + $lang['strftsnoconfigs'] = 'Nenhuma configuração BTC encontrada.'; + $lang['strftsconfigdropped'] = 'Configuração BTC eliminada.'; + $lang['strftsconfigdroppedbad'] = 'Falha ao eliminar da configuração BTC.'; + $lang['strconfdropftsconfig'] = 'Deseja eliminar a configuração BTC "%s"?'; + $lang['strconfdropftsdict'] = 'Deseja eliminar o dicionário BTC "%s"?'; + $lang['strconfdropftsmapping'] = 'Deseja eliminar o mapeamento "%s" da configuração BTC "%s"?'; + $lang['strftstemplate'] = 'Modelo'; + $lang['strftsparser'] = 'Parser'; + $lang['strftsconfigneedsname'] = 'Informe o nome para a sua configuração BTC.'; + $lang['strftsconfigcreated'] = 'Configuração BTC criada.'; + $lang['strftsconfigcreatedbad'] = 'Falha ao criar a configuração BTC.'; + $lang['strftsmapping'] = 'Mapeamento'; + $lang['strftsdicts'] = 'Dicionários'; + $lang['strftsdict'] = 'Dicionário'; + $lang['strftsemptymap'] = 'Mapa de configuração BTC vazio.'; + $lang['strftsconfigaltered'] = 'Configuração BTC alterada.'; + $lang['strftsconfigalteredbad'] = 'Falha ao alterar a configuração BTC.'; + $lang['strftsconfigmap'] = 'Mapa de configuração BTC'; + $lang['strftsparsers'] = 'Parsers BTC'; + $lang['strftsnoparsers'] = 'Nenhum parser BTC disponível.'; + $lang['strftsnodicts'] = 'Nenhum dicionário BTC disponível.'; + $lang['strftsdictcreated'] = 'Dicionário BTC criado.'; + $lang['strftsdictcreatedbad'] = 'Falha ao criar o dicionário BTC.'; + $lang['strftslexize'] = 'Lexize'; + $lang['strftsinit'] = 'Inicializar'; + $lang['strftsoptionsvalues'] = 'Opções e valores'; + $lang['strftsdictneedsname'] = 'Informe o nome para o dicionário BTC.'; + $lang['strftsdictdropped'] = 'Dicionário BTC eliminado.'; + $lang['strftsdictdroppedbad'] = 'Falha ao eliminar o dicionário BTC.'; + $lang['strftsdictaltered'] = 'Dicionário BTC alterado.'; + $lang['strftsdictalteredbad'] = 'Falha ao alterar o dicinário BTC.'; + $lang['strftsaddmapping'] = 'Adicionar novo mapeamento'; + $lang['strftsspecifymappingtodrop'] = 'Informe ao menos um mapeamento para eliminar.'; + $lang['strftsspecifyconfigtoalter'] = 'Informe uma configuração BTC para alterar'; + $lang['strftsmappingdropped'] = 'Mapeamento BTC eliminado.'; + $lang['strftsmappingdroppedbad'] = 'Falha ao remover o mapeamento BTC.'; + $lang['strftsnodictionaries'] = 'Nenhum dicionário encontrado.'; + $lang['strftsmappingaltered'] = 'Mapeamento BTC alterado.'; + $lang['strftsmappingalteredbad'] = 'Falha ao alterar o mapeamento BTC.'; + $lang['strftsmappingadded'] = 'Mapeamento BTC adicionado.'; + $lang['strftsmappingaddedbad'] = 'Falha ao adicionar o mapeamento BTC.'; + $lang['strftstabconfigs'] = 'Configurações'; + $lang['strftstabdicts'] = 'Dicionários'; + $lang['strftstabparsers'] = 'Parsers'; + $lang['strftscantparsercopy'] = 'Não é possível especificar ambos parser e modelo durante a criação da configuração de busca de texto.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-pt.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-pt.php new file mode 100644 index 00000000..01b12a41 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/portuguese-pt.php @@ -0,0 +1,608 @@ +>'; +$lang['strtrue'] = 'VERDADEIRO'; +$lang['strfalse'] = 'FALSO'; +$lang['strcolumn'] = 'Coluna'; +$lang['strobjects'] = 'objecto(s)'; +$lang['strclustered'] = 'Conjunto?'; +$lang['strseparator'] = ': '; +$lang['strexplain'] = 'Explicação'; +$lang['strexplainanalyze'] = 'Explicação de Análise'; +$lang['strfind'] = 'Procurar'; +$lang['stroptions'] = 'Opções'; +$lang['strrefresh'] = 'Actualizar'; +$lang['strdownload'] = 'Descarreguar'; +$lang['strdownloadgzipped'] = 'Descarregar comprimido com gzip'; +$lang['strinfo'] = 'Informação'; +$lang['stroids'] = 'OIDs'; +$lang['stradvanced'] = 'Avançado'; +$lang['strvariables'] = 'Variáveis'; +$lang['strprocess'] = 'Processo'; +$lang['strprocesses'] = 'Processos'; +$lang['strsetting'] = 'Configurações'; +$lang['streditsql'] = 'Editar SQL'; +$lang['strruntime'] = 'Tempo total decorrido: %s ms'; +$lang['strpaginate'] = 'Paginar resultados'; +$lang['struploadscript'] = 'ou upload um script SQL:'; +$lang['strstarttime'] = 'Hora de início'; +$lang['strfile'] = 'Ficheiro'; +$lang['strfileimported'] = 'Ficheiro importado.'; +$lang['strphpversionnotsupported'] = 'Versão do PHP não é suportada. Por favor actualize para a versão %s ou superior.'; +$lang['strpostgresqlversionnotsupported'] = 'Versão do PostgreSQL não é suportada. Por favor actualize para a versão %s ou superior.'; +$lang['strnoobjects'] = 'Não foram escontrados objectos.'; +$lang['strrownotunique'] = 'Não existe identificador único para esta linha.'; +$lang['strnouploads'] = 'Upload de ficheiros indisponível.'; +$lang['strimporterror'] = 'Erro na importação.'; +$lang['strimporterrorline'] = 'Erro ao importar na linha %s.'; +$lang['strinsertandrepeat'] = 'Inserir & Repetir'; +$lang['strnumcols'] = 'Número de colunas'; +$lang['strcolneedsname'] = 'Tem de definir um nome para a coluna.'; +$lang['strselectallfields'] = 'Seleccione todos os campos'; +$lang['strselectunary'] = 'Operadores unários não podem ter valores.'; +$lang['strtablealtered'] = 'Tabela alterada.'; +$lang['strtablealteredbad'] = 'Alteração da Tabela falhou.'; +$lang['strstructureonly'] = 'Só Estrutura'; +$lang['strstructureanddata'] = 'Estrutura e dados'; +$lang['strtabbed'] = 'Tabulado'; +$lang['strauto'] = 'Auto'; +$lang['strconfvacuumtable'] = 'Tem a certeza que pretende aspirar "%s"?'; +$lang['strestimatedrowcount'] = 'Contagem de linhas Estimada'; +$lang['strsessiondefaults'] = 'Configurações padrão da sessão'; +$lang['struserneedsname'] = 'Tem de dar um nome ao seu útilizador.'; +$lang['strnogroup'] = 'Grupo não encontrado.'; +$lang['strcreategroup'] = 'Criar grupo'; +$lang['straddmember'] = 'Adicionar membro'; +$lang['strmemberadded'] = 'Membro adicionado.'; +$lang['strmemberaddedbad'] = 'Falha ao adicionar Membro.'; +$lang['strdropmember'] = 'Retirar membro'; +$lang['strconfdropmember'] = 'Tem a certeza que pretende retirar o membro "%s" do grupo "%s"?'; +$lang['strmemberdropped'] = 'Membro retirado.'; +$lang['strmemberdroppedbad'] = 'Falha ao retirar membro.'; +$lang['strgrantor'] = 'Grantor'; +$lang['strasterisk'] = '*'; +$lang['strreindexgood'] = 'Reindexação completa.'; +$lang['strreindexbad'] = 'Falha na Reindexação.'; +$lang['strfull'] = 'Cheio'; +$lang['strfreeze'] = 'Congelado'; +$lang['strforce'] = 'Forçar'; +$lang['strsignalsent'] = 'Sinal enviado.'; +$lang['strsignalsentbad'] = 'Falha ao enviar sinal.'; +$lang['strallobjects'] = 'Todos os objectos'; +$lang['strviewneedsfields'] = 'Tem de específicar a coluna que pretende seleccionar para a sua vista.'; +$lang['strviewlink'] = 'ligar chaves'; +$lang['strviewconditions'] = 'Condições Adicionais'; +$lang['strcreateviewwiz'] = 'Criar vista com assistente'; +$lang['strsequencereset'] = 'Limpar sequência.'; +$lang['strsequenceresetbad'] = 'Falha ao limpar sequência.'; +$lang['strindex'] = 'Index'; +$lang['strconfcluster'] = 'Tem a certeza que pretende conjugar "%s"?'; +$lang['strclusteredgood'] = 'Conjugação completa.'; +$lang['strclusteredbad'] = 'Falha ao conjugar.'; +$lang['strcreateplfunction'] = 'Criar função Create SQL/PL'; +$lang['strcreateinternalfunction'] = 'Criar função interna'; +$lang['strcreatecfunction'] = 'Criar função em C'; +$lang['strobjectfile'] = 'Ficheiro Objecto'; +$lang['strlinksymbol'] = 'Ligar Símbolo'; +$lang['strtriggeraltered'] = 'Trigger Alterado.'; +$lang['strtriggeralteredbad'] = 'Falha ao alterar Trigger.'; +$lang['strcreatecomptype'] = 'Criar tipo composto'; +$lang['strtypeneedsfield'] = 'Tem de específicar pelo menos um campo.'; +$lang['strtypeneedscols'] = 'Tem de específicar um número válido de campos.'; +$lang['strflavor'] = 'Sabor'; +$lang['strbasetype'] = 'Base'; +$lang['strcompositetype'] = 'Compôr'; +$lang['strpseudotype'] = 'Pseudo'; +$lang['strschemaaltered'] = 'Esquema Alterado.'; +$lang['strschemaalteredbad'] = 'Falha ao alterar o esquema.'; +$lang['strsearchpath'] = 'Caminho de pesquisa no esquema'; +$lang['strdomain'] = 'Domínio'; +$lang['strdomains'] = 'Domínios'; +$lang['strshowalldomains'] = 'Lista todos os domínios'; +$lang['strnodomains'] = 'Não foram encontrados domínios.'; +$lang['strcreatedomain'] = 'Criar domínio'; +$lang['strdomaindropped'] = 'Eliminar domínio.'; +$lang['strdomaindroppedbad'] = 'Falha ao eliminar o domínio.'; +$lang['strconfdropdomain'] = 'Tem a certeza que pretende eliminar o dominio "%s"?'; +$lang['strdomainneedsname'] = 'Tem de específicar um nome para o seu domínio.'; +$lang['strdomaincreated'] = 'Domínio criado.'; +$lang['strdomaincreatedbad'] = 'Falha ao criar domínio.'; +$lang['strdomainaltered'] = 'Alterar domínio.'; +$lang['strdomainalteredbad'] = 'Falha ao alterar domínio.'; +$lang['stroperator'] = 'Operador'; +$lang['strshowalloperators'] = 'Lista todos os operadores'; +$lang['strnooperator'] = 'Não foi encontrado o operador.'; +$lang['strnooperators'] = 'Não foram encontrados operadores.'; +$lang['strcreateoperator'] = 'Criar operador'; +$lang['strleftarg'] = 'Tipo de ARGumento esquerdo'; +$lang['strrightarg'] = 'Tipo de ARGumento direito'; +$lang['strcommutator'] = 'Comutador'; +$lang['strnegator'] = 'Negador'; +$lang['strrestrict'] = 'Restrito'; +$lang['strjoin'] = 'Juntar'; +$lang['strhashes'] = 'Referências'; +$lang['strmerges'] = 'Mesclrar'; +$lang['strleftsort'] = 'Ordenação esquerda'; +$lang['strrightsort'] = 'Ordenação direita'; +$lang['strlessthan'] = 'Menor que'; +$lang['strgreaterthan'] = 'Maior que'; +$lang['stroperatorneedsname'] = 'Tem de específicar um nome para o operador.'; +$lang['stroperatorcreated'] = 'Operador criado'; +$lang['stroperatorcreatedbad'] = 'Falha ao criar operador.'; +$lang['strconfdropoperator'] = 'Tem a certeza que pretende eliminar o operador "%s"?'; +$lang['stroperatordropped'] = 'Operador eliminado.'; +$lang['stroperatordroppedbad'] = 'Falha ao eliminar o operador.'; +$lang['strcasts'] = 'Molde'; +$lang['strnocasts'] = 'Não foram encontrador moldes.'; +$lang['strsourcetype'] = 'Tipo de fonte'; +$lang['strtargettype'] = 'Tipo de alvo'; +$lang['strimplicit'] = 'Implicito'; +$lang['strinassignment'] = 'Em assignamento'; +$lang['strbinarycompat'] = '(Binario compativél)'; +$lang['strconversions'] = 'Conversões'; +$lang['strnoconversions'] = 'Não foram encontradas conversões.'; +$lang['strsourceencoding'] = 'Codificação da fonte'; +$lang['strtargetencoding'] = 'Codificação do alvo'; +$lang['strlanguages'] = 'Línguas'; +$lang['strnolanguages'] = 'Não foram encontradas línguas.'; +$lang['strtrusted'] = 'Confiado'; +$lang['strnoinfo'] = 'Informação indisponível.'; +$lang['strreferringtables'] = 'Tabelas de referência'; +$lang['strparenttables'] = 'Tabelas pai'; +$lang['strchildtables'] = 'Tabelas filho'; +$lang['strnoaggregates'] = 'Não foram encontrados agregados.'; +$lang['stralltypes'] = '(Todos os tipos)'; +$lang['stropclasses'] = 'Classes Op'; +$lang['strnoopclasses'] = 'Não foram encontrados operadores de classes.'; +$lang['straccessmethod'] = 'Método de acesso'; +$lang['strrowperf'] = 'Performance das linhas'; +$lang['strioperf'] = 'Performance de E/S'; +$lang['stridxrowperf'] = 'Performance de indexação de linhas'; +$lang['stridxioperf'] = 'Performance em indexação E/S'; +$lang['strpercent'] = '%'; +$lang['strsequential'] = 'Sequêncial'; +$lang['strscan'] = 'Pesquisar'; +$lang['strread'] = 'Lêr'; +$lang['strfetch'] = 'Descarregar'; +$lang['strheap'] = 'Fila'; +$lang['strtoast'] = 'QUEIMAR'; +$lang['strtoastindex'] = 'QUEIMAR Index'; +$lang['strcache'] = 'Cache'; +$lang['strdisk'] = 'Disco'; +$lang['strrows2'] = 'Linhas'; +$lang['strtablespace'] = 'Espaço de Tabela'; +$lang['strtablespaces'] = 'Espaços de Tabela'; +$lang['strshowalltablespaces'] = 'Lista todos os espaços de tabela'; +$lang['strnotablespaces'] = 'Não foram encontrados espaços de tabela.'; +$lang['strcreatetablespace'] = 'Criar espaço de tabela'; +$lang['strlocation'] = 'Localização'; +$lang['strtablespaceneedsname'] = 'Tem de específicar um nome para o espaço de tabela.'; +$lang['strtablespaceneedsloc'] = 'Tem de específicar um directório no qual irá criar o espaço de tabela.'; +$lang['strtablespacecreated'] = 'Espaço de Tabela criado.'; +$lang['strtablespacecreatedbad'] = 'Falha ao criar espaço de tabela.'; +$lang['strconfdroptablespace'] = 'Tem a certeza que pretende eliminar o espaço de tabela "%s"?'; +$lang['strtablespacedropped'] = 'Espaço de tabela eliminado.'; +$lang['strtablespacedroppedbad'] = 'Falha ao eliminar o espaço de tabela.'; +$lang['strtablespacealtered'] = 'Espaço de tabela alterado.'; +$lang['strtablespacealteredbad'] = 'Alteração do Espaçamento de Tabela falhou.'; +$lang['strhelp'] = 'Ajuda'; +$lang['strhelpicon'] = '?'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/romanian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/romanian.php new file mode 100644 index 00000000..667e9326 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/romanian.php @@ -0,0 +1,758 @@ +'; + $lang['strfirst'] = '<< ÃŽnceput'; + $lang['strlast'] = 'SfârÅŸit >>'; + $lang['strfailed'] = 'EÅŸuat'; + $lang['strcreate'] = 'Creare'; + $lang['strcreated'] = 'Creat'; + $lang['strcomment'] = 'Comentariu'; + $lang['strlength'] = 'Lungime'; + $lang['strdefault'] = 'Implicit'; + $lang['stralter'] = 'Modificare'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Anulare'; + $lang['strac'] = 'Activare Auto-completare'; + $lang['strsave'] = 'Salvare'; + $lang['strreset'] = 'ReiniÅ£ializare'; + $lang['strinsert'] = 'Inserare'; + $lang['strselect'] = 'Selectare'; + $lang['strdelete'] = 'Åžtergere'; + $lang['strupdate'] = 'Actualizare'; + $lang['strreferences'] = 'ReferinÅ£e'; + $lang['stryes'] = 'Da'; + $lang['strno'] = 'Nu'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = 'Editare'; + $lang['strcolumn'] = 'Coloană'; + $lang['strcolumns'] = 'Coloane'; + $lang['strrows'] = 'rând(uri)'; + $lang['strrowsaff'] = 'rând(uri) afectate.'; + $lang['strobjects'] = 'obiect(e)'; + $lang['strback'] = 'ÃŽnapoi'; + $lang['strqueryresults'] = 'Rezultatele interogării'; + $lang['strshow'] = 'AfiÅŸare'; + $lang['strempty'] = 'Golire'; + $lang['strlanguage'] = 'Limbă'; + $lang['strencoding'] = 'Codificare'; + $lang['strvalue'] = 'Valoare'; + $lang['strunique'] = 'Unic'; + $lang['strprimary'] = 'Primar'; + $lang['strexport'] = 'Export'; + $lang['strimport'] = 'Import'; + $lang['strallowednulls'] = 'Caractere NULL permise'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Åžir/câmp gol'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Administrare'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analiză'; + $lang['strclusterindex'] = 'Grupare'; + $lang['strclustered'] = 'Grupat?'; + $lang['strreindex'] = 'Re-indexare'; + $lang['strrun'] = 'Executare'; + $lang['stradd'] = 'Adăugare'; + $lang['strevent'] = 'Eveniment'; + $lang['strwhere'] = 'ÃŽn schimb'; + $lang['strinstead'] = 'Execută în schimb'; + $lang['strwhen'] = 'Când'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Dată'; + $lang['strconfirm'] = 'Confirmare'; + $lang['strexpression'] = 'Expresie'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Expandare'; + $lang['strcollapse'] = 'Restrângere'; + $lang['strexplain'] = 'Explicare'; + $lang['strexplainanalyze'] = 'Explicare & Analiză'; + $lang['strfind'] = 'Căutare'; + $lang['stroptions'] = 'OpÅ£iuni'; + $lang['strrefresh'] = 'Reîmprospătare'; + $lang['strdownload'] = 'Transfer'; + $lang['strdownloadgzipped'] = 'Transfer comprimat cu gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OID-uri'; + $lang['stradvanced'] = 'Avansat'; + $lang['strvariables'] = 'Variabile'; + $lang['strprocess'] = 'Proces'; + $lang['strprocesses'] = 'Procese'; + $lang['strsetting'] = 'Valoare'; + $lang['streditsql'] = 'Editare SQL'; + $lang['strruntime'] = 'Timp total de rulare:%s ms'; + $lang['strpaginate'] = 'Paginare rezultate'; + $lang['struploadscript'] = 'sau încărcare script SQL:'; + $lang['strstarttime'] = 'Timp start'; + $lang['strfile'] = 'FiÅŸier'; + $lang['strfileimported'] = 'FiÅŸier importat'; + $lang['strtrycred'] = 'FolosiÅ£i aceste acreditări pentru toate serverele'; + $lang['strexecute'] = 'Executare'; + + // Database sizes + $lang['strsize'] = 'Dimensiune'; + $lang['strbytes'] = 'octeÅ£i'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Această aplicaÅ£ie funcÅ£ionează cel mai bine într-un browser ce suportă frame-uri , dar poate fi folosită ÅŸi fără frame-uri, urmând legătura de mai jos.'; + $lang['strnoframeslink'] = 'Fără frame-uri'; + $lang['strbadconfig'] = 'FiÅŸierul config.inc.php este învechit. Trebuie să-l re-generaÅ£i folosind noul fiÅŸier config.inc.php-dist.'; + $lang['strnotloaded'] = 'Instalarea de PHP nu suportă PostgreSQL. Trebuie să re-compilaÅ£i PHP folosind opÅ£iunea --with-pgsql la configurare.'; + $lang['strpostgresqlversionnotsupported'] = 'Versiune de PostgreSQL ne-suportată. ActualizaÅ£i la versiunea %s sau ulterioară.'; + $lang['strbadschema'] = 'Schemă specificată incorectă.'; + $lang['strbadencoding'] = 'Imposibil de setat codificarea client în baza de date.'; + $lang['strsqlerror'] = 'Eroare SQL:'; + $lang['strinstatement'] = 'ÃŽn instrucÅ£iunea:'; + $lang['strinvalidparam'] = 'Parametrii scriptului sunt incorecÅ£i.'; + $lang['strnodata'] = 'Nici un rând găsit.'; + $lang['strnoobjects'] = 'Nici un obiect găsit.'; + $lang['strrownotunique'] = 'Nici un identificator unic pentru acest rând.'; + $lang['strnouploads'] = 'ÃŽncărcarea de fiÅŸiere este dezactivată.'; + $lang['strimporterror'] = 'Eroare la importare.'; + $lang['strimporterror-fileformat'] = 'Eroare la importare: Imposibil de determinat în mod automat formatul fiÅŸierului.'; + $lang['strimporterrorline'] = 'Eroare la importare pe linia %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Eroare la importare pe linia %s: Linia nu are numărul corect de coloane.'; + $lang['strimporterror-uploadedfile'] = 'Eroare la importare: FiÅŸierul nu a putut fi încărcat pe server'; + $lang['strcannotdumponwindows'] = 'Descărcarea de tabele complexe ÅŸi nume de scheme în Windows nu este suportată.'; + + // Tables + $lang['strtable'] = 'Tabelă'; + $lang['strtables'] = 'Tabele'; + $lang['strshowalltables'] = 'AfiÅŸare toate tabelele'; + $lang['strnotables'] = 'Nici o tabelă găsită.'; + $lang['strnotable'] = 'Nici o tabelă găsită.'; + $lang['strcreatetable'] = 'Creare tabelă.'; + $lang['strtablename'] = 'Nume tabelă'; + $lang['strtableneedsname'] = 'SpecificaÅ£i un nume pentru tabelă.'; + $lang['strtableneedsfield'] = 'SpecificaÅ£i cel puÅ£in un câmp.'; + $lang['strtableneedscols'] = 'SpecificaÅ£i un număr corect de coloane.'; + $lang['strtablecreated'] = 'Tabelă creată.'; + $lang['strtablecreatedbad'] = 'Creare tabelă eÅŸuată.'; + $lang['strconfdroptable'] = 'Sigur ÅŸtergeÅ£i tabela "%s"?'; + $lang['strtabledropped'] = 'Tabelă ÅŸtearsă.'; + $lang['strtabledroppedbad'] = 'Åžtergere tabelă eÅŸuată.'; + $lang['strconfemptytable'] = 'Sigur goliÅ£i tabela "%s"?'; + $lang['strtableemptied'] = 'Tabelă golită.'; + $lang['strtableemptiedbad'] = 'Golire tabelă eÅŸuată.'; + $lang['strinsertrow'] = 'Inserare rând'; + $lang['strrowinserted'] = 'Rând inserat'; + $lang['strrowinsertedbad'] = 'Inserare rând eÅŸuată.'; + $lang['strrowduplicate'] = 'Inserare de rând eÅŸuată, s-a încercat inserarea unui duplicat.'; + $lang['streditrow'] = 'Editare rând'; + $lang['strrowupdated'] = 'Rând actualizat.'; + $lang['strrowupdatedbad'] = 'Actualizare rând eÅŸuată.'; + $lang['strdeleterow'] = 'Åžtergere rând.'; + $lang['strconfdeleterow'] = 'Sigur ÅŸtergeÅ£i acest rând?'; + $lang['strrowdeleted'] = 'Rând ÅŸters.'; + $lang['strrowdeletedbad'] = 'Åžtergere rând eÅŸuată.'; + $lang['strinsertandrepeat'] = 'Inserare & Repetare'; + $lang['strnumcols'] = 'Număr de coloane'; + $lang['strcolneedsname'] = 'SpecificaÅ£i un nume pentru coloană'; + $lang['strselectallfields'] = 'Selectare toate câmpurile'; + $lang['strselectneedscol'] = 'AfiÅŸaÅ£i cel puÅ£in o coloană.'; + $lang['strselectunary'] = 'Operatorii unari nu pot avea valori.'; + $lang['straltercolumn'] = 'Modificare coloană'; + $lang['strcolumnaltered'] = 'Coloană modificată.'; + $lang['strcolumnalteredbad'] = 'Modificare coloană eÅŸuată.'; + $lang['strconfdropcolumn'] = 'Sigur ÅŸtergeÅ£i coloana "%s" din tabela "%s"?'; + $lang['strcolumndropped'] = 'Coloană ÅŸtearsă.'; + $lang['strcolumndroppedbad'] = 'Åžtergere coloană eÅŸuată.'; + $lang['straddcolumn'] = 'Adăugare coloană'; + $lang['strcolumnadded'] = 'Coloană adăugată.'; + $lang['strcolumnaddedbad'] = 'Adăugare coloană eÅŸuată.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabelă modificată.'; + $lang['strtablealteredbad'] = 'Modificare tabelă eÅŸuată.'; + $lang['strdataonly'] = 'Numai date'; + $lang['strstructureonly'] = 'Numai structură'; + $lang['strstructureanddata'] = 'Structură ÅŸi date'; + $lang['strtabbed'] = 'Cu tab-uri'; + $lang['strauto'] = 'Automat'; + $lang['strconfvacuumtable'] = 'Sigur executaÅ£i "vacuum" pe "%s"?'; + $lang['strestimatedrowcount'] = 'Număr estimat de rânduri'; + + // Columns + $lang['strcolprop'] = 'Proprietăţi coloană'; + + // Users + $lang['struser'] = 'Utilizator'; + $lang['strusers'] = 'Utilizatori'; + $lang['strusername'] = 'Nume utilizator'; + $lang['strpassword'] = 'Parolă'; + $lang['strsuper'] = 'Utilizator privilegiat?'; + $lang['strcreatedb'] = 'Creează BD?'; + $lang['strexpires'] = 'Expiră la'; + $lang['strsessiondefaults'] = 'Valori implicite pentru sesiune'; + $lang['strnousers'] = 'Nici un utilizator găsit.'; + $lang['struserupdated'] = 'Utilizator actualizat.'; + $lang['struserupdatedbad'] = 'Actualizare utilizator eÅŸuată.'; + $lang['strshowallusers'] = 'AfiÅŸare toÅ£i utilizatorii'; + $lang['strcreateuser'] = 'Creare utilizator'; + $lang['struserneedsname'] = 'SpecificaÅ£i un nume pentru utilizator.'; + $lang['strusercreated'] = 'Utilizator creat.'; + $lang['strusercreatedbad'] = 'Creare utilizator eÅŸuată.'; + $lang['strconfdropuser'] = 'Sigur ÅŸtergeÅ£i utilizatorul "%s"?'; + $lang['struserdropped'] = 'Utilizator ÅŸters.'; + $lang['struserdroppedbad'] = 'Åžtergere utilizator eÅŸuată.'; + $lang['straccount'] = 'Cont'; + $lang['strchangepassword'] = 'Schimbare parolă'; + $lang['strpasswordchanged'] = 'Parolă schimbată.'; + $lang['strpasswordchangedbad'] = 'Schimbare parolă eÅŸuată.'; + $lang['strpasswordshort'] = 'Parola este prea scurtă.'; + $lang['strpasswordconfirm'] = 'Parola nu se confirmă.'; + + // Groups + $lang['strgroup'] = 'Grup'; + $lang['strgroups'] = 'Grupuri'; + $lang['strshowallgroups'] = 'AfiÅŸare toate grupurile'; + $lang['strnogroup'] = 'Grup negăsit.'; + $lang['strnogroups'] = 'Nici un grup găsit.'; + $lang['strcreategroup'] = 'Creare grup'; + $lang['strgroupneedsname'] = 'SpecificaÅ£i un nume pentru grup.'; + $lang['strgroupcreated'] = 'Grup creat.'; + $lang['strgroupcreatedbad'] = 'Creare grup eÅŸuată.'; + $lang['strconfdropgroup'] = 'Sigur ÅŸtergeÅ£i grupul "%s"?'; + $lang['strgroupdropped'] = 'Grup ÅŸters.'; + $lang['strgroupdroppedbad'] = 'Åžtergere grup eÅŸuată.'; + $lang['strmembers'] = 'Membri'; + $lang['strmemberof'] = 'Membru al'; + $lang['stradminmembers'] = 'Membri administratori'; + $lang['straddmember'] = 'Adăugare membru'; + $lang['strmemberadded'] = 'Membru adăugat.'; + $lang['strmemberaddedbad'] = 'Adăugare membru eÅŸuată.'; + $lang['strdropmember'] = 'Åžtergere membru'; + $lang['strconfdropmember'] = 'Sigur ÅŸtergeÅ£i membrul "%s" din grupul "%s"?'; + $lang['strmemberdropped'] = 'Membru ÅŸters.'; + $lang['strmemberdroppedbad'] = 'Åžtergere membru eÅŸuată.'; + + // Roles + $lang['strrole'] = 'Rol'; + $lang['strroles'] = 'Roluri'; + $lang['strshowallroles'] = 'AfiÅŸare toate rolurile'; + $lang['strnoroles'] = 'Nici un rol găsit'; + $lang['strinheritsprivs'] = 'MoÅŸtenire privilegii?'; + $lang['strcreaterole'] = 'Creare rol'; + $lang['strcancreaterole'] = 'Creare rol posibilă?'; + $lang['strrolecreated'] = 'Rol creat'; + $lang['strrolecreatedbad'] = 'Creare rol eÅŸuată'; + $lang['stralterrole'] = 'Modificare rol'; + $lang['strrolealtered'] = 'Rol modificat'; + $lang['strrolealteredbad'] = 'Modificare rol eÅŸuată'; + $lang['strcanlogin'] = 'Autentificare posibilă?'; + $lang['strconnlimit'] = 'Limită conectare'; + $lang['strdroprole'] = 'Åžtergere rol'; + $lang['strconfdroprole'] = 'Sigur ÅŸtergeÅ£i rolul "%s"?'; + $lang['strroledropped'] = 'Rol ÅŸters'; + $lang['strroledroppedbad'] = 'Åžtergere rol eÅŸuată'; + $lang['strnolimit'] = 'Fără limită'; + $lang['strnever'] = 'Niciodată'; + $lang['strroleneedsname'] = 'SpecificaÅ£i un nume pentru rol'; + + // Privileges + $lang['strprivilege'] = 'Privilegiu'; + $lang['strprivileges'] = 'Privilegii'; + $lang['strnoprivileges'] = 'Acest obiect are privilegiile implicite ale proprietarului.'; + $lang['strgrant'] = 'Acordare'; + $lang['strrevoke'] = 'Revocare'; + $lang['strgranted'] = 'Privilegii schimbate.'; + $lang['strgrantfailed'] = 'Schimbare privilegii eÅŸuată.'; + $lang['strgrantbad'] = 'SpecificaÅ£i cel puÅ£in un utilizator sau grup ÅŸi cel puÅ£in un privilegiu.'; + $lang['strgrantor'] = 'Acordat de'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Bază de date'; + $lang['strdatabases'] = 'Baze de date'; + $lang['strshowalldatabases'] = 'AfiÅŸare toate bazele de date'; + $lang['strnodatabases'] = 'Nici o bază de date găsită.'; + $lang['strcreatedatabase'] = 'Creare bază de date'; + $lang['strdatabasename'] = 'Nume bază de date'; + $lang['strdatabaseneedsname'] = 'SpecificaÅ£i un nume pentru baza de date.'; + $lang['strdatabasecreated'] = 'Bază de date creată.'; + $lang['strdatabasecreatedbad'] = 'Creare bază de date eÅŸuată.'; + $lang['strconfdropdatabase'] = 'Sigur ÅŸtergeÅ£i baza de date "%s"?'; + $lang['strdatabasedropped'] = 'Bază de date ÅŸtearsă.'; + $lang['strdatabasedroppedbad'] = 'Åžtergere bază de date eÅŸuată.'; + $lang['strentersql'] = 'IntroduceÅ£i instrucÅ£iunea SQL de executat:'; + $lang['strsqlexecuted'] = 'InstrucÅ£iune SQL executată.'; + $lang['strvacuumgood'] = 'Vacuum terminat.'; + $lang['strvacuumbad'] = 'Vacuum eÅŸuat.'; + $lang['stranalyzegood'] = 'Analiză terminată.'; + $lang['stranalyzebad'] = 'Analiză eÅŸuată.'; + $lang['strreindexgood'] = 'Re-indexare terminată.'; + $lang['strreindexbad'] = 'Re-indexare eÅŸuată.'; + $lang['strfull'] = 'Complet'; + $lang['strfreeze'] = 'ÃŽngheÅ£are'; + $lang['strforce'] = 'ForÅ£are'; + $lang['strsignalsent'] = 'Semnal trimis.'; + $lang['strsignalsentbad'] = 'Trimitere semnal eÅŸuată.'; + $lang['strallobjects'] = 'Toate obiectele'; + $lang['strdatabasealtered'] = 'Bază de date modificată.'; + $lang['strdatabasealteredbad'] = 'Modificarea bazei de date a eÅŸuat.'; + + // Views + $lang['strview'] = 'Vizualizare'; + $lang['strviews'] = 'Vizualizări'; + $lang['strshowallviews'] = 'AfiÅŸare toate vizualizările'; + $lang['strnoview'] = 'Nici o vizualizare găsită.'; + $lang['strnoviews'] = 'Nici o vizualizare găsită.'; + $lang['strcreateview'] = 'Creare vizualizare'; + $lang['strviewname'] = 'Nume vizualizare'; + $lang['strviewneedsname'] = 'SpecificaÅ£i un nume pentru vizualizare.'; + $lang['strviewneedsdef'] = 'SpecificaÅ£i o definiÅ£ie pentru vizualizare.'; + $lang['strviewneedsfields'] = 'SpecificaÅ£i coloanele pe care le doriÅ£i selectate în vizualizare.'; + $lang['strviewcreated'] = 'Vizualizare creată.'; + $lang['strviewcreatedbad'] = 'Creare vizualizare eÅŸuată.'; + $lang['strconfdropview'] = 'Sigur ÅŸtergeÅ£i vizualizarea "%s"?'; + $lang['strviewdropped'] = 'Vizualizare ÅŸtearsă.'; + $lang['strviewdroppedbad'] = 'Åžtergere vizualizare eÅŸuată.'; + $lang['strviewupdated'] = 'Vizualizare actualizată'; + $lang['strviewupdatedbad'] = 'Actualizare vizualizare eÅŸuată.'; + $lang['strviewlink'] = 'Chei de legătură'; + $lang['strviewconditions'] = 'CondiÅ£ii suplimentare'; + $lang['strcreateviewwiz'] = 'Creare vizualizare folosind expertul'; + + // Sequences + $lang['strsequence'] = 'Secvenţă'; + $lang['strsequences'] = 'SecvenÅ£e'; + $lang['strshowallsequences'] = 'AfiÅŸare toate secvenÅ£ele'; + $lang['strnosequence'] = 'Nici o secvenţă găsită.'; + $lang['strnosequences'] = 'Nici o secvenţă găsită.'; + $lang['strcreatesequence'] = 'Creare secvenţă'; + $lang['strlastvalue'] = 'Ultima valoare'; + $lang['strincrementby'] = 'Incrementare cu'; + $lang['strstartvalue'] = 'Valoare de start'; + $lang['strmaxvalue'] = 'Valoare maximă'; + $lang['strminvalue'] = 'Valoare minimă'; + $lang['strcachevalue'] = 'Valoare cache'; + $lang['strlogcount'] = 'Log count'; + $lang['striscycled'] = 'Ciclică?'; + $lang['strsequenceneedsname'] = 'SpecificaÅ£i un nume pentru secvenţă.'; + $lang['strsequencecreated'] = 'Secvenţă creată.'; + $lang['strsequencecreatedbad'] = 'Creare secvenţă eÅŸuată.'; + $lang['strconfdropsequence'] = 'Sigur ÅŸtergeÅ£i secvenÅ£a "%s"?'; + $lang['strsequencedropped'] = 'Secvenţă ÅŸtearsă.'; + $lang['strsequencedroppedbad'] = 'Åžtergere secvenţă eÅŸuată.'; + $lang['strsequencereset'] = 'ReiniÅ£ializare secvenţă.'; + $lang['strsequenceresetbad'] = 'ReiniÅ£ializare secvenţă eÅŸuată.'; + $lang['straltersequence'] = 'Modificare secvenţă'; + $lang['strsequencealtered'] = 'Secvenţă modificată'; + $lang['strsequencealteredbad'] = 'Modificare secvenţă eÅŸuată'; + $lang['strsetval'] = 'Setare valoare'; + $lang['strsequencesetval'] = 'Valoare secvenţă setată'; + $lang['strsequencesetvalbad'] = 'Setare valoare secvenţă eÅŸuată'; + $lang['strnextval'] = 'Valoare increment'; + $lang['strsequencenextval'] = 'Secvenţă incrementată'; + $lang['strsequencenextvalbad'] = 'Incremetare secvenţă eÅŸuată'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indexuri'; + $lang['strindexname'] = 'Nume index'; + $lang['strshowallindexes'] = 'AfiÅŸare toate indexurile'; + $lang['strnoindex'] = 'Nici un index găsit.'; + $lang['strnoindexes'] = 'Nici un index găsit.'; + $lang['strcreateindex'] = 'Creare index'; + $lang['strtabname'] = 'Nume tabelă'; + $lang['strcolumnname'] = 'Nume coloană'; + $lang['strindexneedsname'] = 'SpecificaÅ£i un nume pentru index.'; + $lang['strindexneedscols'] = 'Indexurile necesită un număr corect de coloane.'; + $lang['strindexcreated'] = 'Index creat'; + $lang['strindexcreatedbad'] = 'Creare index eÅŸuată.'; + $lang['strconfdropindex'] = 'Sigur ÅŸtergeÅ£i indexul "%s"?'; + $lang['strindexdropped'] = 'Index ÅŸters.'; + $lang['strindexdroppedbad'] = 'Åžtergere index eÅŸuată.'; + $lang['strkeyname'] = 'Nume cheie'; + $lang['struniquekey'] = 'Cheie unică'; + $lang['strprimarykey'] = 'Cheie primară'; + $lang['strindextype'] = 'Tip de index'; + $lang['strtablecolumnlist'] = 'Coloane în tabelă'; + $lang['strindexcolumnlist'] = 'Coloane în index'; + $lang['strconfcluster'] = 'Sigur grupaÅ£i "%s"?'; + $lang['strclusteredgood'] = 'Grupare completă.'; + $lang['strclusteredbad'] = 'Grupare eÅŸuată.'; + $lang['strcluster'] = 'Grupare'; + + // Rules + $lang['strrules'] = 'Reguli'; + $lang['strrule'] = 'Regulă'; + $lang['strshowallrules'] = 'AfiÅŸare toate regulile'; + $lang['strnorule'] = 'Nici o regulă găsită.'; + $lang['strnorules'] = 'Nici o regulă găsită.'; + $lang['strcreaterule'] = 'Creare regulă'; + $lang['strrulename'] = 'Nume regulă'; + $lang['strruleneedsname'] = 'SpecificaÅ£i un nume pentru regulă.'; + $lang['strrulecreated'] = 'Regulă creată.'; + $lang['strrulecreatedbad'] = 'Creare regulă eÅŸuată.'; + $lang['strconfdroprule'] = 'Sigur ÅŸtergeÅ£i regula "%s"?'; + $lang['strruledropped'] = 'Regulă ÅŸtearsă.'; + $lang['strruledroppedbad'] = 'Åžtergere regulă eÅŸuată.'; + + // Constraints + $lang['strconstraint'] = 'RestricÅ£ie'; + $lang['strconstraints'] = 'RestricÅ£ii'; + $lang['strshowallconstraints'] = 'AfiÅŸare toate restricÅ£iile'; + $lang['strnoconstraints'] = 'Nici o restricÅ£ie găsită.'; + $lang['strcreateconstraint'] = 'Creare restricÅ£ie'; + $lang['strconstraintcreated'] = 'RestricÅ£ie creată.'; + $lang['strconstraintcreatedbad'] = 'Creare restricÅ£ie eÅŸuată.'; + $lang['strconfdropconstraint'] = 'Sigur ÅŸtergeÅ£i restricÅ£ia "%s"?'; + $lang['strconstraintdropped'] = 'RestricÅ£ie ÅŸtearsă.'; + $lang['strconstraintdroppedbad'] = 'Åžtergere restricÅ£ie eÅŸuată.'; + $lang['straddcheck'] = 'Adăugare verificare'; + $lang['strcheckneedsdefinition'] = 'Verificarea de restricÅ£ie necesită o definiÅ£ie.'; + $lang['strcheckadded'] = 'Verificare de restricÅ£ie adăugată.'; + $lang['strcheckaddedbad'] = 'Adăugare verificare de restricÅ£ie eÅŸuată.'; + $lang['straddpk'] = 'Adăugare cheie primară'; + $lang['strpkneedscols'] = 'Cheia primară necesită cel puÅ£in o coloană.'; + $lang['strpkadded'] = 'Cheie primară adăugată.'; + $lang['strpkaddedbad'] = 'Adăugare cheie primară eÅŸuată.'; + $lang['stradduniq'] = 'Adăugare cheie unică'; + $lang['struniqneedscols'] = 'Cheia unică necesită cel puÅ£in o coloană.'; + $lang['struniqadded'] = 'Cheie unică adăugată.'; + $lang['struniqaddedbad'] = 'Adăugare cheie unică eÅŸuată.'; + $lang['straddfk'] = 'Adăugare cheie străină'; + $lang['strfkneedscols'] = 'Cheia străină necesită cel puÅ£in o coloană.'; + $lang['strfkneedstarget'] = 'Cheia străină necesită o tabelă de destinaÅ£ie.'; + $lang['strfkadded'] = 'Cheie străină adăugată.'; + $lang['strfkaddedbad'] = 'Adăugare cheie străină eÅŸuată.'; + $lang['strfktarget'] = 'Tabelă de destinaÅ£ie'; + $lang['strfkcolumnlist'] = 'Coloane în cheie'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'FuncÅ£ie'; + $lang['strfunctions'] = 'FuncÅ£ii'; + $lang['strshowallfunctions'] = 'AfiÅŸare toate funcÅ£iile'; + $lang['strnofunction'] = 'Nici o functie găsită.'; + $lang['strnofunctions'] = 'Nici o functie găsită.'; + $lang['strcreateplfunction'] = 'Creare funcÅ£ie SQL/PL'; + $lang['strcreateinternalfunction'] = 'Creare funcÅ£ie internă'; + $lang['strcreatecfunction'] = 'Creare funcÅ£ie C'; + $lang['strfunctionname'] = 'Nume funcÅ£ie'; + $lang['strreturns'] = 'ÃŽntoarce'; + $lang['strproglanguage'] = 'Limbaj de programare'; + $lang['strfunctionneedsname'] = 'SpecificaÅ£i un nume pentru funcÅ£ie.'; + $lang['strfunctionneedsdef'] = 'SpecificaÅ£i o definiÅ£ie pentru functie.'; + $lang['strfunctioncreated'] = 'FuncÅ£ie creată.'; + $lang['strfunctioncreatedbad'] = 'Creare funcÅ£ie eÅŸuată.'; + $lang['strconfdropfunction'] = 'Sigur ÅŸtergeÅ£i funcÅ£ia "%s"?'; + $lang['strfunctiondropped'] = 'FuncÅ£ie ÅŸtearsă.'; + $lang['strfunctiondroppedbad'] = 'Åžtergere funcÅ£ie eÅŸuată.'; + $lang['strfunctionupdated'] = 'FuncÅ£ie actualizată.'; + $lang['strfunctionupdatedbad'] = 'Actualizare funcÅ£ie eÅŸuată.'; + $lang['strobjectfile'] = 'FiÅŸier obiect'; + $lang['strlinksymbol'] = 'Simbol de legătură'; + $lang['strarguments'] = 'Argumente'; + $lang['strargmode'] = 'Mod'; + $lang['strargtype'] = 'Tip'; + $lang['strargadd'] = 'Adăugare alt argument'; + $lang['strargremove'] = 'Eliminare argument'; + $lang['strargnoargs'] = 'Această funcÅ£ie nu acceptă nici un argument'; + $lang['strargenableargs'] = 'Activare argumente pasate acestei funcÅ£ii'; + $lang['strargnorowabove'] = 'Trebuie să existe un rând deasupra acestui rând'; + $lang['strargnorowbelow'] = 'Trebuie să existe un rând dedesubtul acestui rând'; + $lang['strargraise'] = 'Mutare în sus'; + $lang['strarglower'] = 'Mutare în jos'; + $lang['strargremoveconfirm'] = 'Sigur eliminaÅ£i acest argument? Această acÅ£iune NU poate fi revocată.'; + + // Triggers + $lang['strtrigger'] = 'DeclanÅŸator'; + $lang['strtriggers'] = 'DeclanÅŸatori'; + $lang['strshowalltriggers'] = 'AfiÅŸare toate declanÅŸatoarele'; + $lang['strnotrigger'] = 'Nici un declanÅŸator găsit.'; + $lang['strnotriggers'] = 'Nici un declanÅŸator găsit.'; + $lang['strcreatetrigger'] = 'Creare declanÅŸator'; + $lang['strtriggerneedsname'] = 'SpecificaÅ£i un nume pentru declanÅŸator.'; + $lang['strtriggerneedsfunc'] = 'SpecificaÅ£i o funcÅ£ie pentru declanÅŸator.'; + $lang['strtriggercreated'] = 'DeclanÅŸator creat.'; + $lang['strtriggercreatedbad'] = 'Creare declanÅŸator eÅŸuată.'; + $lang['strconfdroptrigger'] = 'Sigur ÅŸtergeÅ£i declanÅŸatorul "%s" de pe "%s"?'; + $lang['strconfenabletrigger'] = 'Sigur activaÅ£i declanÅŸatorul "%s" pentru "%s"?'; + $lang['strconfdisabletrigger'] = 'Sigur dezactivaÅ£i declanÅŸatorul "%s" pentru "%s"?'; + $lang['strtriggerdropped'] = 'DeclanÅŸator ÅŸters.'; + $lang['strtriggerdroppedbad'] = 'Åžtergere declanÅŸator eÅŸuată.'; + $lang['strtriggerenabled'] = 'DeclanÅŸator activat'; + $lang['strtriggerenabledbad'] = 'Activare declanÅŸator eÅŸuată'; + $lang['strtriggerdisabled'] = 'DeclanÅŸator dezactivat'; + $lang['strtriggerdisabledbad'] = 'Dezactivare declanÅŸator eÅŸuată'; + $lang['strtriggeraltered'] = 'DeclanÅŸator modificat.'; + $lang['strtriggeralteredbad'] = 'Modificare declanÅŸator eÅŸuată.'; + $lang['strforeach'] = 'Pentru fiecare'; + + // Types + $lang['strtype'] = 'Tip'; + $lang['strtypes'] = 'Tipuri'; + $lang['strshowalltypes'] = 'AfiÅŸare toate tipurile'; + $lang['strnotype'] = 'Nici un tip găsit.'; + $lang['strnotypes'] = 'Nici un tip găsit.'; + $lang['strcreatetype'] = 'Creare tip'; + $lang['strcreatecomptype'] = 'Creare tip compus'; + $lang['strtypeneedsfield'] = 'SpecificaÅ£i cel puÅ£in un câmp.'; + $lang['strtypeneedscols'] = 'SpecificaÅ£i un număr corect de cămpuri.'; + $lang['strtypename'] = 'Nume tip'; + $lang['strinputfn'] = 'FuncÅ£ie de intrare'; + $lang['stroutputfn'] = 'FuncÅ£ie de ieÅŸire'; + $lang['strpassbyval'] = 'Transmis prin valoare?'; + $lang['stralignment'] = 'Aliniere'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Delimitator'; + $lang['strstorage'] = 'Stocare'; + $lang['strfield'] = 'Câmp'; + $lang['strnumfields'] = 'Număr de câmpuri'; + $lang['strtypeneedsname'] = 'SpecificaÅ£i un nume pentru tip.'; + $lang['strtypeneedslen'] = 'SpecificaÅ£i o lungime pentru tip.'; + $lang['strtypecreated'] = 'Tip creat.'; + $lang['strtypecreatedbad'] = 'Creare tip eÅŸuată.'; + $lang['strconfdroptype'] = 'Sigur ÅŸtergeÅ£i tipul "%s"?'; + $lang['strtypedropped'] = 'Tip ÅŸters.'; + $lang['strtypedroppedbad'] = 'Åžtergere tip eÅŸuată.'; + $lang['strflavor'] = 'Flavor'; + $lang['strbasetype'] = 'Bază'; + $lang['strcompositetype'] = 'Compus'; + $lang['strpseudotype'] = 'Pseudo'; + + // Schemas + $lang['strschema'] = 'Schemă'; + $lang['strschemas'] = 'Scheme'; + $lang['strshowallschemas'] = 'AfiÅŸare toate schemele'; + $lang['strnoschema'] = 'Nici o schemă găsită.'; + $lang['strnoschemas'] = 'Nici o schemă găsită.'; + $lang['strcreateschema'] = 'Creare schemă'; + $lang['strschemaname'] = 'Nume schemă'; + $lang['strschemaneedsname'] = 'SpecificaÅ£i un nume pentru schemă.'; + $lang['strschemacreated'] = 'Schemă creată.'; + $lang['strschemacreatedbad'] = 'Creare schemă eÅŸuată.'; + $lang['strconfdropschema'] = 'Sigur ÅŸtergeÅ£i schema "%s"?'; + $lang['strschemadropped'] = 'Schemă ÅŸtearsă.'; + $lang['strschemadroppedbad'] = 'Åžtergere schemă eÅŸuată.'; + $lang['strschemaaltered'] = 'Schemă modificată.'; + $lang['strschemaalteredbad'] = 'Modificare schemă eÅŸuată.'; + $lang['strsearchpath'] = 'Cale de căutare pentru schemă'; + + // Reports + + // Domains + $lang['strdomain'] = 'Domeniu'; + $lang['strdomains'] = 'Domenii'; + $lang['strshowalldomains'] = 'AfiÅŸare toate domeniile'; + $lang['strnodomains'] = 'Nici un domeniu găsit.'; + $lang['strcreatedomain'] = 'Creare domeniu'; + $lang['strdomaindropped'] = 'Domeniu ÅŸters.'; + $lang['strdomaindroppedbad'] = 'Åžtergere domeniu eÅŸuată.'; + $lang['strconfdropdomain'] = 'Sigur ÅŸtergeÅ£i domeniul "%s"?'; + $lang['strdomainneedsname'] = 'SpecificaÅ£i un nume pentru domeniu.'; + $lang['strdomaincreated'] = 'Domeniu creat.'; + $lang['strdomaincreatedbad'] = 'Creare domeniu eÅŸuată.'; + $lang['strdomainaltered'] = 'Domeniu modificat.'; + $lang['strdomainalteredbad'] = 'Modificare domeniu eÅŸuată.'; + + // Operators + $lang['stroperator'] = 'Operator'; + $lang['stroperators'] = 'Operatori'; + $lang['strshowalloperators'] = 'AfiÅŸare toÅ£i operatorii'; + $lang['strnooperator'] = 'Nici un operator găsit.'; + $lang['strnooperators'] = 'Nici un operator găsit.'; + $lang['strcreateoperator'] = 'Creare operator'; + $lang['strleftarg'] = 'Tipul argumentului stâng'; + $lang['strrightarg'] = 'Tipul argumentului drept'; + $lang['strcommutator'] = 'Comutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'RelaÅ£ionare'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'ÃŽmbină'; + $lang['strleftsort'] = 'Sortare stânga'; + $lang['strrightsort'] = 'Sortare dreapta'; + $lang['strlessthan'] = 'Mai mic decăt'; + $lang['strgreaterthan'] = 'Mai mare decăt'; + $lang['stroperatorneedsname'] = 'SpecificaÅ£i un nume pentru operator.'; + $lang['stroperatorcreated'] = 'Operator creat.'; + $lang['stroperatorcreatedbad'] = 'Creare operator eÅŸuată.'; + $lang['strconfdropoperator'] = 'Sigur ÅŸtergeÅ£i operatorul "%s"?'; + $lang['stroperatordropped'] = 'Operator ÅŸters.'; + $lang['stroperatordroppedbad'] = 'Åžtergere operator eÅŸuată.'; + + // Casts + $lang['strcasts'] = 'Conversii de tip'; + $lang['strnocasts'] = 'Nici o conversie de tip găsită.'; + $lang['strsourcetype'] = 'Tip sursă'; + $lang['strtargettype'] = 'Tip destinaÅ£ie'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'ÃŽn alocare'; + $lang['strbinarycompat'] = '(Compatibil binar)'; + + // Conversions + $lang['strconversions'] = 'Conversii'; + $lang['strnoconversions'] = 'Nici o conversie găsită.'; + $lang['strsourceencoding'] = 'Codificare sursă'; + $lang['strtargetencoding'] = 'Codificare destinaÅ£ie'; + + // Languages + $lang['strlanguages'] = 'Limbaje'; + $lang['strnolanguages'] = 'Nici un limbaj găsit.'; + $lang['strtrusted'] = 'Sigur'; + + // Info + $lang['strnoinfo'] = 'Nici o informaÅ£ie disponibilă.'; + $lang['strreferringtables'] = 'Tabele referite'; + $lang['strparenttables'] = 'Tabele părinte'; + $lang['strchildtables'] = 'Tabele copii'; + + // Aggregates + $lang['straggregate'] = 'Agregare'; + $lang['straggregates'] = 'Agregări'; + $lang['strnoaggregates'] = 'Nici o agregare găsită.'; + $lang['stralltypes'] = '(Toate tipurile)'; + $lang['straggrtransfn'] = 'FuncÅ£ie de tranziÅ£ie'; + $lang['strcreateaggregate'] = 'Creare agregare'; + $lang['straggrbasetype'] = 'Tip dată de intrare'; + $lang['straggrsfunc'] = 'FuncÅ£ie tranziÅ£ie de stare'; + $lang['straggrffunc'] = 'FuncÅ£ie finală'; + $lang['straggrinitcond'] = 'CondiÅ£ie iniÅ£ială'; + $lang['straggrsortop'] = 'Operator sortare'; + $lang['strdropaggregate'] = 'Åžtergere agregare'; + $lang['strconfdropaggregate'] = 'Sigur ÅŸtergeÅ£i agregarea "%s"?'; + $lang['straggregatedropped'] = 'Agregare ÅŸtearsă.'; + $lang['straggregatedroppedbad'] = 'Åžtergere agregare eÅŸuată.'; + $lang['stralteraggregate'] = 'Modificare agregare'; + $lang['straggraltered'] = 'Agregare modificată.'; + $lang['straggralteredbad'] = 'Modificare agregare eÅŸuată.'; + $lang['straggrneedsname'] = 'SpecificaÅ£i un nume pentru agregare'; + $lang['straggrneedsbasetype'] = 'SpecificaÅ£i tipul de dată de intrare pentru agregare'; + $lang['straggrneedssfunc'] = 'SpecificaÅ£i numele funcÅ£iei tranziÅ£iei de stare pentru agregare'; + $lang['straggrneedsstype'] = 'SpecificaÅ£i tipul datei pentru valoarea stării agregării'; + $lang['straggrcreated'] = 'Agregare creată.'; + $lang['straggrcreatedbad'] = 'Creare agregare eÅŸuată.'; + $lang['straggrshowall'] = 'AfiÅŸare toate agregările'; + + // Operator Classes + $lang['stropclasses'] = 'Clase de operatori'; + $lang['strnoopclasses'] = 'Nici o clasă de operatori găsită.'; + $lang['straccessmethod'] = 'Metodă de acces'; + + // Stats and performance + $lang['strrowperf'] = 'Performanţă rând'; + $lang['strioperf'] = 'Performanţă I/O'; + $lang['stridxrowperf'] = 'Performanţă index/rând'; + $lang['stridxioperf'] = 'Performanţă index I/O'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'SecvenÅ£ial'; + $lang['strscan'] = 'Scanare'; + $lang['strread'] = 'Citire'; + $lang['strfetch'] = 'Transfer'; + $lang['strheap'] = 'Stivă'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'Index TOAST'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disc'; + $lang['strrows2'] = 'Rânduri'; + + // Tablespaces + $lang['strtablespace'] = 'SpaÅ£iu de tabele'; + $lang['strtablespaces'] = 'SpaÅ£ii de tabele'; + $lang['strshowalltablespaces'] = 'AfiÅŸare toate spaÅ£iile de tabele'; + $lang['strnotablespaces'] = 'Nici un spaÅ£iu de tabele găsit.'; + $lang['strcreatetablespace'] = 'Creare spaÅ£iu de tabele'; + $lang['strlocation'] = 'LocaÅ£ie'; + $lang['strtablespaceneedsname'] = 'SpecificaÅ£i un nume pentru spaÅ£iul de tabele.'; + $lang['strtablespaceneedsloc'] = 'SpecificaÅ£i directorul în care va fi creat spaÅ£iul de tabele.'; + $lang['strtablespacecreated'] = 'SpaÅ£iu de tabele creat.'; + $lang['strtablespacecreatedbad'] = 'Creare spaÅ£iu de tabele eÅŸuată.'; + $lang['strconfdroptablespace'] = 'Sigur ÅŸtergeÅ£i spaÅ£iul de tabele "%s"?'; + $lang['strtablespacedropped'] = 'SpaÅ£iu de tabele ÅŸters.'; + $lang['strtablespacedroppedbad'] = 'Åžtergere ÅŸpaÅ£iu de tabele eÅŸuată.'; + $lang['strtablespacealtered'] = 'SpaÅ£iu de tabele modificat.'; + $lang['strtablespacealteredbad'] = 'Modificare ÅŸpaÅ£iu de tabele eÅŸuată.'; + + // Miscellaneous + $lang['strtopbar'] = '%s rulând pe %s:%s -- SunteÅ£i autentificat ca utilizator "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Ajutor'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Pagini de ajutor'; + $lang['strselecthelppage'] = 'SelectaÅ£i o pagină de ajutor'; + $lang['strinvalidhelppage'] = 'Pagină de ajutor incorectă.'; + $lang['strlogintitle'] = 'Autentificare la %s'; + $lang['strlogoutmsg'] = 'IeÅŸire din %s'; + $lang['strloading'] = 'ÃŽncărcare...'; + $lang['strerrorloading'] = 'Eroare la încărcare'; + $lang['strclicktoreload'] = 'FaceÅ£i clic pentru reîncărcare'; + + // Autovacuum + $lang['strautovacuum'] = 'Autovacuum'; + $lang['strturnedon'] = 'Pornit'; + $lang['strturnedoff'] = 'Oprit'; + $lang['strenabled'] = 'Activat'; + $lang['strvacuumbasethreshold'] = 'Vacuum Base Threshold'; + $lang['strvacuumscalefactor'] = 'Vacuum Scale Factor'; + $lang['stranalybasethreshold'] = 'Analyze Base Threshold'; + $lang['stranalyzescalefactor'] = 'Analyze Scale Factor'; + $lang['strvacuumcostdelay'] = 'Vacuum Cost Delay'; + $lang['strvacuumcostlimit'] = 'Vacuum Cost Limit'; + + // Table-level Locks + $lang['strlocks'] = 'Blocări'; + $lang['strtransaction'] = 'ID tranzacÅ£ie'; + $lang['strprocessid'] = 'ID proces'; + $lang['strmode'] = 'Mod blocare'; + $lang['strislockheld'] = 'Blocaj reÅ£inut?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'TranzacÅ£ii preparate'; + $lang['strxactid'] = 'ID tranzacÅ£ie'; + $lang['strgid'] = 'ID global'; + + + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian-utf8.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian-utf8.php new file mode 100644 index 00000000..12cd7710 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian-utf8.php @@ -0,0 +1,894 @@ +'; + $lang['strfirst'] = '<< Перв.'; + $lang['strlast'] = 'ПоÑл. >>'; + $lang['strfailed'] = 'Прервано'; + $lang['strcreate'] = 'Создать'; + $lang['strcreated'] = 'Создано'; + $lang['strcomment'] = 'Комментарий'; + $lang['strlength'] = 'Длина'; + $lang['strdefault'] = 'По умолчанию'; + $lang['stralter'] = 'Изменить'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Отменить'; + $lang['strkill'] = 'Убить'; + $lang['strac'] = 'Включить автодополнение'; + $lang['strsave'] = 'Сохранить'; + $lang['strreset'] = 'СброÑить'; + $lang['strinsert'] = 'Ð’Ñтавить'; + $lang['strselect'] = 'Выбрать'; + $lang['strdelete'] = 'Удалить'; + $lang['strupdate'] = 'Обновить'; + $lang['strreferences'] = 'СÑылки'; + $lang['stryes'] = 'Да'; + $lang['strno'] = 'Ðет'; + $lang['strtrue'] = 'ИÑтина'; + $lang['strfalse'] = 'Ложь'; + $lang['stredit'] = 'Редактировать'; + $lang['strcolumn'] = 'Ðтрибут'; + $lang['strcolumns'] = 'Ðтрибуты'; + $lang['strrows'] = 'запиÑ(ÑŒ/и/ей)'; + $lang['strrowsaff'] = 'запиÑ(ÑŒ/и/ей) обработано.'; + $lang['strobjects'] = 'объект(а/ов)'; + $lang['strback'] = 'Ðазад'; + $lang['strqueryresults'] = 'Результаты запроÑа'; + $lang['strshow'] = 'Показать'; + $lang['strempty'] = 'ОчиÑтить'; + $lang['strlanguage'] = 'Язык'; + $lang['strencoding'] = 'Кодировка'; + $lang['strvalue'] = 'Значение'; + $lang['strunique'] = 'Уникальный'; + $lang['strprimary'] = 'Первичный'; + $lang['strexport'] = 'ЭкÑпорт'; + $lang['strimport'] = 'Импорт'; + $lang['strallowednulls'] = 'Разрешенные NULL-Ñимволы'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'ПуÑÑ‚Ð°Ñ Ñтрока/поле'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Управление'; + $lang['strvacuum'] = 'ПереÑтроить'; + $lang['stranalyze'] = 'Ðнализировать'; + $lang['strclusterindex'] = 'КлаÑтеризовать'; + $lang['strclustered'] = 'КлаÑтеризован?'; + $lang['strreindex'] = 'ПереÑтроить индекÑ'; + $lang['strexecute'] = 'Выполнить'; + $lang['stradd'] = 'Добавить'; + $lang['strevent'] = 'Событие'; + $lang['strwhere'] = 'Где'; + $lang['strinstead'] = 'Делать вмеÑто'; + $lang['strwhen'] = 'Когда'; + $lang['strformat'] = 'Формат'; + $lang['strdata'] = 'Данные'; + $lang['strconfirm'] = 'Подтвердить'; + $lang['strexpression'] = 'Выражение'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'РаÑширить'; + $lang['strcollapse'] = 'Свернуть'; + $lang['strfind'] = 'Ðайти'; + $lang['stroptions'] = 'Опции'; + $lang['strrefresh'] = 'Обновить'; + $lang['strdownload'] = 'Загрузить'; + $lang['strdownloadgzipped'] = 'Загрузить архив gzip'; + $lang['strinfo'] = 'СведениÑ'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Дополнительно'; + $lang['strvariables'] = 'Переменные'; + $lang['strprocess'] = 'ПроцеÑÑ'; + $lang['strprocesses'] = 'ПроцеÑÑÑ‹'; + $lang['strsetting'] = 'Опции'; + $lang['streditsql'] = 'Редактировать SQL'; + $lang['strruntime'] = 'Ð’Ñ€ÐµÐ¼Ñ Ð²Ñ‹Ð¿Ð¾Ð»Ð½ÐµÐ½Ð¸Ñ: %s мÑек'; + $lang['strpaginate'] = 'Ðумеровать Ñтраницы Ñ Ñ€ÐµÐ·ÑƒÐ»ÑŒÑ‚Ð°Ñ‚Ð°Ð¼Ð¸'; + $lang['struploadscript'] = 'или загрузить SQL-Ñкрипт:'; + $lang['strstarttime'] = 'Ð’Ñ€ÐµÐ¼Ñ Ð½Ð°Ñ‡Ð°Ð»Ð°'; + $lang['strfile'] = 'Файл'; + $lang['strfileimported'] = 'Файл импортирован.'; + $lang['strtrycred'] = 'ИÑпользовать Ñти данные аутентификации Ð´Ð»Ñ Ð²Ñех Ñерверов'; + $lang['strconfdropcred'] = 'Ð’ целÑÑ… безопаÑноÑти отключение уничтожит общую аутентификационную информацию. Ð’Ñ‹ дейÑтвительно хотите отключитÑÑ?'; + $lang['stractionsonmultiplelines'] = 'ДейÑÑ‚Ð²Ð¸Ñ Ð½Ð°Ð´ неÑколькими Ñтроками.'; + $lang['strselectall'] = 'Выбрать вÑе'; + $lang['strunselectall'] = 'Отменить выбор вÑех'; + $lang['strlocale'] = 'Локаль'; + $lang['strcollation'] = 'ПорÑдок Ñортировки Ñтрок (LC_COLLATE)'; + $lang['strctype'] = 'КлаÑÑÐ¸Ñ„Ð¸ÐºÐ°Ñ†Ð¸Ñ Ñимволов (LC_CTYPE)'; + $lang['strdefaultvalues'] = 'Ð—Ð½Ð°Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ð¾ умолчанию'; + $lang['strnewvalues'] = 'Ðовые значениÑ'; + $lang['strstart'] = 'ЗапуÑтить автоматичеÑкое обновление'; + $lang['strstop'] = 'ОÑтановить автоматичеÑкое обновление'; + $lang['strgotoppage'] = 'вверх'; + $lang['strtheme'] = 'Тема'; + $lang['strcluster'] = 'КлаÑтер'; + + // Admin + $lang['stradminondatabase'] = 'Следующие админиÑтративные задачи применÑÑŽÑ‚ÑÑ ÐºÐ¾ вÑей базе данных %s.'; + $lang['stradminontable'] = 'Следующие админиÑтративные задачи применÑÑŽÑ‚ÑÑ Ðº таблице %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'ИÑториÑ'; + $lang['strnohistory'] = 'Ðет иÑтории.'; + $lang['strclearhistory'] = 'ОчиÑтить иÑторию'; + $lang['strdelhistory'] = 'Удалить из иÑтории'; + $lang['strconfdelhistory'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить Ñтот Ð·Ð°Ð¿Ñ€Ð¾Ñ Ð¸Ð· иÑтории?'; + $lang['strconfclearhistory'] = 'Ð’Ñ‹ дейÑтвительно хотите очиÑтить иÑторию?'; + $lang['strnodatabaseselected'] = 'ПожалуйÑта, выберете базу данных.'; + + // Database sizes + $lang['strnoaccess'] = 'Ðет доÑтупа'; + $lang['strsize'] = 'Размер'; + $lang['strbytes'] = 'байт'; + $lang['strkb'] = 'кБ'; + $lang['strmb'] = 'МБ'; + $lang['strgb'] = 'ГБ'; + $lang['strtb'] = 'ТБ'; + + // Error handling + $lang['strnoframes'] = 'Это приложение лучше вÑего работает в браузере, который поддерживает фреймы, но оно может работать и без иÑÐ¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ð½Ð¸Ñ Ñ„Ñ€ÐµÐ¹Ð¼Ð¾Ð² еÑли перейти по ÑÑылке ниже.'; + $lang['strnoframeslink'] = 'ИÑпользовать без фреймов'; + $lang['strbadconfig'] = 'Ваш config.inc.php ÑвлÑетÑÑ ÑƒÑтаревшим. Вам необходимо обновить его из config.inc.php-dist.'; + $lang['strnotloaded'] = 'Ваша инÑталÑÑ†Ð¸Ñ PHP не поддерживает PostgreSQL. Вам необходимо переÑобрать PHP, иÑÐ¿Ð¾Ð»ÑŒÐ·ÑƒÑ Ð¿Ð°Ñ€Ð°Ð¼ÐµÑ‚Ñ€ --with-pgsql Ð´Ð»Ñ configure.'; + $lang['strpostgresqlversionnotsupported'] = 'ВерÑÐ¸Ñ PostgreSQL не поддерживаетÑÑ. ПожалуйÑта, обновитеÑÑŒ до верÑии %s или более поздней.'; + $lang['strbadschema'] = 'Обнаружена Ð½ÐµÐ²ÐµÑ€Ð½Ð°Ñ Ñхема.'; + $lang['strbadencoding'] = 'Ошибка при уÑтановке кодировки клиента (client encoding).'; + $lang['strsqlerror'] = 'Ошибка SQL:'; + $lang['strinstatement'] = 'Ð’ операторе:'; + $lang['strinvalidparam'] = 'Ðеверный параметр Ñкрипта.'; + $lang['strnodata'] = 'Данных не найдено.'; + $lang['strnoobjects'] = 'Объектов не найдено.'; + $lang['strrownotunique'] = 'Ðет уникального идентификатора Ð´Ð»Ñ Ñтой запиÑи.'; + $lang['strnouploads'] = 'Загрузка файла невозможна.'; + $lang['strimporterror'] = 'Ошибка импорта.'; + $lang['strimporterror-fileformat'] = 'Ошибка импорта: Ðевозможно автоматичеÑки определить формат файла.'; + $lang['strimporterrorline'] = 'Ошибка канала при импорте %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Ошибка импорта в Ñтроке %s: Строка не обладает необходимым чиÑлом атрибутов.'; + $lang['strimporterror-uploadedfile'] = 'Ошибка импорта: Файл не может быть загружен на Ñервер'; + $lang['strcannotdumponwindows'] = 'ЭкÑпорт таблиц и Ñхем Ñо Ñложными именами в Windows не поддерживаетÑÑ.'; + $lang['strinvalidserverparam'] = 'Попытка ÑÐ¾ÐµÐ´Ð¸Ð½ÐµÐ½Ð¸Ñ Ñ Ð½ÐµÐºÐ¾Ñ€Ñ€ÐµÐºÑ‚Ð½Ñ‹Ð¼ значением параметра "Ñервер", возможно кто-то пытаетÑÑ Ð²Ð·Ð»Ð¾Ð¼Ð°Ñ‚ÑŒ вашу ÑиÑтему.'; + $lang['strnoserversupplied'] = 'Значение параметра "Ñервер" не предÑтавлено!'; + $lang['strbadpgdumppath'] = 'Ошибка ÑкÑпорта: Ðевозможно выполнить pg_dump (указанный в conf/config.inc.php путь: %s). ПожалуйÑта, иÑправте Ñтот путь в конфигурации и заново войдите в ÑиÑтему.'; + $lang['strbadpgdumpallpath'] = 'Ошибка ÑкÑпорта: Ðевозможно выполнить pg_dumpall (указанный в conf/config.inc.php путь: %s). ПожалуйÑта, иÑправте Ñтот путь в конфигурации и заново войдите в ÑиÑтему.'; + $lang['strconnectionfail'] = 'Ошибка Ð¿Ð¾Ð´ÐºÐ»ÑŽÑ‡ÐµÐ½Ð¸Ñ Ðº Ñерверу.'; + + // Tables + $lang['strtable'] = 'Таблица'; + $lang['strtables'] = 'Таблицы'; + $lang['strshowalltables'] = 'Показать вÑе таблицы'; + $lang['strnotables'] = 'Таблиц не найдено.'; + $lang['strnotable'] = 'Таблица не обнаружена.'; + $lang['strcreatetable'] = 'Создать таблицу'; + $lang['strcreatetablelike'] = 'Создать таблицу наподобие'; + $lang['strcreatetablelikeparent'] = 'ИÑÑ…Ð¾Ð´Ð½Ð°Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ð°'; + $lang['strcreatelikewithdefaults'] = 'включить Ð·Ð½Ð°Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ð¾ умолчанию'; + $lang['strcreatelikewithconstraints'] = 'включить ограничениÑ'; + $lang['strcreatelikewithindexes'] = 'включить индекÑÑ‹'; + $lang['strtablename'] = 'Ð˜Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['strtableneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹.'; + $lang['strtablelikeneedslike'] = 'Вам необходимо определить иÑходную таблицу.'; + $lang['strtableneedsfield'] = 'Вам необходимо определить по крайней мере одно поле.'; + $lang['strtableneedscols'] = 'Вам необходимо указать допуÑтимое чиÑло атрибутов.'; + $lang['strtablecreated'] = 'Таблица Ñоздана.'; + $lang['strtablecreatedbad'] = 'Создание таблицы прервано.'; + $lang['strconfdroptable'] = 'Ð’Ñ‹ уверены, что хотите удалить таблицу "%s"?'; + $lang['strtabledropped'] = 'Таблица удалена.'; + $lang['strtabledroppedbad'] = 'Удаление таблицы прервано.'; + $lang['strconfemptytable'] = 'Ð’Ñ‹ уверены, что хотите очиÑтить таблицу "%s"?'; + $lang['strtableemptied'] = 'Таблица очищена.'; + $lang['strtableemptiedbad'] = 'ОчиÑтка таблицы прервана.'; + $lang['strinsertrow'] = 'Добавить запиÑÑŒ'; + $lang['strrowinserted'] = 'ЗапиÑÑŒ добавлена.'; + $lang['strrowinsertedbad'] = 'Добавление запиÑи прервано.'; + $lang['strnofkref'] = 'Ðет ÑоответÑтвующего Ð·Ð½Ð°Ñ‡ÐµÐ½Ð¸Ñ Ð²Ð½ÐµÑˆÐ½ÐµÐ³Ð¾ ключа %s.'; + $lang['strrowduplicate'] = 'Ð’Ñтавка Ñтроки прервана, попытка Ñделать дублирующую вÑтавку.'; + $lang['streditrow'] = 'Редактировать запиÑÑŒ'; + $lang['strrowupdated'] = 'ЗапиÑÑŒ обновлена.'; + $lang['strrowupdatedbad'] = 'Обновление запиÑи прервано.'; + $lang['strdeleterow'] = 'Удалить запиÑÑŒ'; + $lang['strconfdeleterow'] = 'Ð’Ñ‹ уверены, что хотите удалить запиÑÑŒ?'; + $lang['strrowdeleted'] = 'ЗапиÑÑŒ удалена.'; + $lang['strrowdeletedbad'] = 'Удаление запиÑи прервано.'; + $lang['strinsertandrepeat'] = 'Ð’Ñтавить и повторить'; + $lang['strnumcols'] = 'КоличеÑтво атрибутов'; + $lang['strcolneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ Ñтолбца'; + $lang['strselectallfields'] = 'Выбрать вÑе полÑ'; + $lang['strselectneedscol'] = 'Вам необходимо указать по крайней мере один атрибут'; + $lang['strselectunary'] = 'Унарный оператор не может иметь величину.'; + $lang['strcolumnaltered'] = 'Ðтрибут изменен.'; + $lang['strcolumnalteredbad'] = 'Изменение атрибута прервано.'; + $lang['strconfdropcolumn'] = 'Ð’Ñ‹ уверены, что хотите удалить атрибут "%s" таблицы "%s"?'; + $lang['strcolumndropped'] = 'Ðтрибут удален.'; + $lang['strcolumndroppedbad'] = 'Удаление атрибута прервано.'; + $lang['straddcolumn'] = 'Добавить атрибут'; + $lang['strcolumnadded'] = 'Ðтрибут добавлен.'; + $lang['strcolumnaddedbad'] = 'Добавление атрибута прервано.'; + $lang['strcascade'] = 'КаÑкадом'; + $lang['strtablealtered'] = 'Таблица изменена.'; + $lang['strtablealteredbad'] = 'Изменение таблицы прервано.'; + $lang['strdataonly'] = 'Только данные'; + $lang['strstructureonly'] = 'Только Ñтруктуру'; + $lang['strstructureanddata'] = 'Структуру и данные'; + $lang['strtabbed'] = 'Через табулÑцию'; + $lang['strauto'] = 'Ðвто'; + $lang['strconfvacuumtable'] = 'Ð’Ñ‹ дейÑтвительно хотите переÑтроить "%s"?'; + $lang['strconfanalyzetable'] = 'Ð’Ñ‹ дейÑтвительно хотите произвеÑти анализ "%s"?'; + $lang['strconfreindextable'] = 'Ð’Ñ‹ дейÑтвительно хотите переÑтроить Ð¸Ð½Ð´ÐµÐºÑ "%s"?'; + $lang['strconfclustertable'] = 'Ð’Ñ‹ дейÑтвительно хотите клаÑтеризовать "%s"?'; + $lang['strestimatedrowcount'] = 'Предполагаемое чиÑло Ñтрок'; + $lang['strspecifytabletoanalyze'] = 'Вам необходимо указать как минимум одну таблицу Ð´Ð»Ñ Ð°Ð½Ð°Ð»Ð¸Ð·Ð°.'; + $lang['strspecifytabletoempty'] = 'Вам необходимо указать как минимум одну таблицу Ð´Ð»Ñ Ð¾Ñ‡Ð¸Ñтки.'; + $lang['strspecifytabletodrop'] = 'Вам необходимо указать как минимум одну таблицу Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + $lang['strspecifytabletovacuum'] = 'Вам необходимо указать как минимум одну таблицу Ð´Ð»Ñ Ð¿ÐµÑ€ÐµÑтроениÑ.'; + $lang['strspecifytabletoreindex'] = 'Вам необходимо указать как минимум одну таблицу Ð´Ð»Ñ Ð¿ÐµÑ€ÐµÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð¸Ð½Ð´ÐµÐºÑа.'; + $lang['strspecifytabletocluster'] = 'Вам необходимо указать как минимум одну таблицу Ð´Ð»Ñ ÐºÐ»Ð°Ñтеризации.'; + $lang['strnofieldsforinsert'] = 'Ð’Ñ‹ не можете вÑтавить Ñтроку в таблицу без Ñтолбцов.'; + + // Columns + $lang['strcolprop'] = 'СвойÑтва Ñтолбца'; + $lang['strnotableprovided'] = 'Значение параметра "таблица" не предÑтавлено!'; + + // Users + $lang['struser'] = 'Пользователь'; + $lang['strusers'] = 'Пользователи'; + $lang['strusername'] = 'Ð˜Ð¼Ñ Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ'; + $lang['strpassword'] = 'Пароль'; + $lang['strsuper'] = 'Суперпользователь?'; + $lang['strcreatedb'] = 'Создать базу данных?'; + $lang['strexpires'] = 'Срок дейÑтвиÑ'; + $lang['strsessiondefaults'] = 'Опции ÑеанÑа по умолчанию'; + $lang['strnousers'] = 'Ðет таких пользователей.'; + $lang['struserupdated'] = 'Пользователь обновлен.'; + $lang['struserupdatedbad'] = 'Обновление Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strshowallusers'] = 'Показать вÑех пользователей'; + $lang['strcreateuser'] = 'Создать пользователÑ'; + $lang['struserneedsname'] = 'Ð’Ñ‹ должны ввеÑти Ð¸Ð¼Ñ Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ.'; + $lang['strusercreated'] = 'Пользователь Ñоздан.'; + $lang['strusercreatedbad'] = 'Создание Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropuser'] = 'Ð’Ñ‹ уверены, что хотите удалить Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ "%s"?'; + $lang['struserdropped'] = 'Пользователь удален.'; + $lang['struserdroppedbad'] = 'Удаление Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straccount'] = 'Ðккаунт'; + $lang['strchangepassword'] = 'Изменить пароль'; + $lang['strpasswordchanged'] = 'Пароль изменен.'; + $lang['strpasswordchangedbad'] = 'Изменение Ð¿Ð°Ñ€Ð¾Ð»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strpasswordshort'] = 'Пароль Ñлишком короткий.'; + $lang['strpasswordconfirm'] = 'Пароль не ÑоответÑтвует подтверждению.'; + + // Groups + $lang['strgroup'] = 'Группа'; + $lang['strgroups'] = 'Группы'; + $lang['strshowallgroups'] = 'Показать вÑе группы'; + $lang['strnogroup'] = 'Группа не обнаружена.'; + $lang['strnogroups'] = 'Ðи одной группы не найдено.'; + $lang['strcreategroup'] = 'Создать группу'; + $lang['strgroupneedsname'] = 'Вам необходимо указать название группы.'; + $lang['strgroupcreated'] = 'Группа Ñоздана.'; + $lang['strgroupcreatedbad'] = 'Создание группы прервано.'; + $lang['strconfdropgroup'] = 'Ð’Ñ‹ уверены, что хотите удалить группу "%s"?'; + $lang['strgroupdropped'] = 'Группа удалена.'; + $lang['strgroupdroppedbad'] = 'Удаление группы прервано.'; + $lang['strmembers'] = 'УчаÑтников'; + $lang['strmemberof'] = 'Добавить в роли'; + $lang['stradminmembers'] = 'Admin-учаÑтников'; + $lang['straddmember'] = 'Добавить учаÑтника'; + $lang['strmemberadded'] = 'УчаÑтник добавлен.'; + $lang['strmemberaddedbad'] = 'Добавление учаÑтника прервано.'; + $lang['strdropmember'] = 'Удалить учаÑтника'; + $lang['strconfdropmember'] = 'Ð’Ñ‹ уверены, что хотите удалить учаÑтника "%s" из группы "%s"?'; + $lang['strmemberdropped'] = 'УчаÑтник удален.'; + $lang['strmemberdroppedbad'] = 'Удаление учаÑтника прервано.'; + + // Roles + $lang['strrole'] = 'Роль'; + $lang['strroles'] = 'Роли'; + $lang['strshowallroles'] = 'Показать вÑе роли'; + $lang['strnoroles'] = 'Роли не найдены.'; + $lang['strinheritsprivs'] = 'ÐаÑледовать привилегии?'; + $lang['strcreaterole'] = 'Создать роль'; + $lang['strcancreaterole'] = 'Может Ñоздавать роли?'; + $lang['strrolecreated'] = 'Роль Ñоздана.'; + $lang['strrolecreatedbad'] = 'Создание роли прервано.'; + $lang['strrolealtered'] = 'Роль изменена.'; + $lang['strrolealteredbad'] = 'Изменение роли прервано.'; + $lang['strcanlogin'] = 'Может логинитьÑÑ?'; + $lang['strconnlimit'] = 'Лимит Ñоединений'; + $lang['strdroprole'] = 'Удалить роль'; + $lang['strconfdroprole'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить роль "%s"?'; + $lang['strroledropped'] = 'Роль удалена.'; + $lang['strroledroppedbad'] = 'Удаление роли прервано.'; + $lang['strnolimit'] = 'Без ограничений'; + $lang['strnever'] = 'Ðикогда'; + $lang['strroleneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ Ñ€Ð¾Ð»Ð¸.'; + + // Privileges + $lang['strprivilege'] = 'ПривилегиÑ'; + $lang['strprivileges'] = 'Привилегии'; + $lang['strnoprivileges'] = 'Объект не имеет привилегий.'; + $lang['strgrant'] = 'УÑилить'; + $lang['strrevoke'] = 'ОÑлабить'; + $lang['strgranted'] = 'Привилегии изменены.'; + $lang['strgrantfailed'] = 'Изменение привилегий прервано.'; + $lang['strgrantbad'] = 'Вам необходимо указать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ одного Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¸Ð»Ð¸ группу и Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ одну привилегию.'; + $lang['strgrantor'] = 'Донор'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'База данных'; + $lang['strdatabases'] = 'Базы данных'; + $lang['strshowalldatabases'] = 'Показать вÑе базы данных'; + $lang['strnodatabases'] = 'Ðи одной базы данных не найдено.'; + $lang['strcreatedatabase'] = 'Создать базу данных'; + $lang['strdatabasename'] = 'Ð˜Ð¼Ñ Ð±Ð°Ð·Ñ‹ данных'; + $lang['strdatabaseneedsname'] = 'Вам необходимо приÑвоить Ð¸Ð¼Ñ Ð’Ð°ÑˆÐµÐ¹ базе данных.'; + $lang['strdatabasecreated'] = 'База данных Ñоздана.'; + $lang['strdatabasecreatedbad'] = 'Создание базы данных прервано.'; + $lang['strconfdropdatabase'] = 'Ð’Ñ‹ уверены, что хотите уничтожить базу данных "%s"?'; + $lang['strdatabasedropped'] = 'База данных уничтожена.'; + $lang['strdatabasedroppedbad'] = 'Уничтожение базы данных прервано.'; + $lang['strentersql'] = 'Введите SQL-Ð·Ð°Ð¿Ñ€Ð¾Ñ Ð½Ð¸Ð¶Ðµ:'; + $lang['strsqlexecuted'] = 'SQL-Ð·Ð°Ð¿Ñ€Ð¾Ñ Ð²Ñ‹Ð¿Ð¾Ð»Ð½ÐµÐ½.'; + $lang['strvacuumgood'] = 'ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð¿ÐµÑ€ÐµÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð°.'; + $lang['strvacuumbad'] = 'ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð¿ÐµÑ€ÐµÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð°.'; + $lang['stranalyzegood'] = 'ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð°Ð½Ð°Ð»Ð¸Ð·Ð° завершена.'; + $lang['stranalyzebad'] = 'ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð°Ð½Ð°Ð»Ð¸Ð·Ð° прервана.'; + $lang['strreindexgood'] = 'ПереиндекÑÐ°Ñ†Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð°.'; + $lang['strreindexbad'] = 'ПереиндекÑÐ°Ñ†Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð°.'; + $lang['strfull'] = 'ПолноÑтью'; + $lang['strfreeze'] = 'Заморозить'; + $lang['strforce'] = 'Принудительно'; + $lang['strsignalsent'] = 'Сигнал отправлен.'; + $lang['strsignalsentbad'] = 'Отправка Ñигнала прервана.'; + $lang['strallobjects'] = 'Ð’Ñе объекты'; + $lang['strdatabasealtered'] = 'База данных изменена.'; + $lang['strdatabasealteredbad'] = 'Изменение базы данных прервано.'; + $lang['strspecifydatabasetodrop'] = 'Вам необходимо указать как минимум одну базу данных Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + $lang['strtemplatedb'] = 'Шаблон'; + $lang['strconfanalyzedatabase'] = 'Ð’Ñ‹ дейÑтвительно хотите анализировать вÑе таблицы в базе данных "%s"?'; + $lang['strconfvacuumdatabase'] = 'Ð’Ñ‹ дейÑтвительно хотите переÑтроить вÑе таблицы в базе данных "%s"?'; + $lang['strconfreindexdatabase'] = 'Ð’Ñ‹ дейÑтвительно хотите переÑтроить Ð¸Ð½Ð´ÐµÐºÑ Ð²Ñех таблиц в базе данных "%s"?'; + $lang['strconfclusterdatabase'] = 'Ð’Ñ‹ дейÑтвительно хотите клаÑтеризовать вÑе таблицы в базе данных "%s"?'; + + // Views + $lang['strview'] = 'ПредÑтавление'; + $lang['strviews'] = 'ПредÑтавлениÑ'; + $lang['strshowallviews'] = 'Показать вÑе предÑтавлениÑ'; + $lang['strnoview'] = 'ПредÑтавление не найдено.'; + $lang['strnoviews'] = 'Ðи одного предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð½Ðµ найдено.'; + $lang['strcreateview'] = 'Создать предÑтавление'; + $lang['strviewname'] = 'Ð˜Ð¼Ñ Ð¿Ñ€ÐµÐ´ÑтавлениÑ'; + $lang['strviewneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¿Ñ€ÐµÐ´ÑтавлениÑ.'; + $lang['strviewneedsdef'] = 'Вам необходимо определить атрибуты предÑтавлениÑ.'; + $lang['strviewneedsfields'] = 'Вам необходимо определить атрибуты Ð´Ð»Ñ Ð²Ñ‹Ð±Ð¾Ñ€ÐºÐ¸ в ваше предÑтавление.'; + $lang['strviewcreated'] = 'ПредÑтавление Ñоздано.'; + $lang['strviewcreatedbad'] = 'Создание предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropview'] = 'Ð’Ñ‹ уверены, что хотите уничтожить предÑтавление "%s"?'; + $lang['strviewdropped'] = 'ПредÑтавление уничтожено.'; + $lang['strviewdroppedbad'] = 'Уничтожение предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strviewupdated'] = 'ПредÑтавление обновлено.'; + $lang['strviewupdatedbad'] = 'Обновление предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strviewlink'] = 'СвÑзанные ключи'; + $lang['strviewconditions'] = 'Дополнительные уÑловиÑ'; + $lang['strcreateviewwiz'] = 'Создать предÑтавление помощником'; + $lang['strrenamedupfields'] = 'Переименовывать полÑ-дубликаты'; + $lang['strdropdupfields'] = 'УдалÑÑ‚ÑŒ полÑ-дубликаты'; + $lang['strerrordupfields'] = 'Ошибка при поÑвлении полей-дубликатов'; + $lang['strviewaltered'] = 'ПредÑтавление изменено.'; + $lang['strviewalteredbad'] = 'Изменение предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strspecifyviewtodrop'] = 'Вам необходимо определить как минимум одно предÑтавление Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + + // Sequences + $lang['strsequence'] = 'ПоÑледовательноÑÑ‚ÑŒ'; + $lang['strsequences'] = 'ПоÑледовательноÑти'; + $lang['strshowallsequences'] = 'Показать вÑе поÑледовательноÑти'; + $lang['strnosequence'] = 'ПоÑледовательноÑÑ‚ÑŒ не обнаружена.'; + $lang['strnosequences'] = 'Ðи одной поÑледовательноÑти не найдено.'; + $lang['strcreatesequence'] = 'Создать поÑледовательноÑÑ‚ÑŒ'; + $lang['strlastvalue'] = 'ПоÑледнее значение'; + $lang['strincrementby'] = 'Увеличение на'; + $lang['strstartvalue'] = 'Ðачальное значение'; + $lang['strmaxvalue'] = 'МакÑ. величина'; + $lang['strminvalue'] = 'Мин. величина'; + $lang['strcachevalue'] = 'Размер кÑша'; + $lang['strlogcount'] = 'Log Count'; + $lang['strcancycle'] = 'Может зацикливатьÑÑ?'; + $lang['striscalled'] = 'Увеличит поÑледнее значение поÑле Ð¿Ð¾Ð»ÑƒÑ‡ÐµÐ½Ð¸Ñ Ñледующего Ð·Ð½Ð°Ñ‡ÐµÐ½Ð¸Ñ (is_called)?'; + $lang['strsequenceneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¿Ð¾ÑледовательноÑти.'; + $lang['strsequencecreated'] = 'ПоÑледовательноÑÑ‚ÑŒ Ñоздана.'; + $lang['strsequencecreatedbad'] = 'Создание поÑледовательноÑти прервано.'; + $lang['strconfdropsequence'] = 'Ð’Ñ‹ уверены, что хотите уничтожить поÑледовательноÑÑ‚ÑŒ "%s"?'; + $lang['strsequencedropped'] = 'ПоÑледовательноÑÑ‚ÑŒ уничтожена.'; + $lang['strsequencedroppedbad'] = 'Уничтожение поÑледовательноÑти прервано.'; + $lang['strsequencereset'] = 'ПоÑледовательноÑÑ‚ÑŒ Ñброшена.'; + $lang['strsequenceresetbad'] = 'Ð¡Ð±Ñ€Ð¾Ñ Ð¿Ð¾ÑледовательноÑти прерван.'; + $lang['strsequencealtered'] = 'ПоÑледовательноÑÑ‚ÑŒ изменена.'; + $lang['strsequencealteredbad'] = 'Изменение поÑледовательноÑти прервано.'; + $lang['strsetval'] = 'УÑтановить значение'; + $lang['strsequencesetval'] = 'Значение поÑледовательноÑти уÑтановлено.'; + $lang['strsequencesetvalbad'] = 'Изменение Ð·Ð½Ð°Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ð¾ÑледовательноÑти прервано.'; + $lang['strnextval'] = 'Инкрементировать значение'; + $lang['strsequencenextval'] = 'Значение поÑледовательноÑти инкрементировано.'; + $lang['strsequencenextvalbad'] = 'Инкрементирование Ð·Ð½Ð°Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ð¾ÑледовательноÑти прервано.'; + $lang['strspecifysequencetodrop'] = 'Вам необходимо указать как минимун одну поÑледовательноÑÑ‚ÑŒ Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + + // Indexes + $lang['strindex'] = 'ИндекÑ'; + $lang['strindexes'] = 'ИндекÑÑ‹'; + $lang['strindexname'] = 'Ð˜Ð¼Ñ Ð¸Ð½Ð´ÐµÐºÑа'; + $lang['strshowallindexes'] = 'Показать вÑе индекÑÑ‹'; + $lang['strnoindex'] = 'Ð˜Ð½Ð´ÐµÐºÑ Ð½Ðµ обнаружен.'; + $lang['strnoindexes'] = 'Ðи одного индекÑа не найдено.'; + $lang['strcreateindex'] = 'Создать индекÑ'; + $lang['strtabname'] = 'Ð˜Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['strcolumnname'] = 'Ð˜Ð¼Ñ Ð°Ñ‚Ñ€Ð¸Ð±ÑƒÑ‚Ð°'; + $lang['strindexneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¸Ð½Ð´ÐµÐºÑа'; + $lang['strindexneedscols'] = 'Вам необходимо указать допуÑтимое количеÑтво атрибутов.'; + $lang['strindexcreated'] = 'Ð˜Ð½Ð´ÐµÐºÑ Ñоздан.'; + $lang['strindexcreatedbad'] = 'Создание индекÑа прервано.'; + $lang['strconfdropindex'] = 'Ð’Ñ‹ уверены, что хотите уничтожить Ð¸Ð½Ð´ÐµÐºÑ "%s"?'; + $lang['strindexdropped'] = 'Ð˜Ð½Ð´ÐµÐºÑ ÑƒÐ½Ð¸Ñ‡Ñ‚Ð¾Ð¶ÐµÐ½.'; + $lang['strindexdroppedbad'] = 'Уничтожение индекÑа прервано.'; + $lang['strkeyname'] = 'Ð˜Ð¼Ñ ÐºÐ»ÑŽÑ‡Ð°'; + $lang['struniquekey'] = 'Уникальный ключ'; + $lang['strprimarykey'] = 'Первичный ключ'; + $lang['strindextype'] = 'Вид индекÑа'; + $lang['strtablecolumnlist'] = 'Ðтрибутов в таблице'; + $lang['strindexcolumnlist'] = 'Ðтрибутов в индекÑе'; + $lang['strclusteredgood'] = 'КлаÑÑ‚ÐµÑ€Ð¸Ð·Ð°Ñ†Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð°.'; + $lang['strclusteredbad'] = 'КлаÑÑ‚ÐµÑ€Ð¸Ð·Ð°Ñ†Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð°.'; + $lang['strconcurrently'] = 'Без блокировки запиÑи (CONCURRENTLY)'; + $lang['strnoclusteravailable'] = 'Таблица не клаÑтеризуема по индекÑу.'; + + // Rules + $lang['strrules'] = 'Правила'; + $lang['strrule'] = 'Правило'; + $lang['strshowallrules'] = 'Показать вÑе правила'; + $lang['strnorule'] = 'Правило не найдено.'; + $lang['strnorules'] = 'Ðи одного правила не найдено.'; + $lang['strcreaterule'] = 'Создать правило'; + $lang['strrulename'] = 'Ð˜Ð¼Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð°'; + $lang['strruleneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð°.'; + $lang['strrulecreated'] = 'Правило Ñоздано.'; + $lang['strrulecreatedbad'] = 'Создание правила прервано.'; + $lang['strconfdroprule'] = 'Ð’Ñ‹ уверены, что хотите уничтожить правило "%s" on "%s"?'; + $lang['strruledropped'] = 'Правило уничтожено.'; + $lang['strruledroppedbad'] = 'Уничтожение правила прервано.'; + + // Constraints + $lang['strconstraint'] = 'Ограничение'; + $lang['strconstraints'] = 'ОграничениÑ'; + $lang['strshowallconstraints'] = 'Показать вÑе ограничениÑ'; + $lang['strnoconstraints'] = 'Ðи одного Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð½Ðµ найдено.'; + $lang['strcreateconstraint'] = 'Создать ограничение'; + $lang['strconstraintcreated'] = 'Ограничение Ñоздано.'; + $lang['strconstraintcreatedbad'] = 'Создание Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropconstraint'] = 'Ð’Ñ‹ уверены, что хотите уничтожить ограничение "%s" on "%s"?'; + $lang['strconstraintdropped'] = 'Ограничение уничтожено.'; + $lang['strconstraintdroppedbad'] = 'Уничтожение Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straddcheck'] = 'Добавить проверку'; + $lang['strcheckneedsdefinition'] = 'Ограничение проверки нуждаетÑÑ Ð² определении.'; + $lang['strcheckadded'] = 'Ограничение проверки добавлено.'; + $lang['strcheckaddedbad'] = 'Добавление Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ñ€Ð¾Ð²ÐµÑ€ÐºÐ¸ прервано.'; + $lang['straddpk'] = 'Добавить первичный ключ'; + $lang['strpkneedscols'] = 'Первичный ключ должен включать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ один атрибут.'; + $lang['strpkadded'] = 'Первичный ключ добавлен.'; + $lang['strpkaddedbad'] = 'Добавление первичного ключа прервано.'; + $lang['stradduniq'] = 'Добавить уникальный ключ'; + $lang['struniqneedscols'] = 'Уникальный ключ должен включать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ один атрибут.'; + $lang['struniqadded'] = 'Уникальный ключ добавлен.'; + $lang['struniqaddedbad'] = 'Добавление уникального ключа прервано.'; + $lang['straddfk'] = 'Добавить внешний ключ'; + $lang['strfkneedscols'] = 'Внешний ключ должен включать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ один атрибут.'; + $lang['strfkneedstarget'] = 'Внешнему ключу необходимо указать целевую таблицу.'; + $lang['strfkadded'] = 'Внешний ключ добавлен.'; + $lang['strfkaddedbad'] = 'Добавление внешнего ключа прервано.'; + $lang['strfktarget'] = 'Ð¦ÐµÐ»ÐµÐ²Ð°Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ð°'; + $lang['strfkcolumnlist'] = 'Ðтрибуты в ключе'; + $lang['strondelete'] = 'при удалении'; + $lang['stronupdate'] = 'при обновлении'; + + // Functions + $lang['strfunction'] = 'ФункциÑ'; + $lang['strfunctions'] = 'Функции'; + $lang['strshowallfunctions'] = 'Показать вÑе функции'; + $lang['strnofunction'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð½Ðµ обнаружена.'; + $lang['strnofunctions'] = 'Ðи одной функции не найдено.'; + $lang['strcreateplfunction'] = 'Создать SQL/PL функцию'; + $lang['strcreateinternalfunction'] = 'Создать внутреннюю функцию'; + $lang['strcreatecfunction'] = 'Создать функцию на Ñзыке C'; + $lang['strfunctionname'] = 'Ð˜Ð¼Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ð¸'; + $lang['strreturns'] = 'Возвращаемое значение'; + $lang['strproglanguage'] = 'Язык'; + $lang['strfunctionneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ð¸.'; + $lang['strfunctionneedsdef'] = 'Вам необходимо определить функцию.'; + $lang['strfunctioncreated'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ñоздана.'; + $lang['strfunctioncreatedbad'] = 'Создание функции прервано.'; + $lang['strconfdropfunction'] = 'Ð’Ñ‹ уверены, что хотите уничтожить функцию "%s"?'; + $lang['strfunctiondropped'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ ÑƒÐ½Ð¸Ñ‡Ñ‚Ð¾Ð¶ÐµÐ½Ð°.'; + $lang['strfunctiondroppedbad'] = 'Уничтожение функции прервано.'; + $lang['strfunctionupdated'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð¾Ð±Ð½Ð¾Ð²Ð»ÐµÐ½Ð°.'; + $lang['strfunctionupdatedbad'] = 'Обновление функции прервано.'; + $lang['strobjectfile'] = 'Объектный файл'; + $lang['strlinksymbol'] = 'Символ линковки (Ð¸Ð¼Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ð¸ в C)'; + $lang['strarguments'] = 'Ðргументы'; + $lang['strargmode'] = 'Режим'; + $lang['strargtype'] = 'Тип'; + $lang['strargadd'] = 'Добавить еще аргумент'; + $lang['strargremove'] = 'Удалить Ñтот аргумент'; + $lang['strargnoargs'] = 'Эта Ñ„ÑƒÐ½ÐºÑ†Ð¸Ñ Ð½Ðµ будет принимать аргументов.'; + $lang['strargenableargs'] = 'Включить передачу аргументов Ñтой функции.'; + $lang['strargnorowabove'] = 'Ðеобходима Ñтрока выше Ñтой Ñтроки.'; + $lang['strargnorowbelow'] = 'Ðеобходима Ñтрока ниже Ñтой Ñтроки.'; + $lang['strargraise'] = 'ПеремеÑтить вверх.'; + $lang['strarglower'] = 'ПеремеÑтить вниз.'; + $lang['strargremoveconfirm'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить Ñтот аргумент? Отменить удаление невозможно.'; + $lang['strfunctioncosting'] = 'СтоимоÑти функции'; + $lang['strresultrows'] = 'Строк в результате'; + $lang['strexecutioncost'] = 'СтоимоÑÑ‚ÑŒ иÑполнениÑ'; + $lang['strspecifyfunctiontodrop'] = 'Вам необходимо указать как минимум одну функцию Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + + // Triggers + $lang['strtrigger'] = 'Триггер'; + $lang['strtriggers'] = 'Триггеры'; + $lang['strshowalltriggers'] = 'Показать вÑе триггеры'; + $lang['strnotrigger'] = 'Триггер не обнаружен.'; + $lang['strnotriggers'] = 'Ðи одного триггера не найдено.'; + $lang['strcreatetrigger'] = 'Создать триггер'; + $lang['strtriggerneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñ‚Ñ€Ð¸Ð³Ð³ÐµÑ€Ð°.'; + $lang['strtriggerneedsfunc'] = 'Вам необходимо определить функцию триггера.'; + $lang['strtriggercreated'] = 'Триггер Ñоздан.'; + $lang['strtriggercreatedbad'] = 'Создание триггера прервано.'; + $lang['strconfdroptrigger'] = 'Ð’Ñ‹ уверены, что хотите уничтожить триггер "%s" на "%s"?'; + $lang['strconfenabletrigger'] = 'Ð’Ñ‹ дейÑтвительно хотите включить триггер "%s" на "%s"?'; + $lang['strconfdisabletrigger'] = 'Ð’Ñ‹ дейÑтвительно хотите выключить триггер "%s" на "%s"?'; + $lang['strtriggerdropped'] = 'Триггер уничтожен.'; + $lang['strtriggerdroppedbad'] = 'Уничтожение триггера прервано.'; + $lang['strtriggerenabled'] = 'Триггер включен.'; + $lang['strtriggerenabledbad'] = 'Включение триггера прервано.'; + $lang['strtriggerdisabled'] = 'Триггер выключен.'; + $lang['strtriggerdisabledbad'] = 'Выключение триггера прервано.'; + $lang['strtriggeraltered'] = 'Триггер изменен.'; + $lang['strtriggeralteredbad'] = 'Изменение триггера прервано.'; + $lang['strforeach'] = 'Ð”Ð»Ñ ÐºÐ°Ð¶Ð´Ð¾Ð³Ð¾'; + + // Types + $lang['strtype'] = 'Тип данных'; + $lang['strtypes'] = 'Типы данных'; + $lang['strshowalltypes'] = 'Показать вÑе типы данных'; + $lang['strnotype'] = 'Тип данных не обнаружен.'; + $lang['strnotypes'] = 'Ðи одного типа данных не найдено.'; + $lang['strcreatetype'] = 'Создать тип данных'; + $lang['strcreatecomptype'] = 'Создать композитный тип'; + $lang['strcreateenumtype'] = 'Создать перечиÑлимый тип'; + $lang['strtypeneedsfield'] = 'Вам необходимо указать как минимум одно поле.'; + $lang['strtypeneedsvalue'] = 'Вам необходимо указать как минимум одно значение.'; + $lang['strtypeneedscols'] = 'Вам необходимо указать корректное чиÑло полей.'; + $lang['strtypeneedsvals'] = 'Вам необходимо указать корректное чиÑло значений.'; + $lang['strinputfn'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð²Ð²Ð¾Ð´Ð°'; + $lang['stroutputfn'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð²Ñ‹Ð²Ð¾Ð´Ð°'; + $lang['strpassbyval'] = 'Передать по значению?'; + $lang['stralignment'] = 'Выравнивание'; + $lang['strelement'] = 'Элемент'; + $lang['strdelimiter'] = 'Разделитель'; + $lang['strstorage'] = 'Хранилище'; + $lang['strfield'] = 'Поле'; + $lang['strnumfields'] = 'Кол-во полей'; + $lang['strnumvalues'] = 'Кол-во значений'; + $lang['strtypeneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñ‚Ð¸Ð¿Ð° данных.'; + $lang['strtypeneedslen'] = 'Вам необходимо указать размер Ð´Ð»Ñ Ñ‚Ð¸Ð¿Ð° данных.'; + $lang['strtypecreated'] = 'Тип данных Ñоздан.'; + $lang['strtypecreatedbad'] = 'Создание типа данных прервано.'; + $lang['strconfdroptype'] = 'Ð’Ñ‹ уверены, что хотите уничтожить тип данных "%s"?'; + $lang['strtypedropped'] = 'Тип данных уничтожен.'; + $lang['strtypedroppedbad'] = 'Уничтожение типа данных прервано.'; + $lang['strflavor'] = 'Тип'; + $lang['strbasetype'] = 'Базовый'; + $lang['strcompositetype'] = 'Композитный'; + $lang['strpseudotype'] = 'ПÑевдо'; + $lang['strenum'] = 'ПеречиÑлимый'; + $lang['strenumvalues'] = 'ПеречиÑлимые значениÑ'; + + // Schemas + $lang['strschema'] = 'Схема'; + $lang['strschemas'] = 'Схемы'; + $lang['strshowallschemas'] = 'Показать вÑе Ñхемы'; + $lang['strnoschema'] = 'Схема не обнаружена.'; + $lang['strnoschemas'] = 'Ðи одной Ñхемы не найдено.'; + $lang['strcreateschema'] = 'Создать Ñхему'; + $lang['strschemaname'] = 'Ð˜Ð¼Ñ Ñхемы'; + $lang['strschemaneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñхемы.'; + $lang['strschemacreated'] = 'Схема Ñоздана.'; + $lang['strschemacreatedbad'] = 'Создание Ñхемы прервано.'; + $lang['strconfdropschema'] = 'Ð’Ñ‹ уверены, что хотите уничтожить Ñхему "%s"?'; + $lang['strschemadropped'] = 'Схема уничтожена.'; + $lang['strschemadroppedbad'] = 'Уничтожение Ñхемы прервано.'; + $lang['strschemaaltered'] = 'Схема обновлена.'; + $lang['strschemaalteredbad'] = 'Обновление Ñхемы прервано.'; + $lang['strsearchpath'] = 'Пути поиÑка в Ñхемах'; + $lang['strspecifyschematodrop'] = 'Вам необходимо указать как минимум одну Ñхему Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Домен'; + $lang['strdomains'] = 'Домены'; + $lang['strshowalldomains'] = 'Показать вÑе домены'; + $lang['strnodomains'] = 'Ðи одного домена не найдено.'; + $lang['strcreatedomain'] = 'Создать домен'; + $lang['strdomaindropped'] = 'Домен удален.'; + $lang['strdomaindroppedbad'] = 'Удаление домена прервано.'; + $lang['strconfdropdomain'] = 'Ð’Ñ‹ уверены, что хотите удалить домен "%s"?'; + $lang['strdomainneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð´Ð¾Ð¼ÐµÐ½Ð°.'; + $lang['strdomaincreated'] = 'Домен Ñоздан.'; + $lang['strdomaincreatedbad'] = 'Создание домена прервано.'; + $lang['strdomainaltered'] = 'Домен изменен.'; + $lang['strdomainalteredbad'] = 'Изменение домена прервано.'; + + // Operators + $lang['stroperator'] = 'Оператор'; + $lang['stroperators'] = 'Операторы'; + $lang['strshowalloperators'] = 'Показать вÑе операторы'; + $lang['strnooperator'] = 'Оператор не обнаружен.'; + $lang['strnooperators'] = 'Операторы не обнаружены.'; + $lang['strcreateoperator'] = 'Создать оператор'; + $lang['strleftarg'] = 'Тип левого аргумента'; + $lang['strrightarg'] = 'Тип правого аргумента'; + $lang['strcommutator'] = 'Преобразование'; + $lang['strnegator'] = 'Отрицание'; + $lang['strrestrict'] = 'ОÑлабление'; + $lang['strjoin'] = 'Объединение'; + $lang['strhashes'] = 'Хеширование'; + $lang['strmerges'] = 'СлиÑние'; + $lang['strleftsort'] = 'Сотировка по левому'; + $lang['strrightsort'] = 'Сотировка по правому'; + $lang['strlessthan'] = 'Меньше'; + $lang['strgreaterthan'] = 'Больше'; + $lang['stroperatorneedsname'] = 'Вам необходимо указать название оператора.'; + $lang['stroperatorcreated'] = 'Оператор Ñоздан'; + $lang['stroperatorcreatedbad'] = 'Создание оператора прервано.'; + $lang['strconfdropoperator'] = 'Ð’Ñ‹ уверены, что хотите уничтожить оператор "%s"?'; + $lang['stroperatordropped'] = 'Оператор удален.'; + $lang['stroperatordroppedbad'] = 'Удаление оператора прервано.'; + + // Casts + $lang['strcasts'] = 'Образцы'; + $lang['strnocasts'] = 'Образцов не найдено.'; + $lang['strsourcetype'] = 'Тип иÑточника'; + $lang['strtargettype'] = 'Тип приемника'; + $lang['strimplicit'] = 'ÐеÑвный'; + $lang['strinassignment'] = 'Ð’ назначении'; + $lang['strbinarycompat'] = '(двоично ÑовмеÑтимый)'; + + // Conversions + $lang['strconversions'] = 'Преобразование'; + $lang['strnoconversions'] = 'Преобразований не найдено.'; + $lang['strsourceencoding'] = 'Кодировка иÑточника'; + $lang['strtargetencoding'] = 'Кодировка приемника'; + + // Languages + $lang['strlanguages'] = 'Языки'; + $lang['strnolanguages'] = 'Языков не найдено.'; + $lang['strtrusted'] = 'Проверено'; + + // Info + $lang['strnoinfo'] = 'Ðет доÑтупной информации.'; + $lang['strreferringtables'] = 'СÑылающиеÑÑ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['strparenttables'] = 'РодительÑкие таблицы'; + $lang['strchildtables'] = 'Дочерние таблицы'; + + // Aggregates + $lang['straggregate'] = 'Ðгрегатное выражение'; + $lang['straggregates'] = 'Ðгрегатные выражениÑ'; + $lang['strnoaggregates'] = 'Ðгрегатных выражений не найдено.'; + $lang['stralltypes'] = '(Ð’Ñе типы)'; + $lang['strcreateaggregate'] = 'Создать агрегатное выражение'; + $lang['straggrbasetype'] = 'Входной тип данных'; + $lang['straggrsfunc'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ñмены ÑоÑтоÑний'; + $lang['straggrstype'] = 'Тип переменной ÑоÑтоÑниÑ'; + $lang['straggrffunc'] = 'Ð¤Ð¸Ð½Ð°Ð»ÑŒÐ½Ð°Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ñ'; + $lang['straggrinitcond'] = 'Ðачальное уÑловие'; + $lang['straggrsortop'] = 'Оператор Ñортировки'; + $lang['strconfdropaggregate'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить агрегатное выражение "%s"?'; + $lang['straggregatedropped'] = 'Ðгрегатное выражение удалено.'; + $lang['straggregatedroppedbad'] = 'Удаление агрегатного Ð²Ñ‹Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straggraltered'] = 'Ðгрегатное выражение изменено.'; + $lang['straggralteredbad'] = 'Изменение агрегатного Ð²Ñ‹Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straggrneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ Ð°Ð³Ñ€ÐµÐ³Ð°Ñ‚Ð½Ð¾Ð³Ð¾ выражениÑ.'; + $lang['straggrneedsbasetype'] = 'Вам необходимо указать входной тип данных Ð´Ð»Ñ Ð°Ð³Ñ€ÐµÐ³Ð°Ñ‚Ð½Ð¾Ð³Ð¾ выражениÑ.'; + $lang['straggrneedssfunc'] = 'Вам необходимо укакзать Ð¸Ð¼Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ð¸ Ñмены ÑоÑтоÑний Ð´Ð»Ñ Ð°Ð³Ñ€ÐµÐ³Ð°Ñ‚Ð½Ð¾Ð³Ð¾ выражениÑ.'; + $lang['straggrneedsstype'] = 'Вам необходимо указать тип переменной ÑоÑтоÑÐ½Ð¸Ñ Ð´Ð»Ñ Ð°Ð³Ñ€ÐµÐ³Ð°Ñ‚Ð½Ð¾Ð³Ð¾ выражениÑ.'; + $lang['straggrcreated'] = 'Ðгрегатное выражение Ñоздано.'; + $lang['straggrcreatedbad'] = 'Создание агрегатного Ð²Ñ‹Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straggrshowall'] = 'Показать вÑе агрегатные выражениÑ'; + + // Operator Classes + $lang['stropclasses'] = 'КлаÑÑÑ‹ операторов'; + $lang['strnoopclasses'] = 'КлаÑÑов операторов не найдено.'; + $lang['straccessmethod'] = 'Метод доÑтупа'; + + // Stats and performance + $lang['strrowperf'] = 'ПредÑтавление запиÑи'; + $lang['strioperf'] = 'ПредÑтавление ввода/вывода'; + $lang['stridxrowperf'] = 'ПредÑтавление индекÑа запиÑи'; + $lang['stridxioperf'] = 'ПредÑтавление индекÑа ввода/вывода'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'ПоÑледовательный'; + $lang['strscan'] = 'Сканировать'; + $lang['strread'] = 'Читать'; + $lang['strfetch'] = 'Извлечь'; + $lang['strheap'] = 'МуÑор'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST индекÑ'; + $lang['strcache'] = 'Кеш'; + $lang['strdisk'] = 'ДиÑк'; + $lang['strrows2'] = 'ЗапиÑи'; + + // Tablespaces + $lang['strtablespace'] = 'Табличное проÑтранÑтво'; + $lang['strtablespaces'] = 'Табличные проÑтранÑтва'; + $lang['strshowalltablespaces'] = 'Показать вÑе табличные проÑтранÑтва'; + $lang['strnotablespaces'] = 'Табличные проÑтранÑтва не найдены.'; + $lang['strcreatetablespace'] = 'Создать табличное проÑтранÑтво'; + $lang['strlocation'] = 'РаÑположение'; + $lang['strtablespaceneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ‡Ð½Ð¾Ð³Ð¾ проÑтранÑтва.'; + $lang['strtablespaceneedsloc'] = 'Вам необходимо определить директорию, в которой табличное проÑтранÑтво буде Ñоздано.'; + $lang['strtablespacecreated'] = 'Табличное проÑтранÑтво Ñоздано.'; + $lang['strtablespacecreatedbad'] = 'Создание табличного проÑтранÑтва прервано.'; + $lang['strconfdroptablespace'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить табличное проÑтранÑтво "%s"?'; + $lang['strtablespacedropped'] = 'Табличное проÑтранÑтво удалено.'; + $lang['strtablespacedroppedbad'] = 'Удаление табличного проÑтранÑтва прервано.'; + $lang['strtablespacealtered'] = 'Табличное проÑтранÑтво изменено.'; + $lang['strtablespacealteredbad'] = 'Изменение табличного проÑтранÑтва прервано.'; + + // Miscellaneous + $lang['strtopbar'] = '%s выполнÑетÑÑ Ð½Ð° %s:%s -- Ð’Ñ‹ зарегиÑтрированы как "%s"'; + $lang['strtimefmt'] = ' j-m-Y g:i'; + $lang['strhelp'] = 'Помощь'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'ПроÑмотр Ñтраниц помощи'; + $lang['strselecthelppage'] = 'Выберете Ñтраницу помощи'; + $lang['strinvalidhelppage'] = 'ÐÐµÐ¿Ñ€Ð°Ð²Ð¸Ð»ÑŒÐ½Ð°Ñ Ñтраница помощи.'; + $lang['strlogintitle'] = 'Вошли на %s'; + $lang['strlogoutmsg'] = 'Вышли из %s'; + $lang['strloading'] = 'Загрузка...'; + $lang['strerrorloading'] = 'Ошибка при загрузке'; + $lang['strclicktoreload'] = 'Щелкните Ð´Ð»Ñ Ð¿ÐµÑ€ÐµÐ·Ð°Ð³Ñ€ÑƒÐ·ÐºÐ¸'; + + // Autovacuum + $lang['strautovacuum'] = 'ÐвтоматичеÑкое переÑтроение'; + $lang['strturnedon'] = 'Включено'; + $lang['strturnedoff'] = 'Выключено'; + $lang['strenabled'] = 'Включено'; + $lang['strnovacuumconf'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ Ð°Ð²Ñ‚Ð¾Ð¼Ð°Ñ‚Ð¸Ñ‡ÐµÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð½Ðµ найдена.'; + $lang['strvacuumbasethreshold'] = 'Базовый порог переÑтроениÑ'; + $lang['strvacuumscalefactor'] = 'МаÑштабный множитель переÑтроениÑ'; + $lang['stranalybasethreshold'] = 'Базовый порог анализа'; + $lang['stranalyzescalefactor'] = 'МаÑштабный множитель анализа'; + $lang['strvacuumcostdelay'] = 'Задержка при превышении ÑтоимоÑти переÑтроениÑ'; + $lang['strvacuumcostlimit'] = 'Ограничение ÑтоимоÑти переÑтроениÑ'; + $lang['strvacuumpertable'] = 'УÑтановки автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð¿Ð¾ таблицам'; + $lang['straddvacuumtable'] = 'Добавить уÑтановки автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['streditvacuumtable'] = 'Редактировать уÑтановки автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹ %s'; + $lang['strdelvacuumtable'] = 'Удалить уÑтановки автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹ %s?'; + $lang['strvacuumtablereset'] = 'Ð¡Ð±Ñ€Ð¾Ñ ÑƒÑтановок автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹ %s к значениÑм по умолчанию'; + $lang['strdelvacuumtablefail'] = 'Ошибка при удалении уÑтановок автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹ %s'; + $lang['strsetvacuumtablesaved'] = 'УÑтановки автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹ %s Ñохранены.'; + $lang['strsetvacuumtablefail'] = 'Ошибка при Ñохранении уÑтановок автоматичеÑкого переÑÑ‚Ñ€Ð¾ÐµÐ½Ð¸Ñ %s.'; + $lang['strspecifydelvacuumtable'] = 'Вам необходимо указать таблицу, Ð´Ð»Ñ ÐºÐ¾Ñ‚Ð¾Ñ€Ð¾Ð¹ вы хотите удалить уÑтановки автоматичеÑкого переÑтроениÑ.'; + $lang['strspecifyeditvacuumtable'] = 'Вам необходимо указать таблицу, Ð´Ð»Ñ ÐºÐ¾Ñ‚Ð¾Ñ€Ð¾Ð¹ вы хотите редактировать уÑтановки автоматичеÑкого переÑтроениÑ.'; + $lang['strnotdefaultinred'] = 'ЗначениÑ, отличные от значений по умолчанию, отмечены краÑным цветом.'; + + // Table-level Locks + $lang['strlocks'] = 'Блокировки'; + $lang['strtransaction'] = 'ID транзакции'; + $lang['strvirtualtransaction'] = 'ID виртуальной транзакции'; + $lang['strprocessid'] = 'ID процеÑÑа'; + $lang['strmode'] = 'Режим блокировки'; + $lang['strislockheld'] = 'Блокировка удерживаетÑÑ?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Подготовленные транзакции'; + $lang['strxactid'] = 'ID транзакции'; + $lang['strgid'] = 'Глобальный ID'; + + // Fulltext search + $lang['strfulltext'] = 'ПолнотекÑтовый поиÑк (FTS)'; + $lang['strftsconfig'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ FTS'; + $lang['strftsconfigs'] = 'Конфигурации'; + $lang['strftscreateconfig'] = 'Создать конфигурацию FTS'; + $lang['strftscreatedict'] = 'Создать Ñловарь'; + $lang['strftscreatedicttemplate'] = 'Создать шаблон ÑловарÑ'; + $lang['strftscreateparser'] = 'Создать парÑер'; + $lang['strftsnoconfigs'] = 'Конфигурации FTS не найдены.'; + $lang['strftsconfigdropped'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ FTS удалена.'; + $lang['strftsconfigdroppedbad'] = 'Удаление конфигурации FTS прервано.'; + $lang['strconfdropftsconfig'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить конфигурацию FTS "%s"?'; + $lang['strconfdropftsdict'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить Ñловарь FTS "%s"?'; + $lang['strconfdropftsmapping'] = 'Ð’Ñ‹ дейÑтвительно хотите удалить правило "%s" конфигурации FTS "%s"?'; + $lang['strftstemplate'] = 'Шаблон'; + $lang['strftsparser'] = 'ПарÑер'; + $lang['strftsconfigneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ ÐºÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ð¸ FTS.'; + $lang['strftsconfigcreated'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ FTS Ñоздана.'; + $lang['strftsconfigcreatedbad'] = 'Создание конфигурации FTS прервано.'; + $lang['strftsmapping'] = 'Правила'; + $lang['strftsdicts'] = 'Словари'; + $lang['strftsdict'] = 'Словарь'; + $lang['strftsemptymap'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð» FTS пуÑта.'; + $lang['strftsconfigaltered'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ FTS изменена.'; + $lang['strftsconfigalteredbad'] = 'Изменение конфигурации FTS прервано.'; + $lang['strftsconfigmap'] = 'ÐšÐ¾Ð½Ñ„Ð¸Ð³ÑƒÑ€Ð°Ñ†Ð¸Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð» FTS'; + $lang['strftsparsers'] = 'ПарÑеры FTS'; + $lang['strftsnoparsers'] = 'Ðет доÑтупных парÑеров FTS.'; + $lang['strftsnodicts'] = 'Ðет доÑтупных Ñловарей FTS.'; + $lang['strftsdictcreated'] = 'Словарь FTS Ñоздан.'; + $lang['strftsdictcreatedbad'] = 'Создание ÑÐ»Ð¾Ð²Ð°Ñ€Ñ FTS прервано.'; + $lang['strftslexize'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð¿Ñ€ÐµÐ¾Ð±Ñ€Ð°Ð·Ð¾Ð²Ð°Ð½Ð¸Ñ Ñ‚Ð¾ÐºÐµÐ½Ð° в лекÑему (lexize)'; + $lang['strftsinit'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð¸Ð½Ð¸Ñ†Ð¸Ð°Ð»Ð¸Ð·Ð°Ñ†Ð¸Ð¸'; + $lang['strftsoptionsvalues'] = 'Опции и значениÑ'; + $lang['strftsdictneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ ÑÐ»Ð¾Ð²Ð°Ñ€Ñ FTS.'; + $lang['strftsdictdropped'] = 'Словарь FTS удален.'; + $lang['strftsdictdroppedbad'] = 'Удаление ÑÐ»Ð¾Ð²Ð°Ñ€Ñ FTS прервано.'; + $lang['strftsdictaltered'] = 'Словарь FTS изменен.'; + $lang['strftsdictalteredbad'] = 'Изменение ÑÐ»Ð¾Ð²Ð°Ñ€Ñ FTS прервано.'; + $lang['strftsaddmapping'] = 'Добавить новое правило'; + $lang['strftsspecifymappingtodrop'] = 'Вам необходимо указать как минимум одно правило Ð´Ð»Ñ ÑƒÐ´Ð°Ð»ÐµÐ½Ð¸Ñ.'; + $lang['strftsspecifyconfigtoalter'] = 'Вам необходимо указать конфигурацию FTS Ð´Ð»Ñ Ð¸Ð·Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ'; + $lang['strftsmappingdropped'] = 'Правило FTS удалено.'; + $lang['strftsmappingdroppedbad'] = 'Удаление правила FTS прервано.'; + $lang['strftsnodictionaries'] = 'Словари не найдены.'; + $lang['strftsmappingaltered'] = 'Правило FTS изменено.'; + $lang['strftsmappingalteredbad'] = 'Изменение правила FTS прервано.'; + $lang['strftsmappingadded'] = 'Правило FTS добавлено.'; + $lang['strftsmappingaddedbad'] = 'Добавление правила FTS прервано.'; + $lang['strftstabconfigs'] = 'Конфигурации'; + $lang['strftstabdicts'] = 'Словари'; + $lang['strftstabparsers'] = 'ПарÑеры'; + $lang['strftscantparsercopy'] = 'При Ñоздании конфигурации поиÑка Ð½ÐµÐ»ÑŒÐ·Ñ ÑƒÐºÐ°Ð·Ñ‹Ð²Ð°Ñ‚ÑŒ одновременно парÑер и шаблон.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian.php new file mode 100644 index 00000000..da842798 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/russian.php @@ -0,0 +1,586 @@ +'; + $lang['strfirst'] = '<< Перв.'; + $lang['strlast'] = 'ПоÑл. >>'; + $lang['strfailed'] = 'Прервано'; + $lang['strcreate'] = 'Создать'; + $lang['strcreated'] = 'Создано'; + $lang['strcomment'] = 'Комментарий'; + $lang['strlength'] = 'Длина'; + $lang['strdefault'] = 'По умолчанию'; + $lang['stralter'] = 'Изменить'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Отменить'; + $lang['strsave'] = 'Сохранить'; + $lang['strreset'] = 'СброÑить'; + $lang['strinsert'] = 'Ð’Ñтавить'; + $lang['strselect'] = 'Выбрать'; + $lang['strdelete'] = 'Удалить'; + $lang['strupdate'] = 'Обновить'; + $lang['strreferences'] = 'СÑылки'; + $lang['stryes'] = 'Да'; + $lang['strno'] = 'Ðет'; + $lang['strtrue'] = 'ИÑтина'; + $lang['strfalse'] = 'Ложь'; + $lang['stredit'] = 'Редактировать'; + $lang['strcolumns'] = 'Ðтрибуты'; + $lang['strrows'] = 'запиÑ(ÑŒ/и/ей)'; + $lang['strrowsaff'] = 'запиÑ(ÑŒ/и/ей) обработано.'; + $lang['strobjects'] = 'объект(а/ов)'; + $lang['strexample'] = 'и Ñ‚.д.'; + $lang['strback'] = 'Ðазад'; + $lang['strqueryresults'] = 'Результаты запроÑа'; + $lang['strshow'] = 'Показать'; + $lang['strempty'] = 'ОчиÑтить'; + $lang['strlanguage'] = 'Язык'; + $lang['strencoding'] = 'Кодировка'; + $lang['strvalue'] = 'Величина'; + $lang['strunique'] = 'Уникальный'; + $lang['strprimary'] = 'Первичный'; + $lang['strexport'] = 'ЭкÑпорт'; + $lang['strimport'] = 'Импорт'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = 'Выполнить'; + $lang['stradmin'] = 'Управление'; + $lang['strvacuum'] = 'ПереÑтроить'; + $lang['stranalyze'] = 'Ðнализировать'; + $lang['strclusterindex'] = 'КлаÑтеризовать'; + $lang['strclustered'] = 'КлаÑтеризован?'; + $lang['strreindex'] = 'ПереÑтроить индекÑ'; + $lang['strrun'] = 'Выполнить'; + $lang['stradd'] = 'Добавить'; + $lang['strevent'] = 'Событие'; + $lang['strwhere'] = 'Где'; + $lang['strinstead'] = 'Делать вмеÑто'; + $lang['strwhen'] = 'Когда'; + $lang['strformat'] = 'Формат'; + $lang['strdata'] = 'Данные'; + $lang['strconfirm'] = 'Подтвердить'; + $lang['strexpression'] = 'Выражение'; + $lang['strellipsis'] = '...'; + $lang['strexpand'] = 'РаÑширить'; + $lang['strcollapse'] = 'Свернуть'; + $lang['strexplain'] = 'ОбъÑÑнить'; + $lang['strexplainanalyze'] = 'ОбъÑÑнить анализ'; + $lang['strfind'] = 'Ðайти'; + $lang['stroptions'] = 'Опции'; + $lang['strrefresh'] = 'Обновить'; + $lang['strdownload'] = 'Загрузить'; + $lang['strdownloadgzipped'] = 'Загрузить архив gzip'; + $lang['strinfo'] = 'СведениÑ'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Дополнительно'; + $lang['strvariables'] = 'Переменные'; + $lang['strprocess'] = 'ПроцеÑÑ'; + $lang['strprocesses'] = 'ПроцеÑÑÑ‹'; + $lang['strsetting'] = 'Опции'; + $lang['streditsql'] = 'Редактировать SQL'; + $lang['strruntime'] = 'Ð’Ñ€ÐµÐ¼Ñ Ð²Ñ‹Ð¿Ð¾Ð»Ð½ÐµÐ½Ð¸Ñ: %s мÑек'; + $lang['strpaginate'] = 'Ðумеровать Ñтраницы Ñ Ñ€ÐµÐ·ÑƒÐ»ÑŒÑ‚Ð°Ñ‚Ð°Ð¼Ð¸'; + $lang['struploadscript'] = 'или загрузить SQL-Ñкрипт:'; + $lang['strstarttime'] = 'Ð’Ñ€ÐµÐ¼Ñ Ð½Ð°Ñ‡Ð°Ð»Ð°'; + $lang['strfile'] = 'Файл'; + $lang['strfileimported'] = 'Файл импортирован.'; + + // Error handling + $lang['strbadconfig'] = 'Ваш config.inc.php ÑвлÑетÑÑ ÑƒÑтаревшим. Вам необходимо обновить его из config.inc.php-dist.'; + $lang['strnotloaded'] = 'Ваша инÑталÑÑ†Ð¸Ñ PHP не поддерживает PostgreSQL. Вам необходимо переÑобрать PHP, иÑÐ¿Ð¾Ð»ÑŒÐ·ÑƒÑ Ð¿Ð°Ñ€Ð°Ð¼ÐµÑ‚Ñ€ --with-pgsql Ð´Ð»Ñ configure.'; + $lang['strbadschema'] = 'Обнаружена Ð½ÐµÐ²ÐµÑ€Ð½Ð°Ñ Ñхема.'; + $lang['strbadencoding'] = 'Failed to set client encoding in database.'; + $lang['strsqlerror'] = 'Ошибка SQL:'; + $lang['strinstatement'] = 'Ð’ операторе:'; + $lang['strinvalidparam'] = 'Ðеверный параметр Ñкрипта.'; + $lang['strnodata'] = 'Данных не найдено.'; + $lang['strnoobjects'] = 'Объектов не найдено.'; + $lang['strrownotunique'] = 'Ðет уникального идентификатора Ð´Ð»Ñ Ñтой запиÑи.'; + $lang['strnouploads'] = 'Загрузка файла невозможна.'; + $lang['strimporterror'] = 'Ошибка импорта.'; + $lang['strimporterrorline'] = 'Ошибка канала при импорте %s.'; + + // Tables + $lang['strtable'] = 'Таблица'; + $lang['strtables'] = 'Таблицы'; + $lang['strshowalltables'] = 'Показать вÑе таблицы'; + $lang['strnotables'] = 'Таблиц не найдено.'; + $lang['strnotable'] = ' Таблица не обнаружена.'; + $lang['strcreatetable'] = 'Создать таблицу'; + $lang['strtablename'] = 'Ð˜Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['strtableneedsname'] = 'Вам необходимо определить Ð¸Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹.'; + $lang['strtableneedsfield'] = 'Вам необходимо определить по крайней мере одно поле.'; + $lang['strtableneedscols'] = 'Вам необходимо указать допуÑтимое чиÑло атрибутов.'; + $lang['strtablecreated'] = 'Таблица Ñоздана.'; + $lang['strtablecreatedbad'] = 'Создание таблицы прервано.'; + $lang['strconfdroptable'] = 'Ð’Ñ‹ уверены, что хотите удалить таблицу "%s"?'; + $lang['strtabledropped'] = 'Таблица удалена.'; + $lang['strtabledroppedbad'] = 'Удаление таблицы прервано.'; + $lang['strconfemptytable'] = 'Ð’Ñ‹ уверены, что хотите очиÑтить таблицу "%s"?'; + $lang['strtableemptied'] = 'Таблица очищена.'; + $lang['strtableemptiedbad'] = 'ОчиÑтка таблицы прервана.'; + $lang['strinsertrow'] = 'Добавить запиÑÑŒ'; + $lang['strrowinserted'] = 'ЗапиÑÑŒ добавлена.'; + $lang['strrowinsertedbad'] = 'Добавление запиÑи прервано.'; + $lang['streditrow'] = 'Редактировать запиÑÑŒ'; + $lang['strrowupdated'] = 'ЗапиÑÑŒ обновлена.'; + $lang['strrowupdatedbad'] = 'Обновление запиÑи прервано.'; + $lang['strdeleterow'] = 'Удалить запиÑÑŒ'; + $lang['strconfdeleterow'] = 'Ð’Ñ‹ уверены, что хотите удалить запиÑÑŒ?'; + $lang['strrowdeleted'] = 'ЗапиÑÑŒ удалена.'; + $lang['strrowdeletedbad'] = 'Удаление запиÑи прервано.'; + $lang['strsaveandrepeat'] = 'Ð’Ñтавить и повторить'; + $lang['strfield'] = 'Поле'; + $lang['strfields'] = 'ПолÑ'; + $lang['strnumfields'] = 'Кол-во полей'; + $lang['strfieldneedsname'] = 'Вам необходимо назвать поле'; + $lang['strselectallfields'] = 'Выбрать вÑе полÑ'; + $lang['strselectneedscol'] = 'Вам необходимо указать по крайней мере один атрибут'; + $lang['strselectunary'] = 'Унарный оператор не может иметь величину.'; + $lang['straltercolumn'] = 'Изменить атрибут'; + $lang['strcolumnaltered'] = 'Ðтрибут изменен.'; + $lang['strcolumnalteredbad'] = 'Изменение атрибута прервано.'; + $lang['strconfdropcolumn'] = 'Ð’Ñ‹ уверены, что хотите удалить атрибут "%s" таблицы "%s"?'; + $lang['strcolumndropped'] = 'Ðтрибут удален.'; + $lang['strcolumndroppedbad'] = 'Удаление атрибута прервано.'; + $lang['straddcolumn'] = 'Добавить атрибут'; + $lang['strcolumnadded'] = 'Ðтрибут добавлен.'; + $lang['strcolumnaddedbad'] = 'Добавление атрибута прервано.'; + $lang['strdataonly'] = 'Только данные'; + $lang['strcascade'] = 'КаÑкадом'; + $lang['strtablealtered'] = 'Таблица изменена.'; + $lang['strtablealteredbad'] = 'Изменение таблицы прервано.'; + $lang['strdataonly'] = 'Только данные'; + $lang['strstructureonly'] = 'Только Ñтруктуру'; + $lang['strstructureanddata'] = 'Структуру и данные'; + $lang['strtabbed'] = 'Через табулÑцию'; + $lang['strauto'] = 'Ðвто'; + + // Users + $lang['struser'] = 'Пользователь'; + $lang['strusers'] = 'Пользователи'; + $lang['strusername'] = 'Ð˜Ð¼Ñ Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ'; + $lang['strpassword'] = 'Пароль'; + $lang['strsuper'] = 'Суперпользователь?'; + $lang['strcreatedb'] = 'Создать базу данных?'; + $lang['strexpires'] = 'Срок дейÑтвиÑ'; + $lang['strsessiondefaults'] = 'Опции ÑеанÑа по умолчанию'; + $lang['strnousers'] = 'Ðет таких пользователей.'; + $lang['struserupdated'] = 'Пользователь обновлен.'; + $lang['struserupdatedbad'] = 'Обновление Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strshowallusers'] = 'Показать вÑех пользователей'; + $lang['strcreateuser'] = 'Создать пользователÑ'; + $lang['struserneedsname'] = 'Ð’Ñ‹ должны ввеÑти Ð¸Ð¼Ñ Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ.'; + $lang['strusercreated'] = 'Пользователь Ñоздан.'; + $lang['strusercreatedbad'] = 'Создание Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropuser'] = 'Ð’Ñ‹ уверены, что хотите удалить Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ "%s"?'; + $lang['struserdropped'] = 'Пользователь удален.'; + $lang['struserdroppedbad'] = 'Удаление Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straccount'] = 'Ðккаунт'; + $lang['strchangepassword'] = 'Изменить пароль'; + $lang['strpasswordchanged'] = 'Пароль изменен.'; + $lang['strpasswordchangedbad'] = 'Изменение Ð¿Ð°Ñ€Ð¾Ð»Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strpasswordshort'] = 'Пароль Ñлишком короткий.'; + $lang['strpasswordconfirm'] = 'Пароль не ÑоответÑтвует подтверждению.'; + + // Groups + $lang['strgroup'] = 'Группа'; + $lang['strgroups'] = 'Группы'; + $lang['strnogroup'] = 'Группа не обнаружена.'; + $lang['strnogroups'] = 'Ðи одной группы не найдено.'; + $lang['strcreategroup'] = 'Создать группу'; + $lang['strshowallgroups'] = 'Показать вÑе группы'; + $lang['strgroupneedsname'] = 'Вам необходимо указать название группы.'; + $lang['strgroupcreated'] = 'Группа Ñоздана.'; + $lang['strgroupcreatedbad'] = 'Создание группы прервано.'; + $lang['strconfdropgroup'] = 'Ð’Ñ‹ уверены, что хотите удалить группу "%s"?'; + $lang['strgroupdropped'] = 'Группа удалена.'; + $lang['strgroupdroppedbad'] = 'Удаление группы прервано.'; + $lang['strmembers'] = 'УчаÑтников'; + $lang['straddmember'] = 'Добавить учаÑтника'; + $lang['strmemberadded'] = 'УчаÑтник добавлен.'; + $lang['strmemberaddedbad'] = 'Добавление учаÑтника прервано.'; + $lang['strdropmember'] = 'Удалить учаÑтника'; + $lang['strconfdropmember'] = 'Ð’Ñ‹ уверены, что хотите удалить учаÑтника "%s" из группы "%s"?'; + $lang['strmemberdropped'] = 'УчаÑтник удален.'; + $lang['strmemberdroppedbad'] = 'Удаление учаÑтника прервано.'; + + // Privilges + $lang['strprivilege'] = 'ПривилегиÑ'; + $lang['strprivileges'] = 'Привилегии'; + $lang['strnoprivileges'] = 'Объект не имеет привилегий.'; + $lang['strgrant'] = 'УÑилить'; + $lang['strrevoke'] = 'ОÑлабить'; + $lang['strgranted'] = 'Привилегии изменены.'; + $lang['strgrantfailed'] = 'Изменение привилегий прервано.'; + $lang['strgrantbad'] = 'Вам необходимо указать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ одного Ð¿Ð¾Ð»ÑŒÐ·Ð¾Ð²Ð°Ñ‚ÐµÐ»Ñ Ð¸Ð»Ð¸ группу и Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ одну привилегию.'; + $lang['stralterprivs'] = 'Изменить привилегии'; + $lang['strgrantor'] = 'Донор'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'База данных'; + $lang['strdatabases'] = 'Базы данных'; + $lang['strshowalldatabases'] = 'Показать вÑе базы данных'; + $lang['strnodatabase'] = 'База данных не обнаружена.'; + $lang['strnodatabases'] = 'Ðи одной базы данных не найдено.'; + $lang['strcreatedatabase'] = 'Создать базу данных'; + $lang['strdatabasename'] = 'Ð˜Ð¼Ñ Ð±Ð°Ð·Ñ‹ данных'; + $lang['strdatabaseneedsname'] = 'Вам необходимо приÑвоить Ð¸Ð¼Ñ Ð’Ð°ÑˆÐµÐ¹ базе данных.'; + $lang['strdatabasecreated'] = 'База данных Ñоздана.'; + $lang['strdatabasecreatedbad'] = 'Создание базы данных прервано.'; + $lang['strconfdropdatabase'] = 'Ð’Ñ‹ уверены, что хотите уничтожить базу данных "%s"?'; + $lang['strdatabasedropped'] = ' База данных уничтожена.'; + $lang['strdatabasedroppedbad'] = 'Уничтожение базы данных прервано.'; + $lang['strentersql'] = 'Введите SQL-Ð·Ð°Ð¿Ñ€Ð¾Ñ Ð½Ð¸Ð¶Ðµ:'; + $lang['strsqlexecuted'] = 'SQL-Ð·Ð°Ð¿Ñ€Ð¾Ñ Ð²Ñ‹Ð¿Ð¾Ð»Ð½ÐµÐ½.'; + $lang['strvacuumgood'] = 'ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð¿ÐµÑ€ÐµÑтройки завершена.'; + $lang['strvacuumbad'] = 'ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð¿ÐµÑ€ÐµÑтройки прервана.'; + $lang['stranalyzegood'] = ' ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð°Ð½Ð°Ð»Ð¸Ð·Ð° завершена.'; + $lang['stranalyzebad'] = ' ÐžÐ¿ÐµÑ€Ð°Ñ†Ð¸Ñ Ð°Ð½Ð°Ð»Ð¸Ð·Ð° завершена.'; + $lang['strreindexgood'] = 'ПереиндекÑÐ°Ñ†Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð°.'; + $lang['strreindexbad'] = 'ПереиндекÑÐ°Ñ†Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð°.'; + $lang['strfull'] = 'ПолноÑтью'; + $lang['strfreeze'] = 'Заморозить'; + $lang['strforce'] = 'Принудительно'; + + // Views + $lang['strview'] = 'ПредÑтавление'; + $lang['strviews'] = 'ПредÑтавлениÑ'; + $lang['strshowallviews'] = 'Показать вÑе предÑтавлениÑ'; + $lang['strnoview'] = 'ПредÑтавление не найдено.'; + $lang['strnoviews'] = 'Ðи одного предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð½Ðµ найдено.'; + $lang['strcreateview'] = 'Создать предÑтавление'; + $lang['strviewname'] = 'Ð˜Ð¼Ñ Ð¿Ñ€ÐµÐ´ÑтавлениÑ'; + $lang['strviewneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¿Ñ€ÐµÐ´ÑтавлениÑ.'; + $lang['strviewneedsdef'] = 'Вам необходимо определить атрибуты предÑтавлениÑ.'; + $lang['strviewneedsfields'] = 'Вам необходимо определить атрибуты Ð´Ð»Ñ Ð²Ñ‹Ð±Ð¾Ñ€ÐºÐ¸ в ваше предÑтавление.'; + $lang['strviewcreated'] = 'ПредÑтавление Ñоздано.'; + $lang['strviewcreatedbad'] = 'Создание предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropview'] = 'Ð’Ñ‹ уверены, что хотите уничтожить предÑтавление "%s"?'; + $lang['strviewdropped'] = 'ПредÑтавление уничтожено.'; + $lang['strviewdroppedbad'] = 'Уничтожение предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strviewupdated'] = 'ПредÑтавление обновлено.'; + $lang['strviewupdatedbad'] = 'Обновление предÑÑ‚Ð°Ð²Ð»ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strviewlink'] = 'СвÑзанные ключи'; + $lang['strviewconditions'] = 'Дополнительные уÑловиÑ'; + $lang['strcreateviewwiz'] = 'Создать предÑтавление помощником'; + + // Sequences + $lang['strsequence'] = 'ПоÑледовательноÑÑ‚ÑŒ'; + $lang['strsequences'] = ' ПоÑледовательноÑти'; + $lang['strshowallsequences'] = 'Показать вÑе поÑледовательноÑти'; + $lang['strnosequence'] = 'ПоÑледовательноÑÑ‚ÑŒ не обнаружена.'; + $lang['strnosequences'] = 'Ðи одной поÑледовательноÑти не найдено.'; + $lang['strcreatesequence'] = 'Создать поÑледовательноÑÑ‚ÑŒ'; + $lang['strlastvalue'] = 'ПоÑледнее значение'; + $lang['strincrementby'] = 'Увеличение на'; + $lang['strstartvalue'] = 'Ðачальное значение'; + $lang['strmaxvalue'] = 'МакÑ. величина'; + $lang['strminvalue'] = 'Мин. величина'; + $lang['strcachevalue'] = 'Размер кÑша'; + $lang['strlogcount'] = 'Log Count'; + $lang['striscycled'] = 'Зациклить?'; + $lang['strsequenceneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¿Ð¾ÑледовательноÑти.'; + $lang['strsequencecreated'] = 'ПоÑледовательноÑÑ‚ÑŒ Ñоздана.'; + $lang['strsequencecreatedbad'] = 'Создание поÑледовательноÑти прервано.'; + $lang['strconfdropsequence'] = 'Ð’Ñ‹ уверены, что хотите уничтожить поÑледовательноÑÑ‚ÑŒ "%s"?'; + $lang['strsequencedropped'] = 'ПоÑледовательноÑÑ‚ÑŒ уничтожена.'; + $lang['strsequencedroppedbad'] = 'Уничтожение поÑледовательноÑти прервано.'; + $lang['strsequencereset'] = 'ПоÑледовательноÑÑ‚ÑŒ Ñброшена.'; + $lang['strsequenceresetbad'] = 'Ð¡Ð±Ñ€Ð¾Ñ Ð¿Ð¾ÑледовательноÑти прерван.'; + + // Indexes + $lang['strindex'] = 'ИндекÑ'; + $lang['strindexes'] = 'ИндекÑÑ‹'; + $lang['strindexname'] = 'Ð˜Ð¼Ñ Ð¸Ð½Ð´ÐµÐºÑа'; + $lang['strshowallindexes'] = 'Показать вÑе индекÑÑ‹'; + $lang['strnoindex'] = 'Ð˜Ð½Ð´ÐµÐºÑ Ð½Ðµ обнаружен.'; + $lang['strnoindexes'] = 'Ðи одного индекÑа не найдено.'; + $lang['strcreateindex'] = 'Создать индекÑ'; + $lang['strtabname'] = 'Ð˜Ð¼Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['strcolumnname'] = 'Ð˜Ð¼Ñ Ð°Ñ‚Ñ€Ð¸Ð±ÑƒÑ‚Ð°'; + $lang['strindexneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¸Ð½Ð´ÐµÐºÑа'; + $lang['strindexneedscols'] = 'Вам необходимо указать допуÑтимое количеÑтво атрибутов.'; + $lang['strindexcreated'] = 'Ð˜Ð½Ð´ÐµÐºÑ Ñоздан.'; + $lang['strindexcreatedbad'] = 'Создание индекÑа прервано.'; + $lang['strconfdropindex'] = 'Ð’Ñ‹ уверены, что хотите уничтожить Ð¸Ð½Ð´ÐµÐºÑ "%s"?'; + $lang['strindexdropped'] = 'Ð˜Ð½Ð´ÐµÐºÑ ÑƒÐ½Ð¸Ñ‡Ñ‚Ð¾Ð¶ÐµÐ½.'; + $lang['strindexdroppedbad'] = 'Уничтожение индекÑа прервано.'; + $lang['strkeyname'] = 'Ð˜Ð¼Ñ ÐºÐ»ÑŽÑ‡Ð°'; + $lang['struniquekey'] = 'Уникальный ключ'; + $lang['strprimarykey'] = 'Первичный ключ'; + $lang['strindextype'] = 'Вид индекÑа'; + $lang['strindexname'] = 'Ð˜Ð¼Ñ Ð¸Ð½Ð´ÐµÐºÑа'; + $lang['strtablecolumnlist'] = 'Ðтрибутов в таблице'; + $lang['strindexcolumnlist'] = 'Ðтрибутов в индекÑе'; + $lang['strconfcluster'] = 'Ð’Ñ‹ уверены, что хотите клаÑтеризовать "%s"?'; + $lang['strclusteredgood'] = 'КлаÑÑ‚ÐµÑ€Ð¸Ð·Ð°Ñ†Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð°.'; + $lang['strclusteredbad'] = 'КлаÑÑ‚ÐµÑ€Ð¸Ð·Ð°Ñ†Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð°.'; + + // Rules + $lang['strrules'] = 'Правила'; + $lang['strrule'] = 'Правило'; + $lang['strshowallrules'] = 'Показать вÑе правила'; + $lang['strnorule'] = 'Правило не найдено.'; + $lang['strnorules'] = 'Ðи одного правила не найдено.'; + $lang['strcreaterule'] = 'Создать правило'; + $lang['strrulename'] = 'Ð˜Ð¼Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð°'; + $lang['strruleneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð°.'; + $lang['strrulecreated'] = 'Правило Ñоздано.'; + $lang['strrulecreatedbad'] = 'Создание правила прервано.'; + $lang['strconfdroprule'] = 'Ð’Ñ‹ уверены, что хотите уничтожить правило "%s" on "%s"?'; + $lang['strruledropped'] = 'Правило уничтожено.'; + $lang['strruledroppedbad'] = 'Уничтожение правила прервано.'; + + // Constraints + $lang['strconstraints'] = 'ОграничениÑ'; + $lang['strshowallconstraints'] = 'Показать вÑе ограничениÑ'; + $lang['strnoconstraints'] = 'Ðи одного Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð½Ðµ найдено.'; + $lang['strcreateconstraint'] = 'Создать ограничение'; + $lang['strconstraintcreated'] = 'Ограничение Ñоздано.'; + $lang['strconstraintcreatedbad'] = 'Создание Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropconstraint'] = 'Ð’Ñ‹ уверены, что хотите уничтожить ограничение "%s" on "%s"?'; + $lang['strconstraintdropped'] = 'Ограничение уничтожено.'; + $lang['strconstraintdroppedbad'] = 'Уничтожение Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ñ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straddcheck'] = 'Добавить проверку'; + $lang['strcheckneedsdefinition'] = 'Ограничение проверки нуждаетÑÑ Ð² определении.'; + $lang['strcheckadded'] = 'Ограничение проверки добавлено.'; + $lang['strcheckaddedbad'] = 'Добавление Ð¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð¸Ñ Ð¿Ñ€Ð¾Ð²ÐµÑ€ÐºÐ¸ прервано.'; + $lang['straddpk'] = 'Добавить первичный ключ'; + $lang['strpkneedscols'] = 'Первичный ключ должен включать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ один атрибут.'; + $lang['strpkadded'] = 'Первичный ключ добавлен.'; + $lang['strpkaddedbad'] = 'Добавление первичного ключа прервано.'; + $lang['stradduniq'] = 'Добавить уникальный ключ'; + $lang['struniqneedscols'] = 'Уникальный ключ должен включать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ один атрибут.'; + $lang['struniqadded'] = 'Уникальный ключ добавлен.'; + $lang['struniqaddedbad'] = 'Добавление уникального ключа прервано.'; + $lang['straddfk'] = 'Добавить внешний ключ'; + $lang['strfkneedscols'] = 'Внешний ключ должен включать Ñ…Ð¾Ñ‚Ñ Ð±Ñ‹ один атрибут.'; + $lang['strfkneedstarget'] = 'Внешнему ключу необходимо указать целевую таблицу.'; + $lang['strfkadded'] = 'Внешний ключ добавлен.'; + $lang['strfkaddedbad'] = 'Добавление внешнего ключа прервано.'; + $lang['strfktarget'] = 'Ð¦ÐµÐ»ÐµÐ²Ð°Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ð°'; + $lang['strfkcolumnlist'] = 'Ðтрибуты в ключе'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'ФункциÑ'; + $lang['strfunctions'] = ' Функции'; + $lang['strshowallfunctions'] = 'Показать вÑе функции'; + $lang['strnofunction'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð½Ðµ обнаружена.'; + $lang['strnofunctions'] = 'Ðи одной функции не найдено.'; + $lang['strcreatefunction'] = 'Создать функцию'; + $lang['strfunctionname'] = 'Ð˜Ð¼Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ð¸'; + $lang['strreturns'] = 'Возвращаемое значение'; + $lang['strarguments'] = 'Ðргументы'; + $lang['strproglanguage'] = 'Язык программированиÑ'; + $lang['strproglanguage'] = 'Язык'; + $lang['strfunctionneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñ„ÑƒÐ½ÐºÑ†Ð¸Ð¸.'; + $lang['strfunctionneedsdef'] = 'Вам необходимо определить функцию.'; + $lang['strfunctioncreated'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ñоздана.'; + $lang['strfunctioncreatedbad'] = 'Создание функции прервано.'; + $lang['strconfdropfunction'] = 'Ð’Ñ‹ уверены, что хотите уничтожить функцию "%s"?'; + $lang['strfunctiondropped'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ ÑƒÐ½Ð¸Ñ‡Ñ‚Ð¾Ð¶ÐµÐ½Ð°.'; + $lang['strfunctiondroppedbad'] = 'Уничтожение функции прервано.'; + $lang['strfunctionupdated'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð¾Ð±Ð½Ð¾Ð²Ð»ÐµÐ½Ð°.'; + $lang['strfunctionupdatedbad'] = 'Обновление функции прервано.'; + + // Triggers + $lang['strtrigger'] = 'Триггер'; + $lang['strtriggers'] = ' Триггеры'; + $lang['strshowalltriggers'] = 'Показать вÑе триггеры'; + $lang['strnotrigger'] = 'Триггер не обнаружен.'; + $lang['strnotriggers'] = 'Ðи одного триггера не найдено.'; + $lang['strcreatetrigger'] = 'Создать триггер'; + $lang['strtriggerneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñ‚Ñ€Ð¸Ð³Ð³ÐµÑ€Ð°.'; + $lang['strtriggerneedsfunc'] = 'Вам необходимо определить функцию триггера.'; + $lang['strtriggercreated'] = 'Триггер Ñоздан.'; + $lang['strtriggercreatedbad'] = 'Создание триггера прервано.'; + $lang['strconfdroptrigger'] = 'Ð’Ñ‹ уверены, что хотите уничтожить триггер "%s" на "%s"?'; + $lang['strtriggerdropped'] = 'Триггер уничтожен.'; + $lang['strtriggerdroppedbad'] = 'Уничтожение триггера прервано.'; + $lang['strtriggeraltered'] = 'Триггер изменен.'; + $lang['strtriggeralteredbad'] = 'Изменение триггера прервано.'; + + // Types + $lang['strtype'] = 'Тип данных'; + $lang['strtypes'] = 'Типы данных'; + $lang['strshowalltypes'] = 'Показать вÑе типы данных'; + $lang['strnotype'] = 'Тип данных не обнаружен.'; + $lang['strnotypes'] = 'Ðи одного типа данных не найдено.'; + $lang['strcreatetype'] = 'Создать тип данных'; + $lang['strtypename'] = 'Ð˜Ð¼Ñ Ñ‚Ð¸Ð¿Ð° данных'; + $lang['strinputfn'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð²Ð²Ð¾Ð´Ð°'; + $lang['stroutputfn'] = 'Ð¤ÑƒÐ½ÐºÑ†Ð¸Ñ Ð²Ñ‹Ð²Ð¾Ð´Ð°'; + $lang['strpassbyval'] = 'Передать по значению?'; + $lang['stralignment'] = 'Выравнивание'; + $lang['strelement'] = 'Элемент'; + $lang['strdelimiter'] = 'Разделитель'; + $lang['strstorage'] = 'Storage'; + $lang['strtypeneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñ‚Ð¸Ð¿Ð° данных.'; + $lang['strtypeneedslen'] = 'Вам необходимо указать размер Ð´Ð»Ñ Ñ‚Ð¸Ð¿Ð° данных.'; + $lang['strtypecreated'] = 'Тип данных Ñоздан.'; + $lang['strtypecreatedbad'] = 'Создание типа данных прервано.'; + $lang['strconfdroptype'] = 'Ð’Ñ‹ уверены, что хотите уничтожить тип данных "%s"?'; + $lang['strtypedropped'] = 'Тип данных уничтожен.'; + $lang['strtypedroppedbad'] = 'Уничтожение типа данных прервано.'; + + // Schemas + $lang['strschema'] = 'Схема'; + $lang['strschemas'] = 'Схемы'; + $lang['strshowallschemas'] = 'Показать вÑе Ñхемы'; + $lang['strnoschema'] = 'Схема не обнаружена.'; + $lang['strnoschemas'] = 'Ðи одной Ñхемы не найдено.'; + $lang['strcreateschema'] = 'Создать Ñхему'; + $lang['strschemaname'] = 'Ð˜Ð¼Ñ Ñхемы'; + $lang['strschemaneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ñхемы.'; + $lang['strschemacreated'] = 'Схема Ñоздана.'; + $lang['strschemacreatedbad'] = 'Создание Ñхемы прервано.'; + $lang['strconfdropschema'] = 'Ð’Ñ‹ уверены, что хотите уничтожить Ñхему "%s"?'; + $lang['strschemadropped'] = 'Схема уничтожена.'; + $lang['strschemadroppedbad'] = 'Уничтожение Ñхемы прервано.'; + $lang['strschemaaltered'] = 'Схема обновлена.'; + $lang['strschemaalteredbad'] = 'Обновление Ñхемы прервано.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Домен'; + $lang['strdomains'] = 'Домены'; + $lang['strshowalldomains'] = 'Показать вÑе домены'; + $lang['strnodomains'] = 'Ðи одного домена не найдено.'; + $lang['strcreatedomain'] = 'Создать домен'; + $lang['strdomaindropped'] = 'Домен удален.'; + $lang['strdomaindroppedbad'] = 'Удаление домена прервано.'; + $lang['strconfdropdomain'] = 'Ð’Ñ‹ уверены, что хотите удалить домен "%s"?'; + $lang['strdomainneedsname'] = 'Вам необходимо указать Ð¸Ð¼Ñ Ð´Ð¾Ð¼ÐµÐ½Ð°.'; + $lang['strdomaincreated'] = 'Домен Ñоздан.'; + $lang['strdomaincreatedbad'] = 'Создание домена прервано.'; + $lang['strdomainaltered'] = 'Домен изменен.'; + $lang['strdomainalteredbad'] = 'Изменение домена прервано.'; + + // Operators + $lang['stroperator'] = 'Оператор'; + $lang['stroperators'] = 'Операторы'; + $lang['strshowalloperators'] = 'Показать вÑе операторы'; + $lang['strnooperator'] = 'Оператор не обнаружен.'; + $lang['strnooperators'] = 'Операторы не обнаружены.'; + $lang['strcreateoperator'] = 'Создать оператор'; + $lang['strleftarg'] = 'Тип левого аргумента'; + $lang['strrightarg'] = 'Тип правого аргумента'; + $lang['strcommutator'] = 'Преобразование'; + $lang['strnegator'] = 'Отрицание'; + $lang['strrestrict'] = 'ОÑлабление'; + $lang['strjoin'] = 'Объединение'; + $lang['strhashes'] = 'Хеширование'; + $lang['strmerges'] = 'СлиÑние'; + $lang['strleftsort'] = 'Сотировка по левому'; + $lang['strrightsort'] = 'Сотировка по правому'; + $lang['strlessthan'] = 'Меньше'; + $lang['strgreaterthan'] = 'Больше'; + $lang['stroperatorneedsname'] = 'Вам необходимо указать название оператора.'; + $lang['stroperatorcreated'] = 'Оператор Ñоздан'; + $lang['stroperatorcreatedbad'] = 'Создание оператора прервано.'; + $lang['strconfdropoperator'] = 'Ð’Ñ‹ уверены, что хотите уничтожить оператор "%s"?'; + $lang['stroperatordropped'] = 'Оператор удален.'; + $lang['stroperatordroppedbad'] = 'Удаление оператора прервано.'; + + // Casts + $lang['strcasts'] = 'Образцы'; + $lang['strnocasts'] = 'Образцов не найдено.'; + $lang['strsourcetype'] = 'Тип иÑточника'; + $lang['strtargettype'] = 'Тип приемника'; + $lang['strimplicit'] = 'ÐеÑвный'; + $lang['strinassignment'] = 'Ð’ назначении'; + $lang['strbinarycompat'] = '(двоично ÑовмеÑтимый)'; + + // Conversions + $lang['strconversions'] = 'Преобразование'; + $lang['strnoconversions'] = 'Преобразований не найдено.'; + $lang['strsourceencoding'] = 'Кодировка иÑточника'; + $lang['strtargetencoding'] = 'Кодировка приемника'; + + // Languages + $lang['strlanguages'] = 'Языки'; + $lang['strnolanguages'] = 'Языков не найдено.'; + $lang['strtrusted'] = 'Проверено'; + + // Info + $lang['strnoinfo'] = 'Ðет доÑтупной информации.'; + $lang['strreferringtables'] = 'СÑылающиеÑÑ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ‹'; + $lang['strparenttables'] = 'РодительÑкие таблицы'; + $lang['strchildtables'] = 'Дочерние таблицы'; + + // Aggregates + $lang['straggregates'] = 'Ðгрегатные выражениÑ'; + $lang['strnoaggregates'] = 'Ðгрегатных выражений не найдено.'; + $lang['stralltypes'] = '(Ð’Ñе типы)'; + + // Operator Classes + $lang['stropclasses'] = 'КлаÑÑÑ‹ операторов'; + $lang['strnoopclasses'] = 'КлаÑÑов операторов не найдено.'; + $lang['straccessmethod'] = 'Метод доÑтупа'; + + // Stats and performance + $lang['strrowperf'] = 'ПредÑтавление запиÑи'; + $lang['strioperf'] = 'ПредÑтавление ввода/вывода'; + $lang['stridxrowperf'] = 'ПредÑтавление индекÑа запиÑи'; + $lang['stridxioperf'] = 'ПредÑтавление индекÑа ввода/вывода'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'ПоÑледовательный'; + $lang['strscan'] = 'Сканировать'; + $lang['strread'] = 'Читать'; + $lang['strfetch'] = 'Извлечь'; + $lang['strheap'] = 'МуÑор'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST индекÑ'; + $lang['strcache'] = 'Кеш'; + $lang['strdisk'] = 'ДиÑк'; + $lang['strrows2'] = 'ЗапиÑи'; + + // Miscellaneous + $lang['strtopbar'] = '%s выполнÑетÑÑ Ð½Ð° %s:%s -- Ð’Ñ‹ зарегиÑтрированы как "%s"'; + $lang['strtimefmt'] = ' j-m-Y g:i'; + $lang['strhelp'] = 'Помощь'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/slovak.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/slovak.php new file mode 100644 index 00000000..51a3f6b3 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/slovak.php @@ -0,0 +1,648 @@ +>'; + $lang['strfailed'] = 'Chyba.'; + $lang['strcreate'] = 'VytvoriÅ¥'; + $lang['strcreated'] = 'Vytvorené'; + $lang['strcomment'] = 'Komentár'; + $lang['strlength'] = 'Dĺžka'; + $lang['strdefault'] = 'Predvolené'; + $lang['stralter'] = 'ZmeniÅ¥'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'ZruÅ¡iÅ¥'; + $lang['strsave'] = 'UložiÅ¥'; + $lang['strreset'] = 'Reset'; + $lang['strinsert'] = 'VložiÅ¥'; + $lang['strselect'] = 'VybraÅ¥'; + $lang['strdelete'] = 'ZmazaÅ¥'; + $lang['strupdate'] = 'AktualizovaÅ¥'; + $lang['strreferences'] = 'Referencie'; + $lang['stryes'] = 'Ãno'; + $lang['strno'] = 'Nie'; + $lang['strtrue'] = 'True'; + $lang['strfalse'] = 'False'; + $lang['stredit'] = 'UpraviÅ¥'; + $lang['strcolumn'] = 'Stĺpec'; + $lang['strcolumns'] = 'Stĺpce'; + $lang['strrows'] = 'riadky'; + $lang['strrowsaff'] = 'riadkov ovplyvnených.'; + $lang['strobjects'] = 'objekt(y)'; + $lang['strback'] = 'Späť'; + $lang['strqueryresults'] = 'Výsledky Dotazu'; + $lang['strshow'] = 'UkázaÅ¥'; + $lang['strempty'] = 'VyprázdniÅ¥'; + $lang['strlanguage'] = 'Jazyk'; + $lang['strencoding'] = 'Kódovanie'; + $lang['strvalue'] = 'Hodnota'; + $lang['strunique'] = 'Unikátny'; + $lang['strprimary'] = 'Primárny'; + $lang['strexport'] = 'ExportovaÅ¥'; + $lang['strimport'] = 'Import'; + $lang['strallowednulls'] = 'Povolený NULL znak'; + $lang['strbackslashn'] = '\N'; + $lang['strnull'] = 'Null'; + $lang['strnull'] = 'NULL (slovo)'; + $lang['stremptystring'] = 'Prázdny reÅ¥azec/pole'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'VyÄistiÅ¥'; + $lang['stranalyze'] = 'AnalyzovaÅ¥'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'Clustered?'; + $lang['strreindex'] = 'Reindex'; + $lang['strrun'] = 'SpustiÅ¥'; + $lang['stradd'] = 'PridaÅ¥'; + $lang['strremove'] = 'ZmazaÅ¥'; + $lang['strevent'] = 'Prípadne'; + $lang['strwhere'] = 'Kde'; + $lang['strinstead'] = 'UrobiÅ¥ Namiesto'; + $lang['strwhen'] = 'Kedy'; + $lang['strformat'] = 'Formát'; + $lang['strdata'] = 'Dáta'; + $lang['strconfirm'] = 'PotvrdiÅ¥'; + $lang['strexpression'] = 'Výraz'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'RozšíriÅ¥'; + $lang['strcollapse'] = 'ZbaliÅ¥'; + $lang['strexplain'] = 'VysvetliÅ¥'; + $lang['strexplainanalyze'] = 'VysvetliÅ¥ Analyze'; + $lang['strfind'] = 'NájsÅ¥'; + $lang['stroptions'] = 'Nastavenia'; + $lang['strrefresh'] = 'ObnoviÅ¥'; + $lang['strdownload'] = 'Download'; + $lang['strdownloadgzipped'] = 'StiahnuÅ¥ skomprimované pomocou gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Viac'; + $lang['strvariables'] = 'Premenné'; + $lang['strprocess'] = 'Proces'; + $lang['strprocesses'] = 'Procesy'; + $lang['strsetting'] = 'Nastavenie'; + $lang['streditsql'] = 'UpraviÅ¥ SQL'; + $lang['strruntime'] = 'Celkový beh: %s ms'; + $lang['strpaginate'] = 'Výsledky stránkovania'; + $lang['struploadscript'] = 'alebo uploadni SQL skript:'; + $lang['strstarttime'] = 'ÄŒas Å¡tartu'; + $lang['strfile'] = 'Súbor'; + $lang['strfileimported'] = 'Súbor importovaný.'; + $lang['strtrycred'] = 'PoužiÅ¥ tieto hodnoty pre vÅ¡etky hodnoty'; +$lang['strexecute'] = 'Execute'; + + // Error handling + $lang['strnoframes'] = 'Táto aplikácia funguje najlapÅ¡ie s prehliadaÄom, ktorý podporuje technológiu frame-ov, no môže byÅ¥ použitý aj takým, ktorý to nepodporuje nasledovaním tohto odkazu:'; + $lang['strnoframeslink'] = 'NepoužívaÅ¥ frame-y'; + $lang['strbadconfig'] = 'Tvoj config.inc.php je zastaralý. Musíš vygenerovaÅ¥ nový zo súboru config.inc.php-dist.'; + $lang['strnotloaded'] = 'Tvoje PHP nie je skompilované s potrebnou podporou databáz.'; + $lang['strpostgresqlversionnotsupported'] = 'Tvoja verzia PostgreSQL nie je podporovaná. Prosím aktualizuj ju na verziu %s alebo vyÅ¡Å¡iu.'; + $lang['strbadschema'] = 'Å pecifikovaná chybná schéma.'; + $lang['strbadencoding'] = 'Nastavenie kódovania v databáze zlyhalo.'; + $lang['strsqlerror'] = 'SQL chyba:'; + $lang['strinstatement'] = 'Vo výraze:'; + $lang['strinvalidparam'] = 'Chybné parametre skriptu.'; + $lang['strnodata'] = 'Nenájdené žiadne záznamy.'; + $lang['strnoobjects'] = 'Nenájdené žiadne objekty.'; + $lang['strrownotunique'] = 'Žiadny unikátny identifikárot pre tento riadok.'; + $lang['strnouploads'] = 'Upload súborov je vypnutý.'; + $lang['strimporterror'] = 'Chyba Import-u.'; + $lang['strimporterror-fileformat'] = 'Chyba importu: Automatické urÄenie formátu súboru zlyhalo.'; + $lang['strimporterrorline'] = 'Chyba Import-u na riadku %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Chyba importu na riadku %s: Riadok nemá správny poÄet stĺpcov.'; + $lang['strimporterror-uploadedfile'] = 'Chyba importu: Súbor nemôže byÅ¥ upload-nutý k serveru'; + $lang['strcannotdumponwindows'] = 'Dump komplexných tabuliek a schém nie je na platforme Windows podporovaný.'; + + // Tables + $lang['strtable'] = 'Tabuľka'; + $lang['strtables'] = 'Tabuľky'; + $lang['strshowalltables'] = 'ZobraziÅ¥ VÅ¡etky Tabuľky'; + $lang['strnotables'] = 'Nenájdené žiadne tabuľky.'; + $lang['strnotable'] = 'Nenájdená žiadna tabuľka.'; + $lang['strcreatetable'] = 'VytvoriÅ¥ tabuľku'; + $lang['strtablename'] = 'Názov tabuľky'; + $lang['strtableneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju tabuľku.'; + $lang['strtableneedsfield'] = 'Musíš Å¡pecifikovaÅ¥ aspoň jedno pole.'; + $lang['strtableneedscols'] = 'Tabuľky vyžadujú vyhovujúci poÄet stĺpcov.'; + $lang['strtablecreated'] = 'Tabuľka vytvorená.'; + $lang['strtablecreatedbad'] = 'Tabuľka nebola vytvorená.'; + $lang['strconfdroptable'] = 'Naozaj chceÅ¡ odstrániÅ¥ tabuľku "%s"?'; + $lang['strtabledropped'] = 'Tabuľka odstránená.'; + $lang['strtabledroppedbad'] = 'Tabuľka nebola odstránená.'; + $lang['strconfemptytable'] = 'Si si istý, že chceÅ¡ vyprázdniÅ¥ tabuľku "%s"?'; + $lang['strtableemptied'] = 'Tabuľka vyprázdnená.'; + $lang['strtableemptiedbad'] = 'Tabuľka nebola vyprázdnená.'; + $lang['strinsertrow'] = 'VložiÅ¥ Riadok'; + $lang['strrowinserted'] = 'Riadok vložený.'; + $lang['strrowinsertedbad'] = 'Riadok nebol vložený.'; + $lang['strrowduplicate'] = 'Vloženie riadku zlyhalo, pokus o duplikátny insert.'; + $lang['streditrow'] = 'UpraviÅ¥ Riadok'; + $lang['strrowupdated'] = 'Riadok upravený.'; + $lang['strrowupdatedbad'] = 'Riadok nebol upravený.'; + $lang['strdeleterow'] = 'ZmazaÅ¥ Riadok'; + $lang['strconfdeleterow'] = 'Si si istý, že chceÅ¡ zmazaÅ¥ tento riadok?'; + $lang['strrowdeleted'] = 'Riadok zmazaný.'; + $lang['strrowdeletedbad'] = 'Riadok nebol zmazaný.'; + $lang['strinsertandrepeat'] = 'VložiÅ¥ & ZopakovaÅ¥'; + $lang['strnumcols'] = 'PoÄet stĺpcov'; + $lang['strcolneedsname'] = 'Musíš zadaÅ¥ názov pre tvoj stĺpec'; + $lang['strselectallfields'] = 'VybraÅ¥ vÅ¡etky polia'; + $lang['strselectneedscol'] = 'Musíš oznaÄiÅ¥ aspoň jeden stĺpec.'; + $lang['strselectunary'] = 'Unárne operátory nemôžu maÅ¥ hodnoty.'; + $lang['straltercolumn'] = 'ZmeniÅ¥ Stĺpec'; + $lang['strcolumnaltered'] = 'Stĺpec zmenený.'; + $lang['strcolumnalteredbad'] = 'Stĺpec nebol zmenený.'; + $lang['strconfdropcolumn'] = 'Naozaj chceÅ¡ zmazaÅ¥ stĺpec "%s" z tabuľky "%s"?'; + $lang['strcolumndropped'] = 'Stĺpec zmenený.'; + $lang['strcolumndroppedbad'] = 'Stĺpec nebol zmazaný.'; + $lang['straddcolumn'] = 'PridaÅ¥ Stĺpec'; + $lang['strcolumnadded'] = 'Stĺpec pridaný.'; + $lang['strcolumnaddedbad'] = 'Stĺpec nebol pridaný.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tabuľka zmenená.'; + $lang['strtablealteredbad'] = 'Tabuľka nebola zmenená.'; + $lang['strdataonly'] = 'Iba Dáta'; + $lang['strstructureonly'] = 'Iba Å truktúra'; + $lang['strstructureanddata'] = 'Å truktúra a Dáta'; + $lang['strtabbed'] = 'Tabbed'; + $lang['strauto'] = 'Auto'; + $lang['strconfvacuumtable'] = 'Naozaj chceÅ¡ vyÄistiÅ¥ "%s"?'; + $lang['strestimatedrowcount'] = 'Odhadovaný poÄet riadkov'; + + // Users + $lang['struser'] = 'Používateľ'; + $lang['strusers'] = 'Používatelia'; + $lang['strusername'] = 'Meno používateľa'; + $lang['strpassword'] = 'Heslo'; + $lang['strsuper'] = 'Superuser?'; + $lang['strcreatedb'] = 'Vytváranie DB?'; + $lang['strexpires'] = 'Expiruje'; + $lang['strsessiondefaults'] = 'Sessions defaults'; //s cim to tak suvis??:) + $lang['strnousers'] = 'Nenájdení žiadni používatelia.'; + $lang['struserupdated'] = 'Požívatelia zmenení.'; + $lang['struserupdatedbad'] = 'Použivatelia neboli zmenení.'; + $lang['strshowallusers'] = 'ZobraziÅ¥ VÅ¡etkých Používateľov'; + $lang['strcreateuser'] = 'VytvoriÅ¥ používateľa'; + $lang['struserneedsname'] = 'Musíš zadaÅ¥ meno pre svojho používateľa.'; + $lang['strusercreated'] = 'Používateľ vytvorený.'; + $lang['strusercreatedbad'] = 'Používateľ nebol vytvorený.'; + $lang['strconfdropuser'] = 'Naozaj chceÅ¡ zmazaÅ¥ používateľa "%s"?'; + $lang['struserdropped'] = 'Používateľ zmazaný.'; + $lang['struserdroppedbad'] = 'Používateľ nebol zmazaný.'; + + // Groups + $lang['straccount'] = 'Konto'; + $lang['strchangepassword'] = 'ZmeniÅ¥ Heslo'; + $lang['strpasswordchanged'] = 'Heslo zmenené.'; + $lang['strpasswordchangedbad'] = 'Heslo NEBOLO zmenené.'; + $lang['strpasswordshort'] = 'Heslo je príliÅ¡ krátke.'; + $lang['strpasswordconfirm'] = 'Heslo sa nezhoduje so zadaným overovacím heslom.'; + + // Groups + $lang['strgroup'] = 'Skupina'; + $lang['strgroups'] = 'Skupiny'; + $lang['strnogroup'] = 'Skupina nenájdená.'; + $lang['strnogroups'] = 'Žiadne skupiny nenájdené.'; + $lang['strcreategroup'] = 'VytvoriÅ¥ Skupinu'; + $lang['strshowallgroups'] = 'ZobraziÅ¥ VÅ¡etky Skupiny'; + $lang['strgroupneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju skupinu.'; + $lang['strgroupcreated'] = 'Skupina Vytvorená.'; + $lang['strgroupcreatedbad'] = 'Skupina nebola vytvorená.'; + $lang['strconfdropgroup'] = 'Naozaj chceÅ¡ zmazaÅ¥ skupinu "%s"?'; + $lang['strgroupdropped'] = 'Skupina zmazaná.'; + $lang['strgroupdroppedbad'] = 'Skupina nebola zmazaná.'; + $lang['strmembers'] = 'ÄŒlenovia'; + $lang['straddmember'] = 'PridaÅ¥ Älena'; + $lang['strmemberadded'] = 'ÄŒlen pridaný.'; + $lang['strmemberaddedbad'] = 'ÄŒlen nebol pridaný.'; + $lang['strdropmember'] = 'ZmazaÅ¥ Älena'; + $lang['strconfdropmember'] = 'Naozaj chceÅ¡ zmazaÅ¥ cľena "%s" zo skupiny "%s"?'; + $lang['strmemberdropped'] = 'ÄŒlen zmazaný.'; + $lang['strmemberdroppedbad'] = 'ÄŒlen nebol zmazaný.'; + + // Privilges + $lang['strprivilege'] = 'Privilégiá'; + $lang['strprivileges'] = 'Privilégiá'; + $lang['strnoprivileges'] = 'Tento objekt nemá privilégiá.'; + $lang['strgrant'] = 'PovoliÅ¥'; + $lang['strrevoke'] = 'OdobraÅ¥'; + $lang['strgranted'] = 'Privilégiá pridané.'; + $lang['strgrantfailed'] = 'Privilégiá neboli pridané.'; + $lang['strgrantbad'] = 'Musíš Å¡pecifikovat aspoň jedného užívateľa/skupinu a aspoň jedno privilégium.'; + $lang['strgrantor'] = 'Prideľovateľ'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Databáza'; + $lang['strdatabases'] = 'Databázy'; + $lang['strshowalldatabases'] = 'ZobraziÅ¥ vÅ¡etky databázy'; + $lang['strnodatabase'] = 'Nenájdená žiadna Databáza.'; + $lang['strnodatabases'] = 'Nenájdené žiadne Databázy.'; + $lang['strcreatedatabase'] = 'VytvoriÅ¥ databázu'; + $lang['strdatabasename'] = 'Názov databázy'; + $lang['strdatabaseneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju databázu.'; + $lang['strdatabasecreated'] = 'Databáza vytvorená.'; + $lang['strdatabasecreatedbad'] = 'Databáza nebola vytvorená.'; + $lang['strconfdropdatabase'] = 'Naozaj chceÅ¡ zmazaÅ¥ databázu "%s"?'; + $lang['strdatabasedropped'] = 'Databáze zmazaná.'; + $lang['strdatabasedroppedbad'] = 'Databáza nebola zmazaná.'; + $lang['strentersql'] = 'VložiÅ¥ SQL dotaz:'; + $lang['strsqlexecuted'] = 'SQL dotaz vykonaný.'; + $lang['strvacuumgood'] = 'VyÄistenie kompletné.'; + $lang['strvacuumbad'] = 'VyÄistnie zlyhalo.'; + $lang['stranalyzegood'] = 'Analyzovanie kompletné.'; + $lang['stranalyzebad'] = 'Analyzovanie zlyhalo.'; + $lang['strreindexgood'] = 'Reindex hotový.'; + $lang['strreindexbad'] = 'Reindex zlyhal.'; + $lang['strfull'] = 'Full'; //todo - konzultovat!! + $lang['strfreeze'] = 'Freeze'; //deto + $lang['strforce'] = 'Force'; // -||- + $lang['strsignalsent'] = 'Signál odoslaný.'; + $lang['strsignalsentbad'] = 'Odoslanie signálu zlyhalo.'; + $lang['strallobjects'] = 'VÅ¡etky objekty'; + $lang['strdatabasealtered'] = 'Databáza zmenená.'; + $lang['strdatabasealteredbad'] = 'Databáza nebola zmenená.'; + + // Views + $lang['strview'] = 'Náhľad'; + $lang['strviews'] = 'Náhľady'; + $lang['strshowallviews'] = 'ZobraziÅ¥ VÅ¡etky Náhľady'; + $lang['strnoview'] = 'Nenájdený žiadny náhľad.'; + $lang['strnoviews'] = 'Nenájdené žiadne náhľady.'; + $lang['strcreateview'] = 'VytvoriÅ¥ Náhľad'; + $lang['strviewname'] = 'Názov náhľadu'; + $lang['strviewneedsname'] = 'Musíš zadaÅ¥ názov pre tvoj náhľad.'; + $lang['strviewneedsdef'] = 'Musíš zadaÅ¥ definíciu pre tvoj náhľad.'; + $lang['strviewneedsfields'] = 'Mušíš zvoliÅ¥ stĺpce, ktoré chceÅ¡ maÅ¥ vo svojom náhľade.'; + $lang['strviewcreated'] = 'Náhľad vytvorený.'; + $lang['strviewcreatedbad'] = 'Náhľad nebol vytvorený.'; + $lang['strconfdropview'] = 'Naozaj chceÅ¡ zmazaÅ¥ náhľad "%s"?'; + $lang['strviewdropped'] = 'Náhľad zmazaný.'; + $lang['strviewdroppedbad'] = 'Náhľad nebol zmazaný.'; + $lang['strviewupdated'] = 'Náhľad upravený.'; + $lang['strviewupdatedbad'] = 'Náhľad nebol upravený.'; + $lang['strviewlink'] = 'Linkujúce KľúÄe'; + $lang['strviewconditions'] = 'Doplňujúce Podmienky'; + $lang['strcreateviewwiz'] = 'VytvoriÅ¥ náhľad cez \"pomocníka\"'; + + // Sequences + $lang['strsequence'] = 'Sekvencia'; + $lang['strsequences'] = 'Sekvencie'; + $lang['strshowallsequences'] = 'ZobraziÅ¥ VÅ¡etky Sekvencie'; + $lang['strnosequence'] = 'Nenájdená žiadna sekvencia.'; + $lang['strnosequences'] = 'nenájdené žiadne sekvencie.'; + $lang['strcreatesequence'] = 'VytvoriÅ¥ Sekvenciu'; + $lang['strlastvalue'] = 'Posledná Hodnota'; + $lang['strincrementby'] = 'InkrementovaÅ¥ od'; + $lang['strstartvalue'] = 'Start Hodnota'; + $lang['strmaxvalue'] = 'Max Hodnota'; + $lang['strminvalue'] = 'Min Hodnota'; + $lang['strcachevalue'] = 'Cache Hodnota'; + $lang['strlogcount'] = 'Log SúÄet'; + $lang['striscycled'] = 'Je Cycled?'; + $lang['strsequenceneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju sekvenciu.'; + $lang['strsequencecreated'] = 'Sekvencia vytvorená.'; + $lang['strsequencecreatedbad'] = 'Sekvencia nebola vytvorená.'; + $lang['strconfdropsequence'] = 'Naozaj chceÅ¡ zmazaÅ¥ sekvenciu "%s"?'; + $lang['strsequencedropped'] = 'Sekvencia zmazaná.'; + $lang['strsequencedroppedbad'] = 'Sekvencia nebola zmazaná.'; + $lang['strsequencereset'] = 'Sekvencia resetovaná.'; + $lang['strsequenceresetbad'] = 'Sekvencia nebola resetovaná.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indexy'; + $lang['strindexname'] = 'Názov Indexu'; + $lang['strshowallindexes'] = 'ZobraziÅ¥ VÅ¡etky Indexy'; + $lang['strnoindex'] = 'Nenájdený žiadny index.'; + $lang['strnoindexes'] = 'Nenájdené žiadne indexy.'; + $lang['strcreateindex'] = 'VytvoriÅ¥ Index'; + $lang['strtabname'] = 'Tab Meno'; + $lang['strcolumnname'] = 'Názov stÃ¥pca'; + $lang['strindexneedsname'] = 'Musíš zadaÅ¥ názov pre tvoj index'; + $lang['strindexneedscols'] = 'Index vyžaduje vyhovujúci poÄet stĺpcov.'; + $lang['strindexcreated'] = 'Index vytvorený'; + $lang['strindexcreatedbad'] = 'Index nebol vytvorený.'; + $lang['strconfdropindex'] = 'Naozaj chceÅ¡ zmazaÅ¥ index "%s"?'; + $lang['strindexdropped'] = 'Index zmazaný.'; + $lang['strindexdroppedbad'] = 'Index nebol zmazaný.'; + $lang['strkeyname'] = 'Názov KľúÄu'; + $lang['struniquekey'] = 'Unikátny KľúÄ'; + $lang['strprimarykey'] = 'Primárny KľúÄ'; + $lang['strindextype'] = 'Typ indexu'; + $lang['strtablecolumnlist'] = 'Stĺpce v Tabuľke'; + $lang['strindexcolumnlist'] = 'Stľpce v Indexe'; + $lang['strconfcluster'] = 'Naozaj chceÅ¡ vytvoriÅ¥ cluster "%s"?'; + $lang['strclusteredgood'] = 'Cluster hotový.'; + $lang['strclusteredbad'] = 'Cluster nebol vytvorený.'; +$lang['strcluster'] = 'Cluster'; + + // Rules + $lang['strrules'] = 'Pravidlá'; + $lang['strrule'] = 'Pravidlo'; + $lang['strshowallrules'] = 'ZobraziÅ¥ VÅ¡etky Pravidlá'; + $lang['strnorule'] = 'Nenájdené žiadne pravidlo.'; + $lang['strnorules'] = 'Nenájdené žiadne pravidlá.'; + $lang['strcreaterule'] = 'VytvoriÅ¥ pravidlo'; + $lang['strrulename'] = 'Názov pravidla'; + $lang['strruleneedsname'] = 'Musíš zadaÅ¥ názov pre tvoje pravidlo.'; + $lang['strrulecreated'] = 'Pravidlo vytvorené.'; + $lang['strrulecreatedbad'] = 'Pravidlo nebolo vytvorené.'; + $lang['strconfdroprule'] = 'Naozaj chceÅ¡ zmazaÅ¥ pravidlo "%s" na "%s"?'; + $lang['strruledropped'] = 'Pravidlo zmazané.'; + $lang['strruledroppedbad'] = 'Pravidlo nebolo zmazané.'; + + // Constraints + $lang['strconstraint'] = 'Obmedzenie'; + $lang['strconstraints'] = 'Obmedzenia'; + $lang['strshowallconstraints'] = 'ZobraziÅ¥ VÅ¡etky Obmedzenia'; + $lang['strnoconstraints'] = 'Nenájdené žiadne obmedzenie.'; + $lang['strcreateconstraint'] = 'VytvoriÅ¥ Obmedzenie'; + $lang['strconstraintcreated'] = 'Obmedzenie vytvorené.'; + $lang['strconstraintcreatedbad'] = 'Obmedzenie nebolo vytvorené.'; + $lang['strconfdropconstraint'] = 'Naozaj chceÅ¡ zmazaÅ¥ obmedzenie "%s" na "%s"?'; + $lang['strconstraintdropped'] = 'Obmedzenie zmazané.'; + $lang['strconstraintdroppedbad'] = 'Obmedzenie nebolo zmazané.'; + $lang['straddcheck'] = 'PridaÅ¥ Overovanie'; + $lang['strcheckneedsdefinition'] = 'Overovanie Obmedzenia vyžaduje jeho definovanie.'; + $lang['strcheckadded'] = 'Overovanie obmedzenia pridané.'; + $lang['strcheckaddedbad'] = 'Overovanie obmedzenia nebolo pridané.'; + $lang['straddpk'] = 'PridaÅ¥ Primárny KľúÄ'; + $lang['strpkneedscols'] = 'Primárny kÄ¾ÃºÄ vyžaduje aspoň jeden stĺpec.'; + $lang['strpkadded'] = 'Primárny kÄ¾ÃºÄ pridaný.'; + $lang['strpkaddedbad'] = 'Primárny kÄ¾ÃºÄ nebol pridaný.'; + $lang['stradduniq'] = 'PridaÅ¥ Unikátny KľúÄ'; + $lang['struniqneedscols'] = 'Unikátny kÄ¾ÃºÄ vyžaduje aspoň jeden stĺpec.'; + $lang['struniqadded'] = 'Unikátny kÄ¾ÃºÄ pridaný.'; + $lang['struniqaddedbad'] = 'Unikátny kÄ¾ÃºÄ nebol pridaný.'; + $lang['straddfk'] = 'PridaÅ¥ Cudzí KľúÄ'; + $lang['strfkneedscols'] = 'Cudzí kÄ¾ÃºÄ vyžaduje aspoň jeden stĺpec.'; + $lang['strfkneedstarget'] = 'Cudzí kÄ¾ÃºÄ vyžaduje cieľovú tabuľku.'; + $lang['strfkadded'] = 'Cudzí kÄ¾ÃºÄ pridaný.'; + $lang['strfkaddedbad'] = 'Cudzí kÄ¾ÃºÄ nebol pridaný.'; + $lang['strfktarget'] = 'Cieľová tabuľka'; + $lang['strfkcolumnlist'] = 'Stľpce v kľúÄi'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'Funkcia'; + $lang['strfunctions'] = 'Funkcie'; + $lang['strshowallfunctions'] = 'ZobraziÅ¥ vÅ etky funkcie'; + $lang['strnofunction'] = 'Nenájdená žiadna funkcia.'; + $lang['strnofunctions'] = 'Nenájdené žiadne funkcie.'; + $lang['strcreateplfunction'] = 'VytvoriÅ¥ SQL/PL funkciu'; + $lang['strcreateinternalfunction'] = 'VytvoriÅ¥ internú funkciu'; + $lang['strcreatecfunction'] = 'VytvoriÅ¥ C funkciu'; + $lang['strfunctionname'] = 'Názov funkcie'; + $lang['strreturns'] = 'Vracia'; + $lang['strarguments'] = 'Argumenty'; + $lang['strproglanguage'] = 'Jazyk'; + $lang['strfunctionneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju funkciu.'; + $lang['strfunctionneedsdef'] = 'Musíš zadaÅ¥ definíciu pre tvoju funkciu.'; + $lang['strfunctioncreated'] = 'Funkcia vytvorená.'; + $lang['strfunctioncreatedbad'] = 'Funkcia nebola vytvorená.'; + $lang['strconfdropfunction'] = 'Si si istý, že chceÅ¡ zmazaÅ¥ funkciu "%s"?'; + $lang['strfunctiondropped'] = 'Funkcia zmazaná.'; + $lang['strfunctiondroppedbad'] = 'Funkcia nebola zmazaná.'; + $lang['strfunctionupdated'] = 'Funkcia upravená.'; + $lang['strfunctionupdatedbad'] = 'Funkcia nebola upravená.'; + $lang['strobjectfile'] = 'Objektový súbor'; + $lang['strlinksymbol'] = 'Link symbol'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; //su to medzipravidla ?? po cesky spouste.. + $lang['strtriggers'] = 'Trigger-y'; + $lang['strshowalltriggers'] = 'ZobraziÅ¥ VÅ¡etky Trigger-y'; + $lang['strnotrigger'] = 'Nenájdený žiadny Trigger.'; + $lang['strnotriggers'] = 'Nenájdené žiadne Trigger-y.'; + $lang['strcreatetrigger'] = 'VytvoriÅ¥ Trigger'; + $lang['strtriggerneedsname'] = 'Musíš zadaÅ¥ názov pre tvoj Trigger.'; + $lang['strtriggerneedsfunc'] = 'Musíš zadaÅ¥ funkciu pre tvoj Trigger.'; + $lang['strtriggercreated'] = 'Trigger vytvorený.'; + $lang['strtriggercreatedbad'] = 'Trigger nebol vytvorený.'; + $lang['strconfdroptrigger'] = 'Naozaj chceÅ¡ zmazaÅ¥ Trigger "%s" na "%s"?'; + $lang['strtriggerdropped'] = 'Trigger zmazaný.'; + $lang['strtriggerdroppedbad'] = 'Trigger nebol zmazaný.'; + $lang['strtriggeraltered'] = 'Trigger zmenený.'; + $lang['strtriggeralteredbad'] = 'Trigger nebol zmenený.'; + $lang['strforeach'] = 'Pre každých'; + + // Types + $lang['strtype'] = 'Typ'; + $lang['strtypes'] = 'Typy'; + $lang['strshowalltypes'] = 'ZobraziÅ¥ VÅ¡etky typy'; + $lang['strnotype'] = 'Nenájdený žiadny typ.'; + $lang['strnotypes'] = 'Nenájdené žiadne typy.'; + $lang['strcreatetype'] = 'VytvoriÅ¥ Typ'; + $lang['strcreatecomptype'] = 'VytvoriÅ¥ kompozitný typ'; + $lang['strtypeneedsfield'] = 'Musíš vybraÅ¥ aspoň jedno pole.'; + $lang['strtypeneedscols'] = 'Musíš zadaÅ¥ správny poÄet polí.'; + $lang['strtypename'] = 'Názov typu'; + $lang['strinputfn'] = 'Vstupná funkcia'; + $lang['stroutputfn'] = 'Výstupná funkcia'; + $lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'Alignment'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Delimiter'; + $lang['strstorage'] = 'Storage'; + $lang['strfield'] = 'Pole'; + $lang['strnumfields'] = 'PoÄet polí'; + $lang['strtypeneedsname'] = 'Musíš zadaÅ¥ názov pre tvoj typ.'; + $lang['strtypeneedslen'] = 'Musíš zadaÅ¥ dĺžku pre tvoj typ.'; + $lang['strtypecreated'] = 'Typ Vytvorený'; + $lang['strtypecreatedbad'] = 'Typ nebol vytvorený.'; + $lang['strconfdroptype'] = 'Naozaj chceÅ¡ zmazaÅ¥ typ "%s"?'; + $lang['strtypedropped'] = 'Typ zmazaný.'; + $lang['strtypedroppedbad'] = 'Typ nebol zmazaný.'; + $lang['strflavor'] = 'Flavor'; //todo + $lang['strbasetype'] = 'Základný'; + $lang['strcompositetype'] = 'Kompozitný'; + $lang['strpseudotype'] = 'Pseudo'; + + // Schemas + $lang['strschema'] = 'Schéma'; + $lang['strschemas'] = 'Schémy'; + $lang['strshowallschemas'] = 'ZobraziÅ¥ VÅ¡etky Schémy'; + $lang['strnoschema'] = 'Nenájdená žiadna schéma.'; + $lang['strnoschemas'] = 'Nenájdené žiadne schémy.'; + $lang['strcreateschema'] = 'VytvoriÅ¥ Schému'; + $lang['strschemaname'] = 'Názov Schémy'; + $lang['strschemaneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju schému.'; + $lang['strschemacreated'] = 'Schéma vytvorená'; + $lang['strschemacreatedbad'] = 'Schéma nebola vytvorená.'; + $lang['strconfdropschema'] = 'Naozaj chceÅ¡ zmazaÅ¥ schému "%s"?'; + $lang['strschemadropped'] = 'Schéma zmazaná.'; + $lang['strschemadroppedbad'] = 'Schéma nebola zmazaná.'; + $lang['strschemaaltered'] = 'Schéma zmenená.'; + $lang['strschemaalteredbad'] = 'Schéma nebola zmenená.'; + $lang['strsearchpath'] = 'Cesta k nájdeniu Schémy'; + + // Reports + + //Domains + $lang['strdomain'] = 'Doména'; + $lang['strdomains'] = 'Domény'; + $lang['strshowalldomains'] = 'ZobraziÅ¥ VÅ¡etky Domény'; + $lang['strnodomains'] = 'Nenájdené žiadne domény.'; + $lang['strcreatedomain'] = 'VytvoriÅ¥ doménu'; + $lang['strdomaindropped'] = 'Doména zmazaná.'; + $lang['strdomaindroppedbad'] = 'Doména nebola zmazaná.'; + $lang['strconfdropdomain'] = 'Naozaj chceÅ¡ zmazaÅ¥ doménu "%s"?'; + $lang['strdomainneedsname'] = 'Musíš zadaÅ¥ názov pre tvoju doménu.'; + $lang['strdomaincreated'] = 'Doména vytvorená.'; + $lang['strdomaincreatedbad'] = 'Doména nebola vytvorená.'; + $lang['strdomainaltered'] = 'Doména zmenená.'; + $lang['strdomainalteredbad'] = 'Doména nebola zmenená.'; + + //Operators + $lang['stroperator'] = 'Operátor'; + $lang['stroperators'] = 'Operátory'; + $lang['strshowalloperators'] = 'ZobraziÅ¥ VÅ¡etky Operátory'; + $lang['strnooperator'] = 'Nenájdený žiadny operátor.'; + $lang['strnooperators'] = 'Nenájdené žiadne operátory.'; + $lang['strcreateoperator'] = 'VytvoriÅ¥ Operátor'; + $lang['strleftarg'] = 'Ľavý Arg Typ'; + $lang['strrightarg'] = 'Pravý Arg Typ'; + $lang['strcommutator'] = 'Komutátor'; + $lang['strnegator'] = 'Negátor'; + $lang['strrestrict'] = 'ObmedziÅ¥'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Ľavý sort'; + $lang['strrightsort'] = 'Pravý sort'; + $lang['strlessthan'] = 'Menej ako'; + $lang['strgreaterthan'] = 'Viac ako'; + $lang['stroperatorneedsname'] = 'Musíš zadaÅ¥ názov pre tvoj operátor.'; + $lang['stroperatorcreated'] = 'Operátor vytvorený'; + $lang['stroperatorcreatedbad'] = 'Operátor nebol vytvorený.'; + $lang['strconfdropoperator'] = 'Naozaj chceÅ¡ zmazaÅ¥ operátor "%s"?'; + $lang['stroperatordropped'] = 'Operátor zmazaný.'; + $lang['stroperatordroppedbad'] = 'Operátor nebol zmazaný.'; + + //Casts + $lang['strcasts'] = 'Cast-y'; + $lang['strnocasts'] = 'Nenájdené žiadne Cast-y.'; + $lang['strsourcetype'] = 'Zdrojový typ'; + $lang['strtargettype'] = 'Cieľový typ'; + $lang['strimplicit'] = 'Implicitný'; + $lang['strinassignment'] = 'V priradení'; + $lang['strbinarycompat'] = '(Binárne identické)'; + + // Conversions + $lang['strconversions'] = 'Konverzie'; + $lang['strnoconversions'] = 'Nenájdené žiadne konverzie.'; + $lang['strsourceencoding'] = 'Zdojové kódovanie'; + $lang['strtargetencoding'] = 'Cieľové kódovanie'; + + // Languages + $lang['strlanguages'] = 'Jazyky'; + $lang['strnolanguages'] = 'Nenájdené žiadne jazyky.'; + $lang['strtrusted'] = 'Trusted'; + + // Info + $lang['strnoinfo'] = 'Informácie nedostupné.'; + $lang['strreferringtables'] = 'Referujúce tabuľky'; + $lang['strparenttables'] = 'RodiÄovské tabuľky'; + $lang['strchildtables'] = 'Dcérske tabuľky'; + + // Aggregates + $lang['straggregates'] = 'Agregáty'; + $lang['strnoaggregates'] = 'Nenájdené žiadne agregáty.'; + $lang['stralltypes'] = '(VÅ¡etky typy)'; + + // Operator Classes + $lang['stropclasses'] = 'Op Triedy'; + $lang['strnoopclasses'] = 'Nenájdené žiadne op. triedy.'; + $lang['straccessmethod'] = 'Prístupové metódy'; + + // Stats and performance + $lang['strrowperf'] = 'VýkonnosÅ¥ Riadku'; //to znie dost tupo.. + $lang['strioperf'] = 'I/O Výkon'; + $lang['stridxrowperf'] = 'VýkonnosÅ¥ Indexovania Riadkov'; + $lang['stridxioperf'] = 'Index I/O Výkon'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'SekvenÄný'; + $lang['strscan'] = 'Scan'; //co s tymto tu??? + $lang['strread'] = 'NaÄítaÅ¥'; + $lang['strfetch'] = 'ZískaÅ¥'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Riadkov'; + + // Tablespaces + $lang['strtablespace'] = 'Priestor pre tabuľku'; + $lang['strtablespaces'] = 'Priestory tabuliek'; + $lang['strshowalltablespaces'] = 'ZobraziÅ¥ vÅ¡etky priestory pre tabuľky'; + $lang['strnotablespaces'] = 'Nenájdené žiadne priestory tabuliek.'; + $lang['strcreatetablespace'] = 'VytvoriÅ¥ priestor pre tabuľku'; + $lang['strlocation'] = 'Umiestnenie'; + $lang['strtablespaceneedsname'] = 'Musíš zadaÅ¥ názov priestoru tabuľky.'; + $lang['strtablespaceneedsloc'] = 'Musíš zadaÅ¥ adresár, vktorom sa má vytvoriÅ¥ priestor pre tabuľku.'; + $lang['strtablespacecreated'] = 'Priestor pre tabuľku bol vytvorený.'; + $lang['strtablespacecreatedbad'] = 'Vytvorenie priestoru pre tabuľku zlyhalo.'; + $lang['strconfdroptablespace'] = 'Naozaj chceÅ¡ odstrániÅ¥ priestor tabuľky "%s"?'; + $lang['strtablespacedropped'] = 'Priestor pre tabuľku bol odstránený.'; + $lang['strtablespacedroppedbad'] = 'Odstránenie priestoru zlyhalo.'; + $lang['strtablespacealtered'] = 'Priestor tabuľky zmenený.'; + $lang['strtablespacealteredbad'] = 'Zmenenie priestoru tabuľky zlyhalo.'; + + + // Miscellaneous + $lang['strtopbar'] = '%s beží na %s:%s -- si prihlásený ako "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Pomoc'; + $lang['strhelpicon'] = '?'; + $lang['strlogintitle'] = 'Prihlasujem do %s'; + $lang['strlogoutmsg'] = 'Odhlásený z %s'; + $lang['strloading'] = 'Spracuvávam...'; + $lang['strerrorloading'] = 'Chyba spracovania'; + $lang['strclicktoreload'] = 'Klikni pre obnovenie'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/spanish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/spanish.php new file mode 100644 index 00000000..e4dcb5af --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/spanish.php @@ -0,0 +1,905 @@ +'; + $lang['strfirst'] = '<< Principio'; + $lang['strlast'] = 'Fin >>'; + $lang['strfailed'] = 'Falló'; + $lang['strcreate'] = 'Crear'; + $lang['strcreated'] = 'Creado'; + $lang['strcomment'] = 'Comentario'; + $lang['strlength'] = 'Longitud'; + $lang['strdefault'] = 'Predeterminado'; + $lang['stralter'] = 'Modificar'; + $lang['strok'] = 'Aceptar'; + $lang['strcancel'] = 'Cancelar'; + $lang['strkill'] = 'Terminar'; + $lang['strac'] = 'Activar AutoCompletado'; + $lang['strsave'] = 'Guardar'; + $lang['strreset'] = 'Reestablecer'; + $lang['strrestart'] = 'Reiniciar'; + $lang['strinsert'] = 'Insertar'; + $lang['strselect'] = 'Seleccionar'; + $lang['strdelete'] = 'Eliminar'; + $lang['strupdate'] = 'Actualizar'; + $lang['strreferences'] = 'Referencia'; + $lang['stryes'] = 'Si'; + $lang['strno'] = 'No'; + $lang['strtrue'] = 'VERDADERO'; + $lang['strfalse'] = 'FALSO'; + $lang['stredit'] = 'Editar'; + $lang['strcolumn'] = 'Columna'; + $lang['strcolumns'] = 'Columnas'; + $lang['strrows'] = 'fila(s)'; + $lang['strrowsaff'] = 'fila(s) afectadas.'; + $lang['strobjects'] = 'objeto(s)'; + $lang['strback'] = 'Atrás'; + $lang['strqueryresults'] = 'Resultado de la consulta'; + $lang['strshow'] = 'Mostrar'; + $lang['strempty'] = 'Vaciar'; + $lang['strlanguage'] = 'Idioma'; + $lang['strencoding'] = 'Codificación'; + $lang['strvalue'] = 'Valor'; + $lang['strunique'] = 'Único'; + $lang['strprimary'] = 'Primaria'; + $lang['strexport'] = 'Exportar'; + $lang['strimport'] = 'Importar'; + $lang['strallowednulls'] = 'Permitir valores nulos'; + $lang['strbackslashn'] = '\N'; + $lang['stremptystring'] = 'Cadena o campo vacio'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Limpiar'; + $lang['stranalyze'] = 'Analizar'; + $lang['strclusterindex'] = 'Clúster'; + $lang['strclustered'] = '¿En Clúster?'; + $lang['strreindex'] = 'Actualizar índices'; + $lang['strexecute'] = 'Ejecutar'; + $lang['stradd'] = 'Agregar'; + $lang['strevent'] = 'Evento'; + $lang['strwhere'] = 'Dónde'; + $lang['strinstead'] = 'Hacer en su lugar'; + $lang['strwhen'] = 'Cuándo'; + $lang['strformat'] = 'Formato'; + $lang['strdata'] = 'Dato'; + $lang['strconfirm'] = 'Confirmar'; + $lang['strexpression'] = 'Expresión'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'Expandir'; + $lang['strcollapse'] = 'Contraer'; + $lang['strfind'] = 'Buscar'; + $lang['stroptions'] = 'Opciones'; + $lang['strrefresh'] = 'Refrescar'; + $lang['strdownload'] = 'Descargar'; + $lang['strdownloadgzipped'] = 'Descargar comprimido con gzip'; + $lang['strinfo'] = 'Información'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Avanzado'; + $lang['strvariables'] = 'Variables'; + $lang['strprocess'] = 'Proceso'; + $lang['strprocesses'] = 'Procesos'; + $lang['strblocked'] = 'Bloqueados'; + $lang['strsetting'] = 'Configuración'; + $lang['streditsql'] = 'Editar SQL'; + $lang['strruntime'] = 'Tiempo total de ejecución: %s ms'; + $lang['strpaginate'] = 'Paginar resultados'; + $lang['struploadscript'] = 'o subir un script SQL:'; + $lang['strstarttime'] = 'Hora de comienzo'; + $lang['strfile'] = 'Archivo'; + $lang['strfileimported'] = 'Archivo importado.'; + $lang['strtrycred'] = 'Usar estas crendeciales para todos los servidores'; + $lang['strconfdropcred'] = 'Por razones de seguridad, al desconectar se destruirá tu información compartida. ¿Estás seguro que desea desconectarse?'; + $lang['stractionsonmultiplelines'] = 'Acciones en múltiples líneas'; + $lang['strselectall'] = 'Seleccionar todos'; + $lang['strunselectall'] = 'Seleccionar ninguno'; + $lang['strlocale'] = 'Localización'; + $lang['strcollation'] = 'Colación'; + $lang['strctype'] = 'Tipo de caracter'; + $lang['strdefaultvalues'] = 'Valores por defecto'; + $lang['strnewvalues'] = 'Nuevos valores'; + $lang['strstart'] = 'Iniciar'; + $lang['strstop'] = 'Detener'; + $lang['strgotoppage'] = 'subir al inicio'; + $lang['strtheme'] = 'Tema'; + $lang['strcluster'] = 'Clúster'; + + // Admin + $lang['stradminondatabase'] = 'Las siguientes tareas administrativas aplican a toda la base de datos %s.'; + $lang['stradminontable'] = 'Las siguientes tareas administrativas aplican a la tabla %s.'; + + // User-supplied SQL history + $lang['strhistory'] = 'Historial'; + $lang['strnohistory'] = 'Sin historial.'; + $lang['strclearhistory'] = 'Borrar historial'; + $lang['strdelhistory'] = 'Borrar del historial'; + $lang['strconfdelhistory'] = '¿Desea borrar esta solicitud del historial?'; + $lang['strconfclearhistory'] = '¿Desea borrar el historial?'; + $lang['strnodatabaseselected'] = 'Por favor, seleccione una base de datos.'; + + // Database sizes + $lang['strnoaccess'] = 'Sin acceso'; + $lang['strsize'] = 'Tamaño'; + $lang['strbytes'] = 'bytes'; + $lang['strkb'] = 'kB'; + $lang['strmb'] = 'MB'; + $lang['strgb'] = 'GB'; + $lang['strtb'] = 'TB'; + + // Error handling + $lang['strnoframes'] = 'Esta aplicación funciona mejor con un navegador con soporte para marcos, pero puede usarse sin marcos siguiendo el link de abajo.'; + $lang['strnoframeslink'] = 'Usar sin marcos'; + $lang['strbadconfig'] = 'Su archivo config.inc.php está desactualizado. Deberá regenerarlo a partir del nuevo archivo config.inc.php-dist.'; + $lang['strnotloaded'] = 'Su instalación de PHP no tiene el soporte correcto para PostgreSQL. Deberá recompilar PHP usando la opción --with-pgsql en el configure.'; + $lang['strpostgresqlversionnotsupported'] = 'Su versión de PostgreSQL no está soportada. Por favor actualice a la versión %s o mas reciente.'; + $lang['strbadschema'] = 'El esquema especificado es inválido.'; + $lang['strbadencoding'] = 'No se pudo configurar la codificación del cliente en la base de datos.'; + $lang['strsqlerror'] = 'Error de SQL:'; + $lang['strinstatement'] = 'En la setencia:'; + $lang['strinvalidparam'] = 'Parámetros inválidos del script.'; + $lang['strnodata'] = 'No se encontraron filas.'; + $lang['strnoobjects'] = 'No se encontraron objetos.'; + $lang['strrownotunique'] = 'No existe un identificador único para este registro.'; + $lang['strnouploads'] = 'Está deshabilitada la subida de archivos.'; + $lang['strimporterror'] = 'Error de importación.'; + $lang['strimporterror-fileformat'] = 'Error de importacion: Falló la detección del formato del archivo.'; + $lang['strimporterrorline'] = 'Error de importación en la línea %s.'; + $lang['strimporterrorline-badcolumnnum'] = 'Error de importación en la línea %s: La línea no posee un número incorrecto de columnas.'; + $lang['strimporterror-uploadedfile'] = 'Error de importación: No se pudo subir el archivo al servidor'; + $lang['strcannotdumponwindows'] = 'El volcado de datos de tablas y esquemas con nombres complejos no esta soportado en Windows.'; + $lang['strinvalidserverparam'] = 'Intento de conexión al servidor con un parámetro inválido. Posiblemente alguien está intentando atacar tu sistema.'; + $lang['strnoserversupplied'] = 'No se suministró un servidor'; + $lang['strbadpgdumppath'] = 'Error de exportación: Falló la ejecución de execute pg_dump (según la ruta dada en conf/config.inc.php : %s). Por favor, arregla esta ruta en tu configuración y vuelve a iniciar sesión.'; + $lang['strbadpgdumpallpath'] = 'Error de exportación: Falló la ejecución de pg_dumpall (según la ruta dada en conf/config.inc.php : %s). Por favor, arregla esta ruta en tu configuración y vuelve a iniciar sesión.'; + $lang['strconnectionfail'] = 'No se puede conectar al servidor.'; + + // Tables + $lang['strtable'] = 'Tabla'; + $lang['strtables'] = 'Tablas'; + $lang['strshowalltables'] = 'Mostrar todas las tablas'; + $lang['strnotables'] = 'No se encontraron tablas.'; + $lang['strnotable'] = 'No se encontró la tabla.'; + $lang['strcreatetable'] = 'Crear tabla'; + $lang['strcreatetablelike'] = 'Crear una tabla a partir de una existente'; + $lang['strcreatetablelikeparent'] = 'Tabla de origen'; + $lang['strcreatelikewithdefaults'] = 'INCLUIR VALORES POR DEFECTO'; + $lang['strcreatelikewithconstraints'] = 'INCLUIR RESTRICCIONES'; + $lang['strcreatelikewithindexes'] = 'INCLUIR ÃNDICES'; + $lang['strtablename'] = 'Nombre de la tabla'; + $lang['strtableneedsname'] = 'Debes darle un nombre a la tabla.'; + $lang['strtablelikeneedslike'] = 'Debes especificar una tabla para copiar sus propiedades.'; + $lang['strtableneedsfield'] = 'Debes especificar al menos un campo.'; + $lang['strtableneedscols'] = 'Debes especificar un número válido de columnas.'; + $lang['strtablecreated'] = 'Tabla creada.'; + $lang['strtablecreatedbad'] = 'Falló la creación de la tabla.'; + $lang['strconfdroptable'] = '¿Estás seguro que desea eliminar la tabla "%s"?'; + $lang['strtabledropped'] = 'Tabla eliminada.'; + $lang['strtabledroppedbad'] = 'Falló la eliminación de la tabla.'; + $lang['strconfemptytable'] = '¿Estás seguro que desea vaciar la tabla "%s"?'; + $lang['strtableemptied'] = 'Tabla vaciada.'; + $lang['strtableemptiedbad'] = 'Falló el vaciado de la tabla.'; + $lang['strinsertrow'] = 'Insertar Fila'; + $lang['strrowinserted'] = 'Fila insertada.'; + $lang['strrowinsertedbad'] = 'Falló la inserción de fila.'; + $lang['strnofkref'] = 'No se hay un valor coincidente en la clave foránea %s.'; + $lang['strrowduplicate'] = 'Falló la inserción de fila , se intentó hacer una inserción duplicada.'; + $lang['streditrow'] = 'Editar fila'; + $lang['strrowupdated'] = 'Fila actualizada.'; + $lang['strrowupdatedbad'] = 'Falló la actualización de la fila.'; + $lang['strdeleterow'] = 'Eliminar Fila'; + $lang['strconfdeleterow'] = '¿Estás seguro que quiere eliminar esta fila?'; + $lang['strrowdeleted'] = 'Fila eliminada.'; + $lang['strrowdeletedbad'] = 'Falló la eliminación de fila.'; + $lang['strinsertandrepeat'] = 'Insertar y Repite'; + $lang['strnumcols'] = 'Número de columnas'; + $lang['strcolneedsname'] = 'Debes especificar un nombre para la columna'; + $lang['strselectallfields'] = 'Seleccionar todos los campos.'; + $lang['strselectneedscol'] = 'Debes elegir al menos una columna'; + $lang['strselectunary'] = 'Los operadores unarios no pueden tener valores.'; + $lang['strcolumnaltered'] = 'Columna Modificada.'; + $lang['strcolumnalteredbad'] = 'Falló la modificación de columna.'; + $lang['strconfdropcolumn'] = '¿Estás seguro que quiere eliminar la columna "%s" de la tabla "%s"?'; + $lang['strcolumndropped'] = 'Columna eliminada.'; + $lang['strcolumndroppedbad'] = 'Falló la eliminación de columna.'; + $lang['straddcolumn'] = 'Agregar Columna'; + $lang['strcolumnadded'] = 'Columna agregada.'; + $lang['strcolumnaddedbad'] = 'Falló el agregado de columna.'; + $lang['strcascade'] = 'EN CASCADA'; + $lang['strtablealtered'] = 'Tabla modificada.'; + $lang['strtablealteredbad'] = 'Falló la modificación de la Tabla.'; + $lang['strdataonly'] = 'Solamente datos'; + $lang['strstructureonly'] = 'Solo la estructura'; + $lang['strstructureanddata'] = 'Estructura y datos'; + $lang['strtabbed'] = 'Tabulado'; + $lang['strauto'] = 'Automático'; + $lang['strconfvacuumtable'] = '¿Estás seguro que quiere limpiar "%s"?'; + $lang['strconfanalyzetable'] = '¿Estás seguro que quiere analizar "%s"?'; + $lang['strconfreindextable'] = '¿Estás seguro que quiere actualizar los índices "%s"?'; + $lang['strconfclustertable'] = '¿Estás seguro que quiere clusterizar "%s"?'; + $lang['strestimatedrowcount'] = 'Cantidad de filas estimadas'; + $lang['strspecifytabletoanalyze'] = 'Debes especificar al menos una tabla para analizar.'; + $lang['strspecifytabletoempty'] = 'Debes especificar al menos una tabla para vaciar.'; + $lang['strspecifytabletodrop'] = 'Debes especificar al menos una tabla para eliminar.'; + $lang['strspecifytabletovacuum'] = 'Debes especificar al menos una tabla para limpiar.'; + $lang['strspecifytabletoreindex'] = 'Debes especificar al menos una tabla para actualizar sus índices.'; + $lang['strspecifytabletocluster'] = 'Debes especificar al menos una tabla para clusterizar.'; + $lang['strnofieldsforinsert'] = 'No puedes insertar un registro en una tabla sin columnas.'; + + // Columns + $lang['strcolprop'] = 'Propiedades de la Columna'; + $lang['strnotableprovided'] = '¡No se suministró al menos una tabla!'; + + // Users + $lang['struser'] = 'Usuario'; + $lang['strusers'] = 'Usuarios'; + $lang['strusername'] = 'Nombre de usuario'; + $lang['strpassword'] = 'Contraseña'; + $lang['strsuper'] = '¿Superusuario?'; + $lang['strcreatedb'] = '¿Puede crear BD?'; + $lang['strexpires'] = 'Expira'; + $lang['strsessiondefaults'] = 'Valores predeterminados de la sesión.'; + $lang['strnousers'] = 'No se encontraron usuarios.'; + $lang['struserupdated'] = 'Usuario actualizado.'; + $lang['struserupdatedbad'] = 'Falló la actualización del usuario.'; + $lang['strshowallusers'] = 'Mostrar todos los usuarios'; + $lang['strcreateuser'] = 'Crear usuario'; + $lang['struserneedsname'] = 'Debes dar un nombre a su usuario.'; + $lang['strusercreated'] = 'Usuario creado.'; + $lang['strusercreatedbad'] = 'Falló la creación del usuario.'; + $lang['strconfdropuser'] = '¿Estás seguro de querer eliminar el usuario "%s"?'; + $lang['struserdropped'] = 'Usuario eliminado.'; + $lang['struserdroppedbad'] = 'Falló la eliminación del usuario.'; + $lang['straccount'] = 'Cuenta'; + $lang['strchangepassword'] = 'Cambiar Contraseña'; + $lang['strpasswordchanged'] = 'Contraseña modificada.'; + $lang['strpasswordchangedbad'] = 'Falló al modificar contraseña.'; + $lang['strpasswordshort'] = 'La contraseña es muy corta.'; + $lang['strpasswordconfirm'] = 'Las contraseñas no coinciden.'; + + // Groups + $lang['strgroup'] = 'Grupo'; + $lang['strgroups'] = 'Grupos'; + $lang['strgroupgroups'] = 'Groups in group "%s"'; + $lang['strshowallgroups'] = 'Mostrar todos los grupos'; + $lang['strnogroup'] = 'Grupo no encontrado.'; + $lang['strnogroups'] = 'No se encontraron grupos.'; + $lang['strcreategroup'] = 'Crear Grupo'; + $lang['strgroupneedsname'] = 'Debes darle un nombre al grupo.'; + $lang['strgroupcreated'] = 'Grupo creado.'; + $lang['strgroupcreatedbad'] = 'Falló la creación del grupo.'; + $lang['strconfdropgroup'] = '¿Estás seguro de querer eliminar el grupo "%s"?'; + $lang['strgroupdropped'] = 'Grupo eliminado.'; + $lang['strgroupdroppedbad'] = 'Falló la eliminación del grupo.'; + $lang['strmembers'] = 'Miembros'; + $lang['strmemberof'] = 'Miembro de'; + $lang['stradminmembers'] = 'Administadores '; + $lang['straddmember'] = 'Agregar miembro'; + $lang['strmemberadded'] = 'Miembro agregado.'; + $lang['strmemberaddedbad'] = 'Falló la agregación de un nuevo miembro.'; + $lang['strdropmember'] = 'Retirar miembro'; + $lang['strconfdropmember'] = '¿Estás seguro de retirar el miembro "%s" del grupo "%s"?'; + $lang['strmemberdropped'] = 'Miembro retirado.'; + $lang['strmemberdroppedbad'] = 'Falló al retirar un miembro del grupo.'; + + // Roles + $lang['strrole'] = 'Rol'; + $lang['strroles'] = 'Roles'; + $lang['strshowallroles'] = 'Mostrar todas los roles'; + $lang['strnoroles'] = 'No se encontraron roles.'; + $lang['strinheritsprivs'] = '¿Hereda privilegios?'; + $lang['strcreaterole'] = 'Crear rol'; + $lang['strcancreaterole'] = '¿Puede crear roles?'; + $lang['strrolecreated'] = 'Rol creado.'; + $lang['strrolecreatedbad'] = 'Falló la creación del rol.'; + $lang['strrolealtered'] = 'Rol modificado.'; + $lang['strrolealteredbad'] = 'Falló la modificación del rol.'; + $lang['strcanlogin'] = '¿Puede iniciar sesión?'; + $lang['strconnlimit'] = 'Límite de conexión'; + $lang['strdroprole'] = 'Eliminar rol'; + $lang['strconfdroprole'] = '¿Estás seguro de que desea eliminar el rol "%s"?'; + $lang['strroledropped'] = 'Rol eliminado.'; + $lang['strroledroppedbad'] = 'Falló la eliminación del rol.'; + $lang['strnolimit'] = 'Sin límite'; + $lang['strnever'] = 'Nunca'; + $lang['strroleneedsname'] = 'Debes darle un nombre al rol.'; + + // Privileges + $lang['strprivilege'] = 'Privilegio'; + $lang['strprivileges'] = 'Privilegios'; + $lang['strnoprivileges'] = 'Por defecto, este objeto tiene privilegios de usuario.'; + $lang['strgrant'] = 'Otorgar'; + $lang['strrevoke'] = 'Revocar'; + $lang['strgranted'] = 'Los privilegios cambiaron.'; + $lang['strgrantfailed'] = 'Falló la actualización de los privilegios.'; + $lang['strgrantbad'] = 'Debes especificar al menos un usuario o grupo y al menos un privilegio.'; + $lang['strgrantor'] = 'Cedente'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Base de Datos'; + $lang['strdatabases'] = 'Bases de Datos'; + $lang['strshowalldatabases'] = 'Mostrar todas las bases de datos'; + $lang['strnodatabases'] = 'No se encontraron las bases de datos.'; + $lang['strcreatedatabase'] = 'Crear base de datos'; + $lang['strdatabasename'] = 'Nombre de la base de datos'; + $lang['strdatabaseneedsname'] = 'Debes darle un nombre a la base de datos.'; + $lang['strdatabasecreated'] = 'Base de datos creada.'; + $lang['strdatabasecreatedbad'] = 'Falló la creación de la base de datos.'; + $lang['strconfdropdatabase'] = '¿Estás seguro que quiere eliminar la base de datos "%s"?'; + $lang['strdatabasedropped'] = 'Base de datos eliminada.'; + $lang['strdatabasedroppedbad'] = 'Falló al eliminar la base de datos.'; + $lang['strentersql'] = 'Ingrese la sentencia de SQL para ejecutar:'; + $lang['strsqlexecuted'] = 'SQL ejecutada.'; + $lang['strvacuumgood'] = 'Limpieza completada.'; + $lang['strvacuumbad'] = 'Falló la limpieza.'; + $lang['stranalyzegood'] = 'Análisis completado.'; + $lang['stranalyzebad'] = 'El analisis falló.'; + $lang['strreindexgood'] = 'Actualización de índices completada.'; + $lang['strreindexbad'] = 'Falló la actualización de índices.'; + $lang['strfull'] = 'Llena'; + $lang['strfreeze'] = 'Congelar'; + $lang['strforce'] = 'Forzar'; + $lang['strsignalsent'] = 'Señal enviada.'; + $lang['strsignalsentbad'] = 'Falló el envío de la señal.'; + $lang['strallobjects'] = 'Todos los objetos'; + $lang['strdatabasealtered'] = 'Base de Datos modificada.'; + $lang['strdatabasealteredbad'] = 'Falló al intentar modificar la base de datos.'; + $lang['strspecifydatabasetodrop'] = 'Debes especificar al menos una base de datos para eliminar.'; + $lang['strtemplatedb'] = 'Plantilla'; + $lang['strconfanalyzedatabase'] = '¿Estás seguro que desea analizar todas las tablas en la base de datos "%s"?'; + $lang['strconfvacuumdatabase'] = '¿Estás seguro que desea limpiar todas las tablas en la base de datos "%s"?'; + $lang['strconfreindexdatabase'] = '¿Estás seguro que desea actualizar los índices de todas las tablas en la base de datos "%s"?'; + $lang['strconfclusterdatabase'] = '¿Estás seguro que desea ordenar todas las tablas en la base de datos "%s"?'; + + // Views + $lang['strview'] = 'Vista'; + $lang['strviews'] = 'Vistas'; + $lang['strshowallviews'] = 'Mostrar todas las vistas'; + $lang['strnoview'] = 'No se encontró la vista.'; + $lang['strnoviews'] = 'No se encontraron vistas.'; + $lang['strcreateview'] = 'Crear Vista'; + $lang['strviewname'] = 'Ver el nombre'; + $lang['strviewneedsname'] = 'Debes darle un nombre a la vista.'; + $lang['strviewneedsdef'] = 'Debes darle una definición a su vista.'; + $lang['strviewneedsfields'] = 'Debes seleccionar las columnas deseadas en su vista.'; + $lang['strviewcreated'] = 'Vista creada.'; + $lang['strviewcreatedbad'] = 'Falló al crear la vista.'; + $lang['strconfdropview'] = '¿Estás seguro que quiere eliminar la vista "%s"?'; + $lang['strviewdropped'] = 'Vista eliminada.'; + $lang['strviewdroppedbad'] = 'Falló al intentar eliminar la vista.'; + $lang['strviewupdated'] = 'Vista actualizada.'; + $lang['strviewupdatedbad'] = 'Falló al actualizar la vista.'; + $lang['strviewlink'] = 'Claves de enlace'; + $lang['strviewconditions'] = 'Condiciones adicionales'; + $lang['strcreateviewwiz'] = 'Crear vista usando el asistente'; + $lang['strrenamedupfields'] = 'Renombrar campos duplicados'; + $lang['strdropdupfields'] = 'Eliminar campos duplicados'; + $lang['strerrordupfields'] = 'Error en campos duplicados'; + $lang['strviewaltered'] = 'Vista modificada.'; + $lang['strviewalteredbad'] = 'Falló en la modificación de la vista.'; + $lang['strspecifyviewtodrop'] = 'Debes especificar al menos una vista a eliminar.'; + + // Sequences + $lang['strsequence'] = 'Secuencia'; + $lang['strsequences'] = 'Secuencias'; + $lang['strshowallsequences'] = 'Mostrar todas las secuencias'; + $lang['strnosequence'] = 'No se encontró la secuencia.'; + $lang['strnosequences'] = 'No se encontraron las secuencias.'; + $lang['strcreatesequence'] = 'Crear secuencia'; + $lang['strlastvalue'] = 'Último Valor'; + $lang['strincrementby'] = 'Incremento'; + $lang['strstartvalue'] = 'Valor inicial'; + $lang['strrestartvalue'] = 'Reiniciar valor'; + $lang['strmaxvalue'] = 'Valor máximo'; + $lang['strminvalue'] = 'Valor mínimo'; + $lang['strcachevalue'] = 'Valor de la caché'; + $lang['strlogcount'] = 'Registrar cuenta'; + $lang['strcancycle'] = '¿Cíclica?'; + $lang['striscalled'] = '¿Incrementará el último valor antes de ser llamado (is_called)?'; + $lang['strsequenceneedsname'] = 'Debes especificar el nombre de la secuencia.'; + $lang['strsequencecreated'] = 'Secuencia creada.'; + $lang['strsequencecreatedbad'] = 'Falló la creación de la secuencia.'; + $lang['strconfdropsequence'] = '¿Estás seguro que quiere eliminar la secuencia "%s"?'; + $lang['strsequencedropped'] = 'Secuencia eliminada.'; + $lang['strsequencedroppedbad'] = 'Falló la eliminación de la secuencia.'; + $lang['strsequencerestart'] = 'Secuencia restablecida.'; + $lang['strsequencerestartbad'] = 'Falló al restablecer la secuencia.'; + $lang['strsequencereset'] = 'Secuencia reiniciada.'; + $lang['strsequenceresetbad'] = 'Falló al intentar reiniciar la secuencia.'; + $lang['strsequencealtered'] = 'Secuencia modificada.'; + $lang['strsequencealteredbad'] = 'Falló la modificación de la secuencia.'; + $lang['strsetval'] = 'Fijar el valor'; + $lang['strsequencesetval'] = 'Fijar el valor de la secuencia.'; + $lang['strsequencesetvalbad'] = 'Falló la fijación del valor en la secuencia.'; + $lang['strnextval'] = 'Valor de incremento'; + $lang['strsequencenextval'] = 'Secuencia incrementada.'; + $lang['strsequencenextvalbad'] = 'Falló el incremento de la secuencia.'; + $lang['strspecifysequencetodrop'] = 'Debes especificar al menos una secuencia a eliminar.'; + + // Indexes + $lang['strindex'] = 'Ãndice'; + $lang['strindexes'] = 'Ãndices'; + $lang['strindexname'] = 'Nombre del Ãndice'; + $lang['strshowallindexes'] = 'Mostrar Todos los Ãndices'; + $lang['strnoindex'] = 'No se encontró el índice.'; + $lang['strnoindexes'] = 'No se encontraron índices.'; + $lang['strcreateindex'] = 'Crear Ãndice'; + $lang['strtabname'] = 'Nombre de la pestaña'; + $lang['strcolumnname'] = 'Nombre de Columna'; + $lang['strindexneedsname'] = 'Debes darle un nombre al índice'; + $lang['strindexneedscols'] = 'Los índices requieren un número válido de columnas.'; + $lang['strindexcreated'] = 'Ãndice creado'; + $lang['strindexcreatedbad'] = 'Falló la creación del índice.'; + $lang['strconfdropindex'] = '¿Estás seguro d eliminar el índice "%s"?'; + $lang['strindexdropped'] = 'Ãndice eliminado.'; + $lang['strindexdroppedbad'] = 'Falló la eliminación del índice.'; + $lang['strkeyname'] = 'Nombre de la clave'; + $lang['struniquekey'] = 'Clave única'; + $lang['strprimarykey'] = 'Clave primaria'; + $lang['strindextype'] = 'Tipo de índice'; + $lang['strtablecolumnlist'] = 'Columnas en tabla'; + $lang['strindexcolumnlist'] = 'Columnas en el índice'; + $lang['strconfcluster'] = '¿Estás seguro de querer clusterizar en "%s"?'; + $lang['strclusteredgood'] = 'Clusterización completa.'; + $lang['strclusteredbad'] = 'Falló la clusterización de la tabla.'; + $lang['strconcurrently'] = 'Concurrente'; + $lang['strnoclusteravailable'] = 'Tabla no ordenada en un índice.'; + + // Rules + $lang['strrules'] = 'Reglas'; + $lang['strrule'] = 'Regla'; + $lang['strshowallrules'] = 'Mostrar todas las reglas'; + $lang['strnorule'] = 'No se encontró la regla.'; + $lang['strnorules'] = 'No se encontraron las reglas.'; + $lang['strcreaterule'] = 'Crear regla'; + $lang['strrulename'] = 'Nombre de regla'; + $lang['strruleneedsname'] = 'Debes darle un nombre a la regla.'; + $lang['strrulecreated'] = 'Regla creada.'; + $lang['strrulecreatedbad'] = 'Falló la creación de la regla.'; + $lang['strconfdroprule'] = '¿Estás seguro de querer eliminar la regla "%s" en "%s"?'; + $lang['strruledropped'] = 'Regla eliminada.'; + $lang['strruledroppedbad'] = 'Falló la eliminación de la regla.'; + + // Constraints + $lang['strconstraint'] = 'Restricción'; + $lang['strconstraints'] = 'Restricciones'; + $lang['strshowallconstraints'] = 'Mostrar todas las restricciones'; + $lang['strnoconstraints'] = 'No se encontraron restricciones.'; + $lang['strcreateconstraint'] = 'Crear restricción'; + $lang['strconstraintcreated'] = 'Restricción creada.'; + $lang['strconstraintcreatedbad'] = 'Falló la creación de la restricción.'; + $lang['strconfdropconstraint'] = '¿Estás seguro que quiere eliminar la restricción "%s" de "%s"?'; + $lang['strconstraintdropped'] = 'Restricción eliminada.'; + $lang['strconstraintdroppedbad'] = 'Falló al eliminar la restricción.'; + $lang['straddcheck'] = 'Agregar chequeo'; + $lang['strcheckneedsdefinition'] = 'La restricción de chequeo necesita una definición.'; + $lang['strcheckadded'] = 'Restricción de chequeo agregada.'; + $lang['strcheckaddedbad'] = 'Fallo al intentar agregar restricción de chequeo.'; + $lang['straddpk'] = 'Agregar clave primaria'; + $lang['strpkneedscols'] = 'La clave primaria necesita al menos un campo.'; + $lang['strpkadded'] = 'Clave primaria agregada.'; + $lang['strpkaddedbad'] = 'Falló al intentar crear la clave primaria.'; + $lang['stradduniq'] = 'Agregar clave única'; + $lang['struniqneedscols'] = 'La clave única necesita al menos un campo.'; + $lang['struniqadded'] = 'Clave única agregada.'; + $lang['struniqaddedbad'] = 'Falló al intentar agregar la clave única.'; + $lang['straddfk'] = 'Agregar clave foránea'; + $lang['strfkneedscols'] = 'La clave foránea necesita al menos un campo.'; + $lang['strfkneedstarget'] = 'La clave foránea necesita una tabla para referenciar.'; + $lang['strfkadded'] = 'Clave foránea agregada.'; + $lang['strfkaddedbad'] = 'Fallo al agregar la clave foránea.'; + $lang['strfktarget'] = 'Tabla de destino'; + $lang['strfkcolumnlist'] = 'Campos en la clave'; + $lang['strondelete'] = 'AL ELIMINAR'; + $lang['stronupdate'] = 'AL ACTUALIZAR'; + + // Functions + $lang['strfunction'] = 'Función'; + $lang['strfunctions'] = 'Funciones'; + $lang['strshowallfunctions'] = 'Mostrar todas las funciones'; + $lang['strnofunction'] = 'No se encontró la función.'; + $lang['strnofunctions'] = 'No se encontraron funciones.'; + $lang['strcreateplfunction'] = 'Crear función SQL/PL'; + $lang['strcreateinternalfunction'] = 'Crear función interna'; + $lang['strcreatecfunction'] = 'Crear función en C'; + $lang['strfunctionname'] = 'Nombre de la función'; + $lang['strreturns'] = 'Retorna'; + $lang['strproglanguage'] = 'Lenguaje de programación'; + $lang['strfunctionneedsname'] = 'Debes darle un nombre a la función.'; + $lang['strfunctionneedsdef'] = 'Debes darle una definición a la función.'; + $lang['strfunctioncreated'] = 'Función creada.'; + $lang['strfunctioncreatedbad'] = 'Falló la creación de la función.'; + $lang['strconfdropfunction'] = '¿Estás seguro que quiere eliminar la función "%s"?'; + $lang['strfunctiondropped'] = 'Función eliminada.'; + $lang['strfunctiondroppedbad'] = 'Falló al eliminar la función.'; + $lang['strfunctionupdated'] = 'Función actualizada.'; + $lang['strfunctionupdatedbad'] = 'Falló al actualizar la función.'; + $lang['strobjectfile'] = 'Archivo de objeto'; + $lang['strlinksymbol'] = 'Vinculo simbólico'; + $lang['strarguments'] = 'Argumentos'; + $lang['strargmode'] = 'Modo'; + $lang['strargtype'] = 'Tipo'; + $lang['strargadd'] = 'Agregar otro argumento'; + $lang['strargremove'] = 'Eliminar este argumento'; + $lang['strargnoargs'] = 'Esta función no tendrá argumentos.'; + $lang['strargenableargs'] = 'Habilitar argumentos pasados a esta función.'; + $lang['strargnorowabove'] = 'Debe existir una fila por encima de esta fila.'; + $lang['strargnorowbelow'] = 'Debe exisitr una fila por debajo de esta fila.'; + $lang['strargraise'] = 'Mover arriba.'; + $lang['strarglower'] = 'Mover abajo.'; + $lang['strargremoveconfirm'] = '¿Esta seguro que quiere eliminar este argumento? Esto NO se puede deshacer.'; + $lang['strfunctioncosting'] = 'Costo de la función'; + $lang['strresultrows'] = 'Filas en el resultado'; + $lang['strexecutioncost'] = 'Costo de ejecución'; + $lang['strspecifyfunctiontodrop'] = 'Debes especificar al menos una función a eliminar.'; + + // Triggers + $lang['strtrigger'] = 'Disparador'; + $lang['strtriggers'] = 'Disparadores'; + $lang['strshowalltriggers'] = 'Mostrar todos los disparadores'; + $lang['strnotrigger'] = 'No se encontró el disparador.'; + $lang['strnotriggers'] = 'No se encontraron disparadores.'; + $lang['strcreatetrigger'] = 'Crear Disparador'; + $lang['strtriggerneedsname'] = 'Debes darle un nombre al disparador.'; + $lang['strtriggerneedsfunc'] = 'Debes especificar una función para el disparador.'; + $lang['strtriggercreated'] = 'Disparador creado.'; + $lang['strtriggercreatedbad'] = 'Falló la creación del disparador.'; + $lang['strconfdroptrigger'] = '¿Estás seguro que quiere eliminar el disparador "%s" en "%s"?'; + $lang['strconfenabletrigger'] = '¿Estás seguro que desea activar el disparador "%s" en "%s"?'; + $lang['strconfdisabletrigger'] = '¿Estás seguro que desea desactivar el disparador "%s" en "%s"?'; + $lang['strtriggerdropped'] = 'Disparador eliminado.'; + $lang['strtriggerdroppedbad'] = 'Falló al eliminar el disparador.'; + $lang['strtriggerenabled'] = 'Disparador activado.'; + $lang['strtriggerenabledbad'] = 'Falló la activación del disparador.'; + $lang['strtriggerdisabled'] = 'Disparador desactivado.'; + $lang['strtriggerdisabledbad'] = 'Falló la desactivación del disparador.'; + $lang['strtriggeraltered'] = 'Disparador modificado.'; + $lang['strtriggeralteredbad'] = 'Falló la modificación del disparador.'; + $lang['strforeach'] = 'Para cada uno'; + + // Types + $lang['strtype'] = 'Tipo de dato'; + $lang['strtypes'] = 'Tipos de datos'; + $lang['strshowalltypes'] = 'Mostrar todos los tipos'; + $lang['strnotype'] = 'No se encontró el tipo.'; + $lang['strnotypes'] = 'No se encontraron tipos.'; + $lang['strcreatetype'] = 'Crear Tipo'; + $lang['strcreatecomptype'] = 'Crear tipo compuesto'; + $lang['strcreateenumtype'] = 'Crear tipo enumerado'; + $lang['strtypeneedsfield'] = 'Debes especificar al menos un campo.'; + $lang['strtypeneedsvalue'] = 'Debes especificar al menos un valor.'; + $lang['strtypeneedscols'] = 'Tipos compuestos requieren de un número válido de columnas.'; + $lang['strtypeneedsvals'] = 'Debes especificar un número válido de valores.'; + $lang['strinputfn'] = 'Función de entrada'; + $lang['stroutputfn'] = 'Función de salida'; + $lang['strpassbyval'] = '¿Pasar por valor?'; + $lang['stralignment'] = 'Alineamiento'; + $lang['strelement'] = 'Elemento'; + $lang['strdelimiter'] = 'Delimitador'; + $lang['strstorage'] = 'Almacenamiento'; + $lang['strfield'] = 'Campo'; + $lang['strnumfields'] = 'Número de campos'; + $lang['strnumvalues'] = 'Número de valores'; + $lang['strtypeneedsname'] = 'Debes especificar un nombre para el tipo.'; + $lang['strtypeneedslen'] = 'Debes especificar una longitud para el tipo.'; + $lang['strtypecreated'] = 'Tipo creado'; + $lang['strtypecreatedbad'] = 'Falló la creación del tipo.'; + $lang['strconfdroptype'] = '¿Estás seguro de querer eliminar el tipo "%s"?'; + $lang['strtypedropped'] = 'Tipo eliminado.'; + $lang['strtypedroppedbad'] = 'Falló al eliminar el tipo.'; + $lang['strflavor'] = 'Tipo'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Compuesto'; + $lang['strpseudotype'] = 'Seudo'; + $lang['strenum'] = 'Enumerado'; + $lang['strenumvalues'] = 'Valores enumerados'; + + // Schemas + $lang['strschema'] = 'Esquema'; + $lang['strschemas'] = 'Esquemas'; + $lang['strshowallschemas'] = 'Mostrar Todos los Esquemas'; + $lang['strnoschema'] = 'No se encontró el esquema.'; + $lang['strnoschemas'] = 'No se encontraron esquemas.'; + $lang['strcreateschema'] = 'Crear Esquema'; + $lang['strschemaname'] = 'Nombre del esquema'; + $lang['strschemaneedsname'] = 'Debes especificar un nombre para el esquema.'; + $lang['strschemacreated'] = 'Esquema creado'; + $lang['strschemacreatedbad'] = 'Falló la creación del esquema.'; + $lang['strconfdropschema'] = '¿Estás seguro que quiere eliminar el esquema "%s"?'; + $lang['strschemadropped'] = 'Esquema eliminado.'; + $lang['strschemadroppedbad'] = 'Falló la eliminación del esquema.'; + $lang['strschemaaltered'] = 'Esquema actualizado.'; + $lang['strschemaalteredbad'] = 'Falló la actualización del esquema.'; + $lang['strsearchpath'] = 'Ruta de la búsqueda en los esquemas'; + $lang['strspecifyschematodrop'] = 'Debes especificar al menos un esquema a eliminar.'; + + // Reports + + //Domains + $lang['strdomain'] = 'Dominio'; + $lang['strdomains'] = 'Dominios'; + $lang['strshowalldomains'] = 'Mostrar todos los dominios'; + $lang['strnodomains'] = 'No se encontraron dominios.'; + $lang['strcreatedomain'] = 'Crear dominio'; + $lang['strdomaindropped'] = 'Dominio eliminado.'; + $lang['strdomaindroppedbad'] = 'Falló la eliminación del dominio.'; + $lang['strconfdropdomain'] = '¿Esta seguro de querer eliminar el dominio "%s"?'; + $lang['strdomainneedsname'] = 'Debes dar un nombre para el dominio.'; + $lang['strdomaincreated'] = 'Dominio creado.'; + $lang['strdomaincreatedbad'] = 'Falló la creación del dominio.'; + $lang['strdomainaltered'] = 'Dominio modificado.'; + $lang['strdomainalteredbad'] = 'Falló al intentar modificar el dominio.'; + + // Operators + $lang['stroperator'] = 'Operador'; + $lang['stroperators'] = 'Operadores'; + $lang['strshowalloperators'] = 'Mostrar todos los operadores'; + $lang['strnooperator'] = 'No se encontró el operador.'; + $lang['strnooperators'] = 'No se encontraron operadores.'; + $lang['strcreateoperator'] = 'Crear operador'; + $lang['strleftarg'] = 'Tipo de datos del arg. izquierdo'; + $lang['strrightarg'] = 'Tipo de datos del arg. derecho'; + $lang['strcommutator'] = 'Conmutador'; + $lang['strnegator'] = 'Negación'; + $lang['strrestrict'] = 'Restringir'; + $lang['strjoin'] = 'Unión'; + $lang['strhashes'] = 'Llaves (Hash)'; + $lang['strmerges'] = 'Fusiones'; + $lang['strleftsort'] = 'Ordenado izquierdo'; + $lang['strrightsort'] = 'Ordenado derecho'; + $lang['strlessthan'] = 'Menor que'; + $lang['strgreaterthan'] = 'Mayor que'; + $lang['stroperatorneedsname'] = 'Debes darle un nombre al operador.'; + $lang['stroperatorcreated'] = 'Operador creado'; + $lang['stroperatorcreatedbad'] = 'Falló la creación del operador.'; + $lang['strconfdropoperator'] = '¿Estás seguro de querer eliminar el operador "%s"?'; + $lang['stroperatordropped'] = 'Operador eliminado.'; + $lang['stroperatordroppedbad'] = 'Falló en la eliminación del operador.'; + + // Casts + $lang['strcasts'] = 'Conversión de tipos'; + $lang['strnocasts'] = 'No se encontraron conversiones.'; + $lang['strsourcetype'] = 'Tipo del origen'; + $lang['strtargettype'] = 'Tipo del destino'; + $lang['strimplicit'] = 'Implícito'; + $lang['strinassignment'] = 'En asignación'; + $lang['strbinarycompat'] = '(Compatible con binario)'; + + // Conversions + $lang['strconversions'] = 'Conversiones'; + $lang['strnoconversions'] = 'No se encontraron conversiones.'; + $lang['strsourceencoding'] = 'Codificación de la fuente'; + $lang['strtargetencoding'] = 'Codificación del destino'; + + // Languages + $lang['strlanguages'] = 'Lenguajes'; + $lang['strnolanguages'] = 'No se encontraron lenguajes.'; + $lang['strtrusted'] = 'Confiable'; + + // Info + $lang['strnoinfo'] = 'No hay información disponible.'; + $lang['strreferringtables'] = 'Tablas referenciales'; + $lang['strparenttables'] = 'Tablas padre'; + $lang['strchildtables'] = 'Tablas hija'; + + // Aggregates + $lang['straggregate'] = 'Agregación'; + $lang['straggregates'] = 'Agregaciones'; + $lang['strnoaggregates'] = 'No se encontraron agregaciones.'; + $lang['stralltypes'] = '(Todos los tipos)'; + $lang['strcreateaggregate'] = 'Crear Agregación'; + $lang['straggrbasetype'] = 'Tipo del dato de entrada'; + $lang['straggrsfunc'] = 'Función de transición de estado'; + $lang['straggrstype'] = 'Tipo de dato para el valor de estado'; + $lang['straggrffunc'] = 'Función final'; + $lang['straggrinitcond'] = 'Condición inicial'; + $lang['straggrsortop'] = 'Operador de ordenamiento'; + $lang['strconfdropaggregate'] = '¿Estás seguro que desea eliminar la agregación "%s"?'; + $lang['straggregatedropped'] = 'Agregación eliminada.'; + $lang['straggregatedroppedbad'] = 'Falló en la eliminación de la agregación.'; + $lang['straggraltered'] = 'Agregación modificada.'; + $lang['straggralteredbad'] = 'Falló la modificación de la agregación.'; + $lang['straggrneedsname'] = 'Debes especificar un nombre para la agregación.'; + $lang['straggrneedsbasetype'] = 'Debes especificar un tipo de dato de entrada para la agregación.'; + $lang['straggrneedssfunc'] = 'Debes especificar el nombre de la función de transición de estado de la agregación.'; + $lang['straggrneedsstype'] = 'Debes especificar el tipo de dato para la el valor de estado de la agregación.'; + $lang['straggrcreated'] = 'Agregación creada.'; + $lang['straggrcreatedbad'] = 'Falló la creación de la agregación.'; + $lang['straggrshowall'] = 'Mostrar todas las agregaciones'; + + // Operator Classes + $lang['stropclasses'] = 'Clases de operadores'; + $lang['strnoopclasses'] = 'No se encontraron las clases de operadores.'; + $lang['straccessmethod'] = 'Método de acceso'; + + // Stats and performance + $lang['strrowperf'] = 'Rendimiento de fila'; + $lang['strioperf'] = 'Rentimiento de E/S'; + $lang['stridxrowperf'] = 'Rendimiento de índice de la fila'; + $lang['stridxioperf'] = 'Rendimiento de indexado de E/S'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Secuencial'; + $lang['strscan'] = 'Escanear'; + $lang['strread'] = 'Leer'; + $lang['strfetch'] = 'Extraer'; + $lang['strheap'] = 'Salto'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'Indice TOAST'; + $lang['strcache'] = 'Caché'; + $lang['strdisk'] = 'Disco'; + $lang['strrows2'] = 'Filas'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaces'; + $lang['strshowalltablespaces'] = 'Mostrar todos los tablespaces'; + $lang['strnotablespaces'] = 'No se encontraron tablespaces.'; + $lang['strcreatetablespace'] = 'Crear tablespace'; + $lang['strlocation'] = 'Ubicación'; + $lang['strtablespaceneedsname'] = 'Debes darle un nombre al tablespace.'; + $lang['strtablespaceneedsloc'] = 'Debes dar un directorio en donde crear el tablespace.'; + $lang['strtablespacecreated'] = 'Tablespace creado.'; + $lang['strtablespacecreatedbad'] = 'Falló la creación del tablespace.'; + $lang['strconfdroptablespace'] = '¿Esta seguro que quiere eliminar el tablespace "%s"?'; + $lang['strtablespacedropped'] = 'Tablespace eliminado.'; + $lang['strtablespacedroppedbad'] = 'Falló la eliminación del tablespace.'; + $lang['strtablespacealtered'] = 'Tablespace modificado.'; + $lang['strtablespacealteredbad'] = 'Falló la modificación del Tablespace.'; + + // Miscellaneous + $lang['strtopbar'] = '%s corriendo en %s:%s -- Usted ha iniciado sesión con el usuario "%s"'; + $lang['strtimefmt'] = 'd/m/Y, G:i:s'; + $lang['strhelp'] = 'Ayuda'; + $lang['strhelpicon'] = '?'; + $lang['strhelppagebrowser'] = 'Buscador de la página de ayúda'; + $lang['strselecthelppage'] = 'Seleccione una página de ayuda'; + $lang['strinvalidhelppage'] = 'Página de ayuda inválida.'; + $lang['strlogintitle'] = 'Iniciar sesión en %s'; + $lang['strlogoutmsg'] = 'Saliendo de %s'; + $lang['strloading'] = 'Cargando...'; + $lang['strerrorloading'] = 'Error al cargar'; + $lang['strclicktoreload'] = 'Clic para recargar'; + + // Autovacuum + $lang['strautovacuum'] = 'Autolimpiado'; + $lang['strturnedon'] = 'Encendido'; + $lang['strturnedoff'] = 'Apagado'; + $lang['strenabled'] = 'Habilitado'; + $lang['strnovacuumconf'] = 'No se encontró configuración para autolimpiar.'; + $lang['strvacuumbasethreshold'] = 'Umbral de limpiar'; + $lang['strvacuumscalefactor'] = 'Factor de escala de limpiado'; + $lang['stranalybasethreshold'] = 'Analizar umbral base'; + $lang['stranalyzescalefactor'] = 'Analizar Facor de Escala'; + $lang['strvacuumcostdelay'] = 'Tiempo de retraso para limpiar'; + $lang['strvacuumcostlimit'] = 'Limite del costo de limpiar'; + $lang['strvacuumpertable'] = 'Configuración de autolimpiar de cada tabla'; + $lang['straddvacuumtable'] = 'Agregar configuración de autolimpiar a una tabla'; + $lang['streditvacuumtable'] = 'Editar configuración de autolimpiar para la tabla %s'; + $lang['strdelvacuumtable'] = '¿Eliminar configuración de autolimpiar para la tabla %s ?'; + $lang['strvacuumtablereset'] = 'Reiniciar configuración de autolimpiar para la tabla %s '; + $lang['strdelvacuumtablefail'] = 'Falló al remover la configuración de autolimpiar para la tabla %s'; + $lang['strsetvacuumtablesaved'] = 'Configuración de autolimpiar %s guardada.'; + $lang['strsetvacuumtablefail'] = 'Falló la configuración de autolimpiar para la tabla %s.'; + $lang['strspecifydelvacuumtable'] = 'Debes especificar la tabla a la que deseas removerle los parámetros de autolimpiar.'; + $lang['strspecifyeditvacuumtable'] = 'Debes especificar la tabla a la que deseeas editarle los parámetros de autolimpiar.'; + $lang['strnotdefaultinred'] = 'Los valores en rojo no son los valores por defecto.'; + + // Table-level Locks + $lang['strlocks'] = 'Bloqueos'; + $lang['strtransaction'] = 'ID de la transacción'; + $lang['strvirtualtransaction'] = 'ID de la transacción virtual'; + $lang['strprocessid'] = 'ID de proceso'; + $lang['strmode'] = 'Modo de bloqueo'; + $lang['strislockheld'] = '¿Se mantiene el bloqueo?'; + + // Prepared transactions + $lang['strpreparedxacts'] = 'Transacciones preparadas'; + $lang['strxactid'] = 'ID de la Transacción'; + $lang['strgid'] = 'ID Global'; + + // Fulltext search + $lang['strfulltext'] = 'Búsqueda de texto completo'; + $lang['strftsconfig'] = 'Configuración de BTC'; + $lang['strftsconfigs'] = 'Configuraciones'; + $lang['strftscreateconfig'] = 'Crear configuración de BTC'; + $lang['strftscreatedict'] = 'Crear diccionario'; + $lang['strftscreatedicttemplate'] = 'Crear plantilla de dicionario'; + $lang['strftscreateparser'] = 'Crear analizador'; + $lang['strftsnoconfigs'] = 'No se encontró configuración de búsqueda de texto completo.'; + $lang['strftsconfigdropped'] = 'Configuración de búsqueda de texto completo eliminada.'; + $lang['strftsconfigdroppedbad'] = 'Falló la eliminación de la configuración de búsqueda de texto completo.'; + $lang['strconfdropftsconfig'] = '¿Estás seguro de eliminar la configuración de búsqueda de texto completo "%s"?'; + $lang['strconfdropftsdict'] = '¿Estás seguro eliminar el diccionario de BTC "%s"?'; + $lang['strconfdropftsmapping'] = '¿Estás seguro de eliminar la asignación "%s" de la configuración de BTC "%s"?'; + $lang['strftstemplate'] = 'Plantilla'; + $lang['strftsparser'] = 'Analizador'; + $lang['strftsconfigneedsname'] = 'Debes suministrar un nombre para la configuración de la BTC.'; + $lang['strftsconfigcreated'] = 'Configuración de BTC creada.'; + $lang['strftsconfigcreatedbad'] = 'Falló la creación de BTC.'; + $lang['strftsmapping'] = 'Mapeo'; + $lang['strftsdicts'] = 'Diccionarios'; + $lang['strftsdict'] = 'Diccionario'; + $lang['strftsemptymap'] = 'Configuración vacía de la asignación de BTC .'; + $lang['strftsconfigaltered'] = 'Configuración de BTC modificada.'; + $lang['strftsconfigalteredbad'] = 'Falló la modificación de la configuración de BTC.'; + $lang['strftsconfigmap'] = 'Configuración de asignación de BTC'; + $lang['strftsparsers'] = 'Analizadores de BTC'; + $lang['strftsnoparsers'] = 'No hay analizadores de BTC disponibles.'; + $lang['strftsnodicts'] = 'No hay diccionarios de BTC disponibles.'; + $lang['strftsdictcreated'] = 'Diccionario de BTC creado.'; + $lang['strftsdictcreatedbad'] = 'Falló la creación del diccionario BTC.'; + $lang['strftslexize'] = 'Analizar léxicamente'; + $lang['strftsinit'] = 'Iniciar'; + $lang['strftsoptionsvalues'] = 'Opciones y valores'; + $lang['strftsdictneedsname'] = 'Debes suministrar un nombre para el diccionario de BTC.'; + $lang['strftsdictdropped'] = 'Diccionario de BTC eliminado.'; + $lang['strftsdictdroppedbad'] = 'Falló la eliminación del diccionario de BTC.'; + $lang['strftsdictaltered'] = 'Diccionario de BTC modificado.'; + $lang['strftsdictalteredbad'] = 'Falló la modificación del diccionario de BTC.'; + $lang['strftsaddmapping'] = 'Agregar nueva asignación'; + $lang['strftsspecifymappingtodrop'] = 'Debes especificar al menos una asignación a eliminar.'; + $lang['strftsspecifyconfigtoalter'] = 'Debes especificar una configuración de BTC a modificar'; + $lang['strftsmappingdropped'] = 'Asignación de BTC eliminada.'; + $lang['strftsmappingdroppedbad'] = 'Falló la eliminación de la asignación de BTC.'; + $lang['strftsnodictionaries'] = 'No se encontrarón diccionarios.'; + $lang['strftsmappingaltered'] = 'Asignación de BTC modificada.'; + $lang['strftsmappingalteredbad'] = 'Falló la modificación de la asignación de BTC.'; + $lang['strftsmappingadded'] = 'Asignación de BTC agregada.'; + $lang['strftsmappingaddedbad'] = 'Falló la asignación de BTC.'; + $lang['strftstabconfigs'] = 'Configuraciones'; + $lang['strftstabdicts'] = 'Diccionarios'; + $lang['strftstabparsers'] = 'Analizadores'; + $lang['strftscantparsercopy'] = 'No se puede especificar tanto el analizador como la plantilla durante la creación de la configuración de la búsqueda de texto.'; + + //Plugins + $lang['strpluginnotfound'] = 'Error: el plugin \'%s\' no se encontró. Chequea si existe en la carpeta plugins/ , o si el plugin contiene un archivo llamado plugin.php. Los nombres de los plugin son sensibles a las mayúsculas'; + $lang['stractionnotfound'] = 'Error: la acción \'%s\' no se encontró en el \'%s\' del plugin, o no se especificó como acción.'; + $lang['strhooknotfound'] = 'Error: el hook \'%s\' no está disponible.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/swedish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/swedish.php new file mode 100644 index 00000000..bed040ce --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/swedish.php @@ -0,0 +1,565 @@ + + * Due to lack of SQL knowledge som translations may be wrong, mail me the correct one and ill fix it + * + * $Id: swedish.php,v 1.11 2007/04/24 11:42:07 soranzo Exp $ + */ + + // Language and character set + $lang['applang'] = 'Swedish'; + $lang['applocale'] = 'sv-SE'; + $lang['applangdir'] = 'ltr'; + + // Welcome + $lang['strintro'] = 'Välkommen till phpPgAdmin.'; + $lang['strppahome'] = 'phpPgAdmins Hemsida'; + $lang['strpgsqlhome'] = 'PostgreSQLs Hemsida'; + $lang['strpgsqlhome_url'] = 'http://www.postgresql.org/'; + $lang['strlocaldocs'] = 'PostgreSQLs Dokumentation (lokalt)'; + $lang['strreportbug'] = 'Rapportera ett fel'; + $lang['strviewfaq'] = 'Visa FrÃ¥gor & Svar'; + $lang['strviewfaq_url'] = 'http://phppgadmin.sourceforge.net/doku.php?id=faq'; + + // Basic strings + $lang['strlogin'] = 'Logga in'; + $lang['strloginfailed'] = 'Inloggningen misslyckades'; + $lang['strlogindisallowed'] = 'Inloggningen ej tillÃ¥ten'; + $lang['strserver'] = 'Server'; + $lang['strlogout'] = 'Logga ut'; + $lang['strowner'] = 'Ägare'; + $lang['straction'] = 'Ã…tgärd'; + $lang['stractions'] = 'Ã…tgärder'; + $lang['strname'] = 'Namn'; + $lang['strdefinition'] = 'Definition'; + $lang['strproperties'] = 'Egenskaper'; + $lang['strbrowse'] = 'Bläddra'; + $lang['strdrop'] = 'Ta bort'; + $lang['strdropped'] = 'Borttagen'; + $lang['strnull'] = 'Ingenting'; + $lang['strnotnull'] = 'Inte Ingenting'; + $lang['strfirst'] = '<< Första'; + $lang['strlast'] = 'Sista >>'; + $lang['strprev'] = 'FöregÃ¥ende'; + $lang['strfailed'] = 'Misslyckades'; + $lang['strnext'] = 'Nästa'; + $lang['strcreate'] = 'Skapa'; + $lang['strcreated'] = 'Skapad'; + $lang['strcomment'] = 'Kommentar'; + $lang['strlength'] = 'Längd'; + $lang['strdefault'] = 'Standardvärde'; + $lang['stralter'] = 'Ändra'; + $lang['strok'] = 'OK'; + $lang['strcancel'] = 'Ã…ngra'; + $lang['strsave'] = 'Spara'; + $lang['strreset'] = 'Nollställ'; + $lang['strinsert'] = 'Infoga'; + $lang['strselect'] = 'Välj'; + $lang['strdelete'] = 'Radera'; + $lang['strupdate'] = 'Uppdatera'; + $lang['strreferences'] = 'Referencer'; + $lang['stryes'] = 'Ja'; + $lang['strno'] = 'Nej'; + $lang['strtrue'] = 'Sant'; + $lang['strfalse'] = 'Falskt'; + $lang['stredit'] = 'Redigera'; + $lang['strcolumns'] = 'Kolumner'; + $lang['strrows'] = 'Rad(er)'; + $lang['strrowsaff'] = 'Rad(er) PÃ¥verkade.'; + $lang['strobjects'] = 'Objekt'; + $lang['strexample'] = 't. ex.'; + $lang['strback'] = 'BakÃ¥t'; + $lang['strqueryresults'] = 'Sökresultat'; + $lang['strshow'] = 'Visa'; + $lang['strempty'] = 'Tom'; + $lang['strlanguage'] = 'SprÃ¥k'; + $lang['strencoding'] = 'Kodning'; + $lang['strvalue'] = 'Värde'; + $lang['strunique'] = 'Unik'; + $lang['strprimary'] = 'Primär'; + $lang['strexport'] = 'Exportera'; + $lang['strimport'] = 'Importera'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = 'Kör'; + $lang['stradmin'] = 'Admin'; + $lang['strvacuum'] = 'Städa upp'; + $lang['stranalyze'] = 'Analysera'; + $lang['strclusterindex'] = 'Kluster'; + $lang['strclustered'] = 'Klustrat?'; + $lang['strreindex'] = 'Ã…terindexera'; + $lang['strrun'] = 'Kör'; + $lang['stradd'] = 'Lägg till'; + $lang['strinstead'] = 'Gör Istället'; + $lang['strevent'] = 'Händelse'; + $lang['strformat'] = 'Format'; + $lang['strwhen'] = 'När'; + $lang['strdata'] = 'Data'; + $lang['strconfirm'] = 'Bekräfta'; + $lang['strexpression'] = 'Uttryck'; + $lang['strellipsis'] = '...'; + $lang['strwhere'] = 'När'; + $lang['strexplain'] = 'Förklara'; + $lang['strfind'] = 'Sök'; + $lang['stroptions'] = 'Alternativ'; + $lang['strrefresh'] = 'Uppdatera'; + $lang['strcollapse'] = 'Förminska'; + $lang['strexpand'] = 'Utöka'; + $lang['strdownload'] = 'Ladda ner'; + $lang['strdownloadgzipped'] = 'Ladda ner komprimerat med gzip'; + $lang['strinfo'] = 'Info'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Avancerat'; + $lang['strvariables'] = 'Variabler'; + $lang['strprocess'] = 'Process'; + $lang['strprocesses'] = 'Processer'; + $lang['strsetting'] = 'Inställning'; + $lang['strparameters'] = 'Parametrar'; + + // Error handling + $lang['strnotloaded'] = 'Du har inte kompilerat in korrekt databasstöd i din PHP-installation.'; + $lang['strbadconfig'] = 'Din config.inc.php är ej uppdaterad. Du mÃ¥ste Ã¥terskapa den frÃ¥n den nya config.inc.php-dist.'; + $lang['strbadencoding'] = 'Misslyckades att sätta klientkodning i databasen.'; + $lang['strbadschema'] = 'OtillÃ¥tet schema angett.'; + $lang['strinstatement'] = 'I pÃ¥stÃ¥ende:'; + $lang['strsqlerror'] = 'SQL fel:'; + $lang['strinvalidparam'] = 'OtillÃ¥tna scriptparametrar.'; + $lang['strnodata'] = 'Hittade inga rader.'; + $lang['strnoobjects'] = 'Hittade inga objekt.'; + $lang['strrownotunique'] = 'Ingen unik nyckel för denna rad.'; + + // Tables + $lang['strtable'] = 'Tabell'; + $lang['strtables'] = 'Tabeller'; + $lang['strshowalltables'] = 'Visa alla tabeller'; + $lang['strnotables'] = 'Hittade inga tabeller.'; + $lang['strnotable'] = 'Hittade ingen tabell.'; + $lang['strcreatetable'] = 'Skapa tabell'; + $lang['strtablename'] = 'Tabellnamn'; + $lang['strtableneedsname'] = 'Du mÃ¥ste ge ett namn till din tabell.'; + $lang['strtableneedsfield'] = 'Du mÃ¥ste ange minst ett fält.'; + $lang['strtableneedscols'] = 'tabeller kräver ett tillÃ¥tet antal kolumner.'; + $lang['strtablecreated'] = 'Tabell skapad.'; + $lang['strtablecreatedbad'] = 'Misslyckades med att skapa Tabell.'; + $lang['strconfdroptable'] = 'Är du säker pÃ¥ att du vill ta bort tabellen "%s"?'; + $lang['strtabledropped'] = 'Tabellen borttagen.'; + $lang['strinsertrow'] = 'Infoga rad'; + $lang['strtabledroppedbad'] = 'Misslyckades med att ta bort tabellen.'; + $lang['strrowinserted'] = 'Rad infogad.'; + $lang['strconfemptytable'] = 'Är du säker pÃ¥ att du vill tömma tabellen "%s"?'; + $lang['strrowupdated'] = 'Rad uppdaterad.'; + $lang['strrowinsertedbad'] = 'Misslyckades att infoga rad.'; + $lang['strtableemptied'] = 'Tabellen tömd.'; + $lang['strrowupdatedbad'] = 'Misslyckades att uppdatera rad.'; + $lang['streditrow'] = 'Ändra rad'; + $lang['strrowdeleted'] = 'Rad raderad.'; + $lang['strrowdeletedbad'] = 'Misslyckades att radera rad.'; + $lang['strfield'] = 'Fält'; + $lang['strconfdeleterow'] = 'Är du säker pÃ¥ att du vill ta bort denna rad?'; + $lang['strnumfields'] = 'Antal fält'; + $lang['strsaveandrepeat'] = 'Infoga & Upprepa'; + $lang['strtableemptiedbad'] = 'Misslyckades med att tömma tabellen'; + $lang['strdeleterow'] = 'Radera rad'; + $lang['strfields'] = 'Fält'; + $lang['strfieldneedsname'] = 'Du mÃ¥ste namnge fältet'; + $lang['strcolumndropped'] = 'Kolumn raderad.'; + $lang['strselectallfields'] = 'Välj alla fält'; + $lang['strselectneedscol'] = 'Du mÃ¥ste visa minst en kolumn'; + $lang['strselectunary'] = 'Unära operander kan ej ha värden.'; + $lang['strcolumnaltered'] = 'Kolumn ändrad.'; + $lang['straltercolumn'] = 'Ändra kolumn'; + $lang['strcolumnalteredbad'] = 'Misslyckades att ändra kolumn.'; + $lang['strconfdropcolumn'] = 'Är du säker pÃ¥ att du vill radera kolumn "%s" frÃ¥n tabell "%s"?'; + $lang['strcolumndroppedbad'] = 'Misslyckades att radera kolumn.'; + $lang['straddcolumn'] = 'Lägg till kolumn'; + $lang['strcolumnadded'] = 'Kolumn inlagd.'; + $lang['strcolumnaddedbad'] = 'Misslyckades att lägga till kolumne.'; + $lang['strcascade'] = 'KASKAD'; + $lang['strdataonly'] = 'Endast Data'; + $lang['strtablealtered'] = 'Tabell ändrad.'; + $lang['strtablealteredbad'] = 'Misslyckades att ändra tabell.'; + + // Users + $lang['struser'] = 'Användare'; + $lang['strusers'] = 'Användare'; + $lang['strusername'] = 'Användarnamn'; + $lang['strpassword'] = 'Lösenord'; + $lang['strsuper'] = 'Superanvändare?'; + $lang['strcreatedb'] = 'Skapa Databas?'; + $lang['strexpires'] = 'UtgÃ¥ngsdatum'; + $lang['strsessiondefaults'] = 'Sessionsinställningar'; + $lang['strnewname'] = 'Nytt namn'; + $lang['strnousers'] = 'Hittade inga användare.'; + $lang['strrename'] = 'Döp om'; + $lang['struserrenamed'] = 'Användarnamn ändrat.'; + $lang['struserrenamedbad'] = 'Misslyckades att döpa om användare.'; + $lang['struserupdated'] = 'Användare uppdaterad.'; + $lang['struserupdatedbad'] = 'Misslyckades att uppdatera användare.'; + $lang['strshowallusers'] = 'Visa alla användare'; + $lang['strcreateuser'] = 'Skapa användare'; + $lang['struserneedsname'] = 'Du mÃ¥ste namnge användaren.'; + $lang['strconfdropuser'] = 'Är du säker pÃ¥ att du vill radera användaren "%s"?'; + $lang['strusercreated'] = 'Användare skapad.'; + $lang['strusercreatedbad'] = 'Misslyckades att skapa användare.'; + $lang['struserdropped'] = 'Användare raderad.'; + $lang['struserdroppedbad'] = 'Misslyckades att radera användare.'; + $lang['straccount'] = 'Konton'; + $lang['strchangepassword'] = 'Ändra lösenord'; + $lang['strpasswordchanged'] = 'Lösenord ändrat.'; + $lang['strpasswordchangedbad'] = 'Misslyckades att ändra lösenord.'; + $lang['strpasswordshort'] = 'För fÃ¥ tecken i lösenordet.'; + $lang['strpasswordconfirm'] = 'Lösenordet är inte samma som bekräftelsen.'; + $lang['strgroup'] = 'Grupp'; + $lang['strgroups'] = 'Grupper'; + $lang['strnogroup'] = 'Hittade ej grupp.'; + $lang['strnogroups'] = 'Hittade inga grupper.'; + $lang['strcreategroup'] = 'Skapa grupp'; + $lang['strshowallgroups'] = 'Visa alla grupper'; + $lang['strgroupneedsname'] = 'Du mÃ¥ste namnge din grupp.'; + $lang['strgroupcreated'] = 'Grupp skapad.'; + $lang['strgroupdropped'] = 'Grupp raderad.'; + $lang['strgroupcreatedbad'] = 'Misslyckades att skapa grupp.'; + $lang['strconfdropgroup'] = 'Är du säker pÃ¥ att du vill radera grupp "%s"?'; + $lang['strprivileges'] = 'Rättigheter'; + $lang['strgrant'] = 'TillÃ¥t'; + $lang['strgranted'] = 'Rättigheter ändrade.'; + $lang['strgroupdroppedbad'] = 'Misslyckades att radera grupp.'; + $lang['straddmember'] = 'Lägg till medlem'; + $lang['strmemberadded'] = 'Medlem inlagd.'; + $lang['strmemberaddedbad'] = 'Misslyckades att lägga till medlem.'; + $lang['strdropmember'] = 'Radera medlem'; + $lang['strconfdropmember'] = 'Är du säker pÃ¥ att du vill radera medlem "%s" frÃ¥n gruppen "%s"?'; + $lang['strmemberdropped'] = 'Medlem raderad.'; + $lang['strmemberdroppedbad'] = 'Misslyckades att radera medlem.'; + $lang['strprivilege'] = 'Rättighet'; + $lang['strnoprivileges'] = 'Detta objekt har standard ägarrättigheter.'; + $lang['strmembers'] = 'Medelemmar'; + $lang['strrevoke'] = 'Ta tillbaka'; + $lang['strgrantbad'] = 'Du mÃ¥ste ange minst en användare eller grupp och minst en rättighet.'; + $lang['strgrantfailed'] = 'Misslyckades att ändra rättigheter.'; + $lang['stralterprivs'] = 'Ändra rättigheter'; + $lang['strdatabase'] = 'Databas'; + $lang['strdatabasedropped'] = 'Databas raderad.'; + $lang['strdatabases'] = 'Databaser'; + $lang['strentersql'] = 'Ange SQL att köra:'; + $lang['strgrantor'] = 'TillstÃ¥ndsgivare'; + $lang['strasterisk'] = '*'; + $lang['strshowalldatabases'] = 'Visa alla databaser'; + $lang['strnodatabase'] = 'Hittade ingen databas.'; + $lang['strnodatabases'] = 'Hittade inga databaser.'; + $lang['strcreatedatabase'] = 'Skapa databas'; + $lang['strdatabasename'] = 'Databasnamn'; + $lang['strdatabaseneedsname'] = 'Du mÃ¥ste namnge databasen.'; + $lang['strdatabasecreated'] = 'Databas skapad.'; + $lang['strdatabasecreatedbad'] = 'Misslyckades att skapa databas.'; + $lang['strconfdropdatabase'] = 'Är du säker pÃ¥ att du vill radera databas "%s"?'; + $lang['strdatabasedroppedbad'] = 'Misslyckades att radera databas.'; + $lang['strsqlexecuted'] = 'SQL-kommando utfört.'; + $lang['strvacuumgood'] = 'Uppstädning utförd.'; + $lang['strvacuumbad'] = 'Uppstädning misslyckades.'; + $lang['stranalyzegood'] = 'Analysen lyckades.'; + $lang['stranalyzebad'] = 'Analysen misslyckades.'; + $lang['strstructureonly'] = 'Endast struktur'; + $lang['strstructureanddata'] = 'Struktur och data'; + + // Views + $lang['strview'] = 'Vy'; + $lang['strviews'] = 'Vyer'; + $lang['strshowallviews'] = 'Visa alla vyer'; + $lang['strnoview'] = 'Hittade ingen vy.'; + $lang['strnoviews'] = 'Hittade inga vyer.'; + $lang['strcreateview'] = 'Skapa vy'; + $lang['strviewname'] = 'Vynamn'; + $lang['strviewneedsname'] = 'Du mÃ¥ste namnge Vy.'; + $lang['strviewneedsdef'] = 'Du mÃ¥ste ange en definition för din vy.'; + $lang['strviewcreated'] = 'Vy skapad.'; + $lang['strviewcreatedbad'] = 'Misslyckades att skapa vy.'; + $lang['strconfdropview'] = 'Är du säker pÃ¥ att du vill radera vyn "%s"?'; + $lang['strviewdropped'] = 'Vy raderad.'; + $lang['strviewdroppedbad'] = 'Misslyckades att radera vy.'; + $lang['strviewupdated'] = 'Vy uppdaterad.'; + $lang['strviewupdatedbad'] = 'Misslyckades att uppdatera vy.'; + $lang['strviewlink'] = 'Länkade nycklar'; + $lang['strviewconditions'] = 'Ytterligare villkor'; + + // Sequences + $lang['strsequence'] = 'Sekvens'; + $lang['strsequences'] = 'Sekvenser'; + $lang['strshowallsequences'] = 'Visa alla sekvenser'; + $lang['strnosequence'] = 'Hittade ingen sekvens.'; + $lang['strnosequences'] = 'Hittade inga sekvenser.'; + $lang['strcreatesequence'] = 'Skapa sekvens'; + $lang['strlastvalue'] = 'Senaste värde'; + $lang['strincrementby'] = 'Öka med'; + $lang['strstartvalue'] = 'Startvärde'; + $lang['strmaxvalue'] = 'Största värde'; + $lang['strminvalue'] = 'Minsta värde'; + $lang['strcachevalue'] = 'Värde pÃ¥ cache'; + $lang['strlogcount'] = 'Räkna log'; + $lang['striscycled'] = 'Är upprepad?'; + $lang['strsequenceneedsname'] = 'Du mÃ¥ste ge ett namn till din sekvens.'; + $lang['strsequencecreated'] = 'Sekvens skapad.'; + $lang['strsequencecreatedbad'] = 'Misslyckades att skapa sekvens.'; + $lang['strconfdropsequence'] = 'Är du säker pÃ¥ att du vill radera sekvensen "%s"?'; + $lang['strsequencedropped'] = 'Sekvensen borrtagen.'; + $lang['strsequencedroppedbad'] = 'Misslyckades att radera sekvens.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Index'; + $lang['strindexname'] = 'Indexnamn'; + $lang['strshowallindexes'] = 'Visa alla index'; + $lang['strnoindex'] = 'Hittade inget index.'; + $lang['strsequencereset'] = 'Nollställ sekvens.'; + $lang['strsequenceresetbad'] = 'Misslyckades att nollställa sekvens.'; + $lang['strnoindexes'] = 'Hittade inga index.'; + $lang['strcreateindex'] = 'Skapa index'; + $lang['strindexname'] = 'Indexnamn'; + $lang['strtabname'] = 'Tabellnamn'; + $lang['strcolumnname'] = 'Kolumnnamn'; + $lang['strindexneedsname'] = 'Du mÃ¥ste ge ett namn för ditt index'; + $lang['strindexneedscols'] = 'Det krävs ett giltigt antal kolumner för index.'; + $lang['strindexcreated'] = 'Index skapat'; + $lang['strindexcreatedbad'] = 'Misslyckades att skapa index.'; + $lang['strconfdropindex'] = 'Är du säker pÃ¥ att du vill radera index "%s"?'; + $lang['strindexdropped'] = 'Index raderat.'; + $lang['strindexdroppedbad'] = 'Misslyckades att radera index.'; + $lang['strkeyname'] = 'Nyckelvärdesnamn'; + $lang['struniquekey'] = 'Unikt nyckelvärde'; + $lang['strprimarykey'] = 'Primärnyckel'; + $lang['strindextype'] = 'Typ av index'; + $lang['strindexname'] = 'Indexnamn'; + $lang['strtablecolumnlist'] = 'Tabellkolumner'; + $lang['strindexcolumnlist'] = 'Indexkolumner'; + $lang['strconfcluster'] = 'Är du säker pÃ¥ att du vill klustra "%s"?'; + $lang['strclusteredgood'] = 'Klustring avslutad.'; + $lang['strclusteredbad'] = 'Klustring misslyckades.'; + + // Rules + $lang['strrules'] = 'Regler'; + $lang['strrule'] = 'Regel'; + $lang['strshowallrules'] = 'Visa alla regler'; + $lang['strnorule'] = 'Hittade ingen regel.'; + $lang['strnorules'] = 'Hittade inga regler.'; + $lang['strcreaterule'] = 'Skapa regel'; + $lang['strrulename'] = 'Regelnamn'; + $lang['strruleneedsname'] = 'Du mÃ¥ste ge ett namn till din regel.'; + $lang['strrulecreated'] = 'Regel skapad.'; + $lang['strrulecreatedbad'] = 'Misslyckades att skapa regel.'; + $lang['strconfdroprule'] = 'Är du säker pÃ¥ att du vill radera regel "%s" för "%s"?'; + $lang['strruledropped'] = 'Regel raderat.'; + $lang['strruledroppedbad'] = 'Misslyckades att radera regel.'; + + // Constraints + $lang['strconstraints'] = 'Begränsningar'; + $lang['strshowallconstraints'] = 'Visa alla begränsningar'; + $lang['strnoconstraints'] = 'Hittade inga begränsningar.'; + $lang['strcreateconstraint'] = 'Skapa begränsning'; + $lang['strconstraintcreated'] = 'Begränsning skapad.'; + $lang['strconstraintcreatedbad'] = 'Misslyckades att skapa begränsning.'; + $lang['strconfdropconstraint'] = 'Är du säker pÃ¥ att du vill radera begränsning "%s" för "%s"?'; + $lang['strconstraintdropped'] = 'Begränsning raderad.'; + $lang['strconstraintdroppedbad'] = 'Misslyckades att radera begränsning.'; + $lang['straddcheck'] = 'Lägg till en koll'; + $lang['strcheckneedsdefinition'] = 'En kollbegränsning behöver definieras.'; + $lang['strcheckadded'] = 'Kollbegränsning inlagd.'; + $lang['strcheckaddedbad'] = 'Misslyckades att lägga till en koll.'; + $lang['straddpk'] = 'Lägg till primärnyckel'; + $lang['strpkneedscols'] = 'Primärnyckel behöver minst en kolumn.'; + $lang['strpkadded'] = 'Primärnyckel inlagd.'; + $lang['strpkaddedbad'] = 'Misslyckades att lägga till primärnyckel.'; + $lang['stradduniq'] = 'Lägg till Unikt nyckelvärde'; + $lang['struniqneedscols'] = 'Unikt nyckelvärde behöver minst en kolumn.'; + $lang['struniqadded'] = 'Unikt nyckelvärde inlagt.'; + $lang['struniqaddedbad'] = 'Misslyckades att lägga till unikt nyckelvärde.'; + $lang['straddfk'] = 'Lägg till utomstÃ¥ende nyckel'; + $lang['strfkneedscols'] = 'UtomstÃ¥ende nyckel behöver minst en kolumn.'; + $lang['strfkneedstarget'] = 'UtomstÃ¥ende nycket behöver en mÃ¥ltabell.'; + $lang['strfkadded'] = 'UtomstÃ¥ende nyckel inlagd.'; + $lang['strfkaddedbad'] = 'Misslyckades att lägga till utomstÃ¥ende nyckel.'; + $lang['strfktarget'] = 'MÃ¥ltabell'; + $lang['strfkcolumnlist'] = 'Kolumner i nyckel'; + $lang['strondelete'] = 'VID RADERING'; + $lang['stronupdate'] = 'VID UPPDATERING'; + + // Functions + $lang['strfunction'] = 'Funktion'; + $lang['strfunctions'] = 'Funktioner'; + $lang['strshowallfunctions'] = 'Visa alla funktioner'; + $lang['strnofunction'] = 'Hittade ingen funktion.'; + $lang['strnofunctions'] = 'Hittade inga funktioner.'; + $lang['strcreatefunction'] = 'Skapa funktion'; + $lang['strfunctionname'] = 'Funktionsnamn'; + $lang['strreturns'] = 'Ã…terger'; + $lang['strarguments'] = 'Argument'; + $lang['strfunctionneedsname'] = 'Du mÃ¥ste namnge din funktion.'; + $lang['strfunctionneedsdef'] = 'Du mÃ¥ste definiera din funktion.'; + $lang['strfunctioncreated'] = 'Funktion skapad.'; + $lang['strfunctioncreatedbad'] = 'Misslyckades att skapa funktion.'; + $lang['strconfdropfunction'] = 'Är du säker pÃ¥ att du vill radera funktionen "%s"?'; + $lang['strproglanguage'] = 'ProgrammeringssprÃ¥k'; + $lang['strfunctiondropped'] = 'Funktionen raderad.'; + $lang['strfunctiondroppedbad'] = 'Misslyckades att radera funktion.'; + $lang['strfunctionupdated'] = 'Funktion uppdaterad.'; + $lang['strfunctionupdatedbad'] = 'Misslyckades att uppdatera funktion.'; + + // Triggers + $lang['strtrigger'] = 'Mekanism'; + $lang['strtriggers'] = 'Mekanismer'; + $lang['strshowalltriggers'] = 'Visa alla Mekanismer'; + $lang['strnotrigger'] = 'Hittade ingen mekanism.'; + $lang['strnotriggers'] = 'Hittade inga mekanismer.'; + $lang['strcreatetrigger'] = 'Skapa mekanism'; + $lang['strtriggerneedsname'] = 'Du mÃ¥ste namnge din mekanism.'; + $lang['strtriggerneedsfunc'] = 'Du mÃ¥ste specificera en funktion för din mekanism.'; + $lang['strtriggercreated'] = 'Mekanism skapad.'; + $lang['strtriggerdropped'] = 'Mekanism raderad.'; + $lang['strtriggercreatedbad'] = 'Misslyckades att skapa mekanism.'; + $lang['strconfdroptrigger'] = 'Är du säker pÃ¥ att du vill radera mekanismen "%s" pÃ¥ "%s"?'; + $lang['strtriggerdroppedbad'] = 'Misslyckades att radera mekanism.'; + + // Types + $lang['strtype'] = 'Typ'; + $lang['strstorage'] = 'Lagring'; + $lang['strtriggeraltered'] = 'Mekanism ändrad.'; + $lang['strtriggeralteredbad'] = 'Misslyckades att ändra mekanism.'; + $lang['strtypes'] = 'Typer'; + $lang['strtypeneedslen'] = 'Du mÃ¥ste ange typens längd.'; + $lang['strshowalltypes'] = 'Visa alla typer'; + $lang['strnotype'] = 'Hittade ingen typ.'; + $lang['strnotypes'] = 'Hittade inga typer.'; + $lang['strcreatetype'] = 'Skapa typ'; + $lang['strtypename'] = 'Namn pÃ¥ typen'; + $lang['strinputfn'] = 'Infogande funktion'; + $lang['stroutputfn'] = 'Funktion för utvärden'; + $lang['strpassbyval'] = 'GenomgÃ¥tt utvärdering?'; + $lang['stralignment'] = 'Justering'; + $lang['strelement'] = 'Element'; + $lang['strdelimiter'] = 'Avgränsare'; + $lang['strtypeneedsname'] = 'Du mÃ¥ste namnge din typ.'; + $lang['strtypecreated'] = 'Typ skapad'; + $lang['strtypecreatedbad'] = 'Misslyckades att skapa typ.'; + $lang['strconfdroptype'] = 'Är du säker pÃ¥ att du vill radera typen "%s"?'; + $lang['strtypedropped'] = 'Typ raderad.'; + $lang['strtypedroppedbad'] = 'Misslyckades att radera typ.'; + + // Schemas + $lang['strschema'] = 'Schema'; + $lang['strschemas'] = 'Scheman'; + $lang['strshowallschemas'] = 'Visa alla scheman'; + $lang['strnoschema'] = 'Hittade inget schema.'; + $lang['strnoschemas'] = 'Hittade inga scheman.'; + $lang['strcreateschema'] = 'Skapa Schema'; + $lang['strschemaname'] = 'Schemanamn'; + $lang['strschemaneedsname'] = 'Du mÃ¥ste namnge ditt Schema.'; + $lang['strschemacreated'] = 'Schema skapat'; + $lang['strschemacreatedbad'] = 'Misslyckades att skapa schema.'; + $lang['strconfdropschema'] = 'Är du säker pÃ¥ att du vill radera schemat "%s"?'; + $lang['strschemadropped'] = 'Schema raderat.'; + $lang['strschemadroppedbad'] = 'Misslyckades att radera schema.'; + + // Reports + $lang['strtopbar'] = '%s körs pÃ¥ %s:%s -- Du är inloggad som användare "%s"'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + + // Domains + $lang['strdomain'] = 'Domän'; + $lang['strdomains'] = 'Domäner'; + $lang['strshowalldomains'] = 'Visa alla domäner'; + $lang['strnodomains'] = 'Hittade inga domäner.'; + $lang['strcreatedomain'] = 'Skapa domän'; + $lang['strdomaindropped'] = 'Domän raderad.'; + $lang['strdomaindroppedbad'] = 'Misslyckades att radera domän.'; + $lang['strconfdropdomain'] = 'Är du säker pÃ¥ att du vill radera domänen "%s"?'; + $lang['strdomainneedsname'] = 'Du mÃ¥ste ange ett domännamn.'; + $lang['strdomaincreated'] = 'Domän skapad.'; + $lang['strdomaincreatedbad'] = 'Misslyckades att skapa domän.'; + $lang['strdomainaltered'] = 'Domän ändrad.'; + $lang['strdomainalteredbad'] = 'Misslyckades att ändra domän.'; + + // Operators + $lang['stroperator'] = 'Operand'; + $lang['stroperators'] = 'Operander'; + $lang['strshowalloperators'] = 'Visa alla operander'; + $lang['strnooperator'] = 'Hittade ingen operand.'; + $lang['strnooperators'] = 'Hittade inga operander.'; + $lang['strcreateoperator'] = 'Skapa operand'; + $lang['strleftarg'] = 'Arg Typ Vänster'; + $lang['strrightarg'] = 'Arg Typ Höger'; + $lang['strcommutator'] = 'Växlare'; + $lang['strnegator'] = 'Negerande'; + $lang['strrestrict'] = 'Spärra'; + $lang['strjoin'] = 'SlÃ¥ ihop'; + $lang['strhashes'] = 'Hashtabeller'; + $lang['strmerges'] = 'Sammanslagningar'; + $lang['strleftsort'] = 'Sortera vänster'; + $lang['strrightsort'] = 'Sortera höger'; + $lang['strlessthan'] = 'Mindre än'; + $lang['strgreaterthan'] = 'Större än'; + $lang['stroperatorneedsname'] = 'Du mÃ¥ste namnge operanden.'; + $lang['stroperatorcreated'] = 'Operand skapad'; + $lang['stroperatorcreatedbad'] = 'Misslyckades att skapa operand.'; + $lang['strconfdropoperator'] = 'Är du säker pÃ¥ att du vill radera operanden "%s"?'; + $lang['stroperatordropped'] = 'Operand raderad.'; + $lang['stroperatordroppedbad'] = 'Misslyckades att radera operand.'; + + // Casts + $lang['strcasts'] = 'Typomvandlingar'; + $lang['strnocasts'] = 'Hittade inga typomvandlingar.'; + $lang['strsourcetype'] = 'Källtyp'; + $lang['strtargettype'] = 'MÃ¥ltyp'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'Tilldelat i'; + $lang['strbinarycompat'] = '(Binärt kompatibel)'; + + // Conversions + $lang['strconversions'] = 'Omkodningar'; + $lang['strnoconversions'] = 'Hittade inga omkodningar.'; + $lang['strsourceencoding'] = 'Källkodning'; + $lang['strtargetencoding'] = 'MÃ¥lkodning'; + + // Languages + $lang['strlanguages'] = 'SprÃ¥k'; + $lang['strnolanguages'] = 'Hittade inga sprÃ¥k.'; + $lang['strtrusted'] = 'PÃ¥litlig(a)'; + + // Info + $lang['strnoinfo'] = 'Ingen information tillgänglig.'; + $lang['strreferringtables'] = 'Refererande tabeller'; + $lang['strparenttables'] = 'OvanstÃ¥ende tabeller'; + $lang['strchildtables'] = 'Underliggande tabeller'; + + // Aggregates + $lang['straggregates'] = 'Sammanslagningar'; + $lang['strnoaggregates'] = 'Hittade inga sammanslagningar.'; + $lang['stralltypes'] = '(Alla typer)'; + + // Operator Classes + $lang['stropclasses'] = 'Op Klasser'; + $lang['strnoopclasses'] = 'Hittade inga operandklasser.'; + $lang['straccessmethod'] = 'Kopplingsmetod'; + + // Stats and performance + $lang['strrowperf'] = 'Radprestanda'; + $lang['strioperf'] = 'I/O Prestanda'; + $lang['stridxrowperf'] = 'Index Radprestanda'; + $lang['stridxioperf'] = 'Index I/O Prestanda'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sekventiell'; + $lang['strscan'] = 'Scanna'; + $lang['strread'] = 'Läs'; + $lang['strfetch'] = 'Hämta'; + $lang['strheap'] = 'Bunt'; + $lang['strtoast'] = 'Bränn'; + $lang['strtoastindex'] = 'Bränn Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Rader'; + + // Miscellaneous + $lang['strtopbar'] = '%s Körs pÃ¥ %s:%s -- Du är inloggad som användare "%s", %s'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Hjälp'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/synch b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/synch new file mode 100755 index 00000000..7e07d226 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/synch @@ -0,0 +1,71 @@ +#!/bin/bash +# This script will synchronize language file with the master +# english translation using diff(1) utility. +# It doesn't translate strings, only inserts english versions +# to proper positions and deletes removed. And it doesn't +# synchronize commented lines. +# You need to have GNU ed and diff installed in $PATH. +# +# Usage: synch +# +# is the filename without the .php extension +# +# BTW, diff should create better ed scripts than previous +# version of synch (that one with awk code). If it will not, +# be frightened about patching Linux kernel sources ;-) + +if [ -z $1 ] ; then + echo "You must tell me which language I should synchronize." + echo -e "for example: \n\t$0 polish" + exit +fi + +if [ ! -f $1.php ] ; then + echo "Sorry, I cannot find $1.php" + exit +fi + +echo "Making backup of $1.php" +cp $1.php $1.php.old + +# Find variables names ( "$lang['strfoo']" part ) +cat english.php | awk -F"=" '{print $1}' > english.tmp +cat $1.php | awk -F"=" '{print $1}' > $1.tmp + +# diff variable names and create ed script +diff --ignore-case --ignore-all-space --ignore-blank-lines \ + --ignore-matching-lines="*" \ + --ignore-matching-lines="[^:]//" \ + --ed \ + $1.tmp english.tmp > diff.ed + +# No more need for .tmp files +rm *.tmp + +# Add english values and ed destination file +cat diff.ed | awk ' +function grep_n(what, where, n, ln) { +# Returns line with searched text + + while ( (getline line < where ) > 0 ) { + if (index(line, what)>0) { + gsub("^\t","",what); + split(line,a,"="); + print what" = "a[2]; + } +} + close(where); +} + +BEGIN { FS="=" } + +/\$lang/{ grep_n($1, "english.php") ; + next; } + + { print } +END { print "w" }' \ +| ed $1.php + +# Clean temporary files +rm diff.ed + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/translations.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/translations.php new file mode 100644 index 00000000..4c694286 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/translations.php @@ -0,0 +1,86 @@ + 'Afrikaans', + 'arabic' => 'عربي', + 'catalan' => 'Català', + 'chinese-tr' => '繁體中文', + 'chinese-sim' => '简体中文', + 'chinese-utf8-zh_TW' => '正體中文(UTF-8)', + 'chinese-utf8-zh_CN' => '简体中文(UTF-8)', + 'czech' => 'Česky', + 'danish' => 'Danish', + 'dutch' => 'Nederlands', + 'english' => 'English', + 'french' => 'Français', + 'galician' => 'Galego', + 'german' => 'Deutsch', + 'greek' => 'Ελληνικά', + 'hebrew' => 'Hebrew', + 'hungarian' => 'Magyar', + 'italian' => 'Italiano', + 'japanese' => '日本語', + 'lithuanian' => 'Lietuvių', + 'mongol' => 'Mongolian', + 'polish' => 'Polski', + 'portuguese-br' => 'Português-Brasileiro', + 'romanian' => 'Română', + 'russian' => 'Русский', + 'russian-utf8' => 'Русский (UTF-8)', + 'slovak' => 'Slovensky', + 'swedish' => 'Svenska', + 'spanish' => 'Español', + 'turkish' => 'Türkçe', + 'ukrainian' => 'Українська' + ); + + + // ISO639 language code to language file mapping. + // See http://www.w3.org/WAI/ER/IG/ert/iso639.htm for language codes + + // If it's available 'language-country', but not general + // 'language' translation (eg. 'portuguese-br', but not 'portuguese') + // specify both 'la' => 'language-country' and 'la-co' => 'language-country'. + + $availableLanguages = array( + 'af' => 'afrikaans', + 'ar' => 'arabic', + 'ca' => 'catalan', + 'zh' => 'chinese-tr', + 'zh-cn' => 'chinese-sim', + 'utf8-zh-cn' => 'chinese-utf8-cn', + 'utf8-zh-tw' => 'chinese-utf8-tw', + 'cs' => 'czech', + 'da' => 'danish', + 'nl' => 'dutch', + 'en' => 'english', + 'fr' => 'french', + 'gl' => 'galician', + 'de' => 'german', + 'el' => 'greek', + 'he' => 'hebrew', + 'hu' => 'hungarian', + 'it' => 'italian', + 'ja' => 'japanese', + 'lt' => 'lithuanian', + 'mn' => 'mongol', + 'pl' => 'polish', + 'pt' => 'portuguese-br', + 'pt-br' => 'portuguese-br', + 'ro' => 'romanian', + 'ru' => 'russian', + 'sk' => 'slovak', + 'sv' => 'swedish', + 'es' => 'spanish', + 'tr' => 'turkish', + 'uk' => 'ukrainian' + ); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/turkish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/turkish.php new file mode 100644 index 00000000..83773890 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/turkish.php @@ -0,0 +1,641 @@ +>'; + $lang['strfailed'] = 'BaÅŸarısız oldu.'; + $lang['strcreate'] = 'Yarat'; + $lang['strcreated'] = 'Yaratıldı'; + $lang['strcomment'] = 'Yorum'; + $lang['strlength'] = 'Uzunluk'; + $lang['strdefault'] = 'Ön tanımlı deÄŸer'; + $lang['stralter'] = 'DeÄŸiÅŸtir'; + $lang['strok'] = 'Tamam'; + $lang['strcancel'] = 'Ä°ptal Et'; + $lang['strsave'] = 'Kaydet'; + $lang['strreset'] = 'Temizle'; + $lang['strinsert'] = 'Ekle'; + $lang['strselect'] = 'Seç'; + $lang['strdelete'] = 'Sil'; + $lang['strupdate'] = 'Güncelle'; + $lang['strreferences'] = 'References'; + $lang['stryes'] = 'Evet'; + $lang['strno'] = 'Hayır'; + $lang['strtrue'] = 'TRUE'; + $lang['strfalse'] = 'FALSE'; + $lang['stredit'] = 'Düzenle'; + $lang['strcolumn'] = 'KolonF'; + $lang['strcolumns'] = 'Kolonlar'; + $lang['strrows'] = 'satır'; + $lang['strrowsaff'] = 'satır iÅŸlendi.'; + $lang['strobjects'] = 'nesne(ler)'; + $lang['strback'] = 'Geri'; + $lang['strqueryresults'] = 'Sorgu sonuçları'; + $lang['strshow'] = 'Göster'; + $lang['strempty'] = 'BoÅŸalt'; + $lang['strlanguage'] = 'Dil'; + $lang['strencoding'] = 'Karakter kodlaması'; + $lang['strvalue'] = 'DeÄŸer'; + $lang['strunique'] = 'Tekil'; + $lang['strprimary'] = 'Birincil'; + $lang['strexport'] = 'Export'; + $lang['strimport'] = 'Import'; + $lang['strallowednulls'] = 'Ä°zin verilen NULL karakterler'; + $lang['strbackslashn'] = '\N'; + $lang['strnull'] = 'Null'; + $lang['strnull'] = 'NULL (sözcük)'; + $lang['stremptystring'] = 'BoÅŸ metin/alan'; + $lang['strsql'] = 'SQL'; + $lang['stradmin'] = 'Yönetici'; + $lang['strvacuum'] = 'Vacuum'; + $lang['stranalyze'] = 'Analyze'; + $lang['strclusterindex'] = 'Cluster'; + $lang['strclustered'] = 'Cluster edildi mi?'; + $lang['strreindex'] = 'Reindex'; + $lang['strrun'] = 'Çalıştır'; + $lang['stradd'] = 'Ekle'; + $lang['strremove'] = 'Kaldır'; + $lang['strevent'] = 'Event'; + $lang['strwhere'] = 'Where'; + $lang['strinstead'] = 'Do Instead'; + $lang['strwhen'] = 'When'; + $lang['strformat'] = 'Format'; + $lang['strdata'] = 'Veri'; + $lang['strconfirm'] = 'Onayla'; + $lang['strexpression'] = 'Ä°fade'; + $lang['strellipsis'] = '...'; + $lang['strseparator'] = ': '; + $lang['strexpand'] = 'GeniÅŸlet'; + $lang['strcollapse'] = 'Dar görünüm'; + $lang['strexplain'] = 'Explain'; + $lang['strexplainanalyze'] = 'Explain Analyze'; + $lang['strfind'] = 'Bul'; + $lang['stroptions'] = 'Seçenekler'; + $lang['strrefresh'] = 'Yenile'; + $lang['strdownload'] = 'Ä°ndir'; + $lang['strdownloadgzipped'] = 'gzip ile sıkıştırılmış halde indir'; + $lang['strinfo'] = 'Bilgi'; + $lang['stroids'] = 'OIDler'; + $lang['stradvanced'] = 'GeliÅŸmiÅŸ'; + $lang['strvariables'] = 'DeÄŸiÅŸkenler'; + $lang['strprocess'] = 'Süreç'; + $lang['strprocesses'] = 'Süreçler'; + $lang['strsetting'] = 'Ayar'; + $lang['streditsql'] = 'SQL Düzenle'; + $lang['strruntime'] = 'Toplam çalışma süresi: %s ms'; + $lang['strpaginate'] = 'Sonuçları sayfalandır.'; + $lang['struploadscript'] = 'ya da bir SQL betiÄŸi yükleyin:'; + $lang['strstarttime'] = 'BaÅŸlangıç zamanı'; + $lang['strfile'] = 'Dosya'; + $lang['strfileimported'] = 'Dosya import edildi.'; + $lang['strtrycred'] = 'GiriÅŸ bilgilerini tüm sunucular için kullan'; +$lang['strexecute'] = 'Execute'; + + // Error handling + $lang['strnoframes'] = 'Bu uygulama en iyi olarak frame destekli bir tarayıcı ile kullanılabilir; ancak frameler ile kullanmak istemiyorsanız aÅŸağıdaki linke tıklayabilirsiniz.'; + $lang['strnoframeslink'] = 'Frame olmadan kullan'; + $lang['strbadconfig'] = 'config.inc.php dosyaniz güncel deÄŸil. Bu dosyayı yeni config.inc.php-dist dosyasından yaratmanız gerekmektedir.'; + $lang['strnotloaded'] = 'PHP kurulumunuzda PostgreSQL desteÄŸi bulunamamıştır.'; + $lang['strpostgresqlversionnotsupported'] = 'Bu PostgreSQL sürümü desteklenmemektedir. Lütfen %s ya da üstü bir sürüme güncelleyiniz.'; + $lang['strbadschema'] = 'Geçersiz ÅŸema.'; + $lang['strbadencoding'] = 'Ä°stemci dil kodlamasını ayarlamaya çalışırken bir hata oluÅŸtu.'; + $lang['strsqlerror'] = 'SQL hatası:'; + $lang['strinstatement'] = 'Ãœstteki hata, aÅŸağıdaki ifade içinde oluÅŸtu:'; + $lang['strinvalidparam'] = 'Geçersiz betik parametreleri.'; + $lang['strnodata'] = 'Satır bulunamadı.'; + $lang['strnoobjects'] = 'Hiçbir nesne bulunamadı..'; + $lang['strrownotunique'] = 'Bu satır için hiçbir tekil belirtici bulunamadı.'; + $lang['strnouploads'] = 'Dosya yükleme özelliÄŸi etkin deÄŸil.'; + $lang['strimporterror'] = 'Import hatası.'; + $lang['strimporterror-fileformat'] = 'Import hatası: Dosya tipi otomatik olarak belirlenemedi.'; + $lang['strimporterrorline'] = '%s numaralı satırda import hatası.'; +$lang['strimporterrorline-badcolumnnum'] = 'Import error on line %s: Line does not possess the correct number of columns.'; +$lang['strimporterror-uploadedfile'] = 'Import error: File could not be uploaded to the server'; +$lang['strcannotdumponwindows'] = 'Dumping of complex table and schema names on Windows is not supported.'; + + // Tables + $lang['strtable'] = 'Tablo'; + $lang['strtables'] = 'Tablolar'; + $lang['strshowalltables'] = 'Tüm tabloları göster'; + $lang['strnotables'] = 'Veritabanında tablo bulunamadı.'; + $lang['strnotable'] = 'Veritabanında tablo bulunamadı.'; + $lang['strcreatetable'] = 'Yeni tablo yarat'; + $lang['strtablename'] = 'Tablo adı'; + $lang['strtableneedsname'] = 'Tablonuza bir ad vermeniz gerekmektedir.'; + $lang['strtableneedsfield'] = 'En az bir alan belirtmeniz gerekmektedir.'; + $lang['strtableneedscols'] = 'Geçerli miktarda kolon sayısı belirtmeniz gerekmektedir.'; + $lang['strtablecreated'] = 'Tablo yaratıldı.'; + $lang['strtablecreatedbad'] = 'Tablo yaratılamadı.'; + $lang['strconfdroptable'] = '"%s" tablosunu kaldırmak istediÄŸinizden emin misiniz?'; + $lang['strtabledropped'] = 'Tablo kaldırıldı.'; + $lang['strtabledroppedbad'] = 'Tablo kaldırılamadı.'; + $lang['strconfemptytable'] = '"%s" tablosunu boÅŸaltmak istediÄŸinizden emin misiniz?'; + $lang['strtableemptied'] = 'Tablo boÅŸaltıldı.'; + $lang['strtableemptiedbad'] = 'Tablo boÅŸaltılamadı.'; + $lang['strinsertrow'] = 'Yeni kayıt gir'; + $lang['strrowinserted'] = 'Yeni kayıt girildi.'; + $lang['strrowinsertedbad'] = 'Yeni kayıt girme iÅŸlemi baÅŸarısız oldu.'; + $lang['strrowduplicate'] = 'Satır ekleme baÅŸarısız oldu, birbirinin aynı iki kayıt girilmek istendi.'; + $lang['streditrow'] = 'Kayıdın içeriÄŸini deÄŸiÅŸtir.'; + $lang['strrowupdated'] = 'Kayıt güncellendi.'; + $lang['strrowupdatedbad'] = 'Kayıt güncelleme iÅŸleme baÅŸarısız oldu.'; + $lang['strdeleterow'] = 'Kaydı sil'; + $lang['strconfdeleterow'] = 'Bu kaydı silmek istediÄŸinize emin misiniz?'; + $lang['strrowdeleted'] = 'Kayıt silindi.'; + $lang['strrowdeletedbad'] = 'Kayıt silinme iÅŸlemi baÅŸarısız oldu.'; + $lang['strinsertandrepeat'] = 'Ekle ve Tekrarla'; + $lang['strnumcols'] = 'Kolon sayısı'; + $lang['strcolneedsname'] = 'Kolon için bir ad vermelisiniz.'; + $lang['strselectallfields'] = 'Tüm alanları seç'; + $lang['strselectneedscol'] = 'En az bir kolon iÅŸaretlemelisiniz'; + $lang['strselectunary'] = 'Unary operatörlerin deÄŸeri olamaz.'; + $lang['straltercolumn'] = 'Kolonu deÄŸiÅŸtir (alter)'; + $lang['strcolumnaltered'] = 'Kolon deÄŸiÅŸtirildi (alter)'; + $lang['strcolumnalteredbad'] = 'Kolon deÄŸiÅŸtirilme iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropcolumn'] = '"%s" kolonunu "%s" tablosundan silmek istediÄŸinize emin misiniz?'; + $lang['strcolumndropped'] = 'Kolon silindi.'; + $lang['strcolumndroppedbad'] = 'Kolon silme iÅŸlemi baÅŸarısız oldu.'; + $lang['straddcolumn'] = 'Yeni kolon ekle'; + $lang['strcolumnadded'] = 'Kolon eklendi.'; + $lang['strcolumnaddedbad'] = 'Kolon eklenemedi.'; + $lang['strcascade'] = 'CASCADE'; + $lang['strtablealtered'] = 'Tablo alter edildi..'; + $lang['strtablealteredbad'] = 'Tablo alteration iÅŸlemi baÅŸarısız oldu.'; + $lang['strdataonly'] = 'Sadece veri'; + $lang['strstructureonly'] = 'Sadece yapı'; + $lang['strstructureanddata'] = 'Yapı ve veri'; + $lang['strtabbed'] = 'Tabbed'; + $lang['strauto'] = 'Otomatik'; + $lang['strconfvacuumtable'] = '"%s" tablosunu vakumlamak istediÄŸiniz emin misiniz?'; + $lang['strestimatedrowcount'] = 'Yaklaşık satır sayısı'; + + // Users + $lang['struser'] = 'Kullanıcı'; + $lang['strusers'] = 'Kullanıcılar'; + $lang['strusername'] = 'Kullanıcı Adı'; + $lang['strpassword'] = 'Åžifresi'; + $lang['strsuper'] = 'Superuser mı?'; + $lang['strcreatedb'] = 'Veritabanı yaratabilsin mi?'; + $lang['strexpires'] = 'Expires'; + $lang['strsessiondefaults'] = 'Oturum varsayılanları'; + $lang['strnousers'] = 'Hiçbir kullanıcı bulunamadı.'; + $lang['struserupdated'] = 'Kullanıcı güncellendi.'; + $lang['struserupdatedbad'] = 'Kullanıcı güncelleme iÅŸlemi baÅŸarısız oldu.'; + $lang['strshowallusers'] = 'Tüm kullanıcıları göster.'; + $lang['strcreateuser'] = 'Yeni kullanıcı yarat'; + $lang['struserneedsname'] = 'Kullanıcınız için bir ad vermelisiniz.'; + $lang['strusercreated'] = 'Kullanıcı yaratıldı.'; + $lang['strusercreatedbad'] = 'Kullanıcı yaratılma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropuser'] = '"%s" kullanıcısını silmek istediÄŸinize emin misiniz?'; + $lang['struserdropped'] = 'Kullanıcı silindi.'; + $lang['struserdroppedbad'] = 'Kullanıcı silme iÅŸlemi baÅŸarısız oldu.'; + $lang['straccount'] = 'Hesap'; + $lang['strchangepassword'] = 'Åžifre DeÄŸiÅŸtir'; + $lang['strpasswordchanged'] = 'Åžifre deÄŸiÅŸtirildi.'; + $lang['strpasswordchangedbad'] = 'Åžifre deÄŸiÅŸtirme baÅŸarısız oldu.'; + $lang['strpasswordshort'] = 'Åžifre çok kısa.'; + $lang['strpasswordconfirm'] = 'Åžifreler uyuÅŸmadı.'; + + // Groups + $lang['strgroup'] = 'Grup'; + $lang['strgroups'] = 'Gruplar'; + $lang['strnogroup'] = 'Grup bulunamadı.'; + $lang['strnogroups'] = 'Grup bulunamadı.'; + $lang['strcreategroup'] = 'Yeni grup yarat'; + $lang['strshowallgroups'] = 'Tüm grupları göster'; + $lang['strgroupneedsname'] = 'Grup yaratabilmek için bir ad vermelisiniz.'; + $lang['strgroupcreated'] = 'Grup yaratıldı.'; + $lang['strgroupcreatedbad'] = 'Grup yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropgroup'] = '"%s" grubunu silmek istediÄŸinize emin misiniz?'; + $lang['strgroupdropped'] = 'Grup silindi.'; + $lang['strgroupdroppedbad'] = 'Grup silme iÅŸlemi baÅŸarısız oldu.'; + $lang['strmembers'] = 'Ãœyeler'; + $lang['straddmember'] = 'Ãœye ekle'; + $lang['strmemberadded'] = 'Ãœye eklendi.'; + $lang['strmemberaddedbad'] = 'Ãœye ekleme baÅŸarısız oldu.'; + $lang['strdropmember'] = 'Ãœyeyi kaldır'; + $lang['strconfdropmember'] = '"%s" üyesini "%s" grubundan silmek istediÄŸinize emin misiniz?'; + $lang['strmemberdropped'] = 'Ãœye silindi.'; + $lang['strmemberdroppedbad'] = 'Ãœye silme baÅŸarısız oldu.'; + + // Privilges + $lang['strprivilege'] = 'Ä°zni'; + $lang['strprivileges'] = 'Ä°zinler'; + $lang['strnoprivileges'] = 'Bu nesnenin bir izni yoktur.'; + $lang['strgrant'] = 'Ä°zni ver'; + $lang['strrevoke'] = 'Ä°zni kaldır'; + $lang['strgranted'] = 'Ä°zimler verildi.'; + $lang['strgrantfailed'] = 'Ä°zinlerin grant iÅŸlemi baÅŸarısız oldu.'; + + $lang['strgrantbad'] = 'En az bir kullanıcı ya da grup ve en az bir izin belirtmelisiniz.'; + $lang['strgrantor'] = 'Grantor'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'Veritabanı'; + $lang['strdatabases'] = 'Veritabanları'; + $lang['strshowalldatabases'] = 'Tüm veritabanlarını göster'; + $lang['strnodatabase'] = 'Veritabanı bulunamadı.'; + $lang['strnodatabases'] = 'Veritabanı bulunamadı.'; + $lang['strcreatedatabase'] = 'Veritabanı yarat'; + $lang['strdatabasename'] = 'Veritabanı adı'; + $lang['strdatabaseneedsname'] = 'Veritabanınıza bir ad vermelisiniz.'; + $lang['strdatabasecreated'] = 'Veritabanı yaratıldı.'; + $lang['strdatabasecreatedbad'] = 'Veritabanı yaratılamadı.'; + $lang['strconfdropdatabase'] = '"%s" veritabanını kaldırmak istediÄŸinize emin misiniz?'; + $lang['strdatabasedropped'] = 'Veritabanı kaldırıldı.'; + $lang['strdatabasedroppedbad'] = 'Veritabanı kaldırma baÅŸarısız oldu.'; + $lang['strentersql'] = 'Veritabanı üzerinde çalıştırılacak sorgu/sorguları aÅŸağıya yazınız:'; + $lang['strsqlexecuted'] = 'SQL çalıştırıldı.'; + $lang['strvacuumgood'] = 'Vacuum tamamlandı.'; + $lang['strvacuumbad'] = 'Vacuum iÅŸlemi baÅŸarısız oldu.'; + $lang['stranalyzegood'] = 'Analyze iÅŸlemi tamamlandı.'; + $lang['stranalyzebad'] = 'Analyze iÅŸlemi baÅŸarısız oldu.'; + $lang['strreindexgood'] = 'Reindex tamamlandı.'; + $lang['strreindexbad'] = 'Reindex baÅŸarısız oldu.'; + $lang['strfull'] = 'Full'; + $lang['strfreeze'] = 'Freeze'; + $lang['strforce'] = 'Force'; + $lang['strsignalsent'] = 'Sinyal gönderildi.'; + $lang['strsignalsentbad'] = 'Sinyal gönderme iÅŸlemi baÅŸarısız oldu'; + $lang['strallobjects'] = 'Tüm nesneler'; + $lang['strdatabasealtered'] = 'Veritabanı deÄŸiÅŸtirildi.'; + $lang['strdatabasealteredbad'] = 'Veritabanı deÄŸiÅŸtirme baÅŸarısız oldu.'; + + // Views + $lang['strview'] = 'View'; + $lang['strviews'] = 'Viewlar'; + $lang['strshowallviews'] = 'Tüm viewları göster'; + $lang['strnoview'] = 'Bir view bulunamadı.'; + $lang['strnoviews'] = 'Bir view bulunamadı.'; + $lang['strcreateview'] = 'View yarat'; + $lang['strviewname'] = 'View adı'; + $lang['strviewneedsname'] = 'View için bir ad belirtmelisiniz.'; + $lang['strviewneedsdef'] = 'View için bir tanım belirtmelisiniz.'; + $lang['strviewneedsfields'] = 'View içinde görünmesini istediÄŸiniz kolonları belirtmelisiniz.'; + $lang['strviewcreated'] = 'View yaratıldı.'; + $lang['strviewcreatedbad'] = 'View yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropview'] = '"%s" viewini kaldırmak istediÄŸinize emin misiniz?'; + $lang['strviewdropped'] = 'View kaldırıldı.'; + $lang['strviewdroppedbad'] = 'View kaldırma iÅŸlemi baÅŸarısız oldu.'; + $lang['strviewupdated'] = 'View güncellendi.'; + $lang['strviewupdatedbad'] = 'View güncelleme iÅŸlemi baÅŸarısız oldu.'; + $lang['strviewlink'] = 'Linking Keys'; + $lang['strviewconditions'] = 'Ek durumlar'; + $lang['strcreateviewwiz'] = 'Sihirbaz ile view yaratın'; + + // Sequences + $lang['strsequence'] = 'Sequence'; + $lang['strsequences'] = 'Sequences'; + $lang['strshowallsequences'] = 'Show all sequences'; + $lang['strnosequence'] = 'No sequence found.'; + $lang['strnosequences'] = 'No sequences found.'; + $lang['strcreatesequence'] = 'Create sequence'; + $lang['strlastvalue'] = 'Son deÄŸer'; + $lang['strincrementby'] = 'Arttırma deÄŸeri'; + $lang['strstartvalue'] = 'BaÅŸlangıç DeÄŸeri'; + $lang['strmaxvalue'] = 'Max DeÄŸer'; + $lang['strminvalue'] = 'Min DeÄŸer'; + $lang['strcachevalue'] = 'Cache DeÄŸeri'; + $lang['strlogcount'] = 'Log Count'; + $lang['striscycled'] = 'Is Cycled?'; + $lang['strsequenceneedsname'] = 'Sequence için bir ad belirtmelisiniz.'; + $lang['strsequencecreated'] = 'Sequence yaratıldı.'; + $lang['strsequencecreatedbad'] = 'Sequence yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropsequence'] = '"%s" sequence ini kaldırmak istediÄŸinize emin misiniz?'; + $lang['strsequencedropped'] = 'Sequence kaldırıldı.'; + $lang['strsequencedroppedbad'] = 'Sequence kaldırma iÅŸlemi baÅŸarısız oldu.'; + $lang['strsequencereset'] = 'Sequence sıfırlandı.'; + $lang['strsequenceresetbad'] = 'Sequence sıfırlama baÅŸarısız oldu.'; + + // Indexes + $lang['strindex'] = 'Index'; + $lang['strindexes'] = 'Indeksler'; + $lang['strindexname'] = 'Indeks adı'; + $lang['strshowallindexes'] = 'Tüm indeksleri göster'; + $lang['strnoindex'] = 'Hiçbir indeks bulunamadı.'; + $lang['strnoindexes'] = 'Hiçbir indeks bulunamadı.'; + $lang['strcreateindex'] = 'Indeks yarat'; + $lang['strtabname'] = 'Tab Adı'; + $lang['strcolumnname'] = 'Kolon adı'; + $lang['strindexneedsname'] = 'Indeksinize bir ad vermeniz gerekmektedir.'; + $lang['strindexneedscols'] = 'Geçerli kolın sayısı vermeniz gerekmektedir.'; + $lang['strindexcreated'] = 'Indeks yaratıldı.'; + $lang['strindexcreatedbad'] = 'Index creation failed.'; + $lang['strconfdropindex'] = '"%s" indeksini kaldırmak istediÄŸinize emin misiniz?'; + $lang['strindexdropped'] = 'Indeks kaldırıldı.'; + $lang['strindexdroppedbad'] = 'Indeks kaldırılamadı.'; + $lang['strkeyname'] = 'Anahtar adı'; + $lang['struniquekey'] = 'Tekil (Unique) Anahtar'; + $lang['strprimarykey'] = 'Birincil Anahtar (Primary Key)'; + $lang['strindextype'] = 'Indeksin tipi'; + $lang['strtablecolumnlist'] = 'Tablodaki kolonlar'; + $lang['strindexcolumnlist'] = 'Indeksteki kolonlar'; + $lang['strconfcluster'] = '"%s" tablosunu cluster etmek istiyor musunuz?'; + $lang['strclusteredgood'] = 'Cluster tamamlandı.'; + $lang['strclusteredbad'] = 'Cluster baÅŸarısız oldu.'; + $lang['strcluster'] = 'Küme'; + + // Rules + $lang['strrules'] = 'Rules'; + $lang['strrule'] = 'Rule'; + $lang['strshowallrules'] = 'Show all Rules'; + $lang['strnorule'] = 'Rule bulunamadı.'; + $lang['strnorules'] = 'Rule bulunamadı.'; + $lang['strcreaterule'] = 'Rule yarat'; + $lang['strrulename'] = 'Rule adı'; + $lang['strruleneedsname'] = 'Rule için bir ad belirtmelisiniz.'; + $lang['strrulecreated'] = 'Rule yaratıldı.'; + $lang['strrulecreatedbad'] = 'Rule yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdroprule'] = '"%s" kuralını "%s" tablosundan silmek istediÄŸinize emin misiniz?'; + $lang['strruledropped'] = 'Rule silindi'; + $lang['strruledroppedbad'] = 'Rule silinme iÅŸlemi baÅŸarısız oldu.'; + + // Constraints + $lang['strconstraint'] = 'Kısıtlama'; + $lang['strconstraints'] = 'Kısıtlamalar'; + $lang['strshowallconstraints'] = 'Tüm kısıtlamaları (constraint) göster.'; + $lang['strnoconstraints'] = 'Hiçbir kısıtlama (constraint) bulunamadı.'; + $lang['strcreateconstraint'] = 'Kısıtlama (Constraint) yarat'; + $lang['strconstraintcreated'] = 'Kısıtlama (Constraint) yaratıldı.'; + $lang['strconstraintcreatedbad'] = 'Kısıtlama (Constraint) yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropconstraint'] = '"%s" üzerindeki "%s" kısıtlamasını (constraint) kaldırmak istiyor musunuz?'; + $lang['strconstraintdropped'] = 'Kısıtlama (Constraint) kaldırıldı'; + $lang['strconstraintdroppedbad'] = 'Kısıtlama (Constraint) iÅŸlemi baÅŸarısız oldu.'; + $lang['straddcheck'] = 'Kontrol (Check) ekle'; + $lang['strcheckneedsdefinition'] = 'Kontrol (Check) kısıtlaması (constraint) için bir tanım girilmelidir.'; + $lang['strcheckadded'] = 'Kontrol kısıtlaması (Check constraint) eklendi.'; + $lang['strcheckaddedbad'] = 'Kontrol kısıtlaması (Check constraint) ekleme iÅŸlemi baÅŸarısız oldu.'; + $lang['straddpk'] = 'Birincil Anahtar Ekle'; + $lang['strpkneedscols'] = 'Birincil anahtar için en az bir kolon gereklidir.'; + $lang['strpkadded'] = 'Birincil anahtar eklendi.'; + $lang['strpkaddedbad'] = 'Birincil anahtar eklenemedi.'; + $lang['stradduniq'] = 'Tekil (Unique) anahtar ekle'; + $lang['struniqneedscols'] = 'Tekil anahtar yaratmak için en az bir kolon gerekir.'; + $lang['struniqadded'] = 'Tekil anahtar eklendi.'; + $lang['struniqaddedbad'] = 'Tekil anahtar eklenemedi.'; + $lang['straddfk'] = 'Ä°kincil anahtar ekle'; + $lang['strfkneedscols'] = 'Ä°kincil anahtar yaratmak için en az bir kolon gerekir.'; + $lang['strfkneedstarget'] = 'Ä°kincil anahtar hedef bir tablo gerektirir.'; + $lang['strfkadded'] = 'Ä°kincil anahtar eklendi.'; + $lang['strfkaddedbad'] = 'Ä°kincil anahtar eklenemedi.'; + $lang['strfktarget'] = 'Hedef tablo'; + + $lang['strfkcolumnlist'] = 'Anahtardaki kolonlar'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + // Functions + $lang['strfunction'] = 'Fonksiyon'; + $lang['strfunctions'] = 'Fonksiyonlar'; + $lang['strshowallfunctions'] = 'Tüm fonksiyonları göster'; + $lang['strnofunction'] = 'Fonksiyon bulunamadı.'; + $lang['strnofunctions'] = 'Fonksiyon bulunamadı.'; + $lang['strcreateplfunction'] = 'SQL/PL fonksiyonu yarat'; + $lang['strcreateinternalfunction'] = 'İç (internal) fonksiyon yarat'; + $lang['strcreatecfunction'] = 'C fonksiyonu yarat'; + $lang['strfunctionname'] = 'Fonksiyon adı'; + $lang['strreturns'] = 'Dönderilen deÄŸer'; + $lang['strarguments'] = 'Argümanlar'; + $lang['strproglanguage'] = 'Dil'; + $lang['strfunctionneedsname'] = 'Fonksiyona bir ad vermelisiniz.'; + $lang['strfunctionneedsdef'] = 'Fonksiyona bir tanım vermelisiniz.'; + $lang['strfunctioncreated'] = 'Fonksiyon yaratıldı.'; + $lang['strfunctioncreatedbad'] = 'Fonksiyon yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropfunction'] = '"%s" fonksiyonunu kaldırmak istediÄŸinize emin misiniz?'; + $lang['strfunctiondropped'] = 'Fonksiyon kaldırıldı.'; + $lang['strfunctiondroppedbad'] = 'Fonksiyon kaldırma iÅŸlemi baÅŸarısız oldu.'; + $lang['strfunctionupdated'] = 'Fonksiyon güncellendi.'; + $lang['strfunctionupdatedbad'] = 'Function güncelleme iÅŸlemi baÅŸarısız oldu.'; + $lang['strobjectfile'] = 'Nesne dosyası'; + $lang['strlinksymbol'] = 'BaÄŸlantı sembolü'; + + // Triggers + $lang['strtrigger'] = 'Trigger'; + $lang['strtriggers'] = 'Triggerlar'; + $lang['strshowalltriggers'] = 'Tüm triggerları göster'; + $lang['strnotrigger'] = 'Trigger bulunamadı.'; + $lang['strnotriggers'] = 'Trigger bulunamadı.'; + $lang['strcreatetrigger'] = 'Yeni trigger yarat'; + $lang['strtriggerneedsname'] = 'Trigger için bir ad belirtmelisiniz.'; + $lang['strtriggerneedsfunc'] = 'Trigger için bir fonksiyon belirtmelisiniz.'; + $lang['strtriggercreated'] = 'Trigger yaratıldı.'; + $lang['strtriggercreatedbad'] = 'Trigger yaratılamadı.'; + $lang['strconfdroptrigger'] = '"%s" triggerini "%s" tablosundan kaldırmak istediÄŸinize emin misiniz?'; + $lang['strtriggerdropped'] = 'Trigger silindi.'; + $lang['strtriggerdroppedbad'] = 'Trigger silinme iÅŸlemi baÅŸarısız oldu.'; + $lang['strtriggeraltered'] = 'Trigger deÄŸiÅŸtirildi.'; + $lang['strtriggeralteredbad'] = 'Trigger deÄŸiÅŸtirilme iÅŸlemi baÅŸarısız oldu.'; + $lang['strforeach'] = 'Her bir'; + + // Types + $lang['strtype'] = 'Veri tipi'; + $lang['strtypes'] = 'Veri tipleri'; + $lang['strshowalltypes'] = 'Tüm veri tiplerini göster'; + $lang['strnotype'] = 'Hiç veri tipi bulunamadı.'; + $lang['strnotypes'] = 'Hiç veri tipi bulunamadı.'; + $lang['strcreatetype'] = 'Yeni veri tipi yarat'; + $lang['strcreatecomptype'] = 'Karmaşık veri tipi yarat'; + $lang['strtypeneedsfield'] = 'En az bir alan belirtmelisiniz.'; + $lang['strtypeneedscols'] = 'Geçerli bir alan sayısı belirtmelisiniz.'; + $lang['strtypename'] = 'Veri tipi adı'; + $lang['strinputfn'] = 'GiriÅŸ (Input) fonksiyonu'; + $lang['stroutputfn'] = 'Çıkış (Output) fonksiyonu'; + $lang['strpassbyval'] = 'Passed by val?'; + $lang['stralignment'] = 'Alignment'; + $lang['strelement'] = 'Eleman'; + $lang['strdelimiter'] = 'Delimiter'; + $lang['strstorage'] = 'Storage'; + $lang['strfield'] = 'Alan'; + $lang['strnumfields'] = 'Alanların sayısı'; + + $lang['strtypeneedsname'] = 'Veri tipi için bir ad vermelisiniz.'; + $lang['strtypeneedslen'] = 'Veri tipiniz için bir uzunluk belirtmelisiniz.'; + $lang['strtypecreated'] = 'Veri tipi yaratıldı'; + $lang['strtypecreatedbad'] = 'Veri tipi yaratılamadı.'; + $lang['strconfdroptype'] = '"%s" veri tipini kaldırmak istediÄŸinize emin misiniz?'; + $lang['strtypedropped'] = 'Veri tipi kaldırıldı.'; + $lang['strtypedroppedbad'] = 'Veri tipi kaldırılamadı.'; + $lang['strflavor'] = 'Flavor'; + $lang['strbasetype'] = 'Base'; + $lang['strcompositetype'] = 'Composite'; + $lang['strpseudotype'] = 'Pseudo'; + + // Schemas + $lang['strschema'] = 'Åžema'; + $lang['strschemas'] = 'Åžemalar'; + $lang['strshowallschemas'] = 'Tüm ÅŸemaları göster'; + $lang['strnoschema'] = 'Bir ÅŸema bulunamadı.'; + $lang['strnoschemas'] = 'Bir ÅŸema bulunamadı.'; + $lang['strcreateschema'] = 'Åžema yarat'; + $lang['strschemaname'] = 'Åžema adı'; + $lang['strschemaneedsname'] = 'Åžema için bir ad belirtmelisiniz.'; + $lang['strschemacreated'] = 'Åžema yaratıldı'; + $lang['strschemacreatedbad'] = 'Åžema yaratma iÅŸlemi baÅŸarısız oldu'; + $lang['strconfdropschema'] = '"%s" ÅŸemasını kaldırmak istediÄŸinize emin misiniz?'; + $lang['strschemadropped'] = 'Åžema kaldırıldı.'; + $lang['strschemadroppedbad'] = 'Åžema kaldırma iÅŸlemi baÅŸarısız oldu.'; + $lang['strschemaaltered'] = 'Schema deÄŸiÅŸtirildi.'; + $lang['strschemaalteredbad'] = 'Schema deÄŸiÅŸtirilme iÅŸlemi baÅŸarısız oldu.'; + $lang['strsearchpath'] = 'Åžema arama yolu'; + + // Reports + $lang['strdomain'] = 'Domain'; + $lang['strdomains'] = 'Domainler'; + $lang['strshowalldomains'] = 'Tüm domainleri göster.'; + $lang['strnodomains'] = 'Hiçbir domain bulunamadı.'; + $lang['strcreatedomain'] = 'Domain yarat'; + $lang['strdomaindropped'] = 'Domain silindi.'; + $lang['strdomaindroppedbad'] = 'Domain silme baÅŸarısız oldu.'; + $lang['strconfdropdomain'] = '"%s" domain\'ini silmek istediÄŸinize emin misiniz??'; + $lang['strdomainneedsname'] = 'Domain için bir ad vermelisiniz.'; + $lang['strdomaincreated'] = 'Domain yaratıldı.'; + $lang['strdomaincreatedbad'] = 'Domain yaratma baÅŸarısız oldu.'; + $lang['strdomainaltered'] = 'Domain alter edildi.'; + $lang['strdomainalteredbad'] = 'Domain alter iÅŸlemi baÅŸarısız oldu.'; + + $lang['stroperator'] = 'Operatör'; + $lang['stroperators'] = 'Operatörler'; + $lang['strshowalloperators'] = 'Tüm operatörleri göster'; + $lang['strnooperator'] = 'Operatör bulunamadı.'; + $lang['strnooperators'] = 'Operatör bulunamadı.'; + $lang['strcreateoperator'] = 'Operatör yaratıldı.'; + $lang['strleftarg'] = 'Sol Arg Tipi'; + $lang['strrightarg'] = 'SaÄŸ Arg Tipi'; + $lang['strcommutator'] = 'Commutator'; + $lang['strnegator'] = 'Negator'; + $lang['strrestrict'] = 'Restrict'; + $lang['strjoin'] = 'Join'; + $lang['strhashes'] = 'Hashes'; + $lang['strmerges'] = 'Merges'; + $lang['strleftsort'] = 'Left sort'; + $lang['strrightsort'] = 'Right sort'; + $lang['strlessthan'] = 'küçüktür'; + $lang['strgreaterthan'] = 'büyüktür'; + $lang['stroperatorneedsname'] = 'Operatöre bir ad vermelisiniz.'; + $lang['stroperatorcreated'] = 'Operatör yaratıldı'; + $lang['stroperatorcreatedbad'] = 'Operatör yaratma iÅŸlemi baÅŸarısız oldu.'; + $lang['strconfdropoperator'] = '"%s" operatörünü kaldırmak istediÄŸinize emin misiniz?'; + $lang['stroperatordropped'] = 'Operatör kaldırıldı.'; + $lang['stroperatordroppedbad'] = 'Operator kaldırma iÅŸlemi baÅŸarısız oldu.'; + + // Casts + $lang['strcasts'] = 'Casts'; + $lang['strnocasts'] = 'Hiç cast bulunamadı.'; + $lang['strsourcetype'] = 'Kaynak tip'; + $lang['strtargettype'] = 'Hedef tip'; + $lang['strimplicit'] = 'Implicit'; + $lang['strinassignment'] = 'In assignment'; + $lang['strbinarycompat'] = '(Binary uyumlu)'; + + // Conversions + $lang['strconversions'] = 'Dönüşümleri'; + $lang['strnoconversions'] = 'Hiç dönüşüm bulunamadı.'; + $lang['strsourceencoding'] = 'Kaynak dil kodlaması'; + $lang['strtargetencoding'] = 'Hedef dil kodlaması'; + + // Languages + $lang['strlanguages'] = 'Diller'; + $lang['strnolanguages'] = 'Hiç bir dil bulunamadı.'; + $lang['strtrusted'] = 'Güvenilir'; + + // Info + $lang['strnoinfo'] = 'Hiç bir bilgi yok.'; + $lang['strreferringtables'] = 'Referring tables'; + $lang['strparenttables'] = 'Parent tablolar'; + $lang['strchildtables'] = 'Child tablolar'; + + // Aggregates + $lang['straggregates'] = 'Aggregate'; + $lang['strnoaggregates'] = 'Hiç aggregate bulunamadı.'; + $lang['stralltypes'] = '(Tüm veri tipleri)'; + $lang['stropclasses'] = 'Op sınıfları'; + $lang['strnoopclasses'] = 'Hiç operatör sınıfı bulunamadı.'; + $lang['straccessmethod'] = 'EriÅŸim Yöntemi'; + $lang['strrowperf'] = 'Satır BaÅŸarımı'; + $lang['strioperf'] = 'I/O BaÅŸarımı'; + $lang['stridxrowperf'] = 'Index Satır BaÅŸarımı'; + $lang['stridxioperf'] = 'Index I/O BaÅŸarımı'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'Sequential'; + $lang['strscan'] = 'Scan'; + $lang['strread'] = 'Read'; + $lang['strfetch'] = 'Fetch'; + $lang['strheap'] = 'Heap'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST Index'; + $lang['strcache'] = 'Cache'; + $lang['strdisk'] = 'Disk'; + $lang['strrows2'] = 'Rows'; + + // Tablespaces + $lang['strtablespace'] = 'Tablespace'; + $lang['strtablespaces'] = 'Tablespaceler'; + $lang['strshowalltablespaces'] = 'Tüm tablespaceleri göster'; + $lang['strnotablespaces'] = 'Hiç tablespace bulunamadı.'; + $lang['strcreatetablespace'] = 'Tablespace yarat'; + $lang['strlocation'] = 'Yer'; + $lang['strtablespaceneedsname'] = 'Tablespace\'e bir ad vermelisiniz.'; + $lang['strtablespaceneedsloc'] = 'Tablespace\'in yaratılacağı dizini belirtmelisiniz'; + $lang['strtablespacecreated'] = 'Tablespace yaratıldı.'; + $lang['strtablespacecreatedbad'] = 'Tablespace yaratılamadı.'; + $lang['strconfdroptablespace'] = '"%s" adlı tablespace\'i kaldırmak istediÄŸinize emin misiniz?'; + $lang['strtablespacedropped'] = 'Tablespace kaldırıldı.'; + $lang['strtablespacedroppedbad'] = 'Tablespace kaldırılamadı.'; + $lang['strtablespacealtered'] = 'Tablespace deÄŸiÅŸtirildi.'; + $lang['strtablespacealteredbad'] = 'Tablespace deÄŸiÅŸtirilemedi.'; + + // Miscellaneous + $lang['strtopbar'] = '%s, %s:%s üzerinde çalışıyor-- "%s" kullanıcısı ile sisteme giriÅŸ yaptınız.'; + $lang['strtimefmt'] = 'jS M, Y g:iA'; + $lang['strhelp'] = 'Yardım'; + $lang['strhelpicon'] = '?'; + $lang['strlogintitle'] = '%s\'e giriÅŸ yap'; + $lang['strlogoutmsg'] = '%s\'den çıkıldı.'; + $lang['strloading'] = 'Yükleniyor...'; + $lang['strerrorloading'] = 'Yükleme hatası'; + $lang['strclicktoreload'] = 'Yeniden yüklemek için tıklayın.'; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/ukrainian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/ukrainian.php new file mode 100644 index 00000000..b4a6d361 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/lang/ukrainian.php @@ -0,0 +1,584 @@ +'; + $lang['strfirst'] = '<< Перший'; + $lang['strlast'] = 'ОÑтан. >>'; + $lang['strfailed'] = 'Перервано'; + $lang['strcreate'] = 'Створити'; + $lang['strcreated'] = 'Створено'; + $lang['strcomment'] = 'Коментар'; + $lang['strlength'] = 'Довжина'; + $lang['strdefault'] = 'По замовчуванню'; + $lang['stralter'] = 'Змінити'; + $lang['strok'] = 'Гаразд'; + $lang['strcancel'] = 'Відмінити'; + $lang['strsave'] = 'Зберегти'; + $lang['strreset'] = 'Скинути'; + $lang['strinsert'] = 'Ð’Ñтавити'; + $lang['strselect'] = 'Вибрати'; + $lang['strdelete'] = 'Видалити'; + $lang['strupdate'] = 'Оновити'; + $lang['strreferences'] = 'ПоÑиланнÑ'; + $lang['stryes'] = 'Так'; + $lang['strno'] = 'ÐÑ–'; + $lang['strtrue'] = 'ІÑтина'; + $lang['strfalse'] = 'Фальш'; + $lang['stredit'] = 'Редагувати'; + $lang['strcolumns'] = 'Ðтрибути'; + $lang['strrows'] = 'запиÑ(и/ів)'; + $lang['strrowsaff'] = 'запиÑ(и/ів) опрацьовано.'; + $lang['strobjects'] = 'об"єкт(и/ів)'; + $lang['strexample'] = 'Ñ– Ñ‚.д.'; + $lang['strback'] = 'Ðазад'; + $lang['strqueryresults'] = 'Результати запиту'; + $lang['strshow'] = 'Показати'; + $lang['strempty'] = 'ОчиÑтити'; + $lang['strlanguage'] = 'Мова'; + $lang['strencoding'] = 'КодуваннÑ'; + $lang['strvalue'] = 'ЗначеннÑ'; + $lang['strunique'] = 'Унікальний'; + $lang['strprimary'] = 'Первинний'; + $lang['strexport'] = 'ЕкÑпорт'; + $lang['strimport'] = 'Імпорт'; + $lang['strsql'] = 'SQL'; + $lang['strgo'] = 'Виконати'; + $lang['stradmin'] = 'УправліннÑ'; + $lang['strvacuum'] = 'Перебудувати'; + $lang['stranalyze'] = 'Ðналізувати'; + $lang['strclusterindex'] = 'КлаÑтеризувати'; + $lang['strclustered'] = 'КлаÑтеризовано?'; + $lang['strreindex'] = 'Перебудувати індекÑ'; + $lang['strrun'] = 'Виконати'; + $lang['stradd'] = 'Додати'; + $lang['strevent'] = 'ПодіÑ'; + $lang['strwhere'] = 'Де'; + $lang['strinstead'] = 'Робити заміÑÑ‚ÑŒ'; + $lang['strwhen'] = 'Коли'; + $lang['strformat'] = 'Формат'; + $lang['strdata'] = 'Данні'; + $lang['strconfirm'] = 'Підтвердити'; + $lang['strexpression'] = 'Вираз'; + $lang['strellipsis'] = '...'; + $lang['strexpand'] = 'Разширити'; + $lang['strcollapse'] = 'Згорнути'; + $lang['strexplain'] = 'ПоÑÑнити'; + $lang['strexplainanalyze'] = 'ПоÑÑнити аналіз'; + $lang['strfind'] = 'Знайти'; + $lang['stroptions'] = 'Опції'; + $lang['strrefresh'] = 'Оновити'; + $lang['strdownload'] = 'Завантажити'; + $lang['strdownloadgzipped'] = 'Завантажити архів gzip'; + $lang['strinfo'] = 'ВідомоÑÑ‚Ñ–'; + $lang['stroids'] = 'OIDs'; + $lang['stradvanced'] = 'Додатково'; + $lang['strvariables'] = 'Змінні'; + $lang['strprocess'] = 'ПроцеÑ'; + $lang['strprocesses'] = 'ПроцеÑи'; + $lang['strsetting'] = 'ÐалаштуваннÑ'; + $lang['streditsql'] = 'Редагувати SQL'; + $lang['strruntime'] = 'Ð§Ð°Ñ Ð²Ð¸ÐºÐ¾Ð½Ð°Ð½Ð½Ñ: %s мÑек'; + $lang['strpaginate'] = 'Ðумерувати Ñторінки з результатами'; + $lang['struploadscript'] = 'чи завантажити SQL-Ñкрипт:'; + $lang['strstarttime'] = 'Ð§Ð°Ñ Ð¿Ð¾Ñ‡Ð°Ñ‚ÐºÑƒ'; + $lang['strfile'] = 'Файл'; + $lang['strfileimported'] = 'Файл імпортовано.'; + + // Error handling + $lang['strbadconfig'] = 'Ваш config.inc.php заÑтарів. Вам необхідно оновити його із config.inc.php-dist.'; + $lang['strnotloaded'] = 'Ваша інÑталÑÑ†Ñ–Ñ PHP не підтримує PostgreSQL. Вам необхідно перекомпілювати PHP, викориÑтавши параметр --with-pgsql Ð´Ð»Ñ configure.'; + $lang['strbadschema'] = 'ВиÑвлено неправильну Ñхему.'; + $lang['strbadencoding'] = 'Ðеможливо вÑтановити Ваше ÐºÐ¾Ð´ÑƒÐ²Ð°Ð½Ð½Ñ Ð² базі даних.'; + $lang['strsqlerror'] = 'Помилка SQL:'; + $lang['strinstatement'] = 'Ð’ операторі:'; + $lang['strinvalidparam'] = 'Ðеправильний параметр Ñкрипта.'; + $lang['strnodata'] = 'Даних не виÑвлено.'; + $lang['strnoobjects'] = 'Об"єктів не виÑвлено.'; + $lang['strrownotunique'] = 'Ðемає унікального ідентифікатора Ð´Ð»Ñ Ñ†ÑŒÐ¾Ð³Ð¾ запиÑу.'; + $lang['strnouploads'] = 'Ð—Ð°Ð²Ð°Ð½Ñ‚Ð°Ð¶ÐµÐ½Ð½Ñ Ñ„Ð°Ð¹Ð»Ð° неможливе.'; + $lang['strimporterror'] = 'Помилка при імпортуванні.'; + $lang['strimporterrorline'] = 'Помилка каналу при імпортові %s.'; + + // Tables + $lang['strtable'] = 'ТаблицÑ'; + $lang['strtables'] = 'Таблиці'; + $lang['strshowalltables'] = 'Показати вÑÑ– таблиці'; + $lang['strnotables'] = 'Таблиць не виÑвлено.'; + $lang['strnotable'] = ' Таблицю не знайдено.'; + $lang['strcreatetable'] = 'Створити таблицю'; + $lang['strtablename'] = 'Ім"Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ–'; + $lang['strtableneedsname'] = 'Вам необхідно визначити ім"Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ–.'; + $lang['strtableneedsfield'] = 'Вам необхідно визначити щонайменше одне поле.'; + $lang['strtableneedscols'] = 'Вам необхідно вказати допуÑтиме чиÑло атрибутів.'; + $lang['strtablecreated'] = 'Таблицю Ñтворено.'; + $lang['strtablecreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ– перервано.'; + $lang['strconfdroptable'] = 'Ви впевнені, що бажаєте видалити таблицю "%s"?'; + $lang['strtabledropped'] = 'Таблицю видалено.'; + $lang['strtabledroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ– перервано.'; + $lang['strconfemptytable'] = 'Ви впевнені, що бажаєте очиÑтити таблицю "%s"?'; + $lang['strtableemptied'] = 'Таблицю очищено.'; + $lang['strtableemptiedbad'] = 'ÐžÑ‡Ð¸Ñ‰ÐµÐ½Ð½Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ– перервано.'; + $lang['strinsertrow'] = 'Додати запиÑ'; + $lang['strrowinserted'] = 'Ð—Ð°Ð¿Ð¸Ñ Ð´Ð¾Ð´Ð°Ð½Ð¾.'; + $lang['strrowinsertedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ Ð·Ð°Ð¿Ð¸Ñу перервано.'; + $lang['streditrow'] = 'Редагувати запиÑ'; + $lang['strrowupdated'] = 'Ð—Ð°Ð¿Ð¸Ñ Ð¾Ð½Ð¾Ð²Ð»ÐµÐ½Ð¾.'; + $lang['strrowupdatedbad'] = 'ÐžÐ½Ð¾Ð²Ð»ÐµÐ½Ð½Ñ Ð·Ð°Ð¿Ð¸Ñу перервано.'; + $lang['strdeleterow'] = 'Видалити запиÑ'; + $lang['strconfdeleterow'] = 'Ви впевнені, що бажаєте видалити запиÑ?'; + $lang['strrowdeleted'] = 'Ð—Ð°Ð¿Ð¸Ñ Ð²Ð¸Ð´Ð°Ð»ÐµÐ½Ð¾.'; + $lang['strrowdeletedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð·Ð°Ð¿Ð¸Ñу перервано.'; + $lang['strsaveandrepeat'] = 'Ð’Ñтавити Ñ– повторити'; + $lang['strfield'] = 'Поле'; + $lang['strfields'] = 'ПолÑ'; + $lang['strnumfields'] = 'К-Ñ‚ÑŒ полів'; + $lang['strfieldneedsname'] = 'Вам необхідно назвати поле'; + $lang['strselectallfields'] = 'Вибрати вÑÑ– полÑ'; + $lang['strselectneedscol'] = 'Вам необхідно вказати щонайменше один атрибут'; + $lang['strselectunary'] = 'Унарний оператор не может мати величину.'; + $lang['straltercolumn'] = 'Змінити атрибут'; + $lang['strcolumnaltered'] = 'Ðтрибут змінено.'; + $lang['strcolumnalteredbad'] = 'Зміну атрибута перервано.'; + $lang['strconfdropcolumn'] = 'Ви впевнені, що бажаєте видалити атрибут "%s" таблиці "%s"?'; + $lang['strcolumndropped'] = 'Ðтрибут видалено.'; + $lang['strcolumndroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð°Ñ‚Ñ€Ð¸Ð±ÑƒÑ‚Ð° перервано.'; + $lang['straddcolumn'] = 'Додати атрибут'; + $lang['strcolumnadded'] = 'Ðтрибут додано.'; + $lang['strcolumnaddedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ Ð°Ñ‚Ñ€Ð¸Ð±ÑƒÑ‚Ð° перервано.'; + $lang['strdataonly'] = 'Тільки дані'; + $lang['strcascade'] = 'КаÑкадом'; + $lang['strtablealtered'] = 'Таблицю змінено.'; + $lang['strtablealteredbad'] = 'Зміну таблиці перервано.'; + $lang['strdataonly'] = 'Лише дані'; + $lang['strstructureonly'] = 'Лише Ñтруктуру'; + $lang['strstructureanddata'] = 'Структуру Ñ– дані'; + $lang['strtabbed'] = 'Через табулÑцію'; + $lang['strauto'] = 'Ðвто'; + + // Users + $lang['struser'] = 'КориÑтувач'; + $lang['strusers'] = 'КориÑтувачі'; + $lang['strusername'] = 'Ім"Ñ ÐºÐ¾Ñ€Ð¸Ñтувача'; + $lang['strpassword'] = 'Пароль'; + $lang['strsuper'] = 'СуперкориÑтувач?'; + $lang['strcreatedb'] = 'Створити базу даних?'; + $lang['strexpires'] = 'Термін дії'; + $lang['strsessiondefaults'] = 'Опції ÑеанÑу за замовчуваннÑм'; + $lang['strnousers'] = 'Ðемає таких кориÑтувачів.'; + $lang['struserupdated'] = 'КориÑтувача оновлено.'; + $lang['struserupdatedbad'] = 'ÐžÐ½Ð¾Ð²Ð»ÐµÐ½Ð½Ñ ÐºÐ¾Ñ€Ð¸Ñтувача перервано.'; + $lang['strshowallusers'] = 'Показати вÑÑ–Ñ… кориÑтувачів'; + $lang['strcreateuser'] = 'Створити кориÑтувача'; + $lang['struserneedsname'] = 'Ви повинні ввеÑти ім"Ñ ÐºÐ¾Ñ€Ð¸Ñтувача.'; + $lang['strusercreated'] = 'КориÑтувача Ñтворено.'; + $lang['strusercreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ ÐºÐ¾Ñ€Ð¸Ñтувача перервано.'; + $lang['strconfdropuser'] = 'Ви впевнені, що бажаєте видалити кориÑтувача "%s"?'; + $lang['struserdropped'] = 'КориÑтувача видалено.'; + $lang['struserdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ ÐºÐ¾Ñ€Ð¸Ñтувача перервано.'; + $lang['straccount'] = 'Обліковий запиÑ'; + $lang['strchangepassword'] = 'Змінити пароль'; + $lang['strpasswordchanged'] = 'Пароль змінено.'; + $lang['strpasswordchangedbad'] = 'Зміну Ð¿Ð°Ñ€Ð¾Ð»Ñ Ð¿ÐµÑ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strpasswordshort'] = 'Пароль закороткий.'; + $lang['strpasswordconfirm'] = 'Пароль не відповідає підтвержденню.'; + + // Groups + $lang['strgroup'] = 'Група'; + $lang['strgroups'] = 'Групи'; + $lang['strnogroup'] = 'Групу не виÑвлено.'; + $lang['strnogroups'] = 'Жодної групи не виÑвлено.'; + $lang['strcreategroup'] = 'Створити групу'; + $lang['strshowallgroups'] = 'Показати вÑÑ– групи'; + $lang['strgroupneedsname'] = 'Вам необхідно вказати назву групи.'; + $lang['strgroupcreated'] = 'Групу Ñтворено.'; + $lang['strgroupcreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð³Ñ€ÑƒÐ¿Ð¸ перервано.'; + $lang['strconfdropgroup'] = 'Ви впевненні, що бажаєте видалити групу "%s"?'; + $lang['strgroupdropped'] = 'Групу видалено.'; + $lang['strgroupdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð³Ñ€ÑƒÐ¿Ð¸ перервано.'; + $lang['strmembers'] = 'УчаÑників'; + $lang['straddmember'] = 'Додати учаÑника'; + $lang['strmemberadded'] = 'УчаÑника додано.'; + $lang['strmemberaddedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ ÑƒÑ‡Ð°Ñника перервано.'; + $lang['strdropmember'] = 'Видалити учаÑника'; + $lang['strconfdropmember'] = 'Ви впевненні, що бажаєте видалити учаÑника "%s" із групи "%s"?'; + $lang['strmemberdropped'] = 'УчаÑника видалено.'; + $lang['strmemberdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ ÑƒÑ‡Ð°Ñника перервано.'; + + // Privileges + $lang['strprivilege'] = 'Привілей'; + $lang['strprivileges'] = 'Привілеї'; + $lang['strnoprivileges'] = 'Об"єкт не володіє привілеÑми.'; + $lang['strgrant'] = 'ПідÑилити'; + $lang['strrevoke'] = 'ПоÑлабити'; + $lang['strgranted'] = 'Привілеї змінено.'; + $lang['strgrantfailed'] = 'Зміну привілеїв перервано.'; + $lang['strgrantbad'] = 'Вам необхідно вказати щонайменше одного кориÑтувача чи групу Ñ– щонайменше один привілей.'; + $lang['stralterprivs'] = 'Змінити привілеї'; + $lang['strgrantor'] = 'Донор'; + $lang['strasterisk'] = '*'; + + // Databases + $lang['strdatabase'] = 'База даних'; + $lang['strdatabases'] = 'Бази даних'; + $lang['strshowalldatabases'] = 'Показати вÑÑ– бази даних'; + $lang['strnodatabase'] = 'Базу даних не виÑвлено.'; + $lang['strnodatabases'] = 'Жодної бази даних не виÑвлено.'; + $lang['strcreatedatabase'] = 'Створити базу даних'; + $lang['strdatabasename'] = 'Ім"Ñ Ð±Ð°Ð·Ð¸ даних'; + $lang['strdatabaseneedsname'] = 'Вам необхідно приÑвоїти ім"Ñ Ð’Ð°ÑˆÑ–Ð¹ базі даних.'; + $lang['strdatabasecreated'] = 'Базу даних Ñтворено.'; + $lang['strdatabasecreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð±Ð°Ð·Ð¸ даних перервано.'; + $lang['strconfdropdatabase'] = 'Ви впевненні, що бажаєте видалити базу даних "%s"?'; + $lang['strdatabasedropped'] = ' Базу даних видалено.'; + $lang['strdatabasedroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð±Ð°Ð·Ð¸ даних перервано.'; + $lang['strentersql'] = 'Введіть SQL-запит:'; + $lang['strsqlexecuted'] = 'SQL-запит виконано.'; + $lang['strvacuumgood'] = 'Операцію перебудови завершено.'; + $lang['strvacuumbad'] = 'Операцію перебудови перервано.'; + $lang['stranalyzegood'] = ' Операцію аналізу завершено.'; + $lang['stranalyzebad'] = ' Операцію аналізу завершено.'; + $lang['strreindexgood'] = 'ПереіндекÑацію завершено.'; + $lang['strreindexbad'] = 'ПереіндекÑацію перервано.'; + $lang['strfull'] = 'ПовніÑÑ‚ÑŽ'; + $lang['strfreeze'] = 'Заморозити'; + $lang['strforce'] = 'ПримуÑово'; + + // Views + $lang['strview'] = 'Показ'; + $lang['strviews'] = 'Покази'; + $lang['strshowallviews'] = 'ПредÑтавити вÑÑ– покази'; + $lang['strnoview'] = 'Показу не виÑвлено.'; + $lang['strnoviews'] = 'Жодного показу не виÑвлено.'; + $lang['strcreateview'] = 'Створити показ'; + $lang['strviewname'] = 'Ім"Ñ Ð¿Ð¾ÐºÐ°Ð·Ñƒ'; + $lang['strviewneedsname'] = 'Вам необхідно вказати ім"Ñ Ð¿Ð¾ÐºÐ°Ð·Ñƒ.'; + $lang['strviewneedsdef'] = 'Вам необхідно визначити атрибуты показу.'; + $lang['strviewneedsfields'] = 'Вам необхідно визначити атрибуты Ð´Ð»Ñ Ð²Ð¸Ð±Ñ–Ñ€ÐºÐ¸ в ваш показ.'; + $lang['strviewcreated'] = 'Показ Ñтворено.'; + $lang['strviewcreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð¿Ð¾ÐºÐ°Ð·Ñƒ перервано.'; + $lang['strconfdropview'] = 'Ви впевнені, що бажаєте видалити показ "%s"?'; + $lang['strviewdropped'] = 'Показ видалено.'; + $lang['strviewdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð¿Ð¾ÐºÐ°Ð·Ñƒ перервано.'; + $lang['strviewupdated'] = 'Показ оновлено.'; + $lang['strviewupdatedbad'] = 'ÐžÐ½Ð¾Ð²Ð»ÐµÐ½Ð½Ñ Ð¿Ð¾ÐºÐ°Ð·Ñƒ перервано.'; + $lang['strviewlink'] = 'Пов"Ñзані ключі'; + $lang['strviewconditions'] = 'Додаткові умови'; + $lang['strcreateviewwiz'] = 'Створити показ, ÑкориÑтавшиÑÑŒ майÑтром'; + + // Sequences + $lang['strsequence'] = 'ПоÑлідовніÑÑ‚ÑŒ'; + $lang['strsequences'] = ' ПоÑлідовноÑÑ‚Ñ–'; + $lang['strshowallsequences'] = 'Показати вÑÑ– поÑлідовноÑÑ‚Ñ–'; + $lang['strnosequence'] = 'ПоÑлідовніÑÑ‚ÑŒ не виÑвлено.'; + $lang['strnosequences'] = 'Жодної поÑлідовноÑÑ‚Ñ– не виÑвлено.'; + $lang['strcreatesequence'] = 'Створити поÑлідовніÑÑ‚ÑŒ'; + $lang['strlastvalue'] = 'ОÑтаннє значеннÑ'; + $lang['strincrementby'] = 'Ð—Ð±Ñ–Ð»ÑŒÑˆÐµÐ½Ð½Ñ Ð½Ð°'; + $lang['strstartvalue'] = 'Початкове значеннÑ'; + $lang['strmaxvalue'] = 'МакÑ. значеннÑ'; + $lang['strminvalue'] = 'Мін. значеннÑ'; + $lang['strcachevalue'] = 'Розмір кеша'; + $lang['strlogcount'] = 'Log Count'; + $lang['striscycled'] = 'Зациклити?'; + $lang['strsequenceneedsname'] = 'Вам необхідно вказати ім"Ñ Ð¿Ð¾ÑлідовноÑÑ‚Ñ–.'; + $lang['strsequencecreated'] = 'ПоÑлідовніÑÑ‚ÑŒ Ñтворено.'; + $lang['strsequencecreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð¿Ð¾ÑлідовноÑÑ‚Ñ– перервано.'; + $lang['strconfdropsequence'] = 'Ви впевнені, що бажаєте видалити поÑлідовніÑÑ‚ÑŒ "%s"?'; + $lang['strsequencedropped'] = 'ПоÑлідовніÑÑ‚ÑŒ видалено.'; + $lang['strsequencedroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð¿Ð¾ÑлідовноÑÑ‚Ñ– перервано.'; + $lang['strsequencereset'] = 'ПоÑлідовніÑÑ‚ÑŒ Ñкинуто.'; + $lang['strsequenceresetbad'] = 'Ð¡ÐºÐ¸Ð½ÐµÐ½Ð½Ñ Ð¿Ð¾ÑлідовноÑÑ‚Ñ– перервано.'; + + // Indexes + $lang['strindex'] = 'ІндекÑ'; + $lang['strindexes'] = 'ІндекÑи'; + $lang['strindexname'] = 'Ім"Ñ Ñ–Ð½Ð´ÐµÐºÑа'; + $lang['strshowallindexes'] = 'Показати вÑÑ– індекÑи'; + $lang['strnoindex'] = 'Ð†Ð½Ð´ÐµÐºÑ Ð½Ðµ виÑвлено.'; + $lang['strnoindexes'] = 'Жодного індекÑа не знайдено.'; + $lang['strcreateindex'] = 'Створити індекÑ'; + $lang['strtabname'] = 'Ім"Ñ Ñ‚Ð°Ð±Ð»Ð¸Ñ†Ñ–'; + $lang['strcolumnname'] = 'Ім"Ñ Ð°Ñ‚Ñ€Ð¸Ð±ÑƒÑ‚Ð°'; + $lang['strindexneedsname'] = 'Вам необхідно вказати ім"Ñ Ñ–Ð½Ð´ÐµÐºÑа'; + $lang['strindexneedscols'] = 'Вам необхідно вказати можливу кількіÑÑ‚ÑŒ атрибутів.'; + $lang['strindexcreated'] = 'Ð†Ð½Ð´ÐµÐºÑ Ñтворено.'; + $lang['strindexcreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ñ–Ð½Ð´ÐµÐºÑа перервано.'; + $lang['strconfdropindex'] = 'Ви впевнені, що бажаєте видалити Ñ–Ð½Ð´ÐµÐºÑ "%s"?'; + $lang['strindexdropped'] = 'Ð†Ð½Ð´ÐµÐºÑ Ð²Ð¸Ð´Ð°Ð»ÐµÐ½Ð¾.'; + $lang['strindexdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ñ–Ð½Ð´ÐµÐºÑа перервано.'; + $lang['strkeyname'] = 'Ім"Ñ ÐºÐ»ÑŽÑ‡Ð°'; + $lang['struniquekey'] = 'Унікальний ключ'; + $lang['strprimarykey'] = 'Первинний ключ'; + $lang['strindextype'] = 'Вид індекÑа'; + $lang['strindexname'] = 'Ім"Ñ Ñ–Ð½Ð´ÐµÐºÑа'; + $lang['strtablecolumnlist'] = 'Ðтрибутів в таблиці'; + $lang['strindexcolumnlist'] = 'Ðтрибутів в індекÑÑ–'; + $lang['strconfcluster'] = 'Ви впевнені, що бажаєте клаÑтеризувати "%s"?'; + $lang['strclusteredgood'] = 'КлаÑтеризацію завершено.'; + $lang['strclusteredbad'] = 'КлаÑтеризацію перервано.'; + + // Rules + $lang['strrules'] = 'Правила'; + $lang['strrule'] = 'Правило'; + $lang['strshowallrules'] = 'Показати вÑÑ– правила'; + $lang['strnorule'] = 'Правило не виÑвлено.'; + $lang['strnorules'] = 'Жодного правила не виÑвлено.'; + $lang['strcreaterule'] = 'Створити правило'; + $lang['strrulename'] = 'Ім"Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð°'; + $lang['strruleneedsname'] = 'Вам необхідно вказати ім"Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð°.'; + $lang['strrulecreated'] = 'Правило Ñтворено.'; + $lang['strrulecreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð° перервано.'; + $lang['strconfdroprule'] = 'Ви впевнені, що бажаєте видалити правило "%s" з "%s"?'; + $lang['strruledropped'] = 'Правило видалено.'; + $lang['strruledroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð¿Ñ€Ð°Ð²Ð¸Ð»Ð° перервано.'; + + // Constraints + $lang['strconstraints'] = 'ОбмеженнÑ'; + $lang['strshowallconstraints'] = 'Показати вÑÑ– обмеженнÑ'; + $lang['strnoconstraints'] = 'Жодного Ð¾Ð±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð½Ðµ виÑвлено.'; + $lang['strcreateconstraint'] = 'Створити обмеженнÑ'; + $lang['strconstraintcreated'] = 'ÐžÐ±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ñтворено.'; + $lang['strconstraintcreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð¾Ð±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð¿ÐµÑ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['strconfdropconstraint'] = 'Ви впевнені, що бажаєте видалити Ð¾Ð±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ "%s" з "%s"?'; + $lang['strconstraintdropped'] = 'ÐžÐ±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð²Ð¸Ð´Ð°Ð»ÐµÐ½Ð¾.'; + $lang['strconstraintdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð¾Ð±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð¿ÐµÑ€ÐµÑ€Ð²Ð°Ð½Ð¾.'; + $lang['straddcheck'] = 'Додати перевірку'; + $lang['strcheckneedsdefinition'] = 'ÐžÐ±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð¿ÐµÑ€ÐµÐ²Ñ–Ñ€ÐºÐ¸ потребує визначеннÑ.'; + $lang['strcheckadded'] = 'ÐžÐ±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð¿ÐµÑ€ÐµÐ²Ñ–Ñ€ÐºÐ¸ додано.'; + $lang['strcheckaddedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ Ð¾Ð±Ð¼ÐµÐ¶ÐµÐ½Ð½Ñ Ð¿ÐµÑ€ÐµÐ²Ñ–Ñ€ÐºÐ¸ перервано.'; + $lang['straddpk'] = 'Додати первинний ключ'; + $lang['strpkneedscols'] = 'Первинний ключ повинен міÑтити Ñ…Ð¾Ñ‡Ñ Ð± один атрибут.'; + $lang['strpkadded'] = 'Первинний ключ додано.'; + $lang['strpkaddedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ Ð¿ÐµÑ€Ð²Ð¸Ð½Ð½Ð¾Ð³Ð¾ ключа перервано.'; + $lang['stradduniq'] = 'Додати унікальний ключ'; + $lang['struniqneedscols'] = 'Унікальний ключ повинен міÑтити хоча б один атрибут.'; + $lang['struniqadded'] = 'Унікальний ключ додано.'; + $lang['struniqaddedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ ÑƒÐ½Ñ–ÐºÐ°Ð»ÑŒÐ½Ð¾Ð³Ð¾ ключа перервано.'; + $lang['straddfk'] = 'Додати зовнішній ключ'; + $lang['strfkneedscols'] = 'Зовнішній ключ повинен міÑтити хоча б один атрибут.'; + $lang['strfkneedstarget'] = 'Зовнішньому ключеві необхідно вказати цільову таблицю.'; + $lang['strfkadded'] = 'Зовнішній ключ додано.'; + $lang['strfkaddedbad'] = 'Ð”Ð¾Ð´Ð°Ð²Ð°Ð½Ð½Ñ Ð·Ð¾Ð²Ð½Ñ–ÑˆÐ½ÑŒÐ¾Ð³Ð¾ ключа перервано.'; + $lang['strfktarget'] = 'Цільова таблицÑ'; + $lang['strfkcolumnlist'] = 'Ðтрибуты в ключі'; + $lang['strondelete'] = 'ON DELETE'; + $lang['stronupdate'] = 'ON UPDATE'; + + // Functions + $lang['strfunction'] = 'ФункціÑ'; + $lang['strfunctions'] = ' Функції'; + $lang['strshowallfunctions'] = 'Показати вÑÑ– функції'; + $lang['strnofunction'] = 'Функцію не виÑвлено.'; + $lang['strnofunctions'] = 'Жодної функції не виÑвлено.'; + $lang['strcreatefunction'] = 'Створити функцію'; + $lang['strfunctionname'] = 'Ім"Ñ Ñ„ÑƒÐ½ÐºÑ†Ñ–Ñ—'; + $lang['strreturns'] = 'Результат, що повертає'; + $lang['strarguments'] = 'Ðргументи'; + $lang['strproglanguage'] = 'Мова програмуваннÑ'; + $lang['strproglanguage'] = 'Мова'; + $lang['strfunctionneedsname'] = 'Вам необхідно вказати ім"Ñ Ñ„ÑƒÐ½ÐºÑ†Ñ–Ñ—.'; + $lang['strfunctionneedsdef'] = 'Вам необхідно визначити функцію.'; + $lang['strfunctioncreated'] = 'Функцію Ñтворено.'; + $lang['strfunctioncreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ñ„ÑƒÐ½ÐºÑ†Ñ–Ñ— перервано.'; + $lang['strconfdropfunction'] = 'Ви впевнені, що бажаєте видалити функцію "%s"?'; + $lang['strfunctiondropped'] = 'Функцію видалено.'; + $lang['strfunctiondroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ñ„ÑƒÐ½ÐºÑ†Ñ–Ñ— перервано.'; + $lang['strfunctionupdated'] = 'Функцію оновлено.'; + $lang['strfunctionupdatedbad'] = 'ÐžÐ½Ð¾Ð²Ð»ÐµÐ½Ð½Ñ Ñ„ÑƒÐ½ÐºÑ†Ñ–Ñ— перервано.'; + + // Triggers + $lang['strtrigger'] = 'Трігер'; + $lang['strtriggers'] = ' Трігери'; + $lang['strshowalltriggers'] = 'Показати вÑÑ– трігери'; + $lang['strnotrigger'] = 'Трігер не виÑвлено.'; + $lang['strnotriggers'] = 'Жодного трігера не виÑвлено.'; + $lang['strcreatetrigger'] = 'Створити трігер'; + $lang['strtriggerneedsname'] = 'Вам необхідно вказать ім"Ñ Ñ‚Ñ€Ñ–Ð³ÐµÑ€Ð°.'; + $lang['strtriggerneedsfunc'] = 'Вам необхідно визначити функцію трігера.'; + $lang['strtriggercreated'] = 'Трігер Ñтворено.'; + $lang['strtriggercreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ñ‚Ñ€Ñ–Ð³ÐµÑ€Ð° перервано.'; + $lang['strconfdroptrigger'] = 'Ви впевнені, що бажаєтее видалити трігер "%s" на "%s"?'; + $lang['strtriggerdropped'] = 'Трігер видалено.'; + $lang['strtriggerdroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ñ‚Ñ€Ñ–Ð³ÐµÑ€Ð° перервано.'; + $lang['strtriggeraltered'] = 'Трігер змінено.'; + $lang['strtriggeralteredbad'] = 'Зміну трігера перервано.'; + + // Types + $lang['strtype'] = 'Тип даних'; + $lang['strtypes'] = 'Типи даних'; + $lang['strshowalltypes'] = 'Показати вÑÑ– типи даних'; + $lang['strnotype'] = 'Тип даних не виÑвлено.'; + $lang['strnotypes'] = 'Жодного типу даних не виÑвлено.'; + $lang['strcreatetype'] = 'Створити тип даних'; + $lang['strtypename'] = 'Ім"Ñ Ñ‚Ð¸Ð¿Ñƒ даних'; + $lang['strinputfn'] = 'Ð¤ÑƒÐ½ÐºÑ†Ñ–Ñ Ð²Ð²Ð¾Ð´Ñƒ'; + $lang['stroutputfn'] = 'Ð¤ÑƒÐ½ÐºÑ†Ñ–Ñ Ð²Ð¸Ð²Ð¾Ð´Ñƒ'; + $lang['strpassbyval'] = 'Передати за значеннÑм?'; + $lang['stralignment'] = 'ВирівнюваннÑ'; + $lang['strelement'] = 'Елемент'; + $lang['strdelimiter'] = 'Роздільник'; + $lang['strstorage'] = 'ЗберіганнÑ'; + $lang['strtypeneedsname'] = 'Вам необхідно вказати ім"Ñ Ñ‚Ð¸Ð¿Ñƒ даних.'; + $lang['strtypeneedslen'] = 'Вам необхідно вказати розмір Ð´Ð»Ñ Ñ‚Ð¸Ð¿Ñƒ даних.'; + $lang['strtypecreated'] = 'Тип даних Ñтворено.'; + $lang['strtypecreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ñ‚Ð¸Ð¿Ñƒ даних перервано.'; + $lang['strconfdroptype'] = 'Ви впевнені, що бажаєте видалити тип даних "%s"?'; + $lang['strtypedropped'] = 'Тип даних видалено.'; + $lang['strtypedroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ñ‚Ð¸Ð¿Ñƒ даних перервано.'; + + // Schemas + $lang['strschema'] = 'Схема'; + $lang['strschemas'] = 'Схеми'; + $lang['strshowallschemas'] = 'Показати вÑÑ– Ñхеми'; + $lang['strnoschema'] = 'Схему не виÑвлено.'; + $lang['strnoschemas'] = 'Жодної Ñхеми не виÑвлено.'; + $lang['strcreateschema'] = 'Створити Ñхему'; + $lang['strschemaname'] = 'Ім"Ñ Ñхеми'; + $lang['strschemaneedsname'] = 'Вам необхідно вказати ім"Ñ Ñхеми.'; + $lang['strschemacreated'] = 'Схему Ñтворено.'; + $lang['strschemacreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ñхеми перервано.'; + $lang['strconfdropschema'] = 'Ви впевнені, що бажаєте видалити Ñхему "%s"?'; + $lang['strschemadropped'] = 'Схему видалено.'; + $lang['strschemadroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ñхеми перервано.'; + $lang['strschemaaltered'] = 'Схему оновлено.'; + $lang['strschemaalteredbad'] = 'ÐžÐ½Ð¾Ð²Ð»ÐµÐ½Ð½Ñ Ñхеми перервано.'; + + // Reports + + // Domains + $lang['strdomain'] = 'Домен'; + $lang['strdomains'] = 'Домени'; + $lang['strshowalldomains'] = 'Показати вÑÑ– домени'; + $lang['strnodomains'] = 'Жодного домена не виÑвлено.'; + $lang['strcreatedomain'] = 'Створити домен'; + $lang['strdomaindropped'] = 'Домен видалено.'; + $lang['strdomaindroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð´Ð¾Ð¼ÐµÐ½Ð° перервано.'; + $lang['strconfdropdomain'] = 'Ви впевнені, що бажаєте видалити домен "%s"?'; + $lang['strdomainneedsname'] = 'Вам необхідно вказати ім"Ñ Ð´Ð¾Ð¼ÐµÐ½Ð°.'; + $lang['strdomaincreated'] = 'Домен Ñтворено.'; + $lang['strdomaincreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð´Ð¾Ð¼ÐµÐ½Ð° перервано.'; + $lang['strdomainaltered'] = 'Домен змінено.'; + $lang['strdomainalteredbad'] = 'Зміну домена перервано.'; + + // Operators + $lang['stroperator'] = 'Оператор'; + $lang['stroperators'] = 'Оператори'; + $lang['strshowalloperators'] = 'Показати вÑÑ– оператори'; + $lang['strnooperator'] = 'Оператор не виÑвлено.'; + $lang['strnooperators'] = 'Операторів не виÑвлено.'; + $lang['strcreateoperator'] = 'Створити оператор'; + $lang['strleftarg'] = 'Тип лівого аргумента'; + $lang['strrightarg'] = 'Тип правого аргумента'; + $lang['strcommutator'] = 'ПеретвореннÑ'; + $lang['strnegator'] = 'ЗапереченнÑ'; + $lang['strrestrict'] = 'ПоÑлабленнÑ'; + $lang['strjoin'] = 'Об"єднаннÑ'; + $lang['strhashes'] = 'ХешуваннÑ'; + $lang['strmerges'] = 'Об"єднаннÑ'; + $lang['strleftsort'] = 'Ð¡Ð¾Ñ€Ñ‚ÑƒÐ²Ð°Ð½Ð½Ñ Ð·Ð° лівим'; + $lang['strrightsort'] = 'Ð¡Ð¾Ñ€Ñ‚ÑƒÐ²Ð°Ð½Ð½Ñ Ð·Ð° правим'; + $lang['strlessthan'] = 'Менше'; + $lang['strgreaterthan'] = 'Більше'; + $lang['stroperatorneedsname'] = 'Вам необхідно вказати назву оператора.'; + $lang['stroperatorcreated'] = 'Оператор Ñтворено'; + $lang['stroperatorcreatedbad'] = 'Ð¡Ñ‚Ð²Ð¾Ñ€ÐµÐ½Ð½Ñ Ð¾Ð¿ÐµÑ€Ð°Ñ‚Ð¾Ñ€Ð° перервано.'; + $lang['strconfdropoperator'] = 'Ви впевнені, що бажаєтее видалити оператор "%s"?'; + $lang['stroperatordropped'] = 'Оператор видалено.'; + $lang['stroperatordroppedbad'] = 'Ð’Ð¸Ð´Ð°Ð»ÐµÐ½Ð½Ñ Ð¾Ð¿ÐµÑ€Ð°Ñ‚Ð¾Ñ€Ð° перервано.'; + + // Casts + $lang['strcasts'] = 'Взірці'; + $lang['strnocasts'] = 'Взірців не виÑвлено.'; + $lang['strsourcetype'] = 'Тип джерела'; + $lang['strtargettype'] = 'Тип приймача'; + $lang['strimplicit'] = 'ÐеÑвний'; + $lang['strinassignment'] = 'Ð’ призначенні'; + $lang['strbinarycompat'] = '(двійково ÑуміÑний)'; + + // Conversions + $lang['strconversions'] = 'ПеретвореннÑ'; + $lang['strnoconversions'] = 'Перетворень не виÑвлено.'; + $lang['strsourceencoding'] = 'ÐšÐ¾Ð´ÑƒÐ²Ð°Ð½Ð½Ñ Ð´Ð¶ÐµÑ€ÐµÐ»Ð°'; + $lang['strtargetencoding'] = 'ÐšÐ¾Ð´ÑƒÐ²Ð°Ð½Ð½Ñ Ð¿Ñ€Ð¸Ð¹Ð¼Ð°Ñ‡Ð°'; + + // Languages + $lang['strlanguages'] = 'Мови'; + $lang['strnolanguages'] = 'Мов не виÑвлено.'; + $lang['strtrusted'] = 'Перевірено'; + + // Info + $lang['strnoinfo'] = 'Ðемає доÑтупної інформації.'; + $lang['strreferringtables'] = 'Таблиці, що поÑилаютьÑÑ'; + $lang['strparenttables'] = 'БатьківÑькі таблиці'; + $lang['strchildtables'] = 'Дочірні таблиці'; + + // Aggregates + $lang['straggregates'] = 'Ðгрегатні вирази'; + $lang['strnoaggregates'] = 'Ðгрегатних виразів не виÑвлено.'; + $lang['stralltypes'] = '(Ð’ÑÑ– типи)'; + + // Operator Classes + $lang['stropclasses'] = 'КлаÑи операторів'; + $lang['strnoopclasses'] = 'КлаÑів операторів не виÑвлено.'; + $lang['straccessmethod'] = 'Метод доÑтупа'; + + // Stats and performance + $lang['strrowperf'] = 'Показ запиÑу'; + $lang['strioperf'] = 'Показ вводу/виводу'; + $lang['stridxrowperf'] = 'Показ індекÑа запиÑу'; + $lang['stridxioperf'] = 'Показ індекÑа вводу/виводу'; + $lang['strpercent'] = '%'; + $lang['strsequential'] = 'ПоÑлідовний'; + $lang['strscan'] = 'Сканувати'; + $lang['strread'] = 'Читати'; + $lang['strfetch'] = 'ВитÑгнути'; + $lang['strheap'] = 'СміттÑ'; + $lang['strtoast'] = 'TOAST'; + $lang['strtoastindex'] = 'TOAST індекÑ'; + $lang['strcache'] = 'Кеш'; + $lang['strdisk'] = 'ДиÑк'; + $lang['strrows2'] = 'ЗапиÑи'; + + // Miscellaneous + $lang['strtopbar'] = '%s виконуєтьÑÑ Ð½Ð° %s:%s -- Ви зареєÑтрувалиÑÑŒ Ñк "%s"'; + $lang['strtimefmt'] = ' j-m-Y g:i'; + $lang['strhelp'] = 'Допомога'; + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/languages.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/languages.php new file mode 100644 index 00000000..b337638b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/languages.php @@ -0,0 +1,79 @@ +printTrail('database'); + $misc->printTabs('database','languages'); + $misc->printMsg($msg); + + $languages = $data->getLanguages(); + + $columns = array( + 'language' => array( + 'title' => $lang['strname'], + 'field' => field('lanname'), + ), + 'trusted' => array( + 'title' => $lang['strtrusted'], + 'field' => field('lanpltrusted'), + 'type' => 'yesno', + ), + 'function' => array( + 'title' => $lang['strfunction'], + 'field' => field('lanplcallf'), + ), + ); + + $actions = array(); + + $misc->printTable($languages, $columns, $actions, 'languages-languages', $lang['strnolanguages']); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $languages = $data->getLanguages(); + + $attrs = array( + 'text' => field('lanname'), + 'icon' => 'Language' + ); + + $misc->printTree($languages, $attrs, 'languages'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strlanguages']); + $misc->printBody(); + + switch ($action) { + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-csvlib.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-csvlib.inc.php new file mode 100644 index 00000000..1c0d0818 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-csvlib.inc.php @@ -0,0 +1,318 @@ +FieldCount() : 0; + + if ($sql) $sql = urlencode($sql); + // metadata setup + + if ($max <= 0 || $rs->dataProvider == 'empty') { // is insert/update/delete + if (is_object($conn)) { + $sql .= ','.$conn->Affected_Rows(); + $sql .= ','.$conn->Insert_ID(); + } else + $sql .= ',,'; + + $text = "====-1,0,$sql\n"; + return $text; + } + $tt = ($rs->timeCreated) ? $rs->timeCreated : time(); + + ## changed format from ====0 to ====1 + $line = "====1,$tt,$sql\n"; + + if ($rs->databaseType == 'array') { + $rows = $rs->_array; + } else { + $rows = array(); + while (!$rs->EOF) { + $rows[] = $rs->fields; + $rs->MoveNext(); + } + } + + for($i=0; $i < $max; $i++) { + $o = $rs->FetchField($i); + $flds[] = $o; + } + + $savefetch = isset($rs->adodbFetchMode) ? $rs->adodbFetchMode : $rs->fetchMode; + $class = $rs->connection->arrayClass; + $rs2 = new $class(); + $rs2->timeCreated = $rs->timeCreated; # memcache fix + $rs2->sql = $rs->sql; + $rs2->oldProvider = $rs->dataProvider; + $rs2->InitArrayFields($rows,$flds); + $rs2->fetchMode = $savefetch; + return $line.serialize($rs2); + } + + +/** +* Open CSV file and convert it into Data. +* +* @param url file/ftp/http url +* @param err returns the error message +* @param timeout dispose if recordset has been alive for $timeout secs +* +* @return recordset, or false if error occured. If no +* error occurred in sql INSERT/UPDATE/DELETE, +* empty recordset is returned +*/ + function csv2rs($url,&$err,$timeout=0, $rsclass='ADORecordSet_array') + { + $false = false; + $err = false; + $fp = @fopen($url,'rb'); + if (!$fp) { + $err = $url.' file/URL not found'; + return $false; + } + @flock($fp, LOCK_SH); + $arr = array(); + $ttl = 0; + + if ($meta = fgetcsv($fp, 32000, ",")) { + // check if error message + if (strncmp($meta[0],'****',4) === 0) { + $err = trim(substr($meta[0],4,1024)); + fclose($fp); + return $false; + } + // check for meta data + // $meta[0] is -1 means return an empty recordset + // $meta[1] contains a time + + if (strncmp($meta[0], '====',4) === 0) { + + if ($meta[0] == "====-1") { + if (sizeof($meta) < 5) { + $err = "Corrupt first line for format -1"; + fclose($fp); + return $false; + } + fclose($fp); + + if ($timeout > 0) { + $err = " Illegal Timeout $timeout "; + return $false; + } + + $rs = new $rsclass($val=true); + $rs->fields = array(); + $rs->timeCreated = $meta[1]; + $rs->EOF = true; + $rs->_numOfFields = 0; + $rs->sql = urldecode($meta[2]); + $rs->affectedrows = (integer)$meta[3]; + $rs->insertid = $meta[4]; + return $rs; + } + # Under high volume loads, we want only 1 thread/process to _write_file + # so that we don't have 50 processes queueing to write the same data. + # We use probabilistic timeout, ahead of time. + # + # -4 sec before timeout, give processes 1/32 chance of timing out + # -2 sec before timeout, give processes 1/16 chance of timing out + # -1 sec after timeout give processes 1/4 chance of timing out + # +0 sec after timeout, give processes 100% chance of timing out + if (sizeof($meta) > 1) { + if($timeout >0){ + $tdiff = (integer)( $meta[1]+$timeout - time()); + if ($tdiff <= 2) { + switch($tdiff) { + case 4: + case 3: + if ((rand() & 31) == 0) { + fclose($fp); + $err = "Timeout 3"; + return $false; + } + break; + case 2: + if ((rand() & 15) == 0) { + fclose($fp); + $err = "Timeout 2"; + return $false; + } + break; + case 1: + if ((rand() & 3) == 0) { + fclose($fp); + $err = "Timeout 1"; + return $false; + } + break; + default: + fclose($fp); + $err = "Timeout 0"; + return $false; + } // switch + + } // if check flush cache + }// (timeout>0) + $ttl = $meta[1]; + } + //================================================ + // new cache format - use serialize extensively... + if ($meta[0] === '====1') { + // slurp in the data + $MAXSIZE = 128000; + + $text = fread($fp,$MAXSIZE); + if (strlen($text)) { + while ($txt = fread($fp,$MAXSIZE)) { + $text .= $txt; + } + } + fclose($fp); + $rs = unserialize($text); + if (is_object($rs)) $rs->timeCreated = $ttl; + else { + $err = "Unable to unserialize recordset"; + //echo htmlspecialchars($text),' !--END--!

'; + } + return $rs; + } + + $meta = false; + $meta = fgetcsv($fp, 32000, ","); + if (!$meta) { + fclose($fp); + $err = "Unexpected EOF 1"; + return $false; + } + } + + // Get Column definitions + $flds = array(); + foreach($meta as $o) { + $o2 = explode(':',$o); + if (sizeof($o2)!=3) { + $arr[] = $meta; + $flds = false; + break; + } + $fld = new ADOFieldObject(); + $fld->name = urldecode($o2[0]); + $fld->type = $o2[1]; + $fld->max_length = $o2[2]; + $flds[] = $fld; + } + } else { + fclose($fp); + $err = "Recordset had unexpected EOF 2"; + return $false; + } + + // slurp in the data + $MAXSIZE = 128000; + + $text = ''; + while ($txt = fread($fp,$MAXSIZE)) { + $text .= $txt; + } + + fclose($fp); + @$arr = unserialize($text); + //var_dump($arr); + if (!is_array($arr)) { + $err = "Recordset had unexpected EOF (in serialized recordset)"; + if (get_magic_quotes_runtime()) $err .= ". Magic Quotes Runtime should be disabled!"; + return $false; + } + $rs = new $rsclass(); + $rs->timeCreated = $ttl; + $rs->InitArrayFields($arr,$flds); + return $rs; + } + + + /** + * Save a file $filename and its $contents (normally for caching) with file locking + * Returns true if ok, false if fopen/fwrite error, 0 if rename error (eg. file is locked) + */ + function adodb_write_file($filename, $contents,$debug=false) + { + # http://www.php.net/bugs.php?id=9203 Bug that flock fails on Windows + # So to simulate locking, we assume that rename is an atomic operation. + # First we delete $filename, then we create a $tempfile write to it and + # rename to the desired $filename. If the rename works, then we successfully + # modified the file exclusively. + # What a stupid need - having to simulate locking. + # Risks: + # 1. $tempfile name is not unique -- very very low + # 2. unlink($filename) fails -- ok, rename will fail + # 3. adodb reads stale file because unlink fails -- ok, $rs timeout occurs + # 4. another process creates $filename between unlink() and rename() -- ok, rename() fails and cache updated + if (strncmp(PHP_OS,'WIN',3) === 0) { + // skip the decimal place + $mtime = substr(str_replace(' ','_',microtime()),2); + // getmypid() actually returns 0 on Win98 - never mind! + $tmpname = $filename.uniqid($mtime).getmypid(); + if (!($fd = @fopen($tmpname,'w'))) return false; + if (fwrite($fd,$contents)) $ok = true; + else $ok = false; + fclose($fd); + + if ($ok) { + @chmod($tmpname,0644); + // the tricky moment + @unlink($filename); + if (!@rename($tmpname,$filename)) { + unlink($tmpname); + $ok = 0; + } + if (!$ok) { + if ($debug) ADOConnection::outp( " Rename $tmpname ".($ok? 'ok' : 'failed')); + } + } + return $ok; + } + if (!($fd = @fopen($filename, 'a'))) return false; + if (flock($fd, LOCK_EX) && ftruncate($fd, 0)) { + if (fwrite( $fd, $contents )) $ok = true; + else $ok = false; + fclose($fd); + @chmod($filename,0644); + }else { + fclose($fd); + if ($debug)ADOConnection::outp( " Failed acquiring lock for $filename
\n"); + $ok = false; + } + + return $ok; + } +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-datadict.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-datadict.inc.php new file mode 100644 index 00000000..69060c5c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-datadict.inc.php @@ -0,0 +1,1032 @@ +$str

"; +$a= Lens_ParseArgs($str); +print "
";
+print_r($a);
+print "
"; +} + + +if (!function_exists('ctype_alnum')) { + function ctype_alnum($text) { + return preg_match('/^[a-z0-9]*$/i', $text); + } +} + +//Lens_ParseTest(); + +/** + Parse arguments, treat "text" (text) and 'text' as quotation marks. + To escape, use "" or '' or )) + + Will read in "abc def" sans quotes, as: abc def + Same with 'abc def'. + However if `abc def`, then will read in as `abc def` + + @param endstmtchar Character that indicates end of statement + @param tokenchars Include the following characters in tokens apart from A-Z and 0-9 + @returns 2 dimensional array containing parsed tokens. +*/ +function Lens_ParseArgs($args,$endstmtchar=',',$tokenchars='_.-') +{ + $pos = 0; + $intoken = false; + $stmtno = 0; + $endquote = false; + $tokens = array(); + $tokens[$stmtno] = array(); + $max = strlen($args); + $quoted = false; + $tokarr = array(); + + while ($pos < $max) { + $ch = substr($args,$pos,1); + switch($ch) { + case ' ': + case "\t": + case "\n": + case "\r": + if (!$quoted) { + if ($intoken) { + $intoken = false; + $tokens[$stmtno][] = implode('',$tokarr); + } + break; + } + + $tokarr[] = $ch; + break; + + case '`': + if ($intoken) $tokarr[] = $ch; + case '(': + case ')': + case '"': + case "'": + + if ($intoken) { + if (empty($endquote)) { + $tokens[$stmtno][] = implode('',$tokarr); + if ($ch == '(') $endquote = ')'; + else $endquote = $ch; + $quoted = true; + $intoken = true; + $tokarr = array(); + } else if ($endquote == $ch) { + $ch2 = substr($args,$pos+1,1); + if ($ch2 == $endquote) { + $pos += 1; + $tokarr[] = $ch2; + } else { + $quoted = false; + $intoken = false; + $tokens[$stmtno][] = implode('',$tokarr); + $endquote = ''; + } + } else + $tokarr[] = $ch; + + }else { + + if ($ch == '(') $endquote = ')'; + else $endquote = $ch; + $quoted = true; + $intoken = true; + $tokarr = array(); + if ($ch == '`') $tokarr[] = '`'; + } + break; + + default: + + if (!$intoken) { + if ($ch == $endstmtchar) { + $stmtno += 1; + $tokens[$stmtno] = array(); + break; + } + + $intoken = true; + $quoted = false; + $endquote = false; + $tokarr = array(); + + } + + if ($quoted) $tokarr[] = $ch; + else if (ctype_alnum($ch) || strpos($tokenchars,$ch) !== false) $tokarr[] = $ch; + else { + if ($ch == $endstmtchar) { + $tokens[$stmtno][] = implode('',$tokarr); + $stmtno += 1; + $tokens[$stmtno] = array(); + $intoken = false; + $tokarr = array(); + break; + } + $tokens[$stmtno][] = implode('',$tokarr); + $tokens[$stmtno][] = $ch; + $intoken = false; + } + } + $pos += 1; + } + if ($intoken) $tokens[$stmtno][] = implode('',$tokarr); + + return $tokens; +} + + +class ADODB_DataDict { + var $connection; + var $debug = false; + var $dropTable = 'DROP TABLE %s'; + var $renameTable = 'RENAME TABLE %s TO %s'; + var $dropIndex = 'DROP INDEX %s'; + var $addCol = ' ADD'; + var $alterCol = ' ALTER COLUMN'; + var $dropCol = ' DROP COLUMN'; + var $renameColumn = 'ALTER TABLE %s RENAME COLUMN %s TO %s'; // table, old-column, new-column, column-definitions (not used by default) + var $nameRegex = '\w'; + var $nameRegexBrackets = 'a-zA-Z0-9_\(\)'; + var $schema = false; + var $serverInfo = array(); + var $autoIncrement = false; + var $dataProvider; + var $invalidResizeTypes4 = array('CLOB','BLOB','TEXT','DATE','TIME'); // for changetablesql + var $blobSize = 100; /// any varchar/char field this size or greater is treated as a blob + /// in other words, we use a text area for editting. + + function GetCommentSQL($table,$col) + { + return false; + } + + function SetCommentSQL($table,$col,$cmt) + { + return false; + } + + function MetaTables() + { + if (!$this->connection->IsConnected()) return array(); + return $this->connection->MetaTables(); + } + + function MetaColumns($tab, $upper=true, $schema=false) + { + if (!$this->connection->IsConnected()) return array(); + return $this->connection->MetaColumns($this->TableName($tab), $upper, $schema); + } + + function MetaPrimaryKeys($tab,$owner=false,$intkey=false) + { + if (!$this->connection->IsConnected()) return array(); + return $this->connection->MetaPrimaryKeys($this->TableName($tab), $owner, $intkey); + } + + function MetaIndexes($table, $primary = false, $owner = false) + { + if (!$this->connection->IsConnected()) return array(); + return $this->connection->MetaIndexes($this->TableName($table), $primary, $owner); + } + + function MetaType($t,$len=-1,$fieldobj=false) + { + static $typeMap = array( + 'VARCHAR' => 'C', + 'VARCHAR2' => 'C', + 'CHAR' => 'C', + 'C' => 'C', + 'STRING' => 'C', + 'NCHAR' => 'C', + 'NVARCHAR' => 'C', + 'VARYING' => 'C', + 'BPCHAR' => 'C', + 'CHARACTER' => 'C', + 'INTERVAL' => 'C', # Postgres + 'MACADDR' => 'C', # postgres + 'VAR_STRING' => 'C', # mysql + ## + 'LONGCHAR' => 'X', + 'TEXT' => 'X', + 'NTEXT' => 'X', + 'M' => 'X', + 'X' => 'X', + 'CLOB' => 'X', + 'NCLOB' => 'X', + 'LVARCHAR' => 'X', + ## + 'BLOB' => 'B', + 'IMAGE' => 'B', + 'BINARY' => 'B', + 'VARBINARY' => 'B', + 'LONGBINARY' => 'B', + 'B' => 'B', + ## + 'YEAR' => 'D', // mysql + 'DATE' => 'D', + 'D' => 'D', + ## + 'UNIQUEIDENTIFIER' => 'C', # MS SQL Server + ## + 'TIME' => 'T', + 'TIMESTAMP' => 'T', + 'DATETIME' => 'T', + 'TIMESTAMPTZ' => 'T', + 'SMALLDATETIME' => 'T', + 'T' => 'T', + 'TIMESTAMP WITHOUT TIME ZONE' => 'T', // postgresql + ## + 'BOOL' => 'L', + 'BOOLEAN' => 'L', + 'BIT' => 'L', + 'L' => 'L', + ## + 'COUNTER' => 'R', + 'R' => 'R', + 'SERIAL' => 'R', // ifx + 'INT IDENTITY' => 'R', + ## + 'INT' => 'I', + 'INT2' => 'I', + 'INT4' => 'I', + 'INT8' => 'I', + 'INTEGER' => 'I', + 'INTEGER UNSIGNED' => 'I', + 'SHORT' => 'I', + 'TINYINT' => 'I', + 'SMALLINT' => 'I', + 'I' => 'I', + ## + 'LONG' => 'N', // interbase is numeric, oci8 is blob + 'BIGINT' => 'N', // this is bigger than PHP 32-bit integers + 'DECIMAL' => 'N', + 'DEC' => 'N', + 'REAL' => 'N', + 'DOUBLE' => 'N', + 'DOUBLE PRECISION' => 'N', + 'SMALLFLOAT' => 'N', + 'FLOAT' => 'N', + 'NUMBER' => 'N', + 'NUM' => 'N', + 'NUMERIC' => 'N', + 'MONEY' => 'N', + + ## informix 9.2 + 'SQLINT' => 'I', + 'SQLSERIAL' => 'I', + 'SQLSMINT' => 'I', + 'SQLSMFLOAT' => 'N', + 'SQLFLOAT' => 'N', + 'SQLMONEY' => 'N', + 'SQLDECIMAL' => 'N', + 'SQLDATE' => 'D', + 'SQLVCHAR' => 'C', + 'SQLCHAR' => 'C', + 'SQLDTIME' => 'T', + 'SQLINTERVAL' => 'N', + 'SQLBYTES' => 'B', + 'SQLTEXT' => 'X', + ## informix 10 + "SQLINT8" => 'I8', + "SQLSERIAL8" => 'I8', + "SQLNCHAR" => 'C', + "SQLNVCHAR" => 'C', + "SQLLVARCHAR" => 'X', + "SQLBOOL" => 'L' + ); + + if (!$this->connection->IsConnected()) { + $t = strtoupper($t); + if (isset($typeMap[$t])) return $typeMap[$t]; + return 'N'; + } + return $this->connection->MetaType($t,$len,$fieldobj); + } + + function NameQuote($name = NULL,$allowBrackets=false) + { + if (!is_string($name)) { + return FALSE; + } + + $name = trim($name); + + if ( !is_object($this->connection) ) { + return $name; + } + + $quote = $this->connection->nameQuote; + + // if name is of the form `name`, quote it + if ( preg_match('/^`(.+)`$/', $name, $matches) ) { + return $quote . $matches[1] . $quote; + } + + // if name contains special characters, quote it + $regex = ($allowBrackets) ? $this->nameRegexBrackets : $this->nameRegex; + + if ( !preg_match('/^[' . $regex . ']+$/', $name) ) { + return $quote . $name . $quote; + } + + return $name; + } + + function TableName($name) + { + if ( $this->schema ) { + return $this->NameQuote($this->schema) .'.'. $this->NameQuote($name); + } + return $this->NameQuote($name); + } + + // Executes the sql array returned by GetTableSQL and GetIndexSQL + function ExecuteSQLArray($sql, $continueOnError = true) + { + $rez = 2; + $conn = $this->connection; + $saved = $conn->debug; + foreach($sql as $line) { + + if ($this->debug) $conn->debug = true; + $ok = $conn->Execute($line); + $conn->debug = $saved; + if (!$ok) { + if ($this->debug) ADOConnection::outp($conn->ErrorMsg()); + if (!$continueOnError) return 0; + $rez = 1; + } + } + return $rez; + } + + /** + Returns the actual type given a character code. + + C: varchar + X: CLOB (character large object) or largest varchar size if CLOB is not supported + C2: Multibyte varchar + X2: Multibyte CLOB + + B: BLOB (binary large object) + + D: Date + T: Date-time + L: Integer field suitable for storing booleans (0 or 1) + I: Integer + F: Floating point number + N: Numeric or decimal number + */ + + function ActualType($meta) + { + return $meta; + } + + function CreateDatabase($dbname,$options=false) + { + $options = $this->_Options($options); + $sql = array(); + + $s = 'CREATE DATABASE ' . $this->NameQuote($dbname); + if (isset($options[$this->upperName])) + $s .= ' '.$options[$this->upperName]; + + $sql[] = $s; + return $sql; + } + + /* + Generates the SQL to create index. Returns an array of sql strings. + */ + function CreateIndexSQL($idxname, $tabname, $flds, $idxoptions = false) + { + if (!is_array($flds)) { + $flds = explode(',',$flds); + } + + foreach($flds as $key => $fld) { + # some indexes can use partial fields, eg. index first 32 chars of "name" with NAME(32) + $flds[$key] = $this->NameQuote($fld,$allowBrackets=true); + } + + return $this->_IndexSQL($this->NameQuote($idxname), $this->TableName($tabname), $flds, $this->_Options($idxoptions)); + } + + function DropIndexSQL ($idxname, $tabname = NULL) + { + return array(sprintf($this->dropIndex, $this->NameQuote($idxname), $this->TableName($tabname))); + } + + function SetSchema($schema) + { + $this->schema = $schema; + } + + function AddColumnSQL($tabname, $flds) + { + $tabname = $this->TableName ($tabname); + $sql = array(); + list($lines,$pkey,$idxs) = $this->_GenFields($flds); + // genfields can return FALSE at times + if ($lines == null) $lines = array(); + $alter = 'ALTER TABLE ' . $tabname . $this->addCol . ' '; + foreach($lines as $v) { + $sql[] = $alter . $v; + } + if (is_array($idxs)) { + foreach($idxs as $idx => $idxdef) { + $sql_idxs = $this->CreateIndexSql($idx, $tabname, $idxdef['cols'], $idxdef['opts']); + $sql = array_merge($sql, $sql_idxs); + } + } + return $sql; + } + + /** + * Change the definition of one column + * + * As some DBM's can't do that on there own, you need to supply the complete defintion of the new table, + * to allow, recreating the table and copying the content over to the new table + * @param string $tabname table-name + * @param string $flds column-name and type for the changed column + * @param string $tableflds='' complete defintion of the new table, eg. for postgres, default '' + * @param array/string $tableoptions='' options for the new table see CreateTableSQL, default '' + * @return array with SQL strings + */ + function AlterColumnSQL($tabname, $flds, $tableflds='',$tableoptions='') + { + $tabname = $this->TableName ($tabname); + $sql = array(); + list($lines,$pkey,$idxs) = $this->_GenFields($flds); + // genfields can return FALSE at times + if ($lines == null) $lines = array(); + $alter = 'ALTER TABLE ' . $tabname . $this->alterCol . ' '; + foreach($lines as $v) { + $sql[] = $alter . $v; + } + if (is_array($idxs)) { + foreach($idxs as $idx => $idxdef) { + $sql_idxs = $this->CreateIndexSql($idx, $tabname, $idxdef['cols'], $idxdef['opts']); + $sql = array_merge($sql, $sql_idxs); + } + + } + return $sql; + } + + /** + * Rename one column + * + * Some DBM's can only do this together with changeing the type of the column (even if that stays the same, eg. mysql) + * @param string $tabname table-name + * @param string $oldcolumn column-name to be renamed + * @param string $newcolumn new column-name + * @param string $flds='' complete column-defintion-string like for AddColumnSQL, only used by mysql atm., default='' + * @return array with SQL strings + */ + function RenameColumnSQL($tabname,$oldcolumn,$newcolumn,$flds='') + { + $tabname = $this->TableName ($tabname); + if ($flds) { + list($lines,$pkey,$idxs) = $this->_GenFields($flds); + // genfields can return FALSE at times + if ($lines == null) $lines = array(); + list(,$first) = each($lines); + list(,$column_def) = preg_split("/[\t ]+/",$first,2); + } + return array(sprintf($this->renameColumn,$tabname,$this->NameQuote($oldcolumn),$this->NameQuote($newcolumn),$column_def)); + } + + /** + * Drop one column + * + * Some DBM's can't do that on there own, you need to supply the complete defintion of the new table, + * to allow, recreating the table and copying the content over to the new table + * @param string $tabname table-name + * @param string $flds column-name and type for the changed column + * @param string $tableflds='' complete defintion of the new table, eg. for postgres, default '' + * @param array/string $tableoptions='' options for the new table see CreateTableSQL, default '' + * @return array with SQL strings + */ + function DropColumnSQL($tabname, $flds, $tableflds='',$tableoptions='') + { + $tabname = $this->TableName ($tabname); + if (!is_array($flds)) $flds = explode(',',$flds); + $sql = array(); + $alter = 'ALTER TABLE ' . $tabname . $this->dropCol . ' '; + foreach($flds as $v) { + $sql[] = $alter . $this->NameQuote($v); + } + return $sql; + } + + function DropTableSQL($tabname) + { + return array (sprintf($this->dropTable, $this->TableName($tabname))); + } + + function RenameTableSQL($tabname,$newname) + { + return array (sprintf($this->renameTable, $this->TableName($tabname),$this->TableName($newname))); + } + + /** + Generate the SQL to create table. Returns an array of sql strings. + */ + function CreateTableSQL($tabname, $flds, $tableoptions=array()) + { + list($lines,$pkey,$idxs) = $this->_GenFields($flds, true); + // genfields can return FALSE at times + if ($lines == null) $lines = array(); + + $taboptions = $this->_Options($tableoptions); + $tabname = $this->TableName ($tabname); + $sql = $this->_TableSQL($tabname,$lines,$pkey,$taboptions); + + // ggiunta - 2006/10/12 - KLUDGE: + // if we are on autoincrement, and table options includes REPLACE, the + // autoincrement sequence has already been dropped on table creation sql, so + // we avoid passing REPLACE to trigger creation code. This prevents + // creating sql that double-drops the sequence + if ($this->autoIncrement && isset($taboptions['REPLACE'])) + unset($taboptions['REPLACE']); + $tsql = $this->_Triggers($tabname,$taboptions); + foreach($tsql as $s) $sql[] = $s; + + if (is_array($idxs)) { + foreach($idxs as $idx => $idxdef) { + $sql_idxs = $this->CreateIndexSql($idx, $tabname, $idxdef['cols'], $idxdef['opts']); + $sql = array_merge($sql, $sql_idxs); + } + } + + return $sql; + } + + + + function _GenFields($flds,$widespacing=false) + { + if (is_string($flds)) { + $padding = ' '; + $txt = $flds.$padding; + $flds = array(); + $flds0 = Lens_ParseArgs($txt,','); + $hasparam = false; + foreach($flds0 as $f0) { + $f1 = array(); + foreach($f0 as $token) { + switch (strtoupper($token)) { + case 'INDEX': + $f1['INDEX'] = ''; + // fall through intentionally + case 'CONSTRAINT': + case 'DEFAULT': + $hasparam = $token; + break; + default: + if ($hasparam) $f1[$hasparam] = $token; + else $f1[] = $token; + $hasparam = false; + break; + } + } + // 'index' token without a name means single column index: name it after column + if (array_key_exists('INDEX', $f1) && $f1['INDEX'] == '') { + $f1['INDEX'] = isset($f0['NAME']) ? $f0['NAME'] : $f0[0]; + // check if column name used to create an index name was quoted + if (($f1['INDEX'][0] == '"' || $f1['INDEX'][0] == "'" || $f1['INDEX'][0] == "`") && + ($f1['INDEX'][0] == substr($f1['INDEX'], -1))) { + $f1['INDEX'] = $f1['INDEX'][0].'idx_'.substr($f1['INDEX'], 1, -1).$f1['INDEX'][0]; + } + else + $f1['INDEX'] = 'idx_'.$f1['INDEX']; + } + // reset it, so we don't get next field 1st token as INDEX... + $hasparam = false; + + $flds[] = $f1; + + } + } + $this->autoIncrement = false; + $lines = array(); + $pkey = array(); + $idxs = array(); + foreach($flds as $fld) { + $fld = _array_change_key_case($fld); + + $fname = false; + $fdefault = false; + $fautoinc = false; + $ftype = false; + $fsize = false; + $fprec = false; + $fprimary = false; + $fnoquote = false; + $fdefts = false; + $fdefdate = false; + $fconstraint = false; + $fnotnull = false; + $funsigned = false; + $findex = ''; + $funiqueindex = false; + + //----------------- + // Parse attributes + foreach($fld as $attr => $v) { + if ($attr == 2 && is_numeric($v)) $attr = 'SIZE'; + else if (is_numeric($attr) && $attr > 1 && !is_numeric($v)) $attr = strtoupper($v); + + switch($attr) { + case '0': + case 'NAME': $fname = $v; break; + case '1': + case 'TYPE': $ty = $v; $ftype = $this->ActualType(strtoupper($v)); break; + + case 'SIZE': + $dotat = strpos($v,'.'); if ($dotat === false) $dotat = strpos($v,','); + if ($dotat === false) $fsize = $v; + else { + $fsize = substr($v,0,$dotat); + $fprec = substr($v,$dotat+1); + } + break; + case 'UNSIGNED': $funsigned = true; break; + case 'AUTOINCREMENT': + case 'AUTO': $fautoinc = true; $fnotnull = true; break; + case 'KEY': + // a primary key col can be non unique in itself (if key spans many cols...) + case 'PRIMARY': $fprimary = $v; $fnotnull = true; /*$funiqueindex = true;*/ break; + case 'DEF': + case 'DEFAULT': $fdefault = $v; break; + case 'NOTNULL': $fnotnull = $v; break; + case 'NOQUOTE': $fnoquote = $v; break; + case 'DEFDATE': $fdefdate = $v; break; + case 'DEFTIMESTAMP': $fdefts = $v; break; + case 'CONSTRAINT': $fconstraint = $v; break; + // let INDEX keyword create a 'very standard' index on column + case 'INDEX': $findex = $v; break; + case 'UNIQUE': $funiqueindex = true; break; + } //switch + } // foreach $fld + + //-------------------- + // VALIDATE FIELD INFO + if (!strlen($fname)) { + if ($this->debug) ADOConnection::outp("Undefined NAME"); + return false; + } + + $fid = strtoupper(preg_replace('/^`(.+)`$/', '$1', $fname)); + $fname = $this->NameQuote($fname); + + if (!strlen($ftype)) { + if ($this->debug) ADOConnection::outp("Undefined TYPE for field '$fname'"); + return false; + } else { + $ftype = strtoupper($ftype); + } + + $ftype = $this->_GetSize($ftype, $ty, $fsize, $fprec); + + if ($ty == 'X' || $ty == 'X2' || $ty == 'B') $fnotnull = false; // some blob types do not accept nulls + + if ($fprimary) $pkey[] = $fname; + + // some databases do not allow blobs to have defaults + if ($ty == 'X') $fdefault = false; + + // build list of indexes + if ($findex != '') { + if (array_key_exists($findex, $idxs)) { + $idxs[$findex]['cols'][] = ($fname); + if (in_array('UNIQUE', $idxs[$findex]['opts']) != $funiqueindex) { + if ($this->debug) ADOConnection::outp("Index $findex defined once UNIQUE and once not"); + } + if ($funiqueindex && !in_array('UNIQUE', $idxs[$findex]['opts'])) + $idxs[$findex]['opts'][] = 'UNIQUE'; + } + else + { + $idxs[$findex] = array(); + $idxs[$findex]['cols'] = array($fname); + if ($funiqueindex) + $idxs[$findex]['opts'] = array('UNIQUE'); + else + $idxs[$findex]['opts'] = array(); + } + } + + //-------------------- + // CONSTRUCT FIELD SQL + if ($fdefts) { + if (substr($this->connection->databaseType,0,5) == 'mysql') { + $ftype = 'TIMESTAMP'; + } else { + $fdefault = $this->connection->sysTimeStamp; + } + } else if ($fdefdate) { + if (substr($this->connection->databaseType,0,5) == 'mysql') { + $ftype = 'TIMESTAMP'; + } else { + $fdefault = $this->connection->sysDate; + } + } else if ($fdefault !== false && !$fnoquote) { + if ($ty == 'C' or $ty == 'X' or + ( substr($fdefault,0,1) != "'" && !is_numeric($fdefault))) { + + if (($ty == 'D' || $ty == 'T') && strtolower($fdefault) != 'null') { + // convert default date into database-aware code + if ($ty == 'T') + { + $fdefault = $this->connection->DBTimeStamp($fdefault); + } + else + { + $fdefault = $this->connection->DBDate($fdefault); + } + } + else + if (strlen($fdefault) != 1 && substr($fdefault,0,1) == ' ' && substr($fdefault,strlen($fdefault)-1) == ' ') + $fdefault = trim($fdefault); + else if (strtolower($fdefault) != 'null') + $fdefault = $this->connection->qstr($fdefault); + } + } + $suffix = $this->_CreateSuffix($fname,$ftype,$fnotnull,$fdefault,$fautoinc,$fconstraint,$funsigned); + + // add index creation + if ($widespacing) $fname = str_pad($fname,24); + + // check for field names appearing twice + if (array_key_exists($fid, $lines)) { + ADOConnection::outp("Field '$fname' defined twice"); + } + + $lines[$fid] = $fname.' '.$ftype.$suffix; + + if ($fautoinc) $this->autoIncrement = true; + } // foreach $flds + + return array($lines,$pkey,$idxs); + } + + /** + GENERATE THE SIZE PART OF THE DATATYPE + $ftype is the actual type + $ty is the type defined originally in the DDL + */ + function _GetSize($ftype, $ty, $fsize, $fprec) + { + if (strlen($fsize) && $ty != 'X' && $ty != 'B' && strpos($ftype,'(') === false) { + $ftype .= "(".$fsize; + if (strlen($fprec)) $ftype .= ",".$fprec; + $ftype .= ')'; + } + return $ftype; + } + + + // return string must begin with space + function _CreateSuffix($fname,&$ftype,$fnotnull,$fdefault,$fautoinc,$fconstraint,$funsigned) + { + $suffix = ''; + if (strlen($fdefault)) $suffix .= " DEFAULT $fdefault"; + if ($fnotnull) $suffix .= ' NOT NULL'; + if ($fconstraint) $suffix .= ' '.$fconstraint; + return $suffix; + } + + function _IndexSQL($idxname, $tabname, $flds, $idxoptions) + { + $sql = array(); + + if ( isset($idxoptions['REPLACE']) || isset($idxoptions['DROP']) ) { + $sql[] = sprintf ($this->dropIndex, $idxname); + if ( isset($idxoptions['DROP']) ) + return $sql; + } + + if ( empty ($flds) ) { + return $sql; + } + + $unique = isset($idxoptions['UNIQUE']) ? ' UNIQUE' : ''; + + $s = 'CREATE' . $unique . ' INDEX ' . $idxname . ' ON ' . $tabname . ' '; + + if ( isset($idxoptions[$this->upperName]) ) + $s .= $idxoptions[$this->upperName]; + + if ( is_array($flds) ) + $flds = implode(', ',$flds); + $s .= '(' . $flds . ')'; + $sql[] = $s; + + return $sql; + } + + function _DropAutoIncrement($tabname) + { + return false; + } + + function _TableSQL($tabname,$lines,$pkey,$tableoptions) + { + $sql = array(); + + if (isset($tableoptions['REPLACE']) || isset ($tableoptions['DROP'])) { + $sql[] = sprintf($this->dropTable,$tabname); + if ($this->autoIncrement) { + $sInc = $this->_DropAutoIncrement($tabname); + if ($sInc) $sql[] = $sInc; + } + if ( isset ($tableoptions['DROP']) ) { + return $sql; + } + } + $s = "CREATE TABLE $tabname (\n"; + $s .= implode(",\n", $lines); + if (sizeof($pkey)>0) { + $s .= ",\n PRIMARY KEY ("; + $s .= implode(", ",$pkey).")"; + } + if (isset($tableoptions['CONSTRAINTS'])) + $s .= "\n".$tableoptions['CONSTRAINTS']; + + if (isset($tableoptions[$this->upperName.'_CONSTRAINTS'])) + $s .= "\n".$tableoptions[$this->upperName.'_CONSTRAINTS']; + + $s .= "\n)"; + if (isset($tableoptions[$this->upperName])) $s .= $tableoptions[$this->upperName]; + $sql[] = $s; + + return $sql; + } + + /** + GENERATE TRIGGERS IF NEEDED + used when table has auto-incrementing field that is emulated using triggers + */ + function _Triggers($tabname,$taboptions) + { + return array(); + } + + /** + Sanitize options, so that array elements with no keys are promoted to keys + */ + function _Options($opts) + { + if (!is_array($opts)) return array(); + $newopts = array(); + foreach($opts as $k => $v) { + if (is_numeric($k)) $newopts[strtoupper($v)] = $v; + else $newopts[strtoupper($k)] = $v; + } + return $newopts; + } + + + function _getSizePrec($size) + { + $fsize = false; + $fprec = false; + $dotat = strpos($size,'.'); + if ($dotat === false) $dotat = strpos($size,','); + if ($dotat === false) $fsize = $size; + else { + $fsize = substr($size,0,$dotat); + $fprec = substr($size,$dotat+1); + } + return array($fsize, $fprec); + } + + /** + "Florian Buzin [ easywe ]" + + This function changes/adds new fields to your table. You don't + have to know if the col is new or not. It will check on its own. + */ + function ChangeTableSQL($tablename, $flds, $tableoptions = false, $dropOldFlds=false) + { + global $ADODB_FETCH_MODE; + + $save = $ADODB_FETCH_MODE; + $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC; + if ($this->connection->fetchMode !== false) $savem = $this->connection->SetFetchMode(false); + + // check table exists + $save_handler = $this->connection->raiseErrorFn; + $this->connection->raiseErrorFn = ''; + $cols = $this->MetaColumns($tablename); + $this->connection->raiseErrorFn = $save_handler; + + if (isset($savem)) $this->connection->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + + if ( empty($cols)) { + return $this->CreateTableSQL($tablename, $flds, $tableoptions); + } + + if (is_array($flds)) { + // Cycle through the update fields, comparing + // existing fields to fields to update. + // if the Metatype and size is exactly the + // same, ignore - by Mark Newham + $holdflds = array(); + foreach($flds as $k=>$v) { + if ( isset($cols[$k]) && is_object($cols[$k]) ) { + // If already not allowing nulls, then don't change + $obj = $cols[$k]; + if (isset($obj->not_null) && $obj->not_null) + $v = str_replace('NOT NULL','',$v); + if (isset($obj->auto_increment) && $obj->auto_increment && empty($v['AUTOINCREMENT'])) + $v = str_replace('AUTOINCREMENT','',$v); + + $c = $cols[$k]; + $ml = $c->max_length; + $mt = $this->MetaType($c->type,$ml); + + if (isset($c->scale)) $sc = $c->scale; + else $sc = 99; // always force change if scale not known. + + if ($sc == -1) $sc = false; + list($fsize, $fprec) = $this->_getSizePrec($v['SIZE']); + + if ($ml == -1) $ml = ''; + if ($mt == 'X') $ml = $v['SIZE']; + if (($mt != $v['TYPE']) || ($ml != $fsize || $sc != $fprec) || (isset($v['AUTOINCREMENT']) && $v['AUTOINCREMENT'] != $obj->auto_increment)) { + $holdflds[$k] = $v; + } + } else { + $holdflds[$k] = $v; + } + } + $flds = $holdflds; + } + + + // already exists, alter table instead + list($lines,$pkey,$idxs) = $this->_GenFields($flds); + // genfields can return FALSE at times + if ($lines == null) $lines = array(); + $alter = 'ALTER TABLE ' . $this->TableName($tablename); + $sql = array(); + + foreach ( $lines as $id => $v ) { + if ( isset($cols[$id]) && is_object($cols[$id]) ) { + + $flds = Lens_ParseArgs($v,','); + + // We are trying to change the size of the field, if not allowed, simply ignore the request. + // $flds[1] holds the type, $flds[2] holds the size -postnuke addition + if ($flds && in_array(strtoupper(substr($flds[0][1],0,4)),$this->invalidResizeTypes4) + && (isset($flds[0][2]) && is_numeric($flds[0][2]))) { + if ($this->debug) ADOConnection::outp(sprintf("

%s cannot be changed to %s currently

", $flds[0][0], $flds[0][1])); + #echo "

$this->alterCol cannot be changed to $flds currently

"; + continue; + } + $sql[] = $alter . $this->alterCol . ' ' . $v; + } else { + $sql[] = $alter . $this->addCol . ' ' . $v; + } + } + + if ($dropOldFlds) { + foreach ( $cols as $id => $v ) + if ( !isset($lines[$id]) ) + $sql[] = $alter . $this->dropCol . ' ' . $v->name; + } + return $sql; + } +} // class +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-error.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-error.inc.php new file mode 100644 index 00000000..6ec614d2 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-error.inc.php @@ -0,0 +1,258 @@ + DB_ERROR_NOSUCHTABLE, + '/Relation [\"\'].*[\"\'] already exists|Cannot insert a duplicate key into (a )?unique index.*/i' => DB_ERROR_ALREADY_EXISTS, + '/divide by zero$/i' => DB_ERROR_DIVZERO, + '/pg_atoi: error in .*: can\'t parse /i' => DB_ERROR_INVALID_NUMBER, + '/ttribute [\"\'].*[\"\'] not found|Relation [\"\'].*[\"\'] does not have attribute [\"\'].*[\"\']/i' => DB_ERROR_NOSUCHFIELD, + '/parser: parse error at or near \"/i' => DB_ERROR_SYNTAX, + '/referential integrity violation/i' => DB_ERROR_CONSTRAINT, + '/Relation [\"\'].*[\"\'] already exists|Cannot insert a duplicate key into (a )?unique index.*|duplicate key.*violates unique constraint/i' + => DB_ERROR_ALREADY_EXISTS + ); + reset($error_regexps); + while (list($regexp,$code) = each($error_regexps)) { + if (preg_match($regexp, $errormsg)) { + return $code; + } + } + // Fall back to DB_ERROR if there was no mapping. + return DB_ERROR; +} + +function adodb_error_odbc() +{ +static $MAP = array( + '01004' => DB_ERROR_TRUNCATED, + '07001' => DB_ERROR_MISMATCH, + '21S01' => DB_ERROR_MISMATCH, + '21S02' => DB_ERROR_MISMATCH, + '22003' => DB_ERROR_INVALID_NUMBER, + '22008' => DB_ERROR_INVALID_DATE, + '22012' => DB_ERROR_DIVZERO, + '23000' => DB_ERROR_CONSTRAINT, + '24000' => DB_ERROR_INVALID, + '34000' => DB_ERROR_INVALID, + '37000' => DB_ERROR_SYNTAX, + '42000' => DB_ERROR_SYNTAX, + 'IM001' => DB_ERROR_UNSUPPORTED, + 'S0000' => DB_ERROR_NOSUCHTABLE, + 'S0001' => DB_ERROR_NOT_FOUND, + 'S0002' => DB_ERROR_NOSUCHTABLE, + 'S0011' => DB_ERROR_ALREADY_EXISTS, + 'S0012' => DB_ERROR_NOT_FOUND, + 'S0021' => DB_ERROR_ALREADY_EXISTS, + 'S0022' => DB_ERROR_NOT_FOUND, + 'S1000' => DB_ERROR_NOSUCHTABLE, + 'S1009' => DB_ERROR_INVALID, + 'S1090' => DB_ERROR_INVALID, + 'S1C00' => DB_ERROR_NOT_CAPABLE + ); + return $MAP; +} + +function adodb_error_ibase() +{ +static $MAP = array( + -104 => DB_ERROR_SYNTAX, + -150 => DB_ERROR_ACCESS_VIOLATION, + -151 => DB_ERROR_ACCESS_VIOLATION, + -155 => DB_ERROR_NOSUCHTABLE, + -157 => DB_ERROR_NOSUCHFIELD, + -158 => DB_ERROR_VALUE_COUNT_ON_ROW, + -170 => DB_ERROR_MISMATCH, + -171 => DB_ERROR_MISMATCH, + -172 => DB_ERROR_INVALID, + -204 => DB_ERROR_INVALID, + -205 => DB_ERROR_NOSUCHFIELD, + -206 => DB_ERROR_NOSUCHFIELD, + -208 => DB_ERROR_INVALID, + -219 => DB_ERROR_NOSUCHTABLE, + -297 => DB_ERROR_CONSTRAINT, + -530 => DB_ERROR_CONSTRAINT, + -803 => DB_ERROR_CONSTRAINT, + -551 => DB_ERROR_ACCESS_VIOLATION, + -552 => DB_ERROR_ACCESS_VIOLATION, + -922 => DB_ERROR_NOSUCHDB, + -923 => DB_ERROR_CONNECT_FAILED, + -924 => DB_ERROR_CONNECT_FAILED + ); + + return $MAP; +} + +function adodb_error_ifx() +{ +static $MAP = array( + '-201' => DB_ERROR_SYNTAX, + '-206' => DB_ERROR_NOSUCHTABLE, + '-217' => DB_ERROR_NOSUCHFIELD, + '-329' => DB_ERROR_NODBSELECTED, + '-1204' => DB_ERROR_INVALID_DATE, + '-1205' => DB_ERROR_INVALID_DATE, + '-1206' => DB_ERROR_INVALID_DATE, + '-1209' => DB_ERROR_INVALID_DATE, + '-1210' => DB_ERROR_INVALID_DATE, + '-1212' => DB_ERROR_INVALID_DATE + ); + + return $MAP; +} + +function adodb_error_oci8() +{ +static $MAP = array( + 1 => DB_ERROR_ALREADY_EXISTS, + 900 => DB_ERROR_SYNTAX, + 904 => DB_ERROR_NOSUCHFIELD, + 923 => DB_ERROR_SYNTAX, + 942 => DB_ERROR_NOSUCHTABLE, + 955 => DB_ERROR_ALREADY_EXISTS, + 1476 => DB_ERROR_DIVZERO, + 1722 => DB_ERROR_INVALID_NUMBER, + 2289 => DB_ERROR_NOSUCHTABLE, + 2291 => DB_ERROR_CONSTRAINT, + 2449 => DB_ERROR_CONSTRAINT + ); + + return $MAP; +} + +function adodb_error_mssql() +{ +static $MAP = array( + 208 => DB_ERROR_NOSUCHTABLE, + 2601 => DB_ERROR_ALREADY_EXISTS + ); + + return $MAP; +} + +function adodb_error_sqlite() +{ +static $MAP = array( + 1 => DB_ERROR_SYNTAX + ); + + return $MAP; +} + +function adodb_error_mysql() +{ +static $MAP = array( + 1004 => DB_ERROR_CANNOT_CREATE, + 1005 => DB_ERROR_CANNOT_CREATE, + 1006 => DB_ERROR_CANNOT_CREATE, + 1007 => DB_ERROR_ALREADY_EXISTS, + 1008 => DB_ERROR_CANNOT_DROP, + 1045 => DB_ERROR_ACCESS_VIOLATION, + 1046 => DB_ERROR_NODBSELECTED, + 1049 => DB_ERROR_NOSUCHDB, + 1050 => DB_ERROR_ALREADY_EXISTS, + 1051 => DB_ERROR_NOSUCHTABLE, + 1054 => DB_ERROR_NOSUCHFIELD, + 1062 => DB_ERROR_ALREADY_EXISTS, + 1064 => DB_ERROR_SYNTAX, + 1100 => DB_ERROR_NOT_LOCKED, + 1136 => DB_ERROR_VALUE_COUNT_ON_ROW, + 1146 => DB_ERROR_NOSUCHTABLE, + 1048 => DB_ERROR_CONSTRAINT, + 2002 => DB_ERROR_CONNECT_FAILED, + 2005 => DB_ERROR_CONNECT_FAILED + ); + + return $MAP; +} +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-iterator.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-iterator.inc.php new file mode 100644 index 00000000..e8b5e57b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-iterator.inc.php @@ -0,0 +1,30 @@ +Execute("select * from adoxyz"); + foreach($rs as $k => $v) { + echo $k; print_r($v); echo "
"; + } + + + Iterator code based on http://cvs.php.net/cvs.php/php-src/ext/spl/examples/cachingiterator.inc?login=2 + + + Moved to adodb.inc.php to improve performance. + */ + + + + + +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-lib.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-lib.inc.php new file mode 100644 index 00000000..6b2e8910 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-lib.inc.php @@ -0,0 +1,1197 @@ + sizeof($array)) $max = sizeof($array); + else $max = $probe; + + + for ($j=0;$j < $max; $j++) { + $row = $array[$j]; + if (!$row) break; + $i = -1; + foreach($row as $v) { + $i += 1; + + if (isset($types[$i]) && $types[$i]=='C') continue; + + //print " ($i ".$types[$i]. "$v) "; + $v = trim($v); + + if (!preg_match('/^[+-]{0,1}[0-9\.]+$/',$v)) { + $types[$i] = 'C'; // once C, always C + + continue; + } + if ($j == 0) { + // If empty string, we presume is character + // test for integer for 1st row only + // after that it is up to testing other rows to prove + // that it is not an integer + if (strlen($v) == 0) $types[$i] = 'C'; + if (strpos($v,'.') !== false) $types[$i] = 'N'; + else $types[$i] = 'I'; + continue; + } + + if (strpos($v,'.') !== false) $types[$i] = 'N'; + + } + } + +} + +function adodb_transpose(&$arr, &$newarr, &$hdr, &$fobjs) +{ + $oldX = sizeof(reset($arr)); + $oldY = sizeof($arr); + + if ($hdr) { + $startx = 1; + $hdr = array('Fields'); + for ($y = 0; $y < $oldY; $y++) { + $hdr[] = $arr[$y][0]; + } + } else + $startx = 0; + + for ($x = $startx; $x < $oldX; $x++) { + if ($fobjs) { + $o = $fobjs[$x]; + $newarr[] = array($o->name); + } else + $newarr[] = array(); + + for ($y = 0; $y < $oldY; $y++) { + $newarr[$x-$startx][] = $arr[$y][$x]; + } + } +} + +// Force key to upper. +// See also http://www.php.net/manual/en/function.array-change-key-case.php +function _array_change_key_case($an_array) +{ + if (is_array($an_array)) { + $new_array = array(); + foreach($an_array as $key=>$value) + $new_array[strtoupper($key)] = $value; + + return $new_array; + } + + return $an_array; +} + +function _adodb_replace(&$zthis, $table, $fieldArray, $keyCol, $autoQuote, $has_autoinc) +{ + if (count($fieldArray) == 0) return 0; + $first = true; + $uSet = ''; + + if (!is_array($keyCol)) { + $keyCol = array($keyCol); + } + foreach($fieldArray as $k => $v) { + if ($v === null) { + $v = 'NULL'; + $fieldArray[$k] = $v; + } else if ($autoQuote && /*!is_numeric($v) /*and strncmp($v,"'",1) !== 0 -- sql injection risk*/ strcasecmp($v,$zthis->null2null)!=0) { + $v = $zthis->qstr($v); + $fieldArray[$k] = $v; + } + if (in_array($k,$keyCol)) continue; // skip UPDATE if is key + + if ($first) { + $first = false; + $uSet = "$k=$v"; + } else + $uSet .= ",$k=$v"; + } + + $where = false; + foreach ($keyCol as $v) { + if (isset($fieldArray[$v])) { + if ($where) $where .= ' and '.$v.'='.$fieldArray[$v]; + else $where = $v.'='.$fieldArray[$v]; + } + } + + if ($uSet && $where) { + $update = "UPDATE $table SET $uSet WHERE $where"; + + $rs = $zthis->Execute($update); + + + if ($rs) { + if ($zthis->poorAffectedRows) { + /* + The Select count(*) wipes out any errors that the update would have returned. + http://phplens.com/lens/lensforum/msgs.php?id=5696 + */ + if ($zthis->ErrorNo()<>0) return 0; + + # affected_rows == 0 if update field values identical to old values + # for mysql - which is silly. + + $cnt = $zthis->GetOne("select count(*) from $table where $where"); + if ($cnt > 0) return 1; // record already exists + } else { + if (($zthis->Affected_Rows()>0)) return 1; + } + } else + return 0; + } + + // print "

Error=".$this->ErrorNo().'

'; + $first = true; + foreach($fieldArray as $k => $v) { + if ($has_autoinc && in_array($k,$keyCol)) continue; // skip autoinc col + + if ($first) { + $first = false; + $iCols = "$k"; + $iVals = "$v"; + } else { + $iCols .= ",$k"; + $iVals .= ",$v"; + } + } + $insert = "INSERT INTO $table ($iCols) VALUES ($iVals)"; + $rs = $zthis->Execute($insert); + return ($rs) ? 2 : 0; +} + +// Requires $ADODB_FETCH_MODE = ADODB_FETCH_NUM +function _adodb_getmenu(&$zthis, $name,$defstr='',$blank1stItem=true,$multiple=false, + $size=0, $selectAttr='',$compareFields0=true) +{ + $hasvalue = false; + + if ($multiple or is_array($defstr)) { + if ($size==0) $size=5; + $attr = ' multiple size="'.$size.'"'; + if (!strpos($name,'[]')) $name .= '[]'; + } else if ($size) $attr = ' size="'.$size.'"'; + else $attr =''; + + $s = '\n"; +} + +// Requires $ADODB_FETCH_MODE = ADODB_FETCH_NUM +function _adodb_getmenu_gp(&$zthis, $name,$defstr='',$blank1stItem=true,$multiple=false, + $size=0, $selectAttr='',$compareFields0=true) +{ + $hasvalue = false; + + if ($multiple or is_array($defstr)) { + if ($size==0) $size=5; + $attr = ' multiple size="'.$size.'"'; + if (!strpos($name,'[]')) $name .= '[]'; + } else if ($size) $attr = ' size="'.$size.'"'; + else $attr =''; + + $s = '\n"; +} + + +/* + Count the number of records this sql statement will return by using + query rewriting heuristics... + + Does not work with UNIONs, except with postgresql and oracle. + + Usage: + + $conn->Connect(...); + $cnt = _adodb_getcount($conn, $sql); + +*/ +function _adodb_getcount(&$zthis, $sql,$inputarr=false,$secs2cache=0) +{ + $qryRecs = 0; + + if (!empty($zthis->_nestedSQL) || preg_match("/^\s*SELECT\s+DISTINCT/is", $sql) || + preg_match('/\s+GROUP\s+BY\s+/is',$sql) || + preg_match('/\s+UNION\s+/is',$sql)) { + + $rewritesql = adodb_strip_order_by($sql); + + // ok, has SELECT DISTINCT or GROUP BY so see if we can use a table alias + // but this is only supported by oracle and postgresql... + if ($zthis->dataProvider == 'oci8') { + // Allow Oracle hints to be used for query optimization, Chris Wrye + if (preg_match('#/\\*+.*?\\*\\/#', $sql, $hint)) { + $rewritesql = "SELECT ".$hint[0]." COUNT(*) FROM (".$rewritesql.")"; + } else + $rewritesql = "SELECT COUNT(*) FROM (".$rewritesql.")"; + + } else if (strncmp($zthis->databaseType,'postgres',8) == 0 || strncmp($zthis->databaseType,'mysql',5) == 0) { + $rewritesql = "SELECT COUNT(*) FROM ($rewritesql) _ADODB_ALIAS_"; + } else { + $rewritesql = "SELECT COUNT(*) FROM ($rewritesql)"; + } + } else { + // now replace SELECT ... FROM with SELECT COUNT(*) FROM + $rewritesql = preg_replace( + '/^\s*SELECT\s.*\s+FROM\s/Uis','SELECT COUNT(*) FROM ',$sql); + // fix by alexander zhukov, alex#unipack.ru, because count(*) and 'order by' fails + // with mssql, access and postgresql. Also a good speedup optimization - skips sorting! + // also see http://phplens.com/lens/lensforum/msgs.php?id=12752 + $rewritesql = adodb_strip_order_by($rewritesql); + } + + if (isset($rewritesql) && $rewritesql != $sql) { + if (preg_match('/\sLIMIT\s+[0-9]+/i',$sql,$limitarr)) $rewritesql .= $limitarr[0]; + + if ($secs2cache) { + // we only use half the time of secs2cache because the count can quickly + // become inaccurate if new records are added + $qryRecs = $zthis->CacheGetOne($secs2cache/2,$rewritesql,$inputarr); + + } else { + $qryRecs = $zthis->GetOne($rewritesql,$inputarr); + } + if ($qryRecs !== false) return $qryRecs; + } + //-------------------------------------------- + // query rewrite failed - so try slower way... + + + // strip off unneeded ORDER BY if no UNION + if (preg_match('/\s*UNION\s*/is', $sql)) $rewritesql = $sql; + else $rewritesql = $rewritesql = adodb_strip_order_by($sql); + + if (preg_match('/\sLIMIT\s+[0-9]+/i',$sql,$limitarr)) $rewritesql .= $limitarr[0]; + + if ($secs2cache) { + $rstest = $zthis->CacheExecute($secs2cache,$rewritesql,$inputarr); + if (!$rstest) $rstest = $zthis->CacheExecute($secs2cache,$sql,$inputarr); + } else { + $rstest = $zthis->Execute($rewritesql,$inputarr); + if (!$rstest) $rstest = $zthis->Execute($sql,$inputarr); + } + if ($rstest) { + $qryRecs = $rstest->RecordCount(); + if ($qryRecs == -1) { + global $ADODB_EXTENSION; + // some databases will return -1 on MoveLast() - change to MoveNext() + if ($ADODB_EXTENSION) { + while(!$rstest->EOF) { + adodb_movenext($rstest); + } + } else { + while(!$rstest->EOF) { + $rstest->MoveNext(); + } + } + $qryRecs = $rstest->_currentRow; + } + $rstest->Close(); + if ($qryRecs == -1) return 0; + } + return $qryRecs; +} + +/* + Code originally from "Cornel G" + + This code might not work with SQL that has UNION in it + + Also if you are using CachePageExecute(), there is a strong possibility that + data will get out of synch. use CachePageExecute() only with tables that + rarely change. +*/ +function _adodb_pageexecute_all_rows(&$zthis, $sql, $nrows, $page, + $inputarr=false, $secs2cache=0) +{ + $atfirstpage = false; + $atlastpage = false; + $lastpageno=1; + + // If an invalid nrows is supplied, + // we assume a default value of 10 rows per page + if (!isset($nrows) || $nrows <= 0) $nrows = 10; + + $qryRecs = false; //count records for no offset + + $qryRecs = _adodb_getcount($zthis,$sql,$inputarr,$secs2cache); + $lastpageno = (int) ceil($qryRecs / $nrows); + $zthis->_maxRecordCount = $qryRecs; + + + + // ***** Here we check whether $page is the last page or + // whether we are trying to retrieve + // a page number greater than the last page number. + if ($page >= $lastpageno) { + $page = $lastpageno; + $atlastpage = true; + } + + // If page number <= 1, then we are at the first page + if (empty($page) || $page <= 1) { + $page = 1; + $atfirstpage = true; + } + + // We get the data we want + $offset = $nrows * ($page-1); + if ($secs2cache > 0) + $rsreturn = $zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $offset, $inputarr); + else + $rsreturn = $zthis->SelectLimit($sql, $nrows, $offset, $inputarr, $secs2cache); + + + // Before returning the RecordSet, we set the pagination properties we need + if ($rsreturn) { + $rsreturn->_maxRecordCount = $qryRecs; + $rsreturn->rowsPerPage = $nrows; + $rsreturn->AbsolutePage($page); + $rsreturn->AtFirstPage($atfirstpage); + $rsreturn->AtLastPage($atlastpage); + $rsreturn->LastPageNo($lastpageno); + } + return $rsreturn; +} + +// Iván Oliva version +function _adodb_pageexecute_no_last_page(&$zthis, $sql, $nrows, $page, $inputarr=false, $secs2cache=0) +{ + + $atfirstpage = false; + $atlastpage = false; + + if (!isset($page) || $page <= 1) { // If page number <= 1, then we are at the first page + $page = 1; + $atfirstpage = true; + } + if ($nrows <= 0) $nrows = 10; // If an invalid nrows is supplied, we assume a default value of 10 rows per page + + // ***** Here we check whether $page is the last page or whether we are trying to retrieve a page number greater than + // the last page number. + $pagecounter = $page + 1; + $pagecounteroffset = ($pagecounter * $nrows) - $nrows; + if ($secs2cache>0) $rstest = $zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $pagecounteroffset, $inputarr); + else $rstest = $zthis->SelectLimit($sql, $nrows, $pagecounteroffset, $inputarr, $secs2cache); + if ($rstest) { + while ($rstest && $rstest->EOF && $pagecounter>0) { + $atlastpage = true; + $pagecounter--; + $pagecounteroffset = $nrows * ($pagecounter - 1); + $rstest->Close(); + if ($secs2cache>0) $rstest = $zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $pagecounteroffset, $inputarr); + else $rstest = $zthis->SelectLimit($sql, $nrows, $pagecounteroffset, $inputarr, $secs2cache); + } + if ($rstest) $rstest->Close(); + } + if ($atlastpage) { // If we are at the last page or beyond it, we are going to retrieve it + $page = $pagecounter; + if ($page == 1) $atfirstpage = true; // We have to do this again in case the last page is the same as the first + //... page, that is, the recordset has only 1 page. + } + + // We get the data we want + $offset = $nrows * ($page-1); + if ($secs2cache > 0) $rsreturn = $zthis->CacheSelectLimit($secs2cache, $sql, $nrows, $offset, $inputarr); + else $rsreturn = $zthis->SelectLimit($sql, $nrows, $offset, $inputarr, $secs2cache); + + // Before returning the RecordSet, we set the pagination properties we need + if ($rsreturn) { + $rsreturn->rowsPerPage = $nrows; + $rsreturn->AbsolutePage($page); + $rsreturn->AtFirstPage($atfirstpage); + $rsreturn->AtLastPage($atlastpage); + } + return $rsreturn; +} + +function _adodb_getupdatesql(&$zthis,&$rs, $arrFields,$forceUpdate=false,$magicq=false,$force=2) +{ + global $ADODB_QUOTE_FIELDNAMES; + + if (!$rs) { + printf(ADODB_BAD_RS,'GetUpdateSQL'); + return false; + } + + $fieldUpdatedCount = 0; + $arrFields = _array_change_key_case($arrFields); + + $hasnumeric = isset($rs->fields[0]); + $setFields = ''; + + // Loop through all of the fields in the recordset + for ($i=0, $max=$rs->FieldCount(); $i < $max; $i++) { + // Get the field from the recordset + $field = $rs->FetchField($i); + + // If the recordset field is one + // of the fields passed in then process. + $upperfname = strtoupper($field->name); + if (adodb_key_exists($upperfname,$arrFields,$force)) { + + // If the existing field value in the recordset + // is different from the value passed in then + // go ahead and append the field name and new value to + // the update query. + + if ($hasnumeric) $val = $rs->fields[$i]; + else if (isset($rs->fields[$upperfname])) $val = $rs->fields[$upperfname]; + else if (isset($rs->fields[$field->name])) $val = $rs->fields[$field->name]; + else if (isset($rs->fields[strtolower($upperfname)])) $val = $rs->fields[strtolower($upperfname)]; + else $val = ''; + + + if ($forceUpdate || strcmp($val, $arrFields[$upperfname])) { + // Set the counter for the number of fields that will be updated. + $fieldUpdatedCount++; + + // Based on the datatype of the field + // Format the value properly for the database + $type = $rs->MetaType($field->type); + + + if ($type == 'null') { + $type = 'C'; + } + + if ((strpos($upperfname,' ') !== false) || ($ADODB_QUOTE_FIELDNAMES)) + $fnameq = $zthis->nameQuote.$upperfname.$zthis->nameQuote; + else + $fnameq = $upperfname; + + + // is_null requires php 4.0.4 + //********************************************************// + if (is_null($arrFields[$upperfname]) + || (empty($arrFields[$upperfname]) && strlen($arrFields[$upperfname]) == 0) + || $arrFields[$upperfname] === $zthis->null2null + ) + { + switch ($force) { + + //case 0: + // //Ignore empty values. This is allready handled in "adodb_key_exists" function. + //break; + + case 1: + //Set null + $setFields .= $field->name . " = null, "; + break; + + case 2: + //Set empty + $arrFields[$upperfname] = ""; + $setFields .= _adodb_column_sql($zthis, 'U', $type, $upperfname, $fnameq,$arrFields, $magicq); + break; + default: + case 3: + //Set the value that was given in array, so you can give both null and empty values + if (is_null($arrFields[$upperfname]) || $arrFields[$upperfname] === $zthis->null2null) { + $setFields .= $field->name . " = null, "; + } else { + $setFields .= _adodb_column_sql($zthis, 'U', $type, $upperfname, $fnameq,$arrFields, $magicq); + } + break; + } + //********************************************************// + } else { + //we do this so each driver can customize the sql for + //DB specific column types. + //Oracle needs BLOB types to be handled with a returning clause + //postgres has special needs as well + $setFields .= _adodb_column_sql($zthis, 'U', $type, $upperfname, $fnameq, + $arrFields, $magicq); + } + } + } + } + + // If there were any modified fields then build the rest of the update query. + if ($fieldUpdatedCount > 0 || $forceUpdate) { + // Get the table name from the existing query. + if (!empty($rs->tableName)) $tableName = $rs->tableName; + else { + preg_match("/FROM\s+".ADODB_TABLE_REGEX."/is", $rs->sql, $tableName); + $tableName = $tableName[1]; + } + // Get the full where clause excluding the word "WHERE" from + // the existing query. + preg_match('/\sWHERE\s(.*)/is', $rs->sql, $whereClause); + + $discard = false; + // not a good hack, improvements? + if ($whereClause) { + #var_dump($whereClause); + if (preg_match('/\s(ORDER\s.*)/is', $whereClause[1], $discard)); + else if (preg_match('/\s(LIMIT\s.*)/is', $whereClause[1], $discard)); + else if (preg_match('/\s(FOR UPDATE.*)/is', $whereClause[1], $discard)); + else preg_match('/\s.*(\) WHERE .*)/is', $whereClause[1], $discard); # see http://sourceforge.net/tracker/index.php?func=detail&aid=1379638&group_id=42718&atid=433976 + } else + $whereClause = array(false,false); + + if ($discard) + $whereClause[1] = substr($whereClause[1], 0, strlen($whereClause[1]) - strlen($discard[1])); + + $sql = 'UPDATE '.$tableName.' SET '.substr($setFields, 0, -2); + if (strlen($whereClause[1]) > 0) + $sql .= ' WHERE '.$whereClause[1]; + + return $sql; + + } else { + return false; + } +} + +function adodb_key_exists($key, &$arr,$force=2) +{ + if ($force<=0) { + // the following is the old behaviour where null or empty fields are ignored + return (!empty($arr[$key])) || (isset($arr[$key]) && strlen($arr[$key])>0); + } + + if (isset($arr[$key])) return true; + ## null check below + if (ADODB_PHPVER >= 0x4010) return array_key_exists($key,$arr); + return false; +} + +/** + * There is a special case of this function for the oci8 driver. + * The proper way to handle an insert w/ a blob in oracle requires + * a returning clause with bind variables and a descriptor blob. + * + * + */ +function _adodb_getinsertsql(&$zthis,&$rs,$arrFields,$magicq=false,$force=2) +{ +static $cacheRS = false; +static $cacheSig = 0; +static $cacheCols; + global $ADODB_QUOTE_FIELDNAMES; + + $tableName = ''; + $values = ''; + $fields = ''; + $recordSet = null; + $arrFields = _array_change_key_case($arrFields); + $fieldInsertedCount = 0; + + if (is_string($rs)) { + //ok we have a table name + //try and get the column info ourself. + $tableName = $rs; + + //we need an object for the recordSet + //because we have to call MetaType. + //php can't do a $rsclass::MetaType() + $rsclass = $zthis->rsPrefix.$zthis->databaseType; + $recordSet = new $rsclass(-1,$zthis->fetchMode); + $recordSet->connection = $zthis; + + if (is_string($cacheRS) && $cacheRS == $rs) { + $columns = $cacheCols; + } else { + $columns = $zthis->MetaColumns( $tableName ); + $cacheRS = $tableName; + $cacheCols = $columns; + } + } else if (is_subclass_of($rs, 'adorecordset')) { + if (isset($rs->insertSig) && is_integer($cacheRS) && $cacheRS == $rs->insertSig) { + $columns = $cacheCols; + } else { + for ($i=0, $max=$rs->FieldCount(); $i < $max; $i++) + $columns[] = $rs->FetchField($i); + $cacheRS = $cacheSig; + $cacheCols = $columns; + $rs->insertSig = $cacheSig++; + } + $recordSet = $rs; + + } else { + printf(ADODB_BAD_RS,'GetInsertSQL'); + return false; + } + + // Loop through all of the fields in the recordset + foreach( $columns as $field ) { + $upperfname = strtoupper($field->name); + if (adodb_key_exists($upperfname,$arrFields,$force)) { + $bad = false; + if ((strpos($upperfname,' ') !== false) || ($ADODB_QUOTE_FIELDNAMES)) + $fnameq = $zthis->nameQuote.$upperfname.$zthis->nameQuote; + else + $fnameq = $upperfname; + + $type = $recordSet->MetaType($field->type); + + /********************************************************/ + if (is_null($arrFields[$upperfname]) + || (empty($arrFields[$upperfname]) && strlen($arrFields[$upperfname]) == 0) + || $arrFields[$upperfname] === $zthis->null2null + ) + { + switch ($force) { + + case 0: // we must always set null if missing + $bad = true; + break; + + case 1: + $values .= "null, "; + break; + + case 2: + //Set empty + $arrFields[$upperfname] = ""; + $values .= _adodb_column_sql($zthis, 'I', $type, $upperfname, $fnameq,$arrFields, $magicq); + break; + + default: + case 3: + //Set the value that was given in array, so you can give both null and empty values + if (is_null($arrFields[$upperfname]) || $arrFields[$upperfname] === $zthis->null2null) { + $values .= "null, "; + } else { + $values .= _adodb_column_sql($zthis, 'I', $type, $upperfname, $fnameq, $arrFields, $magicq); + } + break; + } // switch + + /*********************************************************/ + } else { + //we do this so each driver can customize the sql for + //DB specific column types. + //Oracle needs BLOB types to be handled with a returning clause + //postgres has special needs as well + $values .= _adodb_column_sql($zthis, 'I', $type, $upperfname, $fnameq, + $arrFields, $magicq); + } + + if ($bad) continue; + // Set the counter for the number of fields that will be inserted. + $fieldInsertedCount++; + + + // Get the name of the fields to insert + $fields .= $fnameq . ", "; + } + } + + + // If there were any inserted fields then build the rest of the insert query. + if ($fieldInsertedCount <= 0) return false; + + // Get the table name from the existing query. + if (!$tableName) { + if (!empty($rs->tableName)) $tableName = $rs->tableName; + else if (preg_match("/FROM\s+".ADODB_TABLE_REGEX."/is", $rs->sql, $tableName)) + $tableName = $tableName[1]; + else + return false; + } + + // Strip off the comma and space on the end of both the fields + // and their values. + $fields = substr($fields, 0, -2); + $values = substr($values, 0, -2); + + // Append the fields and their values to the insert query. + return 'INSERT INTO '.$tableName.' ( '.$fields.' ) VALUES ( '.$values.' )'; +} + + +/** + * This private method is used to help construct + * the update/sql which is generated by GetInsertSQL and GetUpdateSQL. + * It handles the string construction of 1 column -> sql string based on + * the column type. We want to do 'safe' handling of BLOBs + * + * @param string the type of sql we are trying to create + * 'I' or 'U'. + * @param string column data type from the db::MetaType() method + * @param string the column name + * @param array the column value + * + * @return string + * + */ +function _adodb_column_sql_oci8(&$zthis,$action, $type, $fname, $fnameq, $arrFields, $magicq) +{ + $sql = ''; + + // Based on the datatype of the field + // Format the value properly for the database + switch($type) { + case 'B': + //in order to handle Blobs correctly, we need + //to do some magic for Oracle + + //we need to create a new descriptor to handle + //this properly + if (!empty($zthis->hasReturningInto)) { + if ($action == 'I') { + $sql = 'empty_blob(), '; + } else { + $sql = $fnameq. '=empty_blob(), '; + } + //add the variable to the returning clause array + //so the user can build this later in + //case they want to add more to it + $zthis->_returningArray[$fname] = ':xx'.$fname.'xx'; + } else if (empty($arrFields[$fname])){ + if ($action == 'I') { + $sql = 'empty_blob(), '; + } else { + $sql = $fnameq. '=empty_blob(), '; + } + } else { + //this is to maintain compatibility + //with older adodb versions. + $sql = _adodb_column_sql($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq,false); + } + break; + + case "X": + //we need to do some more magic here for long variables + //to handle these correctly in oracle. + + //create a safe bind var name + //to avoid conflicts w/ dupes. + if (!empty($zthis->hasReturningInto)) { + if ($action == 'I') { + $sql = ':xx'.$fname.'xx, '; + } else { + $sql = $fnameq.'=:xx'.$fname.'xx, '; + } + //add the variable to the returning clause array + //so the user can build this later in + //case they want to add more to it + $zthis->_returningArray[$fname] = ':xx'.$fname.'xx'; + } else { + //this is to maintain compatibility + //with older adodb versions. + $sql = _adodb_column_sql($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq,false); + } + break; + + default: + $sql = _adodb_column_sql($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq,false); + break; + } + + return $sql; +} + +function _adodb_column_sql(&$zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq, $recurse=true) +{ + + if ($recurse) { + switch($zthis->dataProvider) { + case 'postgres': + if ($type == 'L') $type = 'C'; + break; + case 'oci8': + return _adodb_column_sql_oci8($zthis, $action, $type, $fname, $fnameq, $arrFields, $magicq); + + } + } + + switch($type) { + case "C": + case "X": + case 'B': + $val = $zthis->qstr($arrFields[$fname],$magicq); + break; + + case "D": + $val = $zthis->DBDate($arrFields[$fname]); + break; + + case "T": + $val = $zthis->DBTimeStamp($arrFields[$fname]); + break; + + case "N": + $val = $arrFields[$fname]; + if (!is_numeric($val)) $val = str_replace(',', '.', (float)$val); + break; + + case "I": + case "R": + $val = $arrFields[$fname]; + if (!is_numeric($val)) $val = (integer) $val; + break; + + default: + $val = str_replace(array("'"," ","("),"",$arrFields[$fname]); // basic sql injection defence + if (empty($val)) $val = '0'; + break; + } + + if ($action == 'I') return $val . ", "; + + + return $fnameq . "=" . $val . ", "; + +} + + + +function _adodb_debug_execute(&$zthis, $sql, $inputarr) +{ + $ss = ''; + if ($inputarr) { + foreach($inputarr as $kk=>$vv) { + if (is_string($vv) && strlen($vv)>64) $vv = substr($vv,0,64).'...'; + if (is_null($vv)) $ss .= "($kk=>null) "; + else $ss .= "($kk=>'$vv') "; + } + $ss = "[ $ss ]"; + } + $sqlTxt = is_array($sql) ? $sql[0] : $sql; + /*str_replace(', ','##1#__^LF',is_array($sql) ? $sql[0] : $sql); + $sqlTxt = str_replace(',',', ',$sqlTxt); + $sqlTxt = str_replace('##1#__^LF', ', ' ,$sqlTxt); + */ + // check if running from browser or command-line + $inBrowser = isset($_SERVER['HTTP_USER_AGENT']); + + $dbt = $zthis->databaseType; + if (isset($zthis->dsnType)) $dbt .= '-'.$zthis->dsnType; + if ($inBrowser) { + if ($ss) { + $ss = ''.htmlspecialchars($ss).''; + } + if ($zthis->debug === -1) + ADOConnection::outp( "
\n($dbt): ".htmlspecialchars($sqlTxt)."   $ss\n
\n",false); + else if ($zthis->debug !== -99) + ADOConnection::outp( "


\n($dbt): ".htmlspecialchars($sqlTxt)."   $ss\n
\n",false); + } else { + $ss = "\n ".$ss; + if ($zthis->debug !== -99) + ADOConnection::outp("-----
\n($dbt): ".$sqlTxt." $ss\n-----
\n",false); + } + + $qID = $zthis->_query($sql,$inputarr); + + /* + Alexios Fakios notes that ErrorMsg() must be called before ErrorNo() for mssql + because ErrorNo() calls Execute('SELECT @ERROR'), causing recursion + */ + if ($zthis->databaseType == 'mssql') { + // ErrorNo is a slow function call in mssql, and not reliable in PHP 4.0.6 + + if($emsg = $zthis->ErrorMsg()) { + if ($err = $zthis->ErrorNo()) { + if ($zthis->debug === -99) + ADOConnection::outp( "
\n($dbt): ".htmlspecialchars($sqlTxt)."   $ss\n
\n",false); + + ADOConnection::outp($err.': '.$emsg); + } + } + } else if (!$qID) { + + if ($zthis->debug === -99) + if ($inBrowser) ADOConnection::outp( "
\n($dbt): ".htmlspecialchars($sqlTxt)."   $ss\n
\n",false); + else ADOConnection::outp("-----
\n($dbt): ".$sqlTxt."$ss\n-----
\n",false); + + ADOConnection::outp($zthis->ErrorNo() .': '. $zthis->ErrorMsg()); + } + + if ($zthis->debug === 99) _adodb_backtrace(true,9999,2); + return $qID; +} + +# pretty print the debug_backtrace function +function _adodb_backtrace($printOrArr=true,$levels=9999,$skippy=0,$ishtml=null) +{ + if (!function_exists('debug_backtrace')) return ''; + + if ($ishtml === null) $html = (isset($_SERVER['HTTP_USER_AGENT'])); + else $html = $ishtml; + + $fmt = ($html) ? " %% line %4d, file: %s" : "%% line %4d, file: %s"; + + $MAXSTRLEN = 128; + + $s = ($html) ? '
' : '';
+	
+	if (is_array($printOrArr)) $traceArr = $printOrArr;
+	else $traceArr = debug_backtrace();
+	array_shift($traceArr);
+	array_shift($traceArr);
+	$tabs = sizeof($traceArr)-2;
+	
+	foreach ($traceArr as $arr) {
+		if ($skippy) {$skippy -= 1; continue;}
+		$levels -= 1;
+		if ($levels < 0) break;
+		
+		$args = array();
+		for ($i=0; $i < $tabs; $i++) $s .=  ($html) ? '   ' : "\t";
+		$tabs -= 1;
+		if ($html) $s .= '';
+		if (isset($arr['class'])) $s .= $arr['class'].'.';
+		if (isset($arr['args']))
+		 foreach($arr['args'] as $v) {
+			if (is_null($v)) $args[] = 'null';
+			else if (is_array($v)) $args[] = 'Array['.sizeof($v).']';
+			else if (is_object($v)) $args[] = 'Object:'.get_class($v);
+			else if (is_bool($v)) $args[] = $v ? 'true' : 'false';
+			else {
+				$v = (string) @$v;
+				$str = htmlspecialchars(str_replace(array("\r","\n"),' ',substr($v,0,$MAXSTRLEN)));
+				if (strlen($v) > $MAXSTRLEN) $str .= '...';
+				$args[] = $str;
+			}
+		}
+		$s .= $arr['function'].'('.implode(', ',$args).')';
+		
+		
+		$s .= @sprintf($fmt, $arr['line'],$arr['file'],basename($arr['file']));
+			
+		$s .= "\n";
+	}	
+	if ($html) $s .= '
'; + if ($printOrArr) print $s; + + return $s; +} +/* +function _adodb_find_from($sql) +{ + + $sql = str_replace(array("\n","\r"), ' ', $sql); + $charCount = strlen($sql); + + $inString = false; + $quote = ''; + $parentheseCount = 0; + $prevChars = ''; + $nextChars = ''; + + + for($i = 0; $i < $charCount; $i++) { + + $char = substr($sql,$i,1); + $prevChars = substr($sql,0,$i); + $nextChars = substr($sql,$i+1); + + if((($char == "'" || $char == '"' || $char == '`') && substr($prevChars,-1,1) != '\\') && $inString === false) { + $quote = $char; + $inString = true; + } + + elseif((($char == "'" || $char == '"' || $char == '`') && substr($prevChars,-1,1) != '\\') && $inString === true && $quote == $char) { + $quote = ""; + $inString = false; + } + + elseif($char == "(" && $inString === false) + $parentheseCount++; + + elseif($char == ")" && $inString === false && $parentheseCount > 0) + $parentheseCount--; + + elseif($parentheseCount <= 0 && $inString === false && $char == " " && strtoupper(substr($prevChars,-5,5)) == " FROM") + return $i; + + } +} +*/ + +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-time.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-time.inc.php new file mode 100644 index 00000000..51bcf195 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb-time.inc.php @@ -0,0 +1,1432 @@ + 4 digit year conversion. The maximum is billions of years in the +future, but this is a theoretical limit as the computation of that year +would take too long with the current implementation of adodb_mktime(). + +This library replaces native functions as follows: + +
	
+	getdate()  with  adodb_getdate()
+	date()     with  adodb_date() 
+	gmdate()   with  adodb_gmdate()
+	mktime()   with  adodb_mktime()
+	gmmktime() with  adodb_gmmktime()
+	strftime() with  adodb_strftime()
+	strftime() with  adodb_gmstrftime()
+
+ +The parameters are identical, except that adodb_date() accepts a subset +of date()'s field formats. Mktime() will convert from local time to GMT, +and date() will convert from GMT to local time, but daylight savings is +not handled currently. + +This library is independant of the rest of ADOdb, and can be used +as standalone code. + +PERFORMANCE + +For high speed, this library uses the native date functions where +possible, and only switches to PHP code when the dates fall outside +the 32-bit signed integer range. + +GREGORIAN CORRECTION + +Pope Gregory shortened October of A.D. 1582 by ten days. Thursday, +October 4, 1582 (Julian) was followed immediately by Friday, October 15, +1582 (Gregorian). + +Since 0.06, we handle this correctly, so: + +adodb_mktime(0,0,0,10,15,1582) - adodb_mktime(0,0,0,10,4,1582) + == 24 * 3600 (1 day) + +============================================================================= + +COPYRIGHT + +(c) 2003-2005 John Lim and released under BSD-style license except for code by +jackbbs, which includes adodb_mktime, adodb_get_gmt_diff, adodb_is_leap_year +and originally found at http://www.php.net/manual/en/function.mktime.php + +============================================================================= + +BUG REPORTS + +These should be posted to the ADOdb forums at + + http://phplens.com/lens/lensforum/topics.php?id=4 + +============================================================================= + +FUNCTION DESCRIPTIONS + + +** FUNCTION adodb_getdate($date=false) + +Returns an array containing date information, as getdate(), but supports +dates greater than 1901 to 2038. The local date/time format is derived from a +heuristic the first time adodb_getdate is called. + + +** FUNCTION adodb_date($fmt, $timestamp = false) + +Convert a timestamp to a formatted local date. If $timestamp is not defined, the +current timestamp is used. Unlike the function date(), it supports dates +outside the 1901 to 2038 range. + +The format fields that adodb_date supports: + +
+	a - "am" or "pm" 
+	A - "AM" or "PM" 
+	d - day of the month, 2 digits with leading zeros; i.e. "01" to "31" 
+	D - day of the week, textual, 3 letters; e.g. "Fri" 
+	F - month, textual, long; e.g. "January" 
+	g - hour, 12-hour format without leading zeros; i.e. "1" to "12" 
+	G - hour, 24-hour format without leading zeros; i.e. "0" to "23" 
+	h - hour, 12-hour format; i.e. "01" to "12" 
+	H - hour, 24-hour format; i.e. "00" to "23" 
+	i - minutes; i.e. "00" to "59" 
+	j - day of the month without leading zeros; i.e. "1" to "31" 
+	l (lowercase 'L') - day of the week, textual, long; e.g. "Friday"  
+	L - boolean for whether it is a leap year; i.e. "0" or "1" 
+	m - month; i.e. "01" to "12" 
+	M - month, textual, 3 letters; e.g. "Jan" 
+	n - month without leading zeros; i.e. "1" to "12" 
+	O - Difference to Greenwich time in hours; e.g. "+0200" 
+	Q - Quarter, as in 1, 2, 3, 4 
+	r - RFC 2822 formatted date; e.g. "Thu, 21 Dec 2000 16:01:07 +0200" 
+	s - seconds; i.e. "00" to "59" 
+	S - English ordinal suffix for the day of the month, 2 characters; 
+	   			i.e. "st", "nd", "rd" or "th" 
+	t - number of days in the given month; i.e. "28" to "31"
+	T - Timezone setting of this machine; e.g. "EST" or "MDT" 
+	U - seconds since the Unix Epoch (January 1 1970 00:00:00 GMT)  
+	w - day of the week, numeric, i.e. "0" (Sunday) to "6" (Saturday) 
+	Y - year, 4 digits; e.g. "1999" 
+	y - year, 2 digits; e.g. "99" 
+	z - day of the year; i.e. "0" to "365" 
+	Z - timezone offset in seconds (i.e. "-43200" to "43200"). 
+	   			The offset for timezones west of UTC is always negative, 
+				and for those east of UTC is always positive. 
+
+ +Unsupported: +
+	B - Swatch Internet time 
+	I (capital i) - "1" if Daylight Savings Time, "0" otherwise.
+	W - ISO-8601 week number of year, weeks starting on Monday 
+
+
+ + +** FUNCTION adodb_date2($fmt, $isoDateString = false) +Same as adodb_date, but 2nd parameter accepts iso date, eg. + + adodb_date2('d-M-Y H:i','2003-12-25 13:01:34'); + + +** FUNCTION adodb_gmdate($fmt, $timestamp = false) + +Convert a timestamp to a formatted GMT date. If $timestamp is not defined, the +current timestamp is used. Unlike the function date(), it supports dates +outside the 1901 to 2038 range. + + +** FUNCTION adodb_mktime($hr, $min, $sec[, $month, $day, $year]) + +Converts a local date to a unix timestamp. Unlike the function mktime(), it supports +dates outside the 1901 to 2038 range. All parameters are optional. + + +** FUNCTION adodb_gmmktime($hr, $min, $sec [, $month, $day, $year]) + +Converts a gmt date to a unix timestamp. Unlike the function gmmktime(), it supports +dates outside the 1901 to 2038 range. Differs from gmmktime() in that all parameters +are currently compulsory. + +** FUNCTION adodb_gmstrftime($fmt, $timestamp = false) +Convert a timestamp to a formatted GMT date. + +** FUNCTION adodb_strftime($fmt, $timestamp = false) + +Convert a timestamp to a formatted local date. Internally converts $fmt into +adodb_date format, then echo result. + +For best results, you can define the local date format yourself. Define a global +variable $ADODB_DATE_LOCALE which is an array, 1st element is date format using +adodb_date syntax, and 2nd element is the time format, also in adodb_date syntax. + + eg. $ADODB_DATE_LOCALE = array('d/m/Y','H:i:s'); + + Supported format codes: + +
+	%a - abbreviated weekday name according to the current locale 
+	%A - full weekday name according to the current locale 
+	%b - abbreviated month name according to the current locale 
+	%B - full month name according to the current locale 
+	%c - preferred date and time representation for the current locale 
+	%d - day of the month as a decimal number (range 01 to 31) 
+	%D - same as %m/%d/%y 
+	%e - day of the month as a decimal number, a single digit is preceded by a space (range ' 1' to '31') 
+	%h - same as %b
+	%H - hour as a decimal number using a 24-hour clock (range 00 to 23) 
+	%I - hour as a decimal number using a 12-hour clock (range 01 to 12) 
+	%m - month as a decimal number (range 01 to 12) 
+	%M - minute as a decimal number 
+	%n - newline character 
+	%p - either `am' or `pm' according to the given time value, or the corresponding strings for the current locale 
+	%r - time in a.m. and p.m. notation 
+	%R - time in 24 hour notation 
+	%S - second as a decimal number 
+	%t - tab character 
+	%T - current time, equal to %H:%M:%S 
+	%x - preferred date representation for the current locale without the time 
+	%X - preferred time representation for the current locale without the date 
+	%y - year as a decimal number without a century (range 00 to 99) 
+	%Y - year as a decimal number including the century 
+	%Z - time zone or name or abbreviation 
+	%% - a literal `%' character 
+
+ + Unsupported codes: +
+	%C - century number (the year divided by 100 and truncated to an integer, range 00 to 99) 
+	%g - like %G, but without the century. 
+	%G - The 4-digit year corresponding to the ISO week number (see %V). 
+	     This has the same format and value as %Y, except that if the ISO week number belongs 
+		 to the previous or next year, that year is used instead. 
+	%j - day of the year as a decimal number (range 001 to 366) 
+	%u - weekday as a decimal number [1,7], with 1 representing Monday 
+	%U - week number of the current year as a decimal number, starting 
+	    with the first Sunday as the first day of the first week 
+	%V - The ISO 8601:1988 week number of the current year as a decimal number, 
+	     range 01 to 53, where week 1 is the first week that has at least 4 days in the 
+		 current year, and with Monday as the first day of the week. (Use %G or %g for 
+		 the year component that corresponds to the week number for the specified timestamp.) 
+	%w - day of the week as a decimal, Sunday being 0 
+	%W - week number of the current year as a decimal number, starting with the 
+	     first Monday as the first day of the first week 
+
+ +============================================================================= + +NOTES + +Useful url for generating test timestamps: + http://www.4webhelp.net/us/timestamp.php + +Possible future optimizations include + +a. Using an algorithm similar to Plauger's in "The Standard C Library" +(page 428, xttotm.c _Ttotm() function). Plauger's algorithm will not +work outside 32-bit signed range, so i decided not to implement it. + +b. Implement daylight savings, which looks awfully complicated, see + http://webexhibits.org/daylightsaving/ + + +CHANGELOG + +- 11 Feb 2008 0.33 +* Bug in 0.32 fix for hour handling. Fixed. + +- 1 Feb 2008 0.32 +* Now adodb_mktime(0,0,0,12+$m,20,2040) works properly. + +- 10 Jan 2008 0.31 +* Now adodb_mktime(0,0,0,24,1,2037) works correctly. + +- 15 July 2007 0.30 +Added PHP 5.2.0 compatability fixes. + * gmtime behaviour for 1970 has changed. We use the actual date if it is between 1970 to 2038 to get the + * timezone, otherwise we use the current year as the baseline to retrieve the timezone. + * Also the timezone's in php 5.2.* support historical data better, eg. if timezone today was +8, but + in 1970 it was +7:30, then php 5.2 return +7:30, while this library will use +8. + * + +- 19 March 2006 0.24 +Changed strftime() locale detection, because some locales prepend the day of week to the date when %c is used. + +- 10 Feb 2006 0.23 +PHP5 compat: when we detect PHP5, the RFC2822 format for gmt 0000hrs is changed from -0000 to +0000. + In PHP4, we will still use -0000 for 100% compat with PHP4. + +- 08 Sept 2005 0.22 +In adodb_date2(), $is_gmt not supported properly. Fixed. + +- 18 July 2005 0.21 +In PHP 4.3.11, the 'r' format has changed. Leading 0 in day is added. Changed for compat. +Added support for negative months in adodb_mktime(). + +- 24 Feb 2005 0.20 +Added limited strftime/gmstrftime support. x10 improvement in performance of adodb_date(). + +- 21 Dec 2004 0.17 +In adodb_getdate(), the timestamp was accidentally converted to gmt when $is_gmt is false. +Also adodb_mktime(0,0,0) did not work properly. Both fixed thx Mauro. + +- 17 Nov 2004 0.16 +Removed intval typecast in adodb_mktime() for secs, allowing: + adodb_mktime(0,0,0 + 2236672153,1,1,1934); +Suggested by Ryan. + +- 18 July 2004 0.15 +All params in adodb_mktime were formerly compulsory. Now only the hour, min, secs is compulsory. +This brings it more in line with mktime (still not identical). + +- 23 June 2004 0.14 + +Allow you to define your own daylights savings function, adodb_daylight_sv. +If the function is defined (somewhere in an include), then you can correct for daylights savings. + +In this example, we apply daylights savings in June or July, adding one hour. This is extremely +unrealistic as it does not take into account time-zone, geographic location, current year. + +function adodb_daylight_sv(&$arr, $is_gmt) +{ + if ($is_gmt) return; + $m = $arr['mon']; + if ($m == 6 || $m == 7) $arr['hours'] += 1; +} + +This is only called by adodb_date() and not by adodb_mktime(). + +The format of $arr is +Array ( + [seconds] => 0 + [minutes] => 0 + [hours] => 0 + [mday] => 1 # day of month, eg 1st day of the month + [mon] => 2 # month (eg. Feb) + [year] => 2102 + [yday] => 31 # days in current year + [leap] => # true if leap year + [ndays] => 28 # no of days in current month + ) + + +- 28 Apr 2004 0.13 +Fixed adodb_date to properly support $is_gmt. Thx to Dimitar Angelov. + +- 20 Mar 2004 0.12 +Fixed month calculation error in adodb_date. 2102-June-01 appeared as 2102-May-32. + +- 26 Oct 2003 0.11 +Because of daylight savings problems (some systems apply daylight savings to +January!!!), changed adodb_get_gmt_diff() to ignore daylight savings. + +- 9 Aug 2003 0.10 +Fixed bug with dates after 2038. +See http://phplens.com/lens/lensforum/msgs.php?id=6980 + +- 1 July 2003 0.09 +Added support for Q (Quarter). +Added adodb_date2(), which accepts ISO date in 2nd param + +- 3 March 2003 0.08 +Added support for 'S' adodb_date() format char. Added constant ADODB_ALLOW_NEGATIVE_TS +if you want PHP to handle negative timestamps between 1901 to 1969. + +- 27 Feb 2003 0.07 +All negative numbers handled by adodb now because of RH 7.3+ problems. +See http://bugs.php.net/bug.php?id=20048&edit=2 + +- 4 Feb 2003 0.06 +Fixed a typo, 1852 changed to 1582! This means that pre-1852 dates +are now correctly handled. + +- 29 Jan 2003 0.05 + +Leap year checking differs under Julian calendar (pre 1582). Also +leap year code optimized by checking for most common case first. + +We also handle month overflow correctly in mktime (eg month set to 13). + +Day overflow for less than one month's days is supported. + +- 28 Jan 2003 0.04 + +Gregorian correction handled. In PHP5, we might throw an error if +mktime uses invalid dates around 5-14 Oct 1582. Released with ADOdb 3.10. +Added limbo 5-14 Oct 1582 check, when we set to 15 Oct 1582. + +- 27 Jan 2003 0.03 + +Fixed some more month problems due to gmt issues. Added constant ADODB_DATE_VERSION. +Fixed calculation of days since start of year for <1970. + +- 27 Jan 2003 0.02 + +Changed _adodb_getdate() to inline leap year checking for better performance. +Fixed problem with time-zones west of GMT +0000. + +- 24 Jan 2003 0.01 + +First implementation. +*/ + + +/* Initialization */ + +/* + Version Number +*/ +define('ADODB_DATE_VERSION',0.33); + +$ADODB_DATETIME_CLASS = (PHP_VERSION >= 5.2); + +/* + This code was originally for windows. But apparently this problem happens + also with Linux, RH 7.3 and later! + + glibc-2.2.5-34 and greater has been changed to return -1 for dates < + 1970. This used to work. The problem exists with RedHat 7.3 and 8.0 + echo (mktime(0, 0, 0, 1, 1, 1960)); // prints -1 + + References: + http://bugs.php.net/bug.php?id=20048&edit=2 + http://lists.debian.org/debian-glibc/2002/debian-glibc-200205/msg00010.html +*/ + +if (!defined('ADODB_ALLOW_NEGATIVE_TS')) define('ADODB_NO_NEGATIVE_TS',1); + +function adodb_date_test_date($y1,$m,$d=13) +{ + $h = round(rand()% 24); + $t = adodb_mktime($h,0,0,$m,$d,$y1); + $rez = adodb_date('Y-n-j H:i:s',$t); + if ($h == 0) $h = '00'; + else if ($h < 10) $h = '0'.$h; + if ("$y1-$m-$d $h:00:00" != $rez) { + print "$y1 error, expected=$y1-$m-$d $h:00:00, adodb=$rez
"; + return false; + } + return true; +} + +function adodb_date_test_strftime($fmt) +{ + $s1 = strftime($fmt); + $s2 = adodb_strftime($fmt); + + if ($s1 == $s2) return true; + + echo "error for $fmt, strftime=$s1, adodb=$s2
"; + return false; +} + +/** + Test Suite +*/ +function adodb_date_test() +{ + + for ($m=-24; $m<=24; $m++) + echo "$m :",adodb_date('d-m-Y',adodb_mktime(0,0,0,1+$m,20,2040)),"
"; + + // cytopia edit + error_reporting(E_ERROR | E_WARNING | E_PARSE); + //error_reporting(E_ALL & ~E_DEPRECATED); + //error_reporting(E_ALL); + print "

Testing adodb_date and adodb_mktime. version=".ADODB_DATE_VERSION.' PHP='.PHP_VERSION."

"; + @set_time_limit(0); + $fail = false; + + // This flag disables calling of PHP native functions, so we can properly test the code + if (!defined('ADODB_TEST_DATES')) define('ADODB_TEST_DATES',1); + + $t = time(); + + + $fmt = 'Y-m-d H:i:s'; + echo '
';
+	echo 'adodb: ',adodb_date($fmt,$t),'
'; + echo 'php : ',date($fmt,$t),'
'; + echo '
'; + + adodb_date_test_strftime('%Y %m %x %X'); + adodb_date_test_strftime("%A %d %B %Y"); + adodb_date_test_strftime("%H %M S"); + + $t = adodb_mktime(0,0,0); + if (!(adodb_date('Y-m-d') == date('Y-m-d'))) print 'Error in '.adodb_mktime(0,0,0).'
'; + + $t = adodb_mktime(0,0,0,6,1,2102); + if (!(adodb_date('Y-m-d',$t) == '2102-06-01')) print 'Error in '.adodb_date('Y-m-d',$t).'
'; + + $t = adodb_mktime(0,0,0,2,1,2102); + if (!(adodb_date('Y-m-d',$t) == '2102-02-01')) print 'Error in '.adodb_date('Y-m-d',$t).'
'; + + + print "

Testing gregorian <=> julian conversion

"; + $t = adodb_mktime(0,0,0,10,11,1492); + //http://www.holidayorigins.com/html/columbus_day.html - Friday check + if (!(adodb_date('D Y-m-d',$t) == 'Fri 1492-10-11')) print 'Error in Columbus landing
'; + + $t = adodb_mktime(0,0,0,2,29,1500); + if (!(adodb_date('Y-m-d',$t) == '1500-02-29')) print 'Error in julian leap years
'; + + $t = adodb_mktime(0,0,0,2,29,1700); + if (!(adodb_date('Y-m-d',$t) == '1700-03-01')) print 'Error in gregorian leap years
'; + + print adodb_mktime(0,0,0,10,4,1582).' '; + print adodb_mktime(0,0,0,10,15,1582); + $diff = (adodb_mktime(0,0,0,10,15,1582) - adodb_mktime(0,0,0,10,4,1582)); + if ($diff != 3600*24) print " Error in gregorian correction = ".($diff/3600/24)." days
"; + + print " 15 Oct 1582, Fri=".(adodb_dow(1582,10,15) == 5 ? 'Fri' : 'Error')."
"; + print " 4 Oct 1582, Thu=".(adodb_dow(1582,10,4) == 4 ? 'Thu' : 'Error')."
"; + + print "

Testing overflow

"; + + $t = adodb_mktime(0,0,0,3,33,1965); + if (!(adodb_date('Y-m-d',$t) == '1965-04-02')) print 'Error in day overflow 1
'; + $t = adodb_mktime(0,0,0,4,33,1971); + if (!(adodb_date('Y-m-d',$t) == '1971-05-03')) print 'Error in day overflow 2
'; + $t = adodb_mktime(0,0,0,1,60,1965); + if (!(adodb_date('Y-m-d',$t) == '1965-03-01')) print 'Error in day overflow 3 '.adodb_date('Y-m-d',$t).'
'; + $t = adodb_mktime(0,0,0,12,32,1965); + if (!(adodb_date('Y-m-d',$t) == '1966-01-01')) print 'Error in day overflow 4 '.adodb_date('Y-m-d',$t).'
'; + $t = adodb_mktime(0,0,0,12,63,1965); + if (!(adodb_date('Y-m-d',$t) == '1966-02-01')) print 'Error in day overflow 5 '.adodb_date('Y-m-d',$t).'
'; + $t = adodb_mktime(0,0,0,13,3,1965); + if (!(adodb_date('Y-m-d',$t) == '1966-01-03')) print 'Error in mth overflow 1
'; + + print "Testing 2-digit => 4-digit year conversion

"; + if (adodb_year_digit_check(00) != 2000) print "Err 2-digit 2000
"; + if (adodb_year_digit_check(10) != 2010) print "Err 2-digit 2010
"; + if (adodb_year_digit_check(20) != 2020) print "Err 2-digit 2020
"; + if (adodb_year_digit_check(30) != 2030) print "Err 2-digit 2030
"; + if (adodb_year_digit_check(40) != 1940) print "Err 2-digit 1940
"; + if (adodb_year_digit_check(50) != 1950) print "Err 2-digit 1950
"; + if (adodb_year_digit_check(90) != 1990) print "Err 2-digit 1990
"; + + // Test string formating + print "

Testing date formating

"; + + $fmt = '\d\a\t\e T Y-m-d H:i:s a A d D F g G h H i j l L m M n O \R\F\C2822 r s t U w y Y z Z 2003'; + $s1 = date($fmt,0); + $s2 = adodb_date($fmt,0); + if ($s1 != $s2) { + print " date() 0 failed
$s1
$s2
"; + } + flush(); + for ($i=100; --$i > 0; ) { + + $ts = 3600.0*((rand()%60000)+(rand()%60000))+(rand()%60000); + $s1 = date($fmt,$ts); + $s2 = adodb_date($fmt,$ts); + //print "$s1
$s2

"; + $pos = strcmp($s1,$s2); + + if (($s1) != ($s2)) { + for ($j=0,$k=strlen($s1); $j < $k; $j++) { + if ($s1[$j] != $s2[$j]) { + print substr($s1,$j).' '; + break; + } + } + print "Error date(): $ts

 
+  \"$s1\" (date len=".strlen($s1).")
+  \"$s2\" (adodb_date len=".strlen($s2).")

"; + $fail = true; + } + + $a1 = getdate($ts); + $a2 = adodb_getdate($ts); + $rez = array_diff($a1,$a2); + if (sizeof($rez)>0) { + print "Error getdate() $ts
"; + print_r($a1); + print "
"; + print_r($a2); + print "

"; + $fail = true; + } + } + + // Test generation of dates outside 1901-2038 + print "

Testing random dates between 100 and 4000

"; + adodb_date_test_date(100,1); + for ($i=100; --$i >= 0;) { + $y1 = 100+rand(0,1970-100); + $m = rand(1,12); + adodb_date_test_date($y1,$m); + + $y1 = 3000-rand(0,3000-1970); + adodb_date_test_date($y1,$m); + } + print '

'; + $start = 1960+rand(0,10); + $yrs = 12; + $i = 365.25*86400*($start-1970); + $offset = 36000+rand(10000,60000); + $max = 365*$yrs*86400; + $lastyear = 0; + + // we generate a timestamp, convert it to a date, and convert it back to a timestamp + // and check if the roundtrip broke the original timestamp value. + print "Testing $start to ".($start+$yrs).", or $max seconds, offset=$offset: "; + $cnt = 0; + for ($max += $i; $i < $max; $i += $offset) { + $ret = adodb_date('m,d,Y,H,i,s',$i); + $arr = explode(',',$ret); + if ($lastyear != $arr[2]) { + $lastyear = $arr[2]; + print " $lastyear "; + flush(); + } + $newi = adodb_mktime($arr[3],$arr[4],$arr[5],$arr[0],$arr[1],$arr[2]); + if ($i != $newi) { + print "Error at $i, adodb_mktime returned $newi ($ret)"; + $fail = true; + break; + } + $cnt += 1; + } + echo "Tested $cnt dates
"; + if (!$fail) print "

Passed !

"; + else print "

Failed :-(

"; +} + +/** + Returns day of week, 0 = Sunday,... 6=Saturday. + Algorithm from PEAR::Date_Calc +*/ +function adodb_dow($year, $month, $day) +{ +/* +Pope Gregory removed 10 days - October 5 to October 14 - from the year 1582 and +proclaimed that from that time onwards 3 days would be dropped from the calendar +every 400 years. + +Thursday, October 4, 1582 (Julian) was followed immediately by Friday, October 15, 1582 (Gregorian). +*/ + if ($year <= 1582) { + if ($year < 1582 || + ($year == 1582 && ($month < 10 || ($month == 10 && $day < 15)))) $greg_correction = 3; + else + $greg_correction = 0; + } else + $greg_correction = 0; + + if($month > 2) + $month -= 2; + else { + $month += 10; + $year--; + } + + $day = floor((13 * $month - 1) / 5) + + $day + ($year % 100) + + floor(($year % 100) / 4) + + floor(($year / 100) / 4) - 2 * + floor($year / 100) + 77 + $greg_correction; + + return $day - 7 * floor($day / 7); +} + + +/** + Checks for leap year, returns true if it is. No 2-digit year check. Also + handles julian calendar correctly. +*/ +function _adodb_is_leap_year($year) +{ + if ($year % 4 != 0) return false; + + if ($year % 400 == 0) { + return true; + // if gregorian calendar (>1582), century not-divisible by 400 is not leap + } else if ($year > 1582 && $year % 100 == 0 ) { + return false; + } + + return true; +} + + +/** + checks for leap year, returns true if it is. Has 2-digit year check +*/ +function adodb_is_leap_year($year) +{ + return _adodb_is_leap_year(adodb_year_digit_check($year)); +} + +/** + Fix 2-digit years. Works for any century. + Assumes that if 2-digit is more than 30 years in future, then previous century. +*/ +function adodb_year_digit_check($y) +{ + if ($y < 100) { + + $yr = (integer) date("Y"); + $century = (integer) ($yr /100); + + if ($yr%100 > 50) { + $c1 = $century + 1; + $c0 = $century; + } else { + $c1 = $century; + $c0 = $century - 1; + } + $c1 *= 100; + // if 2-digit year is less than 30 years in future, set it to this century + // otherwise if more than 30 years in future, then we set 2-digit year to the prev century. + if (($y + $c1) < $yr+30) $y = $y + $c1; + else $y = $y + $c0*100; + } + return $y; +} + +function adodb_get_gmt_diff_ts($ts) +{ + if (0 <= $ts && $ts <= 0x7FFFFFFF) { // check if number in 32-bit signed range) { + $arr = getdate($ts); + $y = $arr['year']; + $m = $arr['mon']; + $d = $arr['mday']; + return adodb_get_gmt_diff($y,$m,$d); + } else { + return adodb_get_gmt_diff(false,false,false); + } + +} + +/** + get local time zone offset from GMT. Does not handle historical timezones before 1970. +*/ +function adodb_get_gmt_diff($y,$m,$d) +{ +static $TZ,$tzo; +global $ADODB_DATETIME_CLASS; + + if (!defined('ADODB_TEST_DATES')) $y = false; + else if ($y < 1970 || $y >= 2038) $y = false; + + if ($ADODB_DATETIME_CLASS && $y !== false) { + $dt = new DateTime(); + $dt->setISODate($y,$m,$d); + if (empty($tzo)) { + $tzo = new DateTimeZone(date_default_timezone_get()); + # $tzt = timezone_transitions_get( $tzo ); + } + return -$tzo->getOffset($dt); + } else { + if (isset($TZ)) return $TZ; + $y = date('Y'); + $TZ = mktime(0,0,0,12,2,$y,0) - gmmktime(0,0,0,12,2,$y,0); + } + + return $TZ; +} + +/** + Returns an array with date info. +*/ +function adodb_getdate($d=false,$fast=false) +{ + if ($d === false) return getdate(); + if (!defined('ADODB_TEST_DATES')) { + if ((abs($d) <= 0x7FFFFFFF)) { // check if number in 32-bit signed range + if (!defined('ADODB_NO_NEGATIVE_TS') || $d >= 0) // if windows, must be +ve integer + return @getdate($d); + } + } + return _adodb_getdate($d); +} + +/* +// generate $YRS table for _adodb_getdate() +function adodb_date_gentable($out=true) +{ + + for ($i=1970; $i >= 1600; $i-=10) { + $s = adodb_gmmktime(0,0,0,1,1,$i); + echo "$i => $s,
"; + } +} +adodb_date_gentable(); + +for ($i=1970; $i > 1500; $i--) { + +echo "
$i "; + adodb_date_test_date($i,1,1); +} + +*/ + + +$_month_table_normal = array("",31,28,31,30,31,30,31,31,30,31,30,31); +$_month_table_leaf = array("",31,29,31,30,31,30,31,31,30,31,30,31); + +function adodb_validdate($y,$m,$d) +{ +global $_month_table_normal,$_month_table_leaf; + + if (_adodb_is_leap_year($y)) $marr = $_month_table_leaf; + else $marr = $_month_table_normal; + + if ($m > 12 || $m < 1) return false; + + if ($d > 31 || $d < 1) return false; + + if ($marr[$m] < $d) return false; + + if ($y < 1000 && $y > 3000) return false; + + return true; +} + +/** + Low-level function that returns the getdate() array. We have a special + $fast flag, which if set to true, will return fewer array values, + and is much faster as it does not calculate dow, etc. +*/ +function _adodb_getdate($origd=false,$fast=false,$is_gmt=false) +{ +static $YRS; +global $_month_table_normal,$_month_table_leaf; + + $d = $origd - ($is_gmt ? 0 : adodb_get_gmt_diff_ts($origd)); + $_day_power = 86400; + $_hour_power = 3600; + $_min_power = 60; + + if ($d < -12219321600) $d -= 86400*10; // if 15 Oct 1582 or earlier, gregorian correction + + $_month_table_normal = array("",31,28,31,30,31,30,31,31,30,31,30,31); + $_month_table_leaf = array("",31,29,31,30,31,30,31,31,30,31,30,31); + + $d366 = $_day_power * 366; + $d365 = $_day_power * 365; + + if ($d < 0) { + + if (empty($YRS)) $YRS = array( + 1970 => 0, + 1960 => -315619200, + 1950 => -631152000, + 1940 => -946771200, + 1930 => -1262304000, + 1920 => -1577923200, + 1910 => -1893456000, + 1900 => -2208988800, + 1890 => -2524521600, + 1880 => -2840140800, + 1870 => -3155673600, + 1860 => -3471292800, + 1850 => -3786825600, + 1840 => -4102444800, + 1830 => -4417977600, + 1820 => -4733596800, + 1810 => -5049129600, + 1800 => -5364662400, + 1790 => -5680195200, + 1780 => -5995814400, + 1770 => -6311347200, + 1760 => -6626966400, + 1750 => -6942499200, + 1740 => -7258118400, + 1730 => -7573651200, + 1720 => -7889270400, + 1710 => -8204803200, + 1700 => -8520336000, + 1690 => -8835868800, + 1680 => -9151488000, + 1670 => -9467020800, + 1660 => -9782640000, + 1650 => -10098172800, + 1640 => -10413792000, + 1630 => -10729324800, + 1620 => -11044944000, + 1610 => -11360476800, + 1600 => -11676096000); + + if ($is_gmt) $origd = $d; + // The valid range of a 32bit signed timestamp is typically from + // Fri, 13 Dec 1901 20:45:54 GMT to Tue, 19 Jan 2038 03:14:07 GMT + // + + # old algorithm iterates through all years. new algorithm does it in + # 10 year blocks + + /* + # old algo + for ($a = 1970 ; --$a >= 0;) { + $lastd = $d; + + if ($leaf = _adodb_is_leap_year($a)) $d += $d366; + else $d += $d365; + + if ($d >= 0) { + $year = $a; + break; + } + } + */ + + $lastsecs = 0; + $lastyear = 1970; + foreach($YRS as $year => $secs) { + if ($d >= $secs) { + $a = $lastyear; + break; + } + $lastsecs = $secs; + $lastyear = $year; + } + + $d -= $lastsecs; + if (!isset($a)) $a = $lastyear; + + //echo ' yr=',$a,' ', $d,'.'; + + for (; --$a >= 0;) { + $lastd = $d; + + if ($leaf = _adodb_is_leap_year($a)) $d += $d366; + else $d += $d365; + + if ($d >= 0) { + $year = $a; + break; + } + } + /**/ + + $secsInYear = 86400 * ($leaf ? 366 : 365) + $lastd; + + $d = $lastd; + $mtab = ($leaf) ? $_month_table_leaf : $_month_table_normal; + for ($a = 13 ; --$a > 0;) { + $lastd = $d; + $d += $mtab[$a] * $_day_power; + if ($d >= 0) { + $month = $a; + $ndays = $mtab[$a]; + break; + } + } + + $d = $lastd; + $day = $ndays + ceil(($d+1) / ($_day_power)); + + $d += ($ndays - $day+1)* $_day_power; + $hour = floor($d/$_hour_power); + + } else { + for ($a = 1970 ;; $a++) { + $lastd = $d; + + if ($leaf = _adodb_is_leap_year($a)) $d -= $d366; + else $d -= $d365; + if ($d < 0) { + $year = $a; + break; + } + } + $secsInYear = $lastd; + $d = $lastd; + $mtab = ($leaf) ? $_month_table_leaf : $_month_table_normal; + for ($a = 1 ; $a <= 12; $a++) { + $lastd = $d; + $d -= $mtab[$a] * $_day_power; + if ($d < 0) { + $month = $a; + $ndays = $mtab[$a]; + break; + } + } + $d = $lastd; + $day = ceil(($d+1) / $_day_power); + $d = $d - ($day-1) * $_day_power; + $hour = floor($d /$_hour_power); + } + + $d -= $hour * $_hour_power; + $min = floor($d/$_min_power); + $secs = $d - $min * $_min_power; + if ($fast) { + return array( + 'seconds' => $secs, + 'minutes' => $min, + 'hours' => $hour, + 'mday' => $day, + 'mon' => $month, + 'year' => $year, + 'yday' => floor($secsInYear/$_day_power), + 'leap' => $leaf, + 'ndays' => $ndays + ); + } + + + $dow = adodb_dow($year,$month,$day); + + return array( + 'seconds' => $secs, + 'minutes' => $min, + 'hours' => $hour, + 'mday' => $day, + 'wday' => $dow, + 'mon' => $month, + 'year' => $year, + 'yday' => floor($secsInYear/$_day_power), + 'weekday' => gmdate('l',$_day_power*(3+$dow)), + 'month' => gmdate('F',mktime(0,0,0,$month,2,1971)), + 0 => $origd + ); +} +/* + if ($isphp5) + $dates .= sprintf('%s%04d',($gmt<=0)?'+':'-',abs($gmt)/36); + else + $dates .= sprintf('%s%04d',($gmt<0)?'+':'-',abs($gmt)/36); + break;*/ +function adodb_tz_offset($gmt,$isphp5) +{ + $zhrs = abs($gmt)/3600; + $hrs = floor($zhrs); + if ($isphp5) + return sprintf('%s%02d%02d',($gmt<=0)?'+':'-',floor($zhrs),($zhrs-$hrs)*60); + else + return sprintf('%s%02d%02d',($gmt<0)?'+':'-',floor($zhrs),($zhrs-$hrs)*60); +} + + +function adodb_gmdate($fmt,$d=false) +{ + return adodb_date($fmt,$d,true); +} + +// accepts unix timestamp and iso date format in $d +function adodb_date2($fmt, $d=false, $is_gmt=false) +{ + if ($d !== false) { + if (!preg_match( + "|^([0-9]{4})[-/\.]?([0-9]{1,2})[-/\.]?([0-9]{1,2})[ -]?(([0-9]{1,2}):?([0-9]{1,2}):?([0-9\.]{1,4}))?|", + ($d), $rr)) return adodb_date($fmt,false,$is_gmt); + + if ($rr[1] <= 100 && $rr[2]<= 1) return adodb_date($fmt,false,$is_gmt); + + // h-m-s-MM-DD-YY + if (!isset($rr[5])) $d = adodb_mktime(0,0,0,$rr[2],$rr[3],$rr[1],false,$is_gmt); + else $d = @adodb_mktime($rr[5],$rr[6],$rr[7],$rr[2],$rr[3],$rr[1],false,$is_gmt); + } + + return adodb_date($fmt,$d,$is_gmt); +} + + +/** + Return formatted date based on timestamp $d +*/ +function adodb_date($fmt,$d=false,$is_gmt=false) +{ +static $daylight; +global $ADODB_DATETIME_CLASS; + + if ($d === false) return ($is_gmt)? @gmdate($fmt): @date($fmt); + if (!defined('ADODB_TEST_DATES')) { + if ((abs($d) <= 0x7FFFFFFF)) { // check if number in 32-bit signed range + if (!defined('ADODB_NO_NEGATIVE_TS') || $d >= 0) // if windows, must be +ve integer + return ($is_gmt)? @gmdate($fmt,$d): @date($fmt,$d); + + } + } + $_day_power = 86400; + + $arr = _adodb_getdate($d,true,$is_gmt); + + if (!isset($daylight)) $daylight = function_exists('adodb_daylight_sv'); + if ($daylight) adodb_daylight_sv($arr, $is_gmt); + + $year = $arr['year']; + $month = $arr['mon']; + $day = $arr['mday']; + $hour = $arr['hours']; + $min = $arr['minutes']; + $secs = $arr['seconds']; + + $max = strlen($fmt); + $dates = ''; + + $isphp5 = PHP_VERSION >= 5; + + /* + at this point, we have the following integer vars to manipulate: + $year, $month, $day, $hour, $min, $secs + */ + for ($i=0; $i < $max; $i++) { + switch($fmt[$i]) { + case 'e': + $dates .= date('e'); + break; + case 'T': + if ($ADODB_DATETIME_CLASS) { + $dt = new DateTime(); + $dt->SetDate($year,$month,$day); + $dates .= $dt->Format('T'); + } else + $dates .= date('T'); + break; + // YEAR + case 'L': $dates .= $arr['leap'] ? '1' : '0'; break; + case 'r': // Thu, 21 Dec 2000 16:01:07 +0200 + + // 4.3.11 uses '04 Jun 2004' + // 4.3.8 uses ' 4 Jun 2004' + $dates .= gmdate('D',$_day_power*(3+adodb_dow($year,$month,$day))).', ' + . ($day<10?'0'.$day:$day) . ' '.date('M',mktime(0,0,0,$month,2,1971)).' '.$year.' '; + + if ($hour < 10) $dates .= '0'.$hour; else $dates .= $hour; + + if ($min < 10) $dates .= ':0'.$min; else $dates .= ':'.$min; + + if ($secs < 10) $dates .= ':0'.$secs; else $dates .= ':'.$secs; + + $gmt = adodb_get_gmt_diff($year,$month,$day); + + $dates .= ' '.adodb_tz_offset($gmt,$isphp5); + break; + + case 'Y': $dates .= $year; break; + case 'y': $dates .= substr($year,strlen($year)-2,2); break; + // MONTH + case 'm': if ($month<10) $dates .= '0'.$month; else $dates .= $month; break; + case 'Q': $dates .= ($month+3)>>2; break; + case 'n': $dates .= $month; break; + case 'M': $dates .= date('M',mktime(0,0,0,$month,2,1971)); break; + case 'F': $dates .= date('F',mktime(0,0,0,$month,2,1971)); break; + // DAY + case 't': $dates .= $arr['ndays']; break; + case 'z': $dates .= $arr['yday']; break; + case 'w': $dates .= adodb_dow($year,$month,$day); break; + case 'l': $dates .= gmdate('l',$_day_power*(3+adodb_dow($year,$month,$day))); break; + case 'D': $dates .= gmdate('D',$_day_power*(3+adodb_dow($year,$month,$day))); break; + case 'j': $dates .= $day; break; + case 'd': if ($day<10) $dates .= '0'.$day; else $dates .= $day; break; + case 'S': + $d10 = $day % 10; + if ($d10 == 1) $dates .= 'st'; + else if ($d10 == 2 && $day != 12) $dates .= 'nd'; + else if ($d10 == 3) $dates .= 'rd'; + else $dates .= 'th'; + break; + + // HOUR + case 'Z': + $dates .= ($is_gmt) ? 0 : -adodb_get_gmt_diff($year,$month,$day); break; + case 'O': + $gmt = ($is_gmt) ? 0 : adodb_get_gmt_diff($year,$month,$day); + + $dates .= adodb_tz_offset($gmt,$isphp5); + break; + + case 'H': + if ($hour < 10) $dates .= '0'.$hour; + else $dates .= $hour; + break; + case 'h': + if ($hour > 12) $hh = $hour - 12; + else { + if ($hour == 0) $hh = '12'; + else $hh = $hour; + } + + if ($hh < 10) $dates .= '0'.$hh; + else $dates .= $hh; + break; + + case 'G': + $dates .= $hour; + break; + + case 'g': + if ($hour > 12) $hh = $hour - 12; + else { + if ($hour == 0) $hh = '12'; + else $hh = $hour; + } + $dates .= $hh; + break; + // MINUTES + case 'i': if ($min < 10) $dates .= '0'.$min; else $dates .= $min; break; + // SECONDS + case 'U': $dates .= $d; break; + case 's': if ($secs < 10) $dates .= '0'.$secs; else $dates .= $secs; break; + // AM/PM + // Note 00:00 to 11:59 is AM, while 12:00 to 23:59 is PM + case 'a': + if ($hour>=12) $dates .= 'pm'; + else $dates .= 'am'; + break; + case 'A': + if ($hour>=12) $dates .= 'PM'; + else $dates .= 'AM'; + break; + default: + $dates .= $fmt[$i]; break; + // ESCAPE + case "\\": + $i++; + if ($i < $max) $dates .= $fmt[$i]; + break; + } + } + return $dates; +} + +/** + Returns a timestamp given a GMT/UTC time. + Note that $is_dst is not implemented and is ignored. +*/ +function adodb_gmmktime($hr,$min,$sec,$mon=false,$day=false,$year=false,$is_dst=false) +{ + return adodb_mktime($hr,$min,$sec,$mon,$day,$year,$is_dst,true); +} + +/** + Return a timestamp given a local time. Originally by jackbbs. + Note that $is_dst is not implemented and is ignored. + + Not a very fast algorithm - O(n) operation. Could be optimized to O(1). +*/ +function adodb_mktime($hr,$min,$sec,$mon=false,$day=false,$year=false,$is_dst=false,$is_gmt=false) +{ + if (!defined('ADODB_TEST_DATES')) { + + if ($mon === false) { + return $is_gmt? @gmmktime($hr,$min,$sec): @mktime($hr,$min,$sec); + } + + // for windows, we don't check 1970 because with timezone differences, + // 1 Jan 1970 could generate negative timestamp, which is illegal + $usephpfns = (1970 < $year && $year < 2038 + || !defined('ADODB_NO_NEGATIVE_TS') && (1901 < $year && $year < 2038) + ); + + + if ($usephpfns && ($year + $mon/12+$day/365.25+$hr/(24*365.25) >= 2038)) $usephpfns = false; + + if ($usephpfns) { + return $is_gmt ? + @gmmktime($hr,$min,$sec,$mon,$day,$year): + @mktime($hr,$min,$sec,$mon,$day,$year); + } + } + + $gmt_different = ($is_gmt) ? 0 : adodb_get_gmt_diff($year,$mon,$day); + + /* + # disabled because some people place large values in $sec. + # however we need it for $mon because we use an array... + $hr = intval($hr); + $min = intval($min); + $sec = intval($sec); + */ + $mon = intval($mon); + $day = intval($day); + $year = intval($year); + + + $year = adodb_year_digit_check($year); + + if ($mon > 12) { + $y = floor(($mon-1)/ 12); + $year += $y; + $mon -= $y*12; + } else if ($mon < 1) { + $y = ceil((1-$mon) / 12); + $year -= $y; + $mon += $y*12; + } + + $_day_power = 86400; + $_hour_power = 3600; + $_min_power = 60; + + $_month_table_normal = array("",31,28,31,30,31,30,31,31,30,31,30,31); + $_month_table_leaf = array("",31,29,31,30,31,30,31,31,30,31,30,31); + + $_total_date = 0; + if ($year >= 1970) { + for ($a = 1970 ; $a <= $year; $a++) { + $leaf = _adodb_is_leap_year($a); + if ($leaf == true) { + $loop_table = $_month_table_leaf; + $_add_date = 366; + } else { + $loop_table = $_month_table_normal; + $_add_date = 365; + } + if ($a < $year) { + $_total_date += $_add_date; + } else { + for($b=1;$b<$mon;$b++) { + $_total_date += $loop_table[$b]; + } + } + } + $_total_date +=$day-1; + $ret = $_total_date * $_day_power + $hr * $_hour_power + $min * $_min_power + $sec + $gmt_different; + + } else { + for ($a = 1969 ; $a >= $year; $a--) { + $leaf = _adodb_is_leap_year($a); + if ($leaf == true) { + $loop_table = $_month_table_leaf; + $_add_date = 366; + } else { + $loop_table = $_month_table_normal; + $_add_date = 365; + } + if ($a > $year) { $_total_date += $_add_date; + } else { + for($b=12;$b>$mon;$b--) { + $_total_date += $loop_table[$b]; + } + } + } + $_total_date += $loop_table[$mon] - $day; + + $_day_time = $hr * $_hour_power + $min * $_min_power + $sec; + $_day_time = $_day_power - $_day_time; + $ret = -( $_total_date * $_day_power + $_day_time - $gmt_different); + if ($ret < -12220185600) $ret += 10*86400; // if earlier than 5 Oct 1582 - gregorian correction + else if ($ret < -12219321600) $ret = -12219321600; // if in limbo, reset to 15 Oct 1582. + } + //print " dmy=$day/$mon/$year $hr:$min:$sec => " .$ret; + return $ret; +} + +function adodb_gmstrftime($fmt, $ts=false) +{ + return adodb_strftime($fmt,$ts,true); +} + +// hack - convert to adodb_date +function adodb_strftime($fmt, $ts=false,$is_gmt=false) +{ +global $ADODB_DATE_LOCALE; + + if (!defined('ADODB_TEST_DATES')) { + if ((abs($ts) <= 0x7FFFFFFF)) { // check if number in 32-bit signed range + if (!defined('ADODB_NO_NEGATIVE_TS') || $ts >= 0) // if windows, must be +ve integer + return ($is_gmt)? @gmstrftime($fmt,$ts): @strftime($fmt,$ts); + + } + } + + if (empty($ADODB_DATE_LOCALE)) { + /* + $tstr = strtoupper(gmstrftime('%c',31366800)); // 30 Dec 1970, 1 am + $sep = substr($tstr,2,1); + $hasAM = strrpos($tstr,'M') !== false; + */ + # see http://phplens.com/lens/lensforum/msgs.php?id=14865 for reasoning, and changelog for version 0.24 + $dstr = gmstrftime('%x',31366800); // 30 Dec 1970, 1 am + $sep = substr($dstr,2,1); + $tstr = strtoupper(gmstrftime('%X',31366800)); // 30 Dec 1970, 1 am + $hasAM = strrpos($tstr,'M') !== false; + + $ADODB_DATE_LOCALE = array(); + $ADODB_DATE_LOCALE[] = strncmp($tstr,'30',2) == 0 ? 'd'.$sep.'m'.$sep.'y' : 'm'.$sep.'d'.$sep.'y'; + $ADODB_DATE_LOCALE[] = ($hasAM) ? 'h:i:s a' : 'H:i:s'; + + } + $inpct = false; + $fmtdate = ''; + for ($i=0,$max = strlen($fmt); $i < $max; $i++) { + $ch = $fmt[$i]; + if ($ch == '%') { + if ($inpct) { + $fmtdate .= '%'; + $inpct = false; + } else + $inpct = true; + } else if ($inpct) { + + $inpct = false; + switch($ch) { + case '0': + case '1': + case '2': + case '3': + case '4': + case '5': + case '6': + case '7': + case '8': + case '9': + case 'E': + case 'O': + /* ignore format modifiers */ + $inpct = true; + break; + + case 'a': $fmtdate .= 'D'; break; + case 'A': $fmtdate .= 'l'; break; + case 'h': + case 'b': $fmtdate .= 'M'; break; + case 'B': $fmtdate .= 'F'; break; + case 'c': $fmtdate .= $ADODB_DATE_LOCALE[0].$ADODB_DATE_LOCALE[1]; break; + case 'C': $fmtdate .= '\C?'; break; // century + case 'd': $fmtdate .= 'd'; break; + case 'D': $fmtdate .= 'm/d/y'; break; + case 'e': $fmtdate .= 'j'; break; + case 'g': $fmtdate .= '\g?'; break; //? + case 'G': $fmtdate .= '\G?'; break; //? + case 'H': $fmtdate .= 'H'; break; + case 'I': $fmtdate .= 'h'; break; + case 'j': $fmtdate .= '?z'; $parsej = true; break; // wrong as j=1-based, z=0-basd + case 'm': $fmtdate .= 'm'; break; + case 'M': $fmtdate .= 'i'; break; + case 'n': $fmtdate .= "\n"; break; + case 'p': $fmtdate .= 'a'; break; + case 'r': $fmtdate .= 'h:i:s a'; break; + case 'R': $fmtdate .= 'H:i:s'; break; + case 'S': $fmtdate .= 's'; break; + case 't': $fmtdate .= "\t"; break; + case 'T': $fmtdate .= 'H:i:s'; break; + case 'u': $fmtdate .= '?u'; $parseu = true; break; // wrong strftime=1-based, date=0-based + case 'U': $fmtdate .= '?U'; $parseU = true; break;// wrong strftime=1-based, date=0-based + case 'x': $fmtdate .= $ADODB_DATE_LOCALE[0]; break; + case 'X': $fmtdate .= $ADODB_DATE_LOCALE[1]; break; + case 'w': $fmtdate .= '?w'; $parseu = true; break; // wrong strftime=1-based, date=0-based + case 'W': $fmtdate .= '?W'; $parseU = true; break;// wrong strftime=1-based, date=0-based + case 'y': $fmtdate .= 'y'; break; + case 'Y': $fmtdate .= 'Y'; break; + case 'Z': $fmtdate .= 'T'; break; + } + } else if (('A' <= ($ch) && ($ch) <= 'Z' ) || ('a' <= ($ch) && ($ch) <= 'z' )) + $fmtdate .= "\\".$ch; + else + $fmtdate .= $ch; + } + //echo "fmt=",$fmtdate,"
"; + if ($ts === false) $ts = time(); + $ret = adodb_date($fmtdate, $ts, $is_gmt); + return $ret; +} + + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb.inc.php new file mode 100644 index 00000000..0187f55c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/adodb.inc.php @@ -0,0 +1,4416 @@ +fields is available on EOF + $ADODB_FETCH_MODE, // DEFAULT, NUM, ASSOC or BOTH. Default follows native driver default... + $ADODB_GETONE_EOF, + $ADODB_QUOTE_FIELDNAMES; // Allows you to force quotes (backticks) around field names in queries generated by getinsertsql and getupdatesql. + + //============================================================================================== + // GLOBAL SETUP + //============================================================================================== + + $ADODB_EXTENSION = defined('ADODB_EXTENSION'); + + //********************************************************// + /* + Controls $ADODB_FORCE_TYPE mode. Default is ADODB_FORCE_VALUE (3). + Used in GetUpdateSql and GetInsertSql functions. Thx to Niko, nuko#mbnet.fi + + 0 = ignore empty fields. All empty fields in array are ignored. + 1 = force null. All empty, php null and string 'null' fields are changed to sql NULL values. + 2 = force empty. All empty, php null and string 'null' fields are changed to sql empty '' or 0 values. + 3 = force value. Value is left as it is. Php null and string 'null' are set to sql NULL values and empty fields '' are set to empty '' sql values. + */ + define('ADODB_FORCE_IGNORE',0); + define('ADODB_FORCE_NULL',1); + define('ADODB_FORCE_EMPTY',2); + define('ADODB_FORCE_VALUE',3); + //********************************************************// + + + if (!$ADODB_EXTENSION || ADODB_EXTENSION < 4.0) { + + define('ADODB_BAD_RS','

Bad $rs in %s. Connection or SQL invalid. Try using $connection->debug=true;

'); + + // allow [ ] @ ` " and . in table names + define('ADODB_TABLE_REGEX','([]0-9a-z_\:\"\`\.\@\[-]*)'); + + // prefetching used by oracle + if (!defined('ADODB_PREFETCH_ROWS')) define('ADODB_PREFETCH_ROWS',10); + + + /* + Controls ADODB_FETCH_ASSOC field-name case. Default is 2, use native case-names. + This currently works only with mssql, odbc, oci8po and ibase derived drivers. + + 0 = assoc lowercase field names. $rs->fields['orderid'] + 1 = assoc uppercase field names. $rs->fields['ORDERID'] + 2 = use native-case field names. $rs->fields['OrderID'] + */ + + define('ADODB_FETCH_DEFAULT',0); + define('ADODB_FETCH_NUM',1); + define('ADODB_FETCH_ASSOC',2); + define('ADODB_FETCH_BOTH',3); + + if (!defined('TIMESTAMP_FIRST_YEAR')) define('TIMESTAMP_FIRST_YEAR',100); + + // PHP's version scheme makes converting to numbers difficult - workaround + $_adodb_ver = (float) PHP_VERSION; + if ($_adodb_ver >= 5.2) { + define('ADODB_PHPVER',0x5200); + } else if ($_adodb_ver >= 5.0) { + define('ADODB_PHPVER',0x5000); + } else + die("PHP5 or later required. You are running ".PHP_VERSION); + } + + + //if (!defined('ADODB_ASSOC_CASE')) define('ADODB_ASSOC_CASE',2); + + + /** + Accepts $src and $dest arrays, replacing string $data + */ + function ADODB_str_replace($src, $dest, $data) + { + if (ADODB_PHPVER >= 0x4050) return str_replace($src,$dest,$data); + + $s = reset($src); + $d = reset($dest); + while ($s !== false) { + $data = str_replace($s,$d,$data); + $s = next($src); + $d = next($dest); + } + return $data; + } + + function ADODB_Setup() + { + GLOBAL + $ADODB_vers, // database version + $ADODB_COUNTRECS, // count number of records returned - slows down query + $ADODB_CACHE_DIR, // directory to cache recordsets + $ADODB_FETCH_MODE, + $ADODB_CACHE, + $ADODB_CACHE_CLASS, + $ADODB_FORCE_TYPE, + $ADODB_GETONE_EOF, + $ADODB_QUOTE_FIELDNAMES; + + if (empty($ADODB_CACHE_CLASS)) $ADODB_CACHE_CLASS = 'ADODB_Cache_File' ; + $ADODB_FETCH_MODE = ADODB_FETCH_DEFAULT; + $ADODB_FORCE_TYPE = ADODB_FORCE_VALUE; + $ADODB_GETONE_EOF = null; + + if (!isset($ADODB_CACHE_DIR)) { + $ADODB_CACHE_DIR = '/tmp'; //(isset($_ENV['TMP'])) ? $_ENV['TMP'] : '/tmp'; + } else { + // do not accept url based paths, eg. http:/ or ftp:/ + if (strpos($ADODB_CACHE_DIR,'://') !== false) + die("Illegal path http:// or ftp://"); + } + + + // Initialize random number generator for randomizing cache flushes + // -- note Since PHP 4.2.0, the seed becomes optional and defaults to a random value if omitted. + srand(((double)microtime())*1000000); + + /** + * ADODB version as a string. + */ + $ADODB_vers = 'V5.11 5 May 2010 (c) 2000-2010 John Lim (jlim#natsoft.com). All rights reserved. Released BSD & LGPL.'; + + /** + * Determines whether recordset->RecordCount() is used. + * Set to false for highest performance -- RecordCount() will always return -1 then + * for databases that provide "virtual" recordcounts... + */ + if (!isset($ADODB_COUNTRECS)) $ADODB_COUNTRECS = true; + } + + + //============================================================================================== + // CHANGE NOTHING BELOW UNLESS YOU ARE DESIGNING ADODB + //============================================================================================== + + ADODB_Setup(); + + //============================================================================================== + // CLASS ADOFieldObject + //============================================================================================== + /** + * Helper class for FetchFields -- holds info on a column + */ + class ADOFieldObject { + var $name = ''; + var $max_length=0; + var $type=""; +/* + // additional fields by dannym... (danny_milo@yahoo.com) + var $not_null = false; + // actually, this has already been built-in in the postgres, fbsql AND mysql module? ^-^ + // so we can as well make not_null standard (leaving it at "false" does not harm anyways) + + var $has_default = false; // this one I have done only in mysql and postgres for now ... + // others to come (dannym) + var $default_value; // default, if any, and supported. Check has_default first. +*/ + } + + // for transaction handling + + function ADODB_TransMonitor($dbms, $fn, $errno, $errmsg, $p1, $p2, &$thisConnection) + { + //print "Errorno ($fn errno=$errno m=$errmsg) "; + $thisConnection->_transOK = false; + if ($thisConnection->_oldRaiseFn) { + $fn = $thisConnection->_oldRaiseFn; + $fn($dbms, $fn, $errno, $errmsg, $p1, $p2,$thisConnection); + } + } + + //------------------ + // class for caching + class ADODB_Cache_File { + + var $createdir = true; // requires creation of temp dirs + + function ADODB_Cache_File() + { + global $ADODB_INCLUDED_CSV; + if (empty($ADODB_INCLUDED_CSV)) include_once(ADODB_DIR.'/adodb-csvlib.inc.php'); + } + + // write serialised recordset to cache item/file + function writecache($filename, $contents, $debug, $secs2cache) + { + return adodb_write_file($filename, $contents,$debug); + } + + // load serialised recordset and unserialise it + function &readcache($filename, &$err, $secs2cache, $rsClass) + { + $rs = csv2rs($filename,$err,$secs2cache,$rsClass); + return $rs; + } + + // flush all items in cache + function flushall($debug=false) + { + global $ADODB_CACHE_DIR; + + $rez = false; + + if (strlen($ADODB_CACHE_DIR) > 1) { + $rez = $this->_dirFlush($ADODB_CACHE_DIR); + if ($debug) ADOConnection::outp( "flushall: $dir
\n". $rez."
"); + } + return $rez; + } + + // flush one file in cache + function flushcache($f, $debug=false) + { + if (!@unlink($f)) { + if ($debug) ADOConnection::outp( "flushcache: failed for $f"); + } + } + + function getdirname($hash) + { + global $ADODB_CACHE_DIR; + if (!isset($this->notSafeMode)) $this->notSafeMode = !ini_get('safe_mode'); + return ($this->notSafeMode) ? $ADODB_CACHE_DIR.'/'.substr($hash,0,2) : $ADODB_CACHE_DIR; + } + + // create temp directories + function createdir($hash, $debug) + { + $dir = $this->getdirname($hash); + if ($this->notSafeMode && !file_exists($dir)) { + $oldu = umask(0); + if (!@mkdir($dir,0771)) if(!is_dir($dir) && $debug) ADOConnection::outp("Cannot create $dir"); + umask($oldu); + } + + return $dir; + } + + /** + * Private function to erase all of the files and subdirectories in a directory. + * + * Just specify the directory, and tell it if you want to delete the directory or just clear it out. + * Note: $kill_top_level is used internally in the function to flush subdirectories. + */ + function _dirFlush($dir, $kill_top_level = false) + { + if(!$dh = @opendir($dir)) return; + + while (($obj = readdir($dh))) { + if($obj=='.' || $obj=='..') continue; + $f = $dir.'/'.$obj; + + if (strpos($obj,'.cache')) @unlink($f); + if (is_dir($f)) $this->_dirFlush($f, true); + } + if ($kill_top_level === true) @rmdir($dir); + return true; + } + } + + //============================================================================================== + // CLASS ADOConnection + //============================================================================================== + + /** + * Connection object. For connecting to databases, and executing queries. + */ + class ADOConnection { + // + // PUBLIC VARS + // + var $dataProvider = 'native'; + var $databaseType = ''; /// RDBMS currently in use, eg. odbc, mysql, mssql + var $database = ''; /// Name of database to be used. + var $host = ''; /// The hostname of the database server + var $user = ''; /// The username which is used to connect to the database server. + var $password = ''; /// Password for the username. For security, we no longer store it. + var $debug = false; /// if set to true will output sql statements + var $maxblobsize = 262144; /// maximum size of blobs or large text fields (262144 = 256K)-- some db's die otherwise like foxpro + var $concat_operator = '+'; /// default concat operator -- change to || for Oracle/Interbase + var $substr = 'substr'; /// substring operator + var $length = 'length'; /// string length ofperator + var $random = 'rand()'; /// random function + var $upperCase = 'upper'; /// uppercase function + var $fmtDate = "'Y-m-d'"; /// used by DBDate() as the default date format used by the database + var $fmtTimeStamp = "'Y-m-d, h:i:s A'"; /// used by DBTimeStamp as the default timestamp fmt. + var $true = '1'; /// string that represents TRUE for a database + var $false = '0'; /// string that represents FALSE for a database + var $replaceQuote = "\\'"; /// string to use to replace quotes + var $nameQuote = '"'; /// string to use to quote identifiers and names + var $charSet=false; /// character set to use - only for interbase, postgres and oci8 + var $metaDatabasesSQL = ''; + var $metaTablesSQL = ''; + var $uniqueOrderBy = false; /// All order by columns have to be unique + var $emptyDate = ' '; + var $emptyTimeStamp = ' '; + var $lastInsID = false; + //-- + var $hasInsertID = false; /// supports autoincrement ID? + var $hasAffectedRows = false; /// supports affected rows for update/delete? + var $hasTop = false; /// support mssql/access SELECT TOP 10 * FROM TABLE + var $hasLimit = false; /// support pgsql/mysql SELECT * FROM TABLE LIMIT 10 + var $readOnly = false; /// this is a readonly database - used by phpLens + var $hasMoveFirst = false; /// has ability to run MoveFirst(), scrolling backwards + var $hasGenID = false; /// can generate sequences using GenID(); + var $hasTransactions = true; /// has transactions + //-- + var $genID = 0; /// sequence id used by GenID(); + var $raiseErrorFn = false; /// error function to call + var $isoDates = false; /// accepts dates in ISO format + var $cacheSecs = 3600; /// cache for 1 hour + + // memcache + var $memCache = false; /// should we use memCache instead of caching in files + var $memCacheHost; /// memCache host + var $memCachePort = 11211; /// memCache port + var $memCacheCompress = false; /// Use 'true' to store the item compressed (uses zlib) + + var $sysDate = false; /// name of function that returns the current date + var $sysTimeStamp = false; /// name of function that returns the current timestamp + var $sysUTimeStamp = false; // name of function that returns the current timestamp accurate to the microsecond or nearest fraction + var $arrayClass = 'ADORecordSet_array'; /// name of class used to generate array recordsets, which are pre-downloaded recordsets + + var $noNullStrings = false; /// oracle specific stuff - if true ensures that '' is converted to ' ' + var $numCacheHits = 0; + var $numCacheMisses = 0; + var $pageExecuteCountRows = true; + var $uniqueSort = false; /// indicates that all fields in order by must be unique + var $leftOuter = false; /// operator to use for left outer join in WHERE clause + var $rightOuter = false; /// operator to use for right outer join in WHERE clause + var $ansiOuter = false; /// whether ansi outer join syntax supported + var $autoRollback = false; // autoRollback on PConnect(). + var $poorAffectedRows = false; // affectedRows not working or unreliable + + var $fnExecute = false; + var $fnCacheExecute = false; + var $blobEncodeType = false; // false=not required, 'I'=encode to integer, 'C'=encode to char + var $rsPrefix = "ADORecordSet_"; + + var $autoCommit = true; /// do not modify this yourself - actually private + var $transOff = 0; /// temporarily disable transactions + var $transCnt = 0; /// count of nested transactions + + var $fetchMode=false; + + var $null2null = 'null'; // in autoexecute/getinsertsql/getupdatesql, this value will be converted to a null + var $bulkBind = false; // enable 2D Execute array + // + // PRIVATE VARS + // + var $_oldRaiseFn = false; + var $_transOK = null; + var $_connectionID = false; /// The returned link identifier whenever a successful database connection is made. + var $_errorMsg = false; /// A variable which was used to keep the returned last error message. The value will + /// then returned by the errorMsg() function + var $_errorCode = false; /// Last error code, not guaranteed to be used - only by oci8 + var $_queryID = false; /// This variable keeps the last created result link identifier + + var $_isPersistentConnection = false; /// A boolean variable to state whether its a persistent connection or normal connection. */ + var $_bindInputArray = false; /// set to true if ADOConnection.Execute() permits binding of array parameters. + var $_evalAll = false; + var $_affected = false; + var $_logsql = false; + var $_transmode = ''; // transaction mode + + + + /** + * Constructor + */ + function ADOConnection() + { + die('Virtual Class -- cannot instantiate'); + } + + static function Version() + { + global $ADODB_vers; + + $ok = preg_match( '/^[Vv]([0-9\.]+)/', $ADODB_vers, $matches ); + if (!$ok) return (float) substr($ADODB_vers,1); + else return $matches[1]; + } + + /** + Get server version info... + + @returns An array with 2 elements: $arr['string'] is the description string, + and $arr[version] is the version (also a string). + */ + function ServerInfo() + { + return array('description' => '', 'version' => ''); + } + + function IsConnected() + { + return !empty($this->_connectionID); + } + + function _findvers($str) + { + if (preg_match('/([0-9]+\.([0-9\.])+)/',$str, $arr)) return $arr[1]; + else return ''; + } + + /** + * All error messages go through this bottleneck function. + * You can define your own handler by defining the function name in ADODB_OUTP. + */ + static function outp($msg,$newline=true) + { + global $ADODB_FLUSH,$ADODB_OUTP; + + if (defined('ADODB_OUTP')) { + $fn = ADODB_OUTP; + $fn($msg,$newline); + return; + } else if (isset($ADODB_OUTP)) { + $fn = $ADODB_OUTP; + $fn($msg,$newline); + return; + } + + if ($newline) $msg .= "
\n"; + + if (isset($_SERVER['HTTP_USER_AGENT']) || !$newline) echo $msg; + else echo strip_tags($msg); + + + if (!empty($ADODB_FLUSH) && ob_get_length() !== false) flush(); // do not flush if output buffering enabled - useless - thx to Jesse Mullan + + } + + function Time() + { + $rs = $this->_Execute("select $this->sysTimeStamp"); + if ($rs && !$rs->EOF) return $this->UnixTimeStamp(reset($rs->fields)); + + return false; + } + + /** + * Connect to database + * + * @param [argHostname] Host to connect to + * @param [argUsername] Userid to login + * @param [argPassword] Associated password + * @param [argDatabaseName] database + * @param [forceNew] force new connection + * + * @return true or false + */ + function Connect($argHostname = "", $argUsername = "", $argPassword = "", $argDatabaseName = "", $forceNew = false) + { + if ($argHostname != "") $this->host = $argHostname; + if ($argUsername != "") $this->user = $argUsername; + if ($argPassword != "") $this->password = 'not stored'; // not stored for security reasons + if ($argDatabaseName != "") $this->database = $argDatabaseName; + + $this->_isPersistentConnection = false; + + if ($forceNew) { + if ($rez=$this->_nconnect($this->host, $this->user, $argPassword, $this->database)) return true; + } else { + if ($rez=$this->_connect($this->host, $this->user, $argPassword, $this->database)) return true; + } + if (isset($rez)) { + $err = $this->ErrorMsg(); + if (empty($err)) $err = "Connection error to server '$argHostname' with user '$argUsername'"; + $ret = false; + } else { + $err = "Missing extension for ".$this->dataProvider; + $ret = 0; + } + if ($fn = $this->raiseErrorFn) + $fn($this->databaseType,'CONNECT',$this->ErrorNo(),$err,$this->host,$this->database,$this); + + + $this->_connectionID = false; + if ($this->debug) ADOConnection::outp( $this->host.': '.$err); + return $ret; + } + + function _nconnect($argHostname, $argUsername, $argPassword, $argDatabaseName) + { + return $this->_connect($argHostname, $argUsername, $argPassword, $argDatabaseName); + } + + + /** + * Always force a new connection to database - currently only works with oracle + * + * @param [argHostname] Host to connect to + * @param [argUsername] Userid to login + * @param [argPassword] Associated password + * @param [argDatabaseName] database + * + * @return true or false + */ + function NConnect($argHostname = "", $argUsername = "", $argPassword = "", $argDatabaseName = "") + { + return $this->Connect($argHostname, $argUsername, $argPassword, $argDatabaseName, true); + } + + /** + * Establish persistent connect to database + * + * @param [argHostname] Host to connect to + * @param [argUsername] Userid to login + * @param [argPassword] Associated password + * @param [argDatabaseName] database + * + * @return return true or false + */ + function PConnect($argHostname = "", $argUsername = "", $argPassword = "", $argDatabaseName = "") + { + + if (defined('ADODB_NEVER_PERSIST')) + return $this->Connect($argHostname,$argUsername,$argPassword,$argDatabaseName); + + if ($argHostname != "") $this->host = $argHostname; + if ($argUsername != "") $this->user = $argUsername; + if ($argPassword != "") $this->password = 'not stored'; + if ($argDatabaseName != "") $this->database = $argDatabaseName; + + $this->_isPersistentConnection = true; + + if ($rez = $this->_pconnect($this->host, $this->user, $argPassword, $this->database)) return true; + if (isset($rez)) { + $err = $this->ErrorMsg(); + if (empty($err)) $err = "Connection error to server '$argHostname' with user '$argUsername'"; + $ret = false; + } else { + $err = "Missing extension for ".$this->dataProvider; + $ret = 0; + } + if ($fn = $this->raiseErrorFn) { + $fn($this->databaseType,'PCONNECT',$this->ErrorNo(),$err,$this->host,$this->database,$this); + } + + $this->_connectionID = false; + if ($this->debug) ADOConnection::outp( $this->host.': '.$err); + return $ret; + } + + function outp_throw($msg,$src='WARN',$sql='') + { + if (defined('ADODB_ERROR_HANDLER') && ADODB_ERROR_HANDLER == 'adodb_throw') { + adodb_throw($this->databaseType,$src,-9999,$msg,$sql,false,$this); + return; + } + ADOConnection::outp($msg); + } + + // create cache class. Code is backward compat with old memcache implementation + function _CreateCache() + { + global $ADODB_CACHE, $ADODB_CACHE_CLASS; + + if ($this->memCache) { + global $ADODB_INCLUDED_MEMCACHE; + + if (empty($ADODB_INCLUDED_MEMCACHE)) include(ADODB_DIR.'/adodb-memcache.lib.inc.php'); + $ADODB_CACHE = new ADODB_Cache_MemCache($this); + } else + $ADODB_CACHE = new $ADODB_CACHE_CLASS($this); + + } + + // Format date column in sql string given an input format that understands Y M D + function SQLDate($fmt, $col=false) + { + if (!$col) $col = $this->sysDate; + return $col; // child class implement + } + + /** + * Should prepare the sql statement and return the stmt resource. + * For databases that do not support this, we return the $sql. To ensure + * compatibility with databases that do not support prepare: + * + * $stmt = $db->Prepare("insert into table (id, name) values (?,?)"); + * $db->Execute($stmt,array(1,'Jill')) or die('insert failed'); + * $db->Execute($stmt,array(2,'Joe')) or die('insert failed'); + * + * @param sql SQL to send to database + * + * @return return FALSE, or the prepared statement, or the original sql if + * if the database does not support prepare. + * + */ + function Prepare($sql) + { + return $sql; + } + + /** + * Some databases, eg. mssql require a different function for preparing + * stored procedures. So we cannot use Prepare(). + * + * Should prepare the stored procedure and return the stmt resource. + * For databases that do not support this, we return the $sql. To ensure + * compatibility with databases that do not support prepare: + * + * @param sql SQL to send to database + * + * @return return FALSE, or the prepared statement, or the original sql if + * if the database does not support prepare. + * + */ + function PrepareSP($sql,$param=true) + { + return $this->Prepare($sql,$param); + } + + /** + * PEAR DB Compat + */ + function Quote($s) + { + return $this->qstr($s,false); + } + + /** + Requested by "Karsten Dambekalns" + */ + function QMagic($s) + { + return $this->qstr($s,get_magic_quotes_gpc()); + } + + function q(&$s) + { + #if (!empty($this->qNull)) if ($s == 'null') return $s; + $s = $this->qstr($s,false); + } + + /** + * PEAR DB Compat - do not use internally. + */ + function ErrorNative() + { + return $this->ErrorNo(); + } + + + /** + * PEAR DB Compat - do not use internally. + */ + function nextId($seq_name) + { + return $this->GenID($seq_name); + } + + /** + * Lock a row, will escalate and lock the table if row locking not supported + * will normally free the lock at the end of the transaction + * + * @param $table name of table to lock + * @param $where where clause to use, eg: "WHERE row=12". If left empty, will escalate to table lock + */ + function RowLock($table,$where,$col='1 as adodbignore') + { + return false; + } + + function CommitLock($table) + { + return $this->CommitTrans(); + } + + function RollbackLock($table) + { + return $this->RollbackTrans(); + } + + /** + * PEAR DB Compat - do not use internally. + * + * The fetch modes for NUMERIC and ASSOC for PEAR DB and ADODB are identical + * for easy porting :-) + * + * @param mode The fetchmode ADODB_FETCH_ASSOC or ADODB_FETCH_NUM + * @returns The previous fetch mode + */ + function SetFetchMode($mode) + { + $old = $this->fetchMode; + $this->fetchMode = $mode; + + if ($old === false) { + global $ADODB_FETCH_MODE; + return $ADODB_FETCH_MODE; + } + return $old; + } + + + /** + * PEAR DB Compat - do not use internally. + */ + function Query($sql, $inputarr=false) + { + $rs = $this->Execute($sql, $inputarr); + if (!$rs && defined('ADODB_PEAR')) return ADODB_PEAR_Error(); + return $rs; + } + + + /** + * PEAR DB Compat - do not use internally + */ + function LimitQuery($sql, $offset, $count, $params=false) + { + $rs = $this->SelectLimit($sql, $count, $offset, $params); + if (!$rs && defined('ADODB_PEAR')) return ADODB_PEAR_Error(); + return $rs; + } + + + /** + * PEAR DB Compat - do not use internally + */ + function Disconnect() + { + return $this->Close(); + } + + /* + Returns placeholder for parameter, eg. + $DB->Param('a') + + will return ':a' for Oracle, and '?' for most other databases... + + For databases that require positioned params, eg $1, $2, $3 for postgresql, + pass in Param(false) before setting the first parameter. + */ + function Param($name,$type='C') + { + return '?'; + } + + /* + InParameter and OutParameter are self-documenting versions of Parameter(). + */ + function InParameter(&$stmt,&$var,$name,$maxLen=4000,$type=false) + { + return $this->Parameter($stmt,$var,$name,false,$maxLen,$type); + } + + /* + */ + function OutParameter(&$stmt,&$var,$name,$maxLen=4000,$type=false) + { + return $this->Parameter($stmt,$var,$name,true,$maxLen,$type); + + } + + + /* + Usage in oracle + $stmt = $db->Prepare('select * from table where id =:myid and group=:group'); + $db->Parameter($stmt,$id,'myid'); + $db->Parameter($stmt,$group,'group',64); + $db->Execute(); + + @param $stmt Statement returned by Prepare() or PrepareSP(). + @param $var PHP variable to bind to + @param $name Name of stored procedure variable name to bind to. + @param [$isOutput] Indicates direction of parameter 0/false=IN 1=OUT 2= IN/OUT. This is ignored in oci8. + @param [$maxLen] Holds an maximum length of the variable. + @param [$type] The data type of $var. Legal values depend on driver. + + */ + function Parameter(&$stmt,&$var,$name,$isOutput=false,$maxLen=4000,$type=false) + { + return false; + } + + + function IgnoreErrors($saveErrs=false) + { + if (!$saveErrs) { + $saveErrs = array($this->raiseErrorFn,$this->_transOK); + $this->raiseErrorFn = false; + return $saveErrs; + } else { + $this->raiseErrorFn = $saveErrs[0]; + $this->_transOK = $saveErrs[1]; + } + } + + /** + Improved method of initiating a transaction. Used together with CompleteTrans(). + Advantages include: + + a. StartTrans/CompleteTrans is nestable, unlike BeginTrans/CommitTrans/RollbackTrans. + Only the outermost block is treated as a transaction.
+ b. CompleteTrans auto-detects SQL errors, and will rollback on errors, commit otherwise.
+ c. All BeginTrans/CommitTrans/RollbackTrans inside a StartTrans/CompleteTrans block + are disabled, making it backward compatible. + */ + function StartTrans($errfn = 'ADODB_TransMonitor') + { + if ($this->transOff > 0) { + $this->transOff += 1; + return true; + } + + $this->_oldRaiseFn = $this->raiseErrorFn; + $this->raiseErrorFn = $errfn; + $this->_transOK = true; + + if ($this->debug && $this->transCnt > 0) ADOConnection::outp("Bad Transaction: StartTrans called within BeginTrans"); + $ok = $this->BeginTrans(); + $this->transOff = 1; + return $ok; + } + + + /** + Used together with StartTrans() to end a transaction. Monitors connection + for sql errors, and will commit or rollback as appropriate. + + @autoComplete if true, monitor sql errors and commit and rollback as appropriate, + and if set to false force rollback even if no SQL error detected. + @returns true on commit, false on rollback. + */ + function CompleteTrans($autoComplete = true) + { + if ($this->transOff > 1) { + $this->transOff -= 1; + return true; + } + $this->raiseErrorFn = $this->_oldRaiseFn; + + $this->transOff = 0; + if ($this->_transOK && $autoComplete) { + if (!$this->CommitTrans()) { + $this->_transOK = false; + if ($this->debug) ADOConnection::outp("Smart Commit failed"); + } else + if ($this->debug) ADOConnection::outp("Smart Commit occurred"); + } else { + $this->_transOK = false; + $this->RollbackTrans(); + if ($this->debug) ADOCOnnection::outp("Smart Rollback occurred"); + } + + return $this->_transOK; + } + + /* + At the end of a StartTrans/CompleteTrans block, perform a rollback. + */ + function FailTrans() + { + if ($this->debug) + if ($this->transOff == 0) { + ADOConnection::outp("FailTrans outside StartTrans/CompleteTrans"); + } else { + ADOConnection::outp("FailTrans was called"); + adodb_backtrace(); + } + $this->_transOK = false; + } + + /** + Check if transaction has failed, only for Smart Transactions. + */ + function HasFailedTrans() + { + if ($this->transOff > 0) return $this->_transOK == false; + return false; + } + + /** + * Execute SQL + * + * @param sql SQL statement to execute, or possibly an array holding prepared statement ($sql[0] will hold sql text) + * @param [inputarr] holds the input data to bind to. Null elements will be set to null. + * @return RecordSet or false + */ + function Execute($sql,$inputarr=false) + { + if ($this->fnExecute) { + $fn = $this->fnExecute; + $ret = $fn($this,$sql,$inputarr); + if (isset($ret)) return $ret; + } + if ($inputarr) { + if (!is_array($inputarr)) $inputarr = array($inputarr); + + $element0 = reset($inputarr); + # is_object check because oci8 descriptors can be passed in + $array_2d = $this->bulkBind && is_array($element0) && !is_object(reset($element0)); + //remove extra memory copy of input -mikefedyk + unset($element0); + + if (!is_array($sql) && !$this->_bindInputArray) { + $sqlarr = explode('?',$sql); + $nparams = sizeof($sqlarr)-1; + if (!$array_2d) $inputarr = array($inputarr); + foreach($inputarr as $arr) { + $sql = ''; $i = 0; + //Use each() instead of foreach to reduce memory usage -mikefedyk + while(list(, $v) = each($arr)) { + $sql .= $sqlarr[$i]; + // from Ron Baldwin + // Only quote string types + $typ = gettype($v); + if ($typ == 'string') + //New memory copy of input created here -mikefedyk + $sql .= $this->qstr($v); + else if ($typ == 'double') + $sql .= str_replace(',','.',$v); // locales fix so 1.1 does not get converted to 1,1 + else if ($typ == 'boolean') + $sql .= $v ? $this->true : $this->false; + else if ($typ == 'object') { + if (method_exists($v, '__toString')) $sql .= $this->qstr($v->__toString()); + else $sql .= $this->qstr((string) $v); + } else if ($v === null) + $sql .= 'NULL'; + else + $sql .= $v; + $i += 1; + + if ($i == $nparams) break; + } // while + if (isset($sqlarr[$i])) { + $sql .= $sqlarr[$i]; + if ($i+1 != sizeof($sqlarr)) $this->outp_throw( "Input Array does not match ?: ".htmlspecialchars($sql),'Execute'); + } else if ($i != sizeof($sqlarr)) + $this->outp_throw( "Input array does not match ?: ".htmlspecialchars($sql),'Execute'); + + $ret = $this->_Execute($sql); + if (!$ret) return $ret; + } + } else { + if ($array_2d) { + if (is_string($sql)) + $stmt = $this->Prepare($sql); + else + $stmt = $sql; + + foreach($inputarr as $arr) { + $ret = $this->_Execute($stmt,$arr); + if (!$ret) return $ret; + } + } else { + $ret = $this->_Execute($sql,$inputarr); + } + } + } else { + $ret = $this->_Execute($sql,false); + } + + return $ret; + } + + + function _Execute($sql,$inputarr=false) + { + if ($this->debug) { + global $ADODB_INCLUDED_LIB; + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + $this->_queryID = _adodb_debug_execute($this, $sql,$inputarr); + } else { + $this->_queryID = @$this->_query($sql,$inputarr); + } + + /************************ + // OK, query executed + *************************/ + + if ($this->_queryID === false) { // error handling if query fails + if ($this->debug == 99) adodb_backtrace(true,5); + $fn = $this->raiseErrorFn; + if ($fn) { + $fn($this->databaseType,'EXECUTE',$this->ErrorNo(),$this->ErrorMsg(),$sql,$inputarr,$this); + } + $false = false; + return $false; + } + + if ($this->_queryID === true) { // return simplified recordset for inserts/updates/deletes with lower overhead + $rsclass = $this->rsPrefix.'empty'; + $rs = (class_exists($rsclass)) ? new $rsclass(): new ADORecordSet_empty(); + + return $rs; + } + + // return real recordset from select statement + $rsclass = $this->rsPrefix.$this->databaseType; + $rs = new $rsclass($this->_queryID,$this->fetchMode); + $rs->connection = $this; // Pablo suggestion + $rs->Init(); + if (is_array($sql)) $rs->sql = $sql[0]; + else $rs->sql = $sql; + if ($rs->_numOfRows <= 0) { + global $ADODB_COUNTRECS; + if ($ADODB_COUNTRECS) { + if (!$rs->EOF) { + $rs = $this->_rs2rs($rs,-1,-1,!is_array($sql)); + $rs->_queryID = $this->_queryID; + } else + $rs->_numOfRows = 0; + } + } + return $rs; + } + + function CreateSequence($seqname='adodbseq',$startID=1) + { + if (empty($this->_genSeqSQL)) return false; + return $this->Execute(sprintf($this->_genSeqSQL,$seqname,$startID)); + } + + function DropSequence($seqname='adodbseq') + { + if (empty($this->_dropSeqSQL)) return false; + return $this->Execute(sprintf($this->_dropSeqSQL,$seqname)); + } + + /** + * Generates a sequence id and stores it in $this->genID; + * GenID is only available if $this->hasGenID = true; + * + * @param seqname name of sequence to use + * @param startID if sequence does not exist, start at this ID + * @return 0 if not supported, otherwise a sequence id + */ + function GenID($seqname='adodbseq',$startID=1) + { + if (!$this->hasGenID) { + return 0; // formerly returns false pre 1.60 + } + + $getnext = sprintf($this->_genIDSQL,$seqname); + + $holdtransOK = $this->_transOK; + + $save_handler = $this->raiseErrorFn; + $this->raiseErrorFn = ''; + @($rs = $this->Execute($getnext)); + $this->raiseErrorFn = $save_handler; + + if (!$rs) { + $this->_transOK = $holdtransOK; //if the status was ok before reset + $createseq = $this->Execute(sprintf($this->_genSeqSQL,$seqname,$startID)); + $rs = $this->Execute($getnext); + } + if ($rs && !$rs->EOF) $this->genID = reset($rs->fields); + else $this->genID = 0; // false + + if ($rs) $rs->Close(); + + return $this->genID; + } + + /** + * @param $table string name of the table, not needed by all databases (eg. mysql), default '' + * @param $column string name of the column, not needed by all databases (eg. mysql), default '' + * @return the last inserted ID. Not all databases support this. + */ + function Insert_ID($table='',$column='') + { + if ($this->_logsql && $this->lastInsID) return $this->lastInsID; + if ($this->hasInsertID) return $this->_insertid($table,$column); + if ($this->debug) { + ADOConnection::outp( '

Insert_ID error

'); + adodb_backtrace(); + } + return false; + } + + + /** + * Portable Insert ID. Pablo Roca + * + * @return the last inserted ID. All databases support this. But aware possible + * problems in multiuser environments. Heavy test this before deploying. + */ + function PO_Insert_ID($table="", $id="") + { + if ($this->hasInsertID){ + return $this->Insert_ID($table,$id); + } else { + return $this->GetOne("SELECT MAX($id) FROM $table"); + } + } + + /** + * @return # rows affected by UPDATE/DELETE + */ + function Affected_Rows() + { + if ($this->hasAffectedRows) { + if ($this->fnExecute === 'adodb_log_sql') { + if ($this->_logsql && $this->_affected !== false) return $this->_affected; + } + $val = $this->_affectedrows(); + return ($val < 0) ? false : $val; + } + + if ($this->debug) ADOConnection::outp( '

Affected_Rows error

',false); + return false; + } + + + /** + * @return the last error message + */ + function ErrorMsg() + { + if ($this->_errorMsg) return '!! '.strtoupper($this->dataProvider.' '.$this->databaseType).': '.$this->_errorMsg; + else return ''; + } + + + /** + * @return the last error number. Normally 0 means no error. + */ + function ErrorNo() + { + return ($this->_errorMsg) ? -1 : 0; + } + + function MetaError($err=false) + { + include_once(ADODB_DIR."/adodb-error.inc.php"); + if ($err === false) $err = $this->ErrorNo(); + return adodb_error($this->dataProvider,$this->databaseType,$err); + } + + function MetaErrorMsg($errno) + { + include_once(ADODB_DIR."/adodb-error.inc.php"); + return adodb_errormsg($errno); + } + + /** + * @returns an array with the primary key columns in it. + */ + function MetaPrimaryKeys($table, $owner=false) + { + // owner not used in base class - see oci8 + $p = array(); + $objs = $this->MetaColumns($table); + if ($objs) { + foreach($objs as $v) { + if (!empty($v->primary_key)) + $p[] = $v->name; + } + } + if (sizeof($p)) return $p; + if (function_exists('ADODB_VIEW_PRIMARYKEYS')) + return ADODB_VIEW_PRIMARYKEYS($this->databaseType, $this->database, $table, $owner); + return false; + } + + /** + * @returns assoc array where keys are tables, and values are foreign keys + */ + function MetaForeignKeys($table, $owner=false, $upper=false) + { + return false; + } + /** + * Choose a database to connect to. Many databases do not support this. + * + * @param dbName is the name of the database to select + * @return true or false + */ + function SelectDB($dbName) + {return false;} + + + /** + * Will select, getting rows from $offset (1-based), for $nrows. + * This simulates the MySQL "select * from table limit $offset,$nrows" , and + * the PostgreSQL "select * from table limit $nrows offset $offset". Note that + * MySQL and PostgreSQL parameter ordering is the opposite of the other. + * eg. + * SelectLimit('select * from table',3); will return rows 1 to 3 (1-based) + * SelectLimit('select * from table',3,2); will return rows 3 to 5 (1-based) + * + * Uses SELECT TOP for Microsoft databases (when $this->hasTop is set) + * BUG: Currently SelectLimit fails with $sql with LIMIT or TOP clause already set + * + * @param sql + * @param [offset] is the row to start calculations from (1-based) + * @param [nrows] is the number of rows to get + * @param [inputarr] array of bind variables + * @param [secs2cache] is a private parameter only used by jlim + * @return the recordset ($rs->databaseType == 'array') + */ + function SelectLimit($sql,$nrows=-1,$offset=-1, $inputarr=false,$secs2cache=0) + { + if ($this->hasTop && $nrows > 0) { + // suggested by Reinhard Balling. Access requires top after distinct + // Informix requires first before distinct - F Riosa + $ismssql = (strpos($this->databaseType,'mssql') !== false); + if ($ismssql) $isaccess = false; + else $isaccess = (strpos($this->databaseType,'access') !== false); + + if ($offset <= 0) { + + // access includes ties in result + if ($isaccess) { + $sql = preg_replace( + '/(^\s*select\s+(distinctrow|distinct)?)/i','\\1 '.$this->hasTop.' '.((integer)$nrows).' ',$sql); + + if ($secs2cache != 0) { + $ret = $this->CacheExecute($secs2cache, $sql,$inputarr); + } else { + $ret = $this->Execute($sql,$inputarr); + } + return $ret; // PHP5 fix + } else if ($ismssql){ + $sql = preg_replace( + '/(^\s*select\s+(distinctrow|distinct)?)/i','\\1 '.$this->hasTop.' '.((integer)$nrows).' ',$sql); + } else { + $sql = preg_replace( + '/(^\s*select\s)/i','\\1 '.$this->hasTop.' '.((integer)$nrows).' ',$sql); + } + } else { + $nn = $nrows + $offset; + if ($isaccess || $ismssql) { + $sql = preg_replace( + '/(^\s*select\s+(distinctrow|distinct)?)/i','\\1 '.$this->hasTop.' '.$nn.' ',$sql); + } else { + $sql = preg_replace( + '/(^\s*select\s)/i','\\1 '.$this->hasTop.' '.$nn.' ',$sql); + } + } + } + + // if $offset>0, we want to skip rows, and $ADODB_COUNTRECS is set, we buffer rows + // 0 to offset-1 which will be discarded anyway. So we disable $ADODB_COUNTRECS. + global $ADODB_COUNTRECS; + + $savec = $ADODB_COUNTRECS; + $ADODB_COUNTRECS = false; + + + if ($secs2cache != 0) $rs = $this->CacheExecute($secs2cache,$sql,$inputarr); + else $rs = $this->Execute($sql,$inputarr); + + $ADODB_COUNTRECS = $savec; + if ($rs && !$rs->EOF) { + $rs = $this->_rs2rs($rs,$nrows,$offset); + } + //print_r($rs); + return $rs; + } + + /** + * Create serializable recordset. Breaks rs link to connection. + * + * @param rs the recordset to serialize + */ + function SerializableRS(&$rs) + { + $rs2 = $this->_rs2rs($rs); + $ignore = false; + $rs2->connection = $ignore; + + return $rs2; + } + + /** + * Convert database recordset to an array recordset + * input recordset's cursor should be at beginning, and + * old $rs will be closed. + * + * @param rs the recordset to copy + * @param [nrows] number of rows to retrieve (optional) + * @param [offset] offset by number of rows (optional) + * @return the new recordset + */ + function &_rs2rs(&$rs,$nrows=-1,$offset=-1,$close=true) + { + if (! $rs) { + $false = false; + return $false; + } + $dbtype = $rs->databaseType; + if (!$dbtype) { + $rs = $rs; // required to prevent crashing in 4.2.1, but does not happen in 4.3.1 -- why ? + return $rs; + } + if (($dbtype == 'array' || $dbtype == 'csv') && $nrows == -1 && $offset == -1) { + $rs->MoveFirst(); + $rs = $rs; // required to prevent crashing in 4.2.1, but does not happen in 4.3.1-- why ? + return $rs; + } + $flds = array(); + for ($i=0, $max=$rs->FieldCount(); $i < $max; $i++) { + $flds[] = $rs->FetchField($i); + } + + $arr = $rs->GetArrayLimit($nrows,$offset); + //print_r($arr); + if ($close) $rs->Close(); + + $arrayClass = $this->arrayClass; + + $rs2 = new $arrayClass(); + $rs2->connection = $this; + $rs2->sql = $rs->sql; + $rs2->dataProvider = $this->dataProvider; + $rs2->InitArrayFields($arr,$flds); + $rs2->fetchMode = isset($rs->adodbFetchMode) ? $rs->adodbFetchMode : $rs->fetchMode; + return $rs2; + } + + /* + * Return all rows. Compat with PEAR DB + */ + function GetAll($sql, $inputarr=false) + { + $arr = $this->GetArray($sql,$inputarr); + return $arr; + } + + function GetAssoc($sql, $inputarr=false,$force_array = false, $first2cols = false) + { + $rs = $this->Execute($sql, $inputarr); + if (!$rs) { + $false = false; + return $false; + } + $arr = $rs->GetAssoc($force_array,$first2cols); + return $arr; + } + + function CacheGetAssoc($secs2cache, $sql=false, $inputarr=false,$force_array = false, $first2cols = false) + { + if (!is_numeric($secs2cache)) { + $first2cols = $force_array; + $force_array = $inputarr; + } + $rs = $this->CacheExecute($secs2cache, $sql, $inputarr); + if (!$rs) { + $false = false; + return $false; + } + $arr = $rs->GetAssoc($force_array,$first2cols); + return $arr; + } + + /** + * Return first element of first row of sql statement. Recordset is disposed + * for you. + * + * @param sql SQL statement + * @param [inputarr] input bind array + */ + function GetOne($sql,$inputarr=false) + { + global $ADODB_COUNTRECS,$ADODB_GETONE_EOF; + $crecs = $ADODB_COUNTRECS; + $ADODB_COUNTRECS = false; + + $ret = false; + $rs = $this->Execute($sql,$inputarr); + if ($rs) { + if ($rs->EOF) $ret = $ADODB_GETONE_EOF; + else $ret = reset($rs->fields); + + $rs->Close(); + } + $ADODB_COUNTRECS = $crecs; + return $ret; + } + + // $where should include 'WHERE fld=value' + function GetMedian($table, $field,$where = '') + { + $total = $this->GetOne("select count(*) from $table $where"); + if (!$total) return false; + + $midrow = (integer) ($total/2); + $rs = $this->SelectLimit("select $field from $table $where order by 1",1,$midrow); + if ($rs && !$rs->EOF) return reset($rs->fields); + return false; + } + + + function CacheGetOne($secs2cache,$sql=false,$inputarr=false) + { + global $ADODB_GETONE_EOF; + $ret = false; + $rs = $this->CacheExecute($secs2cache,$sql,$inputarr); + if ($rs) { + if ($rs->EOF) $ret = $ADODB_GETONE_EOF; + else $ret = reset($rs->fields); + $rs->Close(); + } + + return $ret; + } + + function GetCol($sql, $inputarr = false, $trim = false) + { + + $rs = $this->Execute($sql, $inputarr); + if ($rs) { + $rv = array(); + if ($trim) { + while (!$rs->EOF) { + $rv[] = trim(reset($rs->fields)); + $rs->MoveNext(); + } + } else { + while (!$rs->EOF) { + $rv[] = reset($rs->fields); + $rs->MoveNext(); + } + } + $rs->Close(); + } else + $rv = false; + return $rv; + } + + function CacheGetCol($secs, $sql = false, $inputarr = false,$trim=false) + { + $rs = $this->CacheExecute($secs, $sql, $inputarr); + if ($rs) { + $rv = array(); + if ($trim) { + while (!$rs->EOF) { + $rv[] = trim(reset($rs->fields)); + $rs->MoveNext(); + } + } else { + while (!$rs->EOF) { + $rv[] = reset($rs->fields); + $rs->MoveNext(); + } + } + $rs->Close(); + } else + $rv = false; + + return $rv; + } + + function Transpose(&$rs,$addfieldnames=true) + { + $rs2 = $this->_rs2rs($rs); + $false = false; + if (!$rs2) return $false; + + $rs2->_transpose($addfieldnames); + return $rs2; + } + + /* + Calculate the offset of a date for a particular database and generate + appropriate SQL. Useful for calculating future/past dates and storing + in a database. + + If dayFraction=1.5 means 1.5 days from now, 1.0/24 for 1 hour. + */ + function OffsetDate($dayFraction,$date=false) + { + if (!$date) $date = $this->sysDate; + return '('.$date.'+'.$dayFraction.')'; + } + + + /** + * + * @param sql SQL statement + * @param [inputarr] input bind array + */ + function GetArray($sql,$inputarr=false) + { + global $ADODB_COUNTRECS; + + $savec = $ADODB_COUNTRECS; + $ADODB_COUNTRECS = false; + $rs = $this->Execute($sql,$inputarr); + $ADODB_COUNTRECS = $savec; + if (!$rs) + if (defined('ADODB_PEAR')) { + $cls = ADODB_PEAR_Error(); + return $cls; + } else { + $false = false; + return $false; + } + $arr = $rs->GetArray(); + $rs->Close(); + return $arr; + } + + function CacheGetAll($secs2cache,$sql=false,$inputarr=false) + { + $arr = $this->CacheGetArray($secs2cache,$sql,$inputarr); + return $arr; + } + + function CacheGetArray($secs2cache,$sql=false,$inputarr=false) + { + global $ADODB_COUNTRECS; + + $savec = $ADODB_COUNTRECS; + $ADODB_COUNTRECS = false; + $rs = $this->CacheExecute($secs2cache,$sql,$inputarr); + $ADODB_COUNTRECS = $savec; + + if (!$rs) + if (defined('ADODB_PEAR')) { + $cls = ADODB_PEAR_Error(); + return $cls; + } else { + $false = false; + return $false; + } + $arr = $rs->GetArray(); + $rs->Close(); + return $arr; + } + + function GetRandRow($sql, $arr= false) + { + $rezarr = $this->GetAll($sql, $arr); + $sz = sizeof($rezarr); + return $rezarr[abs(rand()) % $sz]; + } + + /** + * Return one row of sql statement. Recordset is disposed for you. + * + * @param sql SQL statement + * @param [inputarr] input bind array + */ + function GetRow($sql,$inputarr=false) + { + global $ADODB_COUNTRECS; + $crecs = $ADODB_COUNTRECS; + $ADODB_COUNTRECS = false; + + $rs = $this->Execute($sql,$inputarr); + + $ADODB_COUNTRECS = $crecs; + if ($rs) { + if (!$rs->EOF) $arr = $rs->fields; + else $arr = array(); + $rs->Close(); + return $arr; + } + + $false = false; + return $false; + } + + function CacheGetRow($secs2cache,$sql=false,$inputarr=false) + { + $rs = $this->CacheExecute($secs2cache,$sql,$inputarr); + if ($rs) { + if (!$rs->EOF) $arr = $rs->fields; + else $arr = array(); + + $rs->Close(); + return $arr; + } + $false = false; + return $false; + } + + /** + * Insert or replace a single record. Note: this is not the same as MySQL's replace. + * ADOdb's Replace() uses update-insert semantics, not insert-delete-duplicates of MySQL. + * Also note that no table locking is done currently, so it is possible that the + * record be inserted twice by two programs... + * + * $this->Replace('products', array('prodname' =>"'Nails'","price" => 3.99), 'prodname'); + * + * $table table name + * $fieldArray associative array of data (you must quote strings yourself). + * $keyCol the primary key field name or if compound key, array of field names + * autoQuote set to true to use a hueristic to quote strings. Works with nulls and numbers + * but does not work with dates nor SQL functions. + * has_autoinc the primary key is an auto-inc field, so skip in insert. + * + * Currently blob replace not supported + * + * returns 0 = fail, 1 = update, 2 = insert + */ + + function Replace($table, $fieldArray, $keyCol, $autoQuote=false, $has_autoinc=false) + { + global $ADODB_INCLUDED_LIB; + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + + return _adodb_replace($this, $table, $fieldArray, $keyCol, $autoQuote, $has_autoinc); + } + + + /** + * Will select, getting rows from $offset (1-based), for $nrows. + * This simulates the MySQL "select * from table limit $offset,$nrows" , and + * the PostgreSQL "select * from table limit $nrows offset $offset". Note that + * MySQL and PostgreSQL parameter ordering is the opposite of the other. + * eg. + * CacheSelectLimit(15,'select * from table',3); will return rows 1 to 3 (1-based) + * CacheSelectLimit(15,'select * from table',3,2); will return rows 3 to 5 (1-based) + * + * BUG: Currently CacheSelectLimit fails with $sql with LIMIT or TOP clause already set + * + * @param [secs2cache] seconds to cache data, set to 0 to force query. This is optional + * @param sql + * @param [offset] is the row to start calculations from (1-based) + * @param [nrows] is the number of rows to get + * @param [inputarr] array of bind variables + * @return the recordset ($rs->databaseType == 'array') + */ + function CacheSelectLimit($secs2cache,$sql,$nrows=-1,$offset=-1,$inputarr=false) + { + if (!is_numeric($secs2cache)) { + if ($sql === false) $sql = -1; + if ($offset == -1) $offset = false; + // sql, nrows, offset,inputarr + $rs = $this->SelectLimit($secs2cache,$sql,$nrows,$offset,$this->cacheSecs); + } else { + if ($sql === false) $this->outp_throw("Warning: \$sql missing from CacheSelectLimit()",'CacheSelectLimit'); + $rs = $this->SelectLimit($sql,$nrows,$offset,$inputarr,$secs2cache); + } + return $rs; + } + + + /** + * Flush cached recordsets that match a particular $sql statement. + * If $sql == false, then we purge all files in the cache. + */ + + /** + * Flush cached recordsets that match a particular $sql statement. + * If $sql == false, then we purge all files in the cache. + */ + function CacheFlush($sql=false,$inputarr=false) + { + global $ADODB_CACHE_DIR, $ADODB_CACHE; + + if (empty($ADODB_CACHE)) return false; + + if (!$sql) { + $ADODB_CACHE->flushall($this->debug); + return; + } + + $f = $this->_gencachename($sql.serialize($inputarr),false); + return $ADODB_CACHE->flushcache($f, $this->debug); + } + + + /** + * Private function to generate filename for caching. + * Filename is generated based on: + * + * - sql statement + * - database type (oci8, ibase, ifx, etc) + * - database name + * - userid + * - setFetchMode (adodb 4.23) + * + * When not in safe mode, we create 256 sub-directories in the cache directory ($ADODB_CACHE_DIR). + * Assuming that we can have 50,000 files per directory with good performance, + * then we can scale to 12.8 million unique cached recordsets. Wow! + */ + function _gencachename($sql,$createdir) + { + global $ADODB_CACHE, $ADODB_CACHE_DIR; + + if ($this->fetchMode === false) { + global $ADODB_FETCH_MODE; + $mode = $ADODB_FETCH_MODE; + } else { + $mode = $this->fetchMode; + } + $m = md5($sql.$this->databaseType.$this->database.$this->user.$mode); + if (!$ADODB_CACHE->createdir) return $m; + if (!$createdir) $dir = $ADODB_CACHE->getdirname($m); + else $dir = $ADODB_CACHE->createdir($m, $this->debug); + + return $dir.'/adodb_'.$m.'.cache'; + } + + + /** + * Execute SQL, caching recordsets. + * + * @param [secs2cache] seconds to cache data, set to 0 to force query. + * This is an optional parameter. + * @param sql SQL statement to execute + * @param [inputarr] holds the input data to bind to + * @return RecordSet or false + */ + function CacheExecute($secs2cache,$sql=false,$inputarr=false) + { + global $ADODB_CACHE; + + if (empty($ADODB_CACHE)) $this->_CreateCache(); + + if (!is_numeric($secs2cache)) { + $inputarr = $sql; + $sql = $secs2cache; + $secs2cache = $this->cacheSecs; + } + + if (is_array($sql)) { + $sqlparam = $sql; + $sql = $sql[0]; + } else + $sqlparam = $sql; + + + $md5file = $this->_gencachename($sql.serialize($inputarr),true); + $err = ''; + + if ($secs2cache > 0){ + $rs = $ADODB_CACHE->readcache($md5file,$err,$secs2cache,$this->arrayClass); + $this->numCacheHits += 1; + } else { + $err='Timeout 1'; + $rs = false; + $this->numCacheMisses += 1; + } + + if (!$rs) { + // no cached rs found + if ($this->debug) { + if (get_magic_quotes_runtime() && !$this->memCache) { + ADOConnection::outp("Please disable magic_quotes_runtime - it corrupts cache files :("); + } + if ($this->debug !== -1) ADOConnection::outp( " $md5file cache failure: $err (see sql below)"); + } + + $rs = $this->Execute($sqlparam,$inputarr); + + if ($rs) { + + $eof = $rs->EOF; + $rs = $this->_rs2rs($rs); // read entire recordset into memory immediately + $rs->timeCreated = time(); // used by caching + $txt = _rs2serialize($rs,false,$sql); // serialize + + $ok = $ADODB_CACHE->writecache($md5file,$txt,$this->debug, $secs2cache); + if (!$ok) { + if ($ok === false) { + $em = 'Cache write error'; + $en = -32000; + + if ($fn = $this->raiseErrorFn) { + $fn($this->databaseType,'CacheExecute', $en, $em, $md5file,$sql,$this); + } + } else { + $em = 'Cache file locked warning'; + $en = -32001; + // do not call error handling for just a warning + } + + if ($this->debug) ADOConnection::outp( " ".$em); + } + if ($rs->EOF && !$eof) { + $rs->MoveFirst(); + //$rs = csv2rs($md5file,$err); + $rs->connection = $this; // Pablo suggestion + } + + } else if (!$this->memCache) + $ADODB_CACHE->flushcache($md5file); + } else { + $this->_errorMsg = ''; + $this->_errorCode = 0; + + if ($this->fnCacheExecute) { + $fn = $this->fnCacheExecute; + $fn($this, $secs2cache, $sql, $inputarr); + } + // ok, set cached object found + $rs->connection = $this; // Pablo suggestion + if ($this->debug){ + if ($this->debug == 99) adodb_backtrace(); + $inBrowser = isset($_SERVER['HTTP_USER_AGENT']); + $ttl = $rs->timeCreated + $secs2cache - time(); + $s = is_array($sql) ? $sql[0] : $sql; + if ($inBrowser) $s = ''.htmlspecialchars($s).''; + + ADOConnection::outp( " $md5file reloaded, ttl=$ttl [ $s ]"); + } + } + return $rs; + } + + + /* + Similar to PEAR DB's autoExecute(), except that + $mode can be 'INSERT' or 'UPDATE' or DB_AUTOQUERY_INSERT or DB_AUTOQUERY_UPDATE + If $mode == 'UPDATE', then $where is compulsory as a safety measure. + + $forceUpdate means that even if the data has not changed, perform update. + */ + function AutoExecute($table, $fields_values, $mode = 'INSERT', $where = FALSE, $forceUpdate=true, $magicq=false) + { + $false = false; + $sql = 'SELECT * FROM '.$table; + if ($where!==FALSE) $sql .= ' WHERE '.$where; + else if ($mode == 'UPDATE' || $mode == 2 /* DB_AUTOQUERY_UPDATE */) { + $this->outp_throw('AutoExecute: Illegal mode=UPDATE with empty WHERE clause','AutoExecute'); + return $false; + } + + $rs = $this->SelectLimit($sql,1); + if (!$rs) return $false; // table does not exist + $rs->tableName = $table; + $rs->sql = $sql; + + switch((string) $mode) { + case 'UPDATE': + case '2': + $sql = $this->GetUpdateSQL($rs, $fields_values, $forceUpdate, $magicq); + break; + case 'INSERT': + case '1': + $sql = $this->GetInsertSQL($rs, $fields_values, $magicq); + break; + default: + $this->outp_throw("AutoExecute: Unknown mode=$mode",'AutoExecute'); + return $false; + } + $ret = false; + if ($sql) $ret = $this->Execute($sql); + if ($ret) $ret = true; + return $ret; + } + + + /** + * Generates an Update Query based on an existing recordset. + * $arrFields is an associative array of fields with the value + * that should be assigned. + * + * Note: This function should only be used on a recordset + * that is run against a single table and sql should only + * be a simple select stmt with no groupby/orderby/limit + * + * "Jonathan Younger" + */ + function GetUpdateSQL(&$rs, $arrFields,$forceUpdate=false,$magicq=false,$force=null) + { + global $ADODB_INCLUDED_LIB; + + //********************************************************// + //This is here to maintain compatibility + //with older adodb versions. Sets force type to force nulls if $forcenulls is set. + if (!isset($force)) { + global $ADODB_FORCE_TYPE; + $force = $ADODB_FORCE_TYPE; + } + //********************************************************// + + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + return _adodb_getupdatesql($this,$rs,$arrFields,$forceUpdate,$magicq,$force); + } + + /** + * Generates an Insert Query based on an existing recordset. + * $arrFields is an associative array of fields with the value + * that should be assigned. + * + * Note: This function should only be used on a recordset + * that is run against a single table. + */ + function GetInsertSQL(&$rs, $arrFields,$magicq=false,$force=null) + { + global $ADODB_INCLUDED_LIB; + if (!isset($force)) { + global $ADODB_FORCE_TYPE; + $force = $ADODB_FORCE_TYPE; + + } + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + return _adodb_getinsertsql($this,$rs,$arrFields,$magicq,$force); + } + + + /** + * Update a blob column, given a where clause. There are more sophisticated + * blob handling functions that we could have implemented, but all require + * a very complex API. Instead we have chosen something that is extremely + * simple to understand and use. + * + * Note: $blobtype supports 'BLOB' and 'CLOB', default is BLOB of course. + * + * Usage to update a $blobvalue which has a primary key blob_id=1 into a + * field blobtable.blobcolumn: + * + * UpdateBlob('blobtable', 'blobcolumn', $blobvalue, 'blob_id=1'); + * + * Insert example: + * + * $conn->Execute('INSERT INTO blobtable (id, blobcol) VALUES (1, null)'); + * $conn->UpdateBlob('blobtable','blobcol',$blob,'id=1'); + */ + + function UpdateBlob($table,$column,$val,$where,$blobtype='BLOB') + { + return $this->Execute("UPDATE $table SET $column=? WHERE $where",array($val)) != false; + } + + /** + * Usage: + * UpdateBlob('TABLE', 'COLUMN', '/path/to/file', 'ID=1'); + * + * $blobtype supports 'BLOB' and 'CLOB' + * + * $conn->Execute('INSERT INTO blobtable (id, blobcol) VALUES (1, null)'); + * $conn->UpdateBlob('blobtable','blobcol',$blobpath,'id=1'); + */ + function UpdateBlobFile($table,$column,$path,$where,$blobtype='BLOB') + { + $fd = fopen($path,'rb'); + if ($fd === false) return false; + $val = fread($fd,filesize($path)); + fclose($fd); + return $this->UpdateBlob($table,$column,$val,$where,$blobtype); + } + + function BlobDecode($blob) + { + return $blob; + } + + function BlobEncode($blob) + { + return $blob; + } + + function SetCharSet($charset) + { + return false; + } + + function IfNull( $field, $ifNull ) + { + return " CASE WHEN $field is null THEN $ifNull ELSE $field END "; + } + + function LogSQL($enable=true) + { + include_once(ADODB_DIR.'/adodb-perf.inc.php'); + + if ($enable) $this->fnExecute = 'adodb_log_sql'; + else $this->fnExecute = false; + + $old = $this->_logsql; + $this->_logsql = $enable; + if ($enable && !$old) $this->_affected = false; + return $old; + } + + function GetCharSet() + { + return false; + } + + /** + * Usage: + * UpdateClob('TABLE', 'COLUMN', $var, 'ID=1', 'CLOB'); + * + * $conn->Execute('INSERT INTO clobtable (id, clobcol) VALUES (1, null)'); + * $conn->UpdateClob('clobtable','clobcol',$clob,'id=1'); + */ + function UpdateClob($table,$column,$val,$where) + { + return $this->UpdateBlob($table,$column,$val,$where,'CLOB'); + } + + // not the fastest implementation - quick and dirty - jlim + // for best performance, use the actual $rs->MetaType(). + function MetaType($t,$len=-1,$fieldobj=false) + { + + if (empty($this->_metars)) { + $rsclass = $this->rsPrefix.$this->databaseType; + $this->_metars = new $rsclass(false,$this->fetchMode); + $this->_metars->connection = $this; + } + return $this->_metars->MetaType($t,$len,$fieldobj); + } + + + /** + * Change the SQL connection locale to a specified locale. + * This is used to get the date formats written depending on the client locale. + */ + function SetDateLocale($locale = 'En') + { + $this->locale = $locale; + switch (strtoupper($locale)) + { + case 'EN': + $this->fmtDate="'Y-m-d'"; + $this->fmtTimeStamp = "'Y-m-d H:i:s'"; + break; + + case 'US': + $this->fmtDate = "'m-d-Y'"; + $this->fmtTimeStamp = "'m-d-Y H:i:s'"; + break; + + case 'PT_BR': + case 'NL': + case 'FR': + case 'RO': + case 'IT': + $this->fmtDate="'d-m-Y'"; + $this->fmtTimeStamp = "'d-m-Y H:i:s'"; + break; + + case 'GE': + $this->fmtDate="'d.m.Y'"; + $this->fmtTimeStamp = "'d.m.Y H:i:s'"; + break; + + default: + $this->fmtDate="'Y-m-d'"; + $this->fmtTimeStamp = "'Y-m-d H:i:s'"; + break; + } + } + + /** + * GetActiveRecordsClass Performs an 'ALL' query + * + * @param mixed $class This string represents the class of the current active record + * @param mixed $table Table used by the active record object + * @param mixed $whereOrderBy Where, order, by clauses + * @param mixed $bindarr + * @param mixed $primkeyArr + * @param array $extra Query extras: limit, offset... + * @param mixed $relations Associative array: table's foreign name, "hasMany", "belongsTo" + * @access public + * @return void + */ + function GetActiveRecordsClass( + $class, $table,$whereOrderBy=false,$bindarr=false, $primkeyArr=false, + $extra=array(), + $relations=array()) + { + global $_ADODB_ACTIVE_DBS; + ## reduce overhead of adodb.inc.php -- moved to adodb-active-record.inc.php + ## if adodb-active-recordx is loaded -- should be no issue as they will probably use Find() + if (!isset($_ADODB_ACTIVE_DBS))include_once(ADODB_DIR.'/adodb-active-record.inc.php'); + return adodb_GetActiveRecordsClass($this, $class, $table, $whereOrderBy, $bindarr, $primkeyArr, $extra, $relations); + } + + function GetActiveRecords($table,$where=false,$bindarr=false,$primkeyArr=false) + { + $arr = $this->GetActiveRecordsClass('ADODB_Active_Record', $table, $where, $bindarr, $primkeyArr); + return $arr; + } + + /** + * Close Connection + */ + function Close() + { + $rez = $this->_close(); + $this->_connectionID = false; + return $rez; + } + + /** + * Begin a Transaction. Must be followed by CommitTrans() or RollbackTrans(). + * + * @return true if succeeded or false if database does not support transactions + */ + function BeginTrans() + { + if ($this->debug) ADOConnection::outp("BeginTrans: Transactions not supported for this driver"); + return false; + } + + /* set transaction mode */ + function SetTransactionMode( $transaction_mode ) + { + $transaction_mode = $this->MetaTransaction($transaction_mode, $this->dataProvider); + $this->_transmode = $transaction_mode; + } +/* +http://msdn2.microsoft.com/en-US/ms173763.aspx +http://dev.mysql.com/doc/refman/5.0/en/innodb-transaction-isolation.html +http://www.postgresql.org/docs/8.1/interactive/sql-set-transaction.html +http://www.stanford.edu/dept/itss/docs/oracle/10g/server.101/b10759/statements_10005.htm +*/ + function MetaTransaction($mode,$db) + { + $mode = strtoupper($mode); + $mode = str_replace('ISOLATION LEVEL ','',$mode); + + switch($mode) { + + case 'READ UNCOMMITTED': + switch($db) { + case 'oci8': + case 'oracle': + return 'ISOLATION LEVEL READ COMMITTED'; + default: + return 'ISOLATION LEVEL READ UNCOMMITTED'; + } + break; + + case 'READ COMMITTED': + return 'ISOLATION LEVEL READ COMMITTED'; + break; + + case 'REPEATABLE READ': + switch($db) { + case 'oci8': + case 'oracle': + return 'ISOLATION LEVEL SERIALIZABLE'; + default: + return 'ISOLATION LEVEL REPEATABLE READ'; + } + break; + + case 'SERIALIZABLE': + return 'ISOLATION LEVEL SERIALIZABLE'; + break; + + default: + return $mode; + } + } + + /** + * If database does not support transactions, always return true as data always commited + * + * @param $ok set to false to rollback transaction, true to commit + * + * @return true/false. + */ + function CommitTrans($ok=true) + { return true;} + + + /** + * If database does not support transactions, rollbacks always fail, so return false + * + * @return true/false. + */ + function RollbackTrans() + { return false;} + + + /** + * return the databases that the driver can connect to. + * Some databases will return an empty array. + * + * @return an array of database names. + */ + function MetaDatabases() + { + global $ADODB_FETCH_MODE; + + if ($this->metaDatabasesSQL) { + $save = $ADODB_FETCH_MODE; + $ADODB_FETCH_MODE = ADODB_FETCH_NUM; + + if ($this->fetchMode !== false) $savem = $this->SetFetchMode(false); + + $arr = $this->GetCol($this->metaDatabasesSQL); + if (isset($savem)) $this->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + + return $arr; + } + + return false; + } + + + /** + * @param ttype can either be 'VIEW' or 'TABLE' or false. + * If false, both views and tables are returned. + * "VIEW" returns only views + * "TABLE" returns only tables + * @param showSchema returns the schema/user with the table name, eg. USER.TABLE + * @param mask is the input mask - only supported by oci8 and postgresql + * + * @return array of tables for current database. + */ + function MetaTables($ttype=false,$showSchema=false,$mask=false) + { + global $ADODB_FETCH_MODE; + + + $false = false; + if ($mask) { + return $false; + } + if ($this->metaTablesSQL) { + $save = $ADODB_FETCH_MODE; + $ADODB_FETCH_MODE = ADODB_FETCH_NUM; + + if ($this->fetchMode !== false) $savem = $this->SetFetchMode(false); + + $rs = $this->Execute($this->metaTablesSQL); + if (isset($savem)) $this->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + + if ($rs === false) return $false; + $arr = $rs->GetArray(); + $arr2 = array(); + + if ($hast = ($ttype && isset($arr[0][1]))) { + $showt = strncmp($ttype,'T',1); + } + + for ($i=0; $i < sizeof($arr); $i++) { + if ($hast) { + if ($showt == 0) { + if (strncmp($arr[$i][1],'T',1) == 0) $arr2[] = trim($arr[$i][0]); + } else { + if (strncmp($arr[$i][1],'V',1) == 0) $arr2[] = trim($arr[$i][0]); + } + } else + $arr2[] = trim($arr[$i][0]); + } + $rs->Close(); + return $arr2; + } + return $false; + } + + + function _findschema(&$table,&$schema) + { + if (!$schema && ($at = strpos($table,'.')) !== false) { + $schema = substr($table,0,$at); + $table = substr($table,$at+1); + } + } + + /** + * List columns in a database as an array of ADOFieldObjects. + * See top of file for definition of object. + * + * @param $table table name to query + * @param $normalize makes table name case-insensitive (required by some databases) + * @schema is optional database schema to use - not supported by all databases. + * + * @return array of ADOFieldObjects for current table. + */ + function MetaColumns($table,$normalize=true) + { + global $ADODB_FETCH_MODE; + + $false = false; + + if (!empty($this->metaColumnsSQL)) { + + $schema = false; + $this->_findschema($table,$schema); + + $save = $ADODB_FETCH_MODE; + $ADODB_FETCH_MODE = ADODB_FETCH_NUM; + if ($this->fetchMode !== false) $savem = $this->SetFetchMode(false); + $rs = $this->Execute(sprintf($this->metaColumnsSQL,($normalize)?strtoupper($table):$table)); + if (isset($savem)) $this->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + if ($rs === false || $rs->EOF) return $false; + + $retarr = array(); + while (!$rs->EOF) { //print_r($rs->fields); + $fld = new ADOFieldObject(); + $fld->name = $rs->fields[0]; + $fld->type = $rs->fields[1]; + if (isset($rs->fields[3]) && $rs->fields[3]) { + if ($rs->fields[3]>0) $fld->max_length = $rs->fields[3]; + $fld->scale = $rs->fields[4]; + if ($fld->scale>0) $fld->max_length += 1; + } else + $fld->max_length = $rs->fields[2]; + + if ($ADODB_FETCH_MODE == ADODB_FETCH_NUM) $retarr[] = $fld; + else $retarr[strtoupper($fld->name)] = $fld; + $rs->MoveNext(); + } + $rs->Close(); + return $retarr; + } + return $false; + } + + /** + * List indexes on a table as an array. + * @param table table name to query + * @param primary true to only show primary keys. Not actually used for most databases + * + * @return array of indexes on current table. Each element represents an index, and is itself an associative array. + + Array ( + [name_of_index] => Array + ( + [unique] => true or false + [columns] => Array + ( + [0] => firstname + [1] => lastname + ) + ) + */ + function MetaIndexes($table, $primary = false, $owner = false) + { + $false = false; + return $false; + } + + /** + * List columns names in a table as an array. + * @param table table name to query + * + * @return array of column names for current table. + */ + function MetaColumnNames($table, $numIndexes=false,$useattnum=false /* only for postgres */) + { + $objarr = $this->MetaColumns($table); + if (!is_array($objarr)) { + $false = false; + return $false; + } + $arr = array(); + if ($numIndexes) { + $i = 0; + if ($useattnum) { + foreach($objarr as $v) + $arr[$v->attnum] = $v->name; + + } else + foreach($objarr as $v) $arr[$i++] = $v->name; + } else + foreach($objarr as $v) $arr[strtoupper($v->name)] = $v->name; + + return $arr; + } + + /** + * Different SQL databases used different methods to combine strings together. + * This function provides a wrapper. + * + * param s variable number of string parameters + * + * Usage: $db->Concat($str1,$str2); + * + * @return concatenated string + */ + function Concat() + { + $arr = func_get_args(); + return implode($this->concat_operator, $arr); + } + + + /** + * Converts a date "d" to a string that the database can understand. + * + * @param d a date in Unix date time format. + * + * @return date string in database date format + */ + function DBDate($d, $isfld=false) + { + if (empty($d) && $d !== 0) return 'null'; + if ($isfld) return $d; + + if (is_object($d)) return $d->format($this->fmtDate); + + + if (is_string($d) && !is_numeric($d)) { + if ($d === 'null' || strncmp($d,"'",1) === 0) return $d; + if ($this->isoDates) return "'$d'"; + $d = ADOConnection::UnixDate($d); + } + + return adodb_date($this->fmtDate,$d); + } + + function BindDate($d) + { + $d = $this->DBDate($d); + if (strncmp($d,"'",1)) return $d; + + return substr($d,1,strlen($d)-2); + } + + function BindTimeStamp($d) + { + $d = $this->DBTimeStamp($d); + if (strncmp($d,"'",1)) return $d; + + return substr($d,1,strlen($d)-2); + } + + + /** + * Converts a timestamp "ts" to a string that the database can understand. + * + * @param ts a timestamp in Unix date time format. + * + * @return timestamp string in database timestamp format + */ + function DBTimeStamp($ts,$isfld=false) + { + if (empty($ts) && $ts !== 0) return 'null'; + if ($isfld) return $ts; + if (is_object($ts)) return $ts->format($this->fmtTimeStamp); + + # strlen(14) allows YYYYMMDDHHMMSS format + if (!is_string($ts) || (is_numeric($ts) && strlen($ts)<14)) + return adodb_date($this->fmtTimeStamp,$ts); + + if ($ts === 'null') return $ts; + if ($this->isoDates && strlen($ts) !== 14) return "'$ts'"; + + $ts = ADOConnection::UnixTimeStamp($ts); + return adodb_date($this->fmtTimeStamp,$ts); + } + + /** + * Also in ADORecordSet. + * @param $v is a date string in YYYY-MM-DD format + * + * @return date in unix timestamp format, or 0 if before TIMESTAMP_FIRST_YEAR, or false if invalid date format + */ + static function UnixDate($v) + { + if (is_object($v)) { + // odbtp support + //( [year] => 2004 [month] => 9 [day] => 4 [hour] => 12 [minute] => 44 [second] => 8 [fraction] => 0 ) + return adodb_mktime($v->hour,$v->minute,$v->second,$v->month,$v->day, $v->year); + } + + if (is_numeric($v) && strlen($v) !== 8) return $v; + if (!preg_match( "|^([0-9]{4})[-/\.]?([0-9]{1,2})[-/\.]?([0-9]{1,2})|", + ($v), $rr)) return false; + + if ($rr[1] <= TIMESTAMP_FIRST_YEAR) return 0; + // h-m-s-MM-DD-YY + return @adodb_mktime(0,0,0,$rr[2],$rr[3],$rr[1]); + } + + + /** + * Also in ADORecordSet. + * @param $v is a timestamp string in YYYY-MM-DD HH-NN-SS format + * + * @return date in unix timestamp format, or 0 if before TIMESTAMP_FIRST_YEAR, or false if invalid date format + */ + static function UnixTimeStamp($v) + { + if (is_object($v)) { + // odbtp support + //( [year] => 2004 [month] => 9 [day] => 4 [hour] => 12 [minute] => 44 [second] => 8 [fraction] => 0 ) + return adodb_mktime($v->hour,$v->minute,$v->second,$v->month,$v->day, $v->year); + } + + if (!preg_match( + "|^([0-9]{4})[-/\.]?([0-9]{1,2})[-/\.]?([0-9]{1,2})[ ,-]*(([0-9]{1,2}):?([0-9]{1,2}):?([0-9\.]{1,4}))?|", + ($v), $rr)) return false; + + if ($rr[1] <= TIMESTAMP_FIRST_YEAR && $rr[2]<= 1) return 0; + + // h-m-s-MM-DD-YY + if (!isset($rr[5])) return adodb_mktime(0,0,0,$rr[2],$rr[3],$rr[1]); + return @adodb_mktime($rr[5],$rr[6],$rr[7],$rr[2],$rr[3],$rr[1]); + } + + /** + * Also in ADORecordSet. + * + * Format database date based on user defined format. + * + * @param v is the character date in YYYY-MM-DD format, returned by database + * @param fmt is the format to apply to it, using date() + * + * @return a date formated as user desires + */ + + function UserDate($v,$fmt='Y-m-d',$gmt=false) + { + $tt = $this->UnixDate($v); + + // $tt == -1 if pre TIMESTAMP_FIRST_YEAR + if (($tt === false || $tt == -1) && $v != false) return $v; + else if ($tt == 0) return $this->emptyDate; + else if ($tt == -1) { // pre-TIMESTAMP_FIRST_YEAR + } + + return ($gmt) ? adodb_gmdate($fmt,$tt) : adodb_date($fmt,$tt); + + } + + /** + * + * @param v is the character timestamp in YYYY-MM-DD hh:mm:ss format + * @param fmt is the format to apply to it, using date() + * + * @return a timestamp formated as user desires + */ + function UserTimeStamp($v,$fmt='Y-m-d H:i:s',$gmt=false) + { + if (!isset($v)) return $this->emptyTimeStamp; + # strlen(14) allows YYYYMMDDHHMMSS format + if (is_numeric($v) && strlen($v)<14) return ($gmt) ? adodb_gmdate($fmt,$v) : adodb_date($fmt,$v); + $tt = $this->UnixTimeStamp($v); + // $tt == -1 if pre TIMESTAMP_FIRST_YEAR + if (($tt === false || $tt == -1) && $v != false) return $v; + if ($tt == 0) return $this->emptyTimeStamp; + return ($gmt) ? adodb_gmdate($fmt,$tt) : adodb_date($fmt,$tt); + } + + function escape($s,$magic_quotes=false) + { + return $this->addq($s,$magic_quotes); + } + + /** + * Quotes a string, without prefixing nor appending quotes. + */ + function addq($s,$magic_quotes=false) + { + if (!$magic_quotes) { + + if ($this->replaceQuote[0] == '\\'){ + // only since php 4.0.5 + $s = adodb_str_replace(array('\\',"\0"),array('\\\\',"\\\0"),$s); + //$s = str_replace("\0","\\\0", str_replace('\\','\\\\',$s)); + } + return str_replace("'",$this->replaceQuote,$s); + } + + // undo magic quotes for " + $s = str_replace('\\"','"',$s); + + if ($this->replaceQuote == "\\'" || ini_get('magic_quotes_sybase')) // ' already quoted, no need to change anything + return $s; + else {// change \' to '' for sybase/mssql + $s = str_replace('\\\\','\\',$s); + return str_replace("\\'",$this->replaceQuote,$s); + } + } + + /** + * Correctly quotes a string so that all strings are escaped. We prefix and append + * to the string single-quotes. + * An example is $db->qstr("Don't bother",magic_quotes_runtime()); + * + * @param s the string to quote + * @param [magic_quotes] if $s is GET/POST var, set to get_magic_quotes_gpc(). + * This undoes the stupidity of magic quotes for GPC. + * + * @return quoted string to be sent back to database + */ + function qstr($s,$magic_quotes=false) + { + if (!$magic_quotes) { + + if ($this->replaceQuote[0] == '\\'){ + // only since php 4.0.5 + $s = adodb_str_replace(array('\\',"\0"),array('\\\\',"\\\0"),$s); + //$s = str_replace("\0","\\\0", str_replace('\\','\\\\',$s)); + } + return "'".str_replace("'",$this->replaceQuote,$s)."'"; + } + + // undo magic quotes for " + $s = str_replace('\\"','"',$s); + + if ($this->replaceQuote == "\\'" || ini_get('magic_quotes_sybase')) // ' already quoted, no need to change anything + return "'$s'"; + else {// change \' to '' for sybase/mssql + $s = str_replace('\\\\','\\',$s); + return "'".str_replace("\\'",$this->replaceQuote,$s)."'"; + } + } + + + /** + * Will select the supplied $page number from a recordset, given that it is paginated in pages of + * $nrows rows per page. It also saves two boolean values saying if the given page is the first + * and/or last one of the recordset. Added by Iván Oliva to provide recordset pagination. + * + * See readme.htm#ex8 for an example of usage. + * + * @param sql + * @param nrows is the number of rows per page to get + * @param page is the page number to get (1-based) + * @param [inputarr] array of bind variables + * @param [secs2cache] is a private parameter only used by jlim + * @return the recordset ($rs->databaseType == 'array') + * + * NOTE: phpLens uses a different algorithm and does not use PageExecute(). + * + */ + function PageExecute($sql, $nrows, $page, $inputarr=false, $secs2cache=0) + { + global $ADODB_INCLUDED_LIB; + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + if ($this->pageExecuteCountRows) $rs = _adodb_pageexecute_all_rows($this, $sql, $nrows, $page, $inputarr, $secs2cache); + else $rs = _adodb_pageexecute_no_last_page($this, $sql, $nrows, $page, $inputarr, $secs2cache); + return $rs; + } + + + /** + * Will select the supplied $page number from a recordset, given that it is paginated in pages of + * $nrows rows per page. It also saves two boolean values saying if the given page is the first + * and/or last one of the recordset. Added by Iván Oliva to provide recordset pagination. + * + * @param secs2cache seconds to cache data, set to 0 to force query + * @param sql + * @param nrows is the number of rows per page to get + * @param page is the page number to get (1-based) + * @param [inputarr] array of bind variables + * @return the recordset ($rs->databaseType == 'array') + */ + function CachePageExecute($secs2cache, $sql, $nrows, $page,$inputarr=false) + { + /*switch($this->dataProvider) { + case 'postgres': + case 'mysql': + break; + default: $secs2cache = 0; break; + }*/ + $rs = $this->PageExecute($sql,$nrows,$page,$inputarr,$secs2cache); + return $rs; + } + +} // end class ADOConnection + + + + //============================================================================================== + // CLASS ADOFetchObj + //============================================================================================== + + /** + * Internal placeholder for record objects. Used by ADORecordSet->FetchObj(). + */ + class ADOFetchObj { + }; + + //============================================================================================== + // CLASS ADORecordSet_empty + //============================================================================================== + + class ADODB_Iterator_empty implements Iterator { + + private $rs; + + function __construct($rs) + { + $this->rs = $rs; + } + function rewind() + { + } + + function valid() + { + return !$this->rs->EOF; + } + + function key() + { + return false; + } + + function current() + { + return false; + } + + function next() + { + } + + function __call($func, $params) + { + return call_user_func_array(array($this->rs, $func), $params); + } + + function hasMore() + { + return false; + } + + } + + + /** + * Lightweight recordset when there are no records to be returned + */ + class ADORecordSet_empty implements IteratorAggregate + { + var $dataProvider = 'empty'; + var $databaseType = false; + var $EOF = true; + var $_numOfRows = 0; + var $fields = false; + var $connection = false; + function RowCount() {return 0;} + function RecordCount() {return 0;} + function PO_RecordCount(){return 0;} + function Close(){return true;} + function FetchRow() {return false;} + function FieldCount(){ return 0;} + function Init() {} + function getIterator() {return new ADODB_Iterator_empty($this);} + } + + //============================================================================================== + // DATE AND TIME FUNCTIONS + //============================================================================================== + if (!defined('ADODB_DATE_VERSION')) include(ADODB_DIR.'/adodb-time.inc.php'); + + //============================================================================================== + // CLASS ADORecordSet + //============================================================================================== + + class ADODB_Iterator implements Iterator { + + private $rs; + + function __construct($rs) + { + $this->rs = $rs; + } + function rewind() + { + $this->rs->MoveFirst(); + } + + function valid() + { + return !$this->rs->EOF; + } + + function key() + { + return $this->rs->_currentRow; + } + + function current() + { + return $this->rs->fields; + } + + function next() + { + $this->rs->MoveNext(); + } + + function __call($func, $params) + { + return call_user_func_array(array($this->rs, $func), $params); + } + + + function hasMore() + { + return !$this->rs->EOF; + } + + } + + + + /** + * RecordSet class that represents the dataset returned by the database. + * To keep memory overhead low, this class holds only the current row in memory. + * No prefetching of data is done, so the RecordCount() can return -1 ( which + * means recordcount not known). + */ + class ADORecordSet implements IteratorAggregate { + /* + * public variables + */ + var $dataProvider = "native"; + var $fields = false; /// holds the current row data + var $blobSize = 100; /// any varchar/char field this size or greater is treated as a blob + /// in other words, we use a text area for editing. + var $canSeek = false; /// indicates that seek is supported + var $sql; /// sql text + var $EOF = false; /// Indicates that the current record position is after the last record in a Recordset object. + + var $emptyTimeStamp = ' '; /// what to display when $time==0 + var $emptyDate = ' '; /// what to display when $time==0 + var $debug = false; + var $timeCreated=0; /// datetime in Unix format rs created -- for cached recordsets + + var $bind = false; /// used by Fields() to hold array - should be private? + var $fetchMode; /// default fetch mode + var $connection = false; /// the parent connection + /* + * private variables + */ + var $_numOfRows = -1; /** number of rows, or -1 */ + var $_numOfFields = -1; /** number of fields in recordset */ + var $_queryID = -1; /** This variable keeps the result link identifier. */ + var $_currentRow = -1; /** This variable keeps the current row in the Recordset. */ + var $_closed = false; /** has recordset been closed */ + var $_inited = false; /** Init() should only be called once */ + var $_obj; /** Used by FetchObj */ + var $_names; /** Used by FetchObj */ + + var $_currentPage = -1; /** Added by Iván Oliva to implement recordset pagination */ + var $_atFirstPage = false; /** Added by Iván Oliva to implement recordset pagination */ + var $_atLastPage = false; /** Added by Iván Oliva to implement recordset pagination */ + var $_lastPageNo = -1; + var $_maxRecordCount = 0; + var $datetime = false; + + /** + * Constructor + * + * @param queryID this is the queryID returned by ADOConnection->_query() + * + */ + function ADORecordSet($queryID) + { + $this->_queryID = $queryID; + } + + function getIterator() + { + return new ADODB_Iterator($this); + } + + /* this is experimental - i don't really know what to return... */ + function __toString() + { + include_once(ADODB_DIR.'/toexport.inc.php'); + return _adodb_export($this,',',',',false,true); + } + + + function Init() + { + if ($this->_inited) return; + $this->_inited = true; + if ($this->_queryID) @$this->_initrs(); + else { + $this->_numOfRows = 0; + $this->_numOfFields = 0; + } + if ($this->_numOfRows != 0 && $this->_numOfFields && $this->_currentRow == -1) { + + $this->_currentRow = 0; + if ($this->EOF = ($this->_fetch() === false)) { + $this->_numOfRows = 0; // _numOfRows could be -1 + } + } else { + $this->EOF = true; + } + } + + + /** + * Generate a SELECT tag string from a recordset, and return the string. + * If the recordset has 2 cols, we treat the 1st col as the containing + * the text to display to the user, and 2nd col as the return value. Default + * strings are compared with the FIRST column. + * + * @param name name of SELECT tag + * @param [defstr] the value to hilite. Use an array for multiple hilites for listbox. + * @param [blank1stItem] true to leave the 1st item in list empty + * @param [multiple] true for listbox, false for popup + * @param [size] #rows to show for listbox. not used by popup + * @param [selectAttr] additional attributes to defined for SELECT tag. + * useful for holding javascript onChange='...' handlers. + & @param [compareFields0] when we have 2 cols in recordset, we compare the defstr with + * column 0 (1st col) if this is true. This is not documented. + * + * @return HTML + * + * changes by glen.davies@cce.ac.nz to support multiple hilited items + */ + function GetMenu($name,$defstr='',$blank1stItem=true,$multiple=false, + $size=0, $selectAttr='',$compareFields0=true) + { + global $ADODB_INCLUDED_LIB; + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + return _adodb_getmenu($this, $name,$defstr,$blank1stItem,$multiple, + $size, $selectAttr,$compareFields0); + } + + + + /** + * Generate a SELECT tag string from a recordset, and return the string. + * If the recordset has 2 cols, we treat the 1st col as the containing + * the text to display to the user, and 2nd col as the return value. Default + * strings are compared with the SECOND column. + * + */ + function GetMenu2($name,$defstr='',$blank1stItem=true,$multiple=false,$size=0, $selectAttr='') + { + return $this->GetMenu($name,$defstr,$blank1stItem,$multiple, + $size, $selectAttr,false); + } + + /* + Grouped Menu + */ + function GetMenu3($name,$defstr='',$blank1stItem=true,$multiple=false, + $size=0, $selectAttr='') + { + global $ADODB_INCLUDED_LIB; + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + return _adodb_getmenu_gp($this, $name,$defstr,$blank1stItem,$multiple, + $size, $selectAttr,false); + } + + /** + * return recordset as a 2-dimensional array. + * + * @param [nRows] is the number of rows to return. -1 means every row. + * + * @return an array indexed by the rows (0-based) from the recordset + */ + function GetArray($nRows = -1) + { + global $ADODB_EXTENSION; if ($ADODB_EXTENSION) { + $results = adodb_getall($this,$nRows); + return $results; + } + $results = array(); + $cnt = 0; + while (!$this->EOF && $nRows != $cnt) { + $results[] = $this->fields; + $this->MoveNext(); + $cnt++; + } + return $results; + } + + function GetAll($nRows = -1) + { + $arr = $this->GetArray($nRows); + return $arr; + } + + /* + * Some databases allow multiple recordsets to be returned. This function + * will return true if there is a next recordset, or false if no more. + */ + function NextRecordSet() + { + return false; + } + + /** + * return recordset as a 2-dimensional array. + * Helper function for ADOConnection->SelectLimit() + * + * @param offset is the row to start calculations from (1-based) + * @param [nrows] is the number of rows to return + * + * @return an array indexed by the rows (0-based) from the recordset + */ + function GetArrayLimit($nrows,$offset=-1) + { + if ($offset <= 0) { + $arr = $this->GetArray($nrows); + return $arr; + } + + $this->Move($offset); + + $results = array(); + $cnt = 0; + while (!$this->EOF && $nrows != $cnt) { + $results[$cnt++] = $this->fields; + $this->MoveNext(); + } + + return $results; + } + + + /** + * Synonym for GetArray() for compatibility with ADO. + * + * @param [nRows] is the number of rows to return. -1 means every row. + * + * @return an array indexed by the rows (0-based) from the recordset + */ + function GetRows($nRows = -1) + { + $arr = $this->GetArray($nRows); + return $arr; + } + + /** + * return whole recordset as a 2-dimensional associative array if there are more than 2 columns. + * The first column is treated as the key and is not included in the array. + * If there is only 2 columns, it will return a 1 dimensional array of key-value pairs unless + * $force_array == true. + * + * @param [force_array] has only meaning if we have 2 data columns. If false, a 1 dimensional + * array is returned, otherwise a 2 dimensional array is returned. If this sounds confusing, + * read the source. + * + * @param [first2cols] means if there are more than 2 cols, ignore the remaining cols and + * instead of returning array[col0] => array(remaining cols), return array[col0] => col1 + * + * @return an associative array indexed by the first column of the array, + * or false if the data has less than 2 cols. + */ + function GetAssoc($force_array = false, $first2cols = false) + { + global $ADODB_EXTENSION; + + $cols = $this->_numOfFields; + if ($cols < 2) { + $false = false; + return $false; + } + $numIndex = isset($this->fields[0]); + $results = array(); + + if (!$first2cols && ($cols > 2 || $force_array)) { + if ($ADODB_EXTENSION) { + if ($numIndex) { + while (!$this->EOF) { + $results[trim($this->fields[0])] = array_slice($this->fields, 1); + adodb_movenext($this); + } + } else { + while (!$this->EOF) { + // Fix for array_slice re-numbering numeric associative keys + $keys = array_slice(array_keys($this->fields), 1); + $sliced_array = array(); + + foreach($keys as $key) { + $sliced_array[$key] = $this->fields[$key]; + } + + $results[trim(reset($this->fields))] = $sliced_array; + adodb_movenext($this); + } + } + } else { + if ($numIndex) { + while (!$this->EOF) { + $results[trim($this->fields[0])] = array_slice($this->fields, 1); + $this->MoveNext(); + } + } else { + while (!$this->EOF) { + // Fix for array_slice re-numbering numeric associative keys + $keys = array_slice(array_keys($this->fields), 1); + $sliced_array = array(); + + foreach($keys as $key) { + $sliced_array[$key] = $this->fields[$key]; + } + + $results[trim(reset($this->fields))] = $sliced_array; + $this->MoveNext(); + } + } + } + } else { + if ($ADODB_EXTENSION) { + // return scalar values + if ($numIndex) { + while (!$this->EOF) { + // some bug in mssql PHP 4.02 -- doesn't handle references properly so we FORCE creating a new string + $results[trim(($this->fields[0]))] = $this->fields[1]; + adodb_movenext($this); + } + } else { + while (!$this->EOF) { + // some bug in mssql PHP 4.02 -- doesn't handle references properly so we FORCE creating a new string + $v1 = trim(reset($this->fields)); + $v2 = ''.next($this->fields); + $results[$v1] = $v2; + adodb_movenext($this); + } + } + } else { + if ($numIndex) { + while (!$this->EOF) { + // some bug in mssql PHP 4.02 -- doesn't handle references properly so we FORCE creating a new string + $results[trim(($this->fields[0]))] = $this->fields[1]; + $this->MoveNext(); + } + } else { + while (!$this->EOF) { + // some bug in mssql PHP 4.02 -- doesn't handle references properly so we FORCE creating a new string + $v1 = trim(reset($this->fields)); + $v2 = ''.next($this->fields); + $results[$v1] = $v2; + $this->MoveNext(); + } + } + } + } + + $ref = $results; # workaround accelerator incompat with PHP 4.4 :( + return $ref; + } + + + /** + * + * @param v is the character timestamp in YYYY-MM-DD hh:mm:ss format + * @param fmt is the format to apply to it, using date() + * + * @return a timestamp formated as user desires + */ + function UserTimeStamp($v,$fmt='Y-m-d H:i:s') + { + if (is_numeric($v) && strlen($v)<14) return adodb_date($fmt,$v); + $tt = $this->UnixTimeStamp($v); + // $tt == -1 if pre TIMESTAMP_FIRST_YEAR + if (($tt === false || $tt == -1) && $v != false) return $v; + if ($tt === 0) return $this->emptyTimeStamp; + return adodb_date($fmt,$tt); + } + + + /** + * @param v is the character date in YYYY-MM-DD format, returned by database + * @param fmt is the format to apply to it, using date() + * + * @return a date formated as user desires + */ + function UserDate($v,$fmt='Y-m-d') + { + $tt = $this->UnixDate($v); + // $tt == -1 if pre TIMESTAMP_FIRST_YEAR + if (($tt === false || $tt == -1) && $v != false) return $v; + else if ($tt == 0) return $this->emptyDate; + else if ($tt == -1) { // pre-TIMESTAMP_FIRST_YEAR + } + return adodb_date($fmt,$tt); + } + + + /** + * @param $v is a date string in YYYY-MM-DD format + * + * @return date in unix timestamp format, or 0 if before TIMESTAMP_FIRST_YEAR, or false if invalid date format + */ + static function UnixDate($v) + { + return ADOConnection::UnixDate($v); + } + + + /** + * @param $v is a timestamp string in YYYY-MM-DD HH-NN-SS format + * + * @return date in unix timestamp format, or 0 if before TIMESTAMP_FIRST_YEAR, or false if invalid date format + */ + static function UnixTimeStamp($v) + { + return ADOConnection::UnixTimeStamp($v); + } + + + /** + * PEAR DB Compat - do not use internally + */ + function Free() + { + return $this->Close(); + } + + + /** + * PEAR DB compat, number of rows + */ + function NumRows() + { + return $this->_numOfRows; + } + + + /** + * PEAR DB compat, number of cols + */ + function NumCols() + { + return $this->_numOfFields; + } + + /** + * Fetch a row, returning false if no more rows. + * This is PEAR DB compat mode. + * + * @return false or array containing the current record + */ + function FetchRow() + { + if ($this->EOF) { + $false = false; + return $false; + } + $arr = $this->fields; + $this->_currentRow++; + if (!$this->_fetch()) $this->EOF = true; + return $arr; + } + + + /** + * Fetch a row, returning PEAR_Error if no more rows. + * This is PEAR DB compat mode. + * + * @return DB_OK or error object + */ + function FetchInto(&$arr) + { + if ($this->EOF) return (defined('PEAR_ERROR_RETURN')) ? new PEAR_Error('EOF',-1): false; + $arr = $this->fields; + $this->MoveNext(); + return 1; // DB_OK + } + + + /** + * Move to the first row in the recordset. Many databases do NOT support this. + * + * @return true or false + */ + function MoveFirst() + { + if ($this->_currentRow == 0) return true; + return $this->Move(0); + } + + + /** + * Move to the last row in the recordset. + * + * @return true or false + */ + function MoveLast() + { + if ($this->_numOfRows >= 0) return $this->Move($this->_numOfRows-1); + if ($this->EOF) return false; + while (!$this->EOF) { + $f = $this->fields; + $this->MoveNext(); + } + $this->fields = $f; + $this->EOF = false; + return true; + } + + + /** + * Move to next record in the recordset. + * + * @return true if there still rows available, or false if there are no more rows (EOF). + */ + function MoveNext() + { + if (!$this->EOF) { + $this->_currentRow++; + if ($this->_fetch()) return true; + } + $this->EOF = true; + /* -- tested error handling when scrolling cursor -- seems useless. + $conn = $this->connection; + if ($conn && $conn->raiseErrorFn && ($errno = $conn->ErrorNo())) { + $fn = $conn->raiseErrorFn; + $fn($conn->databaseType,'MOVENEXT',$errno,$conn->ErrorMsg().' ('.$this->sql.')',$conn->host,$conn->database); + } + */ + return false; + } + + + /** + * Random access to a specific row in the recordset. Some databases do not support + * access to previous rows in the databases (no scrolling backwards). + * + * @param rowNumber is the row to move to (0-based) + * + * @return true if there still rows available, or false if there are no more rows (EOF). + */ + function Move($rowNumber = 0) + { + $this->EOF = false; + if ($rowNumber == $this->_currentRow) return true; + if ($rowNumber >= $this->_numOfRows) + if ($this->_numOfRows != -1) $rowNumber = $this->_numOfRows-2; + + if ($this->canSeek) { + + if ($this->_seek($rowNumber)) { + $this->_currentRow = $rowNumber; + if ($this->_fetch()) { + return true; + } + } else { + $this->EOF = true; + return false; + } + } else { + if ($rowNumber < $this->_currentRow) return false; + global $ADODB_EXTENSION; + if ($ADODB_EXTENSION) { + while (!$this->EOF && $this->_currentRow < $rowNumber) { + adodb_movenext($this); + } + } else { + + while (! $this->EOF && $this->_currentRow < $rowNumber) { + $this->_currentRow++; + + if (!$this->_fetch()) $this->EOF = true; + } + } + return !($this->EOF); + } + + $this->fields = false; + $this->EOF = true; + return false; + } + + + /** + * Get the value of a field in the current row by column name. + * Will not work if ADODB_FETCH_MODE is set to ADODB_FETCH_NUM. + * + * @param colname is the field to access + * + * @return the value of $colname column + */ + function Fields($colname) + { + return $this->fields[$colname]; + } + + function GetAssocKeys($upper=true) + { + $this->bind = array(); + for ($i=0; $i < $this->_numOfFields; $i++) { + $o = $this->FetchField($i); + if ($upper === 2) $this->bind[$o->name] = $i; + else $this->bind[($upper) ? strtoupper($o->name) : strtolower($o->name)] = $i; + } + } + + /** + * Use associative array to get fields array for databases that do not support + * associative arrays. Submitted by Paolo S. Asioli paolo.asioli#libero.it + * + * If you don't want uppercase cols, set $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC + * before you execute your SQL statement, and access $rs->fields['col'] directly. + * + * $upper 0 = lowercase, 1 = uppercase, 2 = whatever is returned by FetchField + */ + function GetRowAssoc($upper=1) + { + $record = array(); + // if (!$this->fields) return $record; + + if (!$this->bind) { + $this->GetAssocKeys($upper); + } + + foreach($this->bind as $k => $v) { + $record[$k] = $this->fields[$v]; + } + + return $record; + } + + + /** + * Clean up recordset + * + * @return true or false + */ + function Close() + { + // free connection object - this seems to globally free the object + // and not merely the reference, so don't do this... + // $this->connection = false; + if (!$this->_closed) { + $this->_closed = true; + return $this->_close(); + } else + return true; + } + + /** + * synonyms RecordCount and RowCount + * + * @return the number of rows or -1 if this is not supported + */ + function RecordCount() {return $this->_numOfRows;} + + + /* + * If we are using PageExecute(), this will return the maximum possible rows + * that can be returned when paging a recordset. + */ + function MaxRecordCount() + { + return ($this->_maxRecordCount) ? $this->_maxRecordCount : $this->RecordCount(); + } + + /** + * synonyms RecordCount and RowCount + * + * @return the number of rows or -1 if this is not supported + */ + function RowCount() {return $this->_numOfRows;} + + + /** + * Portable RecordCount. Pablo Roca + * + * @return the number of records from a previous SELECT. All databases support this. + * + * But aware possible problems in multiuser environments. For better speed the table + * must be indexed by the condition. Heavy test this before deploying. + */ + function PO_RecordCount($table="", $condition="") { + + $lnumrows = $this->_numOfRows; + // the database doesn't support native recordcount, so we do a workaround + if ($lnumrows == -1 && $this->connection) { + IF ($table) { + if ($condition) $condition = " WHERE " . $condition; + $resultrows = $this->connection->Execute("SELECT COUNT(*) FROM $table $condition"); + if ($resultrows) $lnumrows = reset($resultrows->fields); + } + } + return $lnumrows; + } + + + /** + * @return the current row in the recordset. If at EOF, will return the last row. 0-based. + */ + function CurrentRow() {return $this->_currentRow;} + + /** + * synonym for CurrentRow -- for ADO compat + * + * @return the current row in the recordset. If at EOF, will return the last row. 0-based. + */ + function AbsolutePosition() {return $this->_currentRow;} + + /** + * @return the number of columns in the recordset. Some databases will set this to 0 + * if no records are returned, others will return the number of columns in the query. + */ + function FieldCount() {return $this->_numOfFields;} + + + /** + * Get the ADOFieldObject of a specific column. + * + * @param fieldoffset is the column position to access(0-based). + * + * @return the ADOFieldObject for that column, or false. + */ + function FetchField($fieldoffset = -1) + { + // must be defined by child class + + $false = false; + return $false; + } + + /** + * Get the ADOFieldObjects of all columns in an array. + * + */ + function FieldTypesArray() + { + $arr = array(); + for ($i=0, $max=$this->_numOfFields; $i < $max; $i++) + $arr[] = $this->FetchField($i); + return $arr; + } + + /** + * Return the fields array of the current row as an object for convenience. + * The default case is lowercase field names. + * + * @return the object with the properties set to the fields of the current row + */ + function FetchObj() + { + $o = $this->FetchObject(false); + return $o; + } + + /** + * Return the fields array of the current row as an object for convenience. + * The default case is uppercase. + * + * @param $isupper to set the object property names to uppercase + * + * @return the object with the properties set to the fields of the current row + */ + function FetchObject($isupper=true) + { + if (empty($this->_obj)) { + $this->_obj = new ADOFetchObj(); + $this->_names = array(); + for ($i=0; $i <$this->_numOfFields; $i++) { + $f = $this->FetchField($i); + $this->_names[] = $f->name; + } + } + $i = 0; + if (PHP_VERSION >= 5) $o = clone($this->_obj); + else $o = $this->_obj; + + for ($i=0; $i <$this->_numOfFields; $i++) { + $name = $this->_names[$i]; + if ($isupper) $n = strtoupper($name); + else $n = $name; + + $o->$n = $this->Fields($name); + } + return $o; + } + + /** + * Return the fields array of the current row as an object for convenience. + * The default is lower-case field names. + * + * @return the object with the properties set to the fields of the current row, + * or false if EOF + * + * Fixed bug reported by tim@orotech.net + */ + function FetchNextObj() + { + $o = $this->FetchNextObject(false); + return $o; + } + + + /** + * Return the fields array of the current row as an object for convenience. + * The default is upper case field names. + * + * @param $isupper to set the object property names to uppercase + * + * @return the object with the properties set to the fields of the current row, + * or false if EOF + * + * Fixed bug reported by tim@orotech.net + */ + function FetchNextObject($isupper=true) + { + $o = false; + if ($this->_numOfRows != 0 && !$this->EOF) { + $o = $this->FetchObject($isupper); + $this->_currentRow++; + if ($this->_fetch()) return $o; + } + $this->EOF = true; + return $o; + } + + /** + * Get the metatype of the column. This is used for formatting. This is because + * many databases use different names for the same type, so we transform the original + * type to our standardised version which uses 1 character codes: + * + * @param t is the type passed in. Normally is ADOFieldObject->type. + * @param len is the maximum length of that field. This is because we treat character + * fields bigger than a certain size as a 'B' (blob). + * @param fieldobj is the field object returned by the database driver. Can hold + * additional info (eg. primary_key for mysql). + * + * @return the general type of the data: + * C for character < 250 chars + * X for teXt (>= 250 chars) + * B for Binary + * N for numeric or floating point + * D for date + * T for timestamp + * L for logical/Boolean + * I for integer + * R for autoincrement counter/integer + * + * + */ + function MetaType($t,$len=-1,$fieldobj=false) + { + if (is_object($t)) { + $fieldobj = $t; + $t = $fieldobj->type; + $len = $fieldobj->max_length; + } + // changed in 2.32 to hashing instead of switch stmt for speed... + static $typeMap = array( + 'VARCHAR' => 'C', + 'VARCHAR2' => 'C', + 'CHAR' => 'C', + 'C' => 'C', + 'STRING' => 'C', + 'NCHAR' => 'C', + 'NVARCHAR' => 'C', + 'VARYING' => 'C', + 'BPCHAR' => 'C', + 'CHARACTER' => 'C', + 'INTERVAL' => 'C', # Postgres + 'MACADDR' => 'C', # postgres + 'VAR_STRING' => 'C', # mysql + ## + 'LONGCHAR' => 'X', + 'TEXT' => 'X', + 'NTEXT' => 'X', + 'M' => 'X', + 'X' => 'X', + 'CLOB' => 'X', + 'NCLOB' => 'X', + 'LVARCHAR' => 'X', + ## + 'BLOB' => 'B', + 'IMAGE' => 'B', + 'BINARY' => 'B', + 'VARBINARY' => 'B', + 'LONGBINARY' => 'B', + 'B' => 'B', + ## + 'YEAR' => 'D', // mysql + 'DATE' => 'D', + 'D' => 'D', + ## + 'UNIQUEIDENTIFIER' => 'C', # MS SQL Server + ## + 'SMALLDATETIME' => 'T', + 'TIME' => 'T', + 'TIMESTAMP' => 'T', + 'DATETIME' => 'T', + 'TIMESTAMPTZ' => 'T', + 'T' => 'T', + 'TIMESTAMP WITHOUT TIME ZONE' => 'T', // postgresql + ## + 'BOOL' => 'L', + 'BOOLEAN' => 'L', + 'BIT' => 'L', + 'L' => 'L', + ## + 'COUNTER' => 'R', + 'R' => 'R', + 'SERIAL' => 'R', // ifx + 'INT IDENTITY' => 'R', + ## + 'INT' => 'I', + 'INT2' => 'I', + 'INT4' => 'I', + 'INT8' => 'I', + 'INTEGER' => 'I', + 'INTEGER UNSIGNED' => 'I', + 'SHORT' => 'I', + 'TINYINT' => 'I', + 'SMALLINT' => 'I', + 'I' => 'I', + ## + 'LONG' => 'N', // interbase is numeric, oci8 is blob + 'BIGINT' => 'N', // this is bigger than PHP 32-bit integers + 'DECIMAL' => 'N', + 'DEC' => 'N', + 'REAL' => 'N', + 'DOUBLE' => 'N', + 'DOUBLE PRECISION' => 'N', + 'SMALLFLOAT' => 'N', + 'FLOAT' => 'N', + 'NUMBER' => 'N', + 'NUM' => 'N', + 'NUMERIC' => 'N', + 'MONEY' => 'N', + + ## informix 9.2 + 'SQLINT' => 'I', + 'SQLSERIAL' => 'I', + 'SQLSMINT' => 'I', + 'SQLSMFLOAT' => 'N', + 'SQLFLOAT' => 'N', + 'SQLMONEY' => 'N', + 'SQLDECIMAL' => 'N', + 'SQLDATE' => 'D', + 'SQLVCHAR' => 'C', + 'SQLCHAR' => 'C', + 'SQLDTIME' => 'T', + 'SQLINTERVAL' => 'N', + 'SQLBYTES' => 'B', + 'SQLTEXT' => 'X', + ## informix 10 + "SQLINT8" => 'I8', + "SQLSERIAL8" => 'I8', + "SQLNCHAR" => 'C', + "SQLNVCHAR" => 'C', + "SQLLVARCHAR" => 'X', + "SQLBOOL" => 'L' + ); + + $tmap = false; + $t = strtoupper($t); + $tmap = (isset($typeMap[$t])) ? $typeMap[$t] : 'N'; + switch ($tmap) { + case 'C': + + // is the char field is too long, return as text field... + if ($this->blobSize >= 0) { + if ($len > $this->blobSize) return 'X'; + } else if ($len > 250) { + return 'X'; + } + return 'C'; + + case 'I': + if (!empty($fieldobj->primary_key)) return 'R'; + return 'I'; + + case false: + return 'N'; + + case 'B': + if (isset($fieldobj->binary)) + return ($fieldobj->binary) ? 'B' : 'X'; + return 'B'; + + case 'D': + if (!empty($this->connection) && !empty($this->connection->datetime)) return 'T'; + return 'D'; + + default: + if ($t == 'LONG' && $this->dataProvider == 'oci8') return 'B'; + return $tmap; + } + } + + + function _close() {} + + /** + * set/returns the current recordset page when paginating + */ + function AbsolutePage($page=-1) + { + if ($page != -1) $this->_currentPage = $page; + return $this->_currentPage; + } + + /** + * set/returns the status of the atFirstPage flag when paginating + */ + function AtFirstPage($status=false) + { + if ($status != false) $this->_atFirstPage = $status; + return $this->_atFirstPage; + } + + function LastPageNo($page = false) + { + if ($page != false) $this->_lastPageNo = $page; + return $this->_lastPageNo; + } + + /** + * set/returns the status of the atLastPage flag when paginating + */ + function AtLastPage($status=false) + { + if ($status != false) $this->_atLastPage = $status; + return $this->_atLastPage; + } + +} // end class ADORecordSet + + //============================================================================================== + // CLASS ADORecordSet_array + //============================================================================================== + + /** + * This class encapsulates the concept of a recordset created in memory + * as an array. This is useful for the creation of cached recordsets. + * + * Note that the constructor is different from the standard ADORecordSet + */ + + class ADORecordSet_array extends ADORecordSet + { + var $databaseType = 'array'; + + var $_array; // holds the 2-dimensional data array + var $_types; // the array of types of each column (C B I L M) + var $_colnames; // names of each column in array + var $_skiprow1; // skip 1st row because it holds column names + var $_fieldobjects; // holds array of field objects + var $canSeek = true; + var $affectedrows = false; + var $insertid = false; + var $sql = ''; + var $compat = false; + /** + * Constructor + * + */ + function ADORecordSet_array($fakeid=1) + { + global $ADODB_FETCH_MODE,$ADODB_COMPAT_FETCH; + + // fetch() on EOF does not delete $this->fields + $this->compat = !empty($ADODB_COMPAT_FETCH); + $this->ADORecordSet($fakeid); // fake queryID + $this->fetchMode = $ADODB_FETCH_MODE; + } + + function _transpose($addfieldnames=true) + { + global $ADODB_INCLUDED_LIB; + + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + $hdr = true; + + $fobjs = $addfieldnames ? $this->_fieldobjects : false; + adodb_transpose($this->_array, $newarr, $hdr, $fobjs); + //adodb_pr($newarr); + + $this->_skiprow1 = false; + $this->_array = $newarr; + $this->_colnames = $hdr; + + adodb_probetypes($newarr,$this->_types); + + $this->_fieldobjects = array(); + + foreach($hdr as $k => $name) { + $f = new ADOFieldObject(); + $f->name = $name; + $f->type = $this->_types[$k]; + $f->max_length = -1; + $this->_fieldobjects[] = $f; + } + $this->fields = reset($this->_array); + + $this->_initrs(); + + } + + /** + * Setup the array. + * + * @param array is a 2-dimensional array holding the data. + * The first row should hold the column names + * unless paramter $colnames is used. + * @param typearr holds an array of types. These are the same types + * used in MetaTypes (C,B,L,I,N). + * @param [colnames] array of column names. If set, then the first row of + * $array should not hold the column names. + */ + function InitArray($array,$typearr,$colnames=false) + { + $this->_array = $array; + $this->_types = $typearr; + if ($colnames) { + $this->_skiprow1 = false; + $this->_colnames = $colnames; + } else { + $this->_skiprow1 = true; + $this->_colnames = $array[0]; + } + $this->Init(); + } + /** + * Setup the Array and datatype file objects + * + * @param array is a 2-dimensional array holding the data. + * The first row should hold the column names + * unless paramter $colnames is used. + * @param fieldarr holds an array of ADOFieldObject's. + */ + function InitArrayFields(&$array,&$fieldarr) + { + $this->_array = $array; + $this->_skiprow1= false; + if ($fieldarr) { + $this->_fieldobjects = $fieldarr; + } + $this->Init(); + } + + function GetArray($nRows=-1) + { + if ($nRows == -1 && $this->_currentRow <= 0 && !$this->_skiprow1) { + return $this->_array; + } else { + $arr = ADORecordSet::GetArray($nRows); + return $arr; + } + } + + function _initrs() + { + $this->_numOfRows = sizeof($this->_array); + if ($this->_skiprow1) $this->_numOfRows -= 1; + + $this->_numOfFields =(isset($this->_fieldobjects)) ? + sizeof($this->_fieldobjects):sizeof($this->_types); + } + + /* Use associative array to get fields array */ + function Fields($colname) + { + $mode = isset($this->adodbFetchMode) ? $this->adodbFetchMode : $this->fetchMode; + + if ($mode & ADODB_FETCH_ASSOC) { + if (!isset($this->fields[$colname]) && !is_null($this->fields[$colname])) $colname = strtolower($colname); + return $this->fields[$colname]; + } + if (!$this->bind) { + $this->bind = array(); + for ($i=0; $i < $this->_numOfFields; $i++) { + $o = $this->FetchField($i); + $this->bind[strtoupper($o->name)] = $i; + } + } + return $this->fields[$this->bind[strtoupper($colname)]]; + } + + function FetchField($fieldOffset = -1) + { + if (isset($this->_fieldobjects)) { + return $this->_fieldobjects[$fieldOffset]; + } + $o = new ADOFieldObject(); + $o->name = $this->_colnames[$fieldOffset]; + $o->type = $this->_types[$fieldOffset]; + $o->max_length = -1; // length not known + + return $o; + } + + function _seek($row) + { + if (sizeof($this->_array) && 0 <= $row && $row < $this->_numOfRows) { + $this->_currentRow = $row; + if ($this->_skiprow1) $row += 1; + $this->fields = $this->_array[$row]; + return true; + } + return false; + } + + function MoveNext() + { + if (!$this->EOF) { + $this->_currentRow++; + + $pos = $this->_currentRow; + + if ($this->_numOfRows <= $pos) { + if (!$this->compat) $this->fields = false; + } else { + if ($this->_skiprow1) $pos += 1; + $this->fields = $this->_array[$pos]; + return true; + } + $this->EOF = true; + } + + return false; + } + + function _fetch() + { + $pos = $this->_currentRow; + + if ($this->_numOfRows <= $pos) { + if (!$this->compat) $this->fields = false; + return false; + } + if ($this->_skiprow1) $pos += 1; + $this->fields = $this->_array[$pos]; + return true; + } + + function _close() + { + return true; + } + + } // ADORecordSet_array + + //============================================================================================== + // HELPER FUNCTIONS + //============================================================================================== + + /** + * Synonym for ADOLoadCode. Private function. Do not use. + * + * @deprecated + */ + function ADOLoadDB($dbType) + { + return ADOLoadCode($dbType); + } + + /** + * Load the code for a specific database driver. Private function. Do not use. + */ + function ADOLoadCode($dbType) + { + global $ADODB_LASTDB; + + if (!$dbType) return false; + $db = strtolower($dbType); + switch ($db) { + case 'ado': + if (PHP_VERSION >= 5) $db = 'ado5'; + $class = 'ado'; + break; + case 'ifx': + case 'maxsql': $class = $db = 'mysqlt'; break; + case 'postgres': + case 'postgres8': + case 'pgsql': $class = $db = 'postgres7'; break; + default: + $class = $db; break; + } + + $file = ADODB_DIR."/drivers/adodb-".$db.".inc.php"; + @include_once($file); + $ADODB_LASTDB = $class; + if (class_exists("ADODB_" . $class)) return $class; + + //ADOConnection::outp(adodb_pr(get_declared_classes(),true)); + if (!file_exists($file)) ADOConnection::outp("Missing file: $file"); + else ADOConnection::outp("Syntax error in file: $file"); + return false; + } + + /** + * synonym for ADONewConnection for people like me who cannot remember the correct name + */ + function NewADOConnection($db='') + { + $tmp = ADONewConnection($db); + return $tmp; + } + + /** + * Instantiate a new Connection class for a specific database driver. + * + * @param [db] is the database Connection object to create. If undefined, + * use the last database driver that was loaded by ADOLoadCode(). + * + * @return the freshly created instance of the Connection class. + */ + function ADONewConnection($db='') + { + GLOBAL $ADODB_NEWCONNECTION, $ADODB_LASTDB; + + if (!defined('ADODB_ASSOC_CASE')) define('ADODB_ASSOC_CASE',2); + $errorfn = (defined('ADODB_ERROR_HANDLER')) ? ADODB_ERROR_HANDLER : false; + $false = false; + if (($at = strpos($db,'://')) !== FALSE) { + $origdsn = $db; + $fakedsn = 'fake'.substr($origdsn,$at); + if (($at2 = strpos($origdsn,'@/')) !== FALSE) { + // special handling of oracle, which might not have host + $fakedsn = str_replace('@/','@adodb-fakehost/',$fakedsn); + } + + if ((strpos($origdsn, 'sqlite')) !== FALSE) { + // special handling for SQLite, it only might have the path to the database file. + // If you try to connect to a SQLite database using a dsn like 'sqlite:///path/to/database', the 'parse_url' php function + // will throw you an exception with a message such as "unable to parse url" + list($scheme, $path) = explode('://', $origdsn); + $dsna['scheme'] = $scheme; + if ($qmark = strpos($path,'?')) { + $dsn['query'] = substr($path,$qmark+1); + $path = substr($path,0,$qmark); + } + $dsna['path'] = '/' . urlencode($path); + } else + $dsna = @parse_url($fakedsn); + + if (!$dsna) { + return $false; + } + $dsna['scheme'] = substr($origdsn,0,$at); + if ($at2 !== FALSE) { + $dsna['host'] = ''; + } + + if (strncmp($origdsn,'pdo',3) == 0) { + $sch = explode('_',$dsna['scheme']); + if (sizeof($sch)>1) { + + $dsna['host'] = isset($dsna['host']) ? rawurldecode($dsna['host']) : ''; + if ($sch[1] == 'sqlite') + $dsna['host'] = rawurlencode($sch[1].':'.rawurldecode($dsna['host'])); + else + $dsna['host'] = rawurlencode($sch[1].':host='.rawurldecode($dsna['host'])); + $dsna['scheme'] = 'pdo'; + } + } + + $db = @$dsna['scheme']; + if (!$db) return $false; + $dsna['host'] = isset($dsna['host']) ? rawurldecode($dsna['host']) : ''; + $dsna['user'] = isset($dsna['user']) ? rawurldecode($dsna['user']) : ''; + $dsna['pass'] = isset($dsna['pass']) ? rawurldecode($dsna['pass']) : ''; + $dsna['path'] = isset($dsna['path']) ? rawurldecode(substr($dsna['path'],1)) : ''; # strip off initial / + + if (isset($dsna['query'])) { + $opt1 = explode('&',$dsna['query']); + foreach($opt1 as $k => $v) { + $arr = explode('=',$v); + $opt[$arr[0]] = isset($arr[1]) ? rawurldecode($arr[1]) : 1; + } + } else $opt = array(); + } + /* + * phptype: Database backend used in PHP (mysql, odbc etc.) + * dbsyntax: Database used with regards to SQL syntax etc. + * protocol: Communication protocol to use (tcp, unix etc.) + * hostspec: Host specification (hostname[:port]) + * database: Database to use on the DBMS server + * username: User name for login + * password: Password for login + */ + if (!empty($ADODB_NEWCONNECTION)) { + $obj = $ADODB_NEWCONNECTION($db); + + } + + if(empty($obj)) { + + if (!isset($ADODB_LASTDB)) $ADODB_LASTDB = ''; + if (empty($db)) $db = $ADODB_LASTDB; + + if ($db != $ADODB_LASTDB) $db = ADOLoadCode($db); + + if (!$db) { + if (isset($origdsn)) $db = $origdsn; + if ($errorfn) { + // raise an error + $ignore = false; + $errorfn('ADONewConnection', 'ADONewConnection', -998, + "could not load the database driver for '$db'", + $db,false,$ignore); + } else + ADOConnection::outp( "

ADONewConnection: Unable to load database driver '$db'

",false); + + return $false; + } + + $cls = 'ADODB_'.$db; + if (!class_exists($cls)) { + adodb_backtrace(); + return $false; + } + + $obj = new $cls(); + } + + # constructor should not fail + if ($obj) { + if ($errorfn) $obj->raiseErrorFn = $errorfn; + if (isset($dsna)) { + if (isset($dsna['port'])) $obj->port = $dsna['port']; + foreach($opt as $k => $v) { + switch(strtolower($k)) { + case 'new': + $nconnect = true; $persist = true; break; + case 'persist': + case 'persistent': $persist = $v; break; + case 'debug': $obj->debug = (integer) $v; break; + #ibase + case 'role': $obj->role = $v; break; + case 'dialect': $obj->dialect = (integer) $v; break; + case 'charset': $obj->charset = $v; $obj->charSet=$v; break; + case 'buffers': $obj->buffers = $v; break; + case 'fetchmode': $obj->SetFetchMode($v); break; + #ado + case 'charpage': $obj->charPage = $v; break; + #mysql, mysqli + case 'clientflags': $obj->clientFlags = $v; break; + #mysql, mysqli, postgres + case 'port': $obj->port = $v; break; + #mysqli + case 'socket': $obj->socket = $v; break; + #oci8 + case 'nls_date_format': $obj->NLS_DATE_FORMAT = $v; break; + case 'cachesecs': $obj->cacheSecs = $v; break; + case 'memcache': + $varr = explode(':',$v); + $vlen = sizeof($varr); + if ($vlen == 0) break; + $obj->memCache = true; + $obj->memCacheHost = explode(',',$varr[0]); + if ($vlen == 1) break; + $obj->memCachePort = $varr[1]; + if ($vlen == 2) break; + $obj->memCacheCompress = $varr[2] ? true : false; + break; + } + } + if (empty($persist)) + $ok = $obj->Connect($dsna['host'], $dsna['user'], $dsna['pass'], $dsna['path']); + else if (empty($nconnect)) + $ok = $obj->PConnect($dsna['host'], $dsna['user'], $dsna['pass'], $dsna['path']); + else + $ok = $obj->NConnect($dsna['host'], $dsna['user'], $dsna['pass'], $dsna['path']); + + if (!$ok) return $false; + } + } + return $obj; + } + + + + // $perf == true means called by NewPerfMonitor(), otherwise for data dictionary + function _adodb_getdriver($provider,$drivername,$perf=false) + { + switch ($provider) { + case 'odbtp': if (strncmp('odbtp_',$drivername,6)==0) return substr($drivername,6); + case 'odbc' : if (strncmp('odbc_',$drivername,5)==0) return substr($drivername,5); + case 'ado' : if (strncmp('ado_',$drivername,4)==0) return substr($drivername,4); + case 'native': break; + default: + return $provider; + } + + switch($drivername) { + case 'mysqlt': + case 'mysqli': + $drivername='mysql'; + break; + case 'postgres7': + case 'postgres8': + $drivername = 'postgres'; + break; + case 'firebird15': $drivername = 'firebird'; break; + case 'oracle': $drivername = 'oci8'; break; + case 'access': if ($perf) $drivername = ''; break; + case 'db2' : break; + case 'sapdb' : break; + default: + $drivername = 'generic'; + break; + } + return $drivername; + } + + function NewPerfMonitor(&$conn) + { + $false = false; + $drivername = _adodb_getdriver($conn->dataProvider,$conn->databaseType,true); + if (!$drivername || $drivername == 'generic') return $false; + include_once(ADODB_DIR.'/adodb-perf.inc.php'); + @include_once(ADODB_DIR."/perf/perf-$drivername.inc.php"); + $class = "Perf_$drivername"; + if (!class_exists($class)) return $false; + $perf = new $class($conn); + + return $perf; + } + + function NewDataDictionary(&$conn,$drivername=false) + { + $false = false; + if (!$drivername) $drivername = _adodb_getdriver($conn->dataProvider,$conn->databaseType); + + include_once(ADODB_DIR.'/adodb-lib.inc.php'); + include_once(ADODB_DIR.'/adodb-datadict.inc.php'); + $path = ADODB_DIR."/datadict/datadict-$drivername.inc.php"; + + if (!file_exists($path)) { + ADOConnection::outp("Dictionary driver '$path' not available"); + return $false; + } + include_once($path); + $class = "ADODB2_$drivername"; + $dict = new $class(); + $dict->dataProvider = $conn->dataProvider; + $dict->connection = $conn; + $dict->upperName = strtoupper($drivername); + $dict->quote = $conn->nameQuote; + if (!empty($conn->_connectionID)) + $dict->serverInfo = $conn->ServerInfo(); + + return $dict; + } + + + + /* + Perform a print_r, with pre tags for better formatting. + */ + function adodb_pr($var,$as_string=false) + { + if ($as_string) ob_start(); + + if (isset($_SERVER['HTTP_USER_AGENT'])) { + echo "
\n";print_r($var);echo "
\n"; + } else + print_r($var); + + if ($as_string) { + $s = ob_get_contents(); + ob_end_clean(); + return $s; + } + } + + /* + Perform a stack-crawl and pretty print it. + + @param printOrArr Pass in a boolean to indicate print, or an $exception->trace array (assumes that print is true then). + @param levels Number of levels to display + */ + function adodb_backtrace($printOrArr=true,$levels=9999,$ishtml=null) + { + global $ADODB_INCLUDED_LIB; + if (empty($ADODB_INCLUDED_LIB)) include(ADODB_DIR.'/adodb-lib.inc.php'); + return _adodb_backtrace($printOrArr,$levels,0,$ishtml); + } + + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres.inc.php new file mode 100644 index 00000000..6f580ff6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres.inc.php @@ -0,0 +1,14 @@ + \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres64.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres64.inc.php new file mode 100644 index 00000000..6846303a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres64.inc.php @@ -0,0 +1,1074 @@ + + jlim - changed concat operator to || and data types to MetaType to match documented pgsql types + see http://www.postgresql.org/devel-corner/docs/postgres/datatype.htm + 22 Nov 2000 jlim - added changes to FetchField() and MetaTables() contributed by "raser" + 27 Nov 2000 jlim - added changes to _connect/_pconnect from ideas by "Lennie" + 15 Dec 2000 jlim - added changes suggested by Additional code changes by "Eric G. Werk" egw@netguide.dk. + 31 Jan 2002 jlim - finally installed postgresql. testing + 01 Mar 2001 jlim - Freek Dijkstra changes, also support for text type + + See http://www.varlena.com/varlena/GeneralBits/47.php + + -- What indexes are on my table? + select * from pg_indexes where tablename = 'tablename'; + + -- What triggers are on my table? + select c.relname as "Table", t.tgname as "Trigger Name", + t.tgconstrname as "Constraint Name", t.tgenabled as "Enabled", + t.tgisconstraint as "Is Constraint", cc.relname as "Referenced Table", + p.proname as "Function Name" + from pg_trigger t, pg_class c, pg_class cc, pg_proc p + where t.tgfoid = p.oid and t.tgrelid = c.oid + and t.tgconstrrelid = cc.oid + and c.relname = 'tablename'; + + -- What constraints are on my table? + select r.relname as "Table", c.conname as "Constraint Name", + contype as "Constraint Type", conkey as "Key Columns", + confkey as "Foreign Columns", consrc as "Source" + from pg_class r, pg_constraint c + where r.oid = c.conrelid + and relname = 'tablename'; + +*/ + +// security - hide paths +if (!defined('ADODB_DIR')) die(); + +function adodb_addslashes($s) +{ + $len = strlen($s); + if ($len == 0) return "''"; + if (strncmp($s,"'",1) === 0 && substr($s,$len-1) == "'") return $s; // already quoted + + return "'".addslashes($s)."'"; +} + +class ADODB_postgres64 extends ADOConnection{ + var $databaseType = 'postgres64'; + var $dataProvider = 'postgres'; + var $hasInsertID = true; + var $_resultid = false; + var $concat_operator='||'; + var $metaDatabasesSQL = "select datname from pg_database where datname not in ('template0','template1') order by 1"; + var $metaTablesSQL = "select tablename,'T' from pg_tables where tablename not like 'pg\_%' + and tablename not in ('sql_features', 'sql_implementation_info', 'sql_languages', + 'sql_packages', 'sql_sizing', 'sql_sizing_profiles') + union + select viewname,'V' from pg_views where viewname not like 'pg\_%'"; + //"select tablename from pg_tables where tablename not like 'pg_%' order by 1"; + var $isoDates = true; // accepts dates in ISO format + var $sysDate = "CURRENT_DATE"; + var $sysTimeStamp = "CURRENT_TIMESTAMP"; + var $blobEncodeType = 'C'; + var $metaColumnsSQL = "SELECT a.attname,t.typname,a.attlen,a.atttypmod,a.attnotnull,a.atthasdef,a.attnum + FROM pg_class c, pg_attribute a,pg_type t + WHERE relkind in ('r','v') AND (c.relname='%s' or c.relname = lower('%s')) and a.attname not like '....%%' +AND a.attnum > 0 AND a.atttypid = t.oid AND a.attrelid = c.oid ORDER BY a.attnum"; + + // used when schema defined + var $metaColumnsSQL1 = "SELECT a.attname, t.typname, a.attlen, a.atttypmod, a.attnotnull, a.atthasdef, a.attnum +FROM pg_class c, pg_attribute a, pg_type t, pg_namespace n +WHERE relkind in ('r','v') AND (c.relname='%s' or c.relname = lower('%s')) + and c.relnamespace=n.oid and n.nspname='%s' + and a.attname not like '....%%' AND a.attnum > 0 + AND a.atttypid = t.oid AND a.attrelid = c.oid ORDER BY a.attnum"; + + // get primary key etc -- from Freek Dijkstra + var $metaKeySQL = "SELECT ic.relname AS index_name, a.attname AS column_name,i.indisunique AS unique_key, i.indisprimary AS primary_key + FROM pg_class bc, pg_class ic, pg_index i, pg_attribute a WHERE bc.oid = i.indrelid AND ic.oid = i.indexrelid AND (i.indkey[0] = a.attnum OR i.indkey[1] = a.attnum OR i.indkey[2] = a.attnum OR i.indkey[3] = a.attnum OR i.indkey[4] = a.attnum OR i.indkey[5] = a.attnum OR i.indkey[6] = a.attnum OR i.indkey[7] = a.attnum) AND a.attrelid = bc.oid AND bc.relname = '%s'"; + + var $hasAffectedRows = true; + var $hasLimit = false; // set to true for pgsql 7 only. support pgsql/mysql SELECT * FROM TABLE LIMIT 10 + // below suggested by Freek Dijkstra + var $true = 'TRUE'; // string that represents TRUE for a database + var $false = 'FALSE'; // string that represents FALSE for a database + var $fmtDate = "'Y-m-d'"; // used by DBDate() as the default date format used by the database + var $fmtTimeStamp = "'Y-m-d H:i:s'"; // used by DBTimeStamp as the default timestamp fmt. + var $hasMoveFirst = true; + var $hasGenID = true; + var $_genIDSQL = "SELECT NEXTVAL('%s')"; + var $_genSeqSQL = "CREATE SEQUENCE %s START %s"; + var $_dropSeqSQL = "DROP SEQUENCE %s"; + var $metaDefaultsSQL = "SELECT d.adnum as num, d.adsrc as def from pg_attrdef d, pg_class c where d.adrelid=c.oid and c.relname='%s' order by d.adnum"; + var $random = 'random()'; /// random function + var $autoRollback = true; // apparently pgsql does not autorollback properly before php 4.3.4 + // http://bugs.php.net/bug.php?id=25404 + + var $uniqueIisR = true; + var $_bindInputArray = false; // requires postgresql 7.3+ and ability to modify database + var $disableBlobs = false; // set to true to disable blob checking, resulting in 2-5% improvement in performance. + + // The last (fmtTimeStamp is not entirely correct: + // PostgreSQL also has support for time zones, + // and writes these time in this format: "2001-03-01 18:59:26+02". + // There is no code for the "+02" time zone information, so I just left that out. + // I'm not familiar enough with both ADODB as well as Postgres + // to know what the concequences are. The other values are correct (wheren't in 0.94) + // -- Freek Dijkstra + + function ADODB_postgres64() + { + // changes the metaColumnsSQL, adds columns: attnum[6] + } + + function ServerInfo() + { + if (isset($this->version)) return $this->version; + + $arr['description'] = $this->GetOne("select version()"); + $arr['version'] = ADOConnection::_findvers($arr['description']); + $this->version = $arr; + return $arr; + } + + function IfNull( $field, $ifNull ) + { + return " coalesce($field, $ifNull) "; + } + + // get the last id - never tested + function pg_insert_id($tablename,$fieldname) + { + $result=pg_exec($this->_connectionID, "SELECT last_value FROM ${tablename}_${fieldname}_seq"); + if ($result) { + $arr = @pg_fetch_row($result,0); + pg_freeresult($result); + if (isset($arr[0])) return $arr[0]; + } + return false; + } + +/* Warning from http://www.php.net/manual/function.pg-getlastoid.php: +Using a OID as a unique identifier is not generally wise. +Unless you are very careful, you might end up with a tuple having +a different OID if a database must be reloaded. */ + function _insertid($table,$column) + { + if (!is_resource($this->_resultid) || get_resource_type($this->_resultid) !== 'pgsql result') return false; + $oid = pg_getlastoid($this->_resultid); + // to really return the id, we need the table and column-name, else we can only return the oid != id + return empty($table) || empty($column) ? $oid : $this->GetOne("SELECT $column FROM $table WHERE oid=".(int)$oid); + } + +// I get this error with PHP before 4.0.6 - jlim +// Warning: This compilation does not support pg_cmdtuples() in adodb-postgres.inc.php on line 44 + function _affectedrows() + { + if (!is_resource($this->_resultid) || get_resource_type($this->_resultid) !== 'pgsql result') return false; + return pg_cmdtuples($this->_resultid); + } + + + // returns true/false + function BeginTrans() + { + if ($this->transOff) return true; + $this->transCnt += 1; + return @pg_Exec($this->_connectionID, "begin ".$this->_transmode); + } + + function RowLock($tables,$where,$col='1 as adodbignore') + { + if (!$this->transCnt) $this->BeginTrans(); + return $this->GetOne("select $col from $tables where $where for update"); + } + + // returns true/false. + function CommitTrans($ok=true) + { + if ($this->transOff) return true; + if (!$ok) return $this->RollbackTrans(); + + $this->transCnt -= 1; + return @pg_Exec($this->_connectionID, "commit"); + } + + // returns true/false + function RollbackTrans() + { + if ($this->transOff) return true; + $this->transCnt -= 1; + return @pg_Exec($this->_connectionID, "rollback"); + } + + function MetaTables($ttype=false,$showSchema=false,$mask=false) + { + $info = $this->ServerInfo(); + if ($info['version'] >= 7.3) { + $this->metaTablesSQL = "select tablename,'T' from pg_tables where tablename not like 'pg\_%' + and schemaname not in ( 'pg_catalog','information_schema') + union + select viewname,'V' from pg_views where viewname not like 'pg\_%' and schemaname not in ( 'pg_catalog','information_schema') "; + } + if ($mask) { + $save = $this->metaTablesSQL; + $mask = $this->qstr(strtolower($mask)); + if ($info['version']>=7.3) + $this->metaTablesSQL = " +select tablename,'T' from pg_tables where tablename like $mask and schemaname not in ( 'pg_catalog','information_schema') + union +select viewname,'V' from pg_views where viewname like $mask and schemaname not in ( 'pg_catalog','information_schema') "; + else + $this->metaTablesSQL = " +select tablename,'T' from pg_tables where tablename like $mask + union +select viewname,'V' from pg_views where viewname like $mask"; + } + $ret = ADOConnection::MetaTables($ttype,$showSchema); + + if ($mask) { + $this->metaTablesSQL = $save; + } + return $ret; + } + + + // if magic quotes disabled, use pg_escape_string() + function qstr($s,$magic_quotes=false) + { + if (is_bool($s)) return $s ? 'true' : 'false'; + + if (!$magic_quotes) { + if (ADODB_PHPVER >= 0x5200) { + return "'".pg_escape_string($this->_connectionID,$s)."'"; + } + if (ADODB_PHPVER >= 0x4200) { + return "'".pg_escape_string($s)."'"; + } + if ($this->replaceQuote[0] == '\\'){ + $s = adodb_str_replace(array('\\',"\0"),array('\\\\',"\\\\000"),$s); + } + return "'".str_replace("'",$this->replaceQuote,$s)."'"; + } + + // undo magic quotes for " + $s = str_replace('\\"','"',$s); + return "'$s'"; + } + + + + // Format date column in sql string given an input format that understands Y M D + function SQLDate($fmt, $col=false) + { + if (!$col) $col = $this->sysTimeStamp; + $s = 'TO_CHAR('.$col.",'"; + + $len = strlen($fmt); + for ($i=0; $i < $len; $i++) { + $ch = $fmt[$i]; + switch($ch) { + case 'Y': + case 'y': + $s .= 'YYYY'; + break; + case 'Q': + case 'q': + $s .= 'Q'; + break; + + case 'M': + $s .= 'Mon'; + break; + + case 'm': + $s .= 'MM'; + break; + case 'D': + case 'd': + $s .= 'DD'; + break; + + case 'H': + $s.= 'HH24'; + break; + + case 'h': + $s .= 'HH'; + break; + + case 'i': + $s .= 'MI'; + break; + + case 's': + $s .= 'SS'; + break; + + case 'a': + case 'A': + $s .= 'AM'; + break; + + case 'w': + $s .= 'D'; + break; + + case 'l': + $s .= 'DAY'; + break; + + case 'W': + $s .= 'WW'; + break; + + default: + // handle escape characters... + if ($ch == '\\') { + $i++; + $ch = substr($fmt,$i,1); + } + if (strpos('-/.:;, ',$ch) !== false) $s .= $ch; + else $s .= '"'.$ch.'"'; + + } + } + return $s. "')"; + } + + + + /* + * Load a Large Object from a file + * - the procedure stores the object id in the table and imports the object using + * postgres proprietary blob handling routines + * + * contributed by Mattia Rossi mattia@technologist.com + * modified for safe mode by juraj chlebec + */ + function UpdateBlobFile($table,$column,$path,$where,$blobtype='BLOB') + { + pg_exec ($this->_connectionID, "begin"); + + $fd = fopen($path,'r'); + $contents = fread($fd,filesize($path)); + fclose($fd); + + $oid = pg_lo_create($this->_connectionID); + $handle = pg_lo_open($this->_connectionID, $oid, 'w'); + pg_lo_write($handle, $contents); + pg_lo_close($handle); + + // $oid = pg_lo_import ($path); + pg_exec($this->_connectionID, "commit"); + $rs = ADOConnection::UpdateBlob($table,$column,$oid,$where,$blobtype); + $rez = !empty($rs); + return $rez; + } + + /* + * Deletes/Unlinks a Blob from the database, otherwise it + * will be left behind + * + * Returns TRUE on success or FALSE on failure. + * + * contributed by Todd Rogers todd#windfox.net + */ + function BlobDelete( $blob ) + { + pg_exec ($this->_connectionID, "begin"); + $result = @pg_lo_unlink($blob); + pg_exec ($this->_connectionID, "commit"); + return( $result ); + } + + /* + Hueristic - not guaranteed to work. + */ + function GuessOID($oid) + { + if (strlen($oid)>16) return false; + return is_numeric($oid); + } + + /* + * If an OID is detected, then we use pg_lo_* to open the oid file and read the + * real blob from the db using the oid supplied as a parameter. If you are storing + * blobs using bytea, we autodetect and process it so this function is not needed. + * + * contributed by Mattia Rossi mattia@technologist.com + * + * see http://www.postgresql.org/idocs/index.php?largeobjects.html + * + * Since adodb 4.54, this returns the blob, instead of sending it to stdout. Also + * added maxsize parameter, which defaults to $db->maxblobsize if not defined. + */ + function BlobDecode($blob,$maxsize=false,$hastrans=true) + { + if (!$this->GuessOID($blob)) return $blob; + + if ($hastrans) @pg_exec($this->_connectionID,"begin"); + $fd = @pg_lo_open($this->_connectionID,$blob,"r"); + if ($fd === false) { + if ($hastrans) @pg_exec($this->_connectionID,"commit"); + return $blob; + } + if (!$maxsize) $maxsize = $this->maxblobsize; + $realblob = @pg_loread($fd,$maxsize); + @pg_loclose($fd); + if ($hastrans) @pg_exec($this->_connectionID,"commit"); + return $realblob; + } + + /* + See http://www.postgresql.org/idocs/index.php?datatype-binary.html + + NOTE: SQL string literals (input strings) must be preceded with two backslashes + due to the fact that they must pass through two parsers in the PostgreSQL + backend. + */ + function BlobEncode($blob) + { + if (ADODB_PHPVER >= 0x5200) return pg_escape_bytea($this->_connectionID, $blob); + if (ADODB_PHPVER >= 0x4200) return pg_escape_bytea($blob); + + /*92=backslash, 0=null, 39=single-quote*/ + $badch = array(chr(92),chr(0),chr(39)); # \ null ' + $fixch = array('\\\\134','\\\\000','\\\\047'); + return adodb_str_replace($badch,$fixch,$blob); + + // note that there is a pg_escape_bytea function only for php 4.2.0 or later + } + + // assumes bytea for blob, and varchar for clob + function UpdateBlob($table,$column,$val,$where,$blobtype='BLOB') + { + + if ($blobtype == 'CLOB') { + return $this->Execute("UPDATE $table SET $column=" . $this->qstr($val) . " WHERE $where"); + } + // do not use bind params which uses qstr(), as blobencode() already quotes data + return $this->Execute("UPDATE $table SET $column='".$this->BlobEncode($val)."'::bytea WHERE $where"); + } + + function OffsetDate($dayFraction,$date=false) + { + if (!$date) $date = $this->sysDate; + else if (strncmp($date,"'",1) == 0) { + $len = strlen($date); + if (10 <= $len && $len <= 12) $date = 'date '.$date; + else $date = 'timestamp '.$date; + } + + + return "($date+interval'".($dayFraction * 1440)." minutes')"; + #return "($date+interval'$dayFraction days')"; + } + + + // for schema support, pass in the $table param "$schema.$tabname". + // converts field names to lowercase, $upper is ignored + // see http://phplens.com/lens/lensforum/msgs.php?id=14018 for more info + function MetaColumns($table,$normalize=true) + { + global $ADODB_FETCH_MODE; + + $schema = false; + $false = false; + $this->_findschema($table,$schema); + + if ($normalize) $table = strtolower($table); + + $save = $ADODB_FETCH_MODE; + $ADODB_FETCH_MODE = ADODB_FETCH_NUM; + if ($this->fetchMode !== false) $savem = $this->SetFetchMode(false); + + if ($schema) $rs = $this->Execute(sprintf($this->metaColumnsSQL1,$table,$table,$schema)); + else $rs = $this->Execute(sprintf($this->metaColumnsSQL,$table,$table)); + if (isset($savem)) $this->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + + if ($rs === false) { + return $false; + } + if (!empty($this->metaKeySQL)) { + // If we want the primary keys, we have to issue a separate query + // Of course, a modified version of the metaColumnsSQL query using a + // LEFT JOIN would have been much more elegant, but postgres does + // not support OUTER JOINS. So here is the clumsy way. + + $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC; + + $rskey = $this->Execute(sprintf($this->metaKeySQL,($table))); + // fetch all result in once for performance. + $keys = $rskey->GetArray(); + if (isset($savem)) $this->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + + $rskey->Close(); + unset($rskey); + } + + $rsdefa = array(); + if (!empty($this->metaDefaultsSQL)) { + $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC; + $sql = sprintf($this->metaDefaultsSQL, ($table)); + $rsdef = $this->Execute($sql); + if (isset($savem)) $this->SetFetchMode($savem); + $ADODB_FETCH_MODE = $save; + + if ($rsdef) { + while (!$rsdef->EOF) { + $num = $rsdef->fields['num']; + $s = $rsdef->fields['def']; + if (strpos($s,'::')===false && substr($s, 0, 1) == "'") { /* quoted strings hack... for now... fixme */ + $s = substr($s, 1); + $s = substr($s, 0, strlen($s) - 1); + } + + $rsdefa[$num] = $s; + $rsdef->MoveNext(); + } + } else { + ADOConnection::outp( "==> SQL => " . $sql); + } + unset($rsdef); + } + + $retarr = array(); + while (!$rs->EOF) { + $fld = new ADOFieldObject(); + $fld->name = $rs->fields[0]; + $fld->type = $rs->fields[1]; + $fld->max_length = $rs->fields[2]; + $fld->attnum = $rs->fields[6]; + + if ($fld->max_length <= 0) $fld->max_length = $rs->fields[3]-4; + if ($fld->max_length <= 0) $fld->max_length = -1; + if ($fld->type == 'numeric') { + $fld->scale = $fld->max_length & 0xFFFF; + $fld->max_length >>= 16; + } + // dannym + // 5 hasdefault; 6 num-of-column + $fld->has_default = ($rs->fields[5] == 't'); + if ($fld->has_default) { + $fld->default_value = $rsdefa[$rs->fields[6]]; + } + + //Freek + $fld->not_null = $rs->fields[4] == 't'; + + + // Freek + if (is_array($keys)) { + foreach($keys as $key) { + if ($fld->name == $key['column_name'] AND $key['primary_key'] == 't') + $fld->primary_key = true; + if ($fld->name == $key['column_name'] AND $key['unique_key'] == 't') + $fld->unique = true; // What name is more compatible? + } + } + + if ($ADODB_FETCH_MODE == ADODB_FETCH_NUM) $retarr[] = $fld; + else $retarr[($normalize) ? strtoupper($fld->name) : $fld->name] = $fld; + + $rs->MoveNext(); + } + $rs->Close(); + if (empty($retarr)) + return $false; + else + return $retarr; + + } + + function MetaIndexes ($table, $primary = FALSE, $owner = false) + { + global $ADODB_FETCH_MODE; + + $schema = false; + $this->_findschema($table,$schema); + + if ($schema) { // requires pgsql 7.3+ - pg_namespace used. + $sql = ' +SELECT c.relname as "Name", i.indisunique as "Unique", i.indkey as "Columns" +FROM pg_catalog.pg_class c +JOIN pg_catalog.pg_index i ON i.indexrelid=c.oid +JOIN pg_catalog.pg_class c2 ON c2.oid=i.indrelid + ,pg_namespace n +WHERE (c2.relname=\'%s\' or c2.relname=lower(\'%s\')) and c.relnamespace=c2.relnamespace and c.relnamespace=n.oid and n.nspname=\'%s\''; + } else { + $sql = ' +SELECT c.relname as "Name", i.indisunique as "Unique", i.indkey as "Columns" +FROM pg_catalog.pg_class c +JOIN pg_catalog.pg_index i ON i.indexrelid=c.oid +JOIN pg_catalog.pg_class c2 ON c2.oid=i.indrelid +WHERE (c2.relname=\'%s\' or c2.relname=lower(\'%s\'))'; + } + + if ($primary == FALSE) { + $sql .= ' AND i.indisprimary=false;'; + } + + $save = $ADODB_FETCH_MODE; + $ADODB_FETCH_MODE = ADODB_FETCH_NUM; + if ($this->fetchMode !== FALSE) { + $savem = $this->SetFetchMode(FALSE); + } + + $rs = $this->Execute(sprintf($sql,$table,$table,$schema)); + if (isset($savem)) { + $this->SetFetchMode($savem); + } + $ADODB_FETCH_MODE = $save; + + if (!is_object($rs)) { + $false = false; + return $false; + } + + $col_names = $this->MetaColumnNames($table,true,true); + //3rd param is use attnum, + // see http://sourceforge.net/tracker/index.php?func=detail&aid=1451245&group_id=42718&atid=433976 + $indexes = array(); + while ($row = $rs->FetchRow()) { + $columns = array(); + foreach (explode(' ', $row[2]) as $col) { + $columns[] = $col_names[$col]; + } + + $indexes[$row[0]] = array( + 'unique' => ($row[1] == 't'), + 'columns' => $columns + ); + } + return $indexes; + } + + // returns true or false + // + // examples: + // $db->Connect("host=host1 user=user1 password=secret port=4341"); + // $db->Connect('host1','user1','secret'); + function _connect($str,$user='',$pwd='',$db='',$ctype=0) + { + + if (!function_exists('pg_connect')) return null; + + $this->_errorMsg = false; + + if ($user || $pwd || $db) { + $user = adodb_addslashes($user); + $pwd = adodb_addslashes($pwd); + if (strlen($db) == 0) $db = 'template1'; + $db = adodb_addslashes($db); + if ($str) { + $host = explode(":", $str); + if ($host[0]) $str = "host=".adodb_addslashes($host[0]); + else $str = ''; + if (isset($host[1])) $str .= " port=$host[1]"; + else if (!empty($this->port)) $str .= " port=".$this->port; + } + if ($user) $str .= " user=".$user; + if ($pwd) $str .= " password=".$pwd; + if ($db) $str .= " dbname=".$db; + } + + //if ($user) $linea = "user=$user host=$linea password=$pwd dbname=$db port=5432"; + + if ($ctype === 1) { // persistent + $this->_connectionID = pg_pconnect($str); + } else { + if ($ctype === -1) { // nconnect, we trick pgsql ext by changing the connection str + static $ncnt; + + if (empty($ncnt)) $ncnt = 1; + else $ncnt += 1; + + $str .= str_repeat(' ',$ncnt); + } + $this->_connectionID = @pg_connect($str); + } + if ($this->_connectionID === false) return false; + $this->Execute("set datestyle='ISO'"); + + $info = $this->ServerInfo(); + $this->pgVersion = (float) substr($info['version'],0,3); + if ($this->pgVersion >= 7.1) { // good till version 999 + $this->_nestedSQL = true; + } + return true; + } + + function _nconnect($argHostname, $argUsername, $argPassword, $argDatabaseName) + { + return $this->_connect($argHostname, $argUsername, $argPassword, $argDatabaseName,-1); + } + + // returns true or false + // + // examples: + // $db->PConnect("host=host1 user=user1 password=secret port=4341"); + // $db->PConnect('host1','user1','secret'); + function _pconnect($str,$user='',$pwd='',$db='') + { + return $this->_connect($str,$user,$pwd,$db,1); + } + + + // returns queryID or false + function _query($sql,$inputarr=false) + { + $this->_errorMsg = false; + if ($inputarr) { + /* + It appears that PREPARE/EXECUTE is slower for many queries. + + For query executed 1000 times: + "select id,firstname,lastname from adoxyz + where firstname not like ? and lastname not like ? and id = ?" + + with plan = 1.51861286163 secs + no plan = 1.26903700829 secs + + + + */ + $plan = 'P'.md5($sql); + + $execp = ''; + foreach($inputarr as $v) { + if ($execp) $execp .= ','; + if (is_string($v)) { + if (strncmp($v,"'",1) !== 0) $execp .= $this->qstr($v); + } else { + $execp .= $v; + } + } + + if ($execp) $exsql = "EXECUTE $plan ($execp)"; + else $exsql = "EXECUTE $plan"; + + + $rez = @pg_exec($this->_connectionID,$exsql); + if (!$rez) { + # Perhaps plan does not exist? Prepare/compile plan. + $params = ''; + foreach($inputarr as $v) { + if ($params) $params .= ','; + if (is_string($v)) { + $params .= 'VARCHAR'; + } else if (is_integer($v)) { + $params .= 'INTEGER'; + } else { + $params .= "REAL"; + } + } + $sqlarr = explode('?',$sql); + //print_r($sqlarr); + $sql = ''; + $i = 1; + foreach($sqlarr as $v) { + $sql .= $v.' $'.$i; + $i++; + } + $s = "PREPARE $plan ($params) AS ".substr($sql,0,strlen($sql)-2); + //adodb_pr($s); + $rez = pg_exec($this->_connectionID,$s); + //echo $this->ErrorMsg(); + } + if ($rez) + $rez = pg_exec($this->_connectionID,$exsql); + } else { + //adodb_backtrace(); + $rez = pg_exec($this->_connectionID,$sql); + } + // check if no data returned, then no need to create real recordset + if ($rez && pg_numfields($rez) <= 0) { + if (is_resource($this->_resultid) && get_resource_type($this->_resultid) === 'pgsql result') { + pg_freeresult($this->_resultid); + } + $this->_resultid = $rez; + return true; + } + + return $rez; + } + + function _errconnect() + { + if (defined('DB_ERROR_CONNECT_FAILED')) return DB_ERROR_CONNECT_FAILED; + else return 'Database connection failed'; + } + + /* Returns: the last error message from previous database operation */ + function ErrorMsg() + { + if ($this->_errorMsg !== false) return $this->_errorMsg; + if (ADODB_PHPVER >= 0x4300) { + if (!empty($this->_resultid)) { + $this->_errorMsg = @pg_result_error($this->_resultid); + if ($this->_errorMsg) return $this->_errorMsg; + } + + if (!empty($this->_connectionID)) { + $this->_errorMsg = @pg_last_error($this->_connectionID); + } else $this->_errorMsg = $this->_errconnect(); + } else { + if (empty($this->_connectionID)) $this->_errconnect(); + else $this->_errorMsg = @pg_errormessage($this->_connectionID); + } + return $this->_errorMsg; + } + + function ErrorNo() + { + $e = $this->ErrorMsg(); + if (strlen($e)) { + return ADOConnection::MetaError($e); + } + return 0; + } + + // returns true or false + function _close() + { + if ($this->transCnt) $this->RollbackTrans(); + if ($this->_resultid) { + @pg_freeresult($this->_resultid); + $this->_resultid = false; + } + @pg_close($this->_connectionID); + $this->_connectionID = false; + return true; + } + + + /* + * Maximum size of C field + */ + function CharMax() + { + return 1000000000; // should be 1 Gb? + } + + /* + * Maximum size of X field + */ + function TextMax() + { + return 1000000000; // should be 1 Gb? + } + + +} + +/*-------------------------------------------------------------------------------------- + Class Name: Recordset +--------------------------------------------------------------------------------------*/ + +class ADORecordSet_postgres64 extends ADORecordSet{ + var $_blobArr; + var $databaseType = "postgres64"; + var $canSeek = true; + function ADORecordSet_postgres64($queryID,$mode=false) + { + if ($mode === false) { + global $ADODB_FETCH_MODE; + $mode = $ADODB_FETCH_MODE; + } + switch ($mode) + { + case ADODB_FETCH_NUM: $this->fetchMode = PGSQL_NUM; break; + case ADODB_FETCH_ASSOC:$this->fetchMode = PGSQL_ASSOC; break; + + case ADODB_FETCH_DEFAULT: + case ADODB_FETCH_BOTH: + default: $this->fetchMode = PGSQL_BOTH; break; + } + $this->adodbFetchMode = $mode; + $this->ADORecordSet($queryID); + } + + function GetRowAssoc($upper=true) + { + if ($this->fetchMode == PGSQL_ASSOC && !$upper) return $this->fields; + $row = ADORecordSet::GetRowAssoc($upper); + return $row; + } + + function _initrs() + { + global $ADODB_COUNTRECS; + $qid = $this->_queryID; + $this->_numOfRows = ($ADODB_COUNTRECS)? @pg_numrows($qid):-1; + $this->_numOfFields = @pg_numfields($qid); + + // cache types for blob decode check + // apparently pg_fieldtype actually performs an sql query on the database to get the type. + if (empty($this->connection->noBlobs)) + for ($i=0, $max = $this->_numOfFields; $i < $max; $i++) { + if (pg_fieldtype($qid,$i) == 'bytea') { + $this->_blobArr[$i] = pg_fieldname($qid,$i); + } + } + } + + /* Use associative array to get fields array */ + function Fields($colname) + { + if ($this->fetchMode != PGSQL_NUM) return @$this->fields[$colname]; + + if (!$this->bind) { + $this->bind = array(); + for ($i=0; $i < $this->_numOfFields; $i++) { + $o = $this->FetchField($i); + $this->bind[strtoupper($o->name)] = $i; + } + } + return $this->fields[$this->bind[strtoupper($colname)]]; + } + + function FetchField($off = 0) + { + // offsets begin at 0 + + $o= new ADOFieldObject(); + $o->name = @pg_fieldname($this->_queryID,$off); + $o->type = @pg_fieldtype($this->_queryID,$off); + $o->max_length = @pg_fieldsize($this->_queryID,$off); + return $o; + } + + function _seek($row) + { + return @pg_fetch_row($this->_queryID,$row); + } + + function _decode($blob) + { + if ($blob === NULL) return NULL; + eval('$realblob="'.adodb_str_replace(array('"','$'),array('\"','\$'),$blob).'";'); + return $realblob; + } + + function _fixblobs() + { + + return; # bypass adodb's bytea handling, so we can handle it ourselves within PHP + + if ($this->fetchMode == PGSQL_NUM || $this->fetchMode == PGSQL_BOTH) { + foreach($this->_blobArr as $k => $v) { + $this->fields[$k] = ADORecordSet_postgres64::_decode($this->fields[$k]); + } + } + if ($this->fetchMode == PGSQL_ASSOC || $this->fetchMode == PGSQL_BOTH) { + foreach($this->_blobArr as $k => $v) { + $this->fields[$v] = ADORecordSet_postgres64::_decode($this->fields[$v]); + } + } + } + + // 10% speedup to move MoveNext to child class + function MoveNext() + { + if (!$this->EOF) { + $this->_currentRow++; + if ($this->_numOfRows < 0 || $this->_numOfRows > $this->_currentRow) { + $this->fields = @pg_fetch_array($this->_queryID,$this->_currentRow,$this->fetchMode); + if (is_array($this->fields) && $this->fields) { + if (isset($this->_blobArr)) $this->_fixblobs(); + return true; + } + } + $this->fields = false; + $this->EOF = true; + } + return false; + } + + function _fetch() + { + + if ($this->_currentRow >= $this->_numOfRows && $this->_numOfRows >= 0) + return false; + + $this->fields = @pg_fetch_array($this->_queryID,$this->_currentRow,$this->fetchMode); + + if ($this->fields && isset($this->_blobArr)) $this->_fixblobs(); + + return (is_array($this->fields)); + } + + function _close() + { + return @pg_freeresult($this->_queryID); + } + + function MetaType($t,$len=-1,$fieldobj=false) + { + if (is_object($t)) { + $fieldobj = $t; + $t = $fieldobj->type; + $len = $fieldobj->max_length; + } + switch (strtoupper($t)) { + case 'MONEY': // stupid, postgres expects money to be a string + case 'INTERVAL': + case 'CHAR': + case 'CHARACTER': + case 'VARCHAR': + case 'NAME': + case 'BPCHAR': + case '_VARCHAR': + case 'INET': + case 'MACADDR': + if ($len <= $this->blobSize) return 'C'; + + case 'TEXT': + return 'X'; + + case 'IMAGE': // user defined type + case 'BLOB': // user defined type + case 'BIT': // This is a bit string, not a single bit, so don't return 'L' + case 'VARBIT': + case 'BYTEA': + return 'B'; + + case 'BOOL': + case 'BOOLEAN': + return 'L'; + + case 'DATE': + return 'D'; + + + case 'TIMESTAMP WITHOUT TIME ZONE': + case 'TIME': + case 'DATETIME': + case 'TIMESTAMP': + case 'TIMESTAMPTZ': + return 'T'; + + case 'SMALLINT': + case 'BIGINT': + case 'INTEGER': + case 'INT8': + case 'INT4': + case 'INT2': + if (isset($fieldobj) && + empty($fieldobj->primary_key) && (!$this->connection->uniqueIisR || empty($fieldobj->unique))) return 'I'; + + case 'OID': + case 'SERIAL': + return 'R'; + + default: + return 'N'; + } + } + +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres7.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres7.inc.php new file mode 100644 index 00000000..eecfdc37 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres7.inc.php @@ -0,0 +1,313 @@ +ADODB_postgres64(); + if (ADODB_ASSOC_CASE !== 2) { + $this->rsPrefix .= 'assoc_'; + } + $this->_bindInputArray = PHP_VERSION >= 5.1; + } + + + // the following should be compat with postgresql 7.2, + // which makes obsolete the LIMIT limit,offset syntax + function SelectLimit($sql,$nrows=-1,$offset=-1,$inputarr=false,$secs2cache=0) + { + $offsetStr = ($offset >= 0) ? " OFFSET ".((integer)$offset) : ''; + $limitStr = ($nrows >= 0) ? " LIMIT ".((integer)$nrows) : ''; + if ($secs2cache) + $rs = $this->CacheExecute($secs2cache,$sql."$limitStr$offsetStr",$inputarr); + else + $rs = $this->Execute($sql."$limitStr$offsetStr",$inputarr); + + return $rs; + } + /* + function Prepare($sql) + { + $info = $this->ServerInfo(); + if ($info['version']>=7.3) { + return array($sql,false); + } + return $sql; + } + */ + + /* + I discovered that the MetaForeignKeys method no longer worked for Postgres 8.3. + I went ahead and modified it to work for both 8.2 and 8.3. + Please feel free to include this change in your next release of adodb. + William Kolodny [William.Kolodny#gt-t.net] + */ + function MetaForeignKeys($table, $owner=false, $upper=false) + { + $sql=" + SELECT fum.ftblname AS lookup_table, split_part(fum.rf, ')'::text, 1) AS lookup_field, + fum.ltable AS dep_table, split_part(fum.lf, ')'::text, 1) AS dep_field + FROM ( + SELECT fee.ltable, fee.ftblname, fee.consrc, split_part(fee.consrc,'('::text, 2) AS lf, + split_part(fee.consrc, '('::text, 3) AS rf + FROM ( + SELECT foo.relname AS ltable, foo.ftblname, + pg_get_constraintdef(foo.oid) AS consrc + FROM ( + SELECT c.oid, c.conname AS name, t.relname, ft.relname AS ftblname + FROM pg_constraint c + JOIN pg_class t ON (t.oid = c.conrelid) + JOIN pg_class ft ON (ft.oid = c.confrelid) + JOIN pg_namespace nft ON (nft.oid = ft.relnamespace) + LEFT JOIN pg_description ds ON (ds.objoid = c.oid) + JOIN pg_namespace n ON (n.oid = t.relnamespace) + WHERE c.contype = 'f'::\"char\" + ORDER BY t.relname, n.nspname, c.conname, c.oid + ) foo + ) fee) fum + WHERE fum.ltable='".strtolower($table)."' + ORDER BY fum.ftblname, fum.ltable, split_part(fum.lf, ')'::text, 1) + "; + $rs = $this->Execute($sql); + + if (!$rs || $rs->EOF) return false; + + $a = array(); + while (!$rs->EOF) { + if ($upper) { + $a[strtoupper($rs->Fields('lookup_table'))][] = strtoupper(str_replace('"','',$rs->Fields('dep_field').'='.$rs->Fields('lookup_field'))); + } else { + $a[$rs->Fields('lookup_table')][] = str_replace('"','',$rs->Fields('dep_field').'='.$rs->Fields('lookup_field')); + } + $rs->MoveNext(); + } + + return $a; + + } + + // from Edward Jaramilla, improved version - works on pg 7.4 + function _old_MetaForeignKeys($table, $owner=false, $upper=false) + { + $sql = 'SELECT t.tgargs as args + FROM + pg_trigger t,pg_class c,pg_proc p + WHERE + t.tgenabled AND + t.tgrelid = c.oid AND + t.tgfoid = p.oid AND + p.proname = \'RI_FKey_check_ins\' AND + c.relname = \''.strtolower($table).'\' + ORDER BY + t.tgrelid'; + + $rs = $this->Execute($sql); + + if (!$rs || $rs->EOF) return false; + + $arr = $rs->GetArray(); + $a = array(); + foreach($arr as $v) { + $data = explode(chr(0), $v['args']); + $size = count($data)-1; //-1 because the last node is empty + for($i = 4; $i < $size; $i++) { + if ($upper) + $a[strtoupper($data[2])][] = strtoupper($data[$i].'='.$data[++$i]); + else + $a[$data[2]][] = $data[$i].'='.$data[++$i]; + } + } + return $a; + } + + function _query($sql,$inputarr=false) + { + if (! $this->_bindInputArray) { + // We don't have native support for parameterized queries, so let's emulate it at the parent + return ADODB_postgres64::_query($sql, $inputarr); + } + $this->_errorMsg = false; + // -- added Cristiano da Cunha Duarte + if ($inputarr) { + $sqlarr = explode('?',trim($sql)); + $sql = ''; + $i = 1; + $last = sizeof($sqlarr)-1; + foreach($sqlarr as $v) { + if ($last < $i) $sql .= $v; + else $sql .= $v.' $'.$i; + $i++; + } + + $rez = pg_query_params($this->_connectionID,$sql, $inputarr); + } else { + $rez = pg_query($this->_connectionID,$sql); + } + // check if no data returned, then no need to create real recordset + if ($rez && pg_numfields($rez) <= 0) { + if (is_resource($this->_resultid) && get_resource_type($this->_resultid) === 'pgsql result') { + pg_freeresult($this->_resultid); + } + $this->_resultid = $rez; + return true; + } + return $rez; + } + + // this is a set of functions for managing client encoding - very important if the encodings + // of your database and your output target (i.e. HTML) don't match + //for instance, you may have UNICODE database and server it on-site as WIN1251 etc. + // GetCharSet - get the name of the character set the client is using now + // the functions should work with Postgres 7.0 and above, the set of charsets supported + // depends on compile flags of postgres distribution - if no charsets were compiled into the server + // it will return 'SQL_ANSI' always + function GetCharSet() + { + //we will use ADO's builtin property charSet + $this->charSet = @pg_client_encoding($this->_connectionID); + if (!$this->charSet) { + return false; + } else { + return $this->charSet; + } + } + + // SetCharSet - switch the client encoding + function SetCharSet($charset_name) + { + $this->GetCharSet(); + if ($this->charSet !== $charset_name) { + $if = pg_set_client_encoding($this->_connectionID, $charset_name); + if ($if == "0" & $this->GetCharSet() == $charset_name) { + return true; + } else return false; + } else return true; + } + +} + +/*-------------------------------------------------------------------------------------- + Class Name: Recordset +--------------------------------------------------------------------------------------*/ + +class ADORecordSet_postgres7 extends ADORecordSet_postgres64{ + + var $databaseType = "postgres7"; + + + function ADORecordSet_postgres7($queryID,$mode=false) + { + $this->ADORecordSet_postgres64($queryID,$mode); + } + + // 10% speedup to move MoveNext to child class + function MoveNext() + { + if (!$this->EOF) { + $this->_currentRow++; + if ($this->_numOfRows < 0 || $this->_numOfRows > $this->_currentRow) { + $this->fields = @pg_fetch_array($this->_queryID,$this->_currentRow,$this->fetchMode); + + if (is_array($this->fields)) { + if ($this->fields && isset($this->_blobArr)) $this->_fixblobs(); + return true; + } + } + $this->fields = false; + $this->EOF = true; + } + return false; + } + +} + +class ADORecordSet_assoc_postgres7 extends ADORecordSet_postgres64{ + + var $databaseType = "postgres7"; + + + function ADORecordSet_assoc_postgres7($queryID,$mode=false) + { + $this->ADORecordSet_postgres64($queryID,$mode); + } + + function _fetch() + { + if ($this->_currentRow >= $this->_numOfRows && $this->_numOfRows >= 0) + return false; + + $this->fields = @pg_fetch_array($this->_queryID,$this->_currentRow,$this->fetchMode); + + if ($this->fields) { + if (isset($this->_blobArr)) $this->_fixblobs(); + $this->_updatefields(); + } + + return (is_array($this->fields)); + } + + // Create associative array + function _updatefields() + { + if (ADODB_ASSOC_CASE == 2) return; // native + + $arr = array(); + $lowercase = (ADODB_ASSOC_CASE == 0); + + foreach($this->fields as $k => $v) { + if (is_integer($k)) $arr[$k] = $v; + else { + if ($lowercase) + $arr[strtolower($k)] = $v; + else + $arr[strtoupper($k)] = $v; + } + } + $this->fields = $arr; + } + + function MoveNext() + { + if (!$this->EOF) { + $this->_currentRow++; + if ($this->_numOfRows < 0 || $this->_numOfRows > $this->_currentRow) { + $this->fields = @pg_fetch_array($this->_queryID,$this->_currentRow,$this->fetchMode); + + if (is_array($this->fields)) { + if ($this->fields) { + if (isset($this->_blobArr)) $this->_fixblobs(); + + $this->_updatefields(); + } + return true; + } + } + + + $this->fields = false; + $this->EOF = true; + } + return false; + } +} +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres8.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres8.inc.php new file mode 100644 index 00000000..3134e3c3 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/drivers/adodb-postgres8.inc.php @@ -0,0 +1,12 @@ + \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ar.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ar.inc.php new file mode 100644 index 00000000..4b750952 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ar.inc.php @@ -0,0 +1,33 @@ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'ar', + DB_ERROR => 'ÎØà ÛíÑ ãÍÏÏ', + DB_ERROR_ALREADY_EXISTS => 'ãæÌæÏ ãÓÈÞÇ', + DB_ERROR_CANNOT_CREATE => 'áÇ íãßä ÅäÔÇÁ', + DB_ERROR_CANNOT_DELETE => 'áÇ íãßä ÍÐÝ', + DB_ERROR_CANNOT_DROP => 'áÇ íãßä ÍÐÝ', + DB_ERROR_CONSTRAINT => 'ÚãáíÉ ÅÏÎÇá ããäæÚÉ', + DB_ERROR_DIVZERO => 'ÚãáíÉ ÇáÊÞÓíã Úáì ÕÝÑ', + DB_ERROR_INVALID => 'ÛíÑ ÕÍíÍ', + DB_ERROR_INVALID_DATE => 'ÕíÛÉ æÞÊ Ãæ ÊÇÑíÎ ÛíÑ ÕÍíÍÉ', + DB_ERROR_INVALID_NUMBER => 'ÕíÛÉ ÑÞã ÛíÑ ÕÍíÍÉ', + DB_ERROR_MISMATCH => 'ÛíÑ ãÊØÇÈÞ', + DB_ERROR_NODBSELECTED => 'áã íÊã ÅÎÊíÇÑ ÞÇÚÏÉ ÇáÈíÇäÇÊ ÈÚÏ', + DB_ERROR_NOSUCHFIELD => 'áíÓ åäÇáß ÍÞá ÈåÐÇ ÇáÇÓã', + DB_ERROR_NOSUCHTABLE => 'áíÓ åäÇáß ÌÏæá ÈåÐÇ ÇáÇÓã', + DB_ERROR_NOT_CAPABLE => 'ÞÇÚÏÉ ÇáÈíÇäÇÊ ÇáãÑÊÈØ ÈåÇ ÛíÑ ÞÇÏÑÉ', + DB_ERROR_NOT_FOUND => 'áã íÊã ÅíÌÇÏå', + DB_ERROR_NOT_LOCKED => 'ÛíÑ ãÞÝæá', + DB_ERROR_SYNTAX => 'ÎØà Ýí ÇáÕíÛÉ', + DB_ERROR_UNSUPPORTED => 'ÛíÑ ãÏÚæã', + DB_ERROR_VALUE_COUNT_ON_ROW => 'ÚÏÏ ÇáÞíã Ýí ÇáÓÌá', + DB_ERROR_INVALID_DSN => 'DSN ÛíÑ ÕÍíÍ', + DB_ERROR_CONNECT_FAILED => 'ÝÔá ÚãáíÉ ÇáÅÊÕÇá', + 0 => 'áíÓ åäÇáß ÃÎØÇÁ', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'ÇáÈíÇäÇÊ ÇáãÒæÏÉ ÛíÑ ßÇÝíÉ', + DB_ERROR_EXTENSION_NOT_FOUND=> 'áã íÊã ÅíÌÇÏ ÇáÅÖÇÝÉ ÇáãÊÚáÞÉ', + DB_ERROR_NOSUCHDB => 'áíÓ åäÇáß ÞÇÚÏÉ ÈíÇäÇÊ ÈåÐÇ ÇáÇÓã', + DB_ERROR_ACCESS_VIOLATION => 'ÓãÇÍíÇÊ ÛíÑ ßÇÝíÉ' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bg.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bg.inc.php new file mode 100644 index 00000000..ee307c13 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bg.inc.php @@ -0,0 +1,37 @@ + +*/ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'bg', + DB_ERROR => 'íåèçâåñòíà ãðåøêà', + DB_ERROR_ALREADY_EXISTS => 'âå÷å ñúùåñòâóâà', + DB_ERROR_CANNOT_CREATE => 'íå ìîæå äà áúäå ñúçäàäåíà', + DB_ERROR_CANNOT_DELETE => 'íå ìîæå äà áúäå èçòðèòà', + DB_ERROR_CANNOT_DROP => 'íå ìîæå äà áúäå óíèùîæåíà', + DB_ERROR_CONSTRAINT => 'íàðóøåíî óñëîâèå', + DB_ERROR_DIVZERO => 'äåëåíèå íà íóëà', + DB_ERROR_INVALID => 'íåïðàâèëíî', + DB_ERROR_INVALID_DATE => 'íåêîðåêòíà äàòà èëè ÷àñ', + DB_ERROR_INVALID_NUMBER => 'íåâàëèäåí íîìåð', + DB_ERROR_MISMATCH => 'ïîãðåøíà óïîòðåáà', + DB_ERROR_NODBSELECTED => 'íå å èçáðàíà áàçà äàííè', + DB_ERROR_NOSUCHFIELD => 'íåñúùåñòâóâàùî ïîëå', + DB_ERROR_NOSUCHTABLE => 'íåñúùåñòâóâàùà òàáëèöà', + DB_ERROR_NOT_CAPABLE => 'DB backend not capable', + DB_ERROR_NOT_FOUND => 'íå å íàìåðåíà', + DB_ERROR_NOT_LOCKED => 'íå å çàêëþ÷åíà', + DB_ERROR_SYNTAX => 'ãðåøåí ñèíòàêñèñ', + DB_ERROR_UNSUPPORTED => 'íå ñå ïîääúðæà', + DB_ERROR_VALUE_COUNT_ON_ROW => 'íåêîðåêòåí áðîé êîëîíè â ðåäà', + DB_ERROR_INVALID_DSN => 'íåâàëèäåí DSN', + DB_ERROR_CONNECT_FAILED => 'âðúçêàòà íå ìîæå äà áúäå îñúùåñòâåíà', + 0 => 'íÿìà ãðåøêè', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'ïðåäîñòàâåíèòå äàííè ñà íåäîñòàòú÷íè', + DB_ERROR_EXTENSION_NOT_FOUND=> 'ðàçøèðåíèåòî íå å íàìåðåíî', + DB_ERROR_NOSUCHDB => 'íåñúùåñòâóâàùà áàçà äàííè', + DB_ERROR_ACCESS_VIOLATION => 'íÿìàòå äîñòàòú÷íî ïðàâà' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bgutf8.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bgutf8.inc.php new file mode 100644 index 00000000..5281ed53 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-bgutf8.inc.php @@ -0,0 +1,37 @@ + +*/ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'bgutf8', + DB_ERROR => 'неизвеÑтна грешка', + DB_ERROR_ALREADY_EXISTS => 'вече ÑъщеÑтвува', + DB_ERROR_CANNOT_CREATE => 'не може да бъде Ñъздадена', + DB_ERROR_CANNOT_DELETE => 'не може да бъде изтрита', + DB_ERROR_CANNOT_DROP => 'не може да бъде унищожена', + DB_ERROR_CONSTRAINT => 'нарушено уÑловие', + DB_ERROR_DIVZERO => 'деление на нула', + DB_ERROR_INVALID => 'неправилно', + DB_ERROR_INVALID_DATE => 'некоректна дата или чаÑ', + DB_ERROR_INVALID_NUMBER => 'невалиден номер', + DB_ERROR_MISMATCH => 'погрешна употреба', + DB_ERROR_NODBSELECTED => 'не е избрана база данни', + DB_ERROR_NOSUCHFIELD => 'неÑъщеÑтвуващо поле', + DB_ERROR_NOSUCHTABLE => 'неÑъщеÑтвуваща таблица', + DB_ERROR_NOT_CAPABLE => 'DB backend not capable', + DB_ERROR_NOT_FOUND => 'не е намерена', + DB_ERROR_NOT_LOCKED => 'не е заключена', + DB_ERROR_SYNTAX => 'грешен ÑинтакÑиÑ', + DB_ERROR_UNSUPPORTED => 'не Ñе поддържа', + DB_ERROR_VALUE_COUNT_ON_ROW => 'некоректен брой колони в реда', + DB_ERROR_INVALID_DSN => 'невалиден DSN', + DB_ERROR_CONNECT_FAILED => 'връзката не може да бъде оÑъщеÑтвена', + 0 => 'нÑма грешки', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'предоÑтавените данни Ñа недоÑтатъчни', + DB_ERROR_EXTENSION_NOT_FOUND=> 'разширението не е намерено', + DB_ERROR_NOSUCHDB => 'неÑъщеÑтвуваща база данни', + DB_ERROR_ACCESS_VIOLATION => 'нÑмате доÑтатъчно права' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ca.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ca.inc.php new file mode 100644 index 00000000..3640ebd0 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ca.inc.php @@ -0,0 +1,34 @@ + 'ca', + DB_ERROR => 'error desconegut', + DB_ERROR_ALREADY_EXISTS => 'ja existeix', + DB_ERROR_CANNOT_CREATE => 'no es pot crear', + DB_ERROR_CANNOT_DELETE => 'no es pot esborrar', + DB_ERROR_CANNOT_DROP => 'no es pot eliminar', + DB_ERROR_CONSTRAINT => 'violació de constraint', + DB_ERROR_DIVZERO => 'divisió per zero', + DB_ERROR_INVALID => 'no és vàlid', + DB_ERROR_INVALID_DATE => 'la data o l\'hora no són vàlides', + DB_ERROR_INVALID_NUMBER => 'el nombre no és vàlid', + DB_ERROR_MISMATCH => 'no hi ha coincidència', + DB_ERROR_NODBSELECTED => 'cap base de dades seleccionada', + DB_ERROR_NOSUCHFIELD => 'camp inexistent', + DB_ERROR_NOSUCHTABLE => 'taula inexistent', + DB_ERROR_NOT_CAPABLE => 'l\'execució secundària de DB no pot', + DB_ERROR_NOT_FOUND => 'no trobat', + DB_ERROR_NOT_LOCKED => 'no blocat', + DB_ERROR_SYNTAX => 'error de sintaxi', + DB_ERROR_UNSUPPORTED => 'no suportat', + DB_ERROR_VALUE_COUNT_ON_ROW => 'el nombre de columnes no coincideix amb el nombre de valors en la fila', + DB_ERROR_INVALID_DSN => 'el DSN no és vàlid', + DB_ERROR_CONNECT_FAILED => 'connexió fallida', + 0 => 'cap error', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'les dades subministrades són insuficients', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extensió no trobada', + DB_ERROR_NOSUCHDB => 'base de dades inexistent', + DB_ERROR_ACCESS_VIOLATION => 'permisos insuficients' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cn.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cn.inc.php new file mode 100644 index 00000000..eb8c7de5 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cn.inc.php @@ -0,0 +1,35 @@ + 'cn', + DB_ERROR => 'δ֪´íÎó', + DB_ERROR_ALREADY_EXISTS => 'ÒѾ­´æÔÚ', + DB_ERROR_CANNOT_CREATE => '²»ÄÜ´´½¨', + DB_ERROR_CANNOT_DELETE => '²»ÄÜɾ³ý', + DB_ERROR_CANNOT_DROP => '²»ÄܶªÆú', + DB_ERROR_CONSTRAINT => 'Ô¼ÊøÏÞÖÆ', + DB_ERROR_DIVZERO => '±»0³ý', + DB_ERROR_INVALID => 'ÎÞЧ', + DB_ERROR_INVALID_DATE => 'ÎÞЧµÄÈÕÆÚ»òÕßʱ¼ä', + DB_ERROR_INVALID_NUMBER => 'ÎÞЧµÄÊý×Ö', + DB_ERROR_MISMATCH => '²»Æ¥Åä', + DB_ERROR_NODBSELECTED => 'ûÓÐÊý¾Ý¿â±»Ñ¡Ôñ', + DB_ERROR_NOSUCHFIELD => 'ûÓÐÏàÓ¦µÄ×Ö¶Î', + DB_ERROR_NOSUCHTABLE => 'ûÓÐÏàÓ¦µÄ±í', + DB_ERROR_NOT_CAPABLE => 'Êý¾Ý¿âºǫ́²»¼æÈÝ', + DB_ERROR_NOT_FOUND => 'ûÓз¢ÏÖ', + DB_ERROR_NOT_LOCKED => 'ûÓб»Ëø¶¨', + DB_ERROR_SYNTAX => 'Óï·¨´íÎó', + DB_ERROR_UNSUPPORTED => '²»Ö§³Ö', + DB_ERROR_VALUE_COUNT_ON_ROW => 'ÔÚÐÐÉÏÀÛ¼ÆÖµ', + DB_ERROR_INVALID_DSN => 'ÎÞЧµÄÊý¾ÝÔ´ (DSN)', + DB_ERROR_CONNECT_FAILED => 'Á¬½Óʧ°Ü', + 0 => 'ûÓдíÎó', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'ÌṩµÄÊý¾Ý²»ÄÜ·ûºÏÒªÇó', + DB_ERROR_EXTENSION_NOT_FOUND=> 'À©Õ¹Ã»Óб»·¢ÏÖ', + DB_ERROR_NOSUCHDB => 'ûÓÐÏàÓ¦µÄÊý¾Ý¿â', + DB_ERROR_ACCESS_VIOLATION => 'ûÓкÏÊʵÄȨÏÞ' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cz.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cz.inc.php new file mode 100644 index 00000000..2424c244 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-cz.inc.php @@ -0,0 +1,40 @@ + + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'cz', + DB_ERROR => 'neznámá chyba', + DB_ERROR_ALREADY_EXISTS => 'ji? existuje', + DB_ERROR_CANNOT_CREATE => 'nelze vytvo?it', + DB_ERROR_CANNOT_DELETE => 'nelze smazat', + DB_ERROR_CANNOT_DROP => 'nelze odstranit', + DB_ERROR_CONSTRAINT => 'poru?ení omezující podmínky', + DB_ERROR_DIVZERO => 'd?lení nulou', + DB_ERROR_INVALID => 'neplatné', + DB_ERROR_INVALID_DATE => 'neplatné datum nebo ?as', + DB_ERROR_INVALID_NUMBER => 'neplatné ?íslo', + DB_ERROR_MISMATCH => 'nesouhlasí', + DB_ERROR_NODBSELECTED => '?ádná databáze není vybrána', + DB_ERROR_NOSUCHFIELD => 'pole nenalezeno', + DB_ERROR_NOSUCHTABLE => 'tabulka nenalezena', + DB_ERROR_NOT_CAPABLE => 'nepodporováno', + DB_ERROR_NOT_FOUND => 'nenalezeno', + DB_ERROR_NOT_LOCKED => 'nezam?eno', + DB_ERROR_SYNTAX => 'syntaktická chyba', + DB_ERROR_UNSUPPORTED => 'nepodporováno', + DB_ERROR_VALUE_COUNT_ON_ROW => '', + DB_ERROR_INVALID_DSN => 'neplatné DSN', + DB_ERROR_CONNECT_FAILED => 'p?ipojení selhalo', + 0 => 'bez chyb', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'málo zdrojových dat', + DB_ERROR_EXTENSION_NOT_FOUND=> 'roz?í?ení nenalezeno', + DB_ERROR_NOSUCHDB => 'databáze neexistuje', + DB_ERROR_ACCESS_VIOLATION => 'nedostate?ná práva' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-da.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-da.inc.php new file mode 100644 index 00000000..ca0e72d6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-da.inc.php @@ -0,0 +1,33 @@ + 'da', + DB_ERROR => 'ukendt fejl', + DB_ERROR_ALREADY_EXISTS => 'eksisterer allerede', + DB_ERROR_CANNOT_CREATE => 'kan ikke oprette', + DB_ERROR_CANNOT_DELETE => 'kan ikke slette', + DB_ERROR_CANNOT_DROP => 'kan ikke droppe', + DB_ERROR_CONSTRAINT => 'begrænsning krænket', + DB_ERROR_DIVZERO => 'division med nul', + DB_ERROR_INVALID => 'ugyldig', + DB_ERROR_INVALID_DATE => 'ugyldig dato eller klokkeslet', + DB_ERROR_INVALID_NUMBER => 'ugyldigt tal', + DB_ERROR_MISMATCH => 'mismatch', + DB_ERROR_NODBSELECTED => 'ingen database valgt', + DB_ERROR_NOSUCHFIELD => 'felt findes ikke', + DB_ERROR_NOSUCHTABLE => 'tabel findes ikke', + DB_ERROR_NOT_CAPABLE => 'DB backend opgav', + DB_ERROR_NOT_FOUND => 'ikke fundet', + DB_ERROR_NOT_LOCKED => 'ikke låst', + DB_ERROR_SYNTAX => 'syntaksfejl', + DB_ERROR_UNSUPPORTED => 'ikke understøttet', + DB_ERROR_VALUE_COUNT_ON_ROW => 'resulterende antal felter svarer ikke til forespørgslens antal felter', + DB_ERROR_INVALID_DSN => 'ugyldig DSN', + DB_ERROR_CONNECT_FAILED => 'tilslutning mislykkedes', + 0 => 'ingen fejl', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'utilstrækkelige data angivet', + DB_ERROR_EXTENSION_NOT_FOUND=> 'udvidelse ikke fundet', + DB_ERROR_NOSUCHDB => 'database ikke fundet', + DB_ERROR_ACCESS_VIOLATION => 'utilstrækkelige rettigheder' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-de.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-de.inc.php new file mode 100644 index 00000000..244cb2f6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-de.inc.php @@ -0,0 +1,33 @@ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'de', + DB_ERROR => 'Unbekannter Fehler', + DB_ERROR_ALREADY_EXISTS => 'existiert bereits', + DB_ERROR_CANNOT_CREATE => 'kann nicht erstellen', + DB_ERROR_CANNOT_DELETE => 'kann nicht löschen', + DB_ERROR_CANNOT_DROP => 'Tabelle oder Index konnte nicht gelöscht werden', + DB_ERROR_CONSTRAINT => 'Constraint Verletzung', + DB_ERROR_DIVZERO => 'Division durch Null', + DB_ERROR_INVALID => 'ung¨ltig', + DB_ERROR_INVALID_DATE => 'ung¨ltiges Datum oder Zeit', + DB_ERROR_INVALID_NUMBER => 'ung¨ltige Zahl', + DB_ERROR_MISMATCH => 'Unverträglichkeit', + DB_ERROR_NODBSELECTED => 'keine Dantebank ausgewählt', + DB_ERROR_NOSUCHFIELD => 'Feld nicht vorhanden', + DB_ERROR_NOSUCHTABLE => 'Tabelle nicht vorhanden', + DB_ERROR_NOT_CAPABLE => 'Funktion nicht installiert', + DB_ERROR_NOT_FOUND => 'nicht gefunden', + DB_ERROR_NOT_LOCKED => 'nicht gesperrt', + DB_ERROR_SYNTAX => 'Syntaxfehler', + DB_ERROR_UNSUPPORTED => 'nicht Unterst¨tzt', + DB_ERROR_VALUE_COUNT_ON_ROW => 'Anzahl der zur¨ckgelieferten Felder entspricht nicht der Anzahl der Felder in der Abfrage', + DB_ERROR_INVALID_DSN => 'ung¨ltiger DSN', + DB_ERROR_CONNECT_FAILED => 'Verbindung konnte nicht hergestellt werden', + 0 => 'kein Fehler', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'Nicht gen¨gend Daten geliefert', + DB_ERROR_EXTENSION_NOT_FOUND=> 'erweiterung nicht gefunden', + DB_ERROR_NOSUCHDB => 'keine Datenbank', + DB_ERROR_ACCESS_VIOLATION => 'ungen¨gende Rechte' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-en.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-en.inc.php new file mode 100644 index 00000000..6895995e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-en.inc.php @@ -0,0 +1,33 @@ + 'en', + DB_ERROR => 'unknown error', + DB_ERROR_ALREADY_EXISTS => 'already exists', + DB_ERROR_CANNOT_CREATE => 'can not create', + DB_ERROR_CANNOT_DELETE => 'can not delete', + DB_ERROR_CANNOT_DROP => 'can not drop', + DB_ERROR_CONSTRAINT => 'constraint violation', + DB_ERROR_DIVZERO => 'division by zero', + DB_ERROR_INVALID => 'invalid', + DB_ERROR_INVALID_DATE => 'invalid date or time', + DB_ERROR_INVALID_NUMBER => 'invalid number', + DB_ERROR_MISMATCH => 'mismatch', + DB_ERROR_NODBSELECTED => 'no database selected', + DB_ERROR_NOSUCHFIELD => 'no such field', + DB_ERROR_NOSUCHTABLE => 'no such table', + DB_ERROR_NOT_CAPABLE => 'DB backend not capable', + DB_ERROR_NOT_FOUND => 'not found', + DB_ERROR_NOT_LOCKED => 'not locked', + DB_ERROR_SYNTAX => 'syntax error', + DB_ERROR_UNSUPPORTED => 'not supported', + DB_ERROR_VALUE_COUNT_ON_ROW => 'value count on row', + DB_ERROR_INVALID_DSN => 'invalid DSN', + DB_ERROR_CONNECT_FAILED => 'connect failed', + 0 => 'no error', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'insufficient data supplied', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extension not found', + DB_ERROR_NOSUCHDB => 'no such database', + DB_ERROR_ACCESS_VIOLATION => 'insufficient permissions' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-es.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-es.inc.php new file mode 100644 index 00000000..1e0afbb4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-es.inc.php @@ -0,0 +1,33 @@ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'es', + DB_ERROR => 'error desconocido', + DB_ERROR_ALREADY_EXISTS => 'ya existe', + DB_ERROR_CANNOT_CREATE => 'imposible crear', + DB_ERROR_CANNOT_DELETE => 'imposible borrar', + DB_ERROR_CANNOT_DROP => 'imposible hacer drop', + DB_ERROR_CONSTRAINT => 'violacion de constraint', + DB_ERROR_DIVZERO => 'division por cero', + DB_ERROR_INVALID => 'invalido', + DB_ERROR_INVALID_DATE => 'fecha u hora invalida', + DB_ERROR_INVALID_NUMBER => 'numero invalido', + DB_ERROR_MISMATCH => 'error', + DB_ERROR_NODBSELECTED => 'no hay base de datos seleccionada', + DB_ERROR_NOSUCHFIELD => 'campo invalido', + DB_ERROR_NOSUCHTABLE => 'tabla no existe', + DB_ERROR_NOT_CAPABLE => 'capacidad invalida para esta DB', + DB_ERROR_NOT_FOUND => 'no encontrado', + DB_ERROR_NOT_LOCKED => 'no bloqueado', + DB_ERROR_SYNTAX => 'error de sintaxis', + DB_ERROR_UNSUPPORTED => 'no soportado', + DB_ERROR_VALUE_COUNT_ON_ROW => 'la cantidad de columnas no corresponden a la cantidad de valores', + DB_ERROR_INVALID_DSN => 'DSN invalido', + DB_ERROR_CONNECT_FAILED => 'fallo la conexion', + 0 => 'sin error', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'insuficientes datos', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extension no encontrada', + DB_ERROR_NOSUCHDB => 'base de datos no encontrada', + DB_ERROR_ACCESS_VIOLATION => 'permisos insuficientes' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-esperanto.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-esperanto.inc.php new file mode 100644 index 00000000..16ca00e2 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-esperanto.inc.php @@ -0,0 +1,35 @@ + 'eo', + DB_ERROR => 'nekonata eraro', + DB_ERROR_ALREADY_EXISTS => 'jam ekzistas', + DB_ERROR_CANNOT_CREATE => 'maleblas krei', + DB_ERROR_CANNOT_DELETE => 'maleblas elimini', + DB_ERROR_CANNOT_DROP => 'maleblas elimini (drop)', + DB_ERROR_CONSTRAINT => 'rompo de kondicxoj de provo', + DB_ERROR_DIVZERO => 'divido per 0 (nul)', + DB_ERROR_INVALID => 'malregule', + DB_ERROR_INVALID_DATE => 'malregula dato kaj tempo', + DB_ERROR_INVALID_NUMBER => 'malregula nombro', + DB_ERROR_MISMATCH => 'eraro', + DB_ERROR_NODBSELECTED => 'datumbazo ne elektita', + DB_ERROR_NOSUCHFIELD => 'ne ekzistas kampo', + DB_ERROR_NOSUCHTABLE => 'ne ekzistas tabelo', + DB_ERROR_NOT_CAPABLE => 'DBMS ne povas', + DB_ERROR_NOT_FOUND => 'ne trovita', + DB_ERROR_NOT_LOCKED => 'ne blokita', + DB_ERROR_SYNTAX => 'sintaksa eraro', + DB_ERROR_UNSUPPORTED => 'ne apogata', + DB_ERROR_VALUE_COUNT_ON_ROW => 'nombrilo de valoroj en linio', + DB_ERROR_INVALID_DSN => 'malregula DSN-o', + DB_ERROR_CONNECT_FAILED => 'konekto malsukcesa', + 0 => 'cxio bone', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'ne suficxe da datumo', + DB_ERROR_EXTENSION_NOT_FOUND=> 'etendo ne trovita', + DB_ERROR_NOSUCHDB => 'datumbazo ne ekzistas', + DB_ERROR_ACCESS_VIOLATION => 'ne suficxe da rajto por atingo' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fa.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fa.inc.php new file mode 100644 index 00000000..55943135 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fa.inc.php @@ -0,0 +1,35 @@ + */ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'fa', + DB_ERROR => 'خطای ناشناخته', + DB_ERROR_ALREADY_EXISTS => 'وجود دارد', + DB_ERROR_CANNOT_CREATE => 'امکان create وجود ندارد', + DB_ERROR_CANNOT_DELETE => 'امکان حذ٠وجود ندارد', + DB_ERROR_CANNOT_DROP => 'امکان drop وجود ندارد', + DB_ERROR_CONSTRAINT => 'نقض شرط', + DB_ERROR_DIVZERO => 'تقسیم بر صÙر', + DB_ERROR_INVALID => 'نامعتبر', + DB_ERROR_INVALID_DATE => 'زمان یا تاریخ نامعتبر', + DB_ERROR_INVALID_NUMBER => 'عدد نامعتبر', + DB_ERROR_MISMATCH => 'عدم مطابقت', + DB_ERROR_NODBSELECTED => 'بانک اطلاعاتی انتخاب نشده است', + DB_ERROR_NOSUCHFIELD => 'چنین ستونی وجود ندارد', + DB_ERROR_NOSUCHTABLE => 'چنین جدولی وجود ندارد', + DB_ERROR_NOT_CAPABLE => 'backend بانک اطلاعاتی قادر نیست', + DB_ERROR_NOT_FOUND => 'پیدا نشد', + DB_ERROR_NOT_LOCKED => 'Ù‚ÙÙ„ نشده', + DB_ERROR_SYNTAX => 'خطای دستوری', + DB_ERROR_UNSUPPORTED => 'پشتیبانی نمی شود', + DB_ERROR_VALUE_COUNT_ON_ROW => 'شمارش مقادیر روی ردیÙ', + DB_ERROR_INVALID_DSN => 'DSN نامعتبر', + DB_ERROR_CONNECT_FAILED => 'ارتباط برقرار نشد', + 0 => 'بدون خطا', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'داده ناکاÙÛŒ است', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extension پیدا نشد', + DB_ERROR_NOSUCHDB => 'چنین بانک اطلاعاتی وجود ندارد', + DB_ERROR_ACCESS_VIOLATION => 'حق دسترسی ناکاÙÛŒ' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fr.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fr.inc.php new file mode 100644 index 00000000..066a2a5e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-fr.inc.php @@ -0,0 +1,33 @@ + 'fr', + DB_ERROR => 'erreur inconnue', + DB_ERROR_ALREADY_EXISTS => 'existe déjà', + DB_ERROR_CANNOT_CREATE => 'crétion impossible', + DB_ERROR_CANNOT_DELETE => 'effacement impossible', + DB_ERROR_CANNOT_DROP => 'suppression impossible', + DB_ERROR_CONSTRAINT => 'violation de contrainte', + DB_ERROR_DIVZERO => 'division par zéro', + DB_ERROR_INVALID => 'invalide', + DB_ERROR_INVALID_DATE => 'date ou heure invalide', + DB_ERROR_INVALID_NUMBER => 'nombre invalide', + DB_ERROR_MISMATCH => 'erreur de concordance', + DB_ERROR_NODBSELECTED => 'pas de base de donnéessélectionnée', + DB_ERROR_NOSUCHFIELD => 'nom de colonne invalide', + DB_ERROR_NOSUCHTABLE => 'table ou vue inexistante', + DB_ERROR_NOT_CAPABLE => 'fonction optionnelle non installée', + DB_ERROR_NOT_FOUND => 'pas trouvé', + DB_ERROR_NOT_LOCKED => 'non verrouillé', + DB_ERROR_SYNTAX => 'erreur de syntaxe', + DB_ERROR_UNSUPPORTED => 'non supporté', + DB_ERROR_VALUE_COUNT_ON_ROW => 'valeur insérée trop grande pour colonne', + DB_ERROR_INVALID_DSN => 'DSN invalide', + DB_ERROR_CONNECT_FAILED => 'échec à la connexion', + 0 => "pas d'erreur", // DB_OK + DB_ERROR_NEED_MORE_DATA => 'données fournies insuffisantes', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extension non trouvée', + DB_ERROR_NOSUCHDB => 'base de données inconnue', + DB_ERROR_ACCESS_VIOLATION => 'droits insuffisants' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-hu.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-hu.inc.php new file mode 100644 index 00000000..d6f0ef82 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-hu.inc.php @@ -0,0 +1,34 @@ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'hu', + DB_ERROR => 'ismeretlen hiba', + DB_ERROR_ALREADY_EXISTS => 'már létezik', + DB_ERROR_CANNOT_CREATE => 'nem sikerült létrehozni', + DB_ERROR_CANNOT_DELETE => 'nem sikerült törölni', + DB_ERROR_CANNOT_DROP => 'nem sikerült eldobni', + DB_ERROR_CONSTRAINT => 'szabályok megszegése', + DB_ERROR_DIVZERO => 'osztás nullával', + DB_ERROR_INVALID => 'érvénytelen', + DB_ERROR_INVALID_DATE => 'érvénytelen dátum vagy idõ', + DB_ERROR_INVALID_NUMBER => 'érvénytelen szám', + DB_ERROR_MISMATCH => 'nem megfelelõ', + DB_ERROR_NODBSELECTED => 'nincs kiválasztott adatbázis', + DB_ERROR_NOSUCHFIELD => 'nincs ilyen mezõ', + DB_ERROR_NOSUCHTABLE => 'nincs ilyen tábla', + DB_ERROR_NOT_CAPABLE => 'DB backend nem támogatja', + DB_ERROR_NOT_FOUND => 'nem található', + DB_ERROR_NOT_LOCKED => 'nincs lezárva', + DB_ERROR_SYNTAX => 'szintaktikai hiba', + DB_ERROR_UNSUPPORTED => 'nem támogatott', + DB_ERROR_VALUE_COUNT_ON_ROW => 'soron végzett érték számlálás', + DB_ERROR_INVALID_DSN => 'hibás DSN', + DB_ERROR_CONNECT_FAILED => 'sikertelen csatlakozás', + 0 => 'nincs hiba', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'túl kevés az adat', + DB_ERROR_EXTENSION_NOT_FOUND=> 'bõvítmény nem található', + DB_ERROR_NOSUCHDB => 'nincs ilyen adatbázis', + DB_ERROR_ACCESS_VIOLATION => 'nincs jogosultság' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-it.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-it.inc.php new file mode 100644 index 00000000..20c5b93b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-it.inc.php @@ -0,0 +1,34 @@ + 'it', + DB_ERROR => 'errore sconosciuto', + DB_ERROR_ALREADY_EXISTS => 'esiste già', + DB_ERROR_CANNOT_CREATE => 'non posso creare', + DB_ERROR_CANNOT_DELETE => 'non posso cancellare', + DB_ERROR_CANNOT_DROP => 'non posso eliminare', + DB_ERROR_CONSTRAINT => 'violazione constraint', + DB_ERROR_DIVZERO => 'divisione per zero', + DB_ERROR_INVALID => 'non valido', + DB_ERROR_INVALID_DATE => 'data od ora non valida', + DB_ERROR_INVALID_NUMBER => 'numero non valido', + DB_ERROR_MISMATCH => 'diversi', + DB_ERROR_NODBSELECTED => 'nessun database selezionato', + DB_ERROR_NOSUCHFIELD => 'nessun campo trovato', + DB_ERROR_NOSUCHTABLE => 'nessuna tabella trovata', + DB_ERROR_NOT_CAPABLE => 'DB backend non abilitato', + DB_ERROR_NOT_FOUND => 'non trovato', + DB_ERROR_NOT_LOCKED => 'non bloccato', + DB_ERROR_SYNTAX => 'errore di sintassi', + DB_ERROR_UNSUPPORTED => 'non supportato', + DB_ERROR_VALUE_COUNT_ON_ROW => 'valore inserito troppo grande per una colonna', + DB_ERROR_INVALID_DSN => 'DSN non valido', + DB_ERROR_CONNECT_FAILED => 'connessione fallita', + 0 => 'nessun errore', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'dati inseriti insufficienti', + DB_ERROR_EXTENSION_NOT_FOUND=> 'estensione non trovata', + DB_ERROR_NOSUCHDB => 'database non trovato', + DB_ERROR_ACCESS_VIOLATION => 'permessi insufficienti' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-nl.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-nl.inc.php new file mode 100644 index 00000000..abe77b52 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-nl.inc.php @@ -0,0 +1,33 @@ + 'nl', + DB_ERROR => 'onbekende fout', + DB_ERROR_ALREADY_EXISTS => 'bestaat al', + DB_ERROR_CANNOT_CREATE => 'kan niet aanmaken', + DB_ERROR_CANNOT_DELETE => 'kan niet wissen', + DB_ERROR_CANNOT_DROP => 'kan niet verwijderen', + DB_ERROR_CONSTRAINT => 'constraint overtreding', + DB_ERROR_DIVZERO => 'poging tot delen door nul', + DB_ERROR_INVALID => 'ongeldig', + DB_ERROR_INVALID_DATE => 'ongeldige datum of tijd', + DB_ERROR_INVALID_NUMBER => 'ongeldig nummer', + DB_ERROR_MISMATCH => 'is incorrect', + DB_ERROR_NODBSELECTED => 'geen database geselecteerd', + DB_ERROR_NOSUCHFIELD => 'onbekend veld', + DB_ERROR_NOSUCHTABLE => 'onbekende tabel', + DB_ERROR_NOT_CAPABLE => 'database systeem is niet tot uitvoer in staat', + DB_ERROR_NOT_FOUND => 'niet gevonden', + DB_ERROR_NOT_LOCKED => 'niet vergrendeld', + DB_ERROR_SYNTAX => 'syntaxis fout', + DB_ERROR_UNSUPPORTED => 'niet ondersteund', + DB_ERROR_VALUE_COUNT_ON_ROW => 'waarde telling op rij', + DB_ERROR_INVALID_DSN => 'ongeldige DSN', + DB_ERROR_CONNECT_FAILED => 'connectie mislukt', + 0 => 'geen fout', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'onvoldoende data gegeven', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extensie niet gevonden', + DB_ERROR_NOSUCHDB => 'onbekende database', + DB_ERROR_ACCESS_VIOLATION => 'onvoldoende rechten' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pl.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pl.inc.php new file mode 100644 index 00000000..9d9e3906 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pl.inc.php @@ -0,0 +1,35 @@ + + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'pl', + DB_ERROR => 'niezidentyfikowany b³±d', + DB_ERROR_ALREADY_EXISTS => 'ju¿ istniej±', + DB_ERROR_CANNOT_CREATE => 'nie mo¿na stworzyæ', + DB_ERROR_CANNOT_DELETE => 'nie mo¿na usun±æ', + DB_ERROR_CANNOT_DROP => 'nie mo¿na porzuciæ', + DB_ERROR_CONSTRAINT => 'pogwa³cenie uprawnieñ', + DB_ERROR_DIVZERO => 'dzielenie przez zero', + DB_ERROR_INVALID => 'b³êdny', + DB_ERROR_INVALID_DATE => 'b³êdna godzina lub data', + DB_ERROR_INVALID_NUMBER => 'b³êdny numer', + DB_ERROR_MISMATCH => 'niedopasowanie', + DB_ERROR_NODBSELECTED => 'baza danych nie zosta³a wybrana', + DB_ERROR_NOSUCHFIELD => 'nie znaleziono pola', + DB_ERROR_NOSUCHTABLE => 'nie znaleziono tabeli', + DB_ERROR_NOT_CAPABLE => 'nie zdolny', + DB_ERROR_NOT_FOUND => 'nie znaleziono', + DB_ERROR_NOT_LOCKED => 'nie zakmniêty', + DB_ERROR_SYNTAX => 'b³±d sk³adni', + DB_ERROR_UNSUPPORTED => 'nie obs³uguje', + DB_ERROR_VALUE_COUNT_ON_ROW => 'warto¶æ liczona w szeregu', + DB_ERROR_INVALID_DSN => 'b³êdny DSN', + DB_ERROR_CONNECT_FAILED => 'po³±czenie nie zosta³o zrealizowane', + 0 => 'brak b³êdów', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'niedostateczna ilo¶æ informacji', + DB_ERROR_EXTENSION_NOT_FOUND=> 'nie znaleziono rozszerzenia', + DB_ERROR_NOSUCHDB => 'nie znaleziono bazy', + DB_ERROR_ACCESS_VIOLATION => 'niedostateczne uprawnienia' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pt-br.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pt-br.inc.php new file mode 100644 index 00000000..cd28f7e5 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-pt-br.inc.php @@ -0,0 +1,35 @@ + 'pt-br', + DB_ERROR => 'erro desconhecido', + DB_ERROR_ALREADY_EXISTS => 'já existe', + DB_ERROR_CANNOT_CREATE => 'impossível criar', + DB_ERROR_CANNOT_DELETE => 'impossível excluír', + DB_ERROR_CANNOT_DROP => 'impossível remover', + DB_ERROR_CONSTRAINT => 'violação do confinamente', + DB_ERROR_DIVZERO => 'divisão por zero', + DB_ERROR_INVALID => 'inválido', + DB_ERROR_INVALID_DATE => 'data ou hora inválida', + DB_ERROR_INVALID_NUMBER => 'número inválido', + DB_ERROR_MISMATCH => 'erro', + DB_ERROR_NODBSELECTED => 'nenhum banco de dados selecionado', + DB_ERROR_NOSUCHFIELD => 'campo inválido', + DB_ERROR_NOSUCHTABLE => 'tabela inexistente', + DB_ERROR_NOT_CAPABLE => 'capacidade inválida para este BD', + DB_ERROR_NOT_FOUND => 'não encontrado', + DB_ERROR_NOT_LOCKED => 'não bloqueado', + DB_ERROR_SYNTAX => 'erro de sintaxe', + DB_ERROR_UNSUPPORTED => +'não suportado', + DB_ERROR_VALUE_COUNT_ON_ROW => 'a quantidade de colunas não corresponde ao de valores', + DB_ERROR_INVALID_DSN => 'DSN inválido', + DB_ERROR_CONNECT_FAILED => 'falha na conexão', + 0 => 'sem erro', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'dados insuficientes', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extensão não encontrada', + DB_ERROR_NOSUCHDB => 'banco de dados não encontrado', + DB_ERROR_ACCESS_VIOLATION => 'permissão insuficiente' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ro.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ro.inc.php new file mode 100644 index 00000000..bcd7d132 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ro.inc.php @@ -0,0 +1,35 @@ + */ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'ro', + DB_ERROR => 'eroare necunoscuta', + DB_ERROR_ALREADY_EXISTS => 'deja exista', + DB_ERROR_CANNOT_CREATE => 'nu se poate creea', + DB_ERROR_CANNOT_DELETE => 'nu se poate sterge', + DB_ERROR_CANNOT_DROP => 'nu se poate executa drop', + DB_ERROR_CONSTRAINT => 'violare de constrain', + DB_ERROR_DIVZERO => 'se divide la zero', + DB_ERROR_INVALID => 'invalid', + DB_ERROR_INVALID_DATE => 'data sau timp invalide', + DB_ERROR_INVALID_NUMBER => 'numar invalid', + DB_ERROR_MISMATCH => 'nepotrivire-mismatch', + DB_ERROR_NODBSELECTED => 'nu exista baza de date selectata', + DB_ERROR_NOSUCHFIELD => 'camp inexistent', + DB_ERROR_NOSUCHTABLE => 'tabela inexistenta', + DB_ERROR_NOT_CAPABLE => 'functie optionala neinstalata', + DB_ERROR_NOT_FOUND => 'negasit', + DB_ERROR_NOT_LOCKED => 'neblocat', + DB_ERROR_SYNTAX => 'eroare de sintaxa', + DB_ERROR_UNSUPPORTED => 'nu e suportat', + DB_ERROR_VALUE_COUNT_ON_ROW => 'valoare prea mare pentru coloana', + DB_ERROR_INVALID_DSN => 'DSN invalid', + DB_ERROR_CONNECT_FAILED => 'conectare esuata', + 0 => 'fara eroare', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'data introduse insuficiente', + DB_ERROR_EXTENSION_NOT_FOUND=> 'extensie negasita', + DB_ERROR_NOSUCHDB => 'nu exista baza de date', + DB_ERROR_ACCESS_VIOLATION => 'permisiuni insuficiente' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ru1251.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ru1251.inc.php new file mode 100644 index 00000000..3a20538a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-ru1251.inc.php @@ -0,0 +1,35 @@ + 'ru1251', + DB_ERROR => 'íåèçâåñòíàÿ îøèáêà', + DB_ERROR_ALREADY_EXISTS => 'óæå ñóùåñòâóåò', + DB_ERROR_CANNOT_CREATE => 'íåâîçìîæíî ñîçäàòü', + DB_ERROR_CANNOT_DELETE => 'íåâîçìîæíî óäàëèòü', + DB_ERROR_CANNOT_DROP => 'íåâîçìîæíî óäàëèòü (drop)', + DB_ERROR_CONSTRAINT => 'íàðóøåíèå óñëîâèé ïðîâåðêè', + DB_ERROR_DIVZERO => 'äåëåíèå íà 0', + DB_ERROR_INVALID => 'íåïðàâèëüíî', + DB_ERROR_INVALID_DATE => 'íåêîððåêòíàÿ äàòà èëè âðåìÿ', + DB_ERROR_INVALID_NUMBER => 'íåêîððåêòíîå ÷èñëî', + DB_ERROR_MISMATCH => 'îøèáêà', + DB_ERROR_NODBSELECTED => 'ÁÄ íå âûáðàíà', + DB_ERROR_NOSUCHFIELD => 'íå ñóùåñòâóåò ïîëå', + DB_ERROR_NOSUCHTABLE => 'íå ñóùåñòâóåò òàáëèöà', + DB_ERROR_NOT_CAPABLE => 'ÑÓÁÄ íå â ñîñòîÿíèè', + DB_ERROR_NOT_FOUND => 'íå íàéäåíî', + DB_ERROR_NOT_LOCKED => 'íå çàáëîêèðîâàíî', + DB_ERROR_SYNTAX => 'ñèíòàêñè÷åñêàÿ îøèáêà', + DB_ERROR_UNSUPPORTED => 'íå ïîääåðæèâàåòñÿ', + DB_ERROR_VALUE_COUNT_ON_ROW => 'ñ÷åò÷èê çíà÷åíèé â ñòðîêå', + DB_ERROR_INVALID_DSN => 'íåïðàâèëüíàÿ DSN', + DB_ERROR_CONNECT_FAILED => 'ñîåäèíåíèå íåóñïåøíî', + 0 => 'íåò îøèáêè', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'ïðåäîñòàâëåíî íåäîñòàòî÷íî äàííûõ', + DB_ERROR_EXTENSION_NOT_FOUND=> 'ðàñøèðåíèå íå íàéäåíî', + DB_ERROR_NOSUCHDB => 'íå ñóùåñòâóåò ÁÄ', + DB_ERROR_ACCESS_VIOLATION => 'íåäîñòàòî÷íî ïðàâ äîñòóïà' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-sv.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-sv.inc.php new file mode 100644 index 00000000..a9fd6981 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-sv.inc.php @@ -0,0 +1,33 @@ + 'en', + DB_ERROR => 'Okänt fel', + DB_ERROR_ALREADY_EXISTS => 'finns redan', + DB_ERROR_CANNOT_CREATE => 'kan inte skapa', + DB_ERROR_CANNOT_DELETE => 'kan inte ta bort', + DB_ERROR_CANNOT_DROP => 'kan inte släppa', + DB_ERROR_CONSTRAINT => 'begränsning kränkt', + DB_ERROR_DIVZERO => 'division med noll', + DB_ERROR_INVALID => 'ogiltig', + DB_ERROR_INVALID_DATE => 'ogiltigt datum eller tid', + DB_ERROR_INVALID_NUMBER => 'ogiltigt tal', + DB_ERROR_MISMATCH => 'felaktig matchning', + DB_ERROR_NODBSELECTED => 'ingen databas vald', + DB_ERROR_NOSUCHFIELD => 'inget sådant fält', + DB_ERROR_NOSUCHTABLE => 'ingen sådan tabell', + DB_ERROR_NOT_CAPABLE => 'DB backend klarar det inte', + DB_ERROR_NOT_FOUND => 'finns inte', + DB_ERROR_NOT_LOCKED => 'inte låst', + DB_ERROR_SYNTAX => 'syntaxfel', + DB_ERROR_UNSUPPORTED => 'stöds ej', + DB_ERROR_VALUE_COUNT_ON_ROW => 'värde räknat på rad', + DB_ERROR_INVALID_DSN => 'ogiltig DSN', + DB_ERROR_CONNECT_FAILED => 'anslutning misslyckades', + 0 => 'inget fel', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'otillräckligt med data angivet', + DB_ERROR_EXTENSION_NOT_FOUND=> 'utökning hittades ej', + DB_ERROR_NOSUCHDB => 'ingen sådan databas', + DB_ERROR_ACCESS_VIOLATION => 'otillräckliga rättigheter' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-uk1251.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-uk1251.inc.php new file mode 100644 index 00000000..675016d1 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb-uk1251.inc.php @@ -0,0 +1,35 @@ + 'uk1251', + DB_ERROR => 'íåâ³äîìà ïîìèëêà', + DB_ERROR_ALREADY_EXISTS => 'âæå ³ñíóº', + DB_ERROR_CANNOT_CREATE => 'íåìîæëèâî ñòâîðèòè', + DB_ERROR_CANNOT_DELETE => 'íåìîæëèâî âèäàëèòè', + DB_ERROR_CANNOT_DROP => 'íåìîæëèâî çíèùèòè (drop)', + DB_ERROR_CONSTRAINT => 'ïîðóøåííÿ óìîâ ïåðåâ³ðêè', + DB_ERROR_DIVZERO => 'ä³ëåííÿ íà 0', + DB_ERROR_INVALID => 'íåïðàâèëüíî', + DB_ERROR_INVALID_DATE => 'íåïðàâèëüíà äàòà ÷è ÷àñ', + DB_ERROR_INVALID_NUMBER => 'íåïðàâèëüíå ÷èñëî', + DB_ERROR_MISMATCH => 'ïîìèëêà', + DB_ERROR_NODBSELECTED => 'íå âèáðàíî ÁÄ', + DB_ERROR_NOSUCHFIELD => 'íå ³ñíóº ïîëå', + DB_ERROR_NOSUCHTABLE => 'íå ³ñíóº òàáëèöÿ', + DB_ERROR_NOT_CAPABLE => 'ÑÓÁÄ íå â ñòàí³', + DB_ERROR_NOT_FOUND => 'íå çíàéäåíî', + DB_ERROR_NOT_LOCKED => 'íå çàáëîêîâàíî', + DB_ERROR_SYNTAX => 'ñèíòàêñè÷íà ïîìèëêà', + DB_ERROR_UNSUPPORTED => 'íå ï³äòðèìóºòüñÿ', + DB_ERROR_VALUE_COUNT_ON_ROW => 'ðàõ³âíèê çíà÷åíü â ñòð³÷ö³', + DB_ERROR_INVALID_DSN => 'íåïðàâèëüíà DSN', + DB_ERROR_CONNECT_FAILED => 'ç\'ºäíàííÿ íåóñï³øíå', + 0 => 'âñå ãàðàçä', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'íàäàíî íåäîñòàòíüî äàíèõ', + DB_ERROR_EXTENSION_NOT_FOUND=> 'ðîçøèðåííÿ íå çíàéäåíî', + DB_ERROR_NOSUCHDB => 'íå ³ñíóº ÁÄ', + DB_ERROR_ACCESS_VIOLATION => 'íåäîñòàòíüî ïðàâ äîñòóïà' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb_th.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb_th.inc.php new file mode 100644 index 00000000..3fdd9970 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/lang/adodb_th.inc.php @@ -0,0 +1,33 @@ + +$ADODB_LANG_ARRAY = array ( + 'LANG' => 'th', + DB_ERROR => 'error ไม่รู้สาเหตุ', + DB_ERROR_ALREADY_EXISTS => 'มีà¹?ล้ว', + DB_ERROR_CANNOT_CREATE => 'สร้างไม่ได้', + DB_ERROR_CANNOT_DELETE => 'ลบไม่ได้', + DB_ERROR_CANNOT_DROP => 'drop ไม่ได้', + DB_ERROR_CONSTRAINT => 'constraint violation', + DB_ERROR_DIVZERO => 'หาà¸?ด้วยสูà¸?', + DB_ERROR_INVALID => 'ไม่ valid', + DB_ERROR_INVALID_DATE => 'วันที่ เวลา ไม่ valid', + DB_ERROR_INVALID_NUMBER => 'เลขไม่ valid', + DB_ERROR_MISMATCH => 'mismatch', + DB_ERROR_NODBSELECTED => 'ไม่ได้เลือà¸?à¸?านข้อมูล', + DB_ERROR_NOSUCHFIELD => 'ไม่มีฟีลด์นี้', + DB_ERROR_NOSUCHTABLE => 'ไม่มีตารางนี้', + DB_ERROR_NOT_CAPABLE => 'DB backend not capable', + DB_ERROR_NOT_FOUND => 'ไม่พบ', + DB_ERROR_NOT_LOCKED => 'ไม่ได้ล๊อà¸?', + DB_ERROR_SYNTAX => 'ผิด syntax', + DB_ERROR_UNSUPPORTED => 'ไม่ support', + DB_ERROR_VALUE_COUNT_ON_ROW => 'value count on row', + DB_ERROR_INVALID_DSN => 'invalid DSN', + DB_ERROR_CONNECT_FAILED => 'ไม่สามารถ connect', + 0 => 'no error', // DB_OK + DB_ERROR_NEED_MORE_DATA => 'ข้อมูลไม่เพียงพอ', + DB_ERROR_EXTENSION_NOT_FOUND=> 'ไม่พบ extension', + DB_ERROR_NOSUCHDB => 'ไม่มีข้อมูลนี้', + DB_ERROR_ACCESS_VIOLATION => 'permissions ไม่พอ' +); +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/license.txt b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/license.txt new file mode 100755 index 00000000..2353871c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/license.txt @@ -0,0 +1,182 @@ +ADOdb is dual licensed using BSD and LGPL. + +In plain English, you do not need to distribute your application in source code form, nor do you need to distribute ADOdb source code, provided you follow the rest of terms of the BSD license. + +For more info about ADOdb, visit http://adodb.sourceforge.net/ + +BSD Style-License +================= + +Copyright (c) 2000, 2001, 2002, 2003, 2004 John Lim +All rights reserved. + +Redistribution and use in source and binary forms, with or without modification, +are permitted provided that the following conditions are met: + +Redistributions of source code must retain the above copyright notice, this list +of conditions and the following disclaimer. + +Redistributions in binary form must reproduce the above copyright notice, this list +of conditions and the following disclaimer in the documentation and/or other materials +provided with the distribution. + +Neither the name of the John Lim nor the names of its contributors may be used to +endorse or promote products derived from this software without specific prior written +permission. + +DISCLAIMER: +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY +EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL +JOHN LIM OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, +EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +========================================================== +GNU LESSER GENERAL PUBLIC LICENSE +Version 2.1, February 1999 + +Copyright (C) 1991, 1999 Free Software Foundation, Inc. +59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +Everyone is permitted to copy and distribute verbatim copies +of this license document, but changing it is not allowed. + +[This is the first released version of the Lesser GPL. It also counts + as the successor of the GNU Library Public License, version 2, hence + the version number 2.1.] + + +Preamble +The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public Licenses are intended to guarantee your freedom to share and change free software--to make sure the software is free for all its users. + +This license, the Lesser General Public License, applies to some specially designated software packages--typically libraries--of the Free Software Foundation and other authors who decide to use it. You can use it too, but we suggest you first think carefully about whether this license or the ordinary General Public License is the better strategy to use in any particular case, based on the explanations below. + +When we speak of free software, we are referring to freedom of use, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for this service if you wish); that you receive source code or can get it if you want it; that you can change the software and use pieces of it in new free programs; and that you are informed that you can do these things. + +To protect your rights, we need to make restrictions that forbid distributors to deny you these rights or to ask you to surrender these rights. These restrictions translate to certain responsibilities for you if you distribute copies of the library or if you modify it. + +For example, if you distribute copies of the library, whether gratis or for a fee, you must give the recipients all the rights that we gave you. You must make sure that they, too, receive or can get the source code. If you link other code with the library, you must provide complete object files to the recipients, so that they can relink them with the library after making changes to the library and recompiling it. And you must show them these terms so they know their rights. + +We protect your rights with a two-step method: (1) we copyright the library, and (2) we offer you this license, which gives you legal permission to copy, distribute and/or modify the library. + +To protect each distributor, we want to make it very clear that there is no warranty for the free library. Also, if the library is modified by someone else and passed on, the recipients should know that what they have is not the original version, so that the original author's reputation will not be affected by problems that might be introduced by others. + +Finally, software patents pose a constant threat to the existence of any free program. We wish to make sure that a company cannot effectively restrict the users of a free program by obtaining a restrictive license from a patent holder. Therefore, we insist that any patent license obtained for a version of the library must be consistent with the full freedom of use specified in this license. + +Most GNU software, including some libraries, is covered by the ordinary GNU General Public License. This license, the GNU Lesser General Public License, applies to certain designated libraries, and is quite different from the ordinary General Public License. We use this license for certain libraries in order to permit linking those libraries into non-free programs. + +When a program is linked with a library, whether statically or using a shared library, the combination of the two is legally speaking a combined work, a derivative of the original library. The ordinary General Public License therefore permits such linking only if the entire combination fits its criteria of freedom. The Lesser General Public License permits more lax criteria for linking other code with the library. + +We call this license the "Lesser" General Public License because it does Less to protect the user's freedom than the ordinary General Public License. It also provides other free software developers Less of an advantage over competing non-free programs. These disadvantages are the reason we use the ordinary General Public License for many libraries. However, the Lesser license provides advantages in certain special circumstances. + +For example, on rare occasions, there may be a special need to encourage the widest possible use of a certain library, so that it becomes a de-facto standard. To achieve this, non-free programs must be allowed to use the library. A more frequent case is that a free library does the same job as widely used non-free libraries. In this case, there is little to gain by limiting the free library to free software only, so we use the Lesser General Public License. + +In other cases, permission to use a particular library in non-free programs enables a greater number of people to use a large body of free software. For example, permission to use the GNU C Library in non-free programs enables many more people to use the whole GNU operating system, as well as its variant, the GNU/Linux operating system. + +Although the Lesser General Public License is Less protective of the users' freedom, it does ensure that the user of a program that is linked with the Library has the freedom and the wherewithal to run that program using a modified version of the Library. + +The precise terms and conditions for copying, distribution and modification follow. Pay close attention to the difference between a "work based on the library" and a "work that uses the library". The former contains code derived from the library, whereas the latter must be combined with the library in order to run. + + +TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION +0. This License Agreement applies to any software library or other program which contains a notice placed by the copyright holder or other authorized party saying it may be distributed under the terms of this Lesser General Public License (also called "this License"). Each licensee is addressed as "you". + +A "library" means a collection of software functions and/or data prepared so as to be conveniently linked with application programs (which use some of those functions and data) to form executables. + +The "Library", below, refers to any such software library or work which has been distributed under these terms. A "work based on the Library" means either the Library or any derivative work under copyright law: that is to say, a work containing the Library or a portion of it, either verbatim or with modifications and/or translated straightforwardly into another language. (Hereinafter, translation is included without limitation in the term "modification".) + +"Source code" for a work means the preferred form of the work for making modifications to it. For a library, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the library. + +Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running a program using the Library is not restricted, and output from such a program is covered only if its contents constitute a work based on the Library (independent of the use of the Library in a tool for writing it). Whether that is true depends on what the Library does and what the program that uses the Library does. + +1. You may copy and distribute verbatim copies of the Library's complete source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and distribute a copy of this License along with the Library. + +You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. + +2. You may modify your copy or copies of the Library or any portion of it, thus forming a work based on the Library, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: + + +a) The modified work must itself be a software library. +b) You must cause the files modified to carry prominent notices stating that you changed the files and the date of any change. +c) You must cause the whole of the work to be licensed at no charge to all third parties under the terms of this License. +d) If a facility in the modified Library refers to a function or a table of data to be supplied by an application program that uses the facility, other than as an argument passed when the facility is invoked, then you must make a good faith effort to ensure that, in the event an application does not supply such function or table, the facility still operates, and performs whatever part of its purpose remains meaningful. +(For example, a function in a library to compute square roots has a purpose that is entirely well-defined independent of the application. Therefore, Subsection 2d requires that any application-supplied function or table used by this function must be optional: if the application does not supply it, the square root function must still compute square roots.) + +These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Library, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Library, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Library. + +In addition, mere aggregation of another work not based on the Library with the Library (or with a work based on the Library) on a volume of a storage or distribution medium does not bring the other work under the scope of this License. + +3. You may opt to apply the terms of the ordinary GNU General Public License instead of this License to a given copy of the Library. To do this, you must alter all the notices that refer to this License, so that they refer to the ordinary GNU General Public License, version 2, instead of to this License. (If a newer version than version 2 of the ordinary GNU General Public License has appeared, then you can specify that version instead if you wish.) Do not make any other change in these notices. + +Once this change is made in a given copy, it is irreversible for that copy, so the ordinary GNU General Public License applies to all subsequent copies and derivative works made from that copy. + +This option is useful when you wish to copy part of the code of the Library into a program that is not a library. + +4. You may copy and distribute the Library (or a portion or derivative of it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange. + +If distribution of object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place satisfies the requirement to distribute the source code, even though third parties are not compelled to copy the source along with the object code. + +5. A program that contains no derivative of any portion of the Library, but is designed to work with the Library by being compiled or linked with it, is called a "work that uses the Library". Such a work, in isolation, is not a derivative work of the Library, and therefore falls outside the scope of this License. + +However, linking a "work that uses the Library" with the Library creates an executable that is a derivative of the Library (because it contains portions of the Library), rather than a "work that uses the library". The executable is therefore covered by this License. Section 6 states terms for distribution of such executables. + +When a "work that uses the Library" uses material from a header file that is part of the Library, the object code for the work may be a derivative work of the Library even though the source code is not. Whether this is true is especially significant if the work can be linked without the Library, or if the work is itself a library. The threshold for this to be true is not precisely defined by law. + +If such an object file uses only numerical parameters, data structure layouts and accessors, and small macros and small inline functions (ten lines or less in length), then the use of the object file is unrestricted, regardless of whether it is legally a derivative work. (Executables containing this object code plus portions of the Library will still fall under Section 6.) + +Otherwise, if the work is a derivative of the Library, you may distribute the object code for the work under the terms of Section 6. Any executables containing that work also fall under Section 6, whether or not they are linked directly with the Library itself. + +6. As an exception to the Sections above, you may also combine or link a "work that uses the Library" with the Library to produce a work containing portions of the Library, and distribute that work under terms of your choice, provided that the terms permit modification of the work for the customer's own use and reverse engineering for debugging such modifications. + +You must give prominent notice with each copy of the work that the Library is used in it and that the Library and its use are covered by this License. You must supply a copy of this License. If the work during execution displays copyright notices, you must include the copyright notice for the Library among them, as well as a reference directing the user to the copy of this License. Also, you must do one of these things: + + +a) Accompany the work with the complete corresponding machine-readable source code for the Library including whatever changes were used in the work (which must be distributed under Sections 1 and 2 above); and, if the work is an executable linked with the Library, with the complete machine-readable "work that uses the Library", as object code and/or source code, so that the user can modify the Library and then relink to produce a modified executable containing the modified Library. (It is understood that the user who changes the contents of definitions files in the Library will not necessarily be able to recompile the application to use the modified definitions.) +b) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (1) uses at run time a copy of the library already present on the user's computer system, rather than copying library functions into the executable, and (2) will operate properly with a modified version of the library, if the user installs one, as long as the modified version is interface-compatible with the version that the work was made with. +c) Accompany the work with a written offer, valid for at least three years, to give the same user the materials specified in Subsection 6a, above, for a charge no more than the cost of performing this distribution. +d) If distribution of the work is made by offering access to copy from a designated place, offer equivalent access to copy the above specified materials from the same place. +e) Verify that the user has already received a copy of these materials or that you have already sent this user a copy. +For an executable, the required form of the "work that uses the Library" must include any data and utility programs needed for reproducing the executable from it. However, as a special exception, the materials to be distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable. + +It may happen that this requirement contradicts the license restrictions of other proprietary libraries that do not normally accompany the operating system. Such a contradiction means you cannot use both them and the Library together in an executable that you distribute. + +7. You may place library facilities that are a work based on the Library side-by-side in a single library together with other library facilities not covered by this License, and distribute such a combined library, provided that the separate distribution of the work based on the Library and of the other library facilities is otherwise permitted, and provided that you do these two things: + + +a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities. This must be distributed under the terms of the Sections above. +b) Give prominent notice with the combined library of the fact that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. +8. You may not copy, modify, sublicense, link with, or distribute the Library except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense, link with, or distribute the Library is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. + +9. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Library or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Library (or any work based on the Library), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Library or works based on it. + +10. Each time you redistribute the Library (or any work based on the Library), the recipient automatically receives a license from the original licensor to copy, distribute, link with or modify the Library subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties with this License. + +11. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Library at all. For example, if a patent license would not permit royalty-free redistribution of the Library by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Library. + +If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply, and the section as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. + +This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. + +12. If the distribution and/or use of the Library is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Library under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. + +13. The Free Software Foundation may publish revised and/or new versions of the Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Library does not specify a license version number, you may choose any version ever published by the Free Software Foundation. + +14. If you wish to incorporate parts of the Library into other free programs whose distribution conditions are incompatible with these, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally. + +NO WARRANTY + +15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + +16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + + +END OF TERMS AND CONDITIONS \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/readme.txt b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/readme.txt new file mode 100755 index 00000000..97bdd9ea --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/readme.txt @@ -0,0 +1,62 @@ +>> ADODB Library for PHP4 + +(c) 2000-2004 John Lim (jlim@natsoft.com.my) + +Released under both BSD and GNU Lesser GPL library license. +This means you can use it in proprietary products. + + +>> Introduction + +PHP's database access functions are not standardised. This creates a +need for a database class library to hide the differences between the +different databases (encapsulate the differences) so we can easily +switch databases. + +We currently support MySQL, Interbase, Sybase, PostgreSQL, Oracle, +Microsoft SQL server, Foxpro ODBC, Access ODBC, Informix, DB2, +Sybase SQL Anywhere, generic ODBC and Microsoft's ADO. + +We hope more people will contribute drivers to support other databases. + + +>> Documentation and Examples + +Refer to the adodb/docs directory for full documentation and examples. +There is also a tutorial tute.htm that contrasts ADODB code with +mysql code. + + +>>> Files +Adodb.inc.php is the main file. You need to include only this file. + +Adodb-*.inc.php are the database specific driver code. + +Test.php contains a list of test commands to exercise the class library. + +Adodb-session.php is the PHP4 session handling code. + +Testdatabases.inc.php contains the list of databases to apply the tests on. + +Benchmark.php is a simple benchmark to test the throughput of a simple SELECT +statement for databases described in testdatabases.inc.php. The benchmark +tables are created in test.php. + +readme.htm is the main documentation. + +tute.htm is the tutorial. + + +>> More Info + +For more information, including installation see readme.htm +or visit + http://adodb.sourceforge.net/ + + +>> Feature Requests and Bug Reports + +Email to jlim@natsoft.com.my + + + \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/toexport.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/toexport.inc.php new file mode 100644 index 00000000..6975b51a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/toexport.inc.php @@ -0,0 +1,134 @@ +FieldTypesArray(); + reset($fieldTypes); + $i = 0; + while(list(,$o) = each($fieldTypes)) { + + $v = ($o) ? $o->name : 'Field'.($i++); + if ($escquote) $v = str_replace($quote,$escquotequote,$v); + $v = strip_tags(str_replace("\n", $replaceNewLine, str_replace("\r\n",$replaceNewLine,str_replace($sep,$sepreplace,$v)))); + $elements[] = $v; + + } + $s .= implode($sep, $elements).$NEWLINE; + } + $hasNumIndex = isset($rs->fields[0]); + + $line = 0; + $max = $rs->FieldCount(); + + while (!$rs->EOF) { + $elements = array(); + $i = 0; + + if ($hasNumIndex) { + for ($j=0; $j < $max; $j++) { + $v = $rs->fields[$j]; + if (!is_object($v)) $v = trim($v); + else $v = 'Object'; + if ($escquote) $v = str_replace($quote,$escquotequote,$v); + $v = strip_tags(str_replace("\n", $replaceNewLine, str_replace("\r\n",$replaceNewLine,str_replace($sep,$sepreplace,$v)))); + + if (strpos($v,$sep) !== false || strpos($v,$quote) !== false) $elements[] = "$quote$v$quote"; + else $elements[] = $v; + } + } else { // ASSOCIATIVE ARRAY + foreach($rs->fields as $v) { + if ($escquote) $v = str_replace($quote,$escquotequote,trim($v)); + $v = strip_tags(str_replace("\n", $replaceNewLine, str_replace("\r\n",$replaceNewLine,str_replace($sep,$sepreplace,$v)))); + + if (strpos($v,$sep) !== false || strpos($v,$quote) !== false) $elements[] = "$quote$v$quote"; + else $elements[] = $v; + } + } + $s .= implode($sep, $elements).$NEWLINE; + $rs->MoveNext(); + $line += 1; + if ($fp && ($line % $BUFLINES) == 0) { + if ($fp === true) echo $s; + else fwrite($fp,$s); + $s = ''; + } + } + + if ($fp) { + if ($fp === true) echo $s; + else fwrite($fp,$s); + $s = ''; + } + + return $s; +} +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/tohtml.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/tohtml.inc.php new file mode 100644 index 00000000..76245661 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/adodb/tohtml.inc.php @@ -0,0 +1,201 @@ + +*/ + +// specific code for tohtml +GLOBAL $gSQLMaxRows,$gSQLBlockRows,$ADODB_ROUND; + +$ADODB_ROUND=4; // rounding +$gSQLMaxRows = 1000; // max no of rows to download +$gSQLBlockRows=20; // max no of rows per table block + +// RecordSet to HTML Table +//------------------------------------------------------------ +// Convert a recordset to a html table. Multiple tables are generated +// if the number of rows is > $gSQLBlockRows. This is because +// web browsers normally require the whole table to be downloaded +// before it can be rendered, so we break the output into several +// smaller faster rendering tables. +// +// $rs: the recordset +// $ztabhtml: the table tag attributes (optional) +// $zheaderarray: contains the replacement strings for the headers (optional) +// +// USAGE: +// include('adodb.inc.php'); +// $db = ADONewConnection('mysql'); +// $db->Connect('mysql','userid','password','database'); +// $rs = $db->Execute('select col1,col2,col3 from table'); +// rs2html($rs, 'BORDER=2', array('Title1', 'Title2', 'Title3')); +// $rs->Close(); +// +// RETURNS: number of rows displayed + + +function rs2html(&$rs,$ztabhtml=false,$zheaderarray=false,$htmlspecialchars=true,$echo = true) +{ +$s ='';$rows=0;$docnt = false; +GLOBAL $gSQLMaxRows,$gSQLBlockRows,$ADODB_ROUND; + + if (!$rs) { + printf(ADODB_BAD_RS,'rs2html'); + return false; + } + + if (! $ztabhtml) $ztabhtml = "BORDER='1' WIDTH='98%'"; + //else $docnt = true; + $typearr = array(); + $ncols = $rs->FieldCount(); + $hdr = "\n\n"; + for ($i=0; $i < $ncols; $i++) { + $field = $rs->FetchField($i); + if ($field) { + if ($zheaderarray) $fname = $zheaderarray[$i]; + else $fname = htmlspecialchars($field->name); + $typearr[$i] = $rs->MetaType($field->type,$field->max_length); + //print " $field->name $field->type $typearr[$i] "; + } else { + $fname = 'Field '.($i+1); + $typearr[$i] = 'C'; + } + if (strlen($fname)==0) $fname = ' '; + $hdr .= ""; + } + $hdr .= "\n"; + if ($echo) print $hdr."\n\n"; + else $html = $hdr; + + // smart algorithm - handles ADODB_FETCH_MODE's correctly by probing... + $numoffset = isset($rs->fields[0]) ||isset($rs->fields[1]) || isset($rs->fields[2]); + while (!$rs->EOF) { + + $s .= "\n"; + + for ($i=0; $i < $ncols; $i++) { + if ($i===0) $v=($numoffset) ? $rs->fields[0] : reset($rs->fields); + else $v = ($numoffset) ? $rs->fields[$i] : next($rs->fields); + + $type = $typearr[$i]; + switch($type) { + case 'D': + if (strpos($v,':') !== false); + else { + if (empty($v)) { + $s .= "\n"; + } else { + $s .= " \n"; + } + break; + } + case 'T': + if (empty($v)) $s .= "\n"; + else $s .= " \n"; + break; + + case 'N': + if (abs(abs($v) - round($v,0)) < 0.00000001) + $v = round($v); + else + $v = round($v,$ADODB_ROUND); + case 'I': + $vv = stripslashes((trim($v))); + if (strlen($vv) == 0) $vv .= ' '; + $s .= " \n"; + + break; + /* + case 'B': + if (substr($v,8,2)=="BM" ) $v = substr($v,8); + $mtime = substr(str_replace(' ','_',microtime()),2); + $tmpname = "tmp/".uniqid($mtime).getmypid(); + $fd = @fopen($tmpname,'a'); + @ftruncate($fd,0); + @fwrite($fd,$v); + @fclose($fd); + if (!function_exists ("mime_content_type")) { + function mime_content_type ($file) { + return exec("file -bi ".escapeshellarg($file)); + } + } + $t = mime_content_type($tmpname); + $s .= (substr($t,0,5)=="image") ? " \\n" : " \\n"; + break; + */ + + default: + if ($htmlspecialchars) $v = htmlspecialchars(trim($v)); + $v = trim($v); + if (strlen($v) == 0) $v = ' '; + $s .= " \n"; + + } + } // for + $s .= "\n\n"; + + $rows += 1; + if ($rows >= $gSQLMaxRows) { + $rows = "

Truncated at $gSQLMaxRows

"; + break; + } // switch + + $rs->MoveNext(); + + // additional EOF check to prevent a widow header + if (!$rs->EOF && $rows % $gSQLBlockRows == 0) { + + //if (connection_aborted()) break;// not needed as PHP aborts script, unlike ASP + if ($echo) print $s . "
$fname
  ".$rs->UserDate($v,"D d, M Y") ."   ".$rs->UserTimeStamp($v,"D d, M Y, H:i:s") ."".$vv ."$t$t". str_replace("\n",'
',stripslashes($v)) ."
\n\n"; + else $html .= $s ."\n\n"; + $s = $hdr; + } + } // while + + if ($echo) print $s."\n\n"; + else $html .= $s."\n\n"; + + if ($docnt) if ($echo) print "

".$rows." Rows

"; + + return ($echo) ? $rows : $html; + } + +// pass in 2 dimensional array +function arr2html(&$arr,$ztabhtml='',$zheaderarray='') +{ + if (!$ztabhtml) $ztabhtml = 'BORDER=1'; + + $s = "";//';print_r($arr); + + if ($zheaderarray) { + $s .= ''; + for ($i=0; $i\n"; + } else $s .= " \n"; + $s .= "\n\n"; + } + $s .= '
 
'; + print $s; +} + +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/decorator.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/decorator.inc.php new file mode 100644 index 00000000..c31e6181 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/decorator.inc.php @@ -0,0 +1,215 @@ + 2) { + $v = func_get_args(); + array_shift($v); + return new UrlDecorator($base, new ArrayMergeDecorator($v)); + } + return new UrlDecorator($base, $vars); +} + +function replace($str, $params) { + return new replaceDecorator($str, $params); +} + +// Resolving functions: + +function value(&$var, &$fields, $esc = null) { + if (is_a($var, 'Decorator')) { + $val = $var->value($fields); + } else { + $val =& $var; + } + + if (is_string($val)) { + switch($esc) { + case 'xml': + return strtr($val, array( + '&' => '&', + "'" => ''', '"' => '"', + '<' => '<', '>' => '>' + )); + case 'html': + return htmlentities($val, ENT_COMPAT, 'UTF-8'); + case 'url': + return urlencode($val); + } + } + return $val; +} + +function value_xml(&$var, &$fields) { + return value($var, $fields, 'xml'); +} + +function value_xml_attr($attr, &$var, &$fields) { + $val = value($var, $fields, 'xml'); + if (!empty($val)) + return " {$attr}=\"{$val}\""; + else + return ''; +} + +function value_url(&$var, &$fields) { + return value($var, $fields, 'url'); +} + +// Underlying classes: + +class Decorator +{ + function Decorator($value) { + $this->v = $value; + } + + function value($fields) { + return $this->v; + } +} + +class FieldDecorator extends Decorator +{ + function FieldDecorator($fieldName, $default = null) { + $this->f = $fieldName; + if ($default !== null) $this->d = $default; + } + + function value($fields) { + return isset($fields[$this->f]) ? value($fields[$this->f], $fields) : (isset($this->d) ? $this->d : null); + } +} + +class ArrayMergeDecorator extends Decorator +{ + function ArrayMergeDecorator($arrays) { + $this->m = $arrays; + } + + function value($fields) { + $accum = array(); + foreach($this->m as $var) { + $accum = array_merge($accum, value($var, $fields)); + } + return $accum; + } +} + +class ConcatDecorator extends Decorator +{ + function ConcatDecorator($values) { + $this->c = $values; + } + + function value($fields) { + $accum = ''; + foreach($this->c as $var) { + $accum .= value($var, $fields); + } + return trim($accum); + } +} + +class CallbackDecorator extends Decorator +{ + function CallbackDecorator($callback, $param = null) { + $this->fn = $callback; + $this->p = $param; + } + + function value($fields) { + return call_user_func($this->fn, $fields, $this->p); + } +} + +class IfEmptyDecorator extends Decorator +{ + function IfEmptyDecorator($value, $empty, $full = null) { + $this->v = $value; + $this->e = $empty; + if ($full !== null) $this->f = $full; + } + + function value($fields) { + $val = value($this->v, $fields); + if (empty($val)) + return value($this->e, $fields); + else + return isset($this->f) ? value($this->f, $fields) : $val; + } +} + +class UrlDecorator extends Decorator +{ + function UrlDecorator($base, $queryVars = null) { + $this->b = $base; + if ($queryVars !== null) + $this->q = $queryVars; + } + + function value($fields) { + $url = value($this->b, $fields); + + if ($url === false) return ''; + + if (!empty($this->q)) { + $queryVars = value($this->q, $fields); + + $sep = '?'; + foreach ($queryVars as $var => $value) { + $url .= $sep . value_url($var, $fields) . '=' . value_url($value, $fields); + $sep = '&'; + } + } + return $url; + } +} + +class replaceDecorator extends Decorator +{ + function replaceDecorator($str, $params) { + $this->s = $str; + $this->p = $params; + } + + function value($fields) { + $str = $this->s; + foreach ($this->p as $k => $v) { + $str = str_replace($k, value($v, $fields), $str); + } + return $str; + } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/errorhandler.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/errorhandler.inc.php new file mode 100644 index 00000000..11e93b2b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/errorhandler.inc.php @@ -0,0 +1,78 @@ +{$lang['strsqlerror']}
" . $misc->printVal($errmsg,'errormsg') . "

+

{$lang['strinstatement']}
" . $misc->printVal($sql) . "

+ "; + echo "
{$s}

\n"; + + break; + + case 'PCONNECT': + case 'CONNECT': + $_failed = true; + global $_reload_browser; + $_reload_browser = true; + unset($_SESSION['sharedUsername']); + unset($_SESSION['sharedPassword']); + unset($_SESSION['webdbLogin'][$_REQUEST['server']]); + $msg = $lang['strloginfailed']; + include('./login.php'); + exit; + break; + default: + $s = "$dbms error: [$errno: $errmsg] in $fn($p1, $p2)\n"; + echo "
{$s}

\n"; + break; + } + /* + * Log connection error somewhere + * 0 message is sent to PHP's system logger, using the Operating System's system + * logging mechanism or a file, depending on what the error_log configuration + * directive is set to. + * 1 message is sent by email to the address in the destination parameter. + * This is the only message type where the fourth parameter, extra_headers is used. + * This message type uses the same internal function as mail() does. + * 2 message is sent through the PHP debugging connection. + * This option is only available if remote debugging has been enabled. + * In this case, the destination parameter specifies the host name or IP address + * and optionally, port number, of the socket receiving the debug information. + * 3 message is appended to the file destination + */ + if (defined('ADODB_ERROR_LOG_TYPE')) { + $t = date('Y-m-d H:i:s'); + if (defined('ADODB_ERROR_LOG_DEST')) + error_log("($t) $s", ADODB_ERROR_LOG_TYPE, ADODB_ERROR_LOG_DEST); + else + error_log("($t) $s", ADODB_ERROR_LOG_TYPE); + } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/highlight.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/highlight.php new file mode 100644 index 00000000..74b93e30 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/highlight.php @@ -0,0 +1,1114 @@ +\\0'; + } + + $search[] = "/(\\bclass\s)/"; + $replace[] = '\\0'; + + return preg_replace($search, $replace, $text); +} + + +function preproc_replace($preproc, $text) +{ + foreach ($preproc as $proc) + { + $search[] = "/(\\s*#\s*$proc\\b)/"; + $replace[] = '\\0'; + } + + return preg_replace($search, $replace, $text); +} + + +function sch_syntax_helper($text) +{ + return $text; +} + + +function syntax_highlight_helper($text, $language) +{ + $preproc = array(); + $preproc["C++"] = array( + "if", "ifdef", "ifndef", "elif", "else", + "endif", "include", "define", "undef", "line", + "error", "pragma"); + $preproc["C89"] = & $preproc["C++"]; + $preproc["C"] = & $preproc["C89"]; + + $keywords = array( + "C++" => array( + "asm", "auto", "bool", "break", "case", + "catch", "char", /*class*/ "const", "const_cast", + "continue", "default", "delete", "do", "double", + "dynamic_cast", "else", "enum", "explicit", "export", + "extern", "false", "float", "for", "friend", + "goto", "if", "inline", "int", "long", + "mutable", "namespace", "new", "operator", "private", + "protected", "public", "register", "reinterpret_cast", "return", + "short", "signed", "sizeof", "static", "static_cast", + "struct", "switch", "template", "this", "throw", + "true", "try", "typedef", "typeid", "typename", + "union", "unsigned", "using", "virtual", "void", + "volatile", "wchar_t", "while"), + + "C89" => array( + "auto", "break", "case", "char", "const", + "continue", "default", "do", "double", "else", + "enum", "extern", "float", "for", "goto", + "if", "int", "long", "register", "return", + "short", "signed", "sizeof", "static", "struct", + "switch", "typedef", "union", "unsigned", "void", + "volatile", "while"), + + "C" => array( + "auto", "break", "case", "char", "const", + "continue", "default", "do", "double", "else", + "enum", "extern", "float", "for", "goto", + "if", "int", "long", "register", "return", + "short", "signed", "sizeof", "static", "struct", + "switch", "typedef", "union", "unsigned", "void", + "volatile", "while", "__restrict","_Bool"), + + "PHP" => array( + "and", "or", "xor", "__FILE__", "__LINE__", + "array", "as", "break", "case", "cfunction", + /*class*/ "const", "continue", "declare", "default", + "die", "do", "echo", "else", "elseif", + "empty", "enddeclare", "endfor", "endforeach", "endif", + "endswitch", "endwhile", "eval", "exit", "extends", + "for", "foreach", "function", "global", "if", + "include", "include_once", "isset", "list", "new", + "old_function", "print", "require", "require_once", "return", + "static", "switch", "unset", "use", "var", + "while", "__FUNCTION__", "__CLASS__"), + + "Perl" => array( + "-A", "-B", "-C", "-M", "-O", + "-R", "-S", "-T", "-W", "-X", + "-b", "-c", "-d", "-e", "-f", + "-g", "-k", "-l", "-o", "-p", + "-r", "-s", "-t", "-u", "-w", + "-x", "-z", "ARGV", "DATA", "ENV", + "SIG", "STDERR", "STDIN", "STDOUT", "atan2", + "bind", "binmode", "bless", "caller", "chdir", + "chmod", "chomp", "chop", "chown", "chr", + "chroot", "close", "closedir", "cmp", "connect", + "continue", "cos", "crypt", "dbmclose", "dbmopen", + "defined", "delete", "die", "do", "dump", + "each", "else", "elsif", "endgrent", "endhostent", + "endnetent", "endprotent", "endpwent", "endservent", "eof", + "eq", "eval", "exec", "exists", "exit", + "exp", "fcntl", "fileno", "flock", "for", + "foreach", "fork", "format", "formline", "ge", + "getc", "getgrent", "getgrid", "getgrnam", "gethostbyaddr", + "gethostbyname","gethostent", "getlogin", "getnetbyaddr", "getnetbyname", + "getnetent", "getpeername", "getpgrp", "getppid", "getpriority", + "getprotobyname","getprotobynumber","getprotoent","getpwent","getpwnam", + "getpwuid", "getservbyname","getservbyport","getservent","getsockname", + "getsockopt", "glob", "gmtime", "goto", "grep", + /*gt*/ "hex", "if", "import", "index", + "int", "ioctl", "join", "keys", "kill", + "last", "lc", "lcfirst", "le", "length", + "link", "listen", "local", "localtime", "log", + "lstat", /*lt*/ "m", "map", "mkdir", + "msgctl", "msgget", "msgrcv", "msgsnd", "my", + "ne", "next", "no", "oct", "open", + "opendir", "ord", "pack", "package", "pipe", + "pop", "pos", "print", "printf", "push", + "q", "qq", "quotemeta","qw", "qx", + "rand", "read", "readdir", "readlink", "recv", + "redo", "ref", "refname", "require", "reset", + "return", "reverse", "rewinddir","rindex", "rmdir", + "s", "scalar", "seek", "seekdir", "select", + "semctl", "semget", "semop", "send", "setgrent", + "sethostent", "setnetent", "setpgrp", "setpriority", "setprotoent", + "setpwent", "setservent", "setsockopt","shift", "shmctl", + "shmget", "shmread", "shmwrite", "shutdown", "sin", + "sleep", "socket", "socketpair","sort", "splice", + "split", "sprintf", "sqrt", "srand", "stat", + "study", "sub", "substr", "symlink", "syscall", + "sysopen", "sysread", "system", "syswrite", "tell", + "telldir", "tie", "tied", "time", "times", + "tr", "truncate", "uc", "ucfirst", "umask", + "undef", "unless", "unlink", "unpack", "unshift", + "untie", "until", "use", "utime", "values", + "vec", "wait", "waitpid", "wantarray", "warn", + "while", "write", "y", "or", "and", + "not"), + + "Java" => array( + "abstract", "boolean", "break", "byte", "case", + "catch", "char", /*class*/ "const", "continue", + "default", "do", "double", "else", "extends", + "final", "finally", "float", "for", "goto", + "if", "implements", "import", "instanceof", "int", + "interface", "long", "native", "new", "package", + "private", "protected", "public", "return", "short", + "static", "strictfp", "super", "switch", "synchronized", + "this", "throw", "throws", "transient", "try", + "void", "volatile", "while"), + + "VB" => array( + "AddressOf", "Alias", "And", "Any", "As", + "Binary", "Boolean", "ByRef", "Byte", "ByVal", + "Call", "Case", "CBool", "CByte", "CCur", + "CDate", "CDbl", "CInt", "CLng", "Close", + "Const", "CSng", "CStr", "Currency", "CVar", + "CVErr", "Date", "Debug", "Declare", "DefBool", + "DefByte", "DefCur", "DefDate", "DefDbl", "DefInt", + "DefLng", "DefObj", "DefSng", "DefStr", "DefVar", + "Dim", "Do", "Double", "Each", "Else", + "End", "Enum", "Eqv", "Erase", "Error", + "Event", "Exit", "For", "Friend", "Function", + "Get", "Get", "Global", "GoSub", "GoTo", + "If", "Imp", "Implements","In", "Input", + "Integer", "Is", "LBound", "Len", "Let", + "Lib", "Like", "Line", "Lock", "Long", + "Loop", "LSet", "Mod", "Name", "Next", + "Not", "Nothing", "Null", "Object", "On", + "Open", "Option Base 1","Option Compare Binary", + "Option Compare Database", "Option Compare Text", "Option Explicit", + "Option Private Module", "Optional", "Or", "Output", + "ParamArray", "Preserve", "Print", "Private", "Property", + "Public", "Put", "RaiseEvent","Random", "Read", + "ReDim", "Resume", "Return", "RSet", "Seek", + "Select", "Set", "Single", "Spc", "Static", + "Step", "Stop", "String", "Sub", "Tab", + "Then", "To", "Type", "UBound", "Unlock", + "Variant", "Wend", "While", "With", "WithEvents", + "Write", "Xor"), + + "C#" => array( + "abstract", "as", "base", "bool", "break", + "byte", "case", "catch", "char", "checked", + /*class*/ "const", "continue", "decimal", "default", + "delegate", "do", "double", "else", "enum", + "event", "explicit", "extern", "false", "finally", + "fixed", "float", "for", "foreach", "goto", + "if", "implicit", "in", "int", "interface", + "internal", "is", "lock", "long", "namespace", + "new", "null", "object", "operator", "out", + "override", "params", "private", "protected", "public", + "readonly", "ref", "return", "sbyte", "sealed", + "short", "sizeof", "stackalloc","static", "string", + "struct", "switch", "this", "throw", "true", + "try", "typeof", "uint", "ulong", "unchecked", + "unsafe", "ushort", "using", "virtual", "volatile", + "void", "while"), + + "Ruby" => array( + "alias", "and", "begin", "break", "case", + /*class*/ "def", "defined", "do", "else", + "elsif", "end", "ensure", "false", "for", + "if", "in", "module", "next", "module", + "next", "nil", "not", "or", "redo", + "rescue", "retry", "return", "self", "super", + "then", "true", "undef", "unless", "until", + "when", "while", "yield"), + + "Python" => array( + "and", "assert", "break", /*"class",*/ "continue", + "def", "del", "elif", "else", "except", + "exec", "finally", "for", "from", "global", + "if", "import", "in", "is", "lambda", + "not", "or", "pass", "print", "raise", + "return", "try", "while", "yield"), + + "Pascal" => array( + "Absolute", "Abstract", "All", "And", "And_then", + "Array", "Asm", "Begin", "Bindable", "Case", + /*"Class",*/ "Const", "Constructor","Destructor", "Div", + "Do", "Downto", "Else", "End", "Export", + "File", "For", "Function", "Goto", "If", + "Import", "Implementation","Inherited","In", "Inline", + "Interface", "Is", "Label", "Mod", "Module", + "Nil", "Not", "Object", "Of", "Only", + "Operator", "Or", "Or_else", "Otherwise", "Packed", + "Pow", "Procedure", "Program", "Property", "Protected", + "Qualified", "Record", "Repeat", "Restricted", "Set", + "Shl", "Shr", "Then", "To", "Type", + "Unit", "Until", "Uses", "Value", "Var", + "View", "Virtual", "While", "With", "Xor"), + + "mIRC" => array( + ), + + "PL/I" => array( + "A", "ABS", "ACOS", "%ACTIVATE", "ACTUALCOUNT", + "ADD", "ADDR", "ADDREL", "ALIGNED", "ALLOCATE", + "ALLOC", "ALLOCATION", "ALLOCN", "ANY", "ANYCONDITION", + "APPEND", "AREA", "ASIN", "ATAN", "ATAND", + "ATANH", "AUTOMATIC", "AUTO", "B", "B1", + "B2", "B3", "B4", "BACKUP_DATE", "BASED", + "BATCH", "BEGIN", "BINARY", "BIN", "BIT", + "BLOCK_BOUNDARY_FORMAT", "BLOCK_IO", "BLOCK_SIZE", "BOOL", + "BUCKET_SIZE", "BUILTIN", "BY", "BYTE", "BYTESIZE", + "CALL", "CANCEL_CONTROL_O", "CARRIAGE_RETURN_FORMAT", + "CEIL", "CHAR", "CHARACTER", "CLOSE", "COLLATE", "COLUMN", + "CONDITION", "CONTIGUOUS", "CONTIGUOUS_BEST_TRY", "CONTROLLED", + "CONVERSION", "COPY", "COS", "COSD", "COSH", + "CREATION_DATE", "CURRENT_POSITION", "DATE", + "DATETIME", "%DEACTIVATE", "DECIMAL", "DEC", "%DECLARE", + "%DCL", "DECLARE", "DCL", "DECODE", "DEFAULT_FILE_NAME", + "DEFERRED_WRITE", "DEFINED", "DEF", "DELETE", + "DESCRIPTOR", "%DICTIONARY", "DIMENSION","DIM", "DIRECT", + "DISPLAY", "DIVIDE", "%DO", "DO", "E", + "EDIT", "%ELSE", "ELSE", "EMPTY", "ENCODE", + "%END", "END", "ENDFILE", "ENDPAGE", "ENTRY", + "ENVIRONMENT", "ENV", "%ERROR", "ERROR", "EVERY", + "EXP", "EXPIRATION_DATE", "EXTEND", "EXTENSION_SIZE", + "EXTERNAL", "EXT", "F", "FAST_DELETE", "%FATAL", + "FILE", "FILE_ID", "FILE_ID_TO", "FILE_SIZE", + "FINISH", "FIXED", "FIXEDOVERFLOW", "FOFL", + "FIXED_CONTROL_FROM", "FIXED_CONTROL_SIZE", "FIXED_CONTROL_SIZE_TO", + "FIXED_CONTROL_TO", "FIXED_LENGTH_RECORDS", "FLOAT", + "FLOOR", "FLUSH", "FORMAT", "FREE", "FROM", + "GET", "GLOBALDEF", "GLOBALREF", "%GOTO", + "GOTO", "GO", "TO", "GROUP_PROTETION", "HBOUND", + "HIGH", "INDENT", "%IF", "IF", "IGNORE_LINE_MARKS", + "IN", "%INCLUDE", "INDEX", "INDEXED", "INDEX_NUMBER", + "%INFORM", "INFORM", "INITIAL", "INIT", "INITIAL_FILL", + "INPUT", "INT", "INTERNAL", "INTO", "KEY", + "KEYED", "KEYFROM", "KEYTO", "LABEL", "LBOUND", + "LEAVE", "LENGTH", "LIKE", "LINE", "LINENO", + "LINESIZE", "%LIST", "LIST", "LOCK_ON_READ", "LOCK_ON_WRITE", + "LOG", "LOG10", "LOG2", "LOW", "LTRIM", + "MAIN", "MANUAL_UNLOCKING", "MATCH_GREATER", + "MATCH_GREATER_EQUAL", "MATCH_NEXT", "MATCH_NEXT_EQUAL", + "MAX", "MAXIMUM_RECORD_NUMBER", "MAXIMUM_RECORD_SIZE", + "MAXLENGTH", "MEMBER", "MIN", "MOD", "MULTIBLOCK_COUNT", + "MULTIBUFFER_COUNT", "MULTIPLY", "NEXT_VOLUME", "%NOLIST", + "NOLOCK", "NONEXISTENT_RECORD", "NONRECURSIVE", "NONVARYING", + "NONVAR", "NORESCAN", "NO_ECHO", "NO_FILTER", "NO_SHARE", + "NULL", "OFFSET", "ON", "ONARGSLIST", "ONCHAR", + "ONCODE", "ONFILE", "ONKEY", "ONSOURCE", "OPEN", + "OPTIONAL", "OPTIONS", "OTHERWISE","OTHER", "OUTPUT", + "OVERFLOW", "OFL", "OWNER_GROUP", "OWNER_ID", + "OWNER_MEMBER", "OWNER_PROTECTION", "P", "%PAGE", + "PAGE", "PAGENO", "PAGESIZE", "PARAMETER", "PARM", + "PICTURE", "PIC", "POINTER", "PTR", "POSINT", + "POSITION", "POS", "PRECISION","PREC", "PRESENT", + "PRINT", "PRINTER_FORMAT", "%PROCEDURE", "%PROC", + "PROCEDURE", "PROC", "PROD", "PROMPT", "PURGE_TYPE_AHEAD", + "PUT", "R", "RANK", "READ", "READONLY", + "READ_AHEAD", "READ_CHECK", "READ_REGARDLESS", "RECORD", + "RECORD_ID", "RECORD_ID_ACCESS", "RECORD_ID_TO", "RECURSIVE", + "REFER", "REFERENCE", "RELEASE", "REPEAT", "%REPLACE", + "RESCAN", "RESIGNAL", "RETRIEVAL_POINTERS", "%RETURN", + "RETURN", "RETURNS", "REVERSE", "REVERT", "REVISION_DATE", + "REWIND", "REWIND_ON_CLOSE", "REWIND_ON_OPEN", + "REWRITE", "ROUND", "RTRIM", "%SBTTL", "SCALARVARYING", + "SEARCH", "SELECT", "SEQUENTIAL", "SEQL", + "SET", "SHARED_READ", "SHARED_WRITE", "SIGN", + "SIGNAL", "SIN", "SIND", "SINH", "SIZE", + "SKIP", "SNAP", "SOME", "SPACEBLOCK", "SPOOL", + "SQRT", "STATEMENT", "STATIC", "STOP", "STORAGE", + "STREAM", "STRING", "STRINGRANGE", "STRG", + "STRUCTURE", "SUBSCRIPTRANGE", "SUBRG", "SUBSTR", + "SUBTRACT", "SUM", "SUPERCEDE","SYSIN", "SYSPRINT", + "SYSTEM", "SYSTEM_PROTECTION", "TAB", "TAN", + "TAND", "TANH", "TEMPORARY","%THEN", "THEN", + "TIME", "TIMEOUT_PERIOD", "%TITLE", "TITLE", + "TO", "TRANSLATE", "TRIM", "TRUNC", "TRUNCATE", + "UNALIGNED", "UNAL", "UNDEFINED","UNDF", "UNDERFLOW", + "UFL", "UNION", "UNSPEC", "UNTIL", "UPDATE", + "USER_OPEN", "VALID", "VALUE", "VAL", "VARIABLE", + "VARIANT", "VARYING", "VAR", "VAXCONDITION", "VERIFY", + "WAIT_FOR_RECORD", "%WARN", "WARN", "WHEN", + "WHILE", "WORLD_PROTECTION", "WRITE", "WRITE_BEHIND", + "WRITE_CHECK", "X", "ZERODIVIDE"), + + "SQL" => array( + "abort", "abs", "absolute", "access", + "action", "ada", "add", "admin", + "after", "aggregate", "alias", "all", + "allocate", "alter", "analyse", "analyze", + "and", "any", "are", "array", + "as", "asc", "asensitive", "assertion", + "assignment", "asymmetric", "at", "atomic", + "authorization", "avg", "backward", "before", + "begin", "between", "bigint", "binary", + "bit", "bitvar", "bit_length", "blob", + "boolean", "both", "breadth", "by", + "c", "cache", "call", "called", + "cardinality", "cascade", "cascaded", "case", + "cast", "catalog", "catalog_name", "chain", + "char", "character", "characteristics", "character_length", + "character_set_catalog", "character_set_name", "character_set_schema", "char_length", + "check", "checked", "checkpoint", /* "class", */ + "class_origin", "clob", "close", "cluster", + "coalesce", "cobol", "collate", "collation", + "collation_catalog", "collation_name", "collation_schema", "column", + "column_name", "command_function", "command_function_code", "comment", + "commit", "committed", "completion", "condition_number", + "connect", "connection", "connection_name", "constraint", + "constraints", "constraint_catalog", "constraint_name", "constraint_schema", + "constructor", "contains", "continue", "conversion", + "convert", "copy", "corresponding", "count", + "create", "createdb", "createuser", "cross", + "cube", "current", "current_date", "current_path", + "current_role", "current_time", "current_timestamp", "current_user", + "cursor", "cursor_name", "cycle", "data", + "database", "date", "datetime_interval_code", "datetime_interval_precision", + "day", "deallocate", "dec", "decimal", + "declare", "default", "defaults", "deferrable", + "deferred", "defined", "definer", "delete", + "delimiter", "delimiters", "depth", "deref", + "desc", "describe", "descriptor", "destroy", + "destructor", "deterministic", "diagnostics", "dictionary", + "disconnect", "dispatch", "distinct", "do", + "domain", "double", "drop", "dynamic", + "dynamic_function", "dynamic_function_code", "each", "else", + "encoding", "encrypted", "end", "end-exec", + "equals", "escape", "every", "except", + "exception", "excluding", "exclusive", "exec", + "execute", "existing", "exists", "explain", + "external", "extract", "false", "fetch", + "final", "first", "float", "for", + "force", "foreign", "fortran", "forward", + "found", "free", "freeze", "from", + "full", "function", "g", "general", + "generated", "get", "global", "go", + "goto", "grant", "granted", "group", + "grouping", "handler", "having", "hierarchy", + "hold", "host", "hour", "identity", + "ignore", "ilike", "immediate", "immutable", + "implementation", "implicit", "in", "including", + "increment", "index", "indicator", "infix", + "inherits", "initialize", "initially", "inner", + "inout", "input", "insensitive", "insert", + "instance", "instantiable", "instead", "int", + "integer", "intersect", "interval", "into", + "invoker", "is", "isnull", "isolation", + "iterate", "join", "k", "key", + "key_member", "key_type", "lancompiler", "language", + "large", "last", "lateral", "leading", + "left", "length", "less", "level", + "like", "limit", "listen", "load", + "local", "localtime", "localtimestamp", "location", + "locator", "lock", "lower", "m", + "map", "match", "max", "maxvalue", + "message_length", "message_octet_length", "message_text", "method", + "min", "minute", "minvalue", "mod", + "mode", "modifies", "modify", "module", + "month", "more", "move", "mumps", + "name", "names", "national", "natural", + "nchar", "nclob", "new", "next", + "no", "nocreatedb", "nocreateuser", "none", + "not", "nothing", "notify", "notnull", + "null", "nullable", "nullif", "number", + "numeric", "object", "octet_length", "of", + "off", "offset", "oids", "old", + "on", "only", "open", "operation", + "operator", "option", "options", "or", + "order", "ordinality", "out", "outer", + "output", "overlaps", "overlay", "overriding", + "owner", "pad", "parameter", "parameters", + "parameter_mode", "parameter_name", "parameter_ordinal_position", "parameter_specific_catalog", + "parameter_specific_name", "parameter_specific_schema", "partial", "pascal", + "password", "path", "pendant", "placing", + "pli", "position", "postfix", "precision", + "prefix", "preorder", "prepare", "preserve", + "primary", "prior", "privileges", "procedural", + "procedure", "public", "read", "reads", + "real", "recheck", "recursive", "ref", + "references", "referencing", "reindex", "relative", + "rename", "repeatable", "replace", "reset", + "restart", "restrict", "result", "return", + "returned_length", "returned_octet_length", "returned_sqlstate", "returns", + "revoke", "right", "role", "rollback", + "rollup", "routine", "routine_catalog", "routine_name", + "routine_schema", "row", "rows", "row_count", + "rule", "savepoint", "scale", "schema", + "schema_name", "scope", "scroll", "search", + "second", "section", "security", "select", + "self", "sensitive", "sequence", "serializable", + "server_name", "session", "session_user", "set", + "setof", "sets", "share", "show", + "similar", "simple", "size", "smallint", + "some", "source", "space", "specific", + "specifictype", "specific_name", "sql", "sqlcode", + "sqlerror", "sqlexception", "sqlstate", "sqlwarning", + "stable", "start", "state", "statement", + "static", "statistics", "stdin", "stdout", + "storage", "strict", "structure", "style", + "subclass_origin", "sublist", "substring", "sum", + "symmetric", "sysid", "system", "system_user", + "table", "table_name", "temp", "template", + "temporary", "terminate", "text", "than", "then", + "time", "timestamp", "timezone_hour", "timezone_minute", + "to", "toast", "trailing", "transaction", + "transactions_committed", "transactions_rolled_back", "transaction_active", "transform", + "transforms", "translate", "translation", "treat", + "trigger", "trigger_catalog", "trigger_name", "trigger_schema", + "trim", "true", "truncate", "trusted", + "type", "uncommitted", "under", "unencrypted", + "union", "unique", "unknown", "unlisten", + "unnamed", "unnest", "until", "update", + "upper", "usage", "user", "user_defined_type_catalog", + "user_defined_type_name", "user_defined_type_schema", "using", "vacuum", + "valid", "validator", "value", "values", + "varchar", "variable", "varying", "verbose", + "version", "view", "volatile", "when", + "whenever", "where", "with", "without", + "work", "write", "year", "zone") + + ); + + $case_insensitive = array( + "VB" => true, + "Pascal" => true, + "PL/I" => true, + "SQL" => true + ); + $ncs = false; + if (array_key_exists($language, $case_insensitive)) + $ncs = true; + + $text = (array_key_exists($language, $preproc))? + preproc_replace($preproc[$language], $text) : + $text; + $text = (array_key_exists($language, $keywords))? + keyword_replace($keywords[$language], $text, $ncs) : + $text; + + return $text; +} + + +function rtrim1($span, $lang, $ch) +{ + return syntax_highlight_helper(substr($span, 0, -1), $lang); +} + + +function rtrim1_htmlesc($span, $lang, $ch) +{ + return htmlspecialchars(substr($span, 0, -1)); +} + + +function sch_rtrim1($span, $lang, $ch) +{ + return sch_syntax_helper(substr($span, 0, -1)); +} + + +function rtrim2($span, $lang, $ch) +{ + return substr($span, 0, -2); +} + + +function syn_proc($span, $lang, $ch) +{ + return syntax_highlight_helper($span, $lang); +} + +function dash_putback($span, $lang, $ch) +{ + return syntax_highlight_helper('-' . $span, $lang); +} + +function slash_putback($span, $lang, $ch) +{ + return syntax_highlight_helper('/' . $span, $lang); +} + +function slash_putback_rtrim1($span, $lang, $ch) +{ + return rtrim1('/' . $span, $lang, $ch); +} + +function lparen_putback($span, $lang, $ch) +{ + return syntax_highlight_helper('(' . $span, $lang); +} + +function lparen_putback_rtrim1($span, $lang, $ch) +{ + return rtrim1('(' . $span, $lang, $ch); +} + +function prepend_xml_opentag($span, $lang, $ch) +{ + return '<' . $span; +} + +function proc_void($span, $lang, $ch) +{ + return $span; +} + + +/** + * Syntax highlight function + * Does the bulk of the syntax highlighting by lexing the input + * string, then calling the helper function to highlight keywords. + */ +function syntax_highlight($text, $language) +{ + if ($language == "Plain Text") return $text; + + define("normal_text", 1, true); + define("dq_literal", 2, true); + define("dq_escape", 3, true); + define("sq_literal", 4, true); + define("sq_escape", 5, true); + define("slash_begin", 6, true); + define("star_comment", 7, true); + define("star_end", 8, true); + define("line_comment", 9, true); + define("html_entity", 10, true); + define("lc_escape", 11, true); + define("block_comment",12, true); + define("paren_begin", 13, true); + define("dash_begin", 14, true); + define("bt_literal", 15, true); + define("bt_escape", 16, true); + define("xml_tag_begin",17, true); + define("xml_tag", 18, true); + define("xml_pi", 19, true); + define("sch_normal", 20, true); + define("sch_stresc", 21, true); + define("sch_idexpr", 22, true); + define("sch_numlit", 23, true); + define("sch_chrlit", 24, true); + define("sch_strlit", 25, true); + + $initial_state["Scheme"] = sch_normal; + + $sch[sch_normal][0] = sch_normal; + $sch[sch_normal]['"'] = sch_strlit; + $sch[sch_normal]["#"] = sch_chrlit; + $sch[sch_normal]["0"] = sch_numlit; + $sch[sch_normal]["1"] = sch_numlit; + $sch[sch_normal]["2"] = sch_numlit; + $sch[sch_normal]["3"] = sch_numlit; + $sch[sch_normal]["4"] = sch_numlit; + $sch[sch_normal]["5"] = sch_numlit; + $sch[sch_normal]["6"] = sch_numlit; + $sch[sch_normal]["7"] = sch_numlit; + $sch[sch_normal]["8"] = sch_numlit; + $sch[sch_normal]["9"] = sch_numlit; + + $sch[sch_strlit]['"'] = sch_normal; + $sch[sch_strlit]["\n"] = sch_normal; + $sch[sch_strlit]["\\"] = sch_stresc; + $sch[sch_strlit][0] = sch_strlit; + + $sch[sch_chrlit][" "] = sch_normal; + $sch[sch_chrlit]["\t"] = sch_normal; + $sch[sch_chrlit]["\n"] = sch_normal; + $sch[sch_chrlit]["\r"] = sch_normal; + $sch[sch_chrlit][0] = sch_chrlit; + + $sch[sch_numlit][" "] = sch_normal; + $sch[sch_numlit]["\t"] = sch_normal; + $sch[sch_numlit]["\n"] = sch_normal; + $sch[sch_numlit]["\r"] = sch_normal; + $sch[sch_numlit][0] = sch_numlit; + + // + // State transitions for C + // + $c89[normal_text]["\""] = dq_literal; + $c89[normal_text]["'"] = sq_literal; + $c89[normal_text]["/"] = slash_begin; + $c89[normal_text][0] = normal_text; + + $c89[dq_literal]["\""] = normal_text; + $c89[dq_literal]["\n"] = normal_text; + $c89[dq_literal]["\\"] = dq_escape; + $c89[dq_literal][0] = dq_literal; + + $c89[dq_escape][0] = dq_literal; + + $c89[sq_literal]["'"] = normal_text; + $c89[sq_literal]["\n"] = normal_text; + $c89[sq_literal]["\\"] = sq_escape; + $c89[sq_literal][0] = sq_literal; + + $c89[sq_escape][0] = sq_literal; + + $c89[slash_begin]["*"] = star_comment; + $c89[slash_begin][0] = normal_text; + + $c89[star_comment]["*"] = star_end; + $c89[star_comment][0] = star_comment; + + $c89[star_end]["/"] = normal_text; + $c89[star_end]["*"] = star_end; + $c89[star_end][0] = star_comment; + + // + // State transitions for C++ + // Inherit transitions from C, and add line comment support + // + $cpp = $c89; + $cpp[slash_begin]["/"] = line_comment; + $cpp[line_comment]["\n"] = normal_text; + $cpp[line_comment]["\\"] = lc_escape; + $cpp[line_comment][0] = line_comment; + + $cpp[lc_escape]["\r"] = lc_escape; + $cpp[lc_escape][0] = line_comment; + + // + // State transitions for C99. + // C99 supports line comments like C++ + // + $c99 = $cpp; + + // State transitions for PL/I + // Kinda like C + $pli = $c89; + + // + // State transitions for PHP + // Inherit transitions from C++, and add perl-style line comment support + $php = $cpp; + $php[normal_text]["#"] = line_comment; + $php[sq_literal]["\n"] = sq_literal; + $php[dq_literal]["\n"] = dq_literal; + + // + // State transitions for Perl + $perl[normal_text]["#"] = line_comment; + $perl[normal_text]["\""] = dq_literal; + $perl[normal_text]["'"] = sq_literal; + $perl[normal_text][0] = normal_text; + + $perl[dq_literal]["\""] = normal_text; + $perl[dq_literal]["\\"] = dq_escape; + $perl[dq_literal][0] = dq_literal; + + $perl[dq_escape][0] = dq_literal; + + $perl[sq_literal]["'"] = normal_text; + $perl[sq_literal]["\\"] = sq_escape; + $perl[sq_literal][0] = sq_literal; + + $perl[sq_escape][0] = sq_literal; + + $perl[line_comment]["\n"] = normal_text; + $perl[line_comment][0] = line_comment; + + $mirc[normal_text]["\""] = dq_literal; + $mirc[normal_text][";"] = line_comment; + $mirc[normal_text][0] = normal_text; + + $mirc[dq_literal]["\""] = normal_text; + $mirc[dq_literal]["\\"] = dq_escape; + $mirc[dq_literal][0] = dq_literal; + + $mirc[dq_escape][0] = dq_literal; + + $mirc[line_comment]["\n"] = normal_text; + $mirc[line_comment][0] = line_comment; + + $ruby = $perl; + + $python = $perl; + + $java = $cpp; + + $vb = $perl; + $vb[normal_text]["#"] = normal_text; + $vb[normal_text]["'"] = line_comment; + + $cs = $java; + + $pascal = $c89; + $pascal[normal_text]["("] = paren_begin; + $pascal[normal_text]["/"] = slash_begin; + $pascal[normal_text]["{"] = block_comment; + + $pascal[paren_begin]["*"] = star_comment; + $pascal[paren_begin]["'"] = sq_literal; + $pascal[paren_begin]['"'] = dq_literal; + $pascal[paren_begin][0] = normal_text; + + $pascal[slash_begin]["'"] = sq_literal; + $pascal[slash_begin]['"'] = dq_literal; + $pascal[slash_begin]['/'] = line_comment; + $pascal[slash_begin][0] = normal_text; + + $pascal[star_comment]["*"] = star_end; + $pascal[star_comment][0] = star_comment; + + $pascal[block_comment]["}"] = normal_text; + $pascal[block_comment][0] = block_comment; + + $pascal[line_comment]["\n"] = normal_text; + $pascal[line_comment][0] = line_comment; + + $pascal[star_end][")"] = normal_text; + $pascal[star_end]["*"] = star_end; + $pascal[star_end][0] = star_comment; + + $sql[normal_text]['"'] = dq_literal; + $sql[normal_text]["'"] = sq_literal; + $sql[normal_text]['`'] = bt_literal; + $sql[normal_text]['-'] = dash_begin; + $sql[normal_text][0] = normal_text; + + $sql[dq_literal]['"'] = normal_text; + $sql[dq_literal]['\\'] = dq_escape; + $sql[dq_literal][0] = dq_literal; + + $sql[sq_literal]["'"] = normal_text; + $sql[sq_literal]['\\'] = sq_escape; + $sql[sq_literal][0] = sq_literal; + + $sql[bt_literal]['`'] = normal_text; + $sql[bt_literal]['\\'] = bt_escape; + $sql[bt_literal][0] = bt_literal; + + $sql[dq_escape][0] = dq_literal; + $sql[sq_escape][0] = sq_literal; + $sql[bt_escape][0] = bt_literal; + + $sql[dash_begin]["-"] = line_comment; + $sql[dash_begin][0] = normal_text; + + $sql[line_comment]["\n"] = normal_text; + $sql[line_comment]["\\"] = lc_escape; + $sql[line_comment][0] = line_comment; + + $sql[lc_escape]["\r"] = lc_escape; + $sql[lc_escape][0] = line_comment; + + $xml[normal_text]["<"] = xml_tag_begin; + $xml[normal_text]["&"] = html_entity; + $xml[normal_text][0] = normal_text; + $xml[html_entity][";"] = normal_text; + $xml[html_entity]["<"] = xml_tag_begin; + $xml[html_entity][0] = html_entity; + $xml[xml_tag_begin]["?"] = xml_pi; + $xml[xml_tag_begin]["!"] = line_comment; + $xml[xml_tag_begin][0] = xml_tag; + $xml[xml_tag][">"] = normal_text; + $xml[xml_tag]["\""] = dq_literal; + $xml[xml_tag]["'"] = sq_literal; + $xml[xml_tag][0] = xml_tag; + $xml[xml_pi][">"] = normal_text; + $xml[xml_pi][0] = xml_tag; + $xml[line_comment][">"] = normal_text; + $xml[line_comment][0] = line_comment; + $xml[dq_literal]["\""] = xml_tag; + $xml[dq_literal]["&"] = dq_escape; + $xml[dq_literal][0] = dq_literal; + $xml[sq_literal]["'"] = xml_tag; + $xml[sq_literal]["&"] = sq_escape; + $xml[sq_literal][0] = sq_literal; + $xml[dq_escape][";"] = dq_literal; + $xml[dq_escape][0] = dq_escape; + + // + // Main state transition table + // + $states = array( + "C89" => $c89, + "C" => $c99, + "C++" => $cpp, + "PHP" => $php, + "Perl" => $perl, + "Java" => $java, + "VB" => $vb, + "C#" => $cs, + "Ruby" => $ruby, + "Python" => $python, + "Pascal" => $pascal, + "mIRC" => $mirc, + "PL/I" => $pli, + "SQL" => $sql, + "XML" => $xml, + "Scheme" => $sch + ); + + + // + // Process functions + // + $process["C89"][normal_text][sq_literal] = "rtrim1"; + $process["C89"][normal_text][dq_literal] = "rtrim1"; + $process["C89"][normal_text][slash_begin] = "rtrim1"; + $process["C89"][normal_text][0] = "syn_proc"; + + $process["C89"][slash_begin][star_comment] = "rtrim1"; + $process["C89"][slash_begin][0] = "slash_putback"; + + $process["Scheme"][sch_normal][sch_strlit] = "sch_rtrim1"; + $process["Scheme"][sch_normal][sch_chrlit] = "sch_rtrim1"; + $process["Scheme"][sch_normal][sch_numlit] = "sch_rtrim1"; + + $process["SQL"][normal_text][sq_literal] = "rtrim1"; + $process["SQL"][normal_text][dq_literal] = "rtrim1"; + $process["SQL"][normal_text][bt_literal] = "rtrim1"; + $process["SQL"][normal_text][dash_begin] = "rtrim1"; + $process["SQL"][normal_text][0] = "syn_proc"; + + $process["SQL"][dash_begin][line_comment] = "rtrim1"; + $process["SQL"][dash_begin][0] = "dash_putback"; + + $process["PL/I"] = $process["C89"]; + + $process["C++"] = $process["C89"]; + $process["C++"][slash_begin][line_comment] = "rtrim1"; + + $process["C"] = $process["C++"]; + + $process["PHP"] = $process["C++"]; + $process["PHP"][normal_text][line_comment] = "rtrim1"; + + $process["Perl"][normal_text][sq_literal] = "rtrim1"; + $process["Perl"][normal_text][dq_literal] = "rtrim1"; + $process["Perl"][normal_text][line_comment] = "rtrim1"; + $process["Perl"][normal_text][0] = "syn_proc"; + + $process["Ruby"] = $process["Perl"]; + $process["Python"] = $process["Perl"]; + + $process["mIRC"][normal_text][dq_literal] = "rtrim1"; + $process["mIRC"][normal_text][line_comment] = "rtrim1"; + $process["mIRC"][normal_text][0] = "syn_proc"; + + $process["VB"] = $process["Perl"]; + + $process["Java"] = $process["C++"]; + + $process["C#"] = $process["Java"]; + + $process["Pascal"] = $process["C++"]; + $process["Pascal"][normal_text][line_comment] = "rtrim1"; + $process["Pascal"][normal_text][block_comment] = "rtrim1"; + $process["Pascal"][normal_text][paren_begin] = "rtrim1"; + $process["Pascal"][slash_begin][sq_literal] = "slash_putback_rtrim1"; + $process["Pascal"][slash_begin][dq_literal] = "slash_putback_rtrim1"; + $process["Pascal"][slash_begin][0] = "slash_putback"; + $process["Pascal"][paren_begin][sq_literal] = "lparen_putback_rtrim1"; + $process["Pascal"][paren_begin][dq_literal] = "lparen_putback_rtrim1"; + $process["Pascal"][paren_begin][star_comment] = "rtrim1"; + $process["Pascal"][paren_begin][0] = "lparen_putback"; + + $process["XML"][normal_text][xml_tag_begin] = "rtrim1"; + $process["XML"][normal_text][html_entity] = "rtrim1"; + $process["XML"][html_entity][xml_tag_begin] = "rtrim1"; + $process["XML"][html_entity][0] = "proc_void"; + $process["XML"][xml_tag_begin][xml_tag] = "prepend_xml_opentag"; + $process["XML"][xml_tag_begin][xml_pi] = "rtrim1"; + $process["XML"][xml_tag_begin][line_comment] = "rtrim1"; + $process["XML"][line_comment][normal_text] = "rtrim1_htmlesc"; + $process["XML"][xml_tag][normal_text] = "rtrim1"; + $process["XML"][xml_tag][dq_literal] = "rtrim1"; + $process["XML"][dq_literal][xml_tag] = "rtrim1"; + $process["XML"][dq_literal][dq_escape] = "rtrim1"; + + $process_end["C89"] = "syntax_highlight_helper"; + $process_end["C++"] = $process_end["C89"]; + $process_end["C"] = $process_end["C89"]; + $process_end["PHP"] = $process_end["C89"]; + $process_end["Perl"] = $process_end["C89"]; + $process_end["Java"] = $process_end["C89"]; + $process_end["VB"] = $process_end["C89"]; + $process_end["C#"] = $process_end["C89"]; + $process_end["Ruby"] = $process_end["C89"]; + $process_end["Python"] = $process_end["C89"]; + $process_end["Pascal"] = $process_end["C89"]; + $process_end["mIRC"] = $process_end["C89"]; + $process_end["PL/I"] = $process_end["C89"]; + $process_end["SQL"] = $process_end["C89"]; + $process_end["Scheme"] = "sch_syntax_helper"; + + + $edges["C89"][normal_text .",". dq_literal] = '"'; + $edges["C89"][normal_text .",". sq_literal] = '\''; + $edges["C89"][slash_begin .",". star_comment] = '/*'; + $edges["C89"][dq_literal .",". normal_text] = ''; + $edges["C89"][sq_literal .",". normal_text] = ''; + $edges["C89"][star_end .",". normal_text] = ''; + + $edges["Scheme"][sch_normal .",". sch_strlit] = '"'; + $edges["Scheme"][sch_normal .",". sch_numlit] = ''; + $edges["Scheme"][sch_normal .",". sch_chrlit] = '#'; + $edges["Scheme"][sch_strlit .",". sch_normal] = ''; + $edges["Scheme"][sch_numlit .",". sch_normal] = ''; + $edges["Scheme"][sch_chrlit .",". sch_normal] = ''; + + $edges["SQL"][normal_text .",". dq_literal] = '"'; + $edges["SQL"][normal_text .",". sq_literal] = '\''; + $edges["SQL"][dash_begin .",". line_comment] = '--'; + $edges["SQL"][normal_text .",". bt_literal] = '`'; + $edges["SQL"][dq_literal .",". normal_text] = ''; + $edges["SQL"][sq_literal .",". normal_text] = ''; + $edges["SQL"][line_comment .",". normal_text] = ''; + + $edges["PL/I"] = $edges["C89"]; + + $edges["C++"] = $edges["C89"]; + $edges["C++"][slash_begin .",". line_comment] = '//'; + $edges["C++"][line_comment .",". normal_text] = ''; + + $edges["C"] = $edges["C++"]; + + $edges["PHP"] = $edges["C++"]; + $edges["PHP"][normal_text .",". line_comment] = '#'; + + $edges["Perl"][normal_text .",". dq_literal] = '"'; + $edges["Perl"][normal_text .",". sq_literal] = '\''; + $edges["Perl"][dq_literal .",". normal_text] = ''; + $edges["Perl"][sq_literal .",". normal_text] = ''; + $edges["Perl"][normal_text .",". line_comment] = '#'; + $edges["Perl"][line_comment .",". normal_text] = ''; + + $edges["Ruby"] = $edges["Perl"]; + + $edges["Python"] = $edges["Perl"]; + + $edges["mIRC"][normal_text .",". dq_literal] = '"'; + $edges["mIRC"][normal_text .",". line_comment] = ';'; + $edges["mIRC"][dq_literal .",". normal_text] = ''; + $edges["mIRC"][line_comment .",". normal_text] = ''; + + $edges["VB"] = $edges["Perl"]; + $edges["VB"][normal_text .",". line_comment] = '\''; + + $edges["Java"] = $edges["C++"]; + + $edges["C#"] = $edges["Java"]; + + $edges["Pascal"] = $edges["C89"]; + $edges["Pascal"][paren_begin .",". star_comment] = '(*'; + $edges["Pascal"][paren_begin .",". dq_literal] = '"'; + $edges["Pascal"][paren_begin .",". sq_literal] = '\''; + $edges["Pascal"][slash_begin .",". dq_literal] = '"'; + $edges["Pascal"][slash_begin .",". sq_literal] = '\''; + $edges["Pascal"][slash_begin .",". line_comment] = '//'; + $edges["Pascal"][normal_text . "," . block_comment] = '{'; + $edges["Pascal"][line_comment . "," . normal_text] = ''; + $edges["Pascal"][block_comment . "," . normal_text] = ''; + + $edges["XML"][normal_text . "," . html_entity] = '&'; + $edges["XML"][html_entity . "," . normal_text] = ''; + $edges["XML"][html_entity . "," . xml_tag_begin] = ''; + $edges["XML"][xml_tag . "," . normal_text] = '>'; + $edges["XML"][xml_tag_begin . "," . xml_pi] = '<?'; + $edges["XML"][xml_tag_begin . "," . line_comment] = '<!'; + $edges["XML"][line_comment . "," . normal_text] = '>'; + $edges["XML"][xml_tag .",". dq_literal] = '"'; + $edges["XML"][dq_literal . "," . xml_tag] = '"'; + $edges["XML"][dq_literal . "," . dq_escape] = '&'; + $edges["XML"][dq_escape . "," . dq_literal] = ''; + $edges["XML"][xml_tag .",". sq_literal] = '\''; + $edges["XML"][sq_literal . "," . xml_tag] = '\''; + $edges["XML"][sq_literal . "," . sq_escape] = '&'; + $edges["XML"][sq_escape . "," . sq_literal] = ''; + + // + // The State Machine + // + if (array_key_exists($language, $initial_state)) + $state = $initial_state[$language]; + else + $state = normal_text; + $output = ""; + $span = ""; + while (strlen($text) > 0) + { + $ch = substr($text, 0, 1); + $text = substr($text, 1); + + $oldstate = $state; + $state = (array_key_exists($ch, $states[$language][$state]))? + $states[$language][$state][$ch] : + $states[$language][$state][0]; + + $span .= $ch; + + if ($oldstate != $state) + { + if (array_key_exists($language, $process) && + array_key_exists($oldstate, $process[$language])) + { + if (array_key_exists($state, $process[$language][$oldstate])) + { + $pf = $process[$language][$oldstate][$state]; + $output .= $pf($span, $language, $ch); + } + else + { + $pf = $process[$language][$oldstate][0]; + $output .= $pf($span, $language, $ch); + } + } + else + { + $output .= $span; + } + + if (array_key_exists($language, $edges) && + array_key_exists("$oldstate,$state", $edges[$language])) + $output .= $edges[$language]["$oldstate,$state"]; + + $span = ""; + } + } + + if (array_key_exists($language, $process_end) && $state == normal_text) + $output .= $process_end[$language]($span, $language); + else + $output .= $span; + + if ($state != normal_text) + { + if (array_key_exists($language, $edges) && + array_key_exists("$state," . normal_text, $edges[$language])) + $output .= $edges[$language]["$state," . normal_text]; + } + + return $output; +} + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/js/jquery.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/js/jquery.js new file mode 100644 index 00000000..e7f2a292 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/js/jquery.js @@ -0,0 +1,2 @@ +/*! jQuery v@1.8.1 jquery.com | jquery.org/license */ +(function(a,b){function G(a){var b=F[a]={};return p.each(a.split(s),function(a,c){b[c]=!0}),b}function J(a,c,d){if(d===b&&a.nodeType===1){var e="data-"+c.replace(I,"-$1").toLowerCase();d=a.getAttribute(e);if(typeof d=="string"){try{d=d==="true"?!0:d==="false"?!1:d==="null"?null:+d+""===d?+d:H.test(d)?p.parseJSON(d):d}catch(f){}p.data(a,c,d)}else d=b}return d}function K(a){var b;for(b in a){if(b==="data"&&p.isEmptyObject(a[b]))continue;if(b!=="toJSON")return!1}return!0}function ba(){return!1}function bb(){return!0}function bh(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function bi(a,b){do a=a[b];while(a&&a.nodeType!==1);return a}function bj(a,b,c){b=b||0;if(p.isFunction(b))return p.grep(a,function(a,d){var e=!!b.call(a,d,a);return e===c});if(b.nodeType)return p.grep(a,function(a,d){return a===b===c});if(typeof b=="string"){var d=p.grep(a,function(a){return a.nodeType===1});if(be.test(b))return p.filter(b,d,!c);b=p.filter(b,d)}return p.grep(a,function(a,d){return p.inArray(a,b)>=0===c})}function bk(a){var b=bl.split("|"),c=a.createDocumentFragment();if(c.createElement)while(b.length)c.createElement(b.pop());return c}function bC(a,b){return a.getElementsByTagName(b)[0]||a.appendChild(a.ownerDocument.createElement(b))}function bD(a,b){if(b.nodeType!==1||!p.hasData(a))return;var c,d,e,f=p._data(a),g=p._data(b,f),h=f.events;if(h){delete g.handle,g.events={};for(c in h)for(d=0,e=h[c].length;d").appendTo(e.body),c=b.css("display");b.remove();if(c==="none"||c===""){bI=e.body.appendChild(bI||p.extend(e.createElement("iframe"),{frameBorder:0,width:0,height:0}));if(!bJ||!bI.createElement)bJ=(bI.contentWindow||bI.contentDocument).document,bJ.write(""),bJ.close();b=bJ.body.appendChild(bJ.createElement(a)),c=bH(b,"display"),e.body.removeChild(bI)}return bS[a]=c,c}function ci(a,b,c,d){var e;if(p.isArray(b))p.each(b,function(b,e){c||ce.test(a)?d(a,e):ci(a+"["+(typeof e=="object"?b:"")+"]",e,c,d)});else if(!c&&p.type(b)==="object")for(e in b)ci(a+"["+e+"]",b[e],c,d);else d(a,b)}function cz(a){return function(b,c){typeof b!="string"&&(c=b,b="*");var d,e,f,g=b.toLowerCase().split(s),h=0,i=g.length;if(p.isFunction(c))for(;h)[^>]*$|#([\w\-]*)$)/,v=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,w=/^[\],:{}\s]*$/,x=/(?:^|:|,)(?:\s*\[)+/g,y=/\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,z=/"[^"\\\r\n]*"|true|false|null|-?(?:\d\d*\.|)\d+(?:[eE][\-+]?\d+|)/g,A=/^-ms-/,B=/-([\da-z])/gi,C=function(a,b){return(b+"").toUpperCase()},D=function(){e.addEventListener?(e.removeEventListener("DOMContentLoaded",D,!1),p.ready()):e.readyState==="complete"&&(e.detachEvent("onreadystatechange",D),p.ready())},E={};p.fn=p.prototype={constructor:p,init:function(a,c,d){var f,g,h,i;if(!a)return this;if(a.nodeType)return this.context=this[0]=a,this.length=1,this;if(typeof a=="string"){a.charAt(0)==="<"&&a.charAt(a.length-1)===">"&&a.length>=3?f=[null,a,null]:f=u.exec(a);if(f&&(f[1]||!c)){if(f[1])return c=c instanceof p?c[0]:c,i=c&&c.nodeType?c.ownerDocument||c:e,a=p.parseHTML(f[1],i,!0),v.test(f[1])&&p.isPlainObject(c)&&this.attr.call(a,c,!0),p.merge(this,a);g=e.getElementById(f[2]);if(g&&g.parentNode){if(g.id!==f[2])return d.find(a);this.length=1,this[0]=g}return this.context=e,this.selector=a,this}return!c||c.jquery?(c||d).find(a):this.constructor(c).find(a)}return p.isFunction(a)?d.ready(a):(a.selector!==b&&(this.selector=a.selector,this.context=a.context),p.makeArray(a,this))},selector:"",jquery:"1.8.1",length:0,size:function(){return this.length},toArray:function(){return k.call(this)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var d=p.merge(this.constructor(),a);return d.prevObject=this,d.context=this.context,b==="find"?d.selector=this.selector+(this.selector?" ":"")+c:b&&(d.selector=this.selector+"."+b+"("+c+")"),d},each:function(a,b){return p.each(this,a,b)},ready:function(a){return p.ready.promise().done(a),this},eq:function(a){return a=+a,a===-1?this.slice(a):this.slice(a,a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(k.apply(this,arguments),"slice",k.call(arguments).join(","))},map:function(a){return this.pushStack(p.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:j,sort:[].sort,splice:[].splice},p.fn.init.prototype=p.fn,p.extend=p.fn.extend=function(){var a,c,d,e,f,g,h=arguments[0]||{},i=1,j=arguments.length,k=!1;typeof h=="boolean"&&(k=h,h=arguments[1]||{},i=2),typeof h!="object"&&!p.isFunction(h)&&(h={}),j===i&&(h=this,--i);for(;i0)return;d.resolveWith(e,[p]),p.fn.trigger&&p(e).trigger("ready").off("ready")},isFunction:function(a){return p.type(a)==="function"},isArray:Array.isArray||function(a){return p.type(a)==="array"},isWindow:function(a){return a!=null&&a==a.window},isNumeric:function(a){return!isNaN(parseFloat(a))&&isFinite(a)},type:function(a){return a==null?String(a):E[m.call(a)]||"object"},isPlainObject:function(a){if(!a||p.type(a)!=="object"||a.nodeType||p.isWindow(a))return!1;try{if(a.constructor&&!n.call(a,"constructor")&&!n.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}var d;for(d in a);return d===b||n.call(a,d)},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},error:function(a){throw new Error(a)},parseHTML:function(a,b,c){var d;return!a||typeof a!="string"?null:(typeof b=="boolean"&&(c=b,b=0),b=b||e,(d=v.exec(a))?[b.createElement(d[1])]:(d=p.buildFragment([a],b,c?null:[]),p.merge([],(d.cacheable?p.clone(d.fragment):d.fragment).childNodes)))},parseJSON:function(b){if(!b||typeof b!="string")return null;b=p.trim(b);if(a.JSON&&a.JSON.parse)return a.JSON.parse(b);if(w.test(b.replace(y,"@").replace(z,"]").replace(x,"")))return(new Function("return "+b))();p.error("Invalid JSON: "+b)},parseXML:function(c){var d,e;if(!c||typeof c!="string")return null;try{a.DOMParser?(e=new DOMParser,d=e.parseFromString(c,"text/xml")):(d=new ActiveXObject("Microsoft.XMLDOM"),d.async="false",d.loadXML(c))}catch(f){d=b}return(!d||!d.documentElement||d.getElementsByTagName("parsererror").length)&&p.error("Invalid XML: "+c),d},noop:function(){},globalEval:function(b){b&&r.test(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(A,"ms-").replace(B,C)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,d){var e,f=0,g=a.length,h=g===b||p.isFunction(a);if(d){if(h){for(e in a)if(c.apply(a[e],d)===!1)break}else for(;f0&&a[0]&&a[i-1]||i===0||p.isArray(a));if(j)for(;h-1)i.splice(c,1),e&&(c<=g&&g--,c<=h&&h--)}),this},has:function(a){return p.inArray(a,i)>-1},empty:function(){return i=[],this},disable:function(){return i=j=c=b,this},disabled:function(){return!i},lock:function(){return j=b,c||l.disable(),this},locked:function(){return!j},fireWith:function(a,b){return b=b||[],b=[a,b.slice?b.slice():b],i&&(!d||j)&&(e?j.push(b):k(b)),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!d}};return l},p.extend({Deferred:function(a){var b=[["resolve","done",p.Callbacks("once memory"),"resolved"],["reject","fail",p.Callbacks("once memory"),"rejected"],["notify","progress",p.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return p.Deferred(function(c){p.each(b,function(b,d){var f=d[0],g=a[b];e[d[1]](p.isFunction(g)?function(){var a=g.apply(this,arguments);a&&p.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f+"With"](this===e?c:this,[a])}:c[f])}),a=null}).promise()},promise:function(a){return typeof a=="object"?p.extend(a,d):d}},e={};return d.pipe=d.then,p.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[a^1][2].disable,b[2][2].lock),e[f[0]]=g.fire,e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=k.call(arguments),d=c.length,e=d!==1||a&&p.isFunction(a.promise)?d:0,f=e===1?a:p.Deferred(),g=function(a,b,c){return function(d){b[a]=this,c[a]=arguments.length>1?k.call(arguments):d,c===h?f.notifyWith(b,c):--e||f.resolveWith(b,c)}},h,i,j;if(d>1){h=new Array(d),i=new Array(d),j=new Array(d);for(;b
a",c=n.getElementsByTagName("*"),d=n.getElementsByTagName("a")[0],d.style.cssText="top:1px;float:left;opacity:.5";if(!c||!c.length||!d)return{};f=e.createElement("select"),g=f.appendChild(e.createElement("option")),h=n.getElementsByTagName("input")[0],b={leadingWhitespace:n.firstChild.nodeType===3,tbody:!n.getElementsByTagName("tbody").length,htmlSerialize:!!n.getElementsByTagName("link").length,style:/top/.test(d.getAttribute("style")),hrefNormalized:d.getAttribute("href")==="/a",opacity:/^0.5/.test(d.style.opacity),cssFloat:!!d.style.cssFloat,checkOn:h.value==="on",optSelected:g.selected,getSetAttribute:n.className!=="t",enctype:!!e.createElement("form").enctype,html5Clone:e.createElement("nav").cloneNode(!0).outerHTML!=="<:nav>",boxModel:e.compatMode==="CSS1Compat",submitBubbles:!0,changeBubbles:!0,focusinBubbles:!1,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0,boxSizingReliable:!0,pixelPosition:!1},h.checked=!0,b.noCloneChecked=h.cloneNode(!0).checked,f.disabled=!0,b.optDisabled=!g.disabled;try{delete n.test}catch(o){b.deleteExpando=!1}!n.addEventListener&&n.attachEvent&&n.fireEvent&&(n.attachEvent("onclick",m=function(){b.noCloneEvent=!1}),n.cloneNode(!0).fireEvent("onclick"),n.detachEvent("onclick",m)),h=e.createElement("input"),h.value="t",h.setAttribute("type","radio"),b.radioValue=h.value==="t",h.setAttribute("checked","checked"),h.setAttribute("name","t"),n.appendChild(h),i=e.createDocumentFragment(),i.appendChild(n.lastChild),b.checkClone=i.cloneNode(!0).cloneNode(!0).lastChild.checked,b.appendChecked=h.checked,i.removeChild(h),i.appendChild(n);if(n.attachEvent)for(k in{submit:!0,change:!0,focusin:!0})j="on"+k,l=j in n,l||(n.setAttribute(j,"return;"),l=typeof n[j]=="function"),b[k+"Bubbles"]=l;return p(function(){var c,d,f,g,h="padding:0;margin:0;border:0;display:block;overflow:hidden;",i=e.getElementsByTagName("body")[0];if(!i)return;c=e.createElement("div"),c.style.cssText="visibility:hidden;border:0;width:0;height:0;position:static;top:0;margin-top:1px",i.insertBefore(c,i.firstChild),d=e.createElement("div"),c.appendChild(d),d.innerHTML="
t
",f=d.getElementsByTagName("td"),f[0].style.cssText="padding:0;margin:0;border:0;display:none",l=f[0].offsetHeight===0,f[0].style.display="",f[1].style.display="none",b.reliableHiddenOffsets=l&&f[0].offsetHeight===0,d.innerHTML="",d.style.cssText="box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;",b.boxSizing=d.offsetWidth===4,b.doesNotIncludeMarginInBodyOffset=i.offsetTop!==1,a.getComputedStyle&&(b.pixelPosition=(a.getComputedStyle(d,null)||{}).top!=="1%",b.boxSizingReliable=(a.getComputedStyle(d,null)||{width:"4px"}).width==="4px",g=e.createElement("div"),g.style.cssText=d.style.cssText=h,g.style.marginRight=g.style.width="0",d.style.width="1px",d.appendChild(g),b.reliableMarginRight=!parseFloat((a.getComputedStyle(g,null)||{}).marginRight)),typeof d.style.zoom!="undefined"&&(d.innerHTML="",d.style.cssText=h+"width:1px;padding:1px;display:inline;zoom:1",b.inlineBlockNeedsLayout=d.offsetWidth===3,d.style.display="block",d.style.overflow="visible",d.innerHTML="
",d.firstChild.style.width="5px",b.shrinkWrapBlocks=d.offsetWidth!==3,c.style.zoom=1),i.removeChild(c),c=d=f=g=null}),i.removeChild(n),c=d=f=g=h=i=n=null,b}();var H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,I=/([A-Z])/g;p.extend({cache:{},deletedIds:[],uuid:0,expando:"jQuery"+(p.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){return a=a.nodeType?p.cache[a[p.expando]]:a[p.expando],!!a&&!K(a)},data:function(a,c,d,e){if(!p.acceptData(a))return;var f,g,h=p.expando,i=typeof c=="string",j=a.nodeType,k=j?p.cache:a,l=j?a[h]:a[h]&&h;if((!l||!k[l]||!e&&!k[l].data)&&i&&d===b)return;l||(j?a[h]=l=p.deletedIds.pop()||++p.uuid:l=h),k[l]||(k[l]={},j||(k[l].toJSON=p.noop));if(typeof c=="object"||typeof c=="function")e?k[l]=p.extend(k[l],c):k[l].data=p.extend(k[l].data,c);return f=k[l],e||(f.data||(f.data={}),f=f.data),d!==b&&(f[p.camelCase(c)]=d),i?(g=f[c],g==null&&(g=f[p.camelCase(c)])):g=f,g},removeData:function(a,b,c){if(!p.acceptData(a))return;var d,e,f,g=a.nodeType,h=g?p.cache:a,i=g?a[p.expando]:p.expando;if(!h[i])return;if(b){d=c?h[i]:h[i].data;if(d){p.isArray(b)||(b in d?b=[b]:(b=p.camelCase(b),b in d?b=[b]:b=b.split(" ")));for(e=0,f=b.length;e1,null,!1))},removeData:function(a){return this.each(function(){p.removeData(this,a)})}}),p.extend({queue:function(a,b,c){var d;if(a)return b=(b||"fx")+"queue",d=p._data(a,b),c&&(!d||p.isArray(c)?d=p._data(a,b,p.makeArray(c)):d.push(c)),d||[]},dequeue:function(a,b){b=b||"fx";var c=p.queue(a,b),d=c.length,e=c.shift(),f=p._queueHooks(a,b),g=function(){p.dequeue(a,b)};e==="inprogress"&&(e=c.shift(),d--),e&&(b==="fx"&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return p._data(a,c)||p._data(a,c,{empty:p.Callbacks("once memory").add(function(){p.removeData(a,b+"queue",!0),p.removeData(a,c,!0)})})}}),p.fn.extend({queue:function(a,c){var d=2;return typeof a!="string"&&(c=a,a="fx",d--),arguments.length1)},removeAttr:function(a){return this.each(function(){p.removeAttr(this,a)})},prop:function(a,b){return p.access(this,p.prop,a,b,arguments.length>1)},removeProp:function(a){return a=p.propFix[a]||a,this.each(function(){try{this[a]=b,delete this[a]}catch(c){}})},addClass:function(a){var b,c,d,e,f,g,h;if(p.isFunction(a))return this.each(function(b){p(this).addClass(a.call(this,b,this.className))});if(a&&typeof a=="string"){b=a.split(s);for(c=0,d=this.length;c-1)d=d.replace(" "+c[f]+" "," ");e.className=a?p.trim(d):""}}}return this},toggleClass:function(a,b){var c=typeof a,d=typeof b=="boolean";return p.isFunction(a)?this.each(function(c){p(this).toggleClass(a.call(this,c,this.className,b),b)}):this.each(function(){if(c==="string"){var e,f=0,g=p(this),h=b,i=a.split(s);while(e=i[f++])h=d?h:!g.hasClass(e),g[h?"addClass":"removeClass"](e)}else if(c==="undefined"||c==="boolean")this.className&&p._data(this,"__className__",this.className),this.className=this.className||a===!1?"":p._data(this,"__className__")||""})},hasClass:function(a){var b=" "+a+" ",c=0,d=this.length;for(;c-1)return!0;return!1},val:function(a){var c,d,e,f=this[0];if(!arguments.length){if(f)return c=p.valHooks[f.type]||p.valHooks[f.nodeName.toLowerCase()],c&&"get"in c&&(d=c.get(f,"value"))!==b?d:(d=f.value,typeof d=="string"?d.replace(P,""):d==null?"":d);return}return e=p.isFunction(a),this.each(function(d){var f,g=p(this);if(this.nodeType!==1)return;e?f=a.call(this,d,g.val()):f=a,f==null?f="":typeof f=="number"?f+="":p.isArray(f)&&(f=p.map(f,function(a){return a==null?"":a+""})),c=p.valHooks[this.type]||p.valHooks[this.nodeName.toLowerCase()];if(!c||!("set"in c)||c.set(this,f,"value")===b)this.value=f})}}),p.extend({valHooks:{option:{get:function(a){var b=a.attributes.value;return!b||b.specified?a.value:a.text}},select:{get:function(a){var b,c,d,e,f=a.selectedIndex,g=[],h=a.options,i=a.type==="select-one";if(f<0)return null;c=i?f:0,d=i?f+1:h.length;for(;c=0}),c.length||(a.selectedIndex=-1),c}}},attrFn:{},attr:function(a,c,d,e){var f,g,h,i=a.nodeType;if(!a||i===3||i===8||i===2)return;if(e&&p.isFunction(p.fn[c]))return p(a)[c](d);if(typeof a.getAttribute=="undefined")return p.prop(a,c,d);h=i!==1||!p.isXMLDoc(a),h&&(c=c.toLowerCase(),g=p.attrHooks[c]||(T.test(c)?M:L));if(d!==b){if(d===null){p.removeAttr(a,c);return}return g&&"set"in g&&h&&(f=g.set(a,d,c))!==b?f:(a.setAttribute(c,""+d),d)}return g&&"get"in g&&h&&(f=g.get(a,c))!==null?f:(f=a.getAttribute(c),f===null?b:f)},removeAttr:function(a,b){var c,d,e,f,g=0;if(b&&a.nodeType===1){d=b.split(s);for(;g=0}})});var V=/^(?:textarea|input|select)$/i,W=/^([^\.]*|)(?:\.(.+)|)$/,X=/(?:^|\s)hover(\.\S+|)\b/,Y=/^key/,Z=/^(?:mouse|contextmenu)|click/,$=/^(?:focusinfocus|focusoutblur)$/,_=function(a){return p.event.special.hover?a:a.replace(X,"mouseenter$1 mouseleave$1")};p.event={add:function(a,c,d,e,f){var g,h,i,j,k,l,m,n,o,q,r;if(a.nodeType===3||a.nodeType===8||!c||!d||!(g=p._data(a)))return;d.handler&&(o=d,d=o.handler,f=o.selector),d.guid||(d.guid=p.guid++),i=g.events,i||(g.events=i={}),h=g.handle,h||(g.handle=h=function(a){return typeof p!="undefined"&&(!a||p.event.triggered!==a.type)?p.event.dispatch.apply(h.elem,arguments):b},h.elem=a),c=p.trim(_(c)).split(" ");for(j=0;j=0&&(s=s.slice(0,-1),i=!0),s.indexOf(".")>=0&&(t=s.split("."),s=t.shift(),t.sort());if((!f||p.event.customEvent[s])&&!p.event.global[s])return;c=typeof c=="object"?c[p.expando]?c:new p.Event(s,c):new p.Event(s),c.type=s,c.isTrigger=!0,c.exclusive=i,c.namespace=t.join("."),c.namespace_re=c.namespace?new RegExp("(^|\\.)"+t.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,m=s.indexOf(":")<0?"on"+s:"";if(!f){h=p.cache;for(j in h)h[j].events&&h[j].events[s]&&p.event.trigger(c,d,h[j].handle.elem,!0);return}c.result=b,c.target||(c.target=f),d=d!=null?p.makeArray(d):[],d.unshift(c),n=p.event.special[s]||{};if(n.trigger&&n.trigger.apply(f,d)===!1)return;q=[[f,n.bindType||s]];if(!g&&!n.noBubble&&!p.isWindow(f)){r=n.delegateType||s,k=$.test(r+s)?f:f.parentNode;for(l=f;k;k=k.parentNode)q.push([k,r]),l=k;l===(f.ownerDocument||e)&&q.push([l.defaultView||l.parentWindow||a,r])}for(j=0;j=0),h[l]&&j.push(k);j.length&&t.push({elem:f,matches:j})}n.length>o&&t.push({elem:this,matches:n.slice(o)});for(d=0;d0?this.on(b,null,a,c):this.trigger(b)},Y.test(b)&&(p.event.fixHooks[b]=p.event.keyHooks),Z.test(b)&&(p.event.fixHooks[b]=p.event.mouseHooks)}),function(a,b){function $(a,b,c,d){c=c||[],b=b||q;var e,f,g,j,k=b.nodeType;if(k!==1&&k!==9)return[];if(!a||typeof a!="string")return c;g=h(b);if(!g&&!d)if(e=L.exec(a))if(j=e[1]){if(k===9){f=b.getElementById(j);if(!f||!f.parentNode)return c;if(f.id===j)return c.push(f),c}else if(b.ownerDocument&&(f=b.ownerDocument.getElementById(j))&&i(b,f)&&f.id===j)return c.push(f),c}else{if(e[2])return u.apply(c,t.call(b.getElementsByTagName(a),0)),c;if((j=e[3])&&X&&b.getElementsByClassName)return u.apply(c,t.call(b.getElementsByClassName(j),0)),c}return bk(a,b,c,d,g)}function _(a){return function(b){var c=b.nodeName.toLowerCase();return c==="input"&&b.type===a}}function ba(a){return function(b){var c=b.nodeName.toLowerCase();return(c==="input"||c==="button")&&b.type===a}}function bb(a,b,c){if(a===b)return c;var d=a.nextSibling;while(d){if(d===b)return-1;d=d.nextSibling}return 1}function bc(a,b,c,d){var e,g,h,i,j,k,l,m,n,p,r=!c&&b!==q,s=(r?"":"")+a.replace(H,"$1"),u=y[o][s];if(u)return d?0:t.call(u,0);j=a,k=[],m=0,n=f.preFilter,p=f.filter;while(j){if(!e||(g=I.exec(j)))g&&(j=j.slice(g[0].length),h.selector=l),k.push(h=[]),l="",r&&(j=" "+j);e=!1;if(g=J.exec(j))l+=g[0],j=j.slice(g[0].length),e=h.push({part:g.pop().replace(H," "),string:g[0],captures:g});for(i in p)(g=S[i].exec(j))&&(!n[i]||(g=n[i](g,b,c)))&&(l+=g[0],j=j.slice(g[0].length),e=h.push({part:i,string:g.shift(),captures:g}));if(!e)break}return l&&(h.selector=l),d?j.length:j?$.error(a):t.call(y(s,k),0)}function bd(a,b,e,f){var g=b.dir,h=s++;return a||(a=function(a){return a===e}),b.first?function(b){while(b=b[g])if(b.nodeType===1)return a(b)&&b}:f?function(b){while(b=b[g])if(b.nodeType===1&&a(b))return b}:function(b){var e,f=h+"."+c,i=f+"."+d;while(b=b[g])if(b.nodeType===1){if((e=b[o])===i)return b.sizset;if(typeof e=="string"&&e.indexOf(f)===0){if(b.sizset)return b}else{b[o]=i;if(a(b))return b.sizset=!0,b;b.sizset=!1}}}}function be(a,b){return a?function(c){var d=b(c);return d&&a(d===!0?c:d)}:b}function bf(a,b,c){var d,e,g=0;for(;d=a[g];g++)f.relative[d.part]?e=bd(e,f.relative[d.part],b,c):e=be(e,f.filter[d.part].apply(null,d.captures.concat(b,c)));return e}function bg(a){return function(b){var c,d=0;for(;c=a[d];d++)if(c(b))return!0;return!1}}function bh(a,b,c,d){var e=0,f=b.length;for(;e0?i(h,c,g):[]}function bj(a,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q,r,s=0,t=a.length,v=S.POS,w=new RegExp("^"+v.source+"(?!"+A+")","i"),x=function(){var a=1,c=arguments.length-2;for(;al){g+=k.slice(l,n.index),l=p,q=[c],J.test(g)&&(m&&(q=m),m=e);if(r=O.test(g))g=g.slice(0,-5).replace(J,"$&*"),l++;n.length>1&&n[0].replace(w,x),m=bi(g,n[1],n[2],q,m,r)}g=""}}o||(g+=k),o=!1}g?J.test(g)?bh(g,m||[c],d,e):$(g,c,d,e?e.concat(m):m):u.apply(d,m)}return t===1?d:$.uniqueSort(d)}function bk(a,b,e,g,h){a=a.replace(H,"$1");var i,k,l,m,n,o,p,q,r,s,v=bc(a,b,h),w=b.nodeType;if(S.POS.test(a))return bj(v,b,e,g);if(g)i=t.call(g,0);else if(v.length===1){if((o=t.call(v[0],0)).length>2&&(p=o[0]).part==="ID"&&w===9&&!h&&f.relative[o[1].part]){b=f.find.ID(p.captures[0].replace(R,""),b,h)[0];if(!b)return e;a=a.slice(o.shift().string.length)}r=(v=N.exec(o[0].string))&&!v.index&&b.parentNode||b,q="";for(n=o.length-1;n>=0;n--){p=o[n],s=p.part,q=p.string+q;if(f.relative[s])break;if(f.order.test(s)){i=f.find[s](p.captures[0].replace(R,""),r,h);if(i==null)continue;a=a.slice(0,a.length-q.length)+q.replace(S[s],""),a||u.apply(e,t.call(i,0));break}}}if(a){k=j(a,b,h),c=k.dirruns++,i==null&&(i=f.find.TAG("*",N.test(a)&&b.parentNode||b));for(n=0;m=i[n];n++)d=k.runs++,k(m)&&e.push(m)}return e}var c,d,e,f,g,h,i,j,k,l,m=!0,n="undefined",o=("sizcache"+Math.random()).replace(".",""),q=a.document,r=q.documentElement,s=0,t=[].slice,u=[].push,v=function(a,b){return a[o]=b||!0,a},w=function(){var a={},b=[];return v(function(c,d){return b.push(c)>f.cacheLength&&delete a[b.shift()],a[c]=d},a)},x=w(),y=w(),z=w(),A="[\\x20\\t\\r\\n\\f]",B="(?:\\\\.|[-\\w]|[^\\x00-\\xa0])+",C=B.replace("w","w#"),D="([*^$|!~]?=)",E="\\["+A+"*("+B+")"+A+"*(?:"+D+A+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+C+")|)|)"+A+"*\\]",F=":("+B+")(?:\\((?:(['\"])((?:\\\\.|[^\\\\])*?)\\2|([^()[\\]]*|(?:(?:"+E+")|[^:]|\\\\.)*|.*))\\)|)",G=":(nth|eq|gt|lt|first|last|even|odd)(?:\\(((?:-\\d)?\\d*)\\)|)(?=[^-]|$)",H=new RegExp("^"+A+"+|((?:^|[^\\\\])(?:\\\\.)*)"+A+"+$","g"),I=new RegExp("^"+A+"*,"+A+"*"),J=new RegExp("^"+A+"*([\\x20\\t\\r\\n\\f>+~])"+A+"*"),K=new RegExp(F),L=/^(?:#([\w\-]+)|(\w+)|\.([\w\-]+))$/,M=/^:not/,N=/[\x20\t\r\n\f]*[+~]/,O=/:not\($/,P=/h\d/i,Q=/input|select|textarea|button/i,R=/\\(?!\\)/g,S={ID:new RegExp("^#("+B+")"),CLASS:new RegExp("^\\.("+B+")"),NAME:new RegExp("^\\[name=['\"]?("+B+")['\"]?\\]"),TAG:new RegExp("^("+B.replace("w","w*")+")"),ATTR:new RegExp("^"+E),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|nth|last|first)-child(?:\\("+A+"*(even|odd|(([+-]|)(\\d*)n|)"+A+"*(?:([+-]|)"+A+"*(\\d+)|))"+A+"*\\)|)","i"),POS:new RegExp(G,"ig"),needsContext:new RegExp("^"+A+"*[>+~]|"+G,"i")},T=function(a){var b=q.createElement("div");try{return a(b)}catch(c){return!1}finally{b=null}},U=T(function(a){return a.appendChild(q.createComment("")),!a.getElementsByTagName("*").length}),V=T(function(a){return a.innerHTML="",a.firstChild&&typeof a.firstChild.getAttribute!==n&&a.firstChild.getAttribute("href")==="#"}),W=T(function(a){a.innerHTML="";var b=typeof a.lastChild.getAttribute("multiple");return b!=="boolean"&&b!=="string"}),X=T(function(a){return a.innerHTML="",!a.getElementsByClassName||!a.getElementsByClassName("e").length?!1:(a.lastChild.className="e",a.getElementsByClassName("e").length===2)}),Y=T(function(a){a.id=o+0,a.innerHTML="
",r.insertBefore(a,r.firstChild);var b=q.getElementsByName&&q.getElementsByName(o).length===2+q.getElementsByName(o+0).length;return e=!q.getElementById(o),r.removeChild(a),b});try{t.call(r.childNodes,0)[0].nodeType}catch(Z){t=function(a){var b,c=[];for(;b=this[a];a++)c.push(b);return c}}$.matches=function(a,b){return $(a,null,null,b)},$.matchesSelector=function(a,b){return $(b,null,null,[a]).length>0},g=$.getText=function(a){var b,c="",d=0,e=a.nodeType;if(e){if(e===1||e===9||e===11){if(typeof a.textContent=="string")return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=g(a)}else if(e===3||e===4)return a.nodeValue}else for(;b=a[d];d++)c+=g(b);return c},h=$.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?b.nodeName!=="HTML":!1},i=$.contains=r.contains?function(a,b){var c=a.nodeType===9?a.documentElement:a,d=b&&b.parentNode;return a===d||!!(d&&d.nodeType===1&&c.contains&&c.contains(d))}:r.compareDocumentPosition?function(a,b){return b&&!!(a.compareDocumentPosition(b)&16)}:function(a,b){while(b=b.parentNode)if(b===a)return!0;return!1},$.attr=function(a,b){var c,d=h(a);return d||(b=b.toLowerCase()),f.attrHandle[b]?f.attrHandle[b](a):W||d?a.getAttribute(b):(c=a.getAttributeNode(b),c?typeof a[b]=="boolean"?a[b]?b:null:c.specified?c.value:null:null)},f=$.selectors={cacheLength:50,createPseudo:v,match:S,order:new RegExp("ID|TAG"+(Y?"|NAME":"")+(X?"|CLASS":"")),attrHandle:V?{}:{href:function(a){return a.getAttribute("href",2)},type:function(a){return a.getAttribute("type")}},find:{ID:e?function(a,b,c){if(typeof b.getElementById!==n&&!c){var d=b.getElementById(a);return d&&d.parentNode?[d]:[]}}:function(a,c,d){if(typeof c.getElementById!==n&&!d){var e=c.getElementById(a);return e?e.id===a||typeof e.getAttributeNode!==n&&e.getAttributeNode("id").value===a?[e]:b:[]}},TAG:U?function(a,b){if(typeof b.getElementsByTagName!==n)return b.getElementsByTagName(a)}:function(a,b){var c=b.getElementsByTagName(a);if(a==="*"){var d,e=[],f=0;for(;d=c[f];f++)d.nodeType===1&&e.push(d);return e}return c},NAME:function(a,b){if(typeof b.getElementsByName!==n)return b.getElementsByName(name)},CLASS:function(a,b,c){if(typeof b.getElementsByClassName!==n&&!c)return b.getElementsByClassName(a)}},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(R,""),a[3]=(a[4]||a[5]||"").replace(R,""),a[2]==="~="&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),a[1]==="nth"?(a[2]||$.error(a[0]),a[3]=+(a[3]?a[4]+(a[5]||1):2*(a[2]==="even"||a[2]==="odd")),a[4]=+(a[6]+a[7]||a[2]==="odd")):a[2]&&$.error(a[0]),a},PSEUDO:function(a,b,c){var d,e;if(S.CHILD.test(a[0]))return null;if(a[3])a[2]=a[3];else if(d=a[4])K.test(d)&&(e=bc(d,b,c,!0))&&(e=d.indexOf(")",d.length-e)-d.length)&&(d=d.slice(0,e),a[0]=a[0].slice(0,e)),a[2]=d;return a.slice(0,3)}},filter:{ID:e?function(a){return a=a.replace(R,""),function(b){return b.getAttribute("id")===a}}:function(a){return a=a.replace(R,""),function(b){var c=typeof b.getAttributeNode!==n&&b.getAttributeNode("id");return c&&c.value===a}},TAG:function(a){return a==="*"?function(){return!0}:(a=a.replace(R,"").toLowerCase(),function(b){return b.nodeName&&b.nodeName.toLowerCase()===a})},CLASS:function(a){var b=x[o][a];return b||(b=x(a,new RegExp("(^|"+A+")"+a+"("+A+"|$)"))),function(a){return b.test(a.className||typeof a.getAttribute!==n&&a.getAttribute("class")||"")}},ATTR:function(a,b,c){return b?function(d){var e=$.attr(d,a),f=e+"";if(e==null)return b==="!=";switch(b){case"=":return f===c;case"!=":return f!==c;case"^=":return c&&f.indexOf(c)===0;case"*=":return c&&f.indexOf(c)>-1;case"$=":return c&&f.substr(f.length-c.length)===c;case"~=":return(" "+f+" ").indexOf(c)>-1;case"|=":return f===c||f.substr(0,c.length+1)===c+"-"}}:function(b){return $.attr(b,a)!=null}},CHILD:function(a,b,c,d){if(a==="nth"){var e=s++;return function(a){var b,f,g=0,h=a;if(c===1&&d===0)return!0;b=a.parentNode;if(b&&(b[o]!==e||!a.sizset)){for(h=b.firstChild;h;h=h.nextSibling)if(h.nodeType===1){h.sizset=++g;if(h===a)break}b[o]=e}return f=a.sizset-d,c===0?f===0:f%c===0&&f/c>=0}}return function(b){var c=b;switch(a){case"only":case"first":while(c=c.previousSibling)if(c.nodeType===1)return!1;if(a==="first")return!0;c=b;case"last":while(c=c.nextSibling)if(c.nodeType===1)return!1;return!0}}},PSEUDO:function(a,b,c,d){var e,g=f.pseudos[a]||f.pseudos[a.toLowerCase()];return g||$.error("unsupported pseudo: "+a),g[o]?g(b,c,d):g.length>1?(e=[a,a,"",b],function(a){return g(a,0,e)}):g}},pseudos:{not:v(function(a,b,c){var d=j(a.replace(H,"$1"),b,c);return function(a){return!d(a)}}),enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&!!a.checked||b==="option"&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},parent:function(a){return!f.pseudos.empty(a)},empty:function(a){var b;a=a.firstChild;while(a){if(a.nodeName>"@"||(b=a.nodeType)===3||b===4)return!1;a=a.nextSibling}return!0},contains:v(function(a){return function(b){return(b.textContent||b.innerText||g(b)).indexOf(a)>-1}}),has:v(function(a){return function(b){return $(a,b).length>0}}),header:function(a){return P.test(a.nodeName)},text:function(a){var b,c;return a.nodeName.toLowerCase()==="input"&&(b=a.type)==="text"&&((c=a.getAttribute("type"))==null||c.toLowerCase()===b)},radio:_("radio"),checkbox:_("checkbox"),file:_("file"),password:_("password"),image:_("image"),submit:ba("submit"),reset:ba("reset"),button:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&a.type==="button"||b==="button"},input:function(a){return Q.test(a.nodeName)},focus:function(a){var b=a.ownerDocument;return a===b.activeElement&&(!b.hasFocus||b.hasFocus())&&(!!a.type||!!a.href)},active:function(a){return a===a.ownerDocument.activeElement}},setFilters:{first:function(a,b,c){return c?a.slice(1):[a[0]]},last:function(a,b,c){var d=a.pop();return c?a:[d]},even:function(a,b,c){var d=[],e=c?1:0,f=a.length;for(;e",a.querySelectorAll("[selected]").length||e.push("\\["+A+"*(?:checked|disabled|ismap|multiple|readonly|selected|value)"),a.querySelectorAll(":checked").length||e.push(":checked")}),T(function(a){a.innerHTML="

",a.querySelectorAll("[test^='']").length&&e.push("[*^$]="+A+"*(?:\"\"|'')"),a.innerHTML="",a.querySelectorAll(":enabled").length||e.push(":enabled",":disabled")}),e=e.length&&new RegExp(e.join("|")),bk=function(a,d,f,g,h){if(!g&&!h&&(!e||!e.test(a)))if(d.nodeType===9)try{return u.apply(f,t.call(d.querySelectorAll(a),0)),f}catch(i){}else if(d.nodeType===1&&d.nodeName.toLowerCase()!=="object"){var j,k,l,m=d.getAttribute("id"),n=m||o,p=N.test(a)&&d.parentNode||d;m?n=n.replace(c,"\\$&"):d.setAttribute("id",n),j=bc(a,d,h),n="[id='"+n+"']";for(k=0,l=j.length;k0})}(),f.setFilters.nth=f.setFilters.eq,f.filters=f.pseudos,$.attr=p.attr,p.find=$,p.expr=$.selectors,p.expr[":"]=p.expr.pseudos,p.unique=$.uniqueSort,p.text=$.getText,p.isXMLDoc=$.isXML,p.contains=$.contains}(a);var bc=/Until$/,bd=/^(?:parents|prev(?:Until|All))/,be=/^.[^:#\[\.,]*$/,bf=p.expr.match.needsContext,bg={children:!0,contents:!0,next:!0,prev:!0};p.fn.extend({find:function(a){var b,c,d,e,f,g,h=this;if(typeof a!="string")return p(a).filter(function(){for(b=0,c=h.length;b0)for(e=d;e=0:p.filter(a,this).length>0:this.filter(a).length>0)},closest:function(a,b){var c,d=0,e=this.length,f=[],g=bf.test(a)||typeof a!="string"?p(a,b||this.context):0;for(;d-1:p.find.matchesSelector(c,a)){f.push(c);break}c=c.parentNode}}return f=f.length>1?p.unique(f):f,this.pushStack(f,"closest",a)},index:function(a){return a?typeof a=="string"?p.inArray(this[0],p(a)):p.inArray(a.jquery?a[0]:a,this):this[0]&&this[0].parentNode?this.prevAll().length:-1},add:function(a,b){var c=typeof a=="string"?p(a,b):p.makeArray(a&&a.nodeType?[a]:a),d=p.merge(this.get(),c);return this.pushStack(bh(c[0])||bh(d[0])?d:p.unique(d))},addBack:function(a){return this.add(a==null?this.prevObject:this.prevObject.filter(a))}}),p.fn.andSelf=p.fn.addBack,p.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return p.dir(a,"parentNode")},parentsUntil:function(a,b,c){return p.dir(a,"parentNode",c)},next:function(a){return bi(a,"nextSibling")},prev:function(a){return bi(a,"previousSibling")},nextAll:function(a){return p.dir(a,"nextSibling")},prevAll:function(a){return p.dir(a,"previousSibling")},nextUntil:function(a,b,c){return p.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return p.dir(a,"previousSibling",c)},siblings:function(a){return p.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return p.sibling(a.firstChild)},contents:function(a){return p.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:p.merge([],a.childNodes)}},function(a,b){p.fn[a]=function(c,d){var e=p.map(this,b,c);return bc.test(a)||(d=c),d&&typeof d=="string"&&(e=p.filter(d,e)),e=this.length>1&&!bg[a]?p.unique(e):e,this.length>1&&bd.test(a)&&(e=e.reverse()),this.pushStack(e,a,k.call(arguments).join(","))}}),p.extend({filter:function(a,b,c){return c&&(a=":not("+a+")"),b.length===1?p.find.matchesSelector(b[0],a)?[b[0]]:[]:p.find.matches(a,b)},dir:function(a,c,d){var e=[],f=a[c];while(f&&f.nodeType!==9&&(d===b||f.nodeType!==1||!p(f).is(d)))f.nodeType===1&&e.push(f),f=f[c];return e},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var bl="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",bm=/ jQuery\d+="(?:null|\d+)"/g,bn=/^\s+/,bo=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bp=/<([\w:]+)/,bq=/]","i"),bv=/^(?:checkbox|radio)$/,bw=/checked\s*(?:[^=]|=\s*.checked.)/i,bx=/\/(java|ecma)script/i,by=/^\s*\s*$/g,bz={option:[1,""],legend:[1,"
","
"],thead:[1,"","
"],tr:[2,"","
"],td:[3,"","
"],col:[2,"","
"],area:[1,"",""],_default:[0,"",""]},bA=bk(e),bB=bA.appendChild(e.createElement("div"));bz.optgroup=bz.option,bz.tbody=bz.tfoot=bz.colgroup=bz.caption=bz.thead,bz.th=bz.td,p.support.htmlSerialize||(bz._default=[1,"X
","
"]),p.fn.extend({text:function(a){return p.access(this,function(a){return a===b?p.text(this):this.empty().append((this[0]&&this[0].ownerDocument||e).createTextNode(a))},null,a,arguments.length)},wrapAll:function(a){if(p.isFunction(a))return this.each(function(b){p(this).wrapAll(a.call(this,b))});if(this[0]){var b=p(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){return p.isFunction(a)?this.each(function(b){p(this).wrapInner(a.call(this,b))}):this.each(function(){var b=p(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=p.isFunction(a);return this.each(function(c){p(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){p.nodeName(this,"body")||p(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){(this.nodeType===1||this.nodeType===11)&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){(this.nodeType===1||this.nodeType===11)&&this.insertBefore(a,this.firstChild)})},before:function(){if(!bh(this[0]))return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=p.clean(arguments);return this.pushStack(p.merge(a,this),"before",this.selector)}},after:function(){if(!bh(this[0]))return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=p.clean(arguments);return this.pushStack(p.merge(this,a),"after",this.selector)}},remove:function(a,b){var c,d=0;for(;(c=this[d])!=null;d++)if(!a||p.filter(a,[c]).length)!b&&c.nodeType===1&&(p.cleanData(c.getElementsByTagName("*")),p.cleanData([c])),c.parentNode&&c.parentNode.removeChild(c);return this},empty:function(){var a,b=0;for(;(a=this[b])!=null;b++){a.nodeType===1&&p.cleanData(a.getElementsByTagName("*"));while(a.firstChild)a.removeChild(a.firstChild)}return this},clone:function(a,b){return a=a==null?!1:a,b=b==null?a:b,this.map(function(){return p.clone(this,a,b)})},html:function(a){return p.access(this,function(a){var c=this[0]||{},d=0,e=this.length;if(a===b)return c.nodeType===1?c.innerHTML.replace(bm,""):b;if(typeof a=="string"&&!bs.test(a)&&(p.support.htmlSerialize||!bu.test(a))&&(p.support.leadingWhitespace||!bn.test(a))&&!bz[(bp.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(bo,"<$1>");try{for(;d1&&typeof j=="string"&&bw.test(j))return this.each(function(){p(this).domManip(a,c,d)});if(p.isFunction(j))return this.each(function(e){var f=p(this);a[0]=j.call(this,e,c?f.html():b),f.domManip(a,c,d)});if(this[0]){e=p.buildFragment(a,this,k),g=e.fragment,f=g.firstChild,g.childNodes.length===1&&(g=f);if(f){c=c&&p.nodeName(f,"tr");for(h=e.cacheable||l-1;i0?this.clone(!0):this).get(),p(g[e])[b](d),f=f.concat(d);return this.pushStack(f,a,g.selector)}}),p.extend({clone:function(a,b,c){var d,e,f,g;p.support.html5Clone||p.isXMLDoc(a)||!bu.test("<"+a.nodeName+">")?g=a.cloneNode(!0):(bB.innerHTML=a.outerHTML,bB.removeChild(g=bB.firstChild));if((!p.support.noCloneEvent||!p.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!p.isXMLDoc(a)){bE(a,g),d=bF(a),e=bF(g);for(f=0;d[f];++f)e[f]&&bE(d[f],e[f])}if(b){bD(a,g);if(c){d=bF(a),e=bF(g);for(f=0;d[f];++f)bD(d[f],e[f])}}return d=e=null,g},clean:function(a,b,c,d){var f,g,h,i,j,k,l,m,n,o,q,r,s=b===e&&bA,t=[];if(!b||typeof b.createDocumentFragment=="undefined")b=e;for(f=0;(h=a[f])!=null;f++){typeof h=="number"&&(h+="");if(!h)continue;if(typeof h=="string")if(!br.test(h))h=b.createTextNode(h);else{s=s||bk(b),l=b.createElement("div"),s.appendChild(l),h=h.replace(bo,"<$1>"),i=(bp.exec(h)||["",""])[1].toLowerCase(),j=bz[i]||bz._default,k=j[0],l.innerHTML=j[1]+h+j[2];while(k--)l=l.lastChild;if(!p.support.tbody){m=bq.test(h),n=i==="table"&&!m?l.firstChild&&l.firstChild.childNodes:j[1]===""&&!m?l.childNodes:[];for(g=n.length-1;g>=0;--g)p.nodeName(n[g],"tbody")&&!n[g].childNodes.length&&n[g].parentNode.removeChild(n[g])}!p.support.leadingWhitespace&&bn.test(h)&&l.insertBefore(b.createTextNode(bn.exec(h)[0]),l.firstChild),h=l.childNodes,l.parentNode.removeChild(l)}h.nodeType?t.push(h):p.merge(t,h)}l&&(h=l=s=null);if(!p.support.appendChecked)for(f=0;(h=t[f])!=null;f++)p.nodeName(h,"input")?bG(h):typeof h.getElementsByTagName!="undefined"&&p.grep(h.getElementsByTagName("input"),bG);if(c){q=function(a){if(!a.type||bx.test(a.type))return d?d.push(a.parentNode?a.parentNode.removeChild(a):a):c.appendChild(a)};for(f=0;(h=t[f])!=null;f++)if(!p.nodeName(h,"script")||!q(h))c.appendChild(h),typeof h.getElementsByTagName!="undefined"&&(r=p.grep(p.merge([],h.getElementsByTagName("script")),q),t.splice.apply(t,[f+1,0].concat(r)),f+=r.length)}return t},cleanData:function(a,b){var c,d,e,f,g=0,h=p.expando,i=p.cache,j=p.support.deleteExpando,k=p.event.special;for(;(e=a[g])!=null;g++)if(b||p.acceptData(e)){d=e[h],c=d&&i[d];if(c){if(c.events)for(f in c.events)k[f]?p.event.remove(e,f):p.removeEvent(e,f,c.handle);i[d]&&(delete i[d],j?delete e[h]:e.removeAttribute?e.removeAttribute(h):e[h]=null,p.deletedIds.push(d))}}}}),function(){var a,b;p.uaMatch=function(a){a=a.toLowerCase();var b=/(chrome)[ \/]([\w.]+)/.exec(a)||/(webkit)[ \/]([\w.]+)/.exec(a)||/(opera)(?:.*version|)[ \/]([\w.]+)/.exec(a)||/(msie) ([\w.]+)/.exec(a)||a.indexOf("compatible")<0&&/(mozilla)(?:.*? rv:([\w.]+)|)/.exec(a)||[];return{browser:b[1]||"",version:b[2]||"0"}},a=p.uaMatch(g.userAgent),b={},a.browser&&(b[a.browser]=!0,b.version=a.version),b.chrome?b.webkit=!0:b.webkit&&(b.safari=!0),p.browser=b,p.sub=function(){function a(b,c){return new a.fn.init(b,c)}p.extend(!0,a,this),a.superclass=this,a.fn=a.prototype=this(),a.fn.constructor=a,a.sub=this.sub,a.fn.init=function c(c,d){return d&&d instanceof p&&!(d instanceof a)&&(d=a(d)),p.fn.init.call(this,c,d,b)},a.fn.init.prototype=a.fn;var b=a(e);return a}}();var bH,bI,bJ,bK=/alpha\([^)]*\)/i,bL=/opacity=([^)]*)/,bM=/^(top|right|bottom|left)$/,bN=/^(none|table(?!-c[ea]).+)/,bO=/^margin/,bP=new RegExp("^("+q+")(.*)$","i"),bQ=new RegExp("^("+q+")(?!px)[a-z%]+$","i"),bR=new RegExp("^([-+])=("+q+")","i"),bS={},bT={position:"absolute",visibility:"hidden",display:"block"},bU={letterSpacing:0,fontWeight:400},bV=["Top","Right","Bottom","Left"],bW=["Webkit","O","Moz","ms"],bX=p.fn.toggle;p.fn.extend({css:function(a,c){return p.access(this,function(a,c,d){return d!==b?p.style(a,c,d):p.css(a,c)},a,c,arguments.length>1)},show:function(){return b$(this,!0)},hide:function(){return b$(this)},toggle:function(a,b){var c=typeof a=="boolean";return p.isFunction(a)&&p.isFunction(b)?bX.apply(this,arguments):this.each(function(){(c?a:bZ(this))?p(this).show():p(this).hide()})}}),p.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=bH(a,"opacity");return c===""?"1":c}}}},cssNumber:{fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":p.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,c,d,e){if(!a||a.nodeType===3||a.nodeType===8||!a.style)return;var f,g,h,i=p.camelCase(c),j=a.style;c=p.cssProps[i]||(p.cssProps[i]=bY(j,i)),h=p.cssHooks[c]||p.cssHooks[i];if(d===b)return h&&"get"in h&&(f=h.get(a,!1,e))!==b?f:j[c];g=typeof d,g==="string"&&(f=bR.exec(d))&&(d=(f[1]+1)*f[2]+parseFloat(p.css(a,c)),g="number");if(d==null||g==="number"&&isNaN(d))return;g==="number"&&!p.cssNumber[i]&&(d+="px");if(!h||!("set"in h)||(d=h.set(a,d,e))!==b)try{j[c]=d}catch(k){}},css:function(a,c,d,e){var f,g,h,i=p.camelCase(c);return c=p.cssProps[i]||(p.cssProps[i]=bY(a.style,i)),h=p.cssHooks[c]||p.cssHooks[i],h&&"get"in h&&(f=h.get(a,!0,e)),f===b&&(f=bH(a,c)),f==="normal"&&c in bU&&(f=bU[c]),d||e!==b?(g=parseFloat(f),d||p.isNumeric(g)?g||0:f):f},swap:function(a,b,c){var d,e,f={};for(e in b)f[e]=a.style[e],a.style[e]=b[e];d=c.call(a);for(e in b)a.style[e]=f[e];return d}}),a.getComputedStyle?bH=function(b,c){var d,e,f,g,h=a.getComputedStyle(b,null),i=b.style;return h&&(d=h[c],d===""&&!p.contains(b.ownerDocument,b)&&(d=p.style(b,c)),bQ.test(d)&&bO.test(c)&&(e=i.width,f=i.minWidth,g=i.maxWidth,i.minWidth=i.maxWidth=i.width=d,d=h.width,i.width=e,i.minWidth=f,i.maxWidth=g)),d}:e.documentElement.currentStyle&&(bH=function(a,b){var c,d,e=a.currentStyle&&a.currentStyle[b],f=a.style;return e==null&&f&&f[b]&&(e=f[b]),bQ.test(e)&&!bM.test(b)&&(c=f.left,d=a.runtimeStyle&&a.runtimeStyle.left,d&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":e,e=f.pixelLeft+"px",f.left=c,d&&(a.runtimeStyle.left=d)),e===""?"auto":e}),p.each(["height","width"],function(a,b){p.cssHooks[b]={get:function(a,c,d){if(c)return a.offsetWidth===0&&bN.test(bH(a,"display"))?p.swap(a,bT,function(){return cb(a,b,d)}):cb(a,b,d)},set:function(a,c,d){return b_(a,c,d?ca(a,b,d,p.support.boxSizing&&p.css(a,"boxSizing")==="border-box"):0)}}}),p.support.opacity||(p.cssHooks.opacity={get:function(a,b){return bL.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=p.isNumeric(b)?"alpha(opacity="+b*100+")":"",f=d&&d.filter||c.filter||"";c.zoom=1;if(b>=1&&p.trim(f.replace(bK,""))===""&&c.removeAttribute){c.removeAttribute("filter");if(d&&!d.filter)return}c.filter=bK.test(f)?f.replace(bK,e):f+" "+e}}),p(function(){p.support.reliableMarginRight||(p.cssHooks.marginRight={get:function(a,b){return p.swap(a,{display:"inline-block"},function(){if(b)return bH(a,"marginRight")})}}),!p.support.pixelPosition&&p.fn.position&&p.each(["top","left"],function(a,b){p.cssHooks[b]={get:function(a,c){if(c){var d=bH(a,b);return bQ.test(d)?p(a).position()[b]+"px":d}}}})}),p.expr&&p.expr.filters&&(p.expr.filters.hidden=function(a){return a.offsetWidth===0&&a.offsetHeight===0||!p.support.reliableHiddenOffsets&&(a.style&&a.style.display||bH(a,"display"))==="none"},p.expr.filters.visible=function(a){return!p.expr.filters.hidden(a)}),p.each({margin:"",padding:"",border:"Width"},function(a,b){p.cssHooks[a+b]={expand:function(c){var d,e=typeof c=="string"?c.split(" "):[c],f={};for(d=0;d<4;d++)f[a+bV[d]+b]=e[d]||e[d-2]||e[0];return f}},bO.test(a)||(p.cssHooks[a+b].set=b_)});var cd=/%20/g,ce=/\[\]$/,cf=/\r?\n/g,cg=/^(?:color|date|datetime|datetime-local|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,ch=/^(?:select|textarea)/i;p.fn.extend({serialize:function(){return p.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?p.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||ch.test(this.nodeName)||cg.test(this.type))}).map(function(a,b){var c=p(this).val();return c==null?null:p.isArray(c)?p.map(c,function(a,c){return{name:b.name,value:a.replace(cf,"\r\n")}}):{name:b.name,value:c.replace(cf,"\r\n")}}).get()}}),p.param=function(a,c){var d,e=[],f=function(a,b){b=p.isFunction(b)?b():b==null?"":b,e[e.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};c===b&&(c=p.ajaxSettings&&p.ajaxSettings.traditional);if(p.isArray(a)||a.jquery&&!p.isPlainObject(a))p.each(a,function(){f(this.name,this.value)});else for(d in a)ci(d,a[d],c,f);return e.join("&").replace(cd,"+")};var cj,ck,cl=/#.*$/,cm=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,cn=/^(?:about|app|app\-storage|.+\-extension|file|res|widget):$/,co=/^(?:GET|HEAD)$/,cp=/^\/\//,cq=/\?/,cr=/)<[^<]*)*<\/script>/gi,cs=/([?&])_=[^&]*/,ct=/^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+)|)|)/,cu=p.fn.load,cv={},cw={},cx=["*/"]+["*"];try{cj=f.href}catch(cy){cj=e.createElement("a"),cj.href="",cj=cj.href}ck=ct.exec(cj.toLowerCase())||[],p.fn.load=function(a,c,d){if(typeof a!="string"&&cu)return cu.apply(this,arguments);if(!this.length)return this;var e,f,g,h=this,i=a.indexOf(" ");return i>=0&&(e=a.slice(i,a.length),a=a.slice(0,i)),p.isFunction(c)?(d=c,c=b):c&&typeof c=="object"&&(f="POST"),p.ajax({url:a,type:f,dataType:"html",data:c,complete:function(a,b){d&&h.each(d,g||[a.responseText,b,a])}}).done(function(a){g=arguments,h.html(e?p("
").append(a.replace(cr,"")).find(e):a)}),this},p.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){p.fn[b]=function(a){return this.on(b,a)}}),p.each(["get","post"],function(a,c){p[c]=function(a,d,e,f){return p.isFunction(d)&&(f=f||e,e=d,d=b),p.ajax({type:c,url:a,data:d,success:e,dataType:f})}}),p.extend({getScript:function(a,c){return p.get(a,b,c,"script")},getJSON:function(a,b,c){return p.get(a,b,c,"json")},ajaxSetup:function(a,b){return b?cB(a,p.ajaxSettings):(b=a,a=p.ajaxSettings),cB(a,b),a},ajaxSettings:{url:cj,isLocal:cn.test(ck[1]),global:!0,type:"GET",contentType:"application/x-www-form-urlencoded; charset=UTF-8",processData:!0,async:!0,accepts:{xml:"application/xml, text/xml",html:"text/html",text:"text/plain",json:"application/json, text/javascript","*":cx},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":a.String,"text html":!0,"text json":p.parseJSON,"text xml":p.parseXML},flatOptions:{context:!0,url:!0}},ajaxPrefilter:cz(cv),ajaxTransport:cz(cw),ajax:function(a,c){function y(a,c,f,i){var k,s,t,u,w,y=c;if(v===2)return;v=2,h&&clearTimeout(h),g=b,e=i||"",x.readyState=a>0?4:0,f&&(u=cC(l,x,f));if(a>=200&&a<300||a===304)l.ifModified&&(w=x.getResponseHeader("Last-Modified"),w&&(p.lastModified[d]=w),w=x.getResponseHeader("Etag"),w&&(p.etag[d]=w)),a===304?(y="notmodified",k=!0):(k=cD(l,u),y=k.state,s=k.data,t=k.error,k=!t);else{t=y;if(!y||a)y="error",a<0&&(a=0)}x.status=a,x.statusText=""+(c||y),k?o.resolveWith(m,[s,y,x]):o.rejectWith(m,[x,y,t]),x.statusCode(r),r=b,j&&n.trigger("ajax"+(k?"Success":"Error"),[x,l,k?s:t]),q.fireWith(m,[x,y]),j&&(n.trigger("ajaxComplete",[x,l]),--p.active||p.event.trigger("ajaxStop"))}typeof a=="object"&&(c=a,a=b),c=c||{};var d,e,f,g,h,i,j,k,l=p.ajaxSetup({},c),m=l.context||l,n=m!==l&&(m.nodeType||m instanceof p)?p(m):p.event,o=p.Deferred(),q=p.Callbacks("once memory"),r=l.statusCode||{},t={},u={},v=0,w="canceled",x={readyState:0,setRequestHeader:function(a,b){if(!v){var c=a.toLowerCase();a=u[c]=u[c]||a,t[a]=b}return this},getAllResponseHeaders:function(){return v===2?e:null},getResponseHeader:function(a){var c;if(v===2){if(!f){f={};while(c=cm.exec(e))f[c[1].toLowerCase()]=c[2]}c=f[a.toLowerCase()]}return c===b?null:c},overrideMimeType:function(a){return v||(l.mimeType=a),this},abort:function(a){return a=a||w,g&&g.abort(a),y(0,a),this}};o.promise(x),x.success=x.done,x.error=x.fail,x.complete=q.add,x.statusCode=function(a){if(a){var b;if(v<2)for(b in a)r[b]=[r[b],a[b]];else b=a[x.status],x.always(b)}return this},l.url=((a||l.url)+"").replace(cl,"").replace(cp,ck[1]+"//"),l.dataTypes=p.trim(l.dataType||"*").toLowerCase().split(s),l.crossDomain==null&&(i=ct.exec(l.url.toLowerCase()),l.crossDomain=!(!i||i[1]==ck[1]&&i[2]==ck[2]&&(i[3]||(i[1]==="http:"?80:443))==(ck[3]||(ck[1]==="http:"?80:443)))),l.data&&l.processData&&typeof l.data!="string"&&(l.data=p.param(l.data,l.traditional)),cA(cv,l,c,x);if(v===2)return x;j=l.global,l.type=l.type.toUpperCase(),l.hasContent=!co.test(l.type),j&&p.active++===0&&p.event.trigger("ajaxStart");if(!l.hasContent){l.data&&(l.url+=(cq.test(l.url)?"&":"?")+l.data,delete l.data),d=l.url;if(l.cache===!1){var z=p.now(),A=l.url.replace(cs,"$1_="+z);l.url=A+(A===l.url?(cq.test(l.url)?"&":"?")+"_="+z:"")}}(l.data&&l.hasContent&&l.contentType!==!1||c.contentType)&&x.setRequestHeader("Content-Type",l.contentType),l.ifModified&&(d=d||l.url,p.lastModified[d]&&x.setRequestHeader("If-Modified-Since",p.lastModified[d]),p.etag[d]&&x.setRequestHeader("If-None-Match",p.etag[d])),x.setRequestHeader("Accept",l.dataTypes[0]&&l.accepts[l.dataTypes[0]]?l.accepts[l.dataTypes[0]]+(l.dataTypes[0]!=="*"?", "+cx+"; q=0.01":""):l.accepts["*"]);for(k in l.headers)x.setRequestHeader(k,l.headers[k]);if(!l.beforeSend||l.beforeSend.call(m,x,l)!==!1&&v!==2){w="abort";for(k in{success:1,error:1,complete:1})x[k](l[k]);g=cA(cw,l,c,x);if(!g)y(-1,"No Transport");else{x.readyState=1,j&&n.trigger("ajaxSend",[x,l]),l.async&&l.timeout>0&&(h=setTimeout(function(){x.abort("timeout")},l.timeout));try{v=1,g.send(t,y)}catch(B){if(v<2)y(-1,B);else throw B}}return x}return x.abort()},active:0,lastModified:{},etag:{}});var cE=[],cF=/\?/,cG=/(=)\?(?=&|$)|\?\?/,cH=p.now();p.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=cE.pop()||p.expando+"_"+cH++;return this[a]=!0,a}}),p.ajaxPrefilter("json jsonp",function(c,d,e){var f,g,h,i=c.data,j=c.url,k=c.jsonp!==!1,l=k&&cG.test(j),m=k&&!l&&typeof i=="string"&&!(c.contentType||"").indexOf("application/x-www-form-urlencoded")&&cG.test(i);if(c.dataTypes[0]==="jsonp"||l||m)return f=c.jsonpCallback=p.isFunction(c.jsonpCallback)?c.jsonpCallback():c.jsonpCallback,g=a[f],l?c.url=j.replace(cG,"$1"+f):m?c.data=i.replace(cG,"$1"+f):k&&(c.url+=(cF.test(j)?"&":"?")+c.jsonp+"="+f),c.converters["script json"]=function(){return h||p.error(f+" was not called"),h[0]},c.dataTypes[0]="json",a[f]=function(){h=arguments},e.always(function(){a[f]=g,c[f]&&(c.jsonpCallback=d.jsonpCallback,cE.push(f)),h&&p.isFunction(g)&&g(h[0]),h=g=b}),"script"}),p.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/javascript|ecmascript/},converters:{"text script":function(a){return p.globalEval(a),a}}}),p.ajaxPrefilter("script",function(a){a.cache===b&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),p.ajaxTransport("script",function(a){if(a.crossDomain){var c,d=e.head||e.getElementsByTagName("head")[0]||e.documentElement;return{send:function(f,g){c=e.createElement("script"),c.async="async",a.scriptCharset&&(c.charset=a.scriptCharset),c.src=a.url,c.onload=c.onreadystatechange=function(a,e){if(e||!c.readyState||/loaded|complete/.test(c.readyState))c.onload=c.onreadystatechange=null,d&&c.parentNode&&d.removeChild(c),c=b,e||g(200,"success")},d.insertBefore(c,d.firstChild)},abort:function(){c&&c.onload(0,1)}}}});var cI,cJ=a.ActiveXObject?function(){for(var a in cI)cI[a](0,1)}:!1,cK=0;p.ajaxSettings.xhr=a.ActiveXObject?function(){return!this.isLocal&&cL()||cM()}:cL,function(a){p.extend(p.support,{ajax:!!a,cors:!!a&&"withCredentials"in a})}(p.ajaxSettings.xhr()),p.support.ajax&&p.ajaxTransport(function(c){if(!c.crossDomain||p.support.cors){var d;return{send:function(e,f){var g,h,i=c.xhr();c.username?i.open(c.type,c.url,c.async,c.username,c.password):i.open(c.type,c.url,c.async);if(c.xhrFields)for(h in c.xhrFields)i[h]=c.xhrFields[h];c.mimeType&&i.overrideMimeType&&i.overrideMimeType(c.mimeType),!c.crossDomain&&!e["X-Requested-With"]&&(e["X-Requested-With"]="XMLHttpRequest");try{for(h in e)i.setRequestHeader(h,e[h])}catch(j){}i.send(c.hasContent&&c.data||null),d=function(a,e){var h,j,k,l,m;try{if(d&&(e||i.readyState===4)){d=b,g&&(i.onreadystatechange=p.noop,cJ&&delete cI[g]);if(e)i.readyState!==4&&i.abort();else{h=i.status,k=i.getAllResponseHeaders(),l={},m=i.responseXML,m&&m.documentElement&&(l.xml=m);try{l.text=i.responseText}catch(a){}try{j=i.statusText}catch(n){j=""}!h&&c.isLocal&&!c.crossDomain?h=l.text?200:404:h===1223&&(h=204)}}}catch(o){e||f(-1,o)}l&&f(h,j,l,k)},c.async?i.readyState===4?setTimeout(d,0):(g=++cK,cJ&&(cI||(cI={},p(a).unload(cJ)),cI[g]=d),i.onreadystatechange=d):d()},abort:function(){d&&d(0,1)}}}});var cN,cO,cP=/^(?:toggle|show|hide)$/,cQ=new RegExp("^(?:([-+])=|)("+q+")([a-z%]*)$","i"),cR=/queueHooks$/,cS=[cY],cT={"*":[function(a,b){var c,d,e,f=this.createTween(a,b),g=cQ.exec(b),h=f.cur(),i=+h||0,j=1;if(g){c=+g[2],d=g[3]||(p.cssNumber[a]?"":"px");if(d!=="px"&&i){i=p.css(f.elem,a,!0)||c||1;do e=j=j||".5",i=i/j,p.style(f.elem,a,i+d),j=f.cur()/h;while(j!==1&&j!==e)}f.unit=d,f.start=i,f.end=g[1]?i+(g[1]+1)*c:c}return f}]};p.Animation=p.extend(cW,{tweener:function(a,b){p.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");var c,d=0,e=a.length;for(;d-1,j={},k={},l,m;i?(k=e.position(),l=k.top,m=k.left):(l=parseFloat(g)||0,m=parseFloat(h)||0),p.isFunction(b)&&(b=b.call(a,c,f)),b.top!=null&&(j.top=b.top-f.top+l),b.left!=null&&(j.left=b.left-f.left+m),"using"in b?b.using.call(a,j):e.css(j)}},p.fn.extend({position:function(){if(!this[0])return;var a=this[0],b=this.offsetParent(),c=this.offset(),d=c_.test(b[0].nodeName)?{top:0,left:0}:b.offset();return c.top-=parseFloat(p.css(a,"marginTop"))||0,c.left-=parseFloat(p.css(a,"marginLeft"))||0,d.top+=parseFloat(p.css(b[0],"borderTopWidth"))||0,d.left+=parseFloat(p.css(b[0],"borderLeftWidth"))||0,{top:c.top-d.top,left:c.left-d.left}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||e.body;while(a&&!c_.test(a.nodeName)&&p.css(a,"position")==="static")a=a.offsetParent;return a||e.body})}}),p.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,c){var d=/Y/.test(c);p.fn[a]=function(e){return p.access(this,function(a,e,f){var g=da(a);if(f===b)return g?c in g?g[c]:g.document.documentElement[e]:a[e];g?g.scrollTo(d?p(g).scrollLeft():f,d?f:p(g).scrollTop()):a[e]=f},a,e,arguments.length,null)}}),p.each({Height:"height",Width:"width"},function(a,c){p.each({padding:"inner"+a,content:c,"":"outer"+a},function(d,e){p.fn[e]=function(e,f){var g=arguments.length&&(d||typeof e!="boolean"),h=d||(e===!0||f===!0?"margin":"border");return p.access(this,function(c,d,e){var f;return p.isWindow(c)?c.document.documentElement["client"+a]:c.nodeType===9?(f=c.documentElement,Math.max(c.body["scroll"+a],f["scroll"+a],c.body["offset"+a],f["offset"+a],f["client"+a])):e===b?p.css(c,d,e,h):p.style(c,d,e,h)},c,g?e:b,g,null)}})}),a.jQuery=a.$=p,typeof define=="function"&&define.amd&&define.amd.jQuery&&define("jquery",[],function(){return p})})(window); \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/lib.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/lib.inc.php new file mode 100644 index 00000000..88c32004 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/libraries/lib.inc.php @@ -0,0 +1,271 @@ +stripVar($_GET); + $misc->stripVar($_POST); + $misc->stripVar($_COOKIE); + $misc->stripVar($_REQUEST); + } + + // This has to be deferred until after stripVar above + $misc->setHREF(); + $misc->setForm(); + + // Enforce PHP environment + ini_set('magic_quotes_runtime', 0); + ini_set('magic_quotes_sybase', 0); + ini_set('arg_separator.output', '&'); + + // If login action is set, then set session variables + if (isset($_POST['loginServer']) && isset($_POST['loginUsername']) && + isset($_POST['loginPassword_'.md5($_POST['loginServer'])])) { + + $_server_info = $misc->getServerInfo($_POST['loginServer']); + + $_server_info['username'] = $_POST['loginUsername']; + $_server_info['password'] = $_POST['loginPassword_'.md5($_POST['loginServer'])]; + + $misc->setServerInfo(null, $_server_info, $_POST['loginServer']); + + // Check for shared credentials + if (isset($_POST['loginShared'])) { + $_SESSION['sharedUsername'] = $_POST['loginUsername']; + $_SESSION['sharedPassword'] = $_POST['loginPassword_'.md5($_POST['loginServer'])]; + } + + $_reload_browser = true; + } + + /* select the theme */ + unset($_theme); + if (!isset($conf['theme'])) + $conf['theme'] = 'default'; + + // 1. Check for the theme from a request var + if (isset($_REQUEST['theme']) && is_file("./themes/{$_REQUEST['theme']}/global.css")) { + /* save the selected theme in cookie for a year */ + setcookie('ppaTheme', $_REQUEST['theme'], time()+31536000); + $_theme = $_SESSION['ppaTheme'] = $conf['theme'] = $_REQUEST['theme']; + } + + // 2. Check for theme session var + if (!isset($_theme) && isset($_SESSION['ppaTheme']) && is_file("./themes/{$_SESSION['ppaTheme']}/global.css")) { + $conf['theme'] = $_SESSION['ppaTheme']; + } + + // 3. Check for theme in cookie var + if (!isset($_theme) && isset($_COOKIE['ppaTheme']) && is_file("./themes/{$_COOKIE['ppaTheme']}/global.css")) { + $conf['theme'] = $_COOKIE['ppaTheme']; + } + + // 4. Check for theme by server/db/user + $info = $misc->getServerInfo(); + + if (!is_null($info)) { + $_theme = ''; + + if ( (isset($info['theme']['default'])) + and is_file("./themes/{$info['theme']['default']}/global.css") + ) + $_theme = $info['theme']['default']; + + if ( isset($_REQUEST['database']) + and isset($info['theme']['db'][$_REQUEST['database']]) + and is_file("./themes/{$info['theme']['db'][$_REQUEST['database']]}/global.css") + ) + $_theme = $info['theme']['db'][$_REQUEST['database']]; + + if ( isset($info['username']) + and isset($info['theme']['user'][$info['username']]) + and is_file("./themes/{$info['theme']['user'][$info['username']]}/global.css") + ) + $_theme = $info['theme']['user'][$info['username']]; + + if ($_theme !== '') { + setcookie('ppaTheme', $_theme, time()+31536000); + $conf['theme'] = $_theme; + } + } + + // Determine language file to import: + unset($_language); + + // 1. Check for the language from a request var + if (isset($_REQUEST['language']) && isset($appLangFiles[$_REQUEST['language']])) { + /* save the selected language in cookie for a year */ + setcookie('webdbLanguage', $_REQUEST['language'], time()+31536000); + $_language = $_REQUEST['language']; + } + + // 2. Check for language session var + if (!isset($_language) && isset($_SESSION['webdbLanguage']) && isset($appLangFiles[$_SESSION['webdbLanguage']])) { + $_language = $_SESSION['webdbLanguage']; + } + + // 3. Check for language in cookie var + if (!isset($_language) && isset($_COOKIE['webdbLanguage']) && isset($appLangFiles[$_COOKIE['webdbLanguage']])) { + $_language = $_COOKIE['webdbLanguage']; + } + + // 4. Check for acceptable languages in HTTP_ACCEPT_LANGUAGE var + if (!isset($_language) && $conf['default_lang'] == 'auto' && isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) { + // extract acceptable language tags + // (http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.4) + preg_match_all('/\s*([a-z]{1,8}(?:-[a-z]{1,8})*)(?:;q=([01](?:.[0-9]{0,3})?))?\s*(?:,|$)/', strtolower($_SERVER['HTTP_ACCEPT_LANGUAGE']), $_m, PREG_SET_ORDER); + foreach($_m as $_l) { // $_l[1] = language tag, [2] = quality + if (!isset($_l[2])) $_l[2] = 1; // Default quality to 1 + if ($_l[2] > 0 && $_l[2] <= 1 && isset($availableLanguages[$_l[1]])) { + // Build up array of (quality => language_file) + $_acceptLang[$_l[2]] = $availableLanguages[$_l[1]]; + } + } + unset($_m); + unset($_l); + if (isset($_acceptLang)) { + // Sort acceptable languages by quality + krsort($_acceptLang, SORT_NUMERIC); + $_language = reset($_acceptLang); + unset($_acceptLang); + } + } + + // 5. Otherwise resort to the default set in the config file + if (!isset($_language) && $conf['default_lang'] != 'auto' && isset($appLangFiles[$conf['default_lang']])) { + $_language = $conf['default_lang']; + } + + // 6. Otherwise, default to english. + if (!isset($_language)) + $_language = 'english'; + + + // Import the language file + if (isset($_language)) { + include("./lang/{$_language}.php"); + $_SESSION['webdbLanguage'] = $_language; + } + + // Check for config file version mismatch + if (!isset($conf['version']) || $conf['base_version'] > $conf['version']) { + echo $lang['strbadconfig']; + exit; + } + + // Check database support is properly compiled in + if (!function_exists('pg_connect')) { + echo $lang['strnotloaded']; + exit; + } + + // Manage the plugins + require_once('./classes/PluginManager.php'); + + // Create data accessor object, if necessary + if (!isset($_no_db_connection)) { + if (!isset($_REQUEST['server'])) { + echo $lang['strnoserversupplied']; + exit; + } + $_server_info = $misc->getServerInfo(); + + /* starting with PostgreSQL 9.0, we can set the application name */ + if(isset($_server_info['pgVersion']) && $_server_info['pgVersion'] >= 9) + putenv("PGAPPNAME={$appName}_{$appVersion}"); + + // Redirect to the login form if not logged in + if (!isset($_server_info['username'])) { + include('./login.php'); + exit; + } + + // Connect to the current database, or if one is not specified + // then connect to the default database. + if (isset($_REQUEST['database'])) + $_curr_db = $_REQUEST['database']; + else + $_curr_db = $_server_info['defaultdb']; + + include_once('./classes/database/Connection.php'); + + // Connect to database and set the global $data variable + $data = $misc->getDatabaseAccessor($_curr_db); + + // If schema is defined and database supports schemas, then set the + // schema explicitly. + if (isset($_REQUEST['database']) && isset($_REQUEST['schema'])) { + $status = $data->setSchema($_REQUEST['schema']); + if ($status != 0) { + echo $lang['strbadschema']; + exit; + } + } + } + + if (!function_exists("htmlspecialchars_decode")) { + function htmlspecialchars_decode($string, $quote_style = ENT_COMPAT) { + return strtr($string, array_flip(get_html_translation_table(HTML_SPECIALCHARS, $quote_style))); + } + } + + $plugin_manager = new PluginManager($_language); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/links.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/links.js new file mode 100644 index 00000000..adedec47 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/links.js @@ -0,0 +1,16 @@ +/** + * Function for updating browser frame and topbar frame so that sqledit window + * pops up with properly selected database. + * + * $Id: links.js,v 1.4 2004/07/13 15:24:41 jollytoad Exp $ + */ +function updateLinks(getVars) { + var topbarLink = 'topbar.php' + getVars; + var browserLink = 'browser.php' + getVars; + var detailLink = 'redirect.php' + getVars + 'section=database'; + + parent.frames.topbar.location = topbarLink; + parent.frames.detail.location = detailLink; + parent.frames.browser.location = browserLink; +} + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/login.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/login.php new file mode 100644 index 00000000..6fa92567 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/login.php @@ -0,0 +1,70 @@ +printHeader($lang['strlogin']); + $misc->printBody(); + $misc->printTrail('root'); + + $server_info = $misc->getServerInfo($_REQUEST['server']); + + $misc->printTitle(sprintf($lang['strlogintitle'], $server_info['desc'])); + + if (isset($msg)) $misc->printMsg($msg); + + $md5_server = md5($_REQUEST['server']); +?> + +
+ $val) { + if (substr($key,0,5) == 'login') continue; + echo "\n"; + } +?> + +
+ + + + + + + + + + 1) : ?> +

/>

+ +

+ + + + +printFooter(); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/logout.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/logout.php new file mode 100644 index 00000000..faed8dc8 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/logout.php @@ -0,0 +1,18 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/multiactionform.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/multiactionform.js new file mode 100644 index 00000000..1950608a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/multiactionform.js @@ -0,0 +1,9 @@ +function checkAll(bool) { + + var inputs = document.getElementById('multi_form').getElementsByTagName('input'); + + for (var i=0; iprintTrail('schema'); + $misc->printTabs('schema','opclasses'); + $misc->printMsg($msg); + + $opclasses = $data->getOpClasses(); + + $columns = array( + 'accessmethod' => array( + 'title' => $lang['straccessmethod'], + 'field' => field('amname'), + ), + 'opclass' => array( + 'title' => $lang['strname'], + 'field' => field('opcname'), + ), + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('opcintype'), + ), + 'default' => array( + 'title' => $lang['strdefault'], + 'field' => field('opcdefault'), + 'type' => 'yesno', + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('opccomment'), + ), + ); + + $actions = array(); + + $misc->printTable($opclasses, $columns, $actions, 'opclasses-opclasses', $lang['strnoopclasses']); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $opclasses = $data->getOpClasses(); + + // OpClass prototype: "op_class/access_method" + $proto = concat(field('opcname'),'/',field('amname')); + + $attrs = array( + 'text' => $proto, + 'icon' => 'OperatorClass', + 'toolTip'=> field('opccomment'), + ); + + $misc->printTree($opclasses, $attrs, 'opclasses'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['stropclasses']); + $misc->printBody(); + + switch ($action) { + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/operators.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/operators.php new file mode 100644 index 00000000..354afa6a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/operators.php @@ -0,0 +1,246 @@ +printTrail('operator'); + $misc->printTitle($lang['strproperties'],'pg.operator'); + $misc->printMsg($msg); + + $oprdata = $data->getOperator($_REQUEST['operator_oid']); + $oprdata->fields['oprcanhash'] = $data->phpBool($oprdata->fields['oprcanhash']); + + if ($oprdata->recordCount() > 0) { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + /* these field only exists in 8.2 and before in pg_catalog */ + if (isset($oprdata->fields['oprlsortop'])) { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + } + else { + echo "\n"; + echo "\n"; + } + echo "
{$lang['strname']}", $misc->printVal($oprdata->fields['oprname']), "
{$lang['strleftarg']}", $misc->printVal($oprdata->fields['oprleftname']), "
{$lang['strrightarg']}", $misc->printVal($oprdata->fields['oprrightname']), "
{$lang['strcommutator']}", $misc->printVal($oprdata->fields['oprcom']), "
{$lang['strnegator']}", $misc->printVal($oprdata->fields['oprnegate']), "
{$lang['strjoin']}", $misc->printVal($oprdata->fields['oprjoin']), "
{$lang['strhashes']}", ($oprdata->fields['oprcanhash']) ? $lang['stryes'] : $lang['strno'], "
{$lang['strmerges']}", ($oprdata->fields['oprlsortop'] !== '0' && $oprdata->fields['oprrsortop'] !== '0') ? $lang['stryes'] : $lang['strno'], "
{$lang['strrestrict']}", $misc->printVal($oprdata->fields['oprrest']), "
{$lang['strleftsort']}", $misc->printVal($oprdata->fields['oprlsortop']), "
{$lang['strrightsort']}", $misc->printVal($oprdata->fields['oprrsortop']), "
{$lang['strlessthan']}", $misc->printVal($oprdata->fields['oprltcmpop']), "
{$lang['strgreaterthan']}", $misc->printVal($oprdata->fields['oprgtcmpop']), "
{$lang['strmerges']}", $data->phpBool($oprdata->fields['oprcanmerge']) ? $lang['stryes'] : $lang['strno'], "
\n"; + + $misc->printNavLinks(array ( + 'showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'operators.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strshowalloperators'] + )), 'operators-properties', get_defined_vars() + ); + } + else + doDefault($lang['strinvalidparam']); + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('operator'); + $misc->printTitle($lang['strdrop'], 'pg.operator.drop'); + + echo "

", sprintf($lang['strconfdropoperator'], $misc->printVal($_REQUEST['operator'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropOperator($_POST['operator_oid'], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['stroperatordropped']); + else + doDefault($lang['stroperatordroppedbad']); + } + + } + + /** + * Show default list of operators in the database + */ + function doDefault($msg = '') { + global $data, $conf, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','operators'); + $misc->printMsg($msg); + + $operators = $data->getOperators(); + + $columns = array( + 'operator' => array( + 'title' => $lang['stroperator'], + 'field' => field('oprname'), + 'url' => "operators.php?action=properties&{$misc->href}&", + 'vars' => array('operator' => 'oprname', 'operator_oid' => 'oid'), + ), + 'leftarg' => array( + 'title' => $lang['strleftarg'], + 'field' => field('oprleftname'), + ), + 'rightarg' => array( + 'title' => $lang['strrightarg'], + 'field' => field('oprrightname'), + ), + 'returns' => array( + 'title' => $lang['strreturns'], + 'field' => field('resultname'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('oprcomment'), + ), + ); + + $actions = array( + 'drop' => array( + // 'title' => $lang['strdrop'], + // 'url' => "operators.php?action=confirm_drop&{$misc->href}&", + // 'vars' => array('operator' => 'oprname', 'operator_oid' => 'oid'), + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'operators.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'operator' => field('oprname'), + 'operator_oid' => field('oid') + ) + ) + ) + ) + ); + + $misc->printTable($operators, $columns, $actions, 'operators-operators', $lang['strnooperators']); + +// TODO operators.php action=create $lang['strcreateoperator'] + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $operators = $data->getOperators(); + + // Operator prototype: "type operator type" + $proto = concat(field('oprleftname'), ' ', field('oprname'), ' ', field('oprrightname')); + + $reqvars = $misc->getRequestVars('operator'); + + $attrs = array( + 'text' => $proto, + 'icon' => 'Operator', + 'toolTip'=> field('oprcomment'), + 'action' => url('operators.php', + $reqvars, + array( + 'action' => 'properties', + 'operator' => $proto, + 'operator_oid' => field('oid') + ) + ) + ); + + $misc->printTree($operators, $attrs, 'operators'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['stroperators']); + $misc->printBody(); + + switch ($action) { + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['cancel'])) doDefault(); + else doDrop(false); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'properties': + doProperties(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugin.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugin.php new file mode 100644 index 00000000..0b3e5921 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugin.php @@ -0,0 +1,5 @@ +do_action($_REQUEST['plugin'], $_REQUEST['action']); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/conf/config.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/conf/config.inc.php new file mode 100644 index 00000000..0e6b7ac2 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/conf/config.inc.php @@ -0,0 +1,484 @@ + array ( + // 'sql' => true, + // 'history' => true, + // 'find' => true, + // 'logout' => true, + ), + + /** + * Tabs Links + **/ + 'tab_links' => array ( + 'root' => array ( + // 'intro' => true, + // 'servers' => true, + ), + 'server' => array ( + // 'databases' => true, + // 'roles' => true, /* postgresql 8.1+ */ + // 'users' => true, /* postgresql <8.1 */ + // 'groups' => true, + // 'account' => true, + // 'tablespaces' => true, + // 'export' => true, + // 'reports' => true, + ), + 'database' => array ( + // 'schemas' => true, + // 'sql' => true, + // 'find' => true, + // 'variables' => true, + // 'processes' => true, + // 'locks' => true, + // 'admin' => true, + // 'privileges' => true, + // 'languages' => true, + // 'casts' => true, + // 'export' => true, + ), + 'schema' => array( + // 'tables' => true, + // 'views' => true, + // 'sequences' => true, + // 'functions' => true, + // 'fulltext' => true, + // 'domains' => true, + // 'aggregates' => true, + // 'types' => true, + // 'operators' => true, + // 'opclasses' => true, + // 'conversions' => true, + // 'privileges' => true, + // 'export' => true, + ), + 'table' => array( + // 'columns' => true, + // 'indexes' => true, + // 'constraints' => true, + // 'triggers' => true, + // 'rules' => true, + // 'admin' => true, + // 'info' => true, + // 'privileges' => true, + // 'import' => true, + // 'export' => true, + ), + 'view' => array ( + // 'columns' => true, + // 'definition' => true, + // 'rules' => true, + // 'privileges' => true, + // 'export' => true, + ), + 'function' => array( + // 'definition' => true, + // 'privileges' => true, + ), + 'aggregate' => array( + // 'definition' => true, + ), + 'role' => array( + // 'definition' => true, + ), + 'popup' => array( + // 'sql' => true, + // 'find' => true, + ), + 'column' => array( + // 'properties' => true, + // 'privileges' => true, + ), + 'fulltext' => array( + // 'ftsconfigs' => true, + // 'ftsdicts' => true, + // 'ftsparsers' => true, + ), + ), + + /** + * Trail Links + **/ + // 'trail_links' => true, /* enable/disable the whole trail */ + + /** + * Navigation Links + **/ + 'navlinks' => array( + 'aggregates-properties' => array( + // 'showall' => true, + // 'alter' => true, + // 'drop' => true, + ), + 'aggregates-aggregates' => array( + // 'create' => true, + ), + 'all_db-databases' => array( + // 'create' => true, + ), + 'colproperties-colproperties' => array( + // 'browse' => true, + // 'alter' => true, + // 'drop' => true, + ), + 'constraints-constraints' => array( + // 'addcheck' => true, + // 'adduniq' => true, + // 'addpk' => true, + // 'addfk' => true, + ), + 'display-browse' => array( + // 'back' => true, + // 'edit' => true, + // 'collapse' => true, + // 'createreport' => true, + // 'createview' => true, + // 'download' => true, + // 'insert' => true, + // 'refresh' => true, + ), + 'domains-properties' => array( + // 'drop' => true, + // 'addcheck' => true, + // 'alter' => true, + ), + 'domains-domains' => array( + // 'create' => true, + ), + 'fulltext-fulltext' => array( + // 'createconf' => true, + ), + 'fulltext-viewdicts' => array( + // 'createdict' => true, + ), + 'fulltext-viewconfig' => array( + // 'addmapping' => true, + ), + 'functions-properties' => array( + // 'showall' => true, + // 'alter' => true, + // 'drop' => true, + ), + 'functions-functions' => array( + // 'createpl' => true, + // 'createinternal' => true, + // 'createc' => true, + ), + 'groups-groups' => array( + // 'create' => true, + ), + 'groups-properties' => array( + // 'showall' => true, + ), + 'history-history' => array( + // 'refresh' => true, + // 'download' => true, + // 'clear' => true, + ), + 'indexes-indexes' => array( + // 'create' => true, + ), + 'operators-properties' => array( + // 'showall' => true, + ), + 'privileges-privileges' => array( + // 'grant' => true, + // 'revoke' => true, + // 'showalltables' => true, + // 'showallcolumns' => true, + // 'showallviews' => true, + // 'showalldatabases' => true, + // 'showallschemas' => true, + // 'showallfunctions' => true, + // 'showallsequences' => true, + // 'showalltablespaces' => true, + ), + 'reports-properties' => array( + // 'showall' => true, + // 'alter' => true, + // 'exec' => true, + ), + 'reports-reports' => array( + // 'create' => true, + ), + 'roles-account' => array( + // 'changepassword' => true, + ), + 'roles-properties' => array( + // 'showall' => true, + // 'alter' => true, + // 'drop' => true, + ), + 'roles-roles' => array( + // 'create' => true, + ), + 'rules-rules' => array( + // 'create' => true, + ), + 'schemas-schemas' => array( + // 'create' => true, + ), + 'sequences-properties' => array( + // 'alter' => true, + // 'nextval' => true, + // 'restart' => true, + // 'reset' => true, + ), + 'sequences-sequences' => array( + // 'create' => true, + ), + 'servers-servers' => array( + // 'showall' => true, + /*we cannot filter the group names in navlinks presently*/ + ), + 'sql-form' => array( + // 'back' => true, + // 'alter' => true, + // 'createreport' => true, + // 'createview' => true, + // 'download' => true, + ), + 'tables-tables' => array( + // 'create' => true, + // 'createlike' => true, + ), + 'tablespaces-tablespaces' => array( + // 'create' => true, + ), + 'tblproperties-tblproperties' => array( + // 'browse' => true, + // 'select' => true, + // 'insert' => true, + 'empty' => true, + // 'drop' => true, + // 'addcolumn' => true, + // 'alter' => true, + ), + 'triggers-triggers' => array( + // 'create' => true, + ), + 'types-properties' => array( + // 'showall' => true, + ), + 'types-types' => array( + // 'create' => true, + // 'createcomp' => true, + // 'createenum' => true, + ), + 'users-account' => array( + // 'changepassword' => true, + ), + 'users-users' => array( + // 'create' => true, + ), + 'viewproperties-definition' => array( + // 'alter' => true, + ), + 'viewproperties-viewproperties' => array( + // 'browse' => true, + // 'select' => true, + // 'drop' => true, + // 'alter' => true, + ), + 'views-views' => array( + // 'create' => true, + // 'createwiz' => true, + ), + ), + + /** + * action links + **/ + + 'actionbuttons' => array( + 'admin-admin' => array( + // 'edit' => true, + // 'delete' => true, + ), + 'aggregates-aggregates' => array( + // 'alter' => true, + // 'drop' => true, + ), + 'all_db-databases' => array( + // 'drop' => true, + // 'privileges' => true, + // 'alter' => true, + ), + 'casts-casts' => array( + // none + ), + 'colproperties-colproperties' => array( + // none + ), + 'constraints-constraints' => array( + // 'drop' => true, + ), + 'conversions-conversions' => array( + // none + ), + 'database-variables' => array( + // none + ), + 'database-processes-preparedxacts' => array( + // none + ), + 'database-processes' => array( + // 'cancel' => true, + // 'kill' => true, + ), + 'database-locks' => array( + // none + ), + 'display-browse' => array( + // TODO + // 'edit' => true, + // 'delete' => true, + ), + 'domains-properties' => array( + // 'drop' => true, + ), + 'domains-domains' => array( + // 'alter' => true, + // 'drop' => true, + ), + 'fulltext-fulltext' => array( + // 'drop' => true, + // 'alter' => true, + ), + 'fulltext-viewparsers' => array( + // none + ), + 'fulltext-viewdicts' => array( + // 'drop' => true, + // 'alter' => true, + ), + 'fulltext-viewconfig' => array( + // 'multiactions' => true, + // 'drop' => true, + // 'alter' => true, + ), + 'functions-functions' => array( + // 'multiactions' => true, + // 'alter' => true, + // 'drop' => true, + // 'privileges' => true, + ), + 'groups-members' => array( + // 'drop' => true, + ), + 'groups-properties' => array( + // 'drop' => true, + ), + 'history-history' => array( + // 'run' => true, + // 'remove' => true, + ), + 'indexes-indexes' => array( + // 'cluster' => true, + // 'reindex' => true, + // 'drop' => true, + ), + 'info-referrers' => array( + // 'properties' => true, + ), + 'info-parents' => array( + // 'properties' => true, + ), + 'info-children' => array( + // 'properties' => true, + ), + 'languages-languages' => array( + // none + ), + 'opclasses-opclasses' => array( + // none + ), + 'operators-operators' => array( + // 'drop' => true, + ), + 'reports-reports' => array( + // 'run' => true, + // 'edit' => true, + // 'drop' => true, + ), + 'roles-roles' => array( + // 'alter' => true, + // 'drop' => true, + ), + 'rules-rules' => array( + // 'drop' => true, + ), + 'schemas-schemas' => array( + // 'multiactions' => true, + // 'drop' => true, + // 'privileges' => true, + // 'alter' => true, + ), + 'sequences-sequences' => array( + // 'multiactions' => true, + // 'drop' => true, + // 'privileges' => true, + // 'alter' => true, + ), + 'servers-servers' => array( + // 'logout' => true, + ), + 'tables-tables' => array( + // 'multiactions' => true, + // 'browse' => true, + // 'select' => true, + // 'insert' => true, + // 'empty' => true, + // 'alter' => true, + // 'drop' => true, + // 'vacuum' => true, + // 'analyze' => true, + // 'reindex' => true, + ), + 'tablespaces-tablespaces' => array( + // 'drop' => true, + // 'privileges' => true, + // 'alter' => true, + ), + 'tblproperties-tblproperties' => array( + // 'browse' => true, + // 'alter' => true, + // 'privileges' => true, + // 'drop' => true, + ), + 'triggers-triggers' => array( + // 'alter' => true, + // 'drop' => true, + // 'enable' => true, + // 'disable' => true, + ), + 'types-properties' => array( + // none + ), + 'types-types' => array( + // 'drop' => true, + ), + 'users-users' => array( + // 'alter' => true, + // 'drop' => true, + ), + 'viewproperties-viewproperties' => array( + // 'alter' => true, + ), + 'views-views' => array( + //'multiactions' => true, + // 'browse' => true, + // 'select' => true, + //'alter' => true, + //'drop' => true, + ), + ), +); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/plugin.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/plugin.php new file mode 100644 index 00000000..44669362 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/GuiControl/plugin.php @@ -0,0 +1,145 @@ + array('function1', 'function2'). + * + * Example: + * $hooks = array( + * 'toplinks' => array('add_plugin_toplinks'), + * 'tabs' => array('add_tab_entry'), + * 'action_buttons' => array('add_more_an_entry') + * ); + * + * @return $hooks + */ + function get_hooks() { + $hooks = array( + 'toplinks' => array('filer_toplinks'), + 'tabs' => array('filter_tabs'), + 'trail' => array('filter_trail'), + 'navlinks' => array('filter_navlinks'), + 'actionbuttons' => array('filter_actionbuttons'), + 'tree' => array('filter_tree') + ); + return $hooks; + } + + /** + * This method returns the functions that will be used as actions. + * To do include a function that will be used as action, just put in the $actions array the follwing code: + * + * $actions = array( + * 'show_page', + * 'show_error', + * ); + * + * @return $actions + */ + function get_actions() { + $actions = array( + 'filer_toplinks', + 'filter_tabs', + 'filter_trail', + 'filter_navlinks', + 'filter_actionbuttons', + 'filter_tree', + ); + return $actions; + } + + function filer_toplinks(&$f_params) { + if (!isset($this->conf['top_links'])) + return; + + $top_links = &$f_params['toplinks']; + + foreach ($this->conf['top_links'] as $link => $enabled) + if (isset ($top_links[$link]) + && ($enabled === false) + ) + unset($top_links[$link]); + + return; + } + + function filter_tabs(&$f_params) { + $section = $f_params['section']; + $tabs = &$f_params['tabs']; + + if (!isset($this->conf['tab_links'][$section])) + return; + + foreach ($this->conf['tab_links'][$section] as $link => $enabled) + if (isset ($tabs[$link]) + && ($enabled === false) + ) + unset($tabs[$link]); + return; + } + + function filter_trail(&$f_params) { + if (!isset($this->conf['trail_links'])) + return; + + if ($this->conf['trail_links'] === false) + $f_params['trail'] = array(); + + return; + } + + function filter_navlinks(&$f_params) { + $place = $f_params['place']; + $navlinks = &$f_params['navlinks']; + + if (! isset($this->conf['navlinks'][$place])) + return; + + foreach ($this->conf['navlinks'][$place] as $link => $enabled) + if (isset ($navlinks[$link]) + && ($enabled === false) + ) + unset($navlinks[$link]); + return; + } + + function filter_actionbuttons(&$f_params) { + $place = $f_params['place']; + $actions = &$f_params['actionbuttons']; + + if (! isset($this->conf['actionbuttons'][$place])) + return; + + foreach ($this->conf['actionbuttons'][$place] as $link => $enabled) + if (isset ($actions[$link]) + && ($enabled === false) + ) + unset($actions[$link]); + return; + } + + function filter_tree() { + return; + } +} +?> \ No newline at end of file diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/INSTALL b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/INSTALL new file mode 100644 index 00000000..263f308b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/INSTALL @@ -0,0 +1,13 @@ +phpPgAdmin Report Plugin Installation Guide +------------------------------------------- +1. Report Plugin activation + + Open conf/config.inc.php and add the 'Report' value in the $conf['plugins'] array: + + $conf['plugins'] = array('Report'); + +2. Set up the reports database. + + If you want to enable reports (which are a useful feature) then go to + the 'sql' subdirectory and view the SQL script for your database. It + will contain instructions on how to set up the reports database. diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/README b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/README new file mode 100644 index 00000000..071c199a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/README @@ -0,0 +1,24 @@ +About the phpPgAdmin Report Plugin +---------------------------------- + +The Report plugin is the old report feature of phpPgAdmins removed in +version 5.1 and refactored as a plugin. + +It enables you to create and save ad-hoc SQL queries as reports which +can be easily be executed from within phpPgAdmin. + +To save reports, this plugin requires the creation of a dedicated +database containing a single table; see the INSTALL file and the +sql/reports.sql file for details. + +Following installation, an icon for the Report plugin will appear +on the main overview page for each connected server. This provides +an overview of all reports saved for the entire server, and enables +executionm, editing and deletion of reports, as well as creation of +new reports from scratch. + +New reports can also be created while browsing table and view data, +a "create report" link is provided at the bottom of each data page +which pre-populates the report with the SQL used to generate the +data. + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/classes/Reports.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/classes/Reports.php new file mode 100644 index 00000000..19327b48 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/classes/Reports.php @@ -0,0 +1,128 @@ +conf = $conf; + + // Check to see if the reports database exists + $rs = $data->getDatabase($this->conf['reports_db']); + if ($rs->recordCount() != 1) $status = -1; + else { + // Create a new database access object. + $this->driver = $misc->getDatabaseAccessor($this->conf['reports_db']); + // Reports database should have been created in public schema + $this->driver->setSchema($this->conf['reports_schema']); + $status = 0; + } + } + + /** + * Finds all reports + * @return A recordset + */ + function getReports() { + global $misc; + // Filter for owned reports if necessary + if ($this->conf['owned_reports_only']) { + $server_info = $misc->getServerInfo(); + $filter['created_by'] = $server_info['username']; + $ops = array('created_by' => '='); + } + else $filter = $ops = array(); + + $sql = $this->driver->getSelectSQL($this->conf['reports_table'], + array('report_id', 'report_name', 'db_name', 'date_created', 'created_by', 'descr', 'report_sql', 'paginate'), + $filter, $ops, array('db_name' => 'asc', 'report_name' => 'asc')); + + return $this->driver->selectSet($sql); + } + + /** + * Finds a particular report + * @param $report_id The ID of the report to find + * @return A recordset + */ + function getReport($report_id) { + $sql = $this->driver->getSelectSQL($this->conf['reports_table'], + array('report_id', 'report_name', 'db_name', 'date_created', 'created_by', 'descr', 'report_sql', 'paginate'), + array('report_id' => $report_id), array('report_id' => '='), array()); + + return $this->driver->selectSet($sql); + } + + /** + * Creates a report + * @param $report_name The name of the report + * @param $db_name The name of the database + * @param $descr The comment on the report + * @param $report_sql The SQL for the report + * @param $paginate The report should be paginated + * @return 0 success + */ + function createReport($report_name, $db_name, $descr, $report_sql, $paginate) { + global $misc; + $server_info = $misc->getServerInfo(); + $temp = array( + 'report_name' => $report_name, + 'db_name' => $db_name, + 'created_by' => $server_info['username'], + 'report_sql' => $report_sql, + 'paginate' => $paginate ? 'true' : 'false', + ); + if ($descr != '') $temp['descr'] = $descr; + + return $this->driver->insert($this->conf['reports_table'], $temp); + } + + /** + * Alters a report + * @param $report_id The ID of the report + * @param $report_name The name of the report + * @param $db_name The name of the database + * @param $descr The comment on the report + * @param $report_sql The SQL for the report + * @param $paginate The report should be paginated + * @return 0 success + */ + function alterReport($report_id, $report_name, $db_name, $descr, $report_sql, $paginate) { + global $misc; + $server_info = $misc->getServerInfo(); + $temp = array( + 'report_name' => $report_name, + 'db_name' => $db_name, + 'created_by' => $server_info['username'], + 'report_sql' => $report_sql, + 'paginate' => $paginate ? 'true' : 'false', + 'descr' => $descr + ); + + return $this->driver->update($this->conf['reports_table'], $temp, + array('report_id' => $report_id)); + } + + /** + * Drops a report + * @param $report_id The ID of the report to drop + * @return 0 success + */ + function dropReport($report_id) { + return $this->driver->delete($this->conf['reports_table'], array('report_id' => $report_id)); + } + + } +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/conf/config.inc.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/conf/config.inc.php new file mode 100644 index 00000000..c036544e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/conf/config.inc.php @@ -0,0 +1,12 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/images/Report.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/images/Report.png new file mode 100644 index 0000000000000000000000000000000000000000..f9158b9a02d899fa802621243df3d0b64cf3b8d0 GIT binary patch literal 405 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G_YAk0{w5<>&kwEkwaWrmT&d!4-5>9N}eu`Ar`%NCvEg%4is?p|F-s~ z#NuiH8pX6CesI^dYz<{vX5iYjVnIUYWF^N=wk-mGdKEHTM9TiPi=CYPTPIBTaMYS< zd^~4z&&jlDwg_az-#3!t`;q(gckQC{mVXvnGZ-Gouvk!g^>J;E2FoHR#?}ejT0D1X z98&RVe5$f6a(!rH)SsoF&Az=comaHde%@Q3=b8>&Hgn!5rCB^TFy7N*o}6^7so3Yt zhq#Jhu>_&t%g^uRdDp*v6N7%?=_9kXl?W}qeiyajwQ!ixar7%8C zGW^ba%JY+ceuCPq-mm%5!OZz?sT)nE@2&g6tiQPK=d9BUE=QbV3iIYHU+cT4MP*4t xYeSRAqYAzCYeS40-krRdXnOruWGSN^L&mFroJukae*goJ!PC{xWt~$(698}>rz-#e literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/images/Reports.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/images/Reports.png new file mode 100644 index 0000000000000000000000000000000000000000..4a403e070c32a1be865b83d74dac2e83cf9fab11 GIT binary patch literal 339 zcmV-Z0j&OsP)`^WGXjQ=z6va>Lh z=VgH`z-a)(*I$1aRxMk~aQ^sVoK66`^gp^w;0F8y+62-}s!QMofE1DA61V|>paziY z5)2n0yTrBlC{`D&YBazM#J_+4VYp;@lL=7#FIemkkp2x~{{gZ8VH)t~-(L)uMAn_b z>Vm~JI+zCVbFgE$WNx)C*fzNBAo>r4MmJ!3ZBcF}x=WHhF3Ib?h1CVqin*~HfbNn-)!Ja&{( diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/arabic.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/arabic.php new file mode 100644 index 00000000..32a34c31 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/arabic.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/catalan.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/catalan.php new file mode 100644 index 00000000..0f5c82c3 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/catalan.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-sim.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-sim.php new file mode 100644 index 00000000..aedf4d13 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-sim.php @@ -0,0 +1,22 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-tr.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-tr.php new file mode 100644 index 00000000..d5bfbc14 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-tr.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_CN.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_CN.php new file mode 100644 index 00000000..834a93b8 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_CN.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_TW.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_TW.php new file mode 100644 index 00000000..907b2342 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/chinese-utf8-zh_TW.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/czech.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/czech.php new file mode 100644 index 00000000..ff6f539c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/czech.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/danish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/danish.php new file mode 100644 index 00000000..7d5df866 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/danish.php @@ -0,0 +1,25 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/dutch.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/dutch.php new file mode 100644 index 00000000..aa541fbc --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/dutch.php @@ -0,0 +1,21 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/english.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/english.php new file mode 100644 index 00000000..ce6e6f77 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/english.php @@ -0,0 +1,24 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/french.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/french.php new file mode 100644 index 00000000..ac1f5fdb --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/french.php @@ -0,0 +1,24 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/galician.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/galician.php new file mode 100644 index 00000000..87da669b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/galician.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/german.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/german.php new file mode 100644 index 00000000..5f5cec5a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/german.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/greek.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/greek.php new file mode 100644 index 00000000..78bde375 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/greek.php @@ -0,0 +1,24 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hebrew.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hebrew.php new file mode 100644 index 00000000..d369f066 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hebrew.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hungarian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hungarian.php new file mode 100644 index 00000000..bb94af95 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/hungarian.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/italian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/italian.php new file mode 100644 index 00000000..17716eaa --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/italian.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/japanese.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/japanese.php new file mode 100644 index 00000000..ec0dad25 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/japanese.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/lithuanian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/lithuanian.php new file mode 100644 index 00000000..2f4ddd5e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/lithuanian.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/mongol.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/mongol.php new file mode 100644 index 00000000..0b171dcd --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/mongol.php @@ -0,0 +1,22 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/polish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/polish.php new file mode 100644 index 00000000..ed5e0475 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/polish.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-br.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-br.php new file mode 100644 index 00000000..d686d23e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-br.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-pt.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-pt.php new file mode 100644 index 00000000..769a2c0a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/portuguese-pt.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/romanian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/romanian.php new file mode 100644 index 00000000..c4ad1599 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/romanian.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/russian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/russian.php new file mode 100644 index 00000000..2082be2a --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/russian.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/slovak.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/slovak.php new file mode 100644 index 00000000..fa55a36b --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/slovak.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/spanish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/spanish.php new file mode 100644 index 00000000..7499d2f0 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/spanish.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/swedish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/swedish.php new file mode 100644 index 00000000..8936ea6c --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/swedish.php @@ -0,0 +1,25 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/turkish.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/turkish.php new file mode 100644 index 00000000..278bd9fa --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/turkish.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/ukrainian.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/ukrainian.php new file mode 100644 index 00000000..16060472 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/lang/ukrainian.php @@ -0,0 +1,23 @@ + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/plugin.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/plugin.php new file mode 100644 index 00000000..b37d8161 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/plugin.php @@ -0,0 +1,807 @@ +lang and $this->conf */ + parent::__construct($language); + + /* default values */ + if (! isset($this->conf['reports_db'])) { + $this->conf['reports_db'] = 'phppgadmin'; + } + if (! isset($this->conf['reports_schema'])) { + $this->conf['reports_schema'] = 'public'; + } + if (! isset($this->conf['reports_table'])) { + $this->conf['reports_table'] = 'ppa_reports'; + } + if (! isset($this->conf['owned_reports_only'])) { + $this->conf['owned_reports_only'] = false; + } + } + + function get_reportsdb() { + if ($this->_reportsdb === null) { + $status = 0; + $this->_reportsdb = new Reports($this->conf, $status); + + if ($status !== 0) { + global $misc; + $misc->printHeader($this->lang['strreports']); + $misc->printBody(); + $misc->printTrail('server'); + $misc->printTabs('server','reports'); + $misc->printMsg($this->lang['strnoreportsdb']); + $misc->printFooter(); + exit; + } + } + + return $this->_reportsdb; + } + + /** + * This method returns the functions that will hook in the phpPgAdmin core. + * To do include a function just put in the $hooks array the follwing code: + * 'hook' => array('function1', 'function2'). + * + * Example: + * $hooks = array( + * 'toplinks' => array('add_plugin_toplinks'), + * 'tabs' => array('add_tab_entry'), + * 'action_buttons' => array('add_more_an_entry') + * ); + * + * @return $hooks + */ + function get_hooks() { + $hooks = array( + 'tabs' => array('add_plugin_tabs'), + 'trail' => array('add_plugin_trail'), + 'navlinks' => array('plugin_navlinks') + ); + return $hooks; + } + + /** + * This method returns the functions that will be used as actions. + * To do include a function that will be used as action, just put in the $actions array the follwing code: + * + * $actions = array( + * 'show_page', + * 'show_error', + * ); + * + * @return $actions + */ + function get_actions() { + $actions = array( + 'save_edit', + 'edit', + 'properties', + 'save_create', + 'create', + 'drop', + 'confirm_drop', + 'execute', + 'default_action' + ); + return $actions; + } + + /** + * Add plugin in the tabs + * @param $plugin_functions_parameters + */ + function add_plugin_tabs(&$plugin_functions_parameters) { + global $misc; + + $tabs = &$plugin_functions_parameters['tabs']; + + if ($plugin_functions_parameters['section'] == 'server') { + $tabs['report_plugin'] = array ( + 'title' => $this->lang['strplugindescription'], + 'url' => 'plugin.php', + 'urlvars' => array( + 'subject' => 'server', + 'action' => 'default_action', + 'plugin' => $this->name + ), + 'hide' => false, + 'icon' => $this->icon('Report') + ); + } + + if ($plugin_functions_parameters['section'] == 'report') { + $tabs['report_plugin'] = array ( + 'title' => $this->lang['strplugindescription'], + 'url' => 'plugin.php', + 'urlvars' => array( + 'subject' => 'server', + 'action' => 'default_action', + 'plugin' => $this->name + ), + 'hide' => false, + 'icon' => $this->icon('Report') + ); + } + } + + /** + * Add plugin in the trail + * @param $plugin_functions_parameters + */ + function add_plugin_trail(&$plugin_functions_parameters) { + global $misc; + $trail = &$plugin_functions_parameters['trail']; + $done = false; + $subject = ''; + if (isset($_REQUEST['subject'])) { + $subject = $_REQUEST['subject']; + } + + $action = ''; + if (isset($_REQUEST['action'])) { + $action = $_REQUEST['action']; + } + + if (isset($_REQUEST['plugin']) and $_REQUEST['plugin'] == 'Report') { + $url = array ( + 'url' => 'plugin.php', + 'urlvars' => array ( + 'plugin' => $this->name, + 'action' => 'default_action' + ) + ); + $trail['report_plugin'] = array ( + 'title' => $this->lang['strreport'], + 'text' => $this->lang['strreport'], + 'url' => $misc->getActionUrl($url, $_REQUEST, null, false), + 'icon' => $this->icon('Reports') + ); + } + + if (isset($_REQUEST['plugin']) + and $_REQUEST['plugin'] == 'Report' + and $action != 'default_action' + and in_array($action, $this->get_actions()) + ) { + + $url = array ( + 'url' => 'plugin.php', + 'urlvars' => array ( + 'plugin' => $this->name, + 'action' => 'properties', + 'report_id' => field('report_id'), + ) + ); + + if (isset($_REQUEST['report'])) + $url['urlvars']['report'] = field('report'); + + $trail['report_plugin_name'] = array ( + 'title' => $this->lang['strreport'], + 'text' => $this->lang['strreport'], + 'url' => $misc->getActionUrl($url, $_REQUEST, null, false), + 'icon' => $this->icon('Report') + ); + + if (isset($_REQUEST['report'])) + $trail['report_plugin_name']['text'] = $_REQUEST['report']; + + } + } + + /** + * Add plugin in the navlinks + * @param $plugin_functions_parameters + */ + function plugin_navlinks(&$params) { + global $misc, $lang; + + if ( + ($params['place'] == 'sql-form' + or $params['place'] == 'display-browse') + and ( isset($params['env']['rs']) + and is_object($params['env']['rs']) + and $params['env']['rs']->recordCount() > 0)) + { + if ( ! (isset($_REQUEST['plugin']) + and $_REQUEST['plugin'] == $this->name) + ) { + /* ResultSet doesn't come from a plugin: + * show a create report link. */ + $params['navlinks']['report_link'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array ( + 'plugin' => $this->name, + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + ) + ) + ), + 'content' => $this->lang['strcreatereport'] + ); + + if (isset($_REQUEST['paginate'])) + $params['navlinks']['report_link']['attr']['href']['urlvars']['paginate'] + = $_REQUEST['paginate']; + + if (!empty($_SESSION['sqlquery'])) { + $params['navlinks']['report_link']['attr']['href']['urlvars']['fromsql'] + = 1; + } + else { + if (isset($_REQUEST['subject']) + and isset($_REQUEST[$_REQUEST['subject']])) + { + $params['navlinks']['report_link']['attr']['href']['urlvars']['subject'] + = $_REQUEST['subject']; + $params['navlinks']['report_link']['attr']['href']['urlvars'][$_REQUEST['subject']] + = $_REQUEST[$_REQUEST['subject']]; + + $params['navlinks']['report_link']['attr']['href']['urlvars']['sortkey'] + = isset($_REQUEST['sortkey']) ? $_REQUEST['sortkey'] : ''; + + $params['navlinks']['report_link']['attr']['href']['urlvars']['sortdir'] + = isset($_REQUEST['sortdir']) ? $_REQUEST['sortdir'] : ''; + } + else { + unset($params['navlinks']['report_link']); + } + } + } + else { + /* ResultSet comes from a plugin: + * show a edit report link. */ + $params['navlinks']['report_link'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array ( + 'plugin' => $this->name, + 'action' => 'edit', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'report_id' => $_REQUEST['report_id'] + ) + ) + ), + 'content' => $this->lang['streditreport'] + ); + + /* edit collapse link to add report related vars */ + $params['navlinks']['collapse']['attr']['href']['urlvars'] + ['plugin'] = $this->name; + $params['navlinks']['collapse']['attr']['href']['urlvars'] + ['report_id'] = $_REQUEST['report_id']; + $params['navlinks']['collapse']['attr']['href']['urlvars'] + ['report'] = $_REQUEST['report']; + + /* edit refresh link to add report related vars */ + $params['navlinks']['refresh']['attr']['href']['urlvars'] + ['plugin'] = $this->name; + $params['navlinks']['refresh']['attr']['href']['urlvars'] + ['report_id'] = $_REQUEST['report_id']; + $params['navlinks']['refresh']['attr']['href']['urlvars'] + ['report'] = $_REQUEST['report']; + + if (isset($_REQUEST['action'])) { + $params['navlinks']['collapse']['attr']['href']['urlvars'] + ['action'] = $_REQUEST['action']; + + $params['navlinks']['refresh']['attr']['href']['urlvars'] + ['action'] = $_REQUEST['action']; + } + } + + if (isset($_REQUEST['schema'])) + $params['navlinks']['report_link']['attr']['href']['urlvars']['schema'] + = $_REQUEST['schema']; + } + } + + function get_subject_params() { + $vars = array(); + + if (! isset($_REQUEST['action'])) + return $vars; + + $action = $_REQUEST['action']; + + switch ($action) { + case 'execute': + $vars = array( + 'report_id' => $_REQUEST['report_id'], + 'report' => $_REQUEST['report'], + 'action' => 'properties' /*defaults to properties*/ + ); + if (isset($_REQUEST['back'])) + $vars['action'] = $_REQUEST['back']; + break; + } + + return $vars; + } + + function edit($msg = '') { + global $data, $misc, $lang; + + $reportsdb = $this->get_reportsdb(); + + $misc->printHeader($this->lang['strreports']); + $misc->printBody(); + $misc->printTrail('server'); + $misc->printTabs('server', 'report_plugin'); + $misc->printMsg($msg); + + // If it's a first, load then get the data from the database + $report = $reportsdb->getReport($_REQUEST['report_id']); + + if ($_REQUEST['action'] == 'edit') { + $_POST['report_name'] = $report->fields['report_name']; + $_POST['db_name'] = $report->fields['db_name']; + $_POST['descr'] = $report->fields['descr']; + $_POST['report_sql'] = $report->fields['report_sql']; + if ($report->fields['paginate'] == 't') { + $_POST['paginate'] = true; + } + } + + // Get a list of available databases + $databases = $data->getDatabases(); + + $_REQUEST['report'] = $report->fields['report_name']; + + echo "
name}\" method=\"post\">\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['report_name']), "\" />
{$lang['strdatabase']}
{$lang['strcomment']}
{$lang['strsql']}
\n"; + echo "\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + echo "fields['report_id']}\" />\n"; + echo "
\n"; + $misc->printFooter(); + } + + /** + * Saves changes to a report + */ + function save_edit() { + $reportsdb = $this->get_reportsdb(); + + if (isset($_REQUEST['cancel'])) { + $this->default_action(); + exit; + } + + if (!isset($_POST['report_name'])) $_POST['report_name'] = ''; + if (!isset($_POST['db_name'])) $_POST['db_name'] = ''; + if (!isset($_POST['descr'])) $_POST['descr'] = ''; + if (!isset($_POST['report_sql'])) $_POST['report_sql'] = ''; + + // Check that they've given a name and a definition + if ($_POST['report_name'] == '') { + $this->edit($this->lang['strreportneedsname']); + } elseif ($_POST['report_sql'] == '') { + $this->edit($this->lang['strreportneedsdef']); + } else { + $status = $reportsdb->alterReport($_POST['report_id'], $_POST['report_name'], $_POST['db_name'], + $_POST['descr'], $_POST['report_sql'], isset($_POST['paginate'])); + if ($status == 0) + $this->default_action($this->lang['strreportcreated']); + else + $this->edit($this->lang['strreportcreatedbad']); + } + } + + /** + * Display read-only properties of a report + */ + function properties($msg = '') { + global $data, $reportsdb, $misc; + global $lang; + + $reportsdb = $this->get_reportsdb(); + + $misc->printHeader($this->lang['strreports']); + $misc->printBody(); + $misc->printTrail('server'); + $misc->printTabs('server', 'report_plugin'); + $misc->printMsg($msg); + + $report = $reportsdb->getReport($_REQUEST['report_id']); + + $_REQUEST['report'] = $report->fields['report_name']; + + if ($report->recordCount() == 1) { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}", $misc->printVal($report->fields['report_name']), "
{$lang['strdatabase']}", $misc->printVal($report->fields['db_name']), "
{$lang['strcomment']}", $misc->printVal($report->fields['descr']), "
{$lang['strpaginate']}", $misc->printVal($report->fields['paginate'], 'yesno', array('align' => 'left')), "
{$lang['strsql']}", $misc->printVal($report->fields['report_sql']), "
\n"; + } + else echo "

{$lang['strinvalidparam']}

\n"; + + $urlvars = array ( + 'plugin' => $this->name, + 'server' => $_REQUEST['server'] + ); + if (isset($_REQUEST['schema'])) $urlvars['schema'] = $_REQUEST['schema']; + if (isset($_REQUEST['schema'])) $urlvars['database'] = $_REQUEST['schema']; + + $navlinks = array ( + 'showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array_merge($urlvars, array('action' => 'default_action')) + ) + ), + 'content' => $this->lang['strshowallreports'] + ), + 'edit' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array_merge($urlvars, array( + 'action' => 'edit', + 'report_id' => $report->fields['report_id']) + ) + ) + ), + 'content' => $lang['stredit'] + ), + 'execute' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array_merge($urlvars, array( + 'action' => 'execute', + 'report' => $report->fields['report_name'], + 'database' => $report->fields['db_name'], + 'report_id' => $report->fields['report_id'], + 'paginate' => $report->fields['paginate'], + 'nohistory' => 't', + 'return' => 'plugin', + 'back' => 'properties' + )) + ) + ), + 'content' => $lang['strexecute'] + ) + ); + $misc->printNavLinks($navlinks, 'reports-properties'); + } + + /** + * Displays a screen where they can enter a new report + */ + function create($msg = '') { + global $data, $reportsdb, $misc; + global $lang; + + $misc->printHeader($this->lang['strreports']); + $misc->printBody(); + $misc->printTrail('server'); + $misc->printTabs('server', 'report_plugin'); + $misc->printMsg($msg); + + if (!isset($_REQUEST['report_name'])) $_REQUEST['report_name'] = ''; + if (!isset($_REQUEST['db_name'])) $_REQUEST['db_name'] = ''; + if (!isset($_REQUEST['descr'])) $_REQUEST['descr'] = ''; + if (!isset($_REQUEST['report_sql'])) { + // Set the query from session if linked from a user query result + if (isset($_REQUEST['fromsql']) and $_REQUEST['fromsql'] == 1 ) { + $_REQUEST['report_sql'] = $_SESSION['sqlquery']; + } + else { + $_REQUEST['sortkey'] = isset($_REQUEST['sortkey']) ? $_REQUEST['sortkey'] : ''; + if (preg_match('/^[0-9]+$/', $_REQUEST['sortkey']) && $_REQUEST['sortkey'] > 0) $orderby = array($_REQUEST['sortkey'] => $_REQUEST['sortdir']); + else $orderby = array(); + + $subject = isset($_REQUEST['subject']) && isset($_REQUEST[$_REQUEST['subject']]) + ? $_REQUEST[$_REQUEST['subject']] + : ''; + + $_REQUEST['report_sql'] = $data->getSelectSQL($subject, array(), array(), array(), $orderby); + } + } + + if (isset($_REQUEST['database'])) { + $_REQUEST['db_name'] = $_REQUEST['database']; + unset($_REQUEST['database']); + $misc->setForm(); + } + + $databases = $data->getDatabases(); + + echo "
name}\" method=\"post\">\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['report_name']), "\" />
{$lang['strdatabase']}
{$lang['strcomment']}
{$lang['strsql']}
\n"; + echo "\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + $misc->printFooter(); + } + + /** + * Actually creates the new report in the database + */ + function save_create() { + if (isset($_REQUEST['cancel'])) { + $this->default_action(); + exit; + } + + $reportsdb = $this->get_reportsdb(); + + if (!isset($_POST['report_name'])) $_POST['report_name'] = ''; + if (!isset($_POST['db_name'])) $_POST['db_name'] = ''; + if (!isset($_POST['descr'])) $_POST['descr'] = ''; + if (!isset($_POST['report_sql'])) $_POST['report_sql'] = ''; + + // Check that they've given a name and a definition + if ($_POST['report_name'] == '') $this->create($this->lang['strreportneedsname']); + elseif ($_POST['report_sql'] == '') $this->create($this->lang['strreportneedsdef']); + else { + $status = $reportsdb->createReport($_POST['report_name'], $_POST['db_name'], + $_POST['descr'], $_POST['report_sql'], isset($_POST['paginate'])); + if ($status == 0) + $this->default_action($this->lang['strreportcreated']); + else + $this->create($this->lang['strreportcreatedbad']); + } + } + + /** + * Show confirmation of drop and perform actual drop + */ + function drop() { + global $reportsdb, $misc; + global $lang; + + $confirm = false; + if (isset($_REQUEST['confirm'])) $confirm = true; + + $reportsdb = $this->get_reportsdb(); + + $misc->printHeader($this->lang['strreports']); + $misc->printBody(); + + if (isset($_REQUEST['cancel'])) { + $this->default_action(); + exit; + } + + if ($confirm) { + // Fetch report from the database + $report = $reportsdb->getReport($_REQUEST['report_id']); + + $_REQUEST['report'] = $report->fields['report_name']; + $misc->printTrail('report'); + $misc->printTitle($lang['strdrop']); + + echo "

", sprintf($this->lang['strconfdropreport'], $misc->printVal($report->fields['report_name'])), "

\n"; + + echo "
name}\" method=\"post\">\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } else { + $status = $reportsdb->dropReport($_POST['report_id']); + if ($status == 0) + $this->default_action($this->lang['strreportdropped']); + else + $this->default_action($this->lang['strreportdroppedbad']); + } + + $misc->printFooter(); + } + + function execute() { + global $misc, $data; + + $reportsdb = $this->get_reportsdb(); + + $report = $reportsdb->getReport($_REQUEST['report_id']); + + $_POST['query'] = $report->fields['report_sql']; + + include('./sql.php'); + } + + /** + * Show default list of reports in the database + */ + function default_action($msg = '') { + global $data, $misc, $lang; + + $reportsdb = $this->get_reportsdb(); + + $misc->printHeader($this->lang['strreports']); + $misc->printBody(); + $misc->printTrail('server'); + $misc->printTabs('server', 'report_plugin'); + $misc->printMsg($msg); + + $reports = $reportsdb->getReports(); + + $columns = array( + 'report' => array( + 'title' => $this->lang['strreport'], + 'field' => field('report_name'), + 'url' => "plugin.php?plugin={$this->name}&action=properties&{$misc->href}&", + 'vars' => array( + 'report_id' => 'report_id', + 'report' => 'report_name' + ), + ), + 'database' => array( + 'title' => $lang['strdatabase'], + 'field' => field('db_name'), + ), + 'created' => array( + 'title' => $lang['strcreated'], + 'field' => field('date_created'), + ), + 'paginate' => array( + 'title' => $lang['strpaginate'], + 'field' => field('paginate'), + 'type' => 'yesno', + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('descr'), + ), + ); + + //$return_url = urlencode("plugin.php?plugin={$this->name}&{$misc->href}"); + $urlvars = $misc->getRequestVars(); + + $actions = array( + 'run' => array ( + 'content' => $lang['strexecute'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array_merge($urlvars, array ( + 'plugin' => $this->name, + 'action' => 'execute', + 'report' => field('report_name'), + 'database' => field('db_name'), + 'report_id' => field('report_id'), + 'paginate' => field('paginate'), + 'nohistory' => 't', + 'return' => 'plugin', + 'back' => 'default_action' + )) + ) + ) + ), + 'edit' => array ( + 'content' => $lang['stredit'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array_merge($urlvars, array ( + 'plugin' => $this->name, + 'action' => 'edit', + 'report_id' => field('report_id'), + )) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array_merge($urlvars, array ( + 'plugin' => $this->name, + 'action' => 'drop', + 'confirm' => 'true', + 'report_id' => field('report_id'), + )) + ) + ) + ), + ); + + $misc->printTable($reports, $columns, $actions, 'reports-reports', $this->lang['strnoreports']); + + $navlinks = array ( + array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'plugin.php', + 'urlvars' => array ( + 'plugin' => $this->name, + 'server' => field('server'), + 'action' => 'create') + ) + ), + 'content' => $this->lang['strcreatereport'] + ) + ); + $misc->printNavLinks($navlinks, 'reports-reports'); + $misc->printFooter(); + } +} +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/sql/reports-pgsql.sql b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/sql/reports-pgsql.sql new file mode 100644 index 00000000..1272a762 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/plugins/Report/sql/reports-pgsql.sql @@ -0,0 +1,27 @@ +-- SQL script to create reports database for PostgreSQL +-- +-- To run, type: psql template1 < reports-pgsql.sql +-- +-- $Id: reports-pgsql.sql,v 1.4 2007/04/16 11:02:36 mr-russ Exp $ + +CREATE DATABASE phppgadmin; + +\connect phppgadmin + +CREATE TABLE ppa_reports ( + report_id SERIAL, + report_name varchar(255) NOT NULL, + db_name varchar(255) NOT NULL, + date_created date DEFAULT NOW() NOT NULL, + created_by varchar(255) NOT NULL, + descr text, + report_sql text NOT NULL, + paginate boolean NOT NULL, + PRIMARY KEY (report_id) +); + +-- Allow everyone to do everything with reports. This may +-- or may not be what you want. +GRANT SELECT,INSERT,UPDATE,DELETE ON ppa_reports TO PUBLIC; +GRANT SELECT,UPDATE ON ppa_reports_report_id_seq TO PUBLIC; + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/privileges.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/privileges.php new file mode 100644 index 00000000..ea7b7f95 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/privileges.php @@ -0,0 +1,354 @@ +getUsers(); + // Get groups from the database + $groups = $data->getGroups(); + + $misc->printTrail($_REQUEST['subject']); + + switch ($mode) { + case 'grant': + $misc->printTitle($lang['strgrant'],'pg.privilege.grant'); + break; + case 'revoke': + $misc->printTitle($lang['strrevoke'],'pg.privilege.revoke'); + break; + } + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + // Grant option + if ($data->hasGrantOption()) { + echo "\n"; + echo "\n"; + } + echo "
{$lang['strusers']}
{$lang['strgroups']}\n"; + echo "\n"; + // Only show groups if there are groups! + if ($groups->recordCount() > 0) { + echo "
\n"; + } + echo "
{$lang['strprivileges']}\n"; + foreach ($data->privlist[$_REQUEST['subject']] as $v) { + $v = htmlspecialchars($v); + echo "
\n"; + } + echo "
{$lang['stroptions']}\n"; + if ($mode == 'grant') { + echo "\n"; + } + elseif ($mode == 'revoke') { + echo "
\n"; + echo "
\n"; + } + echo "
\n"; + + echo "

\n"; + echo "\n"; + echo "\n"; + if (isset($_REQUEST[$_REQUEST['subject'].'_oid'])) + echo "\n"; + echo "\n"; + if ($_REQUEST['subject'] == 'column') + echo "\n"; + echo $misc->form; + if ($mode == 'grant') + echo "\n"; + elseif ($mode == 'revoke') + echo "\n"; + echo "

"; + echo "
\n"; + } + else { + // Determine whether object should be ref'd by name or oid. + if (isset($_REQUEST[$_REQUEST['subject'].'_oid'])) + $object = $_REQUEST[$_REQUEST['subject'].'_oid']; + else + $object = $_REQUEST[$_REQUEST['subject']]; + + if (isset($_REQUEST['table'])) $table = $_REQUEST['table']; + else $table = null; + $status = $data->setPrivileges(($mode == 'grant') ? 'GRANT' : 'REVOKE', $_REQUEST['subject'], $object, + isset($_REQUEST['public']), $_REQUEST['username'], $_REQUEST['groupname'], array_keys($_REQUEST['privilege']), + isset($_REQUEST['grantoption']), isset($_REQUEST['cascade']), $table); + + if ($status == 0) + doDefault($lang['strgranted']); + elseif ($status == -3 || $status == -4) + doAlter(true, $_REQUEST['mode'], $lang['strgrantbad']); + else + doAlter(true, $_REQUEST['mode'], $lang['strgrantfailed']); + } + } + + /** + * Show permissions on a database, namespace, relation, language or function + */ + function doDefault($msg = '') { + global $data, $misc, $database; + global $lang; + + $misc->printTrail($_REQUEST['subject']); + + # @@@FIXME: This switch is just a temporary solution, + # need a better way, maybe every type of object should + # have a tab bar??? + switch ($_REQUEST['subject']) { + case 'server': + case 'database': + case 'schema': + case 'table': + case 'column': + case 'view': + $misc->printTabs($_REQUEST['subject'], 'privileges'); + break; + default: + $misc->printTitle($lang['strprivileges'], 'pg.privilege'); + } + $misc->printMsg($msg); + + // Determine whether object should be ref'd by name or oid. + if (isset($_REQUEST[$_REQUEST['subject'].'_oid'])) + $object = $_REQUEST[$_REQUEST['subject'].'_oid']; + else + $object = $_REQUEST[$_REQUEST['subject']]; + + // Get the privileges on the object, given its type + if ($_REQUEST['subject'] == 'column') + $privileges = $data->getPrivileges($object, 'column', $_REQUEST['table']); + else + $privileges = $data->getPrivileges($object, $_REQUEST['subject']); + + if (sizeof($privileges) > 0) { + echo "\n"; + if ($data->hasRoles()) + echo ""; + else + echo ""; + + foreach ($data->privlist[$_REQUEST['subject']] as $v2) { + // Skip over ALL PRIVILEGES + if ($v2 == 'ALL PRIVILEGES') continue; + echo "\n"; + } + if ($data->hasGrantOption()) { + echo ""; + } + echo "\n"; + + // Loop over privileges, outputting them + $i = 0; + foreach ($privileges as $v) { + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + if (!$data->hasRoles()) + echo "\n"; + echo "\n"; + foreach ($data->privlist[$_REQUEST['subject']] as $v2) { + // Skip over ALL PRIVILEGES + if ($v2 == 'ALL PRIVILEGES') continue; + echo "\n"; + } + if ($data->hasGrantOption()) { + echo "\n"; + } + echo "\n"; + $i++; + } + + echo "
{$lang['strrole']}
{$lang['strtype']}{$lang['struser']}/{$lang['strgroup']}{$v2}{$lang['strgrantor']}
", $misc->printVal($v[0]), "", $misc->printVal($v[1]), ""; + if (in_array($v2, $v[2])) + echo $lang['stryes']; + else + echo $lang['strno']; + // If we have grant option for this, end mark + if ($data->hasGrantOption() && in_array($v2, $v[4])) echo $lang['strasterisk']; + echo "", $misc->printVal($v[3]), "
"; + } + else { + echo "

{$lang['strnoprivileges']}

\n"; + } + + // Links for granting to a user or group + switch ($_REQUEST['subject']) { + case 'table': + case 'view': + case 'sequence': + case 'function': + case 'tablespace': + $alllabel = "showall{$_REQUEST['subject']}s"; + $allurl = "{$_REQUEST['subject']}s.php"; + $alltxt = $lang["strshowall{$_REQUEST['subject']}s"]; + break; + case 'schema': + $alllabel = "showallschemas"; + $allurl = "schemas.php"; + $alltxt = $lang["strshowallschemas"]; + break; + case 'database': + $alllabel = "showalldatabases"; + $allurl = 'all_db.php'; + $alltxt = $lang['strshowalldatabases']; + break; + } + + $subject = $_REQUEST['subject']; + $object = $_REQUEST[$_REQUEST['subject']]; + + if ($_REQUEST['subject'] == 'function') { + $objectoid = $_REQUEST[$_REQUEST['subject'].'_oid']; + $urlvars = array ( + 'action' => 'alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + $subject => $object, + "{$subject}_oid" => $objectoid, + 'subject'=> $subject + ); + } + else if ($_REQUEST['subject'] == 'column') { + $urlvars = array ( + 'action' => 'alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + $subject => $object, + 'subject'=> $subject + ); + + if (isset($_REQUEST['table'])) + $urlvars['table'] = $_REQUEST['table']; + else + $urlvars['view'] = $_REQUEST['view']; + } + else { + $urlvars = array ( + 'action' => 'alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + $subject => $object, + 'subject'=> $subject + ); + if (isset($_REQUEST['schema'])) { + $urlvars['schema'] = $_REQUEST['schema']; + } + } + + $navlinks = array ( + 'grant' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array_merge($urlvars, array('mode' => 'grant')) + ) + ), + 'content' => $lang['strgrant'] + ), + 'revoke' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array_merge($urlvars, array('mode' => 'revoke')) + ) + ), + 'content' => $lang['strrevoke'] + ) + ); + + if (isset($allurl)) { + $navlinks[$alllabel] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => $allurl, + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'] + ) + ) + ), + 'content' => $alltxt + ); + if (isset($_REQUEST['schema'])) { + $navlinks[$alllabel]['attr']['href']['urlvars']['schema'] = $_REQUEST['schema']; + } + } + + $misc->printNavLinks($navlinks, 'privileges-privileges', get_defined_vars()); + } + + $misc->printHeader($lang['strprivileges']); + $misc->printBody(); + + switch ($action) { + case 'save': + if (isset($_REQUEST['cancel'])) doDefault(); + else doAlter(false, $_REQUEST['mode']); + break; + case 'alter': + doAlter(true, $_REQUEST['mode']); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/redirect.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/redirect.php new file mode 100644 index 00000000..f31aa086 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/redirect.php @@ -0,0 +1,29 @@ +getLastTabURL($subject); + + // Load query vars into superglobal arrays + if (isset($url['urlvars'])) { + $urlvars = array(); + + foreach($url['urlvars'] as $k => $urlvar) { + $urlvars[$k] = value($urlvar, $_REQUEST); + } + + /* parse_str function is affected by magic_quotes_gpc */ + if (ini_get('magic_quotes_gpc')) { + $misc->stripVar($urlvars); + } + + $_REQUEST = array_merge($_REQUEST, $urlvars); + $_GET = array_merge($_GET, $urlvars); + } + + require $url['url']; +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/robots.txt b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/robots.txt new file mode 100644 index 00000000..223518bb --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/robots.txt @@ -0,0 +1,8 @@ +# Prevent web robots from indexing your phpPgAdmin installation +# See: http://www.searchengineworld.com/robots/robots_tutorial.htm +# +# $Id: robots.txt,v 1.1 2003/09/01 03:02:17 chriskl Exp $ + +User-agent: * +Disallow: / + diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/roles.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/roles.php new file mode 100644 index 00000000..b4444cfa --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/roles.php @@ -0,0 +1,743 @@ +printTrail('role'); + $misc->printTitle($lang['strcreaterole'],'pg.role.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + $roles = $data->getRoles(); + if ($roles->recordCount() > 0) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + $roles->moveFirst(); + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + $roles->moveFirst(); + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + echo "
{$lang['strname']}_maxNameLen}\" name=\"formRolename\" value=\"", htmlspecialchars($_POST['formRolename']), "\" />
{$lang['strpassword']}
{$lang['strconfirm']}
{$lang['strconnlimit']}
{$lang['strexpires']}
{$lang['strmemberof']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['strmembers']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['stradminmembers']}\n"; + echo "\t\t\t\n"; + echo "\t\t
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new role in the database + */ + function doSaveCreate() { + global $data, $lang; + + if(!isset($_POST['memberof'])) $_POST['memberof'] = array(); + if(!isset($_POST['members'])) $_POST['members'] = array(); + if(!isset($_POST['adminmembers'])) $_POST['adminmembers'] = array(); + + // Check data + if ($_POST['formRolename'] == '') + doCreate($lang['strroleneedsname']); + else if ($_POST['formPassword'] != $_POST['formConfirm']) + doCreate($lang['strpasswordconfirm']); + else { + $status = $data->createRole($_POST['formRolename'], $_POST['formPassword'], isset($_POST['formSuper']), + isset($_POST['formCreateDB']), isset($_POST['formCreateRole']), isset($_POST['formInherits']), + isset($_POST['formCanLogin']), $_POST['formConnLimit'], $_POST['formExpires'], $_POST['memberof'], $_POST['members'], + $_POST['adminmembers']); + if ($status == 0) + doDefault($lang['strrolecreated']); + else + doCreate($lang['strrolecreatedbad']); + } + } + + /** + * Function to allow alter a role + */ + function doAlter($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('role'); + $misc->printTitle($lang['stralter'],'pg.role.alter'); + $misc->printMsg($msg); + + $roledata = $data->getRole($_REQUEST['rolename']); + + if ($roledata->recordCount() > 0) { + $server_info = $misc->getServerInfo(); + $canRename = $data->hasUserRename() && ($_REQUEST['rolename'] != $server_info['username']); + $roledata->fields['rolsuper'] = $data->phpBool($roledata->fields['rolsuper']); + $roledata->fields['rolcreatedb'] = $data->phpBool($roledata->fields['rolcreatedb']); + $roledata->fields['rolcreaterole'] = $data->phpBool($roledata->fields['rolcreaterole']); + $roledata->fields['rolinherit'] = $data->phpBool($roledata->fields['rolinherit']); + $roledata->fields['rolcanlogin'] = $data->phpBool($roledata->fields['rolcanlogin']); + + if (!isset($_POST['formExpires'])){ + if ($canRename) $_POST['formNewRoleName'] = $roledata->fields['rolname']; + if ($roledata->fields['rolsuper']) $_POST['formSuper'] = ''; + if ($roledata->fields['rolcreatedb']) $_POST['formCreateDB'] = ''; + if ($roledata->fields['rolcreaterole']) $_POST['formCreateRole'] = ''; + if ($roledata->fields['rolinherit']) $_POST['formInherits'] = ''; + if ($roledata->fields['rolcanlogin']) $_POST['formCanLogin'] = ''; + $_POST['formConnLimit'] = $roledata->fields['rolconnlimit'] == '-1' ? '' : $roledata->fields['rolconnlimit']; + $_POST['formExpires'] = $roledata->fields['rolvaliduntil'] == 'infinity' ? '' : $roledata->fields['rolvaliduntil']; + $_POST['formPassword'] = ''; + } + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + if (!isset($_POST['memberof'])) + { + $memberof = $data->getMemberOf($_REQUEST['rolename']); + if ($memberof->recordCount() > 0) { + $i = 0; + while (!$memberof->EOF) { + $_POST['memberof'][$i++] = $memberof->fields['rolname']; + $memberof->moveNext(); + } + } + else + $_POST['memberof'] = array(); + $memberofold = implode(',', $_POST['memberof']); + } + if (!isset($_POST['members'])) + { + $members = $data->getMembers($_REQUEST['rolename']); + if ($members->recordCount() > 0) { + $i = 0; + while (!$members->EOF) { + $_POST['members'][$i++] = $members->fields['rolname']; + $members->moveNext(); + } + } + else + $_POST['members'] = array(); + $membersold = implode(',', $_POST['members']); + } + if (!isset($_POST['adminmembers'])) + { + $adminmembers = $data->getMembers($_REQUEST['rolename'], 't'); + if ($adminmembers->recordCount() > 0) { + $i = 0; + while (!$adminmembers->EOF) { + $_POST['adminmembers'][$i++] = $adminmembers->fields['rolname']; + $adminmembers->moveNext(); + } + } + else + $_POST['adminmembers'] = array(); + $adminmembersold = implode(',', $_POST['adminmembers']); + } + + $roles = $data->getRoles($_REQUEST['rolename']); + if ($roles->recordCount() > 0) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + $roles->moveFirst(); + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + $roles->moveFirst(); + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + echo "
{$lang['strname']}", ($canRename ? "_maxNameLen}\" value=\"" . htmlspecialchars($_POST['formNewRoleName']) . "\" />" : $misc->printVal($roledata->fields['rolname'])), "
{$lang['strpassword']}
{$lang['strconfirm']}
{$lang['strconnlimit']}
{$lang['strexpires']}
{$lang['strmemberof']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['strmembers']}\n"; + echo "\t\t\t\n"; + echo "\t\t
{$lang['stradminmembers']}\n"; + echo "\t\t\t\n"; + echo "\t\t
\n"; + + echo "

\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Function to save after editing a role + */ + function doSaveAlter() { + global $data, $lang; + + if(!isset($_POST['memberof'])) $_POST['memberof'] = array(); + if(!isset($_POST['members'])) $_POST['members'] = array(); + if(!isset($_POST['adminmembers'])) $_POST['adminmembers'] = array(); + + // Check name and password + if (isset($_POST['formNewRoleName']) && $_POST['formNewRoleName'] == '') + doAlter($lang['strroleneedsname']); + else if ($_POST['formPassword'] != $_POST['formConfirm']) + doAlter($lang['strpasswordconfirm']); + else { + if (isset($_POST['formNewRoleName'])) $status = $data->setRenameRole($_POST['rolename'], $_POST['formPassword'], isset($_POST['formSuper']), isset($_POST['formCreateDB']), isset($_POST['formCreateRole']), isset($_POST['formInherits']), isset($_POST['formCanLogin']), $_POST['formConnLimit'], $_POST['formExpires'], $_POST['memberof'], $_POST['members'], $_POST['adminmembers'], $_POST['memberofold'], $_POST['membersold'], $_POST['adminmembersold'], $_POST['formNewRoleName']); + else $status = $data->setRole($_POST['rolename'], $_POST['formPassword'], isset($_POST['formSuper']), isset($_POST['formCreateDB']), isset($_POST['formCreateRole']), isset($_POST['formInherits']), isset($_POST['formCanLogin']), $_POST['formConnLimit'], $_POST['formExpires'], $_POST['memberof'], $_POST['members'], $_POST['adminmembers'], $_POST['memberofold'], $_POST['membersold'], $_POST['adminmembersold']); + if ($status == 0) + doDefault($lang['strrolealtered']); + else + doAlter($lang['strrolealteredbad']); + } + } + + /** + * Show confirmation of drop a role and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('role'); + $misc->printTitle($lang['strdroprole'],'pg.role.drop'); + + echo "

", sprintf($lang['strconfdroprole'], $misc->printVal($_REQUEST['rolename'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropRole($_REQUEST['rolename']); + if ($status == 0) + doDefault($lang['strroledropped']); + else + doDefault($lang['strroledroppedbad']); + } + } + + /** + * Show the properties of a role + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('role'); + $misc->printTitle($lang['strproperties'],'pg.role'); + $misc->printMsg($msg); + + $roledata = $data->getRole($_REQUEST['rolename']); + if($roledata->recordCount() > 0 ) { + $roledata->fields['rolsuper'] = $data->phpBool($roledata->fields['rolsuper']); + $roledata->fields['rolcreatedb'] = $data->phpBool($roledata->fields['rolcreatedb']); + $roledata->fields['rolcreaterole'] = $data->phpBool($roledata->fields['rolcreaterole']); + $roledata->fields['rolinherit'] = $data->phpBool($roledata->fields['rolinherit']); + $roledata->fields['rolcanlogin'] = $data->phpBool($roledata->fields['rolcanlogin']); + + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
DescriptionValue
{$lang['strname']}", htmlspecialchars($_REQUEST['rolename']), "
{$lang['strsuper']}", (($roledata->fields['rolsuper']) ? $lang['stryes'] : $lang['strno']), "
{$lang['strcreatedb']}", (($roledata->fields['rolcreatedb']) ? $lang['stryes'] : $lang['strno']), "
{$lang['strcancreaterole']}", (($roledata->fields['rolcreaterole']) ? $lang['stryes'] : $lang['strno']), "
{$lang['strinheritsprivs']}", (($roledata->fields['rolinherit']) ? $lang['stryes'] : $lang['strno']), "
{$lang['strcanlogin']}", (($roledata->fields['rolcanlogin']) ? $lang['stryes'] : $lang['strno']), "
{$lang['strconnlimit']}", ($roledata->fields['rolconnlimit'] == '-1' ? $lang['strnolimit'] : $misc->printVal($roledata->fields['rolconnlimit'])), "
{$lang['strexpires']}", ($roledata->fields['rolvaliduntil'] == 'infinity' || is_null($roledata->fields['rolvaliduntil']) ? $lang['strnever'] : $misc->printVal($roledata->fields['rolvaliduntil'])), "
{$lang['strsessiondefaults']}", $misc->printVal($roledata->fields['rolconfig']), "
{$lang['strmemberof']}"; + $memberof = $data->getMemberOf($_REQUEST['rolename']); + if ($memberof->recordCount() > 0) { + while (!$memberof->EOF) { + echo $misc->printVal($memberof->fields['rolname']), "
\n"; + $memberof->moveNext(); + } + } + echo "
{$lang['strmembers']}"; + $members = $data->getMembers($_REQUEST['rolename']); + if ($members->recordCount() > 0) { + while (!$members->EOF) { + echo $misc->printVal($members->fields['rolname']), "
\n"; + $members->moveNext(); + } + } + echo "
{$lang['stradminmembers']}"; + $adminmembers = $data->getMembers($_REQUEST['rolename'], 't'); + if ($adminmembers->recordCount() > 0) { + while (!$adminmembers->EOF) { + echo $misc->printVal($adminmembers->fields['rolname']), "
\n"; + $adminmembers->moveNext(); + } + } + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + + $navlinks = array ( + 'showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strshowallroles'] + ), + 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'action' => 'alter', + 'server' => $_REQUEST['server'], + 'rolename' => $_REQUEST['rolename'] + ) + ) + ), + 'content' => $lang['stralter'] + ), + 'drop' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'rolename' => $_REQUEST['rolename'] + ) + ) + ), + 'content' => $lang['strdrop'] + ) + ); + + $misc->printNavLinks($navlinks, 'roles-properties', get_defined_vars()); + } + + /** + * If a role is not a superuser role, then we have an 'account management' + * page for change his password, etc. We don't prevent them from + * messing with the URL to gain access to other role admin stuff, because + * the PostgreSQL permissions will prevent them changing anything anyway. + */ + function doAccount($msg = '') { + global $data, $misc; + global $lang; + + $server_info = $misc->getServerInfo(); + + $roledata = $data->getRole($server_info['username']); + $_REQUEST['rolename'] = $server_info['username']; + + $misc->printTrail('role'); + $misc->printTabs('server','account'); + $misc->printMsg($msg); + + if ($roledata->recordCount() > 0) { + $roledata->fields['rolsuper'] = $data->phpBool($roledata->fields['rolsuper']); + $roledata->fields['rolcreatedb'] = $data->phpBool($roledata->fields['rolcreatedb']); + $roledata->fields['rolcreaterole'] = $data->phpBool($roledata->fields['rolcreaterole']); + $roledata->fields['rolinherit'] = $data->phpBool($roledata->fields['rolinherit']); + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n
{$lang['strname']}{$lang['strsuper']}{$lang['strcreatedb']}{$lang['strcancreaterole']}{$lang['strinheritsprivs']}{$lang['strconnlimit']}{$lang['strexpires']}{$lang['strsessiondefaults']}
", $misc->printVal($roledata->fields['rolname']), "", $misc->printVal($roledata->fields['rolsuper'], 'yesno'), "", $misc->printVal($roledata->fields['rolcreatedb'], 'yesno'), "", $misc->printVal($roledata->fields['rolcreaterole'], 'yesno'), "", $misc->printVal($roledata->fields['rolinherit'], 'yesno'), "", ($roledata->fields['rolconnlimit'] == '-1' ? $lang['strnolimit'] : $misc->printVal($roledata->fields['rolconnlimit'])), "", ($roledata->fields['rolvaliduntil'] == 'infinity' || is_null($roledata->fields['rolvaliduntil']) ? $lang['strnever'] : $misc->printVal($roledata->fields['rolvaliduntil'])), "", $misc->printVal($roledata->fields['rolconfig']), "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + + $misc->printNavLinks(array ('changepassword' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'action' => 'confchangepassword', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strchangepassword'] + )), 'roles-account', get_defined_vars()); + } + + /** + * Show confirmation of change password and actually change password + */ + function doChangePassword($confirm, $msg = '') { + global $data, $misc; + global $lang, $conf; + + $server_info = $misc->getServerInfo(); + + if ($confirm) { + $_REQUEST['rolename'] = $server_info['username']; + $misc->printTrail('role'); + $misc->printTitle($lang['strchangepassword'],'pg.role.alter'); + $misc->printMsg($msg); + + if (!isset($_POST['password'])) $_POST['password'] = ''; + if (!isset($_POST['confirm'])) $_POST['confirm'] = ''; + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strpassword']}
{$lang['strconfirm']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + } + else { + // Check that password is minimum length + if (strlen($_POST['password']) < $conf['min_password_length']) + doChangePassword(true, $lang['strpasswordshort']); + // Check that password matches confirmation password + elseif ($_POST['password'] != $_POST['confirm']) + doChangePassword(true, $lang['strpasswordconfirm']); + else { + $status = $data->changePassword($server_info['username'], $_POST['password']); + if ($status == 0) + doAccount($lang['strpasswordchanged']); + else + doAccount($lang['strpasswordchangedbad']); + } + } + } + + + /** + * Show default list of roles in the database + */ + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + function renderRoleConnLimit($val) { + global $lang; + return $val == '-1' ? $lang['strnolimit'] : htmlspecialchars($val); + } + + function renderRoleExpires($val) { + global $lang; + return $val == 'infinity' ? $lang['strnever'] : htmlspecialchars($val); + } + + $misc->printTrail('server'); + $misc->printTabs('server','roles'); + $misc->printMsg($msg); + + $roles = $data->getRoles(); + + $columns = array( + 'role' => array( + 'title' => $lang['strrole'], + 'field' => field('rolname'), + 'url' => "redirect.php?subject=role&action=properties&{$misc->href}&", + 'vars' => array('rolename' => 'rolname'), + ), + 'superuser' => array( + 'title' => $lang['strsuper'], + 'field' => field('rolsuper'), + 'type' => 'yesno', + ), + 'createdb' => array( + 'title' => $lang['strcreatedb'], + 'field' => field('rolcreatedb'), + 'type' => 'yesno', + ), + 'createrole' => array( + 'title' => $lang['strcancreaterole'], + 'field' => field('rolcreaterole'), + 'type' => 'yesno', + ), + 'inherits' => array( + 'title' => $lang['strinheritsprivs'], + 'field' => field('rolinherit'), + 'type' => 'yesno', + ), + 'canloging' => array( + 'title' => $lang['strcanlogin'], + 'field' => field('rolcanlogin'), + 'type' => 'yesno', + ), + 'connlimit' => array( + 'title' => $lang['strconnlimit'], + 'field' => field('rolconnlimit'), + 'type' => 'callback', + 'params'=> array('function' => 'renderRoleConnLimit') + ), + 'expires' => array( + 'title' => $lang['strexpires'], + 'field' => field('rolvaliduntil'), + 'type' => 'callback', + 'params'=> array('function' => 'renderRoleExpires', 'null' => $lang['strnever']), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'action' => 'alter', + 'rolename' => field('rolname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'rolename' => field('rolname') + ) + ) + ) + ), + ); + + $misc->printTable($roles, $columns, $actions, 'roles-roles', $lang['strnoroles']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'roles.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strcreaterole'] + ) + ); + $misc->printNavLinks($navlinks, 'roles-roles', get_defined_vars()); + } + + $misc->printHeader($lang['strroles']); + $misc->printBody(); + + switch ($action) { + case 'create': + doCreate(); + break; + case 'save_create': + if (isset($_POST['create'])) doSaveCreate(); + else doDefault(); + break; + case 'alter': + doAlter(); + break; + case 'save_alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'properties': + doProperties(); + break; + case 'confchangepassword': + doChangePassword(true); + break; + case 'changepassword': + if (isset($_REQUEST['ok'])) doChangePassword(false); + else doAccount(); + break; + case 'account': + doAccount(); + break; + default: + doDefault(); + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/rules.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/rules.php new file mode 100644 index 00000000..3ea50c90 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/rules.php @@ -0,0 +1,232 @@ +printTrail($_REQUEST['subject']); + $misc->printTitle($lang['strcreaterule'],'pg.rule.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />
{$lang['strevent']}
{$lang['strwhere']}
"; + echo "\n"; + echo "
{$lang['straction']}"; + echo "
\n"; + echo "\n"; + echo "()
\n"; + + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "

\n"; + echo "
\n"; + + } + else { + if (trim($_POST['name']) == '') + createRule(true, $lang['strruleneedsname']); + else { + $status = $data->createRule($_POST['name'], + $_POST['event'], $_POST[$_POST['subject']], $_POST['where'], + isset($_POST['instead']), $_POST['type'], $_POST['raction']); + if ($status == 0) + doDefault($lang['strrulecreated']); + else + createRule(true, $lang['strrulecreatedbad']); + } + } + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail($_REQUEST['subject']); + $misc->printTitle($lang['strdrop'],'pg.rule.drop'); + + echo "

", sprintf($lang['strconfdroprule'], $misc->printVal($_REQUEST['rule']), + $misc->printVal($_REQUEST[$_REQUEST['reltype']])), "

\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropRule($_POST['rule'], $_POST[$_POST['subject']], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['strruledropped']); + else + doDefault($lang['strruledroppedbad']); + } + + } + + /** + * List all the rules on the table + */ + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail($_REQUEST['subject']); + $misc->printTabs($_REQUEST['subject'], 'rules'); + $misc->printMsg($msg); + + $rules = $data->getRules($_REQUEST[$_REQUEST['subject']]); + + $columns = array( + 'rule' => array( + 'title' => $lang['strname'], + 'field' => field('rulename'), + ), + 'definition' => array( + 'title' => $lang['strdefinition'], + 'field' => field('definition'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $subject = urlencode($_REQUEST['subject']); + $object = urlencode($_REQUEST[$_REQUEST['subject']]); + + $actions = array( + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'rules.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'reltype' => $subject, + $subject => $object, + 'subject' => 'rule', + 'rule' => field('rulename') + ) + ) + ) + ), + ); + + $misc->printTable($rules, $columns, $actions, 'rules-rules', $lang['strnorules']); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'rules.php', + 'urlvars' => array ( + 'action' => 'create_rule', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + $subject => $object, + 'subject' => $subject + ) + ) + ), + 'content' => $lang['strcreaterule'] + )), 'rules-rules', get_defined_vars()); + } + + function doTree() { + global $misc, $data; + + $rules = $data->getRules($_REQUEST[$_REQUEST['subject']]); + + $reqvars = $misc->getRequestVars($_REQUEST['subject']); + + $attrs = array( + 'text' => field('rulename'), + 'icon' => 'Rule', + ); + + $misc->printTree($rules, $attrs, 'rules'); + exit; + } + + if ($action == 'tree') doTree(); + + // Different header if we're view rules or table rules + $misc->printHeader($_REQUEST[$_REQUEST['subject']] . ' - ' . $lang['strrules']); + $misc->printBody(); + + switch ($action) { + case 'create_rule': + createRule(true); + break; + case 'save_create_rule': + if (isset($_POST['cancel'])) doDefault(); + else createRule(false); + break; + case 'drop': + if (isset($_POST['yes'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/schemas.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/schemas.php new file mode 100644 index 00000000..a5ac8381 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/schemas.php @@ -0,0 +1,480 @@ +printTrail('database'); + $misc->printTabs('database','schemas'); + $misc->printMsg($msg); + + // Check that the DB actually supports schemas + $schemas = $data->getSchemas(); + + $columns = array( + 'schema' => array( + 'title' => $lang['strschema'], + 'field' => field('nspname'), + 'url' => "redirect.php?subject=schema&{$misc->href}&", + 'vars' => array('schema' => 'nspname'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('nspowner'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('nspcomment'), + ), + ); + + $actions = array( + 'multiactions' => array( + 'keycols' => array('nsp' => 'nspname'), + 'url' => 'schemas.php', + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'schemas.php', + 'urlvars' => array ( + 'action' => 'drop', + 'nsp' => field('nspname') + ) + ) + ), + 'multiaction' => 'drop', + ), + 'privileges' => array( + 'content' => $lang['strprivileges'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array ( + 'subject' => 'schema', + 'schema' => field('nspname') + ) + ) + ) + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'schemas.php', + 'urlvars' => array ( + 'action' => 'alter', + 'schema' => field('nspname') + ) + ) + ) + ) + ); + + if (!$data->hasAlterSchema()) unset($actions['alter']); + + $misc->printTable($schemas, $columns, $actions, 'schemas-schemas', $lang['strnoschemas']); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'schemas.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'] + ) + ) + ), + 'content' => $lang['strcreateschema'] + )), 'schemas-schemas', get_defined_vars()); + } + + /** + * Displays a screen where they can enter a new schema + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + $server_info = $misc->getServerInfo(); + + if (!isset($_POST['formName'])) $_POST['formName'] = ''; + if (!isset($_POST['formAuth'])) $_POST['formAuth'] = $server_info['username']; + if (!isset($_POST['formSpc'])) $_POST['formSpc'] = ''; + if (!isset($_POST['formComment'])) $_POST['formComment'] = ''; + + // Fetch all users from the database + $users = $data->getUsers(); + + $misc->printTrail('database'); + $misc->printTitle($lang['strcreateschema'],'pg.schema.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + // Owner + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formName']), "\" />
{$lang['strowner']}\n\t\t\t\n\t\t
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new schema in the database + */ + function doSaveCreate() { + global $data, $lang, $_reload_browser; + + // Check that they've given a name + if ($_POST['formName'] == '') doCreate($lang['strschemaneedsname']); + else { + $status = $data->createSchema($_POST['formName'], $_POST['formAuth'], $_POST['formComment']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strschemacreated']); + } + else + doCreate($lang['strschemacreatedbad']); + } + } + + /** + * Display a form to permit editing schema properies. + * TODO: permit changing owner + */ + function doAlter($msg = '') { + global $data, $misc, $lang; + + $misc->printTrail('schema'); + $misc->printTitle($lang['stralter'],'pg.schema.alter'); + $misc->printMsg($msg); + + $schema = $data->getSchemaByName($_REQUEST['schema']); + if ($schema->recordCount() > 0) { + if (!isset($_POST['comment'])) $_POST['comment'] = $schema->fields['nspcomment']; + if (!isset($_POST['schema'])) $_POST['schema'] = $_REQUEST['schema']; + if (!isset($_POST['name'])) $_POST['name'] = $_REQUEST['schema']; + if (!isset($_POST['owner'])) $_POST['owner'] = $schema->fields['ownername']; + + echo "
\n"; + echo "\n"; + + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + + if ($data->hasAlterSchemaOwner()) { + $users = $data->getUsers(); + echo "\n"; + echo "\n"; + } + else + echo ""; + + echo "\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\n"; + echo "
{$lang['strname']}"; + echo "\t\t\t_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />\n"; + echo "\t\t
{$lang['strowner']}
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } else { + echo "

{$lang['strnodata']}

\n"; + } + } + + /** + * Save the form submission containing changes to a schema + */ + function doSaveAlter($msg = '') { + global $data, $misc, $lang, $_reload_browser; + + $status = $data->updateSchema($_POST['schema'], $_POST['comment'], $_POST['name'], $_POST['owner']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strschemaaltered']); + } + else + doAlter($lang['strschemaalteredbad']); + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang, $_reload_browser; + + if (empty($_REQUEST['nsp']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifyschematodrop']); + exit(); + } + + if ($confirm) { + $misc->printTrail('schema'); + $misc->printTitle($lang['strdrop'],'pg.schema.drop'); + + echo "
\n"; + //If multi drop + if (isset($_REQUEST['ma'])) { + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo '

', sprintf($lang['strconfdropschema'], $misc->printVal($a['nsp'])), "

\n"; + echo '\n"; + } + } + else { + echo "

", sprintf($lang['strconfdropschema'], $misc->printVal($_REQUEST['nsp'])), "

\n"; + echo "\n"; + } + + echo "

\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + if (is_array($_POST['nsp'])) { + $msg = ''; + $status = $data->beginTransaction(); + if ($status == 0) { + foreach($_POST['nsp'] as $s) { + $status = $data->dropSchema($s, isset($_POST['cascade'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($s, ENT_QUOTES, 'UTF-8'), $lang['strschemadropped']); + else { + $data->endTransaction(); + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($s, ENT_QUOTES, 'UTF-8'), $lang['strschemadroppedbad'])); + return; + } + } + } + if($data->endTransaction() == 0) { + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else doDefault($lang['strschemadroppedbad']); + } + else{ + $status = $data->dropSchema($_POST['nsp'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strschemadropped']); + } + else + doDefault($lang['strschemadroppedbad']); + } + } + } + + /** + * Displays options for database download + */ + function doExport($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','export'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + // Data only + echo "\n"; + echo "\n"; + echo "\n\n"; + echo "\n\n"; + // Structure only + echo "\n"; + echo "\n\n"; + // Structure and data + echo "\n"; + echo "\n"; + echo "\n\n"; + echo "\n\n"; + echo "\n\n"; + echo "
{$lang['strformat']}{$lang['stroptions']}
"; + echo "{$lang['strformat']}\n
"; + echo "{$lang['strformat']}\n
\n"; + + echo "

{$lang['stroptions']}

\n"; + echo "

\n"; + echo "
\n"; + // MSIE cannot download gzip in SSL mode - it's just broken + if (!(strstr($_SERVER['HTTP_USER_AGENT'], 'MSIE') && isset($_SERVER['HTTPS']))) { + echo "
\n"; + } + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "
\n"; + } + + + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data, $lang; + + $schemas = $data->getSchemas(); + + $reqvars = $misc->getRequestVars('schema'); + + $attrs = array( + 'text' => field('nspname'), + 'icon' => 'Schema', + 'toolTip'=> field('nspcomment'), + 'action' => url('redirect.php', + $reqvars, + array( + 'subject' => 'schema', + 'schema' => field('nspname') + ) + ), + 'branch' => url('schemas.php', + $reqvars, + array( + 'action' => 'subtree', + 'schema' => field('nspname') + ) + ), + ); + + $misc->printTree($schemas, $attrs, 'schemas'); + + exit; + } + + function doSubTree() { + global $misc, $data, $lang; + + $tabs = $misc->getNavTabs('schema'); + + $items = $misc->adjustTabsForTree($tabs); + + $reqvars = $misc->getRequestVars('schema'); + + $attrs = array( + 'text' => field('title'), + 'icon' => field('icon'), + 'action' => url(field('url'), + $reqvars, + field('urlvars', array()) + ), + 'branch' => url(field('url'), + $reqvars, + field('urlvars'), + array('action' => 'tree') + ) + ); + + $misc->printTree($items, $attrs, 'schema'); + exit; + } + + if ($action == 'tree') doTree(); + if ($action == 'subtree') doSubTree(); + + $misc->printHeader($lang['strschemas']); + $misc->printBody(); + + if (isset($_POST['cancel'])) $action = ''; + + switch ($action) { + case 'create': + if (isset($_POST['create'])) doSaveCreate(); + else doCreate(); + break; + case 'alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doAlter(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDrop(true); + break; + case 'export': + doExport(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sequences.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sequences.php new file mode 100644 index 00000000..a51878c0 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sequences.php @@ -0,0 +1,728 @@ +printTrail('schema'); + $misc->printTabs('schema', 'sequences'); + $misc->printMsg($msg); + + // Get all sequences + $sequences = $data->getSequences(); + + $columns = array( + 'sequence' => array( + 'title' => $lang['strsequence'], + 'field' => field('seqname'), + 'url' => "sequences.php?action=properties&{$misc->href}&", + 'vars' => array('sequence' => 'seqname'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('seqowner'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('seqcomment'), + ), + ); + + $actions = array( + 'multiactions' => array( + 'keycols' => array('sequence' => 'seqname'), + 'url' => 'sequences.php', + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'subject' => 'sequence', + 'sequence' => field('seqname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'sequence' => field('seqname') + ) + ) + ), + 'multiaction' => 'confirm_drop', + ), + 'privileges' => array( + 'content' => $lang['strprivileges'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array ( + 'subject' => 'sequence', + 'sequence' => field('seqname') + ) + ) + ) + ), + ); + + $misc->printTable($sequences, $columns, $actions, 'sequences-sequences', $lang['strnosequences']); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreatesequence'] + )), 'sequences-sequences', get_defined_vars()); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $sequences = $data->getSequences(); + + $reqvars = $misc->getRequestVars('sequence'); + + $attrs = array( + 'text' => field('seqname'), + 'icon' => 'Sequence', + 'toolTip'=> field('seqcomment'), + 'action' => url('sequences.php', + $reqvars, + array ( + 'action' => 'properties', + 'sequence' => field('seqname') + ) + ) + ); + + $misc->printTree($sequences, $attrs, 'sequences'); + exit; + } + + /** + * Display the properties of a sequence + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('sequence'); + $misc->printTitle($lang['strproperties'],'pg.sequence'); + $misc->printMsg($msg); + + // Fetch the sequence information + $sequence = $data->getSequence($_REQUEST['sequence']); + + if (is_object($sequence) && $sequence->recordCount() > 0) { + $sequence->fields['is_cycled'] = $data->phpBool($sequence->fields['is_cycled']); + $sequence->fields['is_called'] = $data->phpBool($sequence->fields['is_called']); + + // Show comment if any + if ($sequence->fields['seqcomment'] !== null) + echo "

", $misc->printVal($sequence->fields['seqcomment']), "

\n"; + + echo ""; + echo ""; + if ($data->hasAlterSequenceStart()) { + echo ""; + } + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + if ($data->hasAlterSequenceStart()) { + echo ""; + } + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo "
{$lang['strname']}{$lang['strstartvalue']}{$lang['strlastvalue']}{$lang['strincrementby']}{$lang['strmaxvalue']}{$lang['strminvalue']}{$lang['strcachevalue']}{$lang['strlogcount']}{$lang['strcancycle']}{$lang['striscalled']}
", $misc->printVal($sequence->fields['seqname']), "", $misc->printVal($sequence->fields['start_value']), "", $misc->printVal($sequence->fields['last_value']), "", $misc->printVal($sequence->fields['increment_by']), "", $misc->printVal($sequence->fields['max_value']), "", $misc->printVal($sequence->fields['min_value']), "", $misc->printVal($sequence->fields['cache_value']), "", $misc->printVal($sequence->fields['log_cnt']), "", ($sequence->fields['is_cycled'] ? $lang['stryes'] : $lang['strno']), "", ($sequence->fields['is_called'] ? $lang['stryes'] : $lang['strno']), "
"; + + $navlinks = array ( + 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'sequence' => $sequence->fields['seqname'] + ) + ) + ), + 'content' => $lang['stralter'] + ), + 'setval' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'confirm_setval', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'sequence' => $sequence->fields['seqname'] + ) + ) + ), + 'content' => $lang['strsetval'] + ), + 'nextval' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'nextval', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'sequence' => $sequence->fields['seqname'] + ) + ) + ), + 'content' => $lang['strnextval'] + ), + 'restart' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'restart', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'sequence' => $sequence->fields['seqname'] + ) + ) + ), + 'content' => $lang['strrestart'] + ), + 'reset' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'action' => 'reset', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'sequence' => $sequence->fields['seqname'] + ) + ) + ), + 'content' => $lang['strreset'] + ), + 'showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'sequences.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strshowallsequences'] + ) + ); + + if (! $data->hasAlterSequenceStart()) + unset($navlinks['restart']); + + $misc->printNavLinks($navlinks, 'sequences-properties', get_defined_vars()); + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Drop a sequence + */ + function doDrop($confirm, $msg = '') { + global $data, $misc; + global $lang; + + if (empty($_REQUEST['sequence']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifysequencetodrop']); + exit(); + } + + if ($confirm) { + $misc->printTrail('sequence'); + $misc->printTitle($lang['strdrop'],'pg.sequence.drop'); + $misc->printMsg($msg); + + echo "
\n"; + + //If multi drop + if (isset($_REQUEST['ma'])) { + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfdropsequence'], $misc->printVal($a['sequence'])), "

\n"; + printf('', htmlspecialchars($a['sequence'])); + } + } else { + echo "

", sprintf($lang['strconfdropsequence'], $misc->printVal($_REQUEST['sequence'])), "

\n"; + echo "\n"; + } + + echo "

\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + if (is_array($_POST['sequence'])) { + $msg = ''; + $status = $data->beginTransaction(); + if ($status == 0) { + foreach($_POST['sequence'] as $s) { + $status = $data->dropSequence($s, isset($_POST['cascade'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($s, ENT_QUOTES, 'UTF-8'), $lang['strsequencedropped']); + else { + $data->endTransaction(); + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($s, ENT_QUOTES, 'UTF-8'), $lang['strsequencedroppedbad'])); + return; + } + } + } + if($data->endTransaction() == 0) { + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else doDefault($lang['strsequencedroppedbad']); + } + else{ + $status = $data->dropSequence($_POST['sequence'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strsequencedropped']); + } + else + doDrop(true, $lang['strsequencedroppedbad']); + } + } + } + + /** + * Displays a screen where they can enter a new sequence + */ + function doCreateSequence($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['formSequenceName'])) $_POST['formSequenceName'] = ''; + if (!isset($_POST['formIncrement'])) $_POST['formIncrement'] = ''; + if (!isset($_POST['formMinValue'])) $_POST['formMinValue'] = ''; + if (!isset($_POST['formMaxValue'])) $_POST['formMaxValue'] = ''; + if (!isset($_POST['formStartValue'])) $_POST['formStartValue'] = ''; + if (!isset($_POST['formCacheValue'])) $_POST['formCacheValue'] = ''; + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatesequence'],'pg.sequence.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['formSequenceName']), "\" />
{$lang['strincrementby']}
{$lang['strminvalue']}
{$lang['strmaxvalue']}
{$lang['strstartvalue']}
{$lang['strcachevalue']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new sequence in the database + */ + function doSaveCreateSequence() { + global $data; + global $lang; + + // Check that they've given a name and at least one column + if ($_POST['formSequenceName'] == '') doCreateSequence($lang['strsequenceneedsname']); + else { + $status = $data->createSequence($_POST['formSequenceName'], + $_POST['formIncrement'], $_POST['formMinValue'], + $_POST['formMaxValue'], $_POST['formStartValue'], + $_POST['formCacheValue'], isset($_POST['formCycledValue'])); + if ($status == 0) { + doDefault($lang['strsequencecreated']); + } else { + doCreateSequence($lang['strsequencecreatedbad']); + } + } + } + + /** + * Restarts a sequence + */ + function doRestart() { + global $data; + global $lang; + + $status = $data->restartSequence($_REQUEST['sequence']); + if ($status == 0) + doProperties($lang['strsequencerestart']); + else + doProperties($lang['strsequencerestartbad']); + } + + /** + * Resets a sequence + */ + function doReset() { + global $data; + global $lang; + + $status = $data->resetSequence($_REQUEST['sequence']); + if ($status == 0) + doProperties($lang['strsequencereset']); + else + doProperties($lang['strsequenceresetbad']); + } + + /** + * Set Nextval of a sequence + */ + function doNextval() { + global $data; + global $lang; + + $status = $data->nextvalSequence($_REQUEST['sequence']); + if ($status == 0) + doProperties($lang['strsequencenextval']); + else + doProperties($lang['strsequencenextvalbad']); + } + + /** + * Function to save after 'setval'ing a sequence + */ + function doSaveSetval() { + global $data, $lang, $_reload_browser; + + $status = $data->setvalSequence($_POST['sequence'], $_POST['nextvalue']); + if ($status == 0) + doProperties($lang['strsequencesetval']); + else + doProperties($lang['strsequencesetvalbad']); + } + + /** + * Function to allow 'setval'ing of a sequence + */ + function doSetval($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('sequence'); + $misc->printTitle($lang['strsetval'], 'pg.sequence'); + $misc->printMsg($msg); + + // Fetch the sequence information + $sequence = $data->getSequence($_REQUEST['sequence']); + + if (is_object($sequence) && $sequence->recordCount() > 0) { + echo "
\n"; + echo ""; + echo "\n"; + echo "\n"; + echo "
{$lang['strlastvalue']}"; + echo "_maxNameLen}\" value=\"", + $misc->printVal($sequence->fields['last_value']), "\" />
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Function to save after altering a sequence + */ + function doSaveAlter() { + global $data, $lang, $_reload_browser, $misc; + + + if (!isset($_POST['owner'])) $_POST['owner'] = null; + if (!isset($_POST['newschema'])) $_POST['newschema'] = null; + if (!isset($_POST['formIncrement'])) $_POST['formIncrement'] = null; + if (!isset($_POST['formMinValue'])) $_POST['formMinValue'] = null; + if (!isset($_POST['formMaxValue'])) $_POST['formMaxValue'] = null; + if (!isset($_POST['formStartValue'])) $_POST['formStartValue'] = null; + if (!isset($_POST['formRestartValue'])) $_POST['formRestartValue'] = null; + if (!isset($_POST['formCacheValue'])) $_POST['formCacheValue'] = null; + if (!isset($_POST['formCycledValue'])) $_POST['formCycledValue'] = null; + + $status = $data->alterSequence($_POST['sequence'], $_POST['name'], $_POST['comment'], $_POST['owner'], + $_POST['newschema'], $_POST['formIncrement'], $_POST['formMinValue'], $_POST['formMaxValue'], + $_POST['formRestartValue'], $_POST['formCacheValue'], isset($_POST['formCycledValue']), $_POST['formStartValue']); + + if ($status == 0) { + if ($_POST['sequence'] != $_POST['name']) { + // Jump them to the new view name + $_REQUEST['sequence'] = $_POST['name']; + // Force a browser reload + $_reload_browser = true; + } + if (!empty($_POST['newschema']) && ($_POST['newschema'] != $data->_schema)) { + // Jump them to the new sequence schema + $misc->setCurrentSchema($_POST['newschema']); + $_reload_browser = true; + } + doProperties($lang['strsequencealtered']); + } + else + doProperties($lang['strsequencealteredbad']); + } + + /** + * Function to allow altering of a sequence + */ + function doAlter($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('sequence'); + $misc->printTitle($lang['stralter'], 'pg.sequence.alter'); + $misc->printMsg($msg); + + // Fetch the sequence information + $sequence = $data->getSequence($_REQUEST['sequence']); + + if (is_object($sequence) && $sequence->recordCount() > 0) { + if (!isset($_POST['name'])) $_POST['name'] = $_REQUEST['sequence']; + if (!isset($_POST['comment'])) $_POST['comment'] = $sequence->fields['seqcomment']; + if (!isset($_POST['owner'])) $_POST['owner'] = $sequence->fields['seqowner']; + if (!isset($_POST['newschema'])) $_POST['newschema'] = $sequence->fields['nspname']; + + // Handle Checkbox Value + $sequence->fields['is_cycled'] = $data->phpBool($sequence->fields['is_cycled']); + if ($sequence->fields['is_cycled']) $_POST['formCycledValue'] = 'on'; + + echo "
\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + if ($data->isSuperUser()) { + // Fetch all users + $users = $data->getUsers(); + + echo "\n"; + echo "\n"; + } + + if ($data->hasAlterSequenceSchema()) { + $schemas = $data->getSchemas(); + echo "\n"; + echo "\n"; + } + + echo "\n"; + echo "\n"; + + if ($data->hasAlterSequenceStart()) { + echo "\n"; + echo "\n"; + } + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + echo "
{$lang['strname']}"; + echo "_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />
{$lang['strowner']}
{$lang['strschema']}
{$lang['strcomment']}"; + echo "
{$lang['strstartvalue']}fields['start_value']), "\" />
{$lang['strrestartvalue']}fields['last_value']), "\" />
{$lang['strincrementby']}fields['increment_by']), "\" />
{$lang['strmaxvalue']}fields['max_value']), "\" />
{$lang['strminvalue']}fields['min_value']), "\" />
{$lang['strcachevalue']}fields['cache_value']), "\" />
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + if ($action == 'tree') doTree(); + + // Print header + $misc->printHeader($lang['strsequences']); + $misc->printBody(); + + switch($action) { + case 'create': + doCreateSequence(); + break; + case 'save_create_sequence': + if (isset($_POST['create'])) doSaveCreateSequence(); + else doDefault(); + break; + case 'properties': + doProperties(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'restart': + doRestart(); + break; + case 'reset': + doReset(); + break; + case 'nextval': + doNextval(); + break; + case 'setval': + if (isset($_POST['setval'])) doSaveSetval(); + else doDefault(); + break; + case 'confirm_setval': + doSetval(); + break; + case 'alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doDefault(); + break; + case 'confirm_alter': + doAlter(); + break; + default: + doDefault(); + break; + } + + // Print footer + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/servers.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/servers.php new file mode 100644 index 00000000..a33687f6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/servers.php @@ -0,0 +1,175 @@ +do_hook('logout', $_REQUEST['logoutServer']); + + $server_info = $misc->getServerInfo($_REQUEST['logoutServer']); + $misc->setServerInfo(null, null, $_REQUEST['logoutServer']); + + unset($_SESSION['sharedUsername'], $_SESSION['sharedPassword']); + + doDefault(sprintf($lang['strlogoutmsg'], $server_info['desc'])); + + $_reload_browser = true; + } + + function doDefault($msg = '') { + global $conf, $misc; + global $lang; + + $misc->printTabs('root','servers'); + $misc->printMsg($msg); + $group = isset($_GET['group']) ? $_GET['group'] : false; + + $groups = $misc->getServersGroups(true,$group); + + $columns = array( + 'group' => array( + 'title' => $lang['strgroup'], + 'field' => field('desc'), + 'url' => 'servers.php?', + 'vars' => array('group' => 'id'), + ), + ); + $actions = array(); + + if (($group !== false) and (isset($conf['srv_groups'][$group])) and ($groups->recordCount()>0)) { + $misc->printTitle(sprintf($lang['strgroupgroups'],htmlentities($conf['srv_groups'][$group]['desc'], ENT_QUOTES, 'UTF-8'))); + } + + $misc->printTable($groups, $columns, $actions,'servers-servers'); + + $servers = $misc->getServers(true, $group); + + function svPre(&$rowdata, $actions) { + $actions['logout']['disable'] = empty($rowdata->fields['username']); + return $actions; + } + + $columns = array( + 'server' => array( + 'title' => $lang['strserver'], + 'field' => field('desc'), + 'url' => "redirect.php?subject=server&", + 'vars' => array('server' => 'id'), + ), + 'host' => array( + 'title' => $lang['strhost'], + 'field' => field('host'), + ), + 'port' => array( + 'title' => $lang['strport'], + 'field' => field('port'), + ), + 'username' => array( + 'title' => $lang['strusername'], + 'field' => field('username'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $actions = array( + 'logout' => array( + 'content' => $lang['strlogout'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'servers.php', + 'urlvars' => array ( + 'action' => 'logout', + 'logoutServer' => field('id') + ) + ) + ) + ), + ); + + if (($group !== false) and isset($conf['srv_groups'][$group])) { + $misc->printTitle(sprintf($lang['strgroupservers'],htmlentities($conf['srv_groups'][$group]['desc'], ENT_QUOTES, 'UTF-8'))); + $actions['logout']['attr']['href']['urlvars']['group'] = $group; + } + + $misc->printTable($servers, $columns, $actions, 'servers-servers', $lang['strnoobjects'], 'svPre'); + } + + function doTree() { + global $misc, $conf; + + $nodes = array(); + $group_id = isset($_GET['group']) ? $_GET['group'] : false; + + /* root with srv_groups */ + if (isset($conf['srv_groups']) and count($conf['srv_groups']) > 0 + and $group_id === false) + { + $nodes = $misc->getServersGroups(true); + } + /* group subtree */ + else if (isset($conf['srv_groups']) and $group_id !== false) { + if ($group_id !== 'all') + $nodes = $misc->getServersGroups(false, $group_id); + $nodes = array_merge($nodes, $misc->getServers(false, $group_id)); + include_once('./classes/ArrayRecordSet.php'); + $nodes = new ArrayRecordSet($nodes); + } + /* no srv_group */ + else { + $nodes = $misc->getServers(true, false); + } + + $reqvars = $misc->getRequestVars('server'); + + $attrs = array( + 'text' => field('desc'), + + // Show different icons for logged in/out + 'icon' => field('icon'), + + 'toolTip'=> field('id'), + + 'action' => field('action'), + + // Only create a branch url if the user has + // logged into the server. + 'branch' => field('branch'), + ); + + $misc->printTree($nodes, $attrs, 'servers'); + exit; + } + + + if ($action == 'tree') + doTree(); + + $misc->printHeader($lang['strservers']); + $misc->printBody(); + $misc->printTrail('root'); + + switch ($action) { + case 'logout': + doLogout(); + break; + default: + doDefault($msg); + break; + } + + $misc->printFooter(); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sql.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sql.php new file mode 100644 index 00000000..b2ad46de --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sql.php @@ -0,0 +1,263 @@ +getLastError())), "
\n"; + } + else { + // Print query results + switch (pg_result_status($rs)) { + case PGSQL_TUPLES_OK: + // If rows returned, then display the results + $num_fields = pg_numfields($rs); + echo "

\n"; + for ($k = 0; $k < $num_fields; $k++) { + echo ""; + } + + $i = 0; + $row = pg_fetch_row($rs); + while ($row !== false) { + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + foreach ($row as $k => $v) { + echo ""; + } + echo "\n"; + $row = pg_fetch_row($rs); + $i++; + }; + echo "
", $misc->printVal(pg_fieldname($rs, $k)), "
", $misc->printVal($v, pg_fieldtype($rs, $k), array('null' => true)), "

\n"; + echo $i, " {$lang['strrows']}

\n"; + break; + case PGSQL_COMMAND_OK: + // If we have the command completion tag + if (version_compare(phpversion(), '4.3', '>=')) { + echo htmlspecialchars(pg_result_status($rs, PGSQL_STATUS_STRING)), "
\n"; + } + // Otherwise if any rows have been affected + elseif ($data->conn->Affected_Rows() > 0) { + echo $data->conn->Affected_Rows(), " {$lang['strrowsaff']}
\n"; + } + // Otherwise output nothing... + break; + case PGSQL_EMPTY_QUERY: + break; + default: + break; + } + } + } + + // We need to store the query in a session for editing purposes + // We avoid GPC vars to avoid truncating long queries + if (isset($_REQUEST['subject']) && $_REQUEST['subject'] == 'history') { + // Or maybe we came from the history popup + $_SESSION['sqlquery'] = $_SESSION['history'][$_REQUEST['server']][$_REQUEST['database']][$_GET['queryid']]['query']; + } + elseif (isset($_POST['query'])) { + // Or maybe we came from an sql form + $_SESSION['sqlquery'] = $_POST['query']; + } + else { + echo "could not find the query!!"; + } + + // Pagination maybe set by a get link that has it as FALSE, + // if that's the case, unset the variable. + + if (isset($_REQUEST['paginate']) && $_REQUEST['paginate'] == 'f') { + unset($_REQUEST['paginate']); + unset($_POST['paginate']); + unset($_GET['paginate']); + } + // Check to see if pagination has been specified. In that case, send to display + // script for pagination + /* if a file is given or the request is an explain, do not paginate */ + if (isset($_REQUEST['paginate']) && !(isset($_FILES['script']) && $_FILES['script']['size'] > 0) + && (preg_match('/^\s*explain/i', $_SESSION['sqlquery']) == 0)) { + include('./display.php'); + exit; + } + + $subject = isset($_REQUEST['subject'])? $_REQUEST['subject'] : ''; + $misc->printHeader($lang['strqueryresults']); + $misc->printBody(); + $misc->printTrail('database'); + $misc->printTitle($lang['strqueryresults']); + + // Set the schema search path + if (isset($_REQUEST['search_path'])) { + if ($data->setSearchPath(array_map('trim',explode(',',$_REQUEST['search_path']))) != 0) { + $misc->printFooter(); + exit; + } + } + + // May as well try to time the query + if (function_exists('microtime')) { + list($usec, $sec) = explode(' ', microtime()); + $start_time = ((float)$usec + (float)$sec); + } + else $start_time = null; + // Execute the query. If it's a script upload, special handling is necessary + if (isset($_FILES['script']) && $_FILES['script']['size'] > 0) + $data->executeScript('script', 'sqlCallback'); + else { + // Set fetch mode to NUM so that duplicate field names are properly returned + $data->conn->setFetchMode(ADODB_FETCH_NUM); + $rs = $data->conn->Execute($_SESSION['sqlquery']); + + // $rs will only be an object if there is no error + if (is_object($rs)) { + // Request was run, saving it in history + if(!isset($_REQUEST['nohistory'])) + $misc->saveScriptHistory($_SESSION['sqlquery']); + + // Now, depending on what happened do various things + + // First, if rows returned, then display the results + if ($rs->recordCount() > 0) { + echo "\n"; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($k); + echo ""; + } + echo "\n"; + $i = 0; + while (!$rs->EOF) { + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + foreach ($rs->fields as $k => $v) { + $finfo = $rs->fetchField($k); + echo ""; + } + echo "\n"; + $rs->moveNext(); + $i++; + } + echo "
", $misc->printVal($finfo->name), "
", $misc->printVal($v, $finfo->type, array('null' => true)), "
\n"; + echo "

", $rs->recordCount(), " {$lang['strrows']}

\n"; + } + // Otherwise if any rows have been affected + elseif ($data->conn->Affected_Rows() > 0) { + echo "

", $data->conn->Affected_Rows(), " {$lang['strrowsaff']}

\n"; + } + // Otherwise nodata to print + else echo '

', $lang['strnodata'], "

\n"; + } + } + + // May as well try to time the query + if ($start_time !== null) { + list($usec, $sec) = explode(' ', microtime()); + $end_time = ((float)$usec + (float)$sec); + // Get duration in milliseconds, round to 3dp's + $duration = number_format(($end_time - $start_time) * 1000, 3); + } + else $duration = null; + + // Reload the browser as we may have made schema changes + $_reload_browser = true; + + // Display duration if we know it + if ($duration !== null) { + echo "

", sprintf($lang['strruntime'], $duration), "

\n"; + } + + echo "

{$lang['strsqlexecuted']}

\n"; + + $navlinks = array(); + $fields = array( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + ); + + if(isset($_REQUEST['schema'])) + $fields['schema'] = $_REQUEST['schema']; + + // Return + if (isset($_REQUEST['return'])) { + $urlvars = $misc->getSubjectParams($_REQUEST['return']); + $navlinks['back'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => $urlvars['url'], + 'urlvars' => $urlvars['params'] + ) + ), + 'content' => $lang['strback'] + ); + } + + // Edit + $navlinks['alter'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'database.php', + 'urlvars' => array_merge($fields, array ( + 'action' => 'sql', + )) + ) + ), + 'content' => $lang['streditsql'] + ); + + // Create view and download + if (isset($_SESSION['sqlquery']) && isset($rs) && is_object($rs) && $rs->recordCount() > 0) { + // Report views don't set a schema, so we need to disable create view in that case + if (isset($_REQUEST['schema'])) { + $navlinks['createview'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array_merge($fields, array ( + 'action' => 'create' + )) + ) + ), + 'content' => $lang['strcreateview'] + ); + } + + if (isset($_REQUEST['search_path'])) + $fields['search_path'] = $_REQUEST['search_path']; + + $navlinks['download'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'dataexport.php', + 'urlvars' => $fields + ) + ), + 'content' => $lang['strdownload'] + ); + } + + $misc->printNavLinks($navlinks, 'sql-form', get_defined_vars()); + + $misc->printFooter(); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sqledit.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sqledit.php new file mode 100644 index 00000000..124371d2 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/sqledit.php @@ -0,0 +1,156 @@ +printConnection($onchange); + } + + /** + * Searches for a named database object + */ + function doFind() { + global $data, $misc; + global $lang, $conf; + + if (!isset($_REQUEST['term'])) $_REQUEST['term'] = ''; + if (!isset($_REQUEST['filter'])) $_REQUEST['filter'] = ''; + + $misc->printHeader($lang['strfind']); + + // Bring to the front always + echo "\n"; + + $misc->printTabs($misc->getNavTabs('popup'), 'find'); + + echo "
\n"; + _printConnection(); + echo "

_maxNameLen}\" />\n"; + + // Output list of filters. This is complex due to all the 'has' and 'conf' feature possibilities + echo "\n"; + + echo "\n"; + echo "

\n"; + echo "
\n"; + + // Default focus + $misc->setFocus('forms[0].term'); + } + + /** + * Allow execution of arbitrary SQL statements on a database + */ + function doDefault() { + global $data, $misc; + global $lang; + + if (!isset($_SESSION['sqlquery'])) $_SESSION['sqlquery'] = ''; + + $misc->printHeader($lang['strsql']); + + // Bring to the front always + echo "\n"; + + $misc->printTabs($misc->getNavTabs('popup'), 'sql'); + + echo "
\n"; + _printConnection(); + echo "\n"; + if (!isset($_REQUEST['search_path'])) + $_REQUEST['search_path'] = implode(',',$data->getSearchPath()); + + echo "

\n"; + + echo "\n"; + + // Check that file uploads are enabled + if (ini_get('file_uploads')) { + // Don't show upload option if max size of uploads is zero + $max_size = $misc->inisizeToBytes(ini_get('upload_max_filesize')); + if (is_double($max_size) && $max_size > 0) { + echo "

\n"; + echo "

\n"; + } + } + + echo "

\n"; + + echo "

\n"; + echo "

\n"; + echo "
\n"; + + // Default focus + $misc->setFocus('forms[0].query'); + } + + switch ($action) { + case 'find': + doFind(); + break; + case 'sql': + default: + doDefault(); + break; + } + + // Set the name of the window + $misc->setWindowName('sqledit'); + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tables.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tables.js new file mode 100644 index 00000000..a805a8b4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tables.js @@ -0,0 +1,18 @@ +var predefined_lengths = null; +var sizesLength = false; + +function checkLengths(sValue,idx) { + if(predefined_lengths) { + if(sizesLength==false) { + sizesLength = predefined_lengths.length; + } + for(var i=0;igetDefaultWithOid(); + if ($default_with_oids == 'off') $_REQUEST['withoutoids'] = 'on'; + } + + if (!isset($_REQUEST['name'])) $_REQUEST['name'] = ''; + if (!isset($_REQUEST['fields'])) $_REQUEST['fields'] = ''; + if (!isset($_REQUEST['tblcomment'])) $_REQUEST['tblcomment'] = ''; + if (!isset($_REQUEST['spcname'])) $_REQUEST['spcname'] = ''; + + switch ($_REQUEST['stage']) { + case 1: + // Fetch all tablespaces from the database + if ($data->hasTablespaces()) $tablespaces = $data->getTablespaces(); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatetable'], 'pg.table.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + // Tablespace (if there are any) + if ($data->hasTablespaces() && $tablespaces->recordCount() > 0) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['name']), "\" />
{$lang['strnumcols']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['fields']), "\" />
{$lang['stroptions']}
{$lang['strtablespace']}\n\t\t\t\n\t\t
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + break; + case 2: + global $lang; + + // Check inputs + $fields = trim($_REQUEST['fields']); + if (trim($_REQUEST['name']) == '') { + $_REQUEST['stage'] = 1; + doCreate($lang['strtableneedsname']); + return; + } + elseif ($fields == '' || !is_numeric($fields) || $fields != (int)$fields || $fields < 1) { + $_REQUEST['stage'] = 1; + doCreate($lang['strtableneedscols']); + return; + } + + $types = $data->getTypes(true, false, true); + $types_for_js = array(); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatetable'], 'pg.table.create'); + $misc->printMsg($msg); + + echo ""; + echo "
\n"; + + // Output table header + echo "\n"; + echo "\t"; + echo ""; + echo ""; + echo "\n"; + + for ($i = 0; $i < $_REQUEST['fields']; $i++) { + if (!isset($_REQUEST['field'][$i])) $_REQUEST['field'][$i] = ''; + if (!isset($_REQUEST['length'][$i])) $_REQUEST['length'][$i] = ''; + if (!isset($_REQUEST['default'][$i])) $_REQUEST['default'][$i] = ''; + if (!isset($_REQUEST['colcomment'][$i])) $_REQUEST['colcomment'][$i] = ''; + + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\t"; + } + + // Output array type selector + echo "\t\t\n"; + + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n\t\n"; + } + echo "
{$lang['strcolumn']}{$lang['strtype']}{$lang['strlength']}{$lang['strnotnull']}{$lang['struniquekey']}{$lang['strprimarykey']}{$lang['strdefault']}{$lang['strcomment']}
", $i + 1, ". _maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['field'][$i]), "\" />\n\t\t\t\n\t\t\n"; + if($i==0) { // only define js types array once + $predefined_size_types = array_intersect($data->predefined_size_types,array_keys($types_for_js)); + $escaped_predef_types = array(); // the JS escaped array elements + foreach($predefined_size_types as $value) { + $escaped_predef_types[] = "'{$value}'"; + } + echo "\n\t\n\t\t\t\n\t\t + +
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + if (isset($_REQUEST['withoutoids'])) { + echo "\n"; + } + echo "\n"; + if (isset($_REQUEST['spcname'])) { + echo "\n"; + } + echo "\n"; + echo "

\n"; + echo "
\n"; + + break; + case 3: + global $data, $lang, $_reload_browser; + + if (!isset($_REQUEST['notnull'])) $_REQUEST['notnull'] = array(); + if (!isset($_REQUEST['uniquekey'])) $_REQUEST['uniquekey'] = array(); + if (!isset($_REQUEST['primarykey'])) $_REQUEST['primarykey'] = array(); + if (!isset($_REQUEST['length'])) $_REQUEST['length'] = array(); + // Default tablespace to null if it isn't set + if (!isset($_REQUEST['spcname'])) $_REQUEST['spcname'] = null; + + // Check inputs + $fields = trim($_REQUEST['fields']); + if (trim($_REQUEST['name']) == '') { + $_REQUEST['stage'] = 1; + doCreate($lang['strtableneedsname']); + return; + } + elseif ($fields == '' || !is_numeric($fields) || $fields != (int)$fields || $fields <= 0) { + $_REQUEST['stage'] = 1; + doCreate($lang['strtableneedscols']); + return; + } + + $status = $data->createTable($_REQUEST['name'], $_REQUEST['fields'], $_REQUEST['field'], + $_REQUEST['type'], $_REQUEST['array'], $_REQUEST['length'], $_REQUEST['notnull'], $_REQUEST['default'], + isset($_REQUEST['withoutoids']), $_REQUEST['colcomment'], $_REQUEST['tblcomment'], $_REQUEST['spcname'], + $_REQUEST['uniquekey'], $_REQUEST['primarykey']); + + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strtablecreated']); + } + elseif ($status == -1) { + $_REQUEST['stage'] = 2; + doCreate($lang['strtableneedsfield']); + return; + } + else { + $_REQUEST['stage'] = 2; + doCreate($lang['strtablecreatedbad']); + return; + } + break; + default: + echo "

{$lang['strinvalidparam']}

\n"; + } + } + + /** + * Dsiplay a screen where user can create a table from an existing one. + * We don't have to check if pg supports schema cause create table like + * is available under pg 7.4+ which has schema. + */ + function doCreateLike($confirm, $msg = '') { + global $data, $misc, $lang; + + if (!$confirm) { + + include_once('./classes/Gui.php'); + + if (!isset($_REQUEST['name'])) $_REQUEST['name'] = ''; + if (!isset($_REQUEST['like'])) $_REQUEST['like'] = ''; + if (!isset($_REQUEST['tablespace'])) $_REQUEST['tablespace'] = ''; + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatetable'], 'pg.table.create'); + $misc->printMsg($msg); + + $tbltmp = $data->getTables(true); + $tbltmp = $tbltmp->getArray(); + + $tables = array(); + $tblsel = ''; + foreach ($tbltmp as $a) { + $data->fieldClean($a['nspname']); + $data->fieldClean($a['relname']); + $tables["\"{$a['nspname']}\".\"{$a['relname']}\""] = serialize(array('schema' => $a['nspname'], 'table' => $a['relname'])); + if ($_REQUEST['like'] == $tables["\"{$a['nspname']}\".\"{$a['relname']}\""]) + $tblsel = htmlspecialchars($tables["\"{$a['nspname']}\".\"{$a['relname']}\""]); + } + + unset($tbltmp); + + echo "
\n"; + echo "\n\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + if ($data->hasTablespaces()) { + $tblsp_ = $data->getTablespaces(); + if ($tblsp_->recordCount() > 0) { + $tblsp_ = $tblsp_->getArray(); + $tblsp = array(); + foreach($tblsp_ as $a) $tblsp[$a['spcname']] = $a['spcname']; + + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + } + echo "\t\n\t\t\n\t\t\n\t\n"; + echo "
{$lang['strname']}_maxNameLen}\" value=\"", htmlspecialchars($_REQUEST['name']), "\" />
{$lang['strcreatetablelikeparent']}"; + echo GUI::printCombo($tables, 'like', true, $tblsel, false); + echo "
{$lang['strtablespace']}"; + echo GUI::printCombo($tblsp, 'tablespace', true, $_REQUEST['tablespace'], false); + echo "
{$lang['stroptions']}"; + echo ""; + if ($data->hasCreateTableLikeWithConstraints()) { + echo "
"; + } + if ($data->hasCreateTableLikeWithIndexes()) { + echo "
"; + } + echo "
"; + + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "

\n"; + echo "
\n"; + } + else { + global $_reload_browser; + + if (trim($_REQUEST['name']) == '') { + doCreateLike(false, $lang['strtableneedsname']); + return; + } + if (trim($_REQUEST['like']) == '') { + doCreateLike(false, $lang['strtablelikeneedslike']); + return; + } + + if (!isset($_REQUEST['tablespace'])) $_REQUEST['tablespace'] = ''; + + $status = $data->createTableLike($_REQUEST['name'], unserialize($_REQUEST['like']), isset($_REQUEST['withdefaults']), + isset($_REQUEST['withconstraints']), isset($_REQUEST['withindexes']), $_REQUEST['tablespace']); + + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strtablecreated']); + } + else { + doCreateLike(false, $lang['strtablecreatedbad']); + return; + } + } + } + + /** + * Ask for select parameters and perform select + */ + function doSelectRows($confirm, $msg = '') { + global $data, $misc, $_no_output; + global $lang; + + if ($confirm) { + $misc->printTrail('table'); + $misc->printTabs('table','select'); + $misc->printMsg($msg); + + $attrs = $data->getTableAttributes($_REQUEST['table']); + + echo "
\n"; + if ($attrs->recordCount() > 0) { + // JavaScript for select all feature + echo "\n"; + + echo "\n"; + + // Output table header + echo ""; + echo ""; + echo ""; + + $i = 0; + while (!$attrs->EOF) { + $attrs->fields['attnotnull'] = $data->phpBool($attrs->fields['attnotnull']); + // Set up default value if there isn't one already + if (!isset($_REQUEST['values'][$attrs->fields['attname']])) + $_REQUEST['values'][$attrs->fields['attname']] = null; + if (!isset($_REQUEST['ops'][$attrs->fields['attname']])) + $_REQUEST['ops'][$attrs->fields['attname']] = null; + // Continue drawing row + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + echo ""; + echo ""; + echo ""; + echo "\n"; + echo ""; + echo "\n"; + $i++; + $attrs->moveNext(); + } + // Select all checkbox + echo ""; + echo "
{$lang['strshow']}{$lang['strcolumn']}{$lang['strtype']}{$lang['stroperator']}{$lang['strvalue']}
"; + echo "fields['attname']), "]\"", + isset($_REQUEST['show'][$attrs->fields['attname']]) ? ' checked="checked"' : '', " />", $misc->printVal($attrs->fields['attname']), "", $misc->printVal($data->formatType($attrs->fields['type'], $attrs->fields['atttypmod'])), ""; + echo "\n", $data->printField("values[{$attrs->fields['attname']}]", + $_REQUEST['values'][$attrs->fields['attname']], $attrs->fields['type']), "
\n"; + } + else echo "

{$lang['strinvalidparam']}

\n"; + + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + if (!isset($_POST['show'])) $_POST['show'] = array(); + if (!isset($_POST['values'])) $_POST['values'] = array(); + if (!isset($_POST['nulls'])) $_POST['nulls'] = array(); + + // Verify that they haven't supplied a value for unary operators + foreach ($_POST['ops'] as $k => $v) { + if ($data->selectOps[$v] == 'p' && $_POST['values'][$k] != '') { + doSelectRows(true, $lang['strselectunary']); + return; + } + } + + if (sizeof($_POST['show']) == 0) + doSelectRows(true, $lang['strselectneedscol']); + else { + // Generate query SQL + $query = $data->getSelectSQL($_REQUEST['table'], array_keys($_POST['show']), + $_POST['values'], $_POST['ops']); + $_REQUEST['query'] = $query; + $_REQUEST['return'] = 'selectrows'; + + $_no_output = true; + include('./display.php'); + exit; + } + } + } + + /** + * Ask for insert parameters and then actually insert row + */ + function doInsertRow($confirm, $msg = '') { + global $data, $misc, $conf; + global $lang; + + if ($confirm) { + $misc->printTrail('table'); + $misc->printTabs('table','insert'); + + $misc->printMsg($msg); + + $attrs = $data->getTableAttributes($_REQUEST['table']); + + if (($conf['autocomplete'] != 'disable')) { + $fksprops = $misc->getAutocompleteFKProperties($_REQUEST['table']); + if ($fksprops !== false) + echo $fksprops['code']; + } + else $fksprops = false; + + echo "
\n"; + if ($attrs->recordCount() > 0) { + echo "\n"; + + // Output table header + echo ""; + echo ""; + echo ""; + + $i = 0; + $fields = array(); + while (!$attrs->EOF) { + $fields[$attrs->fields['attnum']] = $attrs->fields['attname']; + $attrs->fields['attnotnull'] = $data->phpBool($attrs->fields['attnotnull']); + // Set up default value if there isn't one already + if (!isset($_REQUEST['values'][$attrs->fields['attnum']])) + $_REQUEST['values'][$attrs->fields['attnum']] = $attrs->fields['adsrc']; + // Default format to 'VALUE' if there is no default, + // otherwise default to 'EXPRESSION' + if (!isset($_REQUEST['format'][$attrs->fields['attnum']])) + $_REQUEST['format'][$attrs->fields['attnum']] = ($attrs->fields['adsrc'] === null) ? 'VALUE' : 'EXPRESSION'; + // Continue drawing row + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + echo ""; + echo ""; + echo "\n"; + echo ""; + } + else { + echo " "; + } + echo "\n"; + echo "\n"; + $i++; + $attrs->moveNext(); + } + echo "
{$lang['strcolumn']}{$lang['strtype']}{$lang['strformat']}{$lang['strnull']}{$lang['strvalue']}
", $misc->printVal($attrs->fields['attname']), "\n"; + echo $misc->printVal($data->formatType($attrs->fields['type'], $attrs->fields['atttypmod'])); + echo "fields['attnum']}]\" value=\"", + htmlspecialchars($attrs->fields['type']), "\" />\n"; + echo "\n"; + // Output null box if the column allows nulls (doesn't look at CHECKs or ASSERTIONS) + if (!$attrs->fields['attnotnull']) { + echo "fields['attnum']}\" style=\"white-space:nowrap;\">"; + if (($fksprops !== false) && isset($fksprops['byfield'][$attrs->fields['attnum']])) { + echo $data->printField("values[{$attrs->fields['attnum']}]", $_REQUEST['values'][$attrs->fields['attnum']], 'fktype'/*force FK*/, + array( + 'id' => "attr_{$attrs->fields['attnum']}", + 'autocomplete' => 'off' + ) + ); + } + else { + echo $data->printField("values[{$attrs->fields['attnum']}]", $_REQUEST['values'][$attrs->fields['attnum']], $attrs->fields['type']); + } + echo "
\n"; + + if (!isset($_SESSION['counter'])) { $_SESSION['counter'] = 0; } + + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + + if($fksprops !== false) { + if ($conf['autocomplete'] != 'default off') + echo "\n"; + else + echo "\n"; + } + echo "

\n"; + } + else { + echo "

{$lang['strnofieldsforinsert']}

\n"; + echo "\n"; + } + echo $misc->form; + echo "
\n"; + } + else { + if (!isset($_POST['values'])) $_POST['values'] = array(); + if (!isset($_POST['nulls'])) $_POST['nulls'] = array(); + $_POST['fields'] = unserialize(htmlspecialchars_decode($_POST['fields'], ENT_QUOTES)); + + if ($_SESSION['counter']++ == $_POST['protection_counter']) { + $status = $data->insertRow($_POST['table'], $_POST['fields'], $_POST['values'], + $_POST['nulls'], $_POST['format'], $_POST['types']); + if ($status == 0) { + if (isset($_POST['insert'])) + doDefault($lang['strrowinserted']); + else { + $_REQUEST['values'] = array(); + $_REQUEST['nulls'] = array(); + doInsertRow(true, $lang['strrowinserted']); + } + } + else + doInsertRow(true, $lang['strrowinsertedbad']); + } else + doInsertRow(true, $lang['strrowduplicate']); + } + + } + + /** + * Show confirmation of empty and perform actual empty + */ + function doEmpty($confirm) { + global $data, $misc; + global $lang; + + if (empty($_REQUEST['table']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifytabletoempty']); + exit(); + } + + if ($confirm) { + if (isset($_REQUEST['ma'])) { + $misc->printTrail('schema'); + $misc->printTitle($lang['strempty'],'pg.table.empty'); + + echo "
\n"; + foreach ($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfemptytable'], $misc->printVal($a['table'])), "

\n"; + printf('', htmlspecialchars($a['table'])); + } + } // END mutli empty + else { + $misc->printTrail('table'); + $misc->printTitle($lang['strempty'],'pg.table.empty'); + + echo "

", sprintf($lang['strconfemptytable'], $misc->printVal($_REQUEST['table'])), "

\n"; + + echo "\n"; + echo "\n"; + } // END not mutli empty + + echo "\n"; + echo $misc->form; + echo " \n"; + echo "
\n"; + } // END if confirm + else { // Do Empty + if (is_array($_REQUEST['table'])) { + $msg=''; + foreach($_REQUEST['table'] as $t) { + $status = $data->emptyTable($t); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($t, ENT_QUOTES, 'UTF-8'), $lang['strtableemptied']); + else { + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($t, ENT_QUOTES, 'UTF-8'), $lang['strtableemptiedbad'])); + return; + } + } + doDefault($msg); + } // END mutli empty + else { + $status = $data->emptyTable($_POST['table']); + if ($status == 0) + doDefault($lang['strtableemptied']); + else + doDefault($lang['strtableemptiedbad']); + } // END not mutli empty + } // END do Empty + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang, $_reload_browser; + + if (empty($_REQUEST['table']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifytabletodrop']); + exit(); + } + + if ($confirm) { + //If multi drop + if (isset($_REQUEST['ma'])) { + + $misc->printTrail('schema'); + $misc->printTitle($lang['strdrop'], 'pg.table.drop'); + + echo "
\n"; + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfdroptable'], $misc->printVal($a['table'])), "

\n"; + printf('', htmlspecialchars($a['table'])); + } + } else { + + $misc->printTrail('table'); + $misc->printTitle($lang['strdrop'], 'pg.table.drop'); + + echo "

", sprintf($lang['strconfdroptable'], $misc->printVal($_REQUEST['table'])), "

\n"; + + echo "\n"; + echo "\n"; + }// END if multi drop + + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } // END confirm + else { + //If multi drop + if (is_array($_REQUEST['table'])) { + $msg = ''; + $status = $data->beginTransaction(); + if ($status == 0) { + foreach($_REQUEST['table'] as $t) { + $status = $data->dropTable($t, isset($_POST['cascade'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($t, ENT_QUOTES, 'UTF-8'), $lang['strtabledropped']); + else { + $data->endTransaction(); + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($t, ENT_QUOTES, 'UTF-8'), $lang['strtabledroppedbad'])); + return; + } + } + } + if($data->endTransaction() == 0) { + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else doDefault($lang['strtabledroppedbad']); + } else { + $status = $data->dropTable($_POST['table'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strtabledropped']); + } + else + doDefault($lang['strtabledroppedbad']); + } + } // END DROP + }// END Function + + /** + * Show default list of tables in the database + */ + function doDefault($msg = '') { + global $data, $conf, $misc, $data; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','tables'); + $misc->printMsg($msg); + + $tables = $data->getTables(); + + $columns = array( + 'table' => array( + 'title' => $lang['strtable'], + 'field' => field('relname'), + 'url' => "redirect.php?subject=table&{$misc->href}&", + 'vars' => array('table' => 'relname'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('relowner'), + ), + 'tablespace' => array( + 'title' => $lang['strtablespace'], + 'field' => field('tablespace') + ), + 'tuples' => array( + 'title' => $lang['strestimatedrowcount'], + 'field' => field('reltuples'), + 'type' => 'numeric' + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('relcomment'), + ), + ); + + $actions = array( + 'multiactions' => array( + 'keycols' => array('table' => 'relname'), + 'url' => 'tables.php', + 'default' => 'analyze', + ), + 'browse' => array( + 'content' => $lang['strbrowse'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'subject' => 'table', + 'return' => 'table', + 'table' => field('relname') + ) + ) + ) + ), + 'select' => array( + 'content' => $lang['strselect'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confselectrows', + 'table' => field('relname') + ) + ) + ) + ), + 'insert' => array( + 'content' => $lang['strinsert'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confinsertrow', + 'table' => field('relname') + ) + ) + ) + ), + 'empty' => array( + 'multiaction' => 'confirm_empty', + 'content' => $lang['strempty'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_empty', + 'table' => field('relname') + ) + ) + ) + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'table' => field('relname') + ) + ) + ) + ), + 'drop' => array( + 'multiaction' => 'confirm_drop', + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'table' => field('relname') + ) + ) + ) + ), + 'vacuum' => array( + 'multiaction' => 'confirm_vacuum', + 'content' => $lang['strvacuum'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_vacuum', + 'table' => field('relname') + ) + ) + ) + ), + 'analyze' => array( + 'multiaction' => 'confirm_analyze', + 'content' => $lang['stranalyze'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_analyze', + 'table' => field('relname') + ) + ) + ) + ), + 'reindex' => array( + 'multiaction' => 'confirm_reindex', + 'content' => $lang['strreindex'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_reindex', + 'table' => field('relname') + ) + ) + ) + ) + //'cluster' TODO ? + ); + + if (!$data->hasTablespaces()) unset($columns['tablespace']); + + $misc->printTable($tables, $columns, $actions, 'tables-tables', $lang['strnotables']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreatetable'] + ) + ); + + if (($tables->recordCount() > 0) && $data->hasCreateTableLike()) { + $navlinks['createlike'] = array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'createlike', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreatetablelike'] + ); + } + $misc->printNavLinks($navlinks, 'tables-tables', get_defined_vars()); + } + + require('./admin.php'); + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $tables = $data->getTables(); + + $reqvars = $misc->getRequestVars('table'); + + $attrs = array( + 'text' => field('relname'), + 'icon' => 'Table', + 'iconAction' => url('display.php', + $reqvars, + array('table' => field('relname')) + ), + 'toolTip'=> field('relcomment'), + 'action' => url('redirect.php', + $reqvars, + array('table' => field('relname')) + ), + 'branch' => url('tables.php', + $reqvars, + array ( + 'action' => 'subtree', + 'table' => field('relname') + ) + ) + ); + + $misc->printTree($tables, $attrs, 'tables'); + exit; + } + + function doSubTree() { + global $misc, $data; + + $tabs = $misc->getNavTabs('table'); + $items = $misc->adjustTabsForTree($tabs); + $reqvars = $misc->getRequestVars('table'); + + $attrs = array( + 'text' => field('title'), + 'icon' => field('icon'), + 'action' => url( + field('url'), + $reqvars, + field('urlvars'), + array('table' => $_REQUEST['table']) + ), + 'branch' => ifempty( + field('branch'), '', url( + field('url'), + $reqvars, + array( + 'action' => 'tree', + 'table' => $_REQUEST['table'] + ) + ) + ), + ); + + $misc->printTree($items, $attrs, 'table'); + exit; + } + + if ($action == 'tree') doTree(); + if ($action == 'subtree') dosubTree(); + + $misc->printHeader($lang['strtables']); + $misc->printBody(); + + switch ($action) { + case 'create': + if (isset($_POST['cancel'])) doDefault(); + else doCreate(); + break; + case 'createlike': + doCreateLike(false); + break; + case 'confcreatelike': + if (isset($_POST['cancel'])) doDefault(); + else doCreateLike(true); + break; + case 'selectrows': + if (!isset($_POST['cancel'])) doSelectRows(false); + else doDefault(); + break; + case 'confselectrows': + doSelectRows(true); + break; + case 'insertrow': + if (!isset($_POST['cancel'])) doInsertRow(false); + else doDefault(); + break; + case 'confinsertrow': + doInsertRow(true); + break; + case 'empty': + if (isset($_POST['empty'])) doEmpty(false); + else doDefault(); + break; + case 'confirm_empty': + doEmpty(true); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + if (adminActions($action, 'table') === false) doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tablespaces.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tablespaces.php new file mode 100644 index 00000000..3c6f8beb --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tablespaces.php @@ -0,0 +1,326 @@ +printTrail('tablespace'); + $misc->printTitle($lang['stralter'],'pg.tablespace.alter'); + $misc->printMsg($msg); + + // Fetch tablespace info + $tablespace = $data->getTablespace($_REQUEST['tablespace']); + // Fetch all users + $users = $data->getUsers(); + + if ($tablespace->recordCount() > 0) { + + if (!isset($_POST['name'])) $_POST['name'] = $tablespace->fields['spcname']; + if (!isset($_POST['owner'])) $_POST['owner'] = $tablespace->fields['spcowner']; + if (!isset($_POST['comment'])) { + $_POST['comment'] = ($data->hasSharedComments()) ? $tablespace->fields['spccomment'] : ''; + } + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + if ($data->hasSharedComments()){ + echo "\n"; + echo "\n"; + } + echo "
{$lang['strname']}"; + echo "_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />
{$lang['strowner']}
{$lang['strcomment']}"; + echo "
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Function to save after altering a tablespace + */ + function doSaveAlter() { + global $data, $lang; + + // Check data + if (trim($_POST['name']) == '') + doAlter($lang['strtablespaceneedsname']); + else { + $status = $data->alterTablespace($_POST['tablespace'], $_POST['name'], $_POST['owner'], $_POST['comment']); + if ($status == 0) { + // If tablespace has been renamed, need to change to the new name + if ($_POST['tablespace'] != $_POST['name']) { + // Jump them to the new table name + $_REQUEST['tablespace'] = $_POST['name']; + } + doDefault($lang['strtablespacealtered']); + } + else + doAlter($lang['strtablespacealteredbad']); + } + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('tablespace'); + $misc->printTitle($lang['strdrop'],'pg.tablespace.drop'); + + echo "

", sprintf($lang['strconfdroptablespace'], $misc->printVal($_REQUEST['tablespace'])), "

\n"; + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->droptablespace($_REQUEST['tablespace']); + if ($status == 0) + doDefault($lang['strtablespacedropped']); + else + doDefault($lang['strtablespacedroppedbad']); + } + } + + /** + * Displays a screen where they can enter a new tablespace + */ + function doCreate($msg = '') { + global $data, $misc, $spcname; + global $lang; + + $server_info = $misc->getServerInfo(); + + if (!isset($_POST['formSpcname'])) $_POST['formSpcname'] = ''; + if (!isset($_POST['formOwner'])) $_POST['formOwner'] = $server_info['username']; + if (!isset($_POST['formLoc'])) $_POST['formLoc'] = ''; + if (!isset($_POST['formComment'])) $_POST['formComment'] = ''; + + // Fetch all users + $users = $data->getUsers(); + + $misc->printTrail('server'); + $misc->printTitle($lang['strcreatetablespace'],'pg.tablespace.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo $misc->form; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + // Comments (if available) + if ($data->hasSharedComments()) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + echo "
{$lang['strname']}_maxNameLen}\" value=\"", htmlspecialchars($_POST['formSpcname']), "\" />
{$lang['strowner']}
{$lang['strlocation']}
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new tablespace in the cluster + */ + function doSaveCreate() { + global $data; + global $lang; + + // Check data + if (trim($_POST['formSpcname']) == '') + doCreate($lang['strtablespaceneedsname']); + elseif (trim($_POST['formLoc']) == '') + doCreate($lang['strtablespaceneedsloc']); + else { + // Default comment to blank if it isn't set + if (!isset($_POST['formComment'])) $_POST['formComment'] = null; + + $status = $data->createTablespace($_POST['formSpcname'], $_POST['formOwner'], $_POST['formLoc'], $_POST['formComment']); + if ($status == 0) + doDefault($lang['strtablespacecreated']); + else + doCreate($lang['strtablespacecreatedbad']); + } + } + + /** + * Show default list of tablespaces in the cluster + */ + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('server'); + $misc->printTabs('server','tablespaces'); + $misc->printMsg($msg); + + $tablespaces = $data->getTablespaces(); + + $columns = array( + 'database' => array( + 'title' => $lang['strname'], + 'field' => field('spcname') + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('spcowner') + ), + 'location' => array( + 'title' => $lang['strlocation'], + 'field' => field('spclocation') + ), + 'actions' => array( + 'title' => $lang['stractions'] + ) + ); + + if ($data->hasSharedComments()) { + $columns['comment'] = array( + 'title' => $lang['strcomment'], + 'field' => field('spccomment'), + ); + } + + + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tablespaces.php', + 'urlvars' => array ( + 'action' => 'edit', + 'tablespace' => field('spcname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tablespaces.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'tablespace' => field('spcname') + ) + ) + ) + ), + 'privileges' => array( + 'content' => $lang['strprivileges'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array ( + 'subject' => 'tablespace', + 'tablespace' => field('spcname') + ) + ) + ) + ) + ); + + $misc->printTable($tablespaces, $columns, $actions, 'tablespaces-tablespaces', $lang['strnotablespaces']); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tablespaces.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strcreatetablespace'] + )), 'tablespaces-tablespaces', get_defined_vars()); + } + + $misc->printHeader($lang['strtablespaces']); + $misc->printBody(); + + switch ($action) { + case 'save_create': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_REQUEST['cancel'])) doDefault(); + else doDrop(false); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'save_edit': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveAlter(); + break; + case 'edit': + doAlter(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tblproperties.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tblproperties.php new file mode 100644 index 00000000..f73ce8b6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/tblproperties.php @@ -0,0 +1,782 @@ +alterTable($_POST['table'], $_POST['name'], $_POST['owner'], $_POST['newschema'], $_POST['comment'], $_POST['tablespace']); + if ($status == 0) { + // If table has been renamed, need to change to the new name and + // reload the browser frame. + if ($_POST['table'] != $_POST['name']) { + // Jump them to the new table name + $_REQUEST['table'] = $_POST['name']; + // Force a browser reload + $_reload_browser = true; + } + // If schema has changed, need to change to the new schema and reload the browser + if (!empty($_POST['newschema']) && ($_POST['newschema'] != $data->_schema)) { + // Jump them to the new sequence schema + $misc->setCurrentSchema($_POST['newschema']); + $_reload_browser = true; + } + doDefault($lang['strtablealtered']); + } + else + doAlter($lang['strtablealteredbad']); + } + + /** + * Function to allow altering of a table + */ + function doAlter($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('table'); + $misc->printTitle($lang['stralter'], 'pg.table.alter'); + $misc->printMsg($msg); + + // Fetch table info + $table = $data->getTable($_REQUEST['table']); + // Fetch all users + $users = $data->getUsers(); + // Fetch all tablespaces from the database + if ($data->hasTablespaces()) $tablespaces = $data->getTablespaces(true); + + if ($table->recordCount() > 0) { + + if (!isset($_POST['name'])) $_POST['name'] = $table->fields['relname']; + if (!isset($_POST['owner'])) $_POST['owner'] = $table->fields['relowner']; + if (!isset($_POST['newschema'])) $_POST['newschema'] = $table->fields['nspname']; + if (!isset($_POST['comment'])) $_POST['comment'] = $table->fields['relcomment']; + if ($data->hasTablespaces() && !isset($_POST['tablespace'])) $_POST['tablespace'] = $table->fields['tablespace']; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + if ($data->isSuperUser()) { + echo "\n"; + echo "\n"; + } + + if ($data->hasAlterTableSchema()) { + $schemas = $data->getSchemas(); + echo "\n"; + echo "\n"; + } + + // Tablespace (if there are any) + if ($data->hasTablespaces() && $tablespaces->recordCount() > 0) { + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}"; + echo "_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name'], ENT_QUOTES), "\" />
{$lang['strowner']}
{$lang['strschema']}
{$lang['strtablespace']}\n\t\t\t\n\t\t
{$lang['strcomment']}"; + echo "
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + function doExport($msg = '') { + global $data, $misc; + global $lang; + + // Determine whether or not the table has an object ID + $hasID = $data->hasObjectID($_REQUEST['table']); + + $misc->printTrail('table'); + $misc->printTabs('table','export'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + // Data only + echo "\n"; + echo "\n"; + echo "\n\n"; + if ($hasID) { + echo "\n\n"; + } + // Structure only + echo "\n"; + echo "\n\n"; + // Structure and data + echo "\n"; + echo "\n"; + echo "\n\n"; + echo "\n\n"; + if ($hasID) { + echo "\n\n"; + } + echo "
{$lang['strformat']}{$lang['stroptions']}
"; + echo "{$lang['strformat']}\n
"; + echo "{$lang['strformat']}\n
\n"; + + echo "

{$lang['stroptions']}

\n"; + echo "

\n"; + echo "

\n"; + + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + function doImport($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('table'); + $misc->printTabs('table','import'); + $misc->printMsg($msg); + + // Check that file uploads are enabled + if (ini_get('file_uploads')) { + // Don't show upload option if max size of uploads is zero + $max_size = $misc->inisizeToBytes(ini_get('upload_max_filesize')); + if (is_double($max_size) && $max_size > 0) { + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strformat']}
{$lang['strallowednulls']}
\n"; + echo "\t\t
\n"; + echo "\t\t
{$lang['strfile']}"; + echo "
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + } + else echo "

{$lang['strnouploads']}

\n"; + } + + /** + * Displays a screen where they can add a column + */ + function doAddColumn($msg = '') { + global $data, $misc, $_reload_browser; + global $lang; + + if (!isset($_REQUEST['stage'])) $_REQUEST['stage'] = 1; + + switch ($_REQUEST['stage']) { + case 1: + // Set variable defaults + if (!isset($_POST['field'])) $_POST['field'] = ''; + if (!isset($_POST['type'])) $_POST['type'] = ''; + if (!isset($_POST['array'])) $_POST['array'] = ''; + if (!isset($_POST['length'])) $_POST['length'] = ''; + if (!isset($_POST['default'])) $_POST['default'] = ''; + if (!isset($_POST['comment'])) $_POST['comment'] = ''; + + // Fetch all available types + $types = $data->getTypes(true, false, true); + $types_for_js = array(); + + $misc->printTrail('table'); + $misc->printTitle($lang['straddcolumn'], 'pg.column.add'); + $misc->printMsg($msg); + + echo ""; + echo "
\n"; + + // Output table header + echo "\n"; + echo "\n\n"; + echo "\n"; + if ($data->hasCreateFieldWithConstraints()) + echo "\n\n"; + echo "\n"; + + echo "\n"; + echo "\n"; + + // Output array type selector + echo "\n"; + $predefined_size_types = array_intersect($data->predefined_size_types, $types_for_js); + $escaped_predef_types = array(); // the JS escaped array elements + foreach($predefined_size_types as $value) { + $escaped_predef_types[] = "'{$value}'"; + } + + echo "\n"; + // Support for adding column with not null and default + if ($data->hasCreateFieldWithConstraints()) { + echo "\n"; + echo "\n"; + } + echo "\n"; + echo "
{$lang['strname']}{$lang['strtype']}{$lang['strlength']}{$lang['strnotnull']}{$lang['strdefault']}{$lang['strcomment']}
_maxNameLen}\" value=\"", + htmlspecialchars($_POST['field']), "\" />
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + if (!$data->hasCreateFieldWithConstraints()) { + echo "\n"; + } + echo "\n"; + echo "

\n"; + echo "
\n"; + echo "\n"; + break; + case 2: + // Check inputs + if (trim($_POST['field']) == '') { + $_REQUEST['stage'] = 1; + doAddColumn($lang['strcolneedsname']); + return; + } + if (!isset($_POST['length'])) $_POST['length'] = ''; + $status = $data->addColumn($_POST['table'], $_POST['field'], + $_POST['type'], $_POST['array'] != '', $_POST['length'], isset($_POST['notnull']), + $_POST['default'], $_POST['comment']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strcolumnadded']); + } + else { + $_REQUEST['stage'] = 1; + doAddColumn($lang['strcolumnaddedbad']); + return; + } + break; + default: + echo "

{$lang['strinvalidparam']}

\n"; + } + } + + /** + * Show confirmation of drop column and perform actual drop + */ + function doDrop($confirm) { + global $data, $database, $misc, $_reload_browser; + global $lang; + + if ($confirm) { + $misc->printTrail('column'); + $misc->printTitle($lang['strdrop'], 'pg.column.drop'); + + echo "

", sprintf($lang['strconfdropcolumn'], $misc->printVal($_REQUEST['column']), + $misc->printVal($_REQUEST['table'])), "

\n"; + + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropColumn($_POST['table'], $_POST['column'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strcolumndropped']); + } + else + doDefault($lang['strcolumndroppedbad']); + } + + } + + function doTree() { + global $misc, $data; + + $columns = $data->getTableAttributes($_REQUEST['table']); + $reqvars = $misc->getRequestVars('column'); + + $attrs = array ( + 'text' => field('attname'), + 'action' => url('colproperties.php', + $reqvars, + array( + 'table' => $_REQUEST['table'], + 'column' => field('attname') + ) + ), + 'icon' => 'Column', + 'iconAction' => url('display.php', + $reqvars, + array( + 'table' => $_REQUEST['table'], + 'column' => field('attname'), + 'query' => replace( + 'SELECT "%column%", count(*) AS "count" FROM "%table%" GROUP BY "%column%" ORDER BY "%column%"', + array ( + '%column%' => field('attname'), + '%table%' => $_REQUEST['table'] + ) + ) + ) + ), + 'toolTip'=> field('comment') + ); + + $misc->printTree($columns, $attrs, 'tblcolumns'); + + exit; + } + + if ($action == 'tree') doTree(); + + /** + * Show default list of columns in the table + */ + function doDefault($msg = '') { + global $data, $conf, $misc; + global $lang; + + function attPre(&$rowdata, $actions) { + global $data; + $rowdata->fields['+type'] = $data->formatType($rowdata->fields['type'], $rowdata->fields['atttypmod']); + $attname = $rowdata->fields['attname']; + $table = $_REQUEST['table']; + $data->fieldClean($attname); + $data->fieldClean($table); + + $actions['browse']['attr']['href']['urlvars']['query'] = "SELECT \"{$attname}\", count(*) AS \"count\" + FROM \"{$table}\" GROUP BY \"{$attname}\" ORDER BY \"{$attname}\""; + + return $actions; + } + + $misc->printTrail('table'); + $misc->printTabs('table','columns'); + $misc->printMsg($msg); + + // Get table + $tdata = $data->getTable($_REQUEST['table']); + // Get columns + $attrs = $data->getTableAttributes($_REQUEST['table']); + // Get constraints keys + $ck = $data->getConstraintsWithFields($_REQUEST['table']); + + // Show comment if any + if ($tdata->fields['relcomment'] !== null) + echo '

', $misc->printVal($tdata->fields['relcomment']), "

\n"; + + $columns = array( + 'column' => array( + 'title' => $lang['strcolumn'], + 'field' => field('attname'), + 'url' => "colproperties.php?subject=column&{$misc->href}&table=".urlencode($_REQUEST['table'])."&", + 'vars' => array('column' => 'attname'), + ), + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('+type'), + ), + 'notnull' => array( + 'title' => $lang['strnotnull'], + 'field' => field('attnotnull'), + 'type' => 'bool', + 'params'=> array('true' => 'NOT NULL', 'false' => ''), + ), + 'default' => array( + 'title' => $lang['strdefault'], + 'field' => field('adsrc'), + ), + 'keyprop' => array( + 'title' => $lang['strconstraints'], + 'class' => 'constraint_cell', + 'field' => field('attname'), + 'type' => 'callback', + 'params'=> array( + 'function' => 'cstrRender', + 'keys' => $ck->getArray() + ) + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('comment') + ), + ); + + function cstrRender($s, $p) { + global $misc, $data; + + $str =''; + foreach ($p['keys'] as $k => $c) { + + if (is_null($p['keys'][$k]['consrc'])) { + $atts = $data->getAttributeNames($_REQUEST['table'], explode(' ', $p['keys'][$k]['indkey'])); + $c['consrc'] = ($c['contype'] == 'u' ? "UNIQUE (" : "PRIMARY KEY (") . join(',', $atts) . ')'; + } + + if ($c['p_field'] == $s) + switch ($c['contype']) { + case 'p': + $str .= 'icon('PrimaryKey') .'" alt="[pk]" title="'. htmlentities($c['consrc'], ENT_QUOTES, 'UTF-8') .'" />'; + break; + case 'f': + $str .= 'icon('ForeignKey') .'" alt="[fk]" title="'. htmlentities($c['consrc'], ENT_QUOTES, 'UTF-8') .'" />'; + break; + case 'u': + $str .= 'icon('UniqueConstraint') .'" alt="[uniq]" title="'. htmlentities($c['consrc'], ENT_QUOTES, 'UTF-8') .'" />'; + break; + case 'c': + $str .= 'icon('CheckConstraint') .'" alt="[check]" title="'. htmlentities($c['consrc'], ENT_QUOTES, 'UTF-8') .'" />'; + } + } + + return $str; + } + + $actions = array( + 'browse' => array( + 'title' => $lang['strbrowse'], + 'url' => "display.php?{$misc->href}&subject=column&return=table&table=".urlencode($_REQUEST['table']).'&', + 'vars' => array('column' => 'attname'), + ), + 'alter' => array( + 'title' => $lang['stralter'], + 'url' => "colproperties.php?action=properties&{$misc->href}&table=".urlencode($_REQUEST['table'])."&", + 'vars' => array('column' => 'attname'), + ), + 'privileges' => array( + 'title' => $lang['strprivileges'], + 'url' => "privileges.php?subject=column&{$misc->href}&table=".urlencode($_REQUEST['table'])."&", + 'vars' => array('column' => 'attname'), + ), + 'drop' => array( + 'title' => $lang['strdrop'], + 'url' => "tblproperties.php?action=confirm_drop&{$misc->href}&table=".urlencode($_REQUEST['table'])."&", + 'vars' => array('column' => 'attname'), + ), + ); + + $actions = array( + 'browse' => array( + 'content' => $lang['strbrowse'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'table' => $_REQUEST['table'], + 'subject' => 'column', + 'return' => 'table', + 'column' => field('attname') + ) + ) + ) + ), + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'colproperties.php', + 'urlvars' => array ( + 'subject' => 'column', + 'action' => 'properties', + 'table' => $_REQUEST['table'], + 'column' => field('attname') + ) + ) + ) + ), + 'privileges' => array( + 'content' => $lang['strprivileges'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'privileges.php', + 'urlvars' => array ( + 'subject' => 'column', + 'table' => $_REQUEST['table'], + 'column' => field('attname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'subject' => 'column', + 'action' => 'confirm_drop', + 'table' => $_REQUEST['table'], + 'column' => field('attname') + ) + ) + ) + ), + ); + + $misc->printTable($attrs, $columns, $actions, 'tblproperties-tblproperties', null, 'attPre'); + + $navlinks = array ( + 'browse' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'], + 'subject' => 'table', + 'return' => 'table' + ) + ) + ), + 'content' => $lang['strbrowse'] + ), + 'select' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confselectrows', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['strselect'] + ), + 'insert' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confinsertrow', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['strinsert'] + ), + 'empty' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_empty', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['strempty'] + ), + 'drop' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tables.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'], + ) + ) + ), + 'content' => $lang['strdrop'] + ), + 'addcolumn' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'action' => 'add_column', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['straddcolumn'] + ), + 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'tblproperties.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['stralter'] + ) + ); + $misc->printNavLinks($navlinks, + 'tblproperties-tblproperties' + , get_defined_vars() + ); + + } + + $misc->printHeader($lang['strtables'] . ' - ' . $_REQUEST['table']); + $misc->printBody(); + + switch ($action) { + case 'alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doDefault(); + break; + case 'confirm_alter': + doAlter(); + break; + case 'import': + doImport(); + break; + case 'export': + doExport(); + break; + case 'add_column': + if (isset($_POST['cancel'])) doDefault(); + else doAddColumn(); + break; + case 'properties': + if (isset($_POST['cancel'])) doDefault(); + else doProperties(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/global.css b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/global.css new file mode 100644 index 00000000..ab8c7613 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/global.css @@ -0,0 +1,321 @@ +@import url(../global.css); +@import url(//maxcdn.bootstrapcdn.com/bootstrap/3.2.2/css/bootstrap.min.css); +/** + * Default style sheet + */ +frame {border-right: 1px solid #CCC;} +.label { + color:#336699 !important; + font-size: 12px; +} + +/** ELEMENTS */ +body { + background-color: #FFFFFF; + margin: 4px; + padding: 0px; +} + +body.browser { + background-color: #FFFFFF !important; + font-size: 12px !important; /*1em;*/ + border-right: 1px #c0c0c0; +} +body.bottombar { + background-color: #f9f9f9; + margin: 0px; + padding: 0px; + /*font-size: smaller; /*1em;*/ + text-align: left; +} +h2 { + color: #336699 !important + + font-weight: bold; + border: 2px solid #DFFBFD; + background-color: #FDFDFD; + padding: 2px 1em; + margin: 0 0 1ex 0; +} +h3 { + color: #336699 !important; + font-size: small; + + font-weight: bold; +} +table.error {background-color: #F9FFFF} +table.error td {background-color: #F9FFFF} +table.navbar {background-color: #F9FFFF} +table.navbar td { + height: 25px; + color: #000000; + background-color: #FDFDFD; + text-align: center; + + font-size: smaller; /* 0.9em */ + font-weight: bold; +} +table.navbar td.active {background-color: #F9FFFF} +th.data { + color: #000000; + background-color: #F9FFFF; + font-size: smaller; /* 0.9em */ + padding:3px; +} +th.data a:active, th.data a:link, th.data a:visited, th.data a:hover { + font-weight: bold; +} +td.dat { + color: #ff0; + text-align: center; +} +th.required {text-decoration: underline} +td.topbar { + background-color: #f9f9f9; + margin: 0px 0px; + padding: 0px; + + font-size: smaller; /*0.8em;*/ + text-align: left; +} + +td.data1 { + padding:2px; +} + +ul.toplink,ul.navlink { + list-style: none; + margin:0;padding:0; +} +ul.navlink{margin:20px 0} +ul.toplink li, ul.navlink li { + display:inline; + border-left:1px solid #000000; + margin:0;padding: 0 2px 0 5px; +} +ul.toplink li:first-child, ul.navlink li:first-child { + border: none; + padding-left:0; +} +tr.data1, tr.data2, tr.data3 { + color: #000000; + + font-size: smaller; /*0.8em;*/ +} + +tr.data1 td, tr.data2 td, tr.data3 td { + padding:2px 4px; + border: 1px solid #EEE; +} + +tr.data1 td.opbutton1, tr.data2 td.opbutton2, tr.data3 td.opbutton3 { + padding:2px 4px; + border: 0 none; + white-space: nowrap; + border-radius:2px; +} + +tr.data1 td.opbutton1 a, tr.data2 td.opbutton2 a, tr.data3 td.opbutton3 a { +-webkit-background-clip: border-box; +-webkit-background-origin: padding-box; +-webkit-background-size: auto; +-webkit-user-select: none; +background-attachment: scroll; +background-clip: border-box; +background-color: rgb(66, 139, 202); +background-image: none; +background-origin: padding-box; +background-size: auto; +border: 1px solid #999; +border-radius:3px; + +cursor: pointer; +display: inline-block; +font-size: 11px; +font-weight: normal; +height: 22px; +line-height: 18px; +margin-bottom: 0px; +padding-bottom: 1px; +padding-left: 5px; +padding-right: 5px; +padding-top: 1px; +text-align: center; +text-decoration: none; +vertical-align: middle; +white-space: nowrap; +color:#fff !important; +} + + +tr.data1:hover, tr.data2:hover, tr.data3:hover { + background-color: #DDD; +} +.row1, .data1 { + background-color: #FFF; + text-align: left; +} +.row2, .data2 { + background-color: #F9FFFF; + text-align: left; +} +.row3, .data3 {background-color: #FDFDFD} +td.opbutton1 { + color: #000000; + border-top: 1px solid #FFFFFF; + border-right: 1px solid #706D41; + border-bottom: 1px solid #706D41; + border-left: 1px solid #FFFFFF; + cursor: pointer; + + font-size: smaller; /*0.8em;*/ + padding-left: 6px; + padding-right: 6px; + text-align: center; +} +td.opbutton2 { + color: #000000; + border-top: 1px solid #FFFFFF; + border-right: 1px solid #706D41; + border-bottom: 1px solid #706D41; + border-left: 1px solid #FFFFFF; + cursor: pointer; + + font-size: smaller; /*0.8em;*/ + padding-left: 6px; + padding-right: 6px; + text-align: center; +} +.topbar {border: 2px solid #f9f9f9} +.topbar, .topbar * { + background-color: #f9f9f9; +} +.topbar .platform, .topbar .host, .topbar .username { + font-weight: bold; +} +.topbar, .trail { + margin-bottom: 2px; +} +.topbar, .trail, .tab { + padding: 2px 1ex; + /*font-size: smaller;*/ +} +.trail, .tab { + border: 2px solid #DFFBFD; + background-color: #FDFDFD; +} +.trail .crumb {background-color: #FDFDFD} +.crumb, .tab { + vertical-align: top; +} +.crumb .icon { + vertical-align: middle; + margin: 0 2px; +} +table.tabs { + width: 100%; + border-collapse: collapse; + margin-bottom: 1ex; +} +.tab {text-align: center} +.tabs .active {background-color: #F9FFFF} +.tab .icon {display: block} +a:active { + color: #989973; + + font-weight: normal; + text-decoration: underline; +} +a,a:link { + color: #336699; + + text-decoration: none; +} +a:visited { + color: #336699; + + text-decoration: none; +} +a:hover { + color: #cc0000; + + text-decoration: none; +} +a.navlink:link, a.toplink:link, ul.navlink li a, ul.toplink li a { + color: #336699; + + font-weight: bold; + text-decoration: none; +} +a.navlink:visited, a.toplink:visited, ul.navlink li a:visited, ul.toplink li a:visited { + color: #336699; + + font-weight: bold; + text-decoration: none; +} +a.navlink:hover, a.toplink:hover, ul.navlink li a:hover, ul.toplink li a:hover { + color: #cc0000; + + font-weight: bold; + text-decoration: none; +} +a.navlink:active, a.toplink:active, ul.navlink li a:active, ul.toplink li a:active { + color: #cc0000; + + font-weight: bold; + text-decoration: none; +} +.active a {font-weight: bold} +a.help { + color: #E68800; + font-size: smaller; + vertical-align: super; + text-decoration: none; +} +pre {font-size: 110%} +pre.data { + + font-size: 100%; +} +pre.error { + font-family: "Lucida Console", "Courier New", "DejaVu Sans Mono", monospace; + font-size: 120%; +} +.intro li {font-weight: bold} +.ac_field {border:1px solid #D9D95F} +.bottom_link { + background: #eee; + border-top: 1px dotted #999; + border-left: 1px dotted #999; + font-size: smaller; +} + +/** FK browsing **/ +div#root > div.fk { + border: 1px solid #000; +} +div.fk { + background: #fff; + border-left: 1px solid #000; + padding: 5px; +} +div.logo { + background-color: #f9f9f9; + margin: 0px; + padding: 0px; + + background-size: 99% 90%; + font-size: smaller; /* 1em; */ + border: none; + margin-bottom: 2px; + background-image: url('../../images/themes/bootstrap/title.png'); + background-repeat: none; + height: 50px; +} +div.logo a { + display: block; + height: 100%; + color: transparent; +} + +.opbutton2, .opbutton1 {width:50px;} diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/title.png b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/bootstrap/title.png new file mode 100644 index 0000000000000000000000000000000000000000..44f5c7a18f9ef396503ae728c360e42a3ae8e01d GIT binary patch literal 5388 zcmeHLX;f3!8jXk=0V_p(MN~*50-})8*MFXsrGo5xFFU74L(|$?Xq>}}pDdI}Y%VSj_&&a8AzG_e)q43xwbWoAa>!(j zb&s_o|3qY4K!E=Rr7_h6?@|T(uEfY0V;ddnjT@b%_1_^(bF7sN{hN0V8?&|z3`$W(YQM zGb0kP?69B^fWVP9&WF~q#*>hXw`RyM<7P-{Cw7z?1%kP{!#wL z3rcFQ(l8;HWjrit6Q`e;DW33L>(r8FD`QyHEZ1zN;cj!ONYg6G^Dyy{B9yNwqcPu5 z+;`6NTp8+7voaM5a#2ghW+l$*NBu`zYoe;E*xX(T4#}-xvm0Mmb!TOr?jDB7S}FeH z#k6G39RNq&acaVd-Dar%?LFh;6TOXIkV6eY7Rs`JuErp!mr5|%cn#0LtXi7?oVViqO`&zr(sk;7W zwdL#%JaYG1i_2-6+^?ZzWuUql1hy7;+a{lYNi4`c?)NxweiVOS+YA+2adwlkETnHz zp{gLbv^4K@>Iih%)gPPBrESbvkn=Ml`GvE+RhHB#KpvHuI4>B}eJlMm+${|z75WZZ zt8?&<^~D$0^-VtTy2*-9Aos0v2*R87?Fv#8^YcP!OL^-uYwpZV{FYUnU+Joy6u)Np zIgBrJ!?aTrWQ2QrDwH;~HZgYh)(BF~u1YoDxS-uaJ@Z$soOktM=JQo`v2B%%r4XHb z{WtY*-4~`>uTk2;nR>|x@&$10Os!yk^}}V7@rPYcJGz!YxapoW5fOWO9M~W0Tun3V@r!|KQR2zNxyj?^Vi?L$bpAbp-sq z=$l7=qP4$IX=DUCk&0SdDe^Z1eyH54++cInM`sx%4mPbPOr;EJ1e;we_TC`qXceu_ zMwwcv_=r?YJ%e~2#ER+ml`@e1IQ8(+KUR8qxilr#uuX&bG@C+K~7mmA& zTbbLFLX5Tb=*Nx!DsKhp@Ke5f>kh{c(Wsc?AKQs2)L03vFtACM+oA8LnFzwp(fp6Z z1+`ArW(??|l*dJ6cUAS*RRxMY%oRUOu4UiR=<+$;y+IdFC#|q|=!g z*@d!xWrFq_jpe&$ZMq)by1qrwT`TE(JUZU^!`>0me6~T&6Ybt&A7plC^{zTt%xn!? zv^6+ONzSOZt1TiZFcbn|f-ua&gdL*e*3>Hznf|l$+cP&Nm$?SMy%Tn`CNjI>));TS zCEj!H?mdxLgR@I0X8N(6S$g0FAEPva!viFX-(JHw85-5s2Z+MbkFT!nY08YEwp|}=vsZ_z0fxRV(v0Xd@*w{>2;G? zi#^Y~t+QK*=KeWWFbK}`SARG9yfx`uBR39qcUabn+k=(}yD+>-Ng>c^#?99{?0suZ z%lvSiWNNd;`7aJ_n9^WfN^S5juB#rt<}%kodvs`-{Y ztCl}o3hVC{>-Q<^MF9g|F6s`wj`rFYUcW!%yt@5_NS|(e-s76{cWn}O9in5>ryvAe znvzg)n&u01HtbMgSJ`^;(h=Nhgb#n7BPxC1V#!GLb zz{;SAVAqx$6>h#rNlmW?ZC?7st}!S+GN==-p@+lIo(OYR*d~z0>_-1}6`e6$gofEPX; z@2$&JAy_OcO+{?GQy!cao!sAZyzVi_^eo3H^W8{$If=2Ia& zqy5WQ(ya1>X*r$Mx5EU2y`|zxPHQYlS}C#eY|zDG4LP6#%eRRjnc^_jqDjr2ATz&ablf1r^WA=ZVBHEW-i4k1YLA-NTe;hYx~Ds3dJfLHY8|cV=(voFVA1QM=XQz? z=QM3P<MJHd%f;AY3~3e#umGOGmpfL;7DQ#L>>x_KNkMxc>qdJ=JRf literal 0 HcmV?d00001 diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/cappuccino/global.css b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/cappuccino/global.css new file mode 100644 index 00000000..5d1a3aa7 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/cappuccino/global.css @@ -0,0 +1,197 @@ +@import url(../global.css); +/** + * cappuccino style sheet + */ +/* ELEMENTS */ +body { + background-color: #ded9c9; + margin: 0; + padding: 0; + font-family: arial; + font-size: 0.9em; /*0.8em;*/ +} +body > * { margin-left: 20px } +body.browser { + background-color: #363330; + font-size: 0.9em; + border-right: 1px dashed #887f5c; + color: #fff; +} +body.browser > * { margin: 0 } +body.browser div.webfx-tree-row:hover { background: #524a42} +h1 {font-size: 1.5em} +h2 { + color: #fff; + font-size: 1em; + font-weight: bold; + border: 2px solid #363330; + background-color: #363330; + padding: 2px 1em; + margin-top: 2em; + margin-bottom: 2em; +} +h3 { + color: #111; + font-weight: bold; +} +table { + border: 0; + border-collapse: collapse; +} +td, th { + padding: 1px 8px; +} +a { + color: #2d547b; + text-decoration: none; +} +a:hover { + color: #cc0000; + text-decoration: underline; +} +input[type=checkbox], input[type=password], input[type=text], input[type=radio] { + background: #ded4b3; + border: 1px solid #887f5c; +} +input[type=submit], input[type=reset], input[type=button], select { + background: #c4ba95 url('../../images/themes/cappuccino/inputbckg.png') repeat-x top left; + border: 1px solid #887f5c; +} +table.error { + background-color: #dec9d0; + border: 2px solid #de7c9c; + margin: auto; +} +th.data { + color: #fff; + background-color: #363330; + border: 1px dotted #887f5c; + font-size: 0.9em; + padding: 3px 7px; +} +th.required {text-decoration: underline} +.topbar, .trail { + color: #fff; + background-color: #363330; + margin: 0; + padding: 0; + text-align: left; +} +.topbar a, .trail a, body.browser a, th.data a { + color: #a8aac2; +} +.topbar .platform, .topbar .host, .topbar .username { + font-weight: bold; +} +.topbar, .trail, .tab { + padding: 2px 1ex; +} +.trail td {padding: 2px} +.crumb .icon {margin-right: 5px} +table.tabs { + width: 100%; + border-collapse: collapse; + margin: 20px 0 40px 0; +} +.tab { + text-align: center; + vertical-align: top; + font-size: 0.8em; + border: 1px solid #887f5c; + background-color: #c8c0a2; + padding: 2px 10px; + white-space: nowrap; +} +.tab:hover {background-color: #b7af8d} +.tabs .active { + border-bottom: none; + background-color: #ded9c9; +} +.tab .icon { + display: block; +} +.active a {font-weight: bold} +a:hover {text-decoration: underline} +ul.toplink, ul.navlink { + list-style: none; + margin:0;padding:0; +} +ul.navlink{margin:20px 0 20px 20px} +ul.toplink li, ul.navlink li { + display:inline; + border-left:1px solid #000000; + margin:0;padding: 0 2px 0 5px; +} +ul.toplink li:first-child, ul.navlink li:first-child { + border: none; + padding-left:0; +} +tr.data1, tr.data2, tr.data3 { + color: #000000; + font-size: 0.8em; + border: 1px dotted #887f5c; +} +tr.data1:hover, tr.data2:hover, tr.data3:hover { + background-color: #c8c0a2; +} +.row1, .data1 { + background-color: #d8d2b9; + text-align: left; +} +.row2, .data2 { + background-color: #ded9c9; + text-align: left; +} +.row3, .data3 {background-color: #d4c8a1} +td.opbutton1, td.opbutton2 { + color: #000000; + cursor: pointer; + padding: 2px 6px; + text-align: center; + border: 1px dotted #887f5c; +} +td.opbutton1:hover, td.opbutton2:hover { + background-color: #b7af8d; +} +a.help { + color: #A46600; + vertical-align: super; + text-decoration: none; + font-size: 0.8em; +} +pre {font-size: 110%} +pre.data {font-size: 100%} +pre.error {font-size: 120%} + +.intro li {font-weight: bold} +.ac_field { + border:1px solid #363330; + background: url('../../images/themes/cappuccino/openListe.png') no-repeat right; + padding-right: 20px; +} +.bottom_link { + background: #b7af8d; + border-top: 1px dotted #887f5c; + border-left: 1px dotted #887f5c; +} + +/** FK browsing **/ +div.fk { + background: #fff; + border-left: 1px dotted #000; + padding: 5px; +} +div.logo { + margin: 0px; + padding: 0px; + border: none; + margin-bottom: 15px; + background-image: url('../../images/themes/cappuccino/title.png'); + background-repeat: no-repeat; + height: 50px; +} +div.logo a { + display: block; + height: 100%; + color: transparent; +} diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/default/global.css b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/default/global.css new file mode 100644 index 00000000..c28cd9f6 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/default/global.css @@ -0,0 +1,266 @@ +@import url(../global.css); +/** + * Default style sheet + */ + +/** ELEMENTS */ +body { + background-color: #FFFFFF; + margin: 4px; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + padding: 0px; + font-size: smaller; /*0.8em;*/ +} +body.browser { + background-color: #efefef; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /*1em;*/ + border-right: 1px dashed #c0c0c0; +} +body.bottombar { + background-color: #CECF9C; + margin: 0px; + padding: 0px; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /*1em;*/ + text-align: left; +} +h2 { + color: #666633; + font-size: medium; /*1.3em;*/ + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: bold; + border: 2px solid #E6E6CC; + background-color: #F3F3E9; + padding: 2px 1em; + margin: 0 0 1ex 0; +} +h3 { + color: #666633; + font-size: small; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: bold; +} +table.error {background-color: #E6E6CC} +table.error td {background-color: #E6E6CC} +table.navbar {background-color: #E6E6CC} +table.navbar td { + height: 25px; + color: #000000; + background-color: #F3F3E9; + text-align: center; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /* 0.9em */ + font-weight: bold; +} +table.navbar td.active {background-color: #E6E6CC} +th.data { + color: #000000; + background-color: #E6E6CC; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /* 0.9em */ +} +th.data a:active, th.data a:link, th.data a:visited, th.data a:hover { + font-weight: bold; +} +td.dat { + color: #ff0; + text-align: center; +} +th.required {text-decoration: underline} +td.topbar { + background-color: #CECF9C; + margin: 0px 0px; + padding: 0px; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /*0.8em;*/ + text-align: left; +} +ul.toplink,ul.navlink { + list-style: none; + margin:0;padding:0; +} +ul.navlink{margin:20px 0} +ul.toplink li, ul.navlink li { + display:inline; + border-left:1px solid #000000; + margin:0;padding: 0 2px 0 5px; +} +ul.toplink li:first-child, ul.navlink li:first-child { + border: none; + padding-left:0; +} +tr.data1, tr.data2, tr.data3 { + color: #000000; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /*0.8em;*/ +} +tr.data1:hover, tr.data2:hover, tr.data3:hover { + background-color: #DDD; +} +.row1, .data1 { + background-color: #F3F3E9; + text-align: left; +} +.row2, .data2 { + background-color: #E6E6CC; + text-align: left; +} +.row3, .data3 {background-color: #F3F3E9} +td.opbutton1 { + color: #000000; + border-top: 1px solid #FFFFFF; + border-right: 1px solid #706D41; + border-bottom: 1px solid #706D41; + border-left: 1px solid #FFFFFF; + cursor: pointer; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /*0.8em;*/ + padding-left: 6px; + padding-right: 6px; + text-align: center; +} +td.opbutton2 { + color: #000000; + border-top: 1px solid #FFFFFF; + border-right: 1px solid #706D41; + border-bottom: 1px solid #706D41; + border-left: 1px solid #FFFFFF; + cursor: pointer; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /*0.8em;*/ + padding-left: 6px; + padding-right: 6px; + text-align: center; +} +.topbar {border: 2px solid #CECF9C} +.topbar, .topbar * { + background-color: #CECF9C; +} +.topbar .platform, .topbar .host, .topbar .username { + font-weight: bold; +} +.topbar, .trail { + margin-bottom: 2px; +} +.topbar, .trail, .tab { + padding: 2px 1ex; + font-size: smaller; +} +.trail, .tab { + border: 2px solid #E6E6CC; + background-color: #F3F3E9; +} +.trail .crumb {background-color: #F3F3E9} +.crumb, .tab { + vertical-align: top; +} +.crumb .icon { + vertical-align: middle; + margin: 0 2px; +} +table.tabs { + width: 100%; + border-collapse: collapse; + margin-bottom: 1ex; +} +.tab {text-align: center} +.tabs .active {background-color: #E6E6CC} +.tab .icon {display: block} +a:active { + color: #989973; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: normal; + text-decoration: underline; +} +a,a:link { + color: #336699; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + text-decoration: none; +} +a:visited { + color: #336699; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + text-decoration: none; +} +a:hover { + color: #cc0000; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + text-decoration: none; +} +a.navlink:link, a.toplink:link, ul.navlink li a, ul.toplink li a { + color: #336699; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: bold; + text-decoration: none; +} +a.navlink:visited, a.toplink:visited, ul.navlink li a:visited, ul.toplink li a:visited { + color: #336699; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: bold; + text-decoration: none; +} +a.navlink:hover, a.toplink:hover, ul.navlink li a:hover, ul.toplink li a:hover { + color: #cc0000; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: bold; + text-decoration: none; +} +a.navlink:active, a.toplink:active, ul.navlink li a:active, ul.toplink li a:active { + color: #cc0000; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-weight: bold; + text-decoration: none; +} +.active a {font-weight: bold} +a.help { + color: #E68800; + font-size: smaller; + vertical-align: super; + text-decoration: none; +} +pre {font-size: 110%} +pre.data { + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: 100%; +} +pre.error { + font-family: "Lucida Console", "Courier New", "DejaVu Sans Mono", monospace; + font-size: 120%; +} +.intro li {font-weight: bold} +.ac_field {border:1px solid #D9D95F} +.bottom_link { + background: #eee; + border-top: 1px dotted #999; + border-left: 1px dotted #999; + font-size: smaller; +} + +/** FK browsing **/ +div#root > div.fk { + border: 1px solid #000; +} +div.fk { + background: #fff; + border-left: 1px solid #000; + padding: 5px; +} +div.logo { + background-color: #CECF9C; + margin: 0px; + padding: 0px; + font-family: arial, tahoma, verdana, helvetica, sans-serif, serif; + font-size: smaller; /* 1em; */ + border: none; + border-bottom: 2px solid #000000; + margin-bottom: 2px; + background-image: url('../../images/themes/default/title.png'); + background-repeat: no-repeat; + height: 50px; +} +div.logo a { + display: block; + height: 100%; + color: transparent; +} diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/global.css b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/global.css new file mode 100644 index 00000000..6e62f0f5 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/global.css @@ -0,0 +1,111 @@ +/** + * This is hte mandatory CSS file to include on top of every CSS theme file + **/ + +img { border: none; } +p.message {color: blue} +p.comment {font-style: italic} +.left{text-align: left} +.pre {white-space: pre} + +.arg_icon { + padding-right:5pt; + padding-left:5pt; +} + +/** Browser Tree using XLoadTree 2 **/ +body.browser { + height: 100%; + margin: 0px; + padding: 0px; + text-align: left; +} +.refreshTree { + float:right; + text-align:right; + padding: 0 3px; +} +.webfx-tree-row {white-space: nowrap} +.webfx-tree-children { + background-repeat: repeat-y; + background-position-y: 1px !important; /* IE only */ +} +.webfx-tree-row img {vertical-align: middle} +.webfx-tree-item-label {margin-left: 0.5ex} +.webfx-tree-icon {margin-left: 1px} +.webfx-tree-hide-root {display: none} + +/** auto-complete on insert **/ +#fkbg { + display:none; + position:fixed; + top:0;left:0; + width:100%; + height:100%; + z-index:10; +} +#fklist { + display:none; + position:absolute; + background:#fff; + border:1px solid #000; + overflow:auto; + z-index:15; +} +#fklist table { + border-collapse:collapse; + border: 1px solid #aaa; +} +#fklist th {border: 1px solid #aaa} +#fklist td, +#fklist th { + padding: 3px 10px; + border-right: 1px solid #aaa; + font-size: 12px; +} +#fklist td a { + display:block; + color:#000; +} +#fklist td a.fkval, p.errmsg { + color:red; +} +.ac_values {width:100%} + +/** bottom link back to top **/ +.bottom_link { + position: fixed; + bottom: 0; + right: 0; + margin: 0; + padding: 4px; + background: #eee; + border-top: 1px dotted #999; + border-left: 1px dotted #999; + font-size: smaller; +} + +/** FK browsing **/ +div#root { + position: absolute; +} +div.fk { + margin-left: 20px; +} +div#fkcontainer { + margin: 0; + position: relative; + width: 100%; + background: none; + border:0px; +} +div.fk_value { + display:inline-block; +} +.highlight { + background-color: #FFFF00; +} +/** Syntax highlighting **/ +.comment {color: #008080} +.keyword {color: #FF8000} +.literal {color: #808080} diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/gotar/global.css b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/gotar/global.css new file mode 100644 index 00000000..5b693189 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/gotar/global.css @@ -0,0 +1,262 @@ +@import url(../global.css); +/** + * Default style sheet + */ + +/** ELEMENTS */ + +body { + background-color: #336; + margin: 0px; + padding: 0px; + font-size: smaller; /*0.8em;*/ + font-family: sans-serif; + color: #fff; +} +p { + color: #fff; +} +p.comment, td.comment_cell { + color: #aff; +} +table { + border:1px gray solid; +} +body.browser { + background-color: #447; + color:#4bf; + font-size: smaller; /*1em;*/ + border-right: 1px dashed #c0c0c0; +} +body.browser a { + color:#fff; +} +body.browser a:hover { + color:#cde; +} +body.browser div.webfx-tree-row:hover { background:#88d } +h2 { + color: #fff; + font-size: medium; /*1.3em;*/ + font-weight: bold; + border: 0; + background-color: #558; + padding: 0; + margin: 0; + text-align:center; +} +h3 { + color: #eee; + font-size: small; + font-weight: bold; +} +table.error {background-color: #f00} +table.error td {background-color: #f84} +th.data { + color: #ada; + background-color: #241; + font-size: smaller; /* 0.9em */ +} +th.data a:active, th.data a:link, th.data a:visited, th.data a:hover { + font-weight: bold; + display:block; +} +td.dat { + color: #ff0; + text-align: center; +} +th.required {text-decoration: underline} +ul.toplink,ul.navlink { + list-style: none; + margin:0;padding:0; +} +ul.navlink{margin:20px 0} +ul.toplink li, ul.navlink li { + display:inline; + border-left:1px solid #eee; + margin:0;padding: 0 2px 0 5px; +} +ul.toplink li:first-child, ul.navlink li:first-child { + border: none; + padding-left:0; +} +tr.data1, tr.data2, tr.data3 { + color: #eed; + font-family: sans-serif; + font-size: smaller; /*0.8em;*/ +} +tr.data1:hover, tr.data2:hover, tr.data3:hover { + background-color: #39663e; +} +.row1, .data1 { + background-color: #2b482e; + text-align: left; +} +input, textarea, select { + border:1px #200 solid; + background:#ddf; +} +input, textarea, select { + color:#210; +} +td label { + display:table; + text-align:center; + height:100%; + width:100%; + border-collapse: collapse; +} +td label span { + display:table-cell; + vertical-align:middle; +} +.data1 select, .data2 select { + font-weight:bold; +} +p input:focus, .data input:focus, .data1 input:focus, .data2 input:focus, textarea:focus, .data1 select, .data2 select { +/* background:#bbf; */ + background:#eef; + color:#000; +} +.row2, .data2 { + background-color: #1a3f1e; + text-align: left; +} +td.opbutton1 { + border: 1px solid #484; + font-size: smaller; /*0.8em;*/ + text-align: center; +} +td.opbutton2 { + border: 1px solid #484; + font-size: smaller; /*0.8em;*/ + text-align: center; +} +td.opbutton1 a, td.opbutton2 a { + padding-left:6px; + padding-right:6px; +} +.topbar { border: 0 } +.topbar, .topbar *, .trail, .tab, .crumb { + border: 0; + background: #336; +} +.topbar .platform, .topbar .host, .topbar .username { + font-weight: bold; +} +.topbar, .trail, .tab { + padding: 2px 1ex; + font-size: smaller; + color: #ddf; +} +.crumb, .tab { + vertical-align: top; +} +.crumb .icon { + vertical-align: middle; + margin: 0; +} +table.tabs { + width: 100%; + border-collapse: collapse; + margin-bottom: 1ex; +} +.tab {text-align: center} +.tabs .active {background-color: #449} +.tab .icon {display: block} +tr,td { height:100% } +td:not(.constraint_cell) a:not(.help), th a { display:inline-block; height:100% } /* vertical-align:middle doesn't work for block elements, CSS sux */ +td.crumb a, td.tab a { width:90% } +tr.data1 a, tr.data2 a { width:100% } +td.opbutton1 a, td.opbutton2 a { width:inherit } +td a.help { display:inline; position:absolute; width:10px; } +a.pagenav { display:inline-block; min-width:15px; } +a.toplink { display:inline } +a:active { + color: #989973; + font-weight: normal; + text-decoration: underline; +} +a,a:link { + color: #afa; + text-decoration: none; +} +a:visited { + color: #df8; + text-decoration: none; +} +a:hover { + color: #f88; + text-decoration: none; +} +a:active { + color: #c00; +} +a.navlink:link, a.toplink:link, ul.navlink li a, ul.toplink li a { + color: #afa; + font-weight: bold; + text-decoration: none; +} +a.navlink:visited, a.toplink:visited, ul.navlink li a:visited, ul.toplink li a:visited { + color: #df8; + font-weight: bold; + text-decoration: none; +} +a.navlink:hover, a.toplink:hover, ul.navlink li a:hover, ul.toplink li a:hover { + color: red; + font-weight: bold; + text-decoration: none; +} +a.navlink:active, a.toplink:active, ul.navlink li a:active, ul.toplink li a:active { + color: #c00; + font-weight: bold; + text-decoration: none; +} +.active a {font-weight: bold} +a.help { + color: #E68800; + font-size: smaller; + vertical-align: super; + text-decoration: none; +} +pre {font-size: 110%} +pre.data { + font-size: 100%; +} +.error p { + color:#822; + background:#fc8; +} +pre.error { + color: #000; + font-family: monospace; + font-size: 120%; +} +.intro li {font-weight: bold} +.ac_field {border:1px solid #D9D95F} +.bottom_link { + color: #004 !important; + background: #eee; + border-top: 1px dotted #999; + border-left: 1px dotted #999; + font-size: smaller; +} + +a.bottom_link:hover { background:#68f } + +/** FK browsing **/ +div#root > div.fk { + border: 1px solid #000; +} +div.fk { + /*background: #84c;*/ + background: rgba(128,32,64,0.6); + border-left: 1px solid #000; + padding: 5px 0 5px 0; +} +div.logo { display:none } +div.logo a { + display: block; + height: 100%; + color: transparent: +} diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/themes.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/themes.php new file mode 100644 index 00000000..f9edb666 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/themes/themes.php @@ -0,0 +1,16 @@ + 'Default', + 'cappuccino' => 'Cappuccino', + 'gotar' => 'Blue/Green', + 'bootstrap' => 'Bootstrap3' + ); +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/triggers.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/triggers.php new file mode 100644 index 00000000..339e4ae4 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/triggers.php @@ -0,0 +1,448 @@ +alterTrigger($_POST['table'], $_POST['trigger'], $_POST['name']); + if ($status == 0) + doDefault($lang['strtriggeraltered']); + else + doAlter($lang['strtriggeralteredbad']); + } + + /** + * Function to allow altering of a trigger + */ + function doAlter($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('trigger'); + $misc->printTitle($lang['stralter'],'pg.trigger.alter'); + $misc->printMsg($msg); + + $triggerdata = $data->getTrigger($_REQUEST['table'], $_REQUEST['trigger']); + + if ($triggerdata->recordCount() > 0) { + + if (!isset($_POST['name'])) $_POST['name'] = $triggerdata->fields['tgname']; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}"; + echo "_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />\n"; + echo "
\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('trigger'); + $misc->printTitle($lang['strdrop'],'pg.trigger.drop'); + + echo "

", sprintf($lang['strconfdroptrigger'], $misc->printVal($_REQUEST['trigger']), + $misc->printVal($_REQUEST['table'])), "

\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->dropTrigger($_POST['trigger'], $_POST['table'], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['strtriggerdropped']); + else + doDefault($lang['strtriggerdroppedbad']); + } + + } + + /** + * Show confirmation of enable trigger and perform enabling the trigger + */ + function doEnable($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('trigger'); + $misc->printTitle($lang['strenable'],'pg.table.alter'); + + echo "

", sprintf($lang['strconfenabletrigger'], $misc->printVal($_REQUEST['trigger']), + $misc->printVal($_REQUEST['table'])), "

\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->enableTrigger($_POST['trigger'], $_POST['table']); + if ($status == 0) + doDefault($lang['strtriggerenabled']); + else + doDefault($lang['strtriggerenabledbad']); + } + + } + + /** + * Show confirmation of disable trigger and perform disabling the trigger + */ + function doDisable($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('trigger'); + $misc->printTitle($lang['strdisable'],'pg.table.alter'); + + echo "

", sprintf($lang['strconfdisabletrigger'], $misc->printVal($_REQUEST['trigger']), + $misc->printVal($_REQUEST['table'])), "

\n"; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + $status = $data->disableTrigger($_POST['trigger'], $_POST['table']); + if ($status == 0) + doDefault($lang['strtriggerdisabled']); + else + doDefault($lang['strtriggerdisabledbad']); + } + + } + + /** + * Let them create s.th. + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('table'); + $misc->printTitle($lang['strcreatetrigger'],'pg.trigger.create'); + $misc->printMsg($msg); + + // Get all the functions that can be used in triggers + $funcs = $data->getTriggerFunctions(); + if ($funcs->recordCount() == 0) { + doDefault($lang['strnofunctions']); + return; + } + + /* Populate functions */ + $sel0 = new XHTML_Select('formFunction'); + while (!$funcs->EOF) { + $sel0->add(new XHTML_Option($funcs->fields['proname'])); + $funcs->moveNext(); + } + + /* Populate times */ + $sel1 = new XHTML_Select('formExecTime'); + $sel1->set_data($data->triggerExecTimes); + + /* Populate events */ + $sel2 = new XHTML_Select('formEvent'); + $sel2->set_data($data->triggerEvents); + + /* Populate occurences */ + $sel3 = new XHTML_Select('formFrequency'); + $sel3->set_data($data->triggerFrequency); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo " \n"; + echo " \n"; + echo "\n"; + echo "\n"; + echo " \n"; + echo " \n"; + echo "\n"; + echo "\n"; + echo " \n"; + echo " \n"; + echo "\n"; + echo "\n"; + echo " \n"; + echo " \n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}{$lang['strwhen']}
", $sel1->fetch(), "
{$lang['strevent']}{$lang['strforeach']}
", $sel2->fetch(), " ", $sel3->fetch(), "
{$lang['strfunction']} {$lang['strarguments']}
", $sel0->fetch(), "()
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "
\n"; + } + + /** + * Actually creates the new trigger in the database + */ + function doSaveCreate() { + global $data; + global $lang; + + // Check that they've given a name and a definition + + if ($_POST['formFunction'] == '') + doCreate($lang['strtriggerneedsfunc']); + elseif ($_POST['formTriggerName'] == '') + doCreate($lang['strtriggerneedsname']); + elseif ($_POST['formEvent'] == '') + doCreate(); + else { + $status = $data->createTrigger($_POST['formTriggerName'], $_POST['table'], + $_POST['formFunction'], $_POST['formExecTime'], $_POST['formEvent'], + $_POST['formFrequency'], $_POST['formTriggerArgs']); + if ($status == 0) + doDefault($lang['strtriggercreated']); + else + doCreate($lang['strtriggercreatedbad']); + } + } + + /** + * List all the triggers on the table + */ + function doDefault($msg = '') { + global $data, $misc, $database; + global $lang; + + function tgPre(&$rowdata,$actions) { + global $data; + // toggle enable/disable trigger per trigger + if( ! $data->phpBool( $rowdata->fields["tgenabled"] ) ) { + unset( $actions['disable'] ); + } + else{ + unset( $actions['enable'] ); + } + + return $actions; + } + + $misc->printTrail('table'); + $misc->printTabs('table','triggers'); + $misc->printMsg($msg); + + $triggers = $data->getTriggers($_REQUEST['table']); + + $columns = array( + 'trigger' => array( + 'title' => $lang['strname'], + 'field' => field('tgname'), + ), + 'definition' => array( + 'title' => $lang['strdefinition'], + 'field' => field('tgdef'), + ), + 'function' => array( + 'title' => $lang['strfunction'], + 'field' => field('proproto'), + 'url' => "functions.php?action=properties&server={$_REQUEST['server']}&database={$_REQUEST['database']}&", + 'vars' => array( + 'schema' => 'pronamespace', + 'function' => 'proproto', + 'function_oid' => 'prooid', + ), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'triggers.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'table' => $_REQUEST['table'], + 'trigger' => field('tgname') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'triggers.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'table' => $_REQUEST['table'], + 'trigger' => field('tgname') + ) + ) + ) + ), + ); + if($data->hasDisableTriggers()) { + $actions['enable'] = array( + 'content' => $lang['strenable'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'triggers.php', + 'urlvars' => array ( + 'action' => 'confirm_enable', + 'table' => $_REQUEST['table'], + 'trigger' => field('tgname') + ) + ) + ) + ); + $actions['disable'] = array( + 'content' => $lang['strdisable'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'triggers.php', + 'urlvars' => array ( + 'action' => 'confirm_disable', + 'table' => $_REQUEST['table'], + 'trigger' => field('tgname') + ) + ) + ) + ); + } + + $misc->printTable($triggers, $columns, $actions, 'triggers-triggers', $lang['strnotriggers'], 'tgPre'); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'triggers.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'table' => $_REQUEST['table'] + ) + ) + ), + 'content' => $lang['strcreatetrigger'] + )), 'triggers-triggers', get_defined_vars()); + } + + function doTree() { + + global $misc, $data; + + $triggers = $data->getTriggers($_REQUEST['table']); + + $reqvars = $misc->getRequestVars('table'); + + $attrs = array( + 'text' => field('tgname'), + 'icon' => 'Trigger', + ); + + $misc->printTree($triggers, $attrs, 'triggers'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strtables'] . ' - ' . $_REQUEST['table'] . ' - ' . $lang['strtriggers']); + $misc->printBody(); + + switch ($action) { + case 'alter': + if (isset($_POST['alter'])) doSaveAlter(); + else doDefault(); + break; + case 'confirm_alter': + doAlter(); + break; + case 'confirm_enable': + doEnable(true); + break; + case 'confirm_disable': + doDisable(true); + break; + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['yes'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'enable': + if (isset($_POST['yes'])) doEnable(false); + else doDefault(); + break; + case 'disable': + if (isset($_POST['yes'])) doDisable(false); + else doDefault(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/types.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/types.php new file mode 100644 index 00000000..a3ca1a34 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/types.php @@ -0,0 +1,714 @@ +getType($_REQUEST['type']); + + $misc->printTrail('type'); + $misc->printTitle($lang['strproperties'], 'pg.type'); + $misc->printMsg($msg); + + function attPre(&$rowdata) { + global $data; + $rowdata->fields['+type'] = $data->formatType($rowdata->fields['type'], $rowdata->fields['atttypmod']); + } + + if ($typedata->recordCount() > 0) { + $vals = false; + switch ($typedata->fields['typtype']) { + case 'c': + $attrs = $data->getTableAttributes($_REQUEST['type']); + + $columns = array( + 'field' => array( + 'title' => $lang['strfield'], + 'field' => field('attname'), + ), + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('+type'), + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('comment'), + ) + ); + + $actions = array(); + + $misc->printTable($attrs, $columns, $actions, 'types-properties', null, 'attPre'); + + break; + case 'e': + $vals = $data->getEnumValues($typedata->fields['typname']); + default: + $byval = $data->phpBool($typedata->fields['typbyval']); + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + if ($data->hasEnumTypes() && $vals) { + $vals = $vals->getArray(); + $nbVals = count($vals); + echo "\n\t\n"; + echo "\n"; + for ($i=1; $i < $nbVals; $i++) + echo "\n"; + } + echo "
{$lang['strname']}", $misc->printVal($typedata->fields['typname']), "
{$lang['strinputfn']}", $misc->printVal($typedata->fields['typin']), "
{$lang['stroutputfn']}", $misc->printVal($typedata->fields['typout']), "
{$lang['strlength']}", $misc->printVal($typedata->fields['typlen']), "
{$lang['strpassbyval']}", ($byval) ? $lang['stryes'] : $lang['strno'], "
{$lang['stralignment']}", $misc->printVal($typedata->fields['typalign']), "
{$lang['strenumvalues']}{$vals[0]['enumval']}
{$vals[$i]['enumval']}
\n"; + } + + $misc->printNavLinks(array ('showall' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'types.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + ) + ) + ), + 'content' => $lang['strshowalltypes'] + )), 'types-properties', get_defined_vars()); + } else + doDefault($lang['strinvalidparam']); + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('type'); + $misc->printTitle($lang['strdrop'], 'pg.type.drop'); + + echo "

", sprintf($lang['strconfdroptype'], $misc->printVal($_REQUEST['type'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropType($_POST['type'], isset($_POST['cascade'])); + if ($status == 0) + doDefault($lang['strtypedropped']); + else + doDefault($lang['strtypedroppedbad']); + } + + } + + /** + * Displays a screen where they can enter a new composite type + */ + function doCreateComposite($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_REQUEST['stage'])) $_REQUEST['stage'] = 1; + if (!isset($_REQUEST['name'])) $_REQUEST['name'] = ''; + if (!isset($_REQUEST['fields'])) $_REQUEST['fields'] = ''; + if (!isset($_REQUEST['typcomment'])) $_REQUEST['typcomment'] = ''; + + switch ($_REQUEST['stage']) { + case 1: + $misc->printTrail('type'); + $misc->printTitle($lang['strcreatecomptype'], 'pg.type.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['name']), "\" />
{$lang['strnumfields']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['fields']), "\" />
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + break; + case 2: + global $lang; + + // Check inputs + $fields = trim($_REQUEST['fields']); + if (trim($_REQUEST['name']) == '') { + $_REQUEST['stage'] = 1; + doCreateComposite($lang['strtypeneedsname']); + return; + } + elseif ($fields == '' || !is_numeric($fields) || $fields != (int)$fields || $fields < 1) { + $_REQUEST['stage'] = 1; + doCreateComposite($lang['strtypeneedscols']); + return; + } + + $types = $data->getTypes(true, false, true); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatecomptype'], 'pg.type.create'); + $misc->printMsg($msg); + + echo "
\n"; + + // Output table header + echo "\n"; + echo "\t"; + echo"\n"; + + for ($i = 0; $i < $_REQUEST['fields']; $i++) { + if (!isset($_REQUEST['field'][$i])) $_REQUEST['field'][$i] = ''; + if (!isset($_REQUEST['length'][$i])) $_REQUEST['length'][$i] = ''; + if (!isset($_REQUEST['colcomment'][$i])) $_REQUEST['colcomment'][$i] = ''; + + echo "\t\n\t\t\n"; + echo "\t\t\n"; + echo "\t\t\n"; + + // Output array type selector + echo "\t\t\n"; + + echo "\t\t\n"; + echo "\t\t\n\t\n"; + } + echo "
{$lang['strfield']}{$lang['strtype']}{$lang['strlength']}{$lang['strcomment']}
", $i + 1, ". _maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['field'][$i]), "\" />\n\t\t\t\n\t\t\n\t\t\t\n\t\t
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + + break; + case 3: + global $data, $lang; + + // Check inputs + $fields = trim($_REQUEST['fields']); + if (trim($_REQUEST['name']) == '') { + $_REQUEST['stage'] = 1; + doCreateComposite($lang['strtypeneedsname']); + return; + } + elseif ($fields == '' || !is_numeric($fields) || $fields != (int)$fields || $fields <= 0) { + $_REQUEST['stage'] = 1; + doCreateComposite($lang['strtypeneedscols']); + return; + } + + $status = $data->createCompositeType($_REQUEST['name'], $_REQUEST['fields'], $_REQUEST['field'], + $_REQUEST['type'], $_REQUEST['array'], $_REQUEST['length'], $_REQUEST['colcomment'], + $_REQUEST['typcomment']); + + if ($status == 0) + doDefault($lang['strtypecreated']); + elseif ($status == -1) { + $_REQUEST['stage'] = 2; + doCreateComposite($lang['strtypeneedsfield']); + return; + } + else { + $_REQUEST['stage'] = 2; + doCreateComposite($lang['strtypecreatedbad']); + return; + } + break; + default: + echo "

{$lang['strinvalidparam']}

\n"; + } + } + + /** + * Displays a screen where they can enter a new enum type + */ + function doCreateEnum($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_REQUEST['stage'])) $_REQUEST['stage'] = 1; + if (!isset($_REQUEST['name'])) $_REQUEST['name'] = ''; + if (!isset($_REQUEST['values'])) $_REQUEST['values'] = ''; + if (!isset($_REQUEST['typcomment'])) $_REQUEST['typcomment'] = ''; + + switch ($_REQUEST['stage']) { + case 1: + $misc->printTrail('type'); + $misc->printTitle($lang['strcreateenumtype'], 'pg.type.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['name']), "\" />
{$lang['strnumvalues']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['values']), "\" />
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + break; + case 2: + global $lang; + + // Check inputs + $values = trim($_REQUEST['values']); + if (trim($_REQUEST['name']) == '') { + $_REQUEST['stage'] = 1; + doCreateEnum($lang['strtypeneedsname']); + return; + } + elseif ($values == '' || !is_numeric($values) || $values != (int)$values || $values < 1) { + $_REQUEST['stage'] = 1; + doCreateEnum($lang['strtypeneedsvals']); + return; + } + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreateenumtype'], 'pg.type.create'); + $misc->printMsg($msg); + + echo "
\n"; + + // Output table header + echo "\n"; + echo "\t\n"; + + for ($i = 0; $i < $_REQUEST['values']; $i++) { + if (!isset($_REQUEST['value'][$i])) $_REQUEST['value'][$i] = ''; + + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + } + echo "
{$lang['strvalue']}
", $i + 1, ". _maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['value'][$i]), "\" />
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + + break; + case 3: + global $data, $lang; + + // Check inputs + $values = trim($_REQUEST['values']); + if (trim($_REQUEST['name']) == '') { + $_REQUEST['stage'] = 1; + doCreateEnum($lang['strtypeneedsname']); + return; + } + elseif ($values == '' || !is_numeric($values) || $values != (int)$values || $values <= 0) { + $_REQUEST['stage'] = 1; + doCreateEnum($lang['strtypeneedsvals']); + return; + } + + $status = $data->createEnumType($_REQUEST['name'], $_REQUEST['value'], $_REQUEST['typcomment']); + + if ($status == 0) + doDefault($lang['strtypecreated']); + elseif ($status == -1) { + $_REQUEST['stage'] = 2; + doCreateEnum($lang['strtypeneedsvalue']); + return; + } + else { + $_REQUEST['stage'] = 2; + doCreateEnum($lang['strtypecreatedbad']); + return; + } + break; + default: + echo "

{$lang['strinvalidparam']}

\n"; + } + } + + /** + * Displays a screen where they can enter a new type + */ + function doCreate($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_POST['typname'])) $_POST['typname'] = ''; + if (!isset($_POST['typin'])) $_POST['typin'] = ''; + if (!isset($_POST['typout'])) $_POST['typout'] = ''; + if (!isset($_POST['typlen'])) $_POST['typlen'] = ''; + if (!isset($_POST['typdef'])) $_POST['typdef'] = ''; + if (!isset($_POST['typelem'])) $_POST['typelem'] = ''; + if (!isset($_POST['typdelim'])) $_POST['typdelim'] = ''; + if (!isset($_POST['typalign'])) $_POST['typalign'] = $data->typAlignDef; + if (!isset($_POST['typstorage'])) $_POST['typstorage'] = $data->typStorageDef; + + // Retrieve all functions and types in the database + $funcs = $data->getFunctions(true); + $types = $data->getTypes(true); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreatetype'], 'pg.type.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo ""; + echo "\n"; + echo ""; + echo "\n"; + echo "\n"; + echo "\n"; + echo ""; + echo "\n"; + echo ""; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_POST['typname']), "\" />
{$lang['strinputfn']}
{$lang['stroutputfn']}
major_version, '7.4', '<') ? ' required' : '') . "\">{$lang['strlength']}
{$lang['strdefault']}
{$lang['strelement']}
{$lang['strdelimiter']}
{$lang['stralignment']}
{$lang['strstorage']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new type in the database + */ + function doSaveCreate() { + global $data; + global $lang; + + // Check that they've given a name and a length. + // Note: We're assuming they've given in and out functions here + // which might be unwise... + if ($_POST['typname'] == '') doCreate($lang['strtypeneedsname']); + elseif ($_POST['typlen'] == '') doCreate($lang['strtypeneedslen']); + else { + $status = $data->createType( + $_POST['typname'], + $_POST['typin'], + $_POST['typout'], + $_POST['typlen'], + $_POST['typdef'], + $_POST['typelem'], + $_POST['typdelim'], + isset($_POST['typbyval']), + $_POST['typalign'], + $_POST['typstorage'] + ); + if ($status == 0) + doDefault($lang['strtypecreated']); + else + doCreate($lang['strtypecreatedbad']); + } + } + + /** + * Show default list of types in the database + */ + function doDefault($msg = '') { + global $data, $conf, $misc; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','types'); + $misc->printMsg($msg); + + $types = $data->getTypes(); + + $columns = array( + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('typname'), + 'url' => "types.php?action=properties&{$misc->href}&", + 'vars' => array('type' => 'basename'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('typowner'), + ), + 'flavour' => array( + 'title' => $lang['strflavor'], + 'field' => field('typtype'), + 'type' => 'verbatim', + 'params'=> array( + 'map' => array( + 'b' => $lang['strbasetype'], + 'c' => $lang['strcompositetype'], + 'd' => $lang['strdomain'], + 'p' => $lang['strpseudotype'], + 'e' => $lang['strenum'], + ), + 'align' => 'center', + ), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('typcomment'), + ), + ); + + if (!isset($types->fields['typtype'])) unset($columns['flavour']); + + $actions = array( + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'types.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'type' => field('basename') + ) + ) + ) + ), + ); + + $misc->printTable($types, $columns, $actions, 'types-types', $lang['strnotypes']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'types.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreatetype'] + ), + 'createcomp' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'types.php', + 'urlvars' => array ( + 'action' => 'create_comp', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreatecomptype'] + ), + 'createenum' => array ( + 'attr'=> array ( + 'href' => array( + 'url' => 'types.php', + 'urlvars' => array ( + 'action' => 'create_enum', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreateenumtype'] + ) + ); + + if (! $data->hasEnumTypes()) { + unset($navlinks['enum']); + } + + $misc->printNavLinks($navlinks, 'types-types', get_defined_vars()); + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $types = $data->getTypes(); + + $reqvars = $misc->getRequestVars('type'); + + $attrs = array( + 'text' => field('typname'), + 'icon' => 'Type', + 'toolTip'=> field('typcomment'), + 'action' => url('types.php', + $reqvars, + array( + 'action' => 'properties', + 'type' => field('basename') + ) + ) + ); + + $misc->printTree($types, $attrs, 'types'); + exit; + } + + if ($action == 'tree') doTree(); + + $misc->printHeader($lang['strtypes']); + $misc->printBody(); + + switch ($action) { + case 'create_comp': + if (isset($_POST['cancel'])) doDefault(); + else doCreateComposite(); + break; + case 'create_enum': + if (isset($_POST['cancel'])) doDefault(); + else doCreateEnum(); + break; + case 'save_create': + if (isset($_POST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['cancel'])) doDefault(); + else doDrop(false); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'properties': + doProperties(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/users.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/users.php new file mode 100644 index 00000000..11775ea5 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/users.php @@ -0,0 +1,415 @@ +getServerInfo(); + + $userdata = $data->getUser($server_info['username']); + $_REQUEST['user'] = $server_info['username']; + + $misc->printTrail('user'); + $misc->printTabs('server','account'); + $misc->printMsg($msg); + + if ($userdata->recordCount() > 0) { + $userdata->fields['usesuper'] = $data->phpBool($userdata->fields['usesuper']); + $userdata->fields['usecreatedb'] = $data->phpBool($userdata->fields['usecreatedb']); + echo "\n"; + echo ""; + echo ""; + echo "\n"; + echo "\n\t\n"; + echo "\t\n"; + echo "\t\n"; + echo "\t\n"; + echo "\t\n"; + echo "\n
{$lang['strusername']}{$lang['strsuper']}{$lang['strcreatedb']}{$lang['strexpires']}{$lang['strsessiondefaults']}
", $misc->printVal($userdata->fields['usename']), "", $misc->printVal($userdata->fields['usesuper'], 'yesno'), "", $misc->printVal($userdata->fields['usecreatedb'], 'yesno'), "", ($userdata->fields['useexpires'] == 'infinity' || is_null($userdata->fields['useexpires']) ? $lang['strnever'] : $misc->printVal($userdata->fields['useexpires'])), "", $misc->printVal($userdata->fields['useconfig']), "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + + $misc->printNavLinks(array ('changepassword' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'users.php', + 'urlvars' => array ( + 'action' => 'confchangepassword', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strchangepassword'] + )), 'users-account', get_defined_vars()); + } + + /** + * Show confirmation of change password and actually change password + */ + function doChangePassword($confirm, $msg = '') { + global $data, $misc; + global $lang, $conf; + + $server_info = $misc->getServerInfo(); + + if ($confirm) { + $_REQUEST['user'] = $server_info['username']; + $misc->printTrail('user'); + $misc->printTitle($lang['strchangepassword'],'pg.user.alter'); + $misc->printMsg($msg); + + if (!isset($_POST['password'])) $_POST['password'] = ''; + if (!isset($_POST['confirm'])) $_POST['confirm'] = ''; + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strpassword']}
{$lang['strconfirm']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + } + else { + // Check that password is minimum length + if (strlen($_POST['password']) < $conf['min_password_length']) + doChangePassword(true, $lang['strpasswordshort']); + // Check that password matches confirmation password + elseif ($_POST['password'] != $_POST['confirm']) + doChangePassword(true, $lang['strpasswordconfirm']); + else { + $status = $data->changePassword($server_info['username'], + $_POST['password']); + if ($status == 0) + doAccount($lang['strpasswordchanged']); + else + doAccount($lang['strpasswordchangedbad']); + } + } + } + + /** + * Function to allow editing of a user + */ + function doEdit($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('user'); + $misc->printTitle($lang['stralter'],'pg.user.alter'); + $misc->printMsg($msg); + + $userdata = $data->getUser($_REQUEST['username']); + + if ($userdata->recordCount() > 0) { + $server_info = $misc->getServerInfo(); + $canRename = $data->hasUserRename() && ($_REQUEST['username'] != $server_info['username']); + $userdata->fields['usesuper'] = $data->phpBool($userdata->fields['usesuper']); + $userdata->fields['usecreatedb'] = $data->phpBool($userdata->fields['usecreatedb']); + + if (!isset($_POST['formExpires'])){ + if ($canRename) $_POST['newname'] = $userdata->fields['usename']; + if ($userdata->fields['usesuper']) $_POST['formSuper'] = ''; + if ($userdata->fields['usecreatedb']) $_POST['formCreateDB'] = ''; + $_POST['formExpires'] = $userdata->fields['useexpires'] == 'infinity' ? '' : $userdata->fields['useexpires']; + $_POST['formPassword'] = ''; + } + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strusername']}", ($canRename ? "_maxNameLen}\" value=\"" . htmlspecialchars($_POST['newname']) . "\" />" : $misc->printVal($userdata->fields['usename'])), "
{$lang['strexpires']}
{$lang['strpassword']}
{$lang['strconfirm']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Function to save after editing a user + */ + function doSaveEdit() { + global $data, $lang; + + // Check name and password + if (isset($_POST['newname']) && $_POST['newname'] == '') + doEdit($lang['struserneedsname']); + else if ($_POST['formPassword'] != $_POST['formConfirm']) + doEdit($lang['strpasswordconfirm']); + else { + if (isset($_POST['newname'])) $status = $data->setRenameUser($_POST['username'], $_POST['formPassword'], isset($_POST['formCreateDB']), isset($_POST['formSuper']), $_POST['formExpires'], $_POST['newname']); + else $status = $data->setUser($_POST['username'], $_POST['formPassword'], isset($_POST['formCreateDB']), isset($_POST['formSuper']), $_POST['formExpires']); + if ($status == 0) + doDefault($lang['struserupdated']); + else + doEdit($lang['struserupdatedbad']); + } + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang; + + if ($confirm) { + $misc->printTrail('user'); + $misc->printTitle($lang['strdrop'],'pg.user.drop'); + + echo "

", sprintf($lang['strconfdropuser'], $misc->printVal($_REQUEST['username'])), "

\n"; + + echo "
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + $status = $data->dropUser($_REQUEST['username']); + if ($status == 0) + doDefault($lang['struserdropped']); + else + doDefault($lang['struserdroppedbad']); + } + } + + /** + * Displays a screen where they can enter a new user + */ + function doCreate($msg = '') { + global $data, $misc, $username; + global $lang; + + if (!isset($_POST['formUsername'])) $_POST['formUsername'] = ''; + if (!isset($_POST['formPassword'])) $_POST['formPassword'] = ''; + if (!isset($_POST['formConfirm'])) $_POST['formConfirm'] = ''; + if (!isset($_POST['formExpires'])) $_POST['formExpires'] = ''; + + $misc->printTrail('server'); + $misc->printTitle($lang['strcreateuser'],'pg.user.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strusername']}_maxNameLen}\" name=\"formUsername\" value=\"", htmlspecialchars($_POST['formUsername']), "\" />
{$lang['strpassword']}
{$lang['strconfirm']}
{$lang['strexpires']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new user in the database + */ + function doSaveCreate() { + global $data; + global $lang; + + // Check data + if ($_POST['formUsername'] == '') + doCreate($lang['struserneedsname']); + else if ($_POST['formPassword'] != $_POST['formConfirm']) + doCreate($lang['strpasswordconfirm']); + else { + $status = $data->createUser($_POST['formUsername'], $_POST['formPassword'], + isset($_POST['formCreateDB']), isset($_POST['formSuper']), $_POST['formExpires'], array()); + if ($status == 0) + doDefault($lang['strusercreated']); + else + doCreate($lang['strusercreatedbad']); + } + } + + /** + * Show default list of users in the database + */ + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + function renderUseExpires($val) { + global $lang; + return $val == 'infinity' ? $lang['strnever'] : htmlspecialchars($val); + } + + $misc->printTrail('server'); + $misc->printTabs('server','users'); + $misc->printMsg($msg); + + $users = $data->getUsers(); + + $columns = array( + 'user' => array( + 'title' => $lang['strusername'], + 'field' => field('usename'), + ), + 'superuser' => array( + 'title' => $lang['strsuper'], + 'field' => field('usesuper'), + 'type' => 'yesno', + ), + 'createdb' => array( + 'title' => $lang['strcreatedb'], + 'field' => field('usecreatedb'), + 'type' => 'yesno', + ), + 'expires' => array( + 'title' => $lang['strexpires'], + 'field' => field('useexpires'), + 'type' => 'callback', + 'params'=> array('function' => 'renderUseExpires', 'null' => $lang['strnever']), + ), + 'defaults' => array( + 'title' => $lang['strsessiondefaults'], + 'field' => field('useconfig'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + ); + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'users.php', + 'urlvars' => array ( + 'action' => 'edit', + 'username' => field('usename') + ) + ) + ) + ), + 'drop' => array( + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'users.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'username' => field('usename') + ) + ) + ) + ), + ); + + $misc->printTable($users, $columns, $actions, 'users-users', $lang['strnousers']); + + $misc->printNavLinks(array ('create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'users.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'] + ) + ) + ), + 'content' => $lang['strcreateuser'] + )), 'users-users', get_defined_vars()); + + } + + $misc->printHeader($lang['strusers']); + $misc->printBody(); + + switch ($action) { + case 'changepassword': + if (isset($_REQUEST['ok'])) doChangePassword(false); + else doAccount(); + break; + case 'confchangepassword': + doChangePassword(true); + break; + case 'account': + doAccount(); + break; + case 'save_create': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_REQUEST['cancel'])) doDefault(); + else doDrop(false); + break; + case 'confirm_drop': + doDrop(true); + break; + case 'save_edit': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveEdit(); + break; + case 'edit': + doEdit(); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/viewproperties.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/viewproperties.php new file mode 100644 index 00000000..950789b5 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/viewproperties.php @@ -0,0 +1,564 @@ +setView($_POST['view'], $_POST['formDefinition'], $_POST['formComment']); + if ($status == 0) + doDefinition($lang['strviewupdated']); + else + doEdit($lang['strviewupdatedbad']); + } + + /** + * Function to allow editing of a view + */ + function doEdit($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('view'); + $misc->printTitle($lang['stredit'],'pg.view.alter'); + $misc->printMsg($msg); + + $viewdata = $data->getView($_REQUEST['view']); + + if ($viewdata->recordCount() > 0) { + + if (!isset($_POST['formDefinition'])) { + $_POST['formDefinition'] = $viewdata->fields['vwdefinition']; + $_POST['formComment'] = $viewdata->fields['relcomment']; + } + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strdefinition']}
{$lang['strcomment']}
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + + /** + * Allow the dumping of the data "in" a view + * NOTE:: PostgreSQL doesn't currently support dumping the data in a view + * so I have disabled the data related parts for now. In the future + * we should allow it conditionally if it becomes supported. This is + * a SMOP since it is based on pg_dump version not backend version. + */ + function doExport($msg = '') { + global $data, $misc; + global $lang; + + $misc->printTrail('view'); + $misc->printTabs('view','export'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\n"; + // Data only + echo "\n"; + + // Structure only + echo "\n"; + echo "\n\n"; + // Structure and data + echo "\n"; + echo "
{$lang['strformat']}{$lang['stroptions']}
\n"; + + echo "

{$lang['stroptions']}

\n"; + echo "

\n"; + echo "

\n"; + + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Show definition for a view + */ + function doDefinition($msg = '') { + global $data, $misc; + global $lang; + + // Get view + $vdata = $data->getView($_REQUEST['view']); + + $misc->printTrail('view'); + $misc->printTabs('view','definition'); + $misc->printMsg($msg); + + if ($vdata->recordCount() > 0) { + // Show comment if any + if ($vdata->fields['relcomment'] !== null) + echo "

", $misc->printVal($vdata->fields['relcomment']), "

\n"; + + echo "\n"; + echo "\n"; + echo "\n"; + echo "
{$lang['strdefinition']}
", $misc->printVal($vdata->fields['vwdefinition']), "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + + $misc->printNavLinks(array ( 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'viewproperties.php', + 'urlvars' => array ( + 'action' => 'edit', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'] + ) + ) + ), + 'content' => $lang['stralter'] + )), 'viewproperties-definition', get_defined_vars()); + } + + /** + * Displays a screen where they can alter a column in a view + */ + function doProperties($msg = '') { + global $data, $misc; + global $lang; + + if (!isset($_REQUEST['stage'])) $_REQUEST['stage'] = 1; + + switch ($_REQUEST['stage']) { + case 1: + global $lang; + + $misc->printTrail('column'); + $misc->printTitle($lang['stralter'],'pg.column.alter'); + $misc->printMsg($msg); + + echo "
\n"; + + // Output view header + echo "\n"; + echo ""; + echo ""; + + $column = $data->getTableAttributes($_REQUEST['view'], $_REQUEST['column']); + + if (!isset($_REQUEST['default'])) { + $_REQUEST['field'] = $column->fields['attname']; + $_REQUEST['default'] = $_REQUEST['olddefault'] = $column->fields['adsrc']; + $_REQUEST['comment'] = $column->fields['comment']; + } + + echo ""; + + echo ""; + echo ""; + echo ""; + + echo "
{$lang['strname']}{$lang['strtype']}{$lang['strdefault']}{$lang['strcomment']}
", $misc->printVal($data->formatType($column->fields['type'], $column->fields['atttypmod'])), "
\n"; + echo "

\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "

\n"; + echo "
\n"; + + break; + case 2: + global $data, $lang; + + // Check inputs + if (trim($_REQUEST['field']) == '') { + $_REQUEST['stage'] = 1; + doProperties($lang['strcolneedsname']); + return; + } + + // Alter the view column + $status = $data->alterColumn($_REQUEST['view'], $_REQUEST['column'], $_REQUEST['field'], + false, false, $_REQUEST['default'], $_REQUEST['olddefault'], + '', '', '', '', $_REQUEST['comment']); + if ($status == 0) + doDefault($lang['strcolumnaltered']); + else { + $_REQUEST['stage'] = 1; + doProperties($lang['strcolumnalteredbad']); + return; + } + break; + default: + echo "

{$lang['strinvalidparam']}

\n"; + } + } + + function doAlter($confirm = false, $msg = '') { + if ($confirm) { + global $data, $misc, $lang; + + $misc->printTrail('view'); + $misc->printTitle($lang['stralter'], 'pg.view.alter'); + $misc->printMsg($msg); + + // Fetch view info + $view = $data->getView($_REQUEST['view']); + + if ($view->recordCount() > 0) { + if (!isset($_POST['name'])) $_POST['name'] = $view->fields['relname']; + if (!isset($_POST['owner'])) $_POST['owner'] = $view->fields['relowner']; + if (!isset($_POST['newschema'])) $_POST['newschema'] = $view->fields['nspname']; + if (!isset($_POST['comment'])) $_POST['comment'] = $view->fields['relcomment']; + + echo "
\n"; + echo "\n"; + echo "\n"; + echo "\n"; + + if ($data->isSuperUser()) { + + // Fetch all users + $users = $data->getUsers(); + + echo "\n"; + echo "\n"; + } + + if ($data->hasAlterTableSchema()) { + $schemas = $data->getSchemas(); + echo "\n"; + echo "\n"; + } + + echo "\n"; + echo "\n"; + echo "
{$lang['strname']}"; + echo "_maxNameLen}\" value=\"", + htmlspecialchars($_POST['name']), "\" />
{$lang['strowner']}
{$lang['strschema']}
{$lang['strcomment']}"; + echo "
\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "

\n"; + echo "

\n"; + echo "
\n"; + } + else echo "

{$lang['strnodata']}

\n"; + } + else{ + global $data, $lang, $_reload_browser, $misc; + + // For databases that don't allow owner change + if (!isset($_POST['owner'])) $_POST['owner'] = ''; + if (!isset($_POST['newschema'])) $_POST['newschema'] = null; + + $status = $data->alterView($_POST['view'], $_POST['name'], $_POST['owner'], $_POST['newschema'], $_POST['comment']); + if ($status == 0) { + // If view has been renamed, need to change to the new name and + // reload the browser frame. + if ($_POST['view'] != $_POST['name']) { + // Jump them to the new view name + $_REQUEST['view'] = $_POST['name']; + // Force a browser reload + $_reload_browser = true; + } + // If schema has changed, need to change to the new schema and reload the browser + if (!empty($_POST['newschema']) && ($_POST['newschema'] != $data->_schema)) { + // Jump them to the new sequence schema + $misc->setCurrentSchema($_POST['newschema']); + $_reload_browser = true; + } + doDefault($lang['strviewaltered']); + } + else doAlter(true, $lang['strviewalteredbad']); + } + } + + function doTree () { + global $misc, $data; + + $reqvars = $misc->getRequestVars('column'); + $columns = $data->getTableAttributes($_REQUEST['view']); + + $attrs = array ( + 'text' => field('attname'), + 'action' => url('colproperties.php', + $reqvars, + array( + 'view' => $_REQUEST['view'], + 'column' => field('attname') + ) + ), + 'icon' => 'Column', + 'iconAction' => url('display.php', + $reqvars, + array( + 'view' => $_REQUEST['view'], + 'column' => field('attname'), + 'query' => replace( + 'SELECT "%column%", count(*) AS "count" FROM %view% GROUP BY "%column%" ORDER BY "%column%"', + array ( + '%column%' => field('attname'), + '%view%' => $_REQUEST['view'] + ) + ) + ) + ), + 'toolTip'=> field('comment') + ); + + $misc->printTree($columns, $attrs, 'viewcolumns'); + + exit; + } + + if ($action == 'tree') doTree(); + + /** + * Show view definition and virtual columns + */ + function doDefault($msg = '') { + global $data, $misc; + global $lang; + + function attPre(&$rowdata) { + global $data; + $rowdata->fields['+type'] = $data->formatType($rowdata->fields['type'], $rowdata->fields['atttypmod']); + } + + $misc->printTrail('view'); + $misc->printTabs('view','columns'); + $misc->printMsg($msg); + + // Get view + $vdata = $data->getView($_REQUEST['view']); + // Get columns (using same method for getting a view) + $attrs = $data->getTableAttributes($_REQUEST['view']); + + // Show comment if any + if ($vdata->fields['relcomment'] !== null) + echo "

", $misc->printVal($vdata->fields['relcomment']), "

\n"; + + $columns = array( + 'column' => array( + 'title' => $lang['strcolumn'], + 'field' => field('attname'), + 'url' => "colproperties.php?subject=column&{$misc->href}&view=".urlencode($_REQUEST['view'])."&", + 'vars' => array('column' => 'attname'), + ), + 'type' => array( + 'title' => $lang['strtype'], + 'field' => field('+type'), + ), + 'default' => array( + 'title' => $lang['strdefault'], + 'field' => field('adsrc'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('comment'), + ), + ); + + $actions = array( + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'viewproperties.php', + 'urlvars' => array ( + 'action' => 'properties', + 'view' => $_REQUEST['view'], + 'column' => field('attname') + ) + ) + ) + ), + ); + + $misc->printTable($attrs, $columns, $actions, 'viewproperties-viewproperties', null, 'attPre'); + + echo "
\n"; + + $navlinks = array ( + 'browse' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'], + 'subject' => 'view', + 'return' => 'view' + ) + ) + ), + 'content' => $lang['strbrowse'] + ), + 'select' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array ( + 'action' => 'confselectrows', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'] + ) + ) + ), + 'content' => $lang['strselect'] + ), + 'drop' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'] + ) + ) + ), + 'content' => $lang['strdrop'] + ), + 'alter' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'viewproperties.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'], + 'view' => $_REQUEST['view'] + ) + ) + ), + 'content' => $lang['stralter'] + ) + ); + + $misc->printNavLinks($navlinks, 'viewproperties-viewproperties', get_defined_vars()); + } + + $misc->printHeader($lang['strviews'] . ' - ' . $_REQUEST['view']); + $misc->printBody(); + + switch ($action) { + case 'save_edit': + if (isset($_POST['cancel'])) doDefinition(); + else doSaveEdit(); + break; + case 'edit': + doEdit(); + break; + case 'export': + doExport(); + break; + case 'definition': + doDefinition(); + break; + case 'properties': + if (isset($_POST['cancel'])) doDefault(); + else doProperties(); + break; + case 'alter': + if (isset($_POST['alter'])) doAlter(false); + else doDefault(); + break; + case 'confirm_alter': + doAlter(true); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/views.php b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/views.php new file mode 100644 index 00000000..b60b0947 --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/views.php @@ -0,0 +1,787 @@ +printTrail('view'); + $misc->printTabs('view','select'); + $misc->printMsg($msg); + + $attrs = $data->getTableAttributes($_REQUEST['view']); + + echo "
\n"; + if ($attrs->recordCount() > 0) { + // JavaScript for select all feature + echo "\n"; + + echo "\n"; + + // Output table header + echo ""; + echo ""; + echo ""; + + $i = 0; + while (!$attrs->EOF) { + $attrs->fields['attnotnull'] = $data->phpBool($attrs->fields['attnotnull']); + // Set up default value if there isn't one already + if (!isset($_REQUEST['values'][$attrs->fields['attname']])) + $_REQUEST['values'][$attrs->fields['attname']] = null; + if (!isset($_REQUEST['ops'][$attrs->fields['attname']])) + $_REQUEST['ops'][$attrs->fields['attname']] = null; + // Continue drawing row + $id = (($i % 2) == 0 ? '1' : '2'); + echo "\n"; + echo ""; + echo ""; + echo ""; + echo "\n"; + echo ""; + echo "\n"; + $i++; + $attrs->moveNext(); + } + // Select all checkbox + echo ""; + echo "
{$lang['strshow']}{$lang['strcolumn']}{$lang['strtype']}{$lang['stroperator']}{$lang['strvalue']}
"; + echo "fields['attname']), "]\"", + isset($_REQUEST['show'][$attrs->fields['attname']]) ? ' checked="checked"' : '', " />", $misc->printVal($attrs->fields['attname']), "", $misc->printVal($data->formatType($attrs->fields['type'], $attrs->fields['atttypmod'])), ""; + echo "", $data->printField("values[{$attrs->fields['attname']}]", + $_REQUEST['values'][$attrs->fields['attname']], $attrs->fields['type']), "
\n"; + } + else echo "

{$lang['strinvalidparam']}

\n"; + + echo "

\n"; + echo "\n"; + echo "\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + else { + if (!isset($_POST['show'])) $_POST['show'] = array(); + if (!isset($_POST['values'])) $_POST['values'] = array(); + if (!isset($_POST['nulls'])) $_POST['nulls'] = array(); + + // Verify that they haven't supplied a value for unary operators + foreach ($_POST['ops'] as $k => $v) { + if ($data->selectOps[$v] == 'p' && $_POST['values'][$k] != '') { + doSelectRows(true, $lang['strselectunary']); + return; + } + } + + if (sizeof($_POST['show']) == 0) + doSelectRows(true, $lang['strselectneedscol']); + else { + // Generate query SQL + $query = $data->getSelectSQL($_REQUEST['view'], array_keys($_POST['show']), + $_POST['values'], $_POST['ops']); + $_REQUEST['query'] = $query; + $_REQUEST['return'] = "schema"; + $_no_output = true; + include('./display.php'); + exit; + } + } + + } + + /** + * Show confirmation of drop and perform actual drop + */ + function doDrop($confirm) { + global $data, $misc; + global $lang, $_reload_browser; + + if (empty($_REQUEST['view']) && empty($_REQUEST['ma'])) { + doDefault($lang['strspecifyviewtodrop']); + exit(); + } + + if ($confirm) { + $misc->printTrail('view'); + $misc->printTitle($lang['strdrop'],'pg.view.drop'); + + echo "
\n"; + + //If multi drop + if (isset($_REQUEST['ma'])) { + foreach($_REQUEST['ma'] as $v) { + $a = unserialize(htmlspecialchars_decode($v, ENT_QUOTES)); + echo "

", sprintf($lang['strconfdropview'], $misc->printVal($a['view'])), "

\n"; + echo '\n"; + } + } + else { + echo "

", sprintf($lang['strconfdropview'], $misc->printVal($_REQUEST['view'])), "

\n"; + echo "\n"; + } + + echo "\n"; + + echo $misc->form; + echo "

\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + else { + if (is_array($_POST['view'])) { + $msg = ''; + $status = $data->beginTransaction(); + if ($status == 0) { + foreach($_POST['view'] as $s) { + $status = $data->dropView($s, isset($_POST['cascade'])); + if ($status == 0) + $msg.= sprintf('%s: %s
', htmlentities($s, ENT_QUOTES, 'UTF-8'), $lang['strviewdropped']); + else { + $data->endTransaction(); + doDefault(sprintf('%s%s: %s
', $msg, htmlentities($s, ENT_QUOTES, 'UTF-8'), $lang['strviewdroppedbad'])); + return; + } + } + } + if($data->endTransaction() == 0) { + // Everything went fine, back to the Default page.... + $_reload_browser = true; + doDefault($msg); + } + else doDefault($lang['strviewdroppedbad']); + } + else{ + $status = $data->dropView($_POST['view'], isset($_POST['cascade'])); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strviewdropped']); + } + else + doDefault($lang['strviewdroppedbad']); + } + } + + } + + /** + * Sets up choices for table linkage, and which fields to select for the view we're creating + */ + function doSetParamsCreate($msg = '') { + global $data, $misc; + global $lang; + + // Check that they've chosen tables for the view definition + if (!isset($_POST['formTables']) ) doWizardCreate($lang['strviewneedsdef']); + else { + // Initialise variables + if (!isset($_REQUEST['formView'])) $_REQUEST['formView'] = ''; + if (!isset($_REQUEST['formComment'])) $_REQUEST['formComment'] = ''; + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreateviewwiz'], 'pg.view.create'); + $misc->printMsg($msg); + + $tblCount = sizeof($_POST['formTables']); + //unserialize our schema/table information and store in arrSelTables + for ($i = 0; $i < $tblCount; $i++) { + $arrSelTables[] = unserialize($_POST['formTables'][$i]); + } + + $linkCount = $tblCount; + + //get linking keys + $rsLinkKeys = $data->getLinkingKeys($arrSelTables); + $linkCount = $rsLinkKeys->recordCount() > $tblCount ? $rsLinkKeys->recordCount() : $tblCount; + + $arrFields = array(); //array that will hold all our table/field names + + //if we have schemas we need to specify the correct schema for each table we're retrieiving + //with getTableAttributes + $curSchema = $data->_schema; + for ($i = 0; $i < $tblCount; $i++) { + if ($data->_schema != $arrSelTables[$i]['schemaname']) { + $data->setSchema($arrSelTables[$i]['schemaname']); + } + + $attrs = $data->getTableAttributes($arrSelTables[$i]['tablename']); + while (!$attrs->EOF) { + $arrFields["{$arrSelTables[$i]['schemaname']}.{$arrSelTables[$i]['tablename']}.{$attrs->fields['attname']}"] = serialize(array( + 'schemaname' => $arrSelTables[$i]['schemaname'], + 'tablename' => $arrSelTables[$i]['tablename'], + 'fieldname' => $attrs->fields['attname']) + ); + $attrs->moveNext(); + } + + $data->setSchema($curSchema); + } + asort($arrFields); + + echo "
\n"; + echo "\n"; + echo ""; + echo "\n\n\n"; + echo ""; + echo "\n\n\n"; + echo "
{$lang['strviewname']}
\n"; + // View name + echo "_maxNameLen}\" />\n"; + echo "
{$lang['strcomment']}
\n"; + // View comments + echo "\n"; + echo "
\n"; + + // Output selector for fields to be retrieved from view + echo "\n"; + echo ""; + echo "\n\n"; + echo "
{$lang['strcolumns']}
\n"; + echo GUI::printCombo($arrFields, 'formFields[]', false, '', true); + echo "
"; + echo "
"; + echo "

"; + + // Output the Linking keys combo boxes + echo "\n"; + echo ""; + $rowClass = 'data1'; + for ($i = 0; $i < $linkCount; $i++) { + // Initialise variables + if (!isset($formLink[$i]['operator'])) $formLink[$i]['operator'] = 'INNER JOIN'; + echo "\n\n\n"; + $rowClass = $rowClass == 'data1' ? 'data2' : 'data1'; + } + echo "
{$lang['strviewlink']}
\n"; + + if (!$rsLinkKeys->EOF) { + $curLeftLink = htmlspecialchars(serialize(array('schemaname' => $rsLinkKeys->fields['p_schema'], 'tablename' => $rsLinkKeys->fields['p_table'], 'fieldname' => $rsLinkKeys->fields['p_field']) ) ); + $curRightLink = htmlspecialchars(serialize(array('schemaname' => $rsLinkKeys->fields['f_schema'], 'tablename' => $rsLinkKeys->fields['f_table'], 'fieldname' => $rsLinkKeys->fields['f_field']) ) ); + $rsLinkKeys->moveNext(); + } + else { + $curLeftLink = ''; + $curRightLink = ''; + } + + echo GUI::printCombo($arrFields, "formLink[$i][leftlink]", true, $curLeftLink, false ); + echo GUI::printCombo($data->joinOps, "formLink[$i][operator]", true, $formLink[$i]['operator']); + echo GUI::printCombo($arrFields, "formLink[$i][rightlink]", true, $curRightLink, false ); + echo "
\n
\n"; + + // Build list of available operators (infix only) + $arrOperators = array(); + foreach ($data->selectOps as $k => $v) { + if ($v == 'i') $arrOperators[$k] = $k; + } + + // Output additional conditions, note that this portion of the wizard treats the right hand side as literal values + //(not as database objects) so field names will be treated as strings, use the above linking keys section to perform joins + echo "\n"; + echo ""; + $rowClass = 'data1'; + for ($i = 0; $i < $linkCount; $i++) { + echo "\n\n\n"; + $rowClass = $rowClass == 'data1' ? 'data2' : 'data1'; + } + echo "
{$lang['strviewconditions']}
\n"; + echo GUI::printCombo($arrFields, "formCondition[$i][field]"); + echo GUI::printCombo($arrOperators, "formCondition[$i][operator]", false, false); + echo "\n"; + echo "
\n"; + echo "

\n"; + + foreach ($arrSelTables as $curTable) { + echo "\n"; + } + + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + } + + /** + * Display a wizard where they can enter a new view + */ + function doWizardCreate($msg = '') { + global $data, $misc; + global $lang; + + $tables = $data->getTables(true); + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreateviewwiz'], 'pg.view.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo ""; + echo "\n\n\n"; + echo "
{$lang['strtables']}
\n"; + + $arrTables = array(); + while (!$tables->EOF) { + $arrTmp = array(); + $arrTmp['schemaname'] = $tables->fields['nspname']; + $arrTmp['tablename'] = $tables->fields['relname']; + $arrTables[$tables->fields['nspname'] . '.' . $tables->fields['relname']] = serialize($arrTmp); + $tables->moveNext(); + } + echo GUI::printCombo($arrTables, 'formTables[]', false, '', true); + + echo "
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Displays a screen where they can enter a new view + */ + function doCreate($msg = '') { + global $data, $misc, $conf; + global $lang; + + if (!isset($_REQUEST['formView'])) $_REQUEST['formView'] = ''; + if (!isset($_REQUEST['formDefinition'])) { + if (isset($_SESSION['sqlquery'])) + $_REQUEST['formDefinition'] = $_SESSION['sqlquery']; + else $_REQUEST['formDefinition'] = 'SELECT '; + } + if (!isset($_REQUEST['formComment'])) $_REQUEST['formComment'] = ''; + + $misc->printTrail('schema'); + $misc->printTitle($lang['strcreateview'], 'pg.view.create'); + $misc->printMsg($msg); + + echo "
\n"; + echo "\n"; + echo "\t\n\t\t\n"; + echo "\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\n\t\n"; + echo "\t\n\t\t\n"; + echo "\t\t\n\t\n"; + echo "
{$lang['strname']}_maxNameLen}\" value=\"", + htmlspecialchars($_REQUEST['formView']), "\" />
{$lang['strdefinition']}
{$lang['strcomment']}
\n"; + echo "

\n"; + echo $misc->form; + echo "\n"; + echo "

\n"; + echo "
\n"; + } + + /** + * Actually creates the new view in the database + */ + function doSaveCreate() { + global $data, $lang, $_reload_browser; + + // Check that they've given a name and a definition + if ($_POST['formView'] == '') doCreate($lang['strviewneedsname']); + elseif ($_POST['formDefinition'] == '') doCreate($lang['strviewneedsdef']); + else { + $status = $data->createView($_POST['formView'], $_POST['formDefinition'], false, $_POST['formComment']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strviewcreated']); + } + else + doCreate($lang['strviewcreatedbad']); + } + } + + /** + * Actually creates the new wizard view in the database + */ + function doSaveCreateWiz() { + global $data, $lang, $_reload_browser; + + // Check that they've given a name and fields they want to select + + if (!strlen($_POST['formView']) ) doSetParamsCreate($lang['strviewneedsname']); + else if (!isset($_POST['formFields']) || !count($_POST['formFields']) ) doSetParamsCreate($lang['strviewneedsfields']); + else { + $selFields = ''; + + if (! empty($_POST['dblFldMeth']) ) + $tmpHsh = array(); + + foreach ($_POST['formFields'] as $curField) { + $arrTmp = unserialize($curField); + $data->fieldArrayClean($arrTmp); + if (! empty($_POST['dblFldMeth']) ) { // doublon control + if (empty($tmpHsh[$arrTmp['fieldname']])) { // field does not exist + $selFields .= "\"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\".\"{$arrTmp['fieldname']}\", "; + $tmpHsh[$arrTmp['fieldname']] = 1; + } else if ($_POST['dblFldMeth'] == 'rename') { // field exist and must be renamed + $tmpHsh[$arrTmp['fieldname']]++; + $selFields .= "\"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\".\"{$arrTmp['fieldname']}\" AS \"{$arrTmp['schemaname']}_{$arrTmp['tablename']}_{$arrTmp['fieldname']}{$tmpHsh[$arrTmp['fieldname']]}\", "; + } + /* field already exist, just ignore this one */ + } else { // no doublon control + $selFields .= "\"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\".\"{$arrTmp['fieldname']}\", "; + } + } + + $selFields = substr($selFields, 0, -2); + unset($arrTmp, $tmpHsh); + $linkFields = ''; + + // If we have links, out put the JOIN ... ON statements + if (is_array($_POST['formLink']) ) { + // Filter out invalid/blank entries for our links + $arrLinks = array(); + foreach ($_POST['formLink'] as $curLink) { + if (strlen($curLink['leftlink']) && strlen($curLink['rightlink']) && strlen($curLink['operator'])) { + $arrLinks[] = $curLink; + } + } + // We must perform some magic to make sure that we have a valid join order + $count = sizeof($arrLinks); + $arrJoined = array(); + $arrUsedTbls = array(); + + // If we have at least one join condition, output it + if ($count > 0) { + $j = 0; + while ($j < $count) { + foreach ($arrLinks as $curLink) { + + $arrLeftLink = unserialize($curLink['leftlink']); + $arrRightLink = unserialize($curLink['rightlink']); + $data->fieldArrayClean($arrLeftLink); + $data->fieldArrayClean($arrRightLink); + + $tbl1 = "\"{$arrLeftLink['schemaname']}\".\"{$arrLeftLink['tablename']}\""; + $tbl2 = "\"{$arrRightLink['schemaname']}\".\"{$arrRightLink['tablename']}\""; + + if ( (!in_array($curLink, $arrJoined) && in_array($tbl1, $arrUsedTbls)) || !count($arrJoined) ) { + + // Make sure for multi-column foreign keys that we use a table alias tables joined to more than once + // This can (and should be) more optimized for multi-column foreign keys + $adj_tbl2 = in_array($tbl2, $arrUsedTbls) ? "$tbl2 AS alias_ppa_" . mktime() : $tbl2; + + $linkFields .= strlen($linkFields) ? "{$curLink['operator']} $adj_tbl2 ON (\"{$arrLeftLink['schemaname']}\".\"{$arrLeftLink['tablename']}\".\"{$arrLeftLink['fieldname']}\" = \"{$arrRightLink['schemaname']}\".\"{$arrRightLink['tablename']}\".\"{$arrRightLink['fieldname']}\") " + : "$tbl1 {$curLink['operator']} $adj_tbl2 ON (\"{$arrLeftLink['schemaname']}\".\"{$arrLeftLink['tablename']}\".\"{$arrLeftLink['fieldname']}\" = \"{$arrRightLink['schemaname']}\".\"{$arrRightLink['tablename']}\".\"{$arrRightLink['fieldname']}\") "; + + $arrJoined[] = $curLink; + if (!in_array($tbl1, $arrUsedTbls) ) $arrUsedTbls[] = $tbl1; + if (!in_array($tbl2, $arrUsedTbls) ) $arrUsedTbls[] = $tbl2; + } + } + $j++; + } + } + } + + //if linkfields has no length then either _POST['formLink'] was not set, or there were no join conditions + //just select from all seleted tables - a cartesian join do a + if (!strlen($linkFields) ) { + foreach ($_POST['formTables'] as $curTable) { + $arrTmp = unserialize($curTable); + $data->fieldArrayClean($arrTmp); + $linkFields .= strlen($linkFields) ? ", \"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\"" : "\"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\""; + } + } + + $addConditions = ''; + if (is_array($_POST['formCondition']) ) { + foreach ($_POST['formCondition'] as $curCondition) { + if (strlen($curCondition['field']) && strlen($curCondition['txt']) ) { + $arrTmp = unserialize($curCondition['field']); + $data->fieldArrayClean($arrTmp); + $addConditions .= strlen($addConditions) ? " AND \"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\".\"{$arrTmp['fieldname']}\" {$curCondition['operator']} '{$curCondition['txt']}' " + : " \"{$arrTmp['schemaname']}\".\"{$arrTmp['tablename']}\".\"{$arrTmp['fieldname']}\" {$curCondition['operator']} '{$curCondition['txt']}' "; + } + } + } + + $viewQuery = "SELECT $selFields FROM $linkFields "; + + //add where from additional conditions + if (strlen($addConditions) ) $viewQuery .= ' WHERE ' . $addConditions; + + $status = $data->createView($_POST['formView'], $viewQuery, false, $_POST['formComment']); + if ($status == 0) { + $_reload_browser = true; + doDefault($lang['strviewcreated']); + } + else + doSetParamsCreate($lang['strviewcreatedbad']); + } + } + + /** + * Show default list of views in the database + */ + function doDefault($msg = '') { + global $data, $misc, $conf; + global $lang; + + $misc->printTrail('schema'); + $misc->printTabs('schema','views'); + $misc->printMsg($msg); + + $views = $data->getViews(); + + $columns = array( + 'view' => array( + 'title' => $lang['strview'], + 'field' => field('relname'), + 'url' => "redirect.php?subject=view&{$misc->href}&", + 'vars' => array('view' => 'relname'), + ), + 'owner' => array( + 'title' => $lang['strowner'], + 'field' => field('relowner'), + ), + 'actions' => array( + 'title' => $lang['stractions'], + ), + 'comment' => array( + 'title' => $lang['strcomment'], + 'field' => field('relcomment'), + ), + ); + + $actions = array( + 'multiactions' => array( + 'keycols' => array('view' => 'relname'), + 'url' => 'views.php', + ), + 'browse' => array( + 'content' => $lang['strbrowse'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'display.php', + 'urlvars' => array ( + 'action' => 'confselectrows', + 'subject' => 'view', + 'return' => 'schema', + 'view' => field('relname') + ) + ) + ) + ), + 'select' => array( + 'content' => $lang['strselect'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array ( + 'action' => 'confselectrows', + 'view' => field('relname') + ) + ) + ) + ), + +// Insert is possible if the relevant rule for the view has been created. +// 'insert' => array( +// 'title' => $lang['strinsert'], +// 'url' => "views.php?action=confinsertrow&{$misc->href}&", +// 'vars' => array('view' => 'relname'), + // ), + + 'alter' => array( + 'content' => $lang['stralter'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'viewproperties.php', + 'urlvars' => array ( + 'action' => 'confirm_alter', + 'view' => field('relname') + ) + ) + ) + ), + 'drop' => array( + 'multiaction' => 'confirm_drop', + 'content' => $lang['strdrop'], + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array ( + 'action' => 'confirm_drop', + 'view' => field('relname') + ) + ) + ) + ), + ); + + $misc->printTable($views, $columns, $actions, 'views-views', $lang['strnoviews']); + + $navlinks = array ( + 'create' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array ( + 'action' => 'create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreateview'] + ), + 'createwiz' => array ( + 'attr'=> array ( + 'href' => array ( + 'url' => 'views.php', + 'urlvars' => array ( + 'action' => 'wiz_create', + 'server' => $_REQUEST['server'], + 'database' => $_REQUEST['database'], + 'schema' => $_REQUEST['schema'] + ) + ) + ), + 'content' => $lang['strcreateviewwiz'] + ) + ); + $misc->printNavLinks($navlinks, 'views-views', get_defined_vars()); + + } + + /** + * Generate XML for the browser tree. + */ + function doTree() { + global $misc, $data; + + $views = $data->getViews(); + + $reqvars = $misc->getRequestVars('view'); + + $attrs = array( + 'text' => field('relname'), + 'icon' => 'View', + 'iconAction' => url('display.php', $reqvars, array('view' => field('relname'))), + 'toolTip'=> field('relcomment'), + 'action' => url('redirect.php', $reqvars, array('view' => field('relname'))), + 'branch' => url('views.php', $reqvars, + array ( + 'action' => 'subtree', + 'view' => field('relname') + ) + ) + ); + + $misc->printTree($views, $attrs, 'views'); + exit; + } + + function doSubTree() { + global $misc, $data; + + $tabs = $misc->getNavTabs('view'); + $items = $misc->adjustTabsForTree($tabs); + $reqvars = $misc->getRequestVars('view'); + + $attrs = array( + 'text' => field('title'), + 'icon' => field('icon'), + 'action' => url(field('url'), $reqvars, field('urlvars'), array('view' => $_REQUEST['view'])), + 'branch' => ifempty( + field('branch'), '', url(field('url'), field('urlvars'), $reqvars, + array( + 'action' => 'tree', + 'view' => $_REQUEST['view'] + ) + ) + ), + ); + + $misc->printTree($items, $attrs, 'view'); + exit; + } + + if ($action == 'tree') doTree(); + if ($action == 'subtree') dosubTree(); + + $misc->printHeader($lang['strviews']); + $misc->printBody(); + + switch ($action) { + case 'selectrows': + if (!isset($_REQUEST['cancel'])) doSelectRows(false); + else doDefault(); + break; + case 'confselectrows': + doSelectRows(true); + break; + case 'save_create_wiz': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveCreateWiz(); + break; + case 'wiz_create': + doWizardCreate(); + break; + case 'set_params_create': + if (isset($_POST['cancel'])) doDefault(); + else doSetParamsCreate(); + break; + case 'save_create': + if (isset($_REQUEST['cancel'])) doDefault(); + else doSaveCreate(); + break; + case 'create': + doCreate(); + break; + case 'drop': + if (isset($_POST['drop'])) doDrop(false); + else doDefault(); + break; + case 'confirm_drop': + doDrop(true); + break; + default: + doDefault(); + break; + } + + $misc->printFooter(); + +?> diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xloadtree2.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xloadtree2.js new file mode 100644 index 00000000..b36eed7e --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xloadtree2.js @@ -0,0 +1,507 @@ +/*----------------------------------------------------------------------------\ +| XLoadTree 2 PRE RELEASE | +| | +| This is a pre release and may not be redistributed. | +| Watch http://webfx.eae.net for the final version | +| | +|-----------------------------------------------------------------------------| +| Created by Erik Arvidsson & Emil A Eklund | +| (http://webfx.eae.net/contact.html#erik) | +| (http://webfx.eae.net/contact.html#emil) | +| For WebFX (http://webfx.eae.net/) | +|-----------------------------------------------------------------------------| +| A tree menu system for IE 5.5+, Mozilla 1.4+, Opera 7.5+ | +|-----------------------------------------------------------------------------| +| Copyright (c) 1999 - 2005 Erik Arvidsson & Emil A Eklund | +|-----------------------------------------------------------------------------| +| This software is provided "as is", without warranty of any kind, express or | +| implied, including but not limited to the warranties of merchantability, | +| fitness for a particular purpose and noninfringement. In no event shall the | +| authors or copyright holders be liable for any claim, damages or other | +| liability, whether in an action of contract, tort or otherwise, arising | +| from, out of or in connection with the software or the use or other | +| dealings in the software. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| This software is available under the three different licenses mentioned | +| below. To use this software you must chose, and qualify, for one of those. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| The WebFX Non-Commercial License http://webfx.eae.net/license.html | +| Permits anyone the right to use the software in a non-commercial context | +| free of charge. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| The WebFX Commercial license http://webfx.eae.net/commercial.html | +| Permits the license holder the right to use the software in a commercial | +| context. Such license must be specifically obtained, however it's valid for | +| any number of implementations of the licensed software. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| GPL - The GNU General Public License http://www.gnu.org/licenses/gpl.txt | +| Permits anyone the right to use and modify the software without limitations | +| as long as proper credits are given and the original and modified source | +| code are included. Requires that the final product, software derivate from | +| the original source or any software utilizing a GPL component, such as | +| this, is also licensed under the GPL license. | +|-----------------------------------------------------------------------------| +| 2004-02-21 | Pre release distributed to a few selected tester | +| 2005-06-06 | Removed dependency on XML Extras | +|-----------------------------------------------------------------------------| +| Dependencies: xtree2.js Supplies the tree control | +|-----------------------------------------------------------------------------| +| Created 2003-??-?? | All changes are in the log above. | Updated 2004-06-06 | +|-----------------------------------------------------------------------------| +| Note local changes have been made to allow Icons to have different links | +| than thier text label counterparts. Thanks to JGuillaume de Rorthais | +\----------------------------------------------------------------------------*/ + +webFXTreeConfig.loadingText = "Loading..."; +webFXTreeConfig.loadingIcon = "images/loading.gif"; +webFXTreeConfig.errorLoadingText = "Error Loading"; +webFXTreeConfig.errorIcon = "images/exclamation.16.png"; +webFXTreeConfig.reloadText = "Click to reload"; + + +function WebFXLoadTree(sText, sXmlSrc, oAction, sBehavior, sIcon, oIconAction, sOpenIcon) { + WebFXTree.call(this, sText, oAction, sBehavior, sIcon, oIconAction, sOpenIcon); + + // setup default property values + this.src = sXmlSrc; + this.loading = !sXmlSrc; + this.loaded = !sXmlSrc; + this.errorText = ""; + + if (this.src) { + /// add loading Item + this._loadingItem = WebFXLoadTree.createLoadingItem(); + this.add(this._loadingItem); + + if (this.getExpanded()) { + WebFXLoadTree.loadXmlDocument(this); + } + } +} + +WebFXLoadTree.createLoadingItem = function () { + return new WebFXTreeItem(webFXTreeConfig.loadingText, null, null, + webFXTreeConfig.loadingIcon); +}; + +_p = WebFXLoadTree.prototype = new WebFXTree; + +_p.setExpanded = function (b) { + WebFXTree.prototype.setExpanded.call(this, b); + + if (this.src && b) { + if (!this.loaded && !this.loading) { + // load + WebFXLoadTree.loadXmlDocument(this); + } + } +}; + +function WebFXLoadTreeItem(sText, sXmlSrc, oAction, eParent, sIcon, oIconAction, sOpenIcon) { + WebFXTreeItem.call(this, sText, oAction, eParent, sIcon, oIconAction, sOpenIcon); + +// setup default property values + this.src = sXmlSrc; + this.loading = !sXmlSrc; + this.loaded = !sXmlSrc; + this.errorText = ""; + + if (this.src) { + /// add loading Item + this._loadingItem = WebFXLoadTree.createLoadingItem(); + this.add(this._loadingItem); + + if (this.getExpanded()) { + WebFXLoadTree.loadXmlDocument(this); + } + } +} + +_p = WebFXLoadTreeItem.prototype = new WebFXTreeItem; + +_p.setExpanded = function (b) { + WebFXTreeItem.prototype.setExpanded.call(this, b); + + if (this.src && b) { + if (!this.loaded && !this.loading) { + // load + WebFXLoadTree.loadXmlDocument(this); + } + } +}; + +// reloads the src file if already loaded +WebFXLoadTree.prototype.reload = +_p.reload = function () { + // if loading do nothing + if (this.loaded) { + var t = this.getTree(); + var expanded = this.getExpanded(); + var sr = t.getSuspendRedraw(); + t.setSuspendRedraw(true); + + // remove + while (this.childNodes.length > 0) { + this.remove(this.childNodes[this.childNodes.length - 1]); + } + + this.loaded = false; + + this._loadingItem = WebFXLoadTree.createLoadingItem(); + this.add(this._loadingItem); + + if (expanded) { + this.setExpanded(true); + } + + t.setSuspendRedraw(sr); + this.update(); + } else if (this.open && !this.loading) { + WebFXLoadTree.loadXmlDocument(this); + } +}; + + + +WebFXLoadTree.prototype.setSrc = +_p.setSrc = function (sSrc) { + var oldSrc = this.src; + if (sSrc == oldSrc) return; + + var expanded = this.getExpanded(); + + // remove all + this._callSuspended(function () { + // remove + while (this.childNodes.length > 0) + this.remove(this.childNodes[this.childNodes.length - 1]); + }); + this.update(); + + this.loaded = false; + this.loading = false; + if (this._loadingItem) { + this._loadingItem.dispose(); + this._loadingItem = null; + } + this.src = sSrc; + + if (sSrc) { + this._loadingItem = WebFXLoadTree.createLoadingItem(); + this.add(this._loadingItem); + } + + this.setExpanded(expanded); +}; + +WebFXLoadTree.prototype.getSrc = +_p.getSrc = function () { + return this.src; +}; + +WebFXLoadTree.prototype.dispose = function () { + WebFXTree.prototype.dispose.call(this); + if (this._xmlHttp) + { + if (this._xmlHttp.dispose) { + this._xmlHttp.dispose(); + } + try { + this._xmlHttp.onreadystatechange = null; + this._xmlHttp.abort(); + } catch (ex) {} + this._xmlHttp = null; + } +}; + +_p.dispose = function () { + WebFXTreeItem.prototype.dispose.call(this); + if (this._xmlHttp) { + if (this._xmlHttp.dispose) { + this._xmlHttp.dispose(); + } + try { + this._xmlHttp.onreadystatechange = null; + this._xmlHttp.abort(); + } catch (ex) {} + this._xmlHttp = null; + } +}; + + +// The path is divided by '/' and the item is identified by the text +WebFXLoadTree.prototype.openPath = +_p.openPath = function (sPath, bSelect, bFocus) { + // remove any old pending paths to open + delete this._pathToOpen; + //delete this._pathToOpenById; + this._selectPathOnLoad = bSelect; + this._focusPathOnLoad = bFocus; + + if (sPath == "") { + if (bSelect) { + this.select(); + } + if (bFocus) { + window.setTimeout("WebFXTreeAbstractNode._onTimeoutFocus(\"" + this.getId() + "\")", 10); + } + return; + } + + var parts = sPath.split("/"); + var remainingPath = parts.slice(1).join("/"); + + if (sPath.charAt(0) == "/") { + this.getTree().openPath(remainingPath, bSelect, bFocus); + } else { + // open + this.setExpanded(true); + if (this.loaded) { + parts = sPath.split("/"); + var ti = this.findChildByText(parts[0]); + if (!ti) { + throw "Could not find child node with text \"" + parts[0] + "\""; + } + + ti.openPath(remainingPath, bSelect, bFocus); + } else { + this._pathToOpen = sPath; + } + } +}; + + +// Opera has some serious attribute problems. We need to use getAttribute +// for certain attributes +WebFXLoadTree._attrs = ["text", "src", "action", "id", "target"]; + +WebFXLoadTree.createItemFromElement = function (oNode) { + var jsAttrs = {}; + var i, l; + + l = oNode.attributes.length; + for (i = 0; i < l; i++) { + oNode.attributes[i].nodeValue = String(oNode.attributes[i].nodeValue).replace(/&/g, "&"); // replace for Safari fix for DOM Bug + if (oNode.attributes[i] == null) { + continue; + } + jsAttrs[oNode.attributes[i].nodeName] = oNode.attributes[i].nodeValue; + } + + var name, val; + for (i = 0; i < WebFXLoadTree._attrs.length; i++) { + name = WebFXLoadTree._attrs[i]; + value = oNode.getAttribute(name); + if (value) { + jsAttrs[name] = value; + } + } + + var action; + if (jsAttrs.onaction) { + action = new Function(jsAttrs.onaction); + } else if (jsAttrs.action) { + action = jsAttrs.action; + } + var jsNode = new WebFXLoadTreeItem(jsAttrs.html || "", jsAttrs.src, action, + null, jsAttrs.icon, jsAttrs.iconaction, jsAttrs.openicon); + if (jsAttrs.text) { + jsNode.setText(jsAttrs.text); + } + + if (jsAttrs.target) { + jsNode.target = jsAttrs.target; + } + if (jsAttrs.id) { + jsNode.setId(jsAttrs.id); + } + if (jsAttrs.tooltip) { + jsNode.toolTip = jsAttrs.tooltip; + } + if (jsAttrs.expanded) { + jsNode.setExpanded(jsAttrs.expanded != "false"); + } + if (jsAttrs.onload) { + jsNode.onload = new Function(jsAttrs.onload); + } + if (jsAttrs.onerror) { + jsNode.onerror = new Function(jsAttrs.onerror); + } + + jsNode.attributes = jsAttrs; + + // go through childNodes + var cs = oNode.childNodes; + l = cs.length; + for (i = 0; i < l; i++) { + if (cs[i].tagName == "tree") { + jsNode.add(WebFXLoadTree.createItemFromElement(cs[i])); + } + } + + return jsNode; +}; + +WebFXLoadTree.loadXmlDocument = function (jsNode) { + if (jsNode.loading || jsNode.loaded) { + return; + } + jsNode.loading = true; + var id = jsNode.getId(); + jsNode._xmlHttp = window.XMLHttpRequest ? new XMLHttpRequest : new window.ActiveXObject("Microsoft.XmlHttp"); + jsNode._xmlHttp.open("GET", jsNode.src, true); // async + jsNode._xmlHttp.onreadystatechange = new Function("WebFXLoadTree._onload(\"" + id + "\")"); + + // call in new thread to allow ui to update + window.setTimeout("WebFXLoadTree._ontimeout(\"" + id + "\")", 10); +}; + +WebFXLoadTree._onload = function (sId) { + var jsNode = webFXTreeHandler.all[sId]; + if (jsNode._xmlHttp.readyState == 4) { + WebFXLoadTree.documentLoaded(jsNode); + webFXLoadTreeQueue.remove(jsNode); + if (jsNode._xmlHttp.dispose) + jsNode._xmlHttp.dispose(); + jsNode._xmlHttp = null; + } +}; + +WebFXLoadTree._ontimeout = function (sId) { + var jsNode = webFXTreeHandler.all[sId]; + webFXLoadTreeQueue.add(jsNode); +}; + + + +// Inserts an xml document as a subtree to the provided node +WebFXLoadTree.documentLoaded = function (jsNode) { + if (jsNode.loaded) { + return; + } + + jsNode.errorText = ""; + jsNode.loaded = true; + jsNode.loading = false; + + var t = jsNode.getTree(); + var oldSuspend = t.getSuspendRedraw(); + t.setSuspendRedraw(true); + + var doc = jsNode._xmlHttp.responseXML; + + // check that the load of the xml file went well + if(!doc || doc.parserError && doc.parseError.errorCode != 0 || !doc.documentElement) { + if (!doc || doc.parseError.errorCode == 0) { + jsNode.errorText = webFXTreeConfig.errorLoadingText + " " + jsNode.src + " (" + jsNode._xmlHttp.status + ": " + jsNode._xmlHttp.statusText + ")"; + } else { + jsNode.errorText = webFXTreeConfig.errorLoadingText + " " + jsNode.src + " (" + doc.parseError.reason + ")"; + } + } else { + // there is one extra level of tree elements + var root = doc.documentElement; + + // loop through all tree children + var count = 0; + var cs = root.childNodes; + var l = cs.length; + var newNode; + for (var i = 0; i < l; i++) { + if (cs[i].tagName == "tree") { + newNode=WebFXLoadTree.createItemFromElement(cs[i]); + jsNode.add(newNode); + count++; + } + } + + if (count == 1 && newNode.childNodes.length) { + var parent=jsNode.parentNode; + newNode.setExpanded(true); + } + // if no children we got an error + if (count == 0) { + jsNode.errorText = webFXTreeConfig.errorLoadingText + " " + jsNode.src + " (???)"; + } + } + + if (jsNode.errorText != "") { + jsNode._loadingItem.icon = webFXTreeConfig.errorIcon; + jsNode._loadingItem.text = jsNode.errorText; + jsNode._loadingItem.action = WebFXLoadTree._reloadParent; + jsNode._loadingItem.toolTip = webFXTreeConfig.reloadText; + + t.setSuspendRedraw(oldSuspend); + + jsNode._loadingItem.update(); + + if (typeof jsNode.onerror == "function") { + jsNode.onerror(); + } + } else { + // remove dummy + if (jsNode._loadingItem != null) { + jsNode.remove(jsNode._loadingItem); + } + + if (jsNode._pathToOpen) { + jsNode.openPath(jsNode._pathToOpen, jsNode._selectPathOnLoad, jsNode._focusPathOnLoad); + } + + t.setSuspendRedraw(oldSuspend); + jsNode.update(); + if (typeof jsNode.onload == "function") { + jsNode.onload(); + } + } +}; + +WebFXLoadTree._reloadParent = function () { + this.getParent().reload(); +}; + + + + + + + +var webFXLoadTreeQueue = { + _nodes: [], + _ie: /msie/i.test(navigator.userAgent), + _opera: /opera/i.test(navigator.userAgent), + + add: function (jsNode) { + if (this._ie || this._opera) { + this._nodes.push(jsNode); + if (this._nodes.length == 1) { + this._send(); + } + } else { + jsNode._xmlHttp.send(null); + } + }, + + remove: function (jsNode) { + if (this._ie || this._opera) { + arrayHelper.remove(this._nodes, jsNode); + if (this._nodes.length > 0) { + this._send(); + } + } + }, + + // IE only + _send: function () { + var id = this._nodes[0].getId(); + var jsNode = webFXTreeHandler.all[id]; + if (!jsNode) { + return; + } + // if no _xmlHttp then remove it + if (!jsNode._xmlHttp) { + this.remove(jsNode); + } else { + jsNode._xmlHttp.send(null); + } + } +}; diff --git a/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xtree2.js b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xtree2.js new file mode 100644 index 00000000..c7feecbc --- /dev/null +++ b/.devilbox/www/htdocs/vendor/phppgadmin-5.6.0/xloadtree/xtree2.js @@ -0,0 +1,1621 @@ +/*----------------------------------------------------------------------------\ +| XTree 2 PRE RELEASE | +| | +| This is a pre release and redistribution is discouraged. | +| Watch http://webfx.eae.net for the final version | +| | +|-----------------------------------------------------------------------------| +| Created by Erik Arvidsson & Emil A Eklund | +| (http://webfx.eae.net/contact.html#erik) | +| (http://webfx.eae.net/contact.html#emil) | +| For WebFX (http://webfx.eae.net/) | +|-----------------------------------------------------------------------------| +| A tree menu system for IE 5.5+, Mozilla 1.4+, Opera 7, KHTML | +|-----------------------------------------------------------------------------| +| Copyright (c) 1999 - 2005 Erik Arvidsson & Emil A Eklund | +|-----------------------------------------------------------------------------| +| This software is provided "as is", without warranty of any kind, express or | +| implied, including but not limited to the warranties of merchantability, | +| fitness for a particular purpose and noninfringement. In no event shall the | +| authors or copyright holders be liable for any claim, damages or other | +| liability, whether in an action of contract, tort or otherwise, arising | +| from, out of or in connection with the software or the use or other | +| dealings in the software. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| This software is available under the three different licenses mentioned | +| below. To use this software you must chose, and qualify, for one of those. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| The WebFX Non-Commercial License http://webfx.eae.net/license.html | +| Permits anyone the right to use the software in a non-commercial context | +| free of charge. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| The WebFX Commercial license http://webfx.eae.net/commercial.html | +| Permits the license holder the right to use the software in a commercial | +| context. Such license must be specifically obtained, however it's valid for | +| any number of implementations of the licensed software. | +| - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | +| GPL - The GNU General Public License http://www.gnu.org/licenses/gpl.txt | +| Permits anyone the right to use and modify the software without limitations | +| as long as proper credits are given and the original and modified source | +| code are included. Requires that the final product, software derivate from | +| the original source or any software utilizing a GPL component, such as | +| this, is also licensed under the GPL license. | +|-----------------------------------------------------------------------------| +| 2004-02-21 | Pre release distributed to a few selected tester | +| 2005-06-06 | Added single tab index to improve keyboard navigation | +|-----------------------------------------------------------------------------| +| Dependencies: xtree2.css Used to define the look and feel | +|-----------------------------------------------------------------------------| +| Created 2003-??-?? | All changes are in the log above. | Updated 2004-06-06 | +\----------------------------------------------------------------------------*/ + + +// +// WebFXTreePersisitance +function WebFXTreePersistence() {} +var _p = WebFXTreePersistence.prototype; +_p.getExpanded = function (oNode) { return false; }; +_p.setExpanded = function (oNode, bOpen) {}; + + + +// Cookie handling +function WebFXCookie() {} + +_p = WebFXCookie.prototype; + +_p.setCookie = function (sName, sValue, nDays) { + var expires = ""; + if (typeof nDays == "number") { + var d = new Date(); + d.setTime(d.getTime() + nDays * 24 * 60 * 60 * 1000); + expires = "; expires=" + d.toGMTString(); + } + + document.cookie = sName + "=" + escape(sValue) + expires + "; path=/"; +}; + +_p.getCookie = function (sName) { + var re = new RegExp("(\;|^)[^;]*(" + sName + ")\=([^;]*)(;|$)"); + var res = re.exec(document.cookie); + return res != null ? unescape(res[3]) : null; +}; + +_p.removeCookie = function (name) { + this.setCookie(name, "", -1); +}; + + +// +// persistence using cookies +// +// This is uses one cookie with the ids of the expanded nodes separated using '+' +// +function WebFXTreeCookiePersistence() { + this._openedMap = {}; + this._cookies = new WebFXCookie; + var s = this._cookies.getCookie(this.cookieName); + if (s) { + var a = s.split("+"); + for (var i = a.length - 1; i >= 0; i--) + this._openedMap[a[i]] = true; + } +} + +_p = WebFXTreeCookiePersistence.prototype = new WebFXTreePersistence; + +_p.cookieName = "webfx-tree-cookie-persistence" + +_p.getExpanded = function (oNode) { + return oNode.id in this._openedMap; +}; + +_p.setExpanded = function (oNode, bOpen) { + var old = this.getExpanded(oNode); + if (old != bOpen) { + if (bOpen) { + this._openedMap[oNode.id] = true; + } else { + delete this._openedMap[oNode.id]; + } + + var res = []; + var i = 0; + for (var id in this._openedMap) + res[i++] = id; + this._cookies.setCookie(this.cookieName, res.join("+")); + } +}; + + + +// this object provides a few useful methods when working with arrays +var arrayHelper = { + indexOf: function (a, o) { + for (var i = 0; i < a.length; i++) { + if (a[i] == o) { + return i; + } + } + return -1; + }, + + insertBefore: function (a, o, o2) { + var i = this.indexOf(a, o2); + if (i == -1) { + a.push(o); + } else { + a.splice(i, 0, o); + } + }, + + remove: function (a, o) { + var i = this.indexOf(a, o); + if (i != -1) { + a.splice(i, 1); + } + } +}; + +/////////////////////////////////////////////////////////////////////////////// +// WebFX Tree Config object // +/////////////////////////////////////////////////////////////////////////////// +var webFXTreeConfig = { + rootIcon : "images/folder.png", + openRootIcon : "images/openfolder.png", + folderIcon : "images/folder.png", + openFolderIcon : "images/openfolder.png", + fileIcon : "images/file.png", + iIcon : "images/I.png", + lIcon : "images/L.png", + lMinusIcon : "images/Lminus.png", + lPlusIcon : "images/Lplus.png", + tIcon : "images/T.png", + tMinusIcon : "images/Tminus.png", + tPlusIcon : "images/Tplus.png", + plusIcon : "images/plus.png", + minusIcon : "images/minus.png", + blankIcon : "images/blank.png", + defaultText : "Tree Item", + defaultAction : null, + defaultBehavior : "classic", + usePersistence : true +}; + +/////////////////////////////////////////////////////////////////////////////// +// WebFX Tree Handler object // +/////////////////////////////////////////////////////////////////////////////// + +var webFXTreeHandler = { + ie: /msie/i.test(navigator.userAgent), + opera: /opera/i.test(navigator.userAgent), + idCounter: 0, + idPrefix: "wfxt-", + getUniqueId: function () { + return this.idPrefix + this.idCounter++; + }, + all: {}, + getNodeById: function (sId) { + return all[sId]; + }, + addNode: function (oNode) { + this.all[oNode.id] = oNode; + }, + removeNode: function (oNode) { + delete this.all[oNode.id]; + }, + + handleEvent: function (e) { + var el = e.target || e.srcElement; + while (el != null && !this.all[el.id]) { + el = el.parentNode; + } + + if (el == null) { + return false; + } + var node = this.all[el.id]; + if (typeof node["_on" + e.type] == "function") { + return node["_on" + e.type](e); + } + return false; + }, + + dispose: function () { + if (this.disposed) return; + for (var id in this.all) { + this.all[id].dispose(); + } + this.disposed = true; + }, + + htmlToText: function (s) { + return String(s).replace(/\s+|<([^>])+>|&|<|>|"| /gi, this._htmlToText); + }, + + _htmlToText: function (s) { + switch (s) { + case "&": + return "&"; + case "<": + return "<"; + case ">": + return ">"; + case """: + return "\""; + case " ": + return String.fromCharCode(160); + default: + if (/\s+/.test(s)) { + return " "; + } + if (/^
|\n|\"|\u00A0/g, this._textToHtml); + }, + + _textToHtml: function (s) { + switch (s) { + case "&": + return "&"; + case "<": + return "<"; + case ">": + return ">"; + case "\n": + return "
"; + case "\"": + return """; // so we can use this in attributes + default: + return " "; + } + }, + + persistenceManager: new WebFXTreeCookiePersistence() +}; + + +/////////////////////////////////////////////////////////////////////////////// +// WebFXTreeAbstractNode +/////////////////////////////////////////////////////////////////////////////// + +function WebFXTreeAbstractNode(sText, oAction, oIconAction) { + this.childNodes = []; + if (sText) this.text = sText; + if (oAction) this.action = oAction; + if (oIconAction) this.iconAction = oIconAction; + this.id = webFXTreeHandler.getUniqueId(); + if (webFXTreeConfig.usePersistence) { + this.open = webFXTreeHandler.persistenceManager.getExpanded(this); + } + webFXTreeHandler.addNode(this); +} + + +_p = WebFXTreeAbstractNode.prototype; +_p._selected = false; +_p.indentWidth = 19; +_p.open = false; +_p.text = webFXTreeConfig.defaultText; +_p.action = null; +_p.iconAcion = null; +_p.target = null; +_p.toolTip = null; +_p._focused = false; + +/* begin tree model */ + +_p.add = function (oChild, oBefore) { + var oldLast; + var emptyBefore = this.childNodes.length == 0; + var p = oChild.parentNode; + + if (oBefore == null) { // append + if (p != null) + p.remove(oChild); + oldLast = this.getLastChild(); + this.childNodes.push(oChild); + } else { // insertBefore + if (oBefore.parentNode != this) { + throw new Error("Can only add nodes before siblings"); + } + if (p != null) { + p.remove(oChild); + } + + arrayHelper.insertBefore(this.childNodes, oChild, oBefore); + } + + if (oBefore) { + if (oBefore == this.firstChild) { + this.firstChild = oChild; + } + oChild.previousSibling = oBefore.previousSibling; + oBefore.previousSibling = oChild; + oChild.nextSibling = oBefore; + } else { + if (!this.firstChild) { + this.firstChild = oChild; + } + if (this.lastChild) { + this.lastChild.nextSibling = oChild; + } + oChild.previousSibling = this.lastChild; + this.lastChild = oChild; + } + + oChild.parentNode = this; + var t = this.getTree(); + if (t) { + oChild.tree = t; + } + var d = this.getDepth(); + if (d != null) { + oChild.depth = d + 1; + } + + if (this.getCreated() && !t.getSuspendRedraw()) { + var el = this.getChildrenElement(); + var newEl = oChild.create(); + var refEl = oBefore ? oBefore.getElement() : null; + el.insertBefore(newEl, refEl); + + if (oldLast) { + oldLast.updateExpandIcon(); + } + if (emptyBefore) { + this.setExpanded(this.getExpanded()); + // if we are using classic expand will not update icon + if (t && t.getBehavior() != "classic") + this.updateIcon(); + } + } + + return oChild; +}; + + + +_p.remove = function (oChild) { + // backwards compatible. If no argument remove the node + if (arguments.length == 0) { + if (this.parentNode) { + return this.parentNode.remove(this); + } + return null; + } + + // if we remove selected or tree with the selected we should select this + var t = this.getTree(); + var si = t ? t.getSelected() : null; + if (si == oChild || oChild.contains(si)) { + if (si.getFocused()) { + this.select(); + window.setTimeout("WebFXTreeAbstractNode._onTimeoutFocus(\"" + this.id + "\")", 10); + } else { + this.select(); + } + } + + if (oChild.parentNode != this) { + throw new Error("Can only remove children"); + } + arrayHelper.remove(this.childNodes, oChild); + + if (this.lastChild == oChild) { + this.lastChild = oChild.previousSibling; + } + if (this.firstChild == oChild) { + this.firstChild = oChild.nextSibling; + } + if (oChild.previousSibling) { + oChild.previousSibling.nextSibling = oChild.nextSibling; + } + if (oChild.nextSibling) { + oChild.nextSibling.previousSibling = oChild.previousSibling; + } + + var wasLast = oChild.isLastSibling(); + + oChild.parentNode = null; + oChild.tree = null; + oChild.depth = null; + + if (t && this.getCreated() && !t.getSuspendRedraw()) { + var el = this.getChildrenElement(); + var childEl = oChild.getElement(); + el.removeChild(childEl); + if (wasLast) { + var newLast = this.getLastChild(); + if (newLast) { + newLast.updateExpandIcon(); + } + } + if (!this.hasChildren()) { + el.style.display = "none"; + this.updateExpandIcon(); + this.updateIcon(); + } + } + + return oChild; +}; + +WebFXTreeAbstractNode._onTimeoutFocus = function (sId) { + var jsNode = webFXTreeHandler.all[sId]; + jsNode.focus(); +}; + +_p.getId = function () { + return this.id; +}; + +_p.getTree = function () { + throw new Error("getTree called on Abstract Node"); +}; + +_p.getDepth = function () { + throw new Error("getDepth called on Abstract Node"); +}; + +_p.getCreated = function () { + var t = this.getTree(); + return t && t.rendered; +}; + +_p.getParent = function () { + return this.parentNode; +}; + +_p.contains = function (oDescendant) { + if (oDescendant == null) return false; + if (oDescendant == this) return true; + var p = oDescendant.parentNode; + return this.contains(p); +}; + +_p.getChildren = _p.getChildNodes = function () { + return this.childNodes; +}; + +_p.getFirstChild = function () { + return this.childNodes[0]; +}; + +_p.getLastChild = function () { + return this.childNodes[this.childNodes.length - 1]; +}; + +_p.getPreviousSibling = function () { + return this.previousSibling; + //var p = this.parentNode; + //if (p == null) return null; + //var cs = p.childNodes; + //return cs[arrayHelper.indexOf(cs, this) - 1] +}; + +_p.getNextSibling = function () { + return this.nextSibling; + //var p = this.parentNode; + //if (p == null) return null; + //var cs = p.childNodes; + //return cs[arrayHelper.indexOf(cs, this) + 1] +}; + +_p.hasChildren = function () { + return this.childNodes.length > 0; +}; + +_p.isLastSibling = function () { + return this.nextSibling == null; + //return this.parentNode && this == this.parentNode.getLastChild(); +}; + +_p.findChildByText = function (s, n) { + if (!n) { + n = 0; + } + var isRe = s instanceof RegExp; + for (var i = 0; i < this.childNodes.length; i++) { + if (isRe && s.test(this.childNodes[i].getText()) || + this.childNodes[i].getText() == s) { + if (n == 0) { + return this.childNodes[i]; + } + n--; + } + } + return null; +}; + +_p.findNodeByText = function (s, n) { + if (!n) { + n = 0; + } + var isRe = s instanceof RegExp; + if (isRe && s.test(this.getText()) || this.getText() == s) { + if (n == 0) { + return this.childNodes[i]; + } + n--; + } + + var res; + for (var i = 0; i < this.childNodes.length; i++) { + res = this.childNodes[i].findNodeByText(s, n); + if (res) { + return res; + } + } + return null; +}; + +/* end tree model */ + +_p.setId = function (sId) { + var el = this.getElement(); + webFXTreeHandler.removeNode(this); + this.id = sId; + if (el) { + el.id = sId; + } + webFXTreeHandler.addNode(this); +}; + +_p.isSelected = function () { + return this._selected; +}; + +_p.select = function () { + this._setSelected(true); +}; + +_p.deselect = function () { + this._setSelected(false); +}; + +_p._setSelected = function (b) { + var t = this.getTree(); + if (!t) return; + if (this._selected != b) { + this._selected = b; + + var wasFocused = false; // used to keep focus state + var si = t.getSelected(); + if (b && si != null && si != this) { + var oldFireChange = t._fireChange; + wasFocused = si._focused; + t._fireChange = false; + si._setSelected(false); + t._fireChange = oldFireChange; + } + + var el = this.getRowElement(); + if (el) { + el.className = this.getRowClassName(); + } + if (b) { + this._setTabIndex(t.tabIndex); + t._selectedItem = this; + t._fireOnChange(); + t.setSelected(this); + if (wasFocused) { + this.focus(); + } + } else { + this._setTabIndex(-1); + } + + if (t.getBehavior() != "classic") { + this.updateIcon(); + } + } +}; + + +_p.getExpanded = function () { + return this.open; +}; + +_p.setExpanded = function (b) { + var ce; + this.open = b; + var t = this.getTree(); + if (this.hasChildren()) { + var si = t ? t.getSelected() : null; + if (!b && this.contains(si)) { + this.select(); + } + + var el = this.getElement(); + if (el) { + ce = this.getChildrenElement(); + if (ce) { + ce.style.display = b ? "block" : "none"; + } + var eie = this.getExpandIconElement(); + if (eie) { + eie.src = this.getExpandIconSrc(); + } + } + + if (webFXTreeConfig.usePersistence) { + webFXTreeHandler.persistenceManager.setExpanded(this, b); + } + } else { + ce = this.getChildrenElement(); + if (ce) + ce.style.display = "none"; + } + if (t && t.getBehavior() == "classic") { + this.updateIcon(); + } +}; + +_p.toggle = function () { + this.setExpanded(!this.getExpanded()); +}; + +_p.expand = function () { + this.setExpanded(true); +}; + +_p.collapse = function () { + this.setExpanded(false); +}; + +_p.collapseChildren = function () { + var cs = this.childNodes; + for (var i = 0; i < cs.length; i++) { + cs[i].collapseAll(); + } +}; + +_p.collapseAll = function () { + this.collapseChildren(); + this.collapse(); +}; + +_p.expandChildren = function () { + var cs = this.childNodes; + for (var i = 0; i < cs.length; i++) { + cs[i].expandAll(); + } +}; + +_p.expandAll = function () { + this.expandChildren(); + this.expand(); +}; + +_p.reveal = function () { + var p = this.getParent(); + if (p) { + p.setExpanded(true); + p.reveal(); + } +}; + +_p.openPath = function (sPath, bSelect, bFocus) { + if (sPath == "") { + if (bSelect) { + this.select(); + } + if (bFocus) { + window.setTimeout("WebFXTreeAbstractNode._onTimeoutFocus(\"" + this.id + "\")", 10); + } + return; + } + + var parts = sPath.split("/"); + var remainingPath = parts.slice(1).join("/"); + var t = this.getTree(); + if (sPath.charAt(0) == "/") { + if (t) { + t.openPath(remainingPath, bSelect, bFocus); + } else { + throw "Invalid path"; + } + } else { + // open + this.setExpanded(true); + parts = sPath.split("/"); + var ti = this.findChildByText(parts[0]); + if (!ti) { + throw "Could not find child node with text \"" + parts[0] + "\""; + } + ti.openPath(remainingPath, bSelect, bFocus); + } +}; + +_p.focus = function () { + var el = this.getLabelElement(); + if (el) { + el.focus(); + } +}; + +_p.getFocused = function () { + return this._focused; +}; + +_p._setTabIndex = function (i) { + var a = this.getLabelElement(); + if (a) { + a.setAttribute("tabindex", i); + } +}; + + +// HTML generation + +_p.toHtml = function () { + var sb = []; + var cs = this.childNodes; + var l = cs.length; + for (var y = 0; y < l; y++) { + sb[y] = cs[y].toHtml(); + } + + var t = this.getTree(); + var hideLines = !t.getShowLines() || t == this.parentNode && !t.getShowRootLines(); + + var childrenHtml = "
" + + sb.join("") + + "
"; + + return "
" + + this.getRowHtml() + + childrenHtml + + "
"; +}; + +_p.getRowHtml = function () { + var t = this.getTree(); + return "
" + + this.getExpandIconHtml() + + //"" + + this.getIconHtml() + + this.getLabelHtml() + + //"" + + "
"; +}; + +_p.getRowClassName = function () { + return "webfx-tree-row" + (this.isSelected() ? " selected" : "") + + (this.action ? "" : " no-action"); +}; + +_p.getLabelHtml = function () { + var toolTip = this.getToolTip(); + var target = this.getTarget(); + var link = this._getHref(); + + if (link == '#') { + return "" + + this.getHtml() + ""; + } + + return "" + + this.getHtml() + ""; +}; + +_p._getHref = function () { + if (typeof this.action == "string") + return this.action; + else + return "#"; +}; + +_p._getIconHref = function () { + if (typeof this.iconAction == "string") + return this.iconAction; + else + return this._getHref(); +} + +_p.getEventHandlersHtml = function () { + return ""; +}; + +_p.getIconHtml = function () { + // here we are not using textToHtml since the file names rarerly contains + // HTML... + var link = this._getIconHref(); + if (link == '#') + return " "; + + return ""; +}; + +_p.getIconSrc = function () { + throw new Error("getIconSrc called on Abstract Node"); +}; + +_p.getExpandIconHtml = function () { + // here we are not using textToHtml since the file names rarerly contains + // HTML... + return ""; +}; + + +_p.getExpandIconSrc = function () { + var src; + var t = this.getTree(); + var hideLines = !t.getShowLines() || t == this.parentNode && !t.getShowRootLines(); + + if (this.hasChildren()) { + var bits = 0; + /* + Bitmap used to determine which icon to use + 1 Plus + 2 Minus + 4 T Line + 8 L Line + */ + + if (t && t.getShowExpandIcons()) { + if (this.getExpanded()) { + bits = 2; + } else { + bits = 1; + } + } + + if (t && !hideLines) { + if (this.isLastSibling()) { + bits += 4; + } else { + bits += 8; + } + } + + switch (bits) { + case 1: + return webFXTreeConfig.plusIcon; + case 2: + return webFXTreeConfig.minusIcon; + case 4: + return webFXTreeConfig.lIcon; + case 5: + return webFXTreeConfig.lPlusIcon; + case 6: + return webFXTreeConfig.lMinusIcon; + case 8: + return webFXTreeConfig.tIcon; + case 9: + return webFXTreeConfig.tPlusIcon; + case 10: + return webFXTreeConfig.tMinusIcon; + default: // 0 + return webFXTreeConfig.blankIcon; + } + } else { + if (t && hideLines) { + return webFXTreeConfig.blankIcon; + } else if (this.isLastSibling()) { + return webFXTreeConfig.lIcon; + } else { + return webFXTreeConfig.tIcon; + } + } +}; + +_p.getLineStyle = function () { + return "background-position:" + this.getLineStyle2() + ";"; +}; + +_p.getLineStyle2 = function () { + return (this.isLastSibling() ? "-100" : (this.getDepth() - 1) * this.indentWidth) + "px 0"; +}; + +// End HTML generation + +// DOM +// this returns the div for the tree node +_p.getElement = function () { + return document.getElementById(this.id); +}; + +// the row is the div that is used to draw the node without the children +_p.getRowElement = function () { + var el = this.getElement(); + if (!el) return null; + return el.firstChild; +}; + +// plus/minus image +_p.getExpandIconElement = function () { + var el = this.getRowElement(); + if (!el) return null; + return el.firstChild; +}; + +_p.getIconElement = function () { + var el = this.getRowElement(); + if (!el) return null; + return el.childNodes[1]; +}; + +// anchor element +_p.getLabelElement = function () { + var el = this.getRowElement(); + if (!el) return null; + return el.lastChild; +}; + +// the div containing the children +_p.getChildrenElement = function () { + var el = this.getElement(); + if (!el) return null; + return el.lastChild; +}; + + +// IE uses about:blank if not attached to document and this can cause Win2k3 +// to fail +if (webFXTreeHandler.ie) { + _p.create = function () { + var dummy = document.createElement("div"); + dummy.style.display = "none"; + document.body.appendChild(dummy); + dummy.innerHTML = this.toHtml(); + var res = dummy.removeChild(dummy.firstChild); + document.body.removeChild(dummy); + return res; + }; +} else { + _p.create = function () { + var dummy = document.createElement("div"); + dummy.innerHTML = this.toHtml(); + return dummy.removeChild(dummy.firstChild); + }; +} + +// Getters and setters for some common fields + +_p.setIcon = function (s) { + this.icon = s; + if (this.getCreated()) { + this.updateIcon(); + } +}; + +_p.getIcon = function () { + return this.icon; +}; + +_p.setOpenIcon = function (s) { + this.openIcon = s; + if (this.getCreated()) { + this.updateIcon(); + } +}; + +_p.getOpenIcon = function () { + return this.openIcon; +}; + +_p.setText = function (s) { + this.setHtml(webFXTreeHandler.textToHtml(s)); +}; + +_p.getText = function () { + return webFXTreeHandler.htmlToText(this.getHtml()); +}; + +_p.setHtml = function (s) { + this.text = s; + var el = this.getLabelElement(); + if (el) { + el.innerHTML = s; + } +}; + +_p.getHtml = function () { + return this.text; +}; + +_p.setTarget = function (s) { + this.target = s; +}; + +_p.getTarget = function () { + return this.target; +}; + +_p.setToolTip = function (s) { + this.toolTip = s; + var el = this.getLabelElement(); + if (el) { + el.title = s; + } +}; + +_p.getToolTip = function () { + return this.toolTip; +}; + +_p.setAction = function (oAction) { + this.action = oAction; + var el = this.getLabelElement(); + if (el) { + el.href = this._getHref(); + } + el = this.getRowElement(); + if (el) { + el.className = this.getRowClassName(); + } +}; + +_p.getAction = function () { + return this.action; +}; + +_p.setIconAction = function (oAction) { + this.iconAction = oAction; + var el = this.getIconElement(); + if (el) { + el.href = this._getIconHref(); + } +} + +_p.getIconAction = function () { + if (this.iconAction) + return this.iconAction; + return _p.getAction(); +}; + +// update methods + +_p.update = function () { + var t = this.getTree(); + if (t.suspendRedraw) return; + var el = this.getElement(); + if (!el || !el.parentNode) return; + var newEl = this.create(); + el.parentNode.replaceChild(newEl, el); + this._setTabIndex(this.tabIndex); // in case root had the tab index + var si = t.getSelected(); + if (si && si.getFocused()) { + si.focus(); + } +}; + +_p.updateExpandIcon = function () { + var t = this.getTree(); + if (t.suspendRedraw) return; + var img = this.getExpandIconElement(); + img.src = this.getExpandIconSrc(); + var cel = this.getChildrenElement(); + cel.style.backgroundPosition = this.getLineStyle2(); +}; + +_p.updateIcon = function () { + var t = this.getTree(); + if (t.suspendRedraw) return; + var img = this.getIconElement(); + img.src = this.getIconSrc(); +}; + +// End DOM + +_p._callSuspended = function (f) { + var t = this.getTree(); + var sr = t.getSuspendRedraw(); + t.setSuspendRedraw(true); + f.call(this); + t.setSuspendRedraw(sr); +}; + +// Event handlers + +_p._onmousedown = function (e) { + var el = e.target || e.srcElement; + // expand icon + if (/webfx-tree-expand-icon/.test(el.className) && this.hasChildren()) { + this.toggle(); + if (webFXTreeHandler.ie) { + window.setTimeout("WebFXTreeAbstractNode._onTimeoutFocus(\"" + this.id + "\")", 10); + } + return false; + } + + this.select(); + if (/*!/webfx-tree-item-label/.test(el.className) && */!webFXTreeHandler.opera) { // opera cancels the click if focus is called + + // in case we are not clicking on the label + if (webFXTreeHandler.ie) { + window.setTimeout("WebFXTreeAbstractNode._onTimeoutFocus(\"" + this.id + "\")", 10); + } else { + this.focus(); + } + } + var rowEl = this.getRowElement(); + if (rowEl) { + rowEl.className = this.getRowClassName(); + } + + return false; +}; + +_p._onclick = function (e) { + var el = e.target || e.srcElement; + // expand icon + if (/webfx-tree-expand-icon/.test(el.className) && this.hasChildren()) { + return false; + } + + var doAction = null; + if (/webfx-tree-icon/.test(el.className) && this.iconAction) { + doAction = this.iconAction; + } else { + doAction = this.action; + } + + if (typeof doAction == "function") { + doAction(); + } else if (doAction != null) { + window.open(doAction, this.target || "_self"); + } + return false; +}; + + +_p._ondblclick = function (e) { + var el = e.target || e.srcElement; + // expand icon + if (/webfx-tree-expand-icon/.test(el.className) && this.hasChildren()) { + return; + } + + this.toggle(); +}; + +_p._onfocus = function (e) { + this.select(); + this._focused = true; +}; + +_p._onblur = function (e) { + this._focused = false; +}; + +_p._onkeydown = function (e) { + var n; + var rv = true; + switch (e.keyCode) { + case 39: // RIGHT + if (e.altKey) { + rv = true; + break; + } + if (this.hasChildren()) { + if (!this.getExpanded()) { + this.setExpanded(true); + } else { + this.getFirstChild().focus(); + } + } + rv = false; + break; + case 37: // LEFT + if (e.altKey) { + rv = true; + break; + } + if (this.hasChildren() && this.getExpanded()) { + this.setExpanded(false); + } else { + var p = this.getParent(); + var t = this.getTree(); + // don't go to root if hidden + if (p && (t.showRootNode || p != t)) { + p.focus(); + } + } + rv = false; + break; + + case 40: // DOWN + n = this.getNextShownNode(); + if (n) { + n.focus(); + } + rv = false; + break; + case 38: // UP + n = this.getPreviousShownNode() + if (n) { + n.focus(); + } + rv = false; + break; + } + + if (!rv && e.preventDefault) { + e.preventDefault(); + } + e.returnValue = rv; + return rv; +}; + +_p._onkeypress = function (e) { + if (!e.altKey && e.keyCode >= 37 && e.keyCode <= 40) { + if (e.preventDefault) { + e.preventDefault(); + } + e.returnValue = false; + return false; + } +}; + +// End event handlers + +_p.dispose = function () { + if (this.disposed) return; + for (var i = this.childNodes.length - 1; i >= 0; i--) { + this.childNodes[i].dispose(); + } + this.tree = null; + this.parentNode = null; + this.childNodes = null; + this.disposed = true; +}; + +// Some methods that are usable when navigating the tree using the arrows +_p.getLastShownDescendant = function () { + if (!this.getExpanded() || !this.hasChildren()) { + return this; + } + // we know there is at least 1 child + return this.getLastChild().getLastShownDescendant(); +}; + +_p.getNextShownNode = function () { + if (this.hasChildren() && this.getExpanded()) { + return this.getFirstChild(); + } else { + var p = this; + var next; + while (p != null) { + next = p.getNextSibling(); + if (next != null) { + return next; + } + p = p.getParent(); + } + return null; + } +}; + +_p.getPreviousShownNode = function () { + var ps = this.getPreviousSibling(); + if (ps != null) { + return ps.getLastShownDescendant(); + } + var p = this.getParent(); + var t = this.getTree(); + if (!t.showRootNode && p == t) { + return null; + } + return p; +}; + + + + + + + +/////////////////////////////////////////////////////////////////////////////// +// WebFXTree +/////////////////////////////////////////////////////////////////////////////// + +function WebFXTree(sText, oAction, sBehavior, sIcon, oIconAction, sOpenIcon) { + WebFXTreeAbstractNode.call(this, sText, oAction, oIconAction); + if (sIcon) this.icon = sIcon; + if (sOpenIcon) this.openIcon = sOpenIcon; + if (sBehavior) this.behavior = sBehavior; +} + +_p = WebFXTree.prototype = new WebFXTreeAbstractNode; +_p.indentWidth = 19; +_p.open = true; +_p._selectedItem = null; +_p._fireChange = true; +_p.rendered = false; +_p.suspendRedraw = false; +_p.showLines = true; +_p.showExpandIcons = true; +_p.showRootNode = true; +_p.showRootLines = true; + +_p.getTree = function () { + return this; +}; + +_p.getDepth = function () { + return 0; +}; + +_p.getCreated = function () { + return this.rendered; +}; + + +/* end tree model */ + +_p.getExpanded = function () { + return !this.showRootNode || WebFXTreeAbstractNode.prototype.getExpanded.call(this); +}; + +_p.setExpanded = function (b) { + if (!this.showRootNode) { + this.open = b; + } else { + WebFXTreeAbstractNode.prototype.setExpanded.call(this, b); + } +}; + +_p.getExpandIconHtml = function () { + return ""; +}; + +// we don't have an expand icon here +_p.getIconElement = function () { + var el = this.getRowElement(); + if (!el) return null; + return el.firstChild; +}; + +// no expand icon for root element +_p.getExpandIconElement = function (oDoc) { + return null; +}; + +_p.updateExpandIcon = function () { + // no expand icon +}; + +_p.getRowClassName = function () { + return WebFXTreeAbstractNode.prototype.getRowClassName.call(this) + + (this.showRootNode ? "" : " webfx-tree-hide-root"); +}; + + +// if classic then the openIcon is used for expanded, otherwise openIcon is used +// for selected + +_p.getIconSrc = function () { + var behavior = this.getTree() ? this.getTree().getBehavior() : webFXTreeConfig.defaultBehavior; + var open = behavior == "classic" && this.getExpanded() || + behavior != "classic" && this.isSelected(); + if (open && this.openIcon) { + return this.openIcon; + } + if (!open && this.icon) { + return this.icon; + } + // fall back on default icons + return open ? webFXTreeConfig.openRootIcon : webFXTreeConfig.rootIcon; +}; + +_p.getEventHandlersHtml = function () { + return " onclick=\"return webFXTreeHandler.handleEvent(event)\" " + + "onmousedown=\"return webFXTreeHandler.handleEvent(event)\" " + + "ondblclick=\"return webFXTreeHandler.handleEvent(event)\" " + + "onkeydown=\"return webFXTreeHandler.handleEvent(event)\" " + + "onkeypress=\"return webFXTreeHandler.handleEvent(event)\""; +}; + +_p.setSelected = function (o) { + if (this._selectedItem != o && o) { + o._setSelected(true); + } +}; + +_p._fireOnChange = function () { + if (this._fireChange && typeof this.onchange == "function") { + this.onchange(); + } +}; + +_p.getSelected = function () { + return this._selectedItem; +}; + +_p.tabIndex = ""; + +_p.setTabIndex = function (i) { + var n = this._selectedItem || (this.showRootNode ? this : this.firstChild); + this.tabIndex = i; + if (n) { + n._setTabIndex(i); + } +}; + +_p.getTabIndex = function () { + return this.tabIndex; +}; + +_p.setBehavior = function (s) { + this.behavior = s; +}; + +_p.getBehavior = function () { + return this.behavior || webFXTreeConfig.defaultBehavior; +}; + +_p.setShowLines = function (b) { + if (this.showLines != b) { + this.showLines = b; + if (this.rendered) { + this.update(); + } + } +}; + +_p.getShowLines = function () { + return this.showLines; +}; + +_p.setShowRootLines = function (b) { + if (this.showRootLines != b) { + this.showRootLines = b; + if (this.rendered) { + this.update(); + } + } +}; + +_p.getShowRootLines = function () { + return this.showRootLines; +}; + +_p.setShowExpandIcons = function (b) { + if (this.showExpandIcons != b) { + this.showExpandIcons = b; + if (this.rendered) { + this.getTree().update(); + } + } +}; + +_p.getShowExpandIcons = function () { + return this.showExpandIcons; +}; + +_p.setShowRootNode = function (b) { + if (this.showRootNode != b) { + this.showRootNode = b; + if (this.rendered) { + this.getTree().update(); + } + } +}; + +_p.getShowRoootNode = function () { + return this.showRootNode; +}; + +_p.onchange = function () {}; + +_p.create = function () { + var el = WebFXTreeAbstractNode.prototype.create.call(this); + this.setTabIndex(this.tabIndex); + this.rendered = true; + return el; +}; + +_p.write = function () { + document.write(this.toHtml()); + this.setTabIndex(this.tabIndex); + this.rendered = true; +}; + +_p.setSuspendRedraw = function (b) { + this.suspendRedraw = b; +}; + +_p.getSuspendRedraw = function () { + return this.suspendRedraw; +}; + + + +/////////////////////////////////////////////////////////////////////////////// +// WebFXTreeItem +/////////////////////////////////////////////////////////////////////////////// + +function WebFXTreeItem(sText, oAction, eParent, sIcon, oIconAction, sOpenIcon) { + WebFXTreeAbstractNode.call(this, sText, oAction, oIconAction); + if (sIcon) this.icon = sIcon; + if (sOpenIcon) this.openIcon = sOpenIcon; + if (eParent) eParent.add(this); +} + +_p = WebFXTreeItem.prototype = new WebFXTreeAbstractNode; +_p.tree = null; + +/* tree model */ + +_p.getDepth = function () { + if (this.depth != null) { + return this.depth; + } + if (this.parentNode) { + var pd = this.parentNode.getDepth(); + return this.depth = (pd != null ? pd + 1 : null); + } + return null; +}; + +_p.getTree = function () { + if (this.tree) { + return this.tree; + } + if (this.parentNode) { + return this.tree = this.parentNode.getTree(); + } + return null; +}; + +_p.getCreated = function () { + var t = this.getTree(); + return t && t.getCreated(); +}; + +// if classic then the openIcon is used for expanded, otherwise openIcon is used +// for selected +_p.getIconSrc = function () { + var behavior = this.getTree() ? this.getTree().getBehavior() : webFXTreeConfig.defaultBehavior; + var open = behavior == "classic" && this.getExpanded() || + behavior != "classic" && this.isSelected(); + if (open && this.openIcon) { + return this.openIcon; + } + if (!open && this.icon) { + return this.icon; + } + + // fall back on default icons + if (this.hasChildren()) { + return open ? webFXTreeConfig.openFolderIcon : webFXTreeConfig.folderIcon; + } + return webFXTreeConfig.fileIcon; +}; + +/* end tree model */ + + + + +if (window.attachEvent) { + window.attachEvent("onunload", function () { + for (var id in webFXTreeHandler.all) + webFXTreeHandler.all[id].dispose(); + }); +} diff --git a/.devilbox/www/include/lib/Html.php b/.devilbox/www/include/lib/Html.php index 4ac93ce1..87ef2c39 100644 --- a/.devilbox/www/include/lib/Html.php +++ b/.devilbox/www/include/lib/Html.php @@ -94,6 +94,11 @@ class Html 'path' => '__PHPMYADMIN__', 'target' => '_blank' ), + array( + 'name' => 'phpPgAdmin', + 'path' => '__PHPPGADMIN__', + 'target' => '_blank' + ), array( 'name' => 'PHPRedMin', 'path' => '/vendor/phpredmin/public/index.php', @@ -385,6 +390,9 @@ HTML; if ($el['path'] == '__PHPMYADMIN__') { $el['path'] = (version_compare(loadClass('Php')->getVersion(), '5.5', '<')) ? '/vendor/phpmyadmin-4.0/index.php' : '/vendor/phpmyadmin-4.8.4/index.php'; } + if ($el['path'] == '__PHPPGADMIN__') { + $el['path'] = (version_compare(loadClass('Php')->getVersion(), '5.2', '<')) ? '/vendor/phpmyadmin-4.0/' : '/vendor/phppgadmin-5.6.0/'; + } if ($el['path'] == '__ADMINER__') { $el['path'] = (version_compare(loadClass('Php')->getVersion(), '5.4', '<')) ? '/vendor/adminer-4.6.3-en.php' : '/vendor/adminer-4.7.0-en.php'; } diff --git a/.tests/intra-tests/vendor-phppgadmin.sh b/.tests/intra-tests/vendor-phppgadmin.sh new file mode 100755 index 00000000..49c63fbe --- /dev/null +++ b/.tests/intra-tests/vendor-phppgadmin.sh @@ -0,0 +1,215 @@ +#!/usr/bin/env bash + +set -e +set -u +set -o pipefail + + +# There's currently an Issue with PHP 7.3, Xdebug and phpMyAdmin. It just segfaults, +# so I will remove it from the checks. +DISABLED_VERSIONS=("") + +# +# NOTE: Parsing curl to tac to circumnvent "failed writing body" +# https://stackoverflow.com/questions/16703647/why-curl-return-and-error-23-failed-writing-body +# + + +### +### Get current PHP version +### + +printf "[TEST] Get PHP version" +# 1st Try +if ! PHP_VERSION="$( curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' | grep -Eo '\([.0-9]+' | grep -Eo '[0-9]+\.[0-9]+' )"; then + # 2nd Try + sleep 1 + if ! PHP_VERSION="$( curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' | grep -Eo '\([.0-9]+' | grep -Eo '[0-9]+\.[0-9]+' )"; then + # 3rd Try + sleep 1 + if ! PHP_VERSION="$( curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' | grep -Eo '\([.0-9]+' | grep -Eo '[0-9]+\.[0-9]+' )"; then + printf "\r[FAIL] Get PHP version\n" + curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' || true + exit 1 + else + printf "\r[OK] Get PHP version (3 rounds): %s\n" "${PHP_VERSION}" + fi + else + printf "\r[OK] Get PHP version (2 rounds): %s\n" "${PHP_VERSION}" + fi +else + printf "\r[OK] Get PHP version (1 round): %s\n" "${PHP_VERSION}" +fi + + +### +### Ensure only to check against desired versions +### + +if [[ ${DISABLED_VERSIONS[*]} =~ ${PHP_VERSION} ]]; then + printf "[SKIP] Skipping all checks for PHP ${PHP_VERSION}\n" + exit 0 +fi + + +### +### Retrieve URL for current PHP version. +### Older PHP versions are presented a link with a different version due to compatibility. +### + +printf "[TEST] Retrieve phpPgAdmin URL" +# 1st Try +if ! URL="$( curl -sS localhost/index.php | grep -Eo "/vendor/phppgadmin-[.0-9]+/" )"; then + # 2nd Try + sleep 1 + if ! URL="$( curl -sS localhost/index.php | grep -Eo "/vendor/phppgadmin-[.0-9]+/" )"; then + # 3rd Try + sleep 1 + if ! URL="$( curl -sS localhost/index.php | grep -Eo "/vendor/phppgadmin-[.0-9]+/" )"; then + printf "\r[FAILED] Retrieve phpMyAdmin URL\n" + curl -sS localhost/index.php | grep -Eo "/vendor/phppgadmin-[.0-9]+/" || true + exit 1 + else + printf "\r[OK] Retrieve phpPgAdmin URL (3 rounds): ${URL}\n" + fi + else + printf "\r[OK] Retrieve phpPgAdmin URL (2 rounds): ${URL}\n" + fi +else + printf "\r[OK] Retrieve phpPgAdmin URL (1 round): ${URL}\n" +fi + + +### +### Ensure given phpPgAdmin version works +### + +printf "[TEST] Fetch ${URL}intro.php" +# 1st Try +if ! curl -sS localhost${URL}intro.php | tac | tac | grep -Eiq "welcome to phpPgAdmin"; then + # 2nd Try + sleep 1 + if ! curl -sS localhost${URL}intro.php | tac | tac | grep -Eiq "welcome to phpPgAdmin"; then + # 3rd Try + sleep 1 + if ! curl -sS localhost${URL}intro.php | tac | tac | grep -Eiq "welcome to phpPgAdmin"; then + printf "\r[FAIL] Fetch ${URL}\n" + curl -sS localhost/${URL}into.php || true + curl -sSI localhost/${URL}into.php || true + exit 1 + else + printf "\r[OK] Fetch ${URL}intro.php (3 rounds)\n" + fi + else + printf "\r[OK] Fetch ${URL}intro.php (2 rounds)\n" + fi +else + printf "\r[OK] Fetch ${URL}intro.php (1 round)\n" +fi + + +### +### Login (get token URL) +### +# 1st Try +printf "[TEST] Retrieve phpPgAdmin token page" +if ! TOKEN_URL="$( curl -sS -c cookie.txt localhost${URL}servers.php | tac | tac | grep -Eo "\"redirect\.php\?subject=server.+\"" )"; then + # 2nd Try + sleep 1 + if ! TOKEN_URL="$( curl -sS -c cookie.txt localhost${URL}servers.php | tac | tac | grep -Eo "\"redirect\.php\?subject=server.+\"" )"; then + # 3rd Try + sleep 1 + if ! TOKEN_URL="$( curl -sS -c cookie.txt localhost${URL}servers.php | tac | tac | grep -Eo "\"redirect\.php\?subject=server.+\"" )"; then + printf "\r[FAIL] Retrieve phpPgAdmin login page\n" + curl -sS localhost/${URL}servers.php || true + curl -sSI localhost/${URL}servers.php || true + rm -f cookie.txt + exit 1 + else + TOKEN_URL="$( echo "${TOKEN_URL}" | sed 's/"//g' )" + TOKEN_URL="$( echo "${TOKEN_URL}" | sed 's/&/\&/g' )" + printf "\r[OK] Retrieve phpPgAdmin token page (3 rounds): ${TOKEN_URL}\n" + fi + else + TOKEN_URL="$( echo "${TOKEN_URL}" | sed 's/"//g' )" + TOKEN_URL="$( echo "${TOKEN_URL}" | sed 's/&/\&/g' )" + printf "\r[OK] Retrieve phpPgAdmin login token (2 rounds): ${TOKEN_URL}\n" + fi +else + TOKEN_URL="$( echo "${TOKEN_URL}" | sed 's/"//g' )" + TOKEN_URL="$( echo "${TOKEN_URL}" | sed 's/&/\&/g' )" + printf "\r[OK] Retrieve phpPgAdmin token page (1 round): ${TOKEN_URL}\n" +fi + + +### +### Login (get Login Token) +### +TOKEN= +printf "[TEST] Retrieve phpPgAdmin login token" +# 1st Try +if ! TOKEN="$( curl -sS -c cookie.txt -b cookie.txt "localhost${URL}${TOKEN_URL}" | tac | tac | grep -Eo "loginPassword_[a-zA-Z0-9]+" )"; then + # 2nd Try + sleep 1 + if ! TOKEN="$( curl -sS -c cookie.txt -b cookie.txt "localhost${URL}${TOKEN_URL}" | tac | tac | grep -Eo "loginPassword_[a-zA-Z0-9]+" )"; then + # 3rd Try + sleep 1 + if ! TOKEN="$( curl -sS -c cookie.txt -b cookie.txt "localhost${URL}${TOKEN_URL}" | tac | tac | grep -Eo "loginPassword_[a-zA-Z0-9]+" )"; then + printf "\r[FAIL] Retrieve phpPgAdmin login token\n" + curl -sS "${TOKEN_URL_URL}" || true + curl -sSI "${TOKEN_URL_URL}" || true + rm -f cookie.txt + exit 1 + else + TOKEN="$( echo "${TOKEN}" | head -1 )" + printf "\r[OK] Retrieve phpPgAdmin login token (3 rounds): ${TOKEN}\n" + fi + else + TOKEN="$( echo "${TOKEN}" | head -1 )" + printf "\r[OK] Retrieve phpPgAdmin login token (2 rounds): ${TOKEN}\n" + fi +else + TOKEN="$( echo "${TOKEN}" | head -1 )" + printf "\r[OK] Retrieve phpPgAdmin login token (1 round): ${TOKEN}\n" +fi + + +### +### Login +### + +printf "[TEST] Submit phpPgAdmin POST login" +# 1st Try +if ! curl -sS -c cookie.txt -b cookie.txt \ + -d "subject=server&server=pgsql%3A5432%3Aallow&loginServer=pgsql%3A5432%3Aallow&loginUsername=postgres&${TOKEN}=&loginSubmit=Login" \ + localhost${URL}redirect.php 2>/dev/null | grep -q "Create database"; then + # 2nd Try + sleep 1 + if ! curl -sS -c cookie.txt -b cookie.txt \ + -d "subject=server&server=pgsql%3A5432%3Aallow&loginServer=pgsql%3A5432%3Aallow&loginUsername=postgres&${TOKEN}=&loginSubmit=Login" \ + localhost${URL}redirect.php 2>/dev/null | grep -q "Create database"; then + # 3rd Try + sleep 1 + if ! curl -sS -c cookie.txt -b cookie.txt \ + -d "subject=server&server=pgsql%3A5432%3Aallow&loginServer=pgsql%3A5432%3Aallow&loginUsername=postgres&${TOKEN}=&loginSubmit=Login" \ + localhost${URL}redirect.php 2>/dev/null | grep -q "Create database"; then + printf "\r[FAIL] Submit phpPgAdmin POST login\n" + curl -sS -c cookie.txt -b cookie.txt \ + -d "subject=server&server=pgsql%3A5432%3Aallow&loginServer=pgsql%3A5432%3Aallow&loginUsername=postgres&${TOKEN}=&loginSubmit=Login" \ + localhost${URL}redirect.php || true + curl -sSI -c cookie.txt -b cookie.txt \ + -d "subject=server&server=pgsql%3A5432%3Aallow&loginServer=pgsql%3A5432%3Aallow&loginUsername=postgres&${TOKEN}=&loginSubmit=Login" \ + localhost${URL}redirect.php || true + rm -f cookie.txt || true + exit 1 + else + printf "\r[OK] Submit phpPgAdmin POST login (3 rounds)\n" + fi + else + printf "\r[OK] Submit phpPgAdmin POST login (2 rounds)\n" + fi +else + printf "\r[OK] Submit phpPgAdmin POST login (1 round)\n" +fi + +rm -f cookie.txt || true