1
0
mirror of https://github.com/node-red/node-red-nodes.git synced 2023-10-10 13:36:58 +02:00

updates to mpd node

This commit is contained in:
Dave C-J 2014-05-17 21:06:58 +01:00
parent 9adc2b2687
commit f9ff63c346
2 changed files with 8 additions and 11 deletions

View File

@ -24,7 +24,7 @@
<script type="text/x-red" data-help-name="mpd out"> <script type="text/x-red" data-help-name="mpd out">
<p>MPD music control output node.</p> <p>MPD music control output node.</p>
<p>Expects <b>msg.payload</b> to be a valid mpc command. Currently only simple commands that expect no reply are supported.</p> <p>Expects <b>msg.payload</b> to be a valid mpc command. Currently only simple commands that expect no reply are supported. play, pause, next, previous, stop, etc.</p>
</script> </script>
<script type="text/javascript"> <script type="text/javascript">
@ -57,7 +57,7 @@
<script type="text/x-red" data-help-name="mpd in"> <script type="text/x-red" data-help-name="mpd in">
<p>MPD music control input node.</p> <p>MPD music control input node.</p>
<p>Creates a <b>msg.payload</b> object with Artist, Album, Track, Genre and Date.</p> <p>Creates a <b>msg.payload</b> object containing Artist, Album, Track, Genre and Date.</p>
</script> </script>
<script type="text/javascript"> <script type="text/javascript">

View File

@ -21,15 +21,13 @@ var komponist = require('komponist');
var mpc = null; var mpc = null;
exec("which mpd",function(err,stdout,stderr) { exec("which mpd",function(err,stdout,stderr) {
if (stdout.indexOf('mpd') == -1) { if (stdout.indexOf('mpd') == -1) {
util.log('[69-mpd.js] Error: Cannot find "mpd" command. Please install MPD.'); throw 'Error: Cannot find "mpd" command. Please install MPD.';
return;
} }
}); });
exec("netstat -an | grep LISTEN | grep 6600",function(err,stdout,stderr) { exec("netstat -an | grep LISTEN | grep 6600",function(err,stdout,stderr) {
if (stdout.indexOf('6600') == -1) { if (stdout.indexOf('6600') == -1) {
util.log('[69-mpd.js] Warning: MPD daemon not listening on port 6600. Please start MPD.'); throw '[69-mpd.js] Error: MPD daemon not listening on port 6600. Please start MPD.';
return;
} }
komponist.createConnection(6600, 'localhost', function(err, client) { komponist.createConnection(6600, 'localhost', function(err, client) {
if (err) node.error("MPD: Failed to connect to MPD server"); if (err) node.error("MPD: Failed to connect to MPD server");
@ -46,19 +44,18 @@ function MPDOut(n) {
if (mpc != null) { if (mpc != null) {
this.on("input", function(msg) { this.on("input", function(msg) {
if (msg != null) { if (msg != null) {
console.log(msg);
try { try {
//node.mpc.command(msg.payload); //node.mpc.command(msg.payload);
node.mpc.command(msg.payload, msg.param, function(err, results) { node.mpc.command(msg.payload, msg.param, function(err, results) {
if (err) { console.log("MPD: Error:",err); } if (err) { node.log("error: "+err); }
//else { console.log(results); } //else { console.log(results); }
}); });
} catch (err) { console.log("MPD: Error:",err); } } catch (err) { node.log("error: "+err); }
} }
}); });
node.mpc.on('error', function(err) { node.mpc.on('error', function(err) {
console.log("MPD: Error:",err); node.log("error: "+err);
}); });
} }
else { node.warn("MPD not running"); } else { node.warn("MPD not running"); }
@ -76,7 +73,7 @@ function MPDIn(n) {
function getSong() { function getSong() {
node.mpc.currentsong(function(err, info) { node.mpc.currentsong(function(err, info) {
if (err) console.log(err); if (err) node.log(err);
else { else {
var msg = {payload:{},topic:"music"}; var msg = {payload:{},topic:"music"};
msg.payload.Artist = info.Artist; msg.payload.Artist = info.Artist;