ProjectLogDao.class.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  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 ProjectLogDao
  19. {
  20. public static $OP_TYPE_ADD = 0;
  21. public static $OP_TYPE_UPDATE = 1;
  22. public static $OP_TYPE_DELETE = 2;
  23. public static $OP_TYPE_OTHERS = 3;
  24. public static $OP_TARGET_PROJECT = 0;
  25. public static $OP_TARGET_API = 1;
  26. public static $OP_TARGET_API_GROUP = 2;
  27. public static $OP_TARGET_STATUS_CODE = 3;
  28. public static $OP_TARGET_STATUS_CODE_GROUP = 4;
  29. public static $OP_TARGET_ENVIRONMENT = 5;
  30. public static $OP_TARGET_PARTNER = 6;
  31. public static $OP_TARGET_PROJECT_DOCUMENT_GROUP = 7;
  32. public static $OP_TARGET_PROJECT_DOCUMENT = 8;
  33. public static $OP_TARGET_AUTOMATED_TEST_CASE_GROUP = 9;
  34. public static $OP_TARGET_AUTOMATED_TEST_CASE = 10;
  35. /**
  36. * 记录操作日志
  37. * @param $project_id
  38. * @param $user_id
  39. * @param $op_target
  40. * @param $op_targetID
  41. * @param $op_type
  42. * @param $op_desc
  43. * @param $op_time
  44. * @return bool
  45. */
  46. public function addOperationLog(&$project_id, &$user_id, $op_target, &$op_targetID, $op_type, $op_desc, $op_time)
  47. {
  48. $db = getDatabase();
  49. $db->prepareExecute('INSERT INTO eo_log_project_operation (eo_log_project_operation.opType,eo_log_project_operation.opUserID,eo_log_project_operation.opDesc,eo_log_project_operation.opTime,eo_log_project_operation.opProjectID,eo_log_project_operation.opTarget,eo_log_project_operation.opTargetID) VALUES (?,?,?,?,?,?,?);', array(
  50. $op_type,
  51. $user_id,
  52. $op_desc,
  53. $op_time,
  54. $project_id,
  55. $op_target,
  56. $op_targetID
  57. ));
  58. if ($db->getAffectRow() > 0)
  59. return $db->getLastInsertID();
  60. else
  61. return FALSE;
  62. }
  63. /**
  64. * 获取操作日志
  65. * @param $project_id
  66. * @param $page
  67. * @param $page_size
  68. * @param $dayOffset
  69. * @return array|bool
  70. */
  71. public function getOperationLogList(&$project_id, &$page, &$page_size, $dayOffset)
  72. {
  73. $db = getDatabase();
  74. $result = array();
  75. $result['logList'] = $db->prepareExecuteAll('SELECT eo_log_project_operation.opTime,eo_log_project_operation.opType,eo_conn_project.partnerNickName,eo_user.userNickName,eo_log_project_operation.opTarget,eo_log_project_operation.opDesc
  76. FROM eo_log_project_operation LEFT JOIN eo_conn_project ON eo_log_project_operation.opUserID = eo_conn_project.userID AND eo_log_project_operation.opProjectID = eo_conn_project.projectID
  77. INNER JOIN eo_user ON eo_log_project_operation.opUserID = eo_user.userID
  78. WHERE eo_log_project_operation.opProjectID = ? AND eo_log_project_operation.opTime > DATE_SUB(NOW(),INTERVAL ? DAY) ORDER BY eo_log_project_operation.opTime DESC LIMIT ?,?;', array(
  79. $project_id,
  80. $dayOffset,
  81. ($page - 1) * $page_size,
  82. $page_size
  83. ));
  84. $log_count = $db->prepareExecute('SELECT COUNT(eo_log_project_operation.opID) AS logCount FROM eo_log_project_operation WHERE eo_log_project_operation.opProjectID = ? AND eo_log_project_operation.opTime > DATE_SUB(NOW(),INTERVAL ? DAY)', array(
  85. $project_id,
  86. $dayOffset
  87. ));
  88. $result = array_merge($result, $log_count);
  89. if (empty($result))
  90. return FALSE;
  91. else
  92. return $result;
  93. }
  94. /**
  95. * 获取24小时之内操作日志以及数量
  96. * @param $project_id
  97. * @return array|bool
  98. */
  99. public function getLogInADay(&$project_id)
  100. {
  101. $db = getDatabase();
  102. $result = array();
  103. $result['logList'] = $db->prepareExecuteAll('SELECT eo_log_project_operation.opTime,eo_conn_project.partnerNickName,eo_user.userNickName,eo_log_project_operation.opDesc FROM eo_log_project_operation LEFT JOIN eo_conn_project ON eo_log_project_operation.opUserID = eo_conn_project.userID AND eo_log_project_operation.opProjectID = eo_conn_project.projectID INNER JOIN eo_user ON eo_log_project_operation.opUserID = eo_user.userID WHERE eo_log_project_operation.opProjectID = ? AND eo_log_project_operation.opTime > DATE_SUB(NOW(),INTERVAL 1 DAY) ORDER BY eo_log_project_operation.opTime DESC LIMIT 0,10;', array(
  104. $project_id
  105. ));
  106. $log_count = $db->prepareExecute('SELECT COUNT(eo_log_project_operation.opID) AS logCount FROM eo_log_project_operation WHERE eo_log_project_operation.opProjectID = ? AND eo_log_project_operation.opTime > DATE_SUB(NOW(),INTERVAL 1 DAY) ', array(
  107. $project_id
  108. ));
  109. $result = array_merge($result, $log_count);
  110. if (empty($result))
  111. return FALSE;
  112. else
  113. return $result;
  114. }
  115. }