126 lines
3.9 KiB
Diff
126 lines
3.9 KiB
Diff
Index: .htaccess
|
|
===================================================================
|
|
RCS file: /cvs/drupal/drupal/.htaccess,v
|
|
retrieving revision 1.90.2.3
|
|
diff -u -p -r1.90.2.3 .htaccess
|
|
--- .htaccess 10 Dec 2008 20:04:08 -0000 1.90.2.3
|
|
+++ .htaccess 3 Aug 2009 22:38:00 -0000
|
|
@@ -100,10 +100,13 @@ DirectoryIndex index.php
|
|
# uncomment the following line:
|
|
# RewriteBase /
|
|
|
|
+ RewriteRule ^xmlrpc/([0-9]+)/?$ xmlrpc.php?version=$1 [L]
|
|
+
|
|
# Rewrite URLs of the form 'x' to the form 'index.php?q=x'.
|
|
RewriteCond %{REQUEST_FILENAME} !-f
|
|
RewriteCond %{REQUEST_FILENAME} !-d
|
|
RewriteCond %{REQUEST_URI} !=/favicon.ico
|
|
+ RewriteCond %{REQUEST_URI} !=/xmlrpc(.*)
|
|
RewriteRule ^(.*)$ index.php?q=$1 [L,QSA]
|
|
</IfModule>
|
|
|
|
Index: xmlrpc.php
|
|
===================================================================
|
|
RCS file: /cvs/drupal/drupal/xmlrpc.php,v
|
|
retrieving revision 1.15
|
|
diff -u -p -r1.15 xmlrpc.php
|
|
--- xmlrpc.php 10 Dec 2005 19:26:47 -0000 1.15
|
|
+++ xmlrpc.php 3 Aug 2009 22:38:00 -0000
|
|
@@ -6,9 +6,77 @@
|
|
* PHP page for handling incoming XML-RPC requests from clients.
|
|
*/
|
|
|
|
+// define xmlrpc method location
|
|
+define('XMLRPC_PATH', 'sites/all/modules');
|
|
+define('XMLRPC_MODULE', 'logger');
|
|
+define('XMLRPC_FILE', 'xmlrpc');
|
|
+
|
|
+// defined xmlrpc endpoints
|
|
+$xmlrpc_versions = array('', 1);
|
|
+
|
|
+// any common.inc or other core functions that xmlrpc processing relies upon
|
|
+function t($string, $args = array(), $langcode = NULL) {
|
|
+ if (empty($args)) {
|
|
+ return $string;
|
|
+ }
|
|
+ else {
|
|
+ // Transform arguments before inserting them.
|
|
+ foreach ($args as $key => $value) {
|
|
+ switch ($key[0]) {
|
|
+ case '@':
|
|
+ case '%':
|
|
+ default:
|
|
+ // Escaped only.
|
|
+ $args[$key] = check_plain($value);
|
|
+ break;
|
|
+
|
|
+ case '!':
|
|
+ // Pass-through.
|
|
+ }
|
|
+ }
|
|
+ return strtr($string, $args);
|
|
+ }
|
|
+}
|
|
+
|
|
+function watchdog_xmlrpc($type, $message, $variables = array(), $severity = WATCHDOG_NOTICE, $link = NULL) {
|
|
+ global $base_root;
|
|
+
|
|
+ $current_db = db_set_active();
|
|
+
|
|
+ db_query("INSERT INTO {watchdog}
|
|
+ (type, message, variables, severity, link, location, referer, hostname, timestamp)
|
|
+ VALUES
|
|
+ ('%s', '%s', '%s', %d, '%s', '%s', '%s', '%s', %d)",
|
|
+ $type,
|
|
+ $message,
|
|
+ serialize($variables),
|
|
+ $severity,
|
|
+ $link,
|
|
+ $base_root . request_uri(),
|
|
+ referer_uri(),
|
|
+ ip_address(),
|
|
+ time());
|
|
+
|
|
+ if ($current_db) {
|
|
+ db_set_active($current_db);
|
|
+ }
|
|
+}
|
|
+
|
|
+
|
|
include_once './includes/bootstrap.inc';
|
|
-drupal_bootstrap(DRUPAL_BOOTSTRAP_FULL);
|
|
+drupal_bootstrap(DRUPAL_BOOTSTRAP_DATABASE);
|
|
include_once './includes/xmlrpc.inc';
|
|
include_once './includes/xmlrpcs.inc';
|
|
|
|
-xmlrpc_server(module_invoke_all('xmlrpc'));
|
|
+if (in_array($_REQUEST['version'], $xmlrpc_versions)) {
|
|
+ require_once XMLRPC_PATH . '/' . XMLRPC_MODULE . '/' . XMLRPC_FILE . $_REQUEST['version'] . '.inc';
|
|
+
|
|
+ //debugging watchdog_xmlrpc('xmlrpc', 'xmlrpc api called with version %version', array('%version' => $_REQUEST['version']), WATCHDOG_DEBUG);
|
|
+
|
|
+ $function = XMLRPC_MODULE . '_xmlrpc';
|
|
+ $callbacks = $function();
|
|
+ xmlrpc_server($callbacks);
|
|
+}
|
|
+else {
|
|
+ xmlrpc_server_error(-32601, t('Server error. Requested method version (@version) not specified.', array("@version" => $_REQUEST['version'])));
|
|
+}
|
|
Index: includes/menu.inc
|
|
===================================================================
|
|
RCS file: /cvs/drupal/drupal/includes/menu.inc,v
|
|
retrieving revision 1.255.2.31
|
|
diff -u -p -r1.255.2.31 menu.inc
|
|
--- includes/menu.inc 27 Apr 2009 12:50:13 -0000 1.255.2.31
|
|
+++ includes/menu.inc 3 Aug 2009 22:38:02 -0000
|
|
@@ -1422,8 +1422,8 @@ function menu_local_tasks($level = 0, $r
|
|
return $root_path;
|
|
}
|
|
else {
|
|
- // We do not display single tabs.
|
|
- return (isset($tabs[$level]) && $tabs[$level]['count'] > 1) ? $tabs[$level]['output'] : '';
|
|
+ // We do not display single tabs: BVDM yes we do for flukso!
|
|
+ return (isset($tabs[$level])) ? $tabs[$level]['output'] : '';
|
|
}
|
|
}
|
|
|