Article.php 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <?php
  2. namespace app\common\model;
  3. use think\Db;
  4. class Article extends Base
  5. {
  6. protected $createTime = 'create_time';
  7. protected $updateTime = 'update_time';
  8. public $table = 'article';
  9. protected $validateName = 'Article';
  10. public function updates(){
  11. $data = request()->post();
  12. $data['org_id'] =cur_org_id();
  13. $result = validate($this->validateName)->check($data,[],'');
  14. if(true !== $result){
  15. $this->error = validate($this->validateName)->getError();
  16. return false;
  17. }
  18. $s = explode('.',$data['path']);
  19. $a = $s[count($s)-1];
  20. if($a!='pdf'){
  21. $this->error = '只能上传pdf文件';
  22. return false;
  23. }
  24. $id = $data['id'];
  25. unset($data['id']);
  26. if($id > 0){
  27. $data['update_time'] = date('Y-m-d H:i:s');
  28. $ret = $this->allowField(true)->save($data,['id'=>$id]);
  29. }else{
  30. $data['create_time'] = date('Y-m-d H:i:s');
  31. $data['create_yyyy'] = date('Y');
  32. $data['create_mm'] = date('d');
  33. $data['create_yyyymmdd'] = date('Ymd');
  34. $ret = $this->allowField(true)->save($data);
  35. }
  36. if(!$ret){
  37. $this->error = '操作失败';
  38. return false;
  39. }
  40. return true;
  41. }
  42. public function getList(){
  43. $list =$this
  44. ->where('org_id',cur_org_id())
  45. ->where('del',0)
  46. ->where('enable',1)
  47. ->select()
  48. ->toArray();
  49. return $list;
  50. }
  51. /*----------API-----------*/
  52. public function lists($page,$size,$orgId,$roleId,$token){
  53. $offset = ($page - 1) * $size;
  54. $map[] = ['org_id','=',$orgId];
  55. $map[] = ['del','=',0];
  56. $map[] = ['enable','=',1];
  57. $parentId = Db::name('roles')
  58. ->where('id',$roleId)
  59. ->find();
  60. if($parentId['parent_id'] >0){
  61. $roleId = $parentId['parent_id'];
  62. }
  63. $m1 = $map;
  64. $m1[] = ['','exp', Db::raw("FIND_IN_SET({$roleId},roles_ids)")];
  65. $m2 = $map;
  66. $m2[] = ['roles_ids','=',null];
  67. $m3 = $map;
  68. $m3[] = ['roles_ids','=',''];
  69. $ret = $this->field('id,title,view,create_time,path,description as descrip,cate_id,limit,org_id')
  70. ->whereOr([ $m1, $m2, $m3 ])
  71. ->limit($offset,$size)
  72. ->order(['sort'=>'desc','id'=>'desc'])
  73. ->select();
  74. $ret = $ret?$ret->toArray():[];
  75. $a = [];
  76. foreach ($ret as $k=>$v){
  77. $v['url']=getSite().'/h5/Index/article?id='.$v['id'].'&token='.$token.'&org_id='.$orgId;
  78. $a[] = formatArray(['id','title','url','descrip','limit','create_time']
  79. ,$v);
  80. }
  81. return $a;
  82. }
  83. }