Forum Replies Created

Viewing 15 replies - 1 through 15 (of 20 total)
  • Dear Jason,
    neither the patch nor the update resolves the problem on my site. No user can log into secured areas. Administrator can log in but is redirected to the dashboard of the admin site. This is a urgent issue as it puts all multisite installations out of business.

    Can you please investigate and publish a patch which is working. Thank you.

    Hi, same Problem here.
    When can we expect the update Jason ?
    Thanks

    Hi, there is an error in the

    wp-responder-email-autoresponder-and-newsletter-plugin/models/iterators/pending_broadcasts.php

    in the second line there is

    include_once __DIR__."/../broadcast.php";

    and it must be

    include_once __DIR__."/../Broadcast.php";

    Hope that works for you.

    It seams we are dealing with this part of the code

    /*
     * This is the function that performs the autoresponder subscription processing
     */
    
    class WPRBackgroundProcessor {
    
        public static function autoresponder_process_subscriber($subscriber_id) {
    
            $getAutoresponderSubscriptionQuery = sprintf("SELECT * FROM {$wpdb->prefix}wpr_followup_subscriptions subscription, {$wpdb->prefix}wpr_subscribers subscribers WHERE
                                                                    subscription.sid=%d AND
                                                                    subscribers.id=subscription.sid AND
                                                                    subscribers.active=1 AND subscribers.confirmed=1;", $subscriber_id);
    
            $subscriptionResults = $wpdb->get_results($getAutoresponderSubscriptionQuery);
    
            if (0 == count ($subscriptionResults)) {
                return;
            }
    
        }
    
        public static function process_autoresponders() {
    
            $processor = AutoresponderProcessor::getProcessor();
            set_time_limit(WPR_MAX_AUTORESPONDER_PROCESS_EXECUTION_TIME);
    
            $timeOfStart = time();
            $currentTime = new DateTime(sprintf("@%d", $timeOfStart));
    
            $timeWhenAutoresponderProcessLastDidAHeartBeat = get_option("_wpr_autoresponder_process_status");
            if (self::whetherAnotherInstanceIsAlreadyRunning($timeOfStart, $timeWhenAutoresponderProcessLastDidAHeartBeat)) {
                return;
            }
    
            //set the time of ping for the autoresponder process status variable
            update_option("_wpr_autoresponder_process_status",$timeOfStart);
    
            //set the start time of the autoresponder process
            do_action("_wpr_autoresponder_process_start", $currentTime);
    
            //run the autoresponder processor
    
            $processor->run_for_time($currentTime);
    
            //call the hooks that need notification for the
            do_action('_wpr_autoresponder_process_end', $currentTime);
            update_option("_wpr_autoresponder_process_status","stopped");
    
        }
    
        public static function whetherAnotherInstanceIsAlreadyRunning($timeOfStart, $timeWhenAutoresponderProcessLastDidAHeartBeat)
        {
            $timeMaximumExecutionTimeAgo = $timeOfStart - WPR_MAX_AUTORESPONDER_PROCESS_EXECUTION_TIME;
            if (!empty($timeWhenAutoresponderProcessLastDidAHeartBeat) && $timeWhenAutoresponderProcessLastDidAHeartBeat != "stopped") {
                $timeWhenAutoresponderProcessLastDidAHeartBeat = intval($timeWhenAutoresponderProcessLastDidAHeartBeat);
                if ($timeWhenAutoresponderProcessLastDidAHeartBeat != 0 && (self::whetherLastAutoresponderProcessHeartBeatValidityExpired($timeWhenAutoresponderProcessLastDidAHeartBeat, $timeMaximumExecutionTimeAgo))) {
                    return true;
                }
            }
    
            return false;
        }
    
        private static function whetherLastAutoresponderProcessHeartBeatValidityExpired($timeWhenAutoresponderProcessLastDidAHeartBeat, $timeMaximumExecutionTimeAgo)
        {
            return !($timeWhenAutoresponderProcessLastDidAHeartBeat < $timeMaximumExecutionTimeAgo);
        }
    
    }

    Anyone got a Idea how to fix it ??

    Hi,
    could you find a solution?

    I have the same Problem here, Hopefully Raj would give us some input on that.

    found it in /other/cron.php

    Can you please tell me where to fix that.

    Thanks

    Thread Starter andaluzo

    (@andaluzo)

    I resolved it with

    putting the following as index.php in the template for ‘/’

    ?php
    /**
     * The main template file.
     *
     * This is the most generic template file in a WordPress theme
     * and one of the two required files for a theme (the other being style.css).
     * It is used to display a page when nothing more specific matches a query.
     * E.g., it puts together the home page when no home.php file exists.
     * Learn more: https://codex.www.ads-software.com/Template_Hierarchy
     *
     * @package WordPress
     * @subpackage Redirect
     */
    
    /**
     * Detect browser language.
     *
     * @param array $allowed_languages An array of languages that are available on the site.
     * @param string $default_language Default language to use if none could be detected.
     * @param string $lang_variable Custom user language support. If not specified $_SERVER['HTTP_ACCEPT_LANGUAGE'] is used.
     * @param string $strict_mode If true (default) the whole language code ("en-us") is used and not only the left part ("en").
     * @return string The detected browser language.
     */
    function get_lang_from_browser($allowed_languages, $default_language, $lang_variable = NULL, $strict_mode = TRUE) {
        // Use $_SERVER['HTTP_ACCEPT_LANGUAGE'] if no language variable is available
        if (NULL === $lang_variable)
            $lang_variable = $_SERVER['HTTP_ACCEPT_LANGUAGE'];
    
        // Any info sent?
        if (empty($lang_variable))
            return $default_language;
    
        // Split the header
        $accepted_languages = preg_split('/,\s*/', $lang_variable);
    
        // Set default values
        $current_lang = $default_language;
        $current_q    = 0;
        // Now work through all included languages
        foreach ($accepted_languages as $accepted_language) {
            // Get all info about this language
            $res = preg_match(
                '/^([a-z]{1,8}(?:-[a-z]{1,8})*)'.
                '(?:;\s*q=(0(?:\.[0-9]{1,3})?|1(?:\.0{1,3})?))?$/i',
                $accepted_language,
                $matches
            );
    
            if (!$res)
                continue;
    
            // Get language code and split into parts immediately
            $lang_code = explode('-', $matches[1]);
    
            // Is there a quality set?
            if (isset($matches[2]))
                $lang_quality = (float)$matches[2];
            else
                $lang_quality = 1.0;
    
            // Until the language code is empty...
            while (count($lang_code)) {
                // Check if the language code is available
                if (in_array(strtolower(join('-', $lang_code)), $allowed_languages)) {
                    // Check quality
                    if ($lang_quality > $current_q) {
                        $current_lang = strtolower(join('-', $lang_code));
                        $current_q = $lang_quality;
                        break;
                    }
                }
                // If we're in strict mode we won't try to minimalize the language
                if ($strict_mode)
                    break;
    
                // Cut the most right part of the language code
                array_pop($lang_code);
            }
        }
    
        return $current_lang;
    }
    
    $allowed_langs = array('en', 'de', 'es');
    $lang = get_lang_from_browser($allowed_langs, 'en', NULL, FALSE);
    header('Location: https://' . $_SERVER['HTTP_HOST'] . "/$lang/");
    
    exit();
    ?>

    If you generate it as blank theme you should also put some styles.css in that Theme folder.

    Works great, seams to be German engineering your plugin ??

    Thread Starter andaluzo

    (@andaluzo)

    Thanks guys finaly i found it myself.

    In the httpd.conf was

    Allow override none

    which should be

    allow override all

    Thread Starter andaluzo

    (@andaluzo)

    Resolved

    Thread Starter andaluzo

    (@andaluzo)

    Thanks, this did the trick.

    BUT, same plugins all active again and it works. Sometimes I just dont get it ??

    @mbr solution, thanks for the hint.

    Today I deleted this “Widget Logic Visual” plugin one, not worth the pain waiting.

    What you guys think about this one
    https://www.ads-software.com/extend/plugins/widget-logic/
    Maybe an alternative?

    yeah, good idea. I am already with a nice theme which is already adapted. will break my head to change that now :). would love to see the plugin work again.

    Dear John,

    that word for general widget funcions but I try to access the logic function of the widgets so I can display them limited to certain pages.

    Any Idea how to do that?

    Thanks

Viewing 15 replies - 1 through 15 (of 20 total)