<?php /** * @author Jaap Jansma <jaap.jansma@civicoop.org> * @license AGPL-3.0 */ namespace Civi\DataProcessor\DataFlow\SqlDataFlow; class SimpleWhereClause implements WhereClauseInterface { protected $table_alias; protected $field; protected $operator; protected $value; public function __construct($table_alias, $field, $operator, $value, $valueType = 'String') { $this->table_alias = $table_alias; $this->field = $field; $this->operator = $operator; if (is_array($value)) { $esacpedValues = array(); foreach($value as $val) { $esacpedValues[] = "'". \CRM_Utils_Type::escape($val, $valueType)."'"; } if ($operator == 'BETWEEN' || $operator == 'NOT BETWEEN') { $this->value = implode(" AND ", $esacpedValues); } else { $this->value = "(" . implode(", ", $esacpedValues) . ")"; } } else { $this->value = \CRM_Utils_Type::escape($value, $valueType); } } /** * Returns the where clause * E.g. contact_type = 'Individual' * * @return string */ public function getWhereClause() { if ($this->operator == 'NOT IN') { // If the operator is NOT IN also include NULL values. return "(`{$this->table_alias}`.`{$this->field}` {$this->operator} {$this->value} OR `{$this->table_alias}`.`{$this->field}` IS NULL)"; } return "`{$this->table_alias}`.`{$this->field}` {$this->operator} {$this->value}"; } }