示例#1
0
 public function addUser(User $model)
 {
     if (empty($model->username)) {
         return new ApiResponse(Code::FAIL_EMPTY_ACCOUNT, '');
     }
     if ($resp = $this->checkPassword($model->password)) {
         return $resp;
     }
     $gender = rand(0, 10) > 5 ? 'g' : 'b';
     $model->avatar = 'avatar/default/' . $gender . rand(0, 9) . '.jpg';
     $model->token = TextUtil::generateGUID();
     $model->create_time = time();
     $model->reg_ip = ApiRequest::getRemoteIp();
     $password = $this->enCryptPassword($model->password);
     $dbManager = Db::getInstance();
     $statement = $dbManager->prepare(self::ADD_USER);
     if (!$statement->execute([$model->username, $password, $model->create_time, $model->nick, $model->motto, $model->avatar, $model->token, $model->reg_ip])) {
         return new ApiResponse(Code::FAIL_USER_NAME_ALREADY_EXISTS, null);
     }
     $model->id = $dbManager->lastInsertId();
     JegarnUtil::addUser($model->id, $model->username, $model->token);
     JegarnUtil::sendUserSystemTextChatMessage($model->id, 'welcome to jegarn');
     // add login record
     $loginLog = new LoginLog($model->id, LoginLog::STATUS_SUCCESS);
     LoginLogManager::getInstance()->addLog($loginLog);
     // make friends with counter, join group 'Counter Group', join chatroom 'Counter Room'
     $targetId = self::COUNTER_UID;
     $groupId = self::COUNTER_GROUP_ID;
     $chatroomId = self::COUNTER_CHATROOM_ID;
     $sqlList = ["INSERT INTO `m_roster`(uid,target_id,status,create_time,update_time,remark,group_id,rank) VALUES ({$targetId},{$model->id},3,{$model->create_time},0,NULL,0,0)", "INSERT INTO `m_roster`(uid,target_id,status,create_time,update_time,remark,group_id,rank) VALUES ({$model->id},{$targetId},3,{$model->create_time},0,NULL,0,0)", "INSERT into `m_group_user`(gid,uid,permission,create_time,status,remark) values({$groupId},{$model->id},0,{$model->create_time},3,NULL)", "INSERT into `m_group_user`(gid,uid,permission,create_time,status,remark) values({$chatroomId},{$model->id},0,{$model->create_time},3,NULL)"];
     foreach ($sqlList as $sql) {
         $dbManager->exec($sql);
     }
     JegarnUtil::joinGroup($groupId, $model->id);
     JegarnUtil::joinChatroom($chatroomId, $model->id);
     return null;
 }