diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 000000000..940aad0e7 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 000000000..9ffbec9f7 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/.idea/trunk.iml b/.idea/trunk.iml new file mode 100644 index 000000000..b31359362 --- /dev/null +++ b/.idea/trunk.iml @@ -0,0 +1,18 @@ + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 000000000..78e665fde --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/workspace.xml b/.idea/workspace.xml new file mode 100644 index 000000000..275e819ba --- /dev/null +++ b/.idea/workspace.xml @@ -0,0 +1,424 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + true + DEFINITION_ORDER + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + project + + + true + + + + DIRECTORY + + false + + + + + + + C:\Users\Anyon\AppData\Roaming\Subversion + + + + + + + + + 1486970693317 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/composer.json b/composer.json index 6dd78189d..307c3304a 100644 --- a/composer.json +++ b/composer.json @@ -19,12 +19,10 @@ "php": ">=5.4.0", "pclzip/pclzip": "^2.8", "qiniu/php-sdk": "^7.0", - "aferrandini/phpqrcode": "^1.0", "zoujingli/wechat-php-sdk": "dev-master", "topthink/framework": "^5.0", "topthink/think-captcha": "^1.0", "topthink/think-mongo": "^1.1", - "topthink/think-worker": "^1.0", "topthink/think-queue": "^1.0" }, "extra": { diff --git a/composer.lock b/composer.lock new file mode 100644 index 000000000..7cdd8786d --- /dev/null +++ b/composer.lock @@ -0,0 +1,388 @@ +{ + "_readme": [ + "This file locks the dependencies of your project to a known state", + "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", + "This file is @generated automatically" + ], + "hash": "7c9685d29208f32193dc293722b2f2e7", + "content-hash": "80db93fe5e6971dc5fd7643c71527810", + "packages": [ + { + "name": "pclzip/pclzip", + "version": "2.8.2", + "source": { + "type": "git", + "url": "https://github.com/ivanlanin/pclzip.git", + "reference": "19dd1de9d3f5fc4d7d70175b4c344dee329f45fd" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/ivanlanin/pclzip/19dd1de9d3f5fc4d7d70175b4c344dee329f45fd.zip", + "reference": "19dd1de9d3f5fc4d7d70175b4c344dee329f45fd", + "shasum": "" + }, + "type": "library", + "autoload": { + "classmap": [ + "pclzip.lib.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "LGPL-2.1" + ], + "authors": [ + { + "name": "Vincent Blavet" + } + ], + "description": "A PHP library that offers compression and extraction functions for Zip formatted archives", + "homepage": "http://www.phpconcept.net/pclzip", + "keywords": [ + "php", + "zip" + ], + "time": "2014-06-05 11:42:24" + }, + { + "name": "qiniu/php-sdk", + "version": "v7.1.3", + "source": { + "type": "git", + "url": "https://github.com/qiniu/php-sdk.git", + "reference": "b91653485e36b4797d7a302cc86c49695e47a642" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/qiniu/php-sdk/b91653485e36b4797d7a302cc86c49695e47a642.zip", + "reference": "b91653485e36b4797d7a302cc86c49695e47a642", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "phpunit/phpunit": "~4.0", + "squizlabs/php_codesniffer": "~2.3" + }, + "type": "library", + "autoload": { + "psr-4": { + "Qiniu\\": "src/Qiniu" + }, + "files": [ + "src/Qiniu/functions.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Qiniu", + "email": "sdk@qiniu.com", + "homepage": "http://www.qiniu.com" + } + ], + "description": "Qiniu Resource (Cloud) Storage SDK for PHP", + "homepage": "http://developer.qiniu.com/", + "keywords": [ + "cloud", + "qiniu", + "sdk", + "storage" + ], + "time": "2016-11-18 02:57:31" + }, + { + "name": "topthink/framework", + "version": "v5.0.6", + "source": { + "type": "git", + "url": "https://github.com/top-think/framework.git", + "reference": "a3a37e6cfad132d5b02ffff8f23a4abc565f7928" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/top-think/framework/a3a37e6cfad132d5b02ffff8f23a4abc565f7928.zip", + "reference": "a3a37e6cfad132d5b02ffff8f23a4abc565f7928", + "shasum": "" + }, + "require": { + "php": ">=5.4.0", + "topthink/think-installer": "~1.0" + }, + "require-dev": { + "johnkary/phpunit-speedtrap": "^1.0", + "mikey179/vfsstream": "~1.6", + "phpdocumentor/reflection-docblock": "^2.0", + "phploc/phploc": "2.*", + "phpunit/phpunit": "4.8.*", + "sebastian/phpcpd": "2.*" + }, + "type": "think-framework", + "autoload": { + "psr-4": { + "think\\": "library/think" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "liu21st", + "email": "liu21st@gmail.com" + } + ], + "description": "the new thinkphp framework", + "homepage": "http://thinkphp.cn/", + "keywords": [ + "framework", + "orm", + "thinkphp" + ], + "time": "2017-02-07 09:39:59" + }, + { + "name": "topthink/think-captcha", + "version": "v1.0.7", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-captcha.git", + "reference": "0c55455df26a1626a60d0dc35d2d89002b741d44" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/top-think/think-captcha/0c55455df26a1626a60d0dc35d2d89002b741d44.zip", + "reference": "0c55455df26a1626a60d0dc35d2d89002b741d44", + "shasum": "" + }, + "type": "library", + "autoload": { + "psr-4": { + "think\\captcha\\": "src/" + }, + "files": [ + "src/helper.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "captcha package for thinkphp5", + "time": "2016-07-06 01:47:11" + }, + { + "name": "topthink/think-helper", + "version": "v1.0.5", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-helper.git", + "reference": "ed64408cdc4cdbd390365ba0906d208b987af520" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/top-think/think-helper/ed64408cdc4cdbd390365ba0906d208b987af520.zip", + "reference": "ed64408cdc4cdbd390365ba0906d208b987af520", + "shasum": "" + }, + "type": "library", + "autoload": { + "psr-4": { + "think\\helper\\": "src" + }, + "files": [ + "src/helper.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "The ThinkPHP5 Helper Package", + "time": "2016-12-01 07:08:40" + }, + { + "name": "topthink/think-installer", + "version": "v1.0.11", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-installer.git", + "reference": "4c6e1ebecd1afce3f4ccc47e147d61bbe1bf641d" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/top-think/think-installer/4c6e1ebecd1afce3f4ccc47e147d61bbe1bf641d.zip", + "reference": "4c6e1ebecd1afce3f4ccc47e147d61bbe1bf641d", + "shasum": "" + }, + "require": { + "composer-plugin-api": "^1.0" + }, + "require-dev": { + "composer/composer": "1.0.*@dev" + }, + "type": "composer-plugin", + "extra": { + "class": "think\\composer\\Plugin" + }, + "autoload": { + "psr-4": { + "think\\composer\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "time": "2016-12-01 09:08:45" + }, + { + "name": "topthink/think-mongo", + "version": "v1.5", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-mongo.git", + "reference": "2dd7ecae965cd3a6e5cc99f3db7c63353dae4cf3" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/top-think/think-mongo/2dd7ecae965cd3a6e5cc99f3db7c63353dae4cf3.zip", + "reference": "2dd7ecae965cd3a6e5cc99f3db7c63353dae4cf3", + "shasum": "" + }, + "type": "library", + "autoload": { + "psr-4": { + "think\\mongo\\": "src" + }, + "files": [] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "liu21st", + "email": "liu21st@gmail.com" + } + ], + "description": "mongodb driver for thinkphp5", + "time": "2017-02-06 06:05:55" + }, + { + "name": "topthink/think-queue", + "version": "v1.1.2", + "source": { + "type": "git", + "url": "https://github.com/top-think/think-queue.git", + "reference": "503c5b809585ca60cba9485a233aa8be4b22c990" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/top-think/think-queue/503c5b809585ca60cba9485a233aa8be4b22c990.zip", + "reference": "503c5b809585ca60cba9485a233aa8be4b22c990", + "shasum": "" + }, + "require": { + "topthink/think-helper": ">=1.0.4", + "topthink/think-installer": ">=1.0.10" + }, + "type": "think-extend", + "extra": { + "think-config": { + "queue": "src/config.php" + } + }, + "autoload": { + "psr-4": { + "think\\": "src" + }, + "files": [ + "src/common.php" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "yunwuxin", + "email": "448901948@qq.com" + } + ], + "description": "The ThinkPHP5 Queue Package", + "time": "2016-12-01 04:29:39" + }, + { + "name": "zoujingli/wechat-php-sdk", + "version": "dev-master", + "source": { + "type": "git", + "url": "https://github.com/zoujingli/wechat-php-sdk.git", + "reference": "36ad89c0f7fe1e4b29591cdb5c25079e1e0bd0e0" + }, + "dist": { + "type": "zip", + "url": "https://packagist.phpcomposer.com/files/zoujingli/wechat-php-sdk/36ad89c0f7fe1e4b29591cdb5c25079e1e0bd0e0.zip", + "reference": "36ad89c0f7fe1e4b29591cdb5c25079e1e0bd0e0", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "type": "project", + "autoload": { + "psr-4": { + "Wechat\\": "./Wechat" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "description": "WeChat development of SDK", + "homepage": "http://www.kancloud.cn/zoujingli/wechat-php-sdk", + "keywords": [ + "wechat-php-sdk" + ], + "time": "2017-02-07 02:34:38" + } + ], + "packages-dev": [], + "aliases": [], + "minimum-stability": "stable", + "stability-flags": { + "zoujingli/wechat-php-sdk": 20 + }, + "prefer-stable": false, + "prefer-lowest": false, + "platform": { + "php": ">=5.4.0" + }, + "platform-dev": [] +} diff --git a/runtime/log/201702/13.log b/runtime/log/201702/13.log new file mode 100644 index 000000000..7eb1236a4 --- /dev/null +++ b/runtime/log/201702/13.log @@ -0,0 +1,747 @@ +[ 2017-02-13T15:24:16+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/ +[ log ] localhost/git/Think.Admin.git/trunk/public/ [运行时间:0.184468s][吞吐率:5.42req/s] [内存消耗:1,867.47kb] [文件加载:51] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => '', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ RUN ] app\index\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\index\controller\Index.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/index\view\index.index.html [ array ( + 0 => 'mysql_ver', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:05+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/ +[ log ] localhost/git/Think.Admin.git/trunk/public/ [运行时间:0.179222s][吞吐率:5.58req/s] [内存消耗:1,735.62kb] [文件加载:49] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => '', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ RUN ] app\index\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\index\controller\Index.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/index\view\index.index.html [ array ( + 0 => 'mysql_ver', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:11+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/ +[ log ] localhost/git/Think.Admin.git/trunk/public/ [运行时间:0.176604s][吞吐率:5.66req/s] [内存消耗:1,735.62kb] [文件加载:49] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => '', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ RUN ] app\index\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\index\controller\Index.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/index\view\index.index.html [ array ( + 0 => 'mysql_ver', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:15+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/ +[ log ] localhost/git/Think.Admin.git/trunk/public/ [运行时间:0.192202s][吞吐率:5.20req/s] [内存消耗:1,735.26kb] [文件加载:49] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => '', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ RUN ] app\index\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\index\controller\Index.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/index\view\index.index.html [ array ( + 0 => 'mysql_ver', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:22+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/ +[ log ] localhost/git/Think.Admin.git/trunk/public/ [运行时间:0.172166s][吞吐率:5.81req/s] [内存消耗:1,735.26kb] [文件加载:49] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => '', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ RUN ] app\index\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\index\controller\Index.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/index\view\index.index.html [ array ( + 0 => 'mysql_ver', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:23+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/ +[ log ] localhost/git/Think.Admin.git/trunk/public/ [运行时间:0.178346s][吞吐率:5.61req/s] [内存消耗:1,735.26kb] [文件加载:49] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => '', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ RUN ] app\index\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\index\controller\Index.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/index\view\index.index.html [ array ( + 0 => 'mysql_ver', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:30+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin [运行时间:0.027518s][吞吐率:36.34req/s] [内存消耗:1,675.81kb] [文件加载:48] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => NULL, + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Index->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Index.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\index.index.html [ array ( +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:35+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login/out +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out [运行时间:0.030166s][吞吐率:33.15req/s] [内存消耗:1,733.65kb] [文件加载:49] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => 'out', + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->out[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\tpl\dispatch_jump.tpl [ array ( + 0 => 'code', + 1 => 'msg', + 2 => 'data', + 3 => 'url', + 4 => 'wait', +) ] +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:38+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.285504s][吞吐率:3.50req/s] [内存消耗:2,396.17kb] [文件加载:54] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:40+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.253184s][吞吐率:3.95req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:43+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.222344s][吞吐率:4.50req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:46+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.227475s][吞吐率:4.40req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:25:53+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.202697s][吞吐率:4.93req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:26:02+08:00 ] 127.0.0.1 127.0.0.1 POST /git/Think.Admin.git/trunk/public/index.php/admin/login.html?spm= +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html?spm= [运行时间:0.224704s][吞吐率:4.45req/s] [内存消耗:2,251.96kb] [文件加载:53] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html', + 'content-type' => 'application/x-www-form-urlencoded; charset=UTF-8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'x-requested-with' => 'XMLHttpRequest', + 'origin' => 'http://localhost', + 'accept' => '*/*', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'content-length' => '29', + 'connection' => 'keep-alive', + 'host' => 'localhost', +) +[ info ] [ PARAM ] array ( + 'spm' => '', + 'username' => 'admin', + 'password' => 'admin', +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:26:06+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.194527s][吞吐率:5.14req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:26:08+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.251247s][吞吐率:3.98req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:26:09+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.213909s][吞吐率:4.67req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- +[ 2017-02-13T15:26:10+08:00 ] 127.0.0.1 127.0.0.1 GET /git/Think.Admin.git/trunk/public/index.php/admin/login.html +[ log ] localhost/git/Think.Admin.git/trunk/public/index.php/admin/login.html [运行时间:0.242357s][吞吐率:4.13req/s] [内存消耗:2,184.48kb] [文件加载:52] +[ info ] [ LANG ] D:\WebRoot\git\Think.Admin.git\trunk\thinkphp\lang\zh-cn.php +[ info ] [ ROUTE ] array ( + 'type' => 'module', + 'module' => + array ( + 0 => 'admin', + 1 => 'login', + 2 => NULL, + ), +) +[ info ] [ HEADER ] array ( + 'cookie' => 'Hm_lvt_a749c1e19337bf37230ba6612eb08384=1461140972; Hm_lvt_df31b90409cbd7237728ca1a770d72e6=1462270422; Hm_lvt_382f81c966395258f239157654081890=1468996754; Hm_lvt_site_tongji_baidu=1470811295; Hm_lvt_ba76f8230db5f616edc89ce066670710=1475199764,1475205882,1475216746,1475222999; Hm_lvt_eafbf4b8e3422783a656563ed24ee102=1476178655; Phpstorm-82d7aa02=0e3cf729-9f9b-47a6-bbaa-60533d7847d8; Hm_lvt_300f21b954333702d5a49058b8302461=1481897306; pgv_pvi=4380452864; Hm_lvt_b74c94c4284592ec7cdd105cda50675b=1483765589,1483767170; Hm_lvt_f9a6d4c4393e28fa0b3f8a7d89c1c6da=1484548786; _ga=GA1.1.1347941633.1484560091; Phpstorm-eab8d6e1=f804067a-eb31-4f5b-afe0-c7b103070070; PHPSESSID=8j7dfvo310ouauv6ve7ulhphu7', + 'accept-language' => 'zh-CN,zh;q=0.8', + 'accept-encoding' => 'gzip, deflate, sdch, br', + 'referer' => 'http://localhost/git/Think.Admin.git/trunk/public/index.php/admin/login/out', + 'accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', + 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.87 Safari/537.36', + 'upgrade-insecure-requests' => '1', + 'cache-control' => 'no-cache', + 'pragma' => 'no-cache', + 'connection' => 'keep-alive', + 'host' => 'localhost', + 'content-length' => '', + 'content-type' => '', +) +[ info ] [ PARAM ] array ( +) +[ info ] [ SESSION ] INIT array ( + 'id' => '', + 'var_session_id' => '', + 'prefix' => 'think', + 'type' => '', + 'auto_start' => true, +) +[ info ] [ RUN ] app\admin\controller\Login->index[ D:\WebRoot\git\Think.Admin.git\trunk\application\admin\controller\Login.php ] +[ info ] [ VIEW ] D:\WebRoot\git\Think.Admin.git\trunk/application/admin\view\login.index.html [ array ( + 0 => 'ptitle', +) ] +[ info ] [ DB ] INIT mysql +[ info ] [ LOG ] INIT File + +--------------------------------------------------------------- diff --git a/runtime/log/201702/13_sql.log b/runtime/log/201702/13_sql.log new file mode 100644 index 000000000..b716cdffa --- /dev/null +++ b/runtime/log/201702/13_sql.log @@ -0,0 +1,74 @@ +[ 2017-02-13T15:24:16+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.072325s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] select version() as ver [ RunTime:0.047469s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:05+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.083081s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] select version() as ver [ RunTime:0.053416s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:11+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.083413s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] select version() as ver [ RunTime:0.054539s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:15+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.090656s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] select version() as ver [ RunTime:0.059757s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:22+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.081388s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] select version() as ver [ RunTime:0.052667s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:23+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.070316s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] select version() as ver [ RunTime:0.048477s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:38+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.092744s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.062826s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.061914s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:40+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.091101s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.060868s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.062520s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:43+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.080324s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.057568s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.055270s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:46+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.080896s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.054947s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.054665s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:25:53+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.071798s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.049264s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.047247s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:26:02+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.080301s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_user` [ RunTime:0.054278s ] +[ sql ] [ SQL ] SELECT * FROM `system_user` WHERE `username` = 'admin' LIMIT 1 [ RunTime:0.052934s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:26:06+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.072369s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.047883s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.047002s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:26:08+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.092387s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.060988s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.061939s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:26:09+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.079486s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.055046s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.052254s ] + +--------------------------------------------------------------- +[ 2017-02-13T15:26:10+08:00 ] [ sql ] [ DB ] CONNECT:[ UseTime:0.089792s ] mysql:dbname=think.admin;host=data.cuci.cc;port=3306;charset=utf8mb4 +[ sql ] [ SQL ] SHOW COLUMNS FROM `system_config` [ RunTime:0.061361s ] +[ sql ] [ SQL ] SELECT * FROM `system_config` [ RunTime:0.059401s ] + +--------------------------------------------------------------- diff --git a/runtime/temp/3bcd978f9cb3f7990d7036969405255d.php b/runtime/temp/3bcd978f9cb3f7990d7036969405255d.php new file mode 100644 index 000000000..deec22671 --- /dev/null +++ b/runtime/temp/3bcd978f9cb3f7990d7036969405255d.php @@ -0,0 +1,46 @@ + + + + + + 跳转提示 + + + +
+ +

:)

+

+ +

:(

+

+ +

+

+ 页面自动 跳转 等待时间: +

+
+ + + diff --git a/runtime/temp/d0720a6de1598fd846b92ea5de3d6a83.php b/runtime/temp/d0720a6de1598fd846b92ea5de3d6a83.php new file mode 100644 index 000000000..1ffc0fb55 --- /dev/null +++ b/runtime/temp/d0720a6de1598fd846b92ea5de3d6a83.php @@ -0,0 +1,23 @@ + + + + + + 后台首页 + + +框架版本: +
+系统类型: +
+运行环境: +
+PHP版本: +
+MySQL版本: +
+上传限制: +
+POST限制: + + \ No newline at end of file diff --git a/runtime/temp/f8a32d1b6015ffcf81f5293caa6f865c.php b/runtime/temp/f8a32d1b6015ffcf81f5293caa6f865c.php new file mode 100644 index 000000000..ecea2d933 --- /dev/null +++ b/runtime/temp/f8a32d1b6015ffcf81f5293caa6f865c.php @@ -0,0 +1,96 @@ + + + + + + + + <?php echo (isset($ptitle) && ($ptitle !== '')?$ptitle:''); ?> + + + + + + + + + + + +
+ + +
+
+ +
+ 欢迎登录后台管理界面平台 + +
+ +
+ +
+
+
+
+
+
+ +
+
+ +
+ + + + \ No newline at end of file diff --git a/runtime/temp/fc8deb1371272955af5d837d65c45b2b.php b/runtime/temp/fc8deb1371272955af5d837d65c45b2b.php new file mode 100644 index 000000000..bab2b2db1 --- /dev/null +++ b/runtime/temp/fc8deb1371272955af5d837d65c45b2b.php @@ -0,0 +1,2 @@ + +admin \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/.gitignore b/vendor/aferrandini/phpqrcode/.gitignore deleted file mode 100644 index 485dee64b..000000000 --- a/vendor/aferrandini/phpqrcode/.gitignore +++ /dev/null @@ -1 +0,0 @@ -.idea diff --git a/vendor/aferrandini/phpqrcode/LICENSE b/vendor/aferrandini/phpqrcode/LICENSE deleted file mode 100644 index 188330326..000000000 --- a/vendor/aferrandini/phpqrcode/LICENSE +++ /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. diff --git a/vendor/aferrandini/phpqrcode/VERSION b/vendor/aferrandini/phpqrcode/VERSION deleted file mode 100644 index e0d3a2ee7..000000000 --- a/vendor/aferrandini/phpqrcode/VERSION +++ /dev/null @@ -1,2 +0,0 @@ -1.1.5 -2012021604 diff --git a/vendor/aferrandini/phpqrcode/cache/frame_1.dat b/vendor/aferrandini/phpqrcode/cache/frame_1.dat deleted file mode 100644 index be28feac4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -xڝ E9u`"PńC牗T!0$ -EɲQmh۾9{kI" 9Ln)Ap־>^zmnŖ;mn \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_1.png b/vendor/aferrandini/phpqrcode/cache/frame_1.png deleted file mode 100644 index 86ce6e98d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_1.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_10.dat b/vendor/aferrandini/phpqrcode/cache/frame_10.dat deleted file mode 100644 index aff163f68..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_10.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_10.png b/vendor/aferrandini/phpqrcode/cache/frame_10.png deleted file mode 100644 index dbfcd70b5..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_10.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_11.dat b/vendor/aferrandini/phpqrcode/cache/frame_11.dat deleted file mode 100644 index 95af68a47..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_11.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_11.png b/vendor/aferrandini/phpqrcode/cache/frame_11.png deleted file mode 100644 index c07c761f1..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_11.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_12.dat b/vendor/aferrandini/phpqrcode/cache/frame_12.dat deleted file mode 100644 index 73228b362..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_12.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_12.png b/vendor/aferrandini/phpqrcode/cache/frame_12.png deleted file mode 100644 index 8ba67822c..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_12.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_13.dat b/vendor/aferrandini/phpqrcode/cache/frame_13.dat deleted file mode 100644 index 2256f0e34..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_13.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_13.png b/vendor/aferrandini/phpqrcode/cache/frame_13.png deleted file mode 100644 index 6e49d35a0..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_13.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_14.dat b/vendor/aferrandini/phpqrcode/cache/frame_14.dat deleted file mode 100644 index e9ae09329..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_14.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_14.png b/vendor/aferrandini/phpqrcode/cache/frame_14.png deleted file mode 100644 index efc36c034..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_14.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_15.dat b/vendor/aferrandini/phpqrcode/cache/frame_15.dat deleted file mode 100644 index 18727818d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_15.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_15.png b/vendor/aferrandini/phpqrcode/cache/frame_15.png deleted file mode 100644 index a9f416c7c..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_15.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_16.dat b/vendor/aferrandini/phpqrcode/cache/frame_16.dat deleted file mode 100644 index 60af67845..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_16.dat +++ /dev/null @@ -1 +0,0 @@ -xA E]sIX;n6`qW6`%A/3!!g̡1N) E|;>6⸏97$c]kkw1[mC͜cR>E,hʼnp#xFyWVWG3+˓S}Ğ#G8b^c^cpc&3YQ"vk9܇} ĿQL/ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_16.png b/vendor/aferrandini/phpqrcode/cache/frame_16.png deleted file mode 100644 index 6ac8fe890..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_16.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_17.dat b/vendor/aferrandini/phpqrcode/cache/frame_17.dat deleted file mode 100644 index 87f0cf593..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_17.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_17.png b/vendor/aferrandini/phpqrcode/cache/frame_17.png deleted file mode 100644 index 5b929ac73..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_17.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_18.dat b/vendor/aferrandini/phpqrcode/cache/frame_18.dat deleted file mode 100644 index bb7138c1d..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_18.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0E]օ,2;s&͚hO1&09OIv@DD &ىKXFv<dq9<%h Ys !(ds;~||b(Yůg#`KSĶsidߍLg:әt/gmkM3{4rTQes><әt3;H#љt3Y+oghٽlnF>i^#awm;g~pgNs{6zp' \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_18.png b/vendor/aferrandini/phpqrcode/cache/frame_18.png deleted file mode 100644 index ee0d6a35e..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_18.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_19.dat b/vendor/aferrandini/phpqrcode/cache/frame_19.dat deleted file mode 100644 index 95e26adc1..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_19.dat +++ /dev/null @@ -1,3 +0,0 @@ -xA - E.No7ћiiRN2W%x@ڜ' -u6.*S;}àT zrt%,};)ZLP$qgLdJ;w.]z#[͝Og" B}};w#1Gb;w_C+w@Dfu2N9R7|pWkk \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_19.png b/vendor/aferrandini/phpqrcode/cache/frame_19.png deleted file mode 100644 index 20fddd84c..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_19.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_2.dat b/vendor/aferrandini/phpqrcode/cache/frame_2.dat deleted file mode 100644 index 7e42f31ca..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_2.dat +++ /dev/null @@ -1 +0,0 @@ -x͒ F{v& &Y+?Z1S'y!a815&۴HٞclF1#6 f6O7C֏8gIfB\DԻ( \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_2.png b/vendor/aferrandini/phpqrcode/cache/frame_2.png deleted file mode 100644 index 9c150ebe3..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_2.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_20.dat b/vendor/aferrandini/phpqrcode/cache/frame_20.dat deleted file mode 100644 index d5ecc1d8a..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_20.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_20.png b/vendor/aferrandini/phpqrcode/cache/frame_20.png deleted file mode 100644 index 23a061d54..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_20.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_21.dat b/vendor/aferrandini/phpqrcode/cache/frame_21.dat deleted file mode 100644 index 1974dd9d4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_21.dat +++ /dev/null @@ -1 +0,0 @@ -xA E]sIX;n6Upв]٘< i-eW)ŕ…H\jvqHL\6ЅrILܹ%@Vv(P4|Xngɝ~]Du1Us S\,2N?DKF-:eJ]p_,a0` X` w,` X]5 Y4{2vJs9)u۹,]^_7$_ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_21.png b/vendor/aferrandini/phpqrcode/cache/frame_21.png deleted file mode 100644 index 291598c72..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_21.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_22.dat b/vendor/aferrandini/phpqrcode/cache/frame_22.dat deleted file mode 100644 index 0f01802d2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_22.dat +++ /dev/null @@ -1,3 +0,0 @@ -xA -0 E]{.]{{{ZBepwe@VERZ3"*2o4y)i#dbdF҅I"4WIu45x.ZS{8k={o.q[:帒qy -)t#N8dCj-OOG}:/:sz!)^IO- 7p 7$}>ɷ7p tssrs Vmҹ}R~7&?7ԦIbh{<Mi- \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_23.png b/vendor/aferrandini/phpqrcode/cache/frame_23.png deleted file mode 100644 index b8f16ae23..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_23.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_24.dat b/vendor/aferrandini/phpqrcode/cache/frame_24.dat deleted file mode 100644 index 7b92e29c4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_24.dat +++ /dev/null @@ -1 +0,0 @@ -xA EMX0;nVP4HSSxU3/O LiJ4V JC%6VR&DBHjDJ??BlcDZ'UXUޏ0ywįj똳3ścj{:GqGNv;笓J <]#8#8H'GqGtr:9#8#8ؓhNt_>teS^\gQe?vuo;>*wlm \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_24.png b/vendor/aferrandini/phpqrcode/cache/frame_24.png deleted file mode 100644 index 397c64f85..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_24.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_25.dat b/vendor/aferrandini/phpqrcode/cache/frame_25.dat deleted file mode 100644 index ba125182e..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_25.dat +++ /dev/null @@ -1,3 +0,0 @@ -xA - s낋]rxY51mMBG -*Sx|Ua5ƵZ-,1HPRjX5iG>WR/+uT廯 ӯ嗴u[Sa[kv5+5nJ%+VXbŊ߬u'SRtzZ++VXbŊٟٟٟ+VXb}Ŋ+VXVI+kq[toVZvoNVw}{r<ýR"R] Wr} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_25.png b/vendor/aferrandini/phpqrcode/cache/frame_25.png deleted file mode 100644 index 25bc4454a..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_25.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_26.dat b/vendor/aferrandini/phpqrcode/cache/frame_26.dat deleted file mode 100644 index d34a73f15..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_26.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA - Eօ,t77ћU E)i7*~cXEBFC6:&L,Mv.KgոYM>>mۚ?vmg?ұηdCUIkE\Msfafa>[sӈ9쬩ެ8b]LgEo w1 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_26.png b/vendor/aferrandini/phpqrcode/cache/frame_26.png deleted file mode 100644 index f4a6b3938..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_26.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_27.dat b/vendor/aferrandini/phpqrcode/cache/frame_27.dat deleted file mode 100644 index b4d9ffd4f..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_27.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_27.png b/vendor/aferrandini/phpqrcode/cache/frame_27.png deleted file mode 100644 index 8419ec230..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_27.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_28.dat b/vendor/aferrandini/phpqrcode/cache/frame_28.dat deleted file mode 100644 index 8cbaa1961..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_28.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_28.png b/vendor/aferrandini/phpqrcode/cache/frame_28.png deleted file mode 100644 index 7609d8e1f..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_28.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_29.dat b/vendor/aferrandini/phpqrcode/cache/frame_29.dat deleted file mode 100644 index 5e4a71103..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_29.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA a޺ @n7+*4!?J 抮]STf)sI"Ȕb0|"Luٸ,E1\6*uQ?>aυR-rn.ꯋ\T:*)|) , ,x_}:^RUoɢu~މX`XЏЏЏЏ_`X`XЏЏЏ_`X`XЏЏЏЏwbX`PU)D"c{z3<}^?bm잃a.] -{Q6uT,9 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_29.png b/vendor/aferrandini/phpqrcode/cache/frame_29.png deleted file mode 100644 index ffe072c86..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_29.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_3.dat b/vendor/aferrandini/phpqrcode/cache/frame_3.dat deleted file mode 100644 index 188d531c2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_3.dat +++ /dev/null @@ -1 +0,0 @@ -x E{v& &Y+bk'ya:TXl޶$W+ӏv9}gR@H0YPBEm?s"bt2cn:ﺭ;YzQ7 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_3.png b/vendor/aferrandini/phpqrcode/cache/frame_3.png deleted file mode 100644 index 945ee7cb9..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_3.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_30.dat b/vendor/aferrandini/phpqrcode/cache/frame_30.dat deleted file mode 100644 index 44cf3d317..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_30.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_30.png b/vendor/aferrandini/phpqrcode/cache/frame_30.png deleted file mode 100644 index 75dbddd24..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_30.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_31.dat b/vendor/aferrandini/phpqrcode/cache/frame_31.dat deleted file mode 100644 index ce429d0a6..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_31.dat +++ /dev/null @@ -1 +0,0 @@ -xA a޺ &r4yķ!mV3Iv!Ҝ2i\NSS4EF2+65e/Ws]!?p=S~Đ?+x6r6y}ǴeR1-WllҌXz/>V櫷:ñA8-+mTbllltM&]ll&]Ill&]y 6` 6`iuyXWi\tz>.zk t77wJϔ4w҈85 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_31.png b/vendor/aferrandini/phpqrcode/cache/frame_31.png deleted file mode 100644 index b14d1fa26..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_31.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_32.dat b/vendor/aferrandini/phpqrcode/cache/frame_32.dat deleted file mode 100644 index aaa0808e2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_32.dat +++ /dev/null @@ -1,2 +0,0 @@ -x - ־. Dl, Mz6Ç gcJD;'.AIqމI,IrYFk%DOy|EDD(L_Y>*ߚ?aOkL_<[c>c˘uLI%#0#0#otѢ}4fv_)Eph5R881#0#0itZ#0#0#0itZ#0#0#0itZl0#09q"HܜHQ"L5}-Y׾k`>z鸳4&p!!`:5 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_32.png b/vendor/aferrandini/phpqrcode/cache/frame_32.png deleted file mode 100644 index 58d42db3c..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_32.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_33.dat b/vendor/aferrandini/phpqrcode/cache/frame_33.dat deleted file mode 100644 index a2613755a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_33.dat +++ /dev/null @@ -1,14 +0,0 @@ -xA a޺@n7+*L++柮bb*LCc kHrjJ5Yi~0_TT}e>5b_w͟?\Rai+7W\wLUNL -+ -+jOkc\˩|%o} 8 -+ -+ -+ 3g -+ -+ -+3g@ -+ -+ -+:RXB9I=ko/Swؘٯ`gr_ٙYVSYzIefnmQoz > \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_33.png b/vendor/aferrandini/phpqrcode/cache/frame_33.png deleted file mode 100644 index 924c728e0..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_33.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_34.dat b/vendor/aferrandini/phpqrcode/cache/frame_34.dat deleted file mode 100644 index 7ceb0259d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_34.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_34.png b/vendor/aferrandini/phpqrcode/cache/frame_34.png deleted file mode 100644 index a477042d8..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_34.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_35.dat b/vendor/aferrandini/phpqrcode/cache/frame_35.dat deleted file mode 100644 index 56bc3e28e..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_35.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_35.png b/vendor/aferrandini/phpqrcode/cache/frame_35.png deleted file mode 100644 index d29806c60..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_35.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_36.dat b/vendor/aferrandini/phpqrcode/cache/frame_36.dat deleted file mode 100644 index 282c60d23..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_36.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_36.png b/vendor/aferrandini/phpqrcode/cache/frame_36.png deleted file mode 100644 index 96ecb4213..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_36.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_37.dat b/vendor/aferrandini/phpqrcode/cache/frame_37.dat deleted file mode 100644 index 015c0f24b..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_37.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_37.png b/vendor/aferrandini/phpqrcode/cache/frame_37.png deleted file mode 100644 index fcc51627d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_37.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_38.dat b/vendor/aferrandini/phpqrcode/cache/frame_38.dat deleted file mode 100644 index 71cf53eb5..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_38.dat +++ /dev/null @@ -1 +0,0 @@ -xA0ЎuA2;Нk(gytp9$D\e^'t-aIFMSkIŤ:7|LkN8N7i}i,[WgӴ?31iN}}=OM:4)SL2eʔ)SL#$ JJM:}]L٧SQL2eʔ)SL2աPt(:)SL2eʔ)S:ECq2eʔ)SL2eʔECѡ8O2eʔ)SL2eTCѡPL2eʔ)SL2ݓsJCIKԂi93n_ +Ri4\g;% }an \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_38.png b/vendor/aferrandini/phpqrcode/cache/frame_38.png deleted file mode 100644 index 89238f3c5..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_38.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_39.dat b/vendor/aferrandini/phpqrcode/cache/frame_39.dat deleted file mode 100644 index 53511f736..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_39.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_39.png b/vendor/aferrandini/phpqrcode/cache/frame_39.png deleted file mode 100644 index 1dc9cd1bc..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_39.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_4.dat b/vendor/aferrandini/phpqrcode/cache/frame_4.dat deleted file mode 100644 index 67b30e82a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_4.dat +++ /dev/null @@ -1 +0,0 @@ -x E=u pجQCOM'ˏ$ @3eF\FNXRyؾC{a8R Ńa2@qkH1(`cj~0ܨعnXGĀ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_4.png b/vendor/aferrandini/phpqrcode/cache/frame_4.png deleted file mode 100644 index b72f9e70d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_4.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_40.dat b/vendor/aferrandini/phpqrcode/cache/frame_40.dat deleted file mode 100644 index 90d36dd13..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_40.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA@Ь@o7`Qfe䕫PA><]߳bZn^AQ}[9^]ynajM܇K̘1cƌ3f̘1{W5}{7lMޚxI<Kαyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘SʑӒ7HK޼g\u_r'4[-]qL8ƝY1q!/(% \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/frame_40.png b/vendor/aferrandini/phpqrcode/cache/frame_40.png deleted file mode 100644 index 8034d862d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/frame_40.png and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/frame_5.dat b/vendor/aferrandini/phpqrcode/cache/frame_5.dat deleted file mode 100644 index d5dafe186..000000000 --- a/vendor/aferrandini/phpqrcode/cache/frame_5.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Eu7ЛZ|ND B0@R$l,->VKZ[I9+Es=ϤL1̄[FZU4?i<;7;P#W-[ݯ6ddddddc",;"sk摑Q&erw######L.摑Иy1^˲\3 v \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_117_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_117_0.dat deleted file mode 100644 index 781c7f875..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_117_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0 }OrR,#3,o5Cq:;;wvNJZG=m} ѱ2iRkj_YYYYYYYYe_/WVVVVVVkd-Ϻ,#OZc]|{ž$ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_121_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_121_0.dat deleted file mode 100644 index 68810c347..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_121_0.dat +++ /dev/null @@ -1 +0,0 @@ -x1 О/w YMS8>2SFOEcW\ۼ{cpKGBКmxhfffffff/s22W|*d1*5̬RWas\xm~8߮r0wjsdm&y \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_125_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_125_0.dat deleted file mode 100644 index 2c73ef1a8..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_125_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA - н_TH`3AOL4 k(ewGW. #2} \Ygggggggggg_d>j^s;;;;;;;;;;'q;;;;;;;;;'˰qu_PYw{e=dG/ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_129_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_129_0.dat deleted file mode 100644 index 812ee8a66..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_129_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - /*DE'hgt-}_pV \"b=s[J=8Dho۞' 0X ۴e0`  j" 0`Wf`^P0`2Ȁ  d07(Y/XLGby"pT \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_137_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_137_0.dat deleted file mode 100644 index f6d993b03..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_137_0.dat +++ /dev/null @@ -1 +0,0 @@ -x1 О/+FZ?J L7Ժ*Ba%L~˻ʓCJYIWJ .K]R0a„ $INTwlLaL0a„ &Ld@PO0a„ &L0e@P?a„ &L0aDe@ &L0aMIlL&)dlgacR<$v,ɺ?U2] \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_141_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_141_0.dat deleted file mode 100644 index 8c685c8ea..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_141_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -x= -0 нi9'EDx͘%I9+E{$m^&uS"D6ڟ]98UMbҾY[2拉Ĉ#F1bĈ%iRN潝ѳ#;#F1bĈN1i#F1bĈ#FtZ}Nk1bĈ#F1bktZ;#F1bFV-u"IoD-*7uj>bMV+ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_149_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_149_0.dat deleted file mode 100644 index d25835029..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_149_0.dat +++ /dev/null @@ -1,3 +0,0 @@ -xA - н_MEQXP৞.|94e{JLv#^n[ ?; -ZIV-*w˒1*+VXbŊXgwqX}JRYbŊ+VXbeΠwfeΠ^bŊ+VXbʜAʜAbŊ+VXbŊ9ٜAbŊ+VXbŊl0*0Tj`?Ϊ;X=zZr* \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_153_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_153_0.dat deleted file mode 100644 index fc79e9ede..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_153_0.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Н/礑h&F`Ҽ@I;PZ^X͌mf.=5 [if-R+!wr˜g\j̘1cƌ3f̘1cfo.2?1z `ƌ3f̘1cƌzƌ3f̘1cƌ3fztf3f̘1cƌ3f̘kk030cƌ3f̘1c9;Ď`vf͚̆ZϘW9 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_157_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_157_0.dat deleted file mode 100644 index ad749f305..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_157_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA - н_QRY k*q͵=j7~nN.p%ڵsi.رcǎ;vر{.-W2={mgy+رcǎ;vɳ2;yּcǎ;vرcNɳ;vرcǎ;v2I9+DyI4ˠ5:Wvdqߜܴ<d2x%[U%2]&K,Ydɒ%ˡ,S՗r2yd=,k_{Xdɒ%K,Yd)0m,Ydɒ%K,Yd)0m,Ydɒ%K,Yme,e%K,Ydɒ%K,eq Ò%K,Ydɒe:I9EQ=Ls I{ZtR}Sn:|R[?_*SL2eʔ)SL&ϦI O2O2eʔ)SL2e*C1PPSL2eʔ)SLP22)SL2eʔ)SLe(}2)SL2eʔ)SLe(}2)SL2eʔ)Sic7;"ޙFͦސٙvL ^2}oO'r \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_173_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_173_0.dat deleted file mode 100644 index 5ef85e7ad..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_173_0.dat +++ /dev/null @@ -1 +0,0 @@ -x10ޯT [4v2ƽok݇;Ӳ]f֞dljlG0n+߻mG˖-[lٲe"Y}oV[lٲe˖-[lٲeհՃ[2lٲe˖-[lٲeհՃ[2lٲe˖-[lٲeհՃ[lٲe˖-[lٲeValٲe˖-[lٲef[BmаE;N-ۜT/rl?* \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_177_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_177_0.dat deleted file mode 100644 index 78a26a77b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_177_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0>I9+?߁iև d̹xֈxN/է|{ظ8d0h=cFf̘1cƌ3f̘qq=w6;l4cƕ<nj3f̘1cƌ3fXһ1ֻcƌ3f̘1cƌ3fXbwnj3f̘1cƌ3f̘M'X&1cƌ3f̘1cƌ3ֻnn1cƌ3f̘1cƌÍ3U< \7+(<OƌΊnj4@ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_21_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_21_0.dat deleted file mode 100644 index 368c9941f..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_21_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_25_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_25_0.dat deleted file mode 100644 index e4a5b6d8a..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_25_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_29_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_29_0.dat deleted file mode 100644 index 74a216b4f..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_29_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_33_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_33_0.dat deleted file mode 100644 index 2ec712a7a..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_33_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_37_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_37_0.dat deleted file mode 100644 index 1588cfce1..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_37_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_41_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_41_0.dat deleted file mode 100644 index e369027e3..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_41_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_45_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_45_0.dat deleted file mode 100644 index 452f126c8..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_45_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_49_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_49_0.dat deleted file mode 100644 index fdd2aac15..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_49_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK E9o#?H/6g$-,X] -xݘ; X԰9<Ѻq2AfH7/5We{#fި?4=N > \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_53_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_53_0.dat deleted file mode 100644 index 572d279ef..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_53_0.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK -@!йoQϺ:(m&s-6Z{m4YX.F٭XZij=:έ֋b忑VH 8 #[Y^Xe \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_57_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_57_0.dat deleted file mode 100644 index ea81e6dc6..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_57_0.dat +++ /dev/null @@ -1,4 +0,0 @@ -xA - {^s=YL՚ ( -ouj)  -Z7yv,ԴwVQ iGiҤDfەwo4ѤoLLȼ}4 h \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_61_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_61_0.dat deleted file mode 100644 index 93d2444d8..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_61_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_65_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_65_0.dat deleted file mode 100644 index df29d7bfb..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_65_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_69_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_69_0.dat deleted file mode 100644 index 8a2cfbd7c..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_69_0.dat +++ /dev/null @@ -1 +0,0 @@ -xK =_+mBd|Q"s+1"),=Ea T"ŐnE-3 ,KYw=ZZT .,K1#֞!Ŋ+V嬪.2XbŊ+VX.kBzwձ̀gkYZ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_89_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_89_0.dat deleted file mode 100644 index aaa4c5267..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_89_0.dat +++ /dev/null @@ -1 +0,0 @@ -x1 ὧi9'Hl?L^"&M?bq?˸,9!z]VScƌ3_c!`n3f̘1č 3f̘1/f>.Uc˻; 2;Y+7 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_93_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_93_0.dat deleted file mode 100644 index e218fa0ef..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_93_0.dat +++ /dev/null @@ -1,3 +0,0 @@ -xK - EyV,OmޠrPH0{2bc{tQ] -{Q{{弬֒ǎ;v_ڳ}L}l߱cǎ;v̑̑̑رcǎ.Legw3qeѾ@i \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_97_0.dat b/vendor/aferrandini/phpqrcode/cache/mask_0/mask_97_0.dat deleted file mode 100644 index 74ac719d0..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_0/mask_97_0.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_101_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_101_1.dat deleted file mode 100644 index ec939b521..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_101_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - н\QEd  1N<#Ֆ-7u.lԦeiXXXXXRZVVeIo1,,,,,v%?gaaaaY K&K=/+ۍ˱ގ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_105_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_105_1.dat deleted file mode 100644 index e1f5c99b4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_105_1.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Ӕ_Υb KB?"*#WʘtgӎJqUM9TLLvǤLLLLLLzgG01111yiߘ4m=՛n+2 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_109_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_109_1.dat deleted file mode 100644 index 7e0d6d164..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_109_1.dat +++ /dev/null @@ -1 +0,0 @@ -xֱ >ӘK}:!iY'*3]fsmb[JƶŖK9}cccccc'u.6Ʀs6666R[^g{/lٷ 7͂ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_113_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_113_1.dat deleted file mode 100644 index 1dd666d9b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_113_1.dat +++ /dev/null @@ -1 +0,0 @@ -x1  -8fL(pBlDM9";-;?1p{\%-3:@ad4*Nadddddd########c]751xYu \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_117_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_117_1.dat deleted file mode 100644 index 8921f6437..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_117_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -xֻ >ӘK$^ 8YQSV'z8jzʇ^]סekXYYYYYYYjݵ# -+yeeeeeeee#WVVVVVVVV;"+yeeeeeeel'e;b&^9{/J$p \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_121_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_121_1.dat deleted file mode 100644 index 64bd8ba04..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_121_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - н\CPbїE$DdƩYtڅλ0$ήꝝga7yٯ痽Y??{{D \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_129_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_129_1.dat deleted file mode 100644 index 62cd1c9a1..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_129_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_133_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_133_1.dat deleted file mode 100644 index 18d68dce8..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_133_1.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Ӕ_΅hh|"zۉ-*dNHQĢR ,X`c9Y(na_` ,X,X,X` #:8  ,X`Bd¾` ,X|ϢY\X; 7-; ` \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_137_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_137_1.dat deleted file mode 100644 index 284d7beab..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_137_1.dat +++ /dev/null @@ -1,3 +0,0 @@ -x1 -0 ӤKh]D,-t #ڌQ[T Ks7_?9|B&X^L0a„&3„M&L0a„ &2D4c0a„ &LȀЌe„ &L0abwȀf,&L0a„7&y2anoL<01O - \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_141_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_141_1.dat deleted file mode 100644 index 83220ddb4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_141_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - >946)3$`s uʮ>Wd )g'M{3\d6ubذaÆ 6lؼn]Nذ9FްaÆ 6lذa3a#oذaÆ 6lذذ5e16lذaÆ ]Sbk6lذaÆ mͤ;CcfIdsG \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_145_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_145_1.dat deleted file mode 100644 index 6a9950f7a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_145_1.dat +++ /dev/null @@ -1 +0,0 @@ -x!0@k 4a)q2i.YCUO{35UZFn]fN>bdwtzJF}F1bĈ#F(F6r1bĈ#F1E1ilF1bĈ#FtF#F1bĈ#FtZ}##F1bĈleHGܣ@ٝ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_149_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_149_1.dat deleted file mode 100644 index 02a3cdc6e..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_149_1.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Ӕ_΅qH_Xci#Gd̘Ք՛gLU^ݮVR>dKVXbŊ+VXeoXJ_bŊ+VXb;ݙ+}Ŋ+VXbŊ+VAVngŊ+VXbŊ}+ +VXbŊVj>hewf*`uTq \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_153_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_153_1.dat deleted file mode 100644 index 2abfca20b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_153_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0\9btEc'HH9efߞmffM#.̘1cƌ3f̘1cf73f̘g̘1cƌ3f̘1co2c]?3f̘1cƌ3f5Mf3f̘1cƌ3f̘17utf3f̘1cƌ3f̘=lj3>V \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_157_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_157_1.dat deleted file mode 100644 index 17344b891..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_157_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - >94Sd/51V)SkJv7eGcǎ;vرc]Zٱc'رcǎ;vر+رg;vرcǎ;}V`N+رcǎ;v:;v;vرcǎ;;}Vޱcǎ;vص'vz#;]klwoA` \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_161_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_161_1.dat deleted file mode 100644 index 669ade1b8..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_161_1.dat +++ /dev/null @@ -1 +0,0 @@ -x10_΅Xš yi~Qbkvp7'M u=]([ 2dȐ +\' 2 2dȐ!C 2s0/3d() 2dȐ!C 241dh 2dȐ!C 2dhcȐSL2eʔ)SL2M SLSL2eʔ)SL2M}LSSL2eʔ)SLeSy)SŔ)SL2eʔ)S;ٔ)S;)SL2eʔ)Sv()Sv()SL2eʔ)SLdT6}a*3mljmzC' \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_173_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_173_1.dat deleted file mode 100644 index 436918c0b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_173_1.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Ӕ_Υ''@y]X1?"g:1犝fn˶˻mm.?lٲe˖-F>glٲ2lٲe˖-[lٲeO`˖e˖-[lٲe˖-[l lٲlٲe˖-[lٲeVO`˖e˖-[lٲe˖-[z0}[z0y˖-[lٲe˖-[Ee[hOVWö=t*| \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_177_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_177_1.dat deleted file mode 100644 index 12e2e522f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_177_1.dat +++ /dev/null @@ -1 +0,0 @@ -x1 Ep0X,a#r}6}nj~\8ƌ3f̘1cƌ7{3f,y3f̘1cƌ3fX_`X&3f̘1cƌ3f̘M_1cy̘1cƌ3f̘1cƌ+3f,y3f̘1cƌ3fX_bX&3f̘1cƌ3fx2dX'x[cy| 3 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_21_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_21_1.dat deleted file mode 100644 index f87e0a112..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_21_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_25_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_25_1.dat deleted file mode 100644 index 3a225e30f..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_25_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_29_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_29_1.dat deleted file mode 100644 index 0a1cb3b5d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_29_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_33_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_33_1.dat deleted file mode 100644 index 318949df0..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_33_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_37_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_37_1.dat deleted file mode 100644 index 5bd9e3aa0..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_37_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_41_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_41_1.dat deleted file mode 100644 index 52e9e58f4..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_41_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_45_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_45_1.dat deleted file mode 100644 index b35c567dc..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_45_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_49_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_49_1.dat deleted file mode 100644 index d20d71710..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_49_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_53_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_53_1.dat deleted file mode 100644 index a676d7dfa..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_53_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_57_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_57_1.dat deleted file mode 100644 index 896ed4357..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_57_1.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_61_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_61_1.dat deleted file mode 100644 index 4165a4bd2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_61_1.dat +++ /dev/null @@ -1 +0,0 @@ -x30CbpPi`@&H^nadQG{n_.4Iy킎`)-5*(of[sm}6YM ;;;;;G{zطz1vw}=wuL%?"=~ei \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_97_1.dat b/vendor/aferrandini/phpqrcode/cache/mask_1/mask_97_1.dat deleted file mode 100644 index 24fa60fc3..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_1/mask_97_1.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0н1\tncKD"H$DH$D"Q&WerH$D"*x[(?/'nd \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_117_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_117_2.dat deleted file mode 100644 index b4dcce46f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_117_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - >94!m dOs\0X,la5#E>Z[ַRT*JR?Q-*T*JR?UW*JRTݟ+JRԤ~m5;S&+ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_121_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_121_2.dat deleted file mode 100644 index a2a0097b1..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_121_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_125_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_125_2.dat deleted file mode 100644 index 0ea40fdae..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_125_2.dat +++ /dev/null @@ -1 +0,0 @@ -x! PӔ_@ U(kp@^Mڮ5-:VF_\t:NtyNqt:NtG;Nt:.8:NtzA}yNq;+n& \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_129_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_129_2.dat deleted file mode 100644 index bf048394b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_129_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0н_KVڡ'.!w]A0X~  !࣠fK# xFy4 vey@^+  ~  L#veI \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_133_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_133_2.dat deleted file mode 100644 index 9e78b6de5..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_133_2.dat +++ /dev/null @@ -1,10 +0,0 @@ -x1 - н&`LQ-g=Aqbʪl fƄȚ44& )OȚYF4444444444c4~9S:3ЌטpǮ> \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_145_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_145_2.dat deleted file mode 100644 index 9ff2bbf3f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_145_2.dat +++ /dev/null @@ -1,4 +0,0 @@ -x1 - нr] -,tQ^&C~ -щj~mɾ.FgMDDDDDDDDDDDST׈DHdZL+ɴDDDDDDDDDDD2-'"""""""":BתEYDd \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_149_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_149_2.dat deleted file mode 100644 index d52e0484b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_149_2.dat +++ /dev/null @@ -1 +0,0 @@ -x;@/gcaGBXB'-ˆouէUQdRVOmT*ǫ;;j廝Ee2PQQQQQQQQQQQ TTTTTTTTTTTTr33R &Tskz_e2P=d \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_153_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_153_2.dat deleted file mode 100644 index 3b0604101..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_153_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0 Ӥ8ZP!BZu賶"bu*)]MFFFFFFFFFFFF%= #ddddddddddddr ot2yFFFFFFFFFFFF& #k5L 2222222222(Y7"d@H \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_157_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_157_2.dat deleted file mode 100644 index 2baf535e2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_157_2.dat +++ /dev/null @@ -1,3 +0,0 @@ -x1 -0>s6MqUH1X&U̘f/u-'.[KGGGGGGGGGGH|NG(ttttttttttNF;::::::::::}Nz$ ->n A#^AG(t =3{ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_161_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_161_2.dat deleted file mode 100644 index d2df7594e..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_161_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_165_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_165_2.dat deleted file mode 100644 index 2e6cd7c6f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_165_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0 Ӥ?BVUG%*+_fs MIIIIIIIII2d;l4()))))))))))eqJنIDIIIIIIIIIII)۠mPRRRRRRRRRRR6l JJJJJJJJJJJJن}RaQRRRRRRRRRRNeK?R퐔͔&W3U \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_169_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_169_2.dat deleted file mode 100644 index 4052062b8..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_169_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_173_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_173_2.dat deleted file mode 100644 index 0a30ba530..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_173_2.dat +++ /dev/null @@ -1 +0,0 @@ -x+@ Pift:>y &d U߬S[]5Z;a5V۞A[Z˴VՃI0ZZZZZZZZZZZZZZ=-Lhi`VFK?ݧhioJ0}o \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_177_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_177_2.dat deleted file mode 100644 index d2c52f990..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_177_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - E>Y4V$~ ,C&U;Ook5bϙGx9%&&&&&&&&&&&n$OL|v#&&&&&&&&&&&&&bbݍXw#&l7bbbbbbbbbbbbbbM"l7bbbbbbbbbbbbbbMa!&݈3)U*F> \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_45_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_45_2.dat deleted file mode 100644 index ad44ff188..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_45_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_49_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_49_2.dat deleted file mode 100644 index 6e8edff24..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_49_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_53_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_53_2.dat deleted file mode 100644 index 682cae2aa..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_53_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_57_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_57_2.dat deleted file mode 100644 index 66a5c056b..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_57_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_61_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_61_2.dat deleted file mode 100644 index 77d3815eb..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_61_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_65_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_65_2.dat deleted file mode 100644 index caf184ada..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_65_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_69_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_69_2.dat deleted file mode 100644 index 6a3801bf5..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_69_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_73_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_73_2.dat deleted file mode 100644 index 74945b718..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_73_2.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_77_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_77_2.dat deleted file mode 100644 index 903cba4a0..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_77_2.dat +++ /dev/null @@ -1 +0,0 @@ -x1 н_CM>Gt ѫe+FWZEm&gއFѶhF+t/FYvFj[*7a \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_81_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_81_2.dat deleted file mode 100644 index 17a9ac2a1..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_81_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0н_KҩVi!O\"A]:xbW1uȦ&_T ΋6H$U^D~bׯb=gX \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_85_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_85_2.dat deleted file mode 100644 index 72c74ff9a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_85_2.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0=1\B7O$A0$8Wwjguu槊RT*uS֧JRTJRRޢN浘V \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_89_2.dat b/vendor/aferrandini/phpqrcode/cache/mask_2/mask_89_2.dat deleted file mode 100644 index 06c9a4fe3..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_2/mask_89_2.dat +++ /dev/null @@ -1 +0,0 @@ -xٱ 0 >/&E*cQqŃ zf$rM)_%s_d3KO1^aL,$H"$KzRPt[I&X9$H"$I$ysI$DI$ɓI$I$Dɍ%es!=LAZ5'̓IVrn/2oƅ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_113_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_113_3.dat deleted file mode 100644 index 023b27304..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_113_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0 D}NrnDFj2KCt?WݲZi.qoP %Smj7ަ:*N:@:***fW9d2*j*}S@`*j৪6Jlѿ}}էTUa24hnt \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_117_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_117_3.dat deleted file mode 100644 index 79cc04d14..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_117_3.dat +++ /dev/null @@ -1,4 +0,0 @@ -x1 -0 ]Q.xIB$?~!z#E)RHZ@bl-)ݿ<ߧ*OUR"5&5*ie J]+ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_145_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_145_3.dat deleted file mode 100644 index 338b7e7a8..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_145_3.dat +++ /dev/null @@ -1,3 +0,0 @@ -x -@|:^ Jy̡yMj-' -9VS֦K9e)PyUwe-m jԨQF5jԨRi٫F4_wk}0+jRBRF5jԨQeOMBJHjԨQF5jwP״˪IH I5jԨQFͳc w5jԨQF:zS*2UZ_C*e_OZ%dIȯb \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_149_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_149_3.dat deleted file mode 100644 index 30bc5fabc..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_149_3.dat +++ /dev/null @@ -1 +0,0 @@ -xA0}Oܠ⦐H頯'Z2{oV|Ι%>yR{!8ÂI+JpI|#f5κ[P A $H Q})&X{ט+Wb`I)5%d \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_153_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_153_3.dat deleted file mode 100644 index 89cdec031..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_153_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0}Ns˹)7mJ,}8X=cW^GeN}o%uJV/{%O>}ӧO}K~O>}ӧO>Q=/ї>}ӧO>}u{ח>}ӧO>}u{蟪/%?}ӧO>}ׯ.N4჏VMmRt(1| \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_177_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_177_3.dat deleted file mode 100644 index 9586979a1..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_177_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_21_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_21_3.dat deleted file mode 100644 index bcb4eec49..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_21_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_25_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_25_3.dat deleted file mode 100644 index 0ffc375fc..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_25_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_29_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_29_3.dat deleted file mode 100644 index 6150ac128..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_29_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_33_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_33_3.dat deleted file mode 100644 index 6053b5e39..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_33_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_37_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_37_3.dat deleted file mode 100644 index 5dea5b9cb..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_37_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_41_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_41_3.dat deleted file mode 100644 index ca9ddc2aa..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_41_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_45_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_45_3.dat deleted file mode 100644 index 3daad97f8..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_45_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK - DsFJ(&)0dЇFg![8=&iaD)d8&Aլa 1'II׳79 ex߾ I&֝CuJy \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_49_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_49_3.dat deleted file mode 100644 index 7f6508ddd..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_49_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_53_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_53_3.dat deleted file mode 100644 index 8800beab1..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_53_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK -0Ds ! -(.Bp&|"-t&`qQ-"9_+)Be/H8D%a~}spKFN=,;;a^t4\FSN \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_57_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_57_3.dat deleted file mode 100644 index 4e1e5da38..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_57_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_61_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_61_3.dat deleted file mode 100644 index bf1a3cc7f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_61_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0fz4-%*dp!yZܫu(~=&ۓ)R2"/"<9FΊ=rb"/rw"2B#3-0-KW \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_65_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_65_3.dat deleted file mode 100644 index 85892089b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_65_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xQ - D4\?R ,!O-Nv1:cZu "UMÕF ~jK-la[^q^Q\=o-laZpUB @IKJzɢ|1Í  \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_69_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_69_3.dat deleted file mode 100644 index 55318a87b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_69_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -x -0 {&2'd l=,Fy;$쇤WE-R:%T,O2g"",Ȣ/DyĈɧ{O䮳",:NvEWN#(&,,]x؅ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_73_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_73_3.dat deleted file mode 100644 index 15be77f64..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_73_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xQ -0 C{g;JJ?dԬK=RasJhTJ6exka\$nIE,-/XB*х=wee4t̒tLщtt߫b gFf qoddn-? \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_77_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_77_3.dat deleted file mode 100644 index ec7828044..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_77_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0 &BiRaK"t`I@|fXyilE:Sza18GifK*?:YC1쌞졘(ቷJ*jl*TRIKR^ؙks)c)c)JZa \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_81_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_81_3.dat deleted file mode 100644 index 47bc0f793..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_81_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 - F=\,JGAġhj>#3X:kԹ\FM Jhu3>TZ{PSgP'kVjժU_ۯUV=P oO:Wҝj[Wxm 5 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_85_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_85_3.dat deleted file mode 100644 index 02c4f8cdb..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_85_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_89_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_89_3.dat deleted file mode 100644 index 2b4cb59fc..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_89_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 ὧ) *.@U |eŵ6ۢw5*) oiK4nk>1}d>@ 4XYCo ۡ1<AhFt - 4@51Wr>7G}}x7|NgN \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_93_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_93_3.dat deleted file mode 100644 index b4cc8a971..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_93_3.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0 D}NrnJɪQ~B06na<<ׇe6MRCP L̓i9M 2 LkŮdDv*"aXjBdAddZTdAdqY0exqeN&WVQvc \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_97_3.dat b/vendor/aferrandini/phpqrcode/cache/mask_3/mask_97_3.dat deleted file mode 100644 index 7adc9ebaa..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_3/mask_97_3.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_101_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_101_4.dat deleted file mode 100644 index 1c97dc048..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_101_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA Fs^1bИ]4m+8+Ve^HR]\c -oWN#X+l HEcp \^.9qW9":.BB \0aPǨcp \ONqjpG}}$.˅ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_105_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_105_4.dat deleted file mode 100644 index 0211cdb3a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_105_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK -0 D=Mr˹A TeEFL2 #鹢_I!딤Ѻ-իkmO]sS T6*'8 N$'NZ^}rU*G9r|c[cN[_=׫5^J 1*qv \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_117_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_117_4.dat deleted file mode 100644 index 386725918..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_117_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -x - н_s]4Dgn2Jj}ҾRsSWGRɧ)5Em#ܯk_"z3\rʕ+r Lk|/{;'/#\p\p># \p\p#>qp\p.$Iq dGR_4  \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_137_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_137_4.dat deleted file mode 100644 index 0c09c487c..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_137_4.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_141_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_141_4.dat deleted file mode 100644 index 62b03f243..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_141_4.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_145_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_145_4.dat deleted file mode 100644 index 33fb21124..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_145_4.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_149_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_149_4.dat deleted file mode 100644 index de99310f3..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_149_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -x -!н_sm +XӋ9=.=Zka]ޒ> Kjo |SSWKZm׌j\Ъ2 W\qW\q"~ jvtv_\qW\qW\q%g3 }+++ r9ArW\qW\qŕA g3WA W\qW\qW]V~v{D3Ȝ!\W^Tڍ[S7vۜgq? -{peo383838{YXz,_OYfe3s38383\C!Ms38383r \C?37938383\C!07M8383q,mMrskWv3~W WB \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_157_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_157_4.dat deleted file mode 100644 index ad5fcf69d..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_157_4.dat +++ /dev/null @@ -1 +0,0 @@ -x10ޯs4"FP=iRX¢X0멪u 4ftl}m➭S|юS P5<]rwqwq^QN6ÏZsߙ,wqwqǝ>Μ5g;;Y}Vgw,wqwqw>9wqwq>3gY;[ww?P3Ƙggt퐮;].3w4A \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_161_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_161_4.dat deleted file mode 100644 index 7604c4540..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_161_4.dat +++ /dev/null @@ -1 +0,0 @@ -xA@ fs!AL_|,4l)iml׉0' +E ]N\x#2/_{7g9쏼ٷ}2r!?}-#Te9C9C9~6Sʇ겺!r!r!ۘse9C9C94_Ɯ|.r!r!s/s0 2r!r8}DwrDXΡ|x|!2 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_165_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_165_4.dat deleted file mode 100644 index d83d63165..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_165_4.dat +++ /dev/null @@ -1,3 +0,0 @@ -xA -1 }Or."*?fPLHIkΫZQ8 -Gyqk-n5+?|֎kKnEŹK.K.?2.|EJ{2<:.Ku\K.K.ǝmu)_8\r%\r%\Џ;'2!_8\r%\r%\Џ;'2!_\r%\r%\rinC?nn9 RK.K.;.HqY'ݽNF?K㕢,R| My*3 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_169_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_169_4.dat deleted file mode 100644 index 4aac95c1e..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_169_4.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_173_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_173_4.dat deleted file mode 100644 index 9df4d865d..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_173_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK -1}Nrna ~ZY!Jt^5(/jkz[pj_?~v:|jwՖ_mXzo6?naCe \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_81_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_81_4.dat deleted file mode 100644 index dd6521613..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_81_4.dat +++ /dev/null @@ -1,3 +0,0 @@ -xA -0 yMyXE m7"892ѸQ1ݳ+xx;t35DIY1x\:u}e/ #Th< -UBz<5G<5{G<5<饫>]Urxu \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_85_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_85_4.dat deleted file mode 100644 index c8d5123e2..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_85_4.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_89_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_89_4.dat deleted file mode 100644 index 5b9bd7ec3..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_89_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -x1 -0 ὧI9%  Vڀfr0}z=#9ҕ:~s1BՁg&4pgq.p.&gT05rgsgqrg捯u38k.Egmb*&7? : \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_93_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_93_4.dat deleted file mode 100644 index be7f5e525..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_93_4.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK - ὧIn$}PŌB]N@%sfkҫ}CzoA}aʽ2|~D&l=Ywq}q\EYjK_ywqwz$==;_݋>+pH9Di \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_97_4.dat b/vendor/aferrandini/phpqrcode/cache/mask_4/mask_97_4.dat deleted file mode 100644 index 5d848caad..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_4/mask_97_4.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_101_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_101_5.dat deleted file mode 100644 index c21869e83..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_101_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -x - E+%=M3Cbv ѬNkûgqkqq{%Oo,iKee3[|iVh]` ` 0ʕz˴T0Gu/q8F13:W>#ȕ0c0Q8E=F#+a X͞+cV%9W>Q]TkY-gLqD艋 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_105_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_105_5.dat deleted file mode 100644 index bc8798c64..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_105_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_109_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_109_5.dat deleted file mode 100644 index 25a394402..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_109_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_113_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_113_5.dat deleted file mode 100644 index 25f42b8b2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_113_5.dat +++ /dev/null @@ -1,9 +0,0 @@ -x -0D^6I63[[EDqc+jy81\c -7c?u}DK4},kkg--3[UƂyUXUXSV:ϫ՝,|кS⫰ - - -Vɫ*X[* - - -zU*NV*JUXUXSXijTi4fZkU^_~Ux }ծZ/r \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_117_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_117_5.dat deleted file mode 100644 index f236940de..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_117_5.dat +++ /dev/null @@ -1 +0,0 @@ -x D|Mn/*{M+pI_&m-ѾC32u?o-kgB7wc=U%yoRhӯșDo:ֶyRJkQ^aaaqOgiJ ;qOg)ӊ0 0 0 [vö>=>0 0 0 Ofz3=>0 0 0.3Z$׷8\pw4:Zp:qX 7 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_121_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_121_5.dat deleted file mode 100644 index 9bb5c4158..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_121_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_125_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_125_5.dat deleted file mode 100644 index 2161c50a4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_125_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA - E&fc;S$?؏Q4YahûyJ}9g==li.;nh_wz.qCWȧy uPk;<<<|*q, mkWqNl% yyyy^2䰅sX|aaaa3ϙ9lH<<<<̿웁[n`Tq8^vy \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_129_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_129_5.dat deleted file mode 100644 index f0c1d6502..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_129_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_133_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_133_5.dat deleted file mode 100644 index 46be8b094..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_133_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0 DѽOcr]4%1mCTxΜ[Dv={FEϏq?ݿ9keѭ}'2^c4G:3=JK-F0`#Hw'#<{~Z4 :BG舻F0`G~:`#?#tw-`#?##t#F0r}Q}eR;M/k1mX=hsH"k M:3qOW}9ԖIH1G;- sڶ?[%M - v#;zg^3d}69Ψޙ@7҄#gv`;׳ީ\$wlv`v;ލ}7wߑa;vkA#gv`=N2wxgWӤ@n?c}SQ:Zd?+9vz)P \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_141_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_141_5.dat deleted file mode 100644 index 60c1a8e81..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_141_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_145_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_145_5.dat deleted file mode 100644 index 9303c07f9..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_145_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_149_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_149_5.dat deleted file mode 100644 index 4256cefd0..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_149_5.dat +++ /dev/null @@ -1,3 +0,0 @@ -x[ -0&c}-s+'^;Ax=Q_gUݏﵪxGTȺV¹UUE_IǴ;T1̠ -]W 2 2 |o5uꆬuI:(WKU躒rPAdAdA; vo_zNO{2rPA9 2 29}^O挞rwQdAdAnMA9(dAdA^W Z.+G^K`׵}`_Fk \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_153_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_153_5.dat deleted file mode 100644 index deea09d77..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_153_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -x -@wfЬ`D"Ie<:au,7Of۳uP6~szs,jլcVZvߨm s^uHYu&l&l&_9 ;]^jsO;ܔrSn&l&l9yכzA rSnM6dM6dM6ރ@/$7ܔl&l&lzŽzACrSnM6dM6dOl7ᰚUuN֛FcPPS,l;HO \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_157_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_157_5.dat deleted file mode 100644 index 176e2a69f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_157_5.dat +++ /dev/null @@ -1 +0,0 @@ -x10Dާri( r* \~>C*vs]Ŝ_{W!zﶬ/)˙v V6V޻,f1Yb n^o>\O],,b,f1YyVgYYYb,f1+ʳ<˳<˳1YbŬ<+ʳ,,b,f1YyVgYYYb,fukys77}vmb=wsw)tW: \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_161_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_161_5.dat deleted file mode 100644 index 70d5fb008..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_161_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xI -@нDp@ o|m rHk㨤~co^Jzװ#5l¦S_92 [}ZÊ=T2ƀP2[cV衆CYf'-X9>v~usK5`e,2,2,2-///o_q}K\reYfeYf峖o+/,\feYfeYfٳexB.e2,2,̲g+l\r16,2,>ϰ=te&_4=tU}/>>>Or5/u>/g}g}gOsvO}/g}g}ٷGo-w{r_{g}g}g_n=n]4Nkβ_M8m?SF< \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_173_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_173_5.dat deleted file mode 100644 index f9a674136..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_173_5.dat +++ /dev/null @@ -1,4 +0,0 @@ -x[ -0&G1gD)[CzeDѷц=RN6FJm JqP}x s_}GFy; -[;]ek[QbTmy&0 L`̄Y?رw؛ fcVN9&0 L`ׄZ}0=F=F9ANL`&0 L`BzYfI=F9AN&0 L`&0 fIsr ' L`&0 L`<i͒"9AN&0 L`VaBX",Um> -=wZgBΜP !8 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_177_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_177_5.dat deleted file mode 100644 index b07c636b6..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_177_5.dat +++ /dev/null @@ -1,11 +0,0 @@ -xъ0~ܾح uO,"% :$Xui=ѶՃgƸ?Ώq.So~z׉W:=h1cq]Ƕi!r8Ɓ`+X -V jj;8ƁX+ -oV`+X -V?[1^h-ֳ5Z;rmS+ -oV`+X -V;Z,YMB+ -V`+X -VZeڦ}r\!W`+X -V`+3Km>SB+ -V`+X -Vc㊛{g;^Qq5ZUݮQL0+*&YDq*6 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_21_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_21_5.dat deleted file mode 100644 index 04f97ea69..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_21_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_25_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_25_5.dat deleted file mode 100644 index c20b59b1f..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_25_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xڝa -@!4 ޳ʢ ?,""j?n=GZy:DR \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_33_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_33_5.dat deleted file mode 100644 index 726d7fd75..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_33_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_37_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_37_5.dat deleted file mode 100644 index 6d32ca6fa..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_37_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_41_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_41_5.dat deleted file mode 100644 index e07c6172a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_41_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xTA - 5?7XMtxҴx ?@7@~"N$Sɰ{+CA'r\Pp<ޏ- ͺ:S3sԉۻީz#qw > \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_45_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_45_5.dat deleted file mode 100644 index 5168a17f9..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_45_5.dat +++ /dev/null @@ -1 +0,0 @@ -xUA 5?U:N&Z":;4P1=bNvSGM1˛n'(κ J{Eѵs] ,sq \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_49_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_49_5.dat deleted file mode 100644 index 9f3f3cd7d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_49_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_53_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_53_5.dat deleted file mode 100644 index 449807bae..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_53_5.dat +++ /dev/null @@ -1 +0,0 @@ -xVA " zYf5ƐJC A;l\,dR. \(e_ еaNi5\żaLP(;2שjN6O u+l{y6od^ C[%  \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_57_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_57_5.dat deleted file mode 100644 index c7dd81f39..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_57_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xVA - 5?NlZHAbBZ0a Md`1z'"<Ր19nvͨ. )bݻ~;9Z#tB~ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_65_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_65_5.dat deleted file mode 100644 index ecd938068..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_65_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_69_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_69_5.dat deleted file mode 100644 index ead4edc1f..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_69_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_73_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_73_5.dat deleted file mode 100644 index 00001176d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_73_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_77_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_77_5.dat deleted file mode 100644 index 1652cdc2d..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_77_5.dat +++ /dev/null @@ -1 +0,0 @@ -xQ Cw#&C`T6ƹB(9 'ֆڢzk"hv.` cXB5[(F>71/34Ϊz^'[FyglgM>OTL4ϔ{&3Wy*ʧb*`<3;Vo0/s6n0ya[mcE \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_81_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_81_5.dat deleted file mode 100644 index 71215e952..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_81_5.dat +++ /dev/null @@ -1,3 +0,0 @@ -x - C~M?tzU4" }tMX2|.ɋ˙F\~m4Xu -ٔ, w:EƄ>X̯=_]g>>zמ/)5ךkkkZsXXY{ܮ}~mt:S#&;U#) \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_85_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_85_5.dat deleted file mode 100644 index 09cf0e281..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_85_5.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_89_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_89_5.dat deleted file mode 100644 index 5fff53069..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_89_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -x - 45enpQ Gcfl^^;;b5;`kU͹߮j`NsO=\[a6~nLD? !6uF%w*Ȭkf77SĆbÆXodw_—mbClNۙ ck&YVoܡ׷BעبAl6 Jjx \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_93_5.dat b/vendor/aferrandini/phpqrcode/cache/mask_5/mask_93_5.dat deleted file mode 100644 index ec4240bd3..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_5/mask_93_5.dat +++ /dev/null @@ -1,2 +0,0 @@ -xK -0 D>&&  fP^8BY5s(imҮ=f3/wۧEyYQwf[} [90303ef̙3'3=,ͼwxDַ.,;s%g,,,=Rὓ7uKKTD<(n lYhV۹sޕyPEtyY]ns ;ss,!LkԅcbL12cX91Z#XEn#;svT~L~LR11vs.1111J1&؍Ń111J1&ƞg KLƪjlk{gڞ5K1/ǐ~,ac$ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_105_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_105_6.dat deleted file mode 100644 index a58fec749..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_105_6.dat +++ /dev/null @@ -1,3 +0,0 @@ -xQ -@ DskBZ#o)Sd}Gܷl쯯^)G]S4S?#BZ:+{sHKNiI!me1 -RWe9!``Uyˀu:檞U=w-oԺwB}cMK蹰{{=y蹰{{=y蹰{wScaoi'fyO=CyO=Cy[{S޻=;|v4}ϯ20 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_109_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_109_6.dat deleted file mode 100644 index be7b4749e..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_109_6.dat +++ /dev/null @@ -1 +0,0 @@ -xA0 ~ρDBHCHV20nuol쯯˻=ۢs9[l'?7R" &2:7QqX_n ]$՚EIY*Lq0 0 0{LJз(s\ɳwX-7^ItIII$~?N0 0 0O'Itg7L$L-Iuzrfr M^'}(O~R]1YLĞu9Qӕ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_113_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_113_6.dat deleted file mode 100644 index 397f52741..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_113_6.dat +++ /dev/null @@ -1,3 +0,0 @@ -x E5NՉbF6on,m>gS9RWcǕ9&%1_cx= GR^w-z?dzv=,}ԥ?ǹژ:9m==@U䲉UXUXVe~by4Wi:e=ɼÆ$<>Ov'Cytaaaa~|'9liΣ<<<<Iæ<:<<<ٕWDzy:.z= ݓʯ sVöE=ll_k0_#vίmj \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_129_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_129_6.dat deleted file mode 100644 index b4695c3ff..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_129_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_133_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_133_6.dat deleted file mode 100644 index 40911dc57..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_133_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_137_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_137_6.dat deleted file mode 100644 index 43ccb68c6..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_137_6.dat +++ /dev/null @@ -1,2 +0,0 @@ -x E5?e^4fHp[1-e)UQV]UWN5o*8|۩W6bk?{f|>s֪r666rҟ=vڲWy -' -Ο;q tQE>U϶f곭xN]Tc(s❮7tAw`v`v`v`kvwfwt;];;;;;!ޙ;ao];l;;;÷| ʷ(3}l.?"މr};\}S-Aw<9;EV'ם \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_141_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_141_6.dat deleted file mode 100644 index 0340409a4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_141_6.dat +++ /dev/null @@ -1,10 +0,0 @@ -xa F4/c]زȐ[=[E럓sm,fn/|kj\j?g[q(NOZc5SGGP[oMVָfvL<WóCaz6U~һ{`nݻdvVy~rZ"qk{>g$XKU}m\bjaGx,f1Yb]z̞^.5[?嬜r,f1YY>grVb,f1Y>g,rVmYb,f,|VY9Yb,f,|VY9+g1Ybً ̦M7>2{9z϶hm3l|9xټ#f#x6 -v%N' \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_161_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_161_6.dat deleted file mode 100644 index ecec68b1a..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_161_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_165_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_165_6.dat deleted file mode 100644 index d641dfa3d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_165_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_169_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_169_6.dat deleted file mode 100644 index ae689723d..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_169_6.dat +++ /dev/null @@ -1 +0,0 @@ -xJ0i9[Jɘk{1b!gnhHkS뉭-V?KIׁ1큏1ƣݎ/`/z)*=3ڏg6^k65CY>㵾+'{է_Vˊx-J<ӛܗr_>>i;rO}/g}g}ٿ}}xO}/g}g}ٷGo/{{r_>>o/z^#}g}ٿd'ʳ|QRNS3YڳZ'msEǷj5 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_173_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_173_6.dat deleted file mode 100644 index 95fa97c7b..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_173_6.dat +++ /dev/null @@ -1 +0,0 @@ -xa09MrM S*:a_-5hh_)uZ֭[loےsmKN{H?x`l#f9>ڟ[eЄώߓ ?^m*/Kmhy%v-nKlkKL`&& g5(gwxYܞa¬pVcZ[#O=SN9&0 L`DŽ 'tjj]QN9&0 L`sYRc@QN9 L`&0 L`"YRc\ ' r&0 L`EH9AN&0 L`& 7p6`|hms R5Ƙȉ k\X/ )g9 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_177_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_177_6.dat deleted file mode 100644 index e9f0476f0..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_177_6.dat +++ /dev/null @@ -1,14 +0,0 @@ -xn {ڤ*4v۴u1{f{_,,K9o 4ǵ7lniJiggir<-MG - - - -xuV+zRCr9+Gq6QWb"Qe"WL+ - XXXXX/|~j,nmuMۤ+ - XXXXXYa,X;M+ - XXXXXe)oӘf|5H늚7/D \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_21_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_21_6.dat deleted file mode 100644 index 6bd505b4a..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_21_6.dat +++ /dev/null @@ -1 +0,0 @@ -xڝQ C9M{i]X1- C!D7 W ٜ&rD)~]<M 3(>{A aS \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_25_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_25_6.dat deleted file mode 100644 index d45083aab..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_25_6.dat +++ /dev/null @@ -1 +0,0 @@ -xڝQA 52)e+(XmZt*(ڹ;tJ<峂_ڤ3oڴ"̢azh}&qvSG֙,-J4}oS[}w \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_29_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_29_6.dat deleted file mode 100644 index 0408e2240..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_29_6.dat +++ /dev/null @@ -1,3 +0,0 @@ -xRA -0 XcL(4EԈB -8Cܾ޳nM+lǝՆO1]&ڍ4UD-6-$:6dZ?ylf? 8?߲_ݏ`8G1`B`;+}&s]<iK'l'9%.7 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_65_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_65_6.dat deleted file mode 100644 index 550fc8fe7..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_65_6.dat +++ /dev/null @@ -1 +0,0 @@ -xWQ i{KNLk?e$Qik41{`+!ڮM ? 1b8 .^wsnFj5EaQX|=w@2v<ŋŞ|4w\UXBQz+TTcBz/48,5`ȱ OV$ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_69_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_69_6.dat deleted file mode 100644 index a3e4fa0f2..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_69_6.dat +++ /dev/null @@ -1 +0,0 @@ -xK @dTh hLSSEq eY@<+*|窮 %>z*7e6QS`.>sE '%@[6@P0h aFxtpl2 Q-g1Nfeo^0FdT>N_OwG3ug {3<[Ժ b?'6^ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_73_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_73_6.dat deleted file mode 100644 index ab71b70ae..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_73_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_77_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_77_6.dat deleted file mode 100644 index ad5a660e3..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_77_6.dat +++ /dev/null @@ -1 +0,0 @@ -x E۲iVa.FpSTY4q~z=:͒ 6m8:#0PضiDy:2Š'Zs&}滜\r0\ŚXw;iPȔL)Seԕ{hDu9LbJSS))gZ{e)qJdLw+#3-V0շljڠS-S 9=ݯ5PPq1M?g \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_81_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_81_6.dat deleted file mode 100644 index 28a6d0752..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_81_6.dat +++ /dev/null @@ -1,3 +0,0 @@ -xQ0D9 rRLvk`0 ;i6\|_cc1huio#2}x*.Yt& -ְq/K;3ve̢ȊAH?`]5Kw!}{Zû߲W -yⷾ^_ykk^Kתb-bYSڸ'֜Nu#MfHSQ?|]IAiMyyuW \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_85_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_85_6.dat deleted file mode 100644 index d5403e49a..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_85_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_89_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_89_6.dat deleted file mode 100644 index eeeb5d197..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_89_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_93_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_93_6.dat deleted file mode 100644 index 6ff38db68..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_93_6.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_97_6.dat b/vendor/aferrandini/phpqrcode/cache/mask_6/mask_97_6.dat deleted file mode 100644 index 3a2072efd..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_6/mask_97_6.dat +++ /dev/null @@ -1,2 +0,0 @@ -xa0sdFx[=4Hoj34&s}* a Vc&35arW^aLClzq,1x SQN]/Giu`&w%,%DY"Kt+HE'|R2(v1vqiqd,%D~%ػJj}ͺĺgY"Kd,+K -]Wt+sF/)].zN'`>1='#`+bl]Z \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_101_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_101_7.dat deleted file mode 100644 index 1f6bc5129..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_101_7.dat +++ /dev/null @@ -1 +0,0 @@ -xQ C}rm`fjT#54'tfaЇo$cmOJ23c<6Xn0F ) \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_105_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_105_7.dat deleted file mode 100644 index 6b0cacfe9..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_105_7.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0EFaMҙNPx)pQ_~|ñ(bF$.aoWGNPUǖM%{oHQUlִL^>+m#{{eo&Y2soM)gncO9sZ3wo+{=f.zޣ{{=zGcskCQϞp^&{^NʷU e5}EwGn+o \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_109_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_109_7.dat deleted file mode 100644 index 9875cbe8c..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_109_7.dat +++ /dev/null @@ -1,2 +0,0 @@ -xA -0 D9Mr}* _x-d:"NJ-k"⨚d{ջגɬ|'rQ5+ s)c7-1nn햺qɔJtg^ʉw̘Ň-?*&Mm@ee5^ -c - -,b\13j4TZfŢo* - - -:Ut* - - -Xů0"%6ed 8rS NsUnk5XejުuVXg,l`u!hXZ\VlM|[ͬ0 0 0 #hF'c]i>Hataaa~<ÆzyqkO0 0 0 㪞Faaa)2˰fÒ%z8tO=3=3:cw -V$ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_121_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_121_7.dat deleted file mode 100644 index d5d577f7e..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_121_7.dat +++ /dev/null @@ -1,2 +0,0 @@ -x[ - Edi;^az,#6ƞ^rh&^amY9_غ5Cr6t^^WlEز~ɿ|MmmS}( ۰ ۰ ۰}mQ]ZVq]vѲ"M1fG, qBmtaaazeF3cxIDmtaaamný$n۰ ۰ ۰ ۏa[}`[yޖ޻)n<4K/Oslnlm/G \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_125_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_125_7.dat deleted file mode 100644 index f9ec0887b..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_125_7.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_129_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_129_7.dat deleted file mode 100644 index 9bf51d529..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_129_7.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_133_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_133_7.dat deleted file mode 100644 index b643ffeda..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_133_7.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_137_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_137_7.dat deleted file mode 100644 index 11d212bf4..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_137_7.dat +++ /dev/null @@ -1,5 +0,0 @@ -x - F4/ c_ǂ+{SK<o[l -Ο -07։Vl;b7fMS;1LCvR|KMH -#Н(Sqd \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_141_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_141_7.dat deleted file mode 100644 index 98dffab00..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_141_7.dat +++ /dev/null @@ -1 +0,0 @@ -xA E= rITY@Ä0!|1tbG0ԗѤs2Z/oa\qzOnҋMntX"KmeM}CpPL^S0S0S0SL )ǔژY߾%b,Sl?zC)tLLLLI2zRXh@)tLLLLI1zbϷB)~0S0S0S07)|B)))3ՖL% tfwM*:~hZsnc$1UTtJg8OYE \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_145_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_145_7.dat deleted file mode 100644 index 4aa2bac11..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_145_7.dat +++ /dev/null @@ -1,2 +0,0 @@ -x - E5?W6Z-^2qbGX6(Ɖu"LbbGuμGk:HwA[jmHݞ3OkQ{l|TEm JfL?2"&)kRfc̉F,z=5X5X5X7F\pUs#5X5X5XFdYk!a ` ` `o8ct ]CC gM5[N%khZp?Iܣϲ^n$Y7AZP[ fȓ0 \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_149_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_149_7.dat deleted file mode 100644 index 809f00554..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_149_7.dat +++ /dev/null @@ -1 +0,0 @@ -xn {? uچ2G$ncFKb3֪tPc ̥7[?9:['9'*Ӗ Gah_/z+6XB>2qYJ0黏Bfa 1 9c7G Ol,^꽓3A:H  1A b0X4%٫#d>&C  1A b+g嬜,f1Yb|Y>+g嬜,f1Ylio.\Ɲo=gϙ-yk_TA \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_161_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_161_7.dat deleted file mode 100644 index 35ba8ff48..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_161_7.dat +++ /dev/null @@ -1 +0,0 @@ -xю y/皨E)Ʈ1~493,˵+ZT=ZeC.~iߏ&>,6e~,lW] 2\;׵2j"e,rXݵV(c쵵ZӖ18ީ/,'t.ee,cX2߱,_|yt|]t.cX2e,cy/ɗys.eLe,cX2lo|Z{+2]bl,cX2e{+֊[A2]X2e,c9CX;QIQH8R҈G"z,&;'o97%P8%6oǽ;]NWn[f7v \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_29_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_29_7.dat deleted file mode 100644 index e3d7391b7..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_29_7.dat +++ /dev/null @@ -1,2 +0,0 @@ -xR9 QpX$lŲf!I2pgSMZj"te0#ԛ`_1-cha~/Eh4"~ \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_37_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_37_7.dat deleted file mode 100644 index 87d9a1a9d..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_37_7.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_41_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_41_7.dat deleted file mode 100644 index 8acec04f0..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_41_7.dat +++ /dev/null @@ -1 +0,0 @@ -xTA 5[fDY(O^bR3/~t/L"7SQQ5j\Sib#Նȏ+ǣw#zx?㽧A-wu曑Y7$b.%A;wRoxG}? \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_45_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_45_7.dat deleted file mode 100644 index dbba31d0b..000000000 Binary files a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_45_7.dat and /dev/null differ diff --git a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_49_7.dat b/vendor/aferrandini/phpqrcode/cache/mask_7/mask_49_7.dat deleted file mode 100644 index be5dce8b7..000000000 --- a/vendor/aferrandini/phpqrcode/cache/mask_7/mask_49_7.dat +++ /dev/null @@ -1 +0,0 @@ -xV0khC-X.ukv o40T%96U5*sI{`_>S?}(:yTl{G&E\6}"AX XϬwidth = $width; - $this->frame = $frame; - $this->x = $width - 1; - $this->y = $width - 1; - $this->dir = -1; - $this->bit = -1; - } - - //---------------------------------------------------------------------- - public function setFrameAt($at, $val) - { - $this->frame[$at['y']][$at['x']] = chr($val); - } - - //---------------------------------------------------------------------- - public function getFrameAt($at) - { - return ord($this->frame[$at['y']][$at['x']]); - } - - //---------------------------------------------------------------------- - public function next() - { - do { - - if($this->bit == -1) { - $this->bit = 0; - return array('x'=>$this->x, 'y'=>$this->y); - } - - $x = $this->x; - $y = $this->y; - $w = $this->width; - - if($this->bit == 0) { - $x--; - $this->bit++; - } else { - $x++; - $y += $this->dir; - $this->bit--; - } - - if($this->dir < 0) { - if($y < 0) { - $y = 0; - $x -= 2; - $this->dir = 1; - if($x == 6) { - $x--; - $y = 9; - } - } - } else { - if($y == $w) { - $y = $w - 1; - $x -= 2; - $this->dir = -1; - if($x == 6) { - $x--; - $y -= 8; - } - } - } - if($x < 0 || $y < 0) return null; - - $this->x = $x; - $this->y = $y; - - } while(ord($this->frame[$y][$x]) & 0x80); - - return array('x'=>$x, 'y'=>$y); - } - -} ; \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRbitstream.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRbitstream.php deleted file mode 100644 index 93606f13f..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRbitstream.php +++ /dev/null @@ -1,182 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRbitstream { - - public $data = array(); - - //---------------------------------------------------------------------- - public function size() - { - return count($this->data); - } - - //---------------------------------------------------------------------- - public function allocate($setLength) - { - $this->data = array_fill(0, $setLength, 0); - return 0; - } - - //---------------------------------------------------------------------- - public static function newFromNum($bits, $num) - { - $bstream = new QRbitstream(); - $bstream->allocate($bits); - - $mask = 1 << ($bits - 1); - for($i=0; $i<$bits; $i++) { - if($num & $mask) { - $bstream->data[$i] = 1; - } else { - $bstream->data[$i] = 0; - } - $mask = $mask >> 1; - } - - return $bstream; - } - - //---------------------------------------------------------------------- - public static function newFromBytes($size, $data) - { - $bstream = new QRbitstream(); - $bstream->allocate($size * 8); - $p=0; - - for($i=0; $i<$size; $i++) { - $mask = 0x80; - for($j=0; $j<8; $j++) { - if($data[$i] & $mask) { - $bstream->data[$p] = 1; - } else { - $bstream->data[$p] = 0; - } - $p++; - $mask = $mask >> 1; - } - } - - return $bstream; - } - - //---------------------------------------------------------------------- - public function append(QRbitstream $arg) - { - if (is_null($arg)) { - return -1; - } - - if($arg->size() == 0) { - return 0; - } - - if($this->size() == 0) { - $this->data = $arg->data; - return 0; - } - - $this->data = array_values(array_merge($this->data, $arg->data)); - - return 0; - } - - //---------------------------------------------------------------------- - public function appendNum($bits, $num) - { - if ($bits == 0) - return 0; - - $b = QRbitstream::newFromNum($bits, $num); - - if(is_null($b)) - return -1; - - $ret = $this->append($b); - unset($b); - - return $ret; - } - - //---------------------------------------------------------------------- - public function appendBytes($size, $data) - { - if ($size == 0) - return 0; - - $b = QRbitstream::newFromBytes($size, $data); - - if(is_null($b)) - return -1; - - $ret = $this->append($b); - unset($b); - - return $ret; - } - - //---------------------------------------------------------------------- - public function toByte() - { - - $size = $this->size(); - - if($size == 0) { - return array(); - } - - $data = array_fill(0, (int)(($size + 7) / 8), 0); - $bytes = (int)($size / 8); - - $p = 0; - - for($i=0; $i<$bytes; $i++) { - $v = 0; - for($j=0; $j<8; $j++) { - $v = $v << 1; - $v |= $this->data[$p]; - $p++; - } - $data[$i] = $v; - } - - if($size & 7) { - $v = 0; - for($j=0; $j<($size & 7); $j++) { - $v = $v << 1; - $v |= $this->data[$p]; - $p++; - } - $data[$bytes] = $v; - } - - return $data; - } - -} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRcode.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRcode.php deleted file mode 100644 index 08b602435..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRcode.php +++ /dev/null @@ -1,158 +0,0 @@ -getVersion() < 0 || $input->getVersion() > Constants::QRSPEC_VERSION_MAX) { - throw new Exception('wrong version'); - } - if($input->getErrorCorrectionLevel() > Constants::QR_ECLEVEL_H) { - throw new Exception('wrong level'); - } - - $raw = new QRrawcode($input); - - QRtools::markTime('after_raw'); - - $version = $raw->version; - $width = QRspec::getWidth($version); - $frame = QRspec::newFrame($version); - - $filler = new FrameFiller($width, $frame); - if(is_null($filler)) { - return NULL; - } - - // inteleaved data and ecc codes - for($i=0; $i<$raw->dataLength + $raw->eccLength; $i++) { - $code = $raw->getCode(); - $bit = 0x80; - for($j=0; $j<8; $j++) { - $addr = $filler->next(); - $filler->setFrameAt($addr, 0x02 | (($bit & $code) != 0)); - $bit = $bit >> 1; - } - } - - QRtools::markTime('after_filler'); - - unset($raw); - - // remainder bits - $j = QRspec::getRemainder($version); - for($i=0; $i<$j; $i++) { - $addr = $filler->next(); - $filler->setFrameAt($addr, 0x02); - } - - $frame = $filler->frame; - unset($filler); - - - // masking - $maskObj = new QRmask(); - if($mask < 0) { - - if (Constants::QR_FIND_BEST_MASK) { - $masked = $maskObj->mask($width, $frame, $input->getErrorCorrectionLevel()); - } else { - $masked = $maskObj->makeMask($width, $frame, (intval(Constants::QR_DEFAULT_MASK) % 8), $input->getErrorCorrectionLevel()); - } - } else { - $masked = $maskObj->makeMask($width, $frame, $mask, $input->getErrorCorrectionLevel()); - } - - if($masked == NULL) { - return NULL; - } - - QRtools::markTime('after_mask'); - - $this->version = $version; - $this->width = $width; - $this->data = $masked; - - return $this; - } - - //---------------------------------------------------------------------- - public function encodeInput(QRinput $input) - { - return $this->encodeMask($input, -1); - } - - //---------------------------------------------------------------------- - public function encodeString8bit($string, $version, $level) - { - if(string == NULL) { - throw new Exception('empty string!'); - return NULL; - } - - $input = new QRinput($version, $level); - if($input == NULL) return NULL; - - $ret = $input->append($input, Constants::QR_MODE_8, strlen($string), str_split($string)); - if($ret < 0) { - unset($input); - return NULL; - } - return $this->encodeInput($input); - } - - //---------------------------------------------------------------------- - public function encodeString($string, $version, $level, $hint, $casesensitive) - { - - if($hint != Constants::QR_MODE_8 && $hint != Constants::QR_MODE_KANJI) { - throw new Exception('bad hint'); - return NULL; - } - - $input = new QRinput($version, $level); - if($input == NULL) return NULL; - - $ret = QRsplit::splitStringToQRinput($string, $input, $hint, $casesensitive); - if($ret < 0) { - return NULL; - } - - return $this->encodeInput($input); - } - - //---------------------------------------------------------------------- - public static function png($text, $outfile = false, $level = Constants::QR_ECLEVEL_L, $size = 3, $margin = 4, $saveandprint=false) - { - $enc = QRencode::factory($level, $size, $margin); - return $enc->encodePNG($text, $outfile, $saveandprint=false); - } - - //---------------------------------------------------------------------- - public static function text($text, $outfile = false, $level = Constants::QR_ECLEVEL_L, $size = 3, $margin = 4) - { - $enc = QRencode::factory($level, $size, $margin); - return $enc->encode($text, $outfile); - } - - //---------------------------------------------------------------------- - public static function raw($text, $outfile = false, $level = Constants::QR_ECLEVEL_L, $size = 3, $margin = 4) - { - $enc = QRencode::factory($level, $size, $margin); - return $enc->encodeRAW($text, $outfile); - } -} diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRencode.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRencode.php deleted file mode 100644 index d05ab6b7b..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRencode.php +++ /dev/null @@ -1,137 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -use Exception; - -class QRencode { - - public $casesensitive = true; - public $eightbit = false; - - public $version = 0; - public $size = 3; - public $margin = 4; - - public $structured = 0; // not supported yet - - public $level = Constants::QR_ECLEVEL_L; - public $hint = Constants::QR_MODE_8; - - //---------------------------------------------------------------------- - public static function factory($level = Constants::QR_ECLEVEL_L, $size = 3, $margin = 4) - { - $enc = new QRencode(); - $enc->size = $size; - $enc->margin = $margin; - - switch ($level.'') { - case '0': - case '1': - case '2': - case '3': - $enc->level = $level; - break; - case 'l': - case 'L': - $enc->level = Constants::QR_ECLEVEL_L; - break; - case 'm': - case 'M': - $enc->level = Constants::QR_ECLEVEL_M; - break; - case 'q': - case 'Q': - $enc->level = Constants::QR_ECLEVEL_Q; - break; - case 'h': - case 'H': - $enc->level = Constants::QR_ECLEVEL_H; - break; - } - - return $enc; - } - - //---------------------------------------------------------------------- - public function encodeRAW($intext, $outfile = false) - { - $code = new QRcode(); - - if($this->eightbit) { - $code->encodeString8bit($intext, $this->version, $this->level); - } else { - $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive); - } - - return $code->data; - } - - //---------------------------------------------------------------------- - public function encode($intext, $outfile = false) - { - $code = new QRcode(); - - if($this->eightbit) { - $code->encodeString8bit($intext, $this->version, $this->level); - } else { - $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive); - } - - QRtools::markTime('after_encode'); - - if ($outfile!== false) { - file_put_contents($outfile, join("\n", QRtools::binarize($code->data))); - } else { - return QRtools::binarize($code->data); - } - } - - //---------------------------------------------------------------------- - public function encodePNG($intext, $outfile = false,$saveandprint=false) - { - try { - ob_start(); - $tab = $this->encode($intext); - $err = ob_get_contents(); - ob_end_clean(); - - if ($err != '') - QRtools::log($outfile, "ERROR: " . $err); - - $maxSize = (int)(Constants::QR_PNG_MAXIMUM_SIZE / (count($tab)+2*$this->margin)); - - QRimage::png($tab, $outfile, min(max(1, $this->size), $maxSize), $this->margin,$saveandprint); - } catch (Exception $e) { - echo $e->getMessage(); - die(); - - QRtools::log($outfile, $e->getMessage()); - } - } -} diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRimage.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRimage.php deleted file mode 100644 index 430a16f84..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRimage.php +++ /dev/null @@ -1,95 +0,0 @@ - - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRimage { - - //---------------------------------------------------------------------- - public static function png($frame, $filename = false, $pixelPerPoint = 4, $outerFrame = 4,$saveandprint=FALSE) - { - $image = self::image($frame, $pixelPerPoint, $outerFrame); - - if ($filename === false) { - Header("Content-type: image/png"); - ImagePng($image); - } else { - if($saveandprint===TRUE){ - ImagePng($image, $filename); - header("Content-type: image/png"); - ImagePng($image); - }else{ - ImagePng($image, $filename); - } - } - - ImageDestroy($image); - } - - //---------------------------------------------------------------------- - public static function jpg($frame, $filename = false, $pixelPerPoint = 8, $outerFrame = 4, $q = 85) - { - $image = self::image($frame, $pixelPerPoint, $outerFrame); - - if ($filename === false) { - Header("Content-type: image/jpeg"); - ImageJpeg($image, null, $q); - } else { - ImageJpeg($image, $filename, $q); - } - - ImageDestroy($image); - } - - //---------------------------------------------------------------------- - private static function image($frame, $pixelPerPoint = 4, $outerFrame = 4) - { - $h = count($frame); - $w = strlen($frame[0]); - - $imgW = $w + 2*$outerFrame; - $imgH = $h + 2*$outerFrame; - - $base_image =ImageCreate($imgW, $imgH); - - $col[0] = ImageColorAllocate($base_image,255,255,255); - $col[1] = ImageColorAllocate($base_image,0,0,0); - - imagefill($base_image, 0, 0, $col[0]); - - for($y=0; $y<$h; $y++) { - for($x=0; $x<$w; $x++) { - if ($frame[$y][$x] == '1') { - ImageSetPixel($base_image,$x+$outerFrame,$y+$outerFrame,$col[1]); - } - } - } - - $target_image =ImageCreate($imgW * $pixelPerPoint, $imgH * $pixelPerPoint); - ImageCopyResized($target_image, $base_image, 0, 0, 0, 0, $imgW * $pixelPerPoint, $imgH * $pixelPerPoint, $imgW, $imgH); - ImageDestroy($base_image); - - return $target_image; - } -} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRinput.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRinput.php deleted file mode 100644 index 8bdd21e71..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRinput.php +++ /dev/null @@ -1,486 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -use Exception; - -class QRinput { - - public $items; - - private $version; - private $level; - - //---------------------------------------------------------------------- - public function __construct($version = 0, $level = Constants::QR_ECLEVEL_L) - { - if ($version < 0 || $version > Constants::QRSPEC_VERSION_MAX || $level > Constants::QR_ECLEVEL_H) { - throw new Exception('Invalid version no'); - return NULL; - } - - $this->version = $version; - $this->level = $level; - } - - //---------------------------------------------------------------------- - public function getVersion() - { - return $this->version; - } - - //---------------------------------------------------------------------- - public function setVersion($version) - { - if($version < 0 || $version > Constants::QRSPEC_VERSION_MAX) { - throw new Exception('Invalid version no'); - return -1; - } - - $this->version = $version; - - return 0; - } - - //---------------------------------------------------------------------- - public function getErrorCorrectionLevel() - { - return $this->level; - } - - //---------------------------------------------------------------------- - public function setErrorCorrectionLevel($level) - { - if($level > Constants::QR_ECLEVEL_H) { - throw new Exception('Invalid ECLEVEL'); - return -1; - } - - $this->level = $level; - - return 0; - } - - //---------------------------------------------------------------------- - public function appendEntry(QRinputItem $entry) - { - $this->items[] = $entry; - } - - //---------------------------------------------------------------------- - public function append($mode, $size, $data) - { - try { - $entry = new QRinputItem($mode, $size, $data); - $this->items[] = $entry; - return 0; - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - - public function insertStructuredAppendHeader($size, $index, $parity) - { - if( $size > Constants::MAX_STRUCTURED_SYMBOLS ) { - throw new Exception('insertStructuredAppendHeader wrong size'); - } - - if( $index <= 0 || $index > Constants::MAX_STRUCTURED_SYMBOLS ) { - throw new Exception('insertStructuredAppendHeader wrong index'); - } - - $buf = array($size, $index, $parity); - - try { - $entry = new QRinputItem(Constants::QR_MODE_STRUCTURE, 3, buf); - array_unshift($this->items, $entry); - return 0; - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - public function calcParity() - { - $parity = 0; - - foreach($this->items as $item) { - if($item->mode != Constants::QR_MODE_STRUCTURE) { - for($i=$item->size-1; $i>=0; $i--) { - $parity ^= $item->data[$i]; - } - } - } - - return $parity; - } - - //---------------------------------------------------------------------- - public static function checkModeNum($size, $data) - { - for($i=0; $i<$size; $i++) { - if((ord($data[$i]) < ord('0')) || (ord($data[$i]) > ord('9'))){ - return false; - } - } - - return true; - } - - //---------------------------------------------------------------------- - public static function estimateBitsModeNum($size) - { - $w = (int)$size / 3; - $bits = $w * 10; - - switch($size - $w * 3) { - case 1: - $bits += 4; - break; - case 2: - $bits += 7; - break; - default: - break; - } - - return $bits; - } - - //---------------------------------------------------------------------- - public static $anTable = array( - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43, - 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1, - -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, - 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 - ); - - //---------------------------------------------------------------------- - public static function lookAnTable($c) - { - return (($c > 127)?-1:self::$anTable[$c]); - } - - //---------------------------------------------------------------------- - public static function checkModeAn($size, $data) - { - for($i=0; $i<$size; $i++) { - if (self::lookAnTable(ord($data[$i])) == -1) { - return false; - } - } - - return true; - } - - //---------------------------------------------------------------------- - public static function estimateBitsModeAn($size) - { - $w = (int)($size / 2); - $bits = $w * 11; - - if($size & 1) { - $bits += 6; - } - - return $bits; - } - - //---------------------------------------------------------------------- - public static function estimateBitsMode8($size) - { - return $size * 8; - } - - //---------------------------------------------------------------------- - public function estimateBitsModeKanji($size) - { - return (int)(($size / 2) * 13); - } - - //---------------------------------------------------------------------- - public static function checkModeKanji($size, $data) - { - if($size & 1) - return false; - - for($i=0; $i<$size; $i+=2) { - $val = (ord($data[$i]) << 8) | ord($data[$i+1]); - if( $val < 0x8140 - || ($val > 0x9ffc && $val < 0xe040) - || $val > 0xebbf) { - return false; - } - } - - return true; - } - - /*********************************************************************** - * Validation - **********************************************************************/ - - public static function check($mode, $size, $data) - { - if($size <= 0) - return false; - - switch($mode) { - case Constants::QR_MODE_NUM: return self::checkModeNum($size, $data); break; - case Constants::QR_MODE_AN: return self::checkModeAn($size, $data); break; - case Constants::QR_MODE_KANJI: return self::checkModeKanji($size, $data); break; - case Constants::QR_MODE_8: return true; break; - case Constants::QR_MODE_STRUCTURE: return true; break; - - default: - break; - } - - return false; - } - - - //---------------------------------------------------------------------- - public function estimateBitStreamSize($version) - { - $bits = 0; - - foreach($this->items as $item) { - $bits += $item->estimateBitStreamSizeOfEntry($version); - } - - return $bits; - } - - //---------------------------------------------------------------------- - public function estimateVersion() - { - $version = 0; - $prev = 0; - do { - $prev = $version; - $bits = $this->estimateBitStreamSize($prev); - $version = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); - if ($version < 0) { - return -1; - } - } while ($version > $prev); - - return $version; - } - - //---------------------------------------------------------------------- - public static function lengthOfCode($mode, $version, $bits) - { - $payload = $bits - 4 - QRspec::lengthIndicator($mode, $version); - switch($mode) { - case Constants::QR_MODE_NUM: - $chunks = (int)($payload / 10); - $remain = $payload - $chunks * 10; - $size = $chunks * 3; - if($remain >= 7) { - $size += 2; - } else if($remain >= 4) { - $size += 1; - } - break; - case Constants::QR_MODE_AN: - $chunks = (int)($payload / 11); - $remain = $payload - $chunks * 11; - $size = $chunks * 2; - if($remain >= 6) - $size++; - break; - case Constants::QR_MODE_8: - $size = (int)($payload / 8); - break; - case Constants::QR_MODE_KANJI: - $size = (int)(($payload / 13) * 2); - break; - case Constants::QR_MODE_STRUCTURE: - $size = (int)($payload / 8); - break; - default: - $size = 0; - break; - } - - $maxsize = QRspec::maximumWords($mode, $version); - if($size < 0) $size = 0; - if($size > $maxsize) $size = $maxsize; - - return $size; - } - - //---------------------------------------------------------------------- - public function createBitStream() - { - $total = 0; - - foreach($this->items as $item) { - $bits = $item->encodeBitStream($this->version); - - if($bits < 0) - return -1; - - $total += $bits; - } - - return $total; - } - - //---------------------------------------------------------------------- - public function convertData() - { - $ver = $this->estimateVersion(); - if($ver > $this->getVersion()) { - $this->setVersion($ver); - } - - for(;;) { - $bits = $this->createBitStream(); - - if($bits < 0) - return -1; - - $ver = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); - if($ver < 0) { - throw new Exception('WRONG VERSION'); - return -1; - } else if($ver > $this->getVersion()) { - $this->setVersion($ver); - } else { - break; - } - } - - return 0; - } - - //---------------------------------------------------------------------- - public function appendPaddingBit(&$bstream) - { - $bits = $bstream->size(); - $maxwords = QRspec::getDataLength($this->version, $this->level); - $maxbits = $maxwords * 8; - - if ($maxbits == $bits) { - return 0; - } - - if ($maxbits - $bits < 5) { - return $bstream->appendNum($maxbits - $bits, 0); - } - - $bits += 4; - $words = (int)(($bits + 7) / 8); - - $padding = new QRbitstream(); - $ret = $padding->appendNum($words * 8 - $bits + 4, 0); - - if($ret < 0) - return $ret; - - $padlen = $maxwords - $words; - - if($padlen > 0) { - - $padbuf = array(); - for($i=0; $i<$padlen; $i++) { - $padbuf[$i] = ($i&1)?0x11:0xec; - } - - $ret = $padding->appendBytes($padlen, $padbuf); - - if($ret < 0) - return $ret; - - } - - $ret = $bstream->append($padding); - - return $ret; - } - - //---------------------------------------------------------------------- - public function mergeBitStream() - { - if($this->convertData() < 0) { - return null; - } - - $bstream = new QRbitstream(); - - foreach($this->items as $item) { - $ret = $bstream->append($item->bstream); - if($ret < 0) { - return null; - } - } - - return $bstream; - } - - //---------------------------------------------------------------------- - public function getBitStream() - { - - $bstream = $this->mergeBitStream(); - - if($bstream == null) { - return null; - } - - $ret = $this->appendPaddingBit($bstream); - if($ret < 0) { - return null; - } - - return $bstream; - } - - //---------------------------------------------------------------------- - public function getByteStream() - { - $bstream = $this->getBitStream(); - if($bstream == null) { - return null; - } - - return $bstream->toByte(); - } -} - - diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRinputItem.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRinputItem.php deleted file mode 100644 index 1e5eb18de..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRinputItem.php +++ /dev/null @@ -1,246 +0,0 @@ -mode = $mode; - $this->size = $size; - $this->data = $setData; - $this->bstream = $bstream; - } - - //---------------------------------------------------------------------- - public function encodeModeNum($version) - { - try { - - $words = (int)($this->size / 3); - $bs = new QRbitstream(); - - $val = 0x1; - $bs->appendNum(4, $val); - $bs->appendNum(QRspec::lengthIndicator(Constants::QR_MODE_NUM, $version), $this->size); - - for($i=0; $i<$words; $i++) { - $val = (ord($this->data[$i*3 ]) - ord('0')) * 100; - $val += (ord($this->data[$i*3+1]) - ord('0')) * 10; - $val += (ord($this->data[$i*3+2]) - ord('0')); - $bs->appendNum(10, $val); - } - - if($this->size - $words * 3 == 1) { - $val = ord($this->data[$words*3]) - ord('0'); - $bs->appendNum(4, $val); - } else if($this->size - $words * 3 == 2) { - $val = (ord($this->data[$words*3 ]) - ord('0')) * 10; - $val += (ord($this->data[$words*3+1]) - ord('0')); - $bs->appendNum(7, $val); - } - - $this->bstream = $bs; - return 0; - - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - public function encodeModeAn($version) - { - try { - $words = (int)($this->size / 2); - $bs = new QRbitstream(); - - $bs->appendNum(4, 0x02); - $bs->appendNum(QRspec::lengthIndicator(Constants::QR_MODE_AN, $version), $this->size); - - for($i=0; $i<$words; $i++) { - $val = (int)QRinput::lookAnTable(ord($this->data[$i*2 ])) * 45; - $val += (int)QRinput::lookAnTable(ord($this->data[$i*2+1])); - - $bs->appendNum(11, $val); - } - - if($this->size & 1) { - $val = QRinput::lookAnTable(ord($this->data[$words * 2])); - $bs->appendNum(6, $val); - } - - $this->bstream = $bs; - return 0; - - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - public function encodeMode8($version) - { - try { - $bs = new QRbitstream(); - - $bs->appendNum(4, 0x4); - $bs->appendNum(QRspec::lengthIndicator(Constants::QR_MODE_8, $version), $this->size); - - for($i=0; $i<$this->size; $i++) { - $bs->appendNum(8, ord($this->data[$i])); - } - - $this->bstream = $bs; - return 0; - - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - public function encodeModeKanji($version) - { - try { - - $bs = new QRbitstream(); - - $bs->appendNum(4, 0x8); - $bs->appendNum(QRspec::lengthIndicator(Constants::QR_MODE_KANJI, $version), (int)($this->size / 2)); - - for($i=0; $i<$this->size; $i+=2) { - $val = (ord($this->data[$i]) << 8) | ord($this->data[$i+1]); - if($val <= 0x9ffc) { - $val -= 0x8140; - } else { - $val -= 0xc140; - } - - $h = ($val >> 8) * 0xc0; - $val = ($val & 0xff) + $h; - - $bs->appendNum(13, $val); - } - - $this->bstream = $bs; - return 0; - - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - public function encodeModeStructure() - { - try { - $bs = new QRbitstream(); - - $bs->appendNum(4, 0x03); - $bs->appendNum(4, ord($this->data[1]) - 1); - $bs->appendNum(4, ord($this->data[0]) - 1); - $bs->appendNum(8, ord($this->data[2])); - - $this->bstream = $bs; - return 0; - - } catch (Exception $e) { - return -1; - } - } - - //---------------------------------------------------------------------- - public function estimateBitStreamSizeOfEntry($version) - { - $bits = 0; - - if($version == 0) - $version = 1; - - switch($this->mode) { - case Constants::QR_MODE_NUM: $bits = QRinput::estimateBitsModeNum($this->size); break; - case Constants::QR_MODE_AN: $bits = QRinput::estimateBitsModeAn($this->size); break; - case Constants::QR_MODE_8: $bits = QRinput::estimateBitsMode8($this->size); break; - case Constants::QR_MODE_KANJI: $bits = QRinput::estimateBitsModeKanji($this->size);break; - case Constants::QR_MODE_STRUCTURE: return Constants::STRUCTURE_HEADER_BITS; - default: - return 0; - } - - $l = QRspec::lengthIndicator($this->mode, $version); - $m = 1 << $l; - $num = (int)(($this->size + $m - 1) / $m); - - $bits += $num * (4 + $l); - - return $bits; - } - - //---------------------------------------------------------------------- - public function encodeBitStream($version) - { - try { - - unset($this->bstream); - $words = QRspec::maximumWords($this->mode, $version); - - if($this->size > $words) { - - $st1 = new QRinputItem($this->mode, $words, $this->data); - $st2 = new QRinputItem($this->mode, $this->size - $words, array_slice($this->data, $words)); - - $st1->encodeBitStream($version); - $st2->encodeBitStream($version); - - $this->bstream = new QRbitstream(); - $this->bstream->append($st1->bstream); - $this->bstream->append($st2->bstream); - - unset($st1); - unset($st2); - - } else { - - $ret = 0; - - switch($this->mode) { - case Constants::QR_MODE_NUM: $ret = $this->encodeModeNum($version); break; - case Constants::QR_MODE_AN: $ret = $this->encodeModeAn($version); break; - case Constants::QR_MODE_8: $ret = $this->encodeMode8($version); break; - case Constants::QR_MODE_KANJI: $ret = $this->encodeModeKanji($version);break; - case Constants::QR_MODE_STRUCTURE: $ret = $this->encodeModeStructure(); break; - - default: - break; - } - - if($ret < 0) - return -1; - } - - return $this->bstream->size(); - - } catch (Exception $e) { - return -1; - } - } -} diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRmask.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRmask.php deleted file mode 100644 index 2be76f471..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRmask.php +++ /dev/null @@ -1,325 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRmask { - - public $runLength = array(); - - //---------------------------------------------------------------------- - public function __construct() - { - $this->runLength = array_fill(0, Constants::QRSPEC_WIDTH_MAX + 1, 0); - } - - //---------------------------------------------------------------------- - public function writeFormatInformation($width, &$frame, $mask, $level) - { - $blacks = 0; - $format = QRspec::getFormatInfo($mask, $level); - - for($i=0; $i<8; $i++) { - if($format & 1) { - $blacks += 2; - $v = 0x85; - } else { - $v = 0x84; - } - - $frame[8][$width - 1 - $i] = chr($v); - if($i < 6) { - $frame[$i][8] = chr($v); - } else { - $frame[$i + 1][8] = chr($v); - } - $format = $format >> 1; - } - - for($i=0; $i<7; $i++) { - if($format & 1) { - $blacks += 2; - $v = 0x85; - } else { - $v = 0x84; - } - - $frame[$width - 7 + $i][8] = chr($v); - if($i == 0) { - $frame[8][7] = chr($v); - } else { - $frame[8][6 - $i] = chr($v); - } - - $format = $format >> 1; - } - - return $blacks; - } - - //---------------------------------------------------------------------- - public function mask0($x, $y) { return ($x+$y)&1; } - public function mask1($x, $y) { return ($y&1); } - public function mask2($x, $y) { return ($x%3); } - public function mask3($x, $y) { return ($x+$y)%3; } - public function mask4($x, $y) { return (((int)($y/2))+((int)($x/3)))&1; } - public function mask5($x, $y) { return (($x*$y)&1)+($x*$y)%3; } - public function mask6($x, $y) { return ((($x*$y)&1)+($x*$y)%3)&1; } - public function mask7($x, $y) { return ((($x*$y)%3)+(($x+$y)&1))&1; } - - //---------------------------------------------------------------------- - private function generateMaskNo($maskNo, $width, $frame) - { - $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); - - for($y=0; $y<$width; $y++) { - for($x=0; $x<$width; $x++) { - if(ord($frame[$y][$x]) & 0x80) { - $bitMask[$y][$x] = 0; - } else { - $maskFunc = call_user_func(array($this, 'mask'.$maskNo), $x, $y); - $bitMask[$y][$x] = ($maskFunc == 0)?1:0; - } - - } - } - - return $bitMask; - } - - //---------------------------------------------------------------------- - public static function serial($bitFrame) - { - $codeArr = array(); - - foreach ($bitFrame as $line) - $codeArr[] = join('', $line); - - return gzcompress(join("\n", $codeArr), 9); - } - - //---------------------------------------------------------------------- - public static function unserial($code) - { - $codeArr = array(); - - $codeLines = explode("\n", gzuncompress($code)); - foreach ($codeLines as $line) - $codeArr[] = str_split($line); - - return $codeArr; - } - - //---------------------------------------------------------------------- - public function makeMaskNo($maskNo, $width, $s, &$d, $maskGenOnly = false) - { - $b = 0; - $bitMask = array(); - - $fileName = Constants::QR_CACHE_DIR.'mask_'.$maskNo.DIRECTORY_SEPARATOR.'mask_'.$width.'_'.$maskNo.'.dat'; - - if (Constants::QR_CACHEABLE) { - if (file_exists($fileName)) { - $bitMask = self::unserial(file_get_contents($fileName)); - } else { - $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); - if (!file_exists(Constants::QR_CACHE_DIR.'mask_'.$maskNo)) - mkdir(Constants::QR_CACHE_DIR.'mask_'.$maskNo); - file_put_contents($fileName, self::serial($bitMask)); - } - } else { - $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); - } - - if ($maskGenOnly) - return; - - $d = $s; - - for($y=0; $y<$width; $y++) { - for($x=0; $x<$width; $x++) { - if($bitMask[$y][$x] == 1) { - $d[$y][$x] = chr(ord($s[$y][$x]) ^ (int)$bitMask[$y][$x]); - } - $b += (int)(ord($d[$y][$x]) & 1); - } - } - - return $b; - } - - //---------------------------------------------------------------------- - public function makeMask($width, $frame, $maskNo, $level) - { - $masked = array_fill(0, $width, str_repeat("\0", $width)); - $this->makeMaskNo($maskNo, $width, $frame, $masked); - $this->writeFormatInformation($width, $masked, $maskNo, $level); - - return $masked; - } - - //---------------------------------------------------------------------- - public function calcN1N3($length) - { - $demerit = 0; - - for($i=0; $i<$length; $i++) { - - if($this->runLength[$i] >= 5) { - $demerit += (Constants::N1 + ($this->runLength[$i] - 5)); - } - if($i & 1) { - if(($i >= 3) && ($i < ($length-2)) && ($this->runLength[$i] % 3 == 0)) { - $fact = (int)($this->runLength[$i] / 3); - if(($this->runLength[$i-2] == $fact) && - ($this->runLength[$i-1] == $fact) && - ($this->runLength[$i+1] == $fact) && - ($this->runLength[$i+2] == $fact)) { - if(($this->runLength[$i-3] < 0) || ($this->runLength[$i-3] >= (4 * $fact))) { - $demerit += Constants::N3; - } else if((($i+3) >= $length) || ($this->runLength[$i+3] >= (4 * $fact))) { - $demerit += Constants::N3; - } - } - } - } - } - return $demerit; - } - - //---------------------------------------------------------------------- - public function evaluateSymbol($width, $frame) - { - $head = 0; - $demerit = 0; - - for($y=0; $y<$width; $y++) { - $head = 0; - $this->runLength[0] = 1; - - $frameY = $frame[$y]; - - if ($y>0) - $frameYM = $frame[$y-1]; - - for($x=0; $x<$width; $x++) { - if(($x > 0) && ($y > 0)) { - $b22 = ord($frameY[$x]) & ord($frameY[$x-1]) & ord($frameYM[$x]) & ord($frameYM[$x-1]); - $w22 = ord($frameY[$x]) | ord($frameY[$x-1]) | ord($frameYM[$x]) | ord($frameYM[$x-1]); - - if(($b22 | ($w22 ^ 1))&1) { - $demerit += Constants::N2; - } - } - if(($x == 0) && (ord($frameY[$x]) & 1)) { - $this->runLength[0] = -1; - $head = 1; - $this->runLength[$head] = 1; - } else if($x > 0) { - if((ord($frameY[$x]) ^ ord($frameY[$x-1])) & 1) { - $head++; - $this->runLength[$head] = 1; - } else { - $this->runLength[$head]++; - } - } - } - - $demerit += $this->calcN1N3($head+1); - } - - for($x=0; $x<$width; $x++) { - $head = 0; - $this->runLength[0] = 1; - - for($y=0; $y<$width; $y++) { - if($y == 0 && (ord($frame[$y][$x]) & 1)) { - $this->runLength[0] = -1; - $head = 1; - $this->runLength[$head] = 1; - } else if($y > 0) { - if((ord($frame[$y][$x]) ^ ord($frame[$y-1][$x])) & 1) { - $head++; - $this->runLength[$head] = 1; - } else { - $this->runLength[$head]++; - } - } - } - - $demerit += $this->calcN1N3($head+1); - } - - return $demerit; - } - - - //---------------------------------------------------------------------- - public function mask($width, $frame, $level) - { - $minDemerit = PHP_INT_MAX; - $bestMaskNum = 0; - $bestMask = array(); - - $checked_masks = array(0,1,2,3,4,5,6,7); - - if (Constants::QR_FIND_FROM_RANDOM !== false) { - - $howManuOut = 8-(Constants::QR_FIND_FROM_RANDOM % 9); - for ($i = 0; $i < $howManuOut; $i++) { - $remPos = rand (0, count($checked_masks)-1); - unset($checked_masks[$remPos]); - $checked_masks = array_values($checked_masks); - } - - } - - $bestMask = $frame; - - foreach($checked_masks as $i) { - $mask = array_fill(0, $width, str_repeat("\0", $width)); - - $demerit = 0; - $blacks = 0; - $blacks = $this->makeMaskNo($i, $width, $frame, $mask); - $blacks += $this->writeFormatInformation($width, $mask, $i, $level); - $blacks = (int)(100 * $blacks / ($width * $width)); - $demerit = (int)((int)(abs($blacks - 50) / 5) * Constants::N4); - $demerit += $this->evaluateSymbol($width, $mask); - - if($demerit < $minDemerit) { - $minDemerit = $demerit; - $bestMask = $mask; - $bestMaskNum = $i; - } - } - - return $bestMask; - } - - //---------------------------------------------------------------------- -} diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrawcode.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrawcode.php deleted file mode 100644 index 25eae7c8d..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrawcode.php +++ /dev/null @@ -1,117 +0,0 @@ -datacode = $input->getByteStream(); - if(is_null($this->datacode)) { - throw new Exception('null input string'); - } - - QRspec::getEccSpec($input->getVersion(), $input->getErrorCorrectionLevel(), $spec); - - $this->version = $input->getVersion(); - $this->b1 = QRspec::rsBlockNum1($spec); - $this->dataLength = QRspec::rsDataLength($spec); - $this->eccLength = QRspec::rsEccLength($spec); - $this->ecccode = array_fill(0, $this->eccLength, 0); - $this->blocks = QRspec::rsBlockNum($spec); - - $ret = $this->init($spec); - if($ret < 0) { - throw new Exception('block alloc error'); - return null; - } - - $this->count = 0; - } - - //---------------------------------------------------------------------- - public function init(array $spec) - { - $dl = QRspec::rsDataCodes1($spec); - $el = QRspec::rsEccCodes1($spec); - $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); - - - $blockNo = 0; - $dataPos = 0; - $eccPos = 0; - for($i=0; $iecccode,$eccPos); - $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs); - $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); - - $dataPos += $dl; - $eccPos += $el; - $blockNo++; - } - - if(QRspec::rsBlockNum2($spec) == 0) - return 0; - - $dl = QRspec::rsDataCodes2($spec); - $el = QRspec::rsEccCodes2($spec); - $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); - - if($rs == NULL) return -1; - - for($i=0; $iecccode,$eccPos); - $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs); - $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); - - $dataPos += $dl; - $eccPos += $el; - $blockNo++; - } - - return 0; - } - - //---------------------------------------------------------------------- - public function getCode() - { - $ret = null; - - if($this->count < $this->dataLength) { - $row = $this->count % $this->blocks; - $col = $this->count / $this->blocks; - if($col >= $this->rsblocks[0]->dataLength) { - $row += $this->b1; - } - $ret = $this->rsblocks[$row]->data[$col]; - } else if($this->count < $this->dataLength + $this->eccLength) { - $row = ($this->count - $this->dataLength) % $this->blocks; - $col = ($this->count - $this->dataLength) / $this->blocks; - $ret = $this->rsblocks[$row]->ecc[$col]; - } else { - return 0; - } - $this->count++; - - return $ret; - } -} diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrs.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrs.php deleted file mode 100644 index 66f0d5e77..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrs.php +++ /dev/null @@ -1,56 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRrs { - - public static $items = array(); - - //---------------------------------------------------------------------- - public static function init_rs($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) - { - foreach(self::$items as $rs) { - if($rs->pad != $pad) continue; - if($rs->nroots != $nroots) continue; - if($rs->mm != $symsize) continue; - if($rs->gfpoly != $gfpoly) continue; - if($rs->fcr != $fcr) continue; - if($rs->prim != $prim) continue; - - return $rs; - } - - $rs = QRrsItem::init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad); - array_unshift(self::$items, $rs); - - return $rs; - } -} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrsItem.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrsItem.php deleted file mode 100644 index ce63a8c35..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrsItem.php +++ /dev/null @@ -1,162 +0,0 @@ -= $this->nn) { - $x -= $this->nn; - $x = ($x >> $this->mm) + ($x & $this->nn); - } - - return $x; - } - - //---------------------------------------------------------------------- - public static function init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) - { - // Common code for intializing a Reed-Solomon control block (char or int symbols) - // Copyright 2004 Phil Karn, KA9Q - // May be used under the terms of the GNU Lesser General Public License (LGPL) - - $rs = null; - - // Check parameter ranges - if($symsize < 0 || $symsize > 8) return $rs; - if($fcr < 0 || $fcr >= (1<<$symsize)) return $rs; - if($prim <= 0 || $prim >= (1<<$symsize)) return $rs; - if($nroots < 0 || $nroots >= (1<<$symsize)) return $rs; // Can't have more roots than symbol values! - if($pad < 0 || $pad >= ((1<<$symsize) -1 - $nroots)) return $rs; // Too much padding - - $rs = new QRrsItem(); - $rs->mm = $symsize; - $rs->nn = (1<<$symsize)-1; - $rs->pad = $pad; - - $rs->alpha_to = array_fill(0, $rs->nn+1, 0); - $rs->index_of = array_fill(0, $rs->nn+1, 0); - - // PHP style macro replacement ;) - $NN =& $rs->nn; - $A0 =& $NN; - - // Generate Galois field lookup tables - $rs->index_of[0] = $A0; // log(zero) = -inf - $rs->alpha_to[$A0] = 0; // alpha**-inf = 0 - $sr = 1; - - for($i=0; $i<$rs->nn; $i++) { - $rs->index_of[$sr] = $i; - $rs->alpha_to[$i] = $sr; - $sr <<= 1; - if($sr & (1<<$symsize)) { - $sr ^= $gfpoly; - } - $sr &= $rs->nn; - } - - if($sr != 1){ - // field generator polynomial is not primitive! - $rs = NULL; - return $rs; - } - - /* Form RS code generator polynomial from its roots */ - $rs->genpoly = array_fill(0, $nroots+1, 0); - - $rs->fcr = $fcr; - $rs->prim = $prim; - $rs->nroots = $nroots; - $rs->gfpoly = $gfpoly; - - /* Find prim-th root of 1, used in decoding */ - for($iprim=1;($iprim % $prim) != 0;$iprim += $rs->nn) - ; // intentional empty-body loop! - - $rs->iprim = (int)($iprim / $prim); - $rs->genpoly[0] = 1; - - for ($i = 0,$root=$fcr*$prim; $i < $nroots; $i++, $root += $prim) { - $rs->genpoly[$i+1] = 1; - - // Multiply rs->genpoly[] by @**(root + x) - for ($j = $i; $j > 0; $j--) { - if ($rs->genpoly[$j] != 0) { - $rs->genpoly[$j] = $rs->genpoly[$j-1] ^ $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[$j]] + $root)]; - } else { - $rs->genpoly[$j] = $rs->genpoly[$j-1]; - } - } - // rs->genpoly[0] can never be zero - $rs->genpoly[0] = $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[0]] + $root)]; - } - - // convert rs->genpoly[] to index form for quicker encoding - for ($i = 0; $i <= $nroots; $i++) - $rs->genpoly[$i] = $rs->index_of[$rs->genpoly[$i]]; - - return $rs; - } - - //---------------------------------------------------------------------- - public function encode_rs_char($data, &$parity) - { - $MM =& $this->mm; - $NN =& $this->nn; - $ALPHA_TO =& $this->alpha_to; - $INDEX_OF =& $this->index_of; - $GENPOLY =& $this->genpoly; - $NROOTS =& $this->nroots; - $FCR =& $this->fcr; - $PRIM =& $this->prim; - $IPRIM =& $this->iprim; - $PAD =& $this->pad; - $A0 =& $NN; - - $parity = array_fill(0, $NROOTS, 0); - - for($i=0; $i< ($NN-$NROOTS-$PAD); $i++) { - - $feedback = $INDEX_OF[$data[$i] ^ $parity[0]]; - if($feedback != $A0) { - // feedback term is non-zero - - // This line is unnecessary when GENPOLY[NROOTS] is unity, as it must - // always be for the polynomials constructed by init_rs() - $feedback = $this->modnn($NN - $GENPOLY[$NROOTS] + $feedback); - - for($j=1;$j<$NROOTS;$j++) { - $parity[$j] ^= $ALPHA_TO[$this->modnn($feedback + $GENPOLY[$NROOTS-$j])]; - } - } - - // Shift - array_shift($parity); - if($feedback != $A0) { - array_push($parity, $ALPHA_TO[$this->modnn($feedback + $GENPOLY[0])]); - } else { - array_push($parity, 0); - } - } - } -} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrsblock.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrsblock.php deleted file mode 100644 index c1d01f22e..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRrsblock.php +++ /dev/null @@ -1,25 +0,0 @@ -encode_rs_char($data, $ecc); - - $this->dataLength = $dl; - $this->data = $data; - $this->eccLength = $el; - $this->ecc = $ecc; - } -}; \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRspec.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRspec.php deleted file mode 100644 index d68432604..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRspec.php +++ /dev/null @@ -1,586 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * The following data / specifications are taken from - * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004) - * or - * "Automatic identification and data capture techniques -- - * QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006) - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRspec { - - public static $capacity = array( - array( 0, 0, 0, array( 0, 0, 0, 0)), - array( 21, 26, 0, array( 7, 10, 13, 17)), // 1 - array( 25, 44, 7, array( 10, 16, 22, 28)), - array( 29, 70, 7, array( 15, 26, 36, 44)), - array( 33, 100, 7, array( 20, 36, 52, 64)), - array( 37, 134, 7, array( 26, 48, 72, 88)), // 5 - array( 41, 172, 7, array( 36, 64, 96, 112)), - array( 45, 196, 0, array( 40, 72, 108, 130)), - array( 49, 242, 0, array( 48, 88, 132, 156)), - array( 53, 292, 0, array( 60, 110, 160, 192)), - array( 57, 346, 0, array( 72, 130, 192, 224)), //10 - array( 61, 404, 0, array( 80, 150, 224, 264)), - array( 65, 466, 0, array( 96, 176, 260, 308)), - array( 69, 532, 0, array( 104, 198, 288, 352)), - array( 73, 581, 3, array( 120, 216, 320, 384)), - array( 77, 655, 3, array( 132, 240, 360, 432)), //15 - array( 81, 733, 3, array( 144, 280, 408, 480)), - array( 85, 815, 3, array( 168, 308, 448, 532)), - array( 89, 901, 3, array( 180, 338, 504, 588)), - array( 93, 991, 3, array( 196, 364, 546, 650)), - array( 97, 1085, 3, array( 224, 416, 600, 700)), //20 - array(101, 1156, 4, array( 224, 442, 644, 750)), - array(105, 1258, 4, array( 252, 476, 690, 816)), - array(109, 1364, 4, array( 270, 504, 750, 900)), - array(113, 1474, 4, array( 300, 560, 810, 960)), - array(117, 1588, 4, array( 312, 588, 870, 1050)), //25 - array(121, 1706, 4, array( 336, 644, 952, 1110)), - array(125, 1828, 4, array( 360, 700, 1020, 1200)), - array(129, 1921, 3, array( 390, 728, 1050, 1260)), - array(133, 2051, 3, array( 420, 784, 1140, 1350)), - array(137, 2185, 3, array( 450, 812, 1200, 1440)), //30 - array(141, 2323, 3, array( 480, 868, 1290, 1530)), - array(145, 2465, 3, array( 510, 924, 1350, 1620)), - array(149, 2611, 3, array( 540, 980, 1440, 1710)), - array(153, 2761, 3, array( 570, 1036, 1530, 1800)), - array(157, 2876, 0, array( 570, 1064, 1590, 1890)), //35 - array(161, 3034, 0, array( 600, 1120, 1680, 1980)), - array(165, 3196, 0, array( 630, 1204, 1770, 2100)), - array(169, 3362, 0, array( 660, 1260, 1860, 2220)), - array(173, 3532, 0, array( 720, 1316, 1950, 2310)), - array(177, 3706, 0, array( 750, 1372, 2040, 2430)) //40 - ); - - //---------------------------------------------------------------------- - public static function getDataLength($version, $level) - { - return self::$capacity[$version][Constants::QRCAP_WORDS] - self::$capacity[$version][Constants::QRCAP_EC][$level]; - } - - //---------------------------------------------------------------------- - public static function getECCLength($version, $level) - { - return self::$capacity[$version][Constants::QRCAP_EC][$level]; - } - - //---------------------------------------------------------------------- - public static function getWidth($version) - { - return self::$capacity[$version][Constants::QRCAP_WIDTH]; - } - - //---------------------------------------------------------------------- - public static function getRemainder($version) - { - return self::$capacity[$version][Constants::QRCAP_REMINDER]; - } - - //---------------------------------------------------------------------- - public static function getMinimumVersion($size, $level) - { - - for($i=1; $i<= Constants::QRSPEC_VERSION_MAX; $i++) { - $words = self::$capacity[$i][Constants::QRCAP_WORDS] - self::$capacity[$i][Constants::QRCAP_EC][$level]; - if($words >= $size) - return $i; - } - - return -1; - } - - //###################################################################### - - public static $lengthTableBits = array( - array(10, 12, 14), - array( 9, 11, 13), - array( 8, 16, 16), - array( 8, 10, 12) - ); - - //---------------------------------------------------------------------- - public static function lengthIndicator($mode, $version) - { - if ($mode == Constants::QR_MODE_STRUCTURE) - return 0; - - if ($version <= 9) { - $l = 0; - } else if ($version <= 26) { - $l = 1; - } else { - $l = 2; - } - - return self::$lengthTableBits[$mode][$l]; - } - - //---------------------------------------------------------------------- - public static function maximumWords($mode, $version) - { - if($mode == Constants::QR_MODE_STRUCTURE) - return 3; - - if($version <= 9) { - $l = 0; - } else if($version <= 26) { - $l = 1; - } else { - $l = 2; - } - - $bits = self::$lengthTableBits[$mode][$l]; - $words = (1 << $bits) - 1; - - if($mode == Constants::QR_MODE_KANJI) { - $words *= 2; // the number of bytes is required - } - - return $words; - } - - // Error correction code ----------------------------------------------- - // Table of the error correction code (Reed-Solomon block) - // See Table 12-16 (pp.30-36), JIS X0510:2004. - - public static $eccTable = array( - array(array( 0, 0), array( 0, 0), array( 0, 0), array( 0, 0)), - array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), // 1 - array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), - array(array( 1, 0), array( 1, 0), array( 2, 0), array( 2, 0)), - array(array( 1, 0), array( 2, 0), array( 2, 0), array( 4, 0)), - array(array( 1, 0), array( 2, 0), array( 2, 2), array( 2, 2)), // 5 - array(array( 2, 0), array( 4, 0), array( 4, 0), array( 4, 0)), - array(array( 2, 0), array( 4, 0), array( 2, 4), array( 4, 1)), - array(array( 2, 0), array( 2, 2), array( 4, 2), array( 4, 2)), - array(array( 2, 0), array( 3, 2), array( 4, 4), array( 4, 4)), - array(array( 2, 2), array( 4, 1), array( 6, 2), array( 6, 2)), //10 - array(array( 4, 0), array( 1, 4), array( 4, 4), array( 3, 8)), - array(array( 2, 2), array( 6, 2), array( 4, 6), array( 7, 4)), - array(array( 4, 0), array( 8, 1), array( 8, 4), array(12, 4)), - array(array( 3, 1), array( 4, 5), array(11, 5), array(11, 5)), - array(array( 5, 1), array( 5, 5), array( 5, 7), array(11, 7)), //15 - array(array( 5, 1), array( 7, 3), array(15, 2), array( 3, 13)), - array(array( 1, 5), array(10, 1), array( 1, 15), array( 2, 17)), - array(array( 5, 1), array( 9, 4), array(17, 1), array( 2, 19)), - array(array( 3, 4), array( 3, 11), array(17, 4), array( 9, 16)), - array(array( 3, 5), array( 3, 13), array(15, 5), array(15, 10)), //20 - array(array( 4, 4), array(17, 0), array(17, 6), array(19, 6)), - array(array( 2, 7), array(17, 0), array( 7, 16), array(34, 0)), - array(array( 4, 5), array( 4, 14), array(11, 14), array(16, 14)), - array(array( 6, 4), array( 6, 14), array(11, 16), array(30, 2)), - array(array( 8, 4), array( 8, 13), array( 7, 22), array(22, 13)), //25 - array(array(10, 2), array(19, 4), array(28, 6), array(33, 4)), - array(array( 8, 4), array(22, 3), array( 8, 26), array(12, 28)), - array(array( 3, 10), array( 3, 23), array( 4, 31), array(11, 31)), - array(array( 7, 7), array(21, 7), array( 1, 37), array(19, 26)), - array(array( 5, 10), array(19, 10), array(15, 25), array(23, 25)), //30 - array(array(13, 3), array( 2, 29), array(42, 1), array(23, 28)), - array(array(17, 0), array(10, 23), array(10, 35), array(19, 35)), - array(array(17, 1), array(14, 21), array(29, 19), array(11, 46)), - array(array(13, 6), array(14, 23), array(44, 7), array(59, 1)), - array(array(12, 7), array(12, 26), array(39, 14), array(22, 41)), //35 - array(array( 6, 14), array( 6, 34), array(46, 10), array( 2, 64)), - array(array(17, 4), array(29, 14), array(49, 10), array(24, 46)), - array(array( 4, 18), array(13, 32), array(48, 14), array(42, 32)), - array(array(20, 4), array(40, 7), array(43, 22), array(10, 67)), - array(array(19, 6), array(18, 31), array(34, 34), array(20, 61)),//40 - ); - - //---------------------------------------------------------------------- - // CACHEABLE!!! - - public static function getEccSpec($version, $level, array &$spec) - { - if (count($spec) < 5) { - $spec = array(0,0,0,0,0); - } - - $b1 = self::$eccTable[$version][$level][0]; - $b2 = self::$eccTable[$version][$level][1]; - $data = self::getDataLength($version, $level); - $ecc = self::getECCLength($version, $level); - - if($b2 == 0) { - $spec[0] = $b1; - $spec[1] = (int)($data / $b1); - $spec[2] = (int)($ecc / $b1); - $spec[3] = 0; - $spec[4] = 0; - } else { - $spec[0] = $b1; - $spec[1] = (int)($data / ($b1 + $b2)); - $spec[2] = (int)($ecc / ($b1 + $b2)); - $spec[3] = $b2; - $spec[4] = $spec[1] + 1; - } - } - - // Alignment pattern --------------------------------------------------- - - // Positions of alignment patterns. - // This array includes only the second and the third position of the - // alignment patterns. Rest of them can be calculated from the distance - // between them. - - // See Table 1 in Appendix E (pp.71) of JIS X0510:2004. - - public static $alignmentPattern = array( - array( 0, 0), - array( 0, 0), array(18, 0), array(22, 0), array(26, 0), array(30, 0), // 1- 5 - array(34, 0), array(22, 38), array(24, 42), array(26, 46), array(28, 50), // 6-10 - array(30, 54), array(32, 58), array(34, 62), array(26, 46), array(26, 48), //11-15 - array(26, 50), array(30, 54), array(30, 56), array(30, 58), array(34, 62), //16-20 - array(28, 50), array(26, 50), array(30, 54), array(28, 54), array(32, 58), //21-25 - array(30, 58), array(34, 62), array(26, 50), array(30, 54), array(26, 52), //26-30 - array(30, 56), array(34, 60), array(30, 58), array(34, 62), array(30, 54), //31-35 - array(24, 50), array(28, 54), array(32, 58), array(26, 54), array(30, 58), //35-40 - ); - - - /** -------------------------------------------------------------------- - * Put an alignment marker. - * @param frame - * @param width - * @param ox,oy center coordinate of the pattern - */ - public static function putAlignmentMarker(array &$frame, $ox, $oy) - { - $finder = array( - "\xa1\xa1\xa1\xa1\xa1", - "\xa1\xa0\xa0\xa0\xa1", - "\xa1\xa0\xa1\xa0\xa1", - "\xa1\xa0\xa0\xa0\xa1", - "\xa1\xa1\xa1\xa1\xa1" - ); - - $yStart = $oy-2; - $xStart = $ox-2; - - for($y=0; $y<5; $y++) { - QRstr::set($frame, $xStart, $yStart+$y, $finder[$y]); - } - } - - //---------------------------------------------------------------------- - public static function putAlignmentPattern($version, &$frame, $width) - { - if($version < 2) - return; - - $d = self::$alignmentPattern[$version][1] - self::$alignmentPattern[$version][0]; - if($d < 0) { - $w = 2; - } else { - $w = (int)(($width - self::$alignmentPattern[$version][0]) / $d + 2); - } - - if($w * $w - 3 == 1) { - $x = self::$alignmentPattern[$version][0]; - $y = self::$alignmentPattern[$version][0]; - self::putAlignmentMarker($frame, $x, $y); - return; - } - - $cx = self::$alignmentPattern[$version][0]; - for($x=1; $x<$w - 1; $x++) { - self::putAlignmentMarker($frame, 6, $cx); - self::putAlignmentMarker($frame, $cx, 6); - $cx += $d; - } - - $cy = self::$alignmentPattern[$version][0]; - for($y=0; $y<$w-1; $y++) { - $cx = self::$alignmentPattern[$version][0]; - for($x=0; $x<$w-1; $x++) { - self::putAlignmentMarker($frame, $cx, $cy); - $cx += $d; - } - $cy += $d; - } - } - - // Version information pattern ----------------------------------------- - - // Version information pattern (BCH coded). - // See Table 1 in Appendix D (pp.68) of JIS X0510:2004. - - // size: [Constants::QRSPEC_VERSION_MAX - 6] - - public static $versionPattern = array( - 0x07c94, 0x085bc, 0x09a99, 0x0a4d3, 0x0bbf6, 0x0c762, 0x0d847, 0x0e60d, - 0x0f928, 0x10b78, 0x1145d, 0x12a17, 0x13532, 0x149a6, 0x15683, 0x168c9, - 0x177ec, 0x18ec4, 0x191e1, 0x1afab, 0x1b08e, 0x1cc1a, 0x1d33f, 0x1ed75, - 0x1f250, 0x209d5, 0x216f0, 0x228ba, 0x2379f, 0x24b0b, 0x2542e, 0x26a64, - 0x27541, 0x28c69 - ); - - //---------------------------------------------------------------------- - public static function getVersionPattern($version) - { - if($version < 7 || $version > Constants::QRSPEC_VERSION_MAX) - return 0; - - return self::$versionPattern[$version -7]; - } - - // Format information -------------------------------------------------- - // See calcFormatInfo in tests/test_qrspec.c (orginal qrencode c lib) - - public static $formatInfo = array( - array(0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976), - array(0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0), - array(0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed), - array(0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b) - ); - - public static function getFormatInfo($mask, $level) - { - if($mask < 0 || $mask > 7) - return 0; - - if($level < 0 || $level > 3) - return 0; - - return self::$formatInfo[$level][$mask]; - } - - // Frame --------------------------------------------------------------- - // Cache of initial frames. - - public static $frames = array(); - - /** -------------------------------------------------------------------- - * Put a finder pattern. - * @param frame - * @param width - * @param ox,oy upper-left coordinate of the pattern - */ - public static function putFinderPattern(&$frame, $ox, $oy) - { - $finder = array( - "\xc1\xc1\xc1\xc1\xc1\xc1\xc1", - "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", - "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", - "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", - "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", - "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", - "\xc1\xc1\xc1\xc1\xc1\xc1\xc1" - ); - - for($y=0; $y<7; $y++) { - QRstr::set($frame, $ox, $oy+$y, $finder[$y]); - } - } - - //---------------------------------------------------------------------- - public static function createFrame($version) - { - $width = self::$capacity[$version][Constants::QRCAP_WIDTH]; - $frameLine = str_repeat ("\0", $width); - $frame = array_fill(0, $width, $frameLine); - - // Finder pattern - self::putFinderPattern($frame, 0, 0); - self::putFinderPattern($frame, $width - 7, 0); - self::putFinderPattern($frame, 0, $width - 7); - - // Separator - $yOffset = $width - 7; - - for($y=0; $y<7; $y++) { - $frame[$y][7] = "\xc0"; - $frame[$y][$width - 8] = "\xc0"; - $frame[$yOffset][7] = "\xc0"; - $yOffset++; - } - - $setPattern = str_repeat("\xc0", 8); - - QRstr::set($frame, 0, 7, $setPattern); - QRstr::set($frame, $width-8, 7, $setPattern); - QRstr::set($frame, 0, $width - 8, $setPattern); - - // Format info - $setPattern = str_repeat("\x84", 9); - QRstr::set($frame, 0, 8, $setPattern); - QRstr::set($frame, $width - 8, 8, $setPattern, 8); - - $yOffset = $width - 8; - - for($y=0; $y<8; $y++,$yOffset++) { - $frame[$y][8] = "\x84"; - $frame[$yOffset][8] = "\x84"; - } - - // Timing pattern - - for($i=1; $i<$width-15; $i++) { - $frame[6][7+$i] = chr(0x90 | ($i & 1)); - $frame[7+$i][6] = chr(0x90 | ($i & 1)); - } - - // Alignment pattern - self::putAlignmentPattern($version, $frame, $width); - - // Version information - if($version >= 7) { - $vinf = self::getVersionPattern($version); - - $v = $vinf; - - for($x=0; $x<6; $x++) { - for($y=0; $y<3; $y++) { - $frame[($width - 11)+$y][$x] = chr(0x88 | ($v & 1)); - $v = $v >> 1; - } - } - - $v = $vinf; - for($y=0; $y<6; $y++) { - for($x=0; $x<3; $x++) { - $frame[$y][$x+($width - 11)] = chr(0x88 | ($v & 1)); - $v = $v >> 1; - } - } - } - - // and a little bit... - $frame[$width - 8][8] = "\x81"; - - return $frame; - } - - //---------------------------------------------------------------------- - public static function debug($frame, $binary_mode = false) - { - if ($binary_mode) { - - foreach ($frame as &$frameLine) { - $frameLine = join('  ', explode('0', $frameLine)); - $frameLine = join('██', explode('1', $frameLine)); - } - - ?> - -


        '; - echo join("
        ", $frame); - echo '






'; - - } else { - - foreach ($frame as &$frameLine) { - $frameLine = join(' ', explode("\xc0", $frameLine)); - $frameLine = join('', explode("\xc1", $frameLine)); - $frameLine = join(' ', explode("\xa0", $frameLine)); - $frameLine = join('', explode("\xa1", $frameLine)); - $frameLine = join('', explode("\x84", $frameLine)); //format 0 - $frameLine = join('', explode("\x85", $frameLine)); //format 1 - $frameLine = join('', explode("\x81", $frameLine)); //special bit - $frameLine = join(' ', explode("\x90", $frameLine)); //clock 0 - $frameLine = join('', explode("\x91", $frameLine)); //clock 1 - $frameLine = join(' ', explode("\x88", $frameLine)); //version - $frameLine = join('', explode("\x89", $frameLine)); //version - $frameLine = join('♦', explode("\x01", $frameLine)); - $frameLine = join('⋅', explode("\0", $frameLine)); - } - - ?> - - "; - echo join("
", $frame); - echo "
"; - - } - } - - //---------------------------------------------------------------------- - public static function serial($frame) - { - return gzcompress(join("\n", $frame), 9); - } - - //---------------------------------------------------------------------- - public static function unserial($code) - { - return explode("\n", gzuncompress($code)); - } - - //---------------------------------------------------------------------- - public static function newFrame($version) - { - if($version < 1 || $version > Constants::QRSPEC_VERSION_MAX) - return null; - - if(!isset(self::$frames[$version])) { - - $fileName = Constants::QR_CACHE_DIR.'frame_'.$version.'.dat'; - - if (Constants::QR_CACHEABLE) { - if (file_exists($fileName)) { - self::$frames[$version] = self::unserial(file_get_contents($fileName)); - } else { - self::$frames[$version] = self::createFrame($version); - file_put_contents($fileName, self::serial(self::$frames[$version])); - } - } else { - self::$frames[$version] = self::createFrame($version); - } - } - - if(is_null(self::$frames[$version])) - return null; - - return self::$frames[$version]; - } - - //---------------------------------------------------------------------- - public static function rsBlockNum($spec) { return $spec[0] + $spec[3]; } - public static function rsBlockNum1($spec) { return $spec[0]; } - public static function rsDataCodes1($spec) { return $spec[1]; } - public static function rsEccCodes1($spec) { return $spec[2]; } - public static function rsBlockNum2($spec) { return $spec[3]; } - public static function rsDataCodes2($spec) { return $spec[4]; } - public static function rsEccCodes2($spec) { return $spec[2]; } - public static function rsDataLength($spec) { return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]); } - public static function rsEccLength($spec) { return ($spec[0] + $spec[3]) * $spec[2]; } - -} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRsplit.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRsplit.php deleted file mode 100644 index 805140a97..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRsplit.php +++ /dev/null @@ -1,316 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * The following data / specifications are taken from - * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004) - * or - * "Automatic identification and data capture techniques -- - * QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006) - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -use Exception; - -class QRsplit { - - public $dataStr = ''; - public $input; - public $modeHint; - - //---------------------------------------------------------------------- - public function __construct($dataStr, $input, $modeHint) - { - $this->dataStr = $dataStr; - $this->input = $input; - $this->modeHint = $modeHint; - } - - //---------------------------------------------------------------------- - public static function isdigitat($str, $pos) - { - if ($pos >= strlen($str)) - return false; - - return ((ord($str[$pos]) >= ord('0'))&&(ord($str[$pos]) <= ord('9'))); - } - - //---------------------------------------------------------------------- - public static function isalnumat($str, $pos) - { - if ($pos >= strlen($str)) - return false; - - return (QRinput::lookAnTable(ord($str[$pos])) >= 0); - } - - //---------------------------------------------------------------------- - public function identifyMode($pos) - { - if ($pos >= strlen($this->dataStr)) - return Constants::QR_MODE_NUL; - - $c = $this->dataStr[$pos]; - - if(self::isdigitat($this->dataStr, $pos)) { - return Constants::QR_MODE_NUM; - } else if(self::isalnumat($this->dataStr, $pos)) { - return Constants::QR_MODE_AN; - } else if($this->modeHint == Constants::QR_MODE_KANJI) { - - if ($pos+1 < strlen($this->dataStr)) - { - $d = $this->dataStr[$pos+1]; - $word = (ord($c) << 8) | ord($d); - if(($word >= 0x8140 && $word <= 0x9ffc) || ($word >= 0xe040 && $word <= 0xebbf)) { - return Constants::QR_MODE_KANJI; - } - } - } - - return Constants::QR_MODE_8; - } - - //---------------------------------------------------------------------- - public function eatNum() - { - $ln = QRspec::lengthIndicator(Constants::QR_MODE_NUM, $this->input->getVersion()); - - $p = 0; - while(self::isdigitat($this->dataStr, $p)) { - $p++; - } - - $run = $p; - $mode = $this->identifyMode($p); - - if($mode == Constants::QR_MODE_8) { - $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln - + QRinput::estimateBitsMode8(1) // + 4 + l8 - - QRinput::estimateBitsMode8($run + 1); // - 4 - l8 - if($dif > 0) { - return $this->eat8(); - } - } - if($mode == Constants::QR_MODE_AN) { - $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln - + QRinput::estimateBitsModeAn(1) // + 4 + la - - QRinput::estimateBitsModeAn($run + 1);// - 4 - la - if($dif > 0) { - return $this->eatAn(); - } - } - - $ret = $this->input->append(Constants::QR_MODE_NUM, $run, str_split($this->dataStr)); - if($ret < 0) - return -1; - - return $run; - } - - //---------------------------------------------------------------------- - public function eatAn() - { - $la = QRspec::lengthIndicator(Constants::QR_MODE_AN, $this->input->getVersion()); - $ln = QRspec::lengthIndicator(Constants::QR_MODE_NUM, $this->input->getVersion()); - - $p = 0; - - while(self::isalnumat($this->dataStr, $p)) { - if(self::isdigitat($this->dataStr, $p)) { - $q = $p; - while(self::isdigitat($this->dataStr, $q)) { - $q++; - } - - $dif = QRinput::estimateBitsModeAn($p) // + 4 + la - + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln - - QRinput::estimateBitsModeAn($q); // - 4 - la - - if($dif < 0) { - break; - } else { - $p = $q; - } - } else { - $p++; - } - } - - $run = $p; - - if(!self::isalnumat($this->dataStr, $p)) { - $dif = QRinput::estimateBitsModeAn($run) + 4 + $la - + QRinput::estimateBitsMode8(1) // + 4 + l8 - - QRinput::estimateBitsMode8($run + 1); // - 4 - l8 - if($dif > 0) { - return $this->eat8(); - } - } - - $ret = $this->input->append(Constants::QR_MODE_AN, $run, str_split($this->dataStr)); - if($ret < 0) - return -1; - - return $run; - } - - //---------------------------------------------------------------------- - public function eatKanji() - { - $p = 0; - - while($this->identifyMode($p) == Constants::QR_MODE_KANJI) { - $p += 2; - } - - $ret = $this->input->append(Constants::QR_MODE_KANJI, $p, str_split($this->dataStr)); - if($ret < 0) - return -1; - - return $ret; - } - - //---------------------------------------------------------------------- - public function eat8() - { - $la = QRspec::lengthIndicator(Constants::QR_MODE_AN, $this->input->getVersion()); - $ln = QRspec::lengthIndicator(Constants::QR_MODE_NUM, $this->input->getVersion()); - - $p = 1; - $dataStrLen = strlen($this->dataStr); - - while($p < $dataStrLen) { - - $mode = $this->identifyMode($p); - if($mode == Constants::QR_MODE_KANJI) { - break; - } - if($mode == Constants::QR_MODE_NUM) { - $q = $p; - while(self::isdigitat($this->dataStr, $q)) { - $q++; - } - $dif = QRinput::estimateBitsMode8($p) // + 4 + l8 - + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln - - QRinput::estimateBitsMode8($q); // - 4 - l8 - if($dif < 0) { - break; - } else { - $p = $q; - } - } else if($mode == Constants::QR_MODE_AN) { - $q = $p; - while(self::isalnumat($this->dataStr, $q)) { - $q++; - } - $dif = QRinput::estimateBitsMode8($p) // + 4 + l8 - + QRinput::estimateBitsModeAn($q - $p) + 4 + $la - - QRinput::estimateBitsMode8($q); // - 4 - l8 - if($dif < 0) { - break; - } else { - $p = $q; - } - } else { - $p++; - } - } - - $run = $p; - $ret = $this->input->append(Constants::QR_MODE_8, $run, str_split($this->dataStr)); - - if($ret < 0) - return -1; - - return $run; - } - - //---------------------------------------------------------------------- - public function splitString() - { - while (strlen($this->dataStr) > 0) - { - if($this->dataStr == '') - return 0; - - $mode = $this->identifyMode(0); - - switch ($mode) { - case Constants::QR_MODE_NUM: $length = $this->eatNum(); break; - case Constants::QR_MODE_AN: $length = $this->eatAn(); break; - case Constants::QR_MODE_KANJI: - if ($hint == Constants::QR_MODE_KANJI) - $length = $this->eatKanji(); - else $length = $this->eat8(); - break; - default: $length = $this->eat8(); break; - - } - - if($length == 0) return 0; - if($length < 0) return -1; - - $this->dataStr = substr($this->dataStr, $length); - } - } - - //---------------------------------------------------------------------- - public function toUpper() - { - $stringLen = strlen($this->dataStr); - $p = 0; - - while ($p<$stringLen) { - $mode = self::identifyMode(substr($this->dataStr, $p), $this->modeHint); - if($mode == Constants::QR_MODE_KANJI) { - $p += 2; - } else { - if (ord($this->dataStr[$p]) >= ord('a') && ord($this->dataStr[$p]) <= ord('z')) { - $this->dataStr[$p] = chr(ord($this->dataStr[$p]) - 32); - } - $p++; - } - } - - return $this->dataStr; - } - - //---------------------------------------------------------------------- - public static function splitStringToQRinput($string, QRinput $input, $modeHint, $casesensitive = true) - { - if(is_null($string) || $string == '\0' || $string == '') { - throw new Exception('empty string!!!'); - } - - $split = new QRsplit($string, $input, $modeHint); - - if(!$casesensitive) - $split->toUpper(); - - return $split->splitString(); - } -} diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRstr.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRstr.php deleted file mode 100644 index 64c4bd5c6..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRstr.php +++ /dev/null @@ -1,35 +0,0 @@ - - * - * PHP QR Code is distributed under LGPL 3 - * Copyright (C) 2010 Dominik Dzienia - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRstr { - public static function set(&$srctab, $x, $y, $repl, $replLen = false) { - $srctab[$y] = substr_replace($srctab[$y], ($replLen !== false)?substr($repl,0,$replLen):$repl, $x, ($replLen !== false)?$replLen:strlen($repl)); - } -} \ No newline at end of file diff --git a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRtools.php b/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRtools.php deleted file mode 100644 index 7c75a6e2a..000000000 --- a/vendor/aferrandini/phpqrcode/lib/PHPQRCode/QRtools.php +++ /dev/null @@ -1,171 +0,0 @@ - - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 3 of the License, or any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - */ - -namespace PHPQRCode; - -class QRtools { - - //---------------------------------------------------------------------- - public static function binarize($frame) - { - $len = count($frame); - foreach ($frame as &$frameLine) { - - for($i=0; $i<$len; $i++) { - $frameLine[$i] = (ord($frameLine[$i])&1)?'1':'0'; - } - } - - return $frame; - } - - //---------------------------------------------------------------------- - public static function tcpdfBarcodeArray($code, $mode = 'QR,L', $tcPdfVersion = '4.5.037') - { - $barcode_array = array(); - - if (!is_array($mode)) - $mode = explode(',', $mode); - - $eccLevel = 'L'; - - if (count($mode) > 1) { - $eccLevel = $mode[1]; - } - - $qrTab = QRcode::text($code, false, $eccLevel); - $size = count($qrTab); - - $barcode_array['num_rows'] = $size; - $barcode_array['num_cols'] = $size; - $barcode_array['bcode'] = array(); - - foreach ($qrTab as $line) { - $arrAdd = array(); - foreach(str_split($line) as $char) - $arrAdd[] = ($char=='1')?1:0; - $barcode_array['bcode'][] = $arrAdd; - } - - return $barcode_array; - } - - //---------------------------------------------------------------------- - public static function clearCache() - { - self::$frames = array(); - } - - //---------------------------------------------------------------------- - public static function buildCache() - { - QRtools::markTime('before_build_cache'); - - $mask = new QRmask(); - for ($a=1; $a <= Constants::QRSPEC_VERSION_MAX; $a++) { - $frame = QRspec::newFrame($a); - if (Constants::QR_IMAGE) { - $fileName = Constants::QR_CACHE_DIR.'frame_'.$a.'.png'; - QRimage::png(self::binarize($frame), $fileName, 1, 0); - } - - $width = count($frame); - $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); - for ($maskNo=0; $maskNo<8; $maskNo++) - $mask->makeMaskNo($maskNo, $width, $frame, $bitMask, true); - } - - QRtools::markTime('after_build_cache'); - } - - //---------------------------------------------------------------------- - public static function log($outfile, $err) - { - if (Constants::QR_LOG_DIR !== false) { - if ($err != '') { - if ($outfile !== false) { - file_put_contents(Constants::QR_LOG_DIR.basename($outfile).'-errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); - } else { - file_put_contents(Constants::QR_LOG_DIR.'errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); - } - } - } - } - - //---------------------------------------------------------------------- - public static function dumpMask($frame) - { - $width = count($frame); - for($y=0;$y<$width;$y++) { - for($x=0;$x<$width;$x++) { - echo ord($frame[$y][$x]).','; - } - } - } - - //---------------------------------------------------------------------- - public static function markTime($markerId) - { - list($usec, $sec) = explode(" ", microtime()); - $time = ((float)$usec + (float)$sec); - - if (!isset($GLOBALS['qr_time_bench'])) - $GLOBALS['qr_time_bench'] = array(); - - $GLOBALS['qr_time_bench'][$markerId] = $time; - } - - //---------------------------------------------------------------------- - public static function timeBenchmark() - { - self::markTime('finish'); - - $lastTime = 0; - $startTime = 0; - $p = 0; - - echo ' - - '; - - foreach($GLOBALS['qr_time_bench'] as $markerId=>$thisTime) { - if ($p > 0) { - echo ''; - } else { - $startTime = $thisTime; - } - - $p++; - $lastTime = $thisTime; - } - - echo ' - - -
BENCHMARK
till '.$markerId.': '.number_format($thisTime-$lastTime, 6).'s
TOTAL: '.number_format($lastTime-$startTime, 6).'s
'; - } - -} - -QRtools::markTime('start'); diff --git a/vendor/aferrandini/phpqrcode/readme.md b/vendor/aferrandini/phpqrcode/readme.md deleted file mode 100644 index e8f2f5ab3..000000000 --- a/vendor/aferrandini/phpqrcode/readme.md +++ /dev/null @@ -1,37 +0,0 @@ -# PHP QRCode Library - -To install this library please follow the next steps: - -## Install the library using `composer`: - -Add the required module to your `composer.json` file: - - { - "require": { - ... - "aferrandini/phpqrcode": "1.0.1" - ... - } - } - -Then run the command `composer update`. - - -## Usage - -Sample code: - - \PHPQRCode\QRcode::png("Test", "/tmp/qrcode.png", 'L', 4, 2); - -This code will generate a PNG file on '/tmp/qrcode.png' with a QRCode that contains the word 'Test'. - -## Acknowledgements - -This library is an import of PHP QR Code by Dominik Dzienia that you can find at http://phpqrcode.sourceforge.net - -Based on C libqrencode library (ver. 3.1.1), Copyright (C) 2006-2010 by Kentaro Fukuchi -http://megaui.net/fukuchi/works/qrencode/index.en.html - -QR Code is registered trademarks of DENSO WAVE INCORPORATED in JAPAN and other countries. - -Reed-Solomon code encoder is written by Phil Karn, KA9Q. Copyright (C) 2002, 2003, 2004, 2006 Phil Karn, KA9Q diff --git a/vendor/autoload.php b/vendor/autoload.php index c2b7d220b..54ecedf96 100644 --- a/vendor/autoload.php +++ b/vendor/autoload.php @@ -4,4 +4,4 @@ require_once __DIR__ . '/composer/autoload_real.php'; -return ComposerAutoloaderInit5a34d2cf88418439a1e7fb45047b8e5a::getLoader(); +return ComposerAutoloaderInitbe5fdc6ce25a854de4cbf5279dee37ce::getLoader(); diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php index 4caa0fb2e..7b914e575 100644 --- a/vendor/composer/autoload_classmap.php +++ b/vendor/composer/autoload_classmap.php @@ -6,25 +6,6 @@ $vendorDir = dirname(dirname(__FILE__)); $baseDir = dirname($vendorDir); return array( - 'PHPQRCode' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode.php', - 'PHPQRCode\\Autoloader' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/Autoloader.php', - 'PHPQRCode\\Constants' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/Constants.php', - 'PHPQRCode\\FrameFiller' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/FrameFiller.php', - 'PHPQRCode\\QRbitstream' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRbitstream.php', - 'PHPQRCode\\QRcode' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRcode.php', - 'PHPQRCode\\QRencode' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRencode.php', - 'PHPQRCode\\QRimage' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRimage.php', - 'PHPQRCode\\QRinput' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRinput.php', - 'PHPQRCode\\QRinputItem' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRinputItem.php', - 'PHPQRCode\\QRmask' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRmask.php', - 'PHPQRCode\\QRrawcode' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrawcode.php', - 'PHPQRCode\\QRrs' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrs.php', - 'PHPQRCode\\QRrsItem' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrsItem.php', - 'PHPQRCode\\QRrsblock' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrsblock.php', - 'PHPQRCode\\QRspec' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRspec.php', - 'PHPQRCode\\QRsplit' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRsplit.php', - 'PHPQRCode\\QRstr' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRstr.php', - 'PHPQRCode\\QRtools' => $vendorDir . '/aferrandini/phpqrcode/lib/PHPQRCode/QRtools.php', 'PclZip' => $vendorDir . '/pclzip/pclzip/pclzip.lib.php', 'Qiniu\\Auth' => $vendorDir . '/qiniu/php-sdk/src/Qiniu/Auth.php', 'Qiniu\\Config' => $vendorDir . '/qiniu/php-sdk/src/Qiniu/Config.php', @@ -58,30 +39,6 @@ return array( 'Wechat\\WechatScript' => $vendorDir . '/zoujingli/wechat-php-sdk/Wechat/WechatScript.php', 'Wechat\\WechatService' => $vendorDir . '/zoujingli/wechat-php-sdk/Wechat/WechatService.php', 'Wechat\\WechatUser' => $vendorDir . '/zoujingli/wechat-php-sdk/Wechat/WechatUser.php', - 'Workerman\\Autoloader' => $vendorDir . '/workerman/workerman/Autoloader.php', - 'Workerman\\Connection\\AsyncTcpConnection' => $vendorDir . '/workerman/workerman/Connection/AsyncTcpConnection.php', - 'Workerman\\Connection\\ConnectionInterface' => $vendorDir . '/workerman/workerman/Connection/ConnectionInterface.php', - 'Workerman\\Connection\\TcpConnection' => $vendorDir . '/workerman/workerman/Connection/TcpConnection.php', - 'Workerman\\Connection\\UdpConnection' => $vendorDir . '/workerman/workerman/Connection/UdpConnection.php', - 'Workerman\\Events\\Ev' => $vendorDir . '/workerman/workerman/Events/Ev.php', - 'Workerman\\Events\\Event' => $vendorDir . '/workerman/workerman/Events/Event.php', - 'Workerman\\Events\\EventInterface' => $vendorDir . '/workerman/workerman/Events/EventInterface.php', - 'Workerman\\Events\\Libevent' => $vendorDir . '/workerman/workerman/Events/Libevent.php', - 'Workerman\\Events\\React' => $vendorDir . '/workerman/workerman/Events/React.php', - 'Workerman\\Events\\React\\ExtEventLoop' => $vendorDir . '/workerman/workerman/Events/React/ExtEventLoop.php', - 'Workerman\\Events\\React\\LibEventLoop' => $vendorDir . '/workerman/workerman/Events/React/LibEventLoop.php', - 'Workerman\\Events\\React\\StreamSelectLoop' => $vendorDir . '/workerman/workerman/Events/React/StreamSelectLoop.php', - 'Workerman\\Events\\Select' => $vendorDir . '/workerman/workerman/Events/Select.php', - 'Workerman\\Lib\\Timer' => $vendorDir . '/workerman/workerman/Lib/Timer.php', - 'Workerman\\Protocols\\Frame' => $vendorDir . '/workerman/workerman/Protocols/Frame.php', - 'Workerman\\Protocols\\Http' => $vendorDir . '/workerman/workerman/Protocols/Http.php', - 'Workerman\\Protocols\\HttpCache' => $vendorDir . '/workerman/workerman/Protocols/Http.php', - 'Workerman\\Protocols\\ProtocolInterface' => $vendorDir . '/workerman/workerman/Protocols/ProtocolInterface.php', - 'Workerman\\Protocols\\Text' => $vendorDir . '/workerman/workerman/Protocols/Text.php', - 'Workerman\\Protocols\\Websocket' => $vendorDir . '/workerman/workerman/Protocols/Websocket.php', - 'Workerman\\Protocols\\Ws' => $vendorDir . '/workerman/workerman/Protocols/Ws.php', - 'Workerman\\WebServer' => $vendorDir . '/workerman/workerman/WebServer.php', - 'Workerman\\Worker' => $vendorDir . '/workerman/workerman/Worker.php', 'think\\App' => $baseDir . '/thinkphp/library/think/App.php', 'think\\Build' => $baseDir . '/thinkphp/library/think/Build.php', 'think\\Cache' => $baseDir . '/thinkphp/library/think/Cache.php', @@ -252,5 +209,4 @@ return array( 'think\\template\\taglib\\Cx' => $baseDir . '/thinkphp/library/think/template/taglib/Cx.php', 'think\\view\\driver\\Php' => $baseDir . '/thinkphp/library/think/view/driver/Php.php', 'think\\view\\driver\\Think' => $baseDir . '/thinkphp/library/think/view/driver/Think.php', - 'think\\worker\\Server' => $vendorDir . '/topthink/think-worker/src/Server.php', ); diff --git a/vendor/composer/autoload_namespaces.php b/vendor/composer/autoload_namespaces.php index ba7e24cd7..b7fc0125d 100644 --- a/vendor/composer/autoload_namespaces.php +++ b/vendor/composer/autoload_namespaces.php @@ -6,5 +6,4 @@ $vendorDir = dirname(dirname(__FILE__)); $baseDir = dirname($vendorDir); return array( - 'PHPQRCode' => array($vendorDir . '/aferrandini/phpqrcode/lib'), ); diff --git a/vendor/composer/autoload_psr4.php b/vendor/composer/autoload_psr4.php index 1dc897235..8c0a54385 100644 --- a/vendor/composer/autoload_psr4.php +++ b/vendor/composer/autoload_psr4.php @@ -6,13 +6,11 @@ $vendorDir = dirname(dirname(__FILE__)); $baseDir = dirname($vendorDir); return array( - 'think\\worker\\' => array($vendorDir . '/topthink/think-worker/src'), 'think\\mongo\\' => array($vendorDir . '/topthink/think-mongo/src'), 'think\\helper\\' => array($vendorDir . '/topthink/think-helper/src'), 'think\\composer\\' => array($vendorDir . '/topthink/think-installer/src'), 'think\\captcha\\' => array($vendorDir . '/topthink/think-captcha/src'), 'think\\' => array($baseDir . '/thinkphp/library/think', $vendorDir . '/topthink/think-queue/src'), - 'Workerman\\' => array($vendorDir . '/workerman/workerman'), 'Wechat\\' => array($vendorDir . '/zoujingli/wechat-php-sdk/Wechat'), 'Qiniu\\' => array($vendorDir . '/qiniu/php-sdk/src/Qiniu'), ); diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php index 0f506dd2e..8d0d33814 100644 --- a/vendor/composer/autoload_real.php +++ b/vendor/composer/autoload_real.php @@ -2,7 +2,7 @@ // autoload_real.php @generated by Composer -class ComposerAutoloaderInit5a34d2cf88418439a1e7fb45047b8e5a +class ComposerAutoloaderInitbe5fdc6ce25a854de4cbf5279dee37ce { private static $loader; @@ -19,15 +19,15 @@ class ComposerAutoloaderInit5a34d2cf88418439a1e7fb45047b8e5a return self::$loader; } - spl_autoload_register(array('ComposerAutoloaderInit5a34d2cf88418439a1e7fb45047b8e5a', 'loadClassLoader'), true, true); + spl_autoload_register(array('ComposerAutoloaderInitbe5fdc6ce25a854de4cbf5279dee37ce', 'loadClassLoader'), true, true); self::$loader = $loader = new \Composer\Autoload\ClassLoader(); - spl_autoload_unregister(array('ComposerAutoloaderInit5a34d2cf88418439a1e7fb45047b8e5a', 'loadClassLoader')); + spl_autoload_unregister(array('ComposerAutoloaderInitbe5fdc6ce25a854de4cbf5279dee37ce', 'loadClassLoader')); $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION'); if ($useStaticLoader) { require_once __DIR__ . '/autoload_static.php'; - call_user_func(\Composer\Autoload\ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a::getInitializer($loader)); + call_user_func(\Composer\Autoload\ComposerStaticInitbe5fdc6ce25a854de4cbf5279dee37ce::getInitializer($loader)); } else { $map = require __DIR__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { @@ -48,19 +48,19 @@ class ComposerAutoloaderInit5a34d2cf88418439a1e7fb45047b8e5a $loader->register(true); if ($useStaticLoader) { - $includeFiles = Composer\Autoload\ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a::$files; + $includeFiles = Composer\Autoload\ComposerStaticInitbe5fdc6ce25a854de4cbf5279dee37ce::$files; } else { $includeFiles = require __DIR__ . '/autoload_files.php'; } foreach ($includeFiles as $fileIdentifier => $file) { - composerRequire5a34d2cf88418439a1e7fb45047b8e5a($fileIdentifier, $file); + composerRequirebe5fdc6ce25a854de4cbf5279dee37ce($fileIdentifier, $file); } return $loader; } } -function composerRequire5a34d2cf88418439a1e7fb45047b8e5a($fileIdentifier, $file) +function composerRequirebe5fdc6ce25a854de4cbf5279dee37ce($fileIdentifier, $file) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { require $file; diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php index 7694e4ffa..bd8785175 100644 --- a/vendor/composer/autoload_static.php +++ b/vendor/composer/autoload_static.php @@ -4,7 +4,7 @@ namespace Composer\Autoload; -class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a +class ComposerStaticInitbe5fdc6ce25a854de4cbf5279dee37ce { public static $files = array ( '9b552a3cc426e3287cc811caefa3cf53' => __DIR__ . '/..' . '/topthink/think-helper/src/helper.php', @@ -16,7 +16,6 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a public static $prefixLengthsPsr4 = array ( 't' => array ( - 'think\\worker\\' => 13, 'think\\mongo\\' => 12, 'think\\helper\\' => 13, 'think\\composer\\' => 15, @@ -25,7 +24,6 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a ), 'W' => array ( - 'Workerman\\' => 10, 'Wechat\\' => 7, ), 'Q' => @@ -35,10 +33,6 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a ); public static $prefixDirsPsr4 = array ( - 'think\\worker\\' => - array ( - 0 => __DIR__ . '/..' . '/topthink/think-worker/src', - ), 'think\\mongo\\' => array ( 0 => __DIR__ . '/..' . '/topthink/think-mongo/src', @@ -60,10 +54,6 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a 0 => __DIR__ . '/../..' . '/thinkphp/library/think', 1 => __DIR__ . '/..' . '/topthink/think-queue/src', ), - 'Workerman\\' => - array ( - 0 => __DIR__ . '/..' . '/workerman/workerman', - ), 'Wechat\\' => array ( 0 => __DIR__ . '/..' . '/zoujingli/wechat-php-sdk/Wechat', @@ -74,36 +64,7 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a ), ); - public static $prefixesPsr0 = array ( - 'P' => - array ( - 'PHPQRCode' => - array ( - 0 => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib', - ), - ), - ); - public static $classMap = array ( - 'PHPQRCode' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode.php', - 'PHPQRCode\\Autoloader' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/Autoloader.php', - 'PHPQRCode\\Constants' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/Constants.php', - 'PHPQRCode\\FrameFiller' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/FrameFiller.php', - 'PHPQRCode\\QRbitstream' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRbitstream.php', - 'PHPQRCode\\QRcode' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRcode.php', - 'PHPQRCode\\QRencode' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRencode.php', - 'PHPQRCode\\QRimage' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRimage.php', - 'PHPQRCode\\QRinput' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRinput.php', - 'PHPQRCode\\QRinputItem' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRinputItem.php', - 'PHPQRCode\\QRmask' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRmask.php', - 'PHPQRCode\\QRrawcode' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrawcode.php', - 'PHPQRCode\\QRrs' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrs.php', - 'PHPQRCode\\QRrsItem' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrsItem.php', - 'PHPQRCode\\QRrsblock' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRrsblock.php', - 'PHPQRCode\\QRspec' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRspec.php', - 'PHPQRCode\\QRsplit' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRsplit.php', - 'PHPQRCode\\QRstr' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRstr.php', - 'PHPQRCode\\QRtools' => __DIR__ . '/..' . '/aferrandini/phpqrcode/lib/PHPQRCode/QRtools.php', 'PclZip' => __DIR__ . '/..' . '/pclzip/pclzip/pclzip.lib.php', 'Qiniu\\Auth' => __DIR__ . '/..' . '/qiniu/php-sdk/src/Qiniu/Auth.php', 'Qiniu\\Config' => __DIR__ . '/..' . '/qiniu/php-sdk/src/Qiniu/Config.php', @@ -137,30 +98,6 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a 'Wechat\\WechatScript' => __DIR__ . '/..' . '/zoujingli/wechat-php-sdk/Wechat/WechatScript.php', 'Wechat\\WechatService' => __DIR__ . '/..' . '/zoujingli/wechat-php-sdk/Wechat/WechatService.php', 'Wechat\\WechatUser' => __DIR__ . '/..' . '/zoujingli/wechat-php-sdk/Wechat/WechatUser.php', - 'Workerman\\Autoloader' => __DIR__ . '/..' . '/workerman/workerman/Autoloader.php', - 'Workerman\\Connection\\AsyncTcpConnection' => __DIR__ . '/..' . '/workerman/workerman/Connection/AsyncTcpConnection.php', - 'Workerman\\Connection\\ConnectionInterface' => __DIR__ . '/..' . '/workerman/workerman/Connection/ConnectionInterface.php', - 'Workerman\\Connection\\TcpConnection' => __DIR__ . '/..' . '/workerman/workerman/Connection/TcpConnection.php', - 'Workerman\\Connection\\UdpConnection' => __DIR__ . '/..' . '/workerman/workerman/Connection/UdpConnection.php', - 'Workerman\\Events\\Ev' => __DIR__ . '/..' . '/workerman/workerman/Events/Ev.php', - 'Workerman\\Events\\Event' => __DIR__ . '/..' . '/workerman/workerman/Events/Event.php', - 'Workerman\\Events\\EventInterface' => __DIR__ . '/..' . '/workerman/workerman/Events/EventInterface.php', - 'Workerman\\Events\\Libevent' => __DIR__ . '/..' . '/workerman/workerman/Events/Libevent.php', - 'Workerman\\Events\\React' => __DIR__ . '/..' . '/workerman/workerman/Events/React.php', - 'Workerman\\Events\\React\\ExtEventLoop' => __DIR__ . '/..' . '/workerman/workerman/Events/React/ExtEventLoop.php', - 'Workerman\\Events\\React\\LibEventLoop' => __DIR__ . '/..' . '/workerman/workerman/Events/React/LibEventLoop.php', - 'Workerman\\Events\\React\\StreamSelectLoop' => __DIR__ . '/..' . '/workerman/workerman/Events/React/StreamSelectLoop.php', - 'Workerman\\Events\\Select' => __DIR__ . '/..' . '/workerman/workerman/Events/Select.php', - 'Workerman\\Lib\\Timer' => __DIR__ . '/..' . '/workerman/workerman/Lib/Timer.php', - 'Workerman\\Protocols\\Frame' => __DIR__ . '/..' . '/workerman/workerman/Protocols/Frame.php', - 'Workerman\\Protocols\\Http' => __DIR__ . '/..' . '/workerman/workerman/Protocols/Http.php', - 'Workerman\\Protocols\\HttpCache' => __DIR__ . '/..' . '/workerman/workerman/Protocols/Http.php', - 'Workerman\\Protocols\\ProtocolInterface' => __DIR__ . '/..' . '/workerman/workerman/Protocols/ProtocolInterface.php', - 'Workerman\\Protocols\\Text' => __DIR__ . '/..' . '/workerman/workerman/Protocols/Text.php', - 'Workerman\\Protocols\\Websocket' => __DIR__ . '/..' . '/workerman/workerman/Protocols/Websocket.php', - 'Workerman\\Protocols\\Ws' => __DIR__ . '/..' . '/workerman/workerman/Protocols/Ws.php', - 'Workerman\\WebServer' => __DIR__ . '/..' . '/workerman/workerman/WebServer.php', - 'Workerman\\Worker' => __DIR__ . '/..' . '/workerman/workerman/Worker.php', 'think\\App' => __DIR__ . '/../..' . '/thinkphp/library/think/App.php', 'think\\Build' => __DIR__ . '/../..' . '/thinkphp/library/think/Build.php', 'think\\Cache' => __DIR__ . '/../..' . '/thinkphp/library/think/Cache.php', @@ -331,16 +268,14 @@ class ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a 'think\\template\\taglib\\Cx' => __DIR__ . '/../..' . '/thinkphp/library/think/template/taglib/Cx.php', 'think\\view\\driver\\Php' => __DIR__ . '/../..' . '/thinkphp/library/think/view/driver/Php.php', 'think\\view\\driver\\Think' => __DIR__ . '/../..' . '/thinkphp/library/think/view/driver/Think.php', - 'think\\worker\\Server' => __DIR__ . '/..' . '/topthink/think-worker/src/Server.php', ); public static function getInitializer(ClassLoader $loader) { return \Closure::bind(function () use ($loader) { - $loader->prefixLengthsPsr4 = ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a::$prefixLengthsPsr4; - $loader->prefixDirsPsr4 = ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a::$prefixDirsPsr4; - $loader->prefixesPsr0 = ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a::$prefixesPsr0; - $loader->classMap = ComposerStaticInit5a34d2cf88418439a1e7fb45047b8e5a::$classMap; + $loader->prefixLengthsPsr4 = ComposerStaticInitbe5fdc6ce25a854de4cbf5279dee37ce::$prefixLengthsPsr4; + $loader->prefixDirsPsr4 = ComposerStaticInitbe5fdc6ce25a854de4cbf5279dee37ce::$prefixDirsPsr4; + $loader->classMap = ComposerStaticInitbe5fdc6ce25a854de4cbf5279dee37ce::$classMap; }, null, ClassLoader::class); } diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json index f34be4848..0d0403aff 100644 --- a/vendor/composer/installed.json +++ b/vendor/composer/installed.json @@ -170,52 +170,6 @@ "storage" ] }, - { - "name": "aferrandini/phpqrcode", - "version": "1.0.1", - "version_normalized": "1.0.1.0", - "source": { - "type": "git", - "url": "https://github.com/aferrandini/PHPQRCode.git", - "reference": "3c1c0454d43710ab5bbe19a51ad4cb41c22e3d46" - }, - "dist": { - "type": "zip", - "url": "https://packagist.phpcomposer.com/files/aferrandini/PHPQRCode/3c1c0454d43710ab5bbe19a51ad4cb41c22e3d46.zip", - "reference": "3c1c0454d43710ab5bbe19a51ad4cb41c22e3d46", - "shasum": "" - }, - "require": { - "php": ">=5.3.0" - }, - "time": "2013-07-08 09:39:08", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-0": { - "PHPQRCode": "lib/" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Ariel Ferrandini", - "email": "arielferrandini@gmail.com", - "homepage": "http://www.ferrandini.com/", - "role": "Developer" - } - ], - "description": "PHPQRCode porting and changed for PHP 5.3 compatibility", - "homepage": "https://github.com/aferrandini/PHPQRCode", - "keywords": [ - "barcode", - "php", - "qrcode" - ] - }, { "name": "topthink/framework", "version": "v5.0.6", @@ -343,93 +297,6 @@ ], "description": "mongodb driver for thinkphp5" }, - { - "name": "workerman/workerman", - "version": "v3.3.8", - "version_normalized": "3.3.8.0", - "source": { - "type": "git", - "url": "https://github.com/walkor/Workerman.git", - "reference": "bbcfd9169cf6acd9d9866e17ed2f2189ee6d7f91" - }, - "dist": { - "type": "zip", - "url": "https://packagist.phpcomposer.com/files/walkor/Workerman/bbcfd9169cf6acd9d9866e17ed2f2189ee6d7f91.zip", - "reference": "bbcfd9169cf6acd9d9866e17ed2f2189ee6d7f91", - "shasum": "" - }, - "require": { - "php": ">=5.3" - }, - "suggest": { - "ext-event": "For better performance." - }, - "time": "2017-02-09 08:07:55", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "Workerman\\": "./" - } - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "walkor", - "email": "walkor@workerman.net", - "homepage": "http://www.workerman.net", - "role": "Developer" - } - ], - "description": "An asynchronous event driven PHP framework for easily building fast, scalable network applications.", - "homepage": "http://www.workerman.net", - "keywords": [ - "asynchronous", - "event-loop" - ] - }, - { - "name": "topthink/think-worker", - "version": "v1.0.1", - "version_normalized": "1.0.1.0", - "source": { - "type": "git", - "url": "https://github.com/top-think/think-worker.git", - "reference": "b609ff5e38dbb7194aab027d2b2c6b31a7ed1bd1" - }, - "dist": { - "type": "zip", - "url": "https://packagist.phpcomposer.com/files/top-think/think-worker/b609ff5e38dbb7194aab027d2b2c6b31a7ed1bd1.zip", - "reference": "b609ff5e38dbb7194aab027d2b2c6b31a7ed1bd1", - "shasum": "" - }, - "require": { - "workerman/workerman": "^3.3.0" - }, - "time": "2016-10-08 06:07:03", - "type": "library", - "installation-source": "dist", - "autoload": { - "psr-4": { - "think\\worker\\": "src" - }, - "files": [] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "Apache-2.0" - ], - "authors": [ - { - "name": "liu21st", - "email": "liu21st@gmail.com" - } - ], - "description": "workerman extend for thinkphp5" - }, { "name": "topthink/think-helper", "version": "v1.0.5", diff --git a/vendor/topthink/think-worker/LICENSE b/vendor/topthink/think-worker/LICENSE deleted file mode 100644 index 8dada3eda..000000000 --- a/vendor/topthink/think-worker/LICENSE +++ /dev/null @@ -1,201 +0,0 @@ - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "{}" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright {yyyy} {name of copyright owner} - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. diff --git a/vendor/topthink/think-worker/README.md b/vendor/topthink/think-worker/README.md deleted file mode 100644 index 4ac581604..000000000 --- a/vendor/topthink/think-worker/README.md +++ /dev/null @@ -1,53 +0,0 @@ -ThinkPHP 5.0 Workerman 扩展 -=============== - -## 安装 -composer require topthink/think-worker - -## 使用方法 -首先创建控制器类并继承 think\worker\Server,然后设置属性和添加回调方法 - -~~~ -namespace app\index\controller; - -use think\worker\Server; - -class Worker extends Server -{ - protected $socket = 'http://0.0.0.0:2346'; - - public function onMessage($connection,$data) - { - $connection->send(json_encode($data)); - } -} -~~~ -支持workerman所有的回调方法定义(回调方法必须是public类型) - - -在应用根目录增加入口文件 server.php - -~~~ -#!/usr/bin/env php - -// +---------------------------------------------------------------------- - -namespace think\worker; - -use Workerman\Worker; - -/** - * Worker控制器扩展类 - */ -abstract class Server -{ - protected $worker; - protected $socket = ''; - protected $protocol = 'http'; - protected $host = '0.0.0.0'; - protected $port = '2346'; - protected $processes = 4; - - /** - * 架构函数 - * @access public - */ - public function __construct() - { - // 实例化 Websocket 服务 - $this->worker = new Worker($this->socket ?: $this->protocol . '://' . $this->host . ':' . $this->port); - // 设置进程数 - $this->worker->count = $this->processes; - // 初始化 - $this->init(); - - // 设置回调 - foreach (['onWorkerStart', 'onConnect', 'onMessage', 'onClose', 'onError', 'onBufferFull', 'onBufferDrain', 'onWorkerStop', 'onWorkerReload'] as $event) { - if (method_exists($this, $event)) { - $this->worker->$event = [$this, $event]; - } - } - // Run worker - Worker::runAll(); - } - - protected function init() - { - } - -} diff --git a/vendor/workerman/workerman/.gitignore b/vendor/workerman/workerman/.gitignore deleted file mode 100644 index 9b668caef..000000000 --- a/vendor/workerman/workerman/.gitignore +++ /dev/null @@ -1,5 +0,0 @@ -logs -.buildpath -.project -.settings -.idea \ No newline at end of file diff --git a/vendor/workerman/workerman/Autoloader.php b/vendor/workerman/workerman/Autoloader.php deleted file mode 100644 index 45773c914..000000000 --- a/vendor/workerman/workerman/Autoloader.php +++ /dev/null @@ -1,69 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman; - -/** - * Autoload. - */ -class Autoloader -{ - /** - * Autoload root path. - * - * @var string - */ - protected static $_autoloadRootPath = ''; - - /** - * Set autoload root path. - * - * @param string $root_path - * @return void - */ - public static function setRootPath($root_path) - { - self::$_autoloadRootPath = $root_path; - } - - /** - * Load files by namespace. - * - * @param string $name - * @return boolean - */ - public static function loadByNamespace($name) - { - $class_path = str_replace('\\', DIRECTORY_SEPARATOR, $name); - if (strpos($name, 'Workerman\\') === 0) { - $class_file = __DIR__ . substr($class_path, strlen('Workerman')) . '.php'; - } else { - if (self::$_autoloadRootPath) { - $class_file = self::$_autoloadRootPath . DIRECTORY_SEPARATOR . $class_path . '.php'; - } - if (empty($class_file) || !is_file($class_file)) { - $class_file = __DIR__ . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . "$class_path.php"; - } - } - - if (is_file($class_file)) { - require_once($class_file); - if (class_exists($name, false)) { - return true; - } - } - return false; - } -} - -spl_autoload_register('\Workerman\Autoloader::loadByNamespace'); \ No newline at end of file diff --git a/vendor/workerman/workerman/Connection/AsyncTcpConnection.php b/vendor/workerman/workerman/Connection/AsyncTcpConnection.php deleted file mode 100644 index 116aa6924..000000000 --- a/vendor/workerman/workerman/Connection/AsyncTcpConnection.php +++ /dev/null @@ -1,316 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Connection; - -use Workerman\Events\EventInterface; -use Workerman\Lib\Timer; -use Workerman\Worker; -use Exception; - -/** - * AsyncTcpConnection. - */ -class AsyncTcpConnection extends TcpConnection -{ - /** - * Emitted when socket connection is successfully established. - * - * @var callback - */ - public $onConnect = null; - - /** - * Transport layer protocol. - * - * @var string - */ - public $transport = 'tcp'; - - /** - * Status. - * - * @var int - */ - protected $_status = self::STATUS_INITIAL; - - /** - * Remote host. - * - * @var string - */ - protected $_remoteHost = ''; - - /** - * Connect start time. - * - * @var string - */ - protected $_connectStartTime = 0; - - /** - * Remote URI. - * - * @var string - */ - protected $_remoteURI = ''; - - /** - * Context option. - * - * @var resource - */ - protected $_contextOption = null; - - /** - * Reconnect timer. - * - * @var int - */ - protected $_reconnectTimer = null; - - - /** - * PHP built-in protocols. - * - * @var array - */ - protected static $_builtinTransports = array( - 'tcp' => 'tcp', - 'udp' => 'udp', - 'unix' => 'unix', - 'ssl' => 'ssl', - 'sslv2' => 'sslv2', - 'sslv3' => 'sslv3', - 'tls' => 'tls' - ); - - /** - * Construct. - * - * @param string $remote_address - * @param array $context_option - * @throws Exception - */ - public function __construct($remote_address, $context_option = null) - { - $address_info = parse_url($remote_address); - if (!$address_info) { - echo new \Exception('bad remote_address'); - $this->_remoteAddress = $remote_address; - } else { - if (!isset($address_info['port'])) { - $address_info['port'] = 80; - } - if (!isset($address_info['path'])) { - $address_info['path'] = '/'; - } - if (!isset($address_info['query'])) { - $address_info['query'] = ''; - } else { - $address_info['query'] = '?' . $address_info['query']; - } - $this->_remoteAddress = "{$address_info['host']}:{$address_info['port']}"; - $this->_remoteHost = $address_info['host']; - $this->_remoteURI = "{$address_info['path']}{$address_info['query']}"; - $scheme = isset($address_info['scheme']) ? $address_info['scheme'] : 'tcp'; - } - - $this->id = self::$_idRecorder++; - // Check application layer protocol class. - if (!isset(self::$_builtinTransports[$scheme])) { - $scheme = ucfirst($scheme); - $this->protocol = '\\Protocols\\' . $scheme; - if (!class_exists($this->protocol)) { - $this->protocol = "\\Workerman\\Protocols\\$scheme"; - if (!class_exists($this->protocol)) { - throw new Exception("class \\Protocols\\$scheme not exist"); - } - } - } else { - $this->transport = self::$_builtinTransports[$scheme]; - } - - // For statistics. - self::$statistics['connection_count']++; - $this->maxSendBufferSize = self::$defaultMaxSendBufferSize; - $this->_contextOption = $context_option; - } - - /** - * Do connect. - * - * @return void - */ - public function connect() - { - if ($this->_status !== self::STATUS_INITIAL && $this->_status !== self::STATUS_CLOSING && - $this->_status !== self::STATUS_CLOSED) { - return; - } - $this->_status = self::STATUS_CONNECTING; - $this->_connectStartTime = microtime(true); - // Open socket connection asynchronously. - if ($this->_contextOption) { - $context = stream_context_create($this->_contextOption); - $this->_socket = stream_socket_client("{$this->transport}://{$this->_remoteAddress}", $errno, $errstr, 0, - STREAM_CLIENT_ASYNC_CONNECT, $context); - } else { - $this->_socket = stream_socket_client("{$this->transport}://{$this->_remoteAddress}", $errno, $errstr, 0, - STREAM_CLIENT_ASYNC_CONNECT); - } - // If failed attempt to emit onError callback. - if (!$this->_socket) { - $this->emitError(WORKERMAN_CONNECT_FAIL, $errstr); - if ($this->_status === self::STATUS_CLOSING) { - $this->destroy(); - } - if ($this->_status === self::STATUS_CLOSED) { - $this->onConnect = null; - } - return; - } - // Add socket to global event loop waiting connection is successfully established or faild. - Worker::$globalEvent->add($this->_socket, EventInterface::EV_WRITE, array($this, 'checkConnection')); - } - - /** - * Reconnect. - * - * @param int $after - * @return void - */ - public function reConnect($after = 0) { - $this->_status = self::STATUS_INITIAL; - if ($this->_reconnectTimer) { - Timer::del($this->_reconnectTimer); - } - if ($after > 0) { - $this->_reconnectTimer = Timer::add($after, array($this, 'connect'), null, false); - return; - } - return $this->connect(); - } - - /** - * Get remote address. - * - * @return string - */ - public function getRemoteHost() - { - return $this->_remoteHost; - } - - /** - * Get remote URI. - * - * @return string - */ - public function getRemoteURI() - { - return $this->_remoteURI; - } - - /** - * Try to emit onError callback. - * - * @param int $code - * @param string $msg - * @return void - */ - protected function emitError($code, $msg) - { - $this->_status = self::STATUS_CLOSING; - if ($this->onError) { - try { - call_user_func($this->onError, $this, $code, $msg); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - } - - /** - * Check connection is successfully established or faild. - * - * @param resource $socket - * @return void - */ - public function checkConnection($socket) - { - // Check socket state. - if ($address = stream_socket_get_name($socket, true)) { - // Remove write listener. - Worker::$globalEvent->del($socket, EventInterface::EV_WRITE); - // Nonblocking. - stream_set_blocking($socket, 0); - // Compatible with hhvm - if (function_exists('stream_set_read_buffer')) { - stream_set_read_buffer($socket, 0); - } - // Try to open keepalive for tcp and disable Nagle algorithm. - if (function_exists('socket_import_stream') && $this->transport === 'tcp') { - $raw_socket = socket_import_stream($socket); - socket_set_option($raw_socket, SOL_SOCKET, SO_KEEPALIVE, 1); - socket_set_option($raw_socket, SOL_TCP, TCP_NODELAY, 1); - } - // Register a listener waiting read event. - Worker::$globalEvent->add($socket, EventInterface::EV_READ, array($this, 'baseRead')); - // There are some data waiting to send. - if ($this->_sendBuffer) { - Worker::$globalEvent->add($socket, EventInterface::EV_WRITE, array($this, 'baseWrite')); - } - $this->_status = self::STATUS_ESTABLISH; - $this->_remoteAddress = $address; - - // Try to emit onConnect callback. - if ($this->onConnect) { - try { - call_user_func($this->onConnect, $this); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - // Try to emit protocol::onConnect - if (method_exists($this->protocol, 'onConnect')) { - try { - call_user_func(array($this->protocol, 'onConnect'), $this); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - } else { - // Connection failed. - $this->emitError(WORKERMAN_CONNECT_FAIL, 'connect ' . $this->_remoteAddress . ' fail after ' . round(microtime(true) - $this->_connectStartTime, 4) . ' seconds'); - if ($this->_status === self::STATUS_CLOSING) { - $this->destroy(); - } - if ($this->_status === self::STATUS_CLOSED) { - $this->onConnect = null; - } - } - } -} diff --git a/vendor/workerman/workerman/Connection/ConnectionInterface.php b/vendor/workerman/workerman/Connection/ConnectionInterface.php deleted file mode 100644 index b39e5ae9b..000000000 --- a/vendor/workerman/workerman/Connection/ConnectionInterface.php +++ /dev/null @@ -1,83 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Connection; - -/** - * ConnectionInterface. - */ -abstract class ConnectionInterface -{ - /** - * Statistics for status command. - * - * @var array - */ - public static $statistics = array( - 'connection_count' => 0, - 'total_request' => 0, - 'throw_exception' => 0, - 'send_fail' => 0, - ); - - /** - * Emitted when data is received. - * - * @var callback - */ - public $onMessage = null; - - /** - * Emitted when the other end of the socket sends a FIN packet. - * - * @var callback - */ - public $onClose = null; - - /** - * Emitted when an error occurs with connection. - * - * @var callback - */ - public $onError = null; - - /** - * Sends data on the connection. - * - * @param string $send_buffer - * @return void|boolean - */ - abstract public function send($send_buffer); - - /** - * Get remote IP. - * - * @return string - */ - abstract public function getRemoteIp(); - - /** - * Get remote port. - * - * @return int - */ - abstract public function getRemotePort(); - - /** - * Close connection. - * - * @param $data - * @return void - */ - abstract public function close($data = null); -} diff --git a/vendor/workerman/workerman/Connection/TcpConnection.php b/vendor/workerman/workerman/Connection/TcpConnection.php deleted file mode 100644 index 0083e4690..000000000 --- a/vendor/workerman/workerman/Connection/TcpConnection.php +++ /dev/null @@ -1,719 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Connection; - -use Workerman\Events\EventInterface; -use Workerman\Worker; -use Exception; - -/** - * TcpConnection. - */ -class TcpConnection extends ConnectionInterface -{ - /** - * Read buffer size. - * - * @var int - */ - const READ_BUFFER_SIZE = 65535; - - /** - * Status initial. - * - * @var int - */ - const STATUS_INITIAL = 0; - - /** - * Status connecting. - * - * @var int - */ - const STATUS_CONNECTING = 1; - - /** - * Status connection established. - * - * @var int - */ - const STATUS_ESTABLISH = 2; - - /** - * Status closing. - * - * @var int - */ - const STATUS_CLOSING = 4; - - /** - * Status closed. - * - * @var int - */ - const STATUS_CLOSED = 8; - - /** - * Emitted when data is received. - * - * @var callback - */ - public $onMessage = null; - - /** - * Emitted when the other end of the socket sends a FIN packet. - * - * @var callback - */ - public $onClose = null; - - /** - * Emitted when an error occurs with connection. - * - * @var callback - */ - public $onError = null; - - /** - * Emitted when the send buffer becomes full. - * - * @var callback - */ - public $onBufferFull = null; - - /** - * Emitted when the send buffer becomes empty. - * - * @var callback - */ - public $onBufferDrain = null; - - /** - * Application layer protocol. - * The format is like this Workerman\\Protocols\\Http. - * - * @var \Workerman\Protocols\ProtocolInterface - */ - public $protocol = null; - - /** - * Transport (tcp/udp/unix/ssl). - * - * @var string - */ - public $transport = 'tcp'; - - /** - * Which worker belong to. - * - * @var Worker - */ - public $worker = null; - - /** - * Connection->id. - * - * @var int - */ - public $id = 0; - - /** - * A copy of $worker->id which used to clean up the connection in worker->connections - * - * @var int - */ - protected $_id = 0; - - /** - * Sets the maximum send buffer size for the current connection. - * OnBufferFull callback will be emited When the send buffer is full. - * - * @var int - */ - public $maxSendBufferSize = 1048576; - - /** - * Default send buffer size. - * - * @var int - */ - public static $defaultMaxSendBufferSize = 1048576; - - /** - * Maximum acceptable packet size. - * - * @var int - */ - public static $maxPackageSize = 10485760; - - /** - * Id recorder. - * - * @var int - */ - protected static $_idRecorder = 1; - - /** - * Socket - * - * @var resource - */ - protected $_socket = null; - - /** - * Send buffer. - * - * @var string - */ - protected $_sendBuffer = ''; - - /** - * Receive buffer. - * - * @var string - */ - protected $_recvBuffer = ''; - - /** - * Current package length. - * - * @var int - */ - protected $_currentPackageLength = 0; - - /** - * Connection status. - * - * @var int - */ - protected $_status = self::STATUS_ESTABLISH; - - /** - * Remote address. - * - * @var string - */ - protected $_remoteAddress = ''; - - /** - * Is paused. - * - * @var bool - */ - protected $_isPaused = false; - - /** - * SSL handshake completed or not - * - * @var bool - */ - protected $_sslHandshakeCompleted = false; - - /** - * Construct. - * - * @param resource $socket - * @param string $remote_address - */ - public function __construct($socket, $remote_address = '') - { - self::$statistics['connection_count']++; - $this->id = $this->_id = self::$_idRecorder++; - $this->_socket = $socket; - stream_set_blocking($this->_socket, 0); - // Compatible with hhvm - if (function_exists('stream_set_read_buffer')) { - stream_set_read_buffer($this->_socket, 0); - } - Worker::$globalEvent->add($this->_socket, EventInterface::EV_READ, array($this, 'baseRead')); - $this->maxSendBufferSize = self::$defaultMaxSendBufferSize; - $this->_remoteAddress = $remote_address; - } - - /** - * Sends data on the connection. - * - * @param string $send_buffer - * @param bool $raw - * @return void|bool|null - */ - public function send($send_buffer, $raw = false) - { - if ($this->_status === self::STATUS_CLOSING || $this->_status === self::STATUS_CLOSED) { - return false; - } - - // Try to call protocol::encode($send_buffer) before sending. - if (false === $raw && $this->protocol) { - $parser = $this->protocol; - $send_buffer = $parser::encode($send_buffer, $this); - if ($send_buffer === '') { - return null; - } - } - - if ($this->_status !== self::STATUS_ESTABLISH || - ($this->transport === 'ssl' && $this->_sslHandshakeCompleted !== true) - ) { - if ($this->_sendBuffer) { - if ($this->bufferIsFull()) { - self::$statistics['send_fail']++; - return false; - } - } - $this->_sendBuffer .= $send_buffer; - $this->checkBufferWillFull(); - return null; - } - - - // Attempt to send data directly. - if ($this->_sendBuffer === '') { - $len = @fwrite($this->_socket, $send_buffer); - // send successful. - if ($len === strlen($send_buffer)) { - return true; - } - // Send only part of the data. - if ($len > 0) { - $this->_sendBuffer = substr($send_buffer, $len); - } else { - // Connection closed? - if (!is_resource($this->_socket) || feof($this->_socket)) { - self::$statistics['send_fail']++; - if ($this->onError) { - try { - call_user_func($this->onError, $this, WORKERMAN_SEND_FAIL, 'client closed'); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - $this->destroy(); - return false; - } - $this->_sendBuffer = $send_buffer; - } - Worker::$globalEvent->add($this->_socket, EventInterface::EV_WRITE, array($this, 'baseWrite')); - // Check if the send buffer will be full. - $this->checkBufferWillFull(); - return null; - } else { - if ($this->bufferIsFull()) { - self::$statistics['send_fail']++; - return false; - } - - $this->_sendBuffer .= $send_buffer; - // Check if the send buffer is full. - $this->checkBufferWillFull(); - } - } - - /** - * Get remote IP. - * - * @return string - */ - public function getRemoteIp() - { - $pos = strrpos($this->_remoteAddress, ':'); - if ($pos) { - return trim(substr($this->_remoteAddress, 0, $pos), '[]'); - } - return ''; - } - - /** - * Get remote port. - * - * @return int - */ - public function getRemotePort() - { - if ($this->_remoteAddress) { - return (int)substr(strrchr($this->_remoteAddress, ':'), 1); - } - return 0; - } - - /** - * Pauses the reading of data. That is onMessage will not be emitted. Useful to throttle back an upload. - * - * @return void - */ - public function pauseRecv() - { - Worker::$globalEvent->del($this->_socket, EventInterface::EV_READ); - $this->_isPaused = true; - } - - /** - * Resumes reading after a call to pauseRecv. - * - * @return void - */ - public function resumeRecv() - { - if ($this->_isPaused === true) { - Worker::$globalEvent->add($this->_socket, EventInterface::EV_READ, array($this, 'baseRead')); - $this->_isPaused = false; - $this->baseRead($this->_socket, false); - } - } - - /** - * Base read handler. - * - * @param resource $socket - * @param bool $check_eof - * @return void - */ - public function baseRead($socket, $check_eof = true) - { - // SSL handshake. - if ($this->transport === 'ssl' && $this->_sslHandshakeCompleted !== true) { - stream_set_blocking($socket, true); - stream_set_timeout($socket, 1); - $ret = stream_socket_enable_crypto($socket, true, STREAM_CRYPTO_METHOD_SSLv23_SERVER); - if(!$ret) { - echo new \Exception('ssl handshake fail, stream_socket_enable_crypto return ' . var_export($ret, true)); - return $this->destroy(); - } - if (isset($this->onSslHandshake)) { - try { - call_user_func($this->onSslHandshake, $this); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - $this->_sslHandshakeCompleted = true; - if ($this->_sendBuffer) { - Worker::$globalEvent->add($socket, EventInterface::EV_WRITE, array($this, 'baseWrite')); - } - return; - } - - $buffer = fread($socket, self::READ_BUFFER_SIZE); - - // Check connection closed. - if ($buffer === '' || $buffer === false) { - if ($check_eof && (feof($socket) || !is_resource($socket) || $buffer === false)) { - $this->destroy(); - return; - } - } else { - $this->_recvBuffer .= $buffer; - } - - // If the application layer protocol has been set up. - if ($this->protocol) { - $parser = $this->protocol; - while ($this->_recvBuffer !== '' && !$this->_isPaused) { - // The current packet length is known. - if ($this->_currentPackageLength) { - // Data is not enough for a package. - if ($this->_currentPackageLength > strlen($this->_recvBuffer)) { - break; - } - } else { - // Get current package length. - $this->_currentPackageLength = $parser::input($this->_recvBuffer, $this); - // The packet length is unknown. - if ($this->_currentPackageLength === 0) { - break; - } elseif ($this->_currentPackageLength > 0 && $this->_currentPackageLength <= self::$maxPackageSize) { - // Data is not enough for a package. - if ($this->_currentPackageLength > strlen($this->_recvBuffer)) { - break; - } - } // Wrong package. - else { - echo 'error package. package_length=' . var_export($this->_currentPackageLength, true); - $this->destroy(); - return; - } - } - - // The data is enough for a packet. - self::$statistics['total_request']++; - // The current packet length is equal to the length of the buffer. - if (strlen($this->_recvBuffer) === $this->_currentPackageLength) { - $one_request_buffer = $this->_recvBuffer; - $this->_recvBuffer = ''; - } else { - // Get a full package from the buffer. - $one_request_buffer = substr($this->_recvBuffer, 0, $this->_currentPackageLength); - // Remove the current package from the receive buffer. - $this->_recvBuffer = substr($this->_recvBuffer, $this->_currentPackageLength); - } - // Reset the current packet length to 0. - $this->_currentPackageLength = 0; - if (!$this->onMessage) { - continue; - } - try { - // Decode request buffer before Emitting onMessage callback. - call_user_func($this->onMessage, $this, $parser::decode($one_request_buffer, $this)); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - return; - } - - if ($this->_recvBuffer === '' || $this->_isPaused) { - return; - } - - // Applications protocol is not set. - self::$statistics['total_request']++; - if (!$this->onMessage) { - $this->_recvBuffer = ''; - return; - } - try { - call_user_func($this->onMessage, $this, $this->_recvBuffer); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - // Clean receive buffer. - $this->_recvBuffer = ''; - } - - /** - * Base write handler. - * - * @return void|bool - */ - public function baseWrite() - { - $len = @fwrite($this->_socket, $this->_sendBuffer); - if ($len === strlen($this->_sendBuffer)) { - Worker::$globalEvent->del($this->_socket, EventInterface::EV_WRITE); - $this->_sendBuffer = ''; - // Try to emit onBufferDrain callback when the send buffer becomes empty. - if ($this->onBufferDrain) { - try { - call_user_func($this->onBufferDrain, $this); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - if ($this->_status === self::STATUS_CLOSING) { - $this->destroy(); - } - return true; - } - if ($len > 0) { - $this->_sendBuffer = substr($this->_sendBuffer, $len); - } else { - self::$statistics['send_fail']++; - $this->destroy(); - } - } - - /** - * This method pulls all the data out of a readable stream, and writes it to the supplied destination. - * - * @param TcpConnection $dest - * @return void - */ - public function pipe($dest) - { - $source = $this; - $this->onMessage = function ($source, $data) use ($dest) { - $dest->send($data); - }; - $this->onClose = function ($source) use ($dest) { - $dest->destroy(); - }; - $dest->onBufferFull = function ($dest) use ($source) { - $source->pauseRecv(); - }; - $dest->onBufferDrain = function ($dest) use ($source) { - $source->resumeRecv(); - }; - } - - /** - * Remove $length of data from receive buffer. - * - * @param int $length - * @return void - */ - public function consumeRecvBuffer($length) - { - $this->_recvBuffer = substr($this->_recvBuffer, $length); - } - - /** - * Close connection. - * - * @param mixed $data - * @param bool $raw - * @return void - */ - public function close($data = null, $raw = false) - { - if ($this->_status === self::STATUS_CLOSING || $this->_status === self::STATUS_CLOSED) { - return; - } else { - if ($data !== null) { - $this->send($data, $raw); - } - $this->_status = self::STATUS_CLOSING; - } - if ($this->_sendBuffer === '') { - $this->destroy(); - } - } - - /** - * Get the real socket. - * - * @return resource - */ - public function getSocket() - { - return $this->_socket; - } - - /** - * Check whether the send buffer will be full. - * - * @return void - */ - protected function checkBufferWillFull() - { - if ($this->maxSendBufferSize <= strlen($this->_sendBuffer)) { - if ($this->onBufferFull) { - try { - call_user_func($this->onBufferFull, $this); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - } - } - - /** - * Whether send buffer is full. - * - * @return bool - */ - protected function bufferIsFull() - { - // Buffer has been marked as full but still has data to send then the packet is discarded. - if ($this->maxSendBufferSize <= strlen($this->_sendBuffer)) { - if ($this->onError) { - try { - call_user_func($this->onError, $this, WORKERMAN_SEND_FAIL, 'send buffer full and drop package'); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - return true; - } - return false; - } - - /** - * Destroy connection. - * - * @return void - */ - public function destroy() - { - // Avoid repeated calls. - if ($this->_status === self::STATUS_CLOSED) { - return; - } - // Remove event listener. - Worker::$globalEvent->del($this->_socket, EventInterface::EV_READ); - Worker::$globalEvent->del($this->_socket, EventInterface::EV_WRITE); - // Close socket. - @fclose($this->_socket); - // Remove from worker->connections. - if ($this->worker) { - unset($this->worker->connections[$this->_id]); - } - $this->_status = self::STATUS_CLOSED; - // Try to emit onClose callback. - if ($this->onClose) { - try { - call_user_func($this->onClose, $this); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - // Try to emit protocol::onClose - if (method_exists($this->protocol, 'onClose')) { - try { - call_user_func(array($this->protocol, 'onClose'), $this); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - if ($this->_status === self::STATUS_CLOSED) { - // Cleaning up the callback to avoid memory leaks. - $this->onMessage = $this->onClose = $this->onError = $this->onBufferFull = $this->onBufferDrain = null; - } - } - - /** - * Destruct. - * - * @return void - */ - public function __destruct() - { - self::$statistics['connection_count']--; - } -} diff --git a/vendor/workerman/workerman/Connection/UdpConnection.php b/vendor/workerman/workerman/Connection/UdpConnection.php deleted file mode 100644 index e4cd2fee4..000000000 --- a/vendor/workerman/workerman/Connection/UdpConnection.php +++ /dev/null @@ -1,115 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Connection; - -/** - * UdpConnection. - */ -class UdpConnection extends ConnectionInterface -{ - /** - * Application layer protocol. - * The format is like this Workerman\\Protocols\\Http. - * - * @var \Workerman\Protocols\ProtocolInterface - */ - public $protocol = null; - - /** - * Udp socket. - * - * @var resource - */ - protected $_socket = null; - - /** - * Remote address. - * - * @var string - */ - protected $_remoteAddress = ''; - - /** - * Construct. - * - * @param resource $socket - * @param string $remote_address - */ - public function __construct($socket, $remote_address) - { - $this->_socket = $socket; - $this->_remoteAddress = $remote_address; - } - - /** - * Sends data on the connection. - * - * @param string $send_buffer - * @param bool $raw - * @return void|boolean - */ - public function send($send_buffer, $raw = false) - { - if (false === $raw && $this->protocol) { - $parser = $this->protocol; - $send_buffer = $parser::encode($send_buffer, $this); - if ($send_buffer === '') { - return null; - } - } - return strlen($send_buffer) === stream_socket_sendto($this->_socket, $send_buffer, 0, $this->_remoteAddress); - } - - /** - * Get remote IP. - * - * @return string - */ - public function getRemoteIp() - { - $pos = strrpos($this->_remoteAddress, ':'); - if ($pos) { - return trim(substr($this->_remoteAddress, 0, $pos), '[]'); - } - return ''; - } - - /** - * Get remote port. - * - * @return int - */ - public function getRemotePort() - { - if ($this->_remoteAddress) { - return (int)substr(strrchr($this->_remoteAddress, ':'), 1); - } - return 0; - } - - /** - * Close connection. - * - * @param mixed $data - * @param bool $raw - * @return bool - */ - public function close($data = null, $raw = false) - { - if ($data !== null) { - $this->send($data, $raw); - } - return true; - } -} diff --git a/vendor/workerman/workerman/Events/Ev.php b/vendor/workerman/workerman/Events/Ev.php deleted file mode 100644 index acc1a3613..000000000 --- a/vendor/workerman/workerman/Events/Ev.php +++ /dev/null @@ -1,173 +0,0 @@ - - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events; - -use Workerman\Worker; - -/** - * ev eventloop - */ -class Ev implements EventInterface -{ - /** - * All listeners for read/write event. - * - * @var array - */ - protected $_allEvents = array(); - - /** - * Event listeners of signal. - * - * @var array - */ - protected $_eventSignal = array(); - - /** - * All timer event listeners. - * [func, args, event, flag, time_interval] - * - * @var array - */ - protected $_eventTimer = array(); - - /** - * Timer id. - * - * @var int - */ - protected static $_timerId = 1; - - /** - * Add a timer. - * {@inheritdoc} - */ - public function add($fd, $flag, $func, $args = null) - { - $callback = function ($event, $socket) use ($fd, $func) { - try { - call_user_func($func, $fd); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - }; - - switch ($flag) { - case self::EV_SIGNAL: - $event = new \EvSignal($fd, $callback); - $this->_eventSignal[$fd] = $event; - return true; - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - $repeat = $flag == self::EV_TIMER_ONCE ? 0 : $fd; - $param = array($func, (array)$args, $flag, $fd, self::$_timerId); - $event = new \EvTimer($fd, $repeat, array($this, 'timerCallback'), $param); - $this->_eventTimer[self::$_timerId] = $event; - return self::$_timerId++; - default : - $fd_key = (int)$fd; - $real_flag = $flag === self::EV_READ ? \Ev::READ : \Ev::WRITE; - $event = new \EvIo($fd, $real_flag, $callback); - $this->_allEvents[$fd_key][$flag] = $event; - return true; - } - - } - - /** - * Remove a timer. - * {@inheritdoc} - */ - public function del($fd, $flag) - { - switch ($flag) { - case self::EV_READ: - case self::EV_WRITE: - $fd_key = (int)$fd; - if (isset($this->_allEvents[$fd_key][$flag])) { - $this->_allEvents[$fd_key][$flag]->stop(); - unset($this->_allEvents[$fd_key][$flag]); - } - if (empty($this->_allEvents[$fd_key])) { - unset($this->_allEvents[$fd_key]); - } - break; - case self::EV_SIGNAL: - $fd_key = (int)$fd; - if (isset($this->_eventSignal[$fd_key])) { - $this->_allEvents[$fd_key][$flag]->stop(); - unset($this->_eventSignal[$fd_key]); - } - break; - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - if (isset($this->_eventTimer[$fd])) { - $this->_eventTimer[$fd]->stop(); - unset($this->_eventTimer[$fd]); - } - break; - } - return true; - } - - /** - * Timer callback. - * - * @param \EvWatcher $event - */ - public function timerCallback($event) - { - $param = $event->data; - $timer_id = $param[4]; - if ($param[2] === self::EV_TIMER_ONCE) { - $this->_eventTimer[$timer_id]->stop(); - unset($this->_eventTimer[$timer_id]); - } - try { - call_user_func_array($param[0], $param[1]); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - - /** - * Remove all timers. - * - * @return void - */ - public function clearAllTimer() - { - foreach ($this->_eventTimer as $event) { - $event->stop(); - } - $this->_eventTimer = array(); - } - - /** - * Main loop. - * - * @see EventInterface::loop() - */ - public function loop() - { - \Ev::run(); - } -} diff --git a/vendor/workerman/workerman/Events/Event.php b/vendor/workerman/workerman/Events/Event.php deleted file mode 100644 index 2d85aafee..000000000 --- a/vendor/workerman/workerman/Events/Event.php +++ /dev/null @@ -1,188 +0,0 @@ - - * @copyright 有个鬼<42765633@qq.com> - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events; - -use Workerman\Worker; - -/** - * libevent eventloop - */ -class Event implements EventInterface -{ - /** - * Event base. - * @var object - */ - protected $_eventBase = null; - - /** - * All listeners for read/write event. - * @var array - */ - protected $_allEvents = array(); - - /** - * Event listeners of signal. - * @var array - */ - protected $_eventSignal = array(); - - /** - * All timer event listeners. - * [func, args, event, flag, time_interval] - * @var array - */ - protected $_eventTimer = array(); - - /** - * Timer id. - * @var int - */ - protected static $_timerId = 1; - - /** - * construct - * @return void - */ - public function __construct() - { - $this->_eventBase = new \EventBase(); - } - - /** - * @see EventInterface::add() - */ - public function add($fd, $flag, $func, $args=array()) - { - switch ($flag) { - case self::EV_SIGNAL: - - $fd_key = (int)$fd; - $event = \Event::signal($this->_eventBase, $fd, $func); - if (!$event||!$event->add()) { - return false; - } - $this->_eventSignal[$fd_key] = $event; - return true; - - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - - $param = array($func, (array)$args, $flag, $fd, self::$_timerId); - $event = new \Event($this->_eventBase, -1, \Event::TIMEOUT|\Event::PERSIST, array($this, "timerCallback"), $param); - if (!$event||!$event->addTimer($fd)) { - return false; - } - $this->_eventTimer[self::$_timerId] = $event; - return self::$_timerId++; - - default : - $fd_key = (int)$fd; - $real_flag = $flag === self::EV_READ ? \Event::READ | \Event::PERSIST : \Event::WRITE | \Event::PERSIST; - $event = new \Event($this->_eventBase, $fd, $real_flag, $func, $fd); - if (!$event||!$event->add()) { - return false; - } - $this->_allEvents[$fd_key][$flag] = $event; - return true; - } - } - - /** - * @see Events\EventInterface::del() - */ - public function del($fd, $flag) - { - switch ($flag) { - - case self::EV_READ: - case self::EV_WRITE: - - $fd_key = (int)$fd; - if (isset($this->_allEvents[$fd_key][$flag])) { - $this->_allEvents[$fd_key][$flag]->del(); - unset($this->_allEvents[$fd_key][$flag]); - } - if (empty($this->_allEvents[$fd_key])) { - unset($this->_allEvents[$fd_key]); - } - break; - - case self::EV_SIGNAL: - - $fd_key = (int)$fd; - if (isset($this->_eventSignal[$fd_key])) { - $this->_allEvents[$fd_key][$flag]->del(); - unset($this->_eventSignal[$fd_key]); - } - break; - - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - if (isset($this->_eventTimer[$fd])) { - $this->_eventTimer[$fd]->del(); - unset($this->_eventTimer[$fd]); - } - break; - } - return true; - } - - /** - * Timer callback. - * @param null $fd - * @param int $what - * @param int $timer_id - */ - public function timerCallback($fd, $what, $param) - { - $timer_id = $param[4]; - - if ($param[2] === self::EV_TIMER_ONCE) { - $this->_eventTimer[$timer_id]->del(); - unset($this->_eventTimer[$timer_id]); - } - - try { - call_user_func_array($param[0], $param[1]); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - - /** - * @see Events\EventInterface::clearAllTimer() - * @return void - */ - public function clearAllTimer() - { - foreach ($this->_eventTimer as $event) { - $event->del(); - } - $this->_eventTimer = array(); - } - - - /** - * @see EventInterface::loop() - */ - public function loop() - { - $this->_eventBase->loop(); - } -} diff --git a/vendor/workerman/workerman/Events/EventInterface.php b/vendor/workerman/workerman/Events/EventInterface.php deleted file mode 100644 index d71b5d438..000000000 --- a/vendor/workerman/workerman/Events/EventInterface.php +++ /dev/null @@ -1,86 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events; - -interface EventInterface -{ - /** - * Read event. - * - * @var int - */ - const EV_READ = 1; - - /** - * Write event. - * - * @var int - */ - const EV_WRITE = 2; - - /** - * Signal event. - * - * @var int - */ - const EV_SIGNAL = 4; - - /** - * Timer event. - * - * @var int - */ - const EV_TIMER = 8; - - /** - * Timer once event. - * - * @var int - */ - const EV_TIMER_ONCE = 16; - - /** - * Add event listener to event loop. - * - * @param mixed $fd - * @param int $flag - * @param callable $func - * @param mixed $args - * @return bool - */ - public function add($fd, $flag, $func, $args = null); - - /** - * Remove event listener from event loop. - * - * @param mixed $fd - * @param int $flag - * @return bool - */ - public function del($fd, $flag); - - /** - * Remove all timers. - * - * @return void - */ - public function clearAllTimer(); - - /** - * Main loop. - * - * @return void - */ - public function loop(); -} diff --git a/vendor/workerman/workerman/Events/Libevent.php b/vendor/workerman/workerman/Events/Libevent.php deleted file mode 100644 index 5644bf1e7..000000000 --- a/vendor/workerman/workerman/Events/Libevent.php +++ /dev/null @@ -1,205 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events; - -use Workerman\Worker; - -/** - * libevent eventloop - */ -class Libevent implements EventInterface -{ - /** - * Event base. - * - * @var resource - */ - protected $_eventBase = null; - - /** - * All listeners for read/write event. - * - * @var array - */ - protected $_allEvents = array(); - - /** - * Event listeners of signal. - * - * @var array - */ - protected $_eventSignal = array(); - - /** - * All timer event listeners. - * [func, args, event, flag, time_interval] - * - * @var array - */ - protected $_eventTimer = array(); - - /** - * construct - */ - public function __construct() - { - $this->_eventBase = event_base_new(); - } - - /** - * {@inheritdoc} - */ - public function add($fd, $flag, $func, $args = array()) - { - switch ($flag) { - case self::EV_SIGNAL: - $fd_key = (int)$fd; - $real_flag = EV_SIGNAL | EV_PERSIST; - $this->_eventSignal[$fd_key] = event_new(); - if (!event_set($this->_eventSignal[$fd_key], $fd, $real_flag, $func, null)) { - return false; - } - if (!event_base_set($this->_eventSignal[$fd_key], $this->_eventBase)) { - return false; - } - if (!event_add($this->_eventSignal[$fd_key])) { - return false; - } - return true; - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - $event = event_new(); - $timer_id = (int)$event; - if (!event_set($event, 0, EV_TIMEOUT, array($this, 'timerCallback'), $timer_id)) { - return false; - } - - if (!event_base_set($event, $this->_eventBase)) { - return false; - } - - $time_interval = $fd * 1000000; - if (!event_add($event, $time_interval)) { - return false; - } - $this->_eventTimer[$timer_id] = array($func, (array)$args, $event, $flag, $time_interval); - return $timer_id; - - default : - $fd_key = (int)$fd; - $real_flag = $flag === self::EV_READ ? EV_READ | EV_PERSIST : EV_WRITE | EV_PERSIST; - - $event = event_new(); - - if (!event_set($event, $fd, $real_flag, $func, null)) { - return false; - } - - if (!event_base_set($event, $this->_eventBase)) { - return false; - } - - if (!event_add($event)) { - return false; - } - - $this->_allEvents[$fd_key][$flag] = $event; - - return true; - } - - } - - /** - * {@inheritdoc} - */ - public function del($fd, $flag) - { - switch ($flag) { - case self::EV_READ: - case self::EV_WRITE: - $fd_key = (int)$fd; - if (isset($this->_allEvents[$fd_key][$flag])) { - event_del($this->_allEvents[$fd_key][$flag]); - unset($this->_allEvents[$fd_key][$flag]); - } - if (empty($this->_allEvents[$fd_key])) { - unset($this->_allEvents[$fd_key]); - } - break; - case self::EV_SIGNAL: - $fd_key = (int)$fd; - if (isset($this->_eventSignal[$fd_key])) { - event_del($this->_eventSignal[$fd_key]); - unset($this->_eventSignal[$fd_key]); - } - break; - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - // 这里 fd 为timerid - if (isset($this->_eventTimer[$fd])) { - event_del($this->_eventTimer[$fd][2]); - unset($this->_eventTimer[$fd]); - } - break; - } - return true; - } - - /** - * Timer callback. - * - * @param mixed $_null1 - * @param int $_null2 - * @param mixed $timer_id - */ - protected function timerCallback($_null1, $_null2, $timer_id) - { - if ($this->_eventTimer[$timer_id][3] === self::EV_TIMER) { - event_add($this->_eventTimer[$timer_id][2], $this->_eventTimer[$timer_id][4]); - } - try { - call_user_func_array($this->_eventTimer[$timer_id][0], $this->_eventTimer[$timer_id][1]); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - if (isset($this->_eventTimer[$timer_id]) && $this->_eventTimer[$timer_id][3] === self::EV_TIMER_ONCE) { - $this->del($timer_id, self::EV_TIMER_ONCE); - } - } - - /** - * {@inheritdoc} - */ - public function clearAllTimer() - { - foreach ($this->_eventTimer as $task_data) { - event_del($task_data[2]); - } - $this->_eventTimer = array(); - } - - /** - * {@inheritdoc} - */ - public function loop() - { - event_base_loop($this->_eventBase); - } -} - diff --git a/vendor/workerman/workerman/Events/React.php b/vendor/workerman/workerman/Events/React.php deleted file mode 100644 index 79e6f96e4..000000000 --- a/vendor/workerman/workerman/Events/React.php +++ /dev/null @@ -1,265 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events; -use React\EventLoop\LoopInterface; -use React\EventLoop\Timer\TimerInterface; - -/** - * select eventloop - */ -class React implements LoopInterface -{ - /** - * @var React\EventLoop\LoopInterface - */ - protected $_loop = null; - - /** - * @var array - */ - protected $_timerIdMap = array(); - - /** - * @var int - */ - protected $_timerIdIndex = 0; - - /** - * React constructor. - */ - public function __construct() { - if (function_exists('event_base_new')) { - $this->_loop = new \Workerman\Events\React\LibEventLoop(); - } elseif (class_exists('EventBase', false)) { - $this->_loop = new \Workerman\Events\React\ExtEventLoop(); - } else { - $this->_loop = new \Workerman\Events\React\StreamSelectLoop(); - } - } - - /** - * Add event listener to event loop. - * - * @param $fd - * @param $flag - * @param $func - * @param array $args - * @return bool - */ - public function add($fd, $flag, $func, $args = array()) - { - $args = (array)$args; - switch ($flag) { - case EventInterface::EV_READ: - return $this->_loop->addReadStream($fd, $func); - case EventInterface::EV_WRITE: - return $this->_loop->addWriteStream($fd, $func); - case EventInterface::EV_SIGNAL: - return $this->_loop->addSignal($fd, $func); - case EventInterface::EV_TIMER: - $timer_obj = $this->_loop->addPeriodicTimer($fd, function() use ($func, $args) { - call_user_func_array($func, $args); - }); - $this->_timerIdMap[++$this->_timerIdIndex] = $timer_obj; - return $this->_timerIdIndex; - case EventInterface::EV_TIMER_ONCE: - $timer_obj = $this->_loop->addTimer($fd, function() use ($func, $args) { - call_user_func_array($func, $args); - }); - $this->_timerIdMap[++$this->_timerIdIndex] = $timer_obj; - return $this->_timerIdIndex; - } - return false; - } - - /** - * Remove event listener from event loop. - * - * @param mixed $fd - * @param int $flag - * @return bool - */ - public function del($fd, $flag) - { - switch ($flag) { - case EventInterface::EV_READ: - return $this->_loop->removeReadStream($fd); - case EventInterface::EV_WRITE: - return $this->_loop->removeWriteStream($fd); - case EventInterface::EV_SIGNAL: - return $this->_loop->removeSignal($fd); - case EventInterface::EV_TIMER: - case EventInterface::EV_TIMER_ONCE; - if (isset($this->_timerIdMap[$fd])){ - $timer_obj = $this->_timerIdMap[$fd]; - unset($this->_timerIdMap[$fd]); - $this->_loop->cancelTimer($timer_obj); - return true; - } - } - return false; - } - - - /** - * Main loop. - * - * @return void - */ - public function loop() - { - $this->_loop->run(); - } - - /** - * Register a listener to be notified when a stream is ready to read. - * - * @param resource $stream The PHP stream resource to check. - * @param callable $listener Invoked when the stream is ready. - */ - public function addReadStream($stream, callable $listener) { - return call_user_func(array($this->_loop, 'addReadStream'), $stream, $listener); - } - - /** - * Register a listener to be notified when a stream is ready to write. - * - * @param resource $stream The PHP stream resource to check. - * @param callable $listener Invoked when the stream is ready. - */ - public function addWriteStream($stream, callable $listener) { - return call_user_func(array($this->_loop, 'addWriteStream'), $stream, $listener); - } - - /** - * Remove the read event listener for the given stream. - * - * @param resource $stream The PHP stream resource. - */ - public function removeReadStream($stream) { - return call_user_func(array($this->_loop, 'removeReadStream'), $stream); - } - - /** - * Remove the write event listener for the given stream. - * - * @param resource $stream The PHP stream resource. - */ - public function removeWriteStream($stream) { - return call_user_func(array($this->_loop, 'removeWriteStream'), $stream); - } - - /** - * Remove all listeners for the given stream. - * - * @param resource $stream The PHP stream resource. - */ - public function removeStream($stream) { - return call_user_func(array($this->_loop, 'removeStream'), $stream); - } - - /** - * Enqueue a callback to be invoked once after the given interval. - * - * The execution order of timers scheduled to execute at the same time is - * not guaranteed. - * - * @param int|float $interval The number of seconds to wait before execution. - * @param callable $callback The callback to invoke. - * - * @return TimerInterface - */ - public function addTimer($interval, callable $callback) { - return call_user_func(array($this->_loop, 'addTimer'), $interval, $callback); - } - - /** - * Enqueue a callback to be invoked repeatedly after the given interval. - * - * The execution order of timers scheduled to execute at the same time is - * not guaranteed. - * - * @param int|float $interval The number of seconds to wait before execution. - * @param callable $callback The callback to invoke. - * - * @return TimerInterface - */ - public function addPeriodicTimer($interval, callable $callback) { - return call_user_func(array($this->_loop, 'addPeriodicTimer'), $interval, $callback); - } - - /** - * Cancel a pending timer. - * - * @param TimerInterface $timer The timer to cancel. - */ - public function cancelTimer(TimerInterface $timer) { - return call_user_func(array($this->_loop, 'cancelTimer'), $timer); - } - - /** - * Check if a given timer is active. - * - * @param TimerInterface $timer The timer to check. - * - * @return boolean True if the timer is still enqueued for execution. - */ - public function isTimerActive(TimerInterface $timer) { - return call_user_func(array($this->_loop, 'isTimerActive'), $timer); - } - - /** - * Schedule a callback to be invoked on the next tick of the event loop. - * - * Callbacks are guaranteed to be executed in the order they are enqueued, - * before any timer or stream events. - * - * @param callable $listener The callback to invoke. - */ - public function nextTick(callable $listener) { - return call_user_func(array($this->_loop, 'nextTick'), $listener); - } - - /** - * Schedule a callback to be invoked on a future tick of the event loop. - * - * Callbacks are guaranteed to be executed in the order they are enqueued. - * - * @param callable $listener The callback to invoke. - */ - public function futureTick(callable $listener) { - return call_user_func(array($this->_loop, 'futureTick'), $listener); - } - - /** - * Perform a single iteration of the event loop. - */ - public function tick() { - return call_user_func(array($this->_loop, 'tick')); - } - - /** - * Run the event loop until there are no more tasks to perform. - */ - public function run() { - return call_user_func(array($this->_loop, 'run')); - } - - /** - * Instruct a running event loop to stop. - */ - public function stop() { - return call_user_func(array($this->_loop, 'stop')); - } -} diff --git a/vendor/workerman/workerman/Events/React/ExtEventLoop.php b/vendor/workerman/workerman/Events/React/ExtEventLoop.php deleted file mode 100644 index ccb504182..000000000 --- a/vendor/workerman/workerman/Events/React/ExtEventLoop.php +++ /dev/null @@ -1,76 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events\React; - -/** - * Class ExtEventLoop - * @package Workerman\Events\React - */ -class ExtEventLoop extends \React\EventLoop\ExtEventLoop -{ - /** - * Event base. - * - * @var EventBase - */ - protected $_eventBase = null; - - /** - * All signal Event instances. - * - * @var array - */ - protected $_signalEvents = array(); - - /** - * Construct - */ - public function __construct() - { - parent::__construct(); - $class = new \ReflectionClass('\React\EventLoop\ExtEventLoop'); - $property = $class->getProperty('eventBase'); - $property->setAccessible(true); - $this->_eventBase = $property->getValue($this); - } - - /** - * Add signal handler. - * - * @param $signal - * @param $callback - * @return bool - */ - public function addSignal($signal, $callback) - { - $event = \Event::signal($this->_eventBase, $signal, $callback); - if (!$event||!$event->add()) { - return false; - } - $this->_signalEvents[$signal] = $event; - } - - /** - * Remove signal handler. - * - * @param $signal - */ - public function removeSignal($signal) - { - if (isset($this->_signalEvents[$signal])) { - $this->_signalEvents[$signal]->del(); - unset($this->_signalEvents[$signal]); - } - } -} diff --git a/vendor/workerman/workerman/Events/React/LibEventLoop.php b/vendor/workerman/workerman/Events/React/LibEventLoop.php deleted file mode 100644 index 1dbf3900d..000000000 --- a/vendor/workerman/workerman/Events/React/LibEventLoop.php +++ /dev/null @@ -1,77 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events\React; - -/** - * Class LibEventLoop - * @package Workerman\Events\React - */ -class LibEventLoop extends \React\EventLoop\LibEventLoop -{ - /** - * Event base. - * - * @var event_base resource - */ - protected $_eventBase = null; - - /** - * All signal Event instances. - * - * @var array - */ - protected $_signalEvents = array(); - - /** - * Construct. - */ - public function __construct() - { - parent::__construct(); - $class = new \ReflectionClass('\React\EventLoop\LibEventLoop'); - $property = $class->getProperty('eventBase'); - $property->setAccessible(true); - $this->_eventBase = $property->getValue($this); - } - - /** - * Add signal handler. - * - * @param $signal - * @param $callback - * @return bool - */ - public function addSignal($signal, $callback) - { - $event = event_new(); - $this->_signalEvents[$signal] = $event; - event_set($event, $signal, EV_SIGNAL | EV_PERSIST, $callback); - event_base_set($event, $this->_eventBase); - event_add($event); - } - - /** - * Remove signal handler. - * - * @param $signal - */ - public function removeSignal($signal) - { - if (isset($this->_signalEvents[$signal])) { - $event = $this->_signalEvents[$signal]; - event_del($event); - unset($this->_signalEvents[$signal]); - } - } -} diff --git a/vendor/workerman/workerman/Events/React/StreamSelectLoop.php b/vendor/workerman/workerman/Events/React/StreamSelectLoop.php deleted file mode 100644 index 5ab8bc7e8..000000000 --- a/vendor/workerman/workerman/Events/React/StreamSelectLoop.php +++ /dev/null @@ -1,77 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events\React; - -/** - * Class StreamSelectLoop - * @package Workerman\Events\React - */ -class StreamSelectLoop extends \React\EventLoop\StreamSelectLoop -{ - /** - * Add signal handler. - * - * @param $signal - * @param $callback - * @return bool - */ - public function addSignal($signal, $callback) - { - if(PHP_EOL !== "\r\n") { - pcntl_signal($signal, $callback); - } - } - - /** - * Remove signal handler. - * - * @param $signal - */ - public function removeSignal($signal) - { - if(PHP_EOL !== "\r\n") { - pcntl_signal($signal, SIG_IGN); - } - } - - /** - * Emulate a stream_select() implementation that does not break when passed - * empty stream arrays. - * - * @param array &$read An array of read streams to select upon. - * @param array &$write An array of write streams to select upon. - * @param integer|null $timeout Activity timeout in microseconds, or null to wait forever. - * - * @return integer|false The total number of streams that are ready for read/write. - * Can return false if stream_select() is interrupted by a signal. - */ - protected function streamSelect(array &$read, array &$write, $timeout) - { - if ($read || $write) { - $except = null; - // Calls signal handlers for pending signals - pcntl_signal_dispatch(); - // suppress warnings that occur, when stream_select is interrupted by a signal - return @stream_select($read, $write, $except, $timeout === null ? null : 0, $timeout); - } - - // Calls signal handlers for pending signals - if(PHP_EOL !== "\r\n") { - pcntl_signal_dispatch(); - } - $timeout && usleep($timeout); - - return 0; - } -} diff --git a/vendor/workerman/workerman/Events/Select.php b/vendor/workerman/workerman/Events/Select.php deleted file mode 100644 index 1b9d16f16..000000000 --- a/vendor/workerman/workerman/Events/Select.php +++ /dev/null @@ -1,263 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Events; - -/** - * select eventloop - */ -class Select implements EventInterface -{ - /** - * All listeners for read/write event. - * - * @var array - */ - public $_allEvents = array(); - - /** - * Event listeners of signal. - * - * @var array - */ - public $_signalEvents = array(); - - /** - * Fds waiting for read event. - * - * @var array - */ - protected $_readFds = array(); - - /** - * Fds waiting for write event. - * - * @var array - */ - protected $_writeFds = array(); - - /** - * Timer scheduler. - * {['data':timer_id, 'priority':run_timestamp], ..} - * - * @var \SplPriorityQueue - */ - protected $_scheduler = null; - - /** - * All timer event listeners. - * [[func, args, flag, timer_interval], ..] - * - * @var array - */ - protected $_task = array(); - - /** - * Timer id. - * - * @var int - */ - protected $_timerId = 1; - - /** - * Select timeout. - * - * @var int - */ - protected $_selectTimeout = 100000000; - - /** - * Paired socket channels - * - * @var array - */ - protected $channel = array(); - - /** - * Construct. - */ - public function __construct() - { - // Create a pipeline and put into the collection of the read to read the descriptor to avoid empty polling. - $this->channel = stream_socket_pair(STREAM_PF_UNIX, STREAM_SOCK_STREAM, STREAM_IPPROTO_IP); - if ($this->channel) { - stream_set_blocking($this->channel[0], 0); - $this->_readFds[0] = $this->channel[0]; - } - // Init SplPriorityQueue. - $this->_scheduler = new \SplPriorityQueue(); - $this->_scheduler->setExtractFlags(\SplPriorityQueue::EXTR_BOTH); - } - - /** - * {@inheritdoc} - */ - public function add($fd, $flag, $func, $args = array()) - { - switch ($flag) { - case self::EV_READ: - $fd_key = (int)$fd; - $this->_allEvents[$fd_key][$flag] = array($func, $fd); - $this->_readFds[$fd_key] = $fd; - break; - case self::EV_WRITE: - $fd_key = (int)$fd; - $this->_allEvents[$fd_key][$flag] = array($func, $fd); - $this->_writeFds[$fd_key] = $fd; - break; - case self::EV_SIGNAL: - $fd_key = (int)$fd; - $this->_signalEvents[$fd_key][$flag] = array($func, $fd); - pcntl_signal($fd, array($this, 'signalHandler')); - break; - case self::EV_TIMER: - case self::EV_TIMER_ONCE: - $run_time = microtime(true) + $fd; - $this->_scheduler->insert($this->_timerId, -$run_time); - $this->_task[$this->_timerId] = array($func, (array)$args, $flag, $fd); - $this->tick(); - return $this->_timerId++; - } - - return true; - } - - /** - * Signal handler. - * - * @param int $signal - */ - public function signalHandler($signal) - { - call_user_func_array($this->_signalEvents[$signal][self::EV_SIGNAL][0], array($signal)); - } - - /** - * {@inheritdoc} - */ - public function del($fd, $flag) - { - $fd_key = (int)$fd; - switch ($flag) { - case self::EV_READ: - unset($this->_allEvents[$fd_key][$flag], $this->_readFds[$fd_key]); - if (empty($this->_allEvents[$fd_key])) { - unset($this->_allEvents[$fd_key]); - } - return true; - case self::EV_WRITE: - unset($this->_allEvents[$fd_key][$flag], $this->_writeFds[$fd_key]); - if (empty($this->_allEvents[$fd_key])) { - unset($this->_allEvents[$fd_key]); - } - return true; - case self::EV_SIGNAL: - unset($this->_signalEvents[$fd_key]); - pcntl_signal($fd, SIG_IGN); - break; - case self::EV_TIMER: - case self::EV_TIMER_ONCE; - unset($this->_task[$fd_key]); - return true; - } - return false; - } - - /** - * Tick for timer. - * - * @return void - */ - protected function tick() - { - while (!$this->_scheduler->isEmpty()) { - $scheduler_data = $this->_scheduler->top(); - $timer_id = $scheduler_data['data']; - $next_run_time = -$scheduler_data['priority']; - $time_now = microtime(true); - $this->_selectTimeout = ($next_run_time - $time_now) * 1000000; - if ($this->_selectTimeout <= 0) { - $this->_scheduler->extract(); - - if (!isset($this->_task[$timer_id])) { - continue; - } - - // [func, args, flag, timer_interval] - $task_data = $this->_task[$timer_id]; - if ($task_data[2] === self::EV_TIMER) { - $next_run_time = $time_now + $task_data[3]; - $this->_scheduler->insert($timer_id, -$next_run_time); - } - call_user_func_array($task_data[0], $task_data[1]); - if (isset($this->_task[$timer_id]) && $task_data[2] === self::EV_TIMER_ONCE) { - $this->del($timer_id, self::EV_TIMER_ONCE); - } - continue; - } - return; - } - $this->_selectTimeout = 100000000; - } - - /** - * {@inheritdoc} - */ - public function clearAllTimer() - { - $this->_scheduler = new \SplPriorityQueue(); - $this->_scheduler->setExtractFlags(\SplPriorityQueue::EXTR_BOTH); - $this->_task = array(); - } - - /** - * {@inheritdoc} - */ - public function loop() - { - $e = null; - while (1) { - // Calls signal handlers for pending signals - pcntl_signal_dispatch(); - - $read = $this->_readFds; - $write = $this->_writeFds; - // Waiting read/write/signal/timeout events. - $ret = @stream_select($read, $write, $e, 0, $this->_selectTimeout); - - if (!$this->_scheduler->isEmpty()) { - $this->tick(); - } - - if (!$ret) { - continue; - } - - foreach ($read as $fd) { - $fd_key = (int)$fd; - if (isset($this->_allEvents[$fd_key][self::EV_READ])) { - call_user_func_array($this->_allEvents[$fd_key][self::EV_READ][0], - array($this->_allEvents[$fd_key][self::EV_READ][1])); - } - } - - foreach ($write as $fd) { - $fd_key = (int)$fd; - if (isset($this->_allEvents[$fd_key][self::EV_WRITE])) { - call_user_func_array($this->_allEvents[$fd_key][self::EV_WRITE][0], - array($this->_allEvents[$fd_key][self::EV_WRITE][1])); - } - } - } - } -} diff --git a/vendor/workerman/workerman/Lib/Constants.php b/vendor/workerman/workerman/Lib/Constants.php deleted file mode 100644 index 81440747a..000000000 --- a/vendor/workerman/workerman/Lib/Constants.php +++ /dev/null @@ -1,35 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ - -// Date.timezone -if (!ini_get('date.timezone')) { - date_default_timezone_set('Asia/Shanghai'); -} -// Display errors. -ini_set('display_errors', 'on'); -// Reporting all. -error_reporting(E_ALL); - -// For onError callback. -define('WORKERMAN_CONNECT_FAIL', 1); -// For onError callback. -define('WORKERMAN_SEND_FAIL', 2); - -// Compatible with php7 -if(!class_exists('Error')) -{ - class Error extends Exception - { - } -} \ No newline at end of file diff --git a/vendor/workerman/workerman/Lib/Timer.php b/vendor/workerman/workerman/Lib/Timer.php deleted file mode 100644 index 4bd4ac5af..000000000 --- a/vendor/workerman/workerman/Lib/Timer.php +++ /dev/null @@ -1,176 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Lib; - -use Workerman\Events\EventInterface; -use Exception; - -/** - * Timer. - * - * example: - * Workerman\Lib\Timer::add($time_interval, callback, array($arg1, $arg2..)); - */ -class Timer -{ - /** - * Tasks that based on ALARM signal. - * [ - * run_time => [[$func, $args, $persistent, time_interval],[$func, $args, $persistent, time_interval],..]], - * run_time => [[$func, $args, $persistent, time_interval],[$func, $args, $persistent, time_interval],..]], - * .. - * ] - * - * @var array - */ - protected static $_tasks = array(); - - /** - * event - * - * @var \Workerman\Events\EventInterface - */ - protected static $_event = null; - - /** - * Init. - * - * @param \Workerman\Events\EventInterface $event - * @return void - */ - public static function init($event = null) - { - if ($event) { - self::$_event = $event; - } else { - pcntl_signal(SIGALRM, array('\Workerman\Lib\Timer', 'signalHandle'), false); - } - } - - /** - * ALARM signal handler. - * - * @return void - */ - public static function signalHandle() - { - if (!self::$_event) { - pcntl_alarm(1); - self::tick(); - } - } - - /** - * Add a timer. - * - * @param int $time_interval - * @param callback $func - * @param mixed $args - * @param bool $persistent - * @return int/false - */ - public static function add($time_interval, $func, $args = array(), $persistent = true) - { - if ($time_interval <= 0) { - echo new Exception("bad time_interval"); - return false; - } - - if (self::$_event) { - return self::$_event->add($time_interval, - $persistent ? EventInterface::EV_TIMER : EventInterface::EV_TIMER_ONCE, $func, $args); - } - - if (!is_callable($func)) { - echo new Exception("not callable"); - return false; - } - - if (empty(self::$_tasks)) { - pcntl_alarm(1); - } - - $time_now = time(); - $run_time = $time_now + $time_interval; - if (!isset(self::$_tasks[$run_time])) { - self::$_tasks[$run_time] = array(); - } - self::$_tasks[$run_time][] = array($func, (array)$args, $persistent, $time_interval); - return 1; - } - - - /** - * Tick. - * - * @return void - */ - public static function tick() - { - if (empty(self::$_tasks)) { - pcntl_alarm(0); - return; - } - - $time_now = time(); - foreach (self::$_tasks as $run_time => $task_data) { - if ($time_now >= $run_time) { - foreach ($task_data as $index => $one_task) { - $task_func = $one_task[0]; - $task_args = $one_task[1]; - $persistent = $one_task[2]; - $time_interval = $one_task[3]; - try { - call_user_func_array($task_func, $task_args); - } catch (\Exception $e) { - echo $e; - } - if ($persistent) { - self::add($time_interval, $task_func, $task_args); - } - } - unset(self::$_tasks[$run_time]); - } - } - } - - /** - * Remove a timer. - * - * @param mixed $timer_id - * @return bool - */ - public static function del($timer_id) - { - if (self::$_event) { - return self::$_event->del($timer_id, EventInterface::EV_TIMER); - } - - return false; - } - - /** - * Remove all timers. - * - * @return void - */ - public static function delAll() - { - self::$_tasks = array(); - pcntl_alarm(0); - if (self::$_event) { - self::$_event->clearAllTimer(); - } - } -} diff --git a/vendor/workerman/workerman/MIT-LICENSE.txt b/vendor/workerman/workerman/MIT-LICENSE.txt deleted file mode 100644 index fd6b1c83f..000000000 --- a/vendor/workerman/workerman/MIT-LICENSE.txt +++ /dev/null @@ -1,21 +0,0 @@ -The MIT License - -Copyright (c) 2009-2015 walkor and contributors (see https://github.com/walkor/workerman/contributors) - -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/vendor/workerman/workerman/Protocols/Frame.php b/vendor/workerman/workerman/Protocols/Frame.php deleted file mode 100644 index 4a6b13ecb..000000000 --- a/vendor/workerman/workerman/Protocols/Frame.php +++ /dev/null @@ -1,61 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Protocols; - -use Workerman\Connection\TcpConnection; - -/** - * Frame Protocol. - */ -class Frame -{ - /** - * Check the integrity of the package. - * - * @param string $buffer - * @param TcpConnection $connection - * @return int - */ - public static function input($buffer, TcpConnection $connection) - { - if (strlen($buffer) < 4) { - return 0; - } - $unpack_data = unpack('Ntotal_length', $buffer); - return $unpack_data['total_length']; - } - - /** - * Decode. - * - * @param string $buffer - * @return string - */ - public static function decode($buffer) - { - return substr($buffer, 4); - } - - /** - * Encode. - * - * @param string $buffer - * @return string - */ - public static function encode($buffer) - { - $total_length = 4 + strlen($buffer); - return pack('N', $total_length) . $buffer; - } -} diff --git a/vendor/workerman/workerman/Protocols/Http.php b/vendor/workerman/workerman/Protocols/Http.php deleted file mode 100644 index 30c3ba918..000000000 --- a/vendor/workerman/workerman/Protocols/Http.php +++ /dev/null @@ -1,577 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Protocols; - -use Workerman\Connection\TcpConnection; -use Workerman\Worker; - -/** - * http protocol - */ -class Http -{ - /** - * The supported HTTP methods - * @var array - */ - public static $methods = array('GET', 'POST', 'PUT', 'DELETE', 'HEAD', 'OPTIONS'); - - /** - * Check the integrity of the package. - * - * @param string $recv_buffer - * @param TcpConnection $connection - * @return int - */ - public static function input($recv_buffer, TcpConnection $connection) - { - if (!strpos($recv_buffer, "\r\n\r\n")) { - // Judge whether the package length exceeds the limit. - if (strlen($recv_buffer) >= TcpConnection::$maxPackageSize) { - $connection->close(); - return 0; - } - return 0; - } - - list($header,) = explode("\r\n\r\n", $recv_buffer, 2); - $method = substr($header, 0, strpos($header, ' ')); - - if(in_array($method, static::$methods)) { - return static::getRequestSize($header, $method); - }else{ - $connection->send("HTTP/1.1 400 Bad Request\r\n\r\n", true); - return 0; - } - } - - /** - * Get whole size of the request - * includes the request headers and request body. - * @param string $header The request headers - * @param string $method The request method - * @return integer - */ - protected static function getRequestSize($header, $method) - { - if($method=='GET') { - return strlen($header) + 4; - } - $match = array(); - if (preg_match("/\r\nContent-Length: ?(\d+)/i", $header, $match)) { - $content_length = isset($match[1]) ? $match[1] : 0; - return $content_length + strlen($header) + 4; - } - return 0; - } - - /** - * Parse $_POST、$_GET、$_COOKIE. - * - * @param string $recv_buffer - * @param TcpConnection $connection - * @return array - */ - public static function decode($recv_buffer, TcpConnection $connection) - { - // Init. - $_POST = $_GET = $_COOKIE = $_REQUEST = $_SESSION = $_FILES = array(); - $GLOBALS['HTTP_RAW_POST_DATA'] = ''; - // Clear cache. - HttpCache::$header = array('Connection' => 'Connection: keep-alive'); - HttpCache::$instance = new HttpCache(); - // $_SERVER - $_SERVER = array( - 'QUERY_STRING' => '', - 'REQUEST_METHOD' => '', - 'REQUEST_URI' => '', - 'SERVER_PROTOCOL' => '', - 'SERVER_SOFTWARE' => 'workerman/'.Worker::VERSION, - 'SERVER_NAME' => '', - 'HTTP_HOST' => '', - 'HTTP_USER_AGENT' => '', - 'HTTP_ACCEPT' => '', - 'HTTP_ACCEPT_LANGUAGE' => '', - 'HTTP_ACCEPT_ENCODING' => '', - 'HTTP_COOKIE' => '', - 'HTTP_CONNECTION' => '', - 'REMOTE_ADDR' => '', - 'REMOTE_PORT' => '0', - ); - - // Parse headers. - list($http_header, $http_body) = explode("\r\n\r\n", $recv_buffer, 2); - $header_data = explode("\r\n", $http_header); - - list($_SERVER['REQUEST_METHOD'], $_SERVER['REQUEST_URI'], $_SERVER['SERVER_PROTOCOL']) = explode(' ', - $header_data[0]); - - $http_post_boundary = ''; - unset($header_data[0]); - foreach ($header_data as $content) { - // \r\n\r\n - if (empty($content)) { - continue; - } - list($key, $value) = explode(':', $content, 2); - $key = str_replace('-', '_', strtoupper($key)); - $value = trim($value); - $_SERVER['HTTP_' . $key] = $value; - switch ($key) { - // HTTP_HOST - case 'HOST': - $tmp = explode(':', $value); - $_SERVER['SERVER_NAME'] = $tmp[0]; - if (isset($tmp[1])) { - $_SERVER['SERVER_PORT'] = $tmp[1]; - } - break; - // cookie - case 'COOKIE': - parse_str(str_replace('; ', '&', $_SERVER['HTTP_COOKIE']), $_COOKIE); - break; - // content-type - case 'CONTENT_TYPE': - if (!preg_match('/boundary="?(\S+)"?/', $value, $match)) { - $_SERVER['CONTENT_TYPE'] = $value; - } else { - $_SERVER['CONTENT_TYPE'] = 'multipart/form-data'; - $http_post_boundary = '--' . $match[1]; - } - break; - case 'CONTENT_LENGTH': - $_SERVER['CONTENT_LENGTH'] = $value; - break; - } - } - - // Parse $_POST. - if ($_SERVER['REQUEST_METHOD'] === 'POST') { - if (isset($_SERVER['CONTENT_TYPE']) && $_SERVER['CONTENT_TYPE'] === 'multipart/form-data') { - self::parseUploadFiles($http_body, $http_post_boundary); - } else { - parse_str($http_body, $_POST); - // $GLOBALS['HTTP_RAW_POST_DATA'] - $GLOBALS['HTTP_RAW_REQUEST_DATA'] = $GLOBALS['HTTP_RAW_POST_DATA'] = $http_body; - } - } - - if ($_SERVER['REQUEST_METHOD'] === 'PUT') { - $GLOBALS['HTTP_RAW_REQUEST_DATA'] = $http_body; - } - - if ($_SERVER['REQUEST_METHOD'] === 'DELETE') { - $GLOBALS['HTTP_RAW_REQUEST_DATA'] = $http_body; - } - - // QUERY_STRING - $_SERVER['QUERY_STRING'] = parse_url($_SERVER['REQUEST_URI'], PHP_URL_QUERY); - if ($_SERVER['QUERY_STRING']) { - // $GET - parse_str($_SERVER['QUERY_STRING'], $_GET); - } else { - $_SERVER['QUERY_STRING'] = ''; - } - - // REQUEST - $_REQUEST = array_merge($_GET, $_POST); - - // REMOTE_ADDR REMOTE_PORT - $_SERVER['REMOTE_ADDR'] = $connection->getRemoteIp(); - $_SERVER['REMOTE_PORT'] = $connection->getRemotePort(); - - return array('get' => $_GET, 'post' => $_POST, 'cookie' => $_COOKIE, 'server' => $_SERVER, 'files' => $_FILES); - } - - /** - * Http encode. - * - * @param string $content - * @param TcpConnection $connection - * @return string - */ - public static function encode($content, TcpConnection $connection) - { - // Default http-code. - if (!isset(HttpCache::$header['Http-Code'])) { - $header = "HTTP/1.1 200 OK\r\n"; - } else { - $header = HttpCache::$header['Http-Code'] . "\r\n"; - unset(HttpCache::$header['Http-Code']); - } - - // Content-Type - if (!isset(HttpCache::$header['Content-Type'])) { - $header .= "Content-Type: text/html;charset=utf-8\r\n"; - } - - // other headers - foreach (HttpCache::$header as $key => $item) { - if ('Set-Cookie' === $key && is_array($item)) { - foreach ($item as $it) { - $header .= $it . "\r\n"; - } - } else { - $header .= $item . "\r\n"; - } - } - - // header - $header .= "Server: workerman/" . Worker::VERSION . "\r\nContent-Length: " . strlen($content) . "\r\n\r\n"; - - // save session - self::sessionWriteClose(); - - // the whole http package - return $header . $content; - } - - /** - * 设置http头 - * - * @return bool|void - */ - public static function header($content, $replace = true, $http_response_code = 0) - { - if (PHP_SAPI != 'cli') { - return $http_response_code ? header($content, $replace, $http_response_code) : header($content, $replace); - } - if (strpos($content, 'HTTP') === 0) { - $key = 'Http-Code'; - } else { - $key = strstr($content, ":", true); - if (empty($key)) { - return false; - } - } - - if ('location' === strtolower($key) && !$http_response_code) { - return self::header($content, true, 302); - } - - if (isset(HttpCache::$codes[$http_response_code])) { - HttpCache::$header['Http-Code'] = "HTTP/1.1 $http_response_code " . HttpCache::$codes[$http_response_code]; - if ($key === 'Http-Code') { - return true; - } - } - - if ($key === 'Set-Cookie') { - HttpCache::$header[$key][] = $content; - } else { - HttpCache::$header[$key] = $content; - } - - return true; - } - - /** - * Remove header. - * - * @param string $name - * @return void - */ - public static function headerRemove($name) - { - if (PHP_SAPI != 'cli') { - header_remove($name); - return; - } - unset(HttpCache::$header[$name]); - } - - /** - * Set cookie. - * - * @param string $name - * @param string $value - * @param integer $maxage - * @param string $path - * @param string $domain - * @param bool $secure - * @param bool $HTTPOnly - * @return bool|void - */ - public static function setcookie( - $name, - $value = '', - $maxage = 0, - $path = '', - $domain = '', - $secure = false, - $HTTPOnly = false - ) { - if (PHP_SAPI != 'cli') { - return setcookie($name, $value, $maxage, $path, $domain, $secure, $HTTPOnly); - } - return self::header( - 'Set-Cookie: ' . $name . '=' . rawurlencode($value) - . (empty($domain) ? '' : '; Domain=' . $domain) - . (empty($maxage) ? '' : '; Max-Age=' . $maxage) - . (empty($path) ? '' : '; Path=' . $path) - . (!$secure ? '' : '; Secure') - . (!$HTTPOnly ? '' : '; HttpOnly'), false); - } - - /** - * sessionStart - * - * @return bool - */ - public static function sessionStart() - { - if (PHP_SAPI != 'cli') { - return session_start(); - } - - self::tryGcSessions(); - - if (HttpCache::$instance->sessionStarted) { - echo "already sessionStarted\n"; - return true; - } - HttpCache::$instance->sessionStarted = true; - // Generate a SID. - if (!isset($_COOKIE[HttpCache::$sessionName]) || !is_file(HttpCache::$sessionPath . '/ses' . $_COOKIE[HttpCache::$sessionName])) { - $file_name = tempnam(HttpCache::$sessionPath, 'ses'); - if (!$file_name) { - return false; - } - HttpCache::$instance->sessionFile = $file_name; - $session_id = substr(basename($file_name), strlen('ses')); - return self::setcookie( - HttpCache::$sessionName - , $session_id - , ini_get('session.cookie_lifetime') - , ini_get('session.cookie_path') - , ini_get('session.cookie_domain') - , ini_get('session.cookie_secure') - , ini_get('session.cookie_httponly') - ); - } - if (!HttpCache::$instance->sessionFile) { - HttpCache::$instance->sessionFile = HttpCache::$sessionPath . '/ses' . $_COOKIE[HttpCache::$sessionName]; - } - // Read session from session file. - if (HttpCache::$instance->sessionFile) { - $raw = file_get_contents(HttpCache::$instance->sessionFile); - if ($raw) { - session_decode($raw); - } - } - return true; - } - - /** - * Save session. - * - * @return bool - */ - public static function sessionWriteClose() - { - if (PHP_SAPI != 'cli') { - return session_write_close(); - } - if (!empty(HttpCache::$instance->sessionStarted) && !empty($_SESSION)) { - $session_str = session_encode(); - if ($session_str && HttpCache::$instance->sessionFile) { - return file_put_contents(HttpCache::$instance->sessionFile, $session_str); - } - } - return empty($_SESSION); - } - - /** - * End, like call exit in php-fpm. - * - * @param string $msg - * @throws \Exception - */ - public static function end($msg = '') - { - if (PHP_SAPI != 'cli') { - exit($msg); - } - if ($msg) { - echo $msg; - } - throw new \Exception('jump_exit'); - } - - /** - * Get mime types. - * - * @return string - */ - public static function getMimeTypesFile() - { - return __DIR__ . '/Http/mime.types'; - } - - /** - * Parse $_FILES. - * - * @param string $http_body - * @param string $http_post_boundary - * @return void - */ - protected static function parseUploadFiles($http_body, $http_post_boundary) - { - $http_body = substr($http_body, 0, strlen($http_body) - (strlen($http_post_boundary) + 4)); - $boundary_data_array = explode($http_post_boundary . "\r\n", $http_body); - if ($boundary_data_array[0] === '') { - unset($boundary_data_array[0]); - } - foreach ($boundary_data_array as $boundary_data_buffer) { - list($boundary_header_buffer, $boundary_value) = explode("\r\n\r\n", $boundary_data_buffer, 2); - // Remove \r\n from the end of buffer. - $boundary_value = substr($boundary_value, 0, -2); - foreach (explode("\r\n", $boundary_header_buffer) as $item) { - list($header_key, $header_value) = explode(": ", $item); - $header_key = strtolower($header_key); - switch ($header_key) { - case "content-disposition": - // Is file data. - if (preg_match('/name=".*?"; filename="(.*?)"$/', $header_value, $match)) { - // Parse $_FILES. - $_FILES[] = array( - 'file_name' => $match[1], - 'file_data' => $boundary_value, - 'file_size' => strlen($boundary_value), - ); - continue; - } // Is post field. - else { - // Parse $_POST. - if (preg_match('/name="(.*?)"$/', $header_value, $match)) { - $_POST[$match[1]] = $boundary_value; - } - } - break; - } - } - } - } - - /** - * Try GC sessions. - * - * @return void - */ - public static function tryGcSessions() - { - if (HttpCache::$sessionGcProbability <= 0 || - HttpCache::$sessionGcDivisor <= 0 || - rand(1, HttpCache::$sessionGcDivisor) > HttpCache::$sessionGcProbability) { - return; - } - - $time_now = time(); - foreach(glob(HttpCache::$sessionPath.'/ses*') as $file) { - if(is_file($file) && $time_now - filemtime($file) > HttpCache::$sessionGcMaxLifeTime) { - unlink($file); - } - } - } -} - -/** - * Http cache for the current http response. - */ -class HttpCache -{ - public static $codes = array( - 100 => 'Continue', - 101 => 'Switching Protocols', - 200 => 'OK', - 201 => 'Created', - 202 => 'Accepted', - 203 => 'Non-Authoritative Information', - 204 => 'No Content', - 205 => 'Reset Content', - 206 => 'Partial Content', - 300 => 'Multiple Choices', - 301 => 'Moved Permanently', - 302 => 'Found', - 303 => 'See Other', - 304 => 'Not Modified', - 305 => 'Use Proxy', - 306 => '(Unused)', - 307 => 'Temporary Redirect', - 400 => 'Bad Request', - 401 => 'Unauthorized', - 402 => 'Payment Required', - 403 => 'Forbidden', - 404 => 'Not Found', - 405 => 'Method Not Allowed', - 406 => 'Not Acceptable', - 407 => 'Proxy Authentication Required', - 408 => 'Request Timeout', - 409 => 'Conflict', - 410 => 'Gone', - 411 => 'Length Required', - 412 => 'Precondition Failed', - 413 => 'Request Entity Too Large', - 414 => 'Request-URI Too Long', - 415 => 'Unsupported Media Type', - 416 => 'Requested Range Not Satisfiable', - 417 => 'Expectation Failed', - 422 => 'Unprocessable Entity', - 423 => 'Locked', - 500 => 'Internal Server Error', - 501 => 'Not Implemented', - 502 => 'Bad Gateway', - 503 => 'Service Unavailable', - 504 => 'Gateway Timeout', - 505 => 'HTTP Version Not Supported', - ); - - /** - * @var HttpCache - */ - public static $instance = null; - public static $header = array(); - public static $sessionPath = ''; - public static $sessionName = ''; - public static $sessionGcProbability = 1; - public static $sessionGcDivisor = 1000; - public static $sessionGcMaxLifeTime = 1440; - public $sessionStarted = false; - public $sessionFile = ''; - - public static function init() - { - self::$sessionName = ini_get('session.name'); - self::$sessionPath = session_save_path(); - if (!self::$sessionPath || strpos(self::$sessionPath, 'tcp://') === 0) { - self::$sessionPath = sys_get_temp_dir(); - } - - if ($gc_probability = ini_get('session.gc_probability')) { - self::$sessionGcProbability = $gc_probability; - } - - if ($gc_divisor = ini_get('session.gc_divisor')) { - self::$sessionGcDivisor = $gc_divisor; - } - - if ($gc_max_life_time = ini_get('session.gc_maxlifetime')) { - self::$sessionGcMaxLifeTime = $gc_max_life_time; - } - - @\session_start(); - } -} - -HttpCache::init(); diff --git a/vendor/workerman/workerman/Protocols/Http/mime.types b/vendor/workerman/workerman/Protocols/Http/mime.types deleted file mode 100644 index 8a218b22a..000000000 --- a/vendor/workerman/workerman/Protocols/Http/mime.types +++ /dev/null @@ -1,80 +0,0 @@ - -types { - text/html html htm shtml; - text/css css; - text/xml xml; - image/gif gif; - image/jpeg jpeg jpg; - application/x-javascript js; - application/atom+xml atom; - application/rss+xml rss; - - text/mathml mml; - text/plain txt; - text/vnd.sun.j2me.app-descriptor jad; - text/vnd.wap.wml wml; - text/x-component htc; - - image/png png; - image/tiff tif tiff; - image/vnd.wap.wbmp wbmp; - image/x-icon ico; - image/x-jng jng; - image/x-ms-bmp bmp; - image/svg+xml svg svgz; - image/webp webp; - - application/java-archive jar war ear; - application/mac-binhex40 hqx; - application/msword doc; - application/pdf pdf; - application/postscript ps eps ai; - application/rtf rtf; - application/vnd.ms-excel xls; - application/vnd.ms-powerpoint ppt; - application/vnd.wap.wmlc wmlc; - application/vnd.google-earth.kml+xml kml; - application/vnd.google-earth.kmz kmz; - application/x-7z-compressed 7z; - application/x-cocoa cco; - application/x-java-archive-diff jardiff; - application/x-java-jnlp-file jnlp; - application/x-makeself run; - application/x-perl pl pm; - application/x-pilot prc pdb; - application/x-rar-compressed rar; - application/x-redhat-package-manager rpm; - application/x-sea sea; - application/x-shockwave-flash swf; - application/x-stuffit sit; - application/x-tcl tcl tk; - application/x-x509-ca-cert der pem crt; - application/x-xpinstall xpi; - application/xhtml+xml xhtml; - application/zip zip; - - application/octet-stream bin exe dll; - application/octet-stream deb; - application/octet-stream dmg; - application/octet-stream eot; - application/octet-stream iso img; - application/octet-stream msi msp msm; - - audio/midi mid midi kar; - audio/mpeg mp3; - audio/ogg ogg; - audio/x-m4a m4a; - audio/x-realaudio ra; - - video/3gpp 3gpp 3gp; - video/mp4 mp4; - video/mpeg mpeg mpg; - video/quicktime mov; - video/webm webm; - video/x-flv flv; - video/x-m4v m4v; - video/x-mng mng; - video/x-ms-asf asx asf; - video/x-ms-wmv wmv; - video/x-msvideo avi; -} diff --git a/vendor/workerman/workerman/Protocols/ProtocolInterface.php b/vendor/workerman/workerman/Protocols/ProtocolInterface.php deleted file mode 100644 index 9afe98498..000000000 --- a/vendor/workerman/workerman/Protocols/ProtocolInterface.php +++ /dev/null @@ -1,52 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Protocols; - -use Workerman\Connection\ConnectionInterface; - -/** - * Protocol interface - */ -interface ProtocolInterface -{ - /** - * Check the integrity of the package. - * Please return the length of package. - * If length is unknow please return 0 that mean wating more data. - * If the package has something wrong please return false the connection will be closed. - * - * @param ConnectionInterface $connection - * @param string $recv_buffer - * @return int|false - */ - public static function input($recv_buffer, ConnectionInterface $connection); - - /** - * Decode package and emit onMessage($message) callback, $message is the result that decode returned. - * - * @param ConnectionInterface $connection - * @param string $recv_buffer - * @return mixed - */ - public static function decode($recv_buffer, ConnectionInterface $connection); - - /** - * Encode package brefore sending to client. - * - * @param ConnectionInterface $connection - * @param mixed $data - * @return string - */ - public static function encode($data, ConnectionInterface $connection); -} diff --git a/vendor/workerman/workerman/Protocols/Text.php b/vendor/workerman/workerman/Protocols/Text.php deleted file mode 100644 index 189baf416..000000000 --- a/vendor/workerman/workerman/Protocols/Text.php +++ /dev/null @@ -1,70 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Protocols; - -use Workerman\Connection\TcpConnection; - -/** - * Text Protocol. - */ -class Text -{ - /** - * Check the integrity of the package. - * - * @param string $buffer - * @param TcpConnection $connection - * @return int - */ - public static function input($buffer, TcpConnection $connection) - { - // Judge whether the package length exceeds the limit. - if (strlen($buffer) >= TcpConnection::$maxPackageSize) { - $connection->close(); - return 0; - } - // Find the position of "\n". - $pos = strpos($buffer, "\n"); - // No "\n", packet length is unknown, continue to wait for the data so return 0. - if ($pos === false) { - return 0; - } - // Return the current package length. - return $pos + 1; - } - - /** - * Encode. - * - * @param string $buffer - * @return string - */ - public static function encode($buffer) - { - // Add "\n" - return $buffer . "\n"; - } - - /** - * Decode. - * - * @param string $buffer - * @return string - */ - public static function decode($buffer) - { - // Remove "\n" - return trim($buffer); - } -} diff --git a/vendor/workerman/workerman/Protocols/Websocket.php b/vendor/workerman/workerman/Protocols/Websocket.php deleted file mode 100644 index 2ab5635da..000000000 --- a/vendor/workerman/workerman/Protocols/Websocket.php +++ /dev/null @@ -1,473 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Protocols; - -use Workerman\Connection\ConnectionInterface; -use Workerman\Connection\TcpConnection; -use Workerman\Worker; - -/** - * WebSocket protocol. - */ -class Websocket implements \Workerman\Protocols\ProtocolInterface -{ - /** - * Websocket blob type. - * - * @var string - */ - const BINARY_TYPE_BLOB = "\x81"; - - /** - * Websocket arraybuffer type. - * - * @var string - */ - const BINARY_TYPE_ARRAYBUFFER = "\x82"; - - /** - * Check the integrity of the package. - * - * @param string $buffer - * @param ConnectionInterface $connection - * @return int - */ - public static function input($buffer, ConnectionInterface $connection) - { - // Receive length. - $recv_len = strlen($buffer); - // We need more data. - if ($recv_len < 2) { - return 0; - } - - // Has not yet completed the handshake. - if (empty($connection->websocketHandshake)) { - return static::dealHandshake($buffer, $connection); - } - - // Buffer websocket frame data. - if ($connection->websocketCurrentFrameLength) { - // We need more frame data. - if ($connection->websocketCurrentFrameLength > $recv_len) { - // Return 0, because it is not clear the full packet length, waiting for the frame of fin=1. - return 0; - } - } else { - $firstbyte = ord($buffer[0]); - $secondbyte = ord($buffer[1]); - $data_len = $secondbyte & 127; - $is_fin_frame = $firstbyte >> 7; - $masked = $secondbyte >> 7; - $opcode = $firstbyte & 0xf; - switch ($opcode) { - case 0x0: - break; - // Blob type. - case 0x1: - break; - // Arraybuffer type. - case 0x2: - break; - // Close package. - case 0x8: - // Try to emit onWebSocketClose callback. - if (isset($connection->onWebSocketClose)) { - try { - call_user_func($connection->onWebSocketClose, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } // Close connection. - else { - $connection->close(); - } - return 0; - // Ping package. - case 0x9: - // Try to emit onWebSocketPing callback. - if (isset($connection->onWebSocketPing)) { - try { - call_user_func($connection->onWebSocketPing, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } // Send pong package to client. - else { - $connection->send(pack('H*', '8a00'), true); - } - - // Consume data from receive buffer. - if (!$data_len) { - $head_len = $masked ? 6 : 2; - $connection->consumeRecvBuffer($head_len); - if ($recv_len > $head_len) { - return static::input(substr($buffer, $head_len), $connection); - } - return 0; - } - break; - // Pong package. - case 0xa: - // Try to emit onWebSocketPong callback. - if (isset($connection->onWebSocketPong)) { - try { - call_user_func($connection->onWebSocketPong, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - // Consume data from receive buffer. - if (!$data_len) { - $head_len = $masked ? 6 : 2; - $connection->consumeRecvBuffer($head_len); - if ($recv_len > $head_len) { - return static::input(substr($buffer, $head_len), $connection); - } - return 0; - } - break; - // Wrong opcode. - default : - echo "error opcode $opcode and close websocket connection. Buffer:" . bin2hex($buffer) . "\n"; - $connection->close(); - return 0; - } - - // Calculate packet length. - $head_len = 6; - if ($data_len === 126) { - $head_len = 8; - if ($head_len > $recv_len) { - return 0; - } - $pack = unpack('nn/ntotal_len', $buffer); - $data_len = $pack['total_len']; - } else { - if ($data_len === 127) { - $head_len = 14; - if ($head_len > $recv_len) { - return 0; - } - $arr = unpack('n/N2c', $buffer); - $data_len = $arr['c1']*4294967296 + $arr['c2']; - } - } - $current_frame_length = $head_len + $data_len; - - $total_package_size = strlen($connection->websocketDataBuffer) + $current_frame_length; - if ($total_package_size > TcpConnection::$maxPackageSize) { - echo "error package. package_length=$total_package_size\n"; - $connection->close(); - return 0; - } - - if ($is_fin_frame) { - return $current_frame_length; - } else { - $connection->websocketCurrentFrameLength = $current_frame_length; - } - } - - // Received just a frame length data. - if ($connection->websocketCurrentFrameLength === $recv_len) { - static::decode($buffer, $connection); - $connection->consumeRecvBuffer($connection->websocketCurrentFrameLength); - $connection->websocketCurrentFrameLength = 0; - return 0; - } // The length of the received data is greater than the length of a frame. - elseif ($connection->websocketCurrentFrameLength < $recv_len) { - static::decode(substr($buffer, 0, $connection->websocketCurrentFrameLength), $connection); - $connection->consumeRecvBuffer($connection->websocketCurrentFrameLength); - $current_frame_length = $connection->websocketCurrentFrameLength; - $connection->websocketCurrentFrameLength = 0; - // Continue to read next frame. - return static::input(substr($buffer, $current_frame_length), $connection); - } // The length of the received data is less than the length of a frame. - else { - return 0; - } - } - - /** - * Websocket encode. - * - * @param string $buffer - * @param ConnectionInterface $connection - * @return string - */ - public static function encode($buffer, ConnectionInterface $connection) - { - if (!is_scalar($buffer)) { - throw new \Exception("You can't send(" . gettype($buffer) . ") to client, you need to convert it to a string. "); - } - $len = strlen($buffer); - if (empty($connection->websocketType)) { - $connection->websocketType = static::BINARY_TYPE_BLOB; - } - - $first_byte = $connection->websocketType; - - if ($len <= 125) { - $encode_buffer = $first_byte . chr($len) . $buffer; - } else { - if ($len <= 65535) { - $encode_buffer = $first_byte . chr(126) . pack("n", $len) . $buffer; - } else { - $encode_buffer = $first_byte . chr(127) . pack("xxxxN", $len) . $buffer; - } - } - - // Handshake not completed so temporary buffer websocket data waiting for send. - if (empty($connection->websocketHandshake)) { - if (empty($connection->tmpWebsocketData)) { - $connection->tmpWebsocketData = ''; - } - // If buffer has already full then discard the current package. - if (strlen($connection->tmpWebsocketData) > $connection->maxSendBufferSize) { - if ($connection->onError) { - try { - call_user_func($connection->onError, $connection, WORKERMAN_SEND_FAIL, 'send buffer full and drop package'); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - return ''; - } - $connection->tmpWebsocketData .= $encode_buffer; - // Check buffer is full. - if ($connection->maxSendBufferSize <= strlen($connection->tmpWebsocketData)) { - if ($connection->onBufferFull) { - try { - call_user_func($connection->onBufferFull, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - } - - // Return empty string. - return ''; - } - - return $encode_buffer; - } - - /** - * Websocket decode. - * - * @param string $buffer - * @param ConnectionInterface $connection - * @return string - */ - public static function decode($buffer, ConnectionInterface $connection) - { - $masks = $data = $decoded = null; - $len = ord($buffer[1]) & 127; - if ($len === 126) { - $masks = substr($buffer, 4, 4); - $data = substr($buffer, 8); - } else { - if ($len === 127) { - $masks = substr($buffer, 10, 4); - $data = substr($buffer, 14); - } else { - $masks = substr($buffer, 2, 4); - $data = substr($buffer, 6); - } - } - for ($index = 0; $index < strlen($data); $index++) { - $decoded .= $data[$index] ^ $masks[$index % 4]; - } - if ($connection->websocketCurrentFrameLength) { - $connection->websocketDataBuffer .= $decoded; - return $connection->websocketDataBuffer; - } else { - if ($connection->websocketDataBuffer !== '') { - $decoded = $connection->websocketDataBuffer . $decoded; - $connection->websocketDataBuffer = ''; - } - return $decoded; - } - } - - /** - * Websocket handshake. - * - * @param string $buffer - * @param \Workerman\Connection\TcpConnection $connection - * @return int - */ - protected static function dealHandshake($buffer, $connection) - { - // HTTP protocol. - if (0 === strpos($buffer, 'GET')) { - // Find \r\n\r\n. - $heder_end_pos = strpos($buffer, "\r\n\r\n"); - if (!$heder_end_pos) { - return 0; - } - $header_length = $heder_end_pos + 4; - - // Get Sec-WebSocket-Key. - $Sec_WebSocket_Key = ''; - if (preg_match("/Sec-WebSocket-Key: *(.*?)\r\n/i", $buffer, $match)) { - $Sec_WebSocket_Key = $match[1]; - } else { - $connection->send("HTTP/1.1 400 Bad Request\r\n\r\n400 Bad Request
Sec-WebSocket-Key not found.
This is a WebSocket service and can not be accessed via HTTP.
See http://wiki.workerman.net/Error1 for detail.", - true); - $connection->close(); - return 0; - } - // Calculation websocket key. - $new_key = base64_encode(sha1($Sec_WebSocket_Key . "258EAFA5-E914-47DA-95CA-C5AB0DC85B11", true)); - // Handshake response data. - $handshake_message = "HTTP/1.1 101 Switching Protocols\r\n"; - $handshake_message .= "Upgrade: websocket\r\n"; - $handshake_message .= "Sec-WebSocket-Version: 13\r\n"; - $handshake_message .= "Connection: Upgrade\r\n"; - $handshake_message .= "Server: workerman/".Worker::VERSION."\r\n"; - $handshake_message .= "Sec-WebSocket-Accept: " . $new_key . "\r\n\r\n"; - // Mark handshake complete.. - $connection->websocketHandshake = true; - // Websocket data buffer. - $connection->websocketDataBuffer = ''; - // Current websocket frame length. - $connection->websocketCurrentFrameLength = 0; - // Current websocket frame data. - $connection->websocketCurrentFrameBuffer = ''; - // Consume handshake data. - $connection->consumeRecvBuffer($header_length); - // Send handshake response. - $connection->send($handshake_message, true); - - // There are data waiting to be sent. - if (!empty($connection->tmpWebsocketData)) { - $connection->send($connection->tmpWebsocketData, true); - $connection->tmpWebsocketData = ''; - } - // blob or arraybuffer - if (empty($connection->websocketType)) { - $connection->websocketType = static::BINARY_TYPE_BLOB; - } - // Try to emit onWebSocketConnect callback. - if (isset($connection->onWebSocketConnect)) { - static::parseHttpHeader($buffer); - try { - call_user_func($connection->onWebSocketConnect, $connection, $buffer); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - if (!empty($_SESSION) && class_exists('\GatewayWorker\Lib\Context')) { - $connection->session = \GatewayWorker\Lib\Context::sessionEncode($_SESSION); - } - $_GET = $_SERVER = $_SESSION = $_COOKIE = array(); - } - if (strlen($buffer) > $header_length) { - return static::input(substr($buffer, $header_length), $connection); - } - return 0; - } // Is flash policy-file-request. - elseif (0 === strpos($buffer, 'send($policy_xml, true); - $connection->consumeRecvBuffer(strlen($buffer)); - return 0; - } - // Bad websocket handshake request. - $connection->send("HTTP/1.1 400 Bad Request\r\n\r\n400 Bad Request
Invalid handshake data for websocket.
See http://wiki.workerman.net/Error1 for detail.", - true); - $connection->close(); - return 0; - } - - /** - * Parse http header. - * - * @param string $buffer - * @return void - */ - protected static function parseHttpHeader($buffer) - { - // Parse headers. - list($http_header, ) = explode("\r\n\r\n", $buffer, 2); - $header_data = explode("\r\n", $http_header); - - if ($_SERVER) { - $_SERVER = array(); - } - - list($_SERVER['REQUEST_METHOD'], $_SERVER['REQUEST_URI'], $_SERVER['SERVER_PROTOCOL']) = explode(' ', - $header_data[0]); - - unset($header_data[0]); - foreach ($header_data as $content) { - // \r\n\r\n - if (empty($content)) { - continue; - } - list($key, $value) = explode(':', $content, 2); - $key = str_replace('-', '_', strtoupper($key)); - $value = trim($value); - $_SERVER['HTTP_' . $key] = $value; - switch ($key) { - // HTTP_HOST - case 'HOST': - $tmp = explode(':', $value); - $_SERVER['SERVER_NAME'] = $tmp[0]; - if (isset($tmp[1])) { - $_SERVER['SERVER_PORT'] = $tmp[1]; - } - break; - // cookie - case 'COOKIE': - parse_str(str_replace('; ', '&', $_SERVER['HTTP_COOKIE']), $_COOKIE); - break; - } - } - - // QUERY_STRING - $_SERVER['QUERY_STRING'] = parse_url($_SERVER['REQUEST_URI'], PHP_URL_QUERY); - if ($_SERVER['QUERY_STRING']) { - // $GET - parse_str($_SERVER['QUERY_STRING'], $_GET); - } else { - $_SERVER['QUERY_STRING'] = ''; - } - } -} diff --git a/vendor/workerman/workerman/Protocols/Ws.php b/vendor/workerman/workerman/Protocols/Ws.php deleted file mode 100644 index da1451f40..000000000 --- a/vendor/workerman/workerman/Protocols/Ws.php +++ /dev/null @@ -1,433 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman\Protocols; - -use Workerman\Worker; -use Workerman\Lib\Timer; -use Workerman\Connection\TcpConnection; - -/** - * Websocket protocol for client. - */ -class Ws -{ - /** - * Websocket blob type. - * - * @var string - */ - const BINARY_TYPE_BLOB = "\x81"; - - /** - * Websocket arraybuffer type. - * - * @var string - */ - const BINARY_TYPE_ARRAYBUFFER = "\x82"; - - /** - * Check the integrity of the package. - * - * @param string $buffer - * @param ConnectionInterface $connection - * @return int - */ - public static function input($buffer, $connection) - { - if (empty($connection->handshakeStep)) { - echo "recv data before handshake. Buffer:" . bin2hex($buffer) . "\n"; - return false; - } - // Recv handshake response - if ($connection->handshakeStep === 1) { - return self::dealHandshake($buffer, $connection); - } - $recv_len = strlen($buffer); - if ($recv_len < 2) { - return 0; - } - // Buffer websocket frame data. - if ($connection->websocketCurrentFrameLength) { - // We need more frame data. - if ($connection->websocketCurrentFrameLength > $recv_len) { - // Return 0, because it is not clear the full packet length, waiting for the frame of fin=1. - return 0; - } - } else { - - $firstbyte = ord($buffer[0]); - $secondbyte = ord($buffer[1]); - $data_len = $secondbyte & 127; - $is_fin_frame = $firstbyte >> 7; - $masked = $secondbyte >> 7; - $opcode = $firstbyte & 0xf; - - switch ($opcode) { - case 0x0: - break; - // Blob type. - case 0x1: - break; - // Arraybuffer type. - case 0x2: - break; - // Close package. - case 0x8: - // Try to emit onWebSocketClose callback. - if (isset($connection->onWebSocketClose)) { - try { - call_user_func($connection->onWebSocketClose, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } // Close connection. - else { - $connection->close(); - } - return 0; - // Ping package. - case 0x9: - // Try to emit onWebSocketPing callback. - if (isset($connection->onWebSocketPing)) { - try { - call_user_func($connection->onWebSocketPing, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } // Send pong package to client. - else { - $connection->send(pack('H*', '8a00'), true); - } - // Consume data from receive buffer. - if (!$data_len) { - $head_len = $masked ? 6 : 2; - $connection->consumeRecvBuffer($head_len); - if ($recv_len > $head_len) { - return self::input(substr($buffer, $head_len), $connection); - } - return 0; - } - break; - // Pong package. - case 0xa: - // Try to emit onWebSocketPong callback. - if (isset($connection->onWebSocketPong)) { - try { - call_user_func($connection->onWebSocketPong, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - // Consume data from receive buffer. - if (!$data_len) { - $head_len = $masked ? 6 : 2; - $connection->consumeRecvBuffer($head_len); - if ($recv_len > $head_len) { - return self::input(substr($buffer, $head_len), $connection); - } - return 0; - } - break; - // Wrong opcode. - default : - echo "error opcode $opcode and close websocket connection. Buffer:" . $buffer . "\n"; - $connection->close(); - return 0; - } - // Calculate packet length. - if ($data_len === 126) { - if (strlen($buffer) < 6) { - return 0; - } - $pack = unpack('nn/ntotal_len', $buffer); - $current_frame_length = $pack['total_len'] + 4; - } else if ($data_len === 127) { - if (strlen($buffer) < 10) { - return 0; - } - $arr = unpack('n/N2c', $buffer); - $current_frame_length = $arr['c1']*4294967296 + $arr['c2'] + 10; - } else { - $current_frame_length = $data_len + 2; - } - - $total_package_size = strlen($connection->websocketDataBuffer) + $current_frame_length; - if ($total_package_size > TcpConnection::$maxPackageSize) { - echo "error package. package_length=$total_package_size\n"; - $connection->close(); - return 0; - } - - if ($is_fin_frame) { - return $current_frame_length; - } else { - $connection->websocketCurrentFrameLength = $current_frame_length; - } - } - // Received just a frame length data. - if ($connection->websocketCurrentFrameLength === $recv_len) { - self::decode($buffer, $connection); - $connection->consumeRecvBuffer($connection->websocketCurrentFrameLength); - $connection->websocketCurrentFrameLength = 0; - return 0; - } // The length of the received data is greater than the length of a frame. - elseif ($connection->websocketCurrentFrameLength < $recv_len) { - self::decode(substr($buffer, 0, $connection->websocketCurrentFrameLength), $connection); - $connection->consumeRecvBuffer($connection->websocketCurrentFrameLength); - $current_frame_length = $connection->websocketCurrentFrameLength; - $connection->websocketCurrentFrameLength = 0; - // Continue to read next frame. - return self::input(substr($buffer, $current_frame_length), $connection); - } // The length of the received data is less than the length of a frame. - else { - return 0; - } - } - - /** - * Websocket encode. - * - * @param string $buffer - * @param ConnectionInterface $connection - * @return string - */ - public static function encode($payload, $connection) - { - if (empty($connection->websocketType)) { - $connection->websocketType = self::BINARY_TYPE_BLOB; - } - $payload = (string)$payload; - if (empty($connection->handshakeStep)) { - self::sendHandshake($connection); - } - $mask = 1; - $mask_key = "\x00\x00\x00\x00"; - - $pack = ''; - $length = $length_flag = strlen($payload); - if (65535 < $length) { - $pack = pack('NN', ($length & 0xFFFFFFFF00000000) >> 32, $length & 0x00000000FFFFFFFF); - $length_flag = 127; - } else if (125 < $length) { - $pack = pack('n*', $length); - $length_flag = 126; - } - - $head = ($mask << 7) | $length_flag; - $head = $connection->websocketType . chr($head) . $pack; - - $frame = $head . $mask_key; - // append payload to frame: - for ($i = 0; $i < $length; $i++) { - $frame .= $payload[$i] ^ $mask_key[$i % 4]; - } - if ($connection->handshakeStep === 1) { - // If buffer has already full then discard the current package. - if (strlen($connection->tmpWebsocketData) > $connection->maxSendBufferSize) { - if ($connection->onError) { - try { - call_user_func($connection->onError, $connection, WORKERMAN_SEND_FAIL, 'send buffer full and drop package'); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - return ''; - } - $connection->tmpWebsocketData = $connection->tmpWebsocketData . $frame; - // Check buffer is full. - if ($connection->maxSendBufferSize <= strlen($connection->tmpWebsocketData)) { - if ($connection->onBufferFull) { - try { - call_user_func($connection->onBufferFull, $connection); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - } - return ''; - } - return $frame; - } - - /** - * Websocket decode. - * - * @param string $buffer - * @param ConnectionInterface $connection - * @return string - */ - public static function decode($bytes, $connection) - { - $masked = $bytes[1] >> 7; - $data_length = $masked ? ord($bytes[1]) & 127 : ord($bytes[1]); - $decoded_data = ''; - if ($masked === true) { - if ($data_length === 126) { - $mask = substr($bytes, 4, 4); - $coded_data = substr($bytes, 8); - } else if ($data_length === 127) { - $mask = substr($bytes, 10, 4); - $coded_data = substr($bytes, 14); - } else { - $mask = substr($bytes, 2, 4); - $coded_data = substr($bytes, 6); - } - for ($i = 0; $i < strlen($coded_data); $i++) { - $decoded_data .= $coded_data[$i] ^ $mask[$i % 4]; - } - } else { - if ($data_length === 126) { - $decoded_data = substr($bytes, 4); - } else if ($data_length === 127) { - $decoded_data = substr($bytes, 10); - } else { - $decoded_data = substr($bytes, 2); - } - } - if ($connection->websocketCurrentFrameLength) { - $connection->websocketDataBuffer .= $decoded_data; - return $connection->websocketDataBuffer; - } else { - if ($connection->websocketDataBuffer !== '') { - $decoded_data = $connection->websocketDataBuffer . $decoded_data; - $connection->websocketDataBuffer = ''; - } - return $decoded_data; - } - } - - /** - * Send websocket handshake data. - * - * @return void - */ - public static function onConnect($connection) - { - self::sendHandshake($connection); - } - - /** - * Clean - * - * @param $connection - */ - public static function onClose($connection) - { - $connection->handshakeStep = null; - $connection->websocketCurrentFrameLength = 0; - $connection->tmpWebsocketData = ''; - $connection->websocketDataBuffer = ''; - if (!empty($connection->websocketPingTimer)) { - Timer::del($connection->websocketPingTimer); - $connection->websocketPingTimer = null; - } - } - - /** - * Send websocket handshake. - * - * @param \Workerman\Connection\TcpConnection $connection - * @return void - */ - public static function sendHandshake($connection) - { - if (!empty($connection->handshakeStep)) { - return; - } - // Get Host. - $port = $connection->getRemotePort(); - $host = $port === 80 ? $connection->getRemoteHost() : $connection->getRemoteHost() . ':' . $port; - // Handshake header. - $header = 'GET ' . $connection->getRemoteURI() . " HTTP/1.1\r\n". - "Host: $host\r\n". - "Connection: Upgrade\r\n". - "Upgrade: websocket\r\n". - "Origin: ". (isset($connection->websocketOrigin) ? $connection->websocketOrigin : '*') ."\r\n". - "Sec-WebSocket-Version: 13\r\n". - "Sec-WebSocket-Key: ".base64_encode(sha1(uniqid(mt_rand(), true), true))."\r\n\r\n"; - $connection->send($header, true); - $connection->handshakeStep = 1; - $connection->websocketCurrentFrameLength = 0; - $connection->websocketDataBuffer = ''; - $connection->tmpWebsocketData = ''; - } - - /** - * Websocket handshake. - * - * @param string $buffer - * @param \Workerman\Connection\TcpConnection $connection - * @return int - */ - public static function dealHandshake($buffer, $connection) - { - $pos = strpos($buffer, "\r\n\r\n"); - if ($pos) { - // handshake complete - $connection->handshakeStep = 2; - $handshake_response_length = $pos + 4; - // Try to emit onWebSocketConnect callback. - if (isset($connection->onWebSocketConnect)) { - try { - call_user_func($connection->onWebSocketConnect, $connection, substr($buffer, 0, $handshake_response_length)); - } catch (\Exception $e) { - Worker::log($e); - exit(250); - } catch (\Error $e) { - Worker::log($e); - exit(250); - } - } - // Headbeat. - if (!empty($connection->websocketPingInterval)) { - $connection->websocketPingTimer = Timer::add($connection->websocketPingInterval, function() use ($connection){ - if (false === $connection->send(pack('H*', '8900'), true)) { - Timer::del($connection->websocketPingTimer); - $connection->websocketPingTimer = null; - } - }); - } - - $connection->consumeRecvBuffer($handshake_response_length); - if (!empty($connection->tmpWebsocketData)) { - $connection->send($connection->tmpWebsocketData, true); - $connection->tmpWebsocketData = ''; - } - if (strlen($buffer) > $handshake_response_length) { - return self::input(substr($buffer, $handshake_response_length), $connection); - } - } - return 0; - } -} diff --git a/vendor/workerman/workerman/README.md b/vendor/workerman/workerman/README.md deleted file mode 100644 index 17b687dec..000000000 --- a/vendor/workerman/workerman/README.md +++ /dev/null @@ -1,636 +0,0 @@ -# Workerman -[![Gitter](https://badges.gitter.im/walkor/Workerman.svg)](https://gitter.im/walkor/Workerman?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=body_badge) - -## What is it -Workerman is an asynchronous event driven PHP framework with high performance for easily building fast, scalable network applications.Supports HTTP, Websocket and other custom protocols. Supports libevent, HHVM, [ReactPHP](https://github.com/reactphp/react). - -## Requires - -PHP 5.3 or Higher -A POSIX compatible operating system (Linux, OSX, BSD) -POSIX and PCNTL extensions for PHP - -## Installation - -``` -composer require workerman/workerman -``` - -## Basic Usage - -### A websocket server -```php -count = 4; - -// Emitted when new connection come -$ws_worker->onConnect = function($connection) -{ - echo "New connection\n"; - }; - -// Emitted when data received -$ws_worker->onMessage = function($connection, $data) -{ - // Send hello $data - $connection->send('hello ' . $data); -}; - -// Emitted when connection closed -$ws_worker->onClose = function($connection) -{ - echo "Connection closed\n"; -}; - -// Run worker -Worker::runAll(); -``` - -### An http server -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\Worker; - -// #### http worker #### -$http_worker = new Worker("http://0.0.0.0:2345"); - -// 4 processes -$http_worker->count = 4; - -// Emitted when data received -$http_worker->onMessage = function($connection, $data) -{ - // $_GET, $_POST, $_COOKIE, $_SESSION, $_SERVER, $_FILES are available - var_dump($_GET, $_POST, $_COOKIE, $_SESSION, $_SERVER, $_FILES); - // send data to client - $connection->send("hello world \n"); -}; - -// run all workers -Worker::runAll(); -``` - -### A WebServer -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\WebServer; -use Workerman\Worker; - -// WebServer -$web = new WebServer("http://0.0.0.0:80"); - -// 4 processes -$web->count = 4; - -// Set the root of domains -$web->addRoot('www.your_domain.com', '/your/path/Web'); -$web->addRoot('www.another_domain.com', '/another/path/Web'); -// run all workers -Worker::runAll(); -``` - -### A tcp server -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\Worker; - -// #### create socket and listen 1234 port #### -$tcp_worker = new Worker("tcp://0.0.0.0:1234"); - -// 4 processes -$tcp_worker->count = 4; - -// Emitted when new connection come -$tcp_worker->onConnect = function($connection) -{ - echo "New Connection\n"; -}; - -// Emitted when data received -$tcp_worker->onMessage = function($connection, $data) -{ - // send data to client - $connection->send("hello $data \n"); -}; - -// Emitted when new connection come -$tcp_worker->onClose = function($connection) -{ - echo "Connection closed\n"; -}; - -Worker::runAll(); -``` - -### Custom protocol -Protocols/MyTextProtocol.php -```php -namespace Protocols; -/** - * User defined protocol - * Format Text+"\n" - */ -class MyTextProtocol -{ - public static function input($recv_buffer) - { - // Find the position of the first occurrence of "\n" - $pos = strpos($recv_buffer, "\n"); - // Not a complete package. Return 0 because the length of package can not be calculated - if($pos === false) - { - return 0; - } - // Return length of the package - return $pos+1; - } - - public static function decode($recv_buffer) - { - return trim($recv_buffer); - } - - public static function encode($data) - { - return $data."\n"; - } -} -``` - -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\Worker; - -// #### MyTextProtocol worker #### -$text_worker = new Worker("MyTextProtocol://0.0.0.0:5678"); - -$text_worker->onConnect = function($connection) -{ - echo "New connection\n"; -}; - -$text_worker->onMessage = function($connection, $data) -{ - // send data to client - $connection->send("hello world \n"); -}; - -$text_worker->onClose = function($connection) -{ - echo "Connection closed\n"; -}; - -// run all workers -Worker::runAll(); -``` - -### Timer -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\Worker; -use Workerman\Lib\Timer; - -$task = new Worker(); -$task->onWorkerStart = function($task) -{ - // 2.5 seconds - $time_interval = 2.5; - $timer_id = Timer::add($time_interval, - function() - { - echo "Timer run\n"; - } - ); -}; - -// run all workers -Worker::runAll(); -``` - -### AsyncTcpConnection (tcp/ws/text/frame etc...) -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\Worker; -use Workerman\Connection\AsyncTcpConnection; - -$worker = new Worker(); -$worker->onWorkerStart = function() -{ - // Websocket protocol for client. - $ws_connection = new AsyncTcpConnection("ws://echo.websocket.org:80"); - $ws_connection->onConnect = function($connection){ - $connection->send('hello'); - }; - $ws_connection->onMessage = function($connection, $data){ - echo "recv: $data\n"; - }; - $ws_connection->onError = function($connection, $code, $msg){ - echo "error: $msg\n"; - }; - $ws_connection->onClose = function($connection){ - echo "connection closed\n"; - }; - $ws_connection->connect(); -}; -Worker::runAll(); -``` - -### Async Mysql of ReactPHP -``` -composer require react/mysql -``` - -```php -onWorkerStart = function() { - global $mysql; - $loop = Worker::getEventLoop(); - $mysql = new React\MySQL\Connection($loop, array( - 'host' => '127.0.0.1', - 'dbname' => 'dbname', - 'user' => 'user', - 'passwd' => 'passwd', - )); - $mysql->on('error', function($e){ - echo $e; - }); - $mysql->connect(function ($e) { - if($e) { - echo $e; - } else { - echo "connect success\n"; - } - }); -}; -$worker->onMessage = function($connection, $data) { - global $mysql; - $mysql->query('show databases' /*trim($data)*/, function ($command, $mysql) use ($connection) { - if ($command->hasError()) { - $error = $command->getError(); - } else { - $results = $command->resultRows; - $fields = $command->resultFields; - $connection->send(json_encode($results)); - } - }); -}; -Worker::runAll(); -``` - -### Async Redis of ReactPHP -``` -composer require clue/redis-react -``` - -```php -onWorkerStart = function() { - global $factory; - $loop = Worker::getEventLoop(); - $factory = new Factory($loop); -}; - -$worker->onMessage = function($connection, $data) { - global $factory; - $factory->createClient('localhost:6379')->then(function (Client $client) use ($connection) { - $client->set('greeting', 'Hello world'); - $client->append('greeting', '!'); - - $client->get('greeting')->then(function ($greeting) use ($connection){ - // Hello world! - echo $greeting . PHP_EOL; - $connection->send($greeting); - }); - - $client->incr('invocation')->then(function ($n) use ($connection){ - echo 'This is invocation #' . $n . PHP_EOL; - $connection->send($n); - }); - }); -}; - -Worker::runAll(); -``` - -### Aysnc dns of ReactPHP -``` -composer require react/dns -``` - -```php -require_once __DIR__ . '/vendor/autoload.php'; -use Workerman\Worker; -$worker = new Worker('tcp://0.0.0.0:6161'); -$worker->onWorkerStart = function() { - global $dns; - // Get event-loop. - $loop = Worker::getEventLoop(); - $factory = new React\Dns\Resolver\Factory(); - $dns = $factory->create('8.8.8.8', $loop); -}; -$worker->onMessage = function($connection, $host) { - global $dns; - $host = trim($host); - $dns->resolve($host)->then(function($ip) use($host, $connection) { - $connection->send("$host: $ip"); - },function($e) use($host, $connection){ - $connection->send("$host: {$e->getMessage()}"); - }); -}; - -Worker::runAll(); -``` - -### Http client of ReactPHP -``` -composer require react/http-client -``` - -```php -onWorkerStart = function() { - global $client; - $loop = Worker::getEventLoop(); - $factory = new React\Dns\Resolver\Factory(); - $dns = $factory->createCached('8.8.8.8', $loop); - $factory = new React\HttpClient\Factory(); - $client = $factory->create($loop, $dns); -}; - -$worker->onMessage = function($connection, $host) { - global $client; - $request = $client->request('GET', trim($host)); - $request->on('error', function(Exception $e) use ($connection) { - $connection->send($e); - }); - $request->on('response', function ($response) use ($connection) { - $response->on('data', function ($data, $response) use ($connection) { - $connection->send($data); - }); - }); - $request->end(); -}; - -Worker::runAll(); -``` - -### ZMQ of ReactPHP -``` -composer require react/zmq -``` - -```php -onWorkerStart = function() { - global $pull; - $loop = Worker::getEventLoop(); - $context = new React\ZMQ\Context($loop); - $pull = $context->getSocket(ZMQ::SOCKET_PULL); - $pull->bind('tcp://127.0.0.1:5555'); - - $pull->on('error', function ($e) { - var_dump($e->getMessage()); - }); - - $pull->on('message', function ($msg) { - echo "Received: $msg\n"; - }); -}; - -Worker::runAll(); -``` - -### STOMP of ReactPHP -``` -composer require react/stomp -``` - -```php -onWorkerStart = function() { - global $client; - $loop = Worker::getEventLoop(); - $factory = new React\Stomp\Factory($loop); - $client = $factory->createClient(array('vhost' => '/', 'login' => 'guest', 'passcode' => 'guest')); - - $client - ->connect() - ->then(function ($client) use ($loop) { - $client->subscribe('/topic/foo', function ($frame) { - echo "Message received: {$frame->body}\n"; - }); - }); -}; - -Worker::runAll(); -``` - - - -## Available commands -```php test.php start ``` -```php test.php start -d ``` -![workerman start](http://www.workerman.net/img/workerman-start.png) -```php test.php status ``` -![workerman satus](http://www.workerman.net/img/workerman-status.png?a=123) -```php test.php stop ``` -```php test.php restart ``` -```php test.php reload ``` - -## Documentation - -中文主页:[http://www.workerman.net](http://www.workerman.net) - -中文文档: [http://doc3.workerman.net](http://doc3.workerman.net) - -Documentation:[https://github.com/walkor/workerman-manual](https://github.com/walkor/workerman-manual/blob/master/english/src/SUMMARY.md) - -# Benchmarks -``` -CPU: Intel(R) Core(TM) i3-3220 CPU @ 3.30GHz and 4 processors totally -Memory: 8G -OS: Ubuntu 14.04 LTS -Software: ab -PHP: 5.5.9 -``` - -**Codes** -```php -count=3; -$worker->onMessage = function($connection, $data) -{ - $connection->send("HTTP/1.1 200 OK\r\nConnection: keep-alive\r\nServer: workerman\r\nContent-Length: 5\r\n\r\nhello"); -}; -Worker::runAll(); -``` -**Result** - -```shell -ab -n1000000 -c100 -k http://127.0.0.1:1234/ -This is ApacheBench, Version 2.3 <$Revision: 1528965 $> -Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ -Licensed to The Apache Software Foundation, http://www.apache.org/ - -Benchmarking 127.0.0.1 (be patient) -Completed 100000 requests -Completed 200000 requests -Completed 300000 requests -Completed 400000 requests -Completed 500000 requests -Completed 600000 requests -Completed 700000 requests -Completed 800000 requests -Completed 900000 requests -Completed 1000000 requests -Finished 1000000 requests - - -Server Software: workerman/3.1.4 -Server Hostname: 127.0.0.1 -Server Port: 1234 - -Document Path: / -Document Length: 5 bytes - -Concurrency Level: 100 -Time taken for tests: 7.240 seconds -Complete requests: 1000000 -Failed requests: 0 -Keep-Alive requests: 1000000 -Total transferred: 73000000 bytes -HTML transferred: 5000000 bytes -Requests per second: 138124.14 [#/sec] (mean) -Time per request: 0.724 [ms] (mean) -Time per request: 0.007 [ms] (mean, across all concurrent requests) -Transfer rate: 9846.74 [Kbytes/sec] received - -Connection Times (ms) - min mean[+/-sd] median max -Connect: 0 0 0.0 0 5 -Processing: 0 1 0.2 1 9 -Waiting: 0 1 0.2 1 9 -Total: 0 1 0.2 1 9 - -Percentage of the requests served within a certain time (ms) - 50% 1 - 66% 1 - 75% 1 - 80% 1 - 90% 1 - 95% 1 - 98% 1 - 99% 1 - 100% 9 (longest request) - -``` - - -## Other links with workerman - -## [PHPSocket.IO](https://github.com/walkor/phpsocket.io) -[Live demo](http://www.workerman.net/demos/phpsocketio-chat/) -[Source code](https://github.com/walkor/phpsocket.io) -![phpsocket.io](http://www.workerman.net/img/socket.io.png) - -## [tadpole](http://kedou.workerman.net/) -[Live demo](http://kedou.workerman.net/) -[Source code](https://github.com/walkor/workerman) -![workerman todpole](http://www.workerman.net/img/workerman-todpole.png) - -## [BrowserQuest](http://www.workerman.net/demos/browserquest/) -[Live demo](http://www.workerman.net/demos/browserquest/) -[Source code](https://github.com/walkor/BrowserQuest-PHP) -![BrowserQuest width workerman](http://www.workerman.net/img/browserquest.jpg) - -## [web vmstat](http://www.workerman.net/demos/vmstat/) -[Live demo](http://www.workerman.net/demos/vmstat/) -[Source code](https://github.com/walkor/workerman-vmstat) -![web vmstat](http://www.workerman.net/img/workerman-vmstat.png) - -## [live-ascii-camera](https://github.com/walkor/live-ascii-camera) -[Live demo camera page](http://www.workerman.net/demos/live-ascii-camera/camera.html) -[Live demo receive page](http://www.workerman.net/demos/live-ascii-camera/) -[Source code](https://github.com/walkor/live-ascii-camera) -![live-ascii-camera](http://www.workerman.net/img/live-ascii-camera.png) - -## [live-camera](https://github.com/walkor/live-camera) -[Live demo camera page](http://www.workerman.net/demos/live-camera/camera.html) -[Live demo receive page](http://www.workerman.net/demos/live-camera/) -[Source code](https://github.com/walkor/live-camera) -![live-camera](http://www.workerman.net/img/live-camera.jpg) - -## [chat room](http://chat.workerman.net/) -[Live demo](http://chat.workerman.net/) -[Source code](https://github.com/walkor/workerman-chat) -![workerman-chat](http://www.workerman.net/img/workerman-chat.png) - -## [statistics](http://www.workerman.net:55757/) -[Live demo](http://www.workerman.net:55757/) -[Source code](https://github.com/walkor/workerman-statistics) -![workerman-statistics](http://www.workerman.net/img/workerman-statistics.png) - -## [flappybird](http://workerman.net/demos/flappy-bird/) -[Live demo](http://workerman.net/demos/flappy-bird/) -[Source code](https://github.com/walkor/workerman-flappy-bird) -![workerman-statistics](http://www.workerman.net/img/workerman-flappy-bird.png) - -## [jsonRpc](https://github.com/walkor/workerman-JsonRpc) -[Source code](https://github.com/walkor/workerman-JsonRpc) -![workerman-jsonRpc](http://www.workerman.net/img/workerman-json-rpc.png) - -## [thriftRpc](https://github.com/walkor/workerman-thrift) -[Source code](https://github.com/walkor/workerman-thrift) -![workerman-thriftRpc](http://www.workerman.net/img/workerman-thrift.png) - -## [web-msg-sender](https://github.com/walkor/web-msg-sender) -[Live demo send page](http://workerman.net:3333/) -[Live demo receive page](http://workerman.net/web-msg-sender.html) -[Source code](https://github.com/walkor/web-msg-sender) -![web-msg-sender](http://www.workerman.net/img/web-msg-sender.png) - -## [shadowsocks-php](https://github.com/walkor/shadowsocks-php) -[Source code](https://github.com/walkor/shadowsocks-php) -![shadowsocks-php](http://www.workerman.net/img/shadowsocks-php.png) - -## [queue](https://github.com/walkor/workerman-queue) -[Source code](https://github.com/walkor/workerman-queue) - -## LICENSE - -Workerman is released under the [MIT license](https://github.com/walkor/workerman/blob/master/MIT-LICENSE.txt). diff --git a/vendor/workerman/workerman/WebServer.php b/vendor/workerman/workerman/WebServer.php deleted file mode 100644 index 235246d96..000000000 --- a/vendor/workerman/workerman/WebServer.php +++ /dev/null @@ -1,301 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman; - -use Workerman\Protocols\Http; -use Workerman\Protocols\HttpCache; - -/** - * WebServer. - */ -class WebServer extends Worker -{ - /** - * Virtual host to path mapping. - * - * @var array ['workerman.net'=>'/home', 'www.workerman.net'=>'home/www'] - */ - protected $serverRoot = array(); - - /** - * Mime mapping. - * - * @var array - */ - protected static $mimeTypeMap = array(); - - - /** - * Used to save user OnWorkerStart callback settings. - * - * @var callback - */ - protected $_onWorkerStart = null; - - /** - * Add virtual host. - * - * @param string $domain - * @param string $root_path - * @return void - */ - public function addRoot($domain, $root_path) - { - $this->serverRoot[$domain] = $root_path; - } - - /** - * Construct. - * - * @param string $socket_name - * @param array $context_option - */ - public function __construct($socket_name, $context_option = array()) - { - list(, $address) = explode(':', $socket_name, 2); - parent::__construct('http:' . $address, $context_option); - $this->name = 'WebServer'; - } - - /** - * Run webserver instance. - * - * @see Workerman.Worker::run() - */ - public function run() - { - $this->_onWorkerStart = $this->onWorkerStart; - $this->onWorkerStart = array($this, 'onWorkerStart'); - $this->onMessage = array($this, 'onMessage'); - parent::run(); - } - - /** - * Emit when process start. - * - * @throws \Exception - */ - public function onWorkerStart() - { - if (empty($this->serverRoot)) { - echo new \Exception('server root not set, please use WebServer::addRoot($domain, $root_path) to set server root path'); - exit(250); - } - - // Init mimeMap. - $this->initMimeTypeMap(); - - // Try to emit onWorkerStart callback. - if ($this->_onWorkerStart) { - try { - call_user_func($this->_onWorkerStart, $this); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - } - - /** - * Init mime map. - * - * @return void - */ - public function initMimeTypeMap() - { - $mime_file = Http::getMimeTypesFile(); - if (!is_file($mime_file)) { - $this->log("$mime_file mime.type file not fond"); - return; - } - $items = file($mime_file, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES); - if (!is_array($items)) { - $this->log("get $mime_file mime.type content fail"); - return; - } - foreach ($items as $content) { - if (preg_match("/\s*(\S+)\s+(\S.+)/", $content, $match)) { - $mime_type = $match[1]; - $workerman_file_extension_var = $match[2]; - $workerman_file_extension_array = explode(' ', substr($workerman_file_extension_var, 0, -1)); - foreach ($workerman_file_extension_array as $workerman_file_extension) { - self::$mimeTypeMap[$workerman_file_extension] = $mime_type; - } - } - } - } - - /** - * Emit when http message coming. - * - * @param Connection\TcpConnection $connection - * @return void - */ - public function onMessage($connection) - { - // REQUEST_URI. - $workerman_url_info = parse_url($_SERVER['REQUEST_URI']); - if (!$workerman_url_info) { - Http::header('HTTP/1.1 400 Bad Request'); - $connection->close('

400 Bad Request

'); - return; - } - - $workerman_path = isset($workerman_url_info['path']) ? $workerman_url_info['path'] : '/'; - - $workerman_path_info = pathinfo($workerman_path); - $workerman_file_extension = isset($workerman_path_info['extension']) ? $workerman_path_info['extension'] : ''; - if ($workerman_file_extension === '') { - $workerman_path = ($len = strlen($workerman_path)) && $workerman_path[$len - 1] === '/' ? $workerman_path . 'index.php' : $workerman_path . '/index.php'; - $workerman_file_extension = 'php'; - } - - $workerman_root_dir = isset($this->serverRoot[$_SERVER['SERVER_NAME']]) ? $this->serverRoot[$_SERVER['SERVER_NAME']] : current($this->serverRoot); - - $workerman_file = "$workerman_root_dir/$workerman_path"; - - if ($workerman_file_extension === 'php' && !is_file($workerman_file)) { - $workerman_file = "$workerman_root_dir/index.php"; - if (!is_file($workerman_file)) { - $workerman_file = "$workerman_root_dir/index.html"; - $workerman_file_extension = 'html'; - } - } - - // File exsits. - if (is_file($workerman_file)) { - // Security check. - if ((!($workerman_request_realpath = realpath($workerman_file)) || !($workerman_root_dir_realpath = realpath($workerman_root_dir))) || 0 !== strpos($workerman_request_realpath, - $workerman_root_dir_realpath) - ) { - Http::header('HTTP/1.1 400 Bad Request'); - $connection->close('

400 Bad Request

'); - return; - } - - $workerman_file = realpath($workerman_file); - - // Request php file. - if ($workerman_file_extension === 'php') { - $workerman_cwd = getcwd(); - chdir($workerman_root_dir); - ini_set('display_errors', 'off'); - ob_start(); - // Try to include php file. - try { - // $_SERVER. - $_SERVER['REMOTE_ADDR'] = $connection->getRemoteIp(); - $_SERVER['REMOTE_PORT'] = $connection->getRemotePort(); - include $workerman_file; - } catch (\Exception $e) { - // Jump_exit? - if ($e->getMessage() != 'jump_exit') { - echo $e; - } - } - $content = ob_get_clean(); - ini_set('display_errors', 'on'); - if (strtolower($_SERVER['HTTP_CONNECTION']) === "keep-alive") { - $connection->send($content); - } else { - $connection->close($content); - } - chdir($workerman_cwd); - return; - } - - // Send file to client. - return self::sendFile($connection, $workerman_file); - } else { - // 404 - Http::header("HTTP/1.1 404 Not Found"); - $connection->close('404 File not found

404 Not Found

'); - return; - } - } - - public static function sendFile($connection, $file_path) - { - // Check 304. - $info = stat($file_path); - $modified_time = $info ? date('D, d M Y H:i:s', $info['mtime']) . ' GMT' : ''; - if (!empty($_SERVER['HTTP_IF_MODIFIED_SINCE']) && $info) { - // Http 304. - if ($modified_time === $_SERVER['HTTP_IF_MODIFIED_SINCE']) { - // 304 - Http::header('HTTP/1.1 304 Not Modified'); - // Send nothing but http headers.. - $connection->close(''); - return; - } - } - - // Http header. - if ($modified_time) { - $modified_time = "Last-Modified: $modified_time\r\n"; - } - $file_size = filesize($file_path); - $file_info = pathinfo($file_path); - $extension = isset($file_info['extension']) ? $file_info['extension'] : ''; - $file_name = isset($file_info['filename']) ? $file_info['filename'] : ''; - $header = "HTTP/1.1 200 OK\r\n"; - if (isset(self::$mimeTypeMap[$extension])) { - $header .= "Content-Type: " . self::$mimeTypeMap[$extension] . "\r\n"; - } else { - $header .= "Content-Type: application/octet-stream\r\n"; - $header .= "Content-Disposition: attachment; filename=\"$file_name\"\r\n"; - } - $header .= "Connection: keep-alive\r\n"; - $header .= $modified_time; - $header .= "Content-Length: $file_size\r\n\r\n"; - $trunk_limit_size = 1024*1024; - if ($file_size < $trunk_limit_size) { - return $connection->send($header.file_get_contents($file_path), true); - } - $connection->send($header, true); - - // Read file content from disk piece by piece and send to client. - $connection->fileHandler = fopen($file_path, 'r'); - $do_write = function()use($connection) - { - // Send buffer not full. - while(empty($connection->bufferFull)) - { - // Read from disk. - $buffer = fread($connection->fileHandler, 8192); - // Read eof. - if($buffer === '' || $buffer === false) - { - return; - } - $connection->send($buffer, true); - } - }; - // Send buffer full. - $connection->onBufferFull = function($connection) - { - $connection->bufferFull = true; - }; - // Send buffer drain. - $connection->onBufferDrain = function($connection)use($do_write) - { - $connection->bufferFull = false; - $do_write(); - }; - $do_write(); - } -} diff --git a/vendor/workerman/workerman/Worker.php b/vendor/workerman/workerman/Worker.php deleted file mode 100644 index c09bd33b3..000000000 --- a/vendor/workerman/workerman/Worker.php +++ /dev/null @@ -1,1641 +0,0 @@ - - * @copyright walkor - * @link http://www.workerman.net/ - * @license http://www.opensource.org/licenses/mit-license.php MIT License - */ -namespace Workerman; - -require_once __DIR__ . '/Lib/Constants.php'; - -use Workerman\Events\EventInterface; -use Workerman\Connection\ConnectionInterface; -use Workerman\Connection\TcpConnection; -use Workerman\Connection\UdpConnection; -use Workerman\Lib\Timer; -use Exception; - -/** - * Worker class - * A container for listening ports - */ -class Worker -{ - /** - * Version. - * - * @var string - */ - const VERSION = '3.3.8'; - - /** - * Status starting. - * - * @var int - */ - const STATUS_STARTING = 1; - - /** - * Status running. - * - * @var int - */ - const STATUS_RUNNING = 2; - - /** - * Status shutdown. - * - * @var int - */ - const STATUS_SHUTDOWN = 4; - - /** - * Status reloading. - * - * @var int - */ - const STATUS_RELOADING = 8; - - /** - * After sending the restart command to the child process KILL_WORKER_TIMER_TIME seconds, - * if the process is still living then forced to kill. - * - * @var int - */ - const KILL_WORKER_TIMER_TIME = 2; - - /** - * Default backlog. Backlog is the maximum length of the queue of pending connections. - * - * @var int - */ - const DEFAULT_BACKLOG = 102400; - /** - * Max udp package size. - * - * @var int - */ - const MAX_UDP_PACKAGE_SIZE = 65535; - - /** - * Worker id. - * - * @var int - */ - public $id = 0; - - /** - * Name of the worker processes. - * - * @var string - */ - public $name = 'none'; - - /** - * Number of worker processes. - * - * @var int - */ - public $count = 1; - - /** - * Unix user of processes, needs appropriate privileges (usually root). - * - * @var string - */ - public $user = ''; - - /** - * Unix group of processes, needs appropriate privileges (usually root). - * - * @var string - */ - public $group = ''; - - /** - * reloadable. - * - * @var bool - */ - public $reloadable = true; - - /** - * reuse port. - * - * @var bool - */ - public $reusePort = false; - - /** - * Emitted when worker processes start. - * - * @var callback - */ - public $onWorkerStart = null; - - /** - * Emitted when a socket connection is successfully established. - * - * @var callback - */ - public $onConnect = null; - - /** - * Emitted when data is received. - * - * @var callback - */ - public $onMessage = null; - - /** - * Emitted when the other end of the socket sends a FIN packet. - * - * @var callback - */ - public $onClose = null; - - /** - * Emitted when an error occurs with connection. - * - * @var callback - */ - public $onError = null; - - /** - * Emitted when the send buffer becomes full. - * - * @var callback - */ - public $onBufferFull = null; - - /** - * Emitted when the send buffer becomes empty. - * - * @var callback - */ - public $onBufferDrain = null; - - /** - * Emitted when worker processes stoped. - * - * @var callback - */ - public $onWorkerStop = null; - - /** - * Emitted when worker processes get reload signal. - * - * @var callback - */ - public $onWorkerReload = null; - - /** - * Transport layer protocol. - * - * @var string - */ - public $transport = 'tcp'; - - /** - * Store all connections of clients. - * - * @var array - */ - public $connections = array(); - - /** - * Application layer protocol. - * - * @var Protocols\ProtocolInterface - */ - public $protocol = ''; - - /** - * Root path for autoload. - * - * @var string - */ - protected $_autoloadRootPath = ''; - - /** - * Daemonize. - * - * @var bool - */ - public static $daemonize = false; - - /** - * Stdout file. - * - * @var string - */ - public static $stdoutFile = '/dev/null'; - - /** - * The file to store master process PID. - * - * @var string - */ - public static $pidFile = ''; - - /** - * Log file. - * - * @var mixed - */ - public static $logFile = ''; - - /** - * Global event loop. - * - * @var Events\EventInterface - */ - public static $globalEvent = null; - - /** - * Emitted when the master process get reload signal. - * - * @var callback - */ - public static $onMasterReload = null; - - /** - * Emitted when the master process terminated. - * - * @var callback - */ - public static $onMasterStop = null; - - /** - * The PID of master process. - * - * @var int - */ - protected static $_masterPid = 0; - - /** - * Listening socket. - * - * @var resource - */ - protected $_mainSocket = null; - - /** - * Socket name. The format is like this http://0.0.0.0:80 . - * - * @var string - */ - protected $_socketName = ''; - - /** - * Context of socket. - * - * @var resource - */ - protected $_context = null; - - /** - * All worker instances. - * - * @var array - */ - protected static $_workers = array(); - - /** - * All worker porcesses pid. - * The format is like this [worker_id=>[pid=>pid, pid=>pid, ..], ..] - * - * @var array - */ - protected static $_pidMap = array(); - - /** - * All worker processes waiting for restart. - * The format is like this [pid=>pid, pid=>pid]. - * - * @var array - */ - protected static $_pidsToRestart = array(); - - /** - * Mapping from PID to worker process ID. - * The format is like this [worker_id=>[0=>$pid, 1=>$pid, ..], ..]. - * - * @var array - */ - protected static $_idMap = array(); - - /** - * Current status. - * - * @var int - */ - protected static $_status = self::STATUS_STARTING; - - /** - * Maximum length of the worker names. - * - * @var int - */ - protected static $_maxWorkerNameLength = 12; - - /** - * Maximum length of the socket names. - * - * @var int - */ - protected static $_maxSocketNameLength = 12; - - /** - * Maximum length of the process user names. - * - * @var int - */ - protected static $_maxUserNameLength = 12; - - /** - * The file to store status info of current worker process. - * - * @var string - */ - protected static $_statisticsFile = ''; - - /** - * Start file. - * - * @var string - */ - protected static $_startFile = ''; - - /** - * Status info of current worker process. - * - * @var array - */ - protected static $_globalStatistics = array( - 'start_timestamp' => 0, - 'worker_exit_info' => array() - ); - - /** - * Available event loops. - * - * @var array - */ - protected static $_availableEventLoops = array( - 'libevent', - 'event', - 'ev' - ); - - /** - * Current eventLoop name. - * - * @var string - */ - protected static $_eventLoopName = 'select'; - - /** - * PHP built-in protocols. - * - * @var array - */ - protected static $_builtinTransports = array( - 'tcp' => 'tcp', - 'udp' => 'udp', - 'unix' => 'unix', - 'ssl' => 'tcp' - ); - - /** - * Run all worker instances. - * - * @return void - */ - public static function runAll() - { - self::checkSapiEnv(); - self::init(); - self::parseCommand(); - self::daemonize(); - self::initWorkers(); - self::installSignal(); - self::saveMasterPid(); - self::forkWorkers(); - self::displayUI(); - self::resetStd(); - self::monitorWorkers(); - } - - /** - * Check sapi. - * - * @return void - */ - protected static function checkSapiEnv() - { - // Only for cli. - if (php_sapi_name() != "cli") { - exit("only run in command line mode \n"); - } - } - - /** - * Init. - * - * @return void - */ - protected static function init() - { - // Start file. - $backtrace = debug_backtrace(); - self::$_startFile = $backtrace[count($backtrace) - 1]['file']; - - // Pid file. - if (empty(self::$pidFile)) { - self::$pidFile = __DIR__ . "/../" . str_replace('/', '_', self::$_startFile) . ".pid"; - } - - // Log file. - if (empty(self::$logFile)) { - self::$logFile = __DIR__ . '/../workerman.log'; - } - $log_file = (string)self::$logFile; - touch($log_file); - chmod($log_file, 0622); - - // State. - self::$_status = self::STATUS_STARTING; - - // For statistics. - self::$_globalStatistics['start_timestamp'] = time(); - self::$_statisticsFile = sys_get_temp_dir() . '/workerman.status'; - - // Process title. - self::setProcessTitle('WorkerMan: master process start_file=' . self::$_startFile); - - // Init data for worker id. - self::initId(); - - // Timer init. - Timer::init(); - } - - /** - * Init All worker instances. - * - * @return void - */ - protected static function initWorkers() - { - foreach (self::$_workers as $worker) { - // Worker name. - if (empty($worker->name)) { - $worker->name = 'none'; - } - - // Get maximum length of worker name. - $worker_name_length = strlen($worker->name); - if (self::$_maxWorkerNameLength < $worker_name_length) { - self::$_maxWorkerNameLength = $worker_name_length; - } - - // Get maximum length of socket name. - $socket_name_length = strlen($worker->getSocketName()); - if (self::$_maxSocketNameLength < $socket_name_length) { - self::$_maxSocketNameLength = $socket_name_length; - } - - // Get unix user of the worker process. - if (empty($worker->user)) { - $worker->user = self::getCurrentUser(); - } else { - if (posix_getuid() !== 0 && $worker->user != self::getCurrentUser()) { - self::log('Warning: You must have the root privileges to change uid and gid.'); - } - } - - // Get maximum length of unix user name. - $user_name_length = strlen($worker->user); - if (self::$_maxUserNameLength < $user_name_length) { - self::$_maxUserNameLength = $user_name_length; - } - - // Listen. - if (!$worker->reusePort) { - $worker->listen(); - } - } - } - - /** - * Get all worker instances. - * - * @return array - */ - public static function getAllWorkers() - { - return self::$_workers; - } - - /** - * Get global event-loop instance. - * - * @return EventInterface - */ - public static function getEventLoop() - { - return self::$globalEvent; - } - - /** - * Init idMap. - * return void - */ - protected static function initId() - { - foreach (self::$_workers as $worker_id => $worker) { - $new_id_map = array(); - for($key = 0; $key < $worker->count; $key++) { - $new_id_map[$key] = isset(self::$_idMap[$worker_id][$key]) ? self::$_idMap[$worker_id][$key] : 0; - } - self::$_idMap[$worker_id] = $new_id_map; - } - } - - /** - * Get unix user of current porcess. - * - * @return string - */ - protected static function getCurrentUser() - { - $user_info = posix_getpwuid(posix_getuid()); - return $user_info['name']; - } - - /** - * Display staring UI. - * - * @return void - */ - protected static function displayUI() - { - self::safeEcho("\033[1A\n\033[K-----------------------\033[47;30m WORKERMAN \033[0m-----------------------------\n\033[0m"); - self::safeEcho('Workerman version:'. Worker::VERSION. " PHP version:". PHP_VERSION. "\n"); - self::safeEcho("------------------------\033[47;30m WORKERS \033[0m-------------------------------\n"); - self::safeEcho("\033[47;30muser\033[0m". str_pad('', - self::$_maxUserNameLength + 2 - strlen('user')). "\033[47;30mworker\033[0m". str_pad('', - self::$_maxWorkerNameLength + 2 - strlen('worker')). "\033[47;30mlisten\033[0m". str_pad('', - self::$_maxSocketNameLength + 2 - strlen('listen')). "\033[47;30mprocesses\033[0m \033[47;30m". "status\033[0m\n"); - - foreach (self::$_workers as $worker) { - self::safeEcho(str_pad($worker->user, self::$_maxUserNameLength + 2). str_pad($worker->name, - self::$_maxWorkerNameLength + 2). str_pad($worker->getSocketName(), - self::$_maxSocketNameLength + 2). str_pad(' ' . $worker->count, 9). " \033[32;40m [OK] \033[0m\n"); - } - self::safeEcho("----------------------------------------------------------------\n"); - if (self::$daemonize) { - global $argv; - $start_file = $argv[0]; - self::safeEcho("Input \"php $start_file stop\" to quit. Start success.\n"); - } else { - self::safeEcho("Press Ctrl-C to quit. Start success.\n"); - } - } - - /** - * Parse command. - * php yourfile.php start | stop | restart | reload | status - * - * @return void - */ - protected static function parseCommand() - { - global $argv; - // Check argv; - $start_file = $argv[0]; - if (!isset($argv[1])) { - exit("Usage: php yourfile.php {start|stop|restart|reload|status}\n"); - } - - // Get command. - $command = trim($argv[1]); - $command2 = isset($argv[2]) ? $argv[2] : ''; - - // Start command. - $mode = ''; - if ($command === 'start') { - if ($command2 === '-d' || Worker::$daemonize) { - $mode = 'in DAEMON mode'; - } else { - $mode = 'in DEBUG mode'; - } - } - self::log("Workerman[$start_file] $command $mode"); - - // Get master process PID. - $master_pid = @file_get_contents(self::$pidFile); - $master_is_alive = $master_pid && @posix_kill($master_pid, 0); - // Master is still alive? - if ($master_is_alive) { - if ($command === 'start' && posix_getpid() != $master_pid) { - self::log("Workerman[$start_file] already running"); - exit; - } - } elseif ($command !== 'start' && $command !== 'restart') { - self::log("Workerman[$start_file] not run"); - exit; - } - - // execute command. - switch ($command) { - case 'start': - if ($command2 === '-d') { - Worker::$daemonize = true; - } - break; - case 'status': - if (is_file(self::$_statisticsFile)) { - @unlink(self::$_statisticsFile); - } - // Master process will send status signal to all child processes. - posix_kill($master_pid, SIGUSR2); - // Waiting amoment. - usleep(500000); - // Display statisitcs data from a disk file. - @readfile(self::$_statisticsFile); - exit(0); - case 'restart': - case 'stop': - self::log("Workerman[$start_file] is stoping ..."); - // Send stop signal to master process. - $master_pid && posix_kill($master_pid, SIGINT); - // Timeout. - $timeout = 5; - $start_time = time(); - // Check master process is still alive? - while (1) { - $master_is_alive = $master_pid && posix_kill($master_pid, 0); - if ($master_is_alive) { - // Timeout? - if (time() - $start_time >= $timeout) { - self::log("Workerman[$start_file] stop fail"); - exit; - } - // Waiting amoment. - usleep(10000); - continue; - } - // Stop success. - self::log("Workerman[$start_file] stop success"); - if ($command === 'stop') { - exit(0); - } - if ($command2 === '-d') { - Worker::$daemonize = true; - } - break; - } - break; - case 'reload': - posix_kill($master_pid, SIGUSR1); - self::log("Workerman[$start_file] reload"); - exit; - default : - exit("Usage: php yourfile.php {start|stop|restart|reload|status}\n"); - } - } - - /** - * Install signal handler. - * - * @return void - */ - protected static function installSignal() - { - // stop - pcntl_signal(SIGINT, array('\Workerman\Worker', 'signalHandler'), false); - // reload - pcntl_signal(SIGUSR1, array('\Workerman\Worker', 'signalHandler'), false); - // status - pcntl_signal(SIGUSR2, array('\Workerman\Worker', 'signalHandler'), false); - // ignore - pcntl_signal(SIGPIPE, SIG_IGN, false); - } - - /** - * Reinstall signal handler. - * - * @return void - */ - protected static function reinstallSignal() - { - // uninstall stop signal handler - pcntl_signal(SIGINT, SIG_IGN, false); - // uninstall reload signal handler - pcntl_signal(SIGUSR1, SIG_IGN, false); - // uninstall status signal handler - pcntl_signal(SIGUSR2, SIG_IGN, false); - // reinstall stop signal handler - self::$globalEvent->add(SIGINT, EventInterface::EV_SIGNAL, array('\Workerman\Worker', 'signalHandler')); - // reinstall reload signal handler - self::$globalEvent->add(SIGUSR1, EventInterface::EV_SIGNAL, array('\Workerman\Worker', 'signalHandler')); - // reinstall status signal handler - self::$globalEvent->add(SIGUSR2, EventInterface::EV_SIGNAL, array('\Workerman\Worker', 'signalHandler')); - } - - /** - * Signal handler. - * - * @param int $signal - */ - public static function signalHandler($signal) - { - switch ($signal) { - // Stop. - case SIGINT: - self::stopAll(); - break; - // Reload. - case SIGUSR1: - self::$_pidsToRestart = self::getAllWorkerPids(); - self::reload(); - break; - // Show status. - case SIGUSR2: - self::writeStatisticsToStatusFile(); - break; - } - } - - /** - * Run as deamon mode. - * - * @throws Exception - */ - protected static function daemonize() - { - if (!self::$daemonize) { - return; - } - umask(0); - $pid = pcntl_fork(); - if (-1 === $pid) { - throw new Exception('fork fail'); - } elseif ($pid > 0) { - exit(0); - } - if (-1 === posix_setsid()) { - throw new Exception("setsid fail"); - } - // Fork again avoid SVR4 system regain the control of terminal. - $pid = pcntl_fork(); - if (-1 === $pid) { - throw new Exception("fork fail"); - } elseif (0 !== $pid) { - exit(0); - } - } - - /** - * Redirect standard input and output. - * - * @throws Exception - */ - protected static function resetStd() - { - if (!self::$daemonize) { - return; - } - global $STDOUT, $STDERR; - $handle = fopen(self::$stdoutFile, "a"); - if ($handle) { - unset($handle); - @fclose(STDOUT); - @fclose(STDERR); - $STDOUT = fopen(self::$stdoutFile, "a"); - $STDERR = fopen(self::$stdoutFile, "a"); - } else { - throw new Exception('can not open stdoutFile ' . self::$stdoutFile); - } - } - - /** - * Save pid. - * - * @throws Exception - */ - protected static function saveMasterPid() - { - self::$_masterPid = posix_getpid(); - if (false === @file_put_contents(self::$pidFile, self::$_masterPid)) { - throw new Exception('can not save pid to ' . self::$pidFile); - } - } - - /** - * Get event loop name. - * - * @return string - */ - protected static function getEventLoopName() - { - if (interface_exists('\React\EventLoop\LoopInterface')) { - return 'React'; - } - foreach (self::$_availableEventLoops as $name) { - if (extension_loaded($name)) { - self::$_eventLoopName = $name; - break; - } - } - return self::$_eventLoopName; - } - - /** - * Get all pids of worker processes. - * - * @return array - */ - protected static function getAllWorkerPids() - { - $pid_array = array(); - foreach (self::$_pidMap as $worker_pid_array) { - foreach ($worker_pid_array as $worker_pid) { - $pid_array[$worker_pid] = $worker_pid; - } - } - return $pid_array; - } - - /** - * Fork some worker processes. - * - * @return void - */ - protected static function forkWorkers() - { - foreach (self::$_workers as $worker) { - if (self::$_status === self::STATUS_STARTING) { - if (empty($worker->name)) { - $worker->name = $worker->getSocketName(); - } - $worker_name_length = strlen($worker->name); - if (self::$_maxWorkerNameLength < $worker_name_length) { - self::$_maxWorkerNameLength = $worker_name_length; - } - } - - $worker->count = $worker->count <= 0 ? 1 : $worker->count; - while (count(self::$_pidMap[$worker->workerId]) < $worker->count) { - static::forkOneWorker($worker); - } - } - } - - /** - * Fork one worker process. - * - * @param Worker $worker - * @throws Exception - */ - protected static function forkOneWorker($worker) - { - // Get available worker id. - $id = self::getId($worker->workerId, 0); - if ($id === false) { - return; - } - $pid = pcntl_fork(); - // For master process. - if ($pid > 0) { - self::$_pidMap[$worker->workerId][$pid] = $pid; - self::$_idMap[$worker->workerId][$id] = $pid; - } // For child processes. - elseif (0 === $pid) { - if ($worker->reusePort) { - $worker->listen(); - } - if (self::$_status === self::STATUS_STARTING) { - self::resetStd(); - } - self::$_pidMap = array(); - self::$_workers = array($worker->workerId => $worker); - Timer::delAll(); - self::setProcessTitle('WorkerMan: worker process ' . $worker->name . ' ' . $worker->getSocketName()); - $worker->setUserAndGroup(); - $worker->id = $id; - $worker->run(); - $err = new Exception('event-loop exited'); - self::log($err); - exit(250); - } else { - throw new Exception("forkOneWorker fail"); - } - } - - /** - * Get worker id. - * - * @param int $worker_id - * @param int $pid - */ - protected static function getId($worker_id, $pid) - { - return array_search($pid, self::$_idMap[$worker_id]); - } - - /** - * Set unix user and group for current process. - * - * @return void - */ - public function setUserAndGroup() - { - // Get uid. - $user_info = posix_getpwnam($this->user); - if (!$user_info) { - self::log("Warning: User {$this->user} not exsits"); - return; - } - $uid = $user_info['uid']; - // Get gid. - if ($this->group) { - $group_info = posix_getgrnam($this->group); - if (!$group_info) { - self::log("Warning: Group {$this->group} not exsits"); - return; - } - $gid = $group_info['gid']; - } else { - $gid = $user_info['gid']; - } - - // Set uid and gid. - if ($uid != posix_getuid() || $gid != posix_getgid()) { - if (!posix_setgid($gid) || !posix_initgroups($user_info['name'], $gid) || !posix_setuid($uid)) { - self::log("Warning: change gid or uid fail."); - } - } - } - - /** - * Set process name. - * - * @param string $title - * @return void - */ - protected static function setProcessTitle($title) - { - // >=php 5.5 - if (function_exists('cli_set_process_title')) { - @cli_set_process_title($title); - } // Need proctitle when php<=5.5 . - elseif (extension_loaded('proctitle') && function_exists('setproctitle')) { - @setproctitle($title); - } - } - - /** - * Monitor all child processes. - * - * @return void - */ - protected static function monitorWorkers() - { - self::$_status = self::STATUS_RUNNING; - while (1) { - // Calls signal handlers for pending signals. - pcntl_signal_dispatch(); - // Suspends execution of the current process until a child has exited, or until a signal is delivered - $status = 0; - $pid = pcntl_wait($status, WUNTRACED); - // Calls signal handlers for pending signals again. - pcntl_signal_dispatch(); - // If a child has already exited. - if ($pid > 0) { - // Find out witch worker process exited. - foreach (self::$_pidMap as $worker_id => $worker_pid_array) { - if (isset($worker_pid_array[$pid])) { - $worker = self::$_workers[$worker_id]; - // Exit status. - if ($status !== 0) { - self::log("worker[" . $worker->name . ":$pid] exit with status $status"); - } - - // For Statistics. - if (!isset(self::$_globalStatistics['worker_exit_info'][$worker_id][$status])) { - self::$_globalStatistics['worker_exit_info'][$worker_id][$status] = 0; - } - self::$_globalStatistics['worker_exit_info'][$worker_id][$status]++; - - // Clear process data. - unset(self::$_pidMap[$worker_id][$pid]); - - // Mark id is available. - $id = self::getId($worker_id, $pid); - self::$_idMap[$worker_id][$id] = 0; - - break; - } - } - // Is still running state then fork a new worker process. - if (self::$_status !== self::STATUS_SHUTDOWN) { - self::forkWorkers(); - // If reloading continue. - if (isset(self::$_pidsToRestart[$pid])) { - unset(self::$_pidsToRestart[$pid]); - self::reload(); - } - } else { - // If shutdown state and all child processes exited then master process exit. - if (!self::getAllWorkerPids()) { - self::exitAndClearAll(); - } - } - } else { - // If shutdown state and all child processes exited then master process exit. - if (self::$_status === self::STATUS_SHUTDOWN && !self::getAllWorkerPids()) { - self::exitAndClearAll(); - } - } - } - } - - /** - * Exit current process. - * - * @return void - */ - protected static function exitAndClearAll() - { - foreach (self::$_workers as $worker) { - $socket_name = $worker->getSocketName(); - if ($worker->transport === 'unix' && $socket_name) { - list(, $address) = explode(':', $socket_name, 2); - @unlink($address); - } - } - @unlink(self::$pidFile); - self::log("Workerman[" . basename(self::$_startFile) . "] has been stopped"); - if (self::$onMasterStop) { - call_user_func(self::$onMasterStop); - } - exit(0); - } - - /** - * Execute reload. - * - * @return void - */ - protected static function reload() - { - // For master process. - if (self::$_masterPid === posix_getpid()) { - // Set reloading state. - if (self::$_status !== self::STATUS_RELOADING && self::$_status !== self::STATUS_SHUTDOWN) { - self::log("Workerman[" . basename(self::$_startFile) . "] reloading"); - self::$_status = self::STATUS_RELOADING; - // Try to emit onMasterReload callback. - if (self::$onMasterReload) { - try { - call_user_func(self::$onMasterReload); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - self::initId(); - } - } - - // Send reload signal to all child processes. - $reloadable_pid_array = array(); - foreach (self::$_pidMap as $worker_id => $worker_pid_array) { - $worker = self::$_workers[$worker_id]; - if ($worker->reloadable) { - foreach ($worker_pid_array as $pid) { - $reloadable_pid_array[$pid] = $pid; - } - } else { - foreach ($worker_pid_array as $pid) { - // Send reload signal to a worker process which reloadable is false. - posix_kill($pid, SIGUSR1); - } - } - } - - // Get all pids that are waiting reload. - self::$_pidsToRestart = array_intersect(self::$_pidsToRestart, $reloadable_pid_array); - - // Reload complete. - if (empty(self::$_pidsToRestart)) { - if (self::$_status !== self::STATUS_SHUTDOWN) { - self::$_status = self::STATUS_RUNNING; - } - return; - } - // Continue reload. - $one_worker_pid = current(self::$_pidsToRestart); - // Send reload signal to a worker process. - posix_kill($one_worker_pid, SIGUSR1); - // If the process does not exit after self::KILL_WORKER_TIMER_TIME seconds try to kill it. - Timer::add(self::KILL_WORKER_TIMER_TIME, 'posix_kill', array($one_worker_pid, SIGKILL), false); - } // For child processes. - else { - $worker = current(self::$_workers); - // Try to emit onWorkerReload callback. - if ($worker->onWorkerReload) { - try { - call_user_func($worker->onWorkerReload, $worker); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - - if ($worker->reloadable) { - self::stopAll(); - } - } - } - - /** - * Stop. - * - * @return void - */ - public static function stopAll() - { - self::$_status = self::STATUS_SHUTDOWN; - // For master process. - if (self::$_masterPid === posix_getpid()) { - self::log("Workerman[" . basename(self::$_startFile) . "] Stopping ..."); - $worker_pid_array = self::getAllWorkerPids(); - // Send stop signal to all child processes. - foreach ($worker_pid_array as $worker_pid) { - posix_kill($worker_pid, SIGINT); - Timer::add(self::KILL_WORKER_TIMER_TIME, 'posix_kill', array($worker_pid, SIGKILL), false); - } - } // For child processes. - else { - // Execute exit. - foreach (self::$_workers as $worker) { - $worker->stop(); - } - exit(0); - } - } - - /** - * Write statistics data to disk. - * - * @return void - */ - protected static function writeStatisticsToStatusFile() - { - // For master process. - if (self::$_masterPid === posix_getpid()) { - $loadavg = sys_getloadavg(); - file_put_contents(self::$_statisticsFile, - "---------------------------------------GLOBAL STATUS--------------------------------------------\n"); - file_put_contents(self::$_statisticsFile, - 'Workerman version:' . Worker::VERSION . " PHP version:" . PHP_VERSION . "\n", FILE_APPEND); - file_put_contents(self::$_statisticsFile, 'start time:' . date('Y-m-d H:i:s', - self::$_globalStatistics['start_timestamp']) . ' run ' . floor((time() - self::$_globalStatistics['start_timestamp']) / (24 * 60 * 60)) . ' days ' . floor(((time() - self::$_globalStatistics['start_timestamp']) % (24 * 60 * 60)) / (60 * 60)) . " hours \n", - FILE_APPEND); - $load_str = 'load average: ' . implode(", ", $loadavg); - file_put_contents(self::$_statisticsFile, - str_pad($load_str, 33) . 'event-loop:' . self::getEventLoopName() . "\n", FILE_APPEND); - file_put_contents(self::$_statisticsFile, - count(self::$_pidMap) . ' workers ' . count(self::getAllWorkerPids()) . " processes\n", - FILE_APPEND); - file_put_contents(self::$_statisticsFile, - str_pad('worker_name', self::$_maxWorkerNameLength) . " exit_status exit_count\n", FILE_APPEND); - foreach (self::$_pidMap as $worker_id => $worker_pid_array) { - $worker = self::$_workers[$worker_id]; - if (isset(self::$_globalStatistics['worker_exit_info'][$worker_id])) { - foreach (self::$_globalStatistics['worker_exit_info'][$worker_id] as $worker_exit_status => $worker_exit_count) { - file_put_contents(self::$_statisticsFile, - str_pad($worker->name, self::$_maxWorkerNameLength) . " " . str_pad($worker_exit_status, - 16) . " $worker_exit_count\n", FILE_APPEND); - } - } else { - file_put_contents(self::$_statisticsFile, - str_pad($worker->name, self::$_maxWorkerNameLength) . " " . str_pad(0, 16) . " 0\n", - FILE_APPEND); - } - } - file_put_contents(self::$_statisticsFile, - "---------------------------------------PROCESS STATUS-------------------------------------------\n", - FILE_APPEND); - file_put_contents(self::$_statisticsFile, - "pid\tmemory " . str_pad('listening', self::$_maxSocketNameLength) . " " . str_pad('worker_name', - self::$_maxWorkerNameLength) . " connections " . str_pad('total_request', - 13) . " " . str_pad('send_fail', 9) . " " . str_pad('throw_exception', 15) . "\n", FILE_APPEND); - - chmod(self::$_statisticsFile, 0722); - - foreach (self::getAllWorkerPids() as $worker_pid) { - posix_kill($worker_pid, SIGUSR2); - } - return; - } - - // For child processes. - /** @var Worker $worker */ - $worker = current(self::$_workers); - $worker_status_str = posix_getpid() . "\t" . str_pad(round(memory_get_usage(true) / (1024 * 1024), 2) . "M", - 7) . " " . str_pad($worker->getSocketName(), - self::$_maxSocketNameLength) . " " . str_pad(($worker->name === $worker->getSocketName() ? 'none' : $worker->name), - self::$_maxWorkerNameLength) . " "; - $worker_status_str .= str_pad(ConnectionInterface::$statistics['connection_count'], - 11) . " " . str_pad(ConnectionInterface::$statistics['total_request'], - 14) . " " . str_pad(ConnectionInterface::$statistics['send_fail'], - 9) . " " . str_pad(ConnectionInterface::$statistics['throw_exception'], 15) . "\n"; - file_put_contents(self::$_statisticsFile, $worker_status_str, FILE_APPEND); - } - - /** - * Check errors when current process exited. - * - * @return void - */ - public static function checkErrors() - { - if (self::STATUS_SHUTDOWN != self::$_status) { - $error_msg = "WORKER EXIT UNEXPECTED "; - $errors = error_get_last(); - if ($errors && ($errors['type'] === E_ERROR || - $errors['type'] === E_PARSE || - $errors['type'] === E_CORE_ERROR || - $errors['type'] === E_COMPILE_ERROR || - $errors['type'] === E_RECOVERABLE_ERROR) - ) { - $error_msg .= self::getErrorType($errors['type']) . " {$errors['message']} in {$errors['file']} on line {$errors['line']}"; - } - self::log($error_msg); - } - } - - /** - * Get error message by error code. - * - * @param integer $type - * @return string - */ - protected static function getErrorType($type) - { - switch ($type) { - case E_ERROR: // 1 // - return 'E_ERROR'; - case E_WARNING: // 2 // - return 'E_WARNING'; - case E_PARSE: // 4 // - return 'E_PARSE'; - case E_NOTICE: // 8 // - return 'E_NOTICE'; - case E_CORE_ERROR: // 16 // - return 'E_CORE_ERROR'; - case E_CORE_WARNING: // 32 // - return 'E_CORE_WARNING'; - case E_COMPILE_ERROR: // 64 // - return 'E_COMPILE_ERROR'; - case E_COMPILE_WARNING: // 128 // - return 'E_COMPILE_WARNING'; - case E_USER_ERROR: // 256 // - return 'E_USER_ERROR'; - case E_USER_WARNING: // 512 // - return 'E_USER_WARNING'; - case E_USER_NOTICE: // 1024 // - return 'E_USER_NOTICE'; - case E_STRICT: // 2048 // - return 'E_STRICT'; - case E_RECOVERABLE_ERROR: // 4096 // - return 'E_RECOVERABLE_ERROR'; - case E_DEPRECATED: // 8192 // - return 'E_DEPRECATED'; - case E_USER_DEPRECATED: // 16384 // - return 'E_USER_DEPRECATED'; - } - return ""; - } - - /** - * Log. - * - * @param string $msg - * @return void - */ - public static function log($msg) - { - $msg = $msg . "\n"; - if (!self::$daemonize) { - self::safeEcho($msg); - } - file_put_contents((string)self::$logFile, date('Y-m-d H:i:s') . ' ' . 'pid:'. posix_getpid() . ' ' . $msg, FILE_APPEND | LOCK_EX); - } - - /** - * Safe Echo. - * - * @param $msg - */ - public static function safeEcho($msg) - { - if (!function_exists('posix_isatty') || posix_isatty(STDOUT)) { - echo $msg; - } - } - - /** - * Construct. - * - * @param string $socket_name - * @param array $context_option - */ - public function __construct($socket_name = '', $context_option = array()) - { - // Save all worker instances. - $this->workerId = spl_object_hash($this); - self::$_workers[$this->workerId] = $this; - self::$_pidMap[$this->workerId] = array(); - - // Get autoload root path. - $backtrace = debug_backtrace(); - $this->_autoloadRootPath = dirname($backtrace[0]['file']); - - // Context for socket. - if ($socket_name) { - $this->_socketName = $socket_name; - if (!isset($context_option['socket']['backlog'])) { - $context_option['socket']['backlog'] = self::DEFAULT_BACKLOG; - } - $this->_context = stream_context_create($context_option); - } - - // Set an empty onMessage callback. - $this->onMessage = function () { - }; - } - - /** - * Listen port. - * - * @throws Exception - */ - public function listen() - { - if (!$this->_socketName || $this->_mainSocket) { - return; - } - - // Autoload. - Autoloader::setRootPath($this->_autoloadRootPath); - - // Get the application layer communication protocol and listening address. - list($scheme, $address) = explode(':', $this->_socketName, 2); - // Check application layer protocol class. - if (!isset(self::$_builtinTransports[$scheme])) { - if(class_exists($scheme)){ - $this->protocol = $scheme; - } else { - $scheme = ucfirst($scheme); - $this->protocol = '\\Protocols\\' . $scheme; - if (!class_exists($this->protocol)) { - $this->protocol = "\\Workerman\\Protocols\\$scheme"; - if (!class_exists($this->protocol)) { - throw new Exception("class \\Protocols\\$scheme not exist"); - } - } - } - if (!isset(self::$_builtinTransports[$this->transport])) { - throw new \Exception('Bad worker->transport ' . var_export($this->transport, true)); - } - } else { - $this->transport = $scheme; - } - - $local_socket = self::$_builtinTransports[$this->transport] . ":" . $address; - - // Flag. - $flags = $this->transport === 'udp' ? STREAM_SERVER_BIND : STREAM_SERVER_BIND | STREAM_SERVER_LISTEN; - $errno = 0; - $errmsg = ''; - // SO_REUSEPORT. - if ($this->reusePort) { - stream_context_set_option($this->_context, 'socket', 'so_reuseport', 1); - } - - // Create an Internet or Unix domain server socket. - $this->_mainSocket = stream_socket_server($local_socket, $errno, $errmsg, $flags, $this->_context); - if (!$this->_mainSocket) { - throw new Exception($errmsg); - } - - if ($this->transport === 'ssl') { - stream_socket_enable_crypto($this->_mainSocket, false); - } - - // Try to open keepalive for tcp and disable Nagle algorithm. - if (function_exists('socket_import_stream') && self::$_builtinTransports[$this->transport] === 'tcp') { - $socket = socket_import_stream($this->_mainSocket); - @socket_set_option($socket, SOL_SOCKET, SO_KEEPALIVE, 1); - @socket_set_option($socket, SOL_TCP, TCP_NODELAY, 1); - } - - // Non blocking. - stream_set_blocking($this->_mainSocket, 0); - - // Register a listener to be notified when server socket is ready to read. - if (self::$globalEvent) { - if ($this->transport !== 'udp') { - self::$globalEvent->add($this->_mainSocket, EventInterface::EV_READ, array($this, 'acceptConnection')); - } else { - self::$globalEvent->add($this->_mainSocket, EventInterface::EV_READ, - array($this, 'acceptUdpConnection')); - } - } - } - - /** - * Get socket name. - * - * @return string - */ - public function getSocketName() - { - return $this->_socketName ? lcfirst($this->_socketName) : 'none'; - } - - /** - * Run worker instance. - * - * @return void - */ - public function run() - { - //Update process state. - self::$_status = self::STATUS_RUNNING; - - // Register shutdown function for checking errors. - register_shutdown_function(array("\\Workerman\\Worker", 'checkErrors')); - - // Set autoload root path. - Autoloader::setRootPath($this->_autoloadRootPath); - - // Create a global event loop. - if (!self::$globalEvent) { - $eventLoopClass = "\\Workerman\\Events\\" . ucfirst(self::getEventLoopName()); - self::$globalEvent = new $eventLoopClass; - // Register a listener to be notified when server socket is ready to read. - if ($this->_socketName) { - if ($this->transport !== 'udp') { - self::$globalEvent->add($this->_mainSocket, EventInterface::EV_READ, - array($this, 'acceptConnection')); - } else { - self::$globalEvent->add($this->_mainSocket, EventInterface::EV_READ, - array($this, 'acceptUdpConnection')); - } - } - } - - // Reinstall signal. - self::reinstallSignal(); - - // Init Timer. - Timer::init(self::$globalEvent); - - // Try to emit onWorkerStart callback. - if ($this->onWorkerStart) { - try { - call_user_func($this->onWorkerStart, $this); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - - // Main loop. - self::$globalEvent->loop(); - } - - /** - * Stop current worker instance. - * - * @return void - */ - public function stop() - { - // Try to emit onWorkerStop callback. - if ($this->onWorkerStop) { - try { - call_user_func($this->onWorkerStop, $this); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - // Remove listener for server socket. - self::$globalEvent->del($this->_mainSocket, EventInterface::EV_READ); - @fclose($this->_mainSocket); - } - - /** - * Accept a connection. - * - * @param resource $socket - * @return void - */ - public function acceptConnection($socket) - { - // Accept a connection on server socket. - $new_socket = @stream_socket_accept($socket, 0, $remote_address); - // Thundering herd. - if (!$new_socket) { - return; - } - - // TcpConnection. - $connection = new TcpConnection($new_socket, $remote_address); - $this->connections[$connection->id] = $connection; - $connection->worker = $this; - $connection->protocol = $this->protocol; - $connection->transport = $this->transport; - $connection->onMessage = $this->onMessage; - $connection->onClose = $this->onClose; - $connection->onError = $this->onError; - $connection->onBufferDrain = $this->onBufferDrain; - $connection->onBufferFull = $this->onBufferFull; - - // Try to emit onConnect callback. - if ($this->onConnect) { - try { - call_user_func($this->onConnect, $connection); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - } - - /** - * For udp package. - * - * @param resource $socket - * @return bool - */ - public function acceptUdpConnection($socket) - { - $recv_buffer = stream_socket_recvfrom($socket, self::MAX_UDP_PACKAGE_SIZE, 0, $remote_address); - if (false === $recv_buffer || empty($remote_address)) { - return false; - } - // UdpConnection. - $connection = new UdpConnection($socket, $remote_address); - $connection->protocol = $this->protocol; - if ($this->onMessage) { - if ($this->protocol) { - $parser = $this->protocol; - $recv_buffer = $parser::decode($recv_buffer, $connection); - // Discard bad packets. - if ($recv_buffer === false) - return true; - } - ConnectionInterface::$statistics['total_request']++; - try { - call_user_func($this->onMessage, $connection, $recv_buffer); - } catch (\Exception $e) { - self::log($e); - exit(250); - } catch (\Error $e) { - self::log($e); - exit(250); - } - } - return true; - } -} diff --git a/vendor/workerman/workerman/composer.json b/vendor/workerman/workerman/composer.json deleted file mode 100644 index 733ab8a6c..000000000 --- a/vendor/workerman/workerman/composer.json +++ /dev/null @@ -1,33 +0,0 @@ -{ - "name" : "workerman/workerman", - "type" : "library", - "keywords": ["event-loop", "asynchronous"], - "homepage": "http://www.workerman.net", - "license" : "MIT", - "description": "An asynchronous event driven PHP framework for easily building fast, scalable network applications.", - "authors" : [ - { - "name" : "walkor", - "email" : "walkor@workerman.net", - "homepage" : "http://www.workerman.net", - "role": "Developer" - } - ], - "support" : { - "email" : "walkor@workerman.net", - "issues": "https://github.com/walkor/workerman/issues", - "forum" : "http://wenda.workerman.net/", - "wiki" : "http://doc3.workerman.net/index.html", - "source": "https://github.com/walkor/workerman" - }, - "require": { - "php": ">=5.3" - }, - "suggest": { - "ext-event": "For better performance." - }, - "autoload": { - "psr-4": {"Workerman\\": "./"} - }, - "minimum-stability":"dev" -}