Read the statement by Michael Teeuw here.
Run JavaScript if a file is created
-
@KirAsh4 the file wouldn’t have anything in it, it simply would trigger the mirror to display the current train status. The only reason I haven’t just sent a text directly from my phone when I hit a location is because there is no way for me to send the actual trains ETA (and if you’ve rode the MTA before it is always late). I was thinking I could display the results of my mta JS module (which does a JSON pull to their api getting the trains ETA) on the screen only when the file becomes available, thus having to avoid her looking at the mirror showing every trains ETA and only displaying my train. If you have any other suggestions I’d definitely like to try them out; like I said I’m doing this more to learn as well. Thanks!
-
Ok, so if I’m understanding you correctly, your setup is:
- you have a JS script that, which given a trigger, will reach out to the MTA’s API and pull in the train’s ETA
- your phone, through Tasker, will send a notification (in the form of a file creation) to the rpi (which is exposed to the internet?)
What you want is, once that file is created, a message gets displayed on the mirror with the train’s ETA.
What am I missing?
-
@KirAsh4 Yup! That’s exactly what the setup is. The Pi is exposed to the internet via SSH on port 22, I changed the password to something pretty obscure but may look into additional security.
Right now the JS script is running every 5 minutes and presenting the ETA for the train that is currently running closest to the actual time of the day. Problem here is that information clearly isn’t important because I’m at work and not in transit. I was trying to make it more robust in that I am able to use Tasker to ping cell towers and once I am in a specific location, output the file to the Pi to then trigger the script. Of course, if there is a better way I’d absolutely look into that, it was just my first thought on how to accomplish it.
-
Have the script check for the date stamp on the file. Have Tasker just
'touch'the existing file. The script needs to store the date stamp when it checks the file. Something like this:// pseudo code, it won't brew coffee var prev_datestamp = 0; var expire_time = 15 * 60 * 1000; // 15 minutes // run every five minutes if (file exists) { if (file.datestamp > previous_datestamp) { // train is on the way, quick, hide the money, hide the poker table // oh, refresh the mirror too previous_datestamp = file.datestamp; } else if (now > file.datestamp + expire_time) { // it's been 15 minutes, be afraid, be very afraid // clear mirror message } } -
Might be wise to incorporate some AJAX into this, no? Having PHP check the file, etc and then pass the results / message back to JS.
-
Not necessarily:
MM² module --> node_helper --> php --> node_helper --> MM² module -
@KirAsh4 This is awesome!
I would just put this in my JS file, right? I’m currently sending the following command through Tasker to the Pi so I think I’m good.
touch curr-train.txt -
Earlier you mentioned you using PHP, so I kept it in the loop. Use node_helper to call the PHP script. Let the PHP script check for the file and report back to node_helper which in turn reports to the module.
-
@KirAsh4 OK, so my PHP script is actually
index.php, it’s effectively the page that loads and is my Mirror. In that file I have a reference to the JS file which runs the mta code.<script src="js/mm-mta.js"></script>So would I put the following in the PHP page? (sorry if I sound dumb here)
var prev_datestamp = 0; var expire_time = 15 * 60 * 1000; // 15 minutes // run every five minutes if (file exists) { if (file.datestamp > previous_datestamp) { <script src="js/mm-mta.js"></script> previous_datestamp = file.datestamp; } else if (now > file.datestamp + expire_time) { <script src="https://code.jquery.com/jquery-1.10.2.js"></script> <script> $("#mta").empty(); </script> } } -
-
Oy, why do it that way … your index.php will never get updated if there’s an upstream change in the code (because we use index.html). You should use the existing infrastructure in MM². Create a new module, have it display in a specific region on the mirror. Every 5 minutes, have the module refresh by doing a call to its node_helper. The node_helper can be a simply python script that checks the specific file in question and reports back to the module.
I thought the PHP script was doing something … it’s not in this case. You don’t need PHP at all for this.
Some places to look for coding ideas:
MM² Module Development Documentation
Look at how modules such as the calendar and newsfeed implement anode_helperwhich does the background tasksYou could still use PHP to do the file checking for you, but to me that’s a bit of an unnecessary overhead.
-
@KirAsh4 LOL - I’m just lost these days with all of this stuff. I should stick to my DB work.
Let me see what I can do with the module documentation, it would be a good experience anyway to learn.
-
@KirAsh4 Just out of curiosity, if I were to add the code you provided into the PHP file, would i need to bracket it with
<?phpthen add the code here?> -
This is hard to answer because I don’t know what your PHP file looks like. I don’t know if you are
echo-ing HTML data, or usingHEREDOC? I’m flying blind here … (as much fun as that could be) -
@KirAsh4 I had actually uploaded that file a few posts back. For reference here’s the entire thing (forgive the ugliness)
<head> <title>Magic Mirror</title> <html> <style type="text/css"> <?php include('css/main.css') ?> <?php include('css//mbta-icons.css') ?> </style> <link rel="stylesheet" type="text/css" href="css/weather-icons.css"> <script type="text/javascript"> var gitHash = '<?php echo trim(`git rev-parse HEAD`) ?>'; </script> <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> <meta name="google" value="notranslate" /> </head> <body> <div class="backgroundTint"></div> <div class="top left"> <div class="date small dimmed"></div> <div class="time"></div> <div class="timeWarning xxsmall"></div> <div class="holidays xxsmall dimmed"></div> <div class="calendar xxsmall"></div> <div class="mbta xxxsmall dimmed"></div> </div> <div class="top right"> <div class="windsun small dimmed"></div> <div class="temp"></div> <div class="tempfeelslike xxsmall"></div> <div class="spacer"></div> <div class="tempgraph"></div> <div class="weekgraph"></div> <div class="summary xxsmall2 dimmed"></div> <div class="weatheralerts xxsmall2 dimmed"></div> </div> <div class="lower-third center-hor"> <div class="compliment light"></div> <div class="weatherCompliment small light"></div> </div> <div class="bottom center-hor"> <div class="newsTitle xsmall xxdimmed"></div> <div class="news medium"></div> </div> <div class="farbottom center-hor"> <div class="newsDots xxxsmall"></div> </div> <div class="farbottom right"> <div class="lastupdated luWeather xxxsmall xxdimmed"></div> <div class="lastupdated luMBTA xxxsmall xxdimmed"></div> <div class="lastupdated luRSS xxxsmall xxdimmed"></div> <div class="lastupdated luHolidays xxxsmall xxdimmed"></div> </div> </div> <!-- Third Parties --> <script src="js/jquery.js"></script> <script src="js/ical_parser.js"></script> <script src="js/moment-with-locales.js"></script> <script src="js/config.js"></script> <script src="js/rrule.js"></script> <script src="js/d3.js"></script> <!-- Our Stuff --> <script src="js/main.js?nocache=<?php echo md5(microtime()) ?>"></script> <script src="js/mm-weather.js?nocache=<?php echo md5(microtime()) ?>"></script> <script src="js/mm-mbta.js?nocache=<?php echo md5(microtime()) ?>"></script> <script src="js/mm-mta.js?nocache=<?php echo md5(microtime()) ?>"></script> </html> </body> -
Then yes, write the proper PHP code and stick it in
<?php ... ?>tags. -
@KirAsh4 awesome, I will give it a shot. I can’t thank you enough! Much appreciated!
-
@KirAsh4 Ah I wasn’t aware this was for MM2. Thought he was still using MM1. Didn’t know you could run PHP scripts on MM2.
-
@EoF, you can, as an external process, just like everything else. :)
Hello! It looks like you're interested in this conversation, but you don't have an account yet.
Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.
With your input, this post could be even better 💗
Register Login