StatusCodeModule.class.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. <?php
  2. /**
  3. * @name eolinker ams open source,eolinker开源版本
  4. * @link https://www.eolinker.com/
  5. * @package eolinker
  6. * @author www.eolinker.com 广州银云信息科技有限公司 ©2015-2018
  7. * eoLinker是目前全球领先、国内最大的在线API接口管理平台,提供自动生成API文档、API自动化测试、Mock测试、团队协作等功能,旨在解决由于前后端分离导致的开发效率低下问题。
  8. * 如在使用的过程中有任何问题,欢迎加入用户讨论群进行反馈,我们将会以最快的速度,最好的服务态度为您解决问题。
  9. *
  10. * eoLinker AMS开源版的开源协议遵循Apache License 2.0,如需获取最新的eolinker开源版以及相关资讯,请访问:https://www.eolinker.com/#/os/download
  11. *
  12. * 官方网站:https://www.eolinker.com/
  13. * 官方博客以及社区:http://blog.eolinker.com/
  14. * 使用教程以及帮助:http://help.eolinker.com/
  15. * 商务合作邮箱:market@eolinker.com
  16. * 用户讨论QQ群:284421832
  17. */
  18. class StatusCodeModule
  19. {
  20. public function __construct()
  21. {
  22. @session_start();
  23. }
  24. /**
  25. * 获取项目用户类型
  26. * @param $codeID
  27. * @return bool|int
  28. */
  29. public function getUserType(&$codeID)
  30. {
  31. $statusCodeDao = new StatusCodeDao();
  32. $projectID = $statusCodeDao->checkStatusCodePermission($codeID, $_SESSION['userID']);
  33. if (empty($projectID)) {
  34. return -1;
  35. }
  36. $dao = new AuthorizationDao();
  37. $result = $dao->getProjectUserType($_SESSION['userID'], $projectID);
  38. if ($result === FALSE) {
  39. return -1;
  40. }
  41. return $result;
  42. }
  43. /**
  44. * 添加状态码
  45. * @param $groupID int 分组ID
  46. * @param $codeDesc string 状态码描述,默认为NULL
  47. * @param $code string 状态码
  48. * @return bool|int
  49. */
  50. public function addCode(&$groupID, &$codeDesc, &$code)
  51. {
  52. $projectDao = new ProjectDao;
  53. $statusCodeGroupDao = new StatusCodeGroupDao;
  54. $statusCodeDao = new StatusCodeDao;
  55. if ($projectID = $statusCodeGroupDao->checkStatusCodeGroupPermission($groupID, $_SESSION['userID'])) {
  56. $projectDao->updateProjectUpdateTime($projectID);
  57. $result = $statusCodeDao->addCode($groupID, $codeDesc, $code);
  58. if ($result) {
  59. //将操作写入日志
  60. $log_dao = new ProjectLogDao();
  61. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE, $result, ProjectLogDao::$OP_TYPE_ADD, "添加状态码:'{$code}'", date("Y-m-d H:i:s", time()));
  62. return $result;
  63. } else {
  64. return FALSE;
  65. }
  66. } else
  67. return FALSE;
  68. }
  69. /**
  70. * 删除状态码
  71. * @param $codeID int 状态码ID
  72. * @return bool
  73. */
  74. public function deleteCode(&$codeID)
  75. {
  76. $projectDao = new ProjectDao;
  77. $statusCodeDao = new StatusCodeDao;
  78. if ($projectID = $statusCodeDao->checkStatusCodePermission($codeID, $_SESSION['userID'])) {
  79. $status_codes = $statusCodeDao->getStatusCodes($code_ids);
  80. $result = $statusCodeDao->deleteCode($codeID);
  81. if ($result) {
  82. $projectDao->updateProjectUpdateTime($projectID);
  83. //将操作写入日志
  84. $log_dao = new ProjectLogDao();
  85. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE, $code_ids, ProjectLogDao::$OP_TYPE_DELETE, "删除状态码:'{$status_codes}'", date("Y-m-d H:i:s", time()));
  86. return TRUE;
  87. } else {
  88. return FALSE;
  89. }
  90. } else
  91. return FALSE;
  92. }
  93. /**
  94. * 批量删除状态码
  95. * @param $code_ids string 状态码ID
  96. * @return bool
  97. */
  98. public function deleteCodes(&$code_ids)
  99. {
  100. $status_code_dao = new StatusCodeDao;
  101. $arr = explode(',', $code_ids);
  102. for ($i = 0; $i < count($arr); $i++) {
  103. if (!($projectID = $status_code_dao->checkStatusCodePermission($arr[$i], $_SESSION['userID'])))
  104. return FALSE;
  105. }
  106. $projectDao = new ProjectDao;
  107. $status_codes = $status_code_dao->getStatusCodes($code_ids);
  108. if ($status_code_dao->deleteCodes($code_ids)) {
  109. $projectDao->updateProjectUpdateTime($projectID);
  110. //将操作写入日志
  111. $log_dao = new ProjectLogDao();
  112. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE, $code_ids, ProjectLogDao::$OP_TYPE_DELETE, "删除状态码:'{$status_codes}'", date("Y-m-d H:i:s", time()));
  113. return TRUE;
  114. } else {
  115. return FALSE;
  116. }
  117. }
  118. /**
  119. * 获取状态码列表
  120. * @param $groupID int 分组ID
  121. * @return array|bool
  122. */
  123. public function getCodeList(&$groupID)
  124. {
  125. $statusCodeGroupDao = new StatusCodeGroupDao;
  126. $statusCodeDao = new StatusCodeDao;
  127. if ($statusCodeGroupDao->checkStatusCodeGroupPermission($groupID, $_SESSION['userID'])) {
  128. return $statusCodeDao->getCodeList($groupID);
  129. } else
  130. return FALSE;
  131. }
  132. /**
  133. * 获取所有状态码列表
  134. * @param $projectID int 项目ID
  135. * @return array|bool
  136. */
  137. public function getAllCodeList(&$projectID)
  138. {
  139. $projectDao = new ProjectDao;
  140. $statusCodeDao = new StatusCodeDao;
  141. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  142. return $statusCodeDao->getAllCodeList($projectID);
  143. } else
  144. return FALSE;
  145. }
  146. /**
  147. * 修改状态码
  148. * @param $groupID int 分组ID
  149. * @param $codeID int 状态码ID
  150. * @param $code string 状态码
  151. * @param $codeDesc string 状态码描述,默认为NULL
  152. * @return bool
  153. */
  154. public function editCode(&$groupID, &$codeID, &$code, &$codeDesc)
  155. {
  156. $projectDao = new ProjectDao;
  157. $statusCodeDao = new StatusCodeDao;
  158. if ($projectID = $statusCodeDao->checkStatusCodePermission($codeID, $_SESSION['userID'])) {
  159. $projectDao->updateProjectUpdateTime($projectID);
  160. $result = $statusCodeDao->editCode($groupID, $codeID, $code, $codeDesc);
  161. if ($result) {
  162. //将操作写入日志
  163. $log_dao = new ProjectLogDao();
  164. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE, $codeID, ProjectLogDao::$OP_TYPE_UPDATE, "修改状态码:'{$code}'", date("Y-m-d H:i:s", time()));
  165. return $result;
  166. } else {
  167. return FALSE;
  168. }
  169. } else
  170. return FALSE;
  171. }
  172. /**
  173. * 搜索状态码
  174. * @param $projectID int 项目ID
  175. * @param $tips string 搜索关键字
  176. * @return array|bool
  177. */
  178. public function searchStatusCode(&$projectID, &$tips)
  179. {
  180. $projectDao = new ProjectDao;
  181. $statusCodeDao = new StatusCodeDao;
  182. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  183. return $statusCodeDao->searchStatusCode($projectID, $tips);
  184. } else
  185. return FALSE;
  186. }
  187. /**
  188. * 获取状态码数量
  189. * @param $projectID int 项目ID
  190. * @return int|bool
  191. */
  192. public function getStatusCodeNum(&$projectID)
  193. {
  194. $projectDao = new ProjectDao;
  195. $statusCodeDao = new StatusCodeDao;
  196. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  197. return $statusCodeDao->getStatusCodeNum($projectID);
  198. } else
  199. return FALSE;
  200. }
  201. /**
  202. * 通过Excel批量添加状态码
  203. * @param $group_id
  204. * @param $code_list
  205. * @return bool
  206. */
  207. public function addStatusCodeByExcel(&$group_id, &$code_list)
  208. {
  209. $statusCodeGroupDao = new StatusCodeGroupDao;
  210. $statusCodeDao = new StatusCodeDao;
  211. if ($projectID = $statusCodeGroupDao->checkStatusCodeGroupPermission($group_id, $_SESSION['userID'])) {
  212. $result = $statusCodeDao->addStatusCodeByExcel($group_id, $code_list);
  213. if ($result) {
  214. //将操作写入日志
  215. $log_dao = new ProjectLogDao();
  216. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE, $group_id, ProjectLogDao::$OP_TYPE_ADD, "通过导入Excel添加状态码", date("Y-m-d H:i:s", time()));
  217. return $result;
  218. } else {
  219. return FALSE;
  220. }
  221. } else {
  222. return FALSE;
  223. }
  224. }
  225. }
  226. ?>