HEX
Server: LiteSpeed
System: Linux d8 4.18.0-553.121.1.lve.el8.x86_64 #1 SMP Thu Apr 30 16:40:41 UTC 2026 x86_64
User: wbwebdes (3015)
PHP: 8.1.31
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/wbwebdes/domains/mailing.wb-cloud.nl/public_html/admin/plugins/SegmentPlugin/Condition.php
<?php
/**
 * SegmentPlugin for phplist.
 *
 * This file is a part of SegmentPlugin.
 *
 * SegmentPlugin is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * CriteriaPlugin 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 General Public License for more details.
 *
 * @category  phplist
 *
 * @author    Duncan Cameron
 * @copyright 2014-2016 Duncan Cameron
 * @license   http://www.gnu.org/licenses/gpl.html GNU General Public License, Version 3
 */

/**
 * @category  phplist
 */
abstract class SegmentPlugin_Condition
{
    private static $count = 0;
    private $id;

    protected $field;
    protected $tables;
    protected $table_prefix;

    // set by ConditionFactory
    public $dao;
    public $messageData;

    protected function formatInList(array $values)
    {
        return '(' . implode(', ', $values) . ')';
    }

    /**
     * Create a comma separated list of the quoted array values for use in an sql statement.
     *
     * @param array values to be combined
     *
     * @return string
     */
    protected function commaQuotedList(array $values)
    {
        return implode(
            ', ',
            array_map(
                function ($item) {
                    return "'" . sql_escape($item) . "'";
                },
                $values
            )
        );
    }

    protected function createUniqueAlias($alias)
    {
        return $alias . $this->id;
    }

    public function __construct($field)
    {
        global $tables;
        global $table_prefix;

        $this->id = ++self::$count;
        $this->tables = $tables;
        $this->table_prefix = $table_prefix;
        $this->field = $field;
    }

    abstract public function operators();

    abstract public function display($op, $value, $namePrefix);

    abstract public function joinQuery($op, $value);
}