From 53fad87b251b5efd8c2017324a6e53fa1b918ca2 Mon Sep 17 00:00:00 2001 From: philc Date: Wed, 7 Aug 2024 08:02:47 +0200 Subject: [PATCH] reindex auto on start --- apxtri.js | 58 ++++++++++++++++++++++++++++--------------------- models/Odmdb.js | 2 +- 2 files changed, 34 insertions(+), 26 deletions(-) diff --git a/apxtri.js b/apxtri.js index cdd3adc..8cd43d1 100755 --- a/apxtri.js +++ b/apxtri.js @@ -7,19 +7,20 @@ const path = require("path"); const cors = require("cors"); const express = require("express"); const process = require("process"); +const Odmdb = require("./models/Odmdb.js"); /******************************************* SEE README.md to have a quick start ********************************************/ if (!fs.existsSync("/etc/nginx/nginx.conf")) { - setupdone=false; - console.log( + setupdone = false; + console.log( "\x1b[31m Check documentation, nginx have to be installed on this server first, no /etc/nginx/nginx.conf available, install then rerun yarn command."); } if (!fs.existsSync("../../conf.json")) { console.log("Warning, this is a first install you must run 'node setup.js dns=domainename user=sudoerlinux'") - process.exit(); + process.exit(); } const conf = require(path.resolve(`../../conf.json`)); @@ -35,32 +36,39 @@ let tribeIds = Object.keys(tribelist); // context is store in /itm/tribename.json ={contexte:{routes:[],models:[{model:,tplstringslg:[]}]} // routes={url,route} check how to add plugin tribe route later // keep only the 2 last part (.) of domain name to validate cors with it (generic domain) -let routes=[] +let routes = [] tribeIds.forEach((t) => { tribelist[t].dns.forEach((d) => { const dm = d.split(".").slice(-2).join("."); if (!doms.includes(dm)) doms.push(dm); + //reindex database + if (t == "smatchit") { + glob.sync(`../../${t}/objects/*`).forEach(o => { + console.log(t, o) + Odmdb.runidx(o) + }) + } }); - const context={}; - const pathtr=path.resolve(`../../${t}`); - context.routes=[] - tribroutes=glob.sync(`${pathtr}/ap*/routes/*.js`).map(f=>{ - const rt=`/${t}/${path.basename(f, ".js")}` - context.routes.push(rt) - return { url: rt, route: f }; + const context = {}; + const pathtr = path.resolve(`../../${t}`); + context.routes = [] + tribroutes = glob.sync(`${pathtr}/ap*/routes/*.js`).map(f => { + const rt = `/${t}/${path.basename(f, ".js")}` + context.routes.push(rt) + return { url: rt, route: f }; }); - context.models=glob.sync(`${pathtr}/ap*/models/*.js`).map(f=>{ - const modname=`${path.basename(f, ".js")}` + context.models = glob.sync(`${pathtr}/ap*/models/*.js`).map(f => { + const modname = `${path.basename(f, ".js")}` return { - model: modname, - tplstrings:glob.sync(`${pathtr}/objects/tplstrings/${modname}_*.json`).map(l=>path.basename(l,'.json').split("_")[1] ) - } + model: modname, + tplstrings: glob.sync(`${pathtr}/objects/tplstrings/${modname}_*.json`).map(l => path.basename(l, '.json').split("_")[1]) + } }) - const conft=`../../itm/${t}.json` - const ctx=fs.readJsonSync(conft) - ctx.context=context - fs.outputJSONSync(conft,ctx,{spaces:2}); - routes=routes.concat(tribroutes); + const conft = `../../itm/${t}.json` + const ctx = fs.readJsonSync(conft) + ctx.context = context + fs.outputJSONSync(conft, ctx, { spaces: 2 }); + routes = routes.concat(tribroutes); }); const app = express(); // load express parameter from conf @@ -70,11 +78,11 @@ Object.keys(conf.api.appset).forEach((p) => { // To set depending of data form or get size to send app.use(bodyParser.urlencoded(conf.api.bodyparse.urlencoded)); // To set depending of post put json data size to send -app.use(express.json({limit:'10mb',type:'application/json',rawBody:true})); +app.use(express.json({ limit: '10mb', type: 'application/json', rawBody: true })); app.use(bodyParser.json(conf.api.bodyparse.json)); app.disable("x-powered-by"); // for security app.locals.tribeids = tribeIds; -if (log){ +if (log) { console.log( currentmod, " Allowed DOMs to access to this apxtri server:", @@ -82,7 +90,7 @@ if (log){ ); console.log(currentmod, " app.locals.tribeids", app.locals.tribeids); } - // Cors management +// Cors management let originlst = "test"; doms.forEach((d) => { originlst += `|${d.replace(/\./g, "\\.")}`; @@ -102,7 +110,7 @@ app.use((req, res, next) => { "request origin:", req.headers.origin, "testcors:", - cor, "headers allowed: [", conf.api.exposedHeaders.join(','),"] match with reg:", regtxt + cor, "headers allowed: [", conf.api.exposedHeaders.join(','), "] match with reg:", regtxt ); cors({ origin: cor, diff --git a/models/Odmdb.js b/models/Odmdb.js index 8e11f8a..e658566 100644 --- a/models/Odmdb.js +++ b/models/Odmdb.js @@ -900,7 +900,7 @@ Odmdb.runidx = (objectPathname, schema) => { }); Object.keys(ventil).forEach((n) => { //if (log) console.log(currentmod,`${objectPathname}/idx/${ventil[n].name}.json`) - fs.outputJSON( + fs.outputJSONSync( `${objectPathname}/idx/${ventil[n].name}.json`, ventil[n].data );