DatabasePartnerDao.class.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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 DatabasePartnerDao
  19. {
  20. /**
  21. * 邀请协作人员
  22. * @param $dbID int 数据库ID
  23. * @param $userID int 被邀请人ID
  24. * @param $inviteUserID int 邀请人ID
  25. * @return bool|int
  26. */
  27. public function invitePartner(&$dbID, &$userID, &$inviteUserID)
  28. {
  29. $db = getDatabase();
  30. $db->prepareExecute('INSERT INTO eo_conn_database (eo_conn_database.dbID,eo_conn_database.userID,eo_conn_database.userType,eo_conn_database.inviteUserID) VALUES (?,?,2,?);', array(
  31. $dbID,
  32. $userID,
  33. $inviteUserID
  34. ));
  35. if ($db->getAffectRow() > 0)
  36. return $db->getLastInsertID();
  37. else
  38. return FALSE;
  39. }
  40. /**
  41. * 移除协作人员
  42. * @param $dbID int 项目ID
  43. * @param $connID int 用户与数据库联系ID
  44. * @return bool
  45. */
  46. public function removePartner(&$dbID, &$connID)
  47. {
  48. $db = getDatabase();
  49. $db->prepareExecute('DELETE FROM eo_conn_database WHERE eo_conn_database.dbID = ? AND eo_conn_database.connID = ? AND eo_conn_database.userType != 0;', array(
  50. $dbID,
  51. $connID
  52. ));
  53. if ($db->getAffectRow() > 0)
  54. return TRUE;
  55. else
  56. return FALSE;
  57. }
  58. /**
  59. * 获取协作人员列表
  60. * @param $dbID int 数据库ID
  61. * @return bool|array
  62. */
  63. public function getPartnerList(&$dbID)
  64. {
  65. $db = getDatabase();
  66. $result = $db->prepareExecuteAll('SELECT eo_conn_database.userID,eo_conn_database.connID,eo_conn_database.userType,eo_user.userName,eo_user.userNickName,eo_conn_database.partnerNickName FROM eo_conn_database INNER JOIN eo_user ON eo_conn_database.userID = eo_user.userID WHERE eo_conn_database.dbID = ? ORDER BY eo_conn_database.userType ASC;', array($dbID));
  67. if (empty($result))
  68. return FALSE;
  69. else
  70. return $result;
  71. }
  72. /**
  73. * 退出协作项目
  74. * @param $dbID int 数据库ID
  75. * @param $userID int 用户ID
  76. * @return bool
  77. */
  78. public function quitPartner(&$dbID, &$userID)
  79. {
  80. $db = getDatabase();
  81. $db->prepareExecute('DELETE FROM eo_conn_database WHERE eo_conn_database.dbID = ? AND eo_conn_database.userID = ? AND eo_conn_database.userType != 0;', array(
  82. $dbID,
  83. $userID
  84. ));
  85. if ($db->getAffectRow() > 0) {
  86. return TRUE;
  87. } else
  88. return FALSE;
  89. }
  90. /**
  91. * 查询是否已经加入过项目
  92. * @param $dbID int 数据库ID
  93. * @param $userName string 用户名
  94. * @return bool
  95. */
  96. public function checkIsInvited(&$dbID, &$userName)
  97. {
  98. $db = getDatabase();
  99. $result = $db->prepareExecuteAll('SELECT eo_conn_database.connID FROM eo_conn_database INNER JOIN eo_user ON eo_user.userID = eo_conn_database.userID WHERE eo_conn_database.dbID = ? AND eo_user.userName = ?;', array(
  100. $dbID,
  101. $userName
  102. ));
  103. if (empty($result))
  104. return FALSE;
  105. else
  106. return TRUE;
  107. }
  108. /**
  109. * 获取用户ID
  110. * @param $connID int 用户与项目联系ID
  111. * @return bool|int
  112. */
  113. public function getUserID(&$connID)
  114. {
  115. $db = getDatabase();
  116. $result = $db->prepareExecute('SELECT eo_conn_database.userID FROM eo_conn_database WHERE eo_conn_database.connID = ?;', array($connID));
  117. if (empty($result))
  118. return FALSE;
  119. else
  120. return $result['userID'];
  121. }
  122. /**
  123. * 修改协作成员的昵称
  124. * @param $dbID int 数据库ID
  125. * @param $conn_id int 连接ID
  126. * @param $nick_name string 昵称
  127. * @return bool
  128. */
  129. public function editPartnerNickName(&$dbID, &$conn_id, &$nick_name)
  130. {
  131. $db = getDatabase();
  132. $db->prepareExecute('UPDATE eo_conn_database SET eo_conn_database.partnerNickName = ? WHERE eo_conn_database.connID = ? AND eo_conn_database.dbID = ?;', array(
  133. $nick_name,
  134. $conn_id,
  135. $dbID
  136. ));
  137. if ($db->getAffectRow() > 0) {
  138. return TRUE;
  139. } else
  140. return FALSE;
  141. }
  142. /**
  143. * 修改协作成员的类型
  144. * @param $dbID int 数据库ID
  145. * @param $conn_id int 连接ID
  146. * @param $user_type int 用户类型
  147. * @return bool
  148. */
  149. public function editPartnerType(&$dbID, &$conn_id, &$user_type)
  150. {
  151. $db = getDatabase();
  152. $db->prepareExecute('UPDATE eo_conn_database SET eo_conn_database.userType = ? WHERE eo_conn_database.connID = ? AND eo_conn_database.dbID = ?;', array(
  153. $user_type,
  154. $conn_id,
  155. $dbID
  156. ));
  157. if ($db->getAffectRow() > 0) {
  158. return TRUE;
  159. } else
  160. return FALSE;
  161. }
  162. }
  163. ?>