Thanks to your flow and this topic I managed to do something similar, yes with puppet but it must be used in chrome for it to work, I attach my example flow for future ideas or help and thank you in advance mate:
flow:
[
{
"id": "fa1432119f33bbfb",
"type": "inject",
"z": "67c61941.053d58",
"name": "",
"props": [
{
"p": "payload"
},
{
"p": "topic",
"vt": "str"
}
],
"repeat": "",
"crontab": "",
"once": false,
"onceDelay": 0.1,
"topic": "",
"payload": "",
"payloadType": "date",
"x": 420,
"y": 1500,
"wires": [
[
"08d8e18d7ce7c0ee"
]
]
},
{
"id": "08d8e18d7ce7c0ee",
"type": "puppeteer-browser-launch",
"z": "67c61941.053d58",
"timeout": "7000",
"slowMo": 0,
"headless": true,
"debugport": 0,
"devtools": false,
"cookies": "",
"name": "",
"x": 620,
"y": 1500,
"wires": [
[
"2671441d86f84188"
]
]
},
{
"id": "e17eeca2886e7d9e",
"type": "puppeteer-page-goto",
"z": "67c61941.053d58",
"name": "LINK",
"url": "http://127.0.0.1:1880/ui/#!/21?socketid=H38GHI0t_eSHpxjMAAAL",
"urltype": "str",
"waitUntil": "networkidle2",
"x": 610,
"y": 1380,
"wires": [
[
"89479f5b9ca016a9"
]
]
},
{
"id": "89479f5b9ca016a9",
"type": "puppeteer-page-screenshot",
"z": "67c61941.053d58",
"name": "",
"fullpage": true,
"x": 130,
"y": 1240,
"wires": [
[
"363b82550dbd1544",
"65ba01c8108db452"
]
]
},
{
"id": "2671441d86f84188",
"type": "puppeteer-page-viewport",
"z": "67c61941.053d58",
"name": "",
"width": "1920",
"height": "1000",
"scale": 1,
"x": 620,
"y": 1440,
"wires": [
[
"e17eeca2886e7d9e"
]
]
},
{
"id": "3749cf6b2b9cbcea",
"type": "puppeteer-browser-close",
"z": "67c61941.053d58",
"name": "",
"x": 820,
"y": 1320,
"wires": [
[
"029730d8083b07b0"
]
]
},
{
"id": "363b82550dbd1544",
"type": "function",
"z": "67c61941.053d58",
"name": "Select Last Value",
"func": "msg.topic = \"SELECT * FROM plc.oee_kpi ORDER BY Fecha DESC LIMIT 1;\";\nreturn msg;",
"outputs": 1,
"noerr": 0,
"initialize": "",
"finalize": "",
"libs": [],
"x": 170,
"y": 1400,
"wires": [
[
"ba45e10e55eb771c"
]
]
},
{
"id": "ba45e10e55eb771c",
"type": "mysql",
"z": "67c61941.053d58",
"mydb": "fb05e811b8b0da75",
"name": "",
"x": 330,
"y": 1400,
"wires": [
[
"33f2686f507a65bb"
]
]
},
{
"id": "33f2686f507a65bb",
"type": "function",
"z": "67c61941.053d58",
"name": "FORMATO DE TABLA",
"func": "//datatime\nvar time = new Date().toLocaleString(\"co\");\nvar imagePath = global.get('image')\n\n\t// Ahora 'data' contiene el contenido de la imagen en un Buffer\n\n//Average/Valor Promedio\nvar a = msg.payload[0][\"Tipodefalla\"];\nvar b = msg.payload[0][\"Turno\"];\nvar c = msg.payload[0][\"Tiemposdeparada\"];\nvar d = msg.payload[0][\"Tiemposdereparacion\"];\nvar e = msg.payload[0][\"Tiempodearranque\"];\n\n\n\nmsg.payload = {\n\tpageOrientation: 'LANDSCAPE',\n\tcontent: [\n\t\t{\n\t\t\timage: '',\n\t\twidth:50},\n\t\t{text: 'Curso: Interfaz MySQL con PLC vía Node-RED', style: 'header'},\n\t\t{text: 'Tema: Generación de Informes en pdf', style: 'header'},\n\t\t{text:'Reporte generado el: '+time+' \\n\\n' },\n\t\t\n\t\t'Ahora puede generar informes personalizados de sus datos en Node-RED. Este es solo un informe de muestra generado para explicar la función. Se puede personalizar el informe según sus preferencias.',\n\t\t{text: 'Valores del mundo real de la tabla de la base de datos MySQL llamada `plc.tanklevel`', style: 'subheader'},\n\t\t'La siguiente tabla muestra los valores provenientes del PLC',\n\t\n\t {text: 'Valores PLC', style: 'subheader'},\n\t\t{\n\t\t\tstyle: 'tableExample',\n\t\t\ttable: {\n\t\t\t\tbody: [\n\t\t\t\t\t[{text:'OEE_ME', style: 'tableHeader'}, {text:'RECHAZO', style: 'tableHeader'}, {text:'ENERGIA_ACTUAL', style: 'tableHeader'}, {text:'AIRE_ACTUAL', style: 'tableHeader'},{text:'GAS_ACTUAL', style: 'tableHeader'}],\n\t\t\t\t\t[\"\"+a+\"\", \"\"+b+\"\", \"\"+c+\"\",\"\"+d+\"\",\"\"+e+\"\"]\n\n\t\t\t\t\n\t\t\t\t]\n\t\t\t},\n\t\t\t\n\t\t},\n\t\t{\n\t\t\timage: 'data:image/jpeg;base64,\"'+imagePath+'\"',\n\t\t\twidth: 700\n\t\t},\n\t\t\t\t\t\t\n\t\t\n\t\t\n\t\t\n\t\t{text: 'Hardware usado', style: 'subheader'},\n\t {\n\t\t\tul: [\n\t\t\t\t{text: 'Siemens S7-1200 con OPC UA'},\n\t\t\t\t{text: 'PLC Ethernet cable'},\n\t\t\t\t{text: '24VDC Power supply'},\n\t\t\t]\n\t\t},\n\t\t\n\t\t\t{text: 'Software usado', style: 'subheader'},\n\t {\n\t\t\tul: [\n\t\t\t\t{text: 'TIA Portal v17'},\n\t\t\t\t{text: 'IOT', color: 'purple'},\n\t\t\t\t//{text: 'Prototipo'},\n\t\t\t]\n\t\t},\n\t\t\n\t\t/*{text: 'Visítenos (Hipervinculado)', style: 'header'},\n\t\t{\n\t\t\tul: [\n\t\t\t\t//{text: 'Escuela de aprendizaje electrónico', color: 'purple' ,link: 'http://learn.codeandcompile.com' },\n\t\t\t\t{text: 'YouTube', color: 'purple', link: 'https://www.youtube.com/channel/UC4rqWPxMnjbOAhKfbse-5Wg/featured' },\n\t\t\t\t{text: 'Instagram', color: 'purple', link: '' },\n\t\t\t]\n\t\t},*/\n\t\t\t{\n\t\t\ttext: '\\n Este documento se genera únicamente con fines de capacitación. Los datos dentro de este documento no provienen de ninguna fuente comprometida. Para cualquier información contactar con Soporte',\n\t\t\tstyle: ['quote', 'small']\n\t\t}\n\n\n ],\n \tstyles: {\n\t\theader: {\n\t\t\tfontSize: 18,\n\t\t\tbold: true,\n\t\t\tmargin: [0, 0, 0, 10]\n\t\t\t\n\t\t},\n\t\tsubheader: {\n\t\t\tfontSize: 16,\n\t\t\tbold: true,\n\t\t\tmargin: [0, 10, 0, 5]\n\t\t},\n\t\ttableExample: {\n\t\t\tmargin: [0, 5, 0, 15],\n\t\t\talignment: 'center'\n\t\t},\n\t\ttableHeader: {\n\t\t\tbold: true,\n\t\t\tfontSize: 13,\n\t\t\tcolor: 'black'\n\t\t},\n\t\t\tquote: {\n\t\t\titalics: true\n\t\t}\n \t}\n};\nreturn msg;",
"outputs": 1,
"noerr": 0,
"initialize": "",
"finalize": "",
"libs": [],
"x": 400,
"y": 1240,
"wires": [
[
"0666a43e7b8d954e"
]
]
},
{
"id": "029730d8083b07b0",
"type": "file",
"z": "67c61941.053d58",
"name": "",
"filename": "C:\\Users\\Cristian Torres\\Desktop\\Reportes\\Informe.pdf",
"filenameType": "str",
"appendNewline": true,
"createDir": true,
"overwriteFile": "true",
"encoding": "none",
"x": 1000,
"y": 1240,
"wires": [
[]
]
},
{
"id": "0666a43e7b8d954e",
"type": "pdfmake",
"z": "67c61941.053d58",
"name": "",
"outputType": "Buffer",
"inputProperty": "payload",
"options": "{}",
"outputProperty": "payload",
"x": 660,
"y": 1240,
"wires": [
[
"029730d8083b07b0"
]
]
},
{
"id": "585ccd1f08c8c921",
"type": "function",
"z": "67c61941.053d58",
"name": "function 199",
"func": "global.set('image', msg.payload)\nreturn msg;",
"outputs": 1,
"noerr": 0,
"initialize": "",
"finalize": "",
"libs": [],
"x": 450,
"y": 1200,
"wires": [
[]
]
},
{
"id": "65ba01c8108db452",
"type": "base64",
"z": "67c61941.053d58",
"name": "",
"action": "",
"property": "payload",
"x": 260,
"y": 1200,
"wires": [
[
"585ccd1f08c8c921"
]
]
},
{
"id": "fb05e811b8b0da75",
"type": "MySQLdatabase",
"name": "",
"host": "127.0.0.1",
"port": "3306",
"db": "plc",
"tz": "",
"charset": "UTF8"
}
]