StatusCodeGroupModule.class.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  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 StatusCodeGroupModule
  19. {
  20. public function __construct()
  21. {
  22. @session_start();
  23. }
  24. /**
  25. * 获取项目用户类型
  26. * @param $groupID int 分组ID
  27. * @return bool|int
  28. */
  29. public function getUserType(&$groupID)
  30. {
  31. $groupDao = new StatusCodeGroupDao();
  32. $projectID = $groupDao->checkStatusCodeGroupPermission($groupID, $_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 $projectID int 项目ID
  46. * @param $groupName string 分组名
  47. * @param $parentGroupID int 父分组ID
  48. * @return bool|int
  49. */
  50. public function addGroup(&$projectID, &$groupName, &$parentGroupID)
  51. {
  52. $projectDao = new ProjectDao;
  53. $statusCodeGroupDao = new StatusCodeGroupDao;
  54. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  55. $projectDao->updateProjectUpdateTime($projectID);
  56. if (is_null($parentGroupID)) {
  57. $result = $statusCodeGroupDao->addGroup($projectID, $groupName);
  58. if ($result) {
  59. //将操作写入日志
  60. $log_dao = new ProjectLogDao();
  61. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $result, ProjectLogDao::$OP_TYPE_ADD, "新增状态码分组:'$groupName'", date("Y-m-d H:i:s", time()));
  62. return $result;
  63. } else {
  64. return FALSE;
  65. }
  66. } else {
  67. $result = $statusCodeGroupDao->addChildGroup($projectID, $groupName, $parentGroupID);
  68. if ($result) {
  69. $parent_group_name = $statusCodeGroupDao->getGroupName($parentGroupID);
  70. //将操作写入日志
  71. $log_dao = new ProjectLogDao();
  72. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $result, ProjectLogDao::$OP_TYPE_ADD, "新增状态码子分组:'$parent_group_name>>$groupName'", date("Y-m-d H:i:s", time()));
  73. return $result;
  74. } else {
  75. return FALSE;
  76. }
  77. }
  78. } else
  79. return FALSE;
  80. }
  81. /**
  82. * 删除分组
  83. * @param $groupID int 分组ID
  84. * @return bool
  85. */
  86. public function deleteGroup(&$groupID)
  87. {
  88. $projectDao = new ProjectDao;
  89. $statusCodeGroupDao = new StatusCodeGroupDao;
  90. if ($projectID = $statusCodeGroupDao->checkStatusCodeGroupPermission($groupID, $_SESSION['userID'])) {
  91. $group_name = $statusCodeGroupDao->getGroupName($groupID);
  92. $result = $statusCodeGroupDao->deleteGroup($groupID);
  93. if ($result) {
  94. $projectDao->updateProjectUpdateTime($projectID);
  95. //将操作写入日志
  96. $log_dao = new ProjectLogDao();
  97. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $groupID, ProjectLogDao::$OP_TYPE_DELETE, "删除状态码分组:'$group_name'", date("Y-m-d H:i:s", time()));
  98. return $result;
  99. } else {
  100. return FALSE;
  101. }
  102. } else
  103. return FALSE;
  104. }
  105. /**
  106. * 获取状态码分组列表
  107. * @param $projectID int 项目ID
  108. * @return bool|array
  109. */
  110. public function getGroupList(&$projectID)
  111. {
  112. $projectDao = new ProjectDao;
  113. $statusCodeGroupDao = new StatusCodeGroupDao;
  114. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  115. return $statusCodeGroupDao->getGroupList($projectID);
  116. } else
  117. return FALSE;
  118. }
  119. /**
  120. * 修改状态码分组
  121. * @param $groupID int 分组ID
  122. * @param $groupName string 分组名
  123. * @param $parentGroupID int 父分组ID
  124. * @return bool
  125. */
  126. public function editGroup(&$groupID, &$groupName, &$parentGroupID)
  127. {
  128. $projectDao = new ProjectDao;
  129. $statusCodeGroupDao = new StatusCodeGroupDao;
  130. if ($projectID = $statusCodeGroupDao->checkStatusCodeGroupPermission($groupID, $_SESSION['userID'])) {
  131. if ($parentGroupID && !$statusCodeGroupDao->checkStatusCodeGroupPermission($parentGroupID, $_SESSION['userID'])) {
  132. return FALSE;
  133. }
  134. $projectDao->updateProjectUpdateTime($projectID);
  135. $result = $statusCodeGroupDao->editGroup($groupID, $groupName, $parentGroupID);
  136. if ($result) {
  137. //将操作写入日志
  138. $log_dao = new ProjectLogDao();
  139. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $groupID, ProjectLogDao::$OP_TYPE_UPDATE, "修改状态码分组:'$groupName'", date("Y-m-d H:i:s", time()));
  140. return $result;
  141. } else {
  142. return FALSE;
  143. }
  144. } else
  145. return FALSE;
  146. }
  147. /**
  148. * 修改分组排序
  149. * @param $projectID int 项目ID
  150. * @param $orderList string 排序列表
  151. * @return bool
  152. */
  153. public function sortGroup(&$projectID, &$orderList)
  154. {
  155. $groupDao = new StatusCodeGroupDao();
  156. $projectDao = new ProjectDao;
  157. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  158. if ($groupDao->sortGroup($projectID, $orderList)) {
  159. $projectDao->updateProjectUpdateTime($projectID);
  160. //将操作写入日志
  161. $log_dao = new ProjectLogDao();
  162. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $projectID, ProjectLogDao::$OP_TYPE_UPDATE, "修改状态码分组排序", date("Y-m-d H:i:s", time()));
  163. return TRUE;
  164. } else {
  165. return FALSE;
  166. }
  167. }
  168. }
  169. /**
  170. * 导出分组
  171. * @param $group_id
  172. * @return bool|string
  173. */
  174. public function exportGroup(&$group_id)
  175. {
  176. $group_dao = new StatusCodeGroupDao();
  177. if (!($projectID = $group_dao->checkStatusCodeGroupPermission($group_id, $_SESSION['userID']))) {
  178. return FALSE;
  179. }
  180. $data = $group_dao->getGroupData($projectID, $group_id);
  181. if ($data) {
  182. $fileName = 'eoLinker_status_code_group_export_' . $_SESSION['userName'] . '_' . time() . '.export';
  183. if (file_put_contents(realpath('./dump') . DIRECTORY_SEPARATOR . $fileName, json_encode($data))) {
  184. $group_name = $group_dao->getGroupName($group_id);
  185. //将操作写入日志
  186. $log_dao = new ProjectLogDao();
  187. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $group_id, ProjectLogDao::$OP_TYPE_OTHERS, "导出状态码分组:$group_name", date("Y-m-d H:i:s", time()));
  188. return $fileName;
  189. }
  190. } else {
  191. return FALSE;
  192. }
  193. }
  194. /**
  195. * 导入分组
  196. * @param $project_id
  197. * @param $data
  198. * @return bool
  199. */
  200. public function importGroup(&$project_id, &$data)
  201. {
  202. $group_dao = new StatusCodeGroupDao();
  203. $project_dao = new ProjectDao();
  204. if (!$project_dao->checkProjectPermission($project_id, $_SESSION['userID'])) {
  205. return FALSE;
  206. }
  207. $result = $group_dao->importGroup($project_id, $data);
  208. if ($result) {
  209. //将操作写入日志
  210. $log_dao = new ProjectLogDao();
  211. $log_dao->addOperationLog($project_id, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_STATUS_CODE_GROUP, $project_id, ProjectLogDao::$OP_TYPE_OTHERS, "导入状态码分组:{$data['groupName']}", date("Y-m-d H:i:s", time()));
  212. return $result;
  213. } else {
  214. return FALSE;
  215. }
  216. }
  217. }
  218. ?>