'date', 'updated_at' => 'date', 'deleted_at' => 'date', 'encrypted' => 'boolean', ]; /** @var array */ protected $dates = ['created_at', 'updated_at', 'deleted_at']; /** @var array */ protected $fillable = ['user_id', 'name']; /** @var array */ protected $hidden = ['encrypted']; /** @var array */ protected $rules = ['name' => 'required|between:1,200',]; /** * @param array $fields * * @return Category */ public static function firstOrCreateEncrypted(array $fields) { // everything but the name: $query = self::orderBy('id'); $search = $fields; unset($search['name']); foreach ($search as $name => $value) { $query->where($name, $value); } $set = $query->get(['categories.*']); /** @var Category $category */ foreach ($set as $category) { if ($category->name == $fields['name']) { return $category; } } // create it! $category = self::create($fields); return $category; } /** * @param Category $value * * @return Category */ public static function routeBinder(Category $value) { if (auth()->check()) { if ($value->user_id == auth()->user()->id) { return $value; } } throw new NotFoundHttpException; } /** * * @param $value * * @return string */ public function getNameAttribute($value) { if ($this->encrypted) { return Crypt::decrypt($value); } return $value; } /** * * @param $value */ public function setNameAttribute($value) { $encrypt = config('firefly.encryption'); $this->attributes['name'] = $encrypt ? Crypt::encrypt($value) : $value; $this->attributes['encrypted'] = $encrypt; } /** * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany */ public function transactionJournals() { return $this->belongsToMany('FireflyIII\Models\TransactionJournal', 'category_transaction_journal', 'category_id'); } /** * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany */ public function transactions() { return $this->belongsToMany('FireflyIII\Models\Transaction', 'category_transaction', 'category_id'); } /** * @return BelongsTo */ public function user(): BelongsTo { return $this->belongsTo('FireflyIII\User'); } }