StatusCodeGroupDao.class.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  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 StatusCodeGroupDao
  19. {
  20. /**
  21. * 添加状态码分组
  22. * @param $projectID int 项目ID
  23. * @param $groupName string 分组名
  24. * @return int|bool
  25. */
  26. public function addGroup(&$projectID, &$groupName)
  27. {
  28. $db = getDatabase();
  29. $db->prepareExecute('INSERT INTO eo_project_status_code_group (eo_project_status_code_group.projectID,eo_project_status_code_group.groupName) VALUES (?,?);', array(
  30. $projectID,
  31. $groupName
  32. ));
  33. $groupID = $db->getLastInsertID();
  34. if ($db->getAffectRow() < 1)
  35. return FALSE;
  36. else
  37. return $groupID;
  38. }
  39. /**
  40. * 添加子分组
  41. * @param $projectID int 项目ID
  42. * @param $groupName string 分组名
  43. * @param $parentGroupID int 父分组ID
  44. * @return bool|int
  45. */
  46. public function addChildGroup(&$projectID, &$groupName, &$parentGroupID)
  47. {
  48. $db = getDatabase();
  49. $db->prepareExecute('INSERT INTO eo_project_status_code_group (eo_project_status_code_group.projectID,eo_project_status_code_group.groupName,eo_project_status_code_group.parentGroupID,eo_project_status_code_group.isChild) VALUES (?,?,?,1);', array(
  50. $projectID,
  51. $groupName,
  52. $parentGroupID
  53. ));
  54. $groupID = $db->getLastInsertID();
  55. if ($db->getAffectRow() < 1)
  56. return FALSE;
  57. else
  58. return $groupID;
  59. }
  60. /**
  61. * 判断用户和分组是否匹配
  62. * @param $groupID int 分组ID
  63. * @param $userID int 用户ID
  64. * @return bool|int
  65. */
  66. public function checkStatusCodeGroupPermission(&$groupID, &$userID)
  67. {
  68. $db = getDatabase();
  69. $result = $db->prepareExecute('SELECT eo_conn_project.projectID FROM eo_conn_project INNER JOIN eo_project_status_code_group ON eo_conn_project.projectID = eo_project_status_code_group.projectID WHERE groupID = ? AND userID = ?;', array(
  70. $groupID,
  71. $userID
  72. ));
  73. if (empty($result))
  74. return FALSE;
  75. else
  76. return $result['projectID'];
  77. }
  78. /**
  79. * 删除分组
  80. * @param $groupID int 分组ID
  81. * @return bool
  82. */
  83. public function deleteGroup(&$groupID)
  84. {
  85. $db = getDatabase();
  86. $db->prepareExecute('DELETE FROM eo_project_status_code_group WHERE eo_project_status_code_group.groupID = ?;', array($groupID));
  87. if ($db->getAffectRow() < 1)
  88. return FALSE;
  89. else
  90. return TRUE;
  91. }
  92. /**
  93. * 获取分组列表
  94. * @param $projectID int 项目ID
  95. * @return bool|array
  96. */
  97. public function getGroupList(&$projectID)
  98. {
  99. $db = getDatabase();
  100. $groupList = $db->prepareExecuteAll('SELECT eo_project_status_code_group.groupID,eo_project_status_code_group.groupName FROM eo_project_status_code_group WHERE projectID = ? AND isChild = 0 ORDER BY eo_project_status_code_group.groupID DESC;', array($projectID));
  101. if (is_array($groupList))
  102. foreach ($groupList as &$parentGroup) {
  103. $parentGroup['childGroupList'] = array();
  104. $childGroup = $db->prepareExecuteAll('SELECT eo_project_status_code_group.groupID,eo_project_status_code_group.groupName,eo_project_status_code_group.parentGroupID FROM eo_project_status_code_group WHERE projectID = ? AND isChild = 1 AND parentGroupID = ? ORDER BY eo_project_status_code_group.groupID DESC;', array(
  105. $projectID,
  106. $parentGroup['groupID']
  107. ));
  108. //判断是否有子分组
  109. if (!empty($childGroup))
  110. $parentGroup['childGroupList'] = $childGroup;
  111. }
  112. $result = array();
  113. $result['groupList'] = $groupList;
  114. $groupOrder = $db->prepareExecute('SELECT eo_api_status_code_group_order.orderList FROM eo_api_status_code_group_order WHERE projectID = ?;', array(
  115. $projectID
  116. ));
  117. $result['groupOrder'] = $groupOrder['orderList'];
  118. if (empty($result))
  119. return FALSE;
  120. else
  121. return $result;
  122. }
  123. /**
  124. * 修改分组
  125. * @param $groupID int 分组ID
  126. * @param $groupName string 分组名
  127. * @param $parentGroupID int 父分组ID
  128. * @return bool
  129. */
  130. public function editGroup(&$groupID, &$groupName, $parentGroupID)
  131. {
  132. $db = getDatabase();
  133. if (!$parentGroupID) {
  134. $db->prepareExecute('UPDATE eo_project_status_code_group SET eo_project_status_code_group.groupName = ?,isChild = 0,parentGroupID = NULL WHERE eo_project_status_code_group.groupID = ?;', array(
  135. $groupName,
  136. $groupID
  137. ));
  138. } else {
  139. $db->prepareExecute('UPDATE eo_project_status_code_group SET eo_project_status_code_group.groupName = ?,isChild = 1,parentGroupID = ? WHERE eo_project_status_code_group.groupID = ?;', array(
  140. $groupName,
  141. $parentGroupID,
  142. $groupID
  143. ));
  144. }
  145. if ($db->getAffectRow() < 1)
  146. return FALSE;
  147. else
  148. return TRUE;
  149. }
  150. /**
  151. * 更新分组排序
  152. * @param $projectID int 项目ID
  153. * @param $orderList string 排序列表
  154. * @return bool
  155. */
  156. public function sortGroup(&$projectID, &$orderList)
  157. {
  158. $db = getDatabase();
  159. $db->prepareExecute('REPLACE INTO eo_api_status_code_group_order(projectID, orderList) VALUES (?,?);', array(
  160. $projectID,
  161. $orderList
  162. ));
  163. if ($db->getAffectRow() > 0)
  164. return TRUE;
  165. else
  166. return FALSE;
  167. }
  168. /**
  169. * 获取分组名称
  170. * @param $group_id
  171. * @return bool
  172. */
  173. public function getGroupName(&$group_id)
  174. {
  175. $db = getDatabase();
  176. $result = $db->prepareExecute('SELECT eo_project_status_code_group.groupName FROM eo_project_status_code_group WHERE eo_project_status_code_group.groupID = ?;', array($group_id));
  177. if (empty($result)) {
  178. return FALSE;
  179. } else {
  180. return $result['groupName'];
  181. }
  182. }
  183. /**
  184. * 获取分组数据
  185. * @param $project_id
  186. * @param $group_id
  187. * @return array|bool
  188. */
  189. public function getGroupData(&$project_id, &$group_id)
  190. {
  191. $db = getDatabase();
  192. $result = array();
  193. $group = $db->prepareExecute('SELECT eo_project_status_code_group.groupName,eo_project_status_code_group.isChild FROM eo_project_status_code_group WHERE eo_project_status_code_group.projectID = ? AND eo_project_status_code_group.groupID = ?;', array(
  194. $project_id,
  195. $group_id
  196. ));
  197. $result['statusCodeList'] = $db->prepareExecuteAll("SELECT eo_project_status_code.codeID,eo_project_status_code.code,eo_project_status_code.codeDescription FROM eo_project_status_code WHERE eo_project_status_code.groupID = ?", array(
  198. $group_id
  199. ));
  200. $result['groupName'] = $group['groupName'];
  201. if ($group['isChild'] == 0) {
  202. $child_group_list = $db->prepareExecuteAll('SELECT eo_project_status_code_group.groupID,eo_project_status_code_group.groupName FROM eo_project_status_code_group WHERE eo_project_status_code_group.parentGroupID = ? AND eo_project_status_code_group.projectID = ?', array(
  203. $group_id,
  204. $project_id
  205. ));
  206. if ($child_group_list) {
  207. $i = 0;
  208. foreach ($child_group_list as $group) {
  209. $result['childGroupList'][$i]['groupName'] = $group['groupName'];
  210. $result['childGroupList'][$i]['statusCodeList'] = $db->prepareExecuteAll("SELECT eo_project_status_code.codeID,eo_project_status_code.code,eo_project_status_code.codeDescription FROM eo_project_status_code WHERE eo_project_status_code.groupID = ?", array(
  211. $group['groupID']
  212. ));
  213. $i++;
  214. }
  215. }
  216. }
  217. if ($result)
  218. return $result;
  219. else
  220. return FALSE;
  221. }
  222. /**
  223. * 导入状态码分组
  224. * @param $project_id
  225. * @param $data
  226. * @return bool
  227. */
  228. public function importGroup(&$project_id, &$data)
  229. {
  230. $db = getDatabase();
  231. try {
  232. $db->beginTransaction();
  233. // 插入分组
  234. $db->prepareExecute('INSERT INTO eo_project_status_code_group (eo_project_status_code_group.projectID,eo_project_status_code_group.groupName) VALUES (?,?);', array(
  235. $project_id,
  236. $data['groupName']
  237. ));
  238. if ($db->getAffectRow() < 1)
  239. throw new \PDOException("add statusCodeGroup error");
  240. $group_id = $db->getLastInsertID();
  241. if ($data['statusCodeList']) {
  242. // 插入状态码
  243. foreach ($data['statusCodeList'] as $status_code) {
  244. $db->prepareExecute('INSERT INTO eo_project_status_code (eo_project_status_code.groupID,eo_project_status_code.code,eo_project_status_code.codeDescription) VALUES (?,?,?);', array(
  245. $group_id,
  246. $status_code['code'],
  247. $status_code['codeDescription']
  248. ));
  249. if ($db->getAffectRow() < 1)
  250. throw new \PDOException("add statusCode error");
  251. }
  252. }
  253. if ($data['childGroupList']) {
  254. $group_id_parent = $group_id;
  255. foreach ($data['childGroupList'] as $child_group) {
  256. // 插入分组
  257. $db->prepareExecute('INSERT INTO eo_project_status_code_group (eo_project_status_code_group.projectID,eo_project_status_code_group.groupName,eo_project_status_code_group.parentGroupID,eo_project_status_code_group.isChild) VALUES (?,?,?,?);', array(
  258. $project_id,
  259. $child_group['groupName'],
  260. $group_id_parent,
  261. 1
  262. ));
  263. if ($db->getAffectRow() < 1) {
  264. throw new \PDOException("add statusCodeGroup error");
  265. }
  266. $group_id = $db->getLastInsertID();
  267. if ($child_group['statusCodeList']) {
  268. // 插入状态码
  269. foreach ($child_group['statusCodeList'] as $status_code) {
  270. $db->prepareExecute('INSERT INTO eo_project_status_code (eo_project_status_code.groupID,eo_project_status_code.code,eo_project_status_code.codeDescription) VALUES (?,?,?);', array(
  271. $group_id,
  272. $status_code['code'],
  273. $status_code['codeDescription']
  274. ));
  275. if ($db->getAffectRow() < 1) {
  276. throw new \PDOException("add statusCode error");
  277. }
  278. }
  279. }
  280. }
  281. }
  282. $db->commit();
  283. return TRUE;
  284. } catch (\PDOException $e) {
  285. $db->rollback();
  286. return FALSE;
  287. }
  288. }
  289. }
  290. ?>