UploadController.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810
  1. <?php
  2. namespace api\controllers;
  3. use app\common\controllers\AController;
  4. use app\modules\admin\models\Attachment;
  5. use app\modules\cms\models\Category;
  6. use app\modules\doc\models\Doc;
  7. use app\modules\doc\models\DocData;
  8. use app\modules\doc\models\DocReal;
  9. use app\modules\doc\models\DocRealData;
  10. use app\modules\doc\models\DocCol;
  11. use app\modules\ucenter\models\UserNum;
  12. use Yii;
  13. class UploadController extends AController
  14. {
  15. public function init()
  16. {
  17. parent::init();
  18. }
  19. //发布单个文档
  20. public function actionSingle()
  21. {
  22. $url = self::urlList('myupload');
  23. $doc = new Doc();
  24. $docData = new DocData();
  25. if($doc->load($this->post)){
  26. $result = $this->_checkRights($doc->is_ad);
  27. if($result['error']==0)
  28. {
  29. if($doc->cat_id)
  30. {
  31. $category = Category::findOne($doc->cat_id);
  32. $parent_cat_ids = explode(",",$category->arr_parent_ids);
  33. $doc->doc_type = 1;
  34. $doc->status = 0;
  35. $doc->stars = 3;
  36. $doc->parent_cat_id = intval($parent_cat_ids[1]);
  37. $doc->root_cat_id = intval($parent_cat_ids[count($parent_cat_ids)-1]);
  38. if(!empty($category->arr_parent_ids))
  39. {
  40. $doc->cat_ids = ",".join(",",array_reverse($parent_cat_ids)).",";
  41. }
  42. else
  43. {
  44. $doc->cat_ids = ",".$doc->cat_id.",";
  45. }
  46. $doc->user_id = $this->user->user_id;
  47. $doc->user_name = $this->user->user_name;
  48. $doc->create_time = TIMESTAMP;
  49. $doc->update_time = TIMESTAMP;
  50. if(!$doc->validate())
  51. {
  52. $result = [
  53. 'error' => 1,
  54. 'msg' => $doc->returnFirstError(),
  55. 'data'=>[]
  56. ];
  57. }
  58. else
  59. {
  60. //tag更新
  61. if(empty($doc->tags))
  62. {
  63. $doc->tags = initTags($doc);
  64. }
  65. if($doc->save())
  66. {
  67. $docData->id = $doc->id;
  68. $docData->load($this->post);
  69. if(empty($docData->content))$docData->content = '';
  70. if(!$docData->validate())
  71. {
  72. $result = [
  73. 'error' => 1,
  74. 'msg' => $docData->returnFirstError(),
  75. 'data'=>[]
  76. ];
  77. }
  78. else
  79. {
  80. if($docData->save())
  81. {
  82. if($docData->file)Attachment::relateAttachmentByTable($docData->file,$docData->shortTableName(),'file',$doc->id);
  83. if($doc->thumb)Attachment::relateAttachmentByTable($doc->thumb,$doc->shortTableName(),'thumb',$doc->id);
  84. if($doc->tags)refreshTag($doc->tags,$doc->shortTableName(),$doc->id,$doc->user_id);
  85. $this->user->refreshData($this->user->user_id);
  86. $this->_refreshNum('doc_uploadnum');
  87. $result = [
  88. 'error' => 0,
  89. 'msg' => '恭喜您,上传成功',
  90. 'data' => ['url'=>$url],
  91. 'code'=>200
  92. ];
  93. }
  94. else
  95. {
  96. $result = [
  97. 'error' => 1,
  98. 'msg' => '上传失败',
  99. 'data'=>[]
  100. ];
  101. }
  102. }
  103. }
  104. else
  105. {
  106. $result = [
  107. 'error' => 1,
  108. 'msg' => '上传失败',
  109. 'data'=>[]
  110. ];
  111. }
  112. }
  113. }
  114. else
  115. {
  116. $result = [
  117. 'error' => 1,
  118. 'msg' => '请求出错,缺少必要参数',
  119. 'data' => [],
  120. 'code'=>200
  121. ];
  122. }
  123. }
  124. }
  125. else
  126. {
  127. $result = [
  128. 'error' => 1,
  129. 'msg' => '请求出错,缺少必要参数',
  130. 'data' => [],
  131. 'code'=>200
  132. ];
  133. }
  134. return $result;
  135. }
  136. //发布合辑
  137. public function actionCollect()
  138. {
  139. $url = self::urlList('myupload');
  140. $id = Yii::$app->request->post('id',0);
  141. if($id)
  142. {
  143. $doc = DocReal::findOne($id);
  144. $docData = DocRealData::findOne($id);
  145. $checkResult = $this->checkRights($this->user_id,$doc);
  146. if($checkResult['error']==1)
  147. {
  148. return $checkResult;
  149. }
  150. }
  151. else
  152. {
  153. $doc = new Doc();
  154. $docData = new DocData();
  155. }
  156. if($doc->load($this->post)){
  157. $result = $this->_checkRights(0,$id);
  158. if($result['error']==0)
  159. {
  160. if($doc->cat_id)
  161. {
  162. $category = Category::findOne($doc->cat_id);
  163. $parent_cat_ids = explode(",",$category->arr_parent_ids);
  164. $doc->status = 0;
  165. $doc->stars = 3;
  166. $doc->parent_cat_id = intval($parent_cat_ids[1]);
  167. $doc->root_cat_id = intval($parent_cat_ids[count($parent_cat_ids)-1]);
  168. if(!empty($category->arr_parent_ids))
  169. {
  170. $doc->cat_ids = ",".join(",",array_reverse($parent_cat_ids)).",";
  171. }
  172. else
  173. {
  174. $doc->cat_ids = ",".$doc->cat_id.",";
  175. }
  176. $doc->user_id = $this->user->user_id;
  177. $doc->user_name = $this->user->user_name;
  178. if($id==0)$doc->create_time = TIMESTAMP;
  179. $doc->update_time = TIMESTAMP;
  180. if(!$doc->validate())
  181. {
  182. $result = [
  183. 'error' => 0,
  184. 'msg' => $doc->returnFirstError(),
  185. 'data'=>[]
  186. ];
  187. }
  188. else
  189. {
  190. //tag更新
  191. if(empty($doc->tags))
  192. {
  193. $doc->tags = initTags($doc);
  194. }
  195. if($doc->save())
  196. {
  197. $docData->id = $doc->id;
  198. $docData->load($this->post);
  199. if(empty($docData->content))$docData->content = '';
  200. if(!$docData->validate())
  201. {
  202. $result = [
  203. 'error' => 1,
  204. 'msg' => $docData->returnFirstError(),
  205. 'data'=>[]
  206. ];
  207. }
  208. else
  209. {
  210. if($docData->save())
  211. {
  212. //合辑关联文档数据
  213. if(!empty($docData->docs))
  214. {
  215. $docIds = explode(",",$docData->docs);
  216. $doc->doc_num = count($docIds);
  217. //写合辑文档关联表
  218. $multiInsertData = [];
  219. if(is_array($docIds))foreach($docIds as $docId)
  220. {
  221. $multiInsertData[] = ['col_id' => $doc->id,'doc_id' => $docId];
  222. }
  223. if(!empty($multiInsertData))
  224. {
  225. Yii::$app->db->createCommand()->batchInsert(DocCol::tableName(), ['col_id', 'doc_id'], $multiInsertData)->execute();
  226. }
  227. }
  228. else
  229. {
  230. $doc->doc_num = 0;
  231. }
  232. $doc->save();
  233. if($doc->thumb)Attachment::relateAttachmentByTable($doc->thumb,$doc->shortTableName(),'thumb',$doc->id);
  234. if($doc->tags)refreshTag($doc->tags,$doc->shortTableName(),$doc->id,$doc->user_id);
  235. $this->user->refreshData($this->user->user_id);
  236. if($id==0)$this->_refreshNum('doc_uploadnum');
  237. $result = [
  238. 'error' => 0,
  239. 'msg' => '恭喜您,发布成功',
  240. 'data' => ['url'=>$url],
  241. 'code'=>200
  242. ];
  243. }
  244. else
  245. {
  246. $result = [
  247. 'error' => 1,
  248. 'msg' => '发布失败',
  249. 'data'=>[]
  250. ];
  251. }
  252. }
  253. }
  254. else
  255. {
  256. $result = [
  257. 'error' => 1,
  258. 'msg' => '发布失败',
  259. 'data'=>[]
  260. ];
  261. }
  262. }
  263. }
  264. else
  265. {
  266. $result = [
  267. 'error' => 1,
  268. 'msg' => '请求出错,缺少必要参数',
  269. 'data' => [],
  270. 'code'=>200
  271. ];
  272. }
  273. }
  274. }
  275. else
  276. {
  277. $result = [
  278. 'error' => 1,
  279. 'msg' => '请求出错,缺少必要参数',
  280. 'data' => [],
  281. 'code'=>200
  282. ];
  283. }
  284. return $result;
  285. }
  286. //发布资源
  287. public function actionSource()
  288. {
  289. $url = self::urlList('myupload');
  290. $id = Yii::$app->request->post('id',0);
  291. if($id)
  292. {
  293. $doc = DocReal::findOne($id);
  294. $docData = DocRealData::findOne($id);
  295. $checkResult = $this->checkRights($this->user_id,$doc);
  296. if($checkResult['error']==1)
  297. {
  298. return $checkResult;
  299. }
  300. }
  301. else
  302. {
  303. $doc = new Doc();
  304. $docData = new DocData();
  305. }
  306. if($doc->load($this->post)){
  307. $result = $this->_checkRights(0,$id);
  308. if($result['error']==0)
  309. {
  310. if($doc->cat_id)
  311. {
  312. $category = Category::findOne($doc->cat_id);
  313. $parent_cat_ids = explode(",",$category->arr_parent_ids);
  314. $doc->status = 0;
  315. $doc->stars = 3;
  316. $doc->parent_cat_id = intval($parent_cat_ids[1]);
  317. $doc->root_cat_id = intval($parent_cat_ids[count($parent_cat_ids)-1]);
  318. if(!empty($category->arr_parent_ids))
  319. {
  320. $doc->cat_ids = ",".join(",",array_reverse($parent_cat_ids)).",";
  321. }
  322. else
  323. {
  324. $doc->cat_ids = ",".$doc->cat_id.",";
  325. }
  326. $doc->user_id = $this->user->user_id;
  327. $doc->user_name = $this->user->user_name;
  328. if($id==0)$doc->create_time = TIMESTAMP;
  329. $doc->update_time = TIMESTAMP;
  330. if(!$doc->validate())
  331. {
  332. $result = [
  333. 'error' => 0,
  334. 'msg' => $doc->returnFirstError(),
  335. 'data'=>[]
  336. ];
  337. }
  338. else
  339. {
  340. //tag更新
  341. if(empty($doc->tags))
  342. {
  343. $doc->tags = initTags($doc);
  344. }
  345. if($doc->save())
  346. {
  347. $docData->id = $doc->id;
  348. $docData->load($this->post);
  349. if(empty($docData->content))$docData->content = '';
  350. if(!$docData->validate())
  351. {
  352. $result = [
  353. 'error' => 1,
  354. 'msg' => $docData->returnFirstError(),
  355. 'data'=>[]
  356. ];
  357. }
  358. else
  359. {
  360. if($docData->save())
  361. {
  362. if($doc->thumb)Attachment::relateAttachmentByTable($doc->thumb,$doc->shortTableName(),'thumb',$doc->id);
  363. if($doc->tags)refreshTag($doc->tags,$doc->shortTableName(),$doc->id,$doc->user_id);
  364. $this->user->refreshData($this->user->user_id);
  365. if($id==0)$this->_refreshNum('doc_uploadnum');
  366. $result = [
  367. 'error' => 0,
  368. 'msg' => '恭喜您,发布成功',
  369. 'data' => ['url'=>$url],
  370. 'code'=>200
  371. ];
  372. }
  373. else
  374. {
  375. $result = [
  376. 'error' => 1,
  377. 'msg' => '发布失败',
  378. 'data'=>[]
  379. ];
  380. }
  381. }
  382. }
  383. else
  384. {
  385. $result = [
  386. 'error' => 1,
  387. 'msg' => '发布失败',
  388. 'data'=>[]
  389. ];
  390. }
  391. }
  392. }
  393. else
  394. {
  395. $result = [
  396. 'error' => 1,
  397. 'msg' => '请求出错,缺少必要参数',
  398. 'data' => [],
  399. 'code'=>200
  400. ];
  401. }
  402. }
  403. }
  404. else
  405. {
  406. $result = [
  407. 'error' => 1,
  408. 'msg' => '请求出错,缺少必要参数',
  409. 'data' => [],
  410. 'code'=>200
  411. ];
  412. }
  413. return $result;
  414. }
  415. //批量上传
  416. public function actionMulti()
  417. {
  418. $url = self::urlList('myupload');
  419. $doc = new Doc();
  420. $docData = new DocData();
  421. if($doc->load($this->post)){
  422. $result = $this->_checkRights($doc->is_ad);
  423. if($result['error']==0)
  424. {
  425. $cat_id = $this->post['cat_id'];
  426. if($cat_id)
  427. {
  428. $category = Category::findOne($cat_id);
  429. $parent_cat_ids = explode(",",$category->arr_parent_ids);
  430. $doc->cat_id =$cat_id;
  431. $doc->doc_type = 1;
  432. $doc->status = 0;
  433. $doc->stars = 3;
  434. $doc->parent_cat_id = intval($parent_cat_ids[1]);
  435. $doc->root_cat_id = intval($parent_cat_ids[count($parent_cat_ids)-1]);
  436. if(!empty($category->arr_parent_ids))
  437. {
  438. $doc->cat_ids = ",".join(",",array_reverse($parent_cat_ids)).",";
  439. }
  440. else
  441. {
  442. $doc->cat_ids = ",".$doc->cat_id.",";
  443. }
  444. $doc->user_id = $this->user->user_id;
  445. $doc->user_name = $this->user->user_name;
  446. $doc->create_time = TIMESTAMP;
  447. $doc->update_time = TIMESTAMP;
  448. if(!$doc->validate())
  449. {
  450. $result = [
  451. 'error' => 1,
  452. 'msg' => $doc->returnFirstError(),
  453. 'data'=>[]
  454. ];
  455. }
  456. else
  457. {
  458. //tag更新
  459. if(empty($doc->tags))
  460. {
  461. $doc->tags = initTags($doc);
  462. }
  463. if($doc->save())
  464. {
  465. $docData->id = $doc->id;
  466. $docData->load($this->post);
  467. if(empty($docData->content))$docData->content = '';
  468. if(!$docData->validate())
  469. {
  470. $result = [
  471. 'error' => 1,
  472. 'msg' => $docData->returnFirstError(),
  473. 'data'=>[]
  474. ];
  475. }
  476. else
  477. {
  478. if($docData->save())
  479. {
  480. if($docData->file)Attachment::relateAttachmentByTable($docData->file,$docData->shortTableName(),'file',$doc->id);
  481. if($doc->tags)refreshTag($doc->tags,$doc->shortTableName(),$doc->id,$doc->user_id);
  482. $this->user->refreshData($this->user->user_id);
  483. $this->_refreshNum('doc_uploadnum');
  484. $result = [
  485. 'error' => 0,
  486. 'msg' => '恭喜您,上传成功',
  487. 'data' => ['url'=>$url],
  488. 'code'=>200
  489. ];
  490. }
  491. else
  492. {
  493. $result = [
  494. 'error' => 1,
  495. 'msg' => '上传失败',
  496. 'data'=>[]
  497. ];
  498. }
  499. }
  500. }
  501. else
  502. {
  503. $result = [
  504. 'error' => 1,
  505. 'msg' => '上传失败',
  506. 'data'=>[]
  507. ];
  508. }
  509. }
  510. }
  511. else
  512. {
  513. $result = [
  514. 'error' => 1,
  515. 'msg' => '请求出错,缺少必要参数',
  516. 'data' => [],
  517. 'code'=>200
  518. ];
  519. }
  520. }
  521. }
  522. else
  523. {
  524. $result = [
  525. 'error' => 1,
  526. 'msg' => '请求出错,缺少必要参数',
  527. 'data' => [],
  528. 'code'=>200
  529. ];
  530. }
  531. return $result;
  532. }
  533. private function _checkRights($is_ad=0,$id=0)
  534. {
  535. $userInfo = $this->userInfo;
  536. if($userInfo['is_lock'])
  537. {
  538. return [
  539. 'error' => 1,
  540. 'msg' => '您的账户已被锁定,请联系管理员',
  541. 'data' => [],
  542. 'code'=>200
  543. ];
  544. }
  545. if($userInfo['is_delete'])
  546. {
  547. return [
  548. 'error' => 1,
  549. 'msg' => '您的账户已被永久禁用,请联系管理员',
  550. 'data' => [],
  551. 'code'=>200
  552. ];
  553. }
  554. if(!$userInfo['open_upload'])
  555. {
  556. return [
  557. 'error' => 1,
  558. 'msg' => '您没有上传权限,请联系管理员',
  559. 'data' => [],
  560. 'code'=>200
  561. ];
  562. }
  563. if($id==0)
  564. {
  565. //上传数量限制
  566. $max_space = $userInfo['group_rights']['doc_max_space'];
  567. $upload_limit_day = $userInfo['group_rights']['doc_uploadnum_day'];
  568. $userNum = UserNum::find()->where("user_id=".$this->user_id." and date='".get_date(TIMESTAMP,'Y-m-d')."'")->one();
  569. if($max_space==-1)
  570. {
  571. return [
  572. 'error' => 1,
  573. 'msg' => '您已被禁止上传',
  574. 'data' => [],
  575. 'code'=>200
  576. ];
  577. }
  578. if(!empty($userNum))
  579. {
  580. if($upload_limit_day>0&&$userNum->doc_uploadnum>=$upload_limit_day)
  581. {
  582. return [
  583. 'error' => 1,
  584. 'msg' => '您已达到今日上传数量上限,上传失败',
  585. 'data' => [],
  586. 'code'=>200
  587. ];
  588. }
  589. }
  590. //对推广文档进行限制判断
  591. if($is_ad==1)
  592. {
  593. $org_vip_settings = $userInfo['org_vip_settings'];
  594. if($org_vip_settings){
  595. $adDocNum = DocReal::find()->where("user_id=".$this->user_id." and is_ad=1 and status=1")->count();
  596. if($adDocNum>=$org_vip_settings['ad_doc_num'])
  597. {
  598. return [
  599. 'error' => 1,
  600. 'msg' => '您已达到推广'.$this->docname.'发布数量上限,请升级VIP',
  601. 'data' => [],
  602. 'code'=>200
  603. ];
  604. }
  605. }
  606. }
  607. }
  608. return [
  609. 'error' => 0,
  610. 'msg' => '允许上传',
  611. 'data' => [],
  612. 'code'=>200
  613. ];
  614. }
  615. public function actionDoctitlecheck()
  616. {
  617. if($this->docconfig['forbidden_title'])
  618. {
  619. $title = safe_replace(Yii::$app->request->get('title'));
  620. $exist = DocReal::find()->where("title='".$title."' and is_delete=0")->one();
  621. $exist1 = Doc::find()->where("title='".$title."' and is_delete=0")->one();
  622. if($exist||$exist1){
  623. $result = [
  624. 'error' => 2,
  625. 'msg' => '已存在相同标题文件',
  626. 'data'=>[]
  627. ];
  628. }
  629. else
  630. {
  631. $result = [
  632. 'error' => 0,
  633. 'msg' => '',
  634. 'data'=>[]
  635. ];
  636. }
  637. }
  638. else
  639. {
  640. $result = [
  641. 'error' => 0,
  642. 'msg' => '',
  643. 'data'=>[]
  644. ];
  645. }
  646. return $result;
  647. }
  648. //内容md5值重复检测
  649. public function actionDocmd5check()
  650. {
  651. $md5 = safe_replace(Yii::$app->request->get('md5'));
  652. $title = safe_replace(Yii::$app->request->get('title'));
  653. $exist = DocReal::find()->where("md5='".$md5."' and is_delete=0")->one();
  654. $exist1 = Doc::find()->where("md5='".$md5."' and is_delete=0")->one();
  655. if($exist||$exist1)
  656. {
  657. $result = [
  658. 'error' => 1,
  659. 'msg' => '已存在相同内容文件',
  660. 'data'=>[]
  661. ];
  662. }
  663. else
  664. {
  665. if(!empty($title))
  666. {
  667. if($this->docconfig['forbidden_title'])
  668. {
  669. $exist = DocReal::find()->where("title='".$title."' and is_delete=0")->one();
  670. $exist1 = Doc::find()->where("title='".$title."' and is_delete=0")->one();
  671. }
  672. if($exist||$exist1){
  673. $result = [
  674. 'error' => 2,
  675. 'msg' => '已存在相同标题文件',
  676. 'data'=>[]
  677. ];
  678. }
  679. else
  680. {
  681. //敏感词检测
  682. if($this->badwordconfig['open'])
  683. {
  684. $sesResult = sensitive($title);
  685. }
  686. else
  687. {
  688. $sesResult = [];
  689. }
  690. if(!empty($sesResult))
  691. {
  692. if($sesResult['log3'])
  693. {
  694. $result = [
  695. 'error' => 1,
  696. 'msg' => $sesResult['log3'],
  697. 'data'=>[]
  698. ];
  699. }
  700. else if($sesResult['log2'])
  701. {
  702. $result = [
  703. 'error' => 1,
  704. 'msg' => $sesResult['log2'],
  705. 'data'=>[]
  706. ];
  707. }
  708. else if($sesResult['log1'])
  709. {
  710. $result = [
  711. 'error' => 1,
  712. 'msg' => $sesResult['log1'],
  713. 'data'=>[]
  714. ];
  715. }
  716. }
  717. else
  718. {
  719. $result = [
  720. 'error' => 0,
  721. 'msg' => '',
  722. 'data'=>[]
  723. ];
  724. }
  725. }
  726. }
  727. else
  728. {
  729. $result = [
  730. 'error' => 0,
  731. 'msg' => '',
  732. 'data'=>[]
  733. ];
  734. }
  735. }
  736. return $result;
  737. }
  738. private function _refreshNum($filed)
  739. {
  740. $userNum = UserNum::find()->where("user_id=".$this->user_id." and date='".get_date(TIMESTAMP,'Y-m-d')."'")->one();
  741. if(!empty($userNum))
  742. {
  743. $userNum->$filed++;
  744. $userNum->save();
  745. }
  746. else
  747. {
  748. $userNum = new UserNum();
  749. $userNum->date = get_date(TIMESTAMP,'Y-m-d');
  750. $userNum->user_id = $this->user_id;
  751. $userNum->$filed = 1;
  752. $userNum->save();
  753. }
  754. }
  755. }