From 5f9f9e2c12d386eba54bd5d9f7c13b22b86d32d8 Mon Sep 17 00:00:00 2001 From: top_nuomi <1130395124@qq.com> Date: Sat, 28 Sep 2019 15:21:12 +0800 Subject: [PATCH] =?UTF-8?q?=E9=87=8D=E5=86=99=E4=B8=AD=E9=97=B4=E4=BB=B6?= =?UTF-8?q?=E3=80=81=E6=94=B9=E8=BF=9B=E8=B7=AF=E7=94=B1=E6=9C=BA=E5=88=B6?= =?UTF-8?q?=E3=80=81=E5=8F=96=E6=B6=88=E4=BA=86=E5=85=A5=E5=8F=A3=E6=96=87?= =?UTF-8?q?=E4=BB=B6=E7=BB=91=E5=AE=9A=E6=A8=A1=E5=9D=97?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 83 +- composer.json | 4 +- composer.lock | 337 +- framework/Framework.php | 26 +- framework/config/config.php | 5 +- framework/extend/JWT.php | 93 + framework/extend/Page.php | 7 +- framework/library/App.php | 70 +- framework/library/Controller.php | 27 +- framework/library/Router.php | 212 +- framework/library/functions/functions.php | 92 +- framework/library/http/Request.php | 205 +- framework/library/http/Response.php | 2 +- .../library/http/response/ResponseData.php | 4 +- framework/library/route/driver/Command.php | 113 +- framework/library/route/driver/Compatible.php | 110 + framework/library/route/driver/Pathinfo.php | 210 - framework/library/route/ifs/RouteIfs.php | 32 +- .../library/template/driver/engine/Engine.php | 4 +- framework/middleware/Init.php | 59 +- framework/middleware/View.php | 11 +- framework/middleware/ifs/MiddlewareIfs.php | 14 +- framework/traits/Json.php | 2 +- framework/vendor/autoload.php | 2 +- .../vendor/composer/autoload_classmap.php | 5 - framework/vendor/composer/autoload_files.php | 11 - .../vendor/composer/autoload_namespaces.php | 1 - framework/vendor/composer/autoload_psr4.php | 6 +- framework/vendor/composer/autoload_real.php | 26 +- framework/vendor/composer/autoload_static.php | 68 +- framework/vendor/composer/index.html | 0 framework/vendor/composer/installed.json | 347 +- framework/vendor/filp/index.html | 0 framework/vendor/filp/whoops/CHANGELOG.md | 13 - framework/vendor/filp/whoops/LICENSE.md | 19 - framework/vendor/filp/whoops/composer.json | 42 - framework/vendor/filp/whoops/index.html | 0 .../src/Whoops/Exception/ErrorException.php | 17 - .../whoops/src/Whoops/Exception/Formatter.php | 73 - .../whoops/src/Whoops/Exception/Frame.php | 296 -- .../src/Whoops/Exception/FrameCollection.php | 203 - .../whoops/src/Whoops/Exception/Inspector.php | 276 - .../whoops/src/Whoops/Exception/index.html | 0 .../src/Whoops/Handler/CallbackHandler.php | 52 - .../whoops/src/Whoops/Handler/Handler.php | 95 - .../src/Whoops/Handler/HandlerInterface.php | 36 - .../Whoops/Handler/JsonResponseHandler.php | 88 - .../src/Whoops/Handler/PlainTextHandler.php | 314 -- .../src/Whoops/Handler/PrettyPageHandler.php | 707 --- .../src/Whoops/Handler/XmlResponseHandler.php | 107 - .../filp/whoops/src/Whoops/Handler/index.html | 0 .../src/Whoops/Resources/css/index.html | 0 .../src/Whoops/Resources/css/whoops.base.css | 583 --- .../whoops/src/Whoops/Resources/index.html | 0 .../src/Whoops/Resources/js/clipboard.min.js | 7 - .../whoops/src/Whoops/Resources/js/index.html | 0 .../src/Whoops/Resources/js/prettify.min.js | 28 - .../src/Whoops/Resources/js/whoops.base.js | 210 - .../src/Whoops/Resources/js/zepto.min.js | 2 - .../Resources/views/env_details.html.php | 42 - .../Resources/views/frame_code.html.php | 63 - .../Resources/views/frame_list.html.php | 17 - .../Resources/views/frames_container.html.php | 3 - .../views/frames_description.html.php | 20 - .../Whoops/Resources/views/header.html.php | 74 - .../Resources/views/header_outer.html.php | 3 - .../src/Whoops/Resources/views/index.html | 0 .../Whoops/Resources/views/layout.html.php | 33 - .../Resources/views/panel_details.html.php | 2 - .../views/panel_details_outer.html.php | 3 - .../Resources/views/panel_left.html.php | 4 - .../Resources/views/panel_left_outer.html.php | 3 - .../vendor/filp/whoops/src/Whoops/Run.php | 410 -- .../filp/whoops/src/Whoops/RunInterface.php | 131 - .../src/Whoops/Util/HtmlDumperOutput.php | 36 - .../filp/whoops/src/Whoops/Util/Misc.php | 77 - .../whoops/src/Whoops/Util/SystemFacade.php | 137 - .../whoops/src/Whoops/Util/TemplateHelper.php | 352 -- .../filp/whoops/src/Whoops/Util/index.html | 0 .../vendor/filp/whoops/src/Whoops/index.html | 0 framework/vendor/filp/whoops/src/index.html | 0 .../{twig/twig => firebase/php-jwt}/LICENSE | 13 +- framework/vendor/firebase/php-jwt/README.md | 200 + .../vendor/firebase/php-jwt/composer.json | 29 + .../php-jwt/src/BeforeValidException.php | 7 + .../firebase/php-jwt/src/ExpiredException.php | 7 + framework/vendor/firebase/php-jwt/src/JWT.php | 379 ++ .../php-jwt/src/SignatureInvalidException.php | 7 + framework/vendor/index.html | 0 framework/vendor/psr/index.html | 0 framework/vendor/psr/log/.gitignore | 1 - framework/vendor/psr/log/LICENSE | 19 - .../vendor/psr/log/Psr/Log/AbstractLogger.php | 128 - .../log/Psr/Log/InvalidArgumentException.php | 7 - framework/vendor/psr/log/Psr/Log/LogLevel.php | 18 - .../psr/log/Psr/Log/LoggerAwareInterface.php | 18 - .../psr/log/Psr/Log/LoggerAwareTrait.php | 26 - .../psr/log/Psr/Log/LoggerInterface.php | 123 - .../vendor/psr/log/Psr/Log/LoggerTrait.php | 140 - .../vendor/psr/log/Psr/Log/NullLogger.php | 28 - .../log/Psr/Log/Test/LoggerInterfaceTest.php | 144 - .../psr/log/Psr/Log/Test/TestLogger.php | 146 - .../vendor/psr/log/Psr/Log/Test/index.html | 0 framework/vendor/psr/log/Psr/Log/index.html | 0 framework/vendor/psr/log/Psr/index.html | 0 framework/vendor/psr/log/README.md | 52 - framework/vendor/psr/log/composer.json | 26 - framework/vendor/psr/log/index.html | 0 framework/vendor/smarty/index.html | 0 framework/vendor/smarty/smarty/COPYING.lib | 165 - .../smarty/INHERITANCE_RELEASE_NOTES.txt | 35 - framework/vendor/smarty/smarty/README | 574 --- framework/vendor/smarty/smarty/README.md | 28 - .../smarty/smarty/SMARTY_2_BC_NOTES.txt | 109 - .../smarty/smarty/SMARTY_3.0_BC_NOTES.txt | 24 - .../vendor/smarty/smarty/SMARTY_3.1_NOTES.txt | 306 -- framework/vendor/smarty/smarty/change_log.txt | 2372 --------- framework/vendor/smarty/smarty/composer.json | 43 - .../smarty/smarty/demo/configs/index.html | 0 .../smarty/smarty/demo/configs/test.conf | 5 - .../vendor/smarty/smarty/demo/index.html | 0 framework/vendor/smarty/smarty/demo/index.php | 30 - .../smarty/demo/plugins/cacheresource.apc.php | 83 - .../demo/plugins/cacheresource.memcache.php | 97 - .../demo/plugins/cacheresource.mysql.php | 162 - .../smarty/smarty/demo/plugins/index.html | 0 .../demo/plugins/resource.extendsall.php | 60 - .../smarty/demo/plugins/resource.mysql.php | 81 - .../smarty/demo/plugins/resource.mysqls.php | 62 - .../smarty/smarty/demo/templates/footer.tpl | 2 - .../smarty/smarty/demo/templates/header.tpl | 5 - .../smarty/smarty/demo/templates/index.html | 0 .../smarty/smarty/demo/templates/index.tpl | 87 - framework/vendor/smarty/smarty/index.html | 0 .../smarty/smarty/libs/Smarty.class.php | 1674 ------ .../smarty/smarty/libs/SmartyBC.class.php | 467 -- framework/vendor/smarty/smarty/libs/debug.tpl | 137 - .../vendor/smarty/smarty/libs/index.html | 0 .../smarty/libs/plugins/block.textformat.php | 110 - .../smarty/libs/plugins/function.counter.php | 78 - .../smarty/libs/plugins/function.cycle.php | 107 - .../smarty/libs/plugins/function.fetch.php | 221 - .../libs/plugins/function.html_checkboxes.php | 237 - .../libs/plugins/function.html_image.php | 163 - .../libs/plugins/function.html_options.php | 196 - .../libs/plugins/function.html_radios.php | 221 - .../plugins/function.html_select_date.php | 387 -- .../plugins/function.html_select_time.php | 364 -- .../libs/plugins/function.html_table.php | 176 - .../smarty/libs/plugins/function.mailto.php | 155 - .../smarty/libs/plugins/function.math.php | 91 - .../smarty/smarty/libs/plugins/index.html | 0 .../libs/plugins/modifier.capitalize.php | 90 - .../libs/plugins/modifier.date_format.php | 65 - .../libs/plugins/modifier.debug_print_var.php | 104 - .../smarty/libs/plugins/modifier.escape.php | 198 - .../libs/plugins/modifier.regex_replace.php | 57 - .../smarty/libs/plugins/modifier.replace.php | 34 - .../smarty/libs/plugins/modifier.spacify.php | 27 - .../smarty/libs/plugins/modifier.truncate.php | 64 - .../libs/plugins/modifiercompiler.cat.php | 29 - .../modifiercompiler.count_characters.php | 32 - .../modifiercompiler.count_paragraphs.php | 27 - .../modifiercompiler.count_sentences.php | 27 - .../plugins/modifiercompiler.count_words.php | 31 - .../libs/plugins/modifiercompiler.default.php | 35 - .../libs/plugins/modifiercompiler.escape.php | 126 - .../plugins/modifiercompiler.from_charset.php | 33 - .../libs/plugins/modifiercompiler.indent.php | 33 - .../libs/plugins/modifiercompiler.lower.php | 31 - .../libs/plugins/modifiercompiler.noprint.php | 21 - .../modifiercompiler.string_format.php | 25 - .../libs/plugins/modifiercompiler.strip.php | 33 - .../plugins/modifiercompiler.strip_tags.php | 29 - .../plugins/modifiercompiler.to_charset.php | 33 - .../plugins/modifiercompiler.unescape.php | 50 - .../libs/plugins/modifiercompiler.upper.php | 29 - .../plugins/modifiercompiler.wordwrap.php | 47 - .../plugins/outputfilter.trimwhitespace.php | 90 - .../plugins/shared.escape_special_chars.php | 53 - .../plugins/shared.literal_compiler_param.php | 35 - .../libs/plugins/shared.make_timestamp.php | 43 - .../libs/plugins/shared.mb_str_replace.php | 55 - .../smarty/libs/plugins/shared.mb_unicode.php | 54 - .../libs/plugins/shared.mb_wordwrap.php | 83 - .../variablefilter.htmlspecialchars.php | 19 - .../smarty/smarty/libs/sysplugins/index.html | 0 .../libs/sysplugins/smarty_cacheresource.php | 442 -- .../smarty_cacheresource_custom.php | 284 - .../smarty_cacheresource_keyvaluestore.php | 493 -- .../libs/sysplugins/smarty_config_source.php | 94 - .../smarty_internal_cacheresource_file.php | 294 -- .../smarty_internal_compile_append.php | 50 - .../smarty_internal_compile_assign.php | 86 - .../smarty_internal_compile_block.php | 438 -- .../smarty_internal_compile_break.php | 75 - .../smarty_internal_compile_call.php | 127 - .../smarty_internal_compile_capture.php | 96 - .../smarty_internal_compile_config_load.php | 82 - .../smarty_internal_compile_continue.php | 75 - .../smarty_internal_compile_debug.php | 41 - .../smarty_internal_compile_eval.php | 71 - .../smarty_internal_compile_extends.php | 85 - .../smarty_internal_compile_for.php | 145 - .../smarty_internal_compile_foreach.php | 229 - .../smarty_internal_compile_function.php | 167 - .../sysplugins/smarty_internal_compile_if.php | 210 - .../smarty_internal_compile_include.php | 265 - .../smarty_internal_compile_include_php.php | 107 - .../smarty_internal_compile_insert.php | 140 - .../smarty_internal_compile_ldelim.php | 39 - .../smarty_internal_compile_nocache.php | 70 - ..._internal_compile_private_block_plugin.php | 85 - ...ternal_compile_private_function_plugin.php | 71 - ...arty_internal_compile_private_modifier.php | 139 - ..._compile_private_object_block_function.php | 86 - ...ternal_compile_private_object_function.php | 84 - ...ernal_compile_private_print_expression.php | 151 - ...ernal_compile_private_registered_block.php | 111 - ...al_compile_private_registered_function.php | 79 - ...ernal_compile_private_special_variable.php | 114 - .../smarty_internal_compile_rdelim.php | 39 - .../smarty_internal_compile_section.php | 206 - .../smarty_internal_compile_setfilter.php | 70 - .../smarty_internal_compile_while.php | 93 - .../smarty_internal_compilebase.php | 174 - .../sysplugins/smarty_internal_config.php | 306 -- .../smarty_internal_config_file_compiler.php | 159 - .../smarty_internal_configfilelexer.php | 643 --- .../smarty_internal_configfileparser.php | 1042 ---- .../libs/sysplugins/smarty_internal_data.php | 576 --- .../libs/sysplugins/smarty_internal_debug.php | 254 - .../smarty_internal_filter_handler.php | 67 - .../smarty_internal_function_call_handler.php | 52 - .../smarty_internal_get_include_path.php | 46 - .../smarty_internal_nocache_insert.php | 51 - .../sysplugins/smarty_internal_parsetree.php | 394 -- .../smarty_internal_resource_eval.php | 96 - .../smarty_internal_resource_extends.php | 112 - .../smarty_internal_resource_file.php | 89 - .../smarty_internal_resource_php.php | 119 - .../smarty_internal_resource_registered.php | 98 - .../smarty_internal_resource_stream.php | 81 - .../smarty_internal_resource_string.php | 97 - ...smarty_internal_smartytemplatecompiler.php | 140 - .../sysplugins/smarty_internal_template.php | 737 --- .../smarty_internal_templatebase.php | 860 ---- .../smarty_internal_templatecompilerbase.php | 823 --- .../smarty_internal_templatelexer.php | 1557 ------ .../smarty_internal_templateparser.php | 4546 ----------------- .../sysplugins/smarty_internal_utility.php | 837 --- .../sysplugins/smarty_internal_write_file.php | 86 - .../libs/sysplugins/smarty_resource.php | 912 ---- .../sysplugins/smarty_resource_custom.php | 95 - .../sysplugins/smarty_resource_recompiled.php | 33 - .../sysplugins/smarty_resource_uncompiled.php | 41 - .../libs/sysplugins/smarty_security.php | 480 -- framework/vendor/symfony/index.html | 0 .../vendor/symfony/polyfill-ctype/Ctype.php | 227 - .../vendor/symfony/polyfill-ctype/LICENSE | 19 - .../vendor/symfony/polyfill-ctype/README.md | 12 - .../symfony/polyfill-ctype/bootstrap.php | 26 - .../symfony/polyfill-ctype/composer.json | 34 - .../vendor/symfony/polyfill-ctype/index.html | 0 .../vendor/symfony/polyfill-mbstring/LICENSE | 19 - .../symfony/polyfill-mbstring/Mbstring.php | 800 --- .../symfony/polyfill-mbstring/README.md | 13 - .../polyfill-mbstring/Resources/index.html | 0 .../Resources/unidata/index.html | 0 .../Resources/unidata/lowerCase.php | 1096 ---- .../Resources/unidata/titleCaseRegexp.php | 5 - .../Resources/unidata/upperCase.php | 1104 ---- .../symfony/polyfill-mbstring/bootstrap.php | 58 - .../symfony/polyfill-mbstring/composer.json | 34 - .../symfony/polyfill-mbstring/index.html | 0 framework/vendor/twig/index.html | 0 framework/vendor/twig/twig/.editorconfig | 18 - framework/vendor/twig/twig/.gitignore | 3 - framework/vendor/twig/twig/.php_cs.dist | 18 - framework/vendor/twig/twig/.travis.yml | 25 - framework/vendor/twig/twig/CHANGELOG | 1314 ----- framework/vendor/twig/twig/README.rst | 15 - framework/vendor/twig/twig/composer.json | 54 - framework/vendor/twig/twig/doc/advanced.rst | 960 ---- framework/vendor/twig/twig/doc/api.rst | 575 --- .../vendor/twig/twig/doc/coding_standards.rst | 101 - framework/vendor/twig/twig/doc/deprecated.rst | 104 - .../vendor/twig/twig/doc/filters/abs.rst | 18 - .../vendor/twig/twig/doc/filters/batch.rst | 48 - .../twig/twig/doc/filters/capitalize.rst | 11 - .../vendor/twig/twig/doc/filters/column.rst | 27 - .../twig/doc/filters/convert_encoding.rst | 22 - .../vendor/twig/twig/doc/filters/date.rst | 82 - .../twig/twig/doc/filters/date_modify.rst | 20 - .../vendor/twig/twig/doc/filters/default.rst | 33 - .../vendor/twig/twig/doc/filters/escape.rst | 119 - .../vendor/twig/twig/doc/filters/first.rst | 22 - .../vendor/twig/twig/doc/filters/format.rst | 16 - .../vendor/twig/twig/doc/filters/index.html | 0 .../vendor/twig/twig/doc/filters/index.rst | 38 - .../vendor/twig/twig/doc/filters/join.rst | 35 - .../twig/twig/doc/filters/json_encode.rst | 23 - .../vendor/twig/twig/doc/filters/keys.rst | 11 - .../vendor/twig/twig/doc/filters/last.rst | 22 - .../vendor/twig/twig/doc/filters/length.rst | 23 - .../vendor/twig/twig/doc/filters/lower.rst | 10 - .../vendor/twig/twig/doc/filters/merge.rst | 48 - .../vendor/twig/twig/doc/filters/nl2br.rst | 19 - .../twig/twig/doc/filters/number_format.rst | 50 - .../vendor/twig/twig/doc/filters/raw.rst | 38 - .../vendor/twig/twig/doc/filters/replace.rst | 25 - .../vendor/twig/twig/doc/filters/reverse.rst | 44 - .../vendor/twig/twig/doc/filters/round.rst | 34 - .../vendor/twig/twig/doc/filters/slice.rst | 68 - .../vendor/twig/twig/doc/filters/sort.rst | 18 - .../twig/twig/doc/filters/spaceless.rst | 65 - .../vendor/twig/twig/doc/filters/split.rst | 50 - .../twig/twig/doc/filters/striptags.rst | 29 - .../vendor/twig/twig/doc/filters/title.rst | 11 - .../vendor/twig/twig/doc/filters/trim.rst | 39 - .../vendor/twig/twig/doc/filters/upper.rst | 10 - .../twig/twig/doc/filters/url_encode.rst | 22 - .../twig/twig/doc/functions/attribute.rst | 23 - .../vendor/twig/twig/doc/functions/block.rst | 35 - .../twig/twig/doc/functions/constant.rst | 23 - .../vendor/twig/twig/doc/functions/cycle.rst | 28 - .../vendor/twig/twig/doc/functions/date.rst | 46 - .../vendor/twig/twig/doc/functions/dump.rst | 66 - .../twig/twig/doc/functions/include.rst | 77 - .../vendor/twig/twig/doc/functions/index.html | 0 .../vendor/twig/twig/doc/functions/index.rst | 20 - .../vendor/twig/twig/doc/functions/max.rst | 17 - .../vendor/twig/twig/doc/functions/min.rst | 17 - .../vendor/twig/twig/doc/functions/parent.rst | 20 - .../vendor/twig/twig/doc/functions/random.rst | 30 - .../vendor/twig/twig/doc/functions/range.rst | 58 - .../vendor/twig/twig/doc/functions/source.rst | 26 - .../doc/functions/template_from_string.rst | 40 - framework/vendor/twig/twig/doc/index.html | 0 framework/vendor/twig/twig/doc/index.rst | 19 - .../vendor/twig/twig/doc/installation.rst | 10 - framework/vendor/twig/twig/doc/internals.rst | 140 - framework/vendor/twig/twig/doc/intro.rst | 70 - framework/vendor/twig/twig/doc/recipes.rst | 527 -- framework/vendor/twig/twig/doc/tags/apply.rst | 23 - .../vendor/twig/twig/doc/tags/autoescape.rst | 61 - framework/vendor/twig/twig/doc/tags/block.rst | 11 - .../vendor/twig/twig/doc/tags/deprecated.rst | 30 - framework/vendor/twig/twig/doc/tags/do.rst | 9 - framework/vendor/twig/twig/doc/tags/embed.rst | 175 - .../vendor/twig/twig/doc/tags/extends.rst | 265 - .../vendor/twig/twig/doc/tags/filter.rst | 26 - framework/vendor/twig/twig/doc/tags/flush.rst | 14 - framework/vendor/twig/twig/doc/tags/for.rst | 169 - framework/vendor/twig/twig/doc/tags/from.rst | 8 - framework/vendor/twig/twig/doc/tags/if.rst | 79 - .../vendor/twig/twig/doc/tags/import.rst | 65 - .../vendor/twig/twig/doc/tags/include.rst | 111 - .../vendor/twig/twig/doc/tags/index.html | 0 framework/vendor/twig/twig/doc/tags/index.rst | 26 - framework/vendor/twig/twig/doc/tags/macro.rst | 96 - .../vendor/twig/twig/doc/tags/sandbox.rst | 30 - framework/vendor/twig/twig/doc/tags/set.rst | 78 - .../vendor/twig/twig/doc/tags/spaceless.rst | 41 - framework/vendor/twig/twig/doc/tags/use.rst | 117 - .../vendor/twig/twig/doc/tags/verbatim.rst | 16 - framework/vendor/twig/twig/doc/tags/with.rst | 41 - framework/vendor/twig/twig/doc/templates.rst | 914 ---- .../vendor/twig/twig/doc/tests/constant.rst | 19 - .../vendor/twig/twig/doc/tests/defined.rst | 30 - .../twig/twig/doc/tests/divisibleby.rst | 10 - .../vendor/twig/twig/doc/tests/empty.rst | 22 - framework/vendor/twig/twig/doc/tests/even.rst | 10 - .../vendor/twig/twig/doc/tests/index.html | 0 .../vendor/twig/twig/doc/tests/index.rst | 15 - .../vendor/twig/twig/doc/tests/iterable.rst | 16 - framework/vendor/twig/twig/doc/tests/null.rst | 12 - framework/vendor/twig/twig/doc/tests/odd.rst | 10 - .../vendor/twig/twig/doc/tests/sameas.rst | 11 - framework/vendor/twig/twig/index.html | 0 .../twig/twig/lib/Twig/BaseNodeVisitor.php | 14 - .../twig/twig/lib/Twig/Cache/Filesystem.php | 14 - .../vendor/twig/twig/lib/Twig/Cache/Null.php | 14 - .../twig/twig/lib/Twig/Cache/index.html | 0 .../twig/twig/lib/Twig/CacheInterface.php | 14 - .../vendor/twig/twig/lib/Twig/Compiler.php | 14 - .../twig/lib/Twig/ContainerRuntimeLoader.php | 14 - .../vendor/twig/twig/lib/Twig/Environment.php | 14 - framework/vendor/twig/twig/lib/Twig/Error.php | 14 - .../twig/twig/lib/Twig/Error/Loader.php | 14 - .../twig/twig/lib/Twig/Error/Runtime.php | 14 - .../twig/twig/lib/Twig/Error/Syntax.php | 14 - .../twig/twig/lib/Twig/Error/index.html | 0 .../twig/lib/Twig/ExistsLoaderInterface.php | 14 - .../twig/twig/lib/Twig/ExpressionParser.php | 14 - .../vendor/twig/twig/lib/Twig/Extension.php | 14 - .../twig/twig/lib/Twig/Extension/Core.php | 14 - .../twig/twig/lib/Twig/Extension/Debug.php | 14 - .../twig/twig/lib/Twig/Extension/Escaper.php | 14 - .../lib/Twig/Extension/GlobalsInterface.php | 14 - .../Twig/Extension/InitRuntimeInterface.php | 14 - .../twig/lib/Twig/Extension/Optimizer.php | 14 - .../twig/twig/lib/Twig/Extension/Profiler.php | 14 - .../twig/twig/lib/Twig/Extension/Sandbox.php | 14 - .../twig/twig/lib/Twig/Extension/Staging.php | 14 - .../twig/lib/Twig/Extension/StringLoader.php | 14 - .../twig/twig/lib/Twig/Extension/index.html | 0 .../twig/twig/lib/Twig/ExtensionInterface.php | 14 - .../twig/twig/lib/Twig/ExtensionSet.php | 14 - .../twig/lib/Twig/FactoryRuntimeLoader.php | 14 - .../Twig/FileExtensionEscapingStrategy.php | 14 - .../vendor/twig/twig/lib/Twig/Filter.php | 14 - .../vendor/twig/twig/lib/Twig/Function.php | 14 - framework/vendor/twig/twig/lib/Twig/Lexer.php | 14 - .../twig/twig/lib/Twig/Loader/Array.php | 14 - .../twig/twig/lib/Twig/Loader/Chain.php | 14 - .../twig/twig/lib/Twig/Loader/Filesystem.php | 14 - .../twig/twig/lib/Twig/Loader/index.html | 0 .../twig/twig/lib/Twig/LoaderInterface.php | 14 - .../vendor/twig/twig/lib/Twig/Markup.php | 14 - framework/vendor/twig/twig/lib/Twig/Node.php | 14 - .../twig/twig/lib/Twig/Node/AutoEscape.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Block.php | 14 - .../twig/lib/Twig/Node/BlockReference.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Body.php | 14 - .../twig/twig/lib/Twig/Node/CheckSecurity.php | 14 - .../twig/twig/lib/Twig/Node/Deprecated.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Do.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Embed.php | 14 - .../twig/twig/lib/Twig/Node/Expression.php | 14 - .../twig/lib/Twig/Node/Expression/Array.php | 14 - .../lib/Twig/Node/Expression/AssignName.php | 14 - .../twig/lib/Twig/Node/Expression/Binary.php | 14 - .../lib/Twig/Node/Expression/Binary/Add.php | 14 - .../lib/Twig/Node/Expression/Binary/And.php | 14 - .../Node/Expression/Binary/BitwiseAnd.php | 14 - .../Twig/Node/Expression/Binary/BitwiseOr.php | 14 - .../Node/Expression/Binary/BitwiseXor.php | 14 - .../Twig/Node/Expression/Binary/Concat.php | 14 - .../lib/Twig/Node/Expression/Binary/Div.php | 14 - .../Twig/Node/Expression/Binary/EndsWith.php | 14 - .../lib/Twig/Node/Expression/Binary/Equal.php | 14 - .../Twig/Node/Expression/Binary/FloorDiv.php | 14 - .../Twig/Node/Expression/Binary/Greater.php | 14 - .../Node/Expression/Binary/GreaterEqual.php | 14 - .../lib/Twig/Node/Expression/Binary/In.php | 14 - .../lib/Twig/Node/Expression/Binary/Less.php | 14 - .../Twig/Node/Expression/Binary/LessEqual.php | 14 - .../Twig/Node/Expression/Binary/Matches.php | 14 - .../lib/Twig/Node/Expression/Binary/Mod.php | 14 - .../lib/Twig/Node/Expression/Binary/Mul.php | 14 - .../Twig/Node/Expression/Binary/NotEqual.php | 14 - .../lib/Twig/Node/Expression/Binary/NotIn.php | 14 - .../lib/Twig/Node/Expression/Binary/Or.php | 14 - .../lib/Twig/Node/Expression/Binary/Power.php | 14 - .../lib/Twig/Node/Expression/Binary/Range.php | 14 - .../Node/Expression/Binary/StartsWith.php | 14 - .../lib/Twig/Node/Expression/Binary/Sub.php | 14 - .../Twig/Node/Expression/Binary/index.html | 0 .../Twig/Node/Expression/BlockReference.php | 14 - .../twig/lib/Twig/Node/Expression/Call.php | 14 - .../lib/Twig/Node/Expression/Conditional.php | 14 - .../lib/Twig/Node/Expression/Constant.php | 14 - .../twig/lib/Twig/Node/Expression/Filter.php | 14 - .../Twig/Node/Expression/Filter/Default.php | 14 - .../Twig/Node/Expression/Filter/index.html | 0 .../lib/Twig/Node/Expression/Function.php | 14 - .../twig/lib/Twig/Node/Expression/GetAttr.php | 14 - .../lib/Twig/Node/Expression/MethodCall.php | 14 - .../twig/lib/Twig/Node/Expression/Name.php | 14 - .../lib/Twig/Node/Expression/NullCoalesce.php | 14 - .../twig/lib/Twig/Node/Expression/Parent.php | 14 - .../lib/Twig/Node/Expression/TempName.php | 14 - .../twig/lib/Twig/Node/Expression/Test.php | 14 - .../Twig/Node/Expression/Test/Constant.php | 14 - .../lib/Twig/Node/Expression/Test/Defined.php | 14 - .../Twig/Node/Expression/Test/Divisibleby.php | 14 - .../lib/Twig/Node/Expression/Test/Even.php | 14 - .../lib/Twig/Node/Expression/Test/Null.php | 14 - .../lib/Twig/Node/Expression/Test/Odd.php | 14 - .../lib/Twig/Node/Expression/Test/Sameas.php | 14 - .../lib/Twig/Node/Expression/Test/index.html | 0 .../twig/lib/Twig/Node/Expression/Unary.php | 14 - .../lib/Twig/Node/Expression/Unary/Neg.php | 14 - .../lib/Twig/Node/Expression/Unary/Not.php | 14 - .../lib/Twig/Node/Expression/Unary/Pos.php | 14 - .../lib/Twig/Node/Expression/Unary/index.html | 0 .../twig/lib/Twig/Node/Expression/index.html | 0 .../vendor/twig/twig/lib/Twig/Node/Flush.php | 14 - .../vendor/twig/twig/lib/Twig/Node/For.php | 14 - .../twig/twig/lib/Twig/Node/ForLoop.php | 14 - .../vendor/twig/twig/lib/Twig/Node/If.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Import.php | 14 - .../twig/twig/lib/Twig/Node/Include.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Macro.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Module.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Print.php | 14 - .../twig/twig/lib/Twig/Node/Sandbox.php | 14 - .../twig/lib/Twig/Node/SandboxedPrint.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Set.php | 14 - .../twig/twig/lib/Twig/Node/Spaceless.php | 14 - .../vendor/twig/twig/lib/Twig/Node/Text.php | 14 - .../vendor/twig/twig/lib/Twig/Node/With.php | 14 - .../vendor/twig/twig/lib/Twig/Node/index.html | 0 .../twig/lib/Twig/NodeCaptureInterface.php | 14 - .../twig/lib/Twig/NodeOutputInterface.php | 14 - .../twig/twig/lib/Twig/NodeTraverser.php | 14 - .../twig/lib/Twig/NodeVisitor/Escaper.php | 14 - .../twig/lib/Twig/NodeVisitor/Optimizer.php | 14 - .../lib/Twig/NodeVisitor/SafeAnalysis.php | 14 - .../twig/lib/Twig/NodeVisitor/Sandbox.php | 14 - .../twig/twig/lib/Twig/NodeVisitor/index.html | 0 .../twig/lib/Twig/NodeVisitorInterface.php | 14 - .../vendor/twig/twig/lib/Twig/Parser.php | 14 - .../twig/lib/Twig/Profiler/Dumper/Base.php | 14 - .../lib/Twig/Profiler/Dumper/Blackfire.php | 14 - .../twig/lib/Twig/Profiler/Dumper/Html.php | 14 - .../twig/lib/Twig/Profiler/Dumper/Text.php | 14 - .../twig/lib/Twig/Profiler/Dumper/index.html | 0 .../lib/Twig/Profiler/Node/EnterProfile.php | 14 - .../lib/Twig/Profiler/Node/LeaveProfile.php | 14 - .../twig/lib/Twig/Profiler/Node/index.html | 0 .../Twig/Profiler/NodeVisitor/Profiler.php | 14 - .../lib/Twig/Profiler/NodeVisitor/index.html | 0 .../twig/twig/lib/Twig/Profiler/Profile.php | 14 - .../twig/twig/lib/Twig/Profiler/index.html | 0 .../twig/lib/Twig/RuntimeLoaderInterface.php | 14 - .../twig/lib/Twig/Sandbox/SecurityError.php | 14 - .../Sandbox/SecurityNotAllowedFilterError.php | 14 - .../SecurityNotAllowedFunctionError.php | 14 - .../Sandbox/SecurityNotAllowedMethodError.php | 14 - .../SecurityNotAllowedPropertyError.php | 14 - .../Sandbox/SecurityNotAllowedTagError.php | 14 - .../twig/lib/Twig/Sandbox/SecurityPolicy.php | 14 - .../Twig/Sandbox/SecurityPolicyInterface.php | 14 - .../twig/twig/lib/Twig/Sandbox/index.html | 0 .../twig/twig/lib/Twig/SimpleFilter.php | 26 - .../twig/twig/lib/Twig/SimpleFunction.php | 26 - .../vendor/twig/twig/lib/Twig/SimpleTest.php | 26 - .../vendor/twig/twig/lib/Twig/Source.php | 14 - .../lib/Twig/SourceContextLoaderInterface.php | 14 - .../vendor/twig/twig/lib/Twig/Template.php | 14 - .../twig/twig/lib/Twig/TemplateWrapper.php | 14 - framework/vendor/twig/twig/lib/Twig/Test.php | 14 - .../lib/Twig/Test/IntegrationTestCase.php | 14 - .../twig/twig/lib/Twig/Test/NodeTestCase.php | 14 - .../vendor/twig/twig/lib/Twig/Test/index.html | 0 framework/vendor/twig/twig/lib/Twig/Token.php | 14 - .../vendor/twig/twig/lib/Twig/TokenParser.php | 14 - .../twig/lib/Twig/TokenParser/AutoEscape.php | 14 - .../twig/twig/lib/Twig/TokenParser/Block.php | 14 - .../twig/lib/Twig/TokenParser/Deprecated.php | 14 - .../twig/twig/lib/Twig/TokenParser/Do.php | 14 - .../twig/twig/lib/Twig/TokenParser/Embed.php | 14 - .../twig/lib/Twig/TokenParser/Extends.php | 14 - .../twig/twig/lib/Twig/TokenParser/Filter.php | 14 - .../twig/twig/lib/Twig/TokenParser/Flush.php | 14 - .../twig/twig/lib/Twig/TokenParser/For.php | 14 - .../twig/twig/lib/Twig/TokenParser/From.php | 14 - .../twig/twig/lib/Twig/TokenParser/If.php | 14 - .../twig/twig/lib/Twig/TokenParser/Import.php | 14 - .../twig/lib/Twig/TokenParser/Include.php | 14 - .../twig/twig/lib/Twig/TokenParser/Macro.php | 14 - .../twig/lib/Twig/TokenParser/Sandbox.php | 14 - .../twig/twig/lib/Twig/TokenParser/Set.php | 14 - .../twig/lib/Twig/TokenParser/Spaceless.php | 14 - .../twig/twig/lib/Twig/TokenParser/Use.php | 14 - .../twig/twig/lib/Twig/TokenParser/With.php | 14 - .../twig/twig/lib/Twig/TokenParser/index.html | 0 .../twig/lib/Twig/TokenParserInterface.php | 14 - .../vendor/twig/twig/lib/Twig/TokenStream.php | 14 - .../lib/Twig/Util/DeprecationCollector.php | 14 - .../lib/Twig/Util/TemplateDirIterator.php | 14 - .../vendor/twig/twig/lib/Twig/Util/index.html | 0 .../vendor/twig/twig/lib/Twig/index.html | 0 framework/vendor/twig/twig/lib/index.html | 0 framework/vendor/twig/twig/phpunit.xml.dist | 33 - .../twig/twig/src/Cache/CacheInterface.php | 60 - .../twig/twig/src/Cache/FilesystemCache.php | 93 - .../vendor/twig/twig/src/Cache/NullCache.php | 40 - .../vendor/twig/twig/src/Cache/index.html | 0 framework/vendor/twig/twig/src/Compiler.php | 245 - .../vendor/twig/twig/src/Environment.php | 995 ---- .../vendor/twig/twig/src/Error/Error.php | 257 - .../twig/twig/src/Error/LoaderError.php | 23 - .../twig/twig/src/Error/RuntimeError.php | 24 - .../twig/twig/src/Error/SyntaxError.php | 48 - .../vendor/twig/twig/src/Error/index.html | 0 .../vendor/twig/twig/src/ExpressionParser.php | 740 --- .../twig/src/Extension/AbstractExtension.php | 47 - .../twig/twig/src/Extension/CoreExtension.php | 1731 ------- .../twig/src/Extension/DebugExtension.php | 66 - .../twig/src/Extension/EscaperExtension.php | 100 - .../twig/src/Extension/ExtensionInterface.php | 73 - .../twig/src/Extension/GlobalsInterface.php | 32 - .../src/Extension/InitRuntimeInterface.php | 36 - .../twig/src/Extension/OptimizerExtension.php | 31 - .../twig/src/Extension/ProfilerExtension.php | 48 - .../Extension/RuntimeExtensionInterface.php | 19 - .../twig/src/Extension/SandboxExtension.php | 125 - .../twig/src/Extension/StagingExtension.php | 102 - .../src/Extension/StringLoaderExtension.php | 46 - .../vendor/twig/twig/src/Extension/index.html | 0 .../vendor/twig/twig/src/ExtensionSet.php | 477 -- .../src/FileExtensionEscapingStrategy.php | 62 - framework/vendor/twig/twig/src/Lexer.php | 496 -- .../twig/twig/src/Loader/ArrayLoader.php | 86 - .../twig/twig/src/Loader/ChainLoader.php | 120 - .../twig/src/Loader/ExistsLoaderInterface.php | 23 - .../twig/twig/src/Loader/FilesystemLoader.php | 308 -- .../twig/twig/src/Loader/LoaderInterface.php | 69 - .../Loader/SourceContextLoaderInterface.php | 21 - .../vendor/twig/twig/src/Loader/index.html | 0 framework/vendor/twig/twig/src/Markup.php | 46 - .../twig/twig/src/Node/AutoEscapeNode.php | 40 - .../vendor/twig/twig/src/Node/BlockNode.php | 45 - .../twig/twig/src/Node/BlockReferenceNode.php | 38 - .../vendor/twig/twig/src/Node/BodyNode.php | 23 - .../twig/twig/src/Node/CheckSecurityNode.php | 85 - .../twig/twig/src/Node/CheckToStringNode.php | 45 - .../twig/twig/src/Node/DeprecatedNode.php | 55 - .../vendor/twig/twig/src/Node/DoNode.php | 40 - .../vendor/twig/twig/src/Node/EmbedNode.php | 50 - .../Node/Expression/AbstractExpression.php | 26 - .../src/Node/Expression/ArrayExpression.php | 88 - .../Node/Expression/AssignNameExpression.php | 29 - .../Node/Expression/Binary/AbstractBinary.php | 44 - .../src/Node/Expression/Binary/AddBinary.php | 25 - .../src/Node/Expression/Binary/AndBinary.php | 25 - .../Expression/Binary/BitwiseAndBinary.php | 25 - .../Expression/Binary/BitwiseOrBinary.php | 25 - .../Expression/Binary/BitwiseXorBinary.php | 25 - .../Node/Expression/Binary/ConcatBinary.php | 25 - .../src/Node/Expression/Binary/DivBinary.php | 25 - .../Node/Expression/Binary/EndsWithBinary.php | 37 - .../Node/Expression/Binary/EqualBinary.php | 24 - .../Node/Expression/Binary/FloorDivBinary.php | 31 - .../Node/Expression/Binary/GreaterBinary.php | 24 - .../Expression/Binary/GreaterEqualBinary.php | 24 - .../src/Node/Expression/Binary/InBinary.php | 35 - .../src/Node/Expression/Binary/LessBinary.php | 24 - .../Expression/Binary/LessEqualBinary.php | 24 - .../Node/Expression/Binary/MatchesBinary.php | 35 - .../src/Node/Expression/Binary/ModBinary.php | 25 - .../src/Node/Expression/Binary/MulBinary.php | 25 - .../Node/Expression/Binary/NotEqualBinary.php | 24 - .../Node/Expression/Binary/NotInBinary.php | 35 - .../src/Node/Expression/Binary/OrBinary.php | 25 - .../Node/Expression/Binary/PowerBinary.php | 24 - .../Node/Expression/Binary/RangeBinary.php | 35 - .../Expression/Binary/StartsWithBinary.php | 37 - .../src/Node/Expression/Binary/SubBinary.php | 25 - .../src/Node/Expression/Binary/index.html | 0 .../Expression/BlockReferenceExpression.php | 88 - .../src/Node/Expression/CallExpression.php | 313 -- .../Node/Expression/ConditionalExpression.php | 38 - .../Node/Expression/ConstantExpression.php | 30 - .../Node/Expression/Filter/DefaultFilter.php | 54 - .../src/Node/Expression/Filter/index.html | 0 .../src/Node/Expression/FilterExpression.php | 42 - .../Node/Expression/FunctionExpression.php | 45 - .../src/Node/Expression/GetAttrExpression.php | 89 - .../twig/src/Node/Expression/InlinePrint.php | 35 - .../Node/Expression/MethodCallExpression.php | 48 - .../src/Node/Expression/NameExpression.php | 92 - .../Expression/NullCoalesceExpression.php | 58 - .../src/Node/Expression/ParentExpression.php | 48 - .../Node/Expression/TempNameExpression.php | 33 - .../src/Node/Expression/Test/ConstantTest.php | 51 - .../src/Node/Expression/Test/DefinedTest.php | 73 - .../Node/Expression/Test/DivisiblebyTest.php | 38 - .../src/Node/Expression/Test/EvenTest.php | 37 - .../src/Node/Expression/Test/NullTest.php | 36 - .../twig/src/Node/Expression/Test/OddTest.php | 37 - .../src/Node/Expression/Test/SameasTest.php | 36 - .../twig/src/Node/Expression/Test/index.html | 0 .../src/Node/Expression/TestExpression.php | 44 - .../Node/Expression/Unary/AbstractUnary.php | 36 - .../src/Node/Expression/Unary/NegUnary.php | 25 - .../src/Node/Expression/Unary/NotUnary.php | 25 - .../src/Node/Expression/Unary/PosUnary.php | 25 - .../twig/src/Node/Expression/Unary/index.html | 0 .../Node/Expression/VariadicExpression.php | 24 - .../twig/twig/src/Node/Expression/index.html | 0 .../vendor/twig/twig/src/Node/FlushNode.php | 37 - .../vendor/twig/twig/src/Node/ForLoopNode.php | 56 - .../vendor/twig/twig/src/Node/ForNode.php | 119 - .../vendor/twig/twig/src/Node/IfNode.php | 72 - .../vendor/twig/twig/src/Node/ImportNode.php | 57 - .../vendor/twig/twig/src/Node/IncludeNode.php | 108 - .../vendor/twig/twig/src/Node/MacroNode.php | 111 - .../vendor/twig/twig/src/Node/ModuleNode.php | 470 -- framework/vendor/twig/twig/src/Node/Node.php | 211 - .../twig/src/Node/NodeCaptureInterface.php | 23 - .../twig/src/Node/NodeOutputInterface.php | 23 - .../vendor/twig/twig/src/Node/PrintNode.php | 41 - .../vendor/twig/twig/src/Node/SandboxNode.php | 47 - .../twig/twig/src/Node/SandboxedPrintNode.php | 54 - .../vendor/twig/twig/src/Node/SetNode.php | 103 - .../twig/twig/src/Node/SpacelessNode.php | 43 - .../vendor/twig/twig/src/Node/TextNode.php | 40 - .../vendor/twig/twig/src/Node/WithNode.php | 72 - .../vendor/twig/twig/src/Node/index.html | 0 .../vendor/twig/twig/src/NodeTraverser.php | 85 - .../src/NodeVisitor/AbstractNodeVisitor.php | 51 - .../src/NodeVisitor/EscaperNodeVisitor.php | 208 - .../src/NodeVisitor/NodeVisitorInterface.php | 51 - .../src/NodeVisitor/OptimizerNodeVisitor.php | 219 - .../NodeVisitor/SafeAnalysisNodeVisitor.php | 160 - .../src/NodeVisitor/SandboxNodeVisitor.php | 135 - .../twig/twig/src/NodeVisitor/index.html | 0 framework/vendor/twig/twig/src/Parser.php | 397 -- .../twig/src/Profiler/Dumper/BaseDumper.php | 65 - .../src/Profiler/Dumper/BlackfireDumper.php | 74 - .../twig/src/Profiler/Dumper/HtmlDumper.php | 49 - .../twig/src/Profiler/Dumper/TextDumper.php | 37 - .../twig/twig/src/Profiler/Dumper/index.html | 0 .../src/Profiler/Node/EnterProfileNode.php | 44 - .../src/Profiler/Node/LeaveProfileNode.php | 38 - .../twig/twig/src/Profiler/Node/index.html | 0 .../NodeVisitor/ProfilerNodeVisitor.php | 78 - .../twig/src/Profiler/NodeVisitor/index.html | 0 .../vendor/twig/twig/src/Profiler/Profile.php | 192 - .../vendor/twig/twig/src/Profiler/index.html | 0 .../RuntimeLoader/ContainerRuntimeLoader.php | 41 - .../RuntimeLoader/FactoryRuntimeLoader.php | 41 - .../RuntimeLoader/RuntimeLoaderInterface.php | 31 - .../twig/twig/src/RuntimeLoader/index.html | 0 .../twig/twig/src/Sandbox/SecurityError.php | 25 - .../Sandbox/SecurityNotAllowedFilterError.php | 46 - .../SecurityNotAllowedFunctionError.php | 46 - .../Sandbox/SecurityNotAllowedMethodError.php | 53 - .../SecurityNotAllowedPropertyError.php | 53 - .../Sandbox/SecurityNotAllowedTagError.php | 46 - .../twig/twig/src/Sandbox/SecurityPolicy.php | 128 - .../src/Sandbox/SecurityPolicyInterface.php | 37 - .../vendor/twig/twig/src/Sandbox/index.html | 0 framework/vendor/twig/twig/src/Source.php | 53 - framework/vendor/twig/twig/src/Template.php | 425 -- .../vendor/twig/twig/src/TemplateWrapper.php | 141 - .../twig/src/Test/IntegrationTestCase.php | 267 - .../twig/twig/src/Test/NodeTestCase.php | 67 - .../vendor/twig/twig/src/Test/index.html | 0 framework/vendor/twig/twig/src/Token.php | 207 - .../src/TokenParser/AbstractTokenParser.php | 34 - .../twig/src/TokenParser/ApplyTokenParser.php | 58 - .../src/TokenParser/AutoEscapeTokenParser.php | 57 - .../twig/src/TokenParser/BlockTokenParser.php | 78 - .../src/TokenParser/DeprecatedTokenParser.php | 44 - .../twig/src/TokenParser/DoTokenParser.php | 37 - .../twig/src/TokenParser/EmbedTokenParser.php | 72 - .../src/TokenParser/ExtendsTokenParser.php | 50 - .../src/TokenParser/FilterTokenParser.php | 61 - .../twig/src/TokenParser/FlushTokenParser.php | 37 - .../twig/src/TokenParser/ForTokenParser.php | 135 - .../twig/src/TokenParser/FromTokenParser.php | 64 - .../twig/src/TokenParser/IfTokenParser.php | 89 - .../src/TokenParser/ImportTokenParser.php | 43 - .../src/TokenParser/IncludeTokenParser.php | 68 - .../twig/src/TokenParser/MacroTokenParser.php | 66 - .../src/TokenParser/SandboxTokenParser.php | 65 - .../twig/src/TokenParser/SetTokenParser.php | 72 - .../src/TokenParser/SpacelessTokenParser.php | 55 - .../src/TokenParser/TokenParserInterface.php | 52 - .../twig/src/TokenParser/UseTokenParser.php | 73 - .../twig/src/TokenParser/WithTokenParser.php | 55 - .../twig/twig/src/TokenParser/index.html | 0 .../vendor/twig/twig/src/TokenStream.php | 133 - framework/vendor/twig/twig/src/TwigFilter.php | 150 - .../vendor/twig/twig/src/TwigFunction.php | 140 - framework/vendor/twig/twig/src/TwigTest.php | 109 - .../twig/src/Util/DeprecationCollector.php | 79 - .../twig/src/Util/TemplateDirIterator.php | 30 - .../vendor/twig/twig/src/Util/index.html | 0 framework/vendor/twig/twig/src/index.html | 0 .../test/Twig/Tests/Cache/FilesystemTest.php | 195 - .../twig/test/Twig/Tests/Cache/index.html | 0 .../twig/test/Twig/Tests/CompilerTest.php | 37 - .../Twig/Tests/ContainerRuntimeLoaderTest.php | 36 - .../test/Twig/Tests/CustomExtensionTest.php | 82 - .../twig/test/Twig/Tests/EnvironmentTest.php | 517 -- .../twig/twig/test/Twig/Tests/ErrorTest.php | 211 - .../test/Twig/Tests/ExpressionParserTest.php | 388 -- .../test/Twig/Tests/Extension/CoreTest.php | 366 -- .../test/Twig/Tests/Extension/SandboxTest.php | 368 -- .../twig/test/Twig/Tests/Extension/index.html | 0 .../Twig/Tests/FactoryRuntimeLoaderTest.php | 34 - .../FileExtensionEscapingStrategyTest.php | 53 - .../twig/test/Twig/Tests/FilesystemHelper.php | 26 - .../Twig/Tests/Fixtures/autoescape/block.test | 21 - .../Twig/Tests/Fixtures/autoescape/index.html | 0 .../Twig/Tests/Fixtures/autoescape/name.test | 22 - .../test/Twig/Tests/Fixtures/errors/base.html | 1 - .../Twig/Tests/Fixtures/errors/index.html | 7 - .../child_contents_outside_blocks.test | 15 - .../exception_in_extension_extends.test | 12 - .../exception_in_extension_include.test | 12 - .../Twig/Tests/Fixtures/exceptions/index.html | 0 ...ltiline_array_with_undefined_variable.test | 18 - ...e_array_with_undefined_variable_again.test | 18 - ...line_function_with_undefined_variable.test | 12 - ...tiline_function_with_unknown_argument.test | 9 - ...multiline_tag_with_undefined_variable.test | 12 - .../strict_comparison_operator.test | 6 - .../syntax_error_in_reused_template.test | 10 - .../Fixtures/exceptions/unclosed_tag.test | 20 - .../Fixtures/exceptions/undefined_parent.test | 10 - .../undefined_template_in_child_template.test | 15 - .../Fixtures/exceptions/undefined_trait.test | 9 - .../Tests/Fixtures/expressions/_self.test | 8 - .../Tests/Fixtures/expressions/array.test | 105 - .../Fixtures/expressions/array_call.test | 14 - .../Tests/Fixtures/expressions/binary.test | 46 - .../Tests/Fixtures/expressions/bitwise.test | 14 - .../call_argument_defined_twice.test | 8 - .../call_positional_arg_after_named_arg.test | 8 - .../Fixtures/expressions/comparison.test | 14 - .../Fixtures/expressions/divisibleby.test | 17 - .../Tests/Fixtures/expressions/dotdot.test | 20 - .../Tests/Fixtures/expressions/ends_with.test | 26 - .../Tests/Fixtures/expressions/floats.test | 14 - .../Tests/Fixtures/expressions/grouping.test | 8 - .../Tests/Fixtures/expressions/index.html | 0 .../Tests/Fixtures/expressions/literals.test | 22 - .../Fixtures/expressions/magic_call.test | 27 - .../Tests/Fixtures/expressions/matches.test | 12 - .../Fixtures/expressions/method_call.test | 28 - .../expressions/negative_numbers.test | 18 - .../expressions/operators_as_variables.test | 16 - .../Tests/Fixtures/expressions/postfix.test | 22 - .../Tests/Fixtures/expressions/power.test | 20 - .../Tests/Fixtures/expressions/sameas.test | 21 - .../Fixtures/expressions/starts_with.test | 27 - .../Tests/Fixtures/expressions/strings.test | 10 - .../expressions/ternary_operator.test | 18 - .../expressions/ternary_operator_noelse.test | 10 - .../expressions/ternary_operator_nothen.test | 10 - .../two_word_operators_as_variables.test | 8 - .../Tests/Fixtures/expressions/unary.test | 12 - .../expressions/unary_macro_arguments.test | 22 - .../expressions/unary_precedence.test | 14 - .../extensions/anonymous_functions.test | 10 - .../Twig/Tests/Fixtures/extensions/index.html | 0 .../test/Twig/Tests/Fixtures/filters/abs.test | 30 - .../Twig/Tests/Fixtures/filters/batch.test | 31 - .../Tests/Fixtures/filters/batch_float.test | 29 - .../filters/batch_with_empty_fill.test | 37 - .../filters/batch_with_exact_elements.test | 33 - .../Fixtures/filters/batch_with_fill.test | 37 - .../Fixtures/filters/batch_with_keys.test | 10 - .../filters/batch_with_more_elements.test | 23 - .../filters/batch_with_zero_elements.test | 10 - .../Twig/Tests/Fixtures/filters/column.test | 11 - .../Fixtures/filters/convert_encoding.test | 8 - .../Twig/Tests/Fixtures/filters/date.test | 90 - .../Fixtures/filters/date_default_format.test | 14 - .../filters/date_default_format_interval.test | 14 - .../Fixtures/filters/date_immutable.test | 35 - .../Tests/Fixtures/filters/date_interval.test | 17 - .../Tests/Fixtures/filters/date_modify.test | 14 - .../Fixtures/filters/date_namedargs.test | 13 - .../Twig/Tests/Fixtures/filters/default.test | 159 - .../Fixtures/filters/dynamic_filter.test | 10 - .../Twig/Tests/Fixtures/filters/escape.test | 8 - .../Fixtures/filters/escape_html_attr.test | 8 - .../Fixtures/filters/escape_javascript.test | 8 - .../filters/escape_non_supported_charset.test | 8 - .../Twig/Tests/Fixtures/filters/first.test | 17 - .../Tests/Fixtures/filters/force_escape.test | 18 - .../Twig/Tests/Fixtures/filters/format.test | 8 - .../Twig/Tests/Fixtures/filters/index.html | 0 .../Twig/Tests/Fixtures/filters/join.test | 38 - .../Tests/Fixtures/filters/json_encode.test | 12 - .../Twig/Tests/Fixtures/filters/last.test | 17 - .../Twig/Tests/Fixtures/filters/length.test | 40 - .../Tests/Fixtures/filters/length_utf8.test | 10 - .../Twig/Tests/Fixtures/filters/merge.test | 25 - .../Twig/Tests/Fixtures/filters/nl2br.test | 14 - .../Tests/Fixtures/filters/number_format.test | 18 - .../filters/number_format_default.test | 21 - .../Twig/Tests/Fixtures/filters/replace.test | 12 - .../Fixtures/filters/replace_invalid_arg.test | 8 - .../Twig/Tests/Fixtures/filters/reverse.test | 18 - .../Twig/Tests/Fixtures/filters/round.test | 22 - .../Twig/Tests/Fixtures/filters/slice.test | 54 - .../Twig/Tests/Fixtures/filters/sort.test | 12 - .../Tests/Fixtures/filters/spaceless.test | 8 - .../Tests/Fixtures/filters/special_chars.test | 8 - .../Twig/Tests/Fixtures/filters/split.test | 20 - .../Tests/Fixtures/filters/split_utf8.test | 22 - .../Tests/Fixtures/filters/static_calls.test | 10 - .../Twig/Tests/Fixtures/filters/trim.test | 24 - .../Tests/Fixtures/filters/urlencode.test | 14 - .../Tests/Fixtures/functions/attribute.test | 18 - .../Twig/Tests/Fixtures/functions/block.test | 12 - .../functions/block_with_template.test | 22 - .../functions/block_without_name.test | 12 - .../functions/block_without_parent.test | 11 - .../Tests/Fixtures/functions/constant.test | 10 - .../Twig/Tests/Fixtures/functions/cycle.test | 16 - .../Twig/Tests/Fixtures/functions/date.test | 27 - .../Fixtures/functions/date_namedargs.test | 11 - .../Twig/Tests/Fixtures/functions/dump.test | 16 - .../Tests/Fixtures/functions/dump_array.test | 19 - .../Fixtures/functions/dynamic_function.test | 10 - .../functions/include/assignment.test | 13 - .../functions/include/autoescaping.test | 10 - .../Fixtures/functions/include/basic.test | 17 - .../functions/include/expression.test | 17 - .../functions/include/ignore_missing.test | 10 - .../include/ignore_missing_exists.test | 11 - .../include/include_missing_extends.test | 13 - .../Fixtures/functions/include/index.html | 0 .../Fixtures/functions/include/missing.test | 8 - .../functions/include/missing_nested.test | 16 - .../Fixtures/functions/include/sandbox.test | 13 - .../functions/include/sandbox_disabling.test | 16 - .../sandbox_disabling_ignore_missing.test | 13 - .../functions/include/template_instance.test | 10 - .../functions/include/templates_as_array.test | 12 - .../functions/include/with_context.test | 16 - .../functions/include/with_variables.test | 12 - .../include_template_from_string.test | 11 - .../Twig/Tests/Fixtures/functions/index.html | 0 .../Tests/Fixtures/functions/magic_call.test | 8 - .../Fixtures/functions/magic_static_call.test | 10 - .../Twig/Tests/Fixtures/functions/max.test | 12 - .../Twig/Tests/Fixtures/functions/min.test | 12 - .../Twig/Tests/Fixtures/functions/range.test | 8 - .../recursive_block_with_inheritance.test | 21 - .../Twig/Tests/Fixtures/functions/source.test | 17 - .../Fixtures/functions/special_chars.test | 8 - .../Fixtures/functions/static_calls.test | 10 - .../functions/template_from_string.test | 15 - .../functions/template_from_string_error.test | 8 - .../Fixtures/functions/undefined_block.test | 16 - .../functions/undefined_block_deep.test | 20 - .../twig/test/Twig/Tests/Fixtures/index.html | 0 .../Tests/Fixtures/macros/default_values.test | 16 - .../Twig/Tests/Fixtures/macros/index.html | 0 .../Tests/Fixtures/macros/nested_calls.test | 18 - .../Fixtures/macros/reserved_variables.test | 14 - .../Twig/Tests/Fixtures/macros/simple.test | 22 - .../Twig/Tests/Fixtures/macros/varargs.test | 21 - .../Fixtures/macros/varargs_argument.test | 7 - .../Tests/Fixtures/macros/with_filters.test | 14 - .../regression/block_names_unicity.test | 19 - .../regression/combined_debug_info.test | 15 - .../Fixtures/regression/empty_token.test | 8 - .../Twig/Tests/Fixtures/regression/index.html | 0 .../Tests/Fixtures/regression/issue_1143.test | 23 - .../Fixtures/regression/multi_word_tests.test | 10 - .../regression/simple_xml_element.test | 17 - .../regression/strings_like_numbers.test | 8 - .../Twig/Tests/Fixtures/tags/apply/basic.test | 10 - .../Twig/Tests/Fixtures/tags/apply/index.html | 0 .../Fixtures/tags/apply/json_encode.test | 8 - .../Tests/Fixtures/tags/apply/multiple.test | 10 - .../Tests/Fixtures/tags/apply/nested.test | 16 - .../Twig/Tests/Fixtures/tags/apply/scope.test | 15 - .../Fixtures/tags/apply/with_for_tag.test | 13 - .../Fixtures/tags/apply/with_if_tag.test | 29 - .../Tests/Fixtures/tags/autoescape/basic.test | 22 - .../Fixtures/tags/autoescape/blocks.test | 12 - .../tags/autoescape/double_escaping.test | 10 - .../Fixtures/tags/autoescape/functions.test | 83 - .../Tests/Fixtures/tags/autoescape/index.html | 0 .../Fixtures/tags/autoescape/literal.test | 87 - .../Fixtures/tags/autoescape/nested.test | 26 - .../Fixtures/tags/autoescape/objects.test | 26 - .../Tests/Fixtures/tags/autoescape/raw.test | 10 - .../Fixtures/tags/autoescape/strategy.test | 11 - .../Tests/Fixtures/tags/autoescape/type.test | 69 - .../tags/autoescape/with_filters.test | 131 - .../autoescape/with_filters_arguments.test | 23 - .../autoescape/with_pre_escape_filters.test | 68 - .../with_preserves_safety_filters.test | 50 - .../Twig/Tests/Fixtures/tags/block/basic.test | 11 - .../tags/block/block_unique_name.test | 11 - .../Fixtures/tags/block/capturing_block.test | 24 - .../tags/block/conditional_block.test | 9 - .../Twig/Tests/Fixtures/tags/block/index.html | 0 .../Fixtures/tags/block/special_chars.test | 10 - .../tags/deprecated/block.legacy.test | 20 - .../Tests/Fixtures/tags/deprecated/index.html | 0 .../tags/deprecated/macro.legacy.test | 21 - .../tags/deprecated/template.legacy.test | 12 - .../Twig/Tests/Fixtures/tags/embed/basic.test | 35 - .../tags/embed/complex_dynamic_parent.test | 35 - .../Fixtures/tags/embed/dynamic_parent.test | 35 - .../Tests/Fixtures/tags/embed/error_line.test | 16 - .../Twig/Tests/Fixtures/tags/embed/index.html | 0 .../Tests/Fixtures/tags/embed/multiple.test | 50 - .../Tests/Fixtures/tags/embed/nested.test | 42 - .../Fixtures/tags/embed/with_extends.test | 60 - .../Fixtures/tags/filter/basic.legacy.test | 12 - .../Tests/Fixtures/tags/filter/index.html | 0 .../tags/filter/json_encode.legacy.test | 10 - .../Fixtures/tags/filter/multiple.legacy.test | 12 - .../Fixtures/tags/filter/nested.legacy.test | 19 - .../Fixtures/tags/filter/scope.legacy.test | 13 - .../tags/filter/with_for_tag.legacy.test | 15 - .../tags/filter/with_if_tag.legacy.test | 31 - .../Tests/Fixtures/tags/for/condition.test | 14 - .../Twig/Tests/Fixtures/tags/for/context.test | 18 - .../Twig/Tests/Fixtures/tags/for/else.test | 23 - .../Twig/Tests/Fixtures/tags/for/index.html | 0 .../Fixtures/tags/for/inner_variables.test | 17 - .../Twig/Tests/Fixtures/tags/for/keys.test | 11 - .../Fixtures/tags/for/keys_and_values.test | 11 - .../Tests/Fixtures/tags/for/loop_context.test | 19 - .../Fixtures/tags/for/loop_context_local.test | 10 - .../Fixtures/tags/for/loop_not_defined.test | 10 - .../tags/for/loop_not_defined_cond.test | 9 - .../Tests/Fixtures/tags/for/nested_else.test | 17 - .../Twig/Tests/Fixtures/tags/for/objects.test | 43 - .../Fixtures/tags/for/objects_countable.test | 47 - .../Tests/Fixtures/tags/for/recursive.test | 18 - .../Twig/Tests/Fixtures/tags/for/values.test | 11 - .../test/Twig/Tests/Fixtures/tags/from.test | 14 - .../Twig/Tests/Fixtures/tags/if/basic.test | 22 - .../Tests/Fixtures/tags/if/expression.test | 22 - .../Twig/Tests/Fixtures/tags/if/index.html | 0 .../Tests/Fixtures/tags/include/basic.test | 16 - .../Fixtures/tags/include/expression.test | 16 - .../Fixtures/tags/include/ignore_missing.test | 10 - .../tags/include/ignore_missing_exists.test | 11 - .../tags/include/include_missing_extends.test | 13 - .../Tests/Fixtures/tags/include/index.html | 0 .../Tests/Fixtures/tags/include/missing.test | 8 - .../Fixtures/tags/include/missing_nested.test | 16 - .../Tests/Fixtures/tags/include/only.test | 20 - .../tags/include/template_instance.test | 10 - .../tags/include/templates_as_array.test | 12 - .../Fixtures/tags/include/with_variables.test | 14 - .../test/Twig/Tests/Fixtures/tags/index.html | 0 .../Fixtures/tags/inheritance/basic.test | 14 - .../Fixtures/tags/inheritance/block_expr.test | 30 - .../tags/inheritance/block_expr2.test | 32 - .../tags/inheritance/capturing_block.test | 17 - .../tags/inheritance/conditional.test | 14 - .../inheritance/conditional_block.legacy.test | 16 - .../Fixtures/tags/inheritance/dynamic.test | 14 - .../Fixtures/tags/inheritance/empty.test | 10 - .../tags/inheritance/extends_as_array.test | 12 - .../extends_as_array_with_empty_name.test | 12 - .../extends_as_array_with_null_name.test | 12 - .../Fixtures/tags/inheritance/index.html | 0 .../Fixtures/tags/inheritance/multiple.test | 12 - .../tags/inheritance/multiple_dynamic.test | 22 - .../tags/inheritance/nested_blocks.test | 22 - .../nested_blocks_parent_only.test | 15 - .../tags/inheritance/nested_inheritance.test | 16 - .../Fixtures/tags/inheritance/parent.test | 12 - .../parent_as_template_wrapper.test | 12 - .../tags/inheritance/parent_change.test | 16 - .../tags/inheritance/parent_in_a_block.test | 8 - .../tags/inheritance/parent_isolation.test | 20 - .../tags/inheritance/parent_nested.test | 28 - .../inheritance/parent_without_extends.test | 8 - .../parent_without_extends_but_traits.test | 14 - .../tags/inheritance/template_instance.test | 14 - .../Tests/Fixtures/tags/inheritance/use.test | 44 - .../Twig/Tests/Fixtures/tags/macro/basic.test | 17 - .../Fixtures/tags/macro/endmacro_name.test | 16 - .../Tests/Fixtures/tags/macro/external.test | 17 - .../Twig/Tests/Fixtures/tags/macro/from.test | 18 - .../Tests/Fixtures/tags/macro/global.test | 14 - .../macro/import_from_string_template.test | 10 - .../Twig/Tests/Fixtures/tags/macro/index.html | 0 .../Fixtures/tags/macro/self_import.test | 17 - .../Fixtures/tags/macro/special_chars.test | 14 - .../Fixtures/tags/macro/super_globals.test | 14 - .../Tests/Fixtures/tags/sandbox/array.test | 16 - .../Tests/Fixtures/tags/sandbox/index.html | 0 .../Fixtures/tags/sandbox/not_valid1.test | 11 - .../Fixtures/tags/sandbox/not_valid2.test | 14 - .../Tests/Fixtures/tags/sandbox/simple.test | 22 - .../Twig/Tests/Fixtures/tags/set/basic.test | 20 - .../Fixtures/tags/set/capture-empty.test | 9 - .../Twig/Tests/Fixtures/tags/set/capture.test | 10 - .../Fixtures/tags/set/capture_scope.test | 10 - .../Tests/Fixtures/tags/set/expression.test | 12 - .../Twig/Tests/Fixtures/tags/set/index.html | 0 .../Tests/Fixtures/tags/set/inheritance.test | 24 - .../tags/set/inheritance_overriding.test | 24 - .../Tests/Fixtures/tags/set/mutating.test | 17 - .../Tests/Fixtures/tags/spaceless/index.html | 0 .../spaceless/root_level_in_child.legacy.test | 23 - .../Tests/Fixtures/tags/spaceless/simple.test | 14 - .../Tests/Fixtures/tags/special_chars.test | 8 - .../Twig/Tests/Fixtures/tags/use/aliases.test | 12 - .../Twig/Tests/Fixtures/tags/use/basic.test | 12 - .../Twig/Tests/Fixtures/tags/use/deep.test | 22 - .../Tests/Fixtures/tags/use/deep_empty.test | 10 - .../Twig/Tests/Fixtures/tags/use/index.html | 0 .../Tests/Fixtures/tags/use/inheritance.test | 25 - .../Tests/Fixtures/tags/use/inheritance2.test | 24 - .../Tests/Fixtures/tags/use/multiple.test | 21 - .../Fixtures/tags/use/multiple_aliases.test | 23 - .../Tests/Fixtures/tags/use/parent_block.test | 24 - .../Fixtures/tags/use/parent_block2.test | 24 - .../Fixtures/tags/use/parent_block3.test | 38 - .../Fixtures/tags/use/use_with_parent.test | 24 - .../Tests/Fixtures/tags/verbatim/basic.test | 10 - .../Tests/Fixtures/tags/verbatim/index.html | 0 .../tags/verbatim/whitespace_control.test | 56 - .../Twig/Tests/Fixtures/tags/with/basic.test | 13 - .../Tests/Fixtures/tags/with/expression.test | 10 - .../Tests/Fixtures/tags/with/globals.test | 10 - .../Twig/Tests/Fixtures/tags/with/index.html | 0 .../Tests/Fixtures/tags/with/iterable.test | 10 - .../Twig/Tests/Fixtures/tags/with/nested.test | 15 - .../Fixtures/tags/with/with_no_hash.test | 10 - .../Tests/Fixtures/tags/with/with_only.test | 10 - .../test/Twig/Tests/Fixtures/tests/array.test | 24 - .../Twig/Tests/Fixtures/tests/constant.test | 14 - .../Twig/Tests/Fixtures/tests/defined.test | 129 - .../Fixtures/tests/defined_for_attribute.test | 35 - .../Fixtures/tests/defined_for_blocks.test | 38 - .../defined_for_blocks_with_template.test | 17 - .../Fixtures/tests/defined_for_constants.test | 14 - .../tests/defined_on_complex_expr.test | 8 - .../Tests/Fixtures/tests/dynamic_test.test | 14 - .../test/Twig/Tests/Fixtures/tests/empty.test | 42 - .../test/Twig/Tests/Fixtures/tests/even.test | 14 - .../test/Twig/Tests/Fixtures/tests/in.test | 116 - .../Tests/Fixtures/tests/in_with_objects.test | 19 - .../test/Twig/Tests/Fixtures/tests/index.html | 0 .../Twig/Tests/Fixtures/tests/iterable.test | 19 - .../Tests/Fixtures/tests/null_coalesce.test | 30 - .../test/Twig/Tests/Fixtures/tests/odd.test | 10 - .../Twig/Tests/Fixtures/whitespace/index.html | 0 .../Tests/Fixtures/whitespace/trim_block.test | 68 - .../whitespace/trim_delimiter_as_strings.test | 10 - .../Tests/Fixtures/whitespace/trim_left.test | 32 - .../Fixtures/whitespace/trim_line_left.test | 33 - .../Fixtures/whitespace/trim_line_right.test | 32 - .../Tests/Fixtures/whitespace/trim_right.test | 28 - .../twig/test/Twig/Tests/IntegrationTest.php | 386 -- .../twig/twig/test/Twig/Tests/LexerTest.php | 370 -- .../twig/test/Twig/Tests/Loader/ArrayTest.php | 88 - .../twig/test/Twig/Tests/Loader/ChainTest.php | 95 - .../test/Twig/Tests/Loader/FilesystemTest.php | 242 - .../Twig/Tests/Loader/Fixtures/index.html | 0 .../array_inheritance_empty_parent.html.twig | 3 - ...y_inheritance_nonexistent_parent.html.twig | 3 - .../array_inheritance_null_parent.html.twig | 3 - .../array_inheritance_valid_parent.html.twig | 3 - .../Loader/Fixtures/inheritance/index.html | 0 .../Fixtures/inheritance/parent.html.twig | 1 - .../inheritance/spare_parent.html.twig | 1 - .../Tests/Loader/Fixtures/named/index.html | 1 - .../Loader/Fixtures/named_bis/index.html | 1 - .../Loader/Fixtures/named_final/index.html | 1 - .../Loader/Fixtures/named_quater/index.html | 0 .../Fixtures/named_quater/named_absolute.html | 1 - .../Loader/Fixtures/named_ter/index.html | 1 - .../Tests/Loader/Fixtures/normal/index.html | 1 - .../Loader/Fixtures/normal_bis/index.html | 1 - .../Loader/Fixtures/normal_final/index.html | 1 - .../Loader/Fixtures/normal_ter/index.html | 1 - .../Tests/Loader/Fixtures/phar/index.html | 0 .../Loader/Fixtures/phar/phar-sample.phar | Bin 6786 -> 0 bytes .../Tests/Loader/Fixtures/themes/index.html | 0 .../Fixtures/themes/theme1/blocks.html.twig | 3 - .../Loader/Fixtures/themes/theme1/index.html | 0 .../Fixtures/themes/theme2/blocks.html.twig | 3 - .../Loader/Fixtures/themes/theme2/index.html | 0 .../twig/test/Twig/Tests/Loader/index.html | 0 .../test/Twig/Tests/Node/AutoEscapeTest.php | 37 - .../Twig/Tests/Node/BlockReferenceTest.php | 34 - .../twig/test/Twig/Tests/Node/BlockTest.php | 43 - .../test/Twig/Tests/Node/DeprecatedTest.php | 82 - .../twig/twig/test/Twig/Tests/Node/DoTest.php | 36 - .../Twig/Tests/Node/Expression/ArrayTest.php | 41 - .../Tests/Node/Expression/AssignNameTest.php | 32 - .../Tests/Node/Expression/Binary/AddTest.php | 38 - .../Tests/Node/Expression/Binary/AndTest.php | 38 - .../Node/Expression/Binary/ConcatTest.php | 38 - .../Tests/Node/Expression/Binary/DivTest.php | 38 - .../Node/Expression/Binary/FloorDivTest.php | 38 - .../Tests/Node/Expression/Binary/ModTest.php | 38 - .../Tests/Node/Expression/Binary/MulTest.php | 38 - .../Tests/Node/Expression/Binary/OrTest.php | 38 - .../Tests/Node/Expression/Binary/SubTest.php | 38 - .../Tests/Node/Expression/Binary/index.html | 0 .../Twig/Tests/Node/Expression/CallTest.php | 153 - .../Tests/Node/Expression/ConditionalTest.php | 42 - .../Tests/Node/Expression/ConstantTest.php | 33 - .../Twig/Tests/Node/Expression/FilterTest.php | 160 - .../Tests/Node/Expression/FunctionTest.php | 120 - .../Tests/Node/Expression/GetAttrTest.php | 58 - .../Twig/Tests/Node/Expression/NameTest.php | 44 - .../Node/Expression/NullCoalesceTest.php | 27 - .../Twig/Tests/Node/Expression/ParentTest.php | 31 - .../Twig/Tests/Node/Expression/TestTest.php | 89 - .../Tests/Node/Expression/Unary/NegTest.php | 36 - .../Tests/Node/Expression/Unary/NotTest.php | 35 - .../Tests/Node/Expression/Unary/PosTest.php | 35 - .../Tests/Node/Expression/Unary/index.html | 0 .../Twig/Tests/Node/Expression/index.html | 0 .../twig/test/Twig/Tests/Node/ForTest.php | 200 - .../twig/twig/test/Twig/Tests/Node/IfTest.php | 95 - .../twig/test/Twig/Tests/Node/ImportTest.php | 45 - .../twig/test/Twig/Tests/Node/IncludeTest.php | 93 - .../twig/test/Twig/Tests/Node/MacroTest.php | 67 - .../twig/test/Twig/Tests/Node/ModuleTest.php | 268 - .../twig/test/Twig/Tests/Node/PrintTest.php | 33 - .../twig/test/Twig/Tests/Node/SandboxTest.php | 47 - .../twig/test/Twig/Tests/Node/SetTest.php | 78 - .../test/Twig/Tests/Node/SpacelessTest.php | 42 - .../twig/test/Twig/Tests/Node/TextTest.php | 31 - .../twig/twig/test/Twig/Tests/Node/index.html | 0 .../Twig/Tests/NodeVisitor/OptimizerTest.php | 114 - .../test/Twig/Tests/NodeVisitor/index.html | 0 .../twig/twig/test/Twig/Tests/ParserTest.php | 211 - .../Tests/Profiler/Dumper/AbstractTest.php | 105 - .../Tests/Profiler/Dumper/BlackfireTest.php | 34 - .../Twig/Tests/Profiler/Dumper/HtmlTest.php | 32 - .../Twig/Tests/Profiler/Dumper/TextTest.php | 32 - .../Twig/Tests/Profiler/Dumper/index.html | 0 .../test/Twig/Tests/Profiler/ProfileTest.php | 112 - .../twig/test/Twig/Tests/Profiler/index.html | 0 .../twig/test/Twig/Tests/TemplateTest.php | 746 --- .../test/Twig/Tests/TemplateWrapperTest.php | 68 - .../twig/test/Twig/Tests/TokenStreamTest.php | 73 - .../Tests/Util/DeprecationCollectorTest.php | 47 - .../twig/twig/test/Twig/Tests/Util/index.html | 0 .../twig/test/Twig/Tests/escapingTest.php | 325 -- .../twig/twig/test/Twig/Tests/index.html | 0 .../vendor/twig/twig/test/Twig/index.html | 0 framework/vendor/twig/twig/test/index.html | 0 1233 files changed, 1422 insertions(+), 84152 deletions(-) create mode 100644 framework/extend/JWT.php create mode 100644 framework/library/route/driver/Compatible.php delete mode 100644 framework/library/route/driver/Pathinfo.php delete mode 100644 framework/vendor/composer/autoload_files.php delete mode 100644 framework/vendor/composer/index.html delete mode 100644 framework/vendor/filp/index.html delete mode 100644 framework/vendor/filp/whoops/CHANGELOG.md delete mode 100644 framework/vendor/filp/whoops/LICENSE.md delete mode 100644 framework/vendor/filp/whoops/composer.json delete mode 100644 framework/vendor/filp/whoops/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Exception/Formatter.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Exception/Frame.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Exception/Inspector.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Exception/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/Handler.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Handler/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/css/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/js/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/js/prettify.min.js delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/js/whoops.base.js delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/js/zepto.min.js delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/env_details.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_code.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_list.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/frames_container.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/frames_description.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/header.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/header_outer.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/layout.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details_outer.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left_outer.html.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Run.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/RunInterface.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Util/HtmlDumperOutput.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Util/Misc.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Util/SystemFacade.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Util/TemplateHelper.php delete mode 100644 framework/vendor/filp/whoops/src/Whoops/Util/index.html delete mode 100644 framework/vendor/filp/whoops/src/Whoops/index.html delete mode 100644 framework/vendor/filp/whoops/src/index.html rename framework/vendor/{twig/twig => firebase/php-jwt}/LICENSE (82%) create mode 100644 framework/vendor/firebase/php-jwt/README.md create mode 100644 framework/vendor/firebase/php-jwt/composer.json create mode 100644 framework/vendor/firebase/php-jwt/src/BeforeValidException.php create mode 100644 framework/vendor/firebase/php-jwt/src/ExpiredException.php create mode 100644 framework/vendor/firebase/php-jwt/src/JWT.php create mode 100644 framework/vendor/firebase/php-jwt/src/SignatureInvalidException.php delete mode 100644 framework/vendor/index.html delete mode 100644 framework/vendor/psr/index.html delete mode 100644 framework/vendor/psr/log/.gitignore delete mode 100644 framework/vendor/psr/log/LICENSE delete mode 100644 framework/vendor/psr/log/Psr/Log/AbstractLogger.php delete mode 100644 framework/vendor/psr/log/Psr/Log/InvalidArgumentException.php delete mode 100644 framework/vendor/psr/log/Psr/Log/LogLevel.php delete mode 100644 framework/vendor/psr/log/Psr/Log/LoggerAwareInterface.php delete mode 100644 framework/vendor/psr/log/Psr/Log/LoggerAwareTrait.php delete mode 100644 framework/vendor/psr/log/Psr/Log/LoggerInterface.php delete mode 100644 framework/vendor/psr/log/Psr/Log/LoggerTrait.php delete mode 100644 framework/vendor/psr/log/Psr/Log/NullLogger.php delete mode 100644 framework/vendor/psr/log/Psr/Log/Test/LoggerInterfaceTest.php delete mode 100644 framework/vendor/psr/log/Psr/Log/Test/TestLogger.php delete mode 100644 framework/vendor/psr/log/Psr/Log/Test/index.html delete mode 100644 framework/vendor/psr/log/Psr/Log/index.html delete mode 100644 framework/vendor/psr/log/Psr/index.html delete mode 100644 framework/vendor/psr/log/README.md delete mode 100644 framework/vendor/psr/log/composer.json delete mode 100644 framework/vendor/psr/log/index.html delete mode 100644 framework/vendor/smarty/index.html delete mode 100644 framework/vendor/smarty/smarty/COPYING.lib delete mode 100644 framework/vendor/smarty/smarty/INHERITANCE_RELEASE_NOTES.txt delete mode 100644 framework/vendor/smarty/smarty/README delete mode 100644 framework/vendor/smarty/smarty/README.md delete mode 100644 framework/vendor/smarty/smarty/SMARTY_2_BC_NOTES.txt delete mode 100644 framework/vendor/smarty/smarty/SMARTY_3.0_BC_NOTES.txt delete mode 100644 framework/vendor/smarty/smarty/SMARTY_3.1_NOTES.txt delete mode 100644 framework/vendor/smarty/smarty/change_log.txt delete mode 100644 framework/vendor/smarty/smarty/composer.json delete mode 100644 framework/vendor/smarty/smarty/demo/configs/index.html delete mode 100644 framework/vendor/smarty/smarty/demo/configs/test.conf delete mode 100644 framework/vendor/smarty/smarty/demo/index.html delete mode 100644 framework/vendor/smarty/smarty/demo/index.php delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/cacheresource.apc.php delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/cacheresource.memcache.php delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/cacheresource.mysql.php delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/index.html delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/resource.extendsall.php delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/resource.mysql.php delete mode 100644 framework/vendor/smarty/smarty/demo/plugins/resource.mysqls.php delete mode 100644 framework/vendor/smarty/smarty/demo/templates/footer.tpl delete mode 100644 framework/vendor/smarty/smarty/demo/templates/header.tpl delete mode 100644 framework/vendor/smarty/smarty/demo/templates/index.html delete mode 100644 framework/vendor/smarty/smarty/demo/templates/index.tpl delete mode 100644 framework/vendor/smarty/smarty/index.html delete mode 100644 framework/vendor/smarty/smarty/libs/Smarty.class.php delete mode 100644 framework/vendor/smarty/smarty/libs/SmartyBC.class.php delete mode 100644 framework/vendor/smarty/smarty/libs/debug.tpl delete mode 100644 framework/vendor/smarty/smarty/libs/index.html delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/block.textformat.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.counter.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.cycle.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.fetch.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_checkboxes.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_image.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_options.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_radios.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_select_date.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_select_time.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.html_table.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.mailto.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/function.math.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/index.html delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.capitalize.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.date_format.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.debug_print_var.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.escape.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.regex_replace.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.replace.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.spacify.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifier.truncate.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.cat.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.count_characters.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.count_paragraphs.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.count_sentences.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.count_words.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.default.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.escape.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.from_charset.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.indent.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.lower.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.noprint.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.string_format.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.strip.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.strip_tags.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.to_charset.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.unescape.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.upper.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/modifiercompiler.wordwrap.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/outputfilter.trimwhitespace.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/shared.escape_special_chars.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/shared.literal_compiler_param.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/shared.make_timestamp.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/shared.mb_str_replace.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/shared.mb_unicode.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/shared.mb_wordwrap.php delete mode 100644 framework/vendor/smarty/smarty/libs/plugins/variablefilter.htmlspecialchars.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/index.html delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_cacheresource.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_cacheresource_custom.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_cacheresource_keyvaluestore.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_config_source.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_cacheresource_file.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_append.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_assign.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_block.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_break.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_call.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_capture.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_config_load.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_continue.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_debug.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_eval.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_extends.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_for.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_foreach.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_function.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_if.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_include.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_include_php.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_insert.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_ldelim.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_nocache.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_block_plugin.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_function_plugin.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_modifier.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_object_block_function.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_object_function.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_print_expression.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_registered_block.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_registered_function.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_private_special_variable.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_rdelim.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_section.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_setfilter.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compile_while.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_compilebase.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_config.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_config_file_compiler.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_configfilelexer.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_configfileparser.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_data.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_debug.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_filter_handler.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_function_call_handler.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_get_include_path.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_nocache_insert.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_parsetree.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_eval.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_extends.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_file.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_php.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_registered.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_stream.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_resource_string.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_smartytemplatecompiler.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_template.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_templatebase.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_templatecompilerbase.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_templatelexer.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_templateparser.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_utility.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_internal_write_file.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_resource.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_resource_custom.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_resource_recompiled.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_resource_uncompiled.php delete mode 100644 framework/vendor/smarty/smarty/libs/sysplugins/smarty_security.php delete mode 100644 framework/vendor/symfony/index.html delete mode 100644 framework/vendor/symfony/polyfill-ctype/Ctype.php delete mode 100644 framework/vendor/symfony/polyfill-ctype/LICENSE delete mode 100644 framework/vendor/symfony/polyfill-ctype/README.md delete mode 100644 framework/vendor/symfony/polyfill-ctype/bootstrap.php delete mode 100644 framework/vendor/symfony/polyfill-ctype/composer.json delete mode 100644 framework/vendor/symfony/polyfill-ctype/index.html delete mode 100644 framework/vendor/symfony/polyfill-mbstring/LICENSE delete mode 100644 framework/vendor/symfony/polyfill-mbstring/Mbstring.php delete mode 100644 framework/vendor/symfony/polyfill-mbstring/README.md delete mode 100644 framework/vendor/symfony/polyfill-mbstring/Resources/index.html delete mode 100644 framework/vendor/symfony/polyfill-mbstring/Resources/unidata/index.html delete mode 100644 framework/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php delete mode 100644 framework/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php delete mode 100644 framework/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php delete mode 100644 framework/vendor/symfony/polyfill-mbstring/bootstrap.php delete mode 100644 framework/vendor/symfony/polyfill-mbstring/composer.json delete mode 100644 framework/vendor/symfony/polyfill-mbstring/index.html delete mode 100644 framework/vendor/twig/index.html delete mode 100644 framework/vendor/twig/twig/.editorconfig delete mode 100644 framework/vendor/twig/twig/.gitignore delete mode 100644 framework/vendor/twig/twig/.php_cs.dist delete mode 100644 framework/vendor/twig/twig/.travis.yml delete mode 100644 framework/vendor/twig/twig/CHANGELOG delete mode 100644 framework/vendor/twig/twig/README.rst delete mode 100644 framework/vendor/twig/twig/composer.json delete mode 100644 framework/vendor/twig/twig/doc/advanced.rst delete mode 100644 framework/vendor/twig/twig/doc/api.rst delete mode 100644 framework/vendor/twig/twig/doc/coding_standards.rst delete mode 100644 framework/vendor/twig/twig/doc/deprecated.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/abs.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/batch.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/capitalize.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/column.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/convert_encoding.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/date.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/date_modify.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/default.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/escape.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/first.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/format.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/index.html delete mode 100644 framework/vendor/twig/twig/doc/filters/index.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/join.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/json_encode.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/keys.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/last.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/length.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/lower.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/merge.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/nl2br.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/number_format.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/raw.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/replace.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/reverse.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/round.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/slice.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/sort.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/spaceless.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/split.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/striptags.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/title.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/trim.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/upper.rst delete mode 100644 framework/vendor/twig/twig/doc/filters/url_encode.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/attribute.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/block.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/constant.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/cycle.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/date.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/dump.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/include.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/index.html delete mode 100644 framework/vendor/twig/twig/doc/functions/index.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/max.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/min.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/parent.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/random.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/range.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/source.rst delete mode 100644 framework/vendor/twig/twig/doc/functions/template_from_string.rst delete mode 100644 framework/vendor/twig/twig/doc/index.html delete mode 100644 framework/vendor/twig/twig/doc/index.rst delete mode 100644 framework/vendor/twig/twig/doc/installation.rst delete mode 100644 framework/vendor/twig/twig/doc/internals.rst delete mode 100644 framework/vendor/twig/twig/doc/intro.rst delete mode 100644 framework/vendor/twig/twig/doc/recipes.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/apply.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/autoescape.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/block.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/deprecated.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/do.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/embed.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/extends.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/filter.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/flush.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/for.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/from.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/if.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/import.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/include.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/index.html delete mode 100644 framework/vendor/twig/twig/doc/tags/index.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/macro.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/sandbox.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/set.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/spaceless.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/use.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/verbatim.rst delete mode 100644 framework/vendor/twig/twig/doc/tags/with.rst delete mode 100644 framework/vendor/twig/twig/doc/templates.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/constant.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/defined.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/divisibleby.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/empty.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/even.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/index.html delete mode 100644 framework/vendor/twig/twig/doc/tests/index.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/iterable.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/null.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/odd.rst delete mode 100644 framework/vendor/twig/twig/doc/tests/sameas.rst delete mode 100644 framework/vendor/twig/twig/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/BaseNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Cache/Filesystem.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Cache/Null.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Cache/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/CacheInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Compiler.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/ContainerRuntimeLoader.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Environment.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Error.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Error/Loader.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Error/Runtime.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Error/Syntax.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Error/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/ExistsLoaderInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/ExpressionParser.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Core.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Debug.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Escaper.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/GlobalsInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/InitRuntimeInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Optimizer.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Profiler.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Sandbox.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/Staging.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/StringLoader.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Extension/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/ExtensionInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/ExtensionSet.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/FactoryRuntimeLoader.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/FileExtensionEscapingStrategy.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Filter.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Function.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Lexer.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Loader/Array.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Loader/Chain.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Loader/Filesystem.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Loader/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/LoaderInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Markup.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/AutoEscape.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Block.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/BlockReference.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Body.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/CheckSecurity.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Deprecated.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Do.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Embed.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Array.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/AssignName.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Add.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/And.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/BitwiseAnd.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/BitwiseOr.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/BitwiseXor.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Concat.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Div.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/EndsWith.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Equal.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/FloorDiv.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Greater.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/GreaterEqual.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/In.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Less.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/LessEqual.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Matches.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Mod.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Mul.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/NotEqual.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/NotIn.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Or.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Power.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Range.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/StartsWith.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/Sub.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Binary/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/BlockReference.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Call.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Conditional.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Constant.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Filter.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Filter/Default.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Filter/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Function.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/GetAttr.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/MethodCall.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Name.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/NullCoalesce.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Parent.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/TempName.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Constant.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Defined.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Divisibleby.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Even.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Null.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Odd.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/Sameas.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Test/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Unary.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Unary/Neg.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Unary/Not.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Unary/Pos.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/Unary/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Expression/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Flush.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/For.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/ForLoop.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/If.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Import.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Include.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Macro.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Module.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Print.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Sandbox.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/SandboxedPrint.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Set.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Spaceless.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/Text.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/With.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Node/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeCaptureInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeOutputInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeTraverser.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeVisitor/Escaper.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeVisitor/Optimizer.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeVisitor/SafeAnalysis.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeVisitor/Sandbox.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeVisitor/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/NodeVisitorInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Parser.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Dumper/Base.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Dumper/Blackfire.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Dumper/Html.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Dumper/Text.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Dumper/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Node/EnterProfile.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Node/LeaveProfile.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Node/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/NodeVisitor/Profiler.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/NodeVisitor/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/Profile.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Profiler/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/RuntimeLoaderInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityError.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityNotAllowedFilterError.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityNotAllowedFunctionError.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityNotAllowedMethodError.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityNotAllowedPropertyError.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityNotAllowedTagError.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityPolicy.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/SecurityPolicyInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Sandbox/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/SimpleFilter.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/SimpleFunction.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/SimpleTest.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Source.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/SourceContextLoaderInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Template.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TemplateWrapper.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Test.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Test/IntegrationTestCase.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Test/NodeTestCase.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Test/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/Token.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/AutoEscape.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Block.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Deprecated.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Do.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Embed.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Extends.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Filter.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Flush.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/For.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/From.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/If.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Import.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Include.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Macro.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Sandbox.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Set.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Spaceless.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/Use.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/With.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParser/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenParserInterface.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/TokenStream.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Util/DeprecationCollector.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Util/TemplateDirIterator.php delete mode 100644 framework/vendor/twig/twig/lib/Twig/Util/index.html delete mode 100644 framework/vendor/twig/twig/lib/Twig/index.html delete mode 100644 framework/vendor/twig/twig/lib/index.html delete mode 100644 framework/vendor/twig/twig/phpunit.xml.dist delete mode 100644 framework/vendor/twig/twig/src/Cache/CacheInterface.php delete mode 100644 framework/vendor/twig/twig/src/Cache/FilesystemCache.php delete mode 100644 framework/vendor/twig/twig/src/Cache/NullCache.php delete mode 100644 framework/vendor/twig/twig/src/Cache/index.html delete mode 100644 framework/vendor/twig/twig/src/Compiler.php delete mode 100644 framework/vendor/twig/twig/src/Environment.php delete mode 100644 framework/vendor/twig/twig/src/Error/Error.php delete mode 100644 framework/vendor/twig/twig/src/Error/LoaderError.php delete mode 100644 framework/vendor/twig/twig/src/Error/RuntimeError.php delete mode 100644 framework/vendor/twig/twig/src/Error/SyntaxError.php delete mode 100644 framework/vendor/twig/twig/src/Error/index.html delete mode 100644 framework/vendor/twig/twig/src/ExpressionParser.php delete mode 100644 framework/vendor/twig/twig/src/Extension/AbstractExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/CoreExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/DebugExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/EscaperExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/ExtensionInterface.php delete mode 100644 framework/vendor/twig/twig/src/Extension/GlobalsInterface.php delete mode 100644 framework/vendor/twig/twig/src/Extension/InitRuntimeInterface.php delete mode 100644 framework/vendor/twig/twig/src/Extension/OptimizerExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/ProfilerExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/RuntimeExtensionInterface.php delete mode 100644 framework/vendor/twig/twig/src/Extension/SandboxExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/StagingExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/StringLoaderExtension.php delete mode 100644 framework/vendor/twig/twig/src/Extension/index.html delete mode 100644 framework/vendor/twig/twig/src/ExtensionSet.php delete mode 100644 framework/vendor/twig/twig/src/FileExtensionEscapingStrategy.php delete mode 100644 framework/vendor/twig/twig/src/Lexer.php delete mode 100644 framework/vendor/twig/twig/src/Loader/ArrayLoader.php delete mode 100644 framework/vendor/twig/twig/src/Loader/ChainLoader.php delete mode 100644 framework/vendor/twig/twig/src/Loader/ExistsLoaderInterface.php delete mode 100644 framework/vendor/twig/twig/src/Loader/FilesystemLoader.php delete mode 100644 framework/vendor/twig/twig/src/Loader/LoaderInterface.php delete mode 100644 framework/vendor/twig/twig/src/Loader/SourceContextLoaderInterface.php delete mode 100644 framework/vendor/twig/twig/src/Loader/index.html delete mode 100644 framework/vendor/twig/twig/src/Markup.php delete mode 100644 framework/vendor/twig/twig/src/Node/AutoEscapeNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/BlockNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/BlockReferenceNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/BodyNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/CheckSecurityNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/CheckToStringNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/DeprecatedNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/DoNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/EmbedNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/AbstractExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/ArrayExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/AssignNameExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/AbstractBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/AddBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/AndBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/BitwiseAndBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/BitwiseOrBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/BitwiseXorBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/ConcatBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/DivBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/EndsWithBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/EqualBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/FloorDivBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/GreaterBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/GreaterEqualBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/InBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/LessBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/LessEqualBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/MatchesBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/ModBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/MulBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/NotEqualBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/NotInBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/OrBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/PowerBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/RangeBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/StartsWithBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/SubBinary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Binary/index.html delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/BlockReferenceExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/CallExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/ConditionalExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/ConstantExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Filter/DefaultFilter.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Filter/index.html delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/FilterExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/FunctionExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/GetAttrExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/InlinePrint.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/MethodCallExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/NameExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/NullCoalesceExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/ParentExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/TempNameExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/ConstantTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/DefinedTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/DivisiblebyTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/EvenTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/NullTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/OddTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/SameasTest.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Test/index.html delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/TestExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Unary/AbstractUnary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Unary/NegUnary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Unary/NotUnary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Unary/PosUnary.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/Unary/index.html delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/VariadicExpression.php delete mode 100644 framework/vendor/twig/twig/src/Node/Expression/index.html delete mode 100644 framework/vendor/twig/twig/src/Node/FlushNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/ForLoopNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/ForNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/IfNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/ImportNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/IncludeNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/MacroNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/ModuleNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/Node.php delete mode 100644 framework/vendor/twig/twig/src/Node/NodeCaptureInterface.php delete mode 100644 framework/vendor/twig/twig/src/Node/NodeOutputInterface.php delete mode 100644 framework/vendor/twig/twig/src/Node/PrintNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/SandboxNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/SandboxedPrintNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/SetNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/SpacelessNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/TextNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/WithNode.php delete mode 100644 framework/vendor/twig/twig/src/Node/index.html delete mode 100644 framework/vendor/twig/twig/src/NodeTraverser.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/AbstractNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/EscaperNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/NodeVisitorInterface.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/OptimizerNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/SafeAnalysisNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/SandboxNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/src/NodeVisitor/index.html delete mode 100644 framework/vendor/twig/twig/src/Parser.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Dumper/BaseDumper.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Dumper/BlackfireDumper.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Dumper/HtmlDumper.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Dumper/TextDumper.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Dumper/index.html delete mode 100644 framework/vendor/twig/twig/src/Profiler/Node/EnterProfileNode.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Node/LeaveProfileNode.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/Node/index.html delete mode 100644 framework/vendor/twig/twig/src/Profiler/NodeVisitor/ProfilerNodeVisitor.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/NodeVisitor/index.html delete mode 100644 framework/vendor/twig/twig/src/Profiler/Profile.php delete mode 100644 framework/vendor/twig/twig/src/Profiler/index.html delete mode 100644 framework/vendor/twig/twig/src/RuntimeLoader/ContainerRuntimeLoader.php delete mode 100644 framework/vendor/twig/twig/src/RuntimeLoader/FactoryRuntimeLoader.php delete mode 100644 framework/vendor/twig/twig/src/RuntimeLoader/RuntimeLoaderInterface.php delete mode 100644 framework/vendor/twig/twig/src/RuntimeLoader/index.html delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityError.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityNotAllowedFilterError.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityNotAllowedFunctionError.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityNotAllowedMethodError.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityNotAllowedPropertyError.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityNotAllowedTagError.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityPolicy.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/SecurityPolicyInterface.php delete mode 100644 framework/vendor/twig/twig/src/Sandbox/index.html delete mode 100644 framework/vendor/twig/twig/src/Source.php delete mode 100644 framework/vendor/twig/twig/src/Template.php delete mode 100644 framework/vendor/twig/twig/src/TemplateWrapper.php delete mode 100644 framework/vendor/twig/twig/src/Test/IntegrationTestCase.php delete mode 100644 framework/vendor/twig/twig/src/Test/NodeTestCase.php delete mode 100644 framework/vendor/twig/twig/src/Test/index.html delete mode 100644 framework/vendor/twig/twig/src/Token.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/AbstractTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/ApplyTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/AutoEscapeTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/BlockTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/DeprecatedTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/DoTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/EmbedTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/ExtendsTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/FilterTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/FlushTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/ForTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/FromTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/IfTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/ImportTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/IncludeTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/MacroTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/SandboxTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/SetTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/SpacelessTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/TokenParserInterface.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/UseTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/WithTokenParser.php delete mode 100644 framework/vendor/twig/twig/src/TokenParser/index.html delete mode 100644 framework/vendor/twig/twig/src/TokenStream.php delete mode 100644 framework/vendor/twig/twig/src/TwigFilter.php delete mode 100644 framework/vendor/twig/twig/src/TwigFunction.php delete mode 100644 framework/vendor/twig/twig/src/TwigTest.php delete mode 100644 framework/vendor/twig/twig/src/Util/DeprecationCollector.php delete mode 100644 framework/vendor/twig/twig/src/Util/TemplateDirIterator.php delete mode 100644 framework/vendor/twig/twig/src/Util/index.html delete mode 100644 framework/vendor/twig/twig/src/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Cache/FilesystemTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Cache/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/CompilerTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/ContainerRuntimeLoaderTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/CustomExtensionTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/EnvironmentTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/ErrorTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/ExpressionParserTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Extension/CoreTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Extension/SandboxTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Extension/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/FactoryRuntimeLoaderTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/FileExtensionEscapingStrategyTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/FilesystemHelper.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/autoescape/block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/autoescape/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/autoescape/name.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/errors/base.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/errors/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/child_contents_outside_blocks.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/exception_in_extension_extends.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/exception_in_extension_include.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/multiline_array_with_undefined_variable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/multiline_array_with_undefined_variable_again.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/multiline_function_with_undefined_variable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/multiline_function_with_unknown_argument.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/multiline_tag_with_undefined_variable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/strict_comparison_operator.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/syntax_error_in_reused_template.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/unclosed_tag.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/undefined_parent.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/undefined_template_in_child_template.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/exceptions/undefined_trait.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/_self.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/array_call.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/binary.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/bitwise.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/call_argument_defined_twice.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/call_positional_arg_after_named_arg.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/comparison.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/divisibleby.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/dotdot.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/ends_with.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/floats.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/grouping.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/literals.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/magic_call.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/matches.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/method_call.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/negative_numbers.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/operators_as_variables.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/postfix.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/power.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/sameas.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/starts_with.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/strings.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/ternary_operator.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/ternary_operator_noelse.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/ternary_operator_nothen.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/two_word_operators_as_variables.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/unary.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/unary_macro_arguments.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/expressions/unary_precedence.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/extensions/anonymous_functions.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/extensions/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/abs.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_float.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_with_empty_fill.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_with_exact_elements.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_with_fill.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_with_keys.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_with_more_elements.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/batch_with_zero_elements.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/column.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/convert_encoding.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date_default_format.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date_default_format_interval.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date_immutable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date_interval.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date_modify.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/date_namedargs.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/default.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/dynamic_filter.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/escape.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/escape_html_attr.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/escape_javascript.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/escape_non_supported_charset.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/first.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/force_escape.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/format.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/join.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/json_encode.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/last.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/length.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/length_utf8.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/merge.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/nl2br.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/number_format.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/number_format_default.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/replace.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/replace_invalid_arg.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/reverse.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/round.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/slice.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/sort.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/spaceless.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/special_chars.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/split.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/split_utf8.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/static_calls.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/trim.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/filters/urlencode.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/attribute.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/block_with_template.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/block_without_name.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/block_without_parent.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/constant.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/cycle.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/date.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/date_namedargs.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/dump.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/dump_array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/dynamic_function.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/assignment.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/autoescaping.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/expression.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/ignore_missing.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/ignore_missing_exists.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/include_missing_extends.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/missing.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/missing_nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/sandbox.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/sandbox_disabling.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/sandbox_disabling_ignore_missing.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/template_instance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/templates_as_array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/with_context.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include/with_variables.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/include_template_from_string.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/magic_call.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/magic_static_call.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/max.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/min.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/range.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/recursive_block_with_inheritance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/source.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/special_chars.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/static_calls.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/template_from_string.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/template_from_string_error.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/undefined_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/functions/undefined_block_deep.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/default_values.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/nested_calls.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/reserved_variables.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/simple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/varargs.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/varargs_argument.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/macros/with_filters.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/block_names_unicity.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/combined_debug_info.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/empty_token.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/issue_1143.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/multi_word_tests.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/simple_xml_element.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/regression/strings_like_numbers.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/json_encode.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/multiple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/scope.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/with_for_tag.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/apply/with_if_tag.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/blocks.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/double_escaping.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/functions.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/literal.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/objects.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/raw.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/strategy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/type.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/with_filters.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/with_filters_arguments.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/with_pre_escape_filters.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/autoescape/with_preserves_safety_filters.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/block/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/block/block_unique_name.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/block/capturing_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/block/conditional_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/block/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/block/special_chars.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/deprecated/block.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/deprecated/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/deprecated/macro.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/deprecated/template.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/complex_dynamic_parent.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/dynamic_parent.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/error_line.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/multiple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/embed/with_extends.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/basic.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/json_encode.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/multiple.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/nested.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/scope.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/with_for_tag.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/filter/with_if_tag.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/condition.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/context.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/else.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/inner_variables.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/keys.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/keys_and_values.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/loop_context.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/loop_context_local.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/loop_not_defined.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/loop_not_defined_cond.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/nested_else.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/objects.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/objects_countable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/recursive.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/for/values.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/from.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/if/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/if/expression.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/if/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/expression.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/ignore_missing.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/ignore_missing_exists.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/include_missing_extends.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/missing.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/missing_nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/only.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/template_instance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/templates_as_array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/include/with_variables.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/block_expr.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/block_expr2.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/capturing_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/conditional.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/conditional_block.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/dynamic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/empty.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/extends_as_array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/extends_as_array_with_empty_name.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/extends_as_array_with_null_name.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/multiple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/multiple_dynamic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/nested_blocks.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/nested_blocks_parent_only.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/nested_inheritance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_as_template_wrapper.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_change.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_in_a_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_isolation.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_without_extends.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/parent_without_extends_but_traits.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/template_instance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/inheritance/use.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/endmacro_name.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/external.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/from.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/global.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/import_from_string_template.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/self_import.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/special_chars.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/macro/super_globals.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/sandbox/array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/sandbox/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/sandbox/not_valid1.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/sandbox/not_valid2.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/sandbox/simple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/capture-empty.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/capture.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/capture_scope.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/expression.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/inheritance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/inheritance_overriding.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/set/mutating.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/spaceless/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/spaceless/root_level_in_child.legacy.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/spaceless/simple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/special_chars.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/aliases.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/deep.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/deep_empty.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/inheritance.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/inheritance2.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/multiple.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/multiple_aliases.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/parent_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/parent_block2.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/parent_block3.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/use/use_with_parent.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/verbatim/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/verbatim/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/verbatim/whitespace_control.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/basic.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/expression.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/globals.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/iterable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/nested.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/with_no_hash.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tags/with/with_only.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/array.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/constant.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/defined.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/defined_for_attribute.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/defined_for_blocks.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/defined_for_blocks_with_template.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/defined_for_constants.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/defined_on_complex_expr.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/dynamic_test.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/empty.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/even.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/in.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/in_with_objects.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/iterable.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/null_coalesce.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/tests/odd.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/trim_block.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/trim_delimiter_as_strings.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/trim_left.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/trim_line_left.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/trim_line_right.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Fixtures/whitespace/trim_right.test delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/IntegrationTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/LexerTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/ArrayTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/ChainTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/FilesystemTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/array_inheritance_empty_parent.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/array_inheritance_nonexistent_parent.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/array_inheritance_null_parent.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/array_inheritance_valid_parent.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/parent.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/inheritance/spare_parent.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/named/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/named_bis/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/named_final/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/named_quater/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/named_quater/named_absolute.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/named_ter/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/normal/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/normal_bis/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/normal_final/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/normal_ter/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/phar/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/phar/phar-sample.phar delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/themes/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/themes/theme1/blocks.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/themes/theme1/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/themes/theme2/blocks.html.twig delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/Fixtures/themes/theme2/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Loader/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/AutoEscapeTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/BlockReferenceTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/BlockTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/DeprecatedTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/DoTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/ArrayTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/AssignNameTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/AddTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/AndTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/ConcatTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/DivTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/FloorDivTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/ModTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/MulTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/OrTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/SubTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Binary/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/CallTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/ConditionalTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/ConstantTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/FilterTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/FunctionTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/GetAttrTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/NameTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/NullCoalesceTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/ParentTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/TestTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Unary/NegTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Unary/NotTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Unary/PosTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/Unary/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/Expression/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/ForTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/IfTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/ImportTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/IncludeTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/MacroTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/ModuleTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/PrintTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/SandboxTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/SetTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/SpacelessTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/TextTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Node/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/NodeVisitor/OptimizerTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/NodeVisitor/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/ParserTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/Dumper/AbstractTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/Dumper/BlackfireTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/Dumper/HtmlTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/Dumper/TextTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/Dumper/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/ProfileTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Profiler/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/TemplateTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/TemplateWrapperTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/TokenStreamTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Util/DeprecationCollectorTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/Util/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/escapingTest.php delete mode 100644 framework/vendor/twig/twig/test/Twig/Tests/index.html delete mode 100644 framework/vendor/twig/twig/test/Twig/index.html delete mode 100644 framework/vendor/twig/twig/test/index.html diff --git a/README.md b/README.md index 1729840..35023b0 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,5 @@ # TOP-Framework -*这是一个部分代码源自三年前毕业设计中的代码集合,后经过一系列重构,形成的一套框架。在此准备写一个文档。* +*部分代码于四年前所写,后经过一系列重构,形成的一套框架。在此准备写一个文档。* ## 目录结构 遵循PSR-2规范的编码风格,遵循PSR-4自动加载规范。 @@ -20,7 +20,7 @@ -route 路由具体实现 -template 模板引擎具体实现 -...... 实际调用的类 - -middleware 面向控制器的中间件 + -middleware 默认中间件 -traits 通用trait -vendor composer加载的类库 -public 可访问公共资源 @@ -59,12 +59,6 @@ require '../framework/Framework.php'; // Framework::resourcePath('/resource/'); // 可使用常量RESOURCE取得该值 -// 当前入口文件默认模块,缺省值:home -// Framework::defaultModule('home'); - -// 路由模式,缺省值:1(pathinfo和兼容模式) -// Framework::runType(1); - Framework::appPath('../application/'); Framework::startApp(); ``` @@ -120,6 +114,7 @@ class Index 4. view($file = '', $param = [], $cache = false) 显示模板(得到模板文件渲染后的内容)。 +此外,控制器方法中可以使用view函数完成相同操作。 5. redirect($url) @@ -137,16 +132,29 @@ public function index() ``` 调用基础控制器中的view方法、并return出去,完成模板的展示。 ### 模板传值 -1. view方法 +1. view方法/view函数 ``` public function index() { return $this->view(null, [ 'param' => 'Hello world!' ]); + return view(null, [ + 'param' => 'Hello world!' + ]); } ``` -2. 直接return数组 +2. view_param函数 +``` +public function index() +{ + view_param([ + 'param' => 'Hello world!', + ]); + return $this->view(); +} +``` +3. 直接return数组 ``` public function index() { @@ -430,7 +438,7 @@ class 模型名称 extends Model 成功返回受影响的记录数,失败抛出DatabaseException异常。 -4. update($data, [$param = false]) +4. update($data, $param = false) 更新一条记录 第一个参数为即将更新的数据,可传入第二个参数为主键。 @@ -870,6 +878,12 @@ $data = $cache->get('text', function ($cache) { ## 路由 路由配置文件位于 application 下,文件名:route.php + +使用方法: +``` +规则名称 => [访问位置, 参数, 执行的中间件, 不执行的中间件] +``` + 现有News控制器中的detail方法 ``` public function detail($id) @@ -883,10 +897,7 @@ public function detail($id) ### 必须参数 添加如下规则 ``` -'detail' => [ - '[id]', - 'home/news/detail' -] +'detail' => ['home/news/detail', 'id'] ``` 完成后,可使用 http://127.0.0.1/detail/1.html 访问到对应位置。 ### 可选参数 @@ -901,18 +912,12 @@ public function detail($id = 0) ``` 添加路由规则 ``` -'detail' => [ - '[:id]', - 'home/news/detail' -] +'detail' => ['home/news/detail', '?id'] ``` 完成后,可使用 http://127.0.0.1/detail.html 访问到对应位置,如果没传递id,则使用默认值。 ### 多个参数 ``` -'detail' => [ - '[id][:type]', - 'home/news/detail' -] +'detail' => ['home/news/detail', 'id,?type'] ``` ## 其他 @@ -1054,7 +1059,7 @@ request(); 当前请求的模型名称 -12. classname +12. controllerFullName 当前请求的完整控制器名称 @@ -1095,7 +1100,13 @@ request()->get('id', ['type'], function ($value) { 使用同get方法 -18. except +18. header + +获取请求中header数据 + +使用同get方法 + +19. except 指定过滤的变量 @@ -1128,33 +1139,31 @@ readfile($filename); ``` 使用header方法设置响应头,接下来使用readfile函数将文件内容读取到缓冲区,这样输出时将下载demo.zip文件。或者直接使用header函数设置响应头也是可行的。 -### 面向控制器的前置、后置方法(请求拦截) -创建application/home/filter/Auth.php测试文件 +### 中间件 +创建application/home/middleware/Auth.php测试文件 ``` -namespace app\home\filter; +namespace app\home\middleware; use top\middleware\ifs\MiddlewareIfs; class Auth implements MiddlewareIfs { - public function before() + public function handler(\Closure $next) { - return '拒绝请求'; - } - - public function after($data) - { - // TODO: Implement after() method. + if (true) { + return '拒绝请求'; + } + return $next(); } } ``` 创建完成后,加入配置 ``` 'middleware' => [ - \app\home\filter\Auth::class + \app\home\middleware\Auth::class ], ``` -现在,访问项目则会得到 ' 拒绝请求 ' 结果。仅当before方法return的值为true时,程序才会继续执行,否则return等效于控制器方法的return。 +现在,访问项目则会得到 ' 拒绝请求 ' 结果。 ### 配置文件 以home模块为例,文件位置 'application/home/config/config.php'。此外还存在一个默认配置文件,文件位置 'framework/config/config.php',如果用户存在同名配置,将会执行merge操作。 diff --git a/composer.json b/composer.json index 381ae56..8795611 100644 --- a/composer.json +++ b/composer.json @@ -9,8 +9,6 @@ } }, "require": { - "filp/whoops": "2.2", - "twig/twig": "2.9", - "smarty/smarty": "3.1.19" + "firebase/php-jwt": "^5.0" } } diff --git a/composer.lock b/composer.lock index 56e4b54..785c15f 100644 --- a/composer.lock +++ b/composer.lock @@ -4,324 +4,32 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "b4062a2339b3d06b488764da6961940c", + "content-hash": "591be91ec1f1bc729042a4077e329da3", "packages": [ { - "name": "filp/whoops", - "version": "2.2.0", + "name": "firebase/php-jwt", + "version": "v5.0.0", "source": { "type": "git", - "url": "https://github.com/filp/whoops.git", - "reference": "181c4502d8f34db7aed7bfe88d4f87875b8e947a" + "url": "https://github.com/firebase/php-jwt.git", + "reference": "9984a4d3a32ae7673d6971ea00bae9d0a1abba0e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/filp/whoops/zipball/181c4502d8f34db7aed7bfe88d4f87875b8e947a", - "reference": "181c4502d8f34db7aed7bfe88d4f87875b8e947a", - "shasum": "" - }, - "require": { - "php": "^5.5.9 || ^7.0", - "psr/log": "^1.0.1" - }, - "require-dev": { - "mockery/mockery": "^0.9 || ^1.0", - "phpunit/phpunit": "^4.8.35 || ^5.7", - "symfony/var-dumper": "^2.6 || ^3.0 || ^4.0" - }, - "suggest": { - "symfony/var-dumper": "Pretty print complex values better with var-dumper available", - "whoops/soap": "Formats errors as SOAP responses" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.1-dev" - } - }, - "autoload": { - "psr-4": { - "Whoops\\": "src/Whoops/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Filipe Dobreira", - "homepage": "https://github.com/filp", - "role": "Developer" - } - ], - "description": "php error handling for cool kids", - "homepage": "https://filp.github.io/whoops/", - "keywords": [ - "error", - "exception", - "handling", - "library", - "throwable", - "whoops" - ], - "time": "2018-03-03T17:56:25+00:00" - }, - { - "name": "psr/log", - "version": "1.1.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/log.git", - "reference": "6c001f1daafa3a3ac1d8ff69ee4db8e799a654dd" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/log/zipball/6c001f1daafa3a3ac1d8ff69ee4db8e799a654dd", - "reference": "6c001f1daafa3a3ac1d8ff69ee4db8e799a654dd", + "url": "https://api.github.com/repos/firebase/php-jwt/zipball/9984a4d3a32ae7673d6971ea00bae9d0a1abba0e", + "reference": "9984a4d3a32ae7673d6971ea00bae9d0a1abba0e", "shasum": "" }, "require": { "php": ">=5.3.0" }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "autoload": { - "psr-4": { - "Psr\\Log\\": "Psr/Log/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" - } - ], - "description": "Common interface for logging libraries", - "homepage": "https://github.com/php-fig/log", - "keywords": [ - "log", - "psr", - "psr-3" - ], - "time": "2018-11-20T15:27:04+00:00" - }, - { - "name": "smarty/smarty", - "version": "v3.1.19", - "source": { - "type": "git", - "url": "https://github.com/smarty-php/smarty.git", - "reference": "be0fd3186ceec57e4da9a44031f517c06ae2418a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/smarty-php/smarty/zipball/be0fd3186ceec57e4da9a44031f517c06ae2418a", - "reference": "be0fd3186ceec57e4da9a44031f517c06ae2418a", - "shasum": "" - }, - "require": { - "php": ">=5.2" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.1.x-dev" - } - }, - "autoload": { - "classmap": [ - "libs/Smarty.class.php", - "libs/SmartyBC.class.php", - "libs/sysplugins/smarty_security.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "LGPL-3.0" - ], - "authors": [ - { - "name": "Monte Ohrt", - "email": "monte@ohrt.com" - }, - { - "name": "Uwe Tews", - "email": "uwe.tews@googlemail.com" - }, - { - "name": "Rodney Rehm", - "email": "rodney.rehm@medialize.de" - } - ], - "description": "Smarty - the compiling PHP template engine", - "homepage": "http://www.smarty.net", - "keywords": [ - "templating" - ], - "time": "2014-10-31T01:29:14+00:00" - }, - { - "name": "symfony/polyfill-ctype", - "version": "v1.11.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-ctype.git", - "reference": "82ebae02209c21113908c229e9883c419720738a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/82ebae02209c21113908c229e9883c419720738a", - "reference": "82ebae02209c21113908c229e9883c419720738a", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "suggest": { - "ext-ctype": "For best performance" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.11-dev" - } - }, - "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Ctype\\": "" - }, - "files": [ - "bootstrap.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - }, - { - "name": "Gert de Pagter", - "email": "BackEndTea@gmail.com" - } - ], - "description": "Symfony polyfill for ctype functions", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "ctype", - "polyfill", - "portable" - ], - "time": "2019-02-06T07:57:58+00:00" - }, - { - "name": "symfony/polyfill-mbstring", - "version": "v1.11.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-mbstring.git", - "reference": "fe5e94c604826c35a32fa832f35bd036b6799609" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/fe5e94c604826c35a32fa832f35bd036b6799609", - "reference": "fe5e94c604826c35a32fa832f35bd036b6799609", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "suggest": { - "ext-mbstring": "For best performance" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.11-dev" - } - }, - "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Mbstring\\": "" - }, - "files": [ - "bootstrap.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "description": "Symfony polyfill for the Mbstring extension", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "mbstring", - "polyfill", - "portable", - "shim" - ], - "time": "2019-02-06T07:57:58+00:00" - }, - { - "name": "twig/twig", - "version": "v2.9.0", - "source": { - "type": "git", - "url": "https://github.com/twigphp/Twig.git", - "reference": "82a1c055c8ed4c4705023bfd0405f3c74db6e3ae" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/twigphp/Twig/zipball/82a1c055c8ed4c4705023bfd0405f3c74db6e3ae", - "reference": "82a1c055c8ed4c4705023bfd0405f3c74db6e3ae", - "shasum": "" - }, - "require": { - "php": "^7.0", - "symfony/polyfill-ctype": "^1.8", - "symfony/polyfill-mbstring": "^1.3" - }, "require-dev": { - "psr/container": "^1.0", - "symfony/debug": "^2.7", - "symfony/phpunit-bridge": "^3.4.19|^4.1.8" + "phpunit/phpunit": " 4.8.35" }, "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.9-dev" - } - }, "autoload": { - "psr-0": { - "Twig_": "lib/" - }, "psr-4": { - "Twig\\": "src/" + "Firebase\\JWT\\": "src" } }, "notification-url": "https://packagist.org/downloads/", @@ -330,28 +38,19 @@ ], "authors": [ { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" + "name": "Neuman Vong", + "email": "neuman+pear@twilio.com", + "role": "Developer" }, { - "name": "Armin Ronacher", - "email": "armin.ronacher@active-4.com", - "role": "Project Founder" - }, - { - "name": "Twig Team", - "homepage": "https://twig.symfony.com/contributors", - "role": "Contributors" + "name": "Anant Narayanan", + "email": "anant@php.net", + "role": "Developer" } ], - "description": "Twig, the flexible, fast, and secure template language for PHP", - "homepage": "https://twig.symfony.com", - "keywords": [ - "templating" - ], - "time": "2019-04-28T06:57:38+00:00" + "description": "A simple library to encode and decode JSON Web Tokens (JWT) in PHP. Should conform to the current spec.", + "homepage": "https://github.com/firebase/php-jwt", + "time": "2017-06-27T22:17:23+00:00" } ], "packages-dev": [], diff --git a/framework/Framework.php b/framework/Framework.php index bb7e23e..19b2350 100644 --- a/framework/Framework.php +++ b/framework/Framework.php @@ -15,19 +15,12 @@ use top\library\App; class Framework { - // 程序运行方式 - private static $type = 1; - - // 默认访问模块 - private static $defaultModule = 'home'; - /** * 框架入口 * @param string $callable */ public static function startApp($callable = '') { - header('content-type: text/html; charset=utf-8'); if (is_callable($callable)) { $callable(self::class); @@ -46,7 +39,7 @@ class Framework self::sessionPath(); require 'library/App.php'; - App::run(self::$type, self::$defaultModule); + App::run(); } else { echo '请使用Framework::appPath()指定应用目录'; } @@ -135,21 +128,4 @@ class Framework } } - /** - * 指定默认访问位置 - * @param string $module - */ - public static function defaultModule($module) - { - self::$defaultModule = $module; - } - - /** - * 指定程序运行方式 - * @param int $type - */ - public static function runType($type) - { - self::$type = $type; - } } diff --git a/framework/config/config.php b/framework/config/config.php index 748f5d0..4820e82 100644 --- a/framework/config/config.php +++ b/framework/config/config.php @@ -5,7 +5,10 @@ return [ 'register' => [ 'Top' => \top\library\template\driver\Top::class, ], - 'middleware' => [], + 'middleware' => [ + \top\middleware\Init::class, + \top\middleware\View::class, + ], 'session' => [ 'open' => false, 'prefix' => '', diff --git a/framework/extend/JWT.php b/framework/extend/JWT.php new file mode 100644 index 0000000..79b6428 --- /dev/null +++ b/framework/extend/JWT.php @@ -0,0 +1,93 @@ +config = Config::instance()->get('jwt'); + if (isset($this->config['key'])) { + $this->key = $this->config['key']; + } else { + throw new \Exception('加密key参数必须'); + } + } + + /** + * 设置附加数据 + * @param $key + * @param $value + * @return $this + */ + public function setData($key, $value) + { + $this->data[$key] = $value; + return $this; + } + + /** + * 设置Token有效期 + * @param $sec + * @return $this + */ + public function exp($sec) + { + $this->exp = $sec; + return $this; + } + + /** + * 获取Token + * @return string + */ + public function token() + { + $time = time(); + $data = array_merge([ + 'iss' => $this->config['iss'], + 'aud' => $this->config['aud'], + 'iat' => $time, + 'nbf' => $time, + 'exp' => $time + $this->exp, + ], $this->data); + return $token = \Firebase\JWT\JWT::encode($data, $this->key, 'HS256'); + } + + /** + * 解析Token + * @param $jwt + * @return object + */ + public function decode($jwt) + { + return $result = \Firebase\JWT\JWT::decode($jwt, $this->key, ['HS256']); + } +} diff --git a/framework/extend/Page.php b/framework/extend/Page.php index 5279fe3..ba862a7 100644 --- a/framework/extend/Page.php +++ b/framework/extend/Page.php @@ -2,7 +2,6 @@ namespace top\extend; - /** * 分页类 * @author topnuomi 2018年11月28日 @@ -77,7 +76,11 @@ class Page // 链接没有匹配&或?,配置了伪静态也就无所谓了 $html = ''; return $html; diff --git a/framework/library/App.php b/framework/library/App.php index a6e7d90..3ba072c 100644 --- a/framework/library/App.php +++ b/framework/library/App.php @@ -6,6 +6,8 @@ use top\library\http\Request; use top\library\error\BaseError; use top\library\exception\BaseException; use top\library\http\Response; +use top\library\route\driver\Command; +use top\library\route\driver\Compatible; class App { @@ -13,9 +15,8 @@ class App /** * 开始执行程序 * @param int $type - * @param string $defaultModule */ - public static function run($type = 1, $defaultModule = 'home') + public static function run() { // 注册框架自动加载 require 'Loader.php'; @@ -40,16 +41,77 @@ class App } set_exception_handler([new BaseException(), 'handler']); - $request = Request::instance(); + $router = self::initRoute(); + $request = Request::instance()->setRoute($router); $response = Response::instance(); + // 加载必要文件 + self::loadFiles(); + // 处理请求并得到数据 $responseData = $response->header([ 'X-Powered-By: TOP-Framework' - ])->dispatch($request->execute($type, $defaultModule)); + ])->dispatch($request->execute()); // 输出内容 echo $responseData->content; } + + /** + * 初始化路由 + * @return Router + */ + private static function initRoute() + { + $driver = null; + if (php_sapi_name() == 'cli') { + // 命令行运行程序 + $driver = new Command(); + } else { + $driver = new Compatible(); + } + return (new Router($driver))->handler(); + } + + /** + * 加载必要文件 + */ + private static function loadFiles() + { + // 加载系统函数库 + require FRAMEWORK_PATH . 'library/functions/functions.php'; + + // 加载用户函数库 + $funcFile = APP_PATH . request()->module() . '/functions.php'; + if (file_exists($funcFile)) { + require $funcFile; + } + + $configInstance = Config::instance(); + + $sessionConfig = $configInstance->get('session'); + if (!empty($sessionConfig) && $sessionConfig['open'] === true) { + session_save_path(SESSION_PATH); + session_start(); + } + + // 数据库驱动 + $config = $configInstance->get('db'); + $driver = $config['driver'] ? $config['driver'] : 'MySQLi'; + Register::set('DBDriver', function () use ($driver) { + $class = '\\top\\library\\database\\driver\\' . $driver; + return $class::instance(); + }); + + // 配置文件中配置的注册 + $initRegister = $configInstance->get('register'); + if (!empty($initRegister)) { + foreach ($initRegister as $key => $value) { + Register::set($key, function () use ($value) { + return $value::instance(); + }); + } + } + } } diff --git a/framework/library/Controller.php b/framework/library/Controller.php index 58a4789..a5110a6 100644 --- a/framework/library/Controller.php +++ b/framework/library/Controller.php @@ -2,6 +2,8 @@ namespace top\library; +use top\traits\Json; + /** * 基础控制器 * @author topnuomi 2018年11月23日 @@ -9,6 +11,8 @@ namespace top\library; abstract class Controller { + use Json; + public function __construct() { } @@ -18,18 +22,11 @@ abstract class Controller * @param $msg * @param int $code * @param array $data - * @param array $ext - * @return false|string + * @return mixed */ - protected function json($msg, $code = 1, $data = [], $ext = []) + protected function json($msg, $code = 1, $data = []) { - $array = [ - 'msg' => $msg, - 'code' => $code, - 'data' => $data, - 'ext' => $ext - ]; - return json_encode($array); + return $this->returnJson($msg, $code, $data); } /** @@ -39,7 +36,7 @@ abstract class Controller */ protected function cache($param = true) { - View::instance()->cache($param); + view_cache($param); return $this; } @@ -50,7 +47,7 @@ abstract class Controller */ protected function param($name, $value) { - View::instance()->param($name, $value); + view_param($name, $value); } /** @@ -62,11 +59,11 @@ abstract class Controller */ protected function view($file = '', $param = [], $cache = false) { - return View::instance()->fetch($file, $param, $cache); + return view($file, $param, $cache); } /** - * 跳转(非ajax) + * 跳转 * @param $url */ protected function redirect($url) @@ -89,7 +86,7 @@ abstract class Controller $viewConfig = Config::instance()->get('view'); $tipsTemplate = $viewConfig['dir'] . 'tips.' . $viewConfig['ext']; (!file_exists($tipsTemplate)) && file_put_contents($tipsTemplate, ''); - return $this->view('tips', [ + return view('tips', [ 'message' => $message, 'url' => $url, 'sec' => $sec diff --git a/framework/library/Router.php b/framework/library/Router.php index 86fb91d..f4e136d 100644 --- a/framework/library/Router.php +++ b/framework/library/Router.php @@ -4,6 +4,7 @@ namespace top\library; use top\library\exception\RouteException; use top\library\route\ifs\RouteIfs; +use top\middleware\ifs\MiddlewareIfs; /** * 路由类 @@ -18,97 +19,180 @@ class Router private $driver; /** - * 当前URI - * @var string + * 自定义路由标识 + * @var null */ - public $uri = ''; + private $ident = null; /** - * 当前原始URI - * @var string - */ - public $rawUri = ''; - - /** - * 模块 - * @var string - */ - public $module = ''; - - /** - * 完整控制器类名 - * @var string - */ - public $class = ''; - - /** - * 控制器 - * @var string - */ - public $ctrl = ''; - - /** - * 方法名称 - * @var string - */ - public $method = ''; - - /** - * 请求参数 + * 自定义路由规则 * @var array */ - public $params = []; + private $rule = []; /** * 实例化时注入具体路由实现和默认位置 * Router constructor. * @param RouteIfs $driver - * @param $default */ - public function __construct(RouteIfs $driver, $default) + public function __construct(RouteIfs $driver) { $this->driver = $driver; - $this->driver->default = $default; - $this->driver->processing(); } /** - * 执行前进行必要检查 + * 完整控制器名 + * @return mixed + */ + public function controllerFullName() + { + return $this->driver->controllerFullName(); + } + + /** + * 控制器名 + * @return mixed + */ + public function controller() + { + return $this->driver->controller(); + } + + /** + * 模块名 + * @return mixed + */ + public function module() + { + return $this->driver->module(); + } + + /** + * 方法名 + * @return mixed + */ + public function method() + { + return $this->driver->method(); + } + + /** + * 请求参数 + * @return mixed + */ + public function params() + { + return $this->driver->params(); + } + + /** + * 获取当前的URI + * @return array + */ + public function uri() + { + $uri = null; + if (isset($_SERVER['PATH_INFO'])) { + $uri = $_SERVER['PATH_INFO']; + } elseif (isset($_GET['s']) && $_GET['s']) { + $uri = $_GET['s']; + } + $uri = str_replace('.html', '', trim($uri, '/')); + return $uri; + } + + /** + * 处理用户自定义路由规则 + * @param $uri + * @return string * @throws RouteException */ - private function check() + private function customRule($uri) { - // 检查模块是否存在 - if (!is_dir(APP_PATH . $this->module)) { - throw new RouteException('模块' . $this->module . '不存在'); - } - // 检查控制器是否存在 - if (!class_exists($this->class)) { - throw new RouteException('控制器' . $this->class . '不存在'); - } - // 检查方法在控制器中是否存在 - if (!in_array($this->method, get_class_methods($this->class))) { - throw new RouteException('方法' . $this->method . '在控制器' . $this->ctrl . '中不存在'); + // 准备检查自定义路由 + $file = APP_PATH . 'route.php'; + if (is_file($file)) $this->rule = require $file; + $uriArray = explode('/', $uri); + $ident = $this->ident = $uriArray[0]; + // 如果标识存在,则准备替换URI + if (isset($this->rule[$ident])) { + $uri = $this->rule[$ident][0]; + $paramString = null; + // 如果存在参数 + if (isset($this->rule[$ident][1]) && $this->rule[$ident][1]) { + $param = (count($uriArray) > 1) ? array_slice($uriArray, 1) : []; + $paramNames = explode(',', $this->rule[$ident][1]); + for ($i = 0; $i < count($paramNames); $i++) { + if (substr($paramNames[$i], 0, 1) == '?') { // 可选参数 + if (isset($param[$i]) && $param[$i]) { // 如果按顺序存在参数,且值有效 + $paramString .= substr($paramNames[$i], 1) . '/' . $param[$i] . '/'; + } + } else { + if (isset($param[$i]) && $param[$i]) { + $paramString .= $paramNames[$i] . '/' . $param[$i] . '/'; + } else { + throw new RouteException('链接中缺少必须参数' . $paramNames[$i]); + } + } + } + } + $uri .= '/' . rtrim($paramString, '/'); } + + return $uri; } /** - * 处理结果返回 + * 路由中间件 + * @param \Closure $application + * @return mixed + */ + public function middleware(\Closure $application) + { + // 不执行的中间件 + $exceptMiddlewareArray = []; + // 加载配置文件中配置的中间件 + $middlewareArray = Config::instance()->get('middleware'); + // 合并路由中配置的中间件、不执行的中间件 + if (isset($this->rule[$this->ident])) { + if (isset($this->rule[$this->ident][2]) && !empty(isset($this->rule[$this->ident][2]))) { + $middlewareArray = array_merge($middlewareArray, $this->rule[$this->ident][2]); + } + if (isset($this->rule[$this->ident][3]) && !empty(isset($this->rule[$this->ident][3]))) { + $exceptMiddlewareArray = $this->rule[$this->ident][3]; + } + } + $middleware = array_reverse($middlewareArray); + $next = $application; + foreach ($middleware as $value) { + if (!in_array($value, $exceptMiddlewareArray)) { + $next = function () use ($next, $value) { + $middleware = new $value; + if ($middleware instanceof MiddlewareIfs) { + return $middleware->handler($next); + } else { + throw new RouteException('中间件' . $value . '不属于MiddlewareIfs类型实例'); + } + }; + } + } + return $next(); + } + + /** + * 处理URI * @return $this - * @throws RouteException */ public function handler() { - $this->uri = $this->driver->uri; - $this->rawUri = $this->driver->rawUri; - $this->module = $this->driver->module; - $this->class = $this->driver->class; - $this->ctrl = $this->driver->ctrl; - $this->method = $this->driver->method; - $this->params = $this->driver->params; - - $this->check(); - + $uri = $this->uri(); + if ($uri) { + // 自定义路由规则 + $uri = $this->customRule($uri); + } + // 初始化路由驱动 + $this->driver->init(urldecode($uri)); return $this; } + } diff --git a/framework/library/functions/functions.php b/framework/library/functions/functions.php index 49c0f31..810c0d3 100644 --- a/framework/library/functions/functions.php +++ b/framework/library/functions/functions.php @@ -1,5 +1,32 @@ $value) { + $data[strtolower($key)] = $value; + } + unset($headers); + return $data; + } else { + $server = $_SERVER; + $headers = []; + foreach ($server as $key => $value) { + if ('http_' == strtolower(substr($key, 0, 5))) { + $headers[strtolower(substr($key, 5))] = $value; + } + } + unset($server); + return $headers; + } +} + /** * 过滤数组 * @param array $array @@ -44,35 +71,13 @@ function model($class) return $model[$class]; } -/** - * print_r - * @param array|string|int|object $value - */ -function p($value) -{ - echo '
';
-    print_r($value);
-    echo '
'; -} - -/** - * var_dump - * @param array|string|int|object $value - */ -function v($value) -{ - echo '
';
-    var_dump($value);
-    echo '
'; -} - /** * 拼接链接(暂时先这样 * @param string $url * @param string|int $param * @return string */ -function u($url, $param = '') +function url($url, $param = '') { if (!empty($param) || is_numeric($param)) { if (is_array($param)) { @@ -85,6 +90,37 @@ function u($url, $param = '') return '/' . $url . $param . '.html'; } +/** + * 设置视图缓存时间 + * @param $sec + */ +function view_cache($sec) +{ + \top\library\View::instance()->cache($sec); +} + +/** + * 参数传递 + * @param $name + * @param $value + */ +function view_param($name, $value) +{ + \top\library\View::instance()->param($name, $value); +} + +/** + * 显示视图 + * @param string $file + * @param array $param + * @param bool $cache + * @return mixed + */ +function view($file = '', $param = [], $cache = false) +{ + return \top\library\View::instance()->fetch($file, $param, $cache); +} + /** * 获取表名 * @param $classname @@ -174,11 +210,17 @@ function get_client_ip($type = 0, $client = true) /** * 页面跳转 * @param $url + * @return false|string */ function redirect($url) { - header('location: ' . u($url)); - exit; + if (request()->isAjax()) { + return json_encode([ + 'redirect' => $url, + ]); + } else { + header('location: ' . $url); + } } /** diff --git a/framework/library/http/Request.php b/framework/library/http/Request.php index 6671916..0c97f08 100644 --- a/framework/library/http/Request.php +++ b/framework/library/http/Request.php @@ -2,13 +2,7 @@ namespace top\library\http; -use top\library\Config; -use top\middleware\ifs\MiddlewareIfs; -use top\middleware\Init; -use top\library\route\driver\Command; -use top\library\route\driver\Pathinfo; -use top\library\Router; -use top\middleware\View; +use top\library\exception\RouteException; use top\traits\Instance; /** @@ -38,30 +32,6 @@ class Request */ private $router = null; - /** - * 模块名 - * @var string - */ - private $module = ''; - - /** - * 控制器完整类名 - * @var string - */ - private $class = ''; - - /** - * 控制器名 - * @var string - */ - private $ctrl = ''; - - /** - * 请求参数 - * @var array - */ - private $params = []; - /** * post、get数据删除的值 * @var array @@ -179,15 +149,11 @@ class Request /** * 当前请求的URI - * @param bool $raw * @return mixed */ - public function uri($raw = false) + public function uri() { - if ($raw) { - return $this->router->rawUri; - } - return $this->router->uri; + return $this->router->uri(); } /** @@ -196,16 +162,16 @@ class Request */ public function module() { - return $this->router->module; + return $this->router->module(); } /** * 控制器完整类名 * @return mixed */ - public function className() + public function controllerFullName() { - return $this->router->class; + return $this->router->controllerFullName(); } /** @@ -214,7 +180,7 @@ class Request */ public function controller() { - return $this->router->ctrl; + return $this->router->controller(); } /** @@ -223,7 +189,7 @@ class Request */ public function method() { - return $this->router->method; + return $this->router->method(); } /** @@ -232,7 +198,7 @@ class Request */ public function params() { - return $this->router->params; + return $this->router->params(); } /** @@ -250,6 +216,23 @@ class Request return $this; } + /** + * 请求的header数据 + * @param string $key + * @return array|false|null + */ + public function header($key = '*') + { + $headers = get_header(); + if ($key == '*') { + return $headers; + } elseif ($key && isset($headers[$key])) { + return $headers[$key]; + } else { + return null; + } + } + /** * GET数据 * @param string $name @@ -316,107 +299,34 @@ class Request } /** - * 设置中间件 - * @param MiddlewareIfs $middleware + * 指定路由 + * @param $router + * @return $this */ - private function middleware(MiddlewareIfs $middleware) + public function setRoute($router) { - $this->middleware[] = $middleware; - } - - /** - * 中间件前置方法 - */ - private function beforeRoute() - { - foreach ($this->middleware as $middleware) { - $returnData = $middleware->before(); - if ($returnData !== true) { - return $returnData; - } - unset($returnData); - } - return true; - } - - /** - * 中间件后置方法 - * @param $data - */ - private function afterRoute($data) - { - $this->middleware = array_reverse($this->middleware); - foreach ($this->middleware as $middleware) { - $middleware->after($data); - } - } - - /** - * 指定路由驱动 - * @param $type - * @return string|Command|Pathinfo - */ - private function routeDriver($type) - { - $routeDriver = ''; - if (php_sapi_name() == 'cli') { - // 命令行运行程序 - $routeDriver = new Command(); - } else { - // 其他方式 - switch ($type) { - case 1: - $routeDriver = new Pathinfo(); - break; - default: - // 其他 - } - } - return $routeDriver; + $this->router = $router; + return $this; } /** * 设置路由并执行程序 - * @param $type - * @param $defaultModule * @return mixed - * @throws \top\library\exception\RouteException */ - public function execute($type, $defaultModule) + public function execute() { - // 实例化路由,并执行对应方法 - $routeDriver = $this->routeDriver($type); - $this->router = (new Router($routeDriver, $defaultModule))->handler(); + $this->check(); - $userMiddleware = Config::instance()->get('middleware'); - $systemMiddleware = [Init::class, View::class]; + // 将执行应用打包为$application + $application = function () { - $middleware = array_merge($systemMiddleware, $userMiddleware); - foreach ($middleware as $key => $value) { - $this->middleware(new $value()); - } - - $data = $this->runAction(); - return $data; - } - - /** - * 调用对应方法 - * @return mixed - * @throws \ReflectionException - */ - private function runAction() - { - $middlewareData = $this->beforeRoute(); - - if ($middlewareData === true) { - $ctrl = $this->router->class; - $method = $this->router->method; - $params = $this->router->params; + $controllerFullName = $this->controllerFullName(); + $method = $this->method(); + $params = $this->params(); $data = null; - $object = new $ctrl(); - $reflectionClass = new \ReflectionClass($ctrl); + $object = new $controllerFullName(); + $reflectionClass = new \ReflectionClass($controllerFullName); if ($reflectionClass->hasMethod('_init')) { $data = $object->_init(); } @@ -430,7 +340,7 @@ class Request } if ($beforeReturnData === null || $beforeReturnData === '' || $beforeReturnData === true) { - $reflectionMethod = new \ReflectionMethod($ctrl, $method); + $reflectionMethod = new \ReflectionMethod($controllerFullName, $method); $data = $reflectionMethod->invokeArgs($object, $params); // 后置方法 @@ -442,16 +352,35 @@ class Request $data = $beforeReturnData; } } - } else { - $data = $middlewareData; + return $data; + }; + + // 由路由中间件去处理application,并返回结果 + return $this->router->middleware($application); + } + + /** + * 执行必要检查 + * @throws RouteException + */ + private function check() + { + // 检查模块是否存在 + if (!is_dir(APP_PATH . $this->module())) { + throw new RouteException('模块' . $this->module() . '不存在'); + } + // 检查控制器是否存在 + if (!class_exists($this->controllerFullName())) { + throw new RouteException('控制器' . $this->controllerFullName() . '不存在'); + } + // 检查方法在控制器中是否存在 + if (!in_array($this->method(), get_class_methods($this->controllerFullName()))) { + throw new RouteException('方法' . $this->method() . '在控制器' . $this->controller() . '中不存在'); } - - $this->afterRoute($data); - - return $data; } public function __destruct() { + } } diff --git a/framework/library/http/Response.php b/framework/library/http/Response.php index ed34a6e..783a846 100644 --- a/framework/library/http/Response.php +++ b/framework/library/http/Response.php @@ -63,4 +63,4 @@ class Response } } -} \ No newline at end of file +} diff --git a/framework/library/http/response/ResponseData.php b/framework/library/http/response/ResponseData.php index 87b75c7..1619d57 100644 --- a/framework/library/http/response/ResponseData.php +++ b/framework/library/http/response/ResponseData.php @@ -22,7 +22,7 @@ class ResponseData public function __construct($data) { - if (DEBUG === false) { + if (DEBUG === false && php_sapi_name() != 'cli') { ob_clean(); } $this->data = $this->checkData($data); @@ -68,4 +68,4 @@ class ResponseData { return $this->data; } -} \ No newline at end of file +} diff --git a/framework/library/route/driver/Command.php b/framework/library/route/driver/Command.php index 763314c..ffd2d56 100644 --- a/framework/library/route/driver/Command.php +++ b/framework/library/route/driver/Command.php @@ -4,70 +4,113 @@ namespace top\library\route\driver; use top\library\route\ifs\RouteIfs; +/** + * 命令行模式 + * Class Command + * @package top\library\route\driver + */ class Command implements RouteIfs { - // 模块 - public $module = ''; - - // 类名 - public $class = ''; - - // 控制器 - public $ctrl = ''; - - // 方法 - public $method = ''; - - // 参数 - public $params = []; - /** - * 暂时就这样吧(逃... + * 解析后的URI信息 + * @var array */ - public function processing() - { - // TODO Auto-generated method stub - $this->module = $this->module(); - $this->ctrl = $this->ctrl(); - $this->class = '\\' . APP_NS . '\\' . $this->module . '\\controller\\' . $this->ctrl; - $this->method = $this->method(); - $this->params = $this->params(); - } + private $uriArray = []; /** - * + * 模块名 + * @return mixed|string */ public function module() { - // TODO Auto-generated method stub + if (isset($this->uriArray[0])) { + return $this->uriArray[0]; + } return 'home'; } /** - * + * 完整控制器名 + * @return mixed|string */ - public function ctrl() + public function controllerFullName() { - // TODO Auto-generated method stub + $className = '\\' . APP_NS . '\\' . $this->module() . '\\controller\\' . $this->controller(); + return $className; + } + + /** + * 控制器名 + * @return string + */ + public function controller() + { + if (isset($this->uriArray[1])) { + return ucfirst($this->uriArray[1]); + } return 'Index'; } /** - * + * 方法名 + * @return mixed|string */ public function method() { - // TODO Auto-generated method stub + if (isset($this->uriArray[2])) { + return $this->uriArray[2]; + } return 'index'; } /** - * + * 请求参数 + * @return array + * @throws \ReflectionException */ public function params() { - // TODO Auto-generated method stub - return []; + return $this->parseParam(); } + + /** + * 解析请求参数 + * @return array + * @throws \ReflectionException + */ + private function parseParam() + { + $array = array_slice($this->uriArray, 3); + // 查找当前方法存在的参数 + $paramName = (new \ReflectionMethod($this->controllerFullName(), $this->method()))->getParameters(); + $paramNameArray = []; + foreach ($paramName as $value) { + $paramNameArray[] = $value->name; + } + $param = []; + for ($i = 0; $i < count($array); $i++) { + if (isset($array[$i + 1]) && in_array($array[$i], $paramNameArray)) { + $_GET[$array[$i]] = $param[$array[$i]] = $array[$i + 1]; + } + } + return $param; + } + + /** + * 执行初始化,解析URI为数组,并返回当前对象 + * @param $uri + * @return $this + */ + public function init($uri) + { + $options = getopt('u:'); + if (isset($options['u']) && $options['u']) { + $this->uriArray = $options['u'] ? explode('/', $options['u']) : []; + } else { + $this->uriArray = []; + } + return $this; + } + } diff --git a/framework/library/route/driver/Compatible.php b/framework/library/route/driver/Compatible.php new file mode 100644 index 0000000..435e4bf --- /dev/null +++ b/framework/library/route/driver/Compatible.php @@ -0,0 +1,110 @@ +uriArray[0])) { + return $this->uriArray[0]; + } + return 'home'; + } + + /** + * 完整控制器名 + * @return mixed|string + */ + public function controllerFullName() + { + $className = '\\' . APP_NS . '\\' . $this->module() . '\\controller\\' . $this->controller(); + return $className; + } + + /** + * 控制器名 + * @return string + */ + public function controller() + { + if (isset($this->uriArray[1])) { + return ucfirst($this->uriArray[1]); + } + return 'Index'; + } + + /** + * 方法名 + * @return mixed|string + */ + public function method() + { + if (isset($this->uriArray[2])) { + return $this->uriArray[2]; + } + return 'index'; + } + + /** + * 请求参数 + * @return array + * @throws \ReflectionException + */ + public function params() + { + return $this->parseParam(); + } + + /** + * 解析请求参数 + * @return array + * @throws \ReflectionException + */ + private function parseParam() + { + $array = array_slice($this->uriArray, 3); + // 查找当前方法存在的参数 + $paramName = (new \ReflectionMethod($this->controllerFullName(), $this->method()))->getParameters(); + $paramNameArray = []; + foreach ($paramName as $value) { + $paramNameArray[] = $value->name; + } + $param = []; + for ($i = 0; $i < count($array); $i++) { + if (isset($array[$i + 1]) && in_array($array[$i], $paramNameArray)) { + $_GET[$array[$i]] = $param[$array[$i]] = $array[$i + 1]; + } + } + return $param; + } + + /** + * 执行初始化,解析URI为数组,并返回当前对象 + * @param $uri + * @return $this + */ + public function init($uri) + { + $this->uriArray = $uri ? explode('/', $uri) : []; + return $this; + } + +} diff --git a/framework/library/route/driver/Pathinfo.php b/framework/library/route/driver/Pathinfo.php deleted file mode 100644 index 31f76fd..0000000 --- a/framework/library/route/driver/Pathinfo.php +++ /dev/null @@ -1,210 +0,0 @@ -uriArray[0]) && $this->uriArray[0]) { - // 模块名小写 - return strtolower($this->uriArray[0]); - } - return 'home'; - } - - /** - * 控制器名 - * @return string - */ - public function ctrl() - { - if (isset($this->uriArray[1]) && $this->uriArray[1]) { - // 类名首字母大写 - return ucfirst($this->uriArray[1]); - } - return 'Index'; - } - - /** - * 具体执行的方法名 - * @return mixed|string - */ - public function method() - { - if (isset($this->uriArray[2]) && $this->uriArray[2]) { - return $this->uriArray[2]; - } - return 'index'; - } - - /** - * 取出参数 - * @return array - * @throws \ReflectionException - */ - public function params() - { - unset($this->uriArray[0], $this->uriArray[1], $this->uriArray[2]); - $this->uriArray = array_merge($this->uriArray, []); - if (!empty($this->uriArray) && class_exists($this->class)) { - $paramName = (new \ReflectionMethod($this->class, $this->method))->getParameters(); - $paramNameArray = []; - for ($i = 0; $i < count($paramName); $i++) { - $paramNameArray[$paramName[$i]->name] = ''; - } - $params = []; - for ($i = 0; $i < count($this->uriArray); $i = $i + 2) { - if (isset($this->uriArray[$i + 1]) && $this->uriArray[$i + 1] != '') { - $_GET[$this->uriArray[$i]] = $this->uriArray[$i + 1]; - if (isset($paramNameArray[$this->uriArray[$i]])) { - $params[$this->uriArray[$i]] = $this->uriArray[$i + 1]; - } - } - } - unset($paramName, $paramNameArray); - return $params; - } - return []; - } - - /** - * 处理URI - * @return mixed|string - */ - private function getUri() - { - if (isset($_SERVER['PATH_INFO'])) { - $pathinfo = ltrim($_SERVER['PATH_INFO'], '/'); - $uri = ($pathinfo != '') ? $pathinfo : $this->default; - } else { - $uri = isset($_GET['s']) ? ltrim($_GET['s'], '/') : $this->default; - unset($_GET['s']); - } - $uri = str_replace('.html', '', $uri); - $this->rawUri = $uri; - $paramArray = explode('/', $uri); - $name = $paramArray[0]; - $file = APP_PATH . 'route.php'; - if (file_exists($file)) { - $routeConfig = require $file; - if (isset($routeConfig[$name])) { - unset($paramArray[0]); - $paramArray = array_merge($paramArray, []); - $params = $routeConfig[$name][0]; - preg_match_all('#\[(.*?)\]#', $params, $needParams); - if (empty($needParams[1])) { - $uri = $routeConfig[$name][1]; - } else { - $uri = trim($routeConfig[$name][1], '/'); - } - foreach ($needParams[1] as $key => $value) { - // 如果有可选参数且可选参数为空,则跳出本次循环 - if (strstr($value, ':') && (!isset($paramArray[$key]) || $paramArray[$key] == '')) { - continue; - } - $value = str_replace(':', '', $value); - $uri .= '/' . $value . '/' . $paramArray[$key]; - } - } - } - $this->uri = $uri; - unset($paramArray, $name); - return $uri; - } - - /** - * 根据URI得到带参数的数组 - * @return array - */ - private function processUriArray() - { - return explode('/', $this->getUri()); - } - - /** - * 赋值解析出的数据 - * @throws \ReflectionException - */ - public function processing() - { - $this->uriArray = $this->processUriArray(); - $this->module = $this->module(); - $this->ctrl = $this->ctrl(); - $this->class = '\\' . APP_NS . '\\' . $this->module . '\\controller\\' . $this->ctrl; - $this->method = $this->method(); - $this->params = $this->params(); - unset($this->uriArray); - } -} diff --git a/framework/library/route/ifs/RouteIfs.php b/framework/library/route/ifs/RouteIfs.php index 1964f3a..1c75e3f 100644 --- a/framework/library/route/ifs/RouteIfs.php +++ b/framework/library/route/ifs/RouteIfs.php @@ -10,27 +10,39 @@ interface RouteIfs { /** - * 处理路由 - */ - public function processing(); - - /** - * 模块 + * 模块名 + * @return mixed */ public function module(); /** - * 控制器 + * 完整控制器名 + * @return mixed */ - public function ctrl(); + public function controllerFullName(); /** - * 方法 + * 控制器名 + * @return mixed + */ + public function controller(); + + /** + * 方法名 + * @return mixed */ public function method(); /** - * 解析参数 + * 参数 + * @return mixed */ public function params(); + + /** + * 初始化路由 + * @param $uri + * @return mixed + */ + public function init($uri); } diff --git a/framework/library/template/driver/engine/Engine.php b/framework/library/template/driver/engine/Engine.php index d4e94b4..3cea905 100644 --- a/framework/library/template/driver/engine/Engine.php +++ b/framework/library/template/driver/engine/Engine.php @@ -176,6 +176,8 @@ class Engine $replace[] = ''; } elseif ($start == ':') { $replace[] = ''; + } elseif ($start == '@') { + $replace[] = ''; } else { $replace[] = $matches[0][$i]; } @@ -326,7 +328,7 @@ class Engine private function getAttr($string, $tags = []) { $attr = []; - $attrPattern = '/[ +](.*?)=[\'"](.*?)[\'"]/is'; + $attrPattern = '/[ +](.*?)=["](.*?)["]/is'; preg_match_all($attrPattern, $string, $result); if (isset($result[0]) && !empty($result[0])) { foreach ($result[1] as $key => $value) { diff --git a/framework/middleware/Init.php b/framework/middleware/Init.php index 4649f5b..c416063 100644 --- a/framework/middleware/Init.php +++ b/framework/middleware/Init.php @@ -2,67 +2,20 @@ namespace top\middleware; -use top\library\Config; use top\middleware\ifs\MiddlewareIfs; -use top\library\Register; -use top\library\View; /** - * 初始化 + * 默认中间件 * * @author topnuomi 2018年11月20日 */ class Init implements MiddlewareIfs { - - /** - * 注册一些可能会用到的类 - * @throws \Exception - */ - public function before() - { - // 加载系统函数库 - require FRAMEWORK_PATH . 'library/functions/functions.php'; - - // 加载用户函数库 - $funcFile = APP_PATH . request()->module() . '/functions.php'; - if (file_exists($funcFile)) { - require $funcFile; - } - - $configInstance = Config::instance(); - - $sessionConfig = $configInstance->get('session'); - if (!empty($sessionConfig) && $sessionConfig['open'] === true) { - session_save_path(SESSION_PATH); - session_start(); - } - - // 数据库驱动 - $config = $configInstance->get('db'); - $driver = $config['driver'] ? $config['driver'] : 'MySQLi'; - Register::set('DBDriver', function () use ($driver) { - $class = '\\top\\library\\database\\driver\\' . $driver; - return $class::instance(); - }); - - // 配置文件中配置的注册 - $initRegister = $configInstance->get('register'); - if (!empty($initRegister)) { - foreach ($initRegister as $key => $value) { - Register::set($key, function () use ($value) { - return $value::instance(); - }); - } - } - - return true; - } - - /** - * @param array $data - */ - public function after($data) + public function handler(\Closure $next) { + // echo '应用开始'; + $closure = $next(); + // echo '应用结束'; + return $closure; } } diff --git a/framework/middleware/View.php b/framework/middleware/View.php index 5eda809..ebae4d5 100644 --- a/framework/middleware/View.php +++ b/framework/middleware/View.php @@ -10,7 +10,7 @@ use top\middleware\ifs\MiddlewareIfs; class View implements MiddlewareIfs { - public function before() + public function handler(\Closure $next) { if (!DEBUG) { $ident = viewCacheIdent(); @@ -22,12 +22,7 @@ class View implements MiddlewareIfs return Response::instance()->dispatch($content); } } - return true; + return $next(); } - public function after($data) - { - // TODO: Implement after() method. - } - -} \ No newline at end of file +} diff --git a/framework/middleware/ifs/MiddlewareIfs.php b/framework/middleware/ifs/MiddlewareIfs.php index 73cf690..64a3709 100644 --- a/framework/middleware/ifs/MiddlewareIfs.php +++ b/framework/middleware/ifs/MiddlewareIfs.php @@ -3,21 +3,11 @@ namespace top\middleware\ifs; /** - * 默认装饰器接口 + * 中间件接口 * * @author topnuomi 2018年11月22日 */ interface MiddlewareIfs { - - /** - * 前置操作 - */ - public function before(); - - /** - * 后置操作 - * @param array $data - */ - public function after($data); + public function handler(\Closure $next); } diff --git a/framework/traits/Json.php b/framework/traits/Json.php index fb6b6c9..c1e2108 100644 --- a/framework/traits/Json.php +++ b/framework/traits/Json.php @@ -12,7 +12,7 @@ trait Json { return json_encode([ 'msg' => $msg, 'code' => $code, - 'data' => $data + 'data' => $data, ]); } } diff --git a/framework/vendor/autoload.php b/framework/vendor/autoload.php index 8442406..e831a7f 100644 --- a/framework/vendor/autoload.php +++ b/framework/vendor/autoload.php @@ -4,4 +4,4 @@ require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInitbf9b224cfc3165ead4e48be673284a7f::getLoader(); +return ComposerAutoloaderInit7b44678ec2aea793416a22dbbbba76ef::getLoader(); diff --git a/framework/vendor/composer/autoload_classmap.php b/framework/vendor/composer/autoload_classmap.php index e60c6b7..71dd9c1 100644 --- a/framework/vendor/composer/autoload_classmap.php +++ b/framework/vendor/composer/autoload_classmap.php @@ -6,9 +6,4 @@ $vendorDir = dirname(dirname(__FILE__)); $baseDir = dirname(dirname($vendorDir)); return array( - 'Smarty' => $vendorDir . '/smarty/smarty/libs/Smarty.class.php', - 'SmartyBC' => $vendorDir . '/smarty/smarty/libs/SmartyBC.class.php', - 'SmartyCompilerException' => $vendorDir . '/smarty/smarty/libs/Smarty.class.php', - 'SmartyException' => $vendorDir . '/smarty/smarty/libs/Smarty.class.php', - 'Smarty_Security' => $vendorDir . '/smarty/smarty/libs/sysplugins/smarty_security.php', ); diff --git a/framework/vendor/composer/autoload_files.php b/framework/vendor/composer/autoload_files.php deleted file mode 100644 index 480f00c..0000000 --- a/framework/vendor/composer/autoload_files.php +++ /dev/null @@ -1,11 +0,0 @@ - $vendorDir . '/symfony/polyfill-ctype/bootstrap.php', - '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php', -); diff --git a/framework/vendor/composer/autoload_namespaces.php b/framework/vendor/composer/autoload_namespaces.php index b76e4ba..4a9c20b 100644 --- a/framework/vendor/composer/autoload_namespaces.php +++ b/framework/vendor/composer/autoload_namespaces.php @@ -6,5 +6,4 @@ $vendorDir = dirname(dirname(__FILE__)); $baseDir = dirname(dirname($vendorDir)); return array( - 'Twig_' => array($vendorDir . '/twig/twig/lib'), ); diff --git a/framework/vendor/composer/autoload_psr4.php b/framework/vendor/composer/autoload_psr4.php index 0e0644c..91d582b 100644 --- a/framework/vendor/composer/autoload_psr4.php +++ b/framework/vendor/composer/autoload_psr4.php @@ -6,9 +6,5 @@ $vendorDir = dirname(dirname(__FILE__)); $baseDir = dirname(dirname($vendorDir)); return array( - 'Whoops\\' => array($vendorDir . '/filp/whoops/src/Whoops'), - 'Twig\\' => array($vendorDir . '/twig/twig/src'), - 'Symfony\\Polyfill\\Mbstring\\' => array($vendorDir . '/symfony/polyfill-mbstring'), - 'Symfony\\Polyfill\\Ctype\\' => array($vendorDir . '/symfony/polyfill-ctype'), - 'Psr\\Log\\' => array($vendorDir . '/psr/log/Psr/Log'), + 'Firebase\\JWT\\' => array($vendorDir . '/firebase/php-jwt/src'), ); diff --git a/framework/vendor/composer/autoload_real.php b/framework/vendor/composer/autoload_real.php index 0b2b4dd..f6483b9 100644 --- a/framework/vendor/composer/autoload_real.php +++ b/framework/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInitbf9b224cfc3165ead4e48be673284a7f +class ComposerAutoloaderInit7b44678ec2aea793416a22dbbbba76ef { private static $loader; @@ -19,15 +19,15 @@ class ComposerAutoloaderInitbf9b224cfc3165ead4e48be673284a7f return self::$loader; } - spl_autoload_register(array('ComposerAutoloaderInitbf9b224cfc3165ead4e48be673284a7f', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInit7b44678ec2aea793416a22dbbbba76ef', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(); - spl_autoload_unregister(array('ComposerAutoloaderInitbf9b224cfc3165ead4e48be673284a7f', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInit7b44678ec2aea793416a22dbbbba76ef', 'loadClassLoader')); $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded()); if ($useStaticLoader) { require_once __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInit7b44678ec2aea793416a22dbbbba76ef::getInitializer($loader)); } else { $map = require __DIR__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { @@ -47,24 +47,6 @@ class ComposerAutoloaderInitbf9b224cfc3165ead4e48be673284a7f $loader->register(true); - if ($useStaticLoader) { - $includeFiles = Composer\Autoload\ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f::$files; - } else { - $includeFiles = require __DIR__ . '/autoload_files.php'; - } - foreach ($includeFiles as $fileIdentifier => $file) { - composerRequirebf9b224cfc3165ead4e48be673284a7f($fileIdentifier, $file); - } - return $loader; } } - -function composerRequirebf9b224cfc3165ead4e48be673284a7f($fileIdentifier, $file) -{ - if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { - require $file; - - $GLOBALS['__composer_autoload_files'][$fileIdentifier] = true; - } -} diff --git a/framework/vendor/composer/autoload_static.php b/framework/vendor/composer/autoload_static.php index 7547383..66720b4 100644 --- a/framework/vendor/composer/autoload_static.php +++ b/framework/vendor/composer/autoload_static.php @@ -4,81 +4,27 @@ namespace Composer\Autoload; -class ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f +class ComposerStaticInit7b44678ec2aea793416a22dbbbba76ef { - public static $files = array ( - '320cde22f66dd4f5d3fd621d3e88b98f' => __DIR__ . '/..' . '/symfony/polyfill-ctype/bootstrap.php', - '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => __DIR__ . '/..' . '/symfony/polyfill-mbstring/bootstrap.php', - ); - public static $prefixLengthsPsr4 = array ( - 'W' => + 'F' => array ( - 'Whoops\\' => 7, - ), - 'T' => - array ( - 'Twig\\' => 5, - ), - 'S' => - array ( - 'Symfony\\Polyfill\\Mbstring\\' => 26, - 'Symfony\\Polyfill\\Ctype\\' => 23, - ), - 'P' => - array ( - 'Psr\\Log\\' => 8, + 'Firebase\\JWT\\' => 13, ), ); public static $prefixDirsPsr4 = array ( - 'Whoops\\' => + 'Firebase\\JWT\\' => array ( - 0 => __DIR__ . '/..' . '/filp/whoops/src/Whoops', + 0 => __DIR__ . '/..' . '/firebase/php-jwt/src', ), - 'Twig\\' => - array ( - 0 => __DIR__ . '/..' . '/twig/twig/src', - ), - 'Symfony\\Polyfill\\Mbstring\\' => - array ( - 0 => __DIR__ . '/..' . '/symfony/polyfill-mbstring', - ), - 'Symfony\\Polyfill\\Ctype\\' => - array ( - 0 => __DIR__ . '/..' . '/symfony/polyfill-ctype', - ), - 'Psr\\Log\\' => - array ( - 0 => __DIR__ . '/..' . '/psr/log/Psr/Log', - ), - ); - - public static $prefixesPsr0 = array ( - 'T' => - array ( - 'Twig_' => - array ( - 0 => __DIR__ . '/..' . '/twig/twig/lib', - ), - ), - ); - - public static $classMap = array ( - 'Smarty' => __DIR__ . '/..' . '/smarty/smarty/libs/Smarty.class.php', - 'SmartyBC' => __DIR__ . '/..' . '/smarty/smarty/libs/SmartyBC.class.php', - 'SmartyCompilerException' => __DIR__ . '/..' . '/smarty/smarty/libs/Smarty.class.php', - 'SmartyException' => __DIR__ . '/..' . '/smarty/smarty/libs/Smarty.class.php', - 'Smarty_Security' => __DIR__ . '/..' . '/smarty/smarty/libs/sysplugins/smarty_security.php', ); public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f::$prefixDirsPsr4; - $loader->prefixesPsr0 = ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f::$prefixesPsr0; - $loader->classMap = ComposerStaticInitbf9b224cfc3165ead4e48be673284a7f::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInit7b44678ec2aea793416a22dbbbba76ef::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInit7b44678ec2aea793416a22dbbbba76ef::$prefixDirsPsr4; }, null, ClassLoader::class); } diff --git a/framework/vendor/composer/index.html b/framework/vendor/composer/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/composer/installed.json b/framework/vendor/composer/installed.json index 37e62c3..5b2924c 100644 --- a/framework/vendor/composer/installed.json +++ b/framework/vendor/composer/installed.json @@ -1,333 +1,31 @@ [ { - "name": "filp/whoops", - "version": "2.2.0", - "version_normalized": "2.2.0.0", + "name": "firebase/php-jwt", + "version": "v5.0.0", + "version_normalized": "5.0.0.0", "source": { "type": "git", - "url": "https://github.com/filp/whoops.git", - "reference": "181c4502d8f34db7aed7bfe88d4f87875b8e947a" + "url": "https://github.com/firebase/php-jwt.git", + "reference": "9984a4d3a32ae7673d6971ea00bae9d0a1abba0e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/filp/whoops/zipball/181c4502d8f34db7aed7bfe88d4f87875b8e947a", - "reference": "181c4502d8f34db7aed7bfe88d4f87875b8e947a", - "shasum": "" - }, - "require": { - "php": "^5.5.9 || ^7.0", - "psr/log": "^1.0.1" - }, - "require-dev": { - "mockery/mockery": "^0.9 || ^1.0", - "phpunit/phpunit": "^4.8.35 || ^5.7", - "symfony/var-dumper": "^2.6 || ^3.0 || ^4.0" - }, - "suggest": { - "symfony/var-dumper": "Pretty print complex values better with var-dumper available", - "whoops/soap": "Formats errors as SOAP responses" - }, - "time": "2018-03-03T17:56:25+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.1-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Whoops\\": "src/Whoops/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Filipe Dobreira", - "homepage": "https://github.com/filp", - "role": "Developer" - } - ], - "description": "php error handling for cool kids", - "homepage": "https://filp.github.io/whoops/", - "keywords": [ - "error", - "exception", - "handling", - "library", - "throwable", - "whoops" - ] - }, - { - "name": "psr/log", - "version": "1.1.0", - "version_normalized": "1.1.0.0", - "source": { - "type": "git", - "url": "https://github.com/php-fig/log.git", - "reference": "6c001f1daafa3a3ac1d8ff69ee4db8e799a654dd" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/php-fig/log/zipball/6c001f1daafa3a3ac1d8ff69ee4db8e799a654dd", - "reference": "6c001f1daafa3a3ac1d8ff69ee4db8e799a654dd", + "url": "https://api.github.com/repos/firebase/php-jwt/zipball/9984a4d3a32ae7673d6971ea00bae9d0a1abba0e", + "reference": "9984a4d3a32ae7673d6971ea00bae9d0a1abba0e", "shasum": "" }, "require": { "php": ">=5.3.0" }, - "time": "2018-11-20T15:27:04+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Psr\\Log\\": "Psr/Log/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" - } - ], - "description": "Common interface for logging libraries", - "homepage": "https://github.com/php-fig/log", - "keywords": [ - "log", - "psr", - "psr-3" - ] - }, - { - "name": "smarty/smarty", - "version": "v3.1.19", - "version_normalized": "3.1.19.0", - "source": { - "type": "git", - "url": "https://github.com/smarty-php/smarty.git", - "reference": "be0fd3186ceec57e4da9a44031f517c06ae2418a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/smarty-php/smarty/zipball/be0fd3186ceec57e4da9a44031f517c06ae2418a", - "reference": "be0fd3186ceec57e4da9a44031f517c06ae2418a", - "shasum": "" - }, - "require": { - "php": ">=5.2" - }, - "time": "2014-10-31T01:29:14+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "3.1.x-dev" - } - }, - "installation-source": "dist", - "autoload": { - "classmap": [ - "libs/Smarty.class.php", - "libs/SmartyBC.class.php", - "libs/sysplugins/smarty_security.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "LGPL-3.0" - ], - "authors": [ - { - "name": "Monte Ohrt", - "email": "monte@ohrt.com" - }, - { - "name": "Uwe Tews", - "email": "uwe.tews@googlemail.com" - }, - { - "name": "Rodney Rehm", - "email": "rodney.rehm@medialize.de" - } - ], - "description": "Smarty - the compiling PHP template engine", - "homepage": "http://www.smarty.net", - "keywords": [ - "templating" - ] - }, - { - "name": "symfony/polyfill-ctype", - "version": "v1.11.0", - "version_normalized": "1.11.0.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-ctype.git", - "reference": "82ebae02209c21113908c229e9883c419720738a" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/82ebae02209c21113908c229e9883c419720738a", - "reference": "82ebae02209c21113908c229e9883c419720738a", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "suggest": { - "ext-ctype": "For best performance" - }, - "time": "2019-02-06T07:57:58+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.11-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Ctype\\": "" - }, - "files": [ - "bootstrap.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - }, - { - "name": "Gert de Pagter", - "email": "BackEndTea@gmail.com" - } - ], - "description": "Symfony polyfill for ctype functions", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "ctype", - "polyfill", - "portable" - ] - }, - { - "name": "symfony/polyfill-mbstring", - "version": "v1.11.0", - "version_normalized": "1.11.0.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-mbstring.git", - "reference": "fe5e94c604826c35a32fa832f35bd036b6799609" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/fe5e94c604826c35a32fa832f35bd036b6799609", - "reference": "fe5e94c604826c35a32fa832f35bd036b6799609", - "shasum": "" - }, - "require": { - "php": ">=5.3.3" - }, - "suggest": { - "ext-mbstring": "For best performance" - }, - "time": "2019-02-06T07:57:58+00:00", - "type": "library", - "extra": { - "branch-alias": { - "dev-master": "1.11-dev" - } - }, - "installation-source": "dist", - "autoload": { - "psr-4": { - "Symfony\\Polyfill\\Mbstring\\": "" - }, - "files": [ - "bootstrap.php" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "description": "Symfony polyfill for the Mbstring extension", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "mbstring", - "polyfill", - "portable", - "shim" - ] - }, - { - "name": "twig/twig", - "version": "v2.9.0", - "version_normalized": "2.9.0.0", - "source": { - "type": "git", - "url": "https://github.com/twigphp/Twig.git", - "reference": "82a1c055c8ed4c4705023bfd0405f3c74db6e3ae" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/twigphp/Twig/zipball/82a1c055c8ed4c4705023bfd0405f3c74db6e3ae", - "reference": "82a1c055c8ed4c4705023bfd0405f3c74db6e3ae", - "shasum": "" - }, - "require": { - "php": "^7.0", - "symfony/polyfill-ctype": "^1.8", - "symfony/polyfill-mbstring": "^1.3" - }, "require-dev": { - "psr/container": "^1.0", - "symfony/debug": "^2.7", - "symfony/phpunit-bridge": "^3.4.19|^4.1.8" + "phpunit/phpunit": " 4.8.35" }, - "time": "2019-04-28T06:57:38+00:00", + "time": "2017-06-27T22:17:23+00:00", "type": "library", - "extra": { - "branch-alias": { - "dev-master": "2.9-dev" - } - }, "installation-source": "dist", "autoload": { - "psr-0": { - "Twig_": "lib/" - }, "psr-4": { - "Twig\\": "src/" + "Firebase\\JWT\\": "src" } }, "notification-url": "https://packagist.org/downloads/", @@ -336,26 +34,17 @@ ], "authors": [ { - "name": "Fabien Potencier", - "email": "fabien@symfony.com", - "homepage": "http://fabien.potencier.org", - "role": "Lead Developer" + "name": "Neuman Vong", + "email": "neuman+pear@twilio.com", + "role": "Developer" }, { - "name": "Armin Ronacher", - "email": "armin.ronacher@active-4.com", - "role": "Project Founder" - }, - { - "name": "Twig Team", - "homepage": "https://twig.symfony.com/contributors", - "role": "Contributors" + "name": "Anant Narayanan", + "email": "anant@php.net", + "role": "Developer" } ], - "description": "Twig, the flexible, fast, and secure template language for PHP", - "homepage": "https://twig.symfony.com", - "keywords": [ - "templating" - ] + "description": "A simple library to encode and decode JSON Web Tokens (JWT) in PHP. Should conform to the current spec.", + "homepage": "https://github.com/firebase/php-jwt" } ] diff --git a/framework/vendor/filp/index.html b/framework/vendor/filp/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/CHANGELOG.md b/framework/vendor/filp/whoops/CHANGELOG.md deleted file mode 100644 index 4bbd620..0000000 --- a/framework/vendor/filp/whoops/CHANGELOG.md +++ /dev/null @@ -1,13 +0,0 @@ -# 2.1.0 - -* Add a `SystemFacade` to allow clients to override Whoops behavior. -* Show frame arguments in `PrettyPageHandler`. -* Highlight the line with the error. -* Add icons to search on Google and Stack Overflow. - -# 2.0.0 - -Backwards compatibility breaking changes: - -* `Run` class is now `final`. If you inherited from `Run`, please now instead use a custom `SystemFacade` injected into the `Run` constructor, or contribute your changes to our core. -* PHP < 5.5 support dropped. diff --git a/framework/vendor/filp/whoops/LICENSE.md b/framework/vendor/filp/whoops/LICENSE.md deleted file mode 100644 index 80407e7..0000000 --- a/framework/vendor/filp/whoops/LICENSE.md +++ /dev/null @@ -1,19 +0,0 @@ -# The MIT License - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE 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. diff --git a/framework/vendor/filp/whoops/composer.json b/framework/vendor/filp/whoops/composer.json deleted file mode 100644 index 7b2c3a6..0000000 --- a/framework/vendor/filp/whoops/composer.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "name": "filp/whoops", - "license": "MIT", - "description": "php error handling for cool kids", - "keywords": ["library", "error", "handling", "exception", "whoops", "throwable"], - "homepage": "https://filp.github.io/whoops/", - "authors": [ - { - "name": "Filipe Dobreira", - "homepage": "https://github.com/filp", - "role": "Developer" - } - ], - "require": { - "php": "^5.5.9 || ^7.0", - "psr/log": "^1.0.1" - }, - "require-dev": { - "phpunit/phpunit": "^4.8.35 || ^5.7", - "mockery/mockery": "^0.9 || ^1.0", - "symfony/var-dumper": "^2.6 || ^3.0 || ^4.0" - }, - "suggest": { - "symfony/var-dumper": "Pretty print complex values better with var-dumper available", - "whoops/soap": "Formats errors as SOAP responses" - }, - "autoload": { - "psr-4": { - "Whoops\\": "src/Whoops/" - } - }, - "autoload-dev": { - "psr-4": { - "Whoops\\": "tests/Whoops/" - } - }, - "extra": { - "branch-alias": { - "dev-master": "2.1-dev" - } - } -} diff --git a/framework/vendor/filp/whoops/index.html b/framework/vendor/filp/whoops/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php b/framework/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php deleted file mode 100644 index d74e823..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Exception/ErrorException.php +++ /dev/null @@ -1,17 +0,0 @@ - - */ - -namespace Whoops\Exception; - -use ErrorException as BaseErrorException; - -/** - * Wraps ErrorException; mostly used for typing (at least now) - * to easily cleanup the stack trace of redundant info. - */ -class ErrorException extends BaseErrorException -{ -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Exception/Formatter.php b/framework/vendor/filp/whoops/src/Whoops/Exception/Formatter.php deleted file mode 100644 index e467559..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Exception/Formatter.php +++ /dev/null @@ -1,73 +0,0 @@ - - */ - -namespace Whoops\Exception; - -class Formatter -{ - /** - * Returns all basic information about the exception in a simple array - * for further convertion to other languages - * @param Inspector $inspector - * @param bool $shouldAddTrace - * @return array - */ - public static function formatExceptionAsDataArray(Inspector $inspector, $shouldAddTrace) - { - $exception = $inspector->getException(); - $response = [ - 'type' => get_class($exception), - 'message' => $exception->getMessage(), - 'file' => $exception->getFile(), - 'line' => $exception->getLine(), - ]; - - if ($shouldAddTrace) { - $frames = $inspector->getFrames(); - $frameData = []; - - foreach ($frames as $frame) { - /** @var Frame $frame */ - $frameData[] = [ - 'file' => $frame->getFile(), - 'line' => $frame->getLine(), - 'function' => $frame->getFunction(), - 'class' => $frame->getClass(), - 'args' => $frame->getArgs(), - ]; - } - - $response['trace'] = $frameData; - } - - return $response; - } - - public static function formatExceptionPlain(Inspector $inspector) - { - $message = $inspector->getException()->getMessage(); - $frames = $inspector->getFrames(); - - $plain = $inspector->getExceptionName(); - $plain .= ' thrown with message "'; - $plain .= $message; - $plain .= '"'."\n\n"; - - $plain .= "Stacktrace:\n"; - foreach ($frames as $i => $frame) { - $plain .= "#". (count($frames) - $i - 1). " "; - $plain .= $frame->getClass() ?: ''; - $plain .= $frame->getClass() && $frame->getFunction() ? ":" : ""; - $plain .= $frame->getFunction() ?: ''; - $plain .= ' in '; - $plain .= ($frame->getFile() ?: '<#unknown>'); - $plain .= ':'; - $plain .= (int) $frame->getLine(). "\n"; - } - - return $plain; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Exception/Frame.php b/framework/vendor/filp/whoops/src/Whoops/Exception/Frame.php deleted file mode 100644 index 4383583..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Exception/Frame.php +++ /dev/null @@ -1,296 +0,0 @@ - - */ - -namespace Whoops\Exception; - -use InvalidArgumentException; -use Serializable; - -class Frame implements Serializable -{ - /** - * @var array - */ - protected $frame; - - /** - * @var string - */ - protected $fileContentsCache; - - /** - * @var array[] - */ - protected $comments = []; - - /** - * @var bool - */ - protected $application; - - /** - * @param array[] - */ - public function __construct(array $frame) - { - $this->frame = $frame; - } - - /** - * @param bool $shortened - * @return string|null - */ - public function getFile($shortened = false) - { - if (empty($this->frame['file'])) { - return null; - } - - $file = $this->frame['file']; - - // Check if this frame occurred within an eval(). - // @todo: This can be made more reliable by checking if we've entered - // eval() in a previous trace, but will need some more work on the upper - // trace collector(s). - if (preg_match('/^(.*)\((\d+)\) : (?:eval\(\)\'d|assert) code$/', $file, $matches)) { - $file = $this->frame['file'] = $matches[1]; - $this->frame['line'] = (int) $matches[2]; - } - - if ($shortened && is_string($file)) { - // Replace the part of the path that all frames have in common, and add 'soft hyphens' for smoother line-breaks. - $dirname = dirname(dirname(dirname(dirname(dirname(dirname(__DIR__)))))); - if ($dirname !== '/') { - $file = str_replace($dirname, "…", $file); - } - $file = str_replace("/", "/­", $file); - } - - return $file; - } - - /** - * @return int|null - */ - public function getLine() - { - return isset($this->frame['line']) ? $this->frame['line'] : null; - } - - /** - * @return string|null - */ - public function getClass() - { - return isset($this->frame['class']) ? $this->frame['class'] : null; - } - - /** - * @return string|null - */ - public function getFunction() - { - return isset($this->frame['function']) ? $this->frame['function'] : null; - } - - /** - * @return array - */ - public function getArgs() - { - return isset($this->frame['args']) ? (array) $this->frame['args'] : []; - } - - /** - * Returns the full contents of the file for this frame, - * if it's known. - * @return string|null - */ - public function getFileContents() - { - if ($this->fileContentsCache === null && $filePath = $this->getFile()) { - // Leave the stage early when 'Unknown' is passed - // this would otherwise raise an exception when - // open_basedir is enabled. - if ($filePath === "Unknown") { - return null; - } - - // Return null if the file doesn't actually exist. - if (!is_file($filePath)) { - return null; - } - - $this->fileContentsCache = file_get_contents($filePath); - } - - return $this->fileContentsCache; - } - - /** - * Adds a comment to this frame, that can be received and - * used by other handlers. For example, the PrettyPage handler - * can attach these comments under the code for each frame. - * - * An interesting use for this would be, for example, code analysis - * & annotations. - * - * @param string $comment - * @param string $context Optional string identifying the origin of the comment - */ - public function addComment($comment, $context = 'global') - { - $this->comments[] = [ - 'comment' => $comment, - 'context' => $context, - ]; - } - - /** - * Returns all comments for this frame. Optionally allows - * a filter to only retrieve comments from a specific - * context. - * - * @param string $filter - * @return array[] - */ - public function getComments($filter = null) - { - $comments = $this->comments; - - if ($filter !== null) { - $comments = array_filter($comments, function ($c) use ($filter) { - return $c['context'] == $filter; - }); - } - - return $comments; - } - - /** - * Returns the array containing the raw frame data from which - * this Frame object was built - * - * @return array - */ - public function getRawFrame() - { - return $this->frame; - } - - /** - * Returns the contents of the file for this frame as an - * array of lines, and optionally as a clamped range of lines. - * - * NOTE: lines are 0-indexed - * - * @example - * Get all lines for this file - * $frame->getFileLines(); // => array( 0 => ' '...', ...) - * @example - * Get one line for this file, starting at line 10 (zero-indexed, remember!) - * $frame->getFileLines(9, 1); // array( 10 => '...', 11 => '...') - * - * @throws InvalidArgumentException if $length is less than or equal to 0 - * @param int $start - * @param int $length - * @return string[]|null - */ - public function getFileLines($start = 0, $length = null) - { - if (null !== ($contents = $this->getFileContents())) { - $lines = explode("\n", $contents); - - // Get a subset of lines from $start to $end - if ($length !== null) { - $start = (int) $start; - $length = (int) $length; - if ($start < 0) { - $start = 0; - } - - if ($length <= 0) { - throw new InvalidArgumentException( - "\$length($length) cannot be lower or equal to 0" - ); - } - - $lines = array_slice($lines, $start, $length, true); - } - - return $lines; - } - } - - /** - * Implements the Serializable interface, with special - * steps to also save the existing comments. - * - * @see Serializable::serialize - * @return string - */ - public function serialize() - { - $frame = $this->frame; - if (!empty($this->comments)) { - $frame['_comments'] = $this->comments; - } - - return serialize($frame); - } - - /** - * Unserializes the frame data, while also preserving - * any existing comment data. - * - * @see Serializable::unserialize - * @param string $serializedFrame - */ - public function unserialize($serializedFrame) - { - $frame = unserialize($serializedFrame); - - if (!empty($frame['_comments'])) { - $this->comments = $frame['_comments']; - unset($frame['_comments']); - } - - $this->frame = $frame; - } - - /** - * Compares Frame against one another - * @param Frame $frame - * @return bool - */ - public function equals(Frame $frame) - { - if (!$this->getFile() || $this->getFile() === 'Unknown' || !$this->getLine()) { - return false; - } - return $frame->getFile() === $this->getFile() && $frame->getLine() === $this->getLine(); - } - - /** - * Returns whether this frame belongs to the application or not. - * - * @return boolean - */ - public function isApplication() - { - return $this->application; - } - - /** - * Mark as an frame belonging to the application. - * - * @param boolean $application - */ - public function setApplication($application) - { - $this->application = $application; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php b/framework/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php deleted file mode 100644 index b043a1c..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Exception/FrameCollection.php +++ /dev/null @@ -1,203 +0,0 @@ - - */ - -namespace Whoops\Exception; - -use ArrayAccess; -use ArrayIterator; -use Countable; -use IteratorAggregate; -use Serializable; -use UnexpectedValueException; - -/** - * Exposes a fluent interface for dealing with an ordered list - * of stack-trace frames. - */ -class FrameCollection implements ArrayAccess, IteratorAggregate, Serializable, Countable -{ - /** - * @var array[] - */ - private $frames; - - /** - * @param array $frames - */ - public function __construct(array $frames) - { - $this->frames = array_map(function ($frame) { - return new Frame($frame); - }, $frames); - } - - /** - * Filters frames using a callable, returns the same FrameCollection - * - * @param callable $callable - * @return FrameCollection - */ - public function filter($callable) - { - $this->frames = array_values(array_filter($this->frames, $callable)); - return $this; - } - - /** - * Map the collection of frames - * - * @param callable $callable - * @return FrameCollection - */ - public function map($callable) - { - // Contain the map within a higher-order callable - // that enforces type-correctness for the $callable - $this->frames = array_map(function ($frame) use ($callable) { - $frame = call_user_func($callable, $frame); - - if (!$frame instanceof Frame) { - throw new UnexpectedValueException( - "Callable to " . __METHOD__ . " must return a Frame object" - ); - } - - return $frame; - }, $this->frames); - - return $this; - } - - /** - * Returns an array with all frames, does not affect - * the internal array. - * - * @todo If this gets any more complex than this, - * have getIterator use this method. - * @see FrameCollection::getIterator - * @return array - */ - public function getArray() - { - return $this->frames; - } - - /** - * @see IteratorAggregate::getIterator - * @return ArrayIterator - */ - public function getIterator() - { - return new ArrayIterator($this->frames); - } - - /** - * @see ArrayAccess::offsetExists - * @param int $offset - */ - public function offsetExists($offset) - { - return isset($this->frames[$offset]); - } - - /** - * @see ArrayAccess::offsetGet - * @param int $offset - */ - public function offsetGet($offset) - { - return $this->frames[$offset]; - } - - /** - * @see ArrayAccess::offsetSet - * @param int $offset - */ - public function offsetSet($offset, $value) - { - throw new \Exception(__CLASS__ . ' is read only'); - } - - /** - * @see ArrayAccess::offsetUnset - * @param int $offset - */ - public function offsetUnset($offset) - { - throw new \Exception(__CLASS__ . ' is read only'); - } - - /** - * @see Countable::count - * @return int - */ - public function count() - { - return count($this->frames); - } - - /** - * Count the frames that belongs to the application. - * - * @return int - */ - public function countIsApplication() - { - return count(array_filter($this->frames, function (Frame $f) { - return $f->isApplication(); - })); - } - - /** - * @see Serializable::serialize - * @return string - */ - public function serialize() - { - return serialize($this->frames); - } - - /** - * @see Serializable::unserialize - * @param string $serializedFrames - */ - public function unserialize($serializedFrames) - { - $this->frames = unserialize($serializedFrames); - } - - /** - * @param Frame[] $frames Array of Frame instances, usually from $e->getPrevious() - */ - public function prependFrames(array $frames) - { - $this->frames = array_merge($frames, $this->frames); - } - - /** - * Gets the innermost part of stack trace that is not the same as that of outer exception - * - * @param FrameCollection $parentFrames Outer exception frames to compare tail against - * @return Frame[] - */ - public function topDiff(FrameCollection $parentFrames) - { - $diff = $this->frames; - - $parentFrames = $parentFrames->getArray(); - $p = count($parentFrames)-1; - - for ($i = count($diff)-1; $i >= 0 && $p >= 0; $i--) { - /** @var Frame $tailFrame */ - $tailFrame = $diff[$i]; - if ($tailFrame->equals($parentFrames[$p])) { - unset($diff[$i]); - } - $p--; - } - return $diff; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Exception/Inspector.php b/framework/vendor/filp/whoops/src/Whoops/Exception/Inspector.php deleted file mode 100644 index c88323b..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Exception/Inspector.php +++ /dev/null @@ -1,276 +0,0 @@ - - */ - -namespace Whoops\Exception; - -use Whoops\Util\Misc; - -class Inspector -{ - /** - * @var \Throwable - */ - private $exception; - - /** - * @var \Whoops\Exception\FrameCollection - */ - private $frames; - - /** - * @var \Whoops\Exception\Inspector - */ - private $previousExceptionInspector; - - /** - * @param \Throwable $exception The exception to inspect - */ - public function __construct($exception) - { - $this->exception = $exception; - } - - /** - * @return \Throwable - */ - public function getException() - { - return $this->exception; - } - - /** - * @return string - */ - public function getExceptionName() - { - return get_class($this->exception); - } - - /** - * @return string - */ - public function getExceptionMessage() - { - return $this->extractDocrefUrl($this->exception->getMessage())['message']; - } - - /** - * Returns a url to the php-manual related to the underlying error - when available. - * - * @return string|null - */ - public function getExceptionDocrefUrl() - { - return $this->extractDocrefUrl($this->exception->getMessage())['url']; - } - - private function extractDocrefUrl($message) - { - $docref = [ - 'message' => $message, - 'url' => null, - ]; - - // php embbeds urls to the manual into the Exception message with the following ini-settings defined - // http://php.net/manual/en/errorfunc.configuration.php#ini.docref-root - if (!ini_get('html_errors') || !ini_get('docref_root')) { - return $docref; - } - - $pattern = "/\[(?:[^<]+)<\/a>\]/"; - if (preg_match($pattern, $message, $matches)) { - // -> strip those automatically generated links from the exception message - $docref['message'] = preg_replace($pattern, '', $message, 1); - $docref['url'] = $matches[1]; - } - - return $docref; - } - - /** - * Does the wrapped Exception has a previous Exception? - * @return bool - */ - public function hasPreviousException() - { - return $this->previousExceptionInspector || $this->exception->getPrevious(); - } - - /** - * Returns an Inspector for a previous Exception, if any. - * @todo Clean this up a bit, cache stuff a bit better. - * @return Inspector - */ - public function getPreviousExceptionInspector() - { - if ($this->previousExceptionInspector === null) { - $previousException = $this->exception->getPrevious(); - - if ($previousException) { - $this->previousExceptionInspector = new Inspector($previousException); - } - } - - return $this->previousExceptionInspector; - } - - /** - * Returns an iterator for the inspected exception's - * frames. - * @return \Whoops\Exception\FrameCollection - */ - public function getFrames() - { - if ($this->frames === null) { - $frames = $this->getTrace($this->exception); - - // Fill empty line/file info for call_user_func_array usages (PHP Bug #44428) - foreach ($frames as $k => $frame) { - if (empty($frame['file'])) { - // Default values when file and line are missing - $file = '[internal]'; - $line = 0; - - $next_frame = !empty($frames[$k + 1]) ? $frames[$k + 1] : []; - - if ($this->isValidNextFrame($next_frame)) { - $file = $next_frame['file']; - $line = $next_frame['line']; - } - - $frames[$k]['file'] = $file; - $frames[$k]['line'] = $line; - } - } - - // Find latest non-error handling frame index ($i) used to remove error handling frames - $i = 0; - foreach ($frames as $k => $frame) { - if ($frame['file'] == $this->exception->getFile() && $frame['line'] == $this->exception->getLine()) { - $i = $k; - } - } - - // Remove error handling frames - if ($i > 0) { - array_splice($frames, 0, $i); - } - - $firstFrame = $this->getFrameFromException($this->exception); - array_unshift($frames, $firstFrame); - - $this->frames = new FrameCollection($frames); - - if ($previousInspector = $this->getPreviousExceptionInspector()) { - // Keep outer frame on top of the inner one - $outerFrames = $this->frames; - $newFrames = clone $previousInspector->getFrames(); - // I assume it will always be set, but let's be safe - if (isset($newFrames[0])) { - $newFrames[0]->addComment( - $previousInspector->getExceptionMessage(), - 'Exception message:' - ); - } - $newFrames->prependFrames($outerFrames->topDiff($newFrames)); - $this->frames = $newFrames; - } - } - - return $this->frames; - } - - /** - * Gets the backtrace from an exception. - * - * If xdebug is installed - * - * @param \Throwable $exception - * @return array - */ - protected function getTrace($e) - { - $traces = $e->getTrace(); - - // Get trace from xdebug if enabled, failure exceptions only trace to the shutdown handler by default - if (!$e instanceof \ErrorException) { - return $traces; - } - - if (!Misc::isLevelFatal($e->getSeverity())) { - return $traces; - } - - if (!extension_loaded('xdebug') || !xdebug_is_enabled()) { - return []; - } - - // Use xdebug to get the full stack trace and remove the shutdown handler stack trace - $stack = array_reverse(xdebug_get_function_stack()); - $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS); - $traces = array_diff_key($stack, $trace); - - return $traces; - } - - /** - * Given an exception, generates an array in the format - * generated by Exception::getTrace() - * @param \Throwable $exception - * @return array - */ - protected function getFrameFromException($exception) - { - return [ - 'file' => $exception->getFile(), - 'line' => $exception->getLine(), - 'class' => get_class($exception), - 'args' => [ - $exception->getMessage(), - ], - ]; - } - - /** - * Given an error, generates an array in the format - * generated by ErrorException - * @param ErrorException $exception - * @return array - */ - protected function getFrameFromError(ErrorException $exception) - { - return [ - 'file' => $exception->getFile(), - 'line' => $exception->getLine(), - 'class' => null, - 'args' => [], - ]; - } - - /** - * Determine if the frame can be used to fill in previous frame's missing info - * happens for call_user_func and call_user_func_array usages (PHP Bug #44428) - * - * @param array $frame - * @return bool - */ - protected function isValidNextFrame(array $frame) - { - if (empty($frame['file'])) { - return false; - } - - if (empty($frame['line'])) { - return false; - } - - if (empty($frame['function']) || !stristr($frame['function'], 'call_user_func')) { - return false; - } - - return true; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Exception/index.html b/framework/vendor/filp/whoops/src/Whoops/Exception/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php b/framework/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php deleted file mode 100644 index cc46e70..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/CallbackHandler.php +++ /dev/null @@ -1,52 +0,0 @@ - - */ - -namespace Whoops\Handler; - -use InvalidArgumentException; - -/** - * Wrapper for Closures passed as handlers. Can be used - * directly, or will be instantiated automagically by Whoops\Run - * if passed to Run::pushHandler - */ -class CallbackHandler extends Handler -{ - /** - * @var callable - */ - protected $callable; - - /** - * @throws InvalidArgumentException If argument is not callable - * @param callable $callable - */ - public function __construct($callable) - { - if (!is_callable($callable)) { - throw new InvalidArgumentException( - 'Argument to ' . __METHOD__ . ' must be valid callable' - ); - } - - $this->callable = $callable; - } - - /** - * @return int|null - */ - public function handle() - { - $exception = $this->getException(); - $inspector = $this->getInspector(); - $run = $this->getRun(); - $callable = $this->callable; - - // invoke the callable directly, to get simpler stacktraces (in comparison to call_user_func). - // this assumes that $callable is a properly typed php-callable, which we check in __construct(). - return $callable($exception, $inspector, $run); - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/Handler.php b/framework/vendor/filp/whoops/src/Whoops/Handler/Handler.php deleted file mode 100644 index cf1f708..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/Handler.php +++ /dev/null @@ -1,95 +0,0 @@ - - */ - -namespace Whoops\Handler; - -use Whoops\Exception\Inspector; -use Whoops\RunInterface; - -/** - * Abstract implementation of a Handler. - */ -abstract class Handler implements HandlerInterface -{ - /* - Return constants that can be returned from Handler::handle - to message the handler walker. - */ - const DONE = 0x10; // returning this is optional, only exists for - // semantic purposes - /** - * The Handler has handled the Throwable in some way, and wishes to skip any other Handler. - * Execution will continue. - */ - const LAST_HANDLER = 0x20; - /** - * The Handler has handled the Throwable in some way, and wishes to quit/stop execution - */ - const QUIT = 0x30; - - /** - * @var RunInterface - */ - private $run; - - /** - * @var Inspector $inspector - */ - private $inspector; - - /** - * @var \Throwable $exception - */ - private $exception; - - /** - * @param RunInterface $run - */ - public function setRun(RunInterface $run) - { - $this->run = $run; - } - - /** - * @return RunInterface - */ - protected function getRun() - { - return $this->run; - } - - /** - * @param Inspector $inspector - */ - public function setInspector(Inspector $inspector) - { - $this->inspector = $inspector; - } - - /** - * @return Inspector - */ - protected function getInspector() - { - return $this->inspector; - } - - /** - * @param \Throwable $exception - */ - public function setException($exception) - { - $this->exception = $exception; - } - - /** - * @return \Throwable - */ - protected function getException() - { - return $this->exception; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php b/framework/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php deleted file mode 100644 index 0265a85..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/HandlerInterface.php +++ /dev/null @@ -1,36 +0,0 @@ - - */ - -namespace Whoops\Handler; - -use Whoops\Exception\Inspector; -use Whoops\RunInterface; - -interface HandlerInterface -{ - /** - * @return int|null A handler may return nothing, or a Handler::HANDLE_* constant - */ - public function handle(); - - /** - * @param RunInterface $run - * @return void - */ - public function setRun(RunInterface $run); - - /** - * @param \Throwable $exception - * @return void - */ - public function setException($exception); - - /** - * @param Inspector $inspector - * @return void - */ - public function setInspector(Inspector $inspector); -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php b/framework/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php deleted file mode 100644 index fdd7ead..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php +++ /dev/null @@ -1,88 +0,0 @@ - - */ - -namespace Whoops\Handler; - -use Whoops\Exception\Formatter; - -/** - * Catches an exception and converts it to a JSON - * response. Additionally can also return exception - * frames for consumption by an API. - */ -class JsonResponseHandler extends Handler -{ - /** - * @var bool - */ - private $returnFrames = false; - - /** - * @var bool - */ - private $jsonApi = false; - - /** - * Returns errors[[]] instead of error[] to be in compliance with the json:api spec - * @param bool $jsonApi Default is false - * @return $this - */ - public function setJsonApi($jsonApi = false) - { - $this->jsonApi = (bool) $jsonApi; - return $this; - } - - /** - * @param bool|null $returnFrames - * @return bool|$this - */ - public function addTraceToOutput($returnFrames = null) - { - if (func_num_args() == 0) { - return $this->returnFrames; - } - - $this->returnFrames = (bool) $returnFrames; - return $this; - } - - /** - * @return int - */ - public function handle() - { - if ($this->jsonApi === true) { - $response = [ - 'errors' => [ - Formatter::formatExceptionAsDataArray( - $this->getInspector(), - $this->addTraceToOutput() - ), - ] - ]; - } else { - $response = [ - 'error' => Formatter::formatExceptionAsDataArray( - $this->getInspector(), - $this->addTraceToOutput() - ), - ]; - } - - echo json_encode($response, defined('JSON_PARTIAL_OUTPUT_ON_ERROR') ? JSON_PARTIAL_OUTPUT_ON_ERROR : 0); - - return Handler::QUIT; - } - - /** - * @return string - */ - public function contentType() - { - return 'application/json'; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php b/framework/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php deleted file mode 100644 index 2f5be90..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/PlainTextHandler.php +++ /dev/null @@ -1,314 +0,0 @@ - -* Plaintext handler for command line and logs. -* @author Pierre-Yves Landuré -*/ - -namespace Whoops\Handler; - -use InvalidArgumentException; -use Psr\Log\LoggerInterface; -use Whoops\Exception\Frame; - -/** -* Handler outputing plaintext error messages. Can be used -* directly, or will be instantiated automagically by Whoops\Run -* if passed to Run::pushHandler -*/ -class PlainTextHandler extends Handler -{ - const VAR_DUMP_PREFIX = ' | '; - - /** - * @var \Psr\Log\LoggerInterface - */ - protected $logger; - - /** - * @var callable - */ - protected $dumper; - - /** - * @var bool - */ - private $addTraceToOutput = true; - - /** - * @var bool|integer - */ - private $addTraceFunctionArgsToOutput = false; - - /** - * @var integer - */ - private $traceFunctionArgsOutputLimit = 1024; - - /** - * @var bool - */ - private $loggerOnly = false; - - /** - * Constructor. - * @throws InvalidArgumentException If argument is not null or a LoggerInterface - * @param \Psr\Log\LoggerInterface|null $logger - */ - public function __construct($logger = null) - { - $this->setLogger($logger); - } - - /** - * Set the output logger interface. - * @throws InvalidArgumentException If argument is not null or a LoggerInterface - * @param \Psr\Log\LoggerInterface|null $logger - */ - public function setLogger($logger = null) - { - if (! (is_null($logger) - || $logger instanceof LoggerInterface)) { - throw new InvalidArgumentException( - 'Argument to ' . __METHOD__ . - " must be a valid Logger Interface (aka. Monolog), " . - get_class($logger) . ' given.' - ); - } - - $this->logger = $logger; - } - - /** - * @return \Psr\Log\LoggerInterface|null - */ - public function getLogger() - { - return $this->logger; - } - - /** - * Set var dumper callback function. - * - * @param callable $dumper - * @return void - */ - public function setDumper(callable $dumper) - { - $this->dumper = $dumper; - } - - /** - * Add error trace to output. - * @param bool|null $addTraceToOutput - * @return bool|$this - */ - public function addTraceToOutput($addTraceToOutput = null) - { - if (func_num_args() == 0) { - return $this->addTraceToOutput; - } - - $this->addTraceToOutput = (bool) $addTraceToOutput; - return $this; - } - - /** - * Add error trace function arguments to output. - * Set to True for all frame args, or integer for the n first frame args. - * @param bool|integer|null $addTraceFunctionArgsToOutput - * @return null|bool|integer - */ - public function addTraceFunctionArgsToOutput($addTraceFunctionArgsToOutput = null) - { - if (func_num_args() == 0) { - return $this->addTraceFunctionArgsToOutput; - } - - if (! is_integer($addTraceFunctionArgsToOutput)) { - $this->addTraceFunctionArgsToOutput = (bool) $addTraceFunctionArgsToOutput; - } else { - $this->addTraceFunctionArgsToOutput = $addTraceFunctionArgsToOutput; - } - } - - /** - * Set the size limit in bytes of frame arguments var_dump output. - * If the limit is reached, the var_dump output is discarded. - * Prevent memory limit errors. - * @var integer - */ - public function setTraceFunctionArgsOutputLimit($traceFunctionArgsOutputLimit) - { - $this->traceFunctionArgsOutputLimit = (integer) $traceFunctionArgsOutputLimit; - } - - /** - * Create plain text response and return it as a string - * @return string - */ - public function generateResponse() - { - $exception = $this->getException(); - return sprintf( - "%s: %s in file %s on line %d%s\n", - get_class($exception), - $exception->getMessage(), - $exception->getFile(), - $exception->getLine(), - $this->getTraceOutput() - ); - } - - /** - * Get the size limit in bytes of frame arguments var_dump output. - * If the limit is reached, the var_dump output is discarded. - * Prevent memory limit errors. - * @return integer - */ - public function getTraceFunctionArgsOutputLimit() - { - return $this->traceFunctionArgsOutputLimit; - } - - /** - * Only output to logger. - * @param bool|null $loggerOnly - * @return null|bool - */ - public function loggerOnly($loggerOnly = null) - { - if (func_num_args() == 0) { - return $this->loggerOnly; - } - - $this->loggerOnly = (bool) $loggerOnly; - } - - /** - * Test if handler can output to stdout. - * @return bool - */ - private function canOutput() - { - return !$this->loggerOnly(); - } - - /** - * Get the frame args var_dump. - * @param \Whoops\Exception\Frame $frame [description] - * @param integer $line [description] - * @return string - */ - private function getFrameArgsOutput(Frame $frame, $line) - { - if ($this->addTraceFunctionArgsToOutput() === false - || $this->addTraceFunctionArgsToOutput() < $line) { - return ''; - } - - // Dump the arguments: - ob_start(); - $this->dump($frame->getArgs()); - if (ob_get_length() > $this->getTraceFunctionArgsOutputLimit()) { - // The argument var_dump is to big. - // Discarded to limit memory usage. - ob_clean(); - return sprintf( - "\n%sArguments dump length greater than %d Bytes. Discarded.", - self::VAR_DUMP_PREFIX, - $this->getTraceFunctionArgsOutputLimit() - ); - } - - return sprintf( - "\n%s", - preg_replace('/^/m', self::VAR_DUMP_PREFIX, ob_get_clean()) - ); - } - - /** - * Dump variable. - * - * @param mixed $var - * @return void - */ - protected function dump($var) - { - if ($this->dumper) { - call_user_func($this->dumper, $var); - } else { - var_dump($var); - } - } - - /** - * Get the exception trace as plain text. - * @return string - */ - private function getTraceOutput() - { - if (! $this->addTraceToOutput()) { - return ''; - } - $inspector = $this->getInspector(); - $frames = $inspector->getFrames(); - - $response = "\nStack trace:"; - - $line = 1; - foreach ($frames as $frame) { - /** @var Frame $frame */ - $class = $frame->getClass(); - - $template = "\n%3d. %s->%s() %s:%d%s"; - if (! $class) { - // Remove method arrow (->) from output. - $template = "\n%3d. %s%s() %s:%d%s"; - } - - $response .= sprintf( - $template, - $line, - $class, - $frame->getFunction(), - $frame->getFile(), - $frame->getLine(), - $this->getFrameArgsOutput($frame, $line) - ); - - $line++; - } - - return $response; - } - - /** - * @return int - */ - public function handle() - { - $response = $this->generateResponse(); - - if ($this->getLogger()) { - $this->getLogger()->error($response); - } - - if (! $this->canOutput()) { - return Handler::DONE; - } - - echo $response; - - return Handler::QUIT; - } - - /** - * @return string - */ - public function contentType() - { - return 'text/plain'; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php b/framework/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php deleted file mode 100644 index 08197b4..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/PrettyPageHandler.php +++ /dev/null @@ -1,707 +0,0 @@ - - */ - -namespace Whoops\Handler; - -use InvalidArgumentException; -use RuntimeException; -use Symfony\Component\VarDumper\Cloner\AbstractCloner; -use Symfony\Component\VarDumper\Cloner\VarCloner; -use UnexpectedValueException; -use Whoops\Exception\Formatter; -use Whoops\Util\Misc; -use Whoops\Util\TemplateHelper; - -class PrettyPageHandler extends Handler -{ - /** - * Search paths to be scanned for resources, in the reverse - * order they're declared. - * - * @var array - */ - private $searchPaths = []; - - /** - * Fast lookup cache for known resource locations. - * - * @var array - */ - private $resourceCache = []; - - /** - * The name of the custom css file. - * - * @var string - */ - private $customCss = null; - - /** - * @var array[] - */ - private $extraTables = []; - - /** - * @var bool - */ - private $handleUnconditionally = false; - - /** - * @var string - */ - private $pageTitle = "Whoops! There was an error."; - - /** - * @var array[] - */ - private $applicationPaths; - - /** - * @var array[] - */ - private $blacklist = [ - '_GET' => [], - '_POST' => [], - '_FILES' => [], - '_COOKIE' => [], - '_SESSION' => [], - '_SERVER' => [], - '_ENV' => [], - ]; - - /** - * A string identifier for a known IDE/text editor, or a closure - * that resolves a string that can be used to open a given file - * in an editor. If the string contains the special substrings - * %file or %line, they will be replaced with the correct data. - * - * @example - * "txmt://open?url=%file&line=%line" - * @var mixed $editor - */ - protected $editor; - - /** - * A list of known editor strings - * @var array - */ - protected $editors = [ - "sublime" => "subl://open?url=file://%file&line=%line", - "textmate" => "txmt://open?url=file://%file&line=%line", - "emacs" => "emacs://open?url=file://%file&line=%line", - "macvim" => "mvim://open/?url=file://%file&line=%line", - "phpstorm" => "phpstorm://open?file=%file&line=%line", - "idea" => "idea://open?file=%file&line=%line", - "vscode" => "vscode://file/%file:%line", - "atom" => "atom://core/open/file?filename=%file&line=%line", - ]; - - /** - * @var TemplateHelper - */ - private $templateHelper; - - /** - * Constructor. - */ - public function __construct() - { - if (ini_get('xdebug.file_link_format') || extension_loaded('xdebug')) { - // Register editor using xdebug's file_link_format option. - $this->editors['xdebug'] = function ($file, $line) { - return str_replace(['%f', '%l'], [$file, $line], ini_get('xdebug.file_link_format')); - }; - } - - // Add the default, local resource search path: - $this->searchPaths[] = __DIR__ . "/../Resources"; - - // blacklist php provided auth based values - $this->blacklist('_SERVER', 'PHP_AUTH_PW'); - - $this->templateHelper = new TemplateHelper(); - - if (class_exists('Symfony\Component\VarDumper\Cloner\VarCloner')) { - $cloner = new VarCloner(); - // Only dump object internals if a custom caster exists. - $cloner->addCasters(['*' => function ($obj, $a, $stub, $isNested, $filter = 0) { - $class = $stub->class; - $classes = [$class => $class] + class_parents($class) + class_implements($class); - - foreach ($classes as $class) { - if (isset(AbstractCloner::$defaultCasters[$class])) { - return $a; - } - } - - // Remove all internals - return []; - }]); - $this->templateHelper->setCloner($cloner); - } - } - - /** - * @return int|null - */ - public function handle() - { - if (!$this->handleUnconditionally()) { - // Check conditions for outputting HTML: - // @todo: Make this more robust - if (PHP_SAPI === 'cli') { - // Help users who have been relying on an internal test value - // fix their code to the proper method - if (isset($_ENV['whoops-test'])) { - throw new \Exception( - 'Use handleUnconditionally instead of whoops-test' - .' environment variable' - ); - } - - return Handler::DONE; - } - } - - $templateFile = $this->getResource("views/layout.html.php"); - $cssFile = $this->getResource("css/whoops.base.css"); - $zeptoFile = $this->getResource("js/zepto.min.js"); - $prettifyFile = $this->getResource("js/prettify.min.js"); - $clipboard = $this->getResource("js/clipboard.min.js"); - $jsFile = $this->getResource("js/whoops.base.js"); - - if ($this->customCss) { - $customCssFile = $this->getResource($this->customCss); - } - - $inspector = $this->getInspector(); - $frames = $this->getExceptionFrames(); - $code = $this->getExceptionCode(); - - // List of variables that will be passed to the layout template. - $vars = [ - "page_title" => $this->getPageTitle(), - - // @todo: Asset compiler - "stylesheet" => file_get_contents($cssFile), - "zepto" => file_get_contents($zeptoFile), - "prettify" => file_get_contents($prettifyFile), - "clipboard" => file_get_contents($clipboard), - "javascript" => file_get_contents($jsFile), - - // Template paths: - "header" => $this->getResource("views/header.html.php"), - "header_outer" => $this->getResource("views/header_outer.html.php"), - "frame_list" => $this->getResource("views/frame_list.html.php"), - "frames_description" => $this->getResource("views/frames_description.html.php"), - "frames_container" => $this->getResource("views/frames_container.html.php"), - "panel_details" => $this->getResource("views/panel_details.html.php"), - "panel_details_outer" => $this->getResource("views/panel_details_outer.html.php"), - "panel_left" => $this->getResource("views/panel_left.html.php"), - "panel_left_outer" => $this->getResource("views/panel_left_outer.html.php"), - "frame_code" => $this->getResource("views/frame_code.html.php"), - "env_details" => $this->getResource("views/env_details.html.php"), - - "title" => $this->getPageTitle(), - "name" => explode("\\", $inspector->getExceptionName()), - "message" => $inspector->getExceptionMessage(), - "docref_url" => $inspector->getExceptionDocrefUrl(), - "code" => $code, - "plain_exception" => Formatter::formatExceptionPlain($inspector), - "frames" => $frames, - "has_frames" => !!count($frames), - "handler" => $this, - "handlers" => $this->getRun()->getHandlers(), - - "active_frames_tab" => count($frames) && $frames->offsetGet(0)->isApplication() ? 'application' : 'all', - "has_frames_tabs" => $this->getApplicationPaths(), - - "tables" => [ - "GET Data" => $this->masked($_GET, '_GET'), - "POST Data" => $this->masked($_POST, '_POST'), - "Files" => isset($_FILES) ? $this->masked($_FILES, '_FILES') : [], - "Cookies" => $this->masked($_COOKIE, '_COOKIE'), - "Session" => isset($_SESSION) ? $this->masked($_SESSION, '_SESSION') : [], - "Server/Request Data" => $this->masked($_SERVER, '_SERVER'), - "Environment Variables" => $this->masked($_ENV, '_ENV'), - ], - ]; - - if (isset($customCssFile)) { - $vars["stylesheet"] .= file_get_contents($customCssFile); - } - - // Add extra entries list of data tables: - // @todo: Consolidate addDataTable and addDataTableCallback - $extraTables = array_map(function ($table) use ($inspector) { - return $table instanceof \Closure ? $table($inspector) : $table; - }, $this->getDataTables()); - $vars["tables"] = array_merge($extraTables, $vars["tables"]); - - $plainTextHandler = new PlainTextHandler(); - $plainTextHandler->setException($this->getException()); - $plainTextHandler->setInspector($this->getInspector()); - $vars["preface"] = ""; - - $this->templateHelper->setVariables($vars); - $this->templateHelper->render($templateFile); - - return Handler::QUIT; - } - - /** - * Get the stack trace frames of the exception that is currently being handled. - * - * @return \Whoops\Exception\FrameCollection; - */ - protected function getExceptionFrames() - { - $frames = $this->getInspector()->getFrames(); - - if ($this->getApplicationPaths()) { - foreach ($frames as $frame) { - foreach ($this->getApplicationPaths() as $path) { - if (strpos($frame->getFile(), $path) === 0) { - $frame->setApplication(true); - break; - } - } - } - } - - return $frames; - } - - /** - * Get the code of the exception that is currently being handled. - * - * @return string - */ - protected function getExceptionCode() - { - $exception = $this->getException(); - - $code = $exception->getCode(); - if ($exception instanceof \ErrorException) { - // ErrorExceptions wrap the php-error types within the 'severity' property - $code = Misc::translateErrorCode($exception->getSeverity()); - } - - return (string) $code; - } - - /** - * @return string - */ - public function contentType() - { - return 'text/html'; - } - - /** - * Adds an entry to the list of tables displayed in the template. - * The expected data is a simple associative array. Any nested arrays - * will be flattened with print_r - * @param string $label - * @param array $data - */ - public function addDataTable($label, array $data) - { - $this->extraTables[$label] = $data; - } - - /** - * Lazily adds an entry to the list of tables displayed in the table. - * The supplied callback argument will be called when the error is rendered, - * it should produce a simple associative array. Any nested arrays will - * be flattened with print_r. - * - * @throws InvalidArgumentException If $callback is not callable - * @param string $label - * @param callable $callback Callable returning an associative array - */ - public function addDataTableCallback($label, /* callable */ $callback) - { - if (!is_callable($callback)) { - throw new InvalidArgumentException('Expecting callback argument to be callable'); - } - - $this->extraTables[$label] = function (\Whoops\Exception\Inspector $inspector = null) use ($callback) { - try { - $result = call_user_func($callback, $inspector); - - // Only return the result if it can be iterated over by foreach(). - return is_array($result) || $result instanceof \Traversable ? $result : []; - } catch (\Exception $e) { - // Don't allow failure to break the rendering of the original exception. - return []; - } - }; - } - - /** - * Returns all the extra data tables registered with this handler. - * Optionally accepts a 'label' parameter, to only return the data - * table under that label. - * @param string|null $label - * @return array[]|callable - */ - public function getDataTables($label = null) - { - if ($label !== null) { - return isset($this->extraTables[$label]) ? - $this->extraTables[$label] : []; - } - - return $this->extraTables; - } - - /** - * Allows to disable all attempts to dynamically decide whether to - * handle or return prematurely. - * Set this to ensure that the handler will perform no matter what. - * @param bool|null $value - * @return bool|null - */ - public function handleUnconditionally($value = null) - { - if (func_num_args() == 0) { - return $this->handleUnconditionally; - } - - $this->handleUnconditionally = (bool) $value; - } - - /** - * Adds an editor resolver, identified by a string - * name, and that may be a string path, or a callable - * resolver. If the callable returns a string, it will - * be set as the file reference's href attribute. - * - * @example - * $run->addEditor('macvim', "mvim://open?url=file://%file&line=%line") - * @example - * $run->addEditor('remove-it', function($file, $line) { - * unlink($file); - * return "http://stackoverflow.com"; - * }); - * @param string $identifier - * @param string $resolver - */ - public function addEditor($identifier, $resolver) - { - $this->editors[$identifier] = $resolver; - } - - /** - * Set the editor to use to open referenced files, by a string - * identifier, or a callable that will be executed for every - * file reference, with a $file and $line argument, and should - * return a string. - * - * @example - * $run->setEditor(function($file, $line) { return "file:///{$file}"; }); - * @example - * $run->setEditor('sublime'); - * - * @throws InvalidArgumentException If invalid argument identifier provided - * @param string|callable $editor - */ - public function setEditor($editor) - { - if (!is_callable($editor) && !isset($this->editors[$editor])) { - throw new InvalidArgumentException( - "Unknown editor identifier: $editor. Known editors:" . - implode(",", array_keys($this->editors)) - ); - } - - $this->editor = $editor; - } - - /** - * Given a string file path, and an integer file line, - * executes the editor resolver and returns, if available, - * a string that may be used as the href property for that - * file reference. - * - * @throws InvalidArgumentException If editor resolver does not return a string - * @param string $filePath - * @param int $line - * @return string|bool - */ - public function getEditorHref($filePath, $line) - { - $editor = $this->getEditor($filePath, $line); - - if (empty($editor)) { - return false; - } - - // Check that the editor is a string, and replace the - // %line and %file placeholders: - if (!isset($editor['url']) || !is_string($editor['url'])) { - throw new UnexpectedValueException( - __METHOD__ . " should always resolve to a string or a valid editor array; got something else instead." - ); - } - - $editor['url'] = str_replace("%line", rawurlencode($line), $editor['url']); - $editor['url'] = str_replace("%file", rawurlencode($filePath), $editor['url']); - - return $editor['url']; - } - - /** - * Given a boolean if the editor link should - * act as an Ajax request. The editor must be a - * valid callable function/closure - * - * @throws UnexpectedValueException If editor resolver does not return a boolean - * @param string $filePath - * @param int $line - * @return bool - */ - public function getEditorAjax($filePath, $line) - { - $editor = $this->getEditor($filePath, $line); - - // Check that the ajax is a bool - if (!isset($editor['ajax']) || !is_bool($editor['ajax'])) { - throw new UnexpectedValueException( - __METHOD__ . " should always resolve to a bool; got something else instead." - ); - } - return $editor['ajax']; - } - - /** - * Given a boolean if the editor link should - * act as an Ajax request. The editor must be a - * valid callable function/closure - * - * @param string $filePath - * @param int $line - * @return array - */ - protected function getEditor($filePath, $line) - { - if (!$this->editor || (!is_string($this->editor) && !is_callable($this->editor))) { - return []; - } - - if (is_string($this->editor) && isset($this->editors[$this->editor]) && !is_callable($this->editors[$this->editor])) { - return [ - 'ajax' => false, - 'url' => $this->editors[$this->editor], - ]; - } - - if (is_callable($this->editor) || (isset($this->editors[$this->editor]) && is_callable($this->editors[$this->editor]))) { - if (is_callable($this->editor)) { - $callback = call_user_func($this->editor, $filePath, $line); - } else { - $callback = call_user_func($this->editors[$this->editor], $filePath, $line); - } - - if (is_string($callback)) { - return [ - 'ajax' => false, - 'url' => $callback, - ]; - } - - return [ - 'ajax' => isset($callback['ajax']) ? $callback['ajax'] : false, - 'url' => isset($callback['url']) ? $callback['url'] : $callback, - ]; - } - - return []; - } - - /** - * @param string $title - * @return void - */ - public function setPageTitle($title) - { - $this->pageTitle = (string) $title; - } - - /** - * @return string - */ - public function getPageTitle() - { - return $this->pageTitle; - } - - /** - * Adds a path to the list of paths to be searched for - * resources. - * - * @throws InvalidArgumentException If $path is not a valid directory - * - * @param string $path - * @return void - */ - public function addResourcePath($path) - { - if (!is_dir($path)) { - throw new InvalidArgumentException( - "'$path' is not a valid directory" - ); - } - - array_unshift($this->searchPaths, $path); - } - - /** - * Adds a custom css file to be loaded. - * - * @param string $name - * @return void - */ - public function addCustomCss($name) - { - $this->customCss = $name; - } - - /** - * @return array - */ - public function getResourcePaths() - { - return $this->searchPaths; - } - - /** - * Finds a resource, by its relative path, in all available search paths. - * The search is performed starting at the last search path, and all the - * way back to the first, enabling a cascading-type system of overrides - * for all resources. - * - * @throws RuntimeException If resource cannot be found in any of the available paths - * - * @param string $resource - * @return string - */ - protected function getResource($resource) - { - // If the resource was found before, we can speed things up - // by caching its absolute, resolved path: - if (isset($this->resourceCache[$resource])) { - return $this->resourceCache[$resource]; - } - - // Search through available search paths, until we find the - // resource we're after: - foreach ($this->searchPaths as $path) { - $fullPath = $path . "/$resource"; - - if (is_file($fullPath)) { - // Cache the result: - $this->resourceCache[$resource] = $fullPath; - return $fullPath; - } - } - - // If we got this far, nothing was found. - throw new RuntimeException( - "Could not find resource '$resource' in any resource paths." - . "(searched: " . join(", ", $this->searchPaths). ")" - ); - } - - /** - * @deprecated - * - * @return string - */ - public function getResourcesPath() - { - $allPaths = $this->getResourcePaths(); - - // Compat: return only the first path added - return end($allPaths) ?: null; - } - - /** - * @deprecated - * - * @param string $resourcesPath - * @return void - */ - public function setResourcesPath($resourcesPath) - { - $this->addResourcePath($resourcesPath); - } - - /** - * Return the application paths. - * - * @return array - */ - public function getApplicationPaths() - { - return $this->applicationPaths; - } - - /** - * Set the application paths. - * - * @param array $applicationPaths - */ - public function setApplicationPaths($applicationPaths) - { - $this->applicationPaths = $applicationPaths; - } - - /** - * Set the application root path. - * - * @param string $applicationRootPath - */ - public function setApplicationRootPath($applicationRootPath) - { - $this->templateHelper->setApplicationRootPath($applicationRootPath); - } - - /** - * blacklist a sensitive value within one of the superglobal arrays. - * - * @param $superGlobalName string the name of the superglobal array, e.g. '_GET' - * @param $key string the key within the superglobal - */ - public function blacklist($superGlobalName, $key) - { - $this->blacklist[$superGlobalName][] = $key; - } - - /** - * Checks all values within the given superGlobal array. - * Blacklisted values will be replaced by a equal length string cointaining only '*' characters. - * - * We intentionally dont rely on $GLOBALS as it depends on 'auto_globals_jit' php.ini setting. - * - * @param $superGlobal array One of the superglobal arrays - * @param $superGlobalName string the name of the superglobal array, e.g. '_GET' - * @return array $values without sensitive data - */ - private function masked(array $superGlobal, $superGlobalName) - { - $blacklisted = $this->blacklist[$superGlobalName]; - - $values = $superGlobal; - foreach ($blacklisted as $key) { - if (isset($superGlobal[$key])) { - $values[$key] = str_repeat('*', strlen($superGlobal[$key])); - } - } - return $values; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php b/framework/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php deleted file mode 100644 index 0d0a577..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Handler/XmlResponseHandler.php +++ /dev/null @@ -1,107 +0,0 @@ - - */ - -namespace Whoops\Handler; - -use SimpleXMLElement; -use Whoops\Exception\Formatter; - -/** - * Catches an exception and converts it to an XML - * response. Additionally can also return exception - * frames for consumption by an API. - */ -class XmlResponseHandler extends Handler -{ - /** - * @var bool - */ - private $returnFrames = false; - - /** - * @param bool|null $returnFrames - * @return bool|$this - */ - public function addTraceToOutput($returnFrames = null) - { - if (func_num_args() == 0) { - return $this->returnFrames; - } - - $this->returnFrames = (bool) $returnFrames; - return $this; - } - - /** - * @return int - */ - public function handle() - { - $response = [ - 'error' => Formatter::formatExceptionAsDataArray( - $this->getInspector(), - $this->addTraceToOutput() - ), - ]; - - echo $this->toXml($response); - - return Handler::QUIT; - } - - /** - * @return string - */ - public function contentType() - { - return 'application/xml'; - } - - /** - * @param SimpleXMLElement $node Node to append data to, will be modified in place - * @param array|\Traversable $data - * @return SimpleXMLElement The modified node, for chaining - */ - private static function addDataToNode(\SimpleXMLElement $node, $data) - { - assert(is_array($data) || $data instanceof Traversable); - - foreach ($data as $key => $value) { - if (is_numeric($key)) { - // Convert the key to a valid string - $key = "unknownNode_". (string) $key; - } - - // Delete any char not allowed in XML element names - $key = preg_replace('/[^a-z0-9\-\_\.\:]/i', '', $key); - - if (is_array($value)) { - $child = $node->addChild($key); - self::addDataToNode($child, $value); - } else { - $value = str_replace('&', '&', print_r($value, true)); - $node->addChild($key, $value); - } - } - - return $node; - } - - /** - * The main function for converting to an XML document. - * - * @param array|\Traversable $data - * @return string XML - */ - private static function toXml($data) - { - assert(is_array($data) || $data instanceof Traversable); - - $node = simplexml_load_string(""); - - return self::addDataToNode($node, $data)->asXML(); - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Handler/index.html b/framework/vendor/filp/whoops/src/Whoops/Handler/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/css/index.html b/framework/vendor/filp/whoops/src/Whoops/Resources/css/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css b/framework/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css deleted file mode 100644 index 8c08bbc..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/css/whoops.base.css +++ /dev/null @@ -1,583 +0,0 @@ -body { - font: 12px "Helvetica Neue", helvetica, arial, sans-serif; - color: #131313; - background: #eeeeee; - padding:0; - margin: 0; - max-height: 100%; - - text-rendering: optimizeLegibility; -} - a { - text-decoration: none; - } - -.panel { - overflow-y: scroll; - height: 100%; - position: fixed; - margin: 0; - left: 0; - top: 0; -} - -.branding { - position: absolute; - top: 10px; - right: 20px; - color: #777777; - font-size: 10px; - z-index: 100; -} - .branding a { - color: #e95353; - } - -header { - color: white; - box-sizing: border-box; - background-color: #2a2a2a; - padding: 35px 40px; - max-height: 180px; - overflow: hidden; - transition: 0.5s; -} - - header.header-expand { - max-height: 1000px; - } - - .exc-title { - margin: 0; - color: #bebebe; - font-size: 14px; - } - .exc-title-primary { - color: #e95353; - } - - .exc-message { - font-size: 20px; - word-wrap: break-word; - margin: 4px 0 0 0; - color: white; - } - .exc-message span { - display: block; - } - .exc-message-empty-notice { - color: #a29d9d; - font-weight: 300; - } - -.details-container { - left: 30%; - width: 70%; - background: #fafafa; -} - .details { - padding: 5px; - } - - .details-heading { - color: #4288CE; - font-weight: 300; - padding-bottom: 10px; - margin-bottom: 10px; - border-bottom: 1px solid rgba(0, 0, 0, .1); - } - - .details pre.sf-dump { - white-space: pre; - word-wrap: inherit; - } - - .details pre.sf-dump, - .details pre.sf-dump .sf-dump-num, - .details pre.sf-dump .sf-dump-const, - .details pre.sf-dump .sf-dump-str, - .details pre.sf-dump .sf-dump-note, - .details pre.sf-dump .sf-dump-ref, - .details pre.sf-dump .sf-dump-public, - .details pre.sf-dump .sf-dump-protected, - .details pre.sf-dump .sf-dump-private, - .details pre.sf-dump .sf-dump-meta, - .details pre.sf-dump .sf-dump-key, - .details pre.sf-dump .sf-dump-index { - color: #463C54; - } - -.left-panel { - width: 30%; - background: #ded8d8; -} - - .frames-description { - background: rgba(0, 0, 0, .05); - padding: 8px 15px; - color: #a29d9d; - font-size: 11px; - } - - .frames-description.frames-description-application { - text-align: center; - font-size: 12px; - } - .frames-container.frames-container-application .frame:not(.frame-application) { - display: none; - } - - .frames-tab { - color: #a29d9d; - display: inline-block; - padding: 4px 8px; - margin: 0 2px; - border-radius: 3px; - } - - .frames-tab.frames-tab-active { - background-color: #2a2a2a; - color: #bebebe; - } - - .frame { - padding: 14px; - cursor: pointer; - transition: all 0.1s ease; - background: #eeeeee; - } - .frame:not(:last-child) { - border-bottom: 1px solid rgba(0, 0, 0, .05); - } - - .frame.active { - box-shadow: inset -5px 0 0 0 #4288CE; - color: #4288CE; - } - - .frame:not(.active):hover { - background: #BEE9EA; - } - - .frame-method-info { - margin-bottom: 10px; - } - - .frame-class, .frame-function, .frame-index { - font-size: 14px; - } - - .frame-index { - float: left; - } - - .frame-method-info { - margin-left: 24px; - } - - .frame-index { - font-size: 11px; - color: #a29d9d; - background-color: rgba(0, 0, 0, .05); - height: 18px; - width: 18px; - line-height: 18px; - border-radius: 5px; - padding: 0 1px 0 1px; - text-align: center; - display: inline-block; - } - - .frame-application .frame-index { - background-color: #2a2a2a; - color: #bebebe; - } - - .frame-file { - font-family: "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace; - color: #a29d9d; - } - - .frame-file .editor-link { - color: #a29d9d; - } - - .frame-line { - font-weight: bold; - } - - .frame-line:before { - content: ":"; - } - - .frame-code { - padding: 5px; - background: #303030; - display: none; - } - - .frame-code.active { - display: block; - } - - .frame-code .frame-file { - color: #a29d9d; - padding: 12px 6px; - - border-bottom: none; - } - - .code-block { - padding: 10px; - margin: 0; - border-radius: 6px; - box-shadow: 0 3px 0 rgba(0, 0, 0, .05), - 0 10px 30px rgba(0, 0, 0, .05), - inset 0 0 1px 0 rgba(255, 255, 255, .07); - -moz-tab-size: 4; - -o-tab-size: 4; - tab-size: 4; - } - - .linenums { - margin: 0; - margin-left: 10px; - } - - .frame-comments { - border-top: none; - margin-top: 15px; - - font-size: 12px; - } - - .frame-comments.empty { - } - - .frame-comments.empty:before { - content: "No comments for this stack frame."; - font-weight: 300; - color: #a29d9d; - } - - .frame-comment { - padding: 10px; - color: #e3e3e3; - border-radius: 6px; - background-color: rgba(255, 255, 255, .05); - } - .frame-comment a { - font-weight: bold; - text-decoration: none; - } - .frame-comment a:hover { - color: #4bb1b1; - } - - .frame-comment:not(:last-child) { - border-bottom: 1px dotted rgba(0, 0, 0, .3); - } - - .frame-comment-context { - font-size: 10px; - color: white; - } - -.delimiter { - display: inline-block; -} - -.data-table-container label { - font-size: 16px; - color: #303030; - font-weight: bold; - margin: 10px 0; - - display: block; - - margin-bottom: 5px; - padding-bottom: 5px; -} - .data-table { - width: 100%; - margin-bottom: 10px; - } - - .data-table tbody { - font: 13px "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace; - } - - .data-table thead { - display: none; - } - - .data-table tr { - padding: 5px 0; - } - - .data-table td:first-child { - width: 20%; - min-width: 130px; - overflow: hidden; - font-weight: bold; - color: #463C54; - padding-right: 5px; - - } - - .data-table td:last-child { - width: 80%; - -ms-word-break: break-all; - word-break: break-all; - word-break: break-word; - -webkit-hyphens: auto; - -moz-hyphens: auto; - hyphens: auto; - } - - .data-table span.empty { - color: rgba(0, 0, 0, .3); - font-weight: 300; - } - .data-table label.empty { - display: inline; - } - -.handler { - padding: 4px 0; - font: 14px "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace; -} - -/* prettify code style -Uses the Doxy theme as a base */ -pre .str, code .str { color: #BCD42A; } /* string */ -pre .kwd, code .kwd { color: #4bb1b1; font-weight: bold; } /* keyword*/ -pre .com, code .com { color: #888; font-weight: bold; } /* comment */ -pre .typ, code .typ { color: #ef7c61; } /* type */ -pre .lit, code .lit { color: #BCD42A; } /* literal */ -pre .pun, code .pun { color: #fff; font-weight: bold; } /* punctuation */ -pre .pln, code .pln { color: #e9e4e5; } /* plaintext */ -pre .tag, code .tag { color: #4bb1b1; } /* html/xml tag */ -pre .htm, code .htm { color: #dda0dd; } /* html tag */ -pre .xsl, code .xsl { color: #d0a0d0; } /* xslt tag */ -pre .atn, code .atn { color: #ef7c61; font-weight: normal;} /* html/xml attribute name */ -pre .atv, code .atv { color: #bcd42a; } /* html/xml attribute value */ -pre .dec, code .dec { color: #606; } /* decimal */ -pre.code-block, code.code-block, .frame-args.code-block, .frame-args.code-block samp { - font-family: "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace; - background: #333; - color: #e9e4e5; -} - pre.code-block { - white-space: pre-wrap; - } - - pre.code-block a, code.code-block a { - text-decoration:none; - } - - .linenums li { - color: #A5A5A5; - } - - .linenums li.current{ - background: rgba(255, 100, 100, .07); - } - .linenums li.current.active { - background: rgba(255, 100, 100, .17); - } - -pre:not(.prettyprinted) { - padding-left: 60px; -} - -#plain-exception { - display: none; -} - -#copy-button { - cursor: pointer; - border: 0; -} - -.clipboard { - opacity: .8; - background: none; - - color: rgba(255, 255, 255, 0.1); - box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.1); - - border-radius: 3px; - - outline: none !important; -} - - .clipboard:hover { - box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.3); - color: rgba(255, 255, 255, 0.3); - } - -/* inspired by githubs kbd styles */ -kbd { - -moz-border-bottom-colors: none; - -moz-border-left-colors: none; - -moz-border-right-colors: none; - -moz-border-top-colors: none; - background-color: #fcfcfc; - border-color: #ccc #ccc #bbb; - border-image: none; - border-style: solid; - border-width: 1px; - color: #555; - display: inline-block; - font-size: 11px; - line-height: 10px; - padding: 3px 5px; - vertical-align: middle; -} - - -/* == Media queries */ - -/* Expand the spacing in the details section */ -@media (min-width: 1000px) { - .details, .frame-code { - padding: 20px 40px; - } - - .details-container { - left: 32%; - width: 68%; - } - - .frames-container { - margin: 5px; - } - - .left-panel { - width: 32%; - } -} - -/* Stack panels */ -@media (max-width: 600px) { - .panel { - position: static; - width: 100%; - } -} - -/* Stack details tables */ -@media (max-width: 400px) { - .data-table, - .data-table tbody, - .data-table tbody tr, - .data-table tbody td { - display: block; - width: 100%; - } - - .data-table tbody tr:first-child { - padding-top: 0; - } - - .data-table tbody td:first-child, - .data-table tbody td:last-child { - padding-left: 0; - padding-right: 0; - } - - .data-table tbody td:last-child { - padding-top: 3px; - } -} - -.tooltipped { - position: relative -} -.tooltipped:after { - position: absolute; - z-index: 1000000; - display: none; - padding: 5px 8px; - color: #fff; - text-align: center; - text-decoration: none; - text-shadow: none; - text-transform: none; - letter-spacing: normal; - word-wrap: break-word; - white-space: pre; - pointer-events: none; - content: attr(aria-label); - background: rgba(0, 0, 0, 0.8); - border-radius: 3px; - -webkit-font-smoothing: subpixel-antialiased -} -.tooltipped:before { - position: absolute; - z-index: 1000001; - display: none; - width: 0; - height: 0; - color: rgba(0, 0, 0, 0.8); - pointer-events: none; - content: ""; - border: 5px solid transparent -} -.tooltipped:hover:before, -.tooltipped:hover:after, -.tooltipped:active:before, -.tooltipped:active:after, -.tooltipped:focus:before, -.tooltipped:focus:after { - display: inline-block; - text-decoration: none -} -.tooltipped-s:after { - top: 100%; - right: 50%; - margin-top: 5px -} -.tooltipped-s:before { - top: auto; - right: 50%; - bottom: -5px; - margin-right: -5px; - border-bottom-color: rgba(0, 0, 0, 0.8) -} - -pre.sf-dump { - padding: 0px !important; - margin: 0px !important; -} - -.search-for-help { - width: 85%; - padding: 0; - margin: 10px 0; - list-style-type: none; - display: inline-block; -} - .search-for-help li { - display: inline-block; - margin-right: 5px; - } - .search-for-help li:last-child { - margin-right: 0; - } - .search-for-help li a { - - } - .search-for-help li a i { - width: 16px; - height: 16px; - overflow: hidden; - display: block; - } - .search-for-help li a svg { - fill: #fff; - } - .search-for-help li a svg path { - background-size: contain; - } diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/index.html b/framework/vendor/filp/whoops/src/Whoops/Resources/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js b/framework/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js deleted file mode 100644 index 36a75a4..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/js/clipboard.min.js +++ /dev/null @@ -1,7 +0,0 @@ -/*! - * clipboard.js v1.5.3 - * https://zenorocha.github.io/clipboard.js - * - * Licensed MIT © Zeno Rocha - */ -!function(t){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var e;e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,e.Clipboard=t()}}(function(){var t,e,n;return function t(e,n,r){function o(a,c){if(!n[a]){if(!e[a]){var s="function"==typeof require&&require;if(!c&&s)return s(a,!0);if(i)return i(a,!0);var u=new Error("Cannot find module '"+a+"'");throw u.code="MODULE_NOT_FOUND",u}var l=n[a]={exports:{}};e[a][0].call(l.exports,function(t){var n=e[a][1][t];return o(n?n:t)},l,l.exports,t,e,n,r)}return n[a].exports}for(var i="function"==typeof require&&require,a=0;ar;r++)n[r].fn.apply(n[r].ctx,e);return this},off:function(t,e){var n=this.e||(this.e={}),r=n[t],o=[];if(r&&e)for(var i=0,a=r.length;a>i;i++)r[i].fn!==e&&r[i].fn._!==e&&o.push(r[i]);return o.length?n[t]=o:delete n[t],this}},e.exports=r},{}],8:[function(t,e,n){"use strict";function r(t){return t&&t.__esModule?t:{"default":t}}function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}n.__esModule=!0;var i=function(){function t(t,e){for(var n=0;n122||(e<65||h>90||d.push([Math.max(65,h)|32,Math.min(e,90)|32]),e<97||h>122||d.push([Math.max(97,h)&-33,Math.min(e,122)&-33]))}}d.sort(function(d,a){return d[0]-a[0]||a[1]-d[1]});a=[];c=[];for(f=0;fh[0]&&(h[1]+1>h[0]&&b.push("-"),b.push(g(h[1])));b.push("]");return b.join("")}function t(d){for(var a=d.source.match(/\[(?:[^\\\]]|\\[\S\s])*]|\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\\d+|\\[^\dux]|\(\?[!:=]|[()^]|[^()[\\^]+/g),b=a.length,i=[],c=0,h=0;c=2&&d==="["?a[c]=j(e):d!=="\\"&&(a[c]=e.replace(/[A-Za-z]/g,function(d){d=d.charCodeAt(0);return"["+String.fromCharCode(d&-33,d|32)+"]"}));return a.join("")}for(var z=0,w=!1,k=!1,m=0,b=a.length;m=5&&"lang-"===f.substring(0, -5))&&!(u&&typeof u[1]==="string"))c=!1,f="src";c||(s[v]=f)}h=b;b+=v.length;if(c){c=u[1];var e=v.indexOf(c),p=e+c.length;u[2]&&(p=v.length-u[2].length,e=p-c.length);f=f.substring(5);E(k+h,v.substring(0,e),g,m);E(k+h+e,c,F(f,c),m);E(k+h+p,v.substring(p),g,m)}else m.push(k+h,f)}a.g=m}var j={},t;(function(){for(var g=a.concat(i),k=[],m={},b=0,o=g.length;b=0;)j[q.charAt(d)]=s;s=s[1];q=""+s;m.hasOwnProperty(q)||(k.push(s),m[q]=r)}k.push(/[\S\s]/);t= -O(k)})();var z=i.length;return g}function l(a){var i=[],g=[];a.tripleQuotedStrings?i.push(["str",/^(?:'''(?:[^'\\]|\\[\S\s]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\\]|\\[\S\s]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$))/,r,"'\""]):a.multiLineStrings?i.push(["str",/^(?:'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$)|`(?:[^\\`]|\\[\S\s])*(?:`|$))/,r,"'\"`"]):i.push(["str",/^(?:'(?:[^\n\r'\\]|\\.)*(?:'|$)|"(?:[^\n\r"\\]|\\.)*(?:"|$))/,r,"\"'"]);a.verbatimStrings&& -g.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,r]);var j=a.hashComments;j&&(a.cStyleComments?(j>1?i.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,r,"#"]):i.push(["com",/^#(?:(?:define|e(?:l|nd)if|else|error|ifn?def|include|line|pragma|undef|warning)\b|[^\n\r]*)/,r,"#"]),g.push(["str",/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h(?:h|pp|\+\+)?|[a-z]\w*)>/,r])):i.push(["com",/^#[^\n\r]*/,r,"#"]));a.cStyleComments&&(g.push(["com",/^\/\/[^\n\r]*/,r]),g.push(["com",/^\/\*[\S\s]*?(?:\*\/|$)/, -r]));a.regexLiterals&&g.push(["lang-regex",/^(?:^^\.?|[+-]|[!=]={0,2}|#|%=?|&&?=?|\(|\*=?|[+-]=|->|\/=?|::?|<{1,3}=?|[,;?@[{~]|\^\^?=?|\|\|?=?|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\s*(\/(?=[^*/])(?:[^/[\\]|\\[\S\s]|\[(?:[^\\\]]|\\[\S\s])*(?:]|$))+\/)/]);(j=a.types)&&g.push(["typ",j]);a=(""+a.keywords).replace(/^ | $/g,"");a.length&&g.push(["kwd",RegExp("^(?:"+a.replace(/[\s,]+/g,"|")+")\\b"),r]);i.push(["pln",/^\s+/,r," \r\n\t\u00a0"]);g.push(["lit", -/^@[$_a-z][\w$@]*/i,r],["typ",/^(?:[@_]?[A-Z]+[a-z][\w$@]*|\w+_t\b)/,r],["pln",/^[$_a-z][\w$@]*/i,r],["lit",/^(?:0x[\da-f]+|(?:\d(?:_\d+)*\d*(?:\.\d*)?|\.\d\+)(?:e[+-]?\d+)?)[a-z]*/i,r,"0123456789"],["pln",/^\\[\S\s]?/,r],["pun",/^.[^\s\w"$'./@\\`]*/,r]);return x(i,g)}function G(a,i,g){function j(a){switch(a.nodeType){case 1:if(z.test(a.className))break;if("br"===a.nodeName)t(a),a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)j(a);break;case 3:case 4:if(g){var b= -a.nodeValue,f=b.match(n);if(f){var i=b.substring(0,f.index);a.nodeValue=i;(b=b.substring(f.index+f[0].length))&&a.parentNode.insertBefore(k.createTextNode(b),a.nextSibling);t(a);i||a.parentNode.removeChild(a)}}}}function t(a){function i(a,b){var d=b?a.cloneNode(!1):a,e=a.parentNode;if(e){var e=i(e,1),f=a.nextSibling;e.appendChild(d);for(var g=f;g;g=f)f=g.nextSibling,e.appendChild(g)}return d}for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=i(a.nextSibling,0),f;(f=a.parentNode)&&f.nodeType=== -1;)a=f;b.push(a)}for(var z=/(?:^|\s)nocode(?:\s|$)/,n=/\r\n?|\n/,k=a.ownerDocument,m=k.createElement("li");a.firstChild;)m.appendChild(a.firstChild);for(var b=[m],o=0;o=0;){var j= -i[g];A.hasOwnProperty(j)?C.console&&console.warn("cannot override language handler %s",j):A[j]=a}}function F(a,i){if(!a||!A.hasOwnProperty(a))a=/^\s*=e&&(j+=2);g>=p&&(s+=2)}}finally{if(c)c.style.display=h}}catch(A){C.console&&console.log(A&&A.stack?A.stack:A)}}var C=window,y=["break,continue,do,else,for,if,return,while"],B=[[y,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],I=[B,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"], -J=[B,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"],K=[J,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,let,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var,virtual,where"],B=[B,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"], -L=[y,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],M=[y,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],y=[y,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],N=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)\b/, -Q=/\S/,R=l({keywords:[I,K,B,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END"+L,M,y],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),A={};n(R,["default-code"]);n(x([],[["pln",/^[^]*(?:>|$)/],["com",/^<\!--[\S\s]*?(?:--\>|$)/],["lang-",/^<\?([\S\s]+?)(?:\?>|$)/],["lang-",/^<%([\S\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-", -/^]*>([\S\s]+?)<\/xmp\b[^>]*>/i],["lang-js",/^]*>([\S\s]*?)(<\/script\b[^>]*>)/i],["lang-css",/^]*>([\S\s]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);n(x([["pln",/^\s+/,r," \t\r\n"],["atv",/^(?:"[^"]*"?|'[^']*'?)/,r,"\"'"]],[["tag",/^^<\/?[a-z](?:[\w-.:]*\w)?|\/?>$/i],["atn",/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^\s"'>]*(?:[^\s"'/>]|\/(?=\s)))/],["pun",/^[/<->]+/], -["lang-js",/^on\w+\s*=\s*"([^"]+)"/i],["lang-js",/^on\w+\s*=\s*'([^']+)'/i],["lang-js",/^on\w+\s*=\s*([^\s"'>]+)/i],["lang-css",/^style\s*=\s*"([^"]+)"/i],["lang-css",/^style\s*=\s*'([^']+)'/i],["lang-css",/^style\s*=\s*([^\s"'>]+)/i]]),["in.tag"]);n(x([],[["atv",/^[\S\s]+/]]),["uq.val"]);n(l({keywords:I,hashComments:!0,cStyleComments:!0,types:N}),["c","cc","cpp","cxx","cyc","m"]);n(l({keywords:"null,true,false"}),["json"]);n(l({keywords:K,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:N}), -["cs"]);n(l({keywords:J,cStyleComments:!0}),["java"]);n(l({keywords:y,hashComments:!0,multiLineStrings:!0}),["bsh","csh","sh"]);n(l({keywords:L,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}),["cv","py"]);n(l({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["perl","pl","pm"]);n(l({keywords:M,hashComments:!0, -multiLineStrings:!0,regexLiterals:!0}),["rb"]);n(l({keywords:B,cStyleComments:!0,regexLiterals:!0}),["js"]);n(l({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,throw,true,try,unless,until,when,while,yes",hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);n(x([],[["str",/^[\S\s]+/]]),["regex"]);var S=C.PR={createSimpleLexer:x,registerLangHandler:n,sourceDecorator:l, -PR_ATTRIB_NAME:"atn",PR_ATTRIB_VALUE:"atv",PR_COMMENT:"com",PR_DECLARATION:"dec",PR_KEYWORD:"kwd",PR_LITERAL:"lit",PR_NOCODE:"nocode",PR_PLAIN:"pln",PR_PUNCTUATION:"pun",PR_SOURCE:"src",PR_STRING:"str",PR_TAG:"tag",PR_TYPE:"typ",prettyPrintOne:C.prettyPrintOne=function(a,i,g){var j=document.createElement("pre");j.innerHTML=a;g&&G(j,g,!0);H({h:i,j:g,c:j,i:1});return j.innerHTML},prettyPrint:C.prettyPrint=function(a){function i(){var u;for(var g=C.PR_SHOULD_USE_CONTINUATION?k.now()+250:Infinity;m= 145) { - $header.addClass('header-expand'); - } - }); - $header.on('mouseleave', function () { - $header.removeClass('header-expand'); - }); - - /* - * add prettyprint classes to our current active codeblock - * run prettyPrint() to highlight the active code - * scroll to the line when prettyprint is done - * highlight the current line - */ - var renderCurrentCodeblock = function(id) { - - // remove previous codeblocks so we only render the active one - $('.code-block').removeClass('prettyprint'); - - // pass the id in when we can for speed - if (typeof(id) === 'undefined' || typeof(id) === 'object') { - var id = /frame\-line\-([\d]*)/.exec($activeLine.attr('id'))[1]; - } - - $('#frame-code-linenums-' + id).addClass('prettyprint'); - $('#frame-code-args-' + id).addClass('prettyprint'); - - prettyPrint(highlightCurrentLine); - - } - - /* - * Highlight the active and neighboring lines for the current frame - * Adjust the offset to make sure that line is veritcally centered - */ - - var highlightCurrentLine = function() { - var activeLineNumber = +($activeLine.find('.frame-line').text()); - var $lines = $activeFrame.find('.linenums li'); - var firstLine = +($lines.first().val()); - - // We show more code than needed, purely for proper syntax highlighting - // Let’s hide a big chunk of that code and then scroll the remaining block - $activeFrame.find('.code-block').first().css({ - maxHeight: 345, - overflow: 'hidden', - }); - - var $offset = $($lines[activeLineNumber - firstLine - 10]); - if ($offset.length > 0) { - $offset[0].scrollIntoView(); - } - - $($lines[activeLineNumber - firstLine - 1]).addClass('current'); - $($lines[activeLineNumber - firstLine]).addClass('current active'); - $($lines[activeLineNumber - firstLine + 1]).addClass('current'); - - $container.scrollTop(0); - - } - - /* - * click handler for loading codeblocks - */ - - $frameContainer.on('click', '.frame', function() { - - var $this = $(this); - var id = /frame\-line\-([\d]*)/.exec($this.attr('id'))[1]; - var $codeFrame = $('#frame-code-' + id); - - if ($codeFrame) { - - $activeLine.removeClass('active'); - $activeFrame.removeClass('active'); - - $this.addClass('active'); - $codeFrame.addClass('active'); - - $activeLine = $this; - $activeFrame = $codeFrame; - - renderCurrentCodeblock(id); - - } - - }); - - var clipboard = new Clipboard('.clipboard'); - var showTooltip = function(elem, msg) { - elem.setAttribute('class', 'clipboard tooltipped tooltipped-s'); - elem.setAttribute('aria-label', msg); - }; - - clipboard.on('success', function(e) { - e.clearSelection(); - - showTooltip(e.trigger, 'Copied!'); - }); - - clipboard.on('error', function(e) { - showTooltip(e.trigger, fallbackMessage(e.action)); - }); - - var btn = document.querySelector('.clipboard'); - - btn.addEventListener('mouseleave', function(e) { - e.currentTarget.setAttribute('class', 'clipboard'); - e.currentTarget.removeAttribute('aria-label'); - }); - - function fallbackMessage(action) { - var actionMsg = ''; - var actionKey = (action === 'cut' ? 'X' : 'C'); - - if (/Mac/i.test(navigator.userAgent)) { - actionMsg = 'Press ⌘-' + actionKey + ' to ' + action; - } else { - actionMsg = 'Press Ctrl-' + actionKey + ' to ' + action; - } - - return actionMsg; - } - - function scrollIntoView($node, $parent) { - var nodeOffset = $node.offset(); - var nodeTop = nodeOffset.top; - var nodeBottom = nodeTop + nodeOffset.height; - var parentScrollTop = $parent.scrollTop(); - var parentHeight = $parent.height(); - - if (nodeTop < 0) { - $parent.scrollTop(parentScrollTop + nodeTop); - } else if (nodeBottom > parentHeight) { - $parent.scrollTop(parentScrollTop + nodeBottom - parentHeight); - } - } - - $(document).on('keydown', function(e) { - var applicationFrames = $frameContainer.hasClass('frames-container-application'), - frameClass = applicationFrames ? '.frame.frame-application' : '.frame'; - - if(e.ctrlKey || e.which === 74 || e.which === 75) { - // CTRL+Arrow-UP/k and Arrow-Down/j support: - // 1) select the next/prev element - // 2) make sure the newly selected element is within the view-scope - // 3) focus the (right) container, so arrow-up/down (without ctrl) scroll the details - if (e.which === 38 /* arrow up */ || e.which === 75 /* k */) { - $activeLine.prev(frameClass).click(); - scrollIntoView($activeLine, $leftPanel); - $container.focus(); - e.preventDefault(); - } else if (e.which === 40 /* arrow down */ || e.which === 74 /* j */) { - $activeLine.next(frameClass).click(); - scrollIntoView($activeLine, $leftPanel); - $container.focus(); - e.preventDefault(); - } - } else if (e.which == 78 /* n */) { - if ($appFramesTab.length) { - setActiveFramesTab($('.frames-tab:not(.frames-tab-active)')); - } - } - }); - - // Render late enough for highlightCurrentLine to be ready - renderCurrentCodeblock(); - - // Avoid to quit the page with some protocol (e.g. IntelliJ Platform REST API) - $ajaxEditors.on('click', function(e){ - e.preventDefault(); - $.get(this.href); - }); - - // Symfony VarDumper: Close the by default expanded objects - $('.sf-dump-expanded') - .removeClass('sf-dump-expanded') - .addClass('sf-dump-compact'); - $('.sf-dump-toggle span').html('▶'); - - // Make the given frames-tab active - function setActiveFramesTab($tab) { - $tab.addClass('frames-tab-active'); - - if ($tab.attr('id') == 'application-frames-tab') { - $frameContainer.addClass('frames-container-application'); - $allFramesTab.removeClass('frames-tab-active'); - } else { - $frameContainer.removeClass('frames-container-application'); - $appFramesTab.removeClass('frames-tab-active'); - } - } - - $('a.frames-tab').on('click', function(e) { - e.preventDefault(); - setActiveFramesTab($(this)); - }); -}); diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/js/zepto.min.js b/framework/vendor/filp/whoops/src/Whoops/Resources/js/zepto.min.js deleted file mode 100644 index 0b2f97a..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/js/zepto.min.js +++ /dev/null @@ -1,2 +0,0 @@ -/* Zepto v1.1.3 - zepto event ajax form ie - zeptojs.com/license */ -var Zepto=function(){function L(t){return null==t?String(t):j[T.call(t)]||"object"}function Z(t){return"function"==L(t)}function $(t){return null!=t&&t==t.window}function _(t){return null!=t&&t.nodeType==t.DOCUMENT_NODE}function D(t){return"object"==L(t)}function R(t){return D(t)&&!$(t)&&Object.getPrototypeOf(t)==Object.prototype}function M(t){return"number"==typeof t.length}function k(t){return s.call(t,function(t){return null!=t})}function z(t){return t.length>0?n.fn.concat.apply([],t):t}function F(t){return t.replace(/::/g,"/").replace(/([A-Z]+)([A-Z][a-z])/g,"$1_$2").replace(/([a-z\d])([A-Z])/g,"$1_$2").replace(/_/g,"-").toLowerCase()}function q(t){return t in f?f[t]:f[t]=new RegExp("(^|\\s)"+t+"(\\s|$)")}function H(t,e){return"number"!=typeof e||c[F(t)]?e:e+"px"}function I(t){var e,n;return u[t]||(e=a.createElement(t),a.body.appendChild(e),n=getComputedStyle(e,"").getPropertyValue("display"),e.parentNode.removeChild(e),"none"==n&&(n="block"),u[t]=n),u[t]}function V(t){return"children"in t?o.call(t.children):n.map(t.childNodes,function(t){return 1==t.nodeType?t:void 0})}function U(n,i,r){for(e in i)r&&(R(i[e])||A(i[e]))?(R(i[e])&&!R(n[e])&&(n[e]={}),A(i[e])&&!A(n[e])&&(n[e]=[]),U(n[e],i[e],r)):i[e]!==t&&(n[e]=i[e])}function B(t,e){return null==e?n(t):n(t).filter(e)}function J(t,e,n,i){return Z(e)?e.call(t,n,i):e}function X(t,e,n){null==n?t.removeAttribute(e):t.setAttribute(e,n)}function W(e,n){var i=e.className,r=i&&i.baseVal!==t;return n===t?r?i.baseVal:i:void(r?i.baseVal=n:e.className=n)}function Y(t){var e;try{return t?"true"==t||("false"==t?!1:"null"==t?null:/^0/.test(t)||isNaN(e=Number(t))?/^[\[\{]/.test(t)?n.parseJSON(t):t:e):t}catch(i){return t}}function G(t,e){e(t);for(var n in t.childNodes)G(t.childNodes[n],e)}var t,e,n,i,C,N,r=[],o=r.slice,s=r.filter,a=window.document,u={},f={},c={"column-count":1,columns:1,"font-weight":1,"line-height":1,opacity:1,"z-index":1,zoom:1},l=/^\s*<(\w+|!)[^>]*>/,h=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,p=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,d=/^(?:body|html)$/i,m=/([A-Z])/g,g=["val","css","html","text","data","width","height","offset"],v=["after","prepend","before","append"],y=a.createElement("table"),x=a.createElement("tr"),b={tr:a.createElement("tbody"),tbody:y,thead:y,tfoot:y,td:x,th:x,"*":a.createElement("div")},w=/complete|loaded|interactive/,E=/^[\w-]*$/,j={},T=j.toString,S={},O=a.createElement("div"),P={tabindex:"tabIndex",readonly:"readOnly","for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder",contenteditable:"contentEditable"},A=Array.isArray||function(t){return t instanceof Array};return S.matches=function(t,e){if(!e||!t||1!==t.nodeType)return!1;var n=t.webkitMatchesSelector||t.mozMatchesSelector||t.oMatchesSelector||t.matchesSelector;if(n)return n.call(t,e);var i,r=t.parentNode,o=!r;return o&&(r=O).appendChild(t),i=~S.qsa(r,e).indexOf(t),o&&O.removeChild(t),i},C=function(t){return t.replace(/-+(.)?/g,function(t,e){return e?e.toUpperCase():""})},N=function(t){return s.call(t,function(e,n){return t.indexOf(e)==n})},S.fragment=function(e,i,r){var s,u,f;return h.test(e)&&(s=n(a.createElement(RegExp.$1))),s||(e.replace&&(e=e.replace(p,"<$1>")),i===t&&(i=l.test(e)&&RegExp.$1),i in b||(i="*"),f=b[i],f.innerHTML=""+e,s=n.each(o.call(f.childNodes),function(){f.removeChild(this)})),R(r)&&(u=n(s),n.each(r,function(t,e){g.indexOf(t)>-1?u[t](e):u.attr(t,e)})),s},S.Z=function(t,e){return t=t||[],t.__proto__=n.fn,t.selector=e||"",t},S.isZ=function(t){return t instanceof S.Z},S.init=function(e,i){var r;if(!e)return S.Z();if("string"==typeof e)if(e=e.trim(),"<"==e[0]&&l.test(e))r=S.fragment(e,RegExp.$1,i),e=null;else{if(i!==t)return n(i).find(e);r=S.qsa(a,e)}else{if(Z(e))return n(a).ready(e);if(S.isZ(e))return e;if(A(e))r=k(e);else if(D(e))r=[e],e=null;else if(l.test(e))r=S.fragment(e.trim(),RegExp.$1,i),e=null;else{if(i!==t)return n(i).find(e);r=S.qsa(a,e)}}return S.Z(r,e)},n=function(t,e){return S.init(t,e)},n.extend=function(t){var e,n=o.call(arguments,1);return"boolean"==typeof t&&(e=t,t=n.shift()),n.forEach(function(n){U(t,n,e)}),t},S.qsa=function(t,e){var n,i="#"==e[0],r=!i&&"."==e[0],s=i||r?e.slice(1):e,a=E.test(s);return _(t)&&a&&i?(n=t.getElementById(s))?[n]:[]:1!==t.nodeType&&9!==t.nodeType?[]:o.call(a&&!i?r?t.getElementsByClassName(s):t.getElementsByTagName(e):t.querySelectorAll(e))},n.contains=function(t,e){return t!==e&&t.contains(e)},n.type=L,n.isFunction=Z,n.isWindow=$,n.isArray=A,n.isPlainObject=R,n.isEmptyObject=function(t){var e;for(e in t)return!1;return!0},n.inArray=function(t,e,n){return r.indexOf.call(e,t,n)},n.camelCase=C,n.trim=function(t){return null==t?"":String.prototype.trim.call(t)},n.uuid=0,n.support={},n.expr={},n.map=function(t,e){var n,r,o,i=[];if(M(t))for(r=0;r=0?e:e+this.length]},toArray:function(){return this.get()},size:function(){return this.length},remove:function(){return this.each(function(){null!=this.parentNode&&this.parentNode.removeChild(this)})},each:function(t){return r.every.call(this,function(e,n){return t.call(e,n,e)!==!1}),this},filter:function(t){return Z(t)?this.not(this.not(t)):n(s.call(this,function(e){return S.matches(e,t)}))},add:function(t,e){return n(N(this.concat(n(t,e))))},is:function(t){return this.length>0&&S.matches(this[0],t)},not:function(e){var i=[];if(Z(e)&&e.call!==t)this.each(function(t){e.call(this,t)||i.push(this)});else{var r="string"==typeof e?this.filter(e):M(e)&&Z(e.item)?o.call(e):n(e);this.forEach(function(t){r.indexOf(t)<0&&i.push(t)})}return n(i)},has:function(t){return this.filter(function(){return D(t)?n.contains(this,t):n(this).find(t).size()})},eq:function(t){return-1===t?this.slice(t):this.slice(t,+t+1)},first:function(){var t=this[0];return t&&!D(t)?t:n(t)},last:function(){var t=this[this.length-1];return t&&!D(t)?t:n(t)},find:function(t){var e,i=this;return e="object"==typeof t?n(t).filter(function(){var t=this;return r.some.call(i,function(e){return n.contains(e,t)})}):1==this.length?n(S.qsa(this[0],t)):this.map(function(){return S.qsa(this,t)})},closest:function(t,e){var i=this[0],r=!1;for("object"==typeof t&&(r=n(t));i&&!(r?r.indexOf(i)>=0:S.matches(i,t));)i=i!==e&&!_(i)&&i.parentNode;return n(i)},parents:function(t){for(var e=[],i=this;i.length>0;)i=n.map(i,function(t){return(t=t.parentNode)&&!_(t)&&e.indexOf(t)<0?(e.push(t),t):void 0});return B(e,t)},parent:function(t){return B(N(this.pluck("parentNode")),t)},children:function(t){return B(this.map(function(){return V(this)}),t)},contents:function(){return this.map(function(){return o.call(this.childNodes)})},siblings:function(t){return B(this.map(function(t,e){return s.call(V(e.parentNode),function(t){return t!==e})}),t)},empty:function(){return this.each(function(){this.innerHTML=""})},pluck:function(t){return n.map(this,function(e){return e[t]})},show:function(){return this.each(function(){"none"==this.style.display&&(this.style.display=""),"none"==getComputedStyle(this,"").getPropertyValue("display")&&(this.style.display=I(this.nodeName))})},replaceWith:function(t){return this.before(t).remove()},wrap:function(t){var e=Z(t);if(this[0]&&!e)var i=n(t).get(0),r=i.parentNode||this.length>1;return this.each(function(o){n(this).wrapAll(e?t.call(this,o):r?i.cloneNode(!0):i)})},wrapAll:function(t){if(this[0]){n(this[0]).before(t=n(t));for(var e;(e=t.children()).length;)t=e.first();n(t).append(this)}return this},wrapInner:function(t){var e=Z(t);return this.each(function(i){var r=n(this),o=r.contents(),s=e?t.call(this,i):t;o.length?o.wrapAll(s):r.append(s)})},unwrap:function(){return this.parent().each(function(){n(this).replaceWith(n(this).children())}),this},clone:function(){return this.map(function(){return this.cloneNode(!0)})},hide:function(){return this.css("display","none")},toggle:function(e){return this.each(function(){var i=n(this);(e===t?"none"==i.css("display"):e)?i.show():i.hide()})},prev:function(t){return n(this.pluck("previousElementSibling")).filter(t||"*")},next:function(t){return n(this.pluck("nextElementSibling")).filter(t||"*")},html:function(t){return 0===arguments.length?this.length>0?this[0].innerHTML:null:this.each(function(e){var i=this.innerHTML;n(this).empty().append(J(this,t,e,i))})},text:function(e){return 0===arguments.length?this.length>0?this[0].textContent:null:this.each(function(){this.textContent=e===t?"":""+e})},attr:function(n,i){var r;return"string"==typeof n&&i===t?0==this.length||1!==this[0].nodeType?t:"value"==n&&"INPUT"==this[0].nodeName?this.val():!(r=this[0].getAttribute(n))&&n in this[0]?this[0][n]:r:this.each(function(t){if(1===this.nodeType)if(D(n))for(e in n)X(this,e,n[e]);else X(this,n,J(this,i,t,this.getAttribute(n)))})},removeAttr:function(t){return this.each(function(){1===this.nodeType&&X(this,t)})},prop:function(e,n){return e=P[e]||e,n===t?this[0]&&this[0][e]:this.each(function(t){this[e]=J(this,n,t,this[e])})},data:function(e,n){var i=this.attr("data-"+e.replace(m,"-$1").toLowerCase(),n);return null!==i?Y(i):t},val:function(t){return 0===arguments.length?this[0]&&(this[0].multiple?n(this[0]).find("option").filter(function(){return this.selected}).pluck("value"):this[0].value):this.each(function(e){this.value=J(this,t,e,this.value)})},offset:function(t){if(t)return this.each(function(e){var i=n(this),r=J(this,t,e,i.offset()),o=i.offsetParent().offset(),s={top:r.top-o.top,left:r.left-o.left};"static"==i.css("position")&&(s.position="relative"),i.css(s)});if(0==this.length)return null;var e=this[0].getBoundingClientRect();return{left:e.left+window.pageXOffset,top:e.top+window.pageYOffset,width:Math.round(e.width),height:Math.round(e.height)}},css:function(t,i){if(arguments.length<2){var r=this[0],o=getComputedStyle(r,"");if(!r)return;if("string"==typeof t)return r.style[C(t)]||o.getPropertyValue(t);if(A(t)){var s={};return n.each(A(t)?t:[t],function(t,e){s[e]=r.style[C(e)]||o.getPropertyValue(e)}),s}}var a="";if("string"==L(t))i||0===i?a=F(t)+":"+H(t,i):this.each(function(){this.style.removeProperty(F(t))});else for(e in t)t[e]||0===t[e]?a+=F(e)+":"+H(e,t[e])+";":this.each(function(){this.style.removeProperty(F(e))});return this.each(function(){this.style.cssText+=";"+a})},index:function(t){return t?this.indexOf(n(t)[0]):this.parent().children().indexOf(this[0])},hasClass:function(t){return t?r.some.call(this,function(t){return this.test(W(t))},q(t)):!1},addClass:function(t){return t?this.each(function(e){i=[];var r=W(this),o=J(this,t,e,r);o.split(/\s+/g).forEach(function(t){n(this).hasClass(t)||i.push(t)},this),i.length&&W(this,r+(r?" ":"")+i.join(" "))}):this},removeClass:function(e){return this.each(function(n){return e===t?W(this,""):(i=W(this),J(this,e,n,i).split(/\s+/g).forEach(function(t){i=i.replace(q(t)," ")}),void W(this,i.trim()))})},toggleClass:function(e,i){return e?this.each(function(r){var o=n(this),s=J(this,e,r,W(this));s.split(/\s+/g).forEach(function(e){(i===t?!o.hasClass(e):i)?o.addClass(e):o.removeClass(e)})}):this},scrollTop:function(e){if(this.length){var n="scrollTop"in this[0];return e===t?n?this[0].scrollTop:this[0].pageYOffset:this.each(n?function(){this.scrollTop=e}:function(){this.scrollTo(this.scrollX,e)})}},scrollLeft:function(e){if(this.length){var n="scrollLeft"in this[0];return e===t?n?this[0].scrollLeft:this[0].pageXOffset:this.each(n?function(){this.scrollLeft=e}:function(){this.scrollTo(e,this.scrollY)})}},position:function(){if(this.length){var t=this[0],e=this.offsetParent(),i=this.offset(),r=d.test(e[0].nodeName)?{top:0,left:0}:e.offset();return i.top-=parseFloat(n(t).css("margin-top"))||0,i.left-=parseFloat(n(t).css("margin-left"))||0,r.top+=parseFloat(n(e[0]).css("border-top-width"))||0,r.left+=parseFloat(n(e[0]).css("border-left-width"))||0,{top:i.top-r.top,left:i.left-r.left}}},offsetParent:function(){return this.map(function(){for(var t=this.offsetParent||a.body;t&&!d.test(t.nodeName)&&"static"==n(t).css("position");)t=t.offsetParent;return t})}},n.fn.detach=n.fn.remove,["width","height"].forEach(function(e){var i=e.replace(/./,function(t){return t[0].toUpperCase()});n.fn[e]=function(r){var o,s=this[0];return r===t?$(s)?s["inner"+i]:_(s)?s.documentElement["scroll"+i]:(o=this.offset())&&o[e]:this.each(function(t){s=n(this),s.css(e,J(this,r,t,s[e]()))})}}),v.forEach(function(t,e){var i=e%2;n.fn[t]=function(){var t,o,r=n.map(arguments,function(e){return t=L(e),"object"==t||"array"==t||null==e?e:S.fragment(e)}),s=this.length>1;return r.length<1?this:this.each(function(t,a){o=i?a:a.parentNode,a=0==e?a.nextSibling:1==e?a.firstChild:2==e?a:null,r.forEach(function(t){if(s)t=t.cloneNode(!0);else if(!o)return n(t).remove();G(o.insertBefore(t,a),function(t){null==t.nodeName||"SCRIPT"!==t.nodeName.toUpperCase()||t.type&&"text/javascript"!==t.type||t.src||window.eval.call(window,t.innerHTML)})})})},n.fn[i?t+"To":"insert"+(e?"Before":"After")]=function(e){return n(e)[t](this),this}}),S.Z.prototype=n.fn,S.uniq=N,S.deserializeValue=Y,n.zepto=S,n}();window.Zepto=Zepto,void 0===window.$&&(window.$=Zepto),function(t){function l(t){return t._zid||(t._zid=e++)}function h(t,e,n,i){if(e=p(e),e.ns)var r=d(e.ns);return(s[l(t)]||[]).filter(function(t){return!(!t||e.e&&t.e!=e.e||e.ns&&!r.test(t.ns)||n&&l(t.fn)!==l(n)||i&&t.sel!=i)})}function p(t){var e=(""+t).split(".");return{e:e[0],ns:e.slice(1).sort().join(" ")}}function d(t){return new RegExp("(?:^| )"+t.replace(" "," .* ?")+"(?: |$)")}function m(t,e){return t.del&&!u&&t.e in f||!!e}function g(t){return c[t]||u&&f[t]||t}function v(e,i,r,o,a,u,f){var h=l(e),d=s[h]||(s[h]=[]);i.split(/\s/).forEach(function(i){if("ready"==i)return t(document).ready(r);var s=p(i);s.fn=r,s.sel=a,s.e in c&&(r=function(e){var n=e.relatedTarget;return!n||n!==this&&!t.contains(this,n)?s.fn.apply(this,arguments):void 0}),s.del=u;var l=u||r;s.proxy=function(t){if(t=j(t),!t.isImmediatePropagationStopped()){t.data=o;var i=l.apply(e,t._args==n?[t]:[t].concat(t._args));return i===!1&&(t.preventDefault(),t.stopPropagation()),i}},s.i=d.length,d.push(s),"addEventListener"in e&&e.addEventListener(g(s.e),s.proxy,m(s,f))})}function y(t,e,n,i,r){var o=l(t);(e||"").split(/\s/).forEach(function(e){h(t,e,n,i).forEach(function(e){delete s[o][e.i],"removeEventListener"in t&&t.removeEventListener(g(e.e),e.proxy,m(e,r))})})}function j(e,i){return(i||!e.isDefaultPrevented)&&(i||(i=e),t.each(E,function(t,n){var r=i[t];e[t]=function(){return this[n]=x,r&&r.apply(i,arguments)},e[n]=b}),(i.defaultPrevented!==n?i.defaultPrevented:"returnValue"in i?i.returnValue===!1:i.getPreventDefault&&i.getPreventDefault())&&(e.isDefaultPrevented=x)),e}function T(t){var e,i={originalEvent:t};for(e in t)w.test(e)||t[e]===n||(i[e]=t[e]);return j(i,t)}var n,e=1,i=Array.prototype.slice,r=t.isFunction,o=function(t){return"string"==typeof t},s={},a={},u="onfocusin"in window,f={focus:"focusin",blur:"focusout"},c={mouseenter:"mouseover",mouseleave:"mouseout"};a.click=a.mousedown=a.mouseup=a.mousemove="MouseEvents",t.event={add:v,remove:y},t.proxy=function(e,n){if(r(e)){var i=function(){return e.apply(n,arguments)};return i._zid=l(e),i}if(o(n))return t.proxy(e[n],e);throw new TypeError("expected function")},t.fn.bind=function(t,e,n){return this.on(t,e,n)},t.fn.unbind=function(t,e){return this.off(t,e)},t.fn.one=function(t,e,n,i){return this.on(t,e,n,i,1)};var x=function(){return!0},b=function(){return!1},w=/^([A-Z]|returnValue$|layer[XY]$)/,E={preventDefault:"isDefaultPrevented",stopImmediatePropagation:"isImmediatePropagationStopped",stopPropagation:"isPropagationStopped"};t.fn.delegate=function(t,e,n){return this.on(e,t,n)},t.fn.undelegate=function(t,e,n){return this.off(e,t,n)},t.fn.live=function(e,n){return t(document.body).delegate(this.selector,e,n),this},t.fn.die=function(e,n){return t(document.body).undelegate(this.selector,e,n),this},t.fn.on=function(e,s,a,u,f){var c,l,h=this;return e&&!o(e)?(t.each(e,function(t,e){h.on(t,s,a,e,f)}),h):(o(s)||r(u)||u===!1||(u=a,a=s,s=n),(r(a)||a===!1)&&(u=a,a=n),u===!1&&(u=b),h.each(function(n,r){f&&(c=function(t){return y(r,t.type,u),u.apply(this,arguments)}),s&&(l=function(e){var n,o=t(e.target).closest(s,r).get(0);return o&&o!==r?(n=t.extend(T(e),{currentTarget:o,liveFired:r}),(c||u).apply(o,[n].concat(i.call(arguments,1)))):void 0}),v(r,e,u,a,s,l||c)}))},t.fn.off=function(e,i,s){var a=this;return e&&!o(e)?(t.each(e,function(t,e){a.off(t,i,e)}),a):(o(i)||r(s)||s===!1||(s=i,i=n),s===!1&&(s=b),a.each(function(){y(this,e,s,i)}))},t.fn.trigger=function(e,n){return e=o(e)||t.isPlainObject(e)?t.Event(e):j(e),e._args=n,this.each(function(){"dispatchEvent"in this?this.dispatchEvent(e):t(this).triggerHandler(e,n)})},t.fn.triggerHandler=function(e,n){var i,r;return this.each(function(s,a){i=T(o(e)?t.Event(e):e),i._args=n,i.target=a,t.each(h(a,e.type||e),function(t,e){return r=e.proxy(i),i.isImmediatePropagationStopped()?!1:void 0})}),r},"focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select keydown keypress keyup error".split(" ").forEach(function(e){t.fn[e]=function(t){return t?this.bind(e,t):this.trigger(e)}}),["focus","blur"].forEach(function(e){t.fn[e]=function(t){return t?this.bind(e,t):this.each(function(){try{this[e]()}catch(t){}}),this}}),t.Event=function(t,e){o(t)||(e=t,t=e.type);var n=document.createEvent(a[t]||"Events"),i=!0;if(e)for(var r in e)"bubbles"==r?i=!!e[r]:n[r]=e[r];return n.initEvent(t,i,!0),j(n)}}(Zepto),function(t){function l(e,n,i){var r=t.Event(n);return t(e).trigger(r,i),!r.isDefaultPrevented()}function h(t,e,i,r){return t.global?l(e||n,i,r):void 0}function p(e){e.global&&0===t.active++&&h(e,null,"ajaxStart")}function d(e){e.global&&!--t.active&&h(e,null,"ajaxStop")}function m(t,e){var n=e.context;return e.beforeSend.call(n,t,e)===!1||h(e,n,"ajaxBeforeSend",[t,e])===!1?!1:void h(e,n,"ajaxSend",[t,e])}function g(t,e,n,i){var r=n.context,o="success";n.success.call(r,t,o,e),i&&i.resolveWith(r,[t,o,e]),h(n,r,"ajaxSuccess",[e,n,t]),y(o,e,n)}function v(t,e,n,i,r){var o=i.context;i.error.call(o,n,e,t),r&&r.rejectWith(o,[n,e,t]),h(i,o,"ajaxError",[n,i,t||e]),y(e,n,i)}function y(t,e,n){var i=n.context;n.complete.call(i,e,t),h(n,i,"ajaxComplete",[e,n]),d(n)}function x(){}function b(t){return t&&(t=t.split(";",2)[0]),t&&(t==f?"html":t==u?"json":s.test(t)?"script":a.test(t)&&"xml")||"text"}function w(t,e){return""==e?t:(t+"&"+e).replace(/[&?]{1,2}/,"?")}function E(e){e.processData&&e.data&&"string"!=t.type(e.data)&&(e.data=t.param(e.data,e.traditional)),!e.data||e.type&&"GET"!=e.type.toUpperCase()||(e.url=w(e.url,e.data),e.data=void 0)}function j(e,n,i,r){return t.isFunction(n)&&(r=i,i=n,n=void 0),t.isFunction(i)||(r=i,i=void 0),{url:e,data:n,success:i,dataType:r}}function S(e,n,i,r){var o,s=t.isArray(n),a=t.isPlainObject(n);t.each(n,function(n,u){o=t.type(u),r&&(n=i?r:r+"["+(a||"object"==o||"array"==o?n:"")+"]"),!r&&s?e.add(u.name,u.value):"array"==o||!i&&"object"==o?S(e,u,i,n):e.add(n,u)})}var i,r,e=0,n=window.document,o=/)<[^<]*)*<\/script>/gi,s=/^(?:text|application)\/javascript/i,a=/^(?:text|application)\/xml/i,u="application/json",f="text/html",c=/^\s*$/;t.active=0,t.ajaxJSONP=function(i,r){if(!("type"in i))return t.ajax(i);var f,h,o=i.jsonpCallback,s=(t.isFunction(o)?o():o)||"jsonp"+ ++e,a=n.createElement("script"),u=window[s],c=function(e){t(a).triggerHandler("error",e||"abort")},l={abort:c};return r&&r.promise(l),t(a).on("load error",function(e,n){clearTimeout(h),t(a).off().remove(),"error"!=e.type&&f?g(f[0],l,i,r):v(null,n||"error",l,i,r),window[s]=u,f&&t.isFunction(u)&&u(f[0]),u=f=void 0}),m(l,i)===!1?(c("abort"),l):(window[s]=function(){f=arguments},a.src=i.url.replace(/\?(.+)=\?/,"?$1="+s),n.head.appendChild(a),i.timeout>0&&(h=setTimeout(function(){c("timeout")},i.timeout)),l)},t.ajaxSettings={type:"GET",beforeSend:x,success:x,error:x,complete:x,context:null,global:!0,xhr:function(){return new window.XMLHttpRequest},accepts:{script:"text/javascript, application/javascript, application/x-javascript",json:u,xml:"application/xml, text/xml",html:f,text:"text/plain"},crossDomain:!1,timeout:0,processData:!0,cache:!0},t.ajax=function(e){var n=t.extend({},e||{}),o=t.Deferred&&t.Deferred();for(i in t.ajaxSettings)void 0===n[i]&&(n[i]=t.ajaxSettings[i]);p(n),n.crossDomain||(n.crossDomain=/^([\w-]+:)?\/\/([^\/]+)/.test(n.url)&&RegExp.$2!=window.location.host),n.url||(n.url=window.location.toString()),E(n),n.cache===!1&&(n.url=w(n.url,"_="+Date.now()));var s=n.dataType,a=/\?.+=\?/.test(n.url);if("jsonp"==s||a)return a||(n.url=w(n.url,n.jsonp?n.jsonp+"=?":n.jsonp===!1?"":"callback=?")),t.ajaxJSONP(n,o);var j,u=n.accepts[s],f={},l=function(t,e){f[t.toLowerCase()]=[t,e]},h=/^([\w-]+:)\/\//.test(n.url)?RegExp.$1:window.location.protocol,d=n.xhr(),y=d.setRequestHeader;if(o&&o.promise(d),n.crossDomain||l("X-Requested-With","XMLHttpRequest"),l("Accept",u||"*/*"),(u=n.mimeType||u)&&(u.indexOf(",")>-1&&(u=u.split(",",2)[0]),d.overrideMimeType&&d.overrideMimeType(u)),(n.contentType||n.contentType!==!1&&n.data&&"GET"!=n.type.toUpperCase())&&l("Content-Type",n.contentType||"application/x-www-form-urlencoded"),n.headers)for(r in n.headers)l(r,n.headers[r]);if(d.setRequestHeader=l,d.onreadystatechange=function(){if(4==d.readyState){d.onreadystatechange=x,clearTimeout(j);var e,i=!1;if(d.status>=200&&d.status<300||304==d.status||0==d.status&&"file:"==h){s=s||b(n.mimeType||d.getResponseHeader("content-type")),e=d.responseText;try{"script"==s?(1,eval)(e):"xml"==s?e=d.responseXML:"json"==s&&(e=c.test(e)?null:t.parseJSON(e))}catch(r){i=r}i?v(i,"parsererror",d,n,o):g(e,d,n,o)}else v(d.statusText||null,d.status?"error":"abort",d,n,o)}},m(d,n)===!1)return d.abort(),v(null,"abort",d,n,o),d;if(n.xhrFields)for(r in n.xhrFields)d[r]=n.xhrFields[r];var T="async"in n?n.async:!0;d.open(n.type,n.url,T,n.username,n.password);for(r in f)y.apply(d,f[r]);return n.timeout>0&&(j=setTimeout(function(){d.onreadystatechange=x,d.abort(),v(null,"timeout",d,n,o)},n.timeout)),d.send(n.data?n.data:null),d},t.get=function(){return t.ajax(j.apply(null,arguments))},t.post=function(){var e=j.apply(null,arguments);return e.type="POST",t.ajax(e)},t.getJSON=function(){var e=j.apply(null,arguments);return e.dataType="json",t.ajax(e)},t.fn.load=function(e,n,i){if(!this.length)return this;var a,r=this,s=e.split(/\s/),u=j(e,n,i),f=u.success;return s.length>1&&(u.url=s[0],a=s[1]),u.success=function(e){r.html(a?t("
").html(e.replace(o,"")).find(a):e),f&&f.apply(r,arguments)},t.ajax(u),this};var T=encodeURIComponent;t.param=function(t,e){var n=[];return n.add=function(t,e){this.push(T(t)+"="+T(e))},S(n,t,e),n.join("&").replace(/%20/g,"+")}}(Zepto),function(t){t.fn.serializeArray=function(){var n,e=[];return t([].slice.call(this.get(0).elements)).each(function(){n=t(this);var i=n.attr("type");"fieldset"!=this.nodeName.toLowerCase()&&!this.disabled&&"submit"!=i&&"reset"!=i&&"button"!=i&&("radio"!=i&&"checkbox"!=i||this.checked)&&e.push({name:n.attr("name"),value:n.val()})}),e},t.fn.serialize=function(){var t=[];return this.serializeArray().forEach(function(e){t.push(encodeURIComponent(e.name)+"="+encodeURIComponent(e.value))}),t.join("&")},t.fn.submit=function(e){if(e)this.bind("submit",e);else if(this.length){var n=t.Event("submit");this.eq(0).trigger(n),n.isDefaultPrevented()||this.get(0).submit()}return this}}(Zepto),function(t){"__proto__"in{}||t.extend(t.zepto,{Z:function(e,n){return e=e||[],t.extend(e,t.fn),e.selector=n||"",e.__Z=!0,e},isZ:function(e){return"array"===t.type(e)&&"__Z"in e}});try{getComputedStyle(void 0)}catch(e){var n=getComputedStyle;window.getComputedStyle=function(t){try{return n(t)}catch(e){return null}}}}(Zepto); diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/env_details.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/env_details.html.php deleted file mode 100644 index 8db1493..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/env_details.html.php +++ /dev/null @@ -1,42 +0,0 @@ - -
-

Environment & details:

- -
- $data): ?> -
- - - - - - - - - - $value): ?> - - - - - -
KeyValue
escape($k) ?>dump($value) ?>
- - - empty - -
- -
- - -
- - $handler): ?> -
- . escape(get_class($handler)) ?> -
- -
- -
diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_code.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_code.html.php deleted file mode 100644 index 534f7c3..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_code.html.php +++ /dev/null @@ -1,63 +0,0 @@ - -
- $frame): ?> - getLine(); ?> -
- - getFileLines($line - 20, 40); - - // getFileLines can return null if there is no source code - if ($range): - $range = array_map(function ($line) { return empty($line) ? ' ' : $line;}, $range); - $start = key($range) + 1; - $code = join("\n", $range); - ?> -
escape($code) ?>
- - - - - dumpArgs($frame); ?> - -
- Arguments -
-
- -
- - - getComments(); - ?> -
- $comment): ?> - -
- escape($context) ?> - escapeButPreserveUris($comment) ?> -
- -
- -
- -
diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_list.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_list.html.php deleted file mode 100644 index a4bc338..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/frame_list.html.php +++ /dev/null @@ -1,17 +0,0 @@ - - $frame): ?> -
- -
- breakOnDelimiter('\\', $tpl->escape($frame->getClass() ?: '')) ?> - breakOnDelimiter('\\', $tpl->escape($frame->getFunction() ?: '')) ?> -
- -
- getFile() ? $tpl->breakOnDelimiter('/', $tpl->shorten($tpl->escape($frame->getFile()))) : '<#unknown>' ?>getLine() ?> -
-
-"> - render($frame_list) ?> -
\ No newline at end of file diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/frames_description.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/frames_description.html.php deleted file mode 100644 index e32cf88..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/frames_description.html.php +++ /dev/null @@ -1,20 +0,0 @@ -
- - - - Application frames (countIsApplication() ?>) - - - - Application frames (countIsApplication() ?>) - - - - All frames () - - - - Stack frames () - - -
diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/header.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/header.html.php deleted file mode 100644 index 11e1c1d..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/header.html.php +++ /dev/null @@ -1,74 +0,0 @@ -
-
- $nameSection): ?> - - escape($nameSection) ?> - - escape($nameSection) . ' \\' ?> - - - - (escape($code) ?>) - -
- -
- - escape($message) ?> - - No message - - - - - escape($plain_exception) ?> - -
-
diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/header_outer.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/header_outer.html.php deleted file mode 100644 index f682cbb..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/header_outer.html.php +++ /dev/null @@ -1,3 +0,0 @@ -
- render($header) ?> -
diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/index.html b/framework/vendor/filp/whoops/src/Whoops/Resources/views/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/layout.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/layout.html.php deleted file mode 100644 index 6b676cc..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/layout.html.php +++ /dev/null @@ -1,33 +0,0 @@ - - - - - - - - <?php echo $tpl->escape($page_title) ?> - - - - - -
-
- - render($panel_left_outer) ?> - - render($panel_details_outer) ?> - -
-
- - - - - - - diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details.html.php deleted file mode 100644 index a85e451..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details.html.php +++ /dev/null @@ -1,2 +0,0 @@ -render($frame_code) ?> -render($env_details) ?> \ No newline at end of file diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details_outer.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details_outer.html.php deleted file mode 100644 index 8162d8c..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_details_outer.html.php +++ /dev/null @@ -1,3 +0,0 @@ -
- render($panel_details) ?> -
\ No newline at end of file diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left.html.php deleted file mode 100644 index 7e652e4..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left.html.php +++ /dev/null @@ -1,4 +0,0 @@ -render($header_outer); -$tpl->render($frames_description); -$tpl->render($frames_container); diff --git a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left_outer.html.php b/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left_outer.html.php deleted file mode 100644 index 77b575c..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Resources/views/panel_left_outer.html.php +++ /dev/null @@ -1,3 +0,0 @@ -
- render($panel_left) ?> -
\ No newline at end of file diff --git a/framework/vendor/filp/whoops/src/Whoops/Run.php b/framework/vendor/filp/whoops/src/Whoops/Run.php deleted file mode 100644 index 1d51f1c..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Run.php +++ /dev/null @@ -1,410 +0,0 @@ - - */ - -namespace Whoops; - -use InvalidArgumentException; -use Whoops\Exception\ErrorException; -use Whoops\Exception\Inspector; -use Whoops\Handler\CallbackHandler; -use Whoops\Handler\Handler; -use Whoops\Handler\HandlerInterface; -use Whoops\Util\Misc; -use Whoops\Util\SystemFacade; - -final class Run implements RunInterface -{ - private $isRegistered; - private $allowQuit = true; - private $sendOutput = true; - - /** - * @var integer|false - */ - private $sendHttpCode = 500; - - /** - * @var HandlerInterface[] - */ - private $handlerStack = []; - - private $silencedPatterns = []; - - private $system; - - public function __construct(SystemFacade $system = null) - { - $this->system = $system ?: new SystemFacade; - } - - /** - * Pushes a handler to the end of the stack - * - * @throws InvalidArgumentException If argument is not callable or instance of HandlerInterface - * @param Callable|HandlerInterface $handler - * @return Run - */ - public function pushHandler($handler) - { - if (is_callable($handler)) { - $handler = new CallbackHandler($handler); - } - - if (!$handler instanceof HandlerInterface) { - throw new InvalidArgumentException( - "Argument to " . __METHOD__ . " must be a callable, or instance of " - . "Whoops\\Handler\\HandlerInterface" - ); - } - - $this->handlerStack[] = $handler; - return $this; - } - - /** - * Removes the last handler in the stack and returns it. - * Returns null if there"s nothing else to pop. - * @return null|HandlerInterface - */ - public function popHandler() - { - return array_pop($this->handlerStack); - } - - /** - * Returns an array with all handlers, in the - * order they were added to the stack. - * @return array - */ - public function getHandlers() - { - return $this->handlerStack; - } - - /** - * Clears all handlers in the handlerStack, including - * the default PrettyPage handler. - * @return Run - */ - public function clearHandlers() - { - $this->handlerStack = []; - return $this; - } - - /** - * @param \Throwable $exception - * @return Inspector - */ - private function getInspector($exception) - { - return new Inspector($exception); - } - - /** - * Registers this instance as an error handler. - * @return Run - */ - public function register() - { - if (!$this->isRegistered) { - // Workaround PHP bug 42098 - // https://bugs.php.net/bug.php?id=42098 - class_exists("\\Whoops\\Exception\\ErrorException"); - class_exists("\\Whoops\\Exception\\FrameCollection"); - class_exists("\\Whoops\\Exception\\Frame"); - class_exists("\\Whoops\\Exception\\Inspector"); - - $this->system->setErrorHandler([$this, self::ERROR_HANDLER]); - $this->system->setExceptionHandler([$this, self::EXCEPTION_HANDLER]); - $this->system->registerShutdownFunction([$this, self::SHUTDOWN_HANDLER]); - - $this->isRegistered = true; - } - - return $this; - } - - /** - * Unregisters all handlers registered by this Whoops\Run instance - * @return Run - */ - public function unregister() - { - if ($this->isRegistered) { - $this->system->restoreExceptionHandler(); - $this->system->restoreErrorHandler(); - - $this->isRegistered = false; - } - - return $this; - } - - /** - * Should Whoops allow Handlers to force the script to quit? - * @param bool|int $exit - * @return bool - */ - public function allowQuit($exit = null) - { - if (func_num_args() == 0) { - return $this->allowQuit; - } - - return $this->allowQuit = (bool) $exit; - } - - /** - * Silence particular errors in particular files - * @param array|string $patterns List or a single regex pattern to match - * @param int $levels Defaults to E_STRICT | E_DEPRECATED - * @return \Whoops\Run - */ - public function silenceErrorsInPaths($patterns, $levels = 10240) - { - $this->silencedPatterns = array_merge( - $this->silencedPatterns, - array_map( - function ($pattern) use ($levels) { - return [ - "pattern" => $pattern, - "levels" => $levels, - ]; - }, - (array) $patterns - ) - ); - return $this; - } - - - /** - * Returns an array with silent errors in path configuration - * - * @return array - */ - public function getSilenceErrorsInPaths() - { - return $this->silencedPatterns; - } - - /* - * Should Whoops send HTTP error code to the browser if possible? - * Whoops will by default send HTTP code 500, but you may wish to - * use 502, 503, or another 5xx family code. - * - * @param bool|int $code - * @return int|false - */ - public function sendHttpCode($code = null) - { - if (func_num_args() == 0) { - return $this->sendHttpCode; - } - - if (!$code) { - return $this->sendHttpCode = false; - } - - if ($code === true) { - $code = 500; - } - - if ($code < 400 || 600 <= $code) { - throw new InvalidArgumentException( - "Invalid status code '$code', must be 4xx or 5xx" - ); - } - - return $this->sendHttpCode = $code; - } - - /** - * Should Whoops push output directly to the client? - * If this is false, output will be returned by handleException - * @param bool|int $send - * @return bool - */ - public function writeToOutput($send = null) - { - if (func_num_args() == 0) { - return $this->sendOutput; - } - - return $this->sendOutput = (bool) $send; - } - - /** - * Handles an exception, ultimately generating a Whoops error - * page. - * - * @param \Throwable $exception - * @return string Output generated by handlers - */ - public function handleException($exception) - { - // Walk the registered handlers in the reverse order - // they were registered, and pass off the exception - $inspector = $this->getInspector($exception); - - // Capture output produced while handling the exception, - // we might want to send it straight away to the client, - // or return it silently. - $this->system->startOutputBuffering(); - - // Just in case there are no handlers: - $handlerResponse = null; - $handlerContentType = null; - - foreach (array_reverse($this->handlerStack) as $handler) { - $handler->setRun($this); - $handler->setInspector($inspector); - $handler->setException($exception); - - // The HandlerInterface does not require an Exception passed to handle() - // and neither of our bundled handlers use it. - // However, 3rd party handlers may have already relied on this parameter, - // and removing it would be possibly breaking for users. - $handlerResponse = $handler->handle($exception); - - // Collect the content type for possible sending in the headers. - $handlerContentType = method_exists($handler, 'contentType') ? $handler->contentType() : null; - - if (in_array($handlerResponse, [Handler::LAST_HANDLER, Handler::QUIT])) { - // The Handler has handled the exception in some way, and - // wishes to quit execution (Handler::QUIT), or skip any - // other handlers (Handler::LAST_HANDLER). If $this->allowQuit - // is false, Handler::QUIT behaves like Handler::LAST_HANDLER - break; - } - } - - $willQuit = $handlerResponse == Handler::QUIT && $this->allowQuit(); - - $output = $this->system->cleanOutputBuffer(); - - // If we're allowed to, send output generated by handlers directly - // to the output, otherwise, and if the script doesn't quit, return - // it so that it may be used by the caller - if ($this->writeToOutput()) { - // @todo Might be able to clean this up a bit better - if ($willQuit) { - // Cleanup all other output buffers before sending our output: - while ($this->system->getOutputBufferLevel() > 0) { - $this->system->endOutputBuffering(); - } - - // Send any headers if needed: - if (Misc::canSendHeaders() && $handlerContentType) { - header("Content-Type: {$handlerContentType}"); - } - } - - $this->writeToOutputNow($output); - } - - if ($willQuit) { - // HHVM fix for https://github.com/facebook/hhvm/issues/4055 - $this->system->flushOutputBuffer(); - - $this->system->stopExecution(1); - } - - return $output; - } - - /** - * Converts generic PHP errors to \ErrorException - * instances, before passing them off to be handled. - * - * This method MUST be compatible with set_error_handler. - * - * @param int $level - * @param string $message - * @param string $file - * @param int $line - * - * @return bool - * @throws ErrorException - */ - public function handleError($level, $message, $file = null, $line = null) - { - if ($level & $this->system->getErrorReportingLevel()) { - foreach ($this->silencedPatterns as $entry) { - $pathMatches = (bool) preg_match($entry["pattern"], $file); - $levelMatches = $level & $entry["levels"]; - if ($pathMatches && $levelMatches) { - // Ignore the error, abort handling - // See https://github.com/filp/whoops/issues/418 - return true; - } - } - - // XXX we pass $level for the "code" param only for BC reasons. - // see https://github.com/filp/whoops/issues/267 - $exception = new ErrorException($message, /*code*/ $level, /*severity*/ $level, $file, $line); - if ($this->canThrowExceptions) { - throw $exception; - } else { - $this->handleException($exception); - } - // Do not propagate errors which were already handled by Whoops. - return true; - } - - // Propagate error to the next handler, allows error_get_last() to - // work on silenced errors. - return false; - } - - /** - * Special case to deal with Fatal errors and the like. - */ - public function handleShutdown() - { - // If we reached this step, we are in shutdown handler. - // An exception thrown in a shutdown handler will not be propagated - // to the exception handler. Pass that information along. - $this->canThrowExceptions = false; - - $error = $this->system->getLastError(); - if ($error && Misc::isLevelFatal($error['type'])) { - // If there was a fatal error, - // it was not handled in handleError yet. - $this->handleError( - $error['type'], - $error['message'], - $error['file'], - $error['line'] - ); - } - } - - /** - * In certain scenarios, like in shutdown handler, we can not throw exceptions - * @var bool - */ - private $canThrowExceptions = true; - - /** - * Echo something to the browser - * @param string $output - * @return $this - */ - private function writeToOutputNow($output) - { - if ($this->sendHttpCode() && \Whoops\Util\Misc::canSendHeaders()) { - $this->system->setHttpResponseCode( - $this->sendHttpCode() - ); - } - - echo $output; - - return $this; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/RunInterface.php b/framework/vendor/filp/whoops/src/Whoops/RunInterface.php deleted file mode 100644 index 67ba90d..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/RunInterface.php +++ /dev/null @@ -1,131 +0,0 @@ - - */ - -namespace Whoops; - -use InvalidArgumentException; -use Whoops\Exception\ErrorException; -use Whoops\Handler\HandlerInterface; - -interface RunInterface -{ - const EXCEPTION_HANDLER = "handleException"; - const ERROR_HANDLER = "handleError"; - const SHUTDOWN_HANDLER = "handleShutdown"; - - /** - * Pushes a handler to the end of the stack - * - * @throws InvalidArgumentException If argument is not callable or instance of HandlerInterface - * @param Callable|HandlerInterface $handler - * @return Run - */ - public function pushHandler($handler); - - /** - * Removes the last handler in the stack and returns it. - * Returns null if there"s nothing else to pop. - * - * @return null|HandlerInterface - */ - public function popHandler(); - - /** - * Returns an array with all handlers, in the - * order they were added to the stack. - * - * @return array - */ - public function getHandlers(); - - /** - * Clears all handlers in the handlerStack, including - * the default PrettyPage handler. - * - * @return Run - */ - public function clearHandlers(); - - /** - * Registers this instance as an error handler. - * - * @return Run - */ - public function register(); - - /** - * Unregisters all handlers registered by this Whoops\Run instance - * - * @return Run - */ - public function unregister(); - - /** - * Should Whoops allow Handlers to force the script to quit? - * - * @param bool|int $exit - * @return bool - */ - public function allowQuit($exit = null); - - /** - * Silence particular errors in particular files - * - * @param array|string $patterns List or a single regex pattern to match - * @param int $levels Defaults to E_STRICT | E_DEPRECATED - * @return \Whoops\Run - */ - public function silenceErrorsInPaths($patterns, $levels = 10240); - - /** - * Should Whoops send HTTP error code to the browser if possible? - * Whoops will by default send HTTP code 500, but you may wish to - * use 502, 503, or another 5xx family code. - * - * @param bool|int $code - * @return int|false - */ - public function sendHttpCode($code = null); - - /** - * Should Whoops push output directly to the client? - * If this is false, output will be returned by handleException - * - * @param bool|int $send - * @return bool - */ - public function writeToOutput($send = null); - - /** - * Handles an exception, ultimately generating a Whoops error - * page. - * - * @param \Throwable $exception - * @return string Output generated by handlers - */ - public function handleException($exception); - - /** - * Converts generic PHP errors to \ErrorException - * instances, before passing them off to be handled. - * - * This method MUST be compatible with set_error_handler. - * - * @param int $level - * @param string $message - * @param string $file - * @param int $line - * - * @return bool - * @throws ErrorException - */ - public function handleError($level, $message, $file = null, $line = null); - - /** - * Special case to deal with Fatal errors and the like. - */ - public function handleShutdown(); -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Util/HtmlDumperOutput.php b/framework/vendor/filp/whoops/src/Whoops/Util/HtmlDumperOutput.php deleted file mode 100644 index 8c828fd..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Util/HtmlDumperOutput.php +++ /dev/null @@ -1,36 +0,0 @@ - - */ - -namespace Whoops\Util; - -/** - * Used as output callable for Symfony\Component\VarDumper\Dumper\HtmlDumper::dump() - * - * @see TemplateHelper::dump() - */ -class HtmlDumperOutput -{ - private $output; - - public function __invoke($line, $depth) - { - // A negative depth means "end of dump" - if ($depth >= 0) { - // Adds a two spaces indentation to the line - $this->output .= str_repeat(' ', $depth) . $line . "\n"; - } - } - - public function getOutput() - { - return $this->output; - } - - public function clear() - { - $this->output = null; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Util/Misc.php b/framework/vendor/filp/whoops/src/Whoops/Util/Misc.php deleted file mode 100644 index 001a687..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Util/Misc.php +++ /dev/null @@ -1,77 +0,0 @@ - - */ - -namespace Whoops\Util; - -class Misc -{ - /** - * Can we at this point in time send HTTP headers? - * - * Currently this checks if we are even serving an HTTP request, - * as opposed to running from a command line. - * - * If we are serving an HTTP request, we check if it's not too late. - * - * @return bool - */ - public static function canSendHeaders() - { - return isset($_SERVER["REQUEST_URI"]) && !headers_sent(); - } - - public static function isAjaxRequest() - { - return ( - !empty($_SERVER['HTTP_X_REQUESTED_WITH']) - && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest'); - } - - /** - * Check, if possible, that this execution was triggered by a command line. - * @return bool - */ - public static function isCommandLine() - { - return PHP_SAPI == 'cli'; - } - - /** - * Translate ErrorException code into the represented constant. - * - * @param int $error_code - * @return string - */ - public static function translateErrorCode($error_code) - { - $constants = get_defined_constants(true); - if (array_key_exists('Core', $constants)) { - foreach ($constants['Core'] as $constant => $value) { - if (substr($constant, 0, 2) == 'E_' && $value == $error_code) { - return $constant; - } - } - } - return "E_UNKNOWN"; - } - - /** - * Determine if an error level is fatal (halts execution) - * - * @param int $level - * @return bool - */ - public static function isLevelFatal($level) - { - $errors = E_ERROR; - $errors |= E_PARSE; - $errors |= E_CORE_ERROR; - $errors |= E_CORE_WARNING; - $errors |= E_COMPILE_ERROR; - $errors |= E_COMPILE_WARNING; - return ($level & $errors) > 0; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Util/SystemFacade.php b/framework/vendor/filp/whoops/src/Whoops/Util/SystemFacade.php deleted file mode 100644 index cc82e7f..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Util/SystemFacade.php +++ /dev/null @@ -1,137 +0,0 @@ - - */ - -namespace Whoops\Util; - -class SystemFacade -{ - /** - * Turns on output buffering. - * - * @return bool - */ - public function startOutputBuffering() - { - return ob_start(); - } - - /** - * @param callable $handler - * @param int $types - * - * @return callable|null - */ - public function setErrorHandler(callable $handler, $types = 'use-php-defaults') - { - // Workaround for PHP 5.5 - if ($types === 'use-php-defaults') { - $types = E_ALL | E_STRICT; - } - return set_error_handler($handler, $types); - } - - /** - * @param callable $handler - * - * @return callable|null - */ - public function setExceptionHandler(callable $handler) - { - return set_exception_handler($handler); - } - - /** - * @return void - */ - public function restoreExceptionHandler() - { - restore_exception_handler(); - } - - /** - * @return void - */ - public function restoreErrorHandler() - { - restore_error_handler(); - } - - /** - * @param callable $function - * - * @return void - */ - public function registerShutdownFunction(callable $function) - { - register_shutdown_function($function); - } - - /** - * @return string|false - */ - public function cleanOutputBuffer() - { - return ob_get_clean(); - } - - /** - * @return int - */ - public function getOutputBufferLevel() - { - return ob_get_level(); - } - - /** - * @return bool - */ - public function endOutputBuffering() - { - return ob_end_clean(); - } - - /** - * @return void - */ - public function flushOutputBuffer() - { - flush(); - } - - /** - * @return int - */ - public function getErrorReportingLevel() - { - return error_reporting(); - } - - /** - * @return array|null - */ - public function getLastError() - { - return error_get_last(); - } - - /** - * @param int $httpCode - * - * @return int - */ - public function setHttpResponseCode($httpCode) - { - return http_response_code($httpCode); - } - - /** - * @param int $exitStatus - */ - public function stopExecution($exitStatus) - { - exit($exitStatus); - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Util/TemplateHelper.php b/framework/vendor/filp/whoops/src/Whoops/Util/TemplateHelper.php deleted file mode 100644 index 00f6ae4..0000000 --- a/framework/vendor/filp/whoops/src/Whoops/Util/TemplateHelper.php +++ /dev/null @@ -1,352 +0,0 @@ - - */ - -namespace Whoops\Util; - -use Symfony\Component\VarDumper\Caster\Caster; -use Symfony\Component\VarDumper\Cloner\AbstractCloner; -use Symfony\Component\VarDumper\Cloner\VarCloner; -use Symfony\Component\VarDumper\Dumper\HtmlDumper; -use Whoops\Exception\Frame; - -/** - * Exposes useful tools for working with/in templates - */ -class TemplateHelper -{ - /** - * An array of variables to be passed to all templates - * @var array - */ - private $variables = []; - - /** - * @var HtmlDumper - */ - private $htmlDumper; - - /** - * @var HtmlDumperOutput - */ - private $htmlDumperOutput; - - /** - * @var AbstractCloner - */ - private $cloner; - - /** - * @var string - */ - private $applicationRootPath; - - public function __construct() - { - // root path for ordinary composer projects - $this->applicationRootPath = dirname(dirname(dirname(dirname(dirname(dirname(__DIR__)))))); - } - - /** - * Escapes a string for output in an HTML document - * - * @param string $raw - * @return string - */ - public function escape($raw) - { - $flags = ENT_QUOTES; - - // HHVM has all constants defined, but only ENT_IGNORE - // works at the moment - if (defined("ENT_SUBSTITUTE") && !defined("HHVM_VERSION")) { - $flags |= ENT_SUBSTITUTE; - } else { - // This is for 5.3. - // The documentation warns of a potential security issue, - // but it seems it does not apply in our case, because - // we do not blacklist anything anywhere. - $flags |= ENT_IGNORE; - } - - $raw = str_replace(chr(9), ' ', $raw); - - return htmlspecialchars($raw, $flags, "UTF-8"); - } - - /** - * Escapes a string for output in an HTML document, but preserves - * URIs within it, and converts them to clickable anchor elements. - * - * @param string $raw - * @return string - */ - public function escapeButPreserveUris($raw) - { - $escaped = $this->escape($raw); - return preg_replace( - "@([A-z]+?://([-\w\.]+[-\w])+(:\d+)?(/([\w/_\.#-]*(\?\S+)?[^\.\s])?)?)@", - "$1", - $escaped - ); - } - - /** - * Makes sure that the given string breaks on the delimiter. - * - * @param string $delimiter - * @param string $s - * @return string - */ - public function breakOnDelimiter($delimiter, $s) - { - $parts = explode($delimiter, $s); - foreach ($parts as &$part) { - $part = '
' . $part . '
'; - } - - return implode($delimiter, $parts); - } - - /** - * Replace the part of the path that all files have in common. - * - * @param string $path - * @return string - */ - public function shorten($path) - { - if ($this->applicationRootPath != "/") { - $path = str_replace($this->applicationRootPath, '…', $path); - } - - return $path; - } - - private function getDumper() - { - if (!$this->htmlDumper && class_exists('Symfony\Component\VarDumper\Cloner\VarCloner')) { - $this->htmlDumperOutput = new HtmlDumperOutput(); - // re-use the same var-dumper instance, so it won't re-render the global styles/scripts on each dump. - $this->htmlDumper = new HtmlDumper($this->htmlDumperOutput); - - $styles = [ - 'default' => 'color:#FFFFFF; line-height:normal; font:12px "Inconsolata", "Fira Mono", "Source Code Pro", Monaco, Consolas, "Lucida Console", monospace !important; word-wrap: break-word; white-space: pre-wrap; position:relative; z-index:99999; word-break: normal', - 'num' => 'color:#BCD42A', - 'const' => 'color: #4bb1b1;', - 'str' => 'color:#BCD42A', - 'note' => 'color:#ef7c61', - 'ref' => 'color:#A0A0A0', - 'public' => 'color:#FFFFFF', - 'protected' => 'color:#FFFFFF', - 'private' => 'color:#FFFFFF', - 'meta' => 'color:#FFFFFF', - 'key' => 'color:#BCD42A', - 'index' => 'color:#ef7c61', - ]; - $this->htmlDumper->setStyles($styles); - } - - return $this->htmlDumper; - } - - /** - * Format the given value into a human readable string. - * - * @param mixed $value - * @return string - */ - public function dump($value) - { - $dumper = $this->getDumper(); - - if ($dumper) { - // re-use the same DumpOutput instance, so it won't re-render the global styles/scripts on each dump. - // exclude verbose information (e.g. exception stack traces) - if (class_exists('Symfony\Component\VarDumper\Caster\Caster')) { - $cloneVar = $this->getCloner()->cloneVar($value, Caster::EXCLUDE_VERBOSE); - // Symfony VarDumper 2.6 Caster class dont exist. - } else { - $cloneVar = $this->getCloner()->cloneVar($value); - } - - $dumper->dump( - $cloneVar, - $this->htmlDumperOutput - ); - - $output = $this->htmlDumperOutput->getOutput(); - $this->htmlDumperOutput->clear(); - - return $output; - } - - return htmlspecialchars(print_r($value, true)); - } - - /** - * Format the args of the given Frame as a human readable html string - * - * @param Frame $frame - * @return string the rendered html - */ - public function dumpArgs(Frame $frame) - { - // we support frame args only when the optional dumper is available - if (!$this->getDumper()) { - return ''; - } - - $html = ''; - $numFrames = count($frame->getArgs()); - - if ($numFrames > 0) { - $html = '
    '; - foreach ($frame->getArgs() as $j => $frameArg) { - $html .= '
  1. '. $this->dump($frameArg) .'
  2. '; - } - $html .= '
'; - } - - return $html; - } - - /** - * Convert a string to a slug version of itself - * - * @param string $original - * @return string - */ - public function slug($original) - { - $slug = str_replace(" ", "-", $original); - $slug = preg_replace('/[^\w\d\-\_]/i', '', $slug); - return strtolower($slug); - } - - /** - * Given a template path, render it within its own scope. This - * method also accepts an array of additional variables to be - * passed to the template. - * - * @param string $template - * @param array $additionalVariables - */ - public function render($template, array $additionalVariables = null) - { - $variables = $this->getVariables(); - - // Pass the helper to the template: - $variables["tpl"] = $this; - - if ($additionalVariables !== null) { - $variables = array_replace($variables, $additionalVariables); - } - - call_user_func(function () { - extract(func_get_arg(1)); - require func_get_arg(0); - }, $template, $variables); - } - - /** - * Sets the variables to be passed to all templates rendered - * by this template helper. - * - * @param array $variables - */ - public function setVariables(array $variables) - { - $this->variables = $variables; - } - - /** - * Sets a single template variable, by its name: - * - * @param string $variableName - * @param mixed $variableValue - */ - public function setVariable($variableName, $variableValue) - { - $this->variables[$variableName] = $variableValue; - } - - /** - * Gets a single template variable, by its name, or - * $defaultValue if the variable does not exist - * - * @param string $variableName - * @param mixed $defaultValue - * @return mixed - */ - public function getVariable($variableName, $defaultValue = null) - { - return isset($this->variables[$variableName]) ? - $this->variables[$variableName] : $defaultValue; - } - - /** - * Unsets a single template variable, by its name - * - * @param string $variableName - */ - public function delVariable($variableName) - { - unset($this->variables[$variableName]); - } - - /** - * Returns all variables for this helper - * - * @return array - */ - public function getVariables() - { - return $this->variables; - } - - /** - * Set the cloner used for dumping variables. - * - * @param AbstractCloner $cloner - */ - public function setCloner($cloner) - { - $this->cloner = $cloner; - } - - /** - * Get the cloner used for dumping variables. - * - * @return AbstractCloner - */ - public function getCloner() - { - if (!$this->cloner) { - $this->cloner = new VarCloner(); - } - return $this->cloner; - } - - /** - * Set the application root path. - * - * @param string $applicationRootPath - */ - public function setApplicationRootPath($applicationRootPath) - { - $this->applicationRootPath = $applicationRootPath; - } - - /** - * Return the application root path. - * - * @return string - */ - public function getApplicationRootPath() - { - return $this->applicationRootPath; - } -} diff --git a/framework/vendor/filp/whoops/src/Whoops/Util/index.html b/framework/vendor/filp/whoops/src/Whoops/Util/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/Whoops/index.html b/framework/vendor/filp/whoops/src/Whoops/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/filp/whoops/src/index.html b/framework/vendor/filp/whoops/src/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/twig/twig/LICENSE b/framework/vendor/firebase/php-jwt/LICENSE similarity index 82% rename from framework/vendor/twig/twig/LICENSE rename to framework/vendor/firebase/php-jwt/LICENSE index d06ced2..cb0c49b 100644 --- a/framework/vendor/twig/twig/LICENSE +++ b/framework/vendor/firebase/php-jwt/LICENSE @@ -1,10 +1,9 @@ -Copyright (c) 2009-2019 by the Twig Team. +Copyright (c) 2011, Neuman Vong -Some rights reserved. +All rights reserved. Redistribution and use in source and binary forms, with or without -modification, are permitted provided that the following conditions are -met: +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. @@ -14,9 +13,9 @@ met: disclaimer in the documentation and/or other materials provided with the distribution. - * The names of the contributors may not be used to endorse or - promote products derived from this software without specific - prior written permission. + * Neither the name of Neuman Vong nor the names of other + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT diff --git a/framework/vendor/firebase/php-jwt/README.md b/framework/vendor/firebase/php-jwt/README.md new file mode 100644 index 0000000..b1a7a3a --- /dev/null +++ b/framework/vendor/firebase/php-jwt/README.md @@ -0,0 +1,200 @@ +[![Build Status](https://travis-ci.org/firebase/php-jwt.png?branch=master)](https://travis-ci.org/firebase/php-jwt) +[![Latest Stable Version](https://poser.pugx.org/firebase/php-jwt/v/stable)](https://packagist.org/packages/firebase/php-jwt) +[![Total Downloads](https://poser.pugx.org/firebase/php-jwt/downloads)](https://packagist.org/packages/firebase/php-jwt) +[![License](https://poser.pugx.org/firebase/php-jwt/license)](https://packagist.org/packages/firebase/php-jwt) + +PHP-JWT +======= +A simple library to encode and decode JSON Web Tokens (JWT) in PHP, conforming to [RFC 7519](https://tools.ietf.org/html/rfc7519). + +Installation +------------ + +Use composer to manage your dependencies and download PHP-JWT: + +```bash +composer require firebase/php-jwt +``` + +Example +------- +```php + "http://example.org", + "aud" => "http://example.com", + "iat" => 1356999524, + "nbf" => 1357000000 +); + +/** + * IMPORTANT: + * You must specify supported algorithms for your application. See + * https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40 + * for a list of spec-compliant algorithms. + */ +$jwt = JWT::encode($token, $key); +$decoded = JWT::decode($jwt, $key, array('HS256')); + +print_r($decoded); + +/* + NOTE: This will now be an object instead of an associative array. To get + an associative array, you will need to cast it as such: +*/ + +$decoded_array = (array) $decoded; + +/** + * You can add a leeway to account for when there is a clock skew times between + * the signing and verifying servers. It is recommended that this leeway should + * not be bigger than a few minutes. + * + * Source: http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html#nbfDef + */ +JWT::$leeway = 60; // $leeway in seconds +$decoded = JWT::decode($jwt, $key, array('HS256')); + +?> +``` +Example with RS256 (openssl) +---------------------------- +```php + "example.org", + "aud" => "example.com", + "iat" => 1356999524, + "nbf" => 1357000000 +); + +$jwt = JWT::encode($token, $privateKey, 'RS256'); +echo "Encode:\n" . print_r($jwt, true) . "\n"; + +$decoded = JWT::decode($jwt, $publicKey, array('RS256')); + +/* + NOTE: This will now be an object instead of an associative array. To get + an associative array, you will need to cast it as such: +*/ + +$decoded_array = (array) $decoded; +echo "Decode:\n" . print_r($decoded_array, true) . "\n"; +?> +``` + +Changelog +--------- + +#### 5.0.0 / 2017-06-26 +- Support RS384 and RS512. + See [#117](https://github.com/firebase/php-jwt/pull/117). Thanks [@joostfaassen](https://github.com/joostfaassen)! +- Add an example for RS256 openssl. + See [#125](https://github.com/firebase/php-jwt/pull/125). Thanks [@akeeman](https://github.com/akeeman)! +- Detect invalid Base64 encoding in signature. + See [#162](https://github.com/firebase/php-jwt/pull/162). Thanks [@psignoret](https://github.com/psignoret)! +- Update `JWT::verify` to handle OpenSSL errors. + See [#159](https://github.com/firebase/php-jwt/pull/159). Thanks [@bshaffer](https://github.com/bshaffer)! +- Add `array` type hinting to `decode` method + See [#101](https://github.com/firebase/php-jwt/pull/101). Thanks [@hywak](https://github.com/hywak)! +- Add all JSON error types. + See [#110](https://github.com/firebase/php-jwt/pull/110). Thanks [@gbalduzzi](https://github.com/gbalduzzi)! +- Bugfix 'kid' not in given key list. + See [#129](https://github.com/firebase/php-jwt/pull/129). Thanks [@stampycode](https://github.com/stampycode)! +- Miscellaneous cleanup, documentation and test fixes. + See [#107](https://github.com/firebase/php-jwt/pull/107), [#115](https://github.com/firebase/php-jwt/pull/115), + [#160](https://github.com/firebase/php-jwt/pull/160), [#161](https://github.com/firebase/php-jwt/pull/161), and + [#165](https://github.com/firebase/php-jwt/pull/165). Thanks [@akeeman](https://github.com/akeeman), + [@chinedufn](https://github.com/chinedufn), and [@bshaffer](https://github.com/bshaffer)! + +#### 4.0.0 / 2016-07-17 +- Add support for late static binding. See [#88](https://github.com/firebase/php-jwt/pull/88) for details. Thanks to [@chappy84](https://github.com/chappy84)! +- Use static `$timestamp` instead of `time()` to improve unit testing. See [#93](https://github.com/firebase/php-jwt/pull/93) for details. Thanks to [@josephmcdermott](https://github.com/josephmcdermott)! +- Fixes to exceptions classes. See [#81](https://github.com/firebase/php-jwt/pull/81) for details. Thanks to [@Maks3w](https://github.com/Maks3w)! +- Fixes to PHPDoc. See [#76](https://github.com/firebase/php-jwt/pull/76) for details. Thanks to [@akeeman](https://github.com/akeeman)! + +#### 3.0.0 / 2015-07-22 +- Minimum PHP version updated from `5.2.0` to `5.3.0`. +- Add `\Firebase\JWT` namespace. See +[#59](https://github.com/firebase/php-jwt/pull/59) for details. Thanks to +[@Dashron](https://github.com/Dashron)! +- Require a non-empty key to decode and verify a JWT. See +[#60](https://github.com/firebase/php-jwt/pull/60) for details. Thanks to +[@sjones608](https://github.com/sjones608)! +- Cleaner documentation blocks in the code. See +[#62](https://github.com/firebase/php-jwt/pull/62) for details. Thanks to +[@johanderuijter](https://github.com/johanderuijter)! + +#### 2.2.0 / 2015-06-22 +- Add support for adding custom, optional JWT headers to `JWT::encode()`. See +[#53](https://github.com/firebase/php-jwt/pull/53/files) for details. Thanks to +[@mcocaro](https://github.com/mcocaro)! + +#### 2.1.0 / 2015-05-20 +- Add support for adding a leeway to `JWT:decode()` that accounts for clock skew +between signing and verifying entities. Thanks to [@lcabral](https://github.com/lcabral)! +- Add support for passing an object implementing the `ArrayAccess` interface for +`$keys` argument in `JWT::decode()`. Thanks to [@aztech-dev](https://github.com/aztech-dev)! + +#### 2.0.0 / 2015-04-01 +- **Note**: It is strongly recommended that you update to > v2.0.0 to address + known security vulnerabilities in prior versions when both symmetric and + asymmetric keys are used together. +- Update signature for `JWT::decode(...)` to require an array of supported + algorithms to use when verifying token signatures. + + +Tests +----- +Run the tests using phpunit: + +```bash +$ pear install PHPUnit +$ phpunit --configuration phpunit.xml.dist +PHPUnit 3.7.10 by Sebastian Bergmann. +..... +Time: 0 seconds, Memory: 2.50Mb +OK (5 tests, 5 assertions) +``` + +New Lines in private keys +----- + +If your private key contains `\n` characters, be sure to wrap it in double quotes `""` +and not single quotes `''` in order to properly interpret the escaped characters. + +License +------- +[3-Clause BSD](http://opensource.org/licenses/BSD-3-Clause). diff --git a/framework/vendor/firebase/php-jwt/composer.json b/framework/vendor/firebase/php-jwt/composer.json new file mode 100644 index 0000000..b76ffd1 --- /dev/null +++ b/framework/vendor/firebase/php-jwt/composer.json @@ -0,0 +1,29 @@ +{ + "name": "firebase/php-jwt", + "description": "A simple library to encode and decode JSON Web Tokens (JWT) in PHP. Should conform to the current spec.", + "homepage": "https://github.com/firebase/php-jwt", + "authors": [ + { + "name": "Neuman Vong", + "email": "neuman+pear@twilio.com", + "role": "Developer" + }, + { + "name": "Anant Narayanan", + "email": "anant@php.net", + "role": "Developer" + } + ], + "license": "BSD-3-Clause", + "require": { + "php": ">=5.3.0" + }, + "autoload": { + "psr-4": { + "Firebase\\JWT\\": "src" + } + }, + "require-dev": { + "phpunit/phpunit": " 4.8.35" + } +} diff --git a/framework/vendor/firebase/php-jwt/src/BeforeValidException.php b/framework/vendor/firebase/php-jwt/src/BeforeValidException.php new file mode 100644 index 0000000..a6ee2f7 --- /dev/null +++ b/framework/vendor/firebase/php-jwt/src/BeforeValidException.php @@ -0,0 +1,7 @@ + + * @author Anant Narayanan + * @license http://opensource.org/licenses/BSD-3-Clause 3-clause BSD + * @link https://github.com/firebase/php-jwt + */ +class JWT +{ + + /** + * When checking nbf, iat or expiration times, + * we want to provide some extra leeway time to + * account for clock skew. + */ + public static $leeway = 0; + + /** + * Allow the current timestamp to be specified. + * Useful for fixing a value within unit testing. + * + * Will default to PHP time() value if null. + */ + public static $timestamp = null; + + public static $supported_algs = array( + 'HS256' => array('hash_hmac', 'SHA256'), + 'HS512' => array('hash_hmac', 'SHA512'), + 'HS384' => array('hash_hmac', 'SHA384'), + 'RS256' => array('openssl', 'SHA256'), + 'RS384' => array('openssl', 'SHA384'), + 'RS512' => array('openssl', 'SHA512'), + ); + + /** + * Decodes a JWT string into a PHP object. + * + * @param string $jwt The JWT + * @param string|array $key The key, or map of keys. + * If the algorithm used is asymmetric, this is the public key + * @param array $allowed_algs List of supported verification algorithms + * Supported algorithms are 'HS256', 'HS384', 'HS512' and 'RS256' + * + * @return object The JWT's payload as a PHP object + * + * @throws UnexpectedValueException Provided JWT was invalid + * @throws SignatureInvalidException Provided JWT was invalid because the signature verification failed + * @throws BeforeValidException Provided JWT is trying to be used before it's eligible as defined by 'nbf' + * @throws BeforeValidException Provided JWT is trying to be used before it's been created as defined by 'iat' + * @throws ExpiredException Provided JWT has since expired, as defined by the 'exp' claim + * + * @uses jsonDecode + * @uses urlsafeB64Decode + */ + public static function decode($jwt, $key, array $allowed_algs = array()) + { + $timestamp = is_null(static::$timestamp) ? time() : static::$timestamp; + + if (empty($key)) { + throw new InvalidArgumentException('Key may not be empty'); + } + $tks = explode('.', $jwt); + if (count($tks) != 3) { + throw new UnexpectedValueException('Wrong number of segments'); + } + list($headb64, $bodyb64, $cryptob64) = $tks; + if (null === ($header = static::jsonDecode(static::urlsafeB64Decode($headb64)))) { + throw new UnexpectedValueException('Invalid header encoding'); + } + if (null === $payload = static::jsonDecode(static::urlsafeB64Decode($bodyb64))) { + throw new UnexpectedValueException('Invalid claims encoding'); + } + if (false === ($sig = static::urlsafeB64Decode($cryptob64))) { + throw new UnexpectedValueException('Invalid signature encoding'); + } + if (empty($header->alg)) { + throw new UnexpectedValueException('Empty algorithm'); + } + if (empty(static::$supported_algs[$header->alg])) { + throw new UnexpectedValueException('Algorithm not supported'); + } + if (!in_array($header->alg, $allowed_algs)) { + throw new UnexpectedValueException('Algorithm not allowed'); + } + if (is_array($key) || $key instanceof \ArrayAccess) { + if (isset($header->kid)) { + if (!isset($key[$header->kid])) { + throw new UnexpectedValueException('"kid" invalid, unable to lookup correct key'); + } + $key = $key[$header->kid]; + } else { + throw new UnexpectedValueException('"kid" empty, unable to lookup correct key'); + } + } + + // Check the signature + if (!static::verify("$headb64.$bodyb64", $sig, $key, $header->alg)) { + throw new SignatureInvalidException('Signature verification failed'); + } + + // Check if the nbf if it is defined. This is the time that the + // token can actually be used. If it's not yet that time, abort. + if (isset($payload->nbf) && $payload->nbf > ($timestamp + static::$leeway)) { + throw new BeforeValidException( + 'Cannot handle token prior to ' . date(DateTime::ISO8601, $payload->nbf) + ); + } + + // Check that this token has been created before 'now'. This prevents + // using tokens that have been created for later use (and haven't + // correctly used the nbf claim). + if (isset($payload->iat) && $payload->iat > ($timestamp + static::$leeway)) { + throw new BeforeValidException( + 'Cannot handle token prior to ' . date(DateTime::ISO8601, $payload->iat) + ); + } + + // Check if this token has expired. + if (isset($payload->exp) && ($timestamp - static::$leeway) >= $payload->exp) { + throw new ExpiredException('Expired token'); + } + + return $payload; + } + + /** + * Converts and signs a PHP object or array into a JWT string. + * + * @param object|array $payload PHP object or array + * @param string $key The secret key. + * If the algorithm used is asymmetric, this is the private key + * @param string $alg The signing algorithm. + * Supported algorithms are 'HS256', 'HS384', 'HS512' and 'RS256' + * @param mixed $keyId + * @param array $head An array with header elements to attach + * + * @return string A signed JWT + * + * @uses jsonEncode + * @uses urlsafeB64Encode + */ + public static function encode($payload, $key, $alg = 'HS256', $keyId = null, $head = null) + { + $header = array('typ' => 'JWT', 'alg' => $alg); + if ($keyId !== null) { + $header['kid'] = $keyId; + } + if ( isset($head) && is_array($head) ) { + $header = array_merge($head, $header); + } + $segments = array(); + $segments[] = static::urlsafeB64Encode(static::jsonEncode($header)); + $segments[] = static::urlsafeB64Encode(static::jsonEncode($payload)); + $signing_input = implode('.', $segments); + + $signature = static::sign($signing_input, $key, $alg); + $segments[] = static::urlsafeB64Encode($signature); + + return implode('.', $segments); + } + + /** + * Sign a string with a given key and algorithm. + * + * @param string $msg The message to sign + * @param string|resource $key The secret key + * @param string $alg The signing algorithm. + * Supported algorithms are 'HS256', 'HS384', 'HS512' and 'RS256' + * + * @return string An encrypted message + * + * @throws DomainException Unsupported algorithm was specified + */ + public static function sign($msg, $key, $alg = 'HS256') + { + if (empty(static::$supported_algs[$alg])) { + throw new DomainException('Algorithm not supported'); + } + list($function, $algorithm) = static::$supported_algs[$alg]; + switch($function) { + case 'hash_hmac': + return hash_hmac($algorithm, $msg, $key, true); + case 'openssl': + $signature = ''; + $success = openssl_sign($msg, $signature, $key, $algorithm); + if (!$success) { + throw new DomainException("OpenSSL unable to sign data"); + } else { + return $signature; + } + } + } + + /** + * Verify a signature with the message, key and method. Not all methods + * are symmetric, so we must have a separate verify and sign method. + * + * @param string $msg The original message (header and body) + * @param string $signature The original signature + * @param string|resource $key For HS*, a string key works. for RS*, must be a resource of an openssl public key + * @param string $alg The algorithm + * + * @return bool + * + * @throws DomainException Invalid Algorithm or OpenSSL failure + */ + private static function verify($msg, $signature, $key, $alg) + { + if (empty(static::$supported_algs[$alg])) { + throw new DomainException('Algorithm not supported'); + } + + list($function, $algorithm) = static::$supported_algs[$alg]; + switch($function) { + case 'openssl': + $success = openssl_verify($msg, $signature, $key, $algorithm); + if ($success === 1) { + return true; + } elseif ($success === 0) { + return false; + } + // returns 1 on success, 0 on failure, -1 on error. + throw new DomainException( + 'OpenSSL error: ' . openssl_error_string() + ); + case 'hash_hmac': + default: + $hash = hash_hmac($algorithm, $msg, $key, true); + if (function_exists('hash_equals')) { + return hash_equals($signature, $hash); + } + $len = min(static::safeStrlen($signature), static::safeStrlen($hash)); + + $status = 0; + for ($i = 0; $i < $len; $i++) { + $status |= (ord($signature[$i]) ^ ord($hash[$i])); + } + $status |= (static::safeStrlen($signature) ^ static::safeStrlen($hash)); + + return ($status === 0); + } + } + + /** + * Decode a JSON string into a PHP object. + * + * @param string $input JSON string + * + * @return object Object representation of JSON string + * + * @throws DomainException Provided string was invalid JSON + */ + public static function jsonDecode($input) + { + if (version_compare(PHP_VERSION, '5.4.0', '>=') && !(defined('JSON_C_VERSION') && PHP_INT_SIZE > 4)) { + /** In PHP >=5.4.0, json_decode() accepts an options parameter, that allows you + * to specify that large ints (like Steam Transaction IDs) should be treated as + * strings, rather than the PHP default behaviour of converting them to floats. + */ + $obj = json_decode($input, false, 512, JSON_BIGINT_AS_STRING); + } else { + /** Not all servers will support that, however, so for older versions we must + * manually detect large ints in the JSON string and quote them (thus converting + *them to strings) before decoding, hence the preg_replace() call. + */ + $max_int_length = strlen((string) PHP_INT_MAX) - 1; + $json_without_bigints = preg_replace('/:\s*(-?\d{'.$max_int_length.',})/', ': "$1"', $input); + $obj = json_decode($json_without_bigints); + } + + if (function_exists('json_last_error') && $errno = json_last_error()) { + static::handleJsonError($errno); + } elseif ($obj === null && $input !== 'null') { + throw new DomainException('Null result with non-null input'); + } + return $obj; + } + + /** + * Encode a PHP object into a JSON string. + * + * @param object|array $input A PHP object or array + * + * @return string JSON representation of the PHP object or array + * + * @throws DomainException Provided object could not be encoded to valid JSON + */ + public static function jsonEncode($input) + { + $json = json_encode($input); + if (function_exists('json_last_error') && $errno = json_last_error()) { + static::handleJsonError($errno); + } elseif ($json === 'null' && $input !== null) { + throw new DomainException('Null result with non-null input'); + } + return $json; + } + + /** + * Decode a string with URL-safe Base64. + * + * @param string $input A Base64 encoded string + * + * @return string A decoded string + */ + public static function urlsafeB64Decode($input) + { + $remainder = strlen($input) % 4; + if ($remainder) { + $padlen = 4 - $remainder; + $input .= str_repeat('=', $padlen); + } + return base64_decode(strtr($input, '-_', '+/')); + } + + /** + * Encode a string with URL-safe Base64. + * + * @param string $input The string you want encoded + * + * @return string The base64 encode of what you passed in + */ + public static function urlsafeB64Encode($input) + { + return str_replace('=', '', strtr(base64_encode($input), '+/', '-_')); + } + + /** + * Helper method to create a JSON error. + * + * @param int $errno An error number from json_last_error() + * + * @return void + */ + private static function handleJsonError($errno) + { + $messages = array( + JSON_ERROR_DEPTH => 'Maximum stack depth exceeded', + JSON_ERROR_STATE_MISMATCH => 'Invalid or malformed JSON', + JSON_ERROR_CTRL_CHAR => 'Unexpected control character found', + JSON_ERROR_SYNTAX => 'Syntax error, malformed JSON', + JSON_ERROR_UTF8 => 'Malformed UTF-8 characters' //PHP >= 5.3.3 + ); + throw new DomainException( + isset($messages[$errno]) + ? $messages[$errno] + : 'Unknown JSON error: ' . $errno + ); + } + + /** + * Get the number of bytes in cryptographic strings. + * + * @param string + * + * @return int + */ + private static function safeStrlen($str) + { + if (function_exists('mb_strlen')) { + return mb_strlen($str, '8bit'); + } + return strlen($str); + } +} diff --git a/framework/vendor/firebase/php-jwt/src/SignatureInvalidException.php b/framework/vendor/firebase/php-jwt/src/SignatureInvalidException.php new file mode 100644 index 0000000..27332b2 --- /dev/null +++ b/framework/vendor/firebase/php-jwt/src/SignatureInvalidException.php @@ -0,0 +1,7 @@ +log(LogLevel::EMERGENCY, $message, $context); - } - - /** - * Action must be taken immediately. - * - * Example: Entire website down, database unavailable, etc. This should - * trigger the SMS alerts and wake you up. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function alert($message, array $context = array()) - { - $this->log(LogLevel::ALERT, $message, $context); - } - - /** - * Critical conditions. - * - * Example: Application component unavailable, unexpected exception. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function critical($message, array $context = array()) - { - $this->log(LogLevel::CRITICAL, $message, $context); - } - - /** - * Runtime errors that do not require immediate action but should typically - * be logged and monitored. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function error($message, array $context = array()) - { - $this->log(LogLevel::ERROR, $message, $context); - } - - /** - * Exceptional occurrences that are not errors. - * - * Example: Use of deprecated APIs, poor use of an API, undesirable things - * that are not necessarily wrong. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function warning($message, array $context = array()) - { - $this->log(LogLevel::WARNING, $message, $context); - } - - /** - * Normal but significant events. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function notice($message, array $context = array()) - { - $this->log(LogLevel::NOTICE, $message, $context); - } - - /** - * Interesting events. - * - * Example: User logs in, SQL logs. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function info($message, array $context = array()) - { - $this->log(LogLevel::INFO, $message, $context); - } - - /** - * Detailed debug information. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function debug($message, array $context = array()) - { - $this->log(LogLevel::DEBUG, $message, $context); - } -} diff --git a/framework/vendor/psr/log/Psr/Log/InvalidArgumentException.php b/framework/vendor/psr/log/Psr/Log/InvalidArgumentException.php deleted file mode 100644 index 67f852d..0000000 --- a/framework/vendor/psr/log/Psr/Log/InvalidArgumentException.php +++ /dev/null @@ -1,7 +0,0 @@ -logger = $logger; - } -} diff --git a/framework/vendor/psr/log/Psr/Log/LoggerInterface.php b/framework/vendor/psr/log/Psr/Log/LoggerInterface.php deleted file mode 100644 index 5ea7243..0000000 --- a/framework/vendor/psr/log/Psr/Log/LoggerInterface.php +++ /dev/null @@ -1,123 +0,0 @@ -log(LogLevel::EMERGENCY, $message, $context); - } - - /** - * Action must be taken immediately. - * - * Example: Entire website down, database unavailable, etc. This should - * trigger the SMS alerts and wake you up. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function alert($message, array $context = array()) - { - $this->log(LogLevel::ALERT, $message, $context); - } - - /** - * Critical conditions. - * - * Example: Application component unavailable, unexpected exception. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function critical($message, array $context = array()) - { - $this->log(LogLevel::CRITICAL, $message, $context); - } - - /** - * Runtime errors that do not require immediate action but should typically - * be logged and monitored. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function error($message, array $context = array()) - { - $this->log(LogLevel::ERROR, $message, $context); - } - - /** - * Exceptional occurrences that are not errors. - * - * Example: Use of deprecated APIs, poor use of an API, undesirable things - * that are not necessarily wrong. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function warning($message, array $context = array()) - { - $this->log(LogLevel::WARNING, $message, $context); - } - - /** - * Normal but significant events. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function notice($message, array $context = array()) - { - $this->log(LogLevel::NOTICE, $message, $context); - } - - /** - * Interesting events. - * - * Example: User logs in, SQL logs. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function info($message, array $context = array()) - { - $this->log(LogLevel::INFO, $message, $context); - } - - /** - * Detailed debug information. - * - * @param string $message - * @param array $context - * - * @return void - */ - public function debug($message, array $context = array()) - { - $this->log(LogLevel::DEBUG, $message, $context); - } - - /** - * Logs with an arbitrary level. - * - * @param mixed $level - * @param string $message - * @param array $context - * - * @return void - */ - abstract public function log($level, $message, array $context = array()); -} diff --git a/framework/vendor/psr/log/Psr/Log/NullLogger.php b/framework/vendor/psr/log/Psr/Log/NullLogger.php deleted file mode 100644 index d8cd682..0000000 --- a/framework/vendor/psr/log/Psr/Log/NullLogger.php +++ /dev/null @@ -1,28 +0,0 @@ -logger) { }` - * blocks. - */ -class NullLogger extends AbstractLogger -{ - /** - * Logs with an arbitrary level. - * - * @param mixed $level - * @param string $message - * @param array $context - * - * @return void - */ - public function log($level, $message, array $context = array()) - { - // noop - } -} diff --git a/framework/vendor/psr/log/Psr/Log/Test/LoggerInterfaceTest.php b/framework/vendor/psr/log/Psr/Log/Test/LoggerInterfaceTest.php deleted file mode 100644 index 4b861c3..0000000 --- a/framework/vendor/psr/log/Psr/Log/Test/LoggerInterfaceTest.php +++ /dev/null @@ -1,144 +0,0 @@ - ". - * - * Example ->error('Foo') would yield "error Foo". - * - * @return string[] - */ - abstract public function getLogs(); - - public function testImplements() - { - $this->assertInstanceOf('Psr\Log\LoggerInterface', $this->getLogger()); - } - - /** - * @dataProvider provideLevelsAndMessages - */ - public function testLogsAtAllLevels($level, $message) - { - $logger = $this->getLogger(); - $logger->{$level}($message, array('user' => 'Bob')); - $logger->log($level, $message, array('user' => 'Bob')); - - $expected = array( - $level.' message of level '.$level.' with context: Bob', - $level.' message of level '.$level.' with context: Bob', - ); - $this->assertEquals($expected, $this->getLogs()); - } - - public function provideLevelsAndMessages() - { - return array( - LogLevel::EMERGENCY => array(LogLevel::EMERGENCY, 'message of level emergency with context: {user}'), - LogLevel::ALERT => array(LogLevel::ALERT, 'message of level alert with context: {user}'), - LogLevel::CRITICAL => array(LogLevel::CRITICAL, 'message of level critical with context: {user}'), - LogLevel::ERROR => array(LogLevel::ERROR, 'message of level error with context: {user}'), - LogLevel::WARNING => array(LogLevel::WARNING, 'message of level warning with context: {user}'), - LogLevel::NOTICE => array(LogLevel::NOTICE, 'message of level notice with context: {user}'), - LogLevel::INFO => array(LogLevel::INFO, 'message of level info with context: {user}'), - LogLevel::DEBUG => array(LogLevel::DEBUG, 'message of level debug with context: {user}'), - ); - } - - /** - * @expectedException \Psr\Log\InvalidArgumentException - */ - public function testThrowsOnInvalidLevel() - { - $logger = $this->getLogger(); - $logger->log('invalid level', 'Foo'); - } - - public function testContextReplacement() - { - $logger = $this->getLogger(); - $logger->info('{Message {nothing} {user} {foo.bar} a}', array('user' => 'Bob', 'foo.bar' => 'Bar')); - - $expected = array('info {Message {nothing} Bob Bar a}'); - $this->assertEquals($expected, $this->getLogs()); - } - - public function testObjectCastToString() - { - if (method_exists($this, 'createPartialMock')) { - $dummy = $this->createPartialMock('Psr\Log\Test\DummyTest', array('__toString')); - } else { - $dummy = $this->getMock('Psr\Log\Test\DummyTest', array('__toString')); - } - $dummy->expects($this->once()) - ->method('__toString') - ->will($this->returnValue('DUMMY')); - - $this->getLogger()->warning($dummy); - - $expected = array('warning DUMMY'); - $this->assertEquals($expected, $this->getLogs()); - } - - public function testContextCanContainAnything() - { - $closed = fopen('php://memory', 'r'); - fclose($closed); - - $context = array( - 'bool' => true, - 'null' => null, - 'string' => 'Foo', - 'int' => 0, - 'float' => 0.5, - 'nested' => array('with object' => new DummyTest), - 'object' => new \DateTime, - 'resource' => fopen('php://memory', 'r'), - 'closed' => $closed, - ); - - $this->getLogger()->warning('Crazy context data', $context); - - $expected = array('warning Crazy context data'); - $this->assertEquals($expected, $this->getLogs()); - } - - public function testContextExceptionKeyCanBeExceptionOrOtherValues() - { - $logger = $this->getLogger(); - $logger->warning('Random message', array('exception' => 'oops')); - $logger->critical('Uncaught Exception!', array('exception' => new \LogicException('Fail'))); - - $expected = array( - 'warning Random message', - 'critical Uncaught Exception!' - ); - $this->assertEquals($expected, $this->getLogs()); - } -} - -class DummyTest -{ - public function __toString() - { - } -} diff --git a/framework/vendor/psr/log/Psr/Log/Test/TestLogger.php b/framework/vendor/psr/log/Psr/Log/Test/TestLogger.php deleted file mode 100644 index 0cdffe4..0000000 --- a/framework/vendor/psr/log/Psr/Log/Test/TestLogger.php +++ /dev/null @@ -1,146 +0,0 @@ - $level, - 'message' => $message, - 'context' => $context, - ]; - - $this->recordsByLevel[$record['level']][] = $record; - $this->records[] = $record; - } - - public function hasRecords($level) - { - return isset($this->recordsByLevel[$level]); - } - - public function hasRecord($record, $level) - { - if (is_string($record)) { - $record = ['message' => $record]; - } - return $this->hasRecordThatPasses(function ($rec) use ($record) { - if ($rec['message'] !== $record['message']) { - return false; - } - if (isset($record['context']) && $rec['context'] !== $record['context']) { - return false; - } - return true; - }, $level); - } - - public function hasRecordThatContains($message, $level) - { - return $this->hasRecordThatPasses(function ($rec) use ($message) { - return strpos($rec['message'], $message) !== false; - }, $level); - } - - public function hasRecordThatMatches($regex, $level) - { - return $this->hasRecordThatPasses(function ($rec) use ($regex) { - return preg_match($regex, $rec['message']) > 0; - }, $level); - } - - public function hasRecordThatPasses(callable $predicate, $level) - { - if (!isset($this->recordsByLevel[$level])) { - return false; - } - foreach ($this->recordsByLevel[$level] as $i => $rec) { - if (call_user_func($predicate, $rec, $i)) { - return true; - } - } - return false; - } - - public function __call($method, $args) - { - if (preg_match('/(.*)(Debug|Info|Notice|Warning|Error|Critical|Alert|Emergency)(.*)/', $method, $matches) > 0) { - $genericMethod = $matches[1] . ('Records' !== $matches[3] ? 'Record' : '') . $matches[3]; - $level = strtolower($matches[2]); - if (method_exists($this, $genericMethod)) { - $args[] = $level; - return call_user_func_array([$this, $genericMethod], $args); - } - } - throw new \BadMethodCallException('Call to undefined method ' . get_class($this) . '::' . $method . '()'); - } - - public function reset() - { - $this->records = []; - } -} diff --git a/framework/vendor/psr/log/Psr/Log/Test/index.html b/framework/vendor/psr/log/Psr/Log/Test/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/psr/log/Psr/Log/index.html b/framework/vendor/psr/log/Psr/Log/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/psr/log/Psr/index.html b/framework/vendor/psr/log/Psr/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/psr/log/README.md b/framework/vendor/psr/log/README.md deleted file mode 100644 index 5571a25..0000000 --- a/framework/vendor/psr/log/README.md +++ /dev/null @@ -1,52 +0,0 @@ -PSR Log -======= - -This repository holds all interfaces/classes/traits related to -[PSR-3](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md). - -Note that this is not a logger of its own. It is merely an interface that -describes a logger. See the specification for more details. - -Installation ------------- - -```bash -composer require psr/log -``` - -Usage ------ - -If you need a logger, you can use the interface like this: - -```php -logger = $logger; - } - - public function doSomething() - { - if ($this->logger) { - $this->logger->info('Doing work'); - } - - // do something useful - } -} -``` - -You can then pick one of the implementations of the interface to get a logger. - -If you want to implement the interface, you can require this package and -implement `Psr\Log\LoggerInterface` in your code. Please read the -[specification text](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md) -for details. diff --git a/framework/vendor/psr/log/composer.json b/framework/vendor/psr/log/composer.json deleted file mode 100644 index 87934d7..0000000 --- a/framework/vendor/psr/log/composer.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "name": "psr/log", - "description": "Common interface for logging libraries", - "keywords": ["psr", "psr-3", "log"], - "homepage": "https://github.com/php-fig/log", - "license": "MIT", - "authors": [ - { - "name": "PHP-FIG", - "homepage": "http://www.php-fig.org/" - } - ], - "require": { - "php": ">=5.3.0" - }, - "autoload": { - "psr-4": { - "Psr\\Log\\": "Psr/Log/" - } - }, - "extra": { - "branch-alias": { - "dev-master": "1.0.x-dev" - } - } -} diff --git a/framework/vendor/psr/log/index.html b/framework/vendor/psr/log/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/index.html b/framework/vendor/smarty/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/COPYING.lib b/framework/vendor/smarty/smarty/COPYING.lib deleted file mode 100644 index 02bbb60..0000000 --- a/framework/vendor/smarty/smarty/COPYING.lib +++ /dev/null @@ -1,165 +0,0 @@ - GNU LESSER GENERAL PUBLIC LICENSE - Version 3, 29 June 2007 - - Copyright (C) 2007 Free Software Foundation, Inc. - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - - - This version of the GNU Lesser General Public License incorporates -the terms and conditions of version 3 of the GNU General Public -License, supplemented by the additional permissions listed below. - - 0. Additional Definitions. - - As used herein, "this License" refers to version 3 of the GNU Lesser -General Public License, and the "GNU GPL" refers to version 3 of the GNU -General Public License. - - "The Library" refers to a covered work governed by this License, -other than an Application or a Combined Work as defined below. - - An "Application" is any work that makes use of an interface provided -by the Library, but which is not otherwise based on the Library. -Defining a subclass of a class defined by the Library is deemed a mode -of using an interface provided by the Library. - - A "Combined Work" is a work produced by combining or linking an -Application with the Library. The particular version of the Library -with which the Combined Work was made is also called the "Linked -Version". - - The "Minimal Corresponding Source" for a Combined Work means the -Corresponding Source for the Combined Work, excluding any source code -for portions of the Combined Work that, considered in isolation, are -based on the Application, and not on the Linked Version. - - The "Corresponding Application Code" for a Combined Work means the -object code and/or source code for the Application, including any data -and utility programs needed for reproducing the Combined Work from the -Application, but excluding the System Libraries of the Combined Work. - - 1. Exception to Section 3 of the GNU GPL. - - You may convey a covered work under sections 3 and 4 of this License -without being bound by section 3 of the GNU GPL. - - 2. Conveying Modified Versions. - - If you modify a copy of the Library, and, in your modifications, a -facility refers to a function or data to be supplied by an Application -that uses the facility (other than as an argument passed when the -facility is invoked), then you may convey a copy of the modified -version: - - a) under this License, provided that you make a good faith effort to - ensure that, in the event an Application does not supply the - function or data, the facility still operates, and performs - whatever part of its purpose remains meaningful, or - - b) under the GNU GPL, with none of the additional permissions of - this License applicable to that copy. - - 3. Object Code Incorporating Material from Library Header Files. - - The object code form of an Application may incorporate material from -a header file that is part of the Library. You may convey such object -code under terms of your choice, provided that, if the incorporated -material is not limited to numerical parameters, data structure -layouts and accessors, or small macros, inline functions and templates -(ten or fewer lines in length), you do both of the following: - - a) Give prominent notice with each copy of the object code that the - Library is used in it and that the Library and its use are - covered by this License. - - b) Accompany the object code with a copy of the GNU GPL and this license - document. - - 4. Combined Works. - - You may convey a Combined Work under terms of your choice that, -taken together, effectively do not restrict modification of the -portions of the Library contained in the Combined Work and reverse -engineering for debugging such modifications, if you also do each of -the following: - - a) Give prominent notice with each copy of the Combined Work that - the Library is used in it and that the Library and its use are - covered by this License. - - b) Accompany the Combined Work with a copy of the GNU GPL and this license - document. - - c) For a Combined Work that displays copyright notices during - execution, include the copyright notice for the Library among - these notices, as well as a reference directing the user to the - copies of the GNU GPL and this license document. - - d) Do one of the following: - - 0) Convey the Minimal Corresponding Source under the terms of this - License, and the Corresponding Application Code in a form - suitable for, and under terms that permit, the user to - recombine or relink the Application with a modified version of - the Linked Version to produce a modified Combined Work, in the - manner specified by section 6 of the GNU GPL for conveying - Corresponding Source. - - 1) Use a suitable shared library mechanism for linking with the - Library. A suitable mechanism is one that (a) uses at run time - a copy of the Library already present on the user's computer - system, and (b) will operate properly with a modified version - of the Library that is interface-compatible with the Linked - Version. - - e) Provide Installation Information, but only if you would otherwise - be required to provide such information under section 6 of the - GNU GPL, and only to the extent that such information is - necessary to install and execute a modified version of the - Combined Work produced by recombining or relinking the - Application with a modified version of the Linked Version. (If - you use option 4d0, the Installation Information must accompany - the Minimal Corresponding Source and Corresponding Application - Code. If you use option 4d1, you must provide the Installation - Information in the manner specified by section 6 of the GNU GPL - for conveying Corresponding Source.) - - 5. Combined Libraries. - - 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 that are not Applications and are not covered by this -License, and convey such a combined library under terms of your -choice, if you do both of the following: - - a) Accompany the combined library with a copy of the same work based - on the Library, uncombined with any other library facilities, - conveyed under the terms of this License. - - b) Give prominent notice with the combined library that part of it - is a work based on the Library, and explaining where to find the - accompanying uncombined form of the same work. - - 6. Revised Versions of the GNU Lesser General Public License. - - The Free Software Foundation may publish revised and/or new versions -of the GNU 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 as you received it specifies that a certain numbered version -of the GNU Lesser General Public License "or any later version" -applies to it, you have the option of following the terms and -conditions either of that published version or of any later version -published by the Free Software Foundation. If the Library as you -received it does not specify a version number of the GNU Lesser -General Public License, you may choose any version of the GNU Lesser -General Public License ever published by the Free Software Foundation. - - If the Library as you received it specifies that a proxy can decide -whether future versions of the GNU Lesser General Public License shall -apply, that proxy's public statement of acceptance of any version is -permanent authorization for you to choose that version for the -Library. \ No newline at end of file diff --git a/framework/vendor/smarty/smarty/INHERITANCE_RELEASE_NOTES.txt b/framework/vendor/smarty/smarty/INHERITANCE_RELEASE_NOTES.txt deleted file mode 100644 index 4a351fa..0000000 --- a/framework/vendor/smarty/smarty/INHERITANCE_RELEASE_NOTES.txt +++ /dev/null @@ -1,35 +0,0 @@ -In Smarty 3.1 template inheritance is a compile time process. All the extending of {block} tags -is done at compile time and the parent and child templates are compiled in a single compiled template. -{include} subtemplate could also {block} tags. Such subtemplate could not compiled by it's own because -it could be used in other context where the {block} extended with a different result. For that reasion -the compiled code of {include} subtemplates gets also merged in compiled inheritance template. - -Merging the code into a single compile template has some drawbacks. -1. You could not use variable file names in {include} Smarty would use the {include} of compilation time. -2. You could not use individual compile_id in {include} -3. Seperate caching of subtemplate was not possible -4. Any change of the template directory structure between calls was not necessarily seen. - -Starting with 3.1.15 some of the above conditions got checked and resulted in an exception. It turned out -that a couple of users did use some of above and now got exceptions. - -To resolve this starting with 3.1.16 there is a new configuration parameter $inheritance_merge_compiled_includes. -For most backward compatibility its default setting is true. -With this setting all {include} subtemplate will be merge into the compiled inheritance template, but the above cases -could be rejected by exception. - - -If $smarty->inheritance_merge_compiled_includes = false; {include} subtemplate will not be merged. -You must now manually merge all {include} subtemplate which do contain {block} tags. This is done by setting the "inline" option. -{include file='foo.bar' inline} - -1. In case of a variable file name like {include file=$foo inline} you must you the variable in a compile_id $smarty->compile_id = $foo; -2. If you use individual compile_id in {include file='foo.tpl' compile_id=$bar inline} it must be used in the - global compile_id as well $smarty->compile_id = $foo; -3. If call templates with different template_dir configurations and a parent could same named child template from different folders - you must make the folder name part of the compile_id. - - -In the upcomming major release Smarty 3.2 inheritance will no longer be a compile time process. -All restrictions will be then removed. - diff --git a/framework/vendor/smarty/smarty/README b/framework/vendor/smarty/smarty/README deleted file mode 100644 index 9304219..0000000 --- a/framework/vendor/smarty/smarty/README +++ /dev/null @@ -1,574 +0,0 @@ -Smarty 3.x - -Author: Monte Ohrt -Author: Uwe Tews - -AN INTRODUCTION TO SMARTY 3 - -NOTICE FOR 3.1 release: - -Please see the SMARTY_3.1_NOTES.txt file that comes with the distribution. - -NOTICE for 3.0.5 release: - -Smarty now follows the PHP error_reporting level by default. If PHP does not mask E_NOTICE and you try to access an unset template variable, you will now get an E_NOTICE warning. To revert to the old behavior: - -$smarty->error_reporting = E_ALL & ~E_NOTICE; - -NOTICE for 3.0 release: - -IMPORTANT: Some API adjustments have been made between the RC4 and 3.0 release. -We felt it is better to make these now instead of after a 3.0 release, then have to -immediately deprecate APIs in 3.1. Online documentation has been updated -to reflect these changes. Specifically: - ----- API CHANGES RC4 -> 3.0 ---- - -$smarty->register->* -$smarty->unregister->* -$smarty->utility->* -$samrty->cache->* - -Have all been changed to local method calls such as: - -$smarty->clearAllCache() -$smarty->registerFoo() -$smarty->unregisterFoo() -$smarty->testInstall() -etc. - -Registration of function, block, compiler, and modifier plugins have been -consolidated under two API calls: - -$smarty->registerPlugin(...) -$smarty->unregisterPlugin(...) - -Registration of pre, post, output and variable filters have been -consolidated under two API calls: - -$smarty->registerFilter(...) -$smarty->unregisterFilter(...) - -Please refer to the online documentation for all specific changes: - -http://www.smarty.net/documentation - ----- - -The Smarty 3 API has been refactored to a syntax geared -for consistency and modularity. The Smarty 2 API syntax is still supported, but -will throw a deprecation notice. You can disable the notices, but it is highly -recommended to adjust your syntax to Smarty 3, as the Smarty 2 syntax must run -through an extra rerouting wrapper. - -Basically, all Smarty methods now follow the "fooBarBaz" camel case syntax. Also, -all Smarty properties now have getters and setters. So for example, the property -$smarty->cache_dir can be set with $smarty->setCacheDir('foo/') and can be -retrieved with $smarty->getCacheDir(). - -Some of the Smarty 3 APIs have been revoked such as the "is*" methods that were -just duplicate functions of the now available "get*" methods. - -Here is a rundown of the Smarty 3 API: - -$smarty->fetch($template, $cache_id = null, $compile_id = null, $parent = null) -$smarty->display($template, $cache_id = null, $compile_id = null, $parent = null) -$smarty->isCached($template, $cache_id = null, $compile_id = null) -$smarty->createData($parent = null) -$smarty->createTemplate($template, $cache_id = null, $compile_id = null, $parent = null) -$smarty->enableSecurity() -$smarty->disableSecurity() -$smarty->setTemplateDir($template_dir) -$smarty->addTemplateDir($template_dir) -$smarty->templateExists($resource_name) -$smarty->loadPlugin($plugin_name, $check = true) -$smarty->loadFilter($type, $name) -$smarty->setExceptionHandler($handler) -$smarty->addPluginsDir($plugins_dir) -$smarty->getGlobal($varname = null) -$smarty->getRegisteredObject($name) -$smarty->getDebugTemplate() -$smarty->setDebugTemplate($tpl_name) -$smarty->assign($tpl_var, $value = null, $nocache = false) -$smarty->assignGlobal($varname, $value = null, $nocache = false) -$smarty->assignByRef($tpl_var, &$value, $nocache = false) -$smarty->append($tpl_var, $value = null, $merge = false, $nocache = false) -$smarty->appendByRef($tpl_var, &$value, $merge = false) -$smarty->clearAssign($tpl_var) -$smarty->clearAllAssign() -$smarty->configLoad($config_file, $sections = null) -$smarty->getVariable($variable, $_ptr = null, $search_parents = true, $error_enable = true) -$smarty->getConfigVariable($variable) -$smarty->getStreamVariable($variable) -$smarty->getConfigVars($varname = null) -$smarty->clearConfig($varname = null) -$smarty->getTemplateVars($varname = null, $_ptr = null, $search_parents = true) -$smarty->clearAllCache($exp_time = null, $type = null) -$smarty->clearCache($template_name, $cache_id = null, $compile_id = null, $exp_time = null, $type = null) - -$smarty->registerPlugin($type, $tag, $callback, $cacheable = true, $cache_attr = array()) - -$smarty->registerObject($object_name, $object_impl, $allowed = array(), $smarty_args = true, $block_methods = array()) - -$smarty->registerFilter($type, $function_name) -$smarty->registerResource($resource_type, $function_names) -$smarty->registerDefaultPluginHandler($function_name) -$smarty->registerDefaultTemplateHandler($function_name) - -$smarty->unregisterPlugin($type, $tag) -$smarty->unregisterObject($object_name) -$smarty->unregisterFilter($type, $function_name) -$smarty->unregisterResource($resource_type) - -$smarty->compileAllTemplates($extension = '.tpl', $force_compile = false, $time_limit = 0, $max_errors = null) -$smarty->clearCompiledTemplate($resource_name = null, $compile_id = null, $exp_time = null) -$smarty->testInstall() - -// then all the getters/setters, available for all properties. Here are a few: - -$caching = $smarty->getCaching(); // get $smarty->caching -$smarty->setCaching(true); // set $smarty->caching -$smarty->setDeprecationNotices(false); // set $smarty->deprecation_notices -$smarty->setCacheId($id); // set $smarty->cache_id -$debugging = $smarty->getDebugging(); // get $smarty->debugging - - -FILE STRUCTURE - -The Smarty 3 file structure is similar to Smarty 2: - -/libs/ - Smarty.class.php -/libs/sysplugins/ - internal.* -/libs/plugins/ - function.mailto.php - modifier.escape.php - ... - -A lot of Smarty 3 core functionality lies in the sysplugins directory; you do -not need to change any files here. The /libs/plugins/ folder is where Smarty -plugins are located. You can add your own here, or create a separate plugin -directory, just the same as Smarty 2. You will still need to create your own -/cache/, /templates/, /templates_c/, /configs/ folders. Be sure /cache/ and -/templates_c/ are writable. - -The typical way to use Smarty 3 should also look familiar: - -require('Smarty.class.php'); -$smarty = new Smarty; -$smarty->assign('foo','bar'); -$smarty->display('index.tpl'); - - -However, Smarty 3 works completely different on the inside. Smarty 3 is mostly -backward compatible with Smarty 2, except for the following items: - -*) Smarty 3 is PHP 5 only. It will not work with PHP 4. -*) The {php} tag is disabled by default. Enable with $smarty->allow_php_tag=true. -*) Delimiters surrounded by whitespace are no longer treated as Smarty tags. - Therefore, { foo } will not compile as a tag, you must use {foo}. This change - Makes Javascript/CSS easier to work with, eliminating the need for {literal}. - This can be disabled by setting $smarty->auto_literal = false; -*) The Smarty 3 API is a bit different. Many Smarty 2 API calls are deprecated - but still work. You will want to update your calls to Smarty 3 for maximum - efficiency. - - -There are many things that are new to Smarty 3. Here are the notable items: - -LEXER/PARSER -============ - -Smarty 3 now uses a lexing tokenizer for its parser/compiler. Basically, this -means Smarty has some syntax additions that make life easier such as in-template -math, shorter/intuitive function parameter options, infinite function recursion, -more accurate error handling, etc. - - -WHAT IS NEW IN SMARTY TEMPLATE SYNTAX -===================================== - -Smarty 3 allows expressions almost anywhere. Expressions can include PHP -functions as long as they are not disabled by the security policy, object -methods and properties, etc. The {math} plugin is no longer necessary but -is still supported for BC. - -Examples: -{$x+$y} will output the sum of x and y. -{$foo = strlen($bar)} function in assignment -{assign var=foo value= $x+$y} in attributes -{$foo = myfunct( ($x+$y)*3 )} as function parameter -{$foo[$x+3]} as array index - -Smarty tags can be used as values within other tags. -Example: {$foo={counter}+3} - -Smarty tags can also be used inside double quoted strings. -Example: {$foo="this is message {counter}"} - -You can define arrays within templates. -Examples: -{assign var=foo value=[1,2,3]} -{assign var=foo value=['y'=>'yellow','b'=>'blue']} -Arrays can be nested. -{assign var=foo value=[1,[9,8],3]} - -There is a new short syntax supported for assigning variables. -Example: {$foo=$bar+2} - -You can assign a value to a specific array element. If the variable exists but -is not an array, it is converted to an array before the new values are assigned. -Examples: -{$foo['bar']=1} -{$foo['bar']['blar']=1} - -You can append values to an array. If the variable exists but is not an array, -it is converted to an array before the new values are assigned. -Example: {$foo[]=1} - -You can use a PHP-like syntax for accessing array elements, as well as the -original "dot" notation. -Examples: -{$foo[1]} normal access -{$foo['bar']} -{$foo['bar'][1]} -{$foo[$x+$x]} index may contain any expression -{$foo[$bar[1]]} nested index -{$foo[section_name]} smarty section access, not array access! - -The original "dot" notation stays, and with improvements. -Examples: -{$foo.a.b.c} => $foo['a']['b']['c'] -{$foo.a.$b.c} => $foo['a'][$b]['c'] with variable index -{$foo.a.{$b+4}.c} => $foo['a'][$b+4]['c'] with expression as index -{$foo.a.{$b.c}} => $foo['a'][$b['c']] with nested index - -note that { and } are used to address ambiguties when nesting the dot syntax. - -Variable names themselves can be variable and contain expressions. -Examples: -$foo normal variable -$foo_{$bar} variable name containing other variable -$foo_{$x+$y} variable name containing expressions -$foo_{$bar}_buh_{$blar} variable name with multiple segments -{$foo_{$x}} will output the variable $foo_1 if $x has a value of 1. - -Object method chaining is implemented. -Example: {$object->method1($x)->method2($y)} - -{for} tag added for looping (replacement for {section} tag): -{for $x=0, $y=count($foo); $x<$y; $x++} .... {/for} -Any number of statements can be used separated by comma as the first -inital expression at {for}. - -{for $x = $start to $end step $step} ... {/for}is in the SVN now . -You can use also -{for $x = $start to $end} ... {/for} -In this case the step value will be automaticall 1 or -1 depending on the start and end values. -Instead of $start and $end you can use any valid expression. -Inside the loop the following special vars can be accessed: -$x@iteration = number of iteration -$x@total = total number of iterations -$x@first = true on first iteration -$x@last = true on last iteration - - -The Smarty 2 {section} syntax is still supported. - -New shorter {foreach} syntax to loop over an array. -Example: {foreach $myarray as $var}...{/foreach} - -Within the foreach loop, properties are access via: - -$var@key foreach $var array key -$var@iteration foreach current iteration count (1,2,3...) -$var@index foreach current index count (0,1,2...) -$var@total foreach $var array total -$var@first true on first iteration -$var@last true on last iteration - -The Smarty 2 {foreach} tag syntax is still supported. - -NOTE: {$bar[foo]} still indicates a variable inside of a {section} named foo. -If you want to access an array element with index foo, you must use quotes -such as {$bar['foo']}, or use the dot syntax {$bar.foo}. - -while block tag is now implemented: -{while $foo}...{/while} -{while $x lt 10}...{/while} - -Direct access to PHP functions: -Just as you can use PHP functions as modifiers directly, you can now access -PHP functions directly, provided they are permitted by security settings: -{time()} - -There is a new {function}...{/function} block tag to implement a template function. -This enables reuse of code sequences like a plugin function. It can call itself recursively. -Template function must be called with the new {call name=foo...} tag. - -Example: - -Template file: -{function name=menu level=0} -
    - {foreach $data as $entry} - {if is_array($entry)} -
  • {$entry@key}
  • - {call name=menu data=$entry level=$level+1} - {else} -
  • {$entry}
  • - {/if} - {/foreach} -
-{/function} - -{$menu = ['item1','item2','item3' => ['item3-1','item3-2','item3-3' => - ['item3-3-1','item3-3-2']],'item4']} - -{call name=menu data=$menu} - - -Generated output: - * item1 - * item2 - * item3 - o item3-1 - o item3-2 - o item3-3 - + item3-3-1 - + item3-3-2 - * item4 - -The function tag itself must have the "name" attribute. This name is the tag -name when calling the function. The function tag may have any number of -additional attributes. These will be default settings for local variables. - -New {nocache} block function: -{nocache}...{/nocache} will declare a section of the template to be non-cached -when template caching is enabled. - -New nocache attribute: -You can declare variable/function output as non-cached with the nocache attribute. -Examples: - -{$foo nocache=true} -{$foo nocache} /* same */ - -{foo bar="baz" nocache=true} -{foo bar="baz" nocache} /* same */ - -{time() nocache=true} -{time() nocache} /* same */ - -Or you can also assign the variable in your script as nocache: -$smarty->assign('foo',$something,true); // third param is nocache setting -{$foo} /* non-cached */ - -$smarty.current_dir returns the directory name of the current template. - -You can use strings directly as templates with the "string" resource type. -Examples: -$smarty->display('string:This is my template, {$foo}!'); // php -{include file="string:This is my template, {$foo}!"} // template - - - -VARIABLE SCOPE / VARIABLE STORAGE -================================= - -In Smarty 2, all assigned variables were stored within the Smarty object. -Therefore, all variables assigned in PHP were accessible by all subsequent -fetch and display template calls. - -In Smarty 3, we have the choice to assign variables to the main Smarty object, -to user-created data objects, and to user-created template objects. -These objects can be chained. The object at the end of a chain can access all -variables belonging to that template and all variables within the parent objects. -The Smarty object can only be the root of a chain, but a chain can be isolated -from the Smarty object. - -All known Smarty assignment interfaces will work on the data and template objects. - -Besides the above mentioned objects, there is also a special storage area for -global variables. - -A Smarty data object can be created as follows: -$data = $smarty->createData(); // create root data object -$data->assign('foo','bar'); // assign variables as usual -$data->config_load('my.conf'); // load config file - -$data= $smarty->createData($smarty); // create data object having a parent link to -the Smarty object - -$data2= $smarty->createData($data); // create data object having a parent link to -the $data data object - -A template object can be created by using the createTemplate method. It has the -same parameter assignments as the fetch() or display() method. -Function definition: -function createTemplate($template, $cache_id = null, $compile_id = null, $parent = null) - -The first parameter can be a template name, a smarty object or a data object. - -Examples: -$tpl = $smarty->createTemplate('mytpl.tpl'); // create template object not linked to any parent -$tpl->assign('foo','bar'); // directly assign variables -$tpl->config_load('my.conf'); // load config file - -$tpl = $smarty->createTemplate('mytpl.tpl',$smarty); // create template having a parent link to the Smarty object -$tpl = $smarty->createTemplate('mytpl.tpl',$data); // create template having a parent link to the $data object - -The standard fetch() and display() methods will implicitly create a template object. -If the $parent parameter is not specified in these method calls, the template object -is will link back to the Smarty object as it's parent. - -If a template is called by an {include...} tag from another template, the -subtemplate links back to the calling template as it's parent. - -All variables assigned locally or from a parent template are accessible. If the -template creates or modifies a variable by using the {assign var=foo...} or -{$foo=...} tags, these new values are only known locally (local scope). When the -template exits, none of the new variables or modifications can be seen in the -parent template(s). This is same behavior as in Smarty 2. - -With Smarty 3, we can assign variables with a scope attribute which allows the -availablility of these new variables or modifications globally (ie in the parent -templates.) - -Possible scopes are local, parent, root and global. -Examples: -{assign var=foo value='bar'} // no scope is specified, the default 'local' -{$foo='bar'} // same, local scope -{assign var=foo value='bar' scope='local'} // same, local scope - -{assign var=foo value='bar' scope='parent'} // Values will be available to the parent object -{$foo='bar' scope='parent'} // (normally the calling template) - -{assign var=foo value='bar' scope='root'} // Values will be exported up to the root object, so they can -{$foo='bar' scope='root'} // be seen from all templates using the same root. - -{assign var=foo value='bar' scope='global'} // Values will be exported to global variable storage, -{$foo='bar' scope='global'} // they are available to any and all templates. - - -The scope attribute can also be attached to the {include...} tag. In this case, -the specified scope will be the default scope for all assignments within the -included template. - - -PLUGINS -======= - -Smarty3 are following the same coding rules as in Smarty2. -The only difference is that the template object is passed as additional third parameter. - -smarty_plugintype_name (array $params, object $smarty, object $template) - -The Smarty 2 plugins are still compatible as long as they do not make use of specific Smarty2 internals. - - -TEMPLATE INHERITANCE: -===================== - -With template inheritance you can define blocks, which are areas that can be -overriden by child templates, so your templates could look like this: - -parent.tpl: - - - {block name='title'}My site name{/block} - - -

{block name='page-title'}Default page title{/block}

-
- {block name='content'} - Default content - {/block} -
- - - -child.tpl: -{extends file='parent.tpl'} -{block name='title'} -Child title -{/block} - -grandchild.tpl: -{extends file='child.tpl'} -{block name='title'}Home - {$smarty.block.parent}{/block} -{block name='page-title'}My home{/block} -{block name='content'} - {foreach $images as $img} - {$img.description} - {/foreach} -{/block} - -We redefined all the blocks here, however in the title block we used {$smarty.block.parent}, -which tells Smarty to insert the default content from the parent template in its place. -The content block was overriden to display the image files, and page-title has also be -overriden to display a completely different title. - -If we render grandchild.tpl we will get this: - - - Home - Child title - - -

My home

-
- image - image - image -
- - - -NOTE: In the child templates everything outside the {extends} or {block} tag sections -is ignored. - -The inheritance tree can be as big as you want (meaning you can extend a file that -extends another one that extends another one and so on..), but be aware that all files -have to be checked for modifications at runtime so the more inheritance the more overhead you add. - -Instead of defining the parent/child relationships with the {extends} tag in the child template you -can use the resource as follow: - -$smarty->display('extends:parent.tpl|child.tpl|grandchild.tpl'); - -Child {block} tags may optionally have a append or prepend attribute. In this case the parent block content -is appended or prepended to the child block content. - -{block name='title' append} My title {/block} - - -PHP STREAMS: -============ - -(see online documentation) - -VARIBLE FILTERS: -================ - -(see online documentation) - - -STATIC CLASS ACCESS AND NAMESPACE SUPPORT -========================================= - -You can register a class with optional namespace for the use in the template like: - -$smarty->register->templateClass('foo','name\name2\myclass'); - -In the template you can use it like this: -{foo::method()} etc. - - -======================= - -Please look through it and send any questions/suggestions/etc to the forums. - -http://www.phpinsider.com/smarty-forum/viewtopic.php?t=14168 - -Monte and Uwe diff --git a/framework/vendor/smarty/smarty/README.md b/framework/vendor/smarty/smarty/README.md deleted file mode 100644 index 5d1fc78..0000000 --- a/framework/vendor/smarty/smarty/README.md +++ /dev/null @@ -1,28 +0,0 @@ -#Smarty 3 template engine -##Distribution repository -Starting with Smarty 3.1.21 Composer has been configured to load the packages from github. - -**NOTE: Because of this change you must clear your local composer cache with the "composer clearcache" command** - -To get the latest stable version use - - "require": { - "smarty/smarty": "~3.1" - } - -in your composer.json file. - - To get the trunk version use - - "require": { - "smarty/smarty": "~3.1@dev" - } - -The "smarty/smarty" package will start at libs/.... subfolder. - -To retrieve the development and documentation folders add - - "require-dev": { - "smarty/smarty-dev": "~3.1@dev" - } - diff --git a/framework/vendor/smarty/smarty/SMARTY_2_BC_NOTES.txt b/framework/vendor/smarty/smarty/SMARTY_2_BC_NOTES.txt deleted file mode 100644 index 79a2cb1..0000000 --- a/framework/vendor/smarty/smarty/SMARTY_2_BC_NOTES.txt +++ /dev/null @@ -1,109 +0,0 @@ -= Known incompatibilities with Smarty 2 = - -== Syntax == - -Smarty 3 API has a new syntax. Much of the Smarty 2 syntax is supported -by a wrapper but deprecated. See the README that comes with Smarty 3 for more -information. - -The {$array|@mod} syntax has always been a bit confusing, where an "@" is required -to apply a modifier to an array instead of the individual elements. Normally you -always want the modifier to apply to the variable regardless of its type. In Smarty 3, -{$array|mod} and {$array|@mod} behave identical. It is safe to drop the "@" and the -modifier will still apply to the array. If you really want the modifier to apply to -each array element, you must loop the array in-template, or use a custom modifier that -supports array iteration. Most smarty functions already escape values where necessary -such as {html_options} - -== PHP Version == -Smarty 3 is PHP 5 only. It will not work with PHP 4. - -== {php} Tag == -The {php} tag is disabled by default. The use of {php} tags is -deprecated. It can be enabled with $smarty->allow_php_tag=true. - -But if you scatter PHP code which belongs together into several -{php} tags it may not work any longer. - -== Delimiters and whitespace == -Delimiters surrounded by whitespace are no longer treated as Smarty tags. -Therefore, { foo } will not compile as a tag, you must use {foo}. This change -Makes Javascript/CSS easier to work with, eliminating the need for {literal}. -This can be disabled by setting $smarty->auto_literal = false; - -== Unquoted Strings == -Smarty 2 was a bit more forgiving (and ambiguous) when it comes to unquoted strings -in parameters. Smarty3 is more restrictive. You can still pass strings without quotes -so long as they contain no special characters. (anything outside of A-Za-z0-9_) - -For example filename strings must be quoted - -{include file='path/foo.tpl'} - - -== Extending the Smarty class == -Smarty 3 makes use of the __construct method for initialization. If you are extending -the Smarty class, its constructor is not called implicitly if the your child class defines -its own constructor. In order to run Smarty's constructor, a call to parent::__construct() -within your child constructor is required. - - -class MySmarty extends Smarty { - function __construct() { - parent::__construct(); - - // your initialization code goes here - - } -} - - -== Autoloader == -Smarty 3 does register its own autoloader with spl_autoload_register. If your code has -an existing __autoload function then this function must be explicitly registered on -the __autoload stack. See http://us3.php.net/manual/en/function.spl-autoload-register.php -for further details. - -== Plugin Filenames == -Smarty 3 optionally supports the PHP spl_autoloader. The autoloader requires filenames -to be lower case. Because of this, Smarty plugin file names must also be lowercase. -In Smarty 2, mixed case file names did work. - -== Scope of Special Smarty Variables == -In Smarty 2 the special Smarty variables $smarty.section... and $smarty.foreach... -had global scope. If you had loops with the same name in subtemplates you could accidentally -overwrite values of parent template. - -In Smarty 3 these special Smarty variable have only local scope in the template which -is defining the loop. If you need their value in a subtemplate you have to pass them -as parameter. - -{include file='path/foo.tpl' index=$smarty.section.foo.index} - - -== SMARTY_RESOURCE_CHAR_SET == -Smarty 3 sets the constant SMARTY_RESOURCE_CHAR_SET to utf-8 as default template charset. -This is now used also on modifiers like escape as default charset. If your templates use -other charsets make sure that you define the constant accordingly. Otherwise you may not -get any output. - -== newline at {if} tags == -A \n was added to the compiled code of the {if},{else},{elseif},{/if} tags to get output of newlines as expected by the template source. -If one of the {if} tags is at the line end you will now get a newline in the HTML output. - -== trigger_error() == -The API function trigger_error() has been removed because it did just map to PHP trigger_error. -However it's still included in the Smarty2 API wrapper. - -== Smarty constants == -The constants -SMARTY_PHP_PASSTHRU -SMARTY_PHP_QUOTE -SMARTY_PHP_REMOVE -SMARTY_PHP_ALLOW -have been replaced with class constants -Smarty::PHP_PASSTHRU -Smarty::PHP_QUOTE -Smarty::PHP_REMOVE -Smarty::PHP_ALLOW - diff --git a/framework/vendor/smarty/smarty/SMARTY_3.0_BC_NOTES.txt b/framework/vendor/smarty/smarty/SMARTY_3.0_BC_NOTES.txt deleted file mode 100644 index fd8b540..0000000 --- a/framework/vendor/smarty/smarty/SMARTY_3.0_BC_NOTES.txt +++ /dev/null @@ -1,24 +0,0 @@ -== Smarty2 backward compatibility == -All Smarty2 specific API functions and deprecated functionallity has been moved -to the SmartyBC class. - -== {php} Tag == -The {php} tag is no longer available in the standard Smarty calls. -The use of {php} tags is deprecated and only available in the SmartyBC class. - -== {include_php} Tag == -The {include_php} tag is no longer available in the standard Smarty calls. -The use of {include_php} tags is deprecated and only available in the SmartyBC class. - -== php template resource == -The support of the php template resource is removed. - -== $cache_dir, $compile_dir, $config_dir, $template_dir access == -The mentioned properties can't be accessed directly any longer. You must use -corresponding getter/setters like addConfigDir(), setConfigDir(), getConfigDir() - -== obsolete Smarty class properties == -The following no longer used properties are removed: -$allow_php_tag -$allow_php_template -$deprecation_notices \ No newline at end of file diff --git a/framework/vendor/smarty/smarty/SMARTY_3.1_NOTES.txt b/framework/vendor/smarty/smarty/SMARTY_3.1_NOTES.txt deleted file mode 100644 index 57709f0..0000000 --- a/framework/vendor/smarty/smarty/SMARTY_3.1_NOTES.txt +++ /dev/null @@ -1,306 +0,0 @@ -Smarty 3.1 Notes -================ - -Smarty 3.1 is a departure from 2.0 compatibility. Most notably, all -backward compatibility has been moved to a separate class file named -SmartyBC.class.php. If you require compatibility with 2.0, you will -need to use this class. - -Some differences from 3.0 are also present. 3.1 begins the journey of -requiring setters/getters for property access. So far this is only -implemented on the five directory properties: template_dir, -plugins_dir, configs_dir, compile_dir and cache_dir. These properties -are now protected, it is required to use the setters/getters instead. -That said, direct property access will still work, however slightly -slower since they will now fall through __set() and __get() and in -turn passed through the setter/getter methods. 3.2 will exhibit a full -list of setter/getter methods for all (currently) public properties, -so code-completion in your IDE will work as expected. - -There is absolutely no PHP allowed in templates any more. All -deprecated features of Smarty 2.0 are gone. Again, use the SmartyBC -class if you need any backward compatibility. - -Internal Changes - - Full UTF-8 Compatibility - -The plugins shipped with Smarty 3.1 have been rewritten to fully -support UTF-8 strings if Multibyte String is available. Without -MBString UTF-8 cannot be handled properly. For those rare cases where -templates themselves have to juggle encodings, the new modifiers -to_charset and from_charset may come in handy. - - Plugin API and Performance - -All Plugins (modifiers, functions, blocks, resources, -default_template_handlers, etc) are now receiving the -Smarty_Internal_Template instance, where they were supplied with the -Smarty instance in Smarty 3.0. *. As The Smarty_Internal_Template -mimics the behavior of Smarty, this API simplification should not -require any changes to custom plugins. - -The plugins shipped with Smarty 3.1 have been rewritten for better -performance. Most notably {html_select_date} and {html_select_time} -have been improved vastly. Performance aside, plugins have also been -reviewed and generalized in their API. {html_select_date} and -{html_select_time} now share almost all available options. - -The escape modifier now knows the $double_encode option, which will -prevent entities from being encoded again. - -The capitalize modifier now know the $lc_rest option, which makes sure -all letters following a captial letter are lower-cased. - -The count_sentences modifier now accepts (.?!) as -legitimate endings of a sentence - previously only (.) was -accepted - -The new unescape modifier is there to reverse the effects of the -escape modifier. This applies to the escape formats html, htmlall and -entity. - - default_template_handler_func - -The invocation of $smarty->$default_template_handler_func had to be -altered. Instead of a Smarty_Internal_Template, the fifth argument is -now provided with the Smarty instance. New footprint: - - -/** - * Default Template Handler - * - * called when Smarty's file: resource is unable to load a requested file - * - * @param string $type resource type (e.g. "file", "string", "eval", "resource") - * @param string $name resource name (e.g. "foo/bar.tpl") - * @param string &$content template's content - * @param integer &$modified template's modification time - * @param Smarty $smarty Smarty instance - * @return string|boolean path to file or boolean true if $content and $modified - * have been filled, boolean false if no default template - * could be loaded - */ -function default_template_handler_func($type, $name, &$content, &$modified, Smarty $smarty) { - if (false) { - // return corrected filepath - return "/tmp/some/foobar.tpl"; - } elseif (false) { - // return a template directly - $content = "the template source"; - $modified = time(); - return true; - } else { - // tell smarty that we failed - return false; - } -} - - Stuff done to the compiler - -Many performance improvements have happened internally. One notable -improvement is that all compiled templates are now handled as PHP -functions. This speeds up repeated templates tremendously, as each one -calls an (in-memory) PHP function instead of performing another file -include/scan. - -New Features - - Template syntax - - {block}..{/block} - -The {block} tag has a new hide option flag. It does suppress the block -content if no corresponding child block exists. -EXAMPLE: -parent.tpl -{block name=body hide} child content "{$smarty.block.child}" was -inserted {block} -In the above example the whole block will be suppressed if no child -block "body" is existing. - - {setfilter}..{/setfilter} - -The new {setfilter} block tag allows the definition of filters which -run on variable output. -SYNTAX: -{setfilter filter1|filter2|filter3....} -Smarty3 will lookup up matching filters in the following search order: -1. varibale filter plugin in plugins_dir. -2. a valid modifier. A modifier specification will also accept -additional parameter like filter2:'foo' -3. a PHP function -{/setfilter} will turn previous filter setting off again. -{setfilter} tags can be nested. -EXAMPLE: -{setfilter filter1} - {$foo} - {setfilter filter2} - {$bar} - {/setfilter} - {$buh} -{/setfilter} -{$blar} -In the above example filter1 will run on the output of $foo, filter2 -on $bar, filter1 again on $buh and no filter on $blar. -NOTES: -- {$foo nofilter} will suppress the filters -- These filters will run in addition to filters defined by -registerFilter('variable',...), autoLoadFilter('variable',...) and -defined default modifier. -- {setfilter} will effect only the current template, not included -subtemplates. - - Resource API - -Smarty 3.1 features a new approach to resource management. The -Smarty_Resource API allows simple, yet powerful integration of custom -resources for templates and configuration files. It offers simple -functions for loading data from a custom resource (e.g. database) as -well as define new template types adhering to the special -non-compiling (e,g, plain php) and non-compile-caching (e.g. eval: -resource type) resources. - -See demo/plugins/resource.mysql.php for an example custom database -resource. - -Note that old-fashioned registration of callbacks for resource -management has been deprecated but is still possible with SmartyBC. - - CacheResource API - -In line with the Resource API, the CacheResource API offers a more -comfortable handling of output-cache data. With the -Smarty_CacheResource_Custom accessing databases is made simple. With -the introduction of Smarty_CacheResource_KeyValueStore the -implementation of resources like memcache or APC became a no-brainer; -simple hash-based storage systems are now supporting hierarchical -output-caches. - -See demo/plugins/cacheresource.mysql.php for an example custom -database CacheResource. -See demo/plugins/cacheresource.memcache.php for an example custom -memcache CacheResource using the KeyValueStore helper. - -Note that old-fashioned registration of $cache_handler is not possible -anymore. As the functionality had not been ported to Smarty 3.0.x -properly, it has been dropped from 3.1 completely. - -Locking facilities have been implemented to avoid concurrent cache -generation. Enable cache locking by setting -$smarty->cache_locking = true; - - Relative Paths in Templates (File-Resource) - -As of Smarty 3.1 {include file="../foo.tpl"} and {include -file="./foo.tpl"} will resolve relative to the template they're in. -Relative paths are available with {include file="..."} and -{extends file="..."}. As $smarty->fetch('../foo.tpl') and -$smarty->fetch('./foo.tpl') cannot be relative to a template, an -exception is thrown. - - Addressing a specific $template_dir - -Smarty 3.1 introduces the $template_dir index notation. -$smarty->fetch('[foo]bar.tpl') and {include file="[foo]bar.tpl"} -require the template bar.tpl to be loaded from $template_dir['foo']; -Smarty::setTemplateDir() and Smarty::addTemplateDir() offer ways to -define indexes along with the actual directories. - - Mixing Resources in extends-Resource - -Taking the php extends: template resource one step further, it is now -possible to mix resources within an extends: call like -$smarty->fetch("extends:file:foo.tpl|db:bar.tpl"); - -To make eval: and string: resources available to the inheritance -chain, eval:base64:TPL_STRING and eval:urlencode:TPL_STRING have been -introduced. Supplying the base64 or urlencode flags will trigger -decoding the TPL_STRING in with either base64_decode() or urldecode(). - - extends-Resource in template inheritance - -Template based inheritance may now inherit from php's extends: -resource like {extends file="extends:foo.tpl|db:bar.tpl"}. - - New Smarty property escape_html - -$smarty->escape_html = true will autoescape all template variable -output by calling htmlspecialchars({$output}, ENT_QUOTES, -SMARTY_RESOURCE_CHAR_SET). -NOTE: -This is a compile time option. If you change the setting you must make -sure that the templates get recompiled. - - New option at Smarty property compile_check - -The automatic recompilation of modified templates can now be -controlled by the following settings: -$smarty->compile_check = COMPILECHECK_OFF (false) - template files -will not be checked -$smarty->compile_check = COMPILECHECK_ON (true) - template files will -always be checked -$smarty->compile_check = COMPILECHECK_CACHEMISS - template files will -be checked if caching is enabled and there is no existing cache file -or it has expired - - Automatic recompilation on Smarty version change - -Templates will now be automatically recompiled on Smarty version -changes to avoide incompatibillities in the compiled code. Compiled -template checked against the current setting of the SMARTY_VERSION -constant. - - default_config_handler_func() - -Analogous to the default_template_handler_func() -default_config_handler_func() has been introduced. - - default_plugin_handler_func() - -An optional default_plugin_handler_func() can be defined which gets called -by the compiler on tags which can't be resolved internally or by plugins. -The default_plugin_handler() can map tags to plugins on the fly. - -New getters/setters - -The following setters/getters will be part of the official -documentation, and will be strongly recommended. Direct property -access will still work for the foreseeable future... it will be -transparently routed through the setters/getters, and consequently a -bit slower. - -array|string getTemplateDir( [string $index] ) -replaces $smarty->template_dir; and $smarty->template_dir[$index]; -Smarty setTemplateDir( array|string $path ) -replaces $smarty->template_dir = "foo"; and $smarty->template_dir = -array("foo", "bar"); -Smarty addTemplateDir( array|string $path, [string $index]) -replaces $smarty->template_dir[] = "bar"; and -$smarty->template_dir[$index] = "bar"; - -array|string getConfigDir( [string $index] ) -replaces $smarty->config_dir; and $smarty->config_dir[$index]; -Smarty setConfigDir( array|string $path ) -replaces $smarty->config_dir = "foo"; and $smarty->config_dir = -array("foo", "bar"); -Smarty addConfigDir( array|string $path, [string $index]) -replaces $smarty->config_dir[] = "bar"; and -$smarty->config_dir[$index] = "bar"; - -array getPluginsDir() -replaces $smarty->plugins_dir; -Smarty setPluginsDir( array|string $path ) -replaces $smarty->plugins_dir = "foo"; -Smarty addPluginsDir( array|string $path ) -replaces $smarty->plugins_dir[] = "bar"; - -string getCompileDir() -replaces $smarty->compile_dir; -Smarty setCompileDir( string $path ) -replaces $smarty->compile_dir = "foo"; - -string getCacheDir() -replaces $smarty->cache_dir; -Smarty setCacheDir( string $path ) -replaces $smarty->cache_dir; diff --git a/framework/vendor/smarty/smarty/change_log.txt b/framework/vendor/smarty/smarty/change_log.txt deleted file mode 100644 index 253c313..0000000 --- a/framework/vendor/smarty/smarty/change_log.txt +++ /dev/null @@ -1,2372 +0,0 @@ - - ===== 3.1.20-dev ===== (xx.xx.2014) - ===== 3.1.19 ===== (30.06.2014) - 20.06.2014 - - bugfix template variables could not be passed as paramter in {include} when the include was in a {nocache} section (topic 25131) - - 17.06.2014 - - bugfix large template text of some charsets could cause parsing errors (topic 24630) - - 08.06.2014 - - bugfix registered objects did not work after spelling fixes of 06.06.2014 - - bugfix {block} tags within {literal} .. {/literal} got not displayed correctly (topic 25024) - - bugfix UNC WINDOWS PATH like "\\psf\path\to\dir" did not work as template directory (Issue 192) - - bugfix {html_image} security check did fail on files relative to basedir (Issue 191) - - 06.06.2014 - - fixed PHPUnit outputFilterTrimWhitespaceTests.php assertion of test result - - fixed spelling, PHPDoc , minor errors, code cleanup - - 02.06.2014 - - using multiple cwd with relative template dirs could result in identical compiled file names. (issue 194 and topic 25099) - - 19.04.2014 - - bugfix calling createTemplate(template, data) with empty data array caused notice of array to string conversion (Issue 189) - - bugfix clearCompiledTemplate() did not delete files on WINDOWS when a compile_id was specified - - 18.04.2014 - - revert bugfix of 5.4.2014 because %-e date format is not supported on all operating systems - - ===== 3.1.18 ===== (07.04.2014) - 06.04.2014 - - bugfix template inheritance fail when using custom resource after patch of 8.3.2014 (Issue 187) - - bugfix update of composer file (Issue 168 and 184) - - 05.04.2014 - - bugfix default date format leads to extra spaces when displaying dates with single digit days (Issue 165) - - 26.03.2014 - - bugfix Smart_Resource_Custom should not lowercase the resource name (Issue 183) - - 24.03.2014 - - bugfix using a {foreach} property like @iteration could fail when used in inheritance parent templates (Issue 182) - - 20.03.2014 - - bugfix $smarty->auto_literal and mbsting.func_overload 2, 6 or 7 did fail (forum topic 24899) - - 18.03.2014 - - revert change of 17.03.2014 - -17.03.2014 - - bugfix $smarty->auto_literal and mbsting.func_overload 2, 6 or 7 did fail (forum topic 24899) - - 15.03.2014 - - bugfix Smarty_CacheResource_Keyvaluestore did use different keys on read/writes and clearCache() calls (Issue 169) - - 13.03.2014 - - bugfix clearXxx() change of 27.1.2014 did not work when specifing cache_id or compile_id (forum topic 24868 and 24867) - - ===== 3.1.17 ===== - 08.03.2014 - - bugfix relative file path {include} within {block} of child templates did throw exception on first call (Issue 177) - - 17.02.2014 - - bugfix Smarty failed when executing PHP on HHVM (Hip Hop 2.4) because uniqid('',true) does return string with ',' (forum topic 20343) - - 16.02.2014 - - bugfix a '//' or '\\' in template_dir path could produce wrong path on relative filepath in {include} (Issue 175) - - 05.02.2014 - - bugfix shared.literal_compiler_param.php did throw an exception when literal did contain a '-' (smarty-developers group) - - 27.01.2014 - - bugfix $smarty->debugging = true; did show the variable of the $smarty object not the variables used in display() call (forum topic 24764) - - bugfix clearCompiledTemplate(), clearAll() and clear() should use realpath to avoid possible exception from RecursiveDirectoryIterator (Issue 171) - - 26.01.2014 - - bugfix undo block nesting checks for {nocache} for reasons like forum topic 23280 (forum topic 24762) - - 18.01.2014 - - bugfix the compiler did fail when using template inheritance and recursive {include} (smarty-developers group) - - 11.01.2014 - - bugfix "* }" (spaces before right delimiter) was interpreted by mistake as comment end tag (Issue 170) - - internals content cache should be clear when updating cache file - - 08.01.2014 - - bugfix Smarty_CacheResource_Custom did not handle template resource type specifications on clearCache() calls (Issue 169) - - bugfix SmartyBC.class.php should use require_once to load Smarty.class.php (forum topic 24683) - - ===== 3.1.16 ===== - 15.12.2013 - - bugfix {include} with {block} tag handling (forum topic 24599, 24594, 24682) (Issue 161) - Read 3.1.16_RELEASE_NOTES for more details - - enhancement additional debug output at $smarty->_parserdebug = true; - - 07.11.2013 - - bugfix too restrictive handling of {include} within {block} tags. 3.1.15 did throw errors where 3.1.14 did not (forum topic 24599) - - bugfix compiler could fail if PHP mbstring.func_overload is enabled (Issue 164) - - 28.10.2013 - - bugfix variable resource name at custom resource plugin did not work within {block} tags (Issue 163) - - bugfix notice "Trying to get property of non-object" removed (Issue 163) - - bugfix correction of modifier capitalize fix from 3.10.2013 (issue 159) - - bugfix multiple {block}s with same name in parent did not work (forum topic 24631) - - 20.10.2013 - - bugfix a variable file name at {extends} tag did fail (forum topic 24618) - - 14.10.2013 - - bugfix yesterdays fix could result in an undefined variable - - 13.10.2013 - - bugfix variable names on {include} in template inheritance did unextepted error message (forum topic 24594) (Issue 161) -.- bugfix relative includes with same name like {include './foo.tpl'} from different folder failed (forum topic 24590)(Issue 161) - - 04.10.2013 - - bugfix variable file names at {extends} had been disbabled by mistake with the rewrite of - template inheritance of 24.08.2013 (forum topic 24585) - -03.10.2013 - - bugfix loops using modifier capitalize did eat up memory (issue 159) - - ===== Smarty 3.1.15 ===== -01.10.2013 - - use current delimiters in compiler error messages (issue 157) - - improvement on performance when using error handler and multiple template folders (issue 152) - -17.09.2013 - - improvement added patch for additional SmartyCompilerException properties for better access to scource information (forum topic 24559) - -16.09.2013 - - bugfix recompiled templates did not show on first request with zend opcache cache (forum topic 24320) - -13.09.2013 - - bugfix html_select_time defaulting error for the Meridian dropdown (forum topic 24549) - -09.09.2012 -- bugfix incorrect compiled code with array(object,method) callback at registered Variable Filter (forum topic 24542) - -27.08.2013 -- bugfix delimiter followed by linebreak did not work as auto literal after update from 24.08.2013 (forum topic 24518) - -24.08.2013 -- bugfix and enhancement - Because several recent problems with template inheritance the {block} tag compiler has been rewriten - - Error messages shown now the correct child template file and line number - - The compiler could fail on some larger UTF-8 text block (forum topic 24455) - - The {strip} tag can now be placed outside {block} tags in child templates (forum topic 24289) -- change SmartyException::$escape is now false by default -- change PHP traceback has been remove for SmartyException and SmartyCompilerException - -14.08.2013 -- bugfix compiled filepath of config file did not observe different config_dir (forum topic 24493) - -13.08.2013 -- bugfix the internal resource cache did not observe config_dir changes (forum topic 24493) - -12.08.2013 -- bugfix internal $tmpx variables must be unique over all inheritance templates (Issue 149) - -10.08.2013 -- bugfix a newline was eaten when a was passed by a Smarty variable and caching was enabled (forum topic 24482) - -29.07.2013 -- bugfix headers already send warning thrown when using 'SMARTY_DEBUG=on' from URL (Issue 148) - -27.07.2013 -- enhancement allow access to properties of registered opjects for Smarty2 BC (forum topic 24344) - -26.07.2013 -- bugfix template inheritance nesting problem (forum topic 24387) - -15.7.2013 -- update code generated by PSR-2 standards fixer which introduced PHP 5.4 incompatibilities of 14.7.2013 - -14.7.2013 -- bugfix increase of internal maximum parser stacksize to allow more complex tag code {forum topic 24426} -- update for PHP 5.4 compatibility -- reformat source to PSR-2 standard - -12.7.2013 -- bugfix Do not remove '//' from file path at normalization (Issue 142) - -2.7.2013 -- bugfix trimwhitespace would replace captured items in wrong order (forum topic 24387) - -===== Smarty-3.1.14 ===== -27.06.2013 -- bugfix removed PHP 5.5 deprecated preg_replace /e option in modifier capitalize (forum topic 24389) - -17.06.2013 -- fixed spelling in sources and documentation (from smarty-developers forum Veres Lajos) -- enhancement added constant SMARTY::CLEAR_EXPIRED for the change of 26.05.2013 (forum topic 24310) -- bugfix added smarty_security.php to composer.json (Issue 135) - -26.05.2013 -- enhancement an expire_time of -1 in clearCache() and clearAllCache() will delete outdated cache files - by their individual cache_lifetime used at creation (forum topic 24310) - -21.05.2013 -- bugfix modifier strip_tags:true was compiled into wrong code (Forum Topic 24287) -- bugfix /n after ?> in Smarty.class.php did start output buffering (Issue 138) - -25.04.2013 -- bugfix escape and wordrap modifier could be compiled into wrong code when used in {nocache}{/nocache} - section but caching is disabled (Forum Topic 24260) - -05.04.2013 -- bugfix post filter must not run when compiling inheritance child blocks (Forum Topic 24094) -- bugfix after the fix for Issue #130 compiler exceptions got double escaped (Forum Topic 24199) - -28.02.2013 -- bugfix nocache blocks could be lost when using CACHING_LIFETIME_SAVED (Issue #133) -- bugfix Compile ID gets nulled when compiling child blocks (Issue #134) - - -24.01.2013 -- bugfix wrong tag type in smarty_internal_templatecompilerbase.php could cause wrong plugin search order (Forum Topic 24028) - -===== Smarty-3.1.13 ===== -13.01.2013 -- enhancement allow to disable exception message escaping by SmartyException::$escape = false; (Issue #130) - -09.01.2013 -- bugfix compilation did fail when a prefilter did modify an {extends} tag c -- bugfix template inheritance could fail if nested {block} tags in childs did contain {$smarty.block.child} (Issue #127) -- bugfix template inheritance could fail if {block} tags in childs did have similar name as used plugins (Issue #128) -- added abstract method declaration doCompile() in Smarty_Internal_TemplateCompilerBase (Forum Topic 23969) - -06.01.2013 -- Allow '://' URL syntax in template names of stream resources (Issue #129) - -27.11.2012 -- bugfix wrong variable usage in smarty_internal_utility.php (Issue #125) - -26.11.2012 -- bugfix global variable assigned within template function are not seen after template function exit (Forum Topic 23800) - -24.11.2012 -- made SmartyBC loadable via composer (Issue #124) - -20.11.2012 -- bugfix assignGlobal() called from plugins did not work (Forum Topic 23771) - -13.11.2012 -- adding attribute "strict" to html_options, html_checkboxes, html_radios to only print disabled/readonly attributes if their values are true or "disabled"/"readonly" (Issue #120) - -01.11.2012 -- bugfix muteExcpetedErrors() would screw up for non-readable paths (Issue #118) - -===== Smarty-3.1.12 ===== -14.09.2012 -- bugfix template inheritance failed to compile with delimiters {/ and /} (Forum Topic 23008) - -11.09.2012 -- bugfix escape Smarty exception messages to avoid possible script execution - -10.09.2012 -- bugfix tag option flags and shorttag attributes did not work when rdel started with '=' (Forum Topic 22979) - -31.08.2012 -- bugfix resolving relative paths broke in some circumstances (Issue #114) - -22.08.2012 -- bugfix test MBString availability through mb_split, as it could've been compiled without regex support (--enable-mbregex). - Either we get MBstring's full package, or we pretend it's not there at all. - -21.08.2012 -- bugfix $auto_literal = false did not work with { block} tags in child templates - (problem was reintroduced after fix in 3.1.7)(Forum Topic 20581) - -17.08.2012 -- bugfix compiled code of nocache sections could contain wrong escaping (Forum Topic 22810) - -15.08.2012 -- bugfix template inheritance did produce wrong code if subtemplates with {block} was - included several times (from smarty-developers forum) - -14.08.2012 -- bugfix PHP5.2 compatibility compromised by SplFileInfo::getBasename() (Issue 110) - -01.08.2012 -- bugfix avoid PHP error on $smarty->configLoad(...) with invalid section specification (Forum Topic 22608) - -30.07.2012 --bugfix {assign} in a nocache section should not overwrite existing variable values - during compilation (issue 109) - -28.07.2012 -- bugfix array access of config variables did not work (Forum Topic 22527) - -19.07.2012 -- bugfix the default plugin handler did create wrong compiled code for static class methods - from external script files (issue 108) - -===== Smarty-3.1.11 ===== -30.06.2012 -- bugfix {block.. hide} did not work as nested child (Forum Topic 22216) - -25.06.2012 -- bugfix the default plugin handler did not allow static class methods for modifier (issue 85) - -24.06.2012 -- bugfix escape modifier support for PHP < 5.2.3 (Forum Topic 21176) - -11.06.2012 -- bugfix the patch for Topic 21856 did break tabs between tag attributes (Forum Topic 22124) - -===== Smarty-3.1.10 ===== -09.06.2012 -- bugfix the compiler did ignore registered compiler plugins for closing tags (Forum Topic 22094) -- bugfix the patch for Topic 21856 did break multiline tags (Forum Topic 22124) - -===== Smarty-3.1.9 ===== -07.06.2012 -- bugfix fetch() and display() with relative paths (Issue 104) -- bugfix treat "0000-00-00" as 0 in modifier.date_format (Issue 103) - -24.05.2012 -- bugfix Smarty_Internal_Write_File::writeFile() could cause race-conditions on linux systems (Issue 101) -- bugfix attribute parameter names of plugins may now contain also "-" and ":" (Forum Topic 21856) -- bugfix add compile_id to cache key of of source (Issue 97) - -22.05.2012 -- bugfix recursive {include} within {section} did fail (Smarty developer group) - -12.05.2012 -- bugfix {html_options} did not properly escape values (Issue 98) - -03.05.2012 -- bugfix make HTTP protocall version variable (issue 96) - -02.05.2012 -- bugfix {nocache}{block}{plugin}... did produce wrong compiled code when caching is disabled (Forum Topic 21572, issue 95) - -12.04.2012 -- bugfix Smarty did eat the linebreak after the closing tag (Issue 93) -- bugfix concurrent cache updates could create a warning (Forum Topic 21403) - -08.04.2012 -- bugfix "\\" was not escaped correctly when generating nocache code (Forum Topic 21364) - -30.03.2012 -- bugfix template inheritance did not throw exception when a parent template was deleted (issue 90) - -27.03.2012 -- bugfix prefilter did run multiple times on inline subtemplates compiled into several main templates (Forum Topic 21325) -- bugfix implement Smarty2's behaviour of variables assigned by reference in SmartyBC. {assign} will affect all references. - (issue 88) - -21.03.2012 -- bugfix compileAllTemplates() and compileAllConfig() did not return the number of compiled files (Forum Topic 21286) - -13.03.2012 -- correction of yesterdays bugfix (Forum Topic 21175 and 21182) - -12.03.2012 -- bugfix a double quoted string of "$foo" did not compile into PHP "$foo" (Forum Topic 21175) -- bugfix template inheritance did set $merge_compiled_includes globally true - -03.03.2012 -- optimization of compiling speed when same modifier was used several times - -02.03.2012 -- enhancement the default plugin handler can now also resolve undefined modifier (Smarty::PLUGIN_MODIFIER) - (Issue 85) - -===== Smarty-3.1.8 ===== -19.02.2012 -- bugfix {include} could result in a fatal error if used in appended or prepended nested {block} tags - (reported by mh and Issue 83) -- enhancement added Smarty special variable $smarty.template_object to return the current template object (Forum Topic 20289) - - -07.02.2012 -- bugfix increase entropy of internal function names in compiled and cached template files (Forum Topic 20996) -- enhancement cacheable parameter added to default plugin handler, same functionality as in registerPlugin (request by calguy1000) - -06.02.2012 -- improvement stream_resolve_include_path() added to Smarty_Internal_Get_Include_Path (Forum Topic 20980) -- bugfix fetch('extends:foo.tpl') always yielded $source->exists == true (Forum Topic 20980) -- added modifier unescape:"url", fix (Forum Topic 20980) -- improvement replaced some calls of preg_replace with str_replace (Issue 73) - -30.01.2012 -- bugfix Smarty_Security internal $_resource_dir cache wasn't properly propagated - -27.01.2012 -- bugfix Smarty did not a template name of "0" (Forum Topic 20895) - -20.01.2012 -- bugfix typo in Smarty_Internal_Get_IncludePath did cause runtime overhead (Issue 74) -- improvment remove unneeded assigments (Issue 75 and 76) -- fixed typo in template parser -- bugfix output filter must not run before writing cache when template does contain nocache code (Issue 71) - -02.01.2012 -- bugfix {block foo nocache} did not load plugins within child {block} in nocache mode (Forum Topic 20753) - -29.12.2011 -- bugfix enable more entropy in Smarty_Internal_Write_File for "more uniqueness" and Cygwin compatibility (Forum Topic 20724) -- bugfix embedded quotes in single quoted strings did not compile correctly in {nocache} sections (Forum Topic 20730) - -28.12.2011 -- bugfix Smarty's internal header code must be excluded from postfilters (issue 71) - -22.12.2011 -- bugfix the new lexer of 17.12.2011 did fail if mbstring.func_overload != 0 (issue 70) (Forum Topic 20680) -- bugfix template inheritace did fail if mbstring.func_overload != 0 (issue 70) (Forum Topic 20680) - -20.12.2011 -- bugfix template inheritance: {$smarty.block.child} in nested child {block} tags did not return - content after {$smarty.block.child} (Forum Topic 20564) - -===== Smarty-3.1.7 ===== -18.12.2011 -- bugfix strings ending with " in multiline strings of config files failed to compile (issue #67) -- added chaining to Smarty_Internal_Templatebase -- changed unloadFilter() to not return a boolean in favor of chaining and API conformity -- bugfix unregisterObject() raised notice when object to unregister did not exist -- changed internals to use Smarty::$_MBSTRING ($_CHARSET, $_DATE_FORMAT) for better unit testing -- added Smarty::$_UTF8_MODIFIER for proper PCRE charset handling (Forum Topic 20452) -- added Smarty_Security::isTrustedUri() and Smarty_Security::$trusted_uri to validate - remote resource calls through {fetch} and {html_image} (Forum Topic 20627) - -17.12.2011 -- improvement of compiling speed by new handling of plain text blocks in the lexer/parser (issue #68) - -16.12.2011 -- bugfix the source exits flag and timestamp was not setup when template was in php include path (issue #69) - -9.12.2011 -- bugfix {capture} tags around recursive {include} calls did throw exception (Forum Topic 20549) -- bugfix $auto_literal = false did not work with { block} tags in child templates (Forum Topic 20581) -- bugfix template inheritance: do not include code of {include} in overloaded {block} into compiled - parent template (Issue #66} -- bugfix template inheritance: {$smarty.block.child} in nested child {block} tags did not return expected - result (Forum Topic 20564) - -===== Smarty-3.1.6 ===== -30.11.2011 -- bugfix is_cache() for individual cached subtemplates with $smarty->caching = CACHING_OFF did produce - an exception (Forum Topic 20531) - -29.11.2011 -- bugfix added exception if the default plugin handler did return a not static callback (Forum Topic 20512) - -25.11.2011 -- bugfix {html_select_date} and {html_slecet_time} did not default to current time if "time" was not specified - since r4432 (issue 60) - -24.11.2011 -- bugfix a subtemplate later used as main template did use old variable values - -21.11.2011 -- bugfix cache file could include unneeded modifier plugins under certain condition - -18.11.2011 -- bugfix declare all directory properties private to map direct access to getter/setter also on extended Smarty class - -16.11.2011 -- bugfix Smarty_Resource::load() did not always return a proper resource handler (Forum Topic 20414) -- added escape argument to html_checkboxes and html_radios (Forum Topic 20425) - -===== Smarty-3.1.5 ===== -14.11.2011 -- bugfix allow space between function name and open bracket (forum topic 20375) - -09.11.2011 -- bugfix different behaviour of uniqid() on cygwin. See https://bugs.php.net/bug.php?id=34908 - (forum topic 20343) - -01.11.2011 -- bugfix {if} and {while} tags without condition did not throw a SmartyCompilerException (Issue #57) -- bugfix multiline strings in config files could fail on longer strings (reopened Issue #55) - -22.10.2011 -- bugfix smarty_mb_from_unicode() would not decode unicode-points properly -- bugfix use catch Exception instead UnexpectedValueException in - clearCompiledTemplate to be PHP 5.2 compatible - -21.10.2011 -- bugfix apostrophe in plugins_dir path name failed (forum topic 20199) -- improvement sha1() for array keys longer than 150 characters -- add Smarty::$allow_ambiguous_resources to activate unique resource handling (Forum Topic 20128) - -20.10.2011 -- @silenced unlink() in Smarty_Internal_Write_File since debuggers go haywire without it. -- bugfix Smarty::clearCompiledTemplate() threw an Exception if $cache_id was not present in $compile_dir when $use_sub_dirs = true. -- bugfix {html_select_date} and {html_select_time} did not properly handle empty time arguments (Forum Topic 20190) -- improvement removed unnecessary sha1() - -19.10.2011 -- revert PHP4 constructor message -- fixed PHP4 constructor message - -===== Smarty-3.1.4 ===== -19.10.2011 -- added exception when using PHP4 style constructor - -16.10.2011 -- bugfix testInstall() did not propery check cache_dir and compile_dir - -15.10.2011 -- bugfix Smarty_Resource and Smarty_CacheResource runtime caching (Forum Post 75264) - -14.10.2011 -- bugfix unique_resource did not properly apply to compiled resources (Forum Topic 20128) -- add locking to custom resources (Forum Post 75252) -- add Smarty_Internal_Template::clearCache() to accompany isCached() fetch() etc. - -13.10.2011 -- add caching for config files in Smarty_Resource -- bugfix disable of caching after isCached() call did not work (Forum Topic 20131) -- add concept unique_resource to combat potentially ambiguous template_resource values when custom resource handlers are used (Forum Topic 20128) -- bugfix multiline strings in config files could fail on longer strings (Issue #55) - -11.10.2011 -- add runtime checks for not matching {capture}/{/capture} calls (Forum Topic 20120) - -10.10.2011 -- bugfix variable name typo in {html_options} and {html_checkboxes} (Issue #54) -- bugfix tag did create wrong output when caching enabled and the tag was in included subtemplate -- bugfix Smarty_CacheResource_mysql example was missing strtotime() calls - -===== Smarty-3.1.3 ===== -07.10.2011 -- improvement removed html comments from {mailto} (Forum Topic 20092) -- bugfix testInstall() would not show path to internal plugins_dir (Forum Post 74627) -- improvement testInstall() now showing resolved paths and checking the include_path if necessary -- bugfix html_options plugin did not handle object values properly (Issue #49, Forum Topic 20049) -- improvement html_checkboxes and html_radios to accept null- and object values, and label_ids attribute -- improvement removed some unnecessary count()s -- bugfix parent pointer was not set when fetch() for other template was called on template object - -06.10.2011 -- bugfix switch lexer internals depending on mbstring.func_overload -- bugfix start_year and end_year of {html_select_date} did not use current year as offset base (Issue #53) - -05.10.2011 -- bugfix of problem introduced with r4342 by replacing strlen() with isset() -- add environment configuration issue with mbstring.func_overload Smarty cannot compensate for (Issue #45) -- bugfix nofilter tag option did not disable default modifier -- bugfix html_options plugin did not handle null- and object values properly (Issue #49, Forum Topic 20049) - -04.10.2011 -- bugfix assign() in plugins called in subtemplates did change value also in parent template -- bugfix of problem introduced with r4342 on math plugin -- bugfix output filter should not run on individually cached subtemplates -- add unloadFilter() method -- bugfix has_nocache_code flag was not reset before compilation - -===== Smarty-3.1.2 ===== -03.10.2011 -- improvement add internal $joined_template_dir property instead computing it on the fly several times - -01.10.2011 -- improvement replaced most in_array() calls by more efficient isset() on array_flip()ed haystacks -- improvement replaced some strlen($foo) > 3 calls by isset($foo[3]) -- improvement Smarty_Internal_Utility::clearCompiledTemplate() removed redundant strlen()s - -29.09.2011 -- improvement of Smarty_Internal_Config::loadConfigVars() dropped the in_array for index look up - -28.09.2011 -- bugfix on template functions called nocache calling other template functions - -27.09.2011 -- bugfix possible warning "attempt to modify property of non-object" in {section} (issue #34) -- added chaining to Smarty_Internal_Data so $smarty->assign('a',1)->assign('b',2); is possible now -- bugfix remove race condition when a custom resource did change timestamp during compilation -- bugfix variable property did not work on objects variable in template -- bugfix smarty_make_timestamp() failed to process DateTime objects properly -- bugfix wrong resource could be used on compile check of custom resource - -26.09.2011 -- bugfix repeated calls to same subtemplate did not make use of cached template object - -24.09.2011 -- removed internal muteExpectedErrors() calls in favor of having the implementor call this once from his application -- optimized muteExpectedErrors() to pass errors to the latest registered error handler, if appliccable -- added compile_dir and cache_dir to list of muted directories -- improvment better error message for undefined templates at {include} - -23.09.2011 -- remove unused properties -- optimization use real function instead anonymous function for preg_replace_callback -- bugfix a relative {include} in child template blocks failed -- bugfix direct setting of $template_dir, $config_dir, $plugins_dir in __construct() of an - extended Smarty class created problems -- bugfix error muting was not implemented for cache locking - -===== Smarty 3.1.1 ===== -22.09.2011 -- bugfix {foreachelse} does fail if {section} was nested inside {foreach} -- bugfix debug.tpl did not display correctly when it was compiled with escape_html = true - -21.09.2011 -- bugfix look for mixed case plugin file names as in 3.0 if not found try all lowercase -- added $error_muting to suppress error messages even for badly implemented error_handlers -- optimized autoloader -- reverted ./ and ../ handling in fetch() and display() - they're allowed again - -20.09.2011 -- bugfix removed debug echo output while compiling template inheritance -- bugfix relative paths in $template_dir broke relative path resolving in {include "../foo.tpl"} -- bugfix {include} did not work inside nested {block} tags -- bugfix {assign} with scope root and global did not work in all cases - -19.09.2011 -- bugfix regression in Smarty_CacheReource_KeyValueStore introduced by r4261 -- bugfix output filter shall not run on included subtemplates - -18.09.2011 -- bugfix template caching did not care about file.tpl in different template_dir -- bugfix {include $file} was broken when merge_compiled_incluges = true -- bugfix {include} was broken when merge_compiled_incluges = true and same indluded template - was used in different main templates in one compilation run -- bugfix for Smarty2 style compiler plugins on unnamed attribute passing like {tag $foo $bar} -- bugfix debug.tpl did not display correctly when it was compiled with escape_html = true - -17.09.2011 -- bugfix lock_id for file resource would create invalid filepath -- bugfix resource caching did not care about file.tpl in different template_dir - -===== Smarty 3.1.0 ===== -15/09/2011 -- optimization of {foreach}; call internal _count() method only when "total" or "last" {foreach} properties are used - -11/09/2011 -- added unregisterObject() method - -06/09/2011 -- bugfix isset() did not work in templates on config variables - -03/09/2011 -- bugfix createTemplate() must default to cache_id and compile_id of Smarty object -- bugfix Smarty_CacheResource_KeyValueStore must include $source->uid in cache filepath to keep templates with same - name but different folders separated -- added cacheresource.apc.php example in demo folder - -02/09/2011 -- bugfix cache lock file must use absolute filepath - -01/09/2011 -- update of cache locking - -30/08/2011 -- added locking mechanism to CacheResource API (implemented with File and KeyValueStores) - -28/08/2011 -- bugfix clearCompileTemplate() did not work for specific template subfolder or resource - -27/08/2011 -- bugfix {$foo|bar+1} did create syntax error - -26/08/2011 -- bugfix when generating nocache code which contains double \ -- bugfix handle race condition if cache file was deleted between filemtime and include - -17/08/2011 -- bugfix CacheResource_Custom bad internal fetch() call - -15/08/2011 -- bugfix CacheResource would load content twice for KeyValueStore and Custom handlers - -06/08/2011 -- bugfix {include} with scope attribute could execute in wrong scope -- optimization of compile_check processing - -03/08/2011 -- allow comment tags to comment {block} tags out in child templates - -26/07/2011 -- bugfix experimental getTags() method did not work - -24/07/2011 -- sure opened output buffers are closed on exception -- bugfix {foreach} did not work on IteratorAggregate - -22/07/2011 -- clear internal caches on clearAllCache(), clearCache(), clearCompiledTemplate() - -21/07/2011 -- bugfix value changes of variable values assigned to Smarty object could not be seen on repeated $smarty->fetch() calls - -17/07/2011 -- bugfix {$smarty.block.child} did drop a notice at undefined child - -15/07/2011 -- bugfix individual cache_lifetime of {include} did not work correctly inside {block} tags -- added caches for Smarty_Template_Source and Smarty_Template_Compiled to reduce I/O for multiple cache_id rendering - -14/07/2011 -- made Smarty::loadPlugin() respect the include_path if required - -13/07/2011 -- optimized internal file write functionality -- bugfix PHP did eat line break on nocache sections -- fixed typo of Smarty_Security properties $allowed_modifiers and $disabled_modifiers - -06/07/2011 -- bugfix variable modifier must run befor gereral filtering/escaping - -04/07/2011 -- bugfix use (?P) syntax at preg_match as some pcre libraries failed on (?) -- some performance improvement when using generic getter/setter on template objects - -30/06/2011 -- bugfix generic getter/setter of Smarty properties used on template objects did throw exception -- removed is_dir and is_readable checks from directory setters for better performance - -28/06/2011 -- added back support of php template resource as undocumented feature -- bugfix automatic recompilation on version change could drop undefined index notice on old 3.0 cache and compiled files -- update of README_3_1_DEV.txt and moved into the distribution folder -- improvement show first characters of eval and string templates instead sha1 Uid in debug window - -===== Smarty 3.1-RC1 ===== -25/06/2011 -- revert change of 17/06/2011. $_smarty varibale removed. call loadPlugin() from inside plugin code if required -- code cleanup, remove no longer used properties and methods -- update of PHPdoc comments - -23/06/2011 -- bugfix {html_select_date} would not respect current time zone - -19/06/2011 -- added $errors argument to testInstall() functions to suppress output. -- added plugin-file checks to testInstall() - -18/06/2011 -- bugfix mixed use of same subtemplate inline and not inline in same script could cause a warning during compilation - -17/06/2011 -- bugfix/change use $_smarty->loadPlugin() when loading nested depending plugins via loadPlugin -- bugfix {include ... inline} within {block}...{/block} did fail - -16/06/2011 -- bugfix do not overwrite '$smarty' template variable when {include ... scope=parent} is called -- bugfix complete empty inline subtemplates did fail - -15/06/2011 -- bugfix template variables where not accessable within inline subtemplates - -12/06/2011 -- bugfix removed unneeded merging of template variable when fetching includled subtemplates - -10/06/2011 -- made protected properties $template_dir, $plugins_dir, $cache_dir, $compile_dir, $config_dir accessible via magic methods - -09/06/2011 -- fix smarty security_policy issue in plugins {html_image} and {fetch} - -05/06/2011 -- update of SMARTY_VERSION -- bugfix made getTags() working again - -04/06/2011 -- allow extends resource in file attribute of {extends} tag - -03/06/2011 -- added {setfilter} tag to set filters for variable output -- added escape_html property to control autoescaping of variable output - -27/05/2011 -- added allowed/disabled tags and modifiers in security for sandboxing - -23/05/2011 -- added base64: and urlencode: arguments to eval and string resource types - -22/05/2011 -- made time-attribute of {html_select_date} and {html_select_time} accept arrays as defined by attributes prefix and field_array - -13/05/2011 -- remove setOption / getOption calls from SamrtyBC class - -02/05/2011 -- removed experimental setOption() getOption() methods -- output returned content also on opening tag calls of block plugins -- rewrite of default plugin handler -- compile code of variable filters for better performance - -20/04/2011 -- allow {php} {include_php} tags and PHP_ALLOW handling only with the SmartyBC class -- removed support of php template resource - -20/04/2011 -- added extendsall resource example -- optimization of template variable access -- optimization of subtemplate handling {include} -- optimization of template class - -01/04/2011 -- bugfix quote handling in capitalize modifier - -28/03/2011 -- bugfix stripslashes() requried when using PCRE e-modifier - -04/03/2011 -- upgrade to new PHP_LexerGenerator version 0.4.0 for better performance - -27/02/2011 -- ignore .svn folders when clearing cache and compiled files -- string resources do not need a modify check - -26/02/2011 -- replaced smarty_internal_wrapper by SmartyBC class -- load utility functions as static methods instead through __call() -- bugfix in extends resource when subresources are used -- optimization of modify checks - -25/02/2011 -- use $smarty->error_unassigned to control NOTICE handling on unassigned variables - -21/02/2011 -- added new new compile_check mode COMPILECHECK_CACHEMISS -- corrected new cloning behaviour of createTemplate() -- do no longer store the compiler object as property in the compile_tag classes to avoid possible memory leaks - during compilation - -19/02/2011 -- optimizations on merge_compiled_includes handling -- a couple of optimizations and bugfixes related to new resource structure - -17/02/2011 -- changed ./ and ../ behaviour - -14/02/2011 -- added {block ... hide} option to suppress block if no child is defined - -13/02/2011 -- update handling of recursive subtemplate calls -- bugfix replace $smarty->triggerError() by exception in smarty_internal_resource_extends.php - -12/02/2011 -- new class Smarty_Internal_TemplateBase with shared methods of Smarty and Template objects -- optimizations of template processing -- made register... methods permanet -- code for default_plugin_handler -- add automatic recompilation at version change - -04/02/2011 -- change in Smarty_CacheResource_Custom -- bugfix cache_lifetime did not compile correctly at {include} after last update -- moved isCached processing into CacheResource class -- bugfix new CacheResource API did not work with disabled compile_check - -03/02/2011 -- handle template content as function to improve speed on multiple calls of same subtemplate and isCached()/display() calls -- bugfixes and improvents in the new resource API -- optimizations of template class code - -25/01/2011 -- optimized function html_select_time - -22/01/2011 -- added Smarty::$use_include_path configuration directive for Resource API - -21/01/2011 -- optimized function html_select_date - -19/01/2011 -- optimized outputfilter trimwhitespace - -18/01/2011 -- bugfix Config to use Smarty_Resource to fetch sources -- optimized Smarty_Security's isTrustedDir() and isTrustedPHPDir() - -17/01/2011 -- bugfix HTTP headers for CGI SAPIs - -16/01/2011 -- optimized internals of Smarty_Resource and Smarty_CacheResource - -14/01/2011 -- added modifiercompiler escape to improve performance of escaping html, htmlall, url, urlpathinfo, quotes, javascript -- added support to choose template_dir to load from: [index]filename.tpl - -12/01/2011 -- added unencode modifier to revert results of encode modifier -- added to_charset and from_charset modifier for character encoding - -11/01/2011 -- added SMARTY_MBSTRING to generalize MBString detection -- added argument $lc_rest to modifier.capitalize to lower-case anything but the first character of a word -- changed strip modifier to consider unicode white-space, too -- changed wordwrap modifier to accept UTF-8 strings -- changed count_sentences modifier to consider unicode characters and treat sequences delimited by ? and ! as sentences, too -- added argument $double_encode to modifier.escape (applies to html and htmlall only) -- changed escape modifier to be UTF-8 compliant -- changed textformat block to be UTF-8 compliant -- optimized performance of mailto function -- fixed spacify modifier so characters are not prepended and appended, made it unicode compatible -- fixed truncate modifier to properly use mb_string if possible -- removed UTF-8 frenzy from count_characters modifier -- fixed count_words modifier to treat "hello-world" as a single word like str_count_words() does -- removed UTF-8 frenzy from upper modifier -- removed UTF-8 frenzy from lower modifier - -01/01/2011 -- optimize smarty_modified_escape for hex, hexentity, decentity. - -28/12/2010 -- changed $tpl_vars, $config_vars and $parent to belong to Smarty_Internal_Data -- added Smarty::registerCacheResource() for dynamic cache resource object registration - -27/12/2010 -- added Smarty_CacheResource API and refactored existing cache resources accordingly -- added Smarty_CacheResource_Custom and Smarty_CacheResource_Mysql - -26/12/2010 -- added Smarty_Resource API and refactored existing resources accordingly -- added Smarty_Resource_Custom and Smarty_Resource_Mysql -- bugfix Smarty::createTemplate() to return properly cloned template instances - -24/12/2010 -- optimize smarty_function_escape_special_chars() for PHP >= 5.2.3 - -===== SVN 3.0 trunk ===== -14/05/2011 -- bugfix error handling at stream resources - -13/05/2011 -- bugfix condition starting with "-" did fail at {if} and {while} tags - -22/04/2011 -- bugfix allow only fixed string as file attribute at {extends} tag - -01/04/2011 -- bugfix do not run filters and default modifier when displaying the debug template -- bugfix of embedded double quotes within multi line strings (""") - -29/03/2011 -- bugfix on error message in smarty_internal_compile_block.php -- bugfix mb handling in strip modifier -- bugfix for Smarty2 style registered compiler function on unnamed attribute passing like {tag $foo $bar} - -17/03/2011 -- bugfix on default {function} parameters when {function} was used in nocache sections -- bugfix on compiler object destruction. compiler_object property was by mistake unset. - -09/03/2011 --bugfix a variable filter should run before modifiers on an output tag (see change of 23/07/2010) - -08/03/2011 -- bugfix loading config file without section should load only defaults - -03/03/2011 -- bugfix "smarty" template variable was not recreated when cached templated had expired -- bugfix internal rendered_content must be cleared after subtemplate was included - -01/03/2011 -- bugfix replace modifier did not work in 3.0.7 on systems without multibyte support -- bugfix {$smarty.template} could return in 3.0.7 parent template name instead of - child name when it needed to compile - -25/02/2011 -- bugfix for Smarty2 style compiler plugins on unnamed attribute passing like {tag $foo $bar} - -24/02/2011 -- bugfix $smarty->clearCache('some.tpl') did by mistake cache the template object - -18/02/2011 -- bugfix removed possible race condition when isCached() was called for an individually cached subtemplate -- bugfix force default debug.tpl to be loaded by the file resource - -17/02/2011 --improvement not to delete files starting with '.' from cache and template_c folders on clearCompiledTemplate() and clearCache() - -16/02/2011 --fixed typo in exception message of Smarty_Internal_Template --improvement allow leading spaces on } tag closing if auto_literal is enabled - -13/02/2011 -- bufix replace $smarty->triggerError() by exception -- removed obsolete {popup_init..} plugin from demo templates -- bugfix replace $smarty->triggerError() by exception in smarty_internal_resource_extends.php - -===== Smarty 3.0.7 ===== -09/02/2011 -- patched vulnerability when using {$smarty.template} - -01/02/2011 -- removed assert() from config and template parser - -31/01/2011 -- bugfix the lexer/parser did fail on special characters like VT - -16/01/2011 --bugfix of ArrayAccess object handling in internal _count() method --bugfix of Iterator object handling in internal _count() method - -14/01/2011 --bugfix removed memory leak while processing compileAllTemplates - -12/01/2011 -- bugfix in {if} and {while} tag compiler when using assignments as condition and nocache mode - -10/01/2011 -- bugfix when using {$smarty.block.child} and name of {block} was in double quoted string -- bugfix updateParentVariables() was called twice when leaving {include} processing - -- bugfix mb_str_replace in replace and escape modifiers work with utf8 - -31/12/2010 -- bugfix dynamic configuration of $debugging_crtl did not work -- bugfix default value of $config_read_hidden changed to false -- bugfix format of attribute array on compiler plugins -- bugfix getTemplateVars() could return value from wrong scope - -28/12/2010 -- bugfix multiple {append} tags failed to compile. - -22/12/2010 -- update do not clone the Smarty object an internal createTemplate() calls to increase performance - -21/12/2010 -- update html_options to support class and id attrs - -17/12/2010 -- bugfix added missing support of $cache_attrs for registered plugins - -15/12/2010 -- bugfix assignment as condition in {while} did drop an E_NOTICE - -14/12/2010 -- bugfix when passing an array as default parameter at {function} tag - -13/12/2010 -- bugfix {$smarty.template} in child template did not return right content -- bugfix Smarty3 did not search the PHP include_path for template files - -===== Smarty 3.0.6 ===== - -12/12/2010 -- bugfix fixed typo regarding yesterdays change to allow streamWrapper - -11/12/2010 -- bugfix nested block tags in template inheritance child templates did not work correctly -- bugfix {$smarty.current_dir} in child template did not point to dir of child template -- bugfix changed code when writing temporary compiled files to allow stream_wrapper - -06/12/2010 -- bugfix getTemplateVars() should return 'null' instead dropping E_NOTICE on an unassigned variable - -05/12/2010 -- bugfix missing declaration of $smarty in Smarty class -- bugfix empty($foo) in {if} did drop a notice when $foo was not assigned - -01/12/2010 -- improvement of {debug} tag output - -27/11/2010 --change run output filter before cache file is written. (same as in Smarty2) - -24/11/2011 --bugfix on parser at !$foo|modifier --change parser logic when assignments used as condition in {if] and {while} to allow assign to array element - -23/11/2011 --bugfix allow integer as attribute name in plugin calls --change trimm whitespace from error message, removed long list of expected tokens - -22/11/2010 -- bugfix on template inheritance when an {extends} tag was inserted by a prefilter -- added error message for illegal variable file attributes at {extends...} tags - -===== Smarty 3.0.5 ===== - - -19/11/2010 -- bugfix on block plugins with modifiers - -18/11/2010 -- change on handling of unassigned template variable -- default will drop E_NOTICE -- bugfix on Smarty2 wrapper load_filter() did not work - -17/11/2010 -- bugfix on {call} with variable function name -- bugfix on {block} if name did contain '-' -- bugfix in function.fetch.php , referece to undefined $smarty - -16/11/2010 -- bugfix whitespace in front of "fetch()/display() have been used in plugins - (introduced with 3.0.2) -- code cleanup - -===== Smarty 3.0.3 ===== - -13/11/2010 -- bugfix on {debug} -- reverted location of loadPlugin() to Smarty class -- fixed comments in plugins -- fixed internal_config (removed unwanted code line) -- improvement remove last linebreak from {function} definition - -===== Smarty 3.0.2 ===== - -12/11/2010 -- reactivated $error_reporting property handling -- fixed typo in compile_continue -- fixed security in {fetch} plugin -- changed back plugin parameters to two. second is template object - with transparent access to Smarty object -- fixed {config_load} scoping form compile time to run time - -===== Smarty 3.0.0 ===== - - - -11/11/2010 -- major update including some API changes - -10/11/2010 -- observe compile_id also for config files - -09/11/2010 --bugfix on complex expressions as start value for {for} tag -request_use_auto_globals -04/11/2010 -- bugfix do not allow access of dynamic and private object members of assigned objects when - security is enabled. - -01/11/2010 -- bugfix related to E_NOTICE change. {if empty($foo)} did fail when $foo contained a string - -28/10/2010 -- bugfix on compiling modifiers within $smarty special vars like {$smarty.post.{$foo|lower}} - -27/10/2010 -- bugfix default parameter values did not work for template functions included with {include} - -25/10/2010 -- bugfix for E_NOTICE change, array elements did not work as modifier parameter - -20/10/2010 -- bugfix for the E_NOTICE change - -19/10/2010 -- change Smarty does no longer mask out E_NOTICE by default during template processing - -13/10/2010 -- bugfix removed ambiguity between ternary and stream variable in template syntax -- bugfix use caching properties of template instead of smarty object when compiling child {block} -- bugfix {*block}...{/block*} did throw an exception in template inheritance -- bugfix on template inheritance using nested eval or string resource in {extends} tags -- bugfix on output buffer handling in isCached() method - -===== RC4 ===== - -01/10/2010 -- added {break} and {continue} tags for flow control of {foreach},{section},{for} and {while} loops -- change of 'string' resource. It's no longer evaluated and compiled files are now stored -- new 'eval' resource which evaluates a template without saving the compiled file -- change in isCached() method to allow multiple calls for the same template - -25/09/2010 -- bugfix on some compiling modifiers - -24/09/2010 -- bugfix merge_compiled_includes flag was not restored correctly in {block} tag - -22/09/2010 -- bugfix on default modifier - -18/09/2010 -- bugfix untility compileAllConfig() did not create sha1 code for compiled template file names if template_dir was defined with no trailing DS -- bugfix on templateExists() for extends resource - -17/09/2010 -- bugfix {$smarty.template} and {$smarty.current_dir} did not compile correctly within {block} tags -- bugfix corrected error message on missing template files in extends resource -- bugfix untility compileAllTemplates() did not create sha1 code for compiled template file names if template_dir was defined with no trailing DS - -16/09/2010 -- bugfix when a doublequoted modifier parameter did contain Smarty tags and ':' - -15/09/2010 -- bugfix resolving conflict between '<%'/'%>' as custom Smarty delimiter and ASP tags -- use ucfirst for resource name on internal resource class names - -12/09/2010 -- bugfix for change of 08/09/2010 (final {block} tags in subtemplates did not produce correct results) - -10/09/2010 -- bugfix for change of 08/09/2010 (final {block} tags in subtemplates did not produce correct results) - -08/09/2010 -- allow multiple template inheritance branches starting in subtemplates - -07/09/2010 -- bugfix {counter} and {cycle} plugin assigned result to smarty variable not in local(template) scope -- bugfix templates containing just {strip} {/strip} tags did produce an error - - -23/08/2010 -- fixed E_STRICT errors for uninitialized variables - -22/08/2010 -- added attribute cache_id to {include} tag - -13/08/2010 -- remove exception_handler property from Smarty class -- added Smarty's own exceptions SmartyException and SmartyCompilerException - -09/08/2010 -- bugfix on modifier with doublequoted strings as parameter containing embedded tags - -06/08/2010 -- bugfix when cascading some modifier like |strip|strip_tags modifier - -05/08/2010 -- added plugin type modifiercompiler to produce compiled modifier code -- changed standard modifier plugins to the compiling versions whenever possible -- bugfix in nocache sections {include} must not cache the subtemplate - -02/08/2010 -- bugfix strip did not work correctly in conjunction with comment lines - -31/07/2010 -- bugfix on nocache attribute at {assign} and {append} - -30/07/2010 -- bugfix passing scope attributes in doublequoted strings did not work at {include} {assign} and {append} - -25/07/2010 -- another bugfix of change from 23/07/2010 when compiling modifier - -24/07/2010 -- bugfix of change from 23/07/2010 when compiling modifier - -23/07/2010 -- changed execution order. A variable filter does now run before modifiers on output of variables -- bugfix use always { and } as delimiter for debug.tpl - - -22/07/2010 -- bugfix in templateExists() method - -20/07/2010 -- fixed handling of { strip } tag with whitespaces - -15/07/2010 -- bufix {$smarty.template} does include now the relative path, not just filename - -===== RC3 ===== - - - - -15/07/2010 -- make the date_format modifier work also on objects of the DateTime class -- implementation of parsetrees in the parser to close security holes and remove unwanted empty line in HTML output - -08/07/2010 -- bugfix on assigning multidimensional arrays within templates -- corrected bugfix for truncate modifier - -07/07/2010 -- bugfix the truncate modifier needs to check if the string is utf-8 encoded or not -- bugfix support of script files relative to trusted_dir - -06/07/2010 -- create exception on recursive {extends} calls -- fixed reported line number at "unexpected closing tag " exception -- bugfix on escape:'mail' modifier -- drop exception if 'item' variable is equal 'from' variable in {foreach} tag - -01/07/2010 -- removed call_user_func_array calls for optimization of compiled code when using registered modifiers and plugins - -25/06/2010 -- bugfix escaping " when block tags are used within doublequoted strings - -24/06/2010 -- replace internal get_time() calls with standard PHP5 microtime(true) calls in Smarty_Internal_Utility -- added $smarty->register->templateClass() and $smarty->unregister->templateClass() methods for supporting static classes with namespace - - -22/06/2010 -- allow spaces between typecast and value in template syntax -- bugfix get correct count of traversables in {foreach} tag - -21/06/2010 -- removed use of PHP shortags SMARTY_PHP_PASSTHRU mode -- improved speed of cache->clear() when a compile_id was specified and use_sub_dirs is true - -20/06/2010 -- replace internal get_time() calls with standard PHP5 microtime(true) calls -- closed security hole when php.ini asp_tags = on - -18/06/2010 -- added __toString method to the Smarty_Variable class - - -14/06/2010 -- make handling of Smarty comments followed by newline BC to Smarty2 - - -===== RC2 ===== - - - -13/06/2010 -- bugfix Smarty3 did not handle hexadecimals like 0x0F as numerical value -- bugifx Smarty3 did not accept numerical constants like .1 or 2. (without a leading or trailing digit) - -11/06/2010 -- bugfix the lexer did fail on larger {literal} ... {/literal} sections - -03/06/2010 -- bugfix on calling template functions like Smarty tags - -01/06/2010 -- bugfix on template functions used with template inheritance -- removed /* vim: set expandtab: */ comments -- bugfix of auto literal problem introduce with fix of 31/05/2010 - -31/05/2010 -- bugfix the parser did not allow some smarty variables with special name like $for, $if, $else and others. - -27/05/2010 -- bugfix on object chaining using variable properties -- make scope of {counter} and {cycle} tags again global as in Smarty2 - -26/05/2010 -- bugfix removed decrepated register_resource call in smarty_internal_template.php - -25/05/2010 -- rewrite of template function handling to improve speed -- bugfix on file dependency when merge_compiled_includes = true - - -16/05/2010 -- bugfix when passing parameter with numeric name like {foo 1='bar' 2='blar'} - -14/05/2010 -- bugfix compile new config files if compile_check and force_compile = false -- added variable static classes names to template syntax - -11/05/2010 -- bugfix make sure that the cache resource is loaded in all conditions when template methods getCached... are called externally -- reverted the change 0f 30/04/2010. With the exception of forward references template functions can be again called by a standard tag. - -10/05/2010 -- bugfix on {foreach} and {for} optimizations of 27/04/2010 - -09/05/2010 -- update of template and config file parser because of minor parser generator bugs - -07/05/2010 -- bugfix on {insert} - -06/05/2010 -- bugfix when merging compiled templates and objects are passed as parameter of the {include} tag - -05/05/2010 -- bugfix on {insert} to cache parameter -- implementation of $smarty->default_modifiers as in Smarty2 -- bugfix on getTemplateVars method - -01/05/2010 -- bugfix on handling of variable method names at object chaning - -30/04/2010 -- bugfix when comparing timestamps in sysplugins/smarty_internal_config.php -- work around of a substr_compare bug in older PHP5 versions -- bugfix on template inheritance for tag names starting with "block" -- bugfix on {function} tag with name attribute in doublequoted strings -- fix to make calling of template functions unambiguously by madatory usage of the {call} tag - -===== RC1 ===== - -27/04/2010 -- change default of $debugging_ctrl to 'NONE' -- optimization of compiled code of {foreach} and {for} loops -- change of compiler for config variables - -27/04/2010 -- bugfix in $smarty->cache->clear() method. (do not cache template object) - - -17/04/2010 -- security fix in {math} plugin - - -12/04/2010 -- bugfix in smarty_internal_templatecompilerbase (overloaded property) -- removed parser restrictions in using true,false and null as ID - -07/04/2010 -- bugfix typo in smarty_internal_templatecompilerbase - -31/03/2010 -- compile locking by touching old compiled files to avoid concurrent compilations - -29/03/2010 -- bugfix allow array definitions as modifier parameter -- bugfix observe compile_check property when loading config files -- added the template object as third filter parameter - -25/03/2010 -- change of utility->compileAllTemplates() log messages -- bugfix on nocache code in {function} tags -- new method utility->compileAllConfig() to compile all config files - -24/03/2010 -- bugfix on register->modifier() error messages - -23/03/2010 -- bugfix on template inheritance when calling multiple child/parent relations -- bugfix on caching mode SMARTY_CACHING_LIFETIME_SAVED and cache_lifetime = 0 - -22/03/2010 -- bugfix make directory separator operating system independend in compileAllTemplates() - -21/03/2010 -- removed unused code in compileAllTemplates() - -19/03/2010 -- bugfix for multiple {/block} tags on same line - -17/03/2010 -- bugfix make $smarty->cache->clear() function independent from caching status - -16/03/2010 -- bugfix on assign attribute at registered template objects -- make handling of modifiers on expression BC to Smarty2 - -15/03/2010 -- bugfix on block plugin calls - -11/03/2010 -- changed parsing of back to Smarty2 behaviour - -08/03/2010 -- bugfix on uninitialized properties in smarty_internal_template -- bugfix on $smarty->disableSecurity() - -04/03/2010 -- bugfix allow uppercase chars in registered resource names -- bugfix on accessing chained objects of static classes - -01/03/2010 -- bugfix on nocache code in {block} tags if child template was included by {include} - -27/02/2010 -- allow block tags inside double quoted string - -26/02/2010 -- cache modified check implemented -- support of access to a class constant from an object (since PHP 5.3) - -24/02/2010 -- bugfix on expressions in doublequoted string enclosed in backticks -- added security property $static_classes for static class security - -18/02/2010 -- bugfix on parsing Smarty tags inside -- bugfix on truncate modifier - -17/02/2010 -- removed restriction that modifiers did require surrounding parenthesis in some cases -- added {$smarty.block.child} special variable for template inheritance - -16/02/2010 -- bugfix on tags for all php_handling modes -- bugfix on parameter of variablefilter.htmlspecialchars.php plugin - -14/02/2010 -- added missing _plugins property in smarty.class.php -- bugfix $smarty.const... inside doublequoted strings and backticks was compiled into wrong PHP code - -12/02/2010 -- bugfix on nested {block} tags -- changed Smarty special variable $smarty.parent to $smarty.block.parent -- added support of nested {bock} tags - -10/02/2010 -- avoid possible notice on $smarty->cache->clear(...), $smarty->clear_cache(....) -- allow Smarty tags inside tags in SMARTY_PHP_QUOTE and SMARTY_PHP_PASSTHRU mode -- bugfix at new "for" syntax like {for $x=1 to 10 step 2} - -09/02/2010 -- added $smarty->_tag_stack for tracing block tag hierarchy - -08/02/2010 -- bugfix use template fullpath at §smarty->cache->clear(...), $smarty->clear_cache(....) -- bugfix of cache filename on extended templates when force_compile=true - -07/02/2010 -- bugfix on changes of 05/02/2010 -- preserve line endings type form template source -- API changes (see README file) - -05/02/2010 -- bugfix on modifier and block plugins with same name - -02/02/2010 -- retaining newlines at registered functions and function plugins - -01/25/2010 -- bugfix cache resource was not loaded when caching was globally off but enabled at a template object -- added test that $_SERVER['SCRIPT_NAME'] does exist in Smarty.class.php - -01/22/2010 -- new method $smarty->createData([$parent]) for creating a data object (required for bugfixes below) -- bugfix config_load() method now works also on a data object -- bugfix get_config_vars() method now works also on a data and template objects -- bugfix clear_config() method now works also on a data and template objects - -01/19/2010 -- bugfix on plugins if same plugin was called from a nocache section first and later from a cached section - - -###beta 7### - - -01/17/2010 -- bugfix on $smarty.const... in double quoted strings - -01/16/2010 -- internal change of config file lexer/parser on handling of section names -- bugfix on registered objects (format parameter of register_object was not handled correctly) - -01/14/2010 -- bugfix on backslash within single quoted strings -- bugfix allow absolute filepath for config files -- bugfix on special Smarty variable $smarty.cookies -- revert handling of newline on no output tags like {if...} -- allow special characters in config file section names for Smarty2 BC - -01/13/2010 -- bugfix on {if} tags - -01/12/2010 -- changed back modifier handling in parser. Some restrictions still apply: - if modifiers are used in side {if...} expression or in mathematical expressions - parentheses must be used. -- bugfix the {function..} tag did not accept the name attribute in double quotes -- closed possible security hole at tags -- bugfix of config file parser on large config files - - -###beta 6#### - -01/11/2010 -- added \n to the compiled code of the {if},{else},{elseif},{/if} tags to get output of newlines as expected by the template source -- added missing support of insert plugins -- added optional nocache attribute to {block} tags in parent template -- updated handling supporting now heredocs and newdocs. (thanks to Thue Jnaus Kristensen) - -01/09/2010 -- bugfix on nocache {block} tags in parent templates - -01/08/2010 -- bugfix on variable filters. filter/nofilter attributes did not work on output statements - -01/07/2010 -- bugfix on file dependency at template inheritance -- bugfix on nocache code at template inheritance - -01/06/2010 -- fixed typo in smarty_internal_resource_registered -- bugfix for custom delimiter at extends resource and {extends} tag - -01/05/2010 -- bugfix sha1() calculations at extends resource and some general improvments on sha1() handling - - -01/03/2010 -- internal change on building cache files - -01/02/2010 -- update cached_timestamp at the template object after cache file is written to avoid possible side effects -- use internally always SMARTY_CACHING_LIFETIME_* constants - -01/01/2010 -- bugfix for obtaining plugins which must be included (related to change of 12/30/2009) -- bugfix for {php} tag (trow an exception if allow_php_tag = false) - -12/31/2009 -- optimization of generated code for doublequoted strings containing variables -- rewrite of {function} tag handling - - can now be declared in an external subtemplate - - can contain nocache sections (nocache_hash handling) - - can be called in noccache sections (nocache_hash handling) - - new {call..} tag to call template functions with a variable name {call name=$foo} -- fixed nocache_hash handling in merged compiled templates - -12/30/2009 -- bugfix for plugins defined in the script as smarty_function_foo - -12/29/2009 -- use sha1() for filepath encoding -- updates on nocache_hash handling -- internal change on merging some data -- fixed cache filename for custom resources - -12/28/2009 -- update for security fixes -- make modifier plugins always trusted -- fixed bug loading modifiers in child template at template inheritance - -12/27/2009 ---- this is a major update with a couple of internal changes --- -- new config file lexer/parser (thanks to Thue Jnaus Kristensen) -- template lexer/parser fixes for PHP and {literal} handing (thanks to Thue Jnaus Kristensen) -- fix on registered plugins with different type but same name -- rewrite of plugin handling (optimized execution speed) -- closed a security hole regarding PHP code injection into cache files -- fixed bug in clear cache handling -- Renamed a couple of internal classes -- code cleanup for merging compiled templates -- couple of runtime optimizations (still not all done) -- update of getCachedTimestamp() -- fixed bug on modifier plugins at nocache output - -12/19/2009 -- bugfix on comment lines in config files - -12/17/2009 -- bugfix of parent/global variable update at included/merged subtemplates -- encode final template filepath into filename of compiled and cached files -- fixed {strip} handling in auto literals - -12/16/2009 -- update of changelog -- added {include file='foo.tpl' inline} inline option to merge compiled code of subtemplate into the calling template - -12/14/2009 -- fixed sideefect of last modification (objects in array index did not work anymore) - -12/13/2009 -- allow boolean negation ("!") as operator on variables outside {if} tag - -12/12/2009 -- bugfix on single quotes inside {function} tag -- fix short append/prepend attributes in {block} tags - -12/11/2009 -- bugfix on clear_compiled_tpl (avoid possible warning) - -12/10/2009 -- bugfix on {function} tags and template inheritance - -12/05/2009 -- fixed problem when a cached file was fetched several times -- removed unneeded lexer code - -12/04/2009 -- added max attribute to for loop -- added security mode allow_super_globals - -12/03/2009 -- template inheritance: child templates can now call functions defined by the {function} tag in the parent template -- added {for $foo = 1 to 5 step 2} syntax -- bugfix for {$foo.$x.$y.$z} - -12/01/2009 -- fixed parsing of names of special formated tags like if,elseif,while,for,foreach -- removed direct access to constants in templates because of some syntax problems -- removed cache resource plugin for mysql from the distribution -- replaced most hard errors (exceptions) by softerrors(trigger_error) in plugins -- use $template_class property for template class name when compiling {include},{eval} and {extends} tags - -11/30/2009 -- map 'true' to SMARTY_CACHING_LIFETIME_CURRENT for the $smarty->caching parameter -- allow {function} tags within {block} tags - -11/28/2009 -- ignore compile_id at debug template -- added direct access to constants in templates -- some lexer/parser optimizations - -11/27/2009 -- added cache resource MYSQL plugin - -11/26/2009 -- bugfix on nested doublequoted strings -- correct line number on unknown tag error message -- changed {include} compiled code -- fix on checking dynamic varibales with error_unassigned = true - -11/25/2009 -- allow the following writing for boolean: true, TRUE, True, false, FALSE, False -- {strip} tag functionality rewritten - -11/24/2009 -- bugfix for $smarty->config_overwrite = false - -11/23/2009 -- suppress warnings on unlink caused by race conditions -- correct line number on unknown tag error message - -------- beta 5 -11/23/2009 -- fixed configfile parser for text starting with a numeric char -- the default_template_handler_func may now return a filepath to a template source - -11/20/2009 -- bugfix for empty config files -- convert timestamps of registered resources to integer - -11/19/2009 -- compiled templates are no longer touched with the filemtime of template source - -11/18/2009 -- allow integer as attribute name in plugin calls - -------- beta 4 -11/18/2009 -- observe umask settings when setting file permissions -- avoide unneeded cache file creation for subtemplates which did occur in some situations -- make $smarty->_current_file available during compilation for Smarty2 BC - -11/17/2009 -- sanitize compile_id and cache_id (replace illegal chars with _) -- use _dir_perms and _file_perms properties at file creation -- new constant SMARTY_RESOURCE_DATE_FORMAT (default '%b %e, %Y') which is used as default format in modifier date_format -- added {foreach $array as $key=>$value} syntax -- renamed extend tag and resource to extends: {extends file='foo.tol'} , $smarty->display('extends:foo.tpl|bar.tpl); -- bugfix cycle plugin - -11/15/2009 -- lexer/parser optimizations on quoted strings - -11/14/2009 -- bugfix on merging compiled templates when source files got removed or renamed. -- bugfix modifiers on registered object tags -- fixed locaion where outputfilters are running -- fixed config file definitions at EOF -- fix on merging compiled templates with nocache sections in nocache includes -- parser could run into a PHP error on wrong file attribute - -11/12/2009 -- fixed variable filenames in {include_php} and {insert} -- added scope to Smarty variables in the {block} tag compiler -- fix on nocache code in child {block} tags - -11/11/2009 -- fixed {foreachelse}, {forelse}, {sectionelse} compiled code at nocache variables -- removed checking for reserved variables -- changed debugging handling - -11/10/2009 -- fixed preg_qoute on delimiters - -11/09/2009 -- lexer/parser bugfix -- new SMARTY_SPL_AUTOLOAD constant to control the autoloader option -- bugfix for {function} block tags in included templates - -11/08/2009 -- fixed alphanumeric array index -- bugfix on complex double quoted strings - -11/05/2009 -- config_load method can now be called on data and template objects - -11/04/2009 -- added typecasting support for template variables -- bugfix on complex indexed special Smarty variables - -11/03/2009 -- fixed parser error on objects with special smarty vars -- fixed file dependency for {incude} inside {block} tag -- fixed not compiling on non existing compiled templates when compile_check = false -- renamed function names of autoloaded Smarty methods to Smarty_Method_.... -- new security_class property (default is Smarty_Security) - -11/02/2009 -- added neq,lte,gte,mod as aliases to if conditions -- throw exception on illegal Smarty() constructor calls - -10/31/2009 -- change of filenames in sysplugins folder for internal spl_autoload function -- lexer/parser changed for increased compilation speed - -10/27/2009 -- fixed missing quotes in include_php.php - -10/27/2009 -- fixed typo in method.register_resource -- pass {} through as literal - -10/26/2009 -- merge only compiled subtemplates into the compiled code of the main template - -10/24/2009 -- fixed nocache vars at internal block tags -- fixed merging of recursive includes - -10/23/2009 -- fixed nocache var problem - -10/22/2009 -- fix trimwhitespace outputfilter parameter - -10/21/2009 -- added {$foo++}{$foo--} syntax -- buxfix changed PHP "if (..):" to "if (..){" because of possible bad code when concenating PHP tags -- autoload Smarty internal classes -- fixed file dependency for config files -- some code optimizations -- fixed function definitions on some autoloaded methods -- fixed nocache variable inside if condition of {if} tag - -10/20/2009 -- check at compile time for variable filter to improve rendering speed if no filter is used -- fixed bug at combination of {elseif} tag and {...} in double quoted strings of static class parameter - -10/19/2009 -- fixed compiled template merging on variable double quoted strings as name -- fixed bug in caching mode 2 and cache_lifetime -1 -- fixed modifier support on block tags - -10/17/2009 -- remove ?>\n'bar','foo2'=>'blar'); - $smarty->display('my.tpl',$data); - -09/29/2009 -- changed {php} tag handling -- removed support of Smarty::instance() -- removed support of PHP resource type -- improved execution speed of {foreach} tags -- fixed bug in {section} tag - -09/23/2009 -- improvements and bugfix on {include} tag handling -NOTICE: existing compiled template and cache files must be deleted - -09/19/2009 -- replace internal "eval()" calls by "include" during rendering process -- speed improvment for templates which have included subtemplates - the compiled code of included templates is merged into the compiled code of the parent template -- added logical operator "xor" for {if} tag -- changed parameter ordering for Smarty2 BC - fetch($template, $cache_id = null, $compile_id = null, $parent = null) - display($template, $cache_id = null, $compile_id = null, $parent = null) - createTemplate($template, $cache_id = null, $compile_id = null, $parent = null) -- property resource_char_set is now replaced by constant SMARTY_RESOURCE_CHAR_SET -- fixed handling of classes in registered blocks -- speed improvement of lexer on text sections - -09/01/2009 -- dropped nl2br as plugin -- added '<>' as comparission operator in {if} tags -- cached caching_lifetime property to cache_liftime for backward compatibility with Smarty2. - {include} optional attribute is also now cache_lifetime -- fixed trigger_error method (moved into Smarty class) -- version is now Beta!!! - - -08/30/2009 -- some speed optimizations on loading internal plugins - - -08/29/2009 -- implemented caching of registered Resources -- new property 'auto_literal'. if true(default) '{ ' and ' }' interpreted as literal, not as Smarty delimiter - - -08/28/2009 -- Fix on line breaks inside {if} tags - -08/26/2009 -- implemented registered resources as in Smarty2. NOTE: caching does not work yet -- new property 'force_cache'. if true it forces the creation of a new cache file -- fixed modifiers on arrays -- some speed optimization on loading internal classes - - -08/24/2009 -- fixed typo in lexer definition for '!==' operator -- bugfix - the ouput of plugins was not cached -- added global variable SCRIPT_NAME - -08/21/2009 -- fixed problems whitespace in conjuction with custom delimiters -- Smarty tags can now be used as value anywhere - -08/18/2009 -- definition of template class name moded in internal.templatebase.php -- whitespace parser changes - -08/12/2009 -- fixed parser problems - -08/11/2009 -- fixed parser problems with custom delimiter - -08/10/2009 -- update of mb support in plugins - - -08/09/2009 -- fixed problems with doublequoted strings at name attribute of {block} tag -- bugfix at scope attribute of {append} tag - -08/08/2009 -- removed all internal calls of Smarty::instance() -- fixed code in double quoted strings - -08/05/2009 -- bugfix mb_string support -- bugfix of \n.\t etc in double quoted strings - -07/29/2009 -- added syntax for variable config vars like #$foo# - -07/28/2009 -- fixed parsing of $smarty.session vars containing objects - -07/22/2009 -- fix of "$" handling in double quoted strings - -07/21/2009 -- fix that {$smarty.current_dir} return correct value within {block} tags. - -07/20/2009 -- drop error message on unmatched {block} {/block} pairs - -07/01/2009 -- fixed smarty_function_html_options call in plugin function.html_select_date.php (missing ,) - -06/24/2009 -- fixed smarty_function_html_options call in plugin function.html_select_date.php - -06/22/2009 -- fix on \n and spaces inside smarty tags -- removed request_use_auto_globals propert as it is no longer needed because Smarty 3 will always run under PHP 5 - - -06/18/2009 -- fixed compilation of block plugins when caching enabled -- added $smarty.current_dir which returns the current working directory - -06/14/2009 -- fixed array access on super globals -- allow smarty tags within xml tags - -06/13/2009 -- bugfix at extend resource: create unique files for compiled template and cache for each combination of template files -- update extend resource to handle appen and prepend block attributes -- instantiate classes of plugins instead of calling them static - -06/03/2009 -- fixed repeat at block plugins - -05/25/2009 -- fixed problem with caching of compiler plugins - -05/14/2009 -- fixed directory separator handling - -05/09/2009 -- syntax change for stream variables -- fixed bug when using absolute template filepath and caching - -05/08/2009 -- fixed bug of {nocache} tag in included templates - -05/06/2009 -- allow that plugins_dir folder names can end without directory separator - -05/05/2009 -- fixed E_STRICT incompabilities -- {function} tag bug fix -- security policy definitions have been moved from plugins folder to file Security.class.php in libs folder -- added allow_super_global configuration to security - -04/30/2009 -- functions defined with the {function} tag now always have global scope - -04/29/2009 -- fixed problem with directory setter methods -- allow that cache_dir can end without directory separator - -04/28/2009 -- the {function} tag can no longer overwrite standard smarty tags -- inherit functions defined by the {fuction} tag into subtemplates -- added {while } sytax to while tag - -04/26/2009 -- added trusted stream checking to security -- internal changes at file dependency check for caching - -04/24/2009 -- changed name of {template} tag to {function} -- added new {template} tag - -04/23/2009 -- fixed access of special smarty variables from included template - -04/22/2009 -- unified template stream syntax with standard Smarty resource syntax $smarty->display('mystream:mytemplate') - -04/21/2009 -- change of new style syntax for forach. Now: {foreach $array as $var} like in PHP - -04/20/2009 -- fixed "$foo.bar ..." variable replacement in double quoted strings -- fixed error in {include} tag with variable file attribute - -04/18/2009 -- added stream resources ($smarty->display('mystream://mytemplate')) -- added stream variables {$mystream:myvar} - -04/14/2009 -- fixed compile_id handling on {include} tags -- fixed append/prepend attributes in {block} tag -- added {if 'expression' is in 'array'} syntax -- use crc32 as hash for compiled config files. - -04/13/2009 -- fixed scope problem with parent variables when appending variables within templates. -- fixed code for {block} without childs (possible sources for notice errors removed) - -04/12/2009 -- added append and prepend attribute to {block} tag - -04/11/2009 -- fixed variables in 'file' attribute of {extend} tag -- fixed problems in modifiers (if mb string functions not present) - -04/10/2009 -- check if mb string functions available otherwise fallback to normal string functions -- added global variable scope SMARTY_GLOBAL_SCOPE -- enable 'variable' filter by default -- fixed {$smarty.block.parent.foo} -- implementation of a 'variable' filter as replacement for default modifier - -04/09/2009 -- fixed execution of filters defined by classes -- compile the always the content of {block} tags to make shure that the filters are running over it -- syntax corrections on variable object property -- syntax corrections on array access in dot syntax - -04/08/2009 -- allow variable object property - -04/07/2009 -- changed variable scopes to SMARTY_LOCAL_SCOPE, SMARTY_PARENT_SCOPE, SMARTY_ROOT_SCOPE to avoid possible conflicts with user constants -- Smarty variable global attribute replaced with scope attribute - -04/06/2009 -- variable scopes LOCAL_SCOPE, PARENT_SCOPE, ROOT_SCOPE -- more getter/setter methods - -04/05/2009 -- replaced new array looping syntax {for $foo in $array} with {foreach $foo in $array} to avoid confusion -- added append array for short form of assign {$foo[]='bar'} and allow assignments to nested arrays {$foo['bla']['blue']='bar'} - -04/04/2009 -- make output of template default handlers cachable and save compiled source -- some fixes on yesterdays update - -04/03/2006 -- added registerDefaultTemplateHandler method and functionallity -- added registerDefaultPluginHandler method and functionallity -- added {append} tag to extend Smarty array variabled - -04/02/2009 -- added setter/getter methods -- added $foo@first and $foo@last properties at {for} tag -- added $set_timezone (true/false) property to setup optionally the default time zone - -03/31/2009 -- bugfix smarty.class and internal.security_handler -- added compile_check configuration -- added setter/getter methods - -03/30/2009 -- added all major setter/getter methods - -03/28/2009 -- {block} tags can be nested now -- md5 hash function replace with crc32 for speed optimization -- file order for exted resource inverted -- clear_compiled_tpl and clear_cache_all will not touch .svn folder any longer - -03/27/2009 -- added extend resource - -03/26/2009 -- fixed parser not to create error on `word` in double quoted strings -- allow PHP array(...) -- implemented $smarty.block.name.parent to access parent block content -- fixed smarty.class - - -03/23/2009 -- fixed {foreachelse} and {forelse} tags - -03/22/2009 -- fixed possible sources for notice errors -- rearrange SVN into distribution and development folders - -03/21/2009 -- fixed exceptions in function plugins -- fixed notice error in Smarty.class.php -- allow chained objects to span multiple lines -- fixed error in modifiers - -03/20/2009 -- moved /plugins folder into /libs folder -- added noprint modifier -- autoappend a directory separator if the xxxxx_dir definition have no trailing one - -03/19/2009 -- allow array definition as modifier parameter -- changed modifier to use multi byte string funktions. - -03/17/2009 -- bugfix - -03/15/2009 -- added {include_php} tag for BC -- removed @ error suppression -- bugfix fetch did always repeat output of first call when calling same template several times -- PHPunit tests extended - -03/13/2009 -- changed block syntax to be Smarty like {block:titel} -> {block name=titel} -- compiling of {block} and {extend} tags rewriten for better performance -- added special Smarty variable block ($smarty.block.foo} returns the parent definition of block foo -- optimization of {block} tag compiled code. -- fixed problem with escaped double quotes in double quoted strings - -03/12/2009 -- added support of template inheritance by {extend } and {block } tags. -- bugfix comments within literals -- added scope attribuie to {include} tag - -03/10/2009 -- couple of bugfixes and improvements -- PHPunit tests extended - -03/09/2009 -- added support for global template vars. {assign_global...} $smarty->assign_global(...) -- added direct_access_security -- PHPunit tests extended -- added missing {if} tag conditions like "is div by" etc. - -03/08/2009 -- splitted up the Compiler class to make it easier to use a coustom compiler -- made default plugins_dir relative to Smarty root and not current working directory -- some changes to make the lexer parser better configurable -- implemented {section} tag for Smarty2 BC - -03/07/2009 -- fixed problem with comment tags -- fixed problem with #xxxx in double quoted string -- new {while} tag implemented -- made lexer and paser class configurable as $smarty property -- Smarty method get_template_vars implemented -- Smarty method get_registered_object implemented -- Smarty method trigger_error implemented -- PHPunit tests extended - -03/06/2009 -- final changes on config variable handling -- parser change - unquoted strings will by be converted into single quoted strings -- PHPunit tests extended -- some code cleanup -- fixed problem on catenate strings with expression -- update of count_words modifier -- bugfix on comment tags - - -03/05/2009 -- bugfix on tag with caching enabled -- changes on exception handling (by Monte) - -03/04/2009 -- added support for config variables -- bugfix on tag - -03/02/2009 -- fixed unqouted strings within modifier parameter -- bugfix parsing of mofifier parameter - -03/01/2009 -- modifier chaining works now as in Smarty2 - -02/28/2009 -- changed handling of unqouted strings - -02/26/2009 -- bugfix -- changed $smarty.capture.foo to be global for Smarty2 BC. - -02/24/2009 -- bugfix {php} {/php} tags for backward compatibility -- bugfix for expressions on arrays -- fixed usage of "null" value -- added $smarty.foreach.foo.first and $smarty.foreach.foo.last - -02/06/2009 -- bugfix for request variables without index for example $smarty.get -- experimental solution for variable functions in static class - -02/05/2009 -- update of popup plugin -- added config variables to template parser (load config functions still missing) -- parser bugfix for empty quoted strings - -02/03/2009 -- allow array of objects as static class variabales. -- use htmlentities at source output at template errors. - -02/02/2009 -- changed search order on modifiers to look at plugins folder first -- parser bug fix for modifier on array elements $foo.bar|modifier -- parser bug fix on single quoted srings -- internal: splitted up compiler plugin files - -02/01/2009 -- allow method chaining on static classes -- special Smarty variables $smarty.... implemented -- added {PHP} {/PHP} tags for backward compatibility - -01/31/2009 -- added {math} plugin for Smarty2 BC -- added template_exists method -- changed Smarty3 method enable_security() to enableSecurity() to follow camelCase standards - -01/30/2009 -- bugfix in single quoted strings -- changed syntax for variable property access from $foo:property to $foo@property because of ambiguous syntax at modifiers - -01/29/2009 -- syntax for array definition changed from (1,2,3) to [1,2,3] to remove ambiguous syntax -- allow {for $foo in [1,2,3]} syntax -- bugfix in double quoted strings -- allow tags in template even if short_tags are enabled - -01/28/2009 -- fixed '!==' if condition. - -01/28/2009 -- added support of {strip} {/strip} tag. - -01/27/2009 -- bug fix on backticks in double quoted strings at objects - -01/25/2009 -- Smarty2 modfiers added to SVN - -01/25/2009 -- bugfix allow arrays at object properties in Smarty syntax -- the template object is now passed as additional parameter at plugin calls -- clear_compiled_tpl method completed - -01/20/2009 -- access to class constants implemented ( class::CONSTANT ) -- access to static class variables implemented ( class::$variable ) -- call of static class methods implemented ( class::method() ) - -01/16/2009 -- reallow leading _ in variable names {$_var} -- allow array of objects {$array.index->method()} syntax -- finished work on clear_cache and clear_cache_all methods - -01/11/2009 -- added support of {literal} tag -- added support of {ldelim} and {rdelim} tags -- make code compatible to run with E_STRICT error setting - -01/08/2009 -- moved clear_assign and clear_all_assign to internal.templatebase.php -- added assign_by_ref, append and append_by_ref methods - -01/02/2009 -- added load_filter method -- fished work on filter handling -- optimization of plugin loading - -12/30/2008 -- added compiler support of registered object -- added backtick support in doubled quoted strings for backward compatibility -- some minor bug fixes and improvments - -12/23/2008 -- fixed problem of not working "not" operator in if-expressions -- added handling of compiler function plugins -- finished work on (un)register_compiler_function method -- finished work on (un)register_modifier method -- plugin handling from plugins folder changed for modifier plugins - deleted - internal.modifier.php -- added modifier chaining to parser - -12/17/2008 -- finished (un)register_function method -- finished (un)register_block method -- added security checking for PHP functions in PHP templates -- plugin handling from plugins folder rewritten - new - internal.plugin_handler.php - deleted - internal.block.php - deleted - internal.function.php -- removed plugin checking from security handler - -12/16/2008 - -- new start of this change_log file diff --git a/framework/vendor/smarty/smarty/composer.json b/framework/vendor/smarty/smarty/composer.json deleted file mode 100644 index c84b595..0000000 --- a/framework/vendor/smarty/smarty/composer.json +++ /dev/null @@ -1,43 +0,0 @@ -{ - "name": "smarty/smarty", - "type": "library", - "description": "Smarty - the compiling PHP template engine", - "keywords": ["templating"], - "homepage": "http://www.smarty.net", - "license": "LGPL-3.0", - "authors": [ - { - "name": "Monte Ohrt", - "email": "monte@ohrt.com" - }, - { - "name": "Uwe Tews", - "email": "uwe.tews@googlemail.com" - }, - { - "name": "Rodney Rehm", - "email": "rodney.rehm@medialize.de" - } - ], - "support": { - "irc": "irc://irc.freenode.org/smarty", - "issues": "http://code.google.com/p/smarty-php/issues/list", - "forum": "http://www.smarty.net/forums/" - }, - "require": { - "php": ">=5.2" - }, - "autoload": { - "classmap": [ - "libs/Smarty.class.php", - "libs/SmartyBC.class.php", - "libs/sysplugins/smarty_security.php" - ] - }, - "extra": { - "branch-alias": { - "dev-master": "3.1.x-dev" - } - } - -} diff --git a/framework/vendor/smarty/smarty/demo/configs/index.html b/framework/vendor/smarty/smarty/demo/configs/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/demo/configs/test.conf b/framework/vendor/smarty/smarty/demo/configs/test.conf deleted file mode 100644 index 5eac748..0000000 --- a/framework/vendor/smarty/smarty/demo/configs/test.conf +++ /dev/null @@ -1,5 +0,0 @@ -title = Welcome to Smarty! -cutoff_size = 40 - -[setup] -bold = true diff --git a/framework/vendor/smarty/smarty/demo/index.html b/framework/vendor/smarty/smarty/demo/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/demo/index.php b/framework/vendor/smarty/smarty/demo/index.php deleted file mode 100644 index 33f3035..0000000 --- a/framework/vendor/smarty/smarty/demo/index.php +++ /dev/null @@ -1,30 +0,0 @@ -force_compile = true; -$smarty->debugging = true; -$smarty->caching = true; -$smarty->cache_lifetime = 120; - -$smarty->assign("Name", "Fred Irving Johnathan Bradley Peppergill", true); -$smarty->assign("FirstName", array("John", "Mary", "James", "Henry")); -$smarty->assign("LastName", array("Doe", "Smith", "Johnson", "Case")); -$smarty->assign("Class", array(array("A", "B", "C", "D"), array("E", "F", "G", "H"), - array("I", "J", "K", "L"), array("M", "N", "O", "P"))); - -$smarty->assign("contacts", array(array("phone" => "1", "fax" => "2", "cell" => "3"), - array("phone" => "555-4444", "fax" => "555-3333", "cell" => "760-1234"))); - -$smarty->assign("option_values", array("NY", "NE", "KS", "IA", "OK", "TX")); -$smarty->assign("option_output", array("New York", "Nebraska", "Kansas", "Iowa", "Oklahoma", "Texas")); -$smarty->assign("option_selected", "NE"); - -$smarty->display('index.tpl'); diff --git a/framework/vendor/smarty/smarty/demo/plugins/cacheresource.apc.php b/framework/vendor/smarty/smarty/demo/plugins/cacheresource.apc.php deleted file mode 100644 index d7336f2..0000000 --- a/framework/vendor/smarty/smarty/demo/plugins/cacheresource.apc.php +++ /dev/null @@ -1,83 +0,0 @@ - $v) { - $_res[$k] = $v; - } - - return $_res; - } - - /** - * Save values for a set of keys to cache - * - * @param array $keys list of values to save - * @param int $expire expiration time - * - * @return boolean true on success, false on failure - */ - protected function write(array $keys, $expire = null) - { - foreach ($keys as $k => $v) { - apc_store($k, $v, $expire); - } - - return true; - } - - /** - * Remove values from cache - * - * @param array $keys list of keys to delete - * - * @return boolean true on success, false on failure - */ - protected function delete(array $keys) - { - foreach ($keys as $k) { - apc_delete($k); - } - - return true; - } - - /** - * Remove *all* values from cache - * - * @return boolean true on success, false on failure - */ - protected function purge() - { - return apc_clear_cache('user'); - } -} diff --git a/framework/vendor/smarty/smarty/demo/plugins/cacheresource.memcache.php b/framework/vendor/smarty/smarty/demo/plugins/cacheresource.memcache.php deleted file mode 100644 index e265365..0000000 --- a/framework/vendor/smarty/smarty/demo/plugins/cacheresource.memcache.php +++ /dev/null @@ -1,97 +0,0 @@ -memcache = new Memcache(); - $this->memcache->addServer('127.0.0.1', 11211); - } - - /** - * Read values for a set of keys from cache - * - * @param array $keys list of keys to fetch - * - * @return array list of values with the given keys used as indexes - * @return boolean true on success, false on failure - */ - protected function read(array $keys) - { - $_keys = $lookup = array(); - foreach ($keys as $k) { - $_k = sha1($k); - $_keys[] = $_k; - $lookup[$_k] = $k; - } - $_res = array(); - $res = $this->memcache->get($_keys); - foreach ($res as $k => $v) { - $_res[$lookup[$k]] = $v; - } - - return $_res; - } - - /** - * Save values for a set of keys to cache - * - * @param array $keys list of values to save - * @param int $expire expiration time - * - * @return boolean true on success, false on failure - */ - protected function write(array $keys, $expire = null) - { - foreach ($keys as $k => $v) { - $k = sha1($k); - $this->memcache->set($k, $v, 0, $expire); - } - - return true; - } - - /** - * Remove values from cache - * - * @param array $keys list of keys to delete - * - * @return boolean true on success, false on failure - */ - protected function delete(array $keys) - { - foreach ($keys as $k) { - $k = sha1($k); - $this->memcache->delete($k); - } - - return true; - } - - /** - * Remove *all* values from cache - * - * @return boolean true on success, false on failure - */ - protected function purge() - { - $this->memcache->flush(); - } -} diff --git a/framework/vendor/smarty/smarty/demo/plugins/cacheresource.mysql.php b/framework/vendor/smarty/smarty/demo/plugins/cacheresource.mysql.php deleted file mode 100644 index d8d00ab..0000000 --- a/framework/vendor/smarty/smarty/demo/plugins/cacheresource.mysql.php +++ /dev/null @@ -1,162 +0,0 @@ -CREATE TABLE IF NOT EXISTS `output_cache` ( - * `id` CHAR(40) NOT NULL COMMENT 'sha1 hash', - * `name` VARCHAR(250) NOT NULL, - * `cache_id` VARCHAR(250) NULL DEFAULT NULL, - * `compile_id` VARCHAR(250) NULL DEFAULT NULL, - * `modified` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, - * `content` LONGTEXT NOT NULL, - * PRIMARY KEY (`id`), - * INDEX(`name`), - * INDEX(`cache_id`), - * INDEX(`compile_id`), - * INDEX(`modified`) - * ) ENGINE = InnoDB; - * - * @package CacheResource-examples - * @author Rodney Rehm - */ -class Smarty_CacheResource_Mysql extends Smarty_CacheResource_Custom -{ - // PDO instance - protected $db; - protected $fetch; - protected $fetchTimestamp; - protected $save; - - public function __construct() - { - try { - $this->db = new PDO("mysql:dbname=test;host=127.0.0.1", "smarty"); - } - catch (PDOException $e) { - throw new SmartyException('Mysql Resource failed: ' . $e->getMessage()); - } - $this->fetch = $this->db->prepare('SELECT modified, content FROM output_cache WHERE id = :id'); - $this->fetchTimestamp = $this->db->prepare('SELECT modified FROM output_cache WHERE id = :id'); - $this->save = $this->db->prepare('REPLACE INTO output_cache (id, name, cache_id, compile_id, content) - VALUES (:id, :name, :cache_id, :compile_id, :content)'); - } - - /** - * fetch cached content and its modification time from data source - * - * @param string $id unique cache content identifier - * @param string $name template name - * @param string $cache_id cache id - * @param string $compile_id compile id - * @param string $content cached content - * @param integer $mtime cache modification timestamp (epoch) - * - * @return void - */ - protected function fetch($id, $name, $cache_id, $compile_id, &$content, &$mtime) - { - $this->fetch->execute(array('id' => $id)); - $row = $this->fetch->fetch(); - $this->fetch->closeCursor(); - if ($row) { - $content = $row['content']; - $mtime = strtotime($row['modified']); - } else { - $content = null; - $mtime = null; - } - } - - /** - * Fetch cached content's modification timestamp from data source - * - * @note implementing this method is optional. Only implement it if modification times can be accessed faster than loading the complete cached content. - * - * @param string $id unique cache content identifier - * @param string $name template name - * @param string $cache_id cache id - * @param string $compile_id compile id - * - * @return integer|boolean timestamp (epoch) the template was modified, or false if not found - */ - protected function fetchTimestamp($id, $name, $cache_id, $compile_id) - { - $this->fetchTimestamp->execute(array('id' => $id)); - $mtime = strtotime($this->fetchTimestamp->fetchColumn()); - $this->fetchTimestamp->closeCursor(); - - return $mtime; - } - - /** - * Save content to cache - * - * @param string $id unique cache content identifier - * @param string $name template name - * @param string $cache_id cache id - * @param string $compile_id compile id - * @param integer|null $exp_time seconds till expiration time in seconds or null - * @param string $content content to cache - * - * @return boolean success - */ - protected function save($id, $name, $cache_id, $compile_id, $exp_time, $content) - { - $this->save->execute(array( - 'id' => $id, - 'name' => $name, - 'cache_id' => $cache_id, - 'compile_id' => $compile_id, - 'content' => $content, - )); - - return !!$this->save->rowCount(); - } - - /** - * Delete content from cache - * - * @param string $name template name - * @param string $cache_id cache id - * @param string $compile_id compile id - * @param integer|null $exp_time seconds till expiration or null - * - * @return integer number of deleted caches - */ - protected function delete($name, $cache_id, $compile_id, $exp_time) - { - // delete the whole cache - if ($name === null && $cache_id === null && $compile_id === null && $exp_time === null) { - // returning the number of deleted caches would require a second query to count them - $query = $this->db->query('TRUNCATE TABLE output_cache'); - - return - 1; - } - // build the filter - $where = array(); - // equal test name - if ($name !== null) { - $where[] = 'name = ' . $this->db->quote($name); - } - // equal test compile_id - if ($compile_id !== null) { - $where[] = 'compile_id = ' . $this->db->quote($compile_id); - } - // range test expiration time - if ($exp_time !== null) { - $where[] = 'modified < DATE_SUB(NOW(), INTERVAL ' . intval($exp_time) . ' SECOND)'; - } - // equal test cache_id and match sub-groups - if ($cache_id !== null) { - $where[] = '(cache_id = ' . $this->db->quote($cache_id) - . ' OR cache_id LIKE ' . $this->db->quote($cache_id . '|%') . ')'; - } - // run delete query - $query = $this->db->query('DELETE FROM output_cache WHERE ' . join(' AND ', $where)); - - return $query->rowCount(); - } -} diff --git a/framework/vendor/smarty/smarty/demo/plugins/index.html b/framework/vendor/smarty/smarty/demo/plugins/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/demo/plugins/resource.extendsall.php b/framework/vendor/smarty/smarty/demo/plugins/resource.extendsall.php deleted file mode 100644 index 500b3c8..0000000 --- a/framework/vendor/smarty/smarty/demo/plugins/resource.extendsall.php +++ /dev/null @@ -1,60 +0,0 @@ -smarty->getTemplateDir() as $key => $directory) { - try { - $s = Smarty_Resource::source(null, $source->smarty, '[' . $key . ']' . $source->name); - if (!$s->exists) { - continue; - } - $sources[$s->uid] = $s; - $uid .= $s->filepath; - } - catch (SmartyException $e) { - } - } - - if (!$sources) { - $source->exists = false; - $source->template = $_template; - - return; - } - - $sources = array_reverse($sources, true); - reset($sources); - $s = current($sources); - - $source->components = $sources; - $source->filepath = $s->filepath; - $source->uid = sha1($uid); - $source->exists = $exists; - if ($_template && $_template->smarty->compile_check) { - $source->timestamp = $s->timestamp; - } - // need the template at getContent() - $source->template = $_template; - } -} diff --git a/framework/vendor/smarty/smarty/demo/plugins/resource.mysql.php b/framework/vendor/smarty/smarty/demo/plugins/resource.mysql.php deleted file mode 100644 index dfc9606..0000000 --- a/framework/vendor/smarty/smarty/demo/plugins/resource.mysql.php +++ /dev/null @@ -1,81 +0,0 @@ -CREATE TABLE IF NOT EXISTS `templates` ( - * `name` varchar(100) NOT NULL, - * `modified` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, - * `source` text, - * PRIMARY KEY (`name`) - * ) ENGINE=InnoDB DEFAULT CHARSET=utf8; - * Demo data: - *
INSERT INTO `templates` (`name`, `modified`, `source`) VALUES ('test.tpl', "2010-12-25 22:00:00", '{$x="hello world"}{$x}');
- * - * @package Resource-examples - * @author Rodney Rehm - */ -class Smarty_Resource_Mysql extends Smarty_Resource_Custom -{ - // PDO instance - protected $db; - // prepared fetch() statement - protected $fetch; - // prepared fetchTimestamp() statement - protected $mtime; - - public function __construct() - { - try { - $this->db = new PDO("mysql:dbname=test;host=127.0.0.1", "smarty"); - } - catch (PDOException $e) { - throw new SmartyException('Mysql Resource failed: ' . $e->getMessage()); - } - $this->fetch = $this->db->prepare('SELECT modified, source FROM templates WHERE name = :name'); - $this->mtime = $this->db->prepare('SELECT modified FROM templates WHERE name = :name'); - } - - /** - * Fetch a template and its modification time from database - * - * @param string $name template name - * @param string $source template source - * @param integer $mtime template modification timestamp (epoch) - * - * @return void - */ - protected function fetch($name, &$source, &$mtime) - { - $this->fetch->execute(array('name' => $name)); - $row = $this->fetch->fetch(); - $this->fetch->closeCursor(); - if ($row) { - $source = $row['source']; - $mtime = strtotime($row['modified']); - } else { - $source = null; - $mtime = null; - } - } - - /** - * Fetch a template's modification time from database - * - * @note implementing this method is optional. Only implement it if modification times can be accessed faster than loading the comple template source. - * - * @param string $name template name - * - * @return integer timestamp (epoch) the template was modified - */ - protected function fetchTimestamp($name) - { - $this->mtime->execute(array('name' => $name)); - $mtime = $this->mtime->fetchColumn(); - $this->mtime->closeCursor(); - - return strtotime($mtime); - } -} diff --git a/framework/vendor/smarty/smarty/demo/plugins/resource.mysqls.php b/framework/vendor/smarty/smarty/demo/plugins/resource.mysqls.php deleted file mode 100644 index f694ddf..0000000 --- a/framework/vendor/smarty/smarty/demo/plugins/resource.mysqls.php +++ /dev/null @@ -1,62 +0,0 @@ -CREATE TABLE IF NOT EXISTS `templates` ( - * `name` varchar(100) NOT NULL, - * `modified` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, - * `source` text, - * PRIMARY KEY (`name`) - * ) ENGINE=InnoDB DEFAULT CHARSET=utf8; - * Demo data: - *
INSERT INTO `templates` (`name`, `modified`, `source`) VALUES ('test.tpl', "2010-12-25 22:00:00", '{$x="hello world"}{$x}');
- * - * @package Resource-examples - * @author Rodney Rehm - */ -class Smarty_Resource_Mysqls extends Smarty_Resource_Custom -{ - // PDO instance - protected $db; - // prepared fetch() statement - protected $fetch; - - public function __construct() - { - try { - $this->db = new PDO("mysql:dbname=test;host=127.0.0.1", "smarty"); - } - catch (PDOException $e) { - throw new SmartyException('Mysql Resource failed: ' . $e->getMessage()); - } - $this->fetch = $this->db->prepare('SELECT modified, source FROM templates WHERE name = :name'); - } - - /** - * Fetch a template and its modification time from database - * - * @param string $name template name - * @param string $source template source - * @param integer $mtime template modification timestamp (epoch) - * - * @return void - */ - protected function fetch($name, &$source, &$mtime) - { - $this->fetch->execute(array('name' => $name)); - $row = $this->fetch->fetch(); - $this->fetch->closeCursor(); - if ($row) { - $source = $row['source']; - $mtime = strtotime($row['modified']); - } else { - $source = null; - $mtime = null; - } - } -} diff --git a/framework/vendor/smarty/smarty/demo/templates/footer.tpl b/framework/vendor/smarty/smarty/demo/templates/footer.tpl deleted file mode 100644 index e04310f..0000000 --- a/framework/vendor/smarty/smarty/demo/templates/footer.tpl +++ /dev/null @@ -1,2 +0,0 @@ - - diff --git a/framework/vendor/smarty/smarty/demo/templates/header.tpl b/framework/vendor/smarty/smarty/demo/templates/header.tpl deleted file mode 100644 index 13fa6cb..0000000 --- a/framework/vendor/smarty/smarty/demo/templates/header.tpl +++ /dev/null @@ -1,5 +0,0 @@ - - - {$title} - {$Name} - - diff --git a/framework/vendor/smarty/smarty/demo/templates/index.html b/framework/vendor/smarty/smarty/demo/templates/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/demo/templates/index.tpl b/framework/vendor/smarty/smarty/demo/templates/index.tpl deleted file mode 100644 index 1fbb6d3..0000000 --- a/framework/vendor/smarty/smarty/demo/templates/index.tpl +++ /dev/null @@ -1,87 +0,0 @@ -{config_load file="test.conf" section="setup"} -{include file="header.tpl" title=foo} - -
-
-{* bold and title are read from the config file *}
-    {if #bold#}{/if}
-        {* capitalize the first letters of each word of the title *}
-        Title: {#title#|capitalize}
-        {if #bold#}{/if}
-
-    The current date and time is {$smarty.now|date_format:"%Y-%m-%d %H:%M:%S"}
-
-    The value of global assigned variable $SCRIPT_NAME is {$SCRIPT_NAME}
-
-    Example of accessing server environment variable SERVER_NAME: {$smarty.server.SERVER_NAME}
-
-    The value of {ldelim}$Name{rdelim} is {$Name}
-
-variable modifier example of {ldelim}$Name|upper{rdelim}
-
-{$Name|upper}
-
-
-An example of a section loop:
-
-    {section name=outer
-    loop=$FirstName}
-        {if $smarty.section.outer.index is odd by 2}
-            {$smarty.section.outer.rownum} . {$FirstName[outer]} {$LastName[outer]}
-        {else}
-            {$smarty.section.outer.rownum} * {$FirstName[outer]} {$LastName[outer]}
-        {/if}
-        {sectionelse}
-        none
-    {/section}
-
-    An example of section looped key values:
-
-    {section name=sec1 loop=$contacts}
-        phone: {$contacts[sec1].phone}
-        
- - fax: {$contacts[sec1].fax} -
- - cell: {$contacts[sec1].cell} -
- {/section} -

- - testing strip tags - {strip} - - - - -
- - This is a test - -
- {/strip} - -

- -This is an example of the html_select_date function: - -
- {html_select_date start_year=1998 end_year=2010} -
- -This is an example of the html_select_time function: - -
- {html_select_time use_24_hours=false} -
- -This is an example of the html_options function: - -
- -
- -{include file="footer.tpl"} diff --git a/framework/vendor/smarty/smarty/index.html b/framework/vendor/smarty/smarty/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/libs/Smarty.class.php b/framework/vendor/smarty/smarty/libs/Smarty.class.php deleted file mode 100644 index ea5b9ce..0000000 --- a/framework/vendor/smarty/smarty/libs/Smarty.class.php +++ /dev/null @@ -1,1674 +0,0 @@ - - * @author Uwe Tews - * @author Rodney Rehm - * @package Smarty - * @version 3.1-DEV - */ - -/** - * define shorthand directory separator constant - */ -if (!defined('DS')) { - define('DS', DIRECTORY_SEPARATOR); -} - -/** - * set SMARTY_DIR to absolute path to Smarty library files. - * Sets SMARTY_DIR only if user application has not already defined it. - */ -if (!defined('SMARTY_DIR')) { - define('SMARTY_DIR', dirname(__FILE__) . DS); -} - -/** - * set SMARTY_SYSPLUGINS_DIR to absolute path to Smarty internal plugins. - * Sets SMARTY_SYSPLUGINS_DIR only if user application has not already defined it. - */ -if (!defined('SMARTY_SYSPLUGINS_DIR')) { - define('SMARTY_SYSPLUGINS_DIR', SMARTY_DIR . 'sysplugins' . DS); -} -if (!defined('SMARTY_PLUGINS_DIR')) { - define('SMARTY_PLUGINS_DIR', SMARTY_DIR . 'plugins' . DS); -} -if (!defined('SMARTY_MBSTRING')) { - define('SMARTY_MBSTRING', function_exists('mb_split')); -} -if (!defined('SMARTY_RESOURCE_CHAR_SET')) { - // UTF-8 can only be done properly when mbstring is available! - /** - * @deprecated in favor of Smarty::$_CHARSET - */ - define('SMARTY_RESOURCE_CHAR_SET', SMARTY_MBSTRING ? 'UTF-8' : 'ISO-8859-1'); -} -if (!defined('SMARTY_RESOURCE_DATE_FORMAT')) { - /** - * @deprecated in favor of Smarty::$_DATE_FORMAT - */ - define('SMARTY_RESOURCE_DATE_FORMAT', '%b %e, %Y'); -} - -/** - * register the class autoloader - */ -if (!defined('SMARTY_SPL_AUTOLOAD')) { - define('SMARTY_SPL_AUTOLOAD', 0); -} - -if (SMARTY_SPL_AUTOLOAD && set_include_path(get_include_path() . PATH_SEPARATOR . SMARTY_SYSPLUGINS_DIR) !== false) { - $registeredAutoLoadFunctions = spl_autoload_functions(); - if (!isset($registeredAutoLoadFunctions['spl_autoload'])) { - spl_autoload_register(); - } -} else { - spl_autoload_register('smartyAutoload'); -} - -/** - * Load always needed external class files - */ -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_internal_data.php'; -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_internal_templatebase.php'; -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_internal_template.php'; -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_resource.php'; -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_internal_resource_file.php'; -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_cacheresource.php'; -include_once SMARTY_SYSPLUGINS_DIR . 'smarty_internal_cacheresource_file.php'; - -/** - * This is the main Smarty class - * - * @package Smarty - */ -class Smarty extends Smarty_Internal_TemplateBase -{ - /**#@+ - * constant definitions - */ - - /** - * smarty version - */ - const SMARTY_VERSION = 'Smarty-3.1.19-dev'; - - /** - * define variable scopes - */ - const SCOPE_LOCAL = 0; - const SCOPE_PARENT = 1; - const SCOPE_ROOT = 2; - const SCOPE_GLOBAL = 3; - /** - * define caching modes - */ - const CACHING_OFF = 0; - const CACHING_LIFETIME_CURRENT = 1; - const CACHING_LIFETIME_SAVED = 2; - /** - * define constant for clearing cache files be saved expiration datees - */ - const CLEAR_EXPIRED = - 1; - - /** - * define compile check modes - */ - const COMPILECHECK_OFF = 0; - const COMPILECHECK_ON = 1; - const COMPILECHECK_CACHEMISS = 2; - /** - * modes for handling of "" tags in templates. - */ - const PHP_PASSTHRU = 0; //-> print tags as plain text - const PHP_QUOTE = 1; //-> escape tags as entities - const PHP_REMOVE = 2; //-> escape tags as entities - const PHP_ALLOW = 3; //-> escape tags as entities - /** - * filter types - */ - const FILTER_POST = 'post'; - const FILTER_PRE = 'pre'; - const FILTER_OUTPUT = 'output'; - const FILTER_VARIABLE = 'variable'; - /** - * plugin types - */ - const PLUGIN_FUNCTION = 'function'; - const PLUGIN_BLOCK = 'block'; - const PLUGIN_COMPILER = 'compiler'; - const PLUGIN_MODIFIER = 'modifier'; - const PLUGIN_MODIFIERCOMPILER = 'modifiercompiler'; - - /**#@-*/ - - /** - * assigned global tpl vars - */ - public static $global_tpl_vars = array(); - - /** - * error handler returned by set_error_hanlder() in Smarty::muteExpectedErrors() - */ - public static $_previous_error_handler = null; - /** - * contains directories outside of SMARTY_DIR that are to be muted by muteExpectedErrors() - */ - public static $_muted_directories = array(); - /** - * Flag denoting if Multibyte String functions are available - */ - public static $_MBSTRING = SMARTY_MBSTRING; - /** - * The character set to adhere to (e.g. "UTF-8") - */ - public static $_CHARSET = SMARTY_RESOURCE_CHAR_SET; - /** - * The date format to be used internally - * (accepts date() and strftime()) - */ - public static $_DATE_FORMAT = SMARTY_RESOURCE_DATE_FORMAT; - /** - * Flag denoting if PCRE should run in UTF-8 mode - */ - public static $_UTF8_MODIFIER = 'u'; - - /** - * Flag denoting if operating system is windows - */ - public static $_IS_WINDOWS = false; - - /**#@+ - * variables - */ - - /** - * auto literal on delimiters with whitspace - * - * @var boolean - */ - public $auto_literal = true; - /** - * display error on not assigned variables - * - * @var boolean - */ - public $error_unassigned = false; - /** - * look up relative filepaths in include_path - * - * @var boolean - */ - public $use_include_path = false; - /** - * template directory - * - * @var array - */ - private $template_dir = array(); - /** - * joined template directory string used in cache keys - * - * @var string - */ - public $joined_template_dir = null; - /** - * joined config directory string used in cache keys - * - * @var string - */ - public $joined_config_dir = null; - /** - * default template handler - * - * @var callable - */ - public $default_template_handler_func = null; - /** - * default config handler - * - * @var callable - */ - public $default_config_handler_func = null; - /** - * default plugin handler - * - * @var callable - */ - public $default_plugin_handler_func = null; - /** - * compile directory - * - * @var string - */ - private $compile_dir = null; - /** - * plugins directory - * - * @var array - */ - private $plugins_dir = array(); - /** - * cache directory - * - * @var string - */ - private $cache_dir = null; - /** - * config directory - * - * @var array - */ - private $config_dir = array(); - /** - * force template compiling? - * - * @var boolean - */ - public $force_compile = false; - /** - * check template for modifications? - * - * @var boolean - */ - public $compile_check = true; - /** - * use sub dirs for compiled/cached files? - * - * @var boolean - */ - public $use_sub_dirs = false; - /** - * allow ambiguous resources (that are made unique by the resource handler) - * - * @var boolean - */ - public $allow_ambiguous_resources = false; - /** - * caching enabled - * - * @var boolean - */ - public $caching = false; - /** - * merge compiled includes - * - * @var boolean - */ - public $merge_compiled_includes = false; - /** - * template inheritance merge compiled includes - * - * @var boolean - */ - public $inheritance_merge_compiled_includes = true; - /** - * cache lifetime in seconds - * - * @var integer - */ - public $cache_lifetime = 3600; - /** - * force cache file creation - * - * @var boolean - */ - public $force_cache = false; - /** - * Set this if you want different sets of cache files for the same - * templates. - * - * @var string - */ - public $cache_id = null; - /** - * Set this if you want different sets of compiled files for the same - * templates. - * - * @var string - */ - public $compile_id = null; - /** - * template left-delimiter - * - * @var string - */ - public $left_delimiter = "{"; - /** - * template right-delimiter - * - * @var string - */ - public $right_delimiter = "}"; - /**#@+ - * security - */ - /** - * class name - * This should be instance of Smarty_Security. - * - * @var string - * @see Smarty_Security - */ - public $security_class = 'Smarty_Security'; - /** - * implementation of security class - * - * @var Smarty_Security - */ - public $security_policy = null; - /** - * controls handling of PHP-blocks - * - * @var integer - */ - public $php_handling = self::PHP_PASSTHRU; - /** - * controls if the php template file resource is allowed - * - * @var bool - */ - public $allow_php_templates = false; - /** - * Should compiled-templates be prevented from being called directly? - * {@internal - * Currently used by Smarty_Internal_Template only. - * }} - * - * @var boolean - */ - public $direct_access_security = true; - /**#@-*/ - /** - * debug mode - * Setting this to true enables the debug-console. - * - * @var boolean - */ - public $debugging = false; - /** - * This determines if debugging is enable-able from the browser. - *
    - *
  • NONE => no debugging control allowed
  • - *
  • URL => enable debugging when SMARTY_DEBUG is found in the URL.
  • - *
- * - * @var string - */ - public $debugging_ctrl = 'NONE'; - /** - * Name of debugging URL-param. - * Only used when $debugging_ctrl is set to 'URL'. - * The name of the URL-parameter that activates debugging. - * - * @var type - */ - public $smarty_debug_id = 'SMARTY_DEBUG'; - /** - * Path of debug template. - * - * @var string - */ - public $debug_tpl = null; - /** - * When set, smarty uses this value as error_reporting-level. - * - * @var int - */ - public $error_reporting = null; - /** - * Internal flag for getTags() - * - * @var boolean - */ - public $get_used_tags = false; - - /**#@+ - * config var settings - */ - - /** - * Controls whether variables with the same name overwrite each other. - * - * @var boolean - */ - public $config_overwrite = true; - /** - * Controls whether config values of on/true/yes and off/false/no get converted to boolean. - * - * @var boolean - */ - public $config_booleanize = true; - /** - * Controls whether hidden config sections/vars are read from the file. - * - * @var boolean - */ - public $config_read_hidden = false; - - /**#@-*/ - - /**#@+ - * resource locking - */ - - /** - * locking concurrent compiles - * - * @var boolean - */ - public $compile_locking = true; - /** - * Controls whether cache resources should emply locking mechanism - * - * @var boolean - */ - public $cache_locking = false; - /** - * seconds to wait for acquiring a lock before ignoring the write lock - * - * @var float - */ - public $locking_timeout = 10; - - /**#@-*/ - - /** - * global template functions - * - * @var array - */ - public $template_functions = array(); - /** - * resource type used if none given - * Must be an valid key of $registered_resources. - * - * @var string - */ - public $default_resource_type = 'file'; - /** - * caching type - * Must be an element of $cache_resource_types. - * - * @var string - */ - public $caching_type = 'file'; - /** - * internal config properties - * - * @var array - */ - public $properties = array(); - /** - * config type - * - * @var string - */ - public $default_config_type = 'file'; - /** - * cached template objects - * - * @var array - */ - public $template_objects = array(); - /** - * check If-Modified-Since headers - * - * @var boolean - */ - public $cache_modified_check = false; - /** - * registered plugins - * - * @var array - */ - public $registered_plugins = array(); - /** - * plugin search order - * - * @var array - */ - public $plugin_search_order = array('function', 'block', 'compiler', 'class'); - /** - * registered objects - * - * @var array - */ - public $registered_objects = array(); - /** - * registered classes - * - * @var array - */ - public $registered_classes = array(); - /** - * registered filters - * - * @var array - */ - public $registered_filters = array(); - /** - * registered resources - * - * @var array - */ - public $registered_resources = array(); - /** - * resource handler cache - * - * @var array - */ - public $_resource_handlers = array(); - /** - * registered cache resources - * - * @var array - */ - public $registered_cache_resources = array(); - /** - * cache resource handler cache - * - * @var array - */ - public $_cacheresource_handlers = array(); - /** - * autoload filter - * - * @var array - */ - public $autoload_filters = array(); - /** - * default modifier - * - * @var array - */ - public $default_modifiers = array(); - /** - * autoescape variable output - * - * @var boolean - */ - public $escape_html = false; - /** - * global internal smarty vars - * - * @var array - */ - public static $_smarty_vars = array(); - /** - * start time for execution time calculation - * - * @var int - */ - public $start_time = 0; - /** - * default file permissions - * - * @var int - */ - public $_file_perms = 0644; - /** - * default dir permissions - * - * @var int - */ - public $_dir_perms = 0771; - /** - * block tag hierarchy - * - * @var array - */ - public $_tag_stack = array(); - /** - * self pointer to Smarty object - * - * @var Smarty - */ - public $smarty; - /** - * required by the compiler for BC - * - * @var string - */ - public $_current_file = null; - /** - * internal flag to enable parser debugging - * - * @var bool - */ - public $_parserdebug = false; - /** - * Saved parameter of merged templates during compilation - * - * @var array - */ - public $merged_templates_func = array(); - /**#@-*/ - - /** - * Initialize new Smarty object - - */ - public function __construct() - { - // selfpointer needed by some other class methods - $this->smarty = $this; - if (is_callable('mb_internal_encoding')) { - mb_internal_encoding(Smarty::$_CHARSET); - } - $this->start_time = microtime(true); - // set default dirs - $this->setTemplateDir('.' . DS . 'templates' . DS) - ->setCompileDir('.' . DS . 'templates_c' . DS) - ->setPluginsDir(SMARTY_PLUGINS_DIR) - ->setCacheDir('.' . DS . 'cache' . DS) - ->setConfigDir('.' . DS . 'configs' . DS); - - $this->debug_tpl = 'file:' . dirname(__FILE__) . '/debug.tpl'; - if (isset($_SERVER['SCRIPT_NAME'])) { - $this->assignGlobal('SCRIPT_NAME', $_SERVER['SCRIPT_NAME']); - } - } - - /** - * Class destructor - */ - public function __destruct() - { - // intentionally left blank - } - - /** - * <> set selfpointer on cloned object - */ - public function __clone() - { - $this->smarty = $this; - } - - /** - * <> Generic getter. - * Calls the appropriate getter function. - * Issues an E_USER_NOTICE if no valid getter is found. - * - * @param string $name property name - * - * @return mixed - */ - public function __get($name) - { - $allowed = array( - 'template_dir' => 'getTemplateDir', - 'config_dir' => 'getConfigDir', - 'plugins_dir' => 'getPluginsDir', - 'compile_dir' => 'getCompileDir', - 'cache_dir' => 'getCacheDir', - ); - - if (isset($allowed[$name])) { - return $this->{$allowed[$name]}(); - } else { - trigger_error('Undefined property: ' . get_class($this) . '::$' . $name, E_USER_NOTICE); - } - } - - /** - * <> Generic setter. - * Calls the appropriate setter function. - * Issues an E_USER_NOTICE if no valid setter is found. - * - * @param string $name property name - * @param mixed $value parameter passed to setter - */ - public function __set($name, $value) - { - $allowed = array( - 'template_dir' => 'setTemplateDir', - 'config_dir' => 'setConfigDir', - 'plugins_dir' => 'setPluginsDir', - 'compile_dir' => 'setCompileDir', - 'cache_dir' => 'setCacheDir', - ); - - if (isset($allowed[$name])) { - $this->{$allowed[$name]}($value); - } else { - trigger_error('Undefined property: ' . get_class($this) . '::$' . $name, E_USER_NOTICE); - } - } - - /** - * Check if a template resource exists - * - * @param string $resource_name template name - * - * @return boolean status - */ - public function templateExists($resource_name) - { - // create template object - $save = $this->template_objects; - $tpl = new $this->template_class($resource_name, $this); - // check if it does exists - $result = $tpl->source->exists; - $this->template_objects = $save; - - return $result; - } - - /** - * Returns a single or all global variables - * - * @param string $varname variable name or null - * - * @return string variable value or or array of variables - */ - public function getGlobal($varname = null) - { - if (isset($varname)) { - if (isset(self::$global_tpl_vars[$varname])) { - return self::$global_tpl_vars[$varname]->value; - } else { - return ''; - } - } else { - $_result = array(); - foreach (self::$global_tpl_vars AS $key => $var) { - $_result[$key] = $var->value; - } - - return $_result; - } - } - - /** - * Empty cache folder - * - * @param integer $exp_time expiration time - * @param string $type resource type - * - * @return integer number of cache files deleted - */ - public function clearAllCache($exp_time = null, $type = null) - { - // load cache resource and call clearAll - $_cache_resource = Smarty_CacheResource::load($this, $type); - Smarty_CacheResource::invalidLoadedCache($this); - - return $_cache_resource->clearAll($this, $exp_time); - } - - /** - * Empty cache for a specific template - * - * @param string $template_name template name - * @param string $cache_id cache id - * @param string $compile_id compile id - * @param integer $exp_time expiration time - * @param string $type resource type - * - * @return integer number of cache files deleted - */ - public function clearCache($template_name, $cache_id = null, $compile_id = null, $exp_time = null, $type = null) - { - // load cache resource and call clear - $_cache_resource = Smarty_CacheResource::load($this, $type); - Smarty_CacheResource::invalidLoadedCache($this); - - return $_cache_resource->clear($this, $template_name, $cache_id, $compile_id, $exp_time); - } - - /** - * Loads security class and enables security - * - * @param string|Smarty_Security $security_class if a string is used, it must be class-name - * - * @return Smarty current Smarty instance for chaining - * @throws SmartyException when an invalid class name is provided - */ - public function enableSecurity($security_class = null) - { - if ($security_class instanceof Smarty_Security) { - $this->security_policy = $security_class; - - return $this; - } elseif (is_object($security_class)) { - throw new SmartyException("Class '" . get_class($security_class) . "' must extend Smarty_Security."); - } - if ($security_class == null) { - $security_class = $this->security_class; - } - if (!class_exists($security_class)) { - throw new SmartyException("Security class '$security_class' is not defined"); - } elseif ($security_class !== 'Smarty_Security' && !is_subclass_of($security_class, 'Smarty_Security')) { - throw new SmartyException("Class '$security_class' must extend Smarty_Security."); - } else { - $this->security_policy = new $security_class($this); - } - - return $this; - } - - /** - * Disable security - * - * @return Smarty current Smarty instance for chaining - */ - public function disableSecurity() - { - $this->security_policy = null; - - return $this; - } - - /** - * Set template directory - * - * @param string|array $template_dir directory(s) of template sources - * - * @return Smarty current Smarty instance for chaining - */ - public function setTemplateDir($template_dir) - { - $this->template_dir = array(); - foreach ((array) $template_dir as $k => $v) { - $this->template_dir[$k] = preg_replace('#(\w+)(/|\\\\){1,}#', '$1$2', rtrim($v, '/\\')) . DS; - } - - $this->joined_template_dir = join(DIRECTORY_SEPARATOR, $this->template_dir); - - return $this; - } - - /** - * Add template directory(s) - * - * @param string|array $template_dir directory(s) of template sources - * @param string $key of the array element to assign the template dir to - * - * @return Smarty current Smarty instance for chaining - * @throws SmartyException when the given template directory is not valid - */ - public function addTemplateDir($template_dir, $key = null) - { - // make sure we're dealing with an array - $this->template_dir = (array) $this->template_dir; - - if (is_array($template_dir)) { - foreach ($template_dir as $k => $v) { - $v = preg_replace('#(\w+)(/|\\\\){1,}#', '$1$2', rtrim($v, '/\\')) . DS; - if (is_int($k)) { - // indexes are not merged but appended - $this->template_dir[] = $v; - } else { - // string indexes are overridden - $this->template_dir[$k] = $v; - } - } - } else { - $v = preg_replace('#(\w+)(/|\\\\){1,}#', '$1$2', rtrim($template_dir, '/\\')) . DS; - if ($key !== null) { - // override directory at specified index - $this->template_dir[$key] = $v; - } else { - // append new directory - $this->template_dir[] = $v; - } - } - $this->joined_template_dir = join(DIRECTORY_SEPARATOR, $this->template_dir); - - return $this; - } - - /** - * Get template directories - * - * @param mixed $index index of directory to get, null to get all - * - * @return array|string list of template directories, or directory of $index - */ - public function getTemplateDir($index = null) - { - if ($index !== null) { - return isset($this->template_dir[$index]) ? $this->template_dir[$index] : null; - } - - return (array) $this->template_dir; - } - - /** - * Set config directory - * - * @param $config_dir - * - * @return Smarty current Smarty instance for chaining - */ - public function setConfigDir($config_dir) - { - $this->config_dir = array(); - foreach ((array) $config_dir as $k => $v) { - $this->config_dir[$k] = preg_replace('#(\w+)(/|\\\\){1,}#', '$1$2', rtrim($v, '/\\')) . DS; - } - - $this->joined_config_dir = join(DIRECTORY_SEPARATOR, $this->config_dir); - - return $this; - } - - /** - * Add config directory(s) - * - * @param string|array $config_dir directory(s) of config sources - * @param mixed $key key of the array element to assign the config dir to - * - * @return Smarty current Smarty instance for chaining - */ - public function addConfigDir($config_dir, $key = null) - { - // make sure we're dealing with an array - $this->config_dir = (array) $this->config_dir; - - if (is_array($config_dir)) { - foreach ($config_dir as $k => $v) { - $v = preg_replace('#(\w+)(/|\\\\){1,}#', '$1$2', rtrim($v, '/\\')) . DS; - if (is_int($k)) { - // indexes are not merged but appended - $this->config_dir[] = $v; - } else { - // string indexes are overridden - $this->config_dir[$k] = $v; - } - } - } else { - $v = preg_replace('#(\w+)(/|\\\\){1,}#', '$1$2', rtrim($config_dir, '/\\')) . DS; - if ($key !== null) { - // override directory at specified index - $this->config_dir[$key] = rtrim($v, '/\\') . DS; - } else { - // append new directory - $this->config_dir[] = rtrim($v, '/\\') . DS; - } - } - - $this->joined_config_dir = join(DIRECTORY_SEPARATOR, $this->config_dir); - - return $this; - } - - /** - * Get config directory - * - * @param mixed $index index of directory to get, null to get all - * - * @return array|string configuration directory - */ - public function getConfigDir($index = null) - { - if ($index !== null) { - return isset($this->config_dir[$index]) ? $this->config_dir[$index] : null; - } - - return (array) $this->config_dir; - } - - /** - * Set plugins directory - * - * @param string|array $plugins_dir directory(s) of plugins - * - * @return Smarty current Smarty instance for chaining - */ - public function setPluginsDir($plugins_dir) - { - $this->plugins_dir = array(); - foreach ((array) $plugins_dir as $k => $v) { - $this->plugins_dir[$k] = rtrim($v, '/\\') . DS; - } - - return $this; - } - - /** - * Adds directory of plugin files - * - * @param $plugins_dir - * - * @return Smarty current Smarty instance for chaining - */ - public function addPluginsDir($plugins_dir) - { - // make sure we're dealing with an array - $this->plugins_dir = (array) $this->plugins_dir; - - if (is_array($plugins_dir)) { - foreach ($plugins_dir as $k => $v) { - if (is_int($k)) { - // indexes are not merged but appended - $this->plugins_dir[] = rtrim($v, '/\\') . DS; - } else { - // string indexes are overridden - $this->plugins_dir[$k] = rtrim($v, '/\\') . DS; - } - } - } else { - // append new directory - $this->plugins_dir[] = rtrim($plugins_dir, '/\\') . DS; - } - - $this->plugins_dir = array_unique($this->plugins_dir); - - return $this; - } - - /** - * Get plugin directories - * - * @return array list of plugin directories - */ - public function getPluginsDir() - { - return (array) $this->plugins_dir; - } - - /** - * Set compile directory - * - * @param string $compile_dir directory to store compiled templates in - * - * @return Smarty current Smarty instance for chaining - */ - public function setCompileDir($compile_dir) - { - $this->compile_dir = rtrim($compile_dir, '/\\') . DS; - if (!isset(Smarty::$_muted_directories[$this->compile_dir])) { - Smarty::$_muted_directories[$this->compile_dir] = null; - } - - return $this; - } - - /** - * Get compiled directory - * - * @return string path to compiled templates - */ - public function getCompileDir() - { - return $this->compile_dir; - } - - /** - * Set cache directory - * - * @param string $cache_dir directory to store cached templates in - * - * @return Smarty current Smarty instance for chaining - */ - public function setCacheDir($cache_dir) - { - $this->cache_dir = rtrim($cache_dir, '/\\') . DS; - if (!isset(Smarty::$_muted_directories[$this->cache_dir])) { - Smarty::$_muted_directories[$this->cache_dir] = null; - } - - return $this; - } - - /** - * Get cache directory - * - * @return string path of cache directory - */ - public function getCacheDir() - { - return $this->cache_dir; - } - - /** - * Set default modifiers - * - * @param array|string $modifiers modifier or list of modifiers to set - * - * @return Smarty current Smarty instance for chaining - */ - public function setDefaultModifiers($modifiers) - { - $this->default_modifiers = (array) $modifiers; - - return $this; - } - - /** - * Add default modifiers - * - * @param array|string $modifiers modifier or list of modifiers to add - * - * @return Smarty current Smarty instance for chaining - */ - public function addDefaultModifiers($modifiers) - { - if (is_array($modifiers)) { - $this->default_modifiers = array_merge($this->default_modifiers, $modifiers); - } else { - $this->default_modifiers[] = $modifiers; - } - - return $this; - } - - /** - * Get default modifiers - * - * @return array list of default modifiers - */ - public function getDefaultModifiers() - { - return $this->default_modifiers; - } - - /** - * Set autoload filters - * - * @param array $filters filters to load automatically - * @param string $type "pre", "output", … specify the filter type to set. Defaults to none treating $filters' keys as the appropriate types - * - * @return Smarty current Smarty instance for chaining - */ - public function setAutoloadFilters($filters, $type = null) - { - if ($type !== null) { - $this->autoload_filters[$type] = (array) $filters; - } else { - $this->autoload_filters = (array) $filters; - } - - return $this; - } - - /** - * Add autoload filters - * - * @param array $filters filters to load automatically - * @param string $type "pre", "output", … specify the filter type to set. Defaults to none treating $filters' keys as the appropriate types - * - * @return Smarty current Smarty instance for chaining - */ - public function addAutoloadFilters($filters, $type = null) - { - if ($type !== null) { - if (!empty($this->autoload_filters[$type])) { - $this->autoload_filters[$type] = array_merge($this->autoload_filters[$type], (array) $filters); - } else { - $this->autoload_filters[$type] = (array) $filters; - } - } else { - foreach ((array) $filters as $key => $value) { - if (!empty($this->autoload_filters[$key])) { - $this->autoload_filters[$key] = array_merge($this->autoload_filters[$key], (array) $value); - } else { - $this->autoload_filters[$key] = (array) $value; - } - } - } - - return $this; - } - - /** - * Get autoload filters - * - * @param string $type type of filter to get autoloads for. Defaults to all autoload filters - * - * @return array array( 'type1' => array( 'filter1', 'filter2', … ) ) or array( 'filter1', 'filter2', …) if $type was specified - */ - public function getAutoloadFilters($type = null) - { - if ($type !== null) { - return isset($this->autoload_filters[$type]) ? $this->autoload_filters[$type] : array(); - } - - return $this->autoload_filters; - } - - /** - * return name of debugging template - * - * @return string - */ - public function getDebugTemplate() - { - return $this->debug_tpl; - } - - /** - * set the debug template - * - * @param string $tpl_name - * - * @return Smarty current Smarty instance for chaining - * @throws SmartyException if file is not readable - */ - public function setDebugTemplate($tpl_name) - { - if (!is_readable($tpl_name)) { - throw new SmartyException("Unknown file '{$tpl_name}'"); - } - $this->debug_tpl = $tpl_name; - - return $this; - } - - /** - * creates a template object - * - * @param string $template the resource handle of the template file - * @param mixed $cache_id cache id to be used with this template - * @param mixed $compile_id compile id to be used with this template - * @param object $parent next higher level of Smarty variables - * @param boolean $do_clone flag is Smarty object shall be cloned - * - * @return object template object - */ - public function createTemplate($template, $cache_id = null, $compile_id = null, $parent = null, $do_clone = true) - { - if ($cache_id !== null && (is_object($cache_id) || is_array($cache_id))) { - $parent = $cache_id; - $cache_id = null; - } - if ($parent !== null && is_array($parent)) { - $data = $parent; - $parent = null; - } else { - $data = null; - } - // default to cache_id and compile_id of Smarty object - $cache_id = $cache_id === null ? $this->cache_id : $cache_id; - $compile_id = $compile_id === null ? $this->compile_id : $compile_id; - // already in template cache? - if ($this->allow_ambiguous_resources) { - $_templateId = Smarty_Resource::getUniqueTemplateName($this, $template) . $cache_id . $compile_id; - } else { - $_templateId = $this->joined_template_dir . '#' . $template . $cache_id . $compile_id; - } - if (isset($_templateId[150])) { - $_templateId = sha1($_templateId); - } - if ($do_clone) { - if (isset($this->template_objects[$_templateId])) { - // return cached template object - $tpl = clone $this->template_objects[$_templateId]; - $tpl->smarty = clone $tpl->smarty; - $tpl->parent = $parent; - $tpl->tpl_vars = array(); - $tpl->config_vars = array(); - } else { - $tpl = new $this->template_class($template, clone $this, $parent, $cache_id, $compile_id); - } - } else { - if (isset($this->template_objects[$_templateId])) { - // return cached template object - $tpl = $this->template_objects[$_templateId]; - $tpl->parent = $parent; - $tpl->tpl_vars = array(); - $tpl->config_vars = array(); - } else { - $tpl = new $this->template_class($template, $this, $parent, $cache_id, $compile_id); - } - } - // fill data if present - if (!empty($data) && is_array($data)) { - // set up variable values - foreach ($data as $_key => $_val) { - $tpl->tpl_vars[$_key] = new Smarty_variable($_val); - } - } - - return $tpl; - } - - /** - * Takes unknown classes and loads plugin files for them - * class name format: Smarty_PluginType_PluginName - * plugin filename format: plugintype.pluginname.php - * - * @param string $plugin_name class plugin name to load - * @param bool $check check if already loaded - * - * @throws SmartyException - * @return string |boolean filepath of loaded file or false - */ - public function loadPlugin($plugin_name, $check = true) - { - // if function or class exists, exit silently (already loaded) - if ($check && (is_callable($plugin_name) || class_exists($plugin_name, false))) { - return true; - } - // Plugin name is expected to be: Smarty_[Type]_[Name] - $_name_parts = explode('_', $plugin_name, 3); - // class name must have three parts to be valid plugin - // count($_name_parts) < 3 === !isset($_name_parts[2]) - if (!isset($_name_parts[2]) || strtolower($_name_parts[0]) !== 'smarty') { - throw new SmartyException("plugin {$plugin_name} is not a valid name format"); - } - // if type is "internal", get plugin from sysplugins - if (strtolower($_name_parts[1]) == 'internal') { - $file = SMARTY_SYSPLUGINS_DIR . strtolower($plugin_name) . '.php'; - if (file_exists($file)) { - require_once($file); - - return $file; - } else { - return false; - } - } - // plugin filename is expected to be: [type].[name].php - $_plugin_filename = "{$_name_parts[1]}.{$_name_parts[2]}.php"; - - $_stream_resolve_include_path = function_exists('stream_resolve_include_path'); - - // loop through plugin dirs and find the plugin - foreach ($this->getPluginsDir() as $_plugin_dir) { - $names = array( - $_plugin_dir . $_plugin_filename, - $_plugin_dir . strtolower($_plugin_filename), - ); - foreach ($names as $file) { - if (file_exists($file)) { - require_once($file); - - return $file; - } - if ($this->use_include_path && !preg_match('/^([\/\\\\]|[a-zA-Z]:[\/\\\\])/', $_plugin_dir)) { - // try PHP include_path - if ($_stream_resolve_include_path) { - $file = stream_resolve_include_path($file); - } else { - $file = Smarty_Internal_Get_Include_Path::getIncludePath($file); - } - - if ($file !== false) { - require_once($file); - - return $file; - } - } - } - } - // no plugin loaded - return false; - } - - /** - * Compile all template files - * - * @param string $extension file extension - * @param bool $force_compile force all to recompile - * @param int $time_limit - * @param int $max_errors - * - * @return integer number of template files recompiled - */ - public function compileAllTemplates($extension = '.tpl', $force_compile = false, $time_limit = 0, $max_errors = null) - { - return Smarty_Internal_Utility::compileAllTemplates($extension, $force_compile, $time_limit, $max_errors, $this); - } - - /** - * Compile all config files - * - * @param string $extension file extension - * @param bool $force_compile force all to recompile - * @param int $time_limit - * @param int $max_errors - * - * @return integer number of template files recompiled - */ - public function compileAllConfig($extension = '.conf', $force_compile = false, $time_limit = 0, $max_errors = null) - { - return Smarty_Internal_Utility::compileAllConfig($extension, $force_compile, $time_limit, $max_errors, $this); - } - - /** - * Delete compiled template file - * - * @param string $resource_name template name - * @param string $compile_id compile id - * @param integer $exp_time expiration time - * - * @return integer number of template files deleted - */ - public function clearCompiledTemplate($resource_name = null, $compile_id = null, $exp_time = null) - { - return Smarty_Internal_Utility::clearCompiledTemplate($resource_name, $compile_id, $exp_time, $this); - } - - /** - * Return array of tag/attributes of all tags used by an template - * - * @param Smarty_Internal_Template $template - * - * @return array of tag/attributes - */ - public function getTags(Smarty_Internal_Template $template) - { - return Smarty_Internal_Utility::getTags($template); - } - - /** - * Run installation test - * - * @param array $errors Array to write errors into, rather than outputting them - * - * @return boolean true if setup is fine, false if something is wrong - */ - public function testInstall(&$errors = null) - { - return Smarty_Internal_Utility::testInstall($this, $errors); - } - - /** - * Error Handler to mute expected messages - * - * @link http://php.net/set_error_handler - * - * @param integer $errno Error level - * @param $errstr - * @param $errfile - * @param $errline - * @param $errcontext - * - * @return boolean - */ - public static function mutingErrorHandler($errno, $errstr, $errfile, $errline, $errcontext) - { - $_is_muted_directory = false; - - // add the SMARTY_DIR to the list of muted directories - if (!isset(Smarty::$_muted_directories[SMARTY_DIR])) { - $smarty_dir = realpath(SMARTY_DIR); - if ($smarty_dir !== false) { - Smarty::$_muted_directories[SMARTY_DIR] = array( - 'file' => $smarty_dir, - 'length' => strlen($smarty_dir), - ); - } - } - - // walk the muted directories and test against $errfile - foreach (Smarty::$_muted_directories as $key => &$dir) { - if (!$dir) { - // resolve directory and length for speedy comparisons - $file = realpath($key); - if ($file === false) { - // this directory does not exist, remove and skip it - unset(Smarty::$_muted_directories[$key]); - continue; - } - $dir = array( - 'file' => $file, - 'length' => strlen($file), - ); - } - if (!strncmp($errfile, $dir['file'], $dir['length'])) { - $_is_muted_directory = true; - break; - } - } - - // pass to next error handler if this error did not occur inside SMARTY_DIR - // or the error was within smarty but masked to be ignored - if (!$_is_muted_directory || ($errno && $errno & error_reporting())) { - if (Smarty::$_previous_error_handler) { - return call_user_func(Smarty::$_previous_error_handler, $errno, $errstr, $errfile, $errline, $errcontext); - } else { - return false; - } - } - } - - /** - * Enable error handler to mute expected messages - * - * @return void - */ - public static function muteExpectedErrors() - { - /* - error muting is done because some people implemented custom error_handlers using - http://php.net/set_error_handler and for some reason did not understand the following paragraph: - - It is important to remember that the standard PHP error handler is completely bypassed for the - error types specified by error_types unless the callback function returns FALSE. - error_reporting() settings will have no effect and your error handler will be called regardless - - however you are still able to read the current value of error_reporting and act appropriately. - Of particular note is that this value will be 0 if the statement that caused the error was - prepended by the @ error-control operator. - - Smarty deliberately uses @filemtime() over file_exists() and filemtime() in some places. Reasons include - - @filemtime() is almost twice as fast as using an additional file_exists() - - between file_exists() and filemtime() a possible race condition is opened, - which does not exist using the simple @filemtime() approach. - */ - $error_handler = array('Smarty', 'mutingErrorHandler'); - $previous = set_error_handler($error_handler); - - // avoid dead loops - if ($previous !== $error_handler) { - Smarty::$_previous_error_handler = $previous; - } - } - - /** - * Disable error handler muting expected messages - * - * @return void - */ - public static function unmuteExpectedErrors() - { - restore_error_handler(); - } -} - -// Check if we're running on windows -Smarty::$_IS_WINDOWS = strtoupper(substr(PHP_OS, 0, 3)) === 'WIN'; - -// let PCRE (preg_*) treat strings as ISO-8859-1 if we're not dealing with UTF-8 -if (Smarty::$_CHARSET !== 'UTF-8') { - Smarty::$_UTF8_MODIFIER = ''; -} - -/** - * Smarty exception class - * - * @package Smarty - */ -class SmartyException extends Exception -{ - public static $escape = false; - - public function __toString() - { - return ' --> Smarty: ' . (self::$escape ? htmlentities($this->message) : $this->message) . ' <-- '; - } -} - -/** - * Smarty compiler exception class - * - * @package Smarty - */ -class SmartyCompilerException extends SmartyException -{ - public function __toString() - { - return ' --> Smarty Compiler: ' . $this->message . ' <-- '; - } - - /** - * The line number of the template error - * - * @type int|null - */ - public $line = null; - /** - * The template source snippet relating to the error - * - * @type string|null - */ - public $source = null; - /** - * The raw text of the error message - * - * @type string|null - */ - public $desc = null; - /** - * The resource identifier or template name - * - * @type string|null - */ - public $template = null; -} - -/** - * Autoloader - */ -function smartyAutoload($class) -{ - $_class = strtolower($class); - static $_classes = array( - 'smarty_config_source' => true, - 'smarty_config_compiled' => true, - 'smarty_security' => true, - 'smarty_cacheresource' => true, - 'smarty_cacheresource_custom' => true, - 'smarty_cacheresource_keyvaluestore' => true, - 'smarty_resource' => true, - 'smarty_resource_custom' => true, - 'smarty_resource_uncompiled' => true, - 'smarty_resource_recompiled' => true, - ); - - if (!strncmp($_class, 'smarty_internal_', 16) || isset($_classes[$_class])) { - include SMARTY_SYSPLUGINS_DIR . $_class . '.php'; - } -} diff --git a/framework/vendor/smarty/smarty/libs/SmartyBC.class.php b/framework/vendor/smarty/smarty/libs/SmartyBC.class.php deleted file mode 100644 index cec9467..0000000 --- a/framework/vendor/smarty/smarty/libs/SmartyBC.class.php +++ /dev/null @@ -1,467 +0,0 @@ - - * @author Uwe Tews - * @author Rodney Rehm - * @package Smarty - */ -/** - * @ignore - */ -require_once(dirname(__FILE__) . '/Smarty.class.php'); - -/** - * Smarty Backward Compatability Wrapper Class - * - * @package Smarty - */ -class SmartyBC extends Smarty -{ - /** - * Smarty 2 BC - * - * @var string - */ - public $_version = self::SMARTY_VERSION; - - /** - * Initialize new SmartyBC object - * - * @param array $options options to set during initialization, e.g. array( 'forceCompile' => false ) - */ - public function __construct(array $options = array()) - { - parent::__construct($options); - // register {php} tag - $this->registerPlugin('block', 'php', 'smarty_php_tag'); - } - - /** - * wrapper for assign_by_ref - * - * @param string $tpl_var the template variable name - * @param mixed &$value the referenced value to assign - */ - public function assign_by_ref($tpl_var, &$value) - { - $this->assignByRef($tpl_var, $value); - } - - /** - * wrapper for append_by_ref - * - * @param string $tpl_var the template variable name - * @param mixed &$value the referenced value to append - * @param boolean $merge flag if array elements shall be merged - */ - public function append_by_ref($tpl_var, &$value, $merge = false) - { - $this->appendByRef($tpl_var, $value, $merge); - } - - /** - * clear the given assigned template variable. - * - * @param string $tpl_var the template variable to clear - */ - public function clear_assign($tpl_var) - { - $this->clearAssign($tpl_var); - } - - /** - * Registers custom function to be used in templates - * - * @param string $function the name of the template function - * @param string $function_impl the name of the PHP function to register - * @param bool $cacheable - * @param mixed $cache_attrs - */ - public function register_function($function, $function_impl, $cacheable = true, $cache_attrs = null) - { - $this->registerPlugin('function', $function, $function_impl, $cacheable, $cache_attrs); - } - - /** - * Unregisters custom function - * - * @param string $function name of template function - */ - public function unregister_function($function) - { - $this->unregisterPlugin('function', $function); - } - - /** - * Registers object to be used in templates - * - * @param string $object name of template object - * @param object $object_impl the referenced PHP object to register - * @param array $allowed list of allowed methods (empty = all) - * @param boolean $smarty_args smarty argument format, else traditional - * @param array $block_methods list of methods that are block format - * - * @throws SmartyException - * @internal param array $block_functs list of methods that are block format - */ - public function register_object($object, $object_impl, $allowed = array(), $smarty_args = true, $block_methods = array()) - { - settype($allowed, 'array'); - settype($smarty_args, 'boolean'); - $this->registerObject($object, $object_impl, $allowed, $smarty_args, $block_methods); - } - - /** - * Unregisters object - * - * @param string $object name of template object - */ - public function unregister_object($object) - { - $this->unregisterObject($object); - } - - /** - * Registers block function to be used in templates - * - * @param string $block name of template block - * @param string $block_impl PHP function to register - * @param bool $cacheable - * @param mixed $cache_attrs - */ - public function register_block($block, $block_impl, $cacheable = true, $cache_attrs = null) - { - $this->registerPlugin('block', $block, $block_impl, $cacheable, $cache_attrs); - } - - /** - * Unregisters block function - * - * @param string $block name of template function - */ - public function unregister_block($block) - { - $this->unregisterPlugin('block', $block); - } - - /** - * Registers compiler function - * - * @param string $function name of template function - * @param string $function_impl name of PHP function to register - * @param bool $cacheable - */ - public function register_compiler_function($function, $function_impl, $cacheable = true) - { - $this->registerPlugin('compiler', $function, $function_impl, $cacheable); - } - - /** - * Unregisters compiler function - * - * @param string $function name of template function - */ - public function unregister_compiler_function($function) - { - $this->unregisterPlugin('compiler', $function); - } - - /** - * Registers modifier to be used in templates - * - * @param string $modifier name of template modifier - * @param string $modifier_impl name of PHP function to register - */ - public function register_modifier($modifier, $modifier_impl) - { - $this->registerPlugin('modifier', $modifier, $modifier_impl); - } - - /** - * Unregisters modifier - * - * @param string $modifier name of template modifier - */ - public function unregister_modifier($modifier) - { - $this->unregisterPlugin('modifier', $modifier); - } - - /** - * Registers a resource to fetch a template - * - * @param string $type name of resource - * @param array $functions array of functions to handle resource - */ - public function register_resource($type, $functions) - { - $this->registerResource($type, $functions); - } - - /** - * Unregisters a resource - * - * @param string $type name of resource - */ - public function unregister_resource($type) - { - $this->unregisterResource($type); - } - - /** - * Registers a prefilter function to apply - * to a template before compiling - * - * @param callable $function - */ - public function register_prefilter($function) - { - $this->registerFilter('pre', $function); - } - - /** - * Unregisters a prefilter function - * - * @param callable $function - */ - public function unregister_prefilter($function) - { - $this->unregisterFilter('pre', $function); - } - - /** - * Registers a postfilter function to apply - * to a compiled template after compilation - * - * @param callable $function - */ - public function register_postfilter($function) - { - $this->registerFilter('post', $function); - } - - /** - * Unregisters a postfilter function - * - * @param callable $function - */ - public function unregister_postfilter($function) - { - $this->unregisterFilter('post', $function); - } - - /** - * Registers an output filter function to apply - * to a template output - * - * @param callable $function - */ - public function register_outputfilter($function) - { - $this->registerFilter('output', $function); - } - - /** - * Unregisters an outputfilter function - * - * @param callable $function - */ - public function unregister_outputfilter($function) - { - $this->unregisterFilter('output', $function); - } - - /** - * load a filter of specified type and name - * - * @param string $type filter type - * @param string $name filter name - */ - public function load_filter($type, $name) - { - $this->loadFilter($type, $name); - } - - /** - * clear cached content for the given template and cache id - * - * @param string $tpl_file name of template file - * @param string $cache_id name of cache_id - * @param string $compile_id name of compile_id - * @param string $exp_time expiration time - * - * @return boolean - */ - public function clear_cache($tpl_file = null, $cache_id = null, $compile_id = null, $exp_time = null) - { - return $this->clearCache($tpl_file, $cache_id, $compile_id, $exp_time); - } - - /** - * clear the entire contents of cache (all templates) - * - * @param string $exp_time expire time - * - * @return boolean - */ - public function clear_all_cache($exp_time = null) - { - return $this->clearCache(null, null, null, $exp_time); - } - - /** - * test to see if valid cache exists for this template - * - * @param string $tpl_file name of template file - * @param string $cache_id - * @param string $compile_id - * - * @return boolean - */ - public function is_cached($tpl_file, $cache_id = null, $compile_id = null) - { - return $this->isCached($tpl_file, $cache_id, $compile_id); - } - - /** - * clear all the assigned template variables. - */ - public function clear_all_assign() - { - $this->clearAllAssign(); - } - - /** - * clears compiled version of specified template resource, - * or all compiled template files if one is not specified. - * This function is for advanced use only, not normally needed. - * - * @param string $tpl_file - * @param string $compile_id - * @param string $exp_time - * - * @return boolean results of {@link smarty_core_rm_auto()} - */ - public function clear_compiled_tpl($tpl_file = null, $compile_id = null, $exp_time = null) - { - return $this->clearCompiledTemplate($tpl_file, $compile_id, $exp_time); - } - - /** - * Checks whether requested template exists. - * - * @param string $tpl_file - * - * @return boolean - */ - public function template_exists($tpl_file) - { - return $this->templateExists($tpl_file); - } - - /** - * Returns an array containing template variables - * - * @param string $name - * - * @return array - */ - public function get_template_vars($name = null) - { - return $this->getTemplateVars($name); - } - - /** - * Returns an array containing config variables - * - * @param string $name - * - * @return array - */ - public function get_config_vars($name = null) - { - return $this->getConfigVars($name); - } - - /** - * load configuration values - * - * @param string $file - * @param string $section - * @param string $scope - */ - public function config_load($file, $section = null, $scope = 'global') - { - $this->ConfigLoad($file, $section, $scope); - } - - /** - * return a reference to a registered object - * - * @param string $name - * - * @return object - */ - public function get_registered_object($name) - { - return $this->getRegisteredObject($name); - } - - /** - * clear configuration values - * - * @param string $var - */ - public function clear_config($var = null) - { - $this->clearConfig($var); - } - - /** - * trigger Smarty error - * - * @param string $error_msg - * @param integer $error_type - */ - public function trigger_error($error_msg, $error_type = E_USER_WARNING) - { - trigger_error("Smarty error: $error_msg", $error_type); - } -} - -/** - * Smarty {php}{/php} block function - * - * @param array $params parameter list - * @param string $content contents of the block - * @param object $template template object - * @param boolean &$repeat repeat flag - * - * @return string content re-formatted - */ -function smarty_php_tag($params, $content, $template, &$repeat) -{ - eval($content); - - return ''; -} diff --git a/framework/vendor/smarty/smarty/libs/debug.tpl b/framework/vendor/smarty/smarty/libs/debug.tpl deleted file mode 100644 index 61b8876..0000000 --- a/framework/vendor/smarty/smarty/libs/debug.tpl +++ /dev/null @@ -1,137 +0,0 @@ -{capture name='_smarty_debug' assign=debug_output} - - - - Smarty Debug Console - - - - -

Smarty Debug Console - - {if isset($template_name)}{$template_name|debug_print_var nofilter}{else}Total Time {$execution_time|string_format:"%.5f"}{/if}

- - {if !empty($template_data)} -

included templates & config files (load time in seconds)

-
- {foreach $template_data as $template} - {$template.name} - - (compile {$template['compile_time']|string_format:"%.5f"}) (render {$template['render_time']|string_format:"%.5f"}) (cache {$template['cache_time']|string_format:"%.5f"} - ) - -
- {/foreach} -
- {/if} - -

assigned template variables

- - - {foreach $assigned_vars as $vars} - - - - - {/foreach} -
${$vars@key|escape:'html'}{$vars|debug_print_var nofilter}
- -

assigned config file variables (outer template scope)

- - - {foreach $config_vars as $vars} - - - - - {/foreach} - -
{$vars@key|escape:'html'}{$vars|debug_print_var nofilter}
- - -{/capture} - diff --git a/framework/vendor/smarty/smarty/libs/index.html b/framework/vendor/smarty/smarty/libs/index.html deleted file mode 100644 index e69de29..0000000 diff --git a/framework/vendor/smarty/smarty/libs/plugins/block.textformat.php b/framework/vendor/smarty/smarty/libs/plugins/block.textformat.php deleted file mode 100644 index abf5449..0000000 --- a/framework/vendor/smarty/smarty/libs/plugins/block.textformat.php +++ /dev/null @@ -1,110 +0,0 @@ - - * Name: textformat
- * Purpose: format text a certain way with preset styles - * or custom wrap/indent settings
- * Params: - *
- * - style         - string (email)
- * - indent        - integer (0)
- * - wrap          - integer (80)
- * - wrap_char     - string ("\n")
- * - indent_char   - string (" ")
- * - wrap_boundary - boolean (true)
- * 
- * - * @link http://www.smarty.net/manual/en/language.function.textformat.php {textformat} - * (Smarty online manual) - * - * @param array $params parameters - * @param string $content contents of the block - * @param Smarty_Internal_Template $template template object - * @param boolean &$repeat repeat flag - * - * @return string content re-formatted - * @author Monte Ohrt - */ -function smarty_block_textformat($params, $content, $template, &$repeat) -{ - if (is_null($content)) { - return; - } - - $style = null; - $indent = 0; - $indent_first = 0; - $indent_char = ' '; - $wrap = 80; - $wrap_char = "\n"; - $wrap_cut = false; - $assign = null; - - foreach ($params as $_key => $_val) { - switch ($_key) { - case 'style': - case 'indent_char': - case 'wrap_char': - case 'assign': - $$_key = (string) $_val; - break; - - case 'indent': - case 'indent_first': - case 'wrap': - $$_key = (int) $_val; - break; - - case 'wrap_cut': - $$_key = (bool) $_val; - break; - - default: - trigger_error("textformat: unknown attribute '$_key'"); - } - } - - if ($style == 'email') { - $wrap = 72; - } - // split into paragraphs - $_paragraphs = preg_split('![\r\n]{2}!', $content); - - foreach ($_paragraphs as &$_paragraph) { - if (!$_paragraph) { - continue; - } - // convert mult. spaces & special chars to single space - $_paragraph = preg_replace(array('!\s+!' . Smarty::$_UTF8_MODIFIER, '!(^\s+)|(\s+$)!' . Smarty::$_UTF8_MODIFIER), array(' ', ''), $_paragraph); - // indent first line - if ($indent_first > 0) { - $_paragraph = str_repeat($indent_char, $indent_first) . $_paragraph; - } - // wordwrap sentences - if (Smarty::$_MBSTRING) { - require_once(SMARTY_PLUGINS_DIR . 'shared.mb_wordwrap.php'); - $_paragraph = smarty_mb_wordwrap($_paragraph, $wrap - $indent, $wrap_char, $wrap_cut); - } else { - $_paragraph = wordwrap($_paragraph, $wrap - $indent, $wrap_char, $wrap_cut); - } - // indent lines - if ($indent > 0) { - $_paragraph = preg_replace('!^!m', str_repeat($indent_char, $indent), $_paragraph); - } - } - $_output = implode($wrap_char . $wrap_char, $_paragraphs); - - if ($assign) { - $template->assign($assign, $_output); - } else { - return $_output; - } -} diff --git a/framework/vendor/smarty/smarty/libs/plugins/function.counter.php b/framework/vendor/smarty/smarty/libs/plugins/function.counter.php deleted file mode 100644 index 4da85a1..0000000 --- a/framework/vendor/smarty/smarty/libs/plugins/function.counter.php +++ /dev/null @@ -1,78 +0,0 @@ - - * Name: counter
- * Purpose: print out a counter value - * - * @author Monte Ohrt - * @link http://www.smarty.net/manual/en/language.function.counter.php {counter} - * (Smarty online manual) - * - * @param array $params parameters - * @param Smarty_Internal_Template $template template object - * - * @return string|null - */ -function smarty_function_counter($params, $template) -{ - static $counters = array(); - - $name = (isset($params['name'])) ? $params['name'] : 'default'; - if (!isset($counters[$name])) { - $counters[$name] = array( - 'start' => 1, - 'skip' => 1, - 'direction' => 'up', - 'count' => 1 - ); - } - $counter =& $counters[$name]; - - if (isset($params['start'])) { - $counter['start'] = $counter['count'] = (int) $params['start']; - } - - if (!empty($params['assign'])) { - $counter['assign'] = $params['assign']; - } - - if (isset($counter['assign'])) { - $template->assign($counter['assign'], $counter['count']); - } - - if (isset($params['print'])) { - $print = (bool) $params['print']; - } else { - $print = empty($counter['assign']); - } - - if ($print) { - $retval = $counter['count']; - } else { - $retval = null; - } - - if (isset($params['skip'])) { - $counter['skip'] = $params['skip']; - } - - if (isset($params['direction'])) { - $counter['direction'] = $params['direction']; - } - - if ($counter['direction'] == "down") { - $counter['count'] -= $counter['skip']; - } else { - $counter['count'] += $counter['skip']; - } - - return $retval; -} diff --git a/framework/vendor/smarty/smarty/libs/plugins/function.cycle.php b/framework/vendor/smarty/smarty/libs/plugins/function.cycle.php deleted file mode 100644 index 8dc5cd9..0000000 --- a/framework/vendor/smarty/smarty/libs/plugins/function.cycle.php +++ /dev/null @@ -1,107 +0,0 @@ - - * Name: cycle
- * Date: May 3, 2002
- * Purpose: cycle through given values
- * Params: - *
- * - name      - name of cycle (optional)
- * - values    - comma separated list of values to cycle, or an array of values to cycle
- *               (this can be left out for subsequent calls)
- * - reset     - boolean - resets given var to true
- * - print     - boolean - print var or not. default is true
- * - advance   - boolean - whether or not to advance the cycle
- * - delimiter - the value delimiter, default is ","
- * - assign    - boolean, assigns to template var instead of printed.
- * 
- * Examples:
- *
- * {cycle values="#eeeeee,#d0d0d0d"}
- * {cycle name=row values="one,two,three" reset=true}
- * {cycle name=row}
- * 
- * - * @link http://www.smarty.net/manual/en/language.function.cycle.php {cycle} - * (Smarty online manual) - * @author Monte Ohrt - * @author credit to Mark Priatel - * @author credit to Gerard - * @author credit to Jason Sweat - * @version 1.3 - * - * @param array $params parameters - * @param Smarty_Internal_Template $template template object - * - * @return string|null - */ - -function smarty_function_cycle($params, $template) -{ - static $cycle_vars; - - $name = (empty($params['name'])) ? 'default' : $params['name']; - $print = (isset($params['print'])) ? (bool) $params['print'] : true; - $advance = (isset($params['advance'])) ? (bool) $params['advance'] : true; - $reset = (isset($params['reset'])) ? (bool) $params['reset'] : false; - - if (!isset($params['values'])) { - if (!isset($cycle_vars[$name]['values'])) { - trigger_error("cycle: missing 'values' parameter"); - - return; - } - } else { - if (isset($cycle_vars[$name]['values']) - && $cycle_vars[$name]['values'] != $params['values'] - ) { - $cycle_vars[$name]['index'] = 0; - } - $cycle_vars[$name]['values'] = $params['values']; - } - - if (isset($params['delimiter'])) { - $cycle_vars[$name]['delimiter'] = $params['delimiter']; - } elseif (!isset($cycle_vars[$name]['delimiter'])) { - $cycle_vars[$name]['delimiter'] = ','; - } - - if (is_array($cycle_vars[$name]['values'])) { - $cycle_array = $cycle_vars[$name]['values']; - } else { - $cycle_array = explode($cycle_vars[$name]['delimiter'], $cycle_vars[$name]['values']); - } - - if (!isset($cycle_vars[$name]['index']) || $reset) { - $cycle_vars[$name]['index'] = 0; - } - - if (isset($params['assign'])) { - $print = false; - $template->assign($params['assign'], $cycle_array[$cycle_vars[$name]['index']]); - } - - if ($print) { - $retval = $cycle_array[$cycle_vars[$name]['index']]; - } else { - $retval = null; - } - - if ($advance) { - if ($cycle_vars[$name]['index'] >= count($cycle_array) - 1) { - $cycle_vars[$name]['index'] = 0; - } else { - $cycle_vars[$name]['index'] ++; - } - } - - return $retval; -} diff --git a/framework/vendor/smarty/smarty/libs/plugins/function.fetch.php b/framework/vendor/smarty/smarty/libs/plugins/function.fetch.php deleted file mode 100644 index 3506d4a..0000000 --- a/framework/vendor/smarty/smarty/libs/plugins/function.fetch.php +++ /dev/null @@ -1,221 +0,0 @@ - - * Name: fetch
- * Purpose: fetch file, web or ftp data and display results - * - * @link http://www.smarty.net/manual/en/language.function.fetch.php {fetch} - * (Smarty online manual) - * @author Monte Ohrt - * - * @param array $params parameters - * @param Smarty_Internal_Template $template template object - * - * @throws SmartyException - * @return string|null if the assign parameter is passed, Smarty assigns the result to a template variable - */ -function smarty_function_fetch($params, $template) -{ - if (empty($params['file'])) { - trigger_error("[plugin] fetch parameter 'file' cannot be empty", E_USER_NOTICE); - - return; - } - - // strip file protocol - if (stripos($params['file'], 'file://') === 0) { - $params['file'] = substr($params['file'], 7); - } - - $protocol = strpos($params['file'], '://'); - if ($protocol !== false) { - $protocol = strtolower(substr($params['file'], 0, $protocol)); - } - - if (isset($template->smarty->security_policy)) { - if ($protocol) { - // remote resource (or php stream, …) - if (!$template->smarty->security_policy->isTrustedUri($params['file'])) { - return; - } - } else { - // local file - if (!$template->smarty->security_policy->isTrustedResourceDir($params['file'])) { - return; - } - } - } - - $content = ''; - if ($protocol == 'http') { - // http fetch - if ($uri_parts = parse_url($params['file'])) { - // set defaults - $host = $server_name = $uri_parts['host']; - $timeout = 30; - $accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*"; - $agent = "Smarty Template Engine " . Smarty::SMARTY_VERSION; - $referer = ""; - $uri = !empty($uri_parts['path']) ? $uri_parts['path'] : '/'; - $uri .= !empty($uri_parts['query']) ? '?' . $uri_parts['query'] : ''; - $_is_proxy = false; - if (empty($uri_parts['port'])) { - $port = 80; - } else { - $port = $uri_parts['port']; - } - if (!empty($uri_parts['user'])) { - $user = $uri_parts['user']; - } - if (!empty($uri_parts['pass'])) { - $pass = $uri_parts['pass']; - } - // loop through parameters, setup headers - foreach ($params as $param_key => $param_value) { - switch ($param_key) { - case "file": - case "assign": - case "assign_headers": - break; - case "user": - if (!empty($param_value)) { - $user = $param_value; - } - break; - case "pass": - if (!empty($param_value)) { - $pass = $param_value; - } - break; - case "accept": - if (!empty($param_value)) { - $accept = $param_value; - } - break; - case "header": - if (!empty($param_value)) { - if (!preg_match('![\w\d-]+: .+!', $param_value)) { - trigger_error("[plugin] invalid header format '" . $param_value . "'", E_USER_NOTICE); - - return; - } else { - $extra_headers[] = $param_value; - } - } - break; - case "proxy_host": - if (!empty($param_value)) { - $proxy_host = $param_value; - } - break; - case "proxy_port": - if (!preg_match('!\D!', $param_value)) { - $proxy_port = (int) $param_value; - } else { - trigger_error("[plugin] invalid value for attribute '" . $param_key . "'", E_USER_NOTICE); - - return; - } - break; - case "agent": - if (!empty($param_value)) { - $agent = $param_value; - } - break; - case "referer": - if (!empty($param_value)) { - $referer = $param_value; - } - break; - case "timeout": - if (!preg_match('!\D!', $param_value)) { - $timeout = (int) $param_value; - } else { - trigger_error("[plugin] invalid value for attribute '" . $param_key . "'", E_USER_NOTICE); - - return; - } - break; - default: - trigger_error("[plugin] unrecognized attribute '" . $param_key . "'", E_USER_NOTICE); - - return; - } - } - if (!empty($proxy_host) && !empty($proxy_port)) { - $_is_proxy = true; - $fp = fsockopen($proxy_host, $proxy_port, $errno, $errstr, $timeout); - } else { - $fp = fsockopen($server_name, $port, $errno, $errstr, $timeout); - } - - if (!$fp) { - trigger_error("[plugin] unable to fetch: $errstr ($errno)", E_USER_NOTICE); - - return; - } else { - if ($_is_proxy) { - fputs($fp, 'GET ' . $params['file'] . " HTTP/1.0\r\n"); - } else { - fputs($fp, "GET $uri HTTP/1.0\r\n"); - } - if (!empty($host)) { - fputs($fp, "Host: $host\r\n"); - } - if (!empty($accept)) { - fputs($fp, "Accept: $accept\r\n"); - } - if (!empty($agent)) { - fputs($fp, "User-Agent: $agent\r\n"); - } - if (!empty($referer)) { - fputs($fp, "Referer: $referer\r\n"); - } - if (isset($extra_headers) && is_array($extra_headers)) { - foreach ($extra_headers as $curr_header) { - fputs($fp, $curr_header . "\r\n"); - } - } - if (!empty($user) && !empty($pass)) { - fputs($fp, "Authorization: BASIC " . base64_encode("$user:$pass") . "\r\n"); - } - - fputs($fp, "\r\n"); - while (!feof($fp)) { - $content .= fgets($fp, 4096); - } - fclose($fp); - $csplit = preg_split("!\r\n\r\n!", $content, 2); - - $content = $csplit[1]; - - if (!empty($params['assign_headers'])) { - $template->assign($params['assign_headers'], preg_split("!\r\n!", $csplit[0])); - } - } - } else { - trigger_error("[plugin fetch] unable to parse URL, check syntax", E_USER_NOTICE); - - return; - } - } else { - $content = @file_get_contents($params['file']); - if ($content === false) { - throw new SmartyException("{fetch} cannot read resource '" . $params['file'] . "'"); - } - } - - if (!empty($params['assign'])) { - $template->assign($params['assign'], $content); - } else { - return $content; - } -} diff --git a/framework/vendor/smarty/smarty/libs/plugins/function.html_checkboxes.php b/framework/vendor/smarty/smarty/libs/plugins/function.html_checkboxes.php deleted file mode 100644 index d786803..0000000 --- a/framework/vendor/smarty/smarty/libs/plugins/function.html_checkboxes.php +++ /dev/null @@ -1,237 +0,0 @@ - - * Type: function
- * Name: html_checkboxes
- * Date: 24.Feb.2003
- * Purpose: Prints out a list of checkbox input types
- * Examples: - *
- * {html_checkboxes values=$ids output=$names}
- * {html_checkboxes values=$ids name='box' separator='
' output=$names} - * {html_checkboxes values=$ids checked=$checked separator='
' output=$names} - *
- * Params: - *
- * - name       (optional) - string default "checkbox"
- * - values     (required) - array
- * - options    (optional) - associative array
- * - checked    (optional) - array default not set
- * - separator  (optional) - ie 
or   - * - output (optional) - the output next to each checkbox - * - assign (optional) - assign the output as an array to this variable - * - escape (optional) - escape the content (not value), defaults to true - *
- * - * @link http://www.smarty.net/manual/en/language.function.html.checkboxes.php {html_checkboxes} - * (Smarty online manual) - * @author Christopher Kvarme - * @author credits to Monte Ohrt - * @version 1.0 - * - * @param array $params parameters - * @param object $template template object - * - * @return string - * @uses smarty_function_escape_special_chars() - */ -function smarty_function_html_checkboxes($params, $template) -{ - require_once(SMARTY_PLUGINS_DIR . 'shared.escape_special_chars.php'); - - $name = 'checkbox'; - $values = null; - $options = null; - $selected = array(); - $separator = ''; - $escape = true; - $labels = true; - $label_ids = false; - $output = null; - - $extra = ''; - - foreach ($params as $_key => $_val) { - switch ($_key) { - case 'name': - case 'separator': - $$_key = (string) $_val; - break; - - case 'escape': - case 'labels': - case 'label_ids': - $$_key = (bool) $_val; - break; - - case 'options': - $$_key = (array) $_val; - break; - - case 'values': - case 'output': - $$_key = array_values((array) $_val); - break; - - case 'checked': - case 'selected': - if (is_array($_val)) { - $selected = array(); - foreach ($_val as $_sel) { - if (is_object($_sel)) { - if (method_exists($_sel, "__toString")) { - $_sel = smarty_function_escape_special_chars((string) $_sel->__toString()); - } else { - trigger_error("html_checkboxes: selected attribute contains an object of class '" . get_class($_sel) . "' without __toString() method", E_USER_NOTICE); - continue; - } - } else { - $_sel = smarty_function_escape_special_chars((string) $_sel); - } - $selected[$_sel] = true; - } - } elseif (is_object($_val)) { - if (method_exists($_val, "__toString")) { - $selected = smarty_function_escape_special_chars((string) $_val->__toString()); - } else { - trigger_error("html_checkboxes: selected attribute is an object of class '" . get_class($_val) . "' without __toString() method", E_USER_NOTICE); - } - } else { - $selected = smarty_function_escape_special_chars((string) $_val); - } - break; - - case 'checkboxes': - trigger_error('html_checkboxes: the use of the "checkboxes" attribute is deprecated, use "options" instead', E_USER_WARNING); - $options = (array) $_val; - break; - - case 'assign': - break; - - case 'strict': - break; - - case 'disabled': - case 'readonly': - if (!empty($params['strict'])) { - if (!is_scalar($_val)) { - trigger_error("html_options: $_key attribute must be a scalar, only boolean true or string '$_key' will actually add the attribute", E_USER_NOTICE); - } - - if ($_val === true || $_val === $_key) { - $extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_key) . '"'; - } - - break; - } - // omit break; to fall through! - - default: - if (!is_array($_val)) { - $extra .= ' ' . $_key . '="' . smarty_function_escape_special_chars($_val) . '"'; - } else { - trigger_error("html_checkboxes: extra attribute '$_key' cannot be an array", E_USER_NOTICE); - } - break; - } - } - - if (!isset($options) && !isset($values)) { - return ''; - } /* raise error here? */ - - $_html_result = array(); - - if (isset($options)) { - foreach ($options as $_key => $_val) { - $_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels, $label_ids, $escape); - } - } else { - foreach ($values as $_i => $_key) { - $_val = isset($output[$_i]) ? $output[$_i] : ''; - $_html_result[] = smarty_function_html_checkboxes_output($name, $_key, $_val, $selected, $extra, $separator, $labels, $label_ids, $escape); - } - } - - if (!empty($params['assign'])) { - $template->assign($params['assign'], $_html_result); - } else { - return implode("\n", $_html_result); - } -} - -function smarty_function_html_checkboxes_output($name, $value, $output, $selected, $extra, $separator, $labels, $label_ids, $escape = true) -{ - $_output = ''; - - if (is_object($value)) { - if (method_exists($value, "__toString")) { - $value = (string) $value->__toString(); - } else { - trigger_error("html_options: value is an object of class '" . get_class($value) . "' without __toString() method", E_USER_NOTICE); - - return ''; - } - } else { - $value = (string) $value; - } - - if (is_object($output)) { - if (method_exists($output, "__toString")) { - $output = (string) $output->__toString(); - } else { - trigger_error("html_options: output is an object of class '" . get_class($output) . "' without __toString() method", E_USER_NOTICE); - - return ''; - } - } else { - $output = (string) $output; - } - - if ($labels) { - if ($label_ids) { - $_id = smarty_function_escape_special_chars(preg_replace('![^\w\-\.]!' . Smarty::$_UTF8_MODIFIER, '_', $name . '_' . $value)); - $_output .= '