add: Task model and database table

pull/95/head
HFO4 7 years ago
parent 61910ccf35
commit 159ee86b60

@ -0,0 +1,31 @@
<?php
namespace app\index\model;
use think\Model;
use think\Db;
use \app\index\model\Option;
class Task extends Model{
public $taskModel;
public $taskName;
public $taskType;
public $taskContent;
public function __construct($id=null){
if($id!==null){
}
}
public function saveTask(){
Db::name("task")->insert([
"task_name" => $this->taskName,
"attr" => $this->taskContent,
"type" => $this->taskType,
"status" => "todo",
]);
}
}
?>

@ -8,6 +8,7 @@ use think\Db;
use Qiniu\Auth; use Qiniu\Auth;
use \app\index\model\Option; use \app\index\model\Option;
use \app\index\model\FileManage; use \app\index\model\FileManage;
use \app\index\model\Task;
class UploadHandler extends Model{ class UploadHandler extends Model{
@ -183,12 +184,36 @@ class UploadHandler extends Model{
); );
@list($width, $height, $type, $attr) = getimagesize(rtrim($savePath, DS).DS.$Uploadinfo->getSaveName()); @list($width, $height, $type, $attr) = getimagesize(rtrim($savePath, DS).DS.$Uploadinfo->getSaveName());
$picInfo = empty($width)?" ":$width.",".$height; $picInfo = empty($width)?" ":$width.",".$height;
//处理Onedrive等非直传
if($this->policyContent['policy_type'] == "onedrive"){
$task = new Task();
$task->taskName = "Upload" . $info["name"] . "to Onedrive";
$task->taskType = "uploadSingleToOnedrive";
$task->taskContent = json_encode([
"path" => $info["path"],
"fname" => $info["name"],
"objname" => $generatePath."/".$Uploadinfo->getSaveName(),
"fsize" => $Uploadinfo->getSize(),
"picInfo" => $picInfo,
"policyId" => $this->policyContent['id']
]);
$task->saveTask();
echo json_encode(array("key" => $info["name"]));
return;
}
//向数据库中添加文件记录
$addAction = FileManage::addFile($jsonData,$this->policyContent,$this->userId,$picInfo); $addAction = FileManage::addFile($jsonData,$this->policyContent,$this->userId,$picInfo);
if(!$addAction[0]){ if(!$addAction[0]){
$tmpFileName = $Uploadinfo->getSaveName(); $tmpFileName = $Uploadinfo->getSaveName();
unset($Uploadinfo); unset($Uploadinfo);
$this->setError($addAction[1],true,$tmpFileName,$savePath); $this->setError($addAction[1],true,$tmpFileName,$savePath);
} }
//扣除容量
FileManage::storageCheckOut($this->userId,$jsonData["fsize"],$Uploadinfo->getInfo('size')); FileManage::storageCheckOut($this->userId,$jsonData["fsize"],$Uploadinfo->getInfo('size'));
echo json_encode(array("key" => $info["name"])); echo json_encode(array("key" => $info["name"]));
}else{ }else{
@ -221,6 +246,9 @@ class UploadHandler extends Model{
case 'local': case 'local':
return $this->getLocalToken(); return $this->getLocalToken();
break; break;
case 'onedrive':
return $this->getLocalToken();
break;
case 'oss': case 'oss':
return $this->getOssToken(); return $this->getOssToken();
break; break;

@ -323,6 +323,18 @@ ALTER TABLE `sd_download`
-- --
-- Indexes for dumped tables -- Indexes for dumped tables
-- --
--
-- 表的结构 `sd_task`
--
CREATE TABLE `sd_task` (
`id` int(11) NOT NULL,
`task_name` text NOT NULL,
`attr` text NOT NULL,
`type` text NOT NULL,
`status` text NOT NULL,
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
-- --
-- Indexes for table `sd_callback` -- Indexes for table `sd_callback`
@ -335,7 +347,8 @@ ALTER TABLE `sd_callback`
-- --
ALTER TABLE `sd_chunks` ALTER TABLE `sd_chunks`
ADD PRIMARY KEY (`id`); ADD PRIMARY KEY (`id`);
ALTER TABLE `sd_task`
ADD PRIMARY KEY (`id`);
-- --
-- Indexes for table `sd_corn` -- Indexes for table `sd_corn`
-- --
@ -419,6 +432,8 @@ ALTER TABLE `sd_files`
-- --
ALTER TABLE `sd_folders` ALTER TABLE `sd_folders`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=2; MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=2;
ALTER TABLE `sd_task`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT;
-- --
-- 使用表AUTO_INCREMENT `sd_groups` -- 使用表AUTO_INCREMENT `sd_groups`
-- --

@ -183,7 +183,7 @@ function QiniuJsSDK() {
"https://up.qbox.me" "https://up.qbox.me"
] ]
}; };
}else if(uploadConfig.saveType == "local" || uploadConfig.saveType == "oss" ||uploadConfig.saveType == "upyun"||uploadConfig.saveType == "s3"|| uploadConfig.saveType == "remote"){ }else if(uploadConfig.saveType == "local" || uploadConfig.saveType == "oss" ||uploadConfig.saveType == "upyun"||uploadConfig.saveType == "s3"|| uploadConfig.saveType == "remote"||uploadConfig.saveType == "onedrive"){
qiniuUploadUrl = uploadConfig.upUrl; qiniuUploadUrl = uploadConfig.upUrl;
var qiniuUploadUrls = [uploadConfig.upUrl,]; var qiniuUploadUrls = [uploadConfig.upUrl,];
var qiniuUpHosts = { var qiniuUpHosts = {
@ -994,7 +994,7 @@ function QiniuJsSDK() {
'token': that.token, 'token': that.token,
'x:path': file.path 'x:path': file.path
}; };
}else if(uploadConfig.saveType == "local"){ }else if(uploadConfig.saveType == "local"||uploadConfig.saveType == "onedrive"){
multipart_params_obj = { multipart_params_obj = {
'path': file.path 'path': file.path
}; };
@ -1493,7 +1493,7 @@ function QiniuJsSDK() {
} }
} }
local_path = ""; local_path = "";
if(uploadConfig.saveType == "local"){ if(uploadConfig.saveType == "local"||uploadConfig.saveType == "onedrive"){
pathTmp = file.path; pathTmp = file.path;
if(file.path == ""){ if(file.path == ""){
pathTmp = "ROOTDIR"; pathTmp = "ROOTDIR";

Loading…
Cancel
Save