Fixed double named accounts.

This commit is contained in:
James Cole
2015-03-26 18:05:23 +01:00
parent 3d59d141c4
commit e0730c7b39
4 changed files with 49 additions and 7 deletions

View File

@@ -31,9 +31,9 @@ class AccountFormRequest extends Request
$accountRoles = join(',', array_keys(Config::get('firefly.accountRoles'))); $accountRoles = join(',', array_keys(Config::get('firefly.accountRoles')));
$types = join(',', array_keys(Config::get('firefly.subTitlesByIdentifier'))); $types = join(',', array_keys(Config::get('firefly.subTitlesByIdentifier')));
$nameRule = 'required|between:1,100|uniqueForUser:accounts,name'; $nameRule = 'required|between:1,100|uniqueAccountForUser';
if (Account::find(Input::get('id'))) { if (Account::find(Input::get('id'))) {
$nameRule = 'required|between:1,100|belongsToUser:accounts'; $nameRule = 'required|between:1,100|belongsToUser:accounts|uniqueForUser:'.Input::get('id');
} }
return [ return [

View File

@@ -18,7 +18,7 @@ class Account extends Model
= [ = [
'user_id' => 'required|exists:users,id', 'user_id' => 'required|exists:users,id',
'account_type_id' => 'required|exists:account_types,id', 'account_type_id' => 'required|exists:account_types,id',
'name' => 'required|between:1,1024|uniqueForUser:accounts,name', 'name' => 'required|between:1,1024|uniqueAccountForUser',
'active' => 'required|boolean' 'active' => 'required|boolean'
]; ];

View File

@@ -285,12 +285,14 @@ class AccountRepository implements AccountRepositoryInterface
'active' => $data['active'] === true ? true : false, 'active' => $data['active'] === true ? true : false,
] ]
); );
if (!$newAccount->isValid()) { if (!$newAccount->isValid()) {
// does the account already exist? // does the account already exist?
$existingAccount = Account::where('user_id', $data['user'])->where('account_type_id', $accountType->id)->where('name', $data['name'])->first(); $existingAccount = Account::where('user_id', $data['user'])->where('account_type_id', $accountType->id)->where('name', $data['name'])->first();
if (!$existingAccount) { if (!$existingAccount) {
Log::error('Account create error: ' . $newAccount->getErrors()->toJson()); Log::error('Account create error: ' . $newAccount->getErrors()->toJson());
var_dump($newAccount->getErrors()->toArray()); App::abort(500);
} }
$newAccount = $existingAccount; $newAccount = $existingAccount;
} }

View File

@@ -4,8 +4,11 @@ namespace FireflyIII\Validation;
use Auth; use Auth;
use Carbon\Carbon; use Carbon\Carbon;
use Config;
use DB; use DB;
use FireflyIII\Models\AccountType;
use Illuminate\Validation\Validator; use Illuminate\Validation\Validator;
use Input;
use Navigation; use Navigation;
/** /**
@@ -34,6 +37,13 @@ class FireflyValidator extends Validator
} }
/**
* @param $attribute
* @param $value
* @param $parameters
*
* @return bool
*/
public function validatePiggyBankReminder($attribute, $value, $parameters) public function validatePiggyBankReminder($attribute, $value, $parameters)
{ {
$array = $this->data; $array = $this->data;
@@ -51,14 +61,44 @@ class FireflyValidator extends Validator
return true; return true;
} }
$nextReminder = Navigation::addPeriod($startDate, $array['reminder'],0); $nextReminder = Navigation::addPeriod($startDate, $array['reminder'], 0);
// reminder is beyond target? // reminder is beyond target?
if($nextReminder > $targetDate) { if ($nextReminder > $targetDate) {
return false; return false;
} }
return true; return true;
} }
/**
* @param $attribute
* @param $value
* @param $parameters
*
* @return bool
*/
public function validateUniqueAccountForUser($attribute, $value, $parameters)
{
// get account type from data, we must have this:
$type = isset($this->data['what']) ? $this->data['what'] : Input::get('what');
$longType = Config::get('firefly.accountTypeByIdentifier.' . $type);
$dbType = AccountType::whereType($longType)->first();
if (!$dbType) {
return false;
}
$query = DB::table('accounts')->where('name', $value)->where('account_type_id', $dbType->id)->where('user_id', Auth::user()->id);
if (isset($parameters[0])) {
$query->where('id', '!=', $parameters[0]);
}
$count = $query->count();
if ($count == 0) {
return true;
}
return false;
}
/** /**
* @param $attribute * @param $attribute
* @param $value * @param $value
@@ -69,7 +109,7 @@ class FireflyValidator extends Validator
public function validateUniqueForUser($attribute, $value, $parameters) public function validateUniqueForUser($attribute, $value, $parameters)
{ {
$query = DB::table($parameters[0])->where($parameters[1], $value); $query = DB::table($parameters[0])->where($parameters[1], $value);
$query->where('user_id',Auth::user()->id); $query->where('user_id', Auth::user()->id);
if (isset($paramers[2])) { if (isset($paramers[2])) {
$query->where('id', '!=', $parameters[2]); $query->where('id', '!=', $parameters[2]);
} }