PartnerModule.class.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  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 PartnerModule
  19. {
  20. public function __construct()
  21. {
  22. @session_start();
  23. }
  24. /**
  25. * 获取项目用户类型
  26. * @param $projectID int 项目ID
  27. * @return bool|int
  28. */
  29. public function getUserType(&$projectID)
  30. {
  31. $dao = new AuthorizationDao();
  32. $result = $dao->getProjectUserType($_SESSION['userID'], $projectID);
  33. if ($result === FALSE) {
  34. return -1;
  35. }
  36. return $result;
  37. }
  38. /**
  39. * 邀请协作人员
  40. * @param $projectID int 项目ID
  41. * @param $inviteUserID int 邀请人ID
  42. * @return bool|int
  43. */
  44. public function invitePartner(&$projectID, &$inviteUserID)
  45. {
  46. $projectDao = new ProjectDao;
  47. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  48. $projectInfo = $projectDao->getProjectName($projectID);
  49. $summary = '您已被邀请加入项目:' . $projectInfo['projectName'] . ',开始您的高效协作之旅吧!';
  50. $msg = '<p>您好!亲爱的用户:</p><p>您已经被加入项目:<b style="color:#4caf50">' . $projectInfo['projectName'] . '</b>,现在你可以参与项目的开发协作工作。</p><p>如果您在使用的过程中遇到任何问题,欢迎前往<a href="http://blog.eolinker.com/#/bbs/"><b style="color:#4caf50">交流社区</b></a>反馈意见,谢谢!。</p>';
  51. //邀请协作人员
  52. $partnerDao = new PartnerDao;
  53. if ($connID = $partnerDao->invitePartner($projectID, $inviteUserID, $_SESSION['userID'])) {
  54. $inviteUserCall = $partnerDao->getPartnerUserCall($inviteUserID);
  55. //将操作写入日志
  56. $log_dao = new ProjectLogDao();
  57. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_PARTNER, $inviteUserID, ProjectLogDao::$OP_TYPE_ADD, "邀请新成员:'$inviteUserCall'", date("Y-m-d H:i:s", time()));
  58. //给协作人员发送邀请信息
  59. $msgDao = new MessageDao;
  60. $msgDao->sendMessage($_SESSION['userID'], $inviteUserID, 1, $summary, $msg);
  61. return $connID;
  62. } else
  63. return FALSE;
  64. } else
  65. return FALSE;
  66. }
  67. /**
  68. * 移除协作人员
  69. * @param $projectID int 项目ID
  70. * @param $connID int 用户与项目联系ID
  71. * @return bool
  72. */
  73. public function removePartner($projectID, $connID)
  74. {
  75. $projectDao = new ProjectDao;
  76. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  77. $projectInfo = $projectDao->getProjectName($projectID);
  78. $summary = '您已被移除出项目:' . $projectInfo['projectName'];
  79. $msg = '<p>您好!亲爱的用户:</p><p>您已经被移除出项目:<b style="color:#4caf50">' . $projectInfo['projectName'] . '</b>。</p><p>如果您在使用的过程中遇到任何问题,欢迎前往<a href="http://blog.eolinker.com/#/bbs/"><b style="color:#4caf50">交流社区</b></a>反馈意见,谢谢!。</p>';
  80. $partnerDao = new PartnerDao;
  81. $remotePartnerID = $partnerDao->getUserID($connID);
  82. if ($partnerDao->removePartner($projectID, $connID)) {
  83. $inviteUserCall = $partnerDao->getPartnerUserCall($remotePartnerID);
  84. //将操作写入日志
  85. $log_dao = new ProjectLogDao();
  86. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_PARTNER, $remotePartnerID, ProjectLogDao::$OP_TYPE_DELETE, "移除成员:'$inviteUserCall'", date("Y-m-d H:i:s", time()));
  87. //给协作人员发送邀请信息
  88. $msgDao = new MessageDao;
  89. $msgDao->sendMessage(0, $remotePartnerID, 1, $summary, $msg);
  90. return TRUE;
  91. } else
  92. return FALSE;
  93. } else
  94. return FALSE;
  95. }
  96. /**
  97. * 获取协作人员列表
  98. * @param $projectID int 项目ID
  99. * @return bool|array
  100. */
  101. public function getPartnerList(&$projectID)
  102. {
  103. $projectDao = new ProjectDao;
  104. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  105. $partnerDao = new PartnerDao;
  106. $list = $partnerDao->getPartnerList($projectID);
  107. foreach ($list as &$param) {
  108. if ($param['userID'] == $_SESSION['userID'])
  109. $param['isNow'] = 1;
  110. else
  111. $param['isNow'] = 0;
  112. unset($param['userID']);
  113. }
  114. return $list;
  115. } else
  116. return FALSE;
  117. }
  118. /**
  119. * 退出协作项目
  120. * @param $projectID int 项目ID
  121. * @return bool
  122. */
  123. public function quitPartner(&$projectID)
  124. {
  125. $projectDao = new ProjectDao;
  126. if ($projectDao->checkProjectPermission($projectID, $_SESSION['userID'])) {
  127. $partnerDao = new PartnerDao;
  128. if ($partnerDao->quitPartner($projectID, $_SESSION['userID'])) {
  129. $user_call = $partnerDao->getPartnerUserCall($_SESSION['userID']);
  130. //将操作写入日志
  131. $log_dao = new ProjectLogDao();
  132. $log_dao->addOperationLog($projectID, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_PARTNER, $_SESSION['userID'], ProjectLogDao::$OP_TYPE_OTHERS, "'$user_call'退出项目协作", date("Y-m-d H:i:s", time()));
  133. return TRUE;
  134. } else
  135. return FALSE;
  136. } else
  137. return FALSE;
  138. }
  139. /**
  140. * 查询是否已经加入过项目
  141. * @param $projectID int 项目ID
  142. * @param $userName string 用户名
  143. * @return bool
  144. */
  145. public function checkIsInvited(&$projectID, &$userName)
  146. {
  147. $dao = new PartnerDao;
  148. return $dao->checkIsInvited($projectID, $userName);
  149. }
  150. /**
  151. * 修改协作成员的昵称
  152. * @param $project_id int 项目ID
  153. * @param $conn_id int 连接ID
  154. * @param $nick_name string 昵称
  155. * @return bool
  156. */
  157. public function editPartnerNickName(&$project_id, &$conn_id, &$nick_name)
  158. {
  159. $dao = new PartnerDao();
  160. return $dao->editPartnerNickName($project_id, $conn_id, $nick_name);
  161. }
  162. /**
  163. * 修改协作成员的类型
  164. * @param $project_id int 项目ID
  165. * @param $conn_id int 连接ID
  166. * @param $user_type int 用户类型
  167. * @return bool
  168. */
  169. public function editPartnerType(&$project_id, &$conn_id, &$user_type)
  170. {
  171. $dao = new PartnerDao();
  172. $result = $dao->editPartnerType($project_id, $conn_id, $user_type);
  173. if ($result) {
  174. $remote_partner_id = $dao->getUserID($conn_id);
  175. $invite_user_call = $dao->getPartnerUserCall($remote_partner_id);
  176. switch ($user_type) {
  177. case 1:
  178. $type = '管理员';
  179. break;
  180. case 2:
  181. $type = '普通成员(读写)';
  182. break;
  183. case 3:
  184. $type = '普通成员(只读)';
  185. break;
  186. default:
  187. break;
  188. }
  189. //将操作写入日志
  190. $log_dao = new ProjectLogDao();
  191. $log_dao->addOperationLog($project_id, $_SESSION['userID'], ProjectLogDao::$OP_TARGET_PARTNER, $remote_partner_id, ProjectLogDao::$OP_TYPE_DELETE, "修改成员:'$invite_user_call'为'$type'", date("Y-m-d H:i:s", time()));
  192. return $result;
  193. } else {
  194. return FALSE;
  195. }
  196. }
  197. public function getProjectInviteCode(&$project_id)
  198. {
  199. }
  200. public function joinProjectByInviteCode()
  201. {
  202. }
  203. }
  204. ?>