errors added + getRooms, newRoom, addRoomMember, removeRoomMember
This commit is contained in:
parent
b97e81d970
commit
cdb90cdcfb
1 changed files with 112 additions and 2 deletions
|
|
@ -4,8 +4,12 @@ const {sendError, sendMessage} = require ("../message");
|
||||||
|
|
||||||
// new conv
|
// new conv
|
||||||
router.post("/newConv", async (req, res) => {
|
router.post("/newConv", async (req, res) => {
|
||||||
|
if (typeof req.body.sender === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ sender');
|
||||||
|
if (typeof req.body.receiver === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ receiver');
|
||||||
const newConversation = new Conversation({
|
const newConversation = new Conversation({
|
||||||
members: [req.body.sender, req.body.receiver]
|
members: [req.body.sender, req.body.receiver], owner: null
|
||||||
});
|
});
|
||||||
|
|
||||||
try{
|
try{
|
||||||
|
|
@ -18,6 +22,10 @@ router.post("/newConv", async (req, res) => {
|
||||||
|
|
||||||
// get conv
|
// get conv
|
||||||
router.post("/getConv", async (req, res) => {
|
router.post("/getConv", async (req, res) => {
|
||||||
|
if (typeof req.body.sender === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ sender');
|
||||||
|
if (typeof req.body.receiver === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ receiver');
|
||||||
try {
|
try {
|
||||||
const conversation = await Conversation.findOne({$or: [{members: {$eq: [req.body.sender,req.body.receiver]}},{members: {$eq: [req.body.receiver,req.body.sender]}}]},{_id:1});
|
const conversation = await Conversation.findOne({$or: [{members: {$eq: [req.body.sender,req.body.receiver]}},{members: {$eq: [req.body.receiver,req.body.sender]}}]},{_id:1});
|
||||||
sendMessage(res,conversation);
|
sendMessage(res,conversation);
|
||||||
|
|
@ -25,4 +33,106 @@ router.post("/getConv", async (req, res) => {
|
||||||
sendMessage(res,err);
|
sendMessage(res,err);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// get conv
|
||||||
|
router.post("/getRooms", async (req, res) => {
|
||||||
|
if (typeof req.body.member === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ sender');
|
||||||
|
try {
|
||||||
|
const conversation = await Conversation.find({members: {$in: [req.body.member]}, owner: {$exists: true}},{_id:1});
|
||||||
|
sendMessage(res,conversation);
|
||||||
|
}catch (err){
|
||||||
|
sendMessage(res,err);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// new Room
|
||||||
|
router.post("/newRoom", async (req, res) => {
|
||||||
|
if (typeof req.body.owner === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ sender');
|
||||||
|
const newConversation = new Conversation(
|
||||||
|
{members: req.body.owner, owner: req.body.owner});
|
||||||
|
|
||||||
|
try{
|
||||||
|
const savedConversation = await newConversation.save();
|
||||||
|
sendMessage(res,savedConversation._id);
|
||||||
|
}catch (err){
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// add Room Member
|
||||||
|
router.post("/addRoomMember", async (req, res) => {
|
||||||
|
if (typeof req.body.conversationid === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ conversationId');
|
||||||
|
if (typeof req.body.owner === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ owner');
|
||||||
|
if (typeof req.body.member === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ member');
|
||||||
|
if(req.body.member === req.body.owner){
|
||||||
|
return sendError(res, 'Impossible de vous ajouter vous même');
|
||||||
|
}
|
||||||
|
|
||||||
|
try{
|
||||||
|
await Conversation.updateOne(
|
||||||
|
{_id: req.body.conversationid, owner: req.body.owner},
|
||||||
|
{$addToSet: {members: req.body.member}},
|
||||||
|
{useFindAndModify: false},
|
||||||
|
function(err, result){
|
||||||
|
if(result !== undefined){
|
||||||
|
console.log(result);
|
||||||
|
if(result.nModified === 1){
|
||||||
|
sendMessage(res,req.body.member+' added');
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}catch (err){
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
// remove Room Member
|
||||||
|
router.post("/removeRoomMember", async (req, res) => {
|
||||||
|
if (typeof req.body.conversationid === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ conversationId');
|
||||||
|
if (typeof req.body.owner === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ owner');
|
||||||
|
if (typeof req.body.member === 'undefined')
|
||||||
|
return sendError(res, 'Vous n\'avez pas envoyé le champ member');
|
||||||
|
if(req.body.member === req.body.owner){
|
||||||
|
return sendError(res, 'Impossible de vous enlever vous même');
|
||||||
|
}
|
||||||
|
|
||||||
|
try{
|
||||||
|
await Conversation.updateOne(
|
||||||
|
{_id: req.body.conversationid, owner: req.body.owner},
|
||||||
|
{$pull: {members: req.body.member}},
|
||||||
|
{useFindAndModify: false},
|
||||||
|
function(err, result){
|
||||||
|
if(result !== undefined){
|
||||||
|
console.log(result);
|
||||||
|
if(result.nModified === 1){
|
||||||
|
sendMessage(res,req.body.member+' removed');
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}catch (err){
|
||||||
|
sendError(res,err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
module.exports = router;
|
module.exports = router;
|
||||||
|
|
||||||
|
|
|
||||||
Reference in a new issue