mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-04-05 19:41:44 +08:00
ComposerUpdate
This commit is contained in:
parent
d28b3900d7
commit
ab20784645
18
composer.lock
generated
18
composer.lock
generated
@ -595,16 +595,16 @@
|
||||
},
|
||||
{
|
||||
"name": "topthink/think-orm",
|
||||
"version": "v2.0.27",
|
||||
"version": "v2.0.28",
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/top-think/think-orm.git",
|
||||
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50"
|
||||
"reference": "ff5f112f5559497222f2716385b5a709ab82741b"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/top-think/think-orm/zipball/02affaaccade2cdd8bbb2d2f5d15e46113e6eb50",
|
||||
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50",
|
||||
"url": "https://api.github.com/repos/top-think/think-orm/zipball/ff5f112f5559497222f2716385b5a709ab82741b",
|
||||
"reference": "ff5f112f5559497222f2716385b5a709ab82741b",
|
||||
"shasum": "",
|
||||
"mirrors": [
|
||||
{
|
||||
@ -642,7 +642,7 @@
|
||||
"database",
|
||||
"orm"
|
||||
],
|
||||
"time": "2019-10-23T02:16:50+00:00"
|
||||
"time": "2019-11-17T07:53:45+00:00"
|
||||
},
|
||||
{
|
||||
"name": "topthink/think-template",
|
||||
@ -783,12 +783,12 @@
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/zoujingli/ThinkLibrary.git",
|
||||
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864"
|
||||
"reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/9e636a7be3d7c468cb73c40c48835bf51cef6864",
|
||||
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
|
||||
"reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
|
||||
"shasum": "",
|
||||
"mirrors": [
|
||||
{
|
||||
@ -832,7 +832,7 @@
|
||||
],
|
||||
"description": "ThinkPHP v6.0 Development Library",
|
||||
"homepage": "http://framework.thinkadmin.top",
|
||||
"time": "2019-11-18T11:43:36+00:00"
|
||||
"time": "2019-11-19T02:13:00+00:00"
|
||||
}
|
||||
],
|
||||
"packages-dev": [],
|
||||
|
2
vendor/autoload.php
vendored
2
vendor/autoload.php
vendored
@ -4,4 +4,4 @@
|
||||
|
||||
require_once __DIR__ . '/composer/autoload_real.php';
|
||||
|
||||
return ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9::getLoader();
|
||||
return ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142::getLoader();
|
||||
|
14
vendor/composer/autoload_real.php
vendored
14
vendor/composer/autoload_real.php
vendored
@ -2,7 +2,7 @@
|
||||
|
||||
// autoload_real.php @generated by Composer
|
||||
|
||||
class ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9
|
||||
class ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142
|
||||
{
|
||||
private static $loader;
|
||||
|
||||
@ -19,15 +19,15 @@ class ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9
|
||||
return self::$loader;
|
||||
}
|
||||
|
||||
spl_autoload_register(array('ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9', 'loadClassLoader'), true, true);
|
||||
spl_autoload_register(array('ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142', 'loadClassLoader'), true, true);
|
||||
self::$loader = $loader = new \Composer\Autoload\ClassLoader();
|
||||
spl_autoload_unregister(array('ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9', 'loadClassLoader'));
|
||||
spl_autoload_unregister(array('ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142', 'loadClassLoader'));
|
||||
|
||||
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
|
||||
if ($useStaticLoader) {
|
||||
require_once __DIR__ . '/autoload_static.php';
|
||||
|
||||
call_user_func(\Composer\Autoload\ComposerStaticInitdc48cac423beab724a7102138067b2f9::getInitializer($loader));
|
||||
call_user_func(\Composer\Autoload\ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::getInitializer($loader));
|
||||
} else {
|
||||
$map = require __DIR__ . '/autoload_namespaces.php';
|
||||
foreach ($map as $namespace => $path) {
|
||||
@ -48,19 +48,19 @@ class ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9
|
||||
$loader->register(true);
|
||||
|
||||
if ($useStaticLoader) {
|
||||
$includeFiles = Composer\Autoload\ComposerStaticInitdc48cac423beab724a7102138067b2f9::$files;
|
||||
$includeFiles = Composer\Autoload\ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$files;
|
||||
} else {
|
||||
$includeFiles = require __DIR__ . '/autoload_files.php';
|
||||
}
|
||||
foreach ($includeFiles as $fileIdentifier => $file) {
|
||||
composerRequiredc48cac423beab724a7102138067b2f9($fileIdentifier, $file);
|
||||
composerRequire927a7ea59f5590e9e57c74d6ecc97142($fileIdentifier, $file);
|
||||
}
|
||||
|
||||
return $loader;
|
||||
}
|
||||
}
|
||||
|
||||
function composerRequiredc48cac423beab724a7102138067b2f9($fileIdentifier, $file)
|
||||
function composerRequire927a7ea59f5590e9e57c74d6ecc97142($fileIdentifier, $file)
|
||||
{
|
||||
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
|
||||
require $file;
|
||||
|
8
vendor/composer/autoload_static.php
vendored
8
vendor/composer/autoload_static.php
vendored
@ -4,7 +4,7 @@
|
||||
|
||||
namespace Composer\Autoload;
|
||||
|
||||
class ComposerStaticInitdc48cac423beab724a7102138067b2f9
|
||||
class ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142
|
||||
{
|
||||
public static $files = array (
|
||||
'9b552a3cc426e3287cc811caefa3cf53' => __DIR__ . '/..' . '/topthink/think-helper/src/helper.php',
|
||||
@ -470,9 +470,9 @@ class ComposerStaticInitdc48cac423beab724a7102138067b2f9
|
||||
public static function getInitializer(ClassLoader $loader)
|
||||
{
|
||||
return \Closure::bind(function () use ($loader) {
|
||||
$loader->prefixLengthsPsr4 = ComposerStaticInitdc48cac423beab724a7102138067b2f9::$prefixLengthsPsr4;
|
||||
$loader->prefixDirsPsr4 = ComposerStaticInitdc48cac423beab724a7102138067b2f9::$prefixDirsPsr4;
|
||||
$loader->classMap = ComposerStaticInitdc48cac423beab724a7102138067b2f9::$classMap;
|
||||
$loader->prefixLengthsPsr4 = ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$prefixLengthsPsr4;
|
||||
$loader->prefixDirsPsr4 = ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$prefixDirsPsr4;
|
||||
$loader->classMap = ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$classMap;
|
||||
|
||||
}, null, ClassLoader::class);
|
||||
}
|
||||
|
20
vendor/composer/installed.json
vendored
20
vendor/composer/installed.json
vendored
@ -608,17 +608,17 @@
|
||||
},
|
||||
{
|
||||
"name": "topthink/think-orm",
|
||||
"version": "v2.0.27",
|
||||
"version_normalized": "2.0.27.0",
|
||||
"version": "v2.0.28",
|
||||
"version_normalized": "2.0.28.0",
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/top-think/think-orm.git",
|
||||
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50"
|
||||
"reference": "ff5f112f5559497222f2716385b5a709ab82741b"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/top-think/think-orm/zipball/02affaaccade2cdd8bbb2d2f5d15e46113e6eb50",
|
||||
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50",
|
||||
"url": "https://api.github.com/repos/top-think/think-orm/zipball/ff5f112f5559497222f2716385b5a709ab82741b",
|
||||
"reference": "ff5f112f5559497222f2716385b5a709ab82741b",
|
||||
"shasum": "",
|
||||
"mirrors": [
|
||||
{
|
||||
@ -634,7 +634,7 @@
|
||||
"psr/simple-cache": "^1.0",
|
||||
"topthink/think-helper": "^3.1"
|
||||
},
|
||||
"time": "2019-10-23T02:16:50+00:00",
|
||||
"time": "2019-11-17T07:53:45+00:00",
|
||||
"type": "library",
|
||||
"installation-source": "dist",
|
||||
"autoload": {
|
||||
@ -805,12 +805,12 @@
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/zoujingli/ThinkLibrary.git",
|
||||
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864"
|
||||
"reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/9e636a7be3d7c468cb73c40c48835bf51cef6864",
|
||||
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864",
|
||||
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
|
||||
"reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
|
||||
"shasum": "",
|
||||
"mirrors": [
|
||||
{
|
||||
@ -826,7 +826,7 @@
|
||||
"ext-json": "*",
|
||||
"topthink/framework": "^6.0"
|
||||
},
|
||||
"time": "2019-11-18T11:43:36+00:00",
|
||||
"time": "2019-11-19T02:13:00+00:00",
|
||||
"type": "library",
|
||||
"extra": {
|
||||
"think": {
|
||||
|
2
vendor/services.php
vendored
2
vendor/services.php
vendored
@ -1,5 +1,5 @@
|
||||
<?php
|
||||
// This file is automatically generated at:2019-11-18 19:45:16
|
||||
// This file is automatically generated at:2019-11-19 10:15:33
|
||||
declare (strict_types = 1);
|
||||
return array (
|
||||
0 => 'think\\app\\Service',
|
||||
|
22
vendor/topthink/think-orm/src/Model.php
vendored
22
vendor/topthink/think-orm/src/Model.php
vendored
@ -85,6 +85,12 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
|
||||
*/
|
||||
protected $name;
|
||||
|
||||
/**
|
||||
* 主键值
|
||||
* @var string
|
||||
*/
|
||||
protected $key;
|
||||
|
||||
/**
|
||||
* 数据表名称
|
||||
* @var string
|
||||
@ -575,9 +581,13 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
|
||||
$db->startTrans();
|
||||
|
||||
try {
|
||||
$where = $this->getWhere();
|
||||
$this->key = null;
|
||||
$where = $this->getWhere();
|
||||
|
||||
$result = $db->where($where)
|
||||
->strict(false)
|
||||
->cache(true)
|
||||
->setOption('key', $this->key)
|
||||
->field($allowFields)
|
||||
->update($data);
|
||||
|
||||
@ -635,14 +645,15 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
|
||||
$result = $db->strict(false)
|
||||
->field($allowFields)
|
||||
->replace($this->replace)
|
||||
->insert($this->data, false, $sequence);
|
||||
->sequence($sequence)
|
||||
->insert($this->data, true);
|
||||
|
||||
// 获取自动增长主键
|
||||
if ($result && $insertId = $db->getLastInsID($sequence)) {
|
||||
if ($result) {
|
||||
$pk = $this->getPk();
|
||||
|
||||
if (is_string($pk) && (!isset($this->data[$pk]) || '' == $this->data[$pk])) {
|
||||
$this->data[$pk] = $insertId;
|
||||
$this->data[$pk] = $result;
|
||||
}
|
||||
}
|
||||
|
||||
@ -676,7 +687,8 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
|
||||
$pk = $this->getPk();
|
||||
|
||||
if (is_string($pk) && isset($this->data[$pk])) {
|
||||
$where = [[$pk, '=', $this->data[$pk]]];
|
||||
$where = [[$pk, '=', $this->data[$pk]]];
|
||||
$this->key = $this->data[$pk];
|
||||
} elseif (is_array($pk)) {
|
||||
foreach ($pk as $field) {
|
||||
if (isset($this->data[$field])) {
|
||||
|
20
vendor/topthink/think-orm/src/db/BaseQuery.php
vendored
20
vendor/topthink/think-orm/src/db/BaseQuery.php
vendored
@ -490,8 +490,8 @@ abstract class BaseQuery
|
||||
// 子查询
|
||||
} elseif (false === strpos($table, ',')) {
|
||||
if (strpos($table, ' ')) {
|
||||
list($item, $alias) = explode(' ', $table);
|
||||
$table = [];
|
||||
[$item, $alias] = explode(' ', $table);
|
||||
$table = [];
|
||||
$this->alias([$item => $alias]);
|
||||
$table[$item] = $alias;
|
||||
}
|
||||
@ -502,7 +502,7 @@ abstract class BaseQuery
|
||||
foreach ($tables as $item) {
|
||||
$item = trim($item);
|
||||
if (strpos($item, ' ')) {
|
||||
list($item, $alias) = explode(' ', $item);
|
||||
[$item, $alias] = explode(' ', $item);
|
||||
$this->alias([$item => $alias]);
|
||||
$table[$item] = $alias;
|
||||
} else {
|
||||
@ -750,10 +750,10 @@ abstract class BaseQuery
|
||||
* @access public
|
||||
* @param mixed $key 缓存key
|
||||
* @param integer|\DateTime $expire 缓存有效期
|
||||
* @param string $tag 缓存标签
|
||||
* @param string|array $tag 缓存标签
|
||||
* @return $this
|
||||
*/
|
||||
public function cache($key = true, $expire = null, string $tag = null)
|
||||
public function cache($key = true, $expire = null, $tag = null)
|
||||
{
|
||||
if (false === $key || !$this->getConnection()->getCache()) {
|
||||
return $this;
|
||||
@ -1179,11 +1179,11 @@ abstract class BaseQuery
|
||||
|
||||
if (isset($options['page'])) {
|
||||
// 根据页数计算limit
|
||||
list($page, $listRows) = $options['page'];
|
||||
$page = $page > 0 ? $page : 1;
|
||||
$listRows = $listRows ?: (is_numeric($options['limit']) ? $options['limit'] : 20);
|
||||
$offset = $listRows * ($page - 1);
|
||||
$options['limit'] = $offset . ',' . $listRows;
|
||||
[$page, $listRows] = $options['page'];
|
||||
$page = $page > 0 ? $page : 1;
|
||||
$listRows = $listRows ?: (is_numeric($options['limit']) ? $options['limit'] : 20);
|
||||
$offset = $listRows * ($page - 1);
|
||||
$options['limit'] = $offset . ',' . $listRows;
|
||||
}
|
||||
|
||||
$this->options = $options;
|
||||
|
16
vendor/topthink/think-orm/src/db/Builder.php
vendored
16
vendor/topthink/think-orm/src/db/Builder.php
vendored
@ -156,9 +156,9 @@ abstract class Builder
|
||||
}
|
||||
|
||||
if (false !== strpos($key, '->')) {
|
||||
list($key, $name) = explode('->', $key, 2);
|
||||
$item = $this->parseKey($query, $key);
|
||||
$result[$item] = 'json_set(' . $item . ', \'$.' . $name . '\', ' . $this->parseDataBind($query, $key . '->' . $name, $val, $bind) . ')';
|
||||
[$key, $name] = explode('->', $key, 2);
|
||||
$item = $this->parseKey($query, $key);
|
||||
$result[$item] = 'json_set(' . $item . ', \'$.' . $name . '\', ' . $this->parseDataBind($query, $key . '->' . $name, $val, $bind) . ')';
|
||||
} elseif (false === strpos($key, '.') && !in_array($key, $fields, true)) {
|
||||
if ($options['strict']) {
|
||||
throw new Exception('fields not exists:[' . $key . ']');
|
||||
@ -300,7 +300,7 @@ abstract class Builder
|
||||
|
||||
if (!empty($options['soft_delete'])) {
|
||||
// 附加软删除条件
|
||||
list($field, $condition) = $options['soft_delete'];
|
||||
[$field, $condition] = $options['soft_delete'];
|
||||
|
||||
$binds = $query->getFieldsBindType();
|
||||
$whereStr = $whereStr ? '( ' . $whereStr . ' ) AND ' : '';
|
||||
@ -591,7 +591,7 @@ abstract class Builder
|
||||
protected function parseColumn(Query $query, string $key, $exp, array $value, string $field, int $bindType): string
|
||||
{
|
||||
// 字段比较查询
|
||||
list($op, $field) = $value;
|
||||
[$op, $field] = $value;
|
||||
|
||||
if (!in_array(trim($op), ['=', '<>', '>', '>=', '<', '<='])) {
|
||||
throw new Exception('where express error:' . var_export($value, true));
|
||||
@ -802,7 +802,7 @@ abstract class Builder
|
||||
|
||||
// 获取时间字段类型
|
||||
if (strpos($key, '.')) {
|
||||
list($table, $key) = explode('.', $key);
|
||||
[$table, $key] = explode('.', $key);
|
||||
|
||||
if (isset($options['alias']) && $pos = array_search($table, $options['alias'])) {
|
||||
$table = $pos;
|
||||
@ -858,10 +858,10 @@ abstract class Builder
|
||||
$joinStr = '';
|
||||
|
||||
foreach ($join as $item) {
|
||||
list($table, $type, $on) = $item;
|
||||
[$table, $type, $on] = $item;
|
||||
|
||||
if (strpos($on, '=')) {
|
||||
list($val1, $val2) = explode('=', $on, 2);
|
||||
[$val1, $val2] = explode('=', $on, 2);
|
||||
|
||||
$condition = $this->parseKey($query, $val1) . '=' . $this->parseKey($query, $val2);
|
||||
} else {
|
||||
|
@ -96,7 +96,7 @@ class CacheItem
|
||||
/**
|
||||
* 获取缓存Tag
|
||||
* @access public
|
||||
* @return string
|
||||
* @return string|array
|
||||
*/
|
||||
public function getTag()
|
||||
{
|
||||
@ -139,10 +139,10 @@ class CacheItem
|
||||
/**
|
||||
* 为此缓存项设置所属标签
|
||||
* @access public
|
||||
* @param string $tag
|
||||
* @param string|array $tag
|
||||
* @return $this
|
||||
*/
|
||||
public function tag(string $tag = null)
|
||||
public function tag($tag = null)
|
||||
{
|
||||
$this->tag = $tag;
|
||||
return $this;
|
||||
|
@ -236,7 +236,7 @@ abstract class Connection
|
||||
*/
|
||||
protected function parseCache(BaseQuery $query, array $cache): CacheItem
|
||||
{
|
||||
list($key, $expire, $tag) = $cache;
|
||||
[$key, $expire, $tag] = $cache;
|
||||
|
||||
if ($key instanceof CacheItem) {
|
||||
$cacheItem = $key;
|
||||
|
2
vendor/topthink/think-orm/src/db/Fetch.php
vendored
2
vendor/topthink/think-orm/src/db/Fetch.php
vendored
@ -303,7 +303,7 @@ class Fetch
|
||||
|
||||
if (!empty($options['soft_delete'])) {
|
||||
// 软删除
|
||||
list($field, $condition) = $options['soft_delete'];
|
||||
[$field, $condition] = $options['soft_delete'];
|
||||
if ($condition) {
|
||||
$this->query->setOption('soft_delete', null);
|
||||
$this->query->setOption('data', [$field => $condition]);
|
||||
|
28
vendor/topthink/think-orm/src/db/Mongo.php
vendored
28
vendor/topthink/think-orm/src/db/Mongo.php
vendored
@ -615,7 +615,7 @@ class Mongo extends BaseQuery
|
||||
$query = $this->options($options)->limit($count);
|
||||
|
||||
if (strpos($column, '.')) {
|
||||
list($alias, $key) = explode('.', $column);
|
||||
[$alias, $key] = explode('.', $column);
|
||||
} else {
|
||||
$key = $column;
|
||||
}
|
||||
@ -712,4 +712,30 @@ class Mongo extends BaseQuery
|
||||
return $options;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取字段类型信息
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getFieldsType(): array
|
||||
{
|
||||
if (!empty($this->options['field_type'])) {
|
||||
return $this->options['field_type'];
|
||||
}
|
||||
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取字段类型信息
|
||||
* @access public
|
||||
* @param string $field 字段名
|
||||
* @return string|null
|
||||
*/
|
||||
public function getFieldType(string $field)
|
||||
{
|
||||
$fieldType = $this->getFieldsType();
|
||||
|
||||
return $fieldType[$field] ?? null;
|
||||
}
|
||||
}
|
||||
|
@ -98,6 +98,12 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
|
||||
*/
|
||||
protected $transTimes = 0;
|
||||
|
||||
/**
|
||||
* 重连次数
|
||||
* @var int
|
||||
*/
|
||||
protected $reConnectTimes = 0;
|
||||
|
||||
/**
|
||||
* 查询结果类型
|
||||
* @var int
|
||||
@ -329,7 +335,7 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
|
||||
return [];
|
||||
}
|
||||
|
||||
list($tableName) = explode(' ', $tableName);
|
||||
[$tableName] = explode(' ', $tableName);
|
||||
|
||||
if (!strpos($tableName, '.')) {
|
||||
$schema = $this->getConfig('database') . '.' . $tableName;
|
||||
@ -703,9 +709,12 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
|
||||
$this->trigger('', $master);
|
||||
}
|
||||
|
||||
$this->reConnectTimes = 0;
|
||||
|
||||
return $this->PDOStatement;
|
||||
} catch (\Throwable | \Exception $e) {
|
||||
if ($this->isBreak($e)) {
|
||||
if ($this->reConnectTimes < 4 && $this->isBreak($e)) {
|
||||
++$this->reConnectTimes;
|
||||
return $this->close()->getPDOStatement($sql, $bind, $master, $procedure);
|
||||
}
|
||||
|
||||
@ -1070,7 +1079,7 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
|
||||
public function aggregate(BaseQuery $query, string $aggregate, $field, bool $force = false)
|
||||
{
|
||||
if (is_string($field) && 0 === stripos($field, 'DISTINCT ')) {
|
||||
list($distinct, $field) = explode(' ', $field);
|
||||
[$distinct, $field] = explode(' ', $field);
|
||||
}
|
||||
|
||||
$field = $aggregate . '(' . (!empty($distinct) ? 'DISTINCT ' : '') . $this->builder->parseKey($query, $field, true) . ') AS think_' . strtolower($aggregate);
|
||||
@ -1141,11 +1150,11 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
|
||||
if (strpos($column, ',')) {
|
||||
$column = null;
|
||||
} elseif (strpos($column, '.')) {
|
||||
list($alias, $column) = explode('.', $column);
|
||||
[$alias, $column] = explode('.', $column);
|
||||
}
|
||||
|
||||
if (strpos($key, '.')) {
|
||||
list($alias, $key) = explode('.', $key);
|
||||
[$alias, $key] = explode('.', $key);
|
||||
}
|
||||
|
||||
$result = array_column($resultSet, $column, $key);
|
||||
@ -1348,9 +1357,11 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
|
||||
$this->parseSavepoint('trans' . $this->transTimes)
|
||||
);
|
||||
}
|
||||
$this->reConnectTimes = 0;
|
||||
} catch (\Exception $e) {
|
||||
if ($this->isBreak($e)) {
|
||||
if ($this->reConnectTimes < 4 && $this->isBreak($e)) {
|
||||
--$this->transTimes;
|
||||
++$this->reConnectTimes;
|
||||
$this->close()->startTrans();
|
||||
}
|
||||
throw $e;
|
||||
|
2
vendor/topthink/think-orm/src/db/Query.php
vendored
2
vendor/topthink/think-orm/src/db/Query.php
vendored
@ -460,7 +460,7 @@ class Query extends BaseQuery
|
||||
$query = $this->options($options)->limit($count);
|
||||
|
||||
if (strpos($column, '.')) {
|
||||
list($alias, $key) = explode('.', $column);
|
||||
[$alias, $key] = explode('.', $column);
|
||||
} else {
|
||||
$key = $column;
|
||||
}
|
||||
|
@ -58,7 +58,7 @@ class Mongo
|
||||
protected function parseKey(Query $query, string $key): string
|
||||
{
|
||||
if (0 === strpos($key, '__TABLE__.')) {
|
||||
list($collection, $key) = explode('.', $key, 2);
|
||||
[$collection, $key] = explode('.', $key, 2);
|
||||
}
|
||||
|
||||
if ('id' == $key && $this->connection->getConfig('pk_convert_id')) {
|
||||
@ -205,8 +205,8 @@ class Mongo
|
||||
$options = $query->getOptions();
|
||||
if (!empty($options['soft_delete'])) {
|
||||
// 附加软删除条件
|
||||
list($field, $condition) = $options['soft_delete'];
|
||||
$filter['$and'][] = $this->parseWhereItem($query, $field, $condition);
|
||||
[$field, $condition] = $options['soft_delete'];
|
||||
$filter['$and'][] = $this->parseWhereItem($query, $field, $condition);
|
||||
}
|
||||
|
||||
return $filter;
|
||||
@ -220,7 +220,7 @@ class Mongo
|
||||
if (!is_array($val)) {
|
||||
$val = ['=', $val];
|
||||
}
|
||||
list($exp, $value) = $val;
|
||||
[$exp, $value] = $val;
|
||||
|
||||
// 对一个字段使用多个查询条件
|
||||
if (is_array($exp)) {
|
||||
@ -523,8 +523,8 @@ class Mongo
|
||||
*/
|
||||
public function aggregate(Query $query, array $extra): Command
|
||||
{
|
||||
$options = $query->getOptions();
|
||||
list($fun, $field) = $extra;
|
||||
$options = $query->getOptions();
|
||||
[$fun, $field] = $extra;
|
||||
|
||||
if ('id' == $field && $this->connection->getConfig('pk_convert_id')) {
|
||||
$field = '_id';
|
||||
@ -568,7 +568,7 @@ class Mongo
|
||||
{
|
||||
$options = $query->getOptions();
|
||||
|
||||
list($aggregate, $groupBy) = $extra;
|
||||
[$aggregate, $groupBy] = $extra;
|
||||
|
||||
$groups = ['_id' => []];
|
||||
|
||||
|
@ -315,10 +315,10 @@ class Mysql extends Builder
|
||||
|
||||
if (strpos($key, '->') && false === strpos($key, '(')) {
|
||||
// JSON字段支持
|
||||
list($field, $name) = explode('->', $key, 2);
|
||||
[$field, $name] = explode('->', $key, 2);
|
||||
return 'json_extract(' . $this->parseKey($query, $field) . ', \'$' . (strpos($name, '[') === 0 ? '' : '.') . str_replace('->', '.', $name) . '\')';
|
||||
} elseif (strpos($key, '.') && !preg_match('/[,\'\"\(\)`\s]/', $key)) {
|
||||
list($table, $key) = explode('.', $key, 2);
|
||||
[$table, $key] = explode('.', $key, 2);
|
||||
|
||||
$alias = $query->getOptions('alias');
|
||||
|
||||
|
@ -75,8 +75,8 @@ class Oracle extends Builder
|
||||
|
||||
if (strpos($key, '->') && false === strpos($key, '(')) {
|
||||
// JSON字段支持
|
||||
list($field, $name) = explode($key, '->');
|
||||
$key = $field . '."' . $name . '"';
|
||||
[$field, $name] = explode($key, '->');
|
||||
$key = $field . '."' . $name . '"';
|
||||
}
|
||||
|
||||
return $key;
|
||||
|
@ -76,10 +76,10 @@ class Pgsql extends Builder
|
||||
|
||||
if (strpos($key, '->') && false === strpos($key, '(')) {
|
||||
// JSON字段支持
|
||||
list($field, $name) = explode('->', $key);
|
||||
$key = '"' . $field . '"' . '->>\'' . $name . '\'';
|
||||
[$field, $name] = explode('->', $key);
|
||||
$key = '"' . $field . '"' . '->>\'' . $name . '\'';
|
||||
} elseif (strpos($key, '.')) {
|
||||
list($table, $key) = explode('.', $key, 2);
|
||||
[$table, $key] = explode('.', $key, 2);
|
||||
|
||||
$alias = $query->getOptions('alias');
|
||||
|
||||
|
@ -74,7 +74,7 @@ class Sqlite extends Builder
|
||||
$key = trim($key);
|
||||
|
||||
if (strpos($key, '.')) {
|
||||
list($table, $key) = explode('.', $key, 2);
|
||||
[$table, $key] = explode('.', $key, 2);
|
||||
|
||||
$alias = $query->getOptions('alias');
|
||||
|
||||
|
@ -78,7 +78,7 @@ class Sqlsrv extends Builder
|
||||
$array[] = $this->parseRand($query);
|
||||
} else {
|
||||
if (is_numeric($key)) {
|
||||
list($key, $sort) = explode(' ', strpos($val, ' ') ? $val : $val . ' ');
|
||||
[$key, $sort] = explode(' ', strpos($val, ' ') ? $val : $val . ' ');
|
||||
} else {
|
||||
$sort = $val;
|
||||
}
|
||||
@ -121,7 +121,7 @@ class Sqlsrv extends Builder
|
||||
$key = trim($key);
|
||||
|
||||
if (strpos($key, '.') && !preg_match('/[,\'\"\(\)\[\s]/', $key)) {
|
||||
list($table, $key) = explode('.', $key, 2);
|
||||
[$table, $key] = explode('.', $key, 2);
|
||||
|
||||
$alias = $query->getOptions('alias');
|
||||
|
||||
|
@ -109,7 +109,7 @@ trait JoinAndViewQuery
|
||||
// 使用别名
|
||||
if (strpos($join, ' ')) {
|
||||
// 使用别名
|
||||
list($table, $alias) = explode(' ', $join);
|
||||
[$table, $alias] = explode(' ', $join);
|
||||
} else {
|
||||
$table = $join;
|
||||
if (false === strpos($join, '.')) {
|
||||
@ -209,7 +209,7 @@ trait JoinAndViewQuery
|
||||
foreach ($options['order'] as $key => $val) {
|
||||
if (is_numeric($key) && is_string($val)) {
|
||||
if (strpos($val, ' ')) {
|
||||
list($field, $sort) = explode(' ', $val);
|
||||
[$field, $sort] = explode(' ', $val);
|
||||
if (array_key_exists($field, $options['map'])) {
|
||||
$options['order'][$options['map'][$field]] = $sort;
|
||||
unset($options['order'][$key]);
|
||||
|
@ -414,7 +414,7 @@ trait ModelRelationQuery
|
||||
if (!empty($this->options['with_attr'])) {
|
||||
foreach ($this->options['with_attr'] as $name => $val) {
|
||||
if (strpos($name, '.')) {
|
||||
list($relation, $field) = explode('.', $name);
|
||||
[$relation, $field] = explode('.', $name);
|
||||
|
||||
$withRelationAttr[$relation][$field] = $val;
|
||||
unset($this->options['with_attr'][$name]);
|
||||
@ -458,7 +458,7 @@ trait ModelRelationQuery
|
||||
if (!empty($options['with_attr']) && empty($withRelationAttr)) {
|
||||
foreach ($options['with_attr'] as $name => $val) {
|
||||
if (strpos($name, '.')) {
|
||||
list($relation, $field) = explode('.', $name);
|
||||
[$relation, $field] = explode('.', $name);
|
||||
|
||||
$withRelationAttr[$relation][$field] = $val;
|
||||
unset($options['with_attr'][$name]);
|
||||
|
@ -130,7 +130,7 @@ trait ResultOperation
|
||||
|
||||
if (strpos($name, '.')) {
|
||||
// 支持JSON字段 获取器定义
|
||||
list($key, $field) = explode('.', $name);
|
||||
[$key, $field] = explode('.', $name);
|
||||
|
||||
if (isset($result[$key])) {
|
||||
$result[$key][$field] = $closure($result[$key][$field] ?? null, $result[$key]);
|
||||
|
@ -1011,6 +1011,17 @@ class Mongo extends Connection implements ConnectionInterface
|
||||
|
||||
return $this->command($command, $db);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取数据库字段
|
||||
* @access public
|
||||
* @param mixed $tableName 数据表名
|
||||
* @return array
|
||||
*/
|
||||
public function getTableFields($tableName): array
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* 执行数据库事务
|
||||
|
@ -53,7 +53,7 @@ class Mysql extends PDOConnection
|
||||
*/
|
||||
public function getFields(string $tableName): array
|
||||
{
|
||||
list($tableName) = explode(' ', $tableName);
|
||||
[$tableName] = explode(' ', $tableName);
|
||||
|
||||
if (false === strpos($tableName, '`')) {
|
||||
if (strpos($tableName, '.')) {
|
||||
|
@ -50,8 +50,8 @@ class Oracle extends PDOConnection
|
||||
*/
|
||||
public function getFields(string $tableName): array
|
||||
{
|
||||
list($tableName) = explode(' ', $tableName);
|
||||
$sql = "select a.column_name,data_type,DECODE (nullable, 'Y', 0, 1) notnull,data_default, DECODE (A .column_name,b.column_name,1,0) pk from all_tab_columns a,(select column_name from all_constraints c, all_cons_columns col where c.constraint_name = col.constraint_name and c.constraint_type = 'P' and c.table_name = '" . strtoupper($tableName) . "' ) b where table_name = '" . strtoupper($tableName) . "' and a.column_name = b.column_name (+)";
|
||||
[$tableName] = explode(' ', $tableName);
|
||||
$sql = "select a.column_name,data_type,DECODE (nullable, 'Y', 0, 1) notnull,data_default, DECODE (A .column_name,b.column_name,1,0) pk from all_tab_columns a,(select column_name from all_constraints c, all_cons_columns col where c.constraint_name = col.constraint_name and c.constraint_type = 'P' and c.table_name = '" . strtoupper($tableName) . "' ) b where table_name = '" . strtoupper($tableName) . "' and a.column_name = b.column_name (+)";
|
||||
|
||||
$pdo = $this->getPDOStatement($sql);
|
||||
$result = $pdo->fetchAll(PDO::FETCH_ASSOC);
|
||||
|
@ -56,8 +56,8 @@ class Pgsql extends PDOConnection
|
||||
*/
|
||||
public function getFields(string $tableName): array
|
||||
{
|
||||
list($tableName) = explode(' ', $tableName);
|
||||
$sql = 'select fields_name as "field",fields_type as "type",fields_not_null as "null",fields_key_name as "key",fields_default as "default",fields_default as "extra" from table_msg(\'' . $tableName . '\');';
|
||||
[$tableName] = explode(' ', $tableName);
|
||||
$sql = 'select fields_name as "field",fields_type as "type",fields_not_null as "null",fields_key_name as "key",fields_default as "default",fields_default as "extra" from table_msg(\'' . $tableName . '\');';
|
||||
|
||||
$pdo = $this->getPDOStatement($sql);
|
||||
$result = $pdo->fetchAll(PDO::FETCH_ASSOC);
|
||||
|
@ -41,8 +41,8 @@ class Sqlite extends PDOConnection
|
||||
*/
|
||||
public function getFields(string $tableName): array
|
||||
{
|
||||
list($tableName) = explode(' ', $tableName);
|
||||
$sql = 'PRAGMA table_info( ' . $tableName . ' )';
|
||||
[$tableName] = explode(' ', $tableName);
|
||||
$sql = 'PRAGMA table_info( ' . $tableName . ' )';
|
||||
|
||||
$pdo = $this->getPDOStatement($sql);
|
||||
$result = $pdo->fetchAll(PDO::FETCH_ASSOC);
|
||||
|
@ -55,7 +55,7 @@ class Sqlsrv extends PDOConnection
|
||||
*/
|
||||
public function getFields(string $tableName): array
|
||||
{
|
||||
list($tableName) = explode(' ', $tableName);
|
||||
[$tableName] = explode(' ', $tableName);
|
||||
|
||||
$sql = "SELECT column_name, data_type, column_default, is_nullable
|
||||
FROM information_schema.tables AS t
|
||||
|
@ -398,9 +398,9 @@ trait Attribute
|
||||
}
|
||||
|
||||
if (is_array($type)) {
|
||||
list($type, $param) = $type;
|
||||
[$type, $param] = $type;
|
||||
} elseif (strpos($type, ':')) {
|
||||
list($type, $param) = explode(':', $type, 2);
|
||||
[$type, $param] = explode(':', $type, 2);
|
||||
}
|
||||
|
||||
switch ($type) {
|
||||
@ -563,9 +563,9 @@ trait Attribute
|
||||
}
|
||||
|
||||
if (is_array($type)) {
|
||||
list($type, $param) = $type;
|
||||
[$type, $param] = $type;
|
||||
} elseif (strpos($type, ':')) {
|
||||
list($type, $param) = explode(':', $type, 2);
|
||||
[$type, $param] = explode(':', $type, 2);
|
||||
}
|
||||
|
||||
switch ($type) {
|
||||
@ -637,7 +637,7 @@ trait Attribute
|
||||
$name = $this->getRealFieldName($name);
|
||||
|
||||
if (strpos($name, '.')) {
|
||||
list($name, $key) = explode('.', $name);
|
||||
[$name, $key] = explode('.', $name);
|
||||
|
||||
$this->withAttr[$name][$key] = $callback;
|
||||
} else {
|
||||
|
@ -132,7 +132,7 @@ trait Conversion
|
||||
foreach ($this->visible as $key => $val) {
|
||||
if (is_string($val)) {
|
||||
if (strpos($val, '.')) {
|
||||
list($relation, $name) = explode('.', $val);
|
||||
[$relation, $name] = explode('.', $val);
|
||||
$this->visible[$relation][] = $name;
|
||||
} else {
|
||||
$this->visible[$val] = true;
|
||||
@ -145,7 +145,7 @@ trait Conversion
|
||||
foreach ($this->hidden as $key => $val) {
|
||||
if (is_string($val)) {
|
||||
if (strpos($val, '.')) {
|
||||
list($relation, $name) = explode('.', $val);
|
||||
[$relation, $name] = explode('.', $val);
|
||||
$this->hidden[$relation][] = $name;
|
||||
} else {
|
||||
$this->hidden[$val] = true;
|
||||
@ -192,7 +192,7 @@ trait Conversion
|
||||
$item[$key] = $relation ? $relation->append($name)
|
||||
->toArray() : [];
|
||||
} elseif (strpos($name, '.')) {
|
||||
list($key, $attr) = explode('.', $name);
|
||||
[$key, $attr] = explode('.', $name);
|
||||
// 追加关联对象属性
|
||||
$relation = $this->getRelation($key, true);
|
||||
$item[$key] = $relation ? $relation->append([$attr])
|
||||
|
@ -148,7 +148,7 @@ trait RelationShip
|
||||
$subRelation = $relation;
|
||||
$relation = $key;
|
||||
} elseif (strpos($relation, '.')) {
|
||||
list($relation, $subRelation) = explode('.', $relation, 2);
|
||||
[$relation, $subRelation] = explode('.', $relation, 2);
|
||||
}
|
||||
|
||||
$method = Str::camel($relation);
|
||||
@ -263,7 +263,7 @@ trait RelationShip
|
||||
$subRelation = $relation;
|
||||
$relation = $key;
|
||||
} elseif (strpos($relation, '.')) {
|
||||
list($relation, $subRelation) = explode('.', $relation, 2);
|
||||
[$relation, $subRelation] = explode('.', $relation, 2);
|
||||
|
||||
$subRelation = [$subRelation];
|
||||
}
|
||||
@ -312,7 +312,7 @@ trait RelationShip
|
||||
$subRelation = $relation;
|
||||
$relation = $key;
|
||||
} elseif (strpos($relation, '.')) {
|
||||
list($relation, $subRelation) = explode('.', $relation, 2);
|
||||
[$relation, $subRelation] = explode('.', $relation, 2);
|
||||
|
||||
$subRelation = [$subRelation];
|
||||
}
|
||||
@ -549,7 +549,7 @@ trait RelationShip
|
||||
}
|
||||
|
||||
if (is_array($morph)) {
|
||||
list($morphType, $foreignKey) = $morph;
|
||||
[$morphType, $foreignKey] = $morph;
|
||||
} else {
|
||||
$morphType = $morph . '_type';
|
||||
$foreignKey = $morph . '_id';
|
||||
@ -581,7 +581,7 @@ trait RelationShip
|
||||
$type = $type ?: get_class($this);
|
||||
|
||||
if (is_array($morph)) {
|
||||
list($morphType, $foreignKey) = $morph;
|
||||
[$morphType, $foreignKey] = $morph;
|
||||
} else {
|
||||
$morphType = $morph . '_type';
|
||||
$foreignKey = $morph . '_id';
|
||||
@ -608,7 +608,7 @@ trait RelationShip
|
||||
|
||||
// 记录当前关联信息
|
||||
if (is_array($morph)) {
|
||||
list($morphType, $foreignKey) = $morph;
|
||||
[$morphType, $foreignKey] = $morph;
|
||||
} else {
|
||||
$morphType = $morph . '_type';
|
||||
$foreignKey = $morph . '_id';
|
||||
|
@ -133,7 +133,7 @@ class BelongsToMany extends Relation
|
||||
|
||||
foreach ($model->getData() as $key => $val) {
|
||||
if (strpos($key, '__')) {
|
||||
list($name, $attr) = explode('__', $key, 2);
|
||||
[$name, $attr] = explode('__', $key, 2);
|
||||
|
||||
if ('pivot' == $name) {
|
||||
$pivot[$attr] = $val;
|
||||
@ -206,12 +206,11 @@ class BelongsToMany extends Relation
|
||||
* @access public
|
||||
* @param int|array $listRows
|
||||
* @param int|bool $simple
|
||||
* @param array $config
|
||||
* @return Paginator
|
||||
*/
|
||||
public function paginate($listRows = null, $simple = false, $config = []): Paginator
|
||||
public function paginate($listRows = null, $simple = false): Paginator
|
||||
{
|
||||
$result = $this->buildQuery()->paginate($listRows, $simple, $config);
|
||||
$result = $this->buildQuery()->paginate($listRows, $simple);
|
||||
$this->hydratePivot($result);
|
||||
|
||||
return $result;
|
||||
@ -448,7 +447,7 @@ class BelongsToMany extends Relation
|
||||
$pivot = [];
|
||||
foreach ($set->getData() as $key => $val) {
|
||||
if (strpos($key, '__')) {
|
||||
list($name, $attr) = explode('__', $key, 2);
|
||||
[$name, $attr] = explode('__', $key, 2);
|
||||
if ('pivot' == $name) {
|
||||
$pivot[$attr] = $val;
|
||||
unset($set->$key);
|
||||
|
@ -234,7 +234,7 @@ abstract class OneToOne extends Relation
|
||||
// 重新组装模型数据
|
||||
foreach ($result->getData() as $key => $val) {
|
||||
if (strpos($key, '__')) {
|
||||
list($name, $attr) = explode('__', $key, 2);
|
||||
[$name, $attr] = explode('__', $key, 2);
|
||||
if ($name == $relation) {
|
||||
$list[$name][$attr] = $val;
|
||||
unset($result->$key);
|
||||
|
@ -70,7 +70,7 @@ abstract class Helper
|
||||
* @param array $args 额外参数
|
||||
* @return static
|
||||
*/
|
||||
public static function instance($args = [])
|
||||
public static function instance(array $args = [])
|
||||
{
|
||||
return Container::getInstance()->invokeClass(static::class, $args);
|
||||
}
|
||||
|
35
vendor/zoujingli/think-library/src/Library.php
vendored
35
vendor/zoujingli/think-library/src/Library.php
vendored
@ -28,32 +28,21 @@ use think\Service;
|
||||
class Library extends Service
|
||||
{
|
||||
/**
|
||||
* 服务注册
|
||||
* 注册服务
|
||||
*/
|
||||
public function register()
|
||||
{
|
||||
// 注册会话中间键
|
||||
$this->app->middleware->add(SessionInit::class);
|
||||
// 动态加入应用函数
|
||||
foreach (glob($this->app->getAppPath() . '*/sys.php') as $file) {
|
||||
\Composer\Autoload\includeFile($file);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 服务启动
|
||||
*/
|
||||
public function boot()
|
||||
{
|
||||
// 注册访问中间键
|
||||
if (!$this->app->request->isCli()) {
|
||||
if (PHP_SAPI !== 'cli') {
|
||||
// 注册会话中间键
|
||||
$this->app->middleware->add(SessionInit::class);
|
||||
// 注册访问中间键
|
||||
$this->app->middleware->add(function (Request $request, \Closure $next) {
|
||||
$header = [];
|
||||
if (($origin = $request->header('origin', '*')) !== '*') {
|
||||
$header['Access-Control-Allow-Origin'] = $origin;
|
||||
$header['Access-Control-Allow-Methods'] = 'GET,POST,PATCH,PUT,DELETE';
|
||||
$header['Access-Control-Allow-Headers'] = 'Authorization,Content-Type,If-Match,If-Modified-Since,If-None-Match,If-Unmodified-Since,X-Requested-With';
|
||||
$header['Access-Control-Expose-Headers'] = 'User-Form-Token';
|
||||
$header['Access-Control-Expose-Headers'] = 'User-Form-Token,User-Token,Token';
|
||||
}
|
||||
// 访问模式及访问权限检查
|
||||
if ($request->isOptions()) {
|
||||
@ -67,6 +56,17 @@ class Library extends Service
|
||||
}
|
||||
}, 'route');
|
||||
}
|
||||
// 动态加入应用函数
|
||||
foreach (glob($this->app->getAppPath() . '*/sys.php') as $file) {
|
||||
\Composer\Autoload\includeFile($file);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 启动服务
|
||||
*/
|
||||
public function boot()
|
||||
{
|
||||
// 注册系统任务指令
|
||||
$this->commands([
|
||||
'think\admin\queue\WorkQueue',
|
||||
@ -78,5 +78,4 @@ class Library extends Service
|
||||
'think\admin\command\Install',
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
@ -64,7 +64,7 @@ class Install extends Command
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:install');
|
||||
$this->setDescription("[安装]在线安装或更新指定模块文件");
|
||||
$this->setDescription("[安装]安装或更新指定模块");
|
||||
$this->addArgument('name', Argument::OPTIONAL, '模块名称', '');
|
||||
}
|
||||
|
||||
|
@ -32,7 +32,7 @@ class ListenQueue extends Command
|
||||
*/
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:listen')->setDescription('[监听]常驻异步任务循环监听主进程');
|
||||
$this->setName('xtask:listen')->setDescription('[监听]启动任务监听主进程');
|
||||
}
|
||||
|
||||
/**
|
||||
@ -46,10 +46,10 @@ class ListenQueue extends Command
|
||||
protected function execute(Input $input, Output $output)
|
||||
{
|
||||
$this->app->db->name('SystemQueue')->count();
|
||||
if (($process = ProcessService::instance($this->app))->iswin()) {
|
||||
if (($process = ProcessService::instance())->iswin()) {
|
||||
$this->setProcessTitle("ThinkAdmin 监听主进程 {$process->version()}");
|
||||
}
|
||||
$output->comment('============ 异步任务监听中 ============');
|
||||
$output->comment('============ 任务监听中 ============');
|
||||
while (true) {
|
||||
foreach ($this->app->db->name('SystemQueue')->where([['status', '=', '1'], ['exec_time', '<=', time()]])->order('exec_time asc')->limit(100)->select() as $vo) {
|
||||
try {
|
||||
|
@ -32,7 +32,7 @@ class QueryQueue extends Command
|
||||
*/
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:query')->setDescription('[控制]查询正在执行的所有任务进程');
|
||||
$this->setName('xtask:query')->setDescription('[控制]查询正在运行的进程');
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -21,7 +21,7 @@ use think\console\Input;
|
||||
use think\console\Output;
|
||||
|
||||
/**
|
||||
* 检查并创建异步任务监听主进程
|
||||
* 检查并创建监听主进程
|
||||
* Class StartQueue
|
||||
* @package think\admin\queue
|
||||
*/
|
||||
@ -33,7 +33,7 @@ class StartQueue extends Command
|
||||
*/
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:start')->setDescription('[控制]创建异步任务守护监听主进程');
|
||||
$this->setName('xtask:start')->setDescription('[控制]创建守护监听主进程');
|
||||
}
|
||||
|
||||
/**
|
||||
@ -47,14 +47,14 @@ class StartQueue extends Command
|
||||
$process = ProcessService::instance();
|
||||
$command = $process->think("xtask:listen");
|
||||
if (count($result = $process->query($command)) > 0) {
|
||||
$output->info("异步任务监听主进程{$result['0']['pid']}已经启动!");
|
||||
$output->info("监听主进程{$result['0']['pid']}已经启动!");
|
||||
} else {
|
||||
$process->create($command);
|
||||
sleep(1);
|
||||
if (count($result = $process->query($command)) > 0) {
|
||||
$output->info("异步任务监听主进程{$result['0']['pid']}启动成功!");
|
||||
$output->info("监听主进程{$result['0']['pid']}启动成功!");
|
||||
} else {
|
||||
$output->error('异步任务监听主进程创建失败!');
|
||||
$output->error('监听主进程创建失败!');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -32,7 +32,7 @@ class StateQueue extends Command
|
||||
*/
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:state')->setDescription('[控制]查看异步任务监听主进程状态');
|
||||
$this->setName('xtask:state')->setDescription('[控制]查看监听主进程状态');
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -33,7 +33,7 @@ class StopQueue extends Command
|
||||
*/
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:stop')->setDescription('[控制]平滑停止所有的异步任务进程');
|
||||
$this->setName('xtask:stop')->setDescription('[控制]平滑停止所有的进程');
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -48,7 +48,7 @@ class WorkQueue extends Command
|
||||
*/
|
||||
protected function configure()
|
||||
{
|
||||
$this->setName('xtask:_work')->setDescription('[执行]创建执行单个指定任务的进程');
|
||||
$this->setName('xtask:_work')->setDescription('[执行]创建指令任务的进程');
|
||||
$this->addArgument('code', Argument::OPTIONAL, '任务编号');
|
||||
$this->addArgument('splt', Argument::OPTIONAL, '指令结束符');
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user