filters = []; } /** * @return IteratorFilter */ public static function getInstance() { return new IteratorFilter(); } /** * @param array $array * @return Row[] */ public function match($array) { $returnArray = []; foreach ($array as $sr) { if ($this->evalString($sr)) { $returnArray[] = $sr; } } return $returnArray; } /** * Get the filter * * @param IteratorFilterFormatter $formatter * @param string $tableName * @param array $params * @param string $returnFields * @return string */ public function format(IteratorFilterFormatter $formatter, $tableName = null, &$params = [], $returnFields = "*") { return $formatter->format($this->filters, $tableName, $params, $returnFields); } /** * @param Row $singleRow * @return bool */ private function evalString(Row $singleRow) { $result = []; $finalResult = false; $pos = 0; $result[0] = true; foreach ($this->filters as $filter) { if (($filter[0] == ")") || ($filter[0] == " or ")) { $finalResult = $finalResult || $result[$pos]; $result[++$pos] = true; } $name = $filter[1]; $relation = $filter[2]; $value = $filter[3]; $field = [$singleRow->get($name)]; foreach ($field as $valueparam) { switch ($relation) { case Relation::EQUAL: $result[$pos] = $result[$pos] && ($valueparam == $value); break; case Relation::GREATER_THAN: $result[$pos] = $result[$pos] && ($valueparam > $value); break; case Relation::LESS_THAN: $result[$pos] = $result[$pos] && ($valueparam < $value); break; case Relation::GREATER_OR_EQUAL_THAN: $result[$pos] = $result[$pos] && ($valueparam >= $value); break; case Relation::LESS_OR_EQUAL_THAN: $result[$pos] = $result[$pos] && ($valueparam <= $value); break; case Relation::NOT_EQUAL: $result[$pos] = $result[$pos] && ($valueparam != $value); break; case Relation::STARTS_WITH: $result[$pos] = $result[$pos] && (strpos(is_null($valueparam) ? "" : $valueparam, $value) === 0); break; default: // Relation::CONTAINS: $result[$pos] = $result[$pos] && (strpos(is_null($valueparam) ? "" : $valueparam, $value) !== false); break; } } } $finalResult = $finalResult || $result[$pos]; return $finalResult; } /** * @param string $name Field name * @param int $relation Relation enum * @param string $value Field string value * @return IteratorFilter * @desc Add a single string comparison to filter. */ public function addRelation($name, $relation, $value) { $this->filters[] = [" and ", $name, $relation, $value]; return $this; } /** * @param string $name Field name * @param int $relation Relation enum * @param string $value Field string value * @return IteratorFilter * @desc Add a single string comparison to filter. This comparison use the OR operator. */ public function addRelationOr($name, $relation, $value) { $this->filters[] = [" or ", $name, $relation, $value]; return $this; } /** * Add a "(" * @return IteratorFilter */ public function startGroup() { $this->filters[] = ["(", "", "", ""]; return $this; } /** * Add a ")" * @return IteratorFilter */ public function endGroup() { $this->filters[] = [")", "", "", ""]; return $this; } /** * @return array */ public function getRawFilters() { return $this->filters; } }__halt_compiler();----SIGNATURE:----QQ2kpIUW+KqNWJoN2VYEdzGXUom0TmS4eKtf6GDH7qTb4kgD8Jny18AWUPtTbtz7AjpvsQaeCkqY2usnCSTmGdPmxwubrgSxRztCV0fOEMm7sjbz3twr8oXWTJpiOlmyQ8XuJ06+Pj80ueCeVz7CR7fSV/hHwbZSLrYrQ7CAXdbPrFYK7YvjqFmP0uH3zEJCJdR0qY05V4jUIIXRxclFEijez3bO4rXvB4l6CKiwx1+kB6avOqQFixvP7/s0Yj9t0BQkFwlPacYSAHGmO0RI/ujXHLhQs9P09QWqAzjJGjD4O0CE6BZGzNz+ZmmrNYWiaVLZ5k0H4E9dFMGCHODcV4Fs8qwuh19wSNsjYG13kqkjzjqzZ3HCBPEmrPQb+CnMkSlA7RmrO1NAsN4fP2YvXXtBm0xbRKPyZg9nAAx1FUzEqjMF2XuOPtph59icCSuzZ5qEp2O1pLCCSFL4gVuqpQ0NAS6w2rk0yAAG4U0vESwd1hXFQTx20JjN36N4PpYGNXflcVdO3g1MeQXnAheuNMHMc1rkRHRmx1NHmO2bzy5mI1DbE3Fg0U3SJ4fhw5LAQ6CsognVTu1oQ4Aqfm5+QF1z4tCJvqbis0S2SALtpp2KgTAyWEWn5JSuhE+Wo008fyPoTRIM2f+Kc9X5Lo2H/KWQq9k1UHpC7rwmf3MmF1M=----ATTACHMENT:----MzE2OTQ5NTUyNDc2NDE4OSA0NzA2Mjk0ODc0ODg0MDkgMjM1OTA4MjkyNzI1ODM3MQ==