123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320 |
- <?php
- class AutoGenerateDao
- {
-
- public function importApi(&$data, &$project_id)
- {
- $db = getDatabase();
- try {
-
- $db->beginTransaction();
- $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));
- $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));
- $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));
- $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));
- $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));
- $db->prepareExecuteAll('DELETE FROM eo_api_group WHERE eo_api_group.projectID = ?;', array($project_id));
- $db->prepareExecuteAll('DELETE FROM eo_api WHERE eo_api.projectID = ?;', array($project_id));
- $db->prepareExecuteAll('DELETE FROM eo_api_cache WHERE eo_api_cache.projectID = ?;', array($project_id));
-
- foreach ($data as $api_group) {
- $db->prepareExecute('INSERT INTO eo_api_group (eo_api_group.groupName,eo_api_group.projectID) VALUES (?,?);', array(
- $api_group['groupName'],
- $project_id
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addGroup error");
- $group_id = $db->getLastInsertID();
- if ($api_group['apiList']) {
- foreach ($api_group['apiList'] as $api) {
-
- $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(
- $api['baseInfo']['apiName'],
- $api['baseInfo']['apiURI'],
- $api['baseInfo']['apiProtocol'],
- $api['baseInfo']['apiSuccessMock'],
- $api['baseInfo']['apiFailureMock'],
- $api['baseInfo']['apiRequestType'],
- $api['baseInfo']['apiStatus'],
- $group_id,
- $project_id,
- $api['baseInfo']['starred'],
- $api['baseInfo']['apiNoteType'],
- $api['baseInfo']['apiNoteRaw'],
- $api['baseInfo']['apiNote'],
- $api['baseInfo']['apiRequestParamType'],
- $api['baseInfo']['apiRequestRaw'],
- $api['baseInfo']['apiUpdateTime']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addApi error");
- $api_id = $db->getLastInsertID();
- if ($api['headerInfo']) {
-
- foreach ($api['headerInfo'] as $header) {
- $db->prepareExecute('INSERT INTO eo_api_header (eo_api_header.headerName,eo_api_header.headerValue,eo_api_header.apiID) VALUES (?,?,?);', array(
- $header['headerName'],
- $header['headerValue'],
- $api_id
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addHeader error");
- }
- }
- if ($api['requestInfo']) {
-
- foreach ($api['requestInfo'] as $request) {
- $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(
- $api_id,
- $request['paramName'],
- $request['paramKey'],
- $request['paramValue'],
- $request['paramLimit'],
- $request['paramNotNull'],
- $request['paramType']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addRequestParam error");
- $param_id = $db->getLastInsertID();
- if ($request['paramValueList']) {
- foreach ($request['paramValueList'] as $value) {
- $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(
- $param_id,
- $value['value'],
- $value['valueDescription']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addApi error");
- };
- }
- };
- }
- if ($api['resultInfo']) {
-
- foreach ($api['resultInfo'] as $result) {
- $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(
- $api_id,
- $result['paramName'],
- $result['paramKey'],
- $result['paramNotNull']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addResultParam error");
- $param_id = $db->getLastInsertID();
- if ($result['paramValueList']) {
- foreach ($result['paramValueList'] as $value) {
- $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(
- $param_id,
- $value['value'],
- $value['valueDescription']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addApi error");
- };
- }
- };
- }
-
- $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(
- $project_id,
- $group_id,
- $api_id,
- json_encode($api),
- $api['baseInfo']['starred']
- ));
- if ($db->getAffectRow() < 1) {
- throw new \PDOException("addApiCache error");
- }
- }
- }
- if (is_array($api_group['apiGroupChildList'])) {
-
- $group_parent_id = $group_id;
- foreach ($api_group['apiGroupChildList'] as $api_group_child) {
- $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(
- $api_group_child['groupName'],
- $project_id,
- $group_parent_id,
- 1
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildGroup error");
- $group_id = $db->getLastInsertID();
-
- if (empty($api_group_child['apiList']))
- continue;
- foreach ($api_group_child['apiList'] as $api) {
-
- $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(
- $api['baseInfo']['apiName'],
- $api['baseInfo']['apiURI'],
- $api['baseInfo']['apiProtocol'],
- $api['baseInfo']['apiSuccessMock'],
- $api['baseInfo']['apiFailureMock'],
- $api['baseInfo']['apiRequestType'],
- $api['baseInfo']['apiStatus'],
- $group_id,
- $project_id,
- $api['baseInfo']['starred'],
- $api['baseInfo']['apiNoteType'],
- $api['baseInfo']['apiNoteRaw'],
- $api['baseInfo']['apiNote'],
- $api['baseInfo']['apiRequestParamType'],
- $api['baseInfo']['apiRequestRaw'],
- $api['baseInfo']['apiUpdateTime']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildApi error");
- $api_id = $db->getLastInsertID();
- if ($api['headerInfo']) {
-
- foreach ($api['headerInfo'] as $header) {
- $db->prepareExecute('INSERT INTO eo_api_header (eo_api_header.headerName,eo_api_header.headerValue,eo_api_header.apiID) VALUES (?,?,?);', array(
- $header['headerName'],
- $header['headerValue'],
- $api_id
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildHeader error");
- }
- }
- if ($api['requestInfo']) {
-
- foreach ($api['requestInfo'] as $request) {
- $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(
- $api_id,
- $request['paramName'],
- $request['paramKey'],
- $request['paramValue'],
- $request['paramLimit'],
- $request['paramNotNull'],
- $request['paramType']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildRequestParam error");
- $param_id = $db->getLastInsertID();
- if ($request['paramValueList']) {
- foreach ($request['paramValueList'] as $value) {
- $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(
- $param_id,
- $value['value'],
- $value['valueDescription']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildApi error");
- };
- }
- };
- }
- if ($api['resultInfo']) {
-
- foreach ($api['resultInfo'] as $result) {
- $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(
- $api_id,
- $result['paramName'],
- $result['paramKey'],
- $result['paramNotNull']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildResultParam error");
- $param_id = $db->getLastInsertID();
- if ($result['paramValueList']) {
- foreach ($result['paramValueList'] as $value) {
- $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(
- $param_id,
- $value['value'],
- $value['valueDescription']
- ));
- if ($db->getAffectRow() < 1)
- throw new \PDOException("addChildParamValue error");
- };
- }
- };
- }
-
- $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(
- $project_id,
- $group_id,
- $api_id,
- json_encode($api),
- $api['baseInfo']['starred']
- ));
- if ($db->getAffectRow() < 1) {
- throw new \PDOException("addChildApiCache error");
- }
- }
- }
- }
- }
- } catch (\PDOException $e) {
- $db->rollBack();
- return FALSE;
- }
- $db->commit();
- return TRUE;
- }
- }
|