firefly-iii/app/Rules/Triggers/FromAccountEnds.php

87 lines
2.2 KiB
PHP
Raw Normal View History

2016-01-13 07:02:22 -06:00
<?php
2016-02-05 05:08:25 -06:00
declare(strict_types = 1);
2016-01-13 07:02:22 -06:00
/**
* FromAccountEnds.php
* Copyright (C) 2016 Sander Dorigo
*
* This software may be modified and distributed under the terms
* of the MIT license. See the LICENSE file for details.
*/
namespace FireflyIII\Rules\Triggers;
use FireflyIII\Models\RuleTrigger;
use FireflyIII\Models\TransactionJournal;
use Log;
/**
* Class FromAccountEnds
*
* @package FireflyIII\Rules\Triggers
*/
class FromAccountEnds implements TriggerInterface
{
/** @var TransactionJournal */
protected $journal;
2016-02-17 08:38:21 -06:00
/** @var RuleTrigger */
protected $trigger;
2016-01-13 07:02:22 -06:00
/**
* TriggerInterface constructor.
*
* @param RuleTrigger $trigger
* @param TransactionJournal $journal
*/
public function __construct(RuleTrigger $trigger, TransactionJournal $journal)
{
$this->trigger = $trigger;
$this->journal = $journal;
}
2016-02-17 08:38:21 -06:00
/**
* @{inheritdoc}
*
* @see TriggerInterface::matchesAnything
*
* @return bool
*/
public function matchesAnything()
{
return $this->trigger->trigger_value === "";
}
2016-01-13 07:02:22 -06:00
/**
* @return bool
*/
public function triggered()
{
$name = strtolower($this->journal->source_account->name);
$nameLength = strlen($name);
$search = strtolower($this->trigger->trigger_value);
$searchLength = strlen($search);
2016-01-13 07:02:22 -06:00
// if the string to search for is longer than the account name,
// shorten the search string.
if ($searchLength > $nameLength) {
Log::debug('Search string "' . $search . '" (' . $searchLength . ') is longer than "' . $name . '" (' . $nameLength . '). ');
$search = substr($search, ($nameLength * -1));
2016-01-13 07:02:22 -06:00
$searchLength = strlen($search);
Log::debug('Search string is now "' . $search . '" (' . $searchLength . ') instead.');
}
$part = substr($name, $searchLength * -1);
2016-01-13 07:02:22 -06:00
if ($part == $search) {
Log::debug('"' . $name . '" ends with "' . $search . '". Return true.');
2016-01-13 07:02:22 -06:00
return true;
}
Log::debug('"' . $name . '" does not end with "' . $search . '". Return false.');
2016-01-13 07:02:22 -06:00
return false;
}
2016-02-17 08:29:26 -06:00
}