Your IP : 216.73.216.97


Current Path : /var/www/clients/client3/web2/web/lists/admin/plugins/SegmentPlugin/
Upload File :
Current File : /var/www/clients/client3/web2/web/lists/admin/plugins/SegmentPlugin/SubscriberConditionEmail.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
 */
class SegmentPlugin_SubscriberConditionEmail extends SegmentPlugin_Condition
{
    public function operators()
    {
        return array(
            SegmentPlugin_Operator::IS => s('is'),
            SegmentPlugin_Operator::MATCHES => s('matches'),
            SegmentPlugin_Operator::NOTMATCHES => s('does not match'),
            SegmentPlugin_Operator::REGEXP => s('REGEXP'),
            SegmentPlugin_Operator::NOTREGEXP => s('not REGEXP'),
            SegmentPlugin_Operator::ISINCLUDED => s('is included'),
            SegmentPlugin_Operator::ISNOTINCLUDED => s('is not included'),
        );
    }

    public function display($op, $value, $namePrefix)
    {
        return ($op == SegmentPlugin_Operator::ISINCLUDED || $op == SegmentPlugin_Operator::ISNOTINCLUDED)
            ? CHtml::textArea($namePrefix . '[value]', $value)
            : CHtml::textField($namePrefix . '[value]', $value);
    }

    public function joinQuery($operator, $value)
    {
        if (!(is_string($value) && $value !== '')) {
            throw new SegmentPlugin_ValueException();
        }

        if (($operator == SegmentPlugin_Operator::REGEXP || $operator == SegmentPlugin_Operator::NOTREGEXP)
            && !$this->dao->isRegexValid($value)) {
            throw new SegmentPlugin_ValueException();
        }
        $target = null;

        switch ($operator) {
            case SegmentPlugin_Operator::MATCHES:
                $op = 'LIKE';
                break;
            case SegmentPlugin_Operator::NOTMATCHES:
                $op = 'NOT LIKE';
                break;
            case SegmentPlugin_Operator::REGEXP:
                $op = 'REGEXP';
                break;
            case SegmentPlugin_Operator::NOTREGEXP:
                $op = 'NOT REGEXP';
                break;
            case SegmentPlugin_Operator::ISINCLUDED:
                $emails = preg_split("/[\r\n]+/", $value, -1, PREG_SPLIT_NO_EMPTY);
                $op = 'IN';
                $target = '(' . $this->commaQuotedList($emails) . ')';
                break;
            case SegmentPlugin_Operator::ISNOTINCLUDED:
                $emails = preg_split("/[\r\n]+/", $value, -1, PREG_SPLIT_NO_EMPTY);
                $op = 'NOT IN';
                $target = '(' . $this->commaQuotedList($emails) . ')';
                break;
            case SegmentPlugin_Operator::IS:
            default:
                $op = '=';
        }

        if (!$target) {
            $target = "'" . sql_escape($value) . "'";
        }
        $r = new stdClass();
        $r->join = '';
        $r->where = "u.email $op $target";

        return $r;
    }
}