StatusCodeDao.class.php 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  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 StatusCodeDao
  19. {
  20. /**
  21. * 添加状态码
  22. * @param $groupID int 分组ID
  23. * @param $codeDesc string 状态码描述,默认为NULL
  24. * @param $code string 状态码
  25. * @return bool|int
  26. */
  27. public function addCode(&$groupID, &$codeDesc, &$code)
  28. {
  29. $db = getDatabase();
  30. $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($groupID, $code, $codeDesc));
  31. if ($db->getAffectRow() < 1)
  32. return FALSE;
  33. else
  34. return $db->getLastInsertID();
  35. }
  36. /**
  37. * 删除状态码
  38. * @param $codeID int 状态码ID
  39. * @return bool
  40. */
  41. public function deleteCode(&$codeID)
  42. {
  43. $db = getDatabase();
  44. $db->prepareExecute('DELETE FROM eo_project_status_code WHERE eo_project_status_code.codeID = ?;', array($codeID));
  45. if ($db->getAffectRow() < 1)
  46. return FALSE;
  47. else
  48. return TRUE;
  49. }
  50. /**
  51. * 获取状态码列表
  52. * @param $groupID int 分组ID
  53. * @return bool|array
  54. */
  55. public function getCodeList(&$groupID)
  56. {
  57. $db = getDatabase();
  58. $result = $db->prepareExecuteAll('SELECT eo_project_status_code.codeID,eo_project_status_code.code,eo_project_status_code.codeDescription,eo_project_status_code_group.groupName,eo_project_status_code_group.groupID,eo_project_status_code_group.parentGroupID FROM eo_project_status_code INNER JOIN eo_project_status_code_group ON eo_project_status_code.groupID = eo_project_status_code_group.groupID WHERE (eo_project_status_code_group.groupID = ? OR eo_project_status_code_group.parentGroupID = ?) ORDER BY eo_project_status_code.code ASC;', array($groupID, $groupID));
  59. if (empty($result))
  60. return FALSE;
  61. else
  62. return $result;
  63. }
  64. /**
  65. * 获取所有状态码列表
  66. * @param $projectID int 项目ID
  67. * @return bool|array
  68. */
  69. public function getAllCodeList(&$projectID)
  70. {
  71. $db = getDatabase();
  72. $result = $db->prepareExecuteAll('SELECT eo_project_status_code_group.groupID,eo_project_status_code_group.parentGroupID,eo_project_status_code_group.groupName,eo_project_status_code.codeID,eo_project_status_code.code,eo_project_status_code.codeDescription FROM eo_project_status_code INNER JOIN eo_project_status_code_group ON eo_project_status_code.groupID = eo_project_status_code_group.groupID WHERE projectID = ? ORDER BY eo_project_status_code.code ASC;', array($projectID));
  73. if (empty($result))
  74. return FALSE;
  75. else
  76. return $result;
  77. }
  78. /**
  79. * 修改状态码
  80. * @param $groupID int 分组ID
  81. * @param $codeID int 状态码ID
  82. * @param $code string 状态码
  83. * @param $codeDesc string 状态码描述,默认为NULL
  84. * @return bool
  85. */
  86. public function editCode(&$groupID, &$codeID, &$code, &$codeDesc)
  87. {
  88. $db = getDatabase();
  89. $db->prepareExecute('UPDATE eo_project_status_code SET eo_project_status_code.groupID = ?, eo_project_status_code.code = ? ,eo_project_status_code.codeDescription = ? WHERE codeID = ?;', array($groupID, $code, $codeDesc, $codeID));
  90. if ($db->getAffectRow() < 1)
  91. return FALSE;
  92. else
  93. return TRUE;
  94. }
  95. /**
  96. * 检查状态码与用户的联系
  97. * @param $codeID int 状态码ID
  98. * @param $userID int 用户ID
  99. * @return bool|int
  100. */
  101. public function checkStatusCodePermission(&$codeID, &$userID)
  102. {
  103. $db = getDatabase();
  104. $result = $db->prepareExecute('SELECT eo_conn_project.projectID FROM eo_project_status_code INNER JOIN eo_conn_project INNER JOIN eo_project_status_code_group ON eo_conn_project.projectID = eo_project_status_code_group.projectID AND eo_project_status_code_group.groupID = eo_project_status_code.groupID WHERE codeID = ? AND userID = ?;', array($codeID, $userID));
  105. if (empty($result))
  106. return FALSE;
  107. else
  108. return $result['projectID'];
  109. }
  110. /**
  111. * 搜索状态码
  112. * @param $projectID int 项目ID
  113. * @param $tips string 搜索关键字
  114. * @return bool|array
  115. */
  116. public function searchStatusCode(&$projectID, &$tips)
  117. {
  118. $db = getDatabase();
  119. $result = $db->prepareExecuteAll('SELECT eo_project_status_code_group.groupID,eo_project_status_code_group.parentGroupID,eo_project_status_code_group.groupName,eo_project_status_code.codeID,eo_project_status_code.code,eo_project_status_code.codeDescription FROM eo_project_status_code INNER JOIN eo_project_status_code_group ON eo_project_status_code.groupID = eo_project_status_code_group.groupID WHERE projectID = ? AND (eo_project_status_code.code LIKE ? OR eo_project_status_code.codeDescription LIKE ?);', array($projectID, '%' . $tips . '%', '%' . $tips . '%'));
  120. if (empty($result))
  121. return FALSE;
  122. else
  123. return $result;
  124. }
  125. /**
  126. * 获取状态码数量
  127. * @param $projectID int 项目ID
  128. * @return bool|int
  129. */
  130. public function getStatusCodeNum(&$projectID)
  131. {
  132. $db = getDatabase();
  133. $result = $db->prepareExecute('SELECT COUNT(*) AS num FROM eo_project_status_code LEFT JOIN eo_project_status_code_group ON eo_project_status_code.groupID = eo_project_status_code_group.groupID WHERE eo_project_status_code_group.projectID = ?;', array($projectID));
  134. if (empty($result))
  135. return FALSE;
  136. else
  137. return $result;
  138. }
  139. /**
  140. * 批量删除状态码
  141. * @param $code_ids string 状态码列表
  142. * @return bool
  143. */
  144. public function deleteCodes(&$code_ids)
  145. {
  146. $db = getDatabase();
  147. $db->prepareExecuteAll("DELETE FROM eo_project_status_code WHERE codeID IN ($code_ids)", array());
  148. if ($db->getAffectRow() < 1) {
  149. return FALSE;
  150. } else {
  151. return TRUE;
  152. }
  153. }
  154. /**
  155. * 获取状态码名称
  156. * @param $code_ids
  157. * @return bool
  158. */
  159. public function getStatusCodes(&$code_ids)
  160. {
  161. $db = getDatabase();
  162. $result = $db->prepareExecute("SELECT GROUP_CONCAT(DISTINCT eo_project_status_code.code) AS statusCodes FROM eo_project_status_code WHERE eo_project_status_code.codeID IN ($code_ids)", array());
  163. if (empty($result)) {
  164. return FALSE;
  165. } else {
  166. return $result['statusCodes'];
  167. }
  168. }
  169. /**
  170. * 通过Excel批量添加状态码
  171. * @param $group_id
  172. * @param $code_list
  173. * @return bool
  174. */
  175. public function addStatusCodeByExcel(&$group_id, &$code_list)
  176. {
  177. $db = getDatabase();
  178. $db->beginTransaction();
  179. foreach ($code_list as $code) {
  180. $db->prepareExecute('INSERT INTO eo_project_status_code (code,codeDescription,groupID) VALUES (?,?,?);', array(
  181. $code['code'],
  182. $code['codeDesc'],
  183. $group_id
  184. ));
  185. if ($db->getAffectRow() < 1) {
  186. $db->rollback();
  187. return FALSE;
  188. }
  189. }
  190. $db->commit();
  191. return TRUE;
  192. }
  193. }
  194. ?>