services.js 82 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668
  1. const express = require("express");
  2. const execSync = require('child_process').execSync;
  3. var parser = require('xml2json');
  4. const fs = require('fs');
  5. var cors = require('cors');
  6. const bodyParser = require("body-parser");
  7. var mysql = require('mysql2/promise');
  8. const bluebird = require('bluebird');
  9. const app = express();
  10. app.use(cors());
  11. const port = 3001;
  12. app.use(bodyParser.urlencoded({ extended: false }));
  13. app.use(bodyParser.json());
  14. let conf = {
  15. connectionLimit : 10,
  16. host : '127.0.0.1',
  17. user : 'ds',
  18. password : 'EmcoAdmin!',
  19. database : 'modeler',
  20. Promise: bluebird
  21. }
  22. const jsn = require("./base.json");
  23. const di = require("./di.json");
  24. const ia = require("./ia.json");
  25. const mach = require("./machinery.json");
  26. const mt = require("./mt.json");
  27. let ns_array = [];
  28. let nsray = [jsn, di, ia, mach, mt];
  29. /*nsray.push(jsn);
  30. nsray.push(di);
  31. nsray.push(ia);
  32. nsray.push(mach);
  33. nsray.push(mt);
  34. */
  35. let type_ar = ['datatypes', 'objecttypes', 'referencetypes', 'variabletypes'];
  36. let classes_ar = ['datatypes', 'objecttypes', 'referencetypes', 'variabletypes', 'objects', 'variables', 'methods'];
  37. let child_refs = ['Organizes','HasComponent','HasProperty','HasAddIn','HasSubtype'];
  38. /*
  39. async function gen_query(sql, params){
  40. const connection = await mysql.createConnection(conf);
  41. const [results, ] = await connection.execute(sql, params);
  42. //console.log(results);
  43. return results;
  44. }*/
  45. async function translateNid(nid, m){ //Uni -> local
  46. try{
  47. let obj = {
  48. idx: 0,
  49. ns: 0,
  50. ident: '0',
  51. combi: '',
  52. p1: '',
  53. p2:''
  54. }
  55. /*
  56. let obj = {
  57. ident_all:"",
  58. ident:"",
  59. ns_local: 0,
  60. combi_local: "",
  61. ns_old: 0,
  62. combi_old: "",
  63. ns_new: 0,
  64. combi_new: ""
  65. }*/
  66. if(nid.includes('ns=')){
  67. const nodeid = nid.split(";");
  68. obj.p1 = nodeid[0];
  69. obj.p2 = nodeid[1];
  70. const n1 = nodeid[0].split("=");
  71. obj.ns = parseInt(n1[1]);
  72. const n2 = nodeid[1].split("=");
  73. obj.ident = n2[1];
  74. var command = "SELECT nsurl FROM ns"+m+"depends WHERE nsindex='"+obj.ns+"';";
  75. var ret = await pool.query(command);
  76. command = "SELECT nsindex FROM namespaces WHERE nsurl='"+ret[0][0].nsurl+"';";
  77. ret = await pool.query(command);
  78. obj.idx = parseInt(ret[0][0].nsindex);
  79. obj.combi = "ns=1;"+nodeid[1];
  80. }else{
  81. const n1 = nid.split("=");
  82. obj.ident = n1[1];
  83. obj.combi = nid;
  84. obj.p2 = nid;
  85. }
  86. return obj;
  87. }catch(err){
  88. console.log(err);
  89. }
  90. }
  91. async function newNid(nid, i){ //Uni -> whatever is needed, global in i
  92. try{
  93. let obj = {
  94. ident_all:"",
  95. ident:"",
  96. ns: i,
  97. ns_local: 0,
  98. combi_local: "",
  99. ns_uni: 0,
  100. combi_uni: nid
  101. }
  102. if(nid.includes('ns=')){
  103. const nodeid = nid.split(";");
  104. obj.ident_all = nodeid[1];
  105. const n1 = nodeid[0].split("=");
  106. const n2 = nodeid[1].split("=");
  107. obj.ident = n2[1];
  108. obj.ns_uni = parseInt(n1[1]);
  109. var command = "SELECT nsurl FROM namespaces WHERE nsindex='"+n1[1]+"';";
  110. var ret = await pool.query(command);
  111. const ul = parseInt(ret[0][0].nsurl);
  112. command = "SELECT nsindex FROM ns"+i+"depends WHERE nsurl='"+ul+"';";
  113. ret = await pool.query(command);
  114. obj.ns_local = parseInt(ret[0][0].nsindex);
  115. obj.combi_local = "ns="+obj.ns_local+";"+obj.ident_all;
  116. }else{
  117. const n1 = nid.split("=");
  118. obj.ident = n1[1];
  119. obj.ident_all = nid;
  120. obj.combi_local = nid;
  121. obj.combi_uni = nid;
  122. }
  123. return obj;
  124. }catch(err){
  125. console.log(err);
  126. }
  127. }
  128. async function getUniNid(nid, m){ //local -> Uni
  129. try{
  130. let obj = {
  131. ident_all:"",
  132. ident:"",
  133. ns: parseInt(m),
  134. ns_local: 0,
  135. combi_local: nid,
  136. ns_uni: 0,
  137. combi_uni: ""
  138. }
  139. if(nid.includes('ns=')){
  140. const nodeid = nid.split(";");
  141. obj.ident_all = nodeid[1];
  142. const n1 = nodeid[0].split("=");
  143. obj.ns_local = parseInt(n1[1]);
  144. const n2 = nodeid[1].split("=");
  145. obj.ident = n2[1];
  146. var command = "SELECT nsurl FROM ns"+m+"depends WHERE nsindex='"+obj.ns_local+"';";
  147. var ret = await pool.query(command);
  148. command = "SELECT nsindex FROM namespaces WHERE nsurl='"+ret[0][0].nsurl+"';";
  149. ret = await pool.query(command);
  150. obj.ns_uni = parseInt(ret[0][0].nsindex);
  151. obj.combi_uni = "ns="+obj.ns_uni+";"+obj.ident_all;
  152. }else{
  153. const n1 = nid.split("=");
  154. obj.ident = n1[1];
  155. obj.ident_all = nid;
  156. obj.combi_uni = nid;
  157. }
  158. return obj;
  159. }catch(err){
  160. console.log(err);
  161. }
  162. }
  163. async function getLocalNid(nid, m){ // Uni -> local
  164. try{
  165. let obj = {
  166. ident_all:"",
  167. ident:"",
  168. ns: 0,
  169. ns_local: 1,
  170. combi_local: "",
  171. ns_uni: m,
  172. combi_uni: ""
  173. }
  174. if(nid.includes('ns=')){
  175. const nodeid = nid.split(";");
  176. obj.ident_all = nodeid[1];
  177. const n1 = nodeid[0].split("=");
  178. obj.ns = obj.ns_uni;
  179. const n2 = nodeid[1].split("=");
  180. obj.ident = n2[1];
  181. obj.combi_local = "ns=1;"+obj.ident_all;
  182. obj.combi_uni = "ns="+m+";"+obj.ident_all;
  183. }else{
  184. const n1 = nid.split("=");
  185. obj.ident = n1[1];
  186. obj.ident_all = nid;
  187. obj.combi_local = nid;
  188. }
  189. return obj;
  190. }catch(err){
  191. console.log(err);
  192. }
  193. }
  194. function database_connection() {
  195. pool = mysql.createPool(conf);
  196. pool.getConnection(function(err, connection) {
  197. if(err) {
  198. logger.error('[ERROR] Connecting to database "' + err.toString() + '"');
  199. setTimeout(function() { database_connection(); }, 2500);
  200. }
  201. else
  202. {
  203. pool.query('SET NAMES utf8');
  204. pool.query('SET CHARACTER SET utf8');
  205. logger.trace('[INFO] Connected to database and set utf8!');
  206. }
  207. })};
  208. database_connection();
  209. function inverse(dev){
  210. if("IsForward" in dev){
  211. if(dev.IsForward === "false"){
  212. return true;
  213. }else{
  214. return false;
  215. }
  216. }else{
  217. return false;
  218. }
  219. }
  220. function forward(dev){
  221. var b = true;
  222. if("IsForward" in dev){
  223. if(dev.IsForward === "false"){
  224. b = false;
  225. }
  226. }else{
  227. b = true;
  228. }
  229. return b;
  230. }
  231. function sortNS(files){
  232. let nsets = [];
  233. for(let x = 0; x<files.length; x++){
  234. if("RequiredModel" in files[x].UANodeSet.Models.Model){
  235. if(Array.isArray(files[x].UANodeSet.Models.Model.RequiredModel)){
  236. var len = files[x].UANodeSet.Models.Model.RequiredModel.length;
  237. for(let y = 0; y < len; y++){
  238. files[x].UANodeSet.Models.Model.RequiredModel[y]
  239. }
  240. }else{
  241. }
  242. }else{
  243. nsets.push(files[x].UANodeSet.Models.Model.ModelUri);
  244. }
  245. }
  246. }
  247. function get_Children(jsnob, nid, ret_obj){
  248. const entities = ['UAObjectType','UAObject','UAVariableType','UAVariable', 'UADataType', 'UAReferenceType', 'UAMethod'];
  249. const set = jsnob.UANodeSet;
  250. for(let y = 0; y< entities.length; y++){
  251. if(entities[y] in set){
  252. try{
  253. const entry = set[entities[y]];
  254. if(Array.isArray(entry)){
  255. for (let i = 0; i < entry.length;i++){
  256. if(Object.keys(entry[i].References).length === 0){
  257. }else{
  258. if(Array.isArray(entry[i].References.Reference)){
  259. for (let x = 0; x < entry[i].References.Reference.length;x++){
  260. if(entry[i].References.Reference[x].$t === nid){
  261. if(inverse(entry[i].References.Reference[x])){
  262. let zobj= overwriteNode(entry[i], nid, entities[y], getIndexArray(jsnob));
  263. if(!checkDouble(zobj,ret_obj)){
  264. ret_obj.push(zobj);
  265. }
  266. }
  267. }
  268. }
  269. }else{
  270. if(entry[i].References.Reference.$t === nid){
  271. if(inverse(entry[i].References.Reference)){
  272. let zobj= overwriteNode(entry[i], nid, entities[y], getIndexArray(jsnob));
  273. if(!checkDouble(zobj,ret_obj)){
  274. ret_obj.push(zobj);
  275. }
  276. }
  277. }
  278. }
  279. }
  280. }
  281. }else{
  282. if(Object.keys(entry.References).length === 0){
  283. }else{
  284. if(Array.isArray(entry.References.Reference)){
  285. for (let x = 0; x < entry.References.Reference.length;x++){
  286. if(entry.References.Reference[x].$t === nid){
  287. if(inverse(entry.References.Reference[x])){
  288. let zobj= overwriteNode(entry, nid, entities[y], getIndexArray(jsnob));
  289. if(!checkDouble(zobj,ret_obj)){
  290. ret_obj.push(zobj);
  291. }
  292. }
  293. }
  294. }
  295. }else{
  296. if(entry.References.Reference.$t === nid){
  297. if(inverse(entry.References.Reference)){
  298. let zobj= overwriteNode(entry, nid, entities[i], getIndexArray(jsnob));
  299. if(!checkDouble(zobj,ret_obj)){
  300. ret_obj.push(zobj);
  301. }
  302. }
  303. }
  304. }
  305. }
  306. }
  307. }catch(err){
  308. console.log(err);
  309. }
  310. }
  311. }
  312. }
  313. function getAllChildren(nid, ret_obj){
  314. for(let ix = 0; ix < ns_array.length; ix++){
  315. get_Children(ns_array[ix][0], nid, ret_obj);
  316. }
  317. }
  318. function getIndexObj(jsnob, ns){
  319. var uri = ns.UANodeSet.Models.Model.ModelUri;
  320. if(uri == "http://opcfoundation.org/UA/"){
  321. return 0;
  322. }
  323. console.log(uri);
  324. let uris = {};
  325. if(jsnob.UANodeSet.NamespaceUris != undefined){
  326. uris = jsnob.UANodeSet.NamespaceUris.Uri;
  327. console.log(uris);
  328. }else{
  329. return 0;
  330. }
  331. for(let i = 0; i < uris.length; i++){
  332. console.log(uris[i]);
  333. if(uris[i] == uri){
  334. return i+1;
  335. }
  336. }
  337. return undefined;
  338. }
  339. function getIndexName(jsnob, name){
  340. if(name == "http://opcfoundation.org/UA/"){
  341. return 0;
  342. }
  343. let uris = {};
  344. if(jsnob.UANodeSet.NamespaceUris != undefined){
  345. uris = jsnob.UANodeSet.NamespaceUris.Uri;
  346. }else{
  347. return 0;
  348. }
  349. for(let i = 0; i < uris.length; i++){
  350. if(uris[i] == name){
  351. return i+1;
  352. }
  353. }
  354. return undefined;
  355. }
  356. function getIndexArray(tobj){
  357. for(let i = 0; i < ns_array.length;i++){
  358. console.log(ns_array[i][1]);
  359. if(tobj.UANodeSet.Models.Model.ModelUri === ns_array[i][0].UANodeSet.Models.Model.ModelUri){
  360. return i;
  361. }
  362. }
  363. return undefined;
  364. }
  365. function getNode(jsnob, ns, id){
  366. let uris = {};
  367. var ns_uri = '';
  368. if(jsnob.UANodeSet.NamespaceUris){
  369. uris = jsnob.UANodeSet.NamespaceUris.Uri;
  370. ns_uri = uris[ns-1];
  371. }
  372. for(let i = 0; i < ns_array.length; i++){
  373. if(ns_array[i][0].UANodeSet.Models.Model.ModelUri == ns_uri){
  374. return i;
  375. }
  376. }
  377. return -1;
  378. }
  379. function overwriteNode(nobj, nid, nc, ns){
  380. var nclass = "";
  381. switch(nc){
  382. case "UAObjectType":
  383. case "UAObject":
  384. case "UAVariableType":
  385. case "UADataType":
  386. case "UAReferenceType": nclass = "Object"; break;
  387. case "UAVariable": nclass = "Variable"; break;
  388. case "UAMethod": nclass = "Method"; break;
  389. default: nclass = "Object";
  390. }
  391. const node = {
  392. id:nobj.NodeId,
  393. text:nobj.DisplayName,
  394. children: true,
  395. data:{
  396. browsename: nobj.BrowseName,
  397. namespace: ns,
  398. elementclass: nc,
  399. nodeclass: nclass,
  400. parentNode: nid,
  401. parentid: "ParentNodeId" in nobj ? nobj.ParentNodeId : null,
  402. description: "Description" in nobj ? nobj.Description : null,
  403. notifier: "EventNotifier" in nobj ? nobj.EventNotifier : null, //Object
  404. isabstract: "IsAbstract" in nobj ? nobj.IsAbstract : null, //ObjectType
  405. datatype: "DataType" in nobj ? nobj.DataType : null, //Variable
  406. value: "Value" in nobj ? nobj.Value : null, //Variable
  407. arraydimensions: "ArrayDimensions" in nobj ? nobj.ArrayDimensions : null, //Variable
  408. references: "References" in nobj ? nobj.References : null
  409. }
  410. }
  411. return node;
  412. }
  413. function searchNode(id){
  414. const entities = ['UAObjectType','UAObject','UAVariableType','UAVariable', 'UADataType', 'UAReferenceType', 'UAMethod']; //7
  415. var nid = "";
  416. var jsnob = {};
  417. if(id.includes("ns=")){
  418. var ns = id.substring(id.length - 4);
  419. const ns1 = ns.split(";");
  420. var nsidx = parseInt(ns1[0]);
  421. jsnob = ns_array[nsidx][0];
  422. }else{
  423. nid = id;
  424. jsnob = ns_array[0][0];
  425. }
  426. const set = jsnob.UANodeSet;
  427. for(let i = 0; i< entities.length; i++){
  428. if(entities[i] in set){
  429. console.log(set.Models.Model.ModelUri+" has a "+entities[i]);
  430. if(Array.isArray(set[entities[i]])){
  431. for(let x = 0; x < set[entities[i]].length;x++){
  432. if(set[entities[i]][x].NodeId === nid){
  433. let nobj = set[entities[i]][x];
  434. const node = overwriteNode(nobj, null, entities[i], getIndexArray(jsnob));
  435. return node;
  436. }
  437. }
  438. }
  439. }
  440. }
  441. return null;
  442. }
  443. function p2json(name, shorty){
  444. try{
  445. const nn = name+".xml";
  446. var nnn = shorty+".json";
  447. fs.readFile( nn, function(err, data){
  448. //fs.readFile( "Opc.Ua.NodeSet2.xml", function(err, data){
  449. let jsn = parser.toJson(data);
  450. fs.writeFileSync(nnn, jsn);
  451. });
  452. }catch(err){
  453. console.log('not work');}
  454. }
  455. /*
  456. function listObjType(){
  457. var keys = [];
  458. console.log("ObjectTypes:");
  459. let obj = jsn.UANodeSet.UAObjectType; //base
  460. var sz = obj.length;
  461. console.log(sz);
  462. for(let i = 0; i < sz; i++){
  463. let arr = Object.keys(obj[i]);
  464. for(let x = 0; x < arr.length; x++){
  465. if(!keys.includes(arr[x])){
  466. keys.push(arr[x]);
  467. }
  468. }
  469. }
  470. obj = di.UANodeSet.UAObjectType; //base
  471. sz = obj.length;
  472. console.log(sz);
  473. for(let i = 0; i < sz; i++){
  474. let arr = Object.keys(obj[i]);
  475. for(let x = 0; x < arr.length; x++){
  476. if(!keys.includes(arr[x])){
  477. keys.push(arr[x]);
  478. }
  479. }
  480. }
  481. obj = ia.UANodeSet.UAObjectType; //base
  482. sz = obj.length;
  483. console.log(sz);
  484. for(let i = 0; i < sz; i++){
  485. let arr = Object.keys(obj[i]);
  486. for(let x = 0; x < arr.length; x++){
  487. if(!keys.includes(arr[x])){
  488. keys.push(arr[x]);
  489. }
  490. }
  491. }
  492. obj = mach.UANodeSet.UAObjectType; //base
  493. sz = obj.length;
  494. console.log(sz);
  495. for(let i = 0; i < sz; i++){
  496. let arr = Object.keys(obj[i]);
  497. for(let x = 0; x < arr.length; x++){
  498. if(!keys.includes(arr[x])){
  499. keys.push(arr[x]);
  500. }
  501. }
  502. }
  503. obj = mt.UANodeSet.UAObjectType; //base
  504. sz = obj.length;
  505. console.log(sz);
  506. for(let i = 0; i < sz; i++){
  507. let arr = Object.keys(obj[i]);
  508. for(let x = 0; x < arr.length; x++){
  509. if(!keys.includes(arr[x])){
  510. keys.push(arr[x]);
  511. }
  512. }
  513. }
  514. console.log(keys);
  515. }
  516. listObjType();
  517. function listObj(){
  518. var keys = [];
  519. console.log("Objects:");
  520. let obj = jsn.UANodeSet.UAObject; //base
  521. var sz = obj.length;
  522. console.log(sz);
  523. for(let i = 0; i < sz; i++){
  524. let arr = Object.keys(obj[i]);
  525. for(let x = 0; x < arr.length; x++){
  526. if(!keys.includes(arr[x])){
  527. keys.push(arr[x]);
  528. }
  529. }
  530. }
  531. obj = di.UANodeSet.UAObject; //base
  532. sz = obj.length;
  533. console.log(sz);
  534. for(let i = 0; i < sz; i++){
  535. let arr = Object.keys(obj[i]);
  536. for(let x = 0; x < arr.length; x++){
  537. if(!keys.includes(arr[x])){
  538. keys.push(arr[x]);
  539. }
  540. }
  541. }
  542. obj = ia.UANodeSet.UAObject; //base
  543. sz = obj.length;
  544. console.log(sz);
  545. for(let i = 0; i < sz; i++){
  546. let arr = Object.keys(obj[i]);
  547. for(let x = 0; x < arr.length; x++){
  548. if(!keys.includes(arr[x])){
  549. keys.push(arr[x]);
  550. }
  551. }
  552. }
  553. obj = mach.UANodeSet.UAObject; //base
  554. sz = obj.length;
  555. console.log(sz);
  556. for(let i = 0; i < sz; i++){
  557. let arr = Object.keys(obj[i]);
  558. for(let x = 0; x < arr.length; x++){
  559. if(!keys.includes(arr[x])){
  560. keys.push(arr[x]);
  561. }
  562. }
  563. }
  564. obj = mt.UANodeSet.UAObject; //base
  565. sz = obj.length;
  566. console.log(sz);
  567. for(let i = 0; i < sz; i++){
  568. let arr = Object.keys(obj[i]);
  569. for(let x = 0; x < arr.length; x++){
  570. if(!keys.includes(arr[x])){
  571. keys.push(arr[x]);
  572. }
  573. }
  574. }
  575. console.log(keys);
  576. }
  577. listObj();
  578. function listVar(){
  579. var keys = [];
  580. console.log("Variables:");
  581. let obj = jsn.UANodeSet.UAVariable; //base
  582. var sz = obj.length;
  583. console.log(sz);
  584. for(let i = 0; i < sz; i++){
  585. let arr = Object.keys(obj[i]);
  586. for(let x = 0; x < arr.length; x++){
  587. if(!keys.includes(arr[x])){
  588. keys.push(arr[x]);
  589. }
  590. }
  591. }
  592. obj = di.UANodeSet.UAVariable; //base
  593. sz = obj.length;
  594. console.log(sz);
  595. for(let i = 0; i < sz; i++){
  596. let arr = Object.keys(obj[i]);
  597. for(let x = 0; x < arr.length; x++){
  598. if(!keys.includes(arr[x])){
  599. keys.push(arr[x]);
  600. }
  601. }
  602. }
  603. obj = ia.UANodeSet.UAVariable; //base
  604. sz = obj.length;
  605. console.log(sz);
  606. for(let i = 0; i < sz; i++){
  607. let arr = Object.keys(obj[i]);
  608. for(let x = 0; x < arr.length; x++){
  609. if(!keys.includes(arr[x])){
  610. keys.push(arr[x]);
  611. }
  612. }
  613. }
  614. obj = mach.UANodeSet.UAVariable; //base
  615. sz = obj.length;
  616. console.log(sz);
  617. for(let i = 0; i < sz; i++){
  618. let arr = Object.keys(obj[i]);
  619. for(let x = 0; x < arr.length; x++){
  620. if(!keys.includes(arr[x])){
  621. keys.push(arr[x]);
  622. }
  623. }
  624. }
  625. obj = mt.UANodeSet.UAVariable; //base
  626. sz = obj.length;
  627. console.log(sz);
  628. for(let i = 0; i < sz; i++){
  629. let arr = Object.keys(obj[i]);
  630. for(let x = 0; x < arr.length; x++){
  631. if(!keys.includes(arr[x])){
  632. keys.push(arr[x]);
  633. }
  634. }
  635. }
  636. console.log(keys);
  637. }
  638. listVar();
  639. function listVarTypes(){
  640. var keys = [];
  641. console.log("VariableTypes:");
  642. let obj = jsn.UANodeSet.UAVariableType; //base
  643. var sz = obj.length;
  644. console.log(sz);
  645. for(let i = 0; i < sz; i++){
  646. let arr = Object.keys(obj[i]);
  647. for(let x = 0; x < arr.length; x++){
  648. if(!keys.includes(arr[x])){
  649. keys.push(arr[x]);
  650. }
  651. }
  652. }
  653. obj = di.UANodeSet.UAVariableType; //base
  654. sz = obj.length;
  655. console.log(sz);
  656. for(let i = 0; i < sz; i++){
  657. let arr = Object.keys(obj[i]);
  658. for(let x = 0; x < arr.length; x++){
  659. if(!keys.includes(arr[x])){
  660. keys.push(arr[x]);
  661. }
  662. }
  663. }
  664. obj = ia.UANodeSet.UAVariableType; //base
  665. sz = obj.length;
  666. console.log(sz);
  667. for(let i = 0; i < sz; i++){
  668. let arr = Object.keys(obj[i]);
  669. for(let x = 0; x < arr.length; x++){
  670. if(!keys.includes(arr[x])){
  671. keys.push(arr[x]);
  672. }
  673. }
  674. }
  675. obj = mach.UANodeSet.UAVariableType; //base
  676. if(obj !== undefined){
  677. if(Array.isArray(obj)){
  678. sz = obj.length;
  679. console.log(sz);
  680. for(let i = 0; i < sz; i++){
  681. let arr = Object.keys(obj[i]);
  682. for(let x = 0; x < arr.length; x++){
  683. if(!keys.includes(arr[x])){
  684. keys.push(arr[x]);
  685. }
  686. }
  687. }}else{
  688. let arr = Object.keys(obj);
  689. for(let x = 0; x < arr.length; x++){
  690. if(!keys.includes(arr[x])){
  691. keys.push(arr[x]);
  692. }
  693. }
  694. }
  695. }
  696. obj = mt.UANodeSet.UAVariableType; //base
  697. sz = obj.length;
  698. console.log(sz);
  699. for(let i = 0; i < sz; i++){
  700. let arr = Object.keys(obj[i]);
  701. for(let x = 0; x < arr.length; x++){
  702. if(!keys.includes(arr[x])){
  703. keys.push(arr[x]);
  704. }
  705. }
  706. }
  707. console.log(keys);
  708. }
  709. listVarTypes();
  710. function listMethod(){
  711. var keys = [];
  712. console.log("Methods:");
  713. let obj = jsn.UANodeSet.UAMethod; //base
  714. var sz = obj.length;
  715. console.log(sz);
  716. for(let i = 0; i < sz; i++){
  717. let arr = Object.keys(obj[i]);
  718. for(let x = 0; x < arr.length; x++){
  719. if(!keys.includes(arr[x])){
  720. keys.push(arr[x]);
  721. }
  722. }
  723. }
  724. obj = di.UANodeSet.UAMethod; //base
  725. sz = obj.length;
  726. console.log(sz);
  727. for(let i = 0; i < sz; i++){
  728. let arr = Object.keys(obj[i]);
  729. for(let x = 0; x < arr.length; x++){
  730. if(!keys.includes(arr[x])){
  731. keys.push(arr[x]);
  732. }
  733. }
  734. }
  735. obj = ia.UANodeSet.UAMethod; //base
  736. sz = obj.length;
  737. console.log(sz);
  738. for(let i = 0; i < sz; i++){
  739. let arr = Object.keys(obj[i]);
  740. for(let x = 0; x < arr.length; x++){
  741. if(!keys.includes(arr[x])){
  742. keys.push(arr[x]);
  743. }
  744. }
  745. }
  746. obj = mach.UANodeSet.UAMethod; //base
  747. if(obj !== undefined){
  748. if(Array.isArray(obj)){
  749. sz = obj.length;
  750. console.log(sz);
  751. for(let i = 0; i < sz; i++){
  752. let arr = Object.keys(obj[i]);
  753. for(let x = 0; x < arr.length; x++){
  754. if(!keys.includes(arr[x])){
  755. keys.push(arr[x]);
  756. }
  757. }
  758. }}else{
  759. let arr = Object.keys(obj);
  760. for(let x = 0; x < arr.length; x++){
  761. if(!keys.includes(arr[x])){
  762. keys.push(arr[x]);
  763. }
  764. }
  765. }}
  766. obj = mt.UANodeSet.UAMethod; //base
  767. if(obj !== undefined){
  768. if(Array.isArray(obj)){
  769. sz = obj.length;
  770. console.log(sz);
  771. for(let i = 0; i < sz; i++){
  772. let arr = Object.keys(obj[i]);
  773. for(let x = 0; x < arr.length; x++){
  774. if(!keys.includes(arr[x])){
  775. keys.push(arr[x]);
  776. }
  777. }
  778. }}else{
  779. let arr = Object.keys(obj);
  780. for(let x = 0; x < arr.length; x++){
  781. if(!keys.includes(arr[x])){
  782. keys.push(arr[x]);
  783. }
  784. }
  785. }}
  786. console.log(keys);
  787. }
  788. listMethod();
  789. function listDataType(){
  790. var keys = [];
  791. console.log("DataType:");
  792. let obj = jsn.UANodeSet.UADataType; //base
  793. var sz = obj.length;
  794. console.log(sz);
  795. for(let i = 0; i < sz; i++){
  796. let arr = Object.keys(obj[i]);
  797. for(let x = 0; x < arr.length; x++){
  798. if(!keys.includes(arr[x])){
  799. keys.push(arr[x]);
  800. }
  801. }
  802. }
  803. obj = di.UANodeSet.UADataType; //base
  804. sz = obj.length;
  805. console.log(sz);
  806. for(let i = 0; i < sz; i++){
  807. let arr = Object.keys(obj[i]);
  808. for(let x = 0; x < arr.length; x++){
  809. if(!keys.includes(arr[x])){
  810. keys.push(arr[x]);
  811. }
  812. }
  813. }
  814. obj = ia.UANodeSet.UADataType; //base
  815. sz = obj.length;
  816. console.log(sz);
  817. for(let i = 0; i < sz; i++){
  818. let arr = Object.keys(obj[i]);
  819. for(let x = 0; x < arr.length; x++){
  820. if(!keys.includes(arr[x])){
  821. keys.push(arr[x]);
  822. }
  823. }
  824. }
  825. obj = mach.UANodeSet.UADataType; //base
  826. if(obj !== undefined){
  827. if(Array.isArray(obj)){
  828. sz = obj.length;
  829. console.log(sz);
  830. for(let i = 0; i < sz; i++){
  831. let arr = Object.keys(obj[i]);
  832. for(let x = 0; x < arr.length; x++){
  833. if(!keys.includes(arr[x])){
  834. keys.push(arr[x]);
  835. }
  836. }
  837. }}else{
  838. let arr = Object.keys(obj);
  839. for(let x = 0; x < arr.length; x++){
  840. if(!keys.includes(arr[x])){
  841. keys.push(arr[x]);
  842. }
  843. }
  844. }}
  845. obj = mt.UANodeSet.UADataType; //base
  846. sz = obj.length;
  847. console.log(sz);
  848. for(let i = 0; i < sz; i++){
  849. let arr = Object.keys(obj[i]);
  850. for(let x = 0; x < arr.length; x++){
  851. if(!keys.includes(arr[x])){
  852. keys.push(arr[x]);
  853. }
  854. }
  855. }
  856. console.log(keys);
  857. }
  858. listDataType();
  859. function listRefType(){
  860. var keys = [];
  861. console.log("ReferenceTypes:");
  862. let obj = jsn.UANodeSet.UAReferenceType; //base
  863. var sz = obj.length;
  864. console.log(sz);
  865. for(let i = 0; i < sz; i++){
  866. let arr = Object.keys(obj[i]);
  867. for(let x = 0; x < arr.length; x++){
  868. if(!keys.includes(arr[x])){
  869. keys.push(arr[x]);
  870. }
  871. }
  872. }
  873. obj = di.UANodeSet.UAReferenceType; //base
  874. sz = obj.length;
  875. console.log(sz);
  876. for(let i = 0; i < sz; i++){
  877. let arr = Object.keys(obj[i]);
  878. for(let x = 0; x < arr.length; x++){
  879. if(!keys.includes(arr[x])){
  880. keys.push(arr[x]);
  881. }
  882. }
  883. }
  884. obj = ia.UANodeSet.UAReferenceType; //base
  885. sz = obj.length;
  886. console.log(sz);
  887. for(let i = 0; i < sz; i++){
  888. let arr = Object.keys(obj[i]);
  889. for(let x = 0; x < arr.length; x++){
  890. if(!keys.includes(arr[x])){
  891. keys.push(arr[x]);
  892. }
  893. }
  894. }
  895. obj = mach.UANodeSet.UAReferenceType; //base
  896. if(obj !== undefined){
  897. if(Array.isArray(obj)){
  898. sz = obj.length;
  899. console.log(sz);
  900. for(let i = 0; i < sz; i++){
  901. let arr = Object.keys(obj[i]);
  902. for(let x = 0; x < arr.length; x++){
  903. if(!keys.includes(arr[x])){
  904. keys.push(arr[x]);
  905. }
  906. }
  907. }}else{
  908. let arr = Object.keys(obj);
  909. for(let x = 0; x < arr.length; x++){
  910. if(!keys.includes(arr[x])){
  911. keys.push(arr[x]);
  912. }
  913. }
  914. }}
  915. obj = mt.UANodeSet.UAReferenceType; //base
  916. if(obj !== undefined){
  917. if(Array.isArray(obj)){
  918. sz = obj.length;
  919. console.log(sz);
  920. for(let i = 0; i < sz; i++){
  921. let arr = Object.keys(obj[i]);
  922. for(let x = 0; x < arr.length; x++){
  923. if(!keys.includes(arr[x])){
  924. keys.push(arr[x]);
  925. }
  926. }
  927. }}else{
  928. let arr = Object.keys(obj);
  929. for(let x = 0; x < arr.length; x++){
  930. if(!keys.includes(arr[x])){
  931. keys.push(arr[x]);
  932. }
  933. }
  934. }}
  935. console.log(keys);
  936. }
  937. listRefType();
  938. */
  939. let arref = [];
  940. async function getThisNodeAttribute(ix, nid, classname, attr){
  941. try{
  942. var res = "";
  943. //0/i=84/UAObject
  944. var nnid = await getLocalNid(nid);
  945. var command = "SELECT * FROM ns"+ix+""+classname+" WHERE nodeid='"+nnid.combi_local+"';";
  946. var ret = await pool.query(command);
  947. if(ret[0].length !== 0){
  948. res = ret[0][0][attr];
  949. return res;
  950. }
  951. return res;
  952. }catch(err){
  953. console.log(err);
  954. }
  955. }
  956. async function getThisNode(ix, nid, classname){
  957. try{
  958. var res = "";
  959. var nnid = await getLocalNid(nid, ix);
  960. var command = "SELECT * FROM ns"+nnid.ns_uni+""+classname+" WHERE nodeid='"+nnid.combi_local+"';";
  961. var ret = await pool.query(command);
  962. var resp = ret[0][0];
  963. var flag_ch = true;
  964. /*var val1 = await getChildrenSql(ix, nid);
  965. if(val1.length == 0){
  966. flag_ch = false;
  967. }
  968. */
  969. if(ret[0].length !== 0){
  970. var l = await getUniNid(resp.nodeid, nnid.ns_uni);
  971. obj0 = {
  972. id: l.combi_uni,
  973. text: resp.name,
  974. data: ret[0][0],
  975. children: flag_ch
  976. };
  977. obj0.data.nsindex = l.ns_uni;
  978. res = obj0;
  979. return res;
  980. }
  981. return res;
  982. }catch(err){
  983. console.log(err);
  984. }
  985. }
  986. async function getChildrenSql(ix, nid){ //Uni nodeid -> 4/ns=4;i=131
  987. try{
  988. let res = [];
  989. for(let i = ix; i < nsray.length; i++){
  990. var obj = await newNid(nid, i);
  991. var command = "SELECT nodeidorigin FROM ns"+i+"references WHERE target='"+obj.combi_local+"' AND isforward='false';";
  992. var ret = await pool.query(command);
  993. const iterator = ret[0].values();
  994. for (const value of iterator) {
  995. var bb = await getUniNid(value.nodeidorigin, i)
  996. var nc = "";
  997. for(let j = 0; j < classes_ar.length; j++){
  998. if(bb.ns_uni !== 0){
  999. command = "SELECT nodeclass FROM ns"+bb.ns_uni+""+classes_ar[j]+" WHERE nodeid='ns=1;"+bb.ident_all+"';";
  1000. ret = await pool.query(command);
  1001. if(ret[0].length !== 0){
  1002. nc = ret[0][0].nodeclass;
  1003. res.push([bb.combi_uni, bb.ns_uni, nc]);
  1004. }
  1005. }else{
  1006. command = "SELECT nodeclass FROM ns0"+classes_ar[j]+" WHERE nodeid='"+bb.ident_all+"';";
  1007. ret = await pool.query(command);
  1008. if(ret[0].length !== 0){
  1009. nc = ret[0][0].nodeclass;
  1010. res.push([bb.combi_uni, bb.ns_uni, nc]);
  1011. }
  1012. }
  1013. }
  1014. }
  1015. //}
  1016. }
  1017. return res;
  1018. }catch(err){
  1019. console.log(err);
  1020. }
  1021. }
  1022. async function checkRefs(obj, nsix, url){
  1023. try{
  1024. var nid = obj.NodeId;
  1025. var idx1 = 0;
  1026. if(nid.includes('ns=')){
  1027. var iy = nid.indexOf(';');
  1028. var ns = nid.substring(3,iy);
  1029. idx1 = parseInt(ns);
  1030. }
  1031. // 1 oder 0
  1032. // nsix = index bei den nodesets
  1033. var ret = {};
  1034. if(obj['References']){
  1035. let refs = obj.References.Reference;
  1036. if(Array.isArray(refs)){
  1037. for(let i = 0; i < refs.length; i++){
  1038. var elem = refs[i];
  1039. var nid_t = "";
  1040. if(nid.includes('i=')){
  1041. nid_t = 'Numeric';
  1042. }else if(nid.includes('s=')){
  1043. nid_t = 'String';
  1044. }
  1045. var nst = 0;
  1046. var target = "";
  1047. var t_new = "";
  1048. if(elem['$t']){
  1049. target = elem['$t'];
  1050. t_new = await translateNid(target, nsix);
  1051. nst = t_new.idx || 0;
  1052. }
  1053. var command = "INSERT INTO ns"+nsix+"references(nodeidorigin, nodeidtype, nsindex, nsurl, referencetype, isforward, target, ns_target) VALUES ('"+nid+"', '"+nid_t+"', '"+idx1+"', '"+url+"', '"+elem['ReferenceType']+"', '"+elem['IsForward']+"', '"+target+"', '"+nst+"');";
  1054. var ret = await pool.query(command);
  1055. }
  1056. }else{
  1057. var elem = refs;
  1058. var nid_t = "";
  1059. if(nid.includes('i=')){
  1060. nid_t = 'Numeric';
  1061. }else if(nid.includes('s=')){
  1062. nid_t = 'String';
  1063. }
  1064. var nst = 0;
  1065. var target = "";
  1066. var t_new = "";
  1067. if(elem['$t']){
  1068. target = elem['$t'];
  1069. t_new = await translateNid(target, nsix);
  1070. nst = t_new.idx || 0;
  1071. }
  1072. var command = "INSERT INTO ns"+nsix+"references(nodeidorigin, nodeidtype, nsindex, nsurl, referencetype, isforward, target, ns_target) VALUES ('"+nid+"', '"+nid_t+"', '"+idx1+"', '"+url+"', '"+elem['ReferenceType']+"', '"+elem['IsForward']+"', '"+target+"', '"+nst+"');";
  1073. var ret = await pool.query(command);
  1074. }
  1075. }
  1076. }catch(err){
  1077. console.log(err);
  1078. }
  1079. }
  1080. async function getTypeDef(nid, ix){
  1081. try{
  1082. let obj = await translateNid(nid, ix);
  1083. for(let z = 0; z < type_ar.length; z++){
  1084. var command = "SELECT name FROM ns"+obj.idx+""+type_ar[z]+" WHERE nodeid='"+obj.combi+"';";
  1085. var ret = await pool.query(command);
  1086. console.log(ret[0][0]);
  1087. if(ret[0].length === 0){
  1088. }else{
  1089. return ret[0][0].name;
  1090. }
  1091. }
  1092. return "?";
  1093. }catch(err){
  1094. console.log(err);
  1095. }
  1096. }
  1097. async function getDataType(nid, ix){
  1098. try{
  1099. var obj = await translateNid(nid, ix);
  1100. console.log(obj);
  1101. var command = "SELECT name FROM ns"+obj.idx+"datatypes WHERE nodeid='"+obj.combi+"';";
  1102. console.log(command);
  1103. var ret = await pool.query(command);
  1104. return ret[0][0].name;
  1105. }catch(err){
  1106. console.log(err);
  1107. }
  1108. }
  1109. async function getParentRef(entry, ix){
  1110. try{
  1111. let pnode = {
  1112. pnid: "",
  1113. pref: "",
  1114. pinv: "false"
  1115. }
  1116. if(entry['ParentNodeId']){
  1117. pnode.pnid = entry['ParentNodeId'];
  1118. }
  1119. if(entry['References']){
  1120. let refs = entry.References.Reference;
  1121. if(Array.isArray(refs)){
  1122. for(let d = 0; d < refs.length; d++){
  1123. var command = "SELECT DISTINCT target,referencetype FROM ns"+ix+"references WHERE nodeidorigin='"+entry['NodeId']+"' AND referencetype='"+refs[d]['ReferenceType']+"' AND isforward LIKE 'fal%';";
  1124. var ret = await pool.query(command);
  1125. if(ret[0].length === 0){
  1126. continue;
  1127. }else{
  1128. if(pnode.pnid === ret[0][0].target){
  1129. pnode.pref = ret[0][0].referencetype;
  1130. pnode.pinv = "false";
  1131. console.log(ret);
  1132. }else{
  1133. pnode.pnid = ret[0][0].target;
  1134. pnode.pref = ret[0][0].referencetype;
  1135. pnode.pinv = "true";
  1136. }
  1137. }
  1138. }
  1139. }else{
  1140. var command = "SELECT DISTINCT target,referencetype FROM ns"+ix+"references WHERE nodeidorigin='"+entry['NodeId']+"' AND referencetype='"+refs['ReferenceType']+"' AND isforward LIKE 'fal%';";
  1141. var ret = await pool.query(command);
  1142. if(ret[0].length === 0){
  1143. }else{
  1144. if(pnode.pnid === ret[0][0].target){
  1145. pnode.pref = ret[0][0].referencetype;
  1146. pnode.pinv = "false";
  1147. }else{
  1148. pnode.pnid = ret[0][0].target;
  1149. pnode.pref = ret[0][0].referencetype;
  1150. pnode.pinv = "true";
  1151. }
  1152. }
  1153. }
  1154. }
  1155. return pnode;
  1156. }catch(err){
  1157. console.log(err);
  1158. }
  1159. }
  1160. async function createNamespace(m){
  1161. try{
  1162. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"objects(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'Object', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), eventnotifier INT DEFAULT NULL, typedefinition VARCHAR(300) NOT NULL, parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1163. var ret = await pool.query(command);
  1164. command = "CREATE TABLE IF NOT EXISTS ns"+m+"objecttypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'ObjectType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), isabstract VARCHAR(10), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), comment VARCHAR(300), documentation VARCHAR(300), PRIMARY KEY(id));";
  1165. ret = await pool.query(command);
  1166. command = "CREATE TABLE IF NOT EXISTS ns"+m+"variables(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'Variable', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), modellingrule VARCHAR(100) DEFAULT 'Optional', datatype VARCHAR(300) NOT NULL, typedefinition VARCHAR(300) NOT NULL, value VARCHAR(500) DEFAULT NULL, valuerank INT DEFAULT NULL, arraydimensions INT, accesslevel INT DEFAULT NULL, accesslevelex INT DEFAULT NULL, historizing VARCHAR(10), minsamplinginterval INT DEFAULT 500, releasestatus VARCHAR(300), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1167. ret = await pool.query(command);
  1168. command = "CREATE TABLE IF NOT EXISTS ns"+m+"variabletypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'VariableType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), datatype VARCHAR(300) NOT NULL, value VARCHAR(500) DEFAULT NULL, valuerank INT DEFAULT NULL, arraydimensions INT, isabstract VARCHAR(10), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1169. ret = await pool.query(command);
  1170. command = "CREATE TABLE IF NOT EXISTS ns"+m+"methods(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'Method', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), modellingrule VARCHAR(100) DEFAULT 'Optional', executable INT DEFAULT 1, parentreference VARCHAR(300), parentid VARCHAR(300) DEFAULT '#', methoddeclarationid VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1171. ret = await pool.query(command);
  1172. command = "CREATE TABLE IF NOT EXISTS ns"+m+"datatypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'DataType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), isabstract VARCHAR(10), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), definition VARCHAR(300), releasestatus VARCHAR(300), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1173. ret = await pool.query(command);
  1174. command = "CREATE TABLE IF NOT EXISTS ns"+m+"referencetypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, inversename VARCHAR(300), symmetric VARCHAR(10) DEFAULT 'TBD', nodeclass VARCHAR(50) DEFAULT 'ReferenceType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), isabstract VARCHAR(10) DEFAULT 'TBD', parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1175. ret = await pool.query(command);
  1176. command = "CREATE TABLE IF NOT EXISTS ns"+m+"references(id INT AUTO_INCREMENT, nodeidorigin VARCHAR(300) NOT NULL, nodeidtype VARCHAR(100) NOT NULL, nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', referencetype VARCHAR(100) NOT NULL, isforward VARCHAR(10) DEFAULT 'true', target VARCHAR(300), t_nidt VARCHAR(100), ns_target INT DEFAULT NULL, comment VARCHAR(300), PRIMARY KEY(id));";
  1177. ret = await pool.query(command);
  1178. }catch(err){
  1179. console.log(err);
  1180. }
  1181. }
  1182. async function createObj(m){
  1183. try{
  1184. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"objects(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'Object', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), eventnotifier INT DEFAULT NULL, typedefinition VARCHAR(300) NOT NULL, parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1185. var ret = await pool.query(command);
  1186. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1187. let obj = nsray[m].UANodeSet.UAObject;
  1188. if(nsray[m].UANodeSet.UAObject){
  1189. if(Array.isArray(obj)){
  1190. var sz = obj.length;
  1191. for(let i = 0; i < sz; i++){
  1192. var entry = obj[i];
  1193. var nid = entry['NodeId'];
  1194. await checkRefs(entry, m, url);
  1195. var idx = 0;
  1196. if(nid.includes('ns=')){
  1197. var ix = nid.indexOf(';');
  1198. var ns = nid.substring(3,ix);
  1199. idx = parseInt(ns);
  1200. }
  1201. var nid_t = "";
  1202. if(nid.includes('i=')){
  1203. nid_t = 'Numeric';
  1204. }else if(nid.includes('s=')){
  1205. nid_t = 'String';
  1206. }
  1207. var eventnot = 0;
  1208. if(entry['EventNotifier']){
  1209. eventnot = parseInt(entry['EventNotifier']);
  1210. }
  1211. var tt = await getTypeDef(entry['NodeId'], m);
  1212. let pnode = await getParentRef(entry, m);
  1213. command = "INSERT INTO ns"+m+"objects(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, typedefinition, description, eventnotifier, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+tt+"','"+entry['Description']+"', '"+eventnot+"', '"+entry['Documentation']+"');";
  1214. ret = pool.query(command);
  1215. }
  1216. }else{
  1217. var entry = obj;
  1218. var nid = entry['NodeId'];
  1219. var idx = 0;
  1220. await checkRefs(entry, m, url);
  1221. if(nid.includes('ns=')){
  1222. var ix = nid.indexOf(';');
  1223. var ns = nid.substring(3,ix);
  1224. idx = parseInt(ns);
  1225. }
  1226. var nid_t = "";
  1227. if(nid.includes('i=')){
  1228. nid_t = 'Numeric';
  1229. }else if(nid.includes('s=')){
  1230. nid_t = 'String';
  1231. }
  1232. var eventnot = 0;
  1233. if(entry['EventNotifier']){
  1234. eventnot = parseInt(entry['EventNotifier']);
  1235. }
  1236. var tt = await getTypeDef(entry['NodeId'], m);
  1237. let pnode = await getParentRef(entry, m);
  1238. command = "INSERT INTO ns"+m+"objects(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, typedefinition, description, eventnotifier, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+tt+"','"+entry['Description']+"', '"+eventnot+"', '"+entry['Documentation']+"');";
  1239. ret = pool.query(command);
  1240. }
  1241. }
  1242. }catch(err){
  1243. console.log(err);
  1244. }
  1245. }
  1246. async function createObjTypes(m){
  1247. try{
  1248. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"objecttypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'ObjectType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), isabstract VARCHAR(10), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), comment VARCHAR(300), documentation VARCHAR(300), PRIMARY KEY(id));";
  1249. var ret = await pool.query(command);
  1250. let obj = nsray[m].UANodeSet.UAObjectType;
  1251. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1252. if(nsray[m].UANodeSet.UAObjectType){
  1253. if(Array.isArray(obj)){
  1254. var sz = obj.length;
  1255. for(let i = 0; i < sz; i++){
  1256. var entry = obj[i];
  1257. var nid = entry['NodeId'];
  1258. var idx = 0;
  1259. if(nid.includes('ns=')){
  1260. var ix = nid.indexOf(';');
  1261. var ns = nid.substring(3,ix);
  1262. idx = parseInt(ns);
  1263. }
  1264. await checkRefs(entry, m, url);
  1265. var nid_t = "";
  1266. if(nid.includes('i=')){
  1267. nid_t = 'Numeric';
  1268. }else if(nid.includes('s=')){
  1269. nid_t = 'String';
  1270. }
  1271. var isabstr = "TBD";
  1272. if(entry['IsAbstract']){
  1273. isabstr = entry['IsAbstract'];
  1274. }
  1275. var pnid = "#";
  1276. let pnode = await getParentRef(entry, m);
  1277. command = "INSERT INTO ns"+m+"objecttypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, isabstract, description, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+isabstr+"', '"+entry['Description']+"', '"+entry['Documentation']+"');";
  1278. ret = pool.query(command);
  1279. }
  1280. }else{
  1281. var entry = obj;
  1282. var nid = entry['NodeId'];
  1283. var idx = 0;
  1284. if(nid.includes('ns=')){
  1285. var ix = nid.indexOf(';');
  1286. var ns = nid.substring(3,ix);
  1287. idx = parseInt(ns);
  1288. }
  1289. await checkRefs(entry, m, url);
  1290. var nid_t = "";
  1291. if(nid.includes('i=')){
  1292. nid_t = 'Numeric';
  1293. }else if(nid.includes('s=')){
  1294. nid_t = 'String';
  1295. }
  1296. var isabstr = "TBD";
  1297. if(entry['IsAbstract']){
  1298. isabstr = entry['IsAbstract'];
  1299. }
  1300. let pnode = await getParentRef(entry, m);
  1301. command = "INSERT INTO ns"+m+"objecttypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, isabstract, description, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+isabstr+"', '"+entry['Description']+"', '"+entry['Documentation']+"');";
  1302. ret = pool.query(command);
  1303. }
  1304. }
  1305. }catch(err){
  1306. console.log(err);
  1307. }
  1308. }
  1309. async function createVar(m){
  1310. try{
  1311. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"variables(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'Variable', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), modellingrule VARCHAR(100) DEFAULT 'Optional', datatype VARCHAR(300) NOT NULL, typedefinition VARCHAR(300) NOT NULL, value VARCHAR(500) DEFAULT NULL, valuerank INT DEFAULT NULL, arraydimensions INT, accesslevel INT DEFAULT NULL, accesslevelex INT DEFAULT NULL, historizing VARCHAR(10), minsamplinginterval INT DEFAULT 500, releasestatus VARCHAR(300), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1312. var ret = await pool.query(command);
  1313. let obj = nsray[m].UANodeSet.UAVariable;
  1314. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1315. if(nsray[m].UANodeSet.UAVariable){
  1316. if(Array.isArray(obj)){
  1317. var sz = obj.length;
  1318. for(let i = 0; i < sz; i++){
  1319. var entry = obj[i];
  1320. var nid = entry['NodeId'];
  1321. var idx = 0;
  1322. if(nid.includes('ns=')){
  1323. var ix = nid.indexOf(';');
  1324. var ns = nid.substring(3,ix);
  1325. idx = parseInt(ns);
  1326. }
  1327. await checkRefs(entry, m, url);
  1328. var nid_t = "";
  1329. if(nid.includes('i=')){
  1330. nid_t = 'Numeric';
  1331. }else if(nid.includes('s=')){
  1332. nid_t = 'String';
  1333. }
  1334. var valrank = 0;
  1335. if(entry['ValueRank']){
  1336. valrank = entry['ValueRank'];
  1337. }
  1338. var arrdim = 0;
  1339. if(entry['ArrayDimensions']){
  1340. arrdim = entry['ArrayDimensions'];
  1341. }
  1342. var acclev = 0;
  1343. if(entry['AccessLevel']){
  1344. acclev = entry['AccessLevel'];
  1345. }
  1346. var minsamp = 0;
  1347. if(entry['MinimumSamplingInterval']){
  1348. minsamp = entry['MinimumSamplingInterval'];
  1349. }
  1350. var dt = entry['DataType'];
  1351. if(entry['DataType'] && dt.includes('=')){
  1352. dt = await getDataType(dt, m);
  1353. }
  1354. var tt = await getTypeDef(entry['NodeId'], m);
  1355. let pnode = await getParentRef(entry, m);
  1356. command = "INSERT INTO ns"+m+"variables(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, typedefinition, description, datatype, valuerank, arraydimensions, accesslevel, minsamplinginterval, releasestatus) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+tt+"', '"+entry['Description']+"', '"+dt+"', '"+valrank+"', '"+arrdim+"', '"+acclev+"', '"+minsamp+"', '"+entry['ReleaseStatus']+"');";
  1357. ret = await pool.query(command);
  1358. }
  1359. }else{
  1360. var entry = obj;
  1361. var nid = entry['NodeId'];
  1362. var idx = 0;
  1363. if(nid.includes('ns=')){
  1364. var ix = nid.indexOf(';');
  1365. var ns = nid.substring(3,ix);
  1366. idx = parseInt(ns);
  1367. }
  1368. await checkRefs(entry, m, url);
  1369. var nid_t = "";
  1370. if(nid.includes('i=')){
  1371. nid_t = 'Numeric';
  1372. }else if(nid.includes('s=')){
  1373. nid_t = 'String';
  1374. }
  1375. var valrank = 0;
  1376. if(entry['ValueRank']){
  1377. valrank = entry['ValueRank'];
  1378. }
  1379. var arrdim = 0;
  1380. if(entry['ArrayDimensions']){
  1381. arrdim = entry['ArrayDimensions'];
  1382. }
  1383. var acclev = 0;
  1384. if(entry['AccessLevel']){
  1385. acclev = entry['AccessLevel'];
  1386. }
  1387. var minsamp = 0;
  1388. if(entry['MinimumSamplingInterval']){
  1389. minsamp = entry['MinimumSamplingInterval'];
  1390. }
  1391. var dt = entry['DataType'];
  1392. if(entry['DataType'] && dt.includes('=')){
  1393. dt = await getDataType(nid, m);
  1394. }
  1395. var tt = await getTypeDef(entry['NodeId'], m);
  1396. let pnode = await getParentRef(entry, m);
  1397. command = "INSERT INTO ns"+m+"variables(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, typedefinition, parentid, description, datatype, valuerank, arraydimensions, accesslevel, minsamplinginterval, releasestatus) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+tt+"','#', '"+entry['Description']+"', '"+dt+"', '"+valrank+"', '"+arrdim+"', '"+acclev+"', '"+minsamp+"', '"+entry['ReleaseStatus']+"');";
  1398. ret = await pool.query(command);
  1399. }
  1400. }
  1401. }catch(err){
  1402. console.log(err);
  1403. }
  1404. }
  1405. async function createVarTypes(m){
  1406. try{
  1407. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"variabletypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'VariableType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), datatype VARCHAR(300) NOT NULL, value VARCHAR(500) DEFAULT NULL, valuerank INT DEFAULT NULL, arraydimensions INT, isabstract VARCHAR(10), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1408. var ret = await pool.query(command);
  1409. let obj = nsray[m].UANodeSet.UAVariableType;
  1410. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1411. if(nsray[m].UANodeSet.UAVariableType){
  1412. if(Array.isArray(obj)){
  1413. var sz = obj.length;
  1414. for(let i = 0; i < sz; i++){
  1415. console.log(obj[i]);
  1416. var entry = obj[i];
  1417. var nid = entry['NodeId'];
  1418. var idx = 0;
  1419. if(nid.includes('ns=')){
  1420. var ix = nid.indexOf(';');
  1421. var ns = nid.substring(3,ix);
  1422. idx = parseInt(ns);
  1423. }
  1424. await checkRefs(entry, m, url);
  1425. var nid_t = "";
  1426. if(nid.includes('i=')){
  1427. nid_t = 'Numeric';
  1428. }else if(nid.includes('s=')){
  1429. nid_t = 'String';
  1430. }
  1431. var valrank = 0;
  1432. if(entry['ValueRank']){
  1433. valrank = entry['ValueRank'];
  1434. }
  1435. var arrdim = 0;
  1436. if(entry['ArrayDimensions']){
  1437. console.log('Here');
  1438. console.log(entry['ArrayDimensions']);
  1439. arrdim = entry['ArrayDimensions'];
  1440. }
  1441. var isabstr = "TBD";
  1442. if(entry['IsAbstract']){
  1443. isabstr = entry['IsAbstract'];
  1444. }
  1445. var dt = entry['DataType'];
  1446. if(entry['DataType'] && dt.includes('=')){
  1447. dt = await getDataType(nid, m);
  1448. }
  1449. let pnode = await getParentRef(entry, m);
  1450. command = "INSERT INTO ns"+m+"variabletypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, description, datatype, valuerank, arraydimensions, isabstract, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"','"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+dt+"', '"+valrank+"', '"+arrdim+"', '"+isabstr+"', '"+entry['Documentation']+"');";
  1451. ret = pool.query(command);
  1452. }
  1453. }else{
  1454. var entry = obj;
  1455. var nid = entry['NodeId'];
  1456. var idx = 0;
  1457. if(nid.includes('ns=')){
  1458. var ix = nid.indexOf(';');
  1459. var ns = nid.substring(3,ix);
  1460. idx = parseInt(ns);
  1461. }
  1462. await checkRefs(entry, m, url);
  1463. var nid_t = "";
  1464. if(nid.includes('i=')){
  1465. nid_t = 'Numeric';
  1466. }else if(nid.includes('s=')){
  1467. nid_t = 'String';
  1468. }
  1469. var valrank = 0;
  1470. if(entry['ValueRank']){
  1471. valrank = entry['ValueRank'];
  1472. }
  1473. var arrdim = 0;
  1474. if(entry['ArrayDimensions']){
  1475. console.log('Here');
  1476. console.log(entry['ArrayDimensions']);
  1477. arrdim = entry['ArrayDimensions'];
  1478. }
  1479. var isabstr = "TBD";
  1480. if(entry['IsAbstract']){
  1481. isabstr = entry['IsAbstract'];
  1482. }
  1483. var dt = entry['DataType'];
  1484. if(entry['DataType'] && dt.includes('=')){
  1485. dt = await getDataType(nid, m);
  1486. }
  1487. let pnode = await getParentRef(entry, m);
  1488. command = "INSERT INTO ns"+m+"variabletypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, description, datatype, valuerank, arraydimensions, isabstract, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"','"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+dt+"', '"+valrank+"', '"+arrdim+"', '"+isabstr+"', '"+entry['Documentation']+"');";
  1489. ret = pool.query(command);
  1490. }
  1491. }
  1492. }catch(err){
  1493. console.log(err);
  1494. }
  1495. }
  1496. async function createMethods(m){
  1497. try{
  1498. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"methods(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'Method', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), modellingrule VARCHAR(100) DEFAULT 'Optional', executable INT DEFAULT 1, parentreference VARCHAR(300), parentid VARCHAR(300) DEFAULT '#', methoddeclarationid VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1499. var ret = await pool.query(command);
  1500. let obj = nsray[m].UANodeSet.UAMethod;
  1501. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1502. if(nsray[m].UANodeSet.UAMethod){
  1503. if(Array.isArray(obj)){
  1504. var sz = obj.length;
  1505. for(let i = 0; i < sz; i++){
  1506. var entry = obj[i];
  1507. var nid = entry['NodeId'];
  1508. var idx = 0;
  1509. if(nid.includes('ns=')){
  1510. var ix = nid.indexOf(';');
  1511. var ns = nid.substring(3,ix);
  1512. idx = parseInt(ns);
  1513. }
  1514. await checkRefs(entry, m, url);
  1515. var nid_t = "";
  1516. if(nid.includes('i=')){
  1517. nid_t = 'Numeric';
  1518. }else if(nid.includes('s=')){
  1519. nid_t = 'String';
  1520. }
  1521. let pnode = await getParentRef(entry, m);
  1522. command = "INSERT INTO ns"+m+"methods(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, description, methoddeclarationid) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+entry['MethodDeclarationId']+"');";
  1523. ret = pool.query(command);
  1524. }
  1525. }else{
  1526. var entry = obj;
  1527. var nid = entry['NodeId'];
  1528. var idx = 0;
  1529. if(nid.includes('ns=')){
  1530. var ix = nid.indexOf(';');
  1531. var ns = nid.substring(3,ix);
  1532. idx = parseInt(ns);
  1533. }
  1534. await checkRefs(entry, m, url);
  1535. var nid_t = "";
  1536. if(nid.includes('i=')){
  1537. nid_t = 'Numeric';
  1538. }else if(nid.includes('s=')){
  1539. nid_t = 'String';
  1540. }
  1541. let pnode = await getParentRef(entry, m);
  1542. command = "INSERT INTO ns"+m+"methods(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, description, methoddeclarationid) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+entry['MethodDeclarationId']+"');";
  1543. ret = pool.query(command);
  1544. }
  1545. }
  1546. }catch(err){
  1547. console.log(err);
  1548. res.json({result:"NOK"});
  1549. }
  1550. }
  1551. async function createDataTypes(m){
  1552. try{
  1553. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"datatypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, nodeclass VARCHAR(50) DEFAULT 'DataType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), isabstract VARCHAR(10), parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), definition VARCHAR(300), releasestatus VARCHAR(300), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1554. var ret = await pool.query(command);
  1555. let obj = nsray[m].UANodeSet.UADataType;
  1556. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1557. if(nsray[m].UANodeSet.UADataType){
  1558. if(Array.isArray(obj)){
  1559. var sz = obj.length;
  1560. for(let i = 0; i < sz; i++){
  1561. var entry = obj[i];
  1562. var nid = entry['NodeId'];
  1563. var idx = 0;
  1564. if(nid.includes('ns=')){
  1565. var ix = nid.indexOf(';');
  1566. var ns = nid.substring(3,ix);
  1567. idx = parseInt(ns);
  1568. }
  1569. await checkRefs(entry, m, url);
  1570. var nid_t = "";
  1571. if(nid.includes('i=')){
  1572. nid_t = 'Numeric';
  1573. }else if(nid.includes('s=')){
  1574. nid_t = 'String';
  1575. }
  1576. let pnode = await getParentRef(entry, m);
  1577. command = "INSERT INTO ns"+m+"datatypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, description, isabstract, definition, releasestatus, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+entry['IsAbstract']+"', '"+entry['Definition']+"', '"+entry['ReleaseStatus']+"', '"+entry['Documentation']+"');";
  1578. ret = pool.query(command);
  1579. }
  1580. }else{
  1581. var entry = obj;
  1582. var nid = entry['NodeId'];
  1583. var idx = 0;
  1584. if(nid.includes('ns=')){
  1585. var ix = nid.indexOf(';');
  1586. var ns = nid.substring(3,ix);
  1587. idx = parseInt(ns);
  1588. }
  1589. await checkRefs(entry, m, url);
  1590. var nid_t = "";
  1591. if(nid.includes('i=')){
  1592. nid_t = 'Numeric';
  1593. }else if(nid.includes('s=')){
  1594. nid_t = 'String';
  1595. }
  1596. let pnode = await getParentRef(entry, m);
  1597. command = "INSERT INTO ns"+m+"datatypes(nodeid, nodeidtype, nsindex, name, displayname, browsename, parentid, parentreference, parentinverse, description, isabstract, definition, releasestatus, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+entry['IsAbstract']+"', '"+entry['Definition']+"', '"+entry['ReleaseStatus']+"', '"+entry['Documentation']+"');";
  1598. ret = pool.query(command);
  1599. }
  1600. }
  1601. }catch(err){
  1602. console.log(err);
  1603. res.json({result:"NOK"});
  1604. }
  1605. }
  1606. async function createRefTypes(m){
  1607. try{
  1608. var command = "CREATE TABLE IF NOT EXISTS ns"+m+"referencetypes(id INT AUTO_INCREMENT, nodeid VARCHAR(300) NOT NULL UNIQUE, nodeidtype VARCHAR(100) NOT NULL, name VARCHAR(300) NOT NULL, inversename VARCHAR(300), symmetric VARCHAR(10) DEFAULT 'TBD', nodeclass VARCHAR(50) DEFAULT 'ReferenceType', nsindex INT DEFAULT NULL, nsurl VARCHAR(120) DEFAULT 'http://opcfoundation.org/UA/', displayname VARCHAR(300) NOT NULL, browsename VARCHAR(300) NOT NULL, description VARCHAR(300), isabstract VARCHAR(10) DEFAULT 'TBD', parentid VARCHAR(300) DEFAULT '#', parentreference VARCHAR(300), parentinverse VARCHAR(10), documentation VARCHAR(300), comment VARCHAR(300), PRIMARY KEY(id));";
  1609. var ret = await pool.query(command);
  1610. let obj = nsray[m].UANodeSet.UAReferenceType;
  1611. var url = nsray[m].UANodeSet.Models.Model.ModelUri;
  1612. if(nsray[m].UANodeSet.UAReferenceType){
  1613. if(Array.isArray(obj)){
  1614. var sz = obj.length;
  1615. for(let i = 0; i < sz; i++){
  1616. var entry = obj[i];
  1617. var nid = entry['NodeId'];
  1618. var idx = m;
  1619. if(nid.includes('ns=')){
  1620. var ix = nid.indexOf(';');
  1621. var ns = nid.substring(3,ix);
  1622. idx = parseInt(ns);
  1623. }
  1624. await checkRefs(entry, m, url);
  1625. var nid_t = "";
  1626. if(nid.includes('i=')){
  1627. nid_t = 'Numeric';
  1628. }else if(nid.includes('s=')){
  1629. nid_t = 'String';
  1630. }
  1631. let pnode = await getParentRef(entry, m);
  1632. command = "INSERT INTO ns"+m+"referencetypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, description, isabstract, symmetric, inversename, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+entry['IsAbstract']+"', '"+entry['Symmetric']+"', '"+entry['InverseName']+"', '"+entry['Documentation']+"');";
  1633. ret = pool.query(command);
  1634. }
  1635. }else{
  1636. var entry = obj;
  1637. var nid = entry['NodeId'];
  1638. var idx = m;
  1639. if(nid.includes('ns=')){
  1640. var ix = nid.indexOf(';');
  1641. var ns = nid.substring(3,ix);
  1642. idx = parseInt(ns);
  1643. }
  1644. await checkRefs(entry, m, url);
  1645. var nid_t = "";
  1646. if(nid.includes('i=')){
  1647. nid_t = 'Numeric';
  1648. }else if(nid.includes('s=')){
  1649. nid_t = 'String';
  1650. }
  1651. let pnode = await getParentRef(entry, m);
  1652. command = "INSERT INTO ns"+m+"referencetypes(nodeid, nodeidtype, nsindex, nsurl, name, displayname, browsename, parentid, parentreference, parentinverse, parentreference, parentinverse, description, isabstract, symmetric, inversename, documentation) VALUES ('"+entry['NodeId']+"', '"+nid_t+"', '"+idx+"', '"+url+"', '"+entry['DisplayName']+"', '"+entry['DisplayName']+"', '"+entry['BrowseName']+"', '"+pnode.pnid+"', '"+pnode.pref+"', '"+pnode.pinv+"', '"+entry['Description']+"', '"+entry['IsAbstract']+"', '"+entry['Symmetric']+"', '"+entry['InverseName']+"', '"+entry['Documentation']+"');";
  1653. ret = pool.query(command);
  1654. }
  1655. }
  1656. }catch(err){
  1657. console.log(err);
  1658. res.json({result:"NOK"});
  1659. }
  1660. }
  1661. app.get('/obj', async function(req, res){
  1662. try{
  1663. var key = req.body;
  1664. var len = nsray.length;
  1665. for(let m = 0; m < nsray.length; m++){
  1666. await createObj(m);
  1667. }
  1668. res.json({result:'OK',success:true});
  1669. }catch(err){
  1670. console.log(err);
  1671. res.json({result:"NOK"});
  1672. }
  1673. })
  1674. app.get('/obj/:id', async function(req, res){
  1675. try{
  1676. var key = req.body;
  1677. var m = parseInt(req.params["id"]);
  1678. await createObj(m);
  1679. res.json({result:'OK',success:true});
  1680. }catch(err){
  1681. console.log(err);
  1682. res.json({result:"NOK"});
  1683. }
  1684. })
  1685. app.get('/objtypes', async function(req, res){
  1686. try{
  1687. var key = req.body;
  1688. var len = nsray.length;
  1689. for(let m = 0; m < nsray.length; m++){
  1690. await createObjTypes(m);
  1691. }
  1692. res.json({result:'OK',success:true});
  1693. }catch(err){
  1694. console.log(err);
  1695. res.json({result:"NOK"});
  1696. }
  1697. })
  1698. app.get('/objtypes/:id', async function(req, res){
  1699. try{
  1700. var m = parseInt(req.params["id"]);
  1701. await createObjTypes(m);
  1702. res.json({result:'OK',success:true});
  1703. }catch(err){
  1704. console.log(err);
  1705. res.json({result:"NOK"});
  1706. }
  1707. })
  1708. app.get('/var', async function(req, res){
  1709. try{
  1710. var key = req.body;
  1711. var len = nsray.length;
  1712. for(let m = 0; m < nsray.length; m++){
  1713. await createVar(m);
  1714. }
  1715. res.json({result:'OK',success:true});
  1716. }catch(err){
  1717. console.log(err);
  1718. res.json({result:"NOK"});
  1719. }
  1720. })
  1721. app.get('/var/:id', async function(req, res){
  1722. try{
  1723. var m = parseInt(req.params["id"]);
  1724. await createVar(m);
  1725. res.json({result:'OK',success:true});
  1726. }catch(err){
  1727. console.log(err);
  1728. res.json({result:"NOK"});
  1729. }
  1730. })
  1731. app.get('/vartypes', async function(req, res){
  1732. try{
  1733. var key = req.body;
  1734. var len = nsray.length;
  1735. for(let m = 0; m < nsray.length; m++){
  1736. await createVarTypes(m);
  1737. }
  1738. res.json({result:'OK',success:true});
  1739. }catch(err){
  1740. console.log(err);
  1741. res.json({result:"NOK"});
  1742. }
  1743. })
  1744. app.get('/vartypes/:id', async function(req, res){
  1745. try{
  1746. var m = parseInt(req.params["id"]);
  1747. await createVarTypes(m);
  1748. res.json({result:'OK',success:true});
  1749. }catch(err){
  1750. console.log(err);
  1751. res.json({result:"NOK"});
  1752. }
  1753. })
  1754. app.get('/methods', async function(req, res){
  1755. try{
  1756. var key = req.body;
  1757. var len = nsray.length;
  1758. for(let m = 0; m < nsray.length; m++){
  1759. await createMethods(m);
  1760. }
  1761. res.json({result:'OK',success:true});
  1762. }catch(err){
  1763. console.log(err);
  1764. res.json({result:"NOK"});
  1765. }
  1766. })
  1767. app.get('/methods/:id', async function(req, res){
  1768. try{
  1769. var m = parseInt(req.params["id"]);
  1770. await createMethods(m);
  1771. res.json({result:'OK',success:true});
  1772. }catch(err){
  1773. console.log(err);
  1774. res.json({result:"NOK"});
  1775. }
  1776. })
  1777. app.get('/datatypes', async function(req, res){
  1778. try{
  1779. var key = req.body;
  1780. var len = nsray.length;
  1781. for(let m = 0; m < nsray.length; m++){
  1782. await createDataTypes(m);
  1783. }
  1784. res.json({result:'OK',success:true});
  1785. }catch(err){
  1786. console.log(err);
  1787. res.json({result:"NOK"});
  1788. }
  1789. })
  1790. app.get('/datatypes/:id', async function(req, res){
  1791. try{
  1792. var m = parseInt(req.params["id"]);
  1793. await createDataTypes(m);
  1794. res.json({result:'OK',success:true});
  1795. }catch(err){
  1796. console.log(err);
  1797. res.json({result:"NOK"});
  1798. }
  1799. })
  1800. app.get('/reftypes', async function(req, res){
  1801. try{
  1802. var key = req.body;
  1803. var len = nsray.length;
  1804. for(let m = 0; m < nsray.length; m++){
  1805. await createRefTypes(m);
  1806. }
  1807. res.json({result:'OK',success:true});
  1808. }catch(err){
  1809. console.log(err);
  1810. res.json({result:"NOK"});
  1811. }
  1812. })
  1813. app.get('/reftypes/:id', async function(req, res){
  1814. try{
  1815. var m = parseInt(req.params["id"]);
  1816. await createRefTypes(m);
  1817. res.json({result:'OK',success:true});
  1818. }catch(err){
  1819. console.log(err);
  1820. res.json({result:"NOK"});
  1821. }
  1822. })
  1823. app.get('/createnodes/:id', async function(req, res){
  1824. try{
  1825. var m = parseInt(req.params["id"]);
  1826. await createDataTypes(m);
  1827. await createObjTypes(m);
  1828. await createVarTypes(m);
  1829. await createRefTypes(m);
  1830. await createObj(m);
  1831. await createVar(m);
  1832. await createMethods(m);
  1833. res.json({result:'OK',success:true});
  1834. }catch(err){
  1835. console.log(err);
  1836. res.json({result:"NOK"});
  1837. }
  1838. })
  1839. app.get('/namesp', async function(req, res){
  1840. try{
  1841. var key = req.body;
  1842. var sz = nsray.length;
  1843. //-------ns0--------------
  1844. var command = "CREATE TABLE IF NOT EXISTS ns0depends(id INT AUTO_INCREMENT, nsindex INT DEFAULT NULL, nsurl VARCHAR(120), publicationdate VARCHAR(120), version VARCHAR(100), PRIMARY KEY(id));";
  1845. var ret = await pool.query(command);
  1846. command = "INSERT INTO ns0depends(nsindex, nsurl, publicationdate, version) VALUES ('0','http://opcfoundation.org/UA/','"+jsn.UANodeSet.Models.Model['PublicationDate']+"','"+jsn.UANodeSet.Models.Model['Version']+"');";
  1847. ret = pool.query(command);
  1848. //----------------ns0--------------
  1849. for(let i = 1; i < sz; i++){
  1850. var entry0 = nsray[i].UANodeSet.NamespaceUris.Uri;
  1851. command = "CREATE TABLE IF NOT EXISTS ns"+i+"depends(id INT AUTO_INCREMENT, nsindex INT DEFAULT NULL, nsurl VARCHAR(120), publicationdate VARCHAR(120), version VARCHAR(100), PRIMARY KEY(id));";
  1852. ret = await pool.query(command);
  1853. command = "INSERT INTO ns"+i+"depends(nsindex, nsurl, publicationdate, version) VALUES ('0','http://opcfoundation.org/UA/','"+jsn.UANodeSet.Models.Model['PublicationDate']+"','"+jsn.UANodeSet.Models.Model['Version']+"');";
  1854. ret = pool.query(command);
  1855. if(Array.isArray(entry0)){
  1856. var szy = entry0.length;
  1857. for(let y = 0; y < szy; y++){
  1858. var ns = entry0[y];
  1859. command = "INSERT INTO ns"+i+"depends(nsindex, nsurl) VALUES ('"+(y+1)+"','"+ns+"');";
  1860. ret = pool.query(command);
  1861. }
  1862. }else{
  1863. var ns = entry0;
  1864. command = "INSERT INTO ns"+i+"depends(nsindex, nsurl) VALUES ('1','"+entry0+"');";
  1865. ret = pool.query(command);
  1866. }
  1867. var entry = nsray[i].UANodeSet.Models.Model.RequiredModel;
  1868. command = "UPDATE ns"+i+"depends SET publicationdate = '"+nsray[i].UANodeSet.Models.Model['PublicationDate']+"' WHERE nsurl = '"+nsray[i].UANodeSet.Models.Model['ModelUri']+"';";
  1869. ret = pool.query(command);
  1870. command = "UPDATE ns"+i+"depends SET version = '"+nsray[i].UANodeSet.Models.Model['Version']+"' WHERE nsurl = '"+nsray[i].UANodeSet.Models.Model['ModelUri']+"';";
  1871. ret = pool.query(command);
  1872. if(Array.isArray(entry)){
  1873. var szy = entry.length;
  1874. for(let y = 0; y < szy; y++){
  1875. var ns0 = entry[y];
  1876. command = "UPDATE ns"+i+"depends SET publicationdate = '"+ns0['PublicationDate']+"' WHERE nsurl = '"+ns0['ModelUri']+"';";
  1877. ret = pool.query(command);
  1878. command = "UPDATE ns"+i+"depends SET version = '"+ns0['Version']+"' WHERE nsurl = '"+ns0['ModelUri']+"';";
  1879. ret = pool.query(command);
  1880. }
  1881. }else{
  1882. var ns0 = entry;
  1883. command = "UPDATE ns"+i+"depends SET publicationdate = '"+ns0['PublicationDate']+"' WHERE nsurl = '"+ns0['ModelUri']+"';";
  1884. ret = pool.query(command);
  1885. command = "UPDATE ns"+i+"depends SET version = '"+ns0['Version']+"' WHERE nsurl = '"+ns0['ModelUri']+"';";
  1886. ret = pool.query(command);
  1887. }
  1888. }
  1889. res.json({result:'OK',success:true});
  1890. }catch(err){
  1891. console.log(err);
  1892. res.json({result:"NOK"});
  1893. }
  1894. })
  1895. app.get('/allrefs', async function(req, res){
  1896. try{
  1897. console.log(arref);
  1898. res.json({result:'OK',success:true});
  1899. }catch(err){
  1900. console.log("NOK");
  1901. res.json({result:"NOK"});
  1902. }
  1903. })
  1904. app.get('/init', async function(req, res){
  1905. try{
  1906. var len = nsray.length;
  1907. for(let m = 0; m < nsray.length; m++){
  1908. await createNamespace(m);
  1909. }
  1910. res.json({result:'OK',success:true});
  1911. }catch(err){
  1912. console.log("NOK");
  1913. res.json({result:"NOK"});
  1914. }
  1915. })
  1916. app.get('/init/:ns', async function(req, res){
  1917. try{
  1918. var n = req.params["ns"];
  1919. await createNamespace(n);
  1920. res.json({result:'OK',success:true});
  1921. }catch(err){
  1922. console.log("NOK");
  1923. res.json({result:"NOK"});
  1924. }
  1925. })
  1926. /*
  1927. app.post('/key', async function(req, res){
  1928. try{
  1929. var key = req.body;
  1930. console.log(key);
  1931. var ret = await gen_query("SELECT name FROM mitarbeiter WHERE key_id='"+key['key_id']+"';");
  1932. res.json({result:ret[0].name,success:true});
  1933. }catch(err){
  1934. console.log("NOK");
  1935. res.json({result:"NOK"});
  1936. }
  1937. })
  1938. */
  1939. app.get('/look/:ix/:id/:eclass/:attr', async function(req, res){
  1940. try{
  1941. var ix = req.params["ix"];
  1942. var id = req.params["id"];
  1943. var cls = req.params["eclass"];
  1944. var attr = req.params["attr"];
  1945. var class_name = "";
  1946. switch(cls){
  1947. case "ObjectType": class_name="objecttypes"; break;
  1948. case "Object": class_name="objects"; break;
  1949. case "VariableType": class_name="variabletypes"; break;
  1950. case "DataType": class_name="datatypes"; break;
  1951. case "ReferenceType": class_name="referencetypes"; break;
  1952. case "Variable": class_name="variables"; break;
  1953. case "Method": class_name="methods"; break;
  1954. default: class_name="objects";
  1955. }
  1956. var ret = await getThisNodeAttribute(ix, id, class_name, attr);
  1957. res.json({result:ret,success:true});
  1958. }catch(err){
  1959. console.log(err);
  1960. res.json({result:"NOK"});
  1961. }
  1962. })
  1963. app.get('/find/:ix/:id/:eclass', async function(req, res){
  1964. try{
  1965. var ix = req.params["ix"];
  1966. var id = req.params["id"];
  1967. var cls = req.params["eclass"];
  1968. var class_name = "";
  1969. switch(cls){
  1970. case "ObjectType": class_name="objecttypes"; break;
  1971. case "Object": class_name="objects"; break;
  1972. case "VariableType": class_name="variabletypes"; break;
  1973. case "DataType": class_name="datatypes"; break;
  1974. case "ReferenceType": class_name="referencetypes"; break;
  1975. case "Variable": class_name="variables"; break;
  1976. case "Method": class_name="methods"; break;
  1977. default: class_name="objects";
  1978. }
  1979. var ret = await getThisNode(ix, id, class_name);
  1980. res.json(ret);
  1981. }catch(err){
  1982. console.log(err);
  1983. res.json({result:"NOK"});
  1984. }
  1985. })
  1986. app.get('/children/sql/:ix/:id', async function(req, res){
  1987. try{
  1988. var ix = req.params["ix"];
  1989. var id = req.params["id"];
  1990. var ret = await getChildrenSql(ix, id);
  1991. res.json({result:ret, success: true});
  1992. }catch(err){
  1993. console.log(err);
  1994. res.json({result:"NOK"});
  1995. }
  1996. })
  1997. app.get('/typedef', async function(req, res){
  1998. try{
  1999. var ret = await getTypeDef("ns=1;i=103", 4);
  2000. res.json({result:ret,success:true});
  2001. }catch(err){
  2002. console.log(err);
  2003. res.json({result:"NOK"});
  2004. }
  2005. })
  2006. app.get('/parent', async function(req, res){
  2007. try{
  2008. var ret = await getParentRef("ns=1;i=118", 4);
  2009. res.json({result:ret,success:true});
  2010. }catch(err){
  2011. console.log(err);
  2012. res.json({result:"NOK"});
  2013. }
  2014. })
  2015. app.get('/delete', async function(req, res){
  2016. try{
  2017. for(let i = 1; i < 5; i++){
  2018. var command = "DROP TABLE ns"+i+"objects;";
  2019. var ret = await pool.query(command);
  2020. var command = "DROP TABLE ns"+i+"objecttypes;";
  2021. var ret = await pool.query(command);
  2022. var command = "DROP TABLE ns"+i+"variables;";
  2023. var ret = await pool.query(command);
  2024. var command = "DROP TABLE ns"+i+"variabletypes;";
  2025. var ret = await pool.query(command);
  2026. var command = "DROP TABLE ns"+i+"datatypes;";
  2027. var ret = await pool.query(command);
  2028. var command = "DROP TABLE ns"+i+"referencetypes;";
  2029. var ret = await pool.query(command);
  2030. var command = "DROP TABLE ns"+i+"references;";
  2031. var ret = await pool.query(command);
  2032. var command = "DROP TABLE ns"+i+"methods;";
  2033. var ret = await pool.query(command);
  2034. }
  2035. res.json({result:"OK",success:true});
  2036. }catch(err){
  2037. console.log(err);
  2038. res.json({result:"NOK"});
  2039. }
  2040. })
  2041. app.get('/delete/:id', async function(req, res){
  2042. try{
  2043. var i = req.params["id"];
  2044. var command = "DROP TABLE ns"+i+"objects;";
  2045. var ret = await pool.query(command);
  2046. var command = "DROP TABLE ns"+i+"objecttypes;";
  2047. var ret = await pool.query(command);
  2048. var command = "DROP TABLE ns"+i+"variables;";
  2049. var ret = await pool.query(command);
  2050. var command = "DROP TABLE ns"+i+"variabletypes;";
  2051. var ret = await pool.query(command);
  2052. var command = "DROP TABLE ns"+i+"datatypes;";
  2053. var ret = await pool.query(command);
  2054. var command = "DROP TABLE ns"+i+"referencetypes;";
  2055. var ret = await pool.query(command);
  2056. var command = "DROP TABLE ns"+i+"references;";
  2057. var ret = await pool.query(command);
  2058. var command = "DROP TABLE ns"+i+"methods;";
  2059. var ret = await pool.query(command);
  2060. res.json({result:"OK",success:true});
  2061. }catch(err){
  2062. console.log(err);
  2063. res.json({result:"NOK"});
  2064. }
  2065. })
  2066. app.get('/requirejson/:ident/:name',(req, res) =>{
  2067. try{
  2068. var namejs = req.params["name"];
  2069. var shorty = req.params["ident"];
  2070. const id = "./"+namejs+".json";
  2071. const fl = require(id);
  2072. for(let i = 0; i < ns_array.length; i++){
  2073. if(ns_array[i][1] === shorty){
  2074. return res.json({result:"Array already includes element."})
  2075. }
  2076. }
  2077. ns_array.push([fl, shorty, fl.UANodeSet.Models.Model.ModelUri]);
  2078. res.json({result:"OK"});
  2079. }catch(err){
  2080. console.log("NOK");
  2081. res.json({result:"NOK", error: "Json file may not be available. Call list json files."});
  2082. }
  2083. })
  2084. app.get('/shownsarray',(req, res) =>{
  2085. try{ let str = '';
  2086. for(let i = 0; i < ns_array.length; i++){
  2087. str += '('+i+': '+ns_array[i][1]+')';
  2088. }
  2089. res.json({result:str});
  2090. console.log(ns_array);
  2091. }catch(err){
  2092. console.log("NOK");
  2093. res.json({result:"NOK", error: "Json file may not be available. Call list json files."});
  2094. }
  2095. })
  2096. app.get('/getredis',(req, res) =>{
  2097. try{
  2098. redis_get();
  2099. res.json({result:"OK"});
  2100. }catch(err){
  2101. console.log("NOK");
  2102. res.json({result:"NOK"});
  2103. }
  2104. })
  2105. app.get('/get_root',(req, res) =>{
  2106. try{
  2107. let rt = jsn.UANodeSet.UAObject.find( record => record.NodeId === "i=84");
  2108. let resj = {
  2109. id: rt.NodeId,
  2110. parent: "#",
  2111. text: rt.DisplayName};
  2112. res.json(resj);
  2113. }catch(err){
  2114. console.log("NOK");
  2115. res.json({result:"NOK"});
  2116. }
  2117. })
  2118. app.get('/get_children/base/:id',(req, res) =>{
  2119. var nid = req.params["id"];
  2120. try{
  2121. if(Array.isArray(jsn.UANodeSet.UAObject)){
  2122. for (let i = 0; i < jsn.UANodeSet.UAObject.length;i++){
  2123. if(Array.isArray(jsn.UANodeSet.UAObject[i].References.Reference)){
  2124. for (let x = 0; x < jsn.UANodeSet.UAObject[i].References.Reference.length;x++){
  2125. if(jsn.UANodeSet.UAObject[i].References.Reference[x].$t === nid){
  2126. console.log(jsn.UANodeSet.UAObject[i].BrowseName + inverse(jsn.UANodeSet.UAObject[i].References.Reference[x]) +jsn.UANodeSet.UAObject[i].References.Reference[x].ReferenceType);
  2127. }
  2128. }
  2129. }else{
  2130. if(jsn.UANodeSet.UAObject[i].References.Reference.$t === nid){
  2131. console.log(jsn.UANodeSet.UAObject[i].BrowseName + inverse(jsn.UANodeSet.UAObject[i].References.Reference) +jsn.UANodeSet.UAObject[i].References.Reference.ReferenceType);
  2132. }
  2133. }
  2134. }
  2135. }else{
  2136. if(Array.isArray(jsn.UANodeSet.UAObject.References.Reference)){
  2137. for (let x = 0; x < jsn.UANodeSet.UAObject.References.Reference.length;x++){
  2138. if(jsn.UANodeSet.UAObject[i].References.Reference[x].$t === nid){
  2139. console.log(jsn.UANodeSet.UAObject[i].BrowseName + inverse(jsn.UANodeSet.UAObject.References.Reference[x]) +jsn.UANodeSet.UAObject.References.Reference[x].ReferenceType);
  2140. }
  2141. }
  2142. }else{
  2143. if(jsn.UANodeSet.UAObject.References.Reference.$t === nid){
  2144. console.log(jsn.UANodeSet.UAObject.BrowseName + inverse(jsn.UANodeSet.UAObject.References.Reference) +jsn.UANodeSet.UAObject.References.Reference.ReferenceType);
  2145. }
  2146. }
  2147. }
  2148. console.log('');
  2149. res.json({result:"OK"});
  2150. }catch(err){
  2151. console.log("NOK");
  2152. res.json({result:"NOK"});
  2153. }
  2154. })
  2155. app.get('/get_children/all/:ns/:id',(req, res) =>{
  2156. var ret_obj = [];
  2157. var ns = req.params["ns"];
  2158. var id = req.params["id"];
  2159. var nid = 'ns='+ns+';'+'i='+id;
  2160. console.log(nid);
  2161. get_Children(di, nid, ret_obj);
  2162. get_Children(ia, nid, ret_obj);
  2163. get_Children(mach, nid, ret_obj);
  2164. get_Children(mt, nid, ret_obj);
  2165. res.json(ret_obj);
  2166. })
  2167. app.get('/getNode/all/:ns/:id',(req, res) =>{
  2168. var ret_obj = [];
  2169. var ns = req.params["ns"];
  2170. var id = req.params["id"];
  2171. var nid = 'ns='+ns+';'+'i='+id;
  2172. console.log(nid);
  2173. get_Children(di, nid, ret_obj);
  2174. get_Children(ia, nid, ret_obj);
  2175. get_Children(mach, nid, ret_obj);
  2176. get_Children(mt, nid, ret_obj);
  2177. let node = {
  2178. id:nid,
  2179. text: "home",
  2180. children:ret_obj
  2181. }
  2182. res.json(node);
  2183. })
  2184. app.get('/flushall',(req, res) =>{
  2185. redis_flush();
  2186. res.json({result:"OK"});
  2187. })
  2188. app.get('/p2json/:nodeset/:ident',(req, res) =>{
  2189. var name = req.params["nodeset"];
  2190. var shorty = req.params["ident"];
  2191. p2json(name, shorty);
  2192. res.json({result:"OK"});
  2193. })
  2194. app.get('/list_projects', (req, res) => { //reacts to requests -> /list_projects
  2195. const output = execSync("cd .. && cd Projects && ls", { encoding: 'utf-8' });
  2196. var out = output.split("\n");
  2197. if(out[out.length-1] === ""){
  2198. out.splice(-1,1);
  2199. }
  2200. console.log("Response: ", out);
  2201. res.json({result:out});
  2202. })
  2203. app.get('/list_nodesets', (req, res) => { //reacts to requests -> /list_nodesets
  2204. const output = execSync("cd .. && cd nodesets && ls", { encoding: 'utf-8' });
  2205. var out = output.split("\n");
  2206. var result = [];
  2207. for(let i = 0; i < out.length; i++){
  2208. if(out[i].includes(".xml")){
  2209. result.push(out[i]);
  2210. }
  2211. }
  2212. console.log("Response: ", result);
  2213. res.json({result:result});
  2214. })
  2215. app.get('/new_project', (req, res) => { //reacts to requests -> /new_project?name=myproject
  2216. const name = req.query.name; //project name
  2217. const output = execSync("cd .. && cd Projects && ls", { encoding: 'utf-8' });
  2218. var out = output.split("\n");
  2219. var result = "";
  2220. var err = "Error - Project already exists.";
  2221. for(let i = 0; i < out.length; i++){
  2222. if(out[i] === name){
  2223. return res.json({result:err});
  2224. }
  2225. }
  2226. const dir = execSync("cd .. && cd Projects && mkdir "+name, { encoding: 'utf-8' });
  2227. var cp = execSync("sudo cp /home/pi/ModelingTool/nodesets/Opc.Ua.NodeSet2.xml /home/pi/ModelingTool/Projects/"+name+"/Opc.Ua.NodeSet2.xml", { encoding: 'utf-8' });
  2228. cp = execSync("sudo cp /home/pi/ModelingTool/nodesets/Opc.Ua.NodeSet2.json /home/pi/ModelingTool/Projects/"+name+"/Opc.Ua.NodeSet2.json", { encoding: 'utf-8' });
  2229. const cur_dir = execSync("cd .. && cd Projects && cd "+name+" && ls", { encoding: 'utf-8' });
  2230. console.log("New Project was created.");
  2231. res.json({result:cur_dir});
  2232. })
  2233. app.get('/save_project', (req, res) => { //reacts to requests -> /save_project?name=myproject
  2234. const name = req.query.name; //project name
  2235. const output = execSync("sudo cp /var/www/html/root.json /home/pi/ModelingTool/Projects/"+name+"/"+name+".json", { encoding: 'utf-8' });
  2236. console.log("Project "+name+" was saved.");
  2237. res.json({result:"Project saved"});
  2238. })
  2239. app.get('/load_json', (req, res) => { //reacts to requests -> /load_json?name=myproject
  2240. const name = req.query.name; //project name
  2241. var output = execSync("cd .. && cd Projects && ls", { encoding: 'utf-8' });
  2242. var out = output.split("\n");
  2243. var result = "";
  2244. var err = "Error - Project or file not available.";
  2245. for(let i = 0; i < out.length; i++){
  2246. if(out[i] === name){
  2247. var output1 = execSync("cd .. && cd Projects && cd "+name+" && ls", { encoding: 'utf-8' });
  2248. var out1 = output1.split("\n");
  2249. var chk = name+".json"
  2250. for(let y = 0; y < out1.length; y++){
  2251. if(out1[y] === chk){
  2252. result = execSync("sudo cp /home/pi/ModelingTool/Projects/"+name+"/"+name+".json /var/www/html/root.json", { encoding: 'utf-8' });
  2253. console.log("Project has been loaded.");
  2254. return res.json({result:"Project loaded"});
  2255. }
  2256. }
  2257. }
  2258. }
  2259. res.json({result:err});
  2260. })
  2261. app.get('/root', (req, res) => { //reacts to requests -> /root
  2262. console.log("Return root.");
  2263. res.json([{id:"i=84",text:"Root",children:[{id:"i=85",text:"Objects",children:true},{id:"i=86",text:"Types", icon : "/variable_node.svg", children:true},{id:"i=87",text:"View",children:false}]}]);
  2264. })
  2265. function isChildRef(obj){
  2266. if('IsForward' in obj && obj.IsForward === 'false'){
  2267. return false;
  2268. }
  2269. if('IsForward' in obj && obj.IsForward === 'true'){
  2270. switch (obj.ReferenceType) {
  2271. case 'Organizes': return true;
  2272. case 'HasComponent': return true;
  2273. case 'HasProperty': return true;
  2274. case 'HasAddIn': return true;
  2275. case 'HasSubtype': return true;
  2276. default: return false;
  2277. }
  2278. }
  2279. switch (obj.ReferenceType) {
  2280. case 'Organizes': return true;
  2281. case 'HasComponent': return true;
  2282. case 'HasProperty': return true;
  2283. case 'HasAddIn': return true;
  2284. case 'HasSubtype': return true;
  2285. default: return false;
  2286. }
  2287. return false;
  2288. }
  2289. function checkDouble(item, obj){
  2290. for(let i = 0; i < obj.length; i++){
  2291. if(item.id === obj[i].id){
  2292. return true;
  2293. }
  2294. }
  2295. return false;
  2296. }
  2297. /*
  2298. app.get('/lazy', (req, res) => {
  2299. //console.log(req);
  2300. var ret_obj = [];
  2301. let node = {};
  2302. if(req.query.id == "#"){
  2303. //res.json([{id:"i=84",text:"Root",data:{nodeclass:"Object"},children:true}]);
  2304. res.json([{id:"i=84",text:"Root",data:{nodeclass:"Object", idx:0},children:[{id:"i=85",text:"Objects",data:{nodeclass:"Object", idx:0},children:true},{id:"i=86",text:"Types", data:{nodeclass:"Object", idx:0},children:true},{id:"i=87",text:"View",data:{nodeclass:"Object", idx:0},children:true}]}]);
  2305. }
  2306. var nid = req.query.id;
  2307. node = searchNode(nid);
  2308. console.log(node);
  2309. if(node.data.references != null){
  2310. console.log("Here:"+node.data.references);
  2311. if(Array.isArray(node.data.references.Reference)){
  2312. console.log("And:"+node.data.references.Reference);
  2313. for(let x = 0; x < node.data.references.Reference.length; x++ ){
  2314. if(isChildRef(node.data.references.Reference[x])){
  2315. var cnode = searchNode(node.data.references.Reference[x].$t);
  2316. if(!checkDouble(cnode,ret_obj)){
  2317. ret_obj.push(cnode);
  2318. }
  2319. }
  2320. }
  2321. }else{
  2322. console.log("But:"+node.data.references);
  2323. if(isChildRef(node.data.references)){
  2324. var cnode = searchNode(node.data.references.$t);
  2325. if(!checkDouble(cnode,ret_obj)){
  2326. ret_obj.push(cnode);
  2327. }
  2328. }
  2329. }
  2330. }
  2331. getAllChildren(nid, ret_obj);
  2332. console.log(ret_obj);
  2333. res.json(ret_obj);
  2334. });
  2335. */
  2336. app.get('/lazy', async function(req, res) {
  2337. var ret_obj = [];
  2338. let node = {};
  2339. if(req.query.id == "#"){
  2340. res.json([{id:"i=84",text:"Root",data:{nodeclass:"Object", nsindex:0},children:[{id:"i=85",text:"Objects",data:{nodeclass:"Object", nsindex:0},children:true},{id:"i=86",text:"Types", data:{nodeclass:"Object", nsindex:0},children:true},{id:"i=87",text:"View",data:{nodeclass:"Object", nsindex:0},children:true}]}]);
  2341. return 0;
  2342. }
  2343. var nid = req.query.id;
  2344. var idx = req.query.nsindex;
  2345. var classn = req.query.nodeclass;
  2346. var class_name = "";
  2347. switch(classn){
  2348. case "ObjectType": class_name="objecttypes"; break;
  2349. case "Object": class_name="objects"; break;
  2350. case "VariableType": class_name="variabletypes"; break;
  2351. case "DataType": class_name="datatypes"; break;
  2352. case "ReferenceType": class_name="referencetypes"; break;
  2353. case "Variable": class_name="variables"; break;
  2354. case "Method": class_name="methods"; break;
  2355. default: class_name="objects";
  2356. }
  2357. var obj = await getThisNode(idx, nid, class_name);
  2358. //console.log(obj);
  2359. var ch = await getChildrenSql(idx, obj.id);
  2360. //console.log(ch);
  2361. for(let j = 0; j < ch.length; j++){
  2362. classn = ch[j][2];
  2363. switch(classn){
  2364. case "ObjectType": class_name="objecttypes"; break;
  2365. case "Object": class_name="objects"; break;
  2366. case "VariableType": class_name="variabletypes"; break;
  2367. case "DataType": class_name="datatypes"; break;
  2368. case "ReferenceType": class_name="referencetypes"; break;
  2369. case "Variable": class_name="variables"; break;
  2370. case "Method": class_name="methods"; break;
  2371. default: class_name="objects";
  2372. }
  2373. console.log(ch[j][1]+","+ch[j][0]+","+class_name);
  2374. var ch0 = await getThisNode(ch[j][1],ch[j][0],class_name);
  2375. console.log(ch0);
  2376. }
  2377. //console.log(ch);
  2378. node = searchNode(nid);
  2379. //console.log(node);
  2380. if(node.data.references != null){
  2381. //console.log("Here:"+node.data.references);
  2382. if(Array.isArray(node.data.references.Reference)){
  2383. //console.log("And:"+node.data.references.Reference);
  2384. for(let x = 0; x < node.data.references.Reference.length; x++ ){
  2385. if(isChildRef(node.data.references.Reference[x])){
  2386. var cnode = searchNode(node.data.references.Reference[x].$t);
  2387. if(!checkDouble(cnode,ret_obj)){
  2388. ret_obj.push(cnode);
  2389. }
  2390. }
  2391. }
  2392. }else{
  2393. //console.log("But:"+node.data.references);
  2394. if(isChildRef(node.data.references)){
  2395. var cnode = searchNode(node.data.references.$t);
  2396. if(!checkDouble(cnode,ret_obj)){
  2397. ret_obj.push(cnode);
  2398. }
  2399. }
  2400. }
  2401. }
  2402. getAllChildren(nid, ret_obj);
  2403. //console.log(ret_obj);
  2404. res.json(ret_obj);
  2405. });
  2406. app.get('/index/:ns1/:ns2', (req, res) => {
  2407. var n1 = req.params["ns1"];
  2408. var n2 = req.params["ns2"];
  2409. var num = getIndexObj(ns_array[n1][0],ns_array[n2][0]);
  2410. console.log(getNode(ns_array[3][0],2,15048));
  2411. res.send("Index of "+ns_array[n2][1]+' in '+ns_array[n1][1]+' is '+num);
  2412. });
  2413. app.get('/test/:id', (req, res) => { //test
  2414. var n1 = parseInt(req.params["id"]);
  2415. console.log(ns_array[n1][1],);
  2416. var ret = searchNode("i=85");
  2417. console.log(ret);
  2418. res.send("All good");
  2419. //res.json([{id:"i=84",text:"Root",children:[{id:"i=85",text:"Objects",children:true},{id:"i=86",text:"Types", children:true},{id:"i=87",text:"View",children:false}]}]);
  2420. })
  2421. app.get('/require/all', (req, res) => { //test
  2422. ns_array.push([jsn, "base", jsn.UANodeSet.Models.Model.ModelUri]);
  2423. ns_array.push([di, "di", di.UANodeSet.Models.Model.ModelUri]);
  2424. ns_array.push([ia, "ia", ia.UANodeSet.Models.Model.ModelUri]);
  2425. ns_array.push([mach, "mach", mach.UANodeSet.Models.Model.ModelUri]);
  2426. ns_array.push([mt, "mt", mt.UANodeSet.Models.Model.ModelUri]);
  2427. res.json({result:"OK"});
  2428. })
  2429. app.listen(port, () => {
  2430. console.log("Server listening at http://localhost:", port);
  2431. })