summaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorKarl 'vollmerk' Vollmer <vollmer@ampache.org>2006-10-09 05:46:40 +0000
committerKarl 'vollmerk' Vollmer <vollmer@ampache.org>2006-10-09 05:46:40 +0000
commit78590d7d512ada604987fdcc9c31a8c74591f64b (patch)
tree00e7cbb628f6c099cc51df7a86f85be3c5d5ca42 /modules
parentd885efaed4bdfbac1df06e0ff3a4fd0d46701b96 (diff)
downloadampache-78590d7d512ada604987fdcc9c31a8c74591f64b.tar.gz
ampache-78590d7d512ada604987fdcc9c31a8c74591f64b.tar.bz2
ampache-78590d7d512ada604987fdcc9c31a8c74591f64b.zip
fixed a problem with preferences showing disabled localplay modules, included sajax library
Diffstat (limited to 'modules')
-rw-r--r--modules/sajax/Sajax.php373
-rwxr-xr-xmodules/slimserver/slim.class.php295
2 files changed, 523 insertions, 145 deletions
diff --git a/modules/sajax/Sajax.php b/modules/sajax/Sajax.php
new file mode 100644
index 00000000..a74a4aff
--- /dev/null
+++ b/modules/sajax/Sajax.php
@@ -0,0 +1,373 @@
+<?php
+/*
+ SAJAX PHP BACKEND
+ -----------------
+
+ Contributed and copyighted by Thomas Lackner and ModernMethod
+ (http://www.modernmethod.com/).
+
+ Licence: GNU/GPL
+
+*/
+
+
+if (!isset($SAJAX_INCLUDED)) {
+
+ /*
+ * GLOBALS AND DEFAULTS
+ *
+ */
+ $GLOBALS['sajax_version'] = '0.12';
+ $GLOBALS['sajax_debug_mode'] = 0;
+ $GLOBALS['sajax_export_list'] = array();
+ $GLOBALS['sajax_request_type'] = 'GET';
+ $GLOBALS['sajax_remote_uri'] = '';
+ $GLOBALS['sajax_failure_redirect'] = '';
+
+ /*
+ * CODE
+ *
+ */
+
+ //
+ // Initialize the Sajax library.
+ //
+ function sajax_init() {
+ }
+
+ //
+ // Helper function to return the script's own URI.
+ //
+ function sajax_get_my_uri() {
+ return $_SERVER["REQUEST_URI"];
+ }
+ $sajax_remote_uri = sajax_get_my_uri();
+
+ //
+ // Helper function to return an eval()-usable representation
+ // of an object in JavaScript.
+ //
+ function sajax_get_js_repr($value) {
+ $type = gettype($value);
+
+ if ($type == "boolean") {
+ return ($value) ? "Boolean(true)" : "Boolean(false)";
+ }
+ elseif ($type == "integer") {
+ return "parseInt($value)";
+ }
+ elseif ($type == "double") {
+ return "parseFloat($value)";
+ }
+ elseif ($type == "array" || $type == "object" ) {
+ //
+ // XXX Arrays with non-numeric indices are not
+ // permitted according to ECMAScript, yet everyone
+ // uses them.. We'll use an object.
+ //
+ $s = "{ ";
+ if ($type == "object") {
+ $value = get_object_vars($value);
+ }
+ foreach ($value as $k=>$v) {
+ $esc_key = sajax_esc($k);
+ if (is_numeric($k))
+ $s .= "$k: " . sajax_get_js_repr($v) . ", ";
+ else
+ $s .= "\"$esc_key\": " . sajax_get_js_repr($v) . ", ";
+ }
+ if (count($value))
+ $s = substr($s, 0, -2);
+ return $s . " }";
+ }
+ else {
+ $esc_val = sajax_esc($value);
+ $s = "'$esc_val'";
+ return $s;
+ }
+ }
+
+ function sajax_handle_client_request() {
+ global $sajax_export_list;
+
+ $mode = "";
+
+ if (! empty($_GET["rs"]))
+ $mode = "get";
+
+ if (!empty($_POST["rs"]))
+ $mode = "post";
+
+ if (empty($mode))
+ return;
+
+ $target = "";
+
+ if ($mode == "get") {
+ // Bust cache in the head
+ header ("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // Date in the past
+ header ("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
+ // always modified
+ header ("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
+ header ("Pragma: no-cache"); // HTTP/1.0
+ $func_name = $_GET["rs"];
+ if (! empty($_GET["rsargs"]))
+ $args = $_GET["rsargs"];
+ else
+ $args = array();
+ }
+ else {
+ $func_name = $_POST["rs"];
+ if (! empty($_POST["rsargs"]))
+ $args = $_POST["rsargs"];
+ else
+ $args = array();
+ }
+
+ if (! in_array($func_name, $sajax_export_list))
+ echo "-:$func_name not callable";
+ else {
+ echo "+:";
+ $result = call_user_func_array($func_name, $args);
+ echo "var res = " . trim(sajax_get_js_repr($result)) . "; res;";
+ }
+ exit;
+ }
+
+ function sajax_get_common_js() {
+ global $sajax_debug_mode;
+ global $sajax_request_type;
+ global $sajax_remote_uri;
+ global $sajax_failure_redirect;
+
+ $t = strtoupper($sajax_request_type);
+ if ($t != "" && $t != "GET" && $t != "POST")
+ return "// Invalid type: $t.. \n\n";
+
+ ob_start();
+ ?>
+
+ // remote scripting library
+ // (c) copyright 2005 modernmethod, inc
+ var sajax_debug_mode = <?php echo $sajax_debug_mode ? "true" : "false"; ?>;
+ var sajax_request_type = "<?php echo $t; ?>";
+ var sajax_target_id = "";
+ var sajax_failure_redirect = "<?php echo $sajax_failure_redirect; ?>";
+
+ function sajax_debug(text) {
+ if (sajax_debug_mode)
+ alert(text);
+ }
+
+ function sajax_init_object() {
+ sajax_debug("sajax_init_object() called..")
+
+ var A;
+
+ var msxmlhttp = new Array(
+ 'Msxml2.XMLHTTP.5.0',
+ 'Msxml2.XMLHTTP.4.0',
+ 'Msxml2.XMLHTTP.3.0',
+ 'Msxml2.XMLHTTP',
+ 'Microsoft.XMLHTTP');
+ for (var i = 0; i < msxmlhttp.length; i++) {
+ try {
+ A = new ActiveXObject(msxmlhttp[i]);
+ } catch (e) {
+ A = null;
+ }
+ }
+
+ if(!A && typeof XMLHttpRequest != "undefined")
+ A = new XMLHttpRequest();
+ if (!A)
+ sajax_debug("Could not create connection object.");
+ return A;
+ }
+
+ var sajax_requests = new Array();
+
+ function sajax_cancel() {
+ for (var i = 0; i < sajax_requests.length; i++)
+ sajax_requests[i].abort();
+ }
+
+ function sajax_do_call(func_name, args) {
+ var i, x, n;
+ var uri;
+ var post_data;
+ var target_id;
+
+ sajax_debug("in sajax_do_call().." + sajax_request_type + "/" + sajax_target_id);
+ target_id = sajax_target_id;
+ if (typeof(sajax_request_type) == "undefined" || sajax_request_type == "")
+ sajax_request_type = "GET";
+
+ uri = "<?php echo $sajax_remote_uri; ?>";
+ if (sajax_request_type == "GET") {
+
+ if (uri.indexOf("?") == -1)
+ uri += "?rs=" + escape(func_name);
+ else
+ uri += "&rs=" + escape(func_name);
+ uri += "&rst=" + escape(sajax_target_id);
+ uri += "&rsrnd=" + new Date().getTime();
+
+ for (i = 0; i < args.length-1; i++)
+ uri += "&rsargs[]=" + escape(args[i]);
+
+ post_data = null;
+ }
+ else if (sajax_request_type == "POST") {
+ post_data = "rs=" + escape(func_name);
+ post_data += "&rst=" + escape(sajax_target_id);
+ post_data += "&rsrnd=" + new Date().getTime();
+
+ for (i = 0; i < args.length-1; i++)
+ post_data = post_data + "&rsargs[]=" + escape(args[i]);
+ }
+ else {
+ alert("Illegal request type: " + sajax_request_type);
+ }
+
+ x = sajax_init_object();
+ if (x == null) {
+ if (sajax_failure_redirect != "") {
+ location.href = sajax_failure_redirect;
+ return false;
+ } else {
+ sajax_debug("NULL sajax object for user agent:\n" + navigator.userAgent);
+ return false;
+ }
+ } else {
+ x.open(sajax_request_type, uri, true);
+ // window.open(uri);
+
+ sajax_requests[sajax_requests.length] = x;
+
+ if (sajax_request_type == "POST") {
+ x.setRequestHeader("Method", "POST " + uri + " HTTP/1.1");
+ x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
+ }
+
+ x.onreadystatechange = function() {
+ if (x.readyState != 4)
+ return;
+
+ sajax_debug("received " + x.responseText);
+
+ var status;
+ var data;
+ var txt = x.responseText.replace(/^\s*|\s*$/g,"");
+ status = txt.charAt(0);
+ data = txt.substring(2);
+
+ if (status == "") {
+ // let's just assume this is a pre-response bailout and let it slide for now
+ } else if (status == "-")
+ alert("Error: " + data);
+ else {
+ if (target_id != "")
+ document.getElementById(target_id).innerHTML = eval(data);
+ else {
+ try {
+ var callback;
+ var extra_data = false;
+ if (typeof args[args.length-1] == "object") {
+ callback = args[args.length-1].callback;
+ extra_data = args[args.length-1].extra_data;
+ } else {
+ callback = args[args.length-1];
+ }
+ callback(eval(data), extra_data);
+ } catch (e) {
+ sajax_debug("Caught error " + e + ": Could not eval " + data );
+ }
+ }
+ }
+ }
+ }
+
+ sajax_debug(func_name + " uri = " + uri + "/post = " + post_data);
+ x.send(post_data);
+ sajax_debug(func_name + " waiting..");
+ delete x;
+ return true;
+ }
+
+ <?php
+ $html = ob_get_contents();
+ ob_end_clean();
+ return $html;
+ }
+
+ function sajax_show_common_js() {
+ echo sajax_get_common_js();
+ }
+
+ // javascript escape a value
+ function sajax_esc($val)
+ {
+ $val = str_replace("\\", "\\\\", $val);
+ $val = str_replace("\r", "\\r", $val);
+ $val = str_replace("\n", "\\n", $val);
+ $val = str_replace("'", "\\'", $val);
+ return str_replace('"', '\\"', $val);
+ }
+
+ function sajax_get_one_stub($func_name) {
+ ob_start();
+ ?>
+
+ // wrapper for <?php echo $func_name; ?>
+
+ function x_<?php echo $func_name; ?>() {
+ sajax_do_call("<?php echo $func_name; ?>",
+ x_<?php echo $func_name; ?>.arguments);
+ }
+
+ <?php
+ $html = ob_get_contents();
+ ob_end_clean();
+ return $html;
+ }
+
+ function sajax_show_one_stub($func_name) {
+ echo sajax_get_one_stub($func_name);
+ }
+
+ function sajax_export() {
+ global $sajax_export_list;
+
+ $n = func_num_args();
+ for ($i = 0; $i < $n; $i++) {
+ $sajax_export_list[] = func_get_arg($i);
+ }
+ }
+
+ $sajax_js_has_been_shown = 0;
+ function sajax_get_javascript()
+ {
+ global $sajax_js_has_been_shown;
+ global $sajax_export_list;
+
+ $html = "";
+ if (! $sajax_js_has_been_shown) {
+ $html .= sajax_get_common_js();
+ $sajax_js_has_been_shown = 1;
+ }
+ foreach ($sajax_export_list as $func) {
+ $html .= sajax_get_one_stub($func);
+ }
+ return $html;
+ }
+
+ function sajax_show_javascript()
+ {
+ echo sajax_get_javascript();
+ }
+
+
+ $SAJAX_INCLUDED = 1;
+}
+?>
diff --git a/modules/slimserver/slim.class.php b/modules/slimserver/slim.class.php
index 4ac568b7..6b88f9f5 100755
--- a/modules/slimserver/slim.class.php
+++ b/modules/slimserver/slim.class.php
@@ -1,163 +1,168 @@
<?php
+/**
+*
+* Slimp3-Class
+* for querying the slimp3 and the squeezebox players
+*
+* feel free to modify and use it whereever you want.
+* would be nice if you could send me your changes,
+*
+* Homepage:
+* http://trendwhores.de/slimclass.php
+*
+* Tobias Schlottke <tschlottke chr(64) virtualminds chr(46) de>
+* http://www.trendwhores.de
+*
+* Modifications by Andreas <php chr(64) simply chr(46) nu>
+* + Added more options to slimp3()
+* + Added playlist() /w related options
+* + Modified display() to get strings with spaces instead of +'s provided by urlencode
+* + Modified _parse() to handle new options. Quick'n'dirty hack, could probably be prettier!
+*
+* Updated by Vollmer (vollmer@ampache.org)
+* + Added timeout on fsockopen and error information
+* + Added comments and cleaned up code to fix ampache coding standards
+* License: GPL
+*
+*/
+
+class Slimserver {
- /**
- *
- * Slimp3-Class
- * for querying the slimp3 and the squeezebox players
- *
- * feel free to modify and use it whereever you want.
- * would be nice if you could send me your changes,
- *
- * Homepage:
- * http://trendwhores.de/slimclass.php
- *
- * Tobias Schlottke <tschlottke chr(64) virtualminds chr(46) de>
- * http://www.trendwhores.de
- *
- * Modifications by Andreas <php chr(64) simply chr(46) nu>
- * + Added more options to slimp3()
- * + Added playlist() /w related options
- * + Modified display() to get strings with spaces instead of +'s provided by urlencode
- * + Modified _parse() to handle new options. Quick'n'dirty hack, could probably be prettier!
- *
- * License: GPL
- *
- */
+ var $host = 'localhost';
+ var $port = 9090;
- class slim {
-
- var $host = "localhost";
- var $port = 9090;
-
- var $_connection;
-
- var $playerindex;
- var $playercount;
-
-
- function slim($host = NULL, $port = 9090) {
-
- if ($host && $port) {
- $this->host = $host;
- $this->port = $port;
- }
-
- if (!$this->_connection = fsockopen($this->host, $this->port)) {
- return false;
- }
-
- $this->playercount = $this->_psend("player count ?");
- for($i = 0; $i < $this->playercount; $i++) {
- $this->playerindex[$i]['name'] = $this->_psend("player name $i ?");
- $this->playerindex[$i]['ip'] = $this->_psend("player ip $i ?");
- $this->playerindex[$i]['address'] = $this->_psend("player address $i ?");
- # Added some more options /andreas
- $this->playerindex[$i]['mode'] = $this->_psend($this->playerindex[$i]["address"] . " mode ?");
- $this->playerindex[$i]['power'] = $this->_psend($this->playerindex[$i]["address"] . " power ?");
- $this->playerindex[$i]['volume'] = $this->_psend($this->playerindex[$i]["address"] . " mixer volume ?");
- $this->playerindex[$i]['treble'] = $this->_psend($this->playerindex[$i]["address"] . " mixer treble ?");
- $this->playerindex[$i]['bass'] = $this->_psend($this->playerindex[$i]["address"] . " mixer bass ?");
- $this->playerindex[$i]['tracks'] = $this->_psend($this->playerindex[$i]["address"] . " info total songs ?");
- $this->playerindex[$i]['albums'] = $this->_psend($this->playerindex[$i]["address"] . " info total albums ?");
- $this->playerindex[$i]['artists'] = $this->_psend($this->playerindex[$i]["address"] . " info total artists ?");
- $this->playerindex[$i]['genres'] = $this->_psend($this->playerindex[$i]["address"] . " info total genres ?");
-
- }
-
- return true;
- }
+ var $_connection;
+
+ var $playerindex;
+ var $playercount;
+
+ function Slimserver($host = NULL, $port = 9090) {
- function nowplaying($player = 0) {
- $song = array(
- "artist" => $this->_psend("artist $player ?"),
- "title" => $this->_psend("title $player ?"),
- "path" => $this->_psend("path $player ?"),
- "duration" => $this->_psend("duration $player ?"),
- "genre" => $this->_psend("genre $player ?"),
- "album" => $this->_psend("album $player ?")
- );
- return $song;
- }
+ if ($host && $port) {
+ $this->host = $host;
+ $this->port = $port;
+ }
+
+ /* Attempt to establish connection */
+ if (!$this->_connection = fsockopen($this->host, $this->port,$errno,$errstr,'.5')) {
+ debug_event('slimserver','Error: Unable to open socket,' . $errno . ' - ' . $errstr,1);
+ return false;
+ }
- # Added playlist() for related options /andreas
- function playlist($player = 0) {
- #Information related to playlist!
- $index = $this->_psend("playlist index ?");
- $index++;
- $song = array(
- "index" => $index,
- "total" => $this->_psend("playlist tracks ?"),
- # Spaces added to the end of the two first below, quick'n'dirty fix for parsing error... ;)
- "nextartist" => $this->_psend("playlist artist " . $index . " "),
- "nexttitle" => $this->_psend("playlist title " . $index . " "),
- "shuffle" => $this->_psend("playlist shuffle ?"),
- "repeat" => $this->_psend("playlist repeat ?")
- );
- return $song;
- }
+ $this->playercount = $this->_psend("player count ?");
+
+ for($i = 0; $i < $this->playercount; $i++) {
+ $this->playerindex[$i]['name'] = $this->_psend("player name $i ?");
+ $this->playerindex[$i]['ip'] = $this->_psend("player ip $i ?");
+ $this->playerindex[$i]['address'] = $this->_psend("player address $i ?");
+
+ # Added some more options /andreas
+ $this->playerindex[$i]['mode'] = $this->_psend($this->playerindex[$i]["address"] . " mode ?");
+ $this->playerindex[$i]['power'] = $this->_psend($this->playerindex[$i]["address"] . " power ?");
+ $this->playerindex[$i]['volume'] = $this->_psend($this->playerindex[$i]["address"] . " mixer volume ?");
+ $this->playerindex[$i]['treble'] = $this->_psend($this->playerindex[$i]["address"] . " mixer treble ?");
+ $this->playerindex[$i]['bass'] = $this->_psend($this->playerindex[$i]["address"] . " mixer bass ?");
+ $this->playerindex[$i]['tracks'] = $this->_psend($this->playerindex[$i]["address"] . " info total songs ?");
+ $this->playerindex[$i]['albums'] = $this->_psend($this->playerindex[$i]["address"] . " info total albums ?");
+ $this->playerindex[$i]['artists'] = $this->_psend($this->playerindex[$i]["address"] . " info total artists ?");
+ $this->playerindex[$i]['genres'] = $this->_psend($this->playerindex[$i]["address"] . " info total genres ?");
+ }
+ return true;
+
+ } // end constructor
+
+ function nowplaying($player = 0) {
+ $song = array(
+ "artist" => $this->_psend("artist $player ?"),
+ "title" => $this->_psend("title $player ?"),
+ "path" => $this->_psend("path $player ?"),
+ "duration" => $this->_psend("duration $player ?"),
+ "genre" => $this->_psend("genre $player ?"),
+ "album" => $this->_psend("album $player ?")
+ );
+ return $song;
+ }
+
+ # Added playlist() for related options /andreas
+ function playlist($player = 0) {
+ #Information related to playlist!
+ $index = $this->_psend("playlist index ?");
+ $index++;
+ $song = array(
+ "index" => $index,
+ "total" => $this->_psend("playlist tracks ?"),
+ # Spaces added to the end of the two first below, quick'n'dirty fix for parsing error... ;)
+ "nextartist" => $this->_psend("playlist artist " . $index . " "),
+ "nexttitle" => $this->_psend("playlist title " . $index . " "),
+ "shuffle" => $this->_psend("playlist shuffle ?"),
+ "repeat" => $this->_psend("playlist repeat ?")
+ );
+ return $song;
+ }
+
+
+ function display($l1, $l2, $duration = 5, $player = 0) {
+ #$this->_send("display ".urlencode($l1)." ".urlencode($l2)." ".$duration);
+ # above code gave me urlencoded strings on my displat, ie "Hello%20World", below did not... /andreas (php chr(64) simply chr(46) nu)
+ $l1 = str_replace(" ", "%20", $l1);
+ $l2 = str_replace(" ", "%20", $l2);
+ $this->_send("display ".$l1." ".$l2." ".$duration);
+ }
+
+ function cdisplay() {
+ return urldecode($this->_send("display ? ?"));
+ }
+
+ function close() {
+ $this->_send("exit");
+ return true;
+ }
+ # Modified by andreas (php chr(64) simply chr(46) nu)
+ # Don't ask why I did stuff here, don't remember ;)
+ function _parse($string, $cmd = NULL) {
- function display($l1, $l2, $duration = 5, $player = 0) {
- #$this->_send("display ".urlencode($l1)." ".urlencode($l2)." ".$duration);
- # above code gave me urlencoded strings on my displat, ie "Hello%20World", below did not... /andreas (php chr(64) simply chr(46) nu)
- $l1 = str_replace(" ", "%20", $l1);
- $l2 = str_replace(" ", "%20", $l2);
- $this->_send("display ".$l1." ".$l2." ".$duration);
- }
+ if (!$cmd);
+ $cmd = $this->_lastcmd;
- function cdisplay() {
- return urldecode($this->_send("display ? ?"));
- }
+ $quoted = preg_quote(substr($cmd, 0, -1), "\\");
- function close() {
- $this->_send("exit");
- return true;
- }
- # Modified by andreas (php chr(64) simply chr(46) nu)
- # Don't ask why I did stuff here, don't remember ;)
- function _parse($string, $cmd = NULL) {
-
- if (!$cmd);
- $cmd = $this->_lastcmd;
-
- $quoted = preg_quote(substr($cmd, 0, -1), "\\");
-
- if (preg_match("/^".$quoted."(.*)/i", $string, $matches)) {
- $dec = urldecode(trim($matches[1]));
+ if (preg_match("/^".$quoted."(.*)/i", $string, $matches)) {
+ $dec = urldecode(trim($matches[1]));
+ return $dec;
+ } elseif(preg_match("/^".substr($quoted, 0, -2)."(.*)/i", $string, $matches)) {
+ $dec = urldecode(trim($matches[1]));
+ if (substr($dec, -1, 1) == '?')
+ return substr($dec, 0, -1);
+ else
return $dec;
- } elseif(preg_match("/^".substr($quoted, 0, -2)."(.*)/i", $string, $matches)) {
- $dec = urldecode(trim($matches[1]));
- if (substr($dec, -1, 1) == '?')
- return substr($dec, 0, -1);
- else
- return $dec;
-
- # extra parsing for cmd's where MAC address is involved. Me not good at regexps so... ;)
- } elseif(preg_match("/^".$quoted."(.*)/i", urldecode(trim($string)), $matches)) {
- $dec = trim($matches[1]);
- if ($dec == "0")
- return "play";
- else
- return $dec;
- } else {
- return "unable to parse reply: ".$string."<br>(cmd was: $cmd)";
- }
- }
-
- function _send($string) {
- $this->_lastcmd = $string;
-
- if (fputs($this->_connection, $string."\n"))
- return fgets($this->_connection);
+ # extra parsing for cmd's where MAC address is involved. Me not good at regexps so... ;)
+ } elseif(preg_match("/^".$quoted."(.*)/i", urldecode(trim($string)), $matches)) {
+ $dec = trim($matches[1]);
+ if ($dec == "0")
+ return "play";
else
- return false;
+ return $dec;
+ } else {
+ return "unable to parse reply: ".$string."<br>(cmd was: $cmd)";
}
+ }
+
+ function _send($string) {
- function _psend($string) {
- return $this->_parse($this->_send($string));
- }
+ $this->_lastcmd = $string;
+ if (fputs($this->_connection, $string."\n"))
+ return fgets($this->_connection);
+ else
+ return false;
+ }
+
+ function _psend($string) {
+ return $this->_parse($this->_send($string));
}
+}
+
?>