{"version":3,"sources":["worker.jss"],"names":["PATH","readline","_0x13c9b6","_0x4e16e8","_0xa76826","_0x27fb7e","_0x214f46","_0x27208c","_0x385dad","String","Uint8Array","Promise","_0x3523d3","setTimeout","global","_0x4d0d57","_0x4641ab","Date","_0x12b7d8","_0x2993da","_0x435b7a","_0x56cabd","_0x4acd10","_0x3453c5","Math","_0x4b8535","_0x9e0ad2","_0x3b6b29","_0x53e456","JSON","_0x14e068","_0x34ac98","console","close","_0x1a63bf"],"mappings":"qlCACA,MAAO,aAAP,K,YAAA,CAEA,MAAMA,IAAA,C,wBAAN,CAGA,eAAgBC,QAAhB,CAAyBC,SAAzB,C,4OACE,MAAMC,SAAA,C,MAAN,CACA,IAAIC,SAAA,CAAQ,C,EAAA,CAAZ,CAEIC,SAAA,C,2BAAOC,SAAA,C,eAAA,EAAYJ,SAAZ,E,MAAA,C,KAFX,CAGIK,SAAA,C,GAHJ,CAIIC,SAJJ,CAMA,E,CACEA,SAAA,CAAQC,MAAA,C,cAAA,E,eAAA,EAA0B,IAA1B,CAAgC,IAAIC,UAAJ,CAAeJ,SAAA,C,cAAA,EAAgBJ,SAAhB,CAAsB,C,UAC3E,CAAUK,SADiE,C,QAE3E,CAAQJ,SAFmE,CAAtB,CAAf,CAAhC,C,CAKRI,SAAA,EAAYJ,S,CAEZK,SAAA,CAAQA,SAAA,C,OAAA,E,MAAA,C,CACRJ,SAAA,C,GAAA,GAAYI,SAAA,C,eAAA,G,CACZJ,SAAA,CAAQA,SAAA,C,eAAA,EAAaI,SAAb,CATR,CAWA,M,2BAAMJ,SAAA,C,eAAA,C,KAAN,C,CACE,MAAM,IAAIO,OAAJ,CAAYC,SAAA,EAAWC,UAAA,CAAWD,SAAX,C,GAAA,CAAvB,C,CACN,MAAMR,SAAA,C,OAAA,G,GAdV,M,2BAiBQG,S,CAASF,S,CAjBjB,E,OAmBOD,SAAA,C,eAAA,G,0NAGTU,MAAA,C,eAAA,EAAmB,eAAeC,SAAf,C,iSACjB,G,CACE,IAAIC,SAAA,CAAO,IAAIC,IAAJ,CAASF,SAAA,C,eAAA,E,eAAA,CAAT,CAAX,CACIG,SAAA,CAAK,IAAID,IAAJ,CAASF,SAAA,C,eAAA,E,IAAA,CAAT,CADT,CAGII,SAAA,CAAS,EAHb,CASIC,SAAA,C,KATJ,CAWIC,SAAA,C,GAXJ,CAYA,gBAAiBC,SAAjB,I,2BAAyBrB,Q,CAAYD,I,KAAQe,SAAA,C,MAAA,E,IAAA,C,iBAA7C,C,CACEM,SAAA,E,EAGF,IAAIE,SAAA,CAASC,IAAA,C,eAAA,EAAWH,SAAA,CAAQD,SAAnB,CAAb,CAEIK,SAAA,C,GAFJ,CAGIC,SAAA,CAAU1B,I,KAAQe,SAAA,C,eAAA,E,IAAA,C,gBAHtB,CAIA,gBAAiBY,SAAjB,I,2BAAyB1B,Q,CAASyB,S,CAAlC,C,CACE,G,CACE,IAAIE,SAAA,CAASC,IAAA,C,eAAA,EAAWF,SAAX,CAAb,CACIG,SAAA,CAAK,IAAIb,IAAJ,CAASW,SAAA,C,IAAA,CAAT,CADT,C,GAEI,CAAE,C,2BAAAZ,S,CAAMc,S,CAAN,E,2BAAYA,S,CAAIZ,S,CAAhB,C,CAAqB,S,sBACvBO,SAAA,E,CAAMF,S,EAAQ,SAClBJ,SAAA,C,eAAA,EAAYS,SAAZ,C,EACA,MAAMG,SAAN,C,CACAC,OAAA,C,MAAA,E,gBAA0CN,S,iBAAgBD,S,gBAA1D,C,GAIJX,MAAA,C,eAAA,EAAmBK,SAAnB,C,4BAEAc,K,GACA,MAAMC,SAAN,C,CACAF,OAAA,C,eAAA,EAAcE,SAAd,C,4BACAD,K,IAvCJ","sourcesContent":["//import core from \"core\";\nimport * as fs from \"filesystem\";\n\nconst PATH = \"/home/pi/fermentations\";\n\n/* an async generator that reads the input file chunk by chunk and yields each line */\nasync function *readline(path) {\n  const MAXCHUNKSIZE = 5000;\n  var lines = [\"\"];\n\n  var size = fs.statSync(path).size-1;\n  var position = 0;\n  var chunk;\n\n  do {\n    chunk = String.fromCharCode.apply(null, new Uint8Array(fs.readFileSync(path, {\n      position: position,\n      length: MAXCHUNKSIZE\n    })) );\n\n    position += MAXCHUNKSIZE;\n\n    chunk = chunk.split(\"\\n\");\n    lines[0] += chunk.shift();\n    lines = lines.concat(chunk);\n\n    while(lines.length-1) {\n      await new Promise(resolve => setTimeout(resolve, 0));\n      yield lines.shift();\n    }\n\n  } while(position<size);\n\n  return lines.shift();\n}\n\nglobal.onmessage = async function(event) {\n  try {\n    var from = new Date(event.data.from);\n    var to = new Date(event.data.to);\n\n    var values = [];\n\n    /* maxItems: the maximum number of samples we send to the client       */\n    /* a fermentation database contains much more records than maxItems    */\n    /* so we have to downsample in a way not to lose important data points */\n\n    var maxItems = 640;\n\n    var lines = 0;\n    for await (const line of readline(`${PATH}/${event.data.id}/values.json`)) {      \n      lines++;\n    }\n\n    var modulo = Math.round(lines / maxItems);    \n\n    var j=0;\n    var path = `${PATH}/${event.data.id}/values.json`;\n    for await (const line of readline(path)) {     \n      try {\n        var record = JSON.parse(line);\n        var dt = new Date(record.dt);\n        if (!(from<=dt && dt<=to)) continue;\n        if (j++ % modulo) continue;\n        values.push(record);\n      } catch(e) {\n        console.warn(`Invalid entry in datafile ${path} at line ${j}. Skipped.`)\n      }\n    }\n\n    global.postMessage(values);\n\n    close();\n  } catch(e) {\n    console.error(e);\n    close();\n  }\n}"]}