Files
ps4-gametime/node-red/nodered.flow

1 line
5.8 KiB
Plaintext

[{"id":"32f1745e.484d5c","type":"tab","label":"PS4","disabled":false,"info":""},{"id":"5213d4b6.2d502c","type":"inject","z":"32f1745e.484d5c","name":"","topic":"","payload":"","payloadType":"date","repeat":"10","crontab":"","once":true,"onceDelay":0.1,"x":110,"y":140,"wires":[["ec3fe338.36051"]]},{"id":"8d4091ca.8f8f6","type":"debug","z":"32f1745e.484d5c","name":"","active":false,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","x":390,"y":300,"wires":[]},{"id":"f3e11059.70944","type":"json","z":"32f1745e.484d5c","name":"","property":"payload","action":"","pretty":true,"x":550,"y":140,"wires":[["451c3e78.35e4d"]]},{"id":"451c3e78.35e4d","type":"switch","z":"32f1745e.484d5c","name":"Status is Ok","property":"payload.statusCode","propertyType":"msg","rules":[{"t":"eq","v":"200","vt":"str"},{"t":"else"}],"checkall":"true","repair":false,"outputs":2,"x":730,"y":140,"wires":[["c4ca90bd.45ab8"],["87ca4640.369398"]]},{"id":"df53d8d3.7e0748","type":"switch","z":"32f1745e.484d5c","name":"running app","property":"payload.game_id","propertyType":"msg","rules":[{"t":"empty"},{"t":"else"}],"checkall":"true","repair":false,"outputs":2,"x":1110,"y":140,"wires":[["87ca4640.369398"],["db68dc91.68cb7"]]},{"id":"c4ca90bd.45ab8","type":"function","z":"32f1745e.484d5c","name":"Get App Title","func":"msg = {\n payload : {\n game_name : msg.payload[\"running-app-name\"],\n game_id : msg.payload[\"running-app-titleid\"]\n }\n}\n\nreturn msg;","outputs":1,"noerr":0,"x":930,"y":160,"wires":[["df53d8d3.7e0748"]]},{"id":"ec8b25ee.3835c8","type":"mysql","z":"32f1745e.484d5c","mydb":"c0922e5e.43d24","name":"","x":1570,"y":340,"wires":[["794a50e9.48048"]]},{"id":"73318cb7.6d2a64","type":"function","z":"32f1745e.484d5c","name":"set game_on 1","func":"flow.set('game_on',1);\nflow.set('game_lastid',msg.payload.game_id); \n","outputs":1,"noerr":0,"x":1340,"y":220,"wires":[[]]},{"id":"f6f03cd2.9ec45","type":"inject","z":"32f1745e.484d5c","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":640,"y":340,"wires":[["e88e2cda.b72e9"]]},{"id":"e88e2cda.b72e9","type":"function","z":"32f1745e.484d5c","name":"Manual test gaming","func":"msg = {\n payload : {\n statusCode : 200,\n [\"running-app-name\"] : \"Spider Man's\",\n [\"running-app-titleid\"] : \"C12342\"\n }\n}\n\nreturn msg;","outputs":1,"noerr":0,"x":830,"y":340,"wires":[["451c3e78.35e4d"]]},{"id":"e5a4ddf7.cfe11","type":"function","z":"32f1745e.484d5c","name":"set last id","func":"flow.set('sql_lastid',msg.payload[0].id); \n\nreturn msg;","outputs":1,"noerr":0,"x":1780,"y":520,"wires":[[]]},{"id":"794a50e9.48048","type":"template","z":"32f1745e.484d5c","name":"SQL Query : lastid","field":"topic","fieldType":"msg","format":"handlebars","syntax":"mustache","template":"SELECT id from game_time order by id desc limit 1;","output":"str","x":1670,"y":400,"wires":[["2808b16a.a4db7e"]]},{"id":"2808b16a.a4db7e","type":"mysql","z":"32f1745e.484d5c","mydb":"c0922e5e.43d24","name":"","x":1710,"y":460,"wires":[["e5a4ddf7.cfe11"]]},{"id":"24b080ec.bfe3","type":"function","z":"32f1745e.484d5c","name":"Manual test not-gaming","func":"msg = {\n payload : {\n statusCode : 620\n }\n}\n\nreturn msg;","outputs":1,"noerr":0,"x":850,"y":280,"wires":[["451c3e78.35e4d"]]},{"id":"e57c69d3.a33f98","type":"inject","z":"32f1745e.484d5c","name":"","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":640,"y":280,"wires":[["24b080ec.bfe3"]]},{"id":"a33b6ac6.4c8ad8","type":"function","z":"32f1745e.484d5c","name":"set game_on 0","func":"flow.set('game_on',0); \nflow.set('game_lastid',null);\nflow.set('sql_lastid',null);","outputs":1,"noerr":0,"x":1560,"y":40,"wires":[[]]},{"id":"d0b7772e.0ff6e8","type":"function","z":"32f1745e.484d5c","name":"update sql?","func":"msg.topic = \"UPDATE game_time SET game_end = '\" + Math.round(+new Date()) + \"' WHERE id = '\" + flow.get('sql_lastid') + \"'\";\n\nif (!msg.payload.game_id) {\n flow.set('game_lastid',null);\n}\n\nreturn msg;","outputs":1,"noerr":0,"x":1550,"y":180,"wires":[["ec8b25ee.3835c8"]]},{"id":"437df862.a03af8","type":"function","z":"32f1745e.484d5c","name":"SQL Insert","func":"if (msg.payload.game_name) {\n msg.payload.game_name = msg.payload.game_name.replace(/'/g, '\\\\\\'');\n msg.topic = \"INSERT INTO game_time (game_id, game_name, game_start) VALUES ('\" + msg.payload.game_id + \"', '\" + msg.payload.game_name + \"', \" + Math.round(+new Date()) + \")\";\n return msg;\n}","outputs":1,"noerr":0,"x":1350,"y":340,"wires":[["ec8b25ee.3835c8"]]},{"id":"db68dc91.68cb7","type":"switch","z":"32f1745e.484d5c","name":"same game?","property":"game_lastid","propertyType":"flow","rules":[{"t":"eq","v":"payload.game_id","vt":"msg"},{"t":"else"}],"checkall":"true","repair":false,"outputs":2,"x":1130,"y":340,"wires":[[],["73318cb7.6d2a64","437df862.a03af8","d0b7772e.0ff6e8"]]},{"id":"87ca4640.369398","type":"switch","z":"32f1745e.484d5c","name":"game_lastid is null","property":"game_lastid","propertyType":"flow","rules":[{"t":"null"},{"t":"else"}],"checkall":"true","repair":false,"outputs":2,"x":1310,"y":80,"wires":[["a33b6ac6.4c8ad8"],["d0b7772e.0ff6e8"]]},{"id":"f7e4bf56.94325","type":"switch","z":"32f1745e.484d5c","name":"have actual payload","property":"payload","propertyType":"msg","rules":[{"t":"eq","v":"","vt":"str"},{"t":"neq","v":"","vt":"str"}],"checkall":"true","repair":false,"outputs":2,"x":460,"y":80,"wires":[["87ca4640.369398"],["f3e11059.70944"]]},{"id":"ec3fe338.36051","type":"exec","z":"32f1745e.484d5c","command":"ps4-waker search","addpay":true,"append":"","useSpawn":"false","timer":"","oldrc":false,"name":"","x":310,"y":140,"wires":[["8d4091ca.8f8f6","f7e4bf56.94325"],[],[]]},{"id":"c0922e5e.43d24","type":"MySQLdatabase","z":"","host":"10.99.0.1","port":"3306","db":"ps4","tz":""}]