AutoGenerateDao.class.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  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 AutoGenerateDao
  19. {
  20. /**
  21. * 导入接口
  22. * @param $data array json格式数据
  23. * @param $project_id int 项目ID
  24. * @return bool
  25. */
  26. public function importApi(&$data, &$project_id)
  27. {
  28. $db = getDatabase();
  29. try {
  30. // 开始事务
  31. $db->beginTransaction();
  32. $db->prepareExecuteAll('DELETE FROM eo_api_header WHERE eo_api_header.apiID IN (SELECT eo_api.apiID FROM eo_api WHERE eo_api.projectID = ?);', array($project_id));
  33. $db->prepareExecuteAll('DELETE FROM eo_api_request_value WHERE eo_api_request_value.paramID IN (SELECT eo_api_request_param.paramID FROM eo_api_request_param LEFT JOIN eo_api ON eo_api_request_param.apiID = eo_api.apiID WHERE eo_api.projectID = ?);', array($project_id));
  34. $db->prepareExecuteAll('DELETE FROM eo_api_request_param WHERE eo_api_request_param.apiID IN (SELECT eo_api.apiID FROM eo_api WHERE eo_api.projectID = ?)', array($project_id));
  35. $db->prepareExecuteAll('DELETE FROM eo_api_result_value WHERE eo_api_result_value.paramID IN (SELECT eo_api_result_param.paramID FROM eo_api_result_param LEFT JOIN eo_api ON eo_api_result_param.apiID = eo_api.apiID WHERE eo_api.projectID = ?);', array($project_id));
  36. $db->prepareExecuteAll('DELETE FROM eo_api_result_param WHERE eo_api_result_param.apiID IN (SELECT eo_api.apiID FROM eo_api WHERE eo_api.projectID = ?)', array($project_id));
  37. $db->prepareExecuteAll('DELETE FROM eo_api_group WHERE eo_api_group.projectID = ?;', array($project_id));
  38. $db->prepareExecuteAll('DELETE FROM eo_api WHERE eo_api.projectID = ?;', array($project_id));
  39. $db->prepareExecuteAll('DELETE FROM eo_api_cache WHERE eo_api_cache.projectID = ?;', array($project_id));
  40. // 插入接口分组信息
  41. foreach ($data as $api_group) {
  42. $db->prepareExecute('INSERT INTO eo_api_group (eo_api_group.groupName,eo_api_group.projectID) VALUES (?,?);', array(
  43. $api_group['groupName'],
  44. $project_id
  45. ));
  46. if ($db->getAffectRow() < 1)
  47. throw new \PDOException("addGroup error");
  48. $group_id = $db->getLastInsertID();
  49. if ($api_group['apiList']) {
  50. foreach ($api_group['apiList'] as $api) {
  51. // 插入api基本信息
  52. $db->prepareExecute('INSERT INTO eo_api (eo_api.apiName,eo_api.apiURI,eo_api.apiProtocol,eo_api.apiSuccessMock,eo_api.apiFailureMock,eo_api.apiRequestType,eo_api.apiStatus,eo_api.groupID,eo_api.projectID,eo_api.starred,eo_api.apiNoteType,eo_api.apiNoteRaw,eo_api.apiNote,eo_api.apiRequestParamType,eo_api.apiRequestRaw,eo_api.apiUpdateTime) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?);', array(
  53. $api['baseInfo']['apiName'],
  54. $api['baseInfo']['apiURI'],
  55. $api['baseInfo']['apiProtocol'],
  56. $api['baseInfo']['apiSuccessMock'],
  57. $api['baseInfo']['apiFailureMock'],
  58. $api['baseInfo']['apiRequestType'],
  59. $api['baseInfo']['apiStatus'],
  60. $group_id,
  61. $project_id,
  62. $api['baseInfo']['starred'],
  63. $api['baseInfo']['apiNoteType'],
  64. $api['baseInfo']['apiNoteRaw'],
  65. $api['baseInfo']['apiNote'],
  66. $api['baseInfo']['apiRequestParamType'],
  67. $api['baseInfo']['apiRequestRaw'],
  68. $api['baseInfo']['apiUpdateTime']
  69. ));
  70. if ($db->getAffectRow() < 1)
  71. throw new \PDOException("addApi error");
  72. $api_id = $db->getLastInsertID();
  73. if ($api['headerInfo']) {
  74. // 插入header信息
  75. foreach ($api['headerInfo'] as $header) {
  76. $db->prepareExecute('INSERT INTO eo_api_header (eo_api_header.headerName,eo_api_header.headerValue,eo_api_header.apiID) VALUES (?,?,?);', array(
  77. $header['headerName'],
  78. $header['headerValue'],
  79. $api_id
  80. ));
  81. if ($db->getAffectRow() < 1)
  82. throw new \PDOException("addHeader error");
  83. }
  84. }
  85. if ($api['requestInfo']) {
  86. // 插入api请求值信息
  87. foreach ($api['requestInfo'] as $request) {
  88. $db->prepareExecute('INSERT INTO eo_api_request_param (eo_api_request_param.apiID,eo_api_request_param.paramName,eo_api_request_param.paramKey,eo_api_request_param.paramValue,eo_api_request_param.paramLimit,eo_api_request_param.paramNotNull,eo_api_request_param.paramType) VALUES (?,?,?,?,?,?,?);', array(
  89. $api_id,
  90. $request['paramName'],
  91. $request['paramKey'],
  92. $request['paramValue'],
  93. $request['paramLimit'],
  94. $request['paramNotNull'],
  95. $request['paramType']
  96. ));
  97. if ($db->getAffectRow() < 1)
  98. throw new \PDOException("addRequestParam error");
  99. $param_id = $db->getLastInsertID();
  100. if ($request['paramValueList']) {
  101. foreach ($request['paramValueList'] as $value) {
  102. $db->prepareExecute('INSERT INTO eo_api_request_value (eo_api_request_value.paramID,eo_api_request_value.`value`,eo_api_request_value.valueDescription) VALUES (?,?,?);', array(
  103. $param_id,
  104. $value['value'],
  105. $value['valueDescription']
  106. ));
  107. if ($db->getAffectRow() < 1)
  108. throw new \PDOException("addApi error");
  109. };
  110. }
  111. };
  112. }
  113. if ($api['resultInfo']) {
  114. // 插入api返回值信息
  115. foreach ($api['resultInfo'] as $result) {
  116. $db->prepareExecute('INSERT INTO eo_api_result_param (eo_api_result_param.apiID,eo_api_result_param.paramName,eo_api_result_param.paramKey,eo_api_result_param.paramNotNull) VALUES (?,?,?,?);', array(
  117. $api_id,
  118. $result['paramName'],
  119. $result['paramKey'],
  120. $result['paramNotNull']
  121. ));
  122. if ($db->getAffectRow() < 1)
  123. throw new \PDOException("addResultParam error");
  124. $param_id = $db->getLastInsertID();
  125. if ($result['paramValueList']) {
  126. foreach ($result['paramValueList'] as $value) {
  127. $db->prepareExecute('INSERT INTO eo_api_result_value (eo_api_result_value.paramID,eo_api_result_value.`value`,eo_api_result_value.valueDescription) VALUES (?,?,?);;', array(
  128. $param_id,
  129. $value['value'],
  130. $value['valueDescription']
  131. ));
  132. if ($db->getAffectRow() < 1)
  133. throw new \PDOException("addApi error");
  134. };
  135. }
  136. };
  137. }
  138. // 插入api缓存数据用于导出
  139. $db->prepareExecute("INSERT INTO eo_api_cache (eo_api_cache.projectID,eo_api_cache.groupID,eo_api_cache.apiID,eo_api_cache.apiJson,eo_api_cache.starred) VALUES (?,?,?,?,?);", array(
  140. $project_id,
  141. $group_id,
  142. $api_id,
  143. json_encode($api),
  144. $api['baseInfo']['starred']
  145. ));
  146. if ($db->getAffectRow() < 1) {
  147. throw new \PDOException("addApiCache error");
  148. }
  149. }
  150. }
  151. if (is_array($api_group['apiGroupChildList'])) {
  152. // 二级分组代码
  153. $group_parent_id = $group_id;
  154. foreach ($api_group['apiGroupChildList'] as $api_group_child) {
  155. $db->prepareExecute('INSERT INTO eo_api_group (eo_api_group.groupName,eo_api_group.projectID,eo_api_group.parentGroupID, eo_api_group.isChild) VALUES (?,?,?,?);', array(
  156. $api_group_child['groupName'],
  157. $project_id,
  158. $group_parent_id,
  159. 1
  160. ));
  161. if ($db->getAffectRow() < 1)
  162. throw new \PDOException("addChildGroup error");
  163. $group_id = $db->getLastInsertID();
  164. // 如果当前分组没有接口,则跳过到下一分组
  165. if (empty($api_group_child['apiList']))
  166. continue;
  167. foreach ($api_group_child['apiList'] as $api) {
  168. // 插入api基本信息
  169. $db->prepareExecute('INSERT INTO eo_api (eo_api.apiName,eo_api.apiURI,eo_api.apiProtocol,eo_api.apiSuccessMock,eo_api.apiFailureMock,eo_api.apiRequestType,eo_api.apiStatus,eo_api.groupID,eo_api.projectID,eo_api.starred,eo_api.apiNoteType,eo_api.apiNoteRaw,eo_api.apiNote,eo_api.apiRequestParamType,eo_api.apiRequestRaw,eo_api.apiUpdateTime) VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?);', array(
  170. $api['baseInfo']['apiName'],
  171. $api['baseInfo']['apiURI'],
  172. $api['baseInfo']['apiProtocol'],
  173. $api['baseInfo']['apiSuccessMock'],
  174. $api['baseInfo']['apiFailureMock'],
  175. $api['baseInfo']['apiRequestType'],
  176. $api['baseInfo']['apiStatus'],
  177. $group_id,
  178. $project_id,
  179. $api['baseInfo']['starred'],
  180. $api['baseInfo']['apiNoteType'],
  181. $api['baseInfo']['apiNoteRaw'],
  182. $api['baseInfo']['apiNote'],
  183. $api['baseInfo']['apiRequestParamType'],
  184. $api['baseInfo']['apiRequestRaw'],
  185. $api['baseInfo']['apiUpdateTime']
  186. ));
  187. if ($db->getAffectRow() < 1)
  188. throw new \PDOException("addChildApi error");
  189. $api_id = $db->getLastInsertID();
  190. if ($api['headerInfo']) {
  191. // 插入header信息
  192. foreach ($api['headerInfo'] as $header) {
  193. $db->prepareExecute('INSERT INTO eo_api_header (eo_api_header.headerName,eo_api_header.headerValue,eo_api_header.apiID) VALUES (?,?,?);', array(
  194. $header['headerName'],
  195. $header['headerValue'],
  196. $api_id
  197. ));
  198. if ($db->getAffectRow() < 1)
  199. throw new \PDOException("addChildHeader error");
  200. }
  201. }
  202. if ($api['requestInfo']) {
  203. // 插入api请求值信息
  204. foreach ($api['requestInfo'] as $request) {
  205. $db->prepareExecute('INSERT INTO eo_api_request_param (eo_api_request_param.apiID,eo_api_request_param.paramName,eo_api_request_param.paramKey,eo_api_request_param.paramValue,eo_api_request_param.paramLimit,eo_api_request_param.paramNotNull,eo_api_request_param.paramType) VALUES (?,?,?,?,?,?,?);', array(
  206. $api_id,
  207. $request['paramName'],
  208. $request['paramKey'],
  209. $request['paramValue'],
  210. $request['paramLimit'],
  211. $request['paramNotNull'],
  212. $request['paramType']
  213. ));
  214. if ($db->getAffectRow() < 1)
  215. throw new \PDOException("addChildRequestParam error");
  216. $param_id = $db->getLastInsertID();
  217. if ($request['paramValueList']) {
  218. foreach ($request['paramValueList'] as $value) {
  219. $db->prepareExecute('INSERT INTO eo_api_request_value (eo_api_request_value.paramID,eo_api_request_value.`value`,eo_api_request_value.valueDescription) VALUES (?,?,?);', array(
  220. $param_id,
  221. $value['value'],
  222. $value['valueDescription']
  223. ));
  224. if ($db->getAffectRow() < 1)
  225. throw new \PDOException("addChildApi error");
  226. };
  227. }
  228. };
  229. }
  230. if ($api['resultInfo']) {
  231. // 插入api返回值信息
  232. foreach ($api['resultInfo'] as $result) {
  233. $db->prepareExecute('INSERT INTO eo_api_result_param (eo_api_result_param.apiID,eo_api_result_param.paramName,eo_api_result_param.paramKey,eo_api_result_param.paramNotNull) VALUES (?,?,?,?);', array(
  234. $api_id,
  235. $result['paramName'],
  236. $result['paramKey'],
  237. $result['paramNotNull']
  238. ));
  239. if ($db->getAffectRow() < 1)
  240. throw new \PDOException("addChildResultParam error");
  241. $param_id = $db->getLastInsertID();
  242. if ($result['paramValueList']) {
  243. foreach ($result['paramValueList'] as $value) {
  244. $db->prepareExecute('INSERT INTO eo_api_result_value (eo_api_result_value.paramID,eo_api_result_value.`value`,eo_api_result_value.valueDescription) VALUES (?,?,?);;', array(
  245. $param_id,
  246. $value['value'],
  247. $value['valueDescription']
  248. ));
  249. if ($db->getAffectRow() < 1)
  250. throw new \PDOException("addChildParamValue error");
  251. };
  252. }
  253. };
  254. }
  255. // 插入api缓存数据用于导出
  256. $db->prepareExecute("INSERT INTO eo_api_cache (eo_api_cache.projectID,eo_api_cache.groupID,eo_api_cache.apiID,eo_api_cache.apiJson,eo_api_cache.starred) VALUES (?,?,?,?,?);", array(
  257. $project_id,
  258. $group_id,
  259. $api_id,
  260. json_encode($api),
  261. $api['baseInfo']['starred']
  262. ));
  263. if ($db->getAffectRow() < 1) {
  264. throw new \PDOException("addChildApiCache error");
  265. }
  266. }
  267. }
  268. }
  269. }
  270. } catch (\PDOException $e) {
  271. $db->rollBack();
  272. return FALSE;
  273. }
  274. $db->commit();
  275. return TRUE;
  276. }
  277. }