Finally, success! And good grief what an attractive and informative map it isn't.
For anyone else struggling to do the same, here is the flow
[{"id":"5631f7912941c322","type":"group","z":"c91127da6284d27f","name":"Get met office image","style":{"label":true},"nodes":["f702f183af723971","5d9e0666bcc209cf","42481690ebe765d5","eac3d3c6a4ac4346","085eaef8065fde64","86f5347dd5e757b5","56c52ebeef0d8c7c"],"x":14,"y":79,"w":832,"h":122},{"id":"f702f183af723971","type":"inject","z":"c91127da6284d27f","g":"5631f7912941c322","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"","payloadType":"date","x":120,"y":120,"wires":[["5d9e0666bcc209cf"]]},{"id":"5d9e0666bcc209cf","type":"function","z":"c91127da6284d27f","g":"5631f7912941c322","name":"set payload and headers","func":"const clientid = flow.get(\"MetClientID\") || \"32hex\"\nconst clientsecret = flow.get(\"MetClientSecret\") || \"32hex\"\nconst orderid = flow.get(\"MetOrderNo\") || \"o12digits\"\n\nmsg.url = 'https://api-metoffice.apiconnect.ibmcloud.com/metoffice/production/map-images/1.0.0/orders/' + orderid + '/latest/land_cover_ts0_+00/data'\nmsg.headers = {\n 'x-ibm-client-id': clientid,\n 'x-ibm-client-secret': clientsecret\n}\nreturn msg;\n","outputs":1,"timeout":"","noerr":0,"initialize":"","finalize":"","libs":[],"x":330,"y":120,"wires":[["42481690ebe765d5"]]},{"id":"42481690ebe765d5","type":"http request","z":"c91127da6284d27f","g":"5631f7912941c322","name":"","method":"GET","ret":"bin","paytoqs":"ignore","url":"","tls":"","persist":false,"proxy":"","insecureHTTPParser":false,"authType":"","senderr":false,"headers":[],"x":550,"y":120,"wires":[["085eaef8065fde64","eac3d3c6a4ac4346"]]},{"id":"eac3d3c6a4ac4346","type":"file","z":"c91127da6284d27f","g":"5631f7912941c322","name":"","filename":"/home/pi/.node-red/node-red-static/foo.png","filenameType":"str","appendNewline":false,"createDir":false,"overwriteFile":"true","encoding":"setbymsg","x":650,"y":160,"wires":[[]]},{"id":"085eaef8065fde64","type":"debug","z":"c91127da6284d27f","g":"5631f7912941c322","name":"debug 402","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":730,"y":120,"wires":[]},{"id":"86f5347dd5e757b5","type":"inject","z":"c91127da6284d27f","g":"5631f7912941c322","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"","payloadType":"date","x":120,"y":160,"wires":[["56c52ebeef0d8c7c"]]},{"id":"56c52ebeef0d8c7c","type":"ui_template","z":"c91127da6284d27f","g":"5631f7912941c322","group":"f149abdd741ca58e","name":"","order":3,"width":0,"height":0,"format":"<div>\n <img src = \"/foo.png\"></img>\n</div>","storeOutMessages":true,"fwdInMessages":true,"resendOnRefresh":true,"templateScope":"local","className":"","x":280,"y":160,"wires":[[]]},{"id":"f149abdd741ca58e","type":"ui_group","name":"Demo","tab":"1caa8458.b17814","order":1,"disp":true,"width":"12","collapse":false,"className":"test"},{"id":"1caa8458.b17814","type":"ui_tab","name":"Demo","icon":"dashboard","order":3,"disabled":false,"hidden":false}]