123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- <?php
- /**
- * @name eolinker ams open source,eolinker开源版本
- * @link https://www.eolinker.com/
- * @package eolinker
- * @author www.eolinker.com 广州银云信息科技有限公司 ©2015-2018
- * eoLinker是目前全球领先、国内最大的在线API接口管理平台,提供自动生成API文档、API自动化测试、Mock测试、团队协作等功能,旨在解决由于前后端分离导致的开发效率低下问题。
- * 如在使用的过程中有任何问题,欢迎加入用户讨论群进行反馈,我们将会以最快的速度,最好的服务态度为您解决问题。
- *
- * eoLinker AMS开源版的开源协议遵循Apache License 2.0,如需获取最新的eolinker开源版以及相关资讯,请访问:https://www.eolinker.com/#/os/download
- *
- * 官方网站:https://www.eolinker.com/
- * 官方博客以及社区:http://blog.eolinker.com/
- * 使用教程以及帮助:http://help.eolinker.com/
- * 商务合作邮箱:market@eolinker.com
- * 用户讨论QQ群:284421832
- */
- class DatabasePartnerModule
- {
- public function __construct()
- {
- @session_start();
- }
- /**
- * 获取数据字典用户类型
- * @param $dbID int 数据库ID
- * @return bool|int
- */
- public function getUserType(&$dbID)
- {
- $dao = new AuthorizationDao();
- $result = $dao->getDatabaseUserType($_SESSION['userID'], $dbID);
- if ($result === FALSE) {
- return -1;
- }
- return $result;
- }
- /**
- * 邀请协作人员
- * @param $dbID int 数据库ID
- * @param $inviteUserID int 邀请人ID
- * @return mixed
- */
- public function invitePartner(&$dbID, &$inviteUserID)
- {
- $dbDao = new DatabaseDao();
- if ($dbDao->checkDatabasePermission($dbID, $_SESSION['userID'])) {
- $dbInfo = $dbDao->getDatabaseInfo($dbID);
- $summary = '您已被邀请加入数据库:' . $dbInfo['databaseInfo']['databaseName'] . ',开始您的高效协作之旅吧!';
- $msg = '<p>您好!亲爱的用户:</p><p>您已经被加入数据库:<b style="color:#4caf50">' . $dbInfo['databaseInfo']['databaseName'] . '</b>,现在你可以参与数据字典的开发协作工作。</p><p>如果您在使用的过程中遇到任何问题,欢迎前往<a href="http://blog.eolinker.com/#/bbs/"><b style="color:#4caf50">交流社区</b></a>反馈意见,谢谢!。</p>';
- //邀请协作人员
- $partnerDao = new DatabasePartnerDao;
- if ($connID = $partnerDao->invitePartner($dbID, $inviteUserID, $_SESSION['userID'])) {
- //给协作人员发送邀请信息
- $msgDao = new MessageDao;
- $msgDao->sendMessage($_SESSION['userID'], $inviteUserID, 1, $summary, $msg);
- return $connID;
- } else
- return FALSE;
- } else
- return FALSE;
- }
- /**
- * 移除协作人员
- * @param $dbID int 数据库ID
- * @param $connID int 连接ID
- * @return bool
- */
- public function removePartner($dbID, $connID)
- {
- $dbDao = new DatabaseDao();
- if ($dbDao->checkDatabasePermission($dbID, $_SESSION['userID'])) {
- $dbInfo = $dbDao->getDatabaseInfo($dbID);
- $summary = '您已被移除出数据库:' . $dbInfo['databaseInfo']['databaseName'];
- $msg = '<p>您好!亲爱的用户:</p><p>您已经被移除出数据库:<b style="color:#4caf50">' . $dbInfo['databaseInfo']['databaseName'] . '</b>。</p><p>如果您在使用的过程中遇到任何问题,欢迎前往<a href="http://blog.eolinker.com/#/bbs/"><b style="color:#4caf50">交流社区</b></a>反馈意见,谢谢!。</p>';
- $partnerDao = new DatabasePartnerDao;
- $remotePartnerID = $partnerDao->getUserID($connID);
- if ($partnerDao->removePartner($dbID, $connID)) {
- //给协作人员发送邀请信息
- $msgDao = new MessageDao;
- $msgDao->sendMessage(0, $remotePartnerID, 1, $summary, $msg);
- return TRUE;
- } else
- return FALSE;
- } else
- return FALSE;
- }
- /**
- * 获取协作人员列表
- * @param $dbID int 数据库ID
- * @return array|bool
- */
- public function getPartnerList(&$dbID)
- {
- $dbDao = new DatabaseDao();
- if ($dbDao->checkDatabasePermission($dbID, $_SESSION['userID'])) {
- $partnerDao = new DatabasePartnerDao;
- $list = $partnerDao->getPartnerList($dbID);
- foreach ($list as &$param) {
- if ($param['userID'] == $_SESSION['userID'])
- $param['isNow'] = 1;
- else
- $param['isNow'] = 0;
- unset($param['userID']);
- }
- return $list;
- } else
- return FALSE;
- }
- /**
- * 退出协作项目
- * @param $dbID int 数据库ID
- * @return bool
- */
- public function quitPartner(&$dbID)
- {
- $dbDao = new DatabaseDao();
- if ($dbDao->checkDatabasePermission($dbID, $_SESSION['userID'])) {
- $partnerDao = new DatabasePartnerDao;
- if ($partnerDao->quitPartner($dbID, $_SESSION['userID']))
- return TRUE;
- else
- return FALSE;
- } else
- return FALSE;
- }
- /**
- * 查询是否已经加入过项目
- * @param $dbID int 项目ID
- * @param $userName string 用户名
- * @return bool
- */
- public function checkIsInvited(&$dbID, &$userName)
- {
- $dao = new DatabasePartnerDao;
- return $dao->checkIsInvited($dbID, $userName);
- }
- /**
- * 修改协作成员的昵称
- * @param $dbID int 数据库ID
- * @param $conn_id int 连接ID
- * @param $nick_name string 昵称
- * @return bool
- */
- public function editPartnerNickName(&$dbID, &$conn_id, &$nick_name)
- {
- $dao = new DatabasePartnerDao();
- return $dao->editPartnerNickName($dbID, $conn_id, $nick_name);
- }
- /**
- * 修改协作成员的类型
- * @param $dbID int 数据库ID
- * @param $conn_id int 连接ID
- * @param $user_type int 用户类型
- * @return bool
- */
- public function editPartnerType(&$dbID, &$conn_id, &$user_type)
- {
- $dao = new DatabasePartnerDao();
- return $dao->editPartnerType($dbID, $conn_id, $user_type);
- }
- }
- ?>
|