Project.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <?php
  2. namespace App\Module;
  3. use DB;
  4. /**
  5. * Class Project
  6. * @package App\Module
  7. */
  8. class Project
  9. {
  10. /**
  11. * 是否在项目里
  12. * @param int $projectid
  13. * @param string $username
  14. * @param bool $isowner
  15. * @return array
  16. */
  17. public static function inThe($projectid, $username, $isowner = false)
  18. {
  19. $whereArray = [
  20. 'type' => '成员',
  21. 'projectid' => $projectid,
  22. 'username' => $username,
  23. ];
  24. if ($isowner) {
  25. $whereArray['isowner'] = 1;
  26. }
  27. $row = Base::DBC2A(DB::table('project_users')->select(['isowner', 'indate'])->where($whereArray)->first());
  28. if (empty($row)) {
  29. return Base::retError('你不在项目成员内!');
  30. } else {
  31. return Base::retSuccess('你在项目内', $row);
  32. }
  33. }
  34. /**
  35. * 更新项目(complete、unfinished)
  36. * @param int $projectid
  37. */
  38. public static function updateNum($projectid)
  39. {
  40. if ($projectid > 0) {
  41. DB::table('project_lists')->where('id', $projectid)->update([
  42. 'unfinished' => DB::table('project_task')->where('projectid', $projectid)->where('complete', 0)->where('delete', 0)->count(),
  43. 'complete' => DB::table('project_task')->where('projectid', $projectid)->where('complete', 1)->where('delete', 0)->count(),
  44. ]);
  45. }
  46. }
  47. /**
  48. * 任务是否过期
  49. * @param array $task
  50. * @return int
  51. */
  52. public static function taskIsOverdue($task)
  53. {
  54. return $task['complete'] == 0 && $task['enddate'] > 0 && $task['enddate'] <= Base::time() ? 1 : 0;
  55. }
  56. /**
  57. * 过期的排在前
  58. * @param array $taskLists
  59. * @return mixed
  60. */
  61. public static function sortTask($taskLists)
  62. {
  63. $inOrder = [];
  64. foreach ($taskLists as $key => $oitem) {
  65. $inOrder[$key] = $oitem['overdue'] ? -1 : $key;
  66. }
  67. array_multisort($inOrder, SORT_ASC, $taskLists);
  68. return $taskLists;
  69. }
  70. /**
  71. * 获取跟任务有关系的用户(关注的、在项目里的、负责人、创建者)
  72. * @param $taskId
  73. * @return array
  74. */
  75. public static function taskSomeUsers($taskId)
  76. {
  77. $taskDeatil = Base::DBC2A(DB::table('project_task')->select(['follower', 'createuser', 'username', 'projectid'])->where('id', $taskId)->first());
  78. if (empty($taskDeatil)) {
  79. return [];
  80. }
  81. //关注的用户
  82. $userArray = Base::string2array($taskDeatil['follower']);
  83. //创建者
  84. $userArray[] = $taskDeatil['createuser'];
  85. //负责人
  86. $userArray[] = $taskDeatil['username'];
  87. //在项目里的用户
  88. if ($taskDeatil['projectid'] > 0) {
  89. $tempLists = Base::DBC2A(DB::table('project_users')->select(['username'])->where(['projectid' => $taskDeatil['projectid'], 'type' => '成员' ])->get());
  90. foreach ($tempLists AS $item) {
  91. $userArray[] = $item['username'];
  92. }
  93. }
  94. //
  95. return $userArray;
  96. }
  97. /**
  98. * 项目(任务)权限
  99. * @param $type
  100. * @param $projectid
  101. * @param int $taskid
  102. * @return array|mixed
  103. */
  104. public static function role($type, $projectid, $taskid = 0)
  105. {
  106. $user = Users::authE();
  107. if (Base::isError($user)) {
  108. return $user;
  109. } else {
  110. $user = $user['data'];
  111. }
  112. //
  113. $project = Base::DBC2A(DB::table('project_lists')->select(['username', 'setting'])->where('id', $projectid)->where('delete', 0)->first());
  114. if (empty($project)) {
  115. return Base::retError('项目不存在或已被删除!');
  116. }
  117. // 项目负责人最高权限
  118. if ($project['username'] == $user['username']) {
  119. return Base::retSuccess('success');
  120. }
  121. //
  122. $setting = Base::string2array($project['setting']);
  123. foreach (['edit_role', 'complete_role', 'archived_role', 'del_role'] AS $key) {
  124. $setting[$key] = is_array($setting[$key]) ? $setting[$key] : ['__', 'owner'];
  125. }
  126. $setting['add_role'] = is_array($setting['add_role']) ? $setting['add_role'] : ['__', 'member'];
  127. //
  128. $role = $setting[$type];
  129. if (empty($role) || !is_array($role)) {
  130. return Base::retError('操作权限不足!');
  131. }
  132. if (in_array('member', $role)) {
  133. $inRes = Project::inThe($projectid, $user['username']);
  134. if (Base::isError($inRes)) {
  135. return $inRes;
  136. }
  137. } elseif (in_array('owner', $role)) {
  138. if (empty($taskid)) {
  139. return Base::retError('任务不存在!');
  140. }
  141. $task = Base::DBC2A(DB::table('project_task')
  142. ->select(['username'])
  143. ->where([
  144. ['delete', '=', 0],
  145. ['id', '=', $taskid],
  146. ])
  147. ->first());
  148. if (empty($task)) {
  149. return Base::retError('任务不存在!');
  150. }
  151. if ($task['username'] != $user['username']) {
  152. return Base::retError('此操作只允许项目管理员或者任务负责人!');
  153. }
  154. } else {
  155. return Base::retError('此操作仅限项目负责人!');
  156. }
  157. //
  158. return Base::retSuccess('success');
  159. }
  160. }