1
0
forked from apxtri/apxtri

modif for docapi

This commit is contained in:
philc 2024-07-11 13:29:54 +02:00
parent 27ce76e53f
commit 3ec0105455
2 changed files with 212 additions and 105 deletions

View File

@ -30,27 +30,32 @@ Notifications.get = (alias, tribeId) => {
/**
* Get statistic of registering email phone
*/
Notifications.statmaillist=(tribe)=>{
const statinfo={}
let csv="email/phone;name;srckey\n"
const src=`../../${tribe}/objects/maillinglists/*.json`
console.log(path.resolve(src))
glob.sync(src).forEach(f=>{
const name=path.basename(f,".json");
const mlst=fs.readJSONSync(f)
Object.keys(mlst).forEach(c=>{
csv+=`"${c}";"${name}";"${mlst[c].srckeys.join('-')}"\n`
mlst[c].srckeys.forEach(s=>{
if (!statinfo[s]) statinfo[s]={}
if (!statinfo[s][name]) statinfo[s][name]=0
statinfo[s][name]++
})
})
})
Notifications.statmaillist = (tribe) => {
const statinfo = {};
let csv = "email/phone;name;srckey\n";
const src = `../../${tribe}/objects/maillinglists/*.json`;
console.log(path.resolve(src));
glob.sync(src).forEach((f) => {
const name = path.basename(f, ".json");
const mlst = fs.readJSONSync(f);
Object.keys(mlst).forEach((c) => {
csv += `"${c}";"${name}";"${mlst[c].srckeys.join("-")}"\n`;
mlst[c].srckeys.forEach((s) => {
if (!statinfo[s]) statinfo[s] = {};
if (!statinfo[s][name]) statinfo[s][name] = 0;
statinfo[s][name]++;
});
});
});
// fichier csv stocker en local en attendant d'avoir un back pour stocker la reponse dans data.csv
fs.outputFileSync(`../../${tribe}/mailinglst.csv`,csv,"utf-8");
return {status:200,ref:"Notifications",msg:"statistics",data:statinfo}
}
fs.outputFileSync(`../../${tribe}/mailinglst.csv`, csv, "utf-8");
return {
status: 200,
ref: "Notifications",
msg: "statistics",
data: statinfo,
};
};
/**
* Register an typekey(email) or (phone) key into mailinglist for a tribe
@ -58,19 +63,26 @@ Notifications.statmaillist=(tribe)=>{
*/
Notifications.registertolist = (key, typekey, tribe, mlist, srckey, uuid) => {
key = key.toLowerCase();
typekey= (typekey=="telephone")? "telephonefr":typekey;
typekey = typekey == "telephone" ? "telephonefr" : typekey;
if (!Checkjson.testformat(key, typekey))
return {
status: 400,
ref: "Notifications",
msg: "formaterror",
data: { fielderr: typekey, format: typekey }
data: { fielderr: typekey, format: typekey },
};
const destin = `../../${tribe}/objects/maillinglists/${typekey}_${mlist}.json`;
if (!fs.existsSync(destin)){
console.log(`######## Attention tentative d'ecriture non autorisé,le fichier n'existe pas ${destin} créer le à la main vide {}`)
return {status:406,ref:"Notifications",msg:"destinnotallow",data:{destin}}
if (!fs.existsSync(destin)) {
console.log(
`######## Attention tentative d'ecriture non autorisé,le fichier n'existe pas ${destin} créer le à la main vide {}`
);
return {
status: 406,
ref: "Notifications",
msg: "destinnotallow",
data: { destin },
};
}
const filestorage = fs.existsSync(destin) ? fs.readJsonSync(destin) : {};
@ -81,28 +93,30 @@ Notifications.registertolist = (key, typekey, tribe, mlist, srckey, uuid) => {
filestorage[key].srckeys.push(srckey);
if (!filestorage[key].uuids.includes(uuid))
filestorage[key].uuids.push(uuid);
}else{
filestorage[key]={}
filestorage[key].dt_create=dayjs().toISOString();
filestorage[key].srckeys=[srckey];
filestorage[key].uuids=[uuid]
} else {
filestorage[key] = {};
filestorage[key].dt_create = dayjs().toISOString();
filestorage[key].srckeys = [srckey];
filestorage[key].uuids = [uuid];
}
fs.outputJSONSync(destin, filestorage);
return {status:200,ref:"Notifications",msg:"registersuccess",data:{key, typekey, tribe, mlist, srckey, uuid}}
}
return {
status: 200,
ref: "Notifications",
msg: "registersuccess",
data: { key, typekey, tribe, mlist, srckey, uuid },
};
};
/**
* Unsubscribe an eamil or phone from a mailinglist for a tribe
*/
Notifications.unregisterfromlist = (key, typekey, tribe,mlist) => {
Notifications.unregisterfromlist = (key, typekey, tribe, mlist) => {
key = key.toLowerCase();
}
};
/**
* Message to send to an alias from an anonymous or not
*/
Notifications.sendcontact = (body, header) => {
}
Notifications.sendcontact = (body, header) => {};
Notifications.sendsms = async (data, tribeId) => {
/**
* Never use need wallet in mailjet to test
@ -138,11 +152,7 @@ Notifications.sendsms = async (data, tribeId) => {
};
}
let confsms = conf.sms;
if (
fs.existsSync(
`../../itm/${req.session.header.xtribe}.json`
)
) {
if (fs.existsSync(`../../itm/${req.session.header.xtribe}.json`)) {
const conftrib = fs.readJSONSync(
`../../itm/${req.session.header.xtribe}.json`
);
@ -195,6 +205,49 @@ Notifications.sendsms = async (data, tribeId) => {
*/
};
Notifications.manageemail = (data, template, tribe) => {
/**
* Manage email publipostage
* data must contain emailsto
* data optionaly can contain Cc,Bcc as array of emails and attachments as array of filename (into the server)
* Await the 1st email
*/
if (!data.emailsto || data.emailsto.length == 0) {
return {
status: 406,
ref: "Notifications",
msg: "emailsmissing",
data: data,
};
}
if (typeof data.emailsto === "string") data.emailsto = [data.emailsto];
const tplemail = require(path.resolve(template));
let sendit;
data.emailsto.forEach(async (e, i) => {
if (Checkjson.testformat(e, "email")) {
const dat = {};
dat.to = e;
dat.subject = Mustache.render(tplemail.subject, data);
dat.html = Mustache.render(tplemail.subject, data);
dat.text = Mustache.render(tplemail.text, data);
dat.Cc = data.Cc ? tplemail.Cc.push(data.Cc) : tplemail.Cc;
dat.Bcc = data.Bcc ? tplemail.Bcc.push(data.Bcc) : tplemail.Bcc;
dat.attachments = tplemail.attachments.push(data.attachments);
const sendit = Notifications.sendmail(data, tribe);
if (i == 0) {
sendit = await Notifications.sendmail(data, tribe);
if (sendit.status != 200) return sendit;
} else {
Notifications.sendmail(data, tribe);
}
} else {
// not a well formated email
}
});
return sendit;
};
Notifications.sendmail = async (data, tribe) => {
/**
* See https://nodemailer.com/message/ for available fields to add
@ -264,8 +317,9 @@ Notifications.sendmail = async (data, tribe) => {
let missingfile = [];
data.filelist.forEach((fo) => {
if (fs.existsSync(fo.pathfile)) {
} else { missingfile.push(fo.pathfile); }
} else {
missingfile.push(fo.pathfile);
}
});
if (missingfile.lenght > 0)
return {

View File

@ -8,7 +8,6 @@ const isAuthenticated = require("../middlewares/isAuthenticated");
const router = express.Router();
/**
* wait Sagar feedback for language and label description
* @ api {post} /api/notifications/backend - Notification Backend post
@ -21,12 +20,10 @@ const router = express.Router();
* @apiBody {string} msg a key word existing in referentiual
* */
router.post("/backend", (req, res) => {
})
router.post("/backend", (req, res) => {});
/**
* @api {get} adminapi/notifications/:alias/:tribeId
* @api {get} adminapi/notifications/messages/:alias/:tribeId -Get message list for alias in tribe
* @apiName notiflist
* @apiDescription Get list of notifications for an alias and a tribe
* @apiGroup Notifications
@ -39,11 +36,49 @@ router.post("/backend", (req, res) => {
* {status:200,ref:"Notification",msg:"Messagelist",data:{notif:[{tribeId,msg:{from(email or uuid or alias):[{dt,msg}]}}]}
* bouture
**/
router.get("/:alias/:tribeId", (req, res) => {
router.get("/messages/:alias/:tribeId", (req, res) => {
const getnot = Notification.get(req.params.alias, req.params.tribeId);
res.status(getalias.status).send(getalias);
});
/**
* @api {POST} adminapi/notifications/sendmail/:tribe/:template -Send personnalize emails
* @apiName Sendmail
* @apiDescription Send personnalize email with data from template store in ../../{tribe}/template/{template}.json
* @apiGroup Notifications
*
* @apiParam {string} template
* @apiParam {string} tribe
* @apiBody {array} emails to send (array of valid email)
* @apiBody {object} Data to personnalize template
*
* @apiSuccess {object} notif content
* @apiSuccessExample {json} Success-Response:
* HTTP/1.1 200 OK
* {status:200,ref:"Notification",msg:"Messagelist",data:{notif:[{tribeId,msg:{from(email or uuid or alias):[{dt,msg}]}}]}
* bouture
*/
router.post(
"/sendmail/:tribe/:template/:await",
checkHeaders,
isAuthenticated,
(req, res) => {
const pathtpl = `../../${req.params.tribe}/${req.params.template}.js`;
if (fs.existsSync(pathtpl)) {
const sendemail = Notification.manageemail(req.body, pathtpl,req.params.tribe);
res.status(sendemail.status).send(sendemail);
} else {
res
.status(404)
.send({
status: 404,
ref: "Notification",
msg: "templatenotfound",
data: { pathtpl },
});
}
}
);
/**
* @api {POST} adminapi/notifications/registeranonymous/:tribe/:mlist/:typekey/:data -Register email||phone to mlist
@ -61,24 +96,34 @@ router.get("/:alias/:tribeId", (req, res) => {
* {"status":200, "ref":"Notifications", "msg":"registersuccess", "data":{data, typekey, tribe, mlist, srckey, uuid}}}
*
*/
router.post("/registeranonymous",checkHeaders,(req,res)=>{
router.post("/registeranonymous", checkHeaders, (req, res) => {
//console.log("list registration ",req.body)
if (!req.body.typekey || !['email','telephone'].includes(req.body.typekey) ){
return res.status(406).json({status:406,ref:"Notifications",msg:"typekeyunknown",data:{typekey:req.body.typekey}})
if (!req.body.typekey || !["email", "telephone"].includes(req.body.typekey)) {
return res
.status(406)
.json({
status: 406,
ref: "Notifications",
msg: "typekeyunknown",
data: { typekey: req.body.typekey },
});
}
const key= (req.body.contactpoint)?req.body.contactpoint:req.body[req.body.typekey];
result= Notifications.registertolist(
const key = req.body.contactpoint
? req.body.contactpoint
: req.body[req.body.typekey];
result = Notifications.registertolist(
key,
req.body.typekey,
req.body.tribe,
req.body.mlist,
req.body.srckey,
req.session.header.xuuid);
req.session.header.xuuid
);
res.status(result.status).json(result)
})
res.status(result.status).json(result);
});
/**
* @api {GET} adminapi/notifications/unregister/:tribe/:mlist/:typekey/:data/:validation -Unregister email o r phone from a mlist or all mlist
* @api {GET} adminapi/notifications/unregister/:tribe/:mlist/:typekey/:data/:validation -Unregister email or phone from a mlist or all mlist
* @apiName unregister
* @apiGroup Notifications
* @apiDescription Register an email into a mailinglist mlist
@ -95,16 +140,21 @@ router.post("/registeranonymous",checkHeaders,(req,res)=>{
*
*/
router.get("/unregister/:tribe/:mlist/:typekey/:srckey/:data/:validation", checkHeaders, (req, res) => {
Notifications.registertolist = (typekey, tribe, mlist, srckey, uuid)
result= Notifications.registertolist(
router.get(
"/unregister/:tribe/:mlist/:typekey/:srckey/:data/:validation",
checkHeaders,
(req, res) => {
Notifications.registertolist = (typekey, tribe, mlist, srckey, uuid);
result = Notifications.registertolist(
req.params.typekey,
req.params.tribe,
req.params.mlist,
req.params.srckey,
req.session.header.xuuid);
res.status(result.status).json(result)
})
req.session.header.xuuid
);
res.status(result.status).json(result);
}
);
/**
* @api {GET} adminapi/notifications/stat/maillinglst/:tribe --Statistic maillinglst
@ -140,13 +190,11 @@ router.get("/unregister/:tribe/:mlist/:typekey/:srckey/:data/:validation", check
*
*/
router.get("/stat/maillinglst/:tribe", checkHeaders, async (req, res) => {
console.log('passe là');
const resstat=Notifications.statmaillist(req.params.tribe)
console.log("passe là");
const resstat = Notifications.statmaillist(req.params.tribe);
res.status(resstat.status).json(resstat);
});
/**
* @api {POST} adminapi/notifications/contactanonymous/:tribe -Contact anonymous
* @apiName contactanonymous
@ -173,13 +221,18 @@ router.post("/contactanonymous", checkHeaders, async (req, res) => {
/**
* Same as /copntactanonymous but for authenticated user => data are updated in persons/itm/alias.json
*/
router.post("/contact/:tribe/:alias", checkHeaders, isAuthenticated, (req, res) => {
router.post(
"/contact/:tribe/:alias",
checkHeaders,
isAuthenticated,
(req, res) => {
const done = Actions[req.body.order]
? Actions[req.body.order](req.body, req.session.header)
: { status: 406, ref: "Actions", msg: "bodyerror", data: req.body };
console.log(req.body);
res.status(done.status).json(done);
});
}
);
router.get("/contact", checkHeaders, isAuthenticated, (req, res) => {
res.status(200).json({ data: {} });