diff options
author | Karl 'vollmerk' Vollmer <vollmer@ampache.org> | 2006-10-09 05:46:40 +0000 |
---|---|---|
committer | Karl 'vollmerk' Vollmer <vollmer@ampache.org> | 2006-10-09 05:46:40 +0000 |
commit | 78590d7d512ada604987fdcc9c31a8c74591f64b (patch) | |
tree | 00e7cbb628f6c099cc51df7a86f85be3c5d5ca42 /modules | |
parent | d885efaed4bdfbac1df06e0ff3a4fd0d46701b96 (diff) | |
download | ampache-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.php | 373 | ||||
-rwxr-xr-x | modules/slimserver/slim.class.php | 295 |
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));
}
+}
+
?>
|