'json', 'user_id' => 'int', 'r_' . AdminAcl::RESOURCE_USERS => 'int', 'r_' . AdminAcl::RESOURCE_ALLOCATIONS => 'int', 'r_' . AdminAcl::RESOURCE_DATABASES => 'int', 'r_' . AdminAcl::RESOURCE_EGGS => 'int', 'r_' . AdminAcl::RESOURCE_LOCATIONS => 'int', 'r_' . AdminAcl::RESOURCE_NESTS => 'int', 'r_' . AdminAcl::RESOURCE_NODES => 'int', 'r_' . AdminAcl::RESOURCE_PACKS => 'int', 'r_' . AdminAcl::RESOURCE_SERVERS => 'int', ]; /** * Fields that are mass assignable. * * @var array */ protected $fillable = [ 'identifier', 'token', 'allowed_ips', 'memo', ]; /** * Fields that should not be included when calling toArray() or toJson() * on this model. * * @var array */ protected $hidden = ['token']; /** * Rules defining what fields must be passed when making a model. * * @var array */ protected static $applicationRules = [ 'identifier' => 'required', 'memo' => 'required', 'user_id' => 'required', 'token' => 'required', ]; /** * Rules to protect aganist invalid data entry to DB. * * @var array */ protected static $dataIntegrityRules = [ 'user_id' => 'exists:users,id', 'identifier' => 'string|size:16|unique:api_keys,identifier', 'token' => 'string', 'memo' => 'nullable|string|max:500', 'allowed_ips' => 'nullable|json', 'last_used_at' => 'nullable|date', 'r_' . AdminAcl::RESOURCE_USERS => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_ALLOCATIONS => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_DATABASES => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_EGGS => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_LOCATIONS => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_NESTS => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_NODES => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_PACKS => 'integer|min:0|max:3', 'r_' . AdminAcl::RESOURCE_SERVERS => 'integer|min:0|max:3', ]; /** * @var array */ protected $dates = [ self::CREATED_AT, self::UPDATED_AT, 'last_used_at', ]; /** * Return a decrypted version of the token. * * @return string */ public function getDecryptedTokenAttribute() { return app()->make(Encrypter::class)->decrypt($this->token); } /** * Gets the permissions associated with a key. * * @return \Illuminate\Database\Eloquent\Relations\HasMany */ public function permissions() { return $this->hasMany(APIPermission::class, 'key_id'); } }