]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
Merge remote-tracking branch 'upstream/master' into nightly
authorRoland Haeder <roland@mxchange.org>
Sun, 12 Apr 2015 14:08:53 +0000 (16:08 +0200)
committerRoland Haeder <roland@mxchange.org>
Sun, 12 Apr 2015 14:09:03 +0000 (16:09 +0200)
Signed-off-by: Roland Haeder <roland@mxchange.org>
1  2 
classes/File_thumbnail.php
classes/Notice.php
lib/attachmentlistitem.php
lib/implugin.php
plugins/Oembed/actions/oembed.php
plugins/OpportunisticQM/lib/opportunisticqueuemanager.php
scripts/commandline.inc.php

Simple merge
Simple merge
Simple merge
index 9542d4d206d604633691360ad05cc391a26fc4b3,5b0f3dbe092fa42dbd73d01dc3e727392151d1bb..ff6eed3aa508b46327b9071c20a4531804c1f2cd
@@@ -528,11 -530,16 +530,16 @@@ abstract class ImPlugin extends Plugi
       *
       * @return boolean hook return
       */
 -    function onEndInitializeQueueManager($manager)
 +    function onEndInitializeQueueManager(QueueManager $manager)
      {
-         $manager->connect($this->transport . '-in', new ImReceiverQueueHandler($this), 'im');
-         $manager->connect($this->transport, new ImQueueHandler($this));
-         $manager->connect($this->transport . '-out', new ImSenderQueueHandler($this), 'im');
+         // If we don't require CLI mode, or if we do and GNUSOCIAL_CLI _is_ set, then connect the transports
+         // This check is made mostly because some IM plugins can't deliver to transports unless they
+         // have continously running daemons (such as XMPP) and we can't have that over HTTP requests.
+         if (!$this->requires_cli || defined('GNUSOCIAL_CLI')) {
+             $manager->connect($this->transport . '-in', new ImReceiverQueueHandler($this), 'im');
+             $manager->connect($this->transport, new ImQueueHandler($this));
+             $manager->connect($this->transport . '-out', new ImSenderQueueHandler($this), 'im');
+         }
          return true;
      }
  
Simple merge
index 1244187b873bb40ec0d2dd7f00fd16c766530e1b,0000000000000000000000000000000000000000..5f2e1d86eafaedfadab8b2d2e2e6f39d12a33401
mode 100644,000000..100644
--- /dev/null
@@@ -1,248 -1,0 +1,250 @@@
 +<?php
 +/*
 + * StatusNet - a distributed open-source microblogging tool
 + * Copyright (C) 2008, 2009, StatusNet, Inc.
 + *
 + * This program is free software: you can redistribute it and/or modify
 + * it under the terms of the GNU Affero General Public License as published by
 + * the Free Software Foundation, either version 3 of the License, or
 + * (at your option) any later version.
 + *
 + * This program is distributed in the hope that it will be useful,
 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 + * GNU Affero General Public License for more details.
 + *
 + * You should have received a copy of the GNU Affero General Public License
 + * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 + */
 +
 +// -*- mode: php -*-
 +
 +# Abort if called from a web server
 +
 +if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) {
 +    print "This script must be run from the command line\n";
 +    exit();
 +}
 +
 +define('GNUSOCIAL', true);
 +define('STATUSNET', true); //compatibility
 +
++define('GNUSOCIAL_CLI', true);  // to know we're in a CLI environment
++
 +// Set various flags so we don't time out on long-running processes
 +
 +ini_set("max_execution_time", "0");
 +ini_set("max_input_time", "0");
 +set_time_limit(0);
 +mb_internal_encoding('UTF-8');
 +error_reporting(0);
 +# DEBUG: error_reporting(E_ALL & ~E_STRICT & ~E_DEPRECATED);
 +
 +// Add extlib to our path so we can get Console_Getopt
 +
 +$_extra_path = array(INSTALLDIR.'/extlib/');
 +
 +set_include_path(implode(PATH_SEPARATOR, $_extra_path) . PATH_SEPARATOR . get_include_path());
 +
 +require_once 'Console/Getopt.php';
 +
 +// Note: $shortoptions and $longoptions should be pre-defined!
 +
 +$_default_shortoptions = 'qvhc:s:p:';
 +
 +$_default_longoptions = array('quiet', 'verbose', 'help', 'conf=', 'server=', 'path=');
 +
 +if (isset($shortoptions)) {
 +    $shortoptions .= $_default_shortoptions;
 +} else {
 +    $shortoptions = $_default_shortoptions;
 +}
 +
 +if (isset($longoptions)) {
 +    $longoptions = array_merge($longoptions, $_default_longoptions);
 +} else {
 +    $longoptions = $_default_longoptions;
 +}
 +
 +$parser = new Console_Getopt();
 +
 +$result = $parser->getopt($argv, $shortoptions, $longoptions);
 +
 +if (PEAR::isError($result)) {
 +    print $result->getMessage()."\n";
 +    exit(1);
 +} else {
 +    list($options, $args) = $result;
 +}
 +
 +function show_help()
 +{
 +    global $helptext;
 +
 +    $_default_help_text = <<<END_OF_DEFAULT
 +      General options:
 +
 +    -q --quiet           Quiet (little output)
 +    -v --verbose         Verbose (lots of output)
 +    -c --conf=<filename> Use <filename> as config file
 +    -s --server=<name>   Use <name> as server name
 +    -p --path=<path>     Use <path> as path name
 +    -h --help            Show this message and quit.
 +
 +END_OF_DEFAULT;
 +    if (isset($helptext)) {
 +        print $helptext;
 +    }
 +    print $_default_help_text;
 +    exit(0);
 +}
 +
 +foreach ($options as $option) {
 +
 +    switch ($option[0]) {
 +     case '--server':
 +     case 's':
 +        $server = $option[1];
 +        break;
 +
 +     case '--path':
 +     case 'p':
 +        $path = $option[1];
 +        break;
 +
 +     case '--conf':
 +     case 'c':
 +        $conffile = $option[1];
 +        break;
 +
 +     case '--help':
 +     case 'h':
 +        show_help();
 +    }
 +}
 +
 +require_once INSTALLDIR . '/lib/common.php';
 +
 +set_error_handler('common_error_handler');
 +
 +// Set up the language infrastructure so we can localize anything that
 +// needs to be sent out to users, such as mail notifications.
 +common_init_language();
 +
 +function _make_matches($opt, $alt)
 +{
 +    $matches = array();
 +
 +    if (strlen($opt) > 1 && 0 != strncmp($opt, '--', 2)) {
 +        $matches[] = '--'.$opt;
 +    } else {
 +        $matches[] = $opt;
 +    }
 +
 +    if (!empty($alt)) {
 +        if (strlen($alt) > 1 && 0 != strncmp($alt, '--', 2)) {
 +            $matches[] = '--'.$alt;
 +        } else {
 +            $matches[] = $alt;
 +        }
 +    }
 +
 +    return $matches;
 +}
 +
 +function have_option($opt, $alt=null)
 +{
 +    global $options;
 +
 +    $matches = _make_matches($opt, $alt);
 +
 +    foreach ($options as $option) {
 +        if (in_array($option[0], $matches)) {
 +            return true;
 +        }
 +    }
 +
 +    return false;
 +}
 +
 +function get_option_value($opt, $alt=null)
 +{
 +    global $options;
 +
 +    $matches = _make_matches($opt, $alt);
 +
 +    foreach ($options as $option) {
 +        if (in_array($option[0], $matches)) {
 +            return $option[1];
 +        }
 +    }
 +
 +    return null;
 +}
 +
 +class NoUserArgumentException extends Exception
 +{
 +}
 +
 +function getUser()
 +{
 +    $user = null;
 +
 +    if (have_option('i', 'id')) {
 +        $id = get_option_value('i', 'id');
 +        $user = User::getKV('id', $id);
 +        if (empty($user)) {
 +            throw new Exception("Can't find user with id '$id'.");
 +        }
 +    } else if (have_option('n', 'nickname')) {
 +        $nickname = get_option_value('n', 'nickname');
 +        $user = User::getKV('nickname', $nickname);
 +        if (empty($user)) {
 +            throw new Exception("Can't find user with nickname '$nickname'");
 +        }
 +    } else {
 +        throw new NoUserArgumentException("No user argument specified.");
 +    }
 +
 +    return $user;
 +}
 +
 +/** "Printf not quiet" */
 +
 +function printfnq()
 +{
 +    if (have_option('q', 'quiet')) {
 +        return null;
 +    }
 +
 +    $cargs  = func_num_args();
 +
 +    if ($cargs == 0) {
 +        return 0;
 +    }
 +
 +    $args   = func_get_args();
 +    $format = array_shift($args);
 +
 +    return vprintf($format, $args);
 +}
 +
 +/** "Print when verbose" */
 +
 +function printfv()
 +{
 +    if (!have_option('v', 'verbose')) {
 +        return null;
 +    }
 +
 +    $cargs  = func_num_args();
 +
 +    if ($cargs == 0) {
 +        return 0;
 +    }
 +
 +    $args   = func_get_args();
 +    $format = array_shift($args);
 +
 +    return vprintf($format, $args);
 +}