'required|exists:users,id', 'account_type_id' => 'required|exists:account_types,id', 'name' => 'required|between:1,1024|uniqueAccountForUser', 'active' => 'required|boolean' ]; /** * @param array $fields * @SuppressWarnings(PHPMD.CyclomaticComplexity) * * @return Account|null */ public static function firstOrCreateEncrypted(array $fields) { // everything but the name: $query = Account::orderBy('id'); foreach ($fields as $name => $value) { if ($name != 'name') { $query->where($name, $value); } } $set = $query->get(['accounts.*']); /** @var Account $account */ foreach ($set as $account) { if ($account->name == $fields['name']) { return $account; } } // create it! $account = Account::create($fields); if (is_null($account->id)) { // could not create account: App::abort(500, 'Could not create new account with data: ' . json_encode($fields) . ' because ' . json_encode($account->getErrors())); } return $account; } /** * @param array $fields * * @return Account|null */ public static function firstOrNullEncrypted(array $fields) { // everything but the name: $query = Account::orderBy('id'); foreach ($fields as $name => $value) { if ($name != 'name') { $query->where($name, $value); } } $set = $query->get(['accounts.*']); /** @var Account $account */ foreach ($set as $account) { if ($account->name == $fields['name']) { return $account; } } return null; } /** * @codeCoverageIgnore * @return \Illuminate\Database\Eloquent\Relations\HasMany */ public function accountMeta() { return $this->hasMany('FireflyIII\Models\AccountMeta'); } /** * @codeCoverageIgnore * @return \Illuminate\Database\Eloquent\Relations\BelongsTo */ public function accountType() { return $this->belongsTo('FireflyIII\Models\AccountType'); } /** * @codeCoverageIgnore * @return array */ public function getDates() { return ['created_at', 'updated_at', 'deleted_at']; } /** * * @param $fieldName * @codeCoverageIgnore * * @return string|null */ public function getMeta($fieldName) { foreach ($this->accountMeta as $meta) { if ($meta->name == $fieldName) { return $meta->data; } } return null; } /** * @codeCoverageIgnore * * @param $value * * @return string */ public function getNameAttribute($value) { if (intval($this->encrypted) == 1) { return Crypt::decrypt($value); } return $value; } /** * @param $value * @codeCoverageIgnore * @return float|int */ public function getVirtualBalanceAttribute($value) { if (is_null($this->virtual_balance_encrypted)) { return $value; } $value = intval(Crypt::decrypt($this->virtual_balance_encrypted)); $value = $value / 100; return $value; } /** * @codeCoverageIgnore * @return \Illuminate\Database\Eloquent\Relations\HasMany */ public function piggyBanks() { return $this->hasMany('FireflyIII\Models\PiggyBank'); } /** * @codeCoverageIgnore * * @param EloquentBuilder $query * @param array $types */ public function scopeAccountTypeIn(EloquentBuilder $query, array $types) { if (is_null($this->joinedAccountTypes)) { $query->leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id'); $this->joinedAccountTypes = true; } $query->whereIn('account_types.type', $types); } /** * @codeCoverageIgnore * * @param EloquentBuilder $query * @param string $name * @param string $value */ public function scopeHasMetaValue(EloquentBuilder $query, $name, $value) { $joinName = str_replace('.', '_', $name); $query->leftJoin( 'account_meta as ' . $joinName, function (JoinClause $join) use ($joinName, $name) { $join->on($joinName . '.account_id', '=', 'accounts.id')->where($joinName . '.name', '=', $name); } ); $query->where($joinName . '.data', json_encode($value)); } /** * @codeCoverageIgnore * * @param $value */ public function setNameAttribute($value) { $this->attributes['name'] = Crypt::encrypt($value); $this->attributes['encrypted'] = true; } /** * @param $value * @codeCoverageIgnore */ public function setVirtualBalanceAttribute($value) { // save in cents: $value = intval($value * 100); $this->attributes['virtual_balance_encrypted'] = Crypt::encrypt($value); $this->attributes['virtual_balance'] = ($value / 100); } /** * @codeCoverageIgnore * @return \Illuminate\Database\Eloquent\Relations\HasMany */ public function transactions() { return $this->hasMany('FireflyIII\Models\Transaction'); } /** * @codeCoverageIgnore * @return \Illuminate\Database\Eloquent\Relations\BelongsTo */ public function user() { return $this->belongsTo('FireflyIII\User'); } }