AsEncryptedCollection.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. namespace Illuminate\Database\Eloquent\Casts;
  3. use Illuminate\Contracts\Database\Eloquent\Castable;
  4. use Illuminate\Contracts\Database\Eloquent\CastsAttributes;
  5. use Illuminate\Support\Collection;
  6. use Illuminate\Support\Facades\Crypt;
  7. use InvalidArgumentException;
  8. class AsEncryptedCollection implements Castable
  9. {
  10. /**
  11. * Get the caster class to use when casting from / to this cast target.
  12. *
  13. * @param array $arguments
  14. * @return \Illuminate\Contracts\Database\Eloquent\CastsAttributes<\Illuminate\Support\Collection<array-key, mixed>, iterable>
  15. */
  16. public static function castUsing(array $arguments)
  17. {
  18. return new class($arguments) implements CastsAttributes
  19. {
  20. public function __construct(protected array $arguments)
  21. {
  22. }
  23. public function get($model, $key, $value, $attributes)
  24. {
  25. $collectionClass = $this->arguments[0] ?? Collection::class;
  26. if (! is_a($collectionClass, Collection::class, true)) {
  27. throw new InvalidArgumentException('The provided class must extend ['.Collection::class.'].');
  28. }
  29. if (isset($attributes[$key])) {
  30. return new $collectionClass(Json::decode(Crypt::decryptString($attributes[$key])));
  31. }
  32. return null;
  33. }
  34. public function set($model, $key, $value, $attributes)
  35. {
  36. if (! is_null($value)) {
  37. return [$key => Crypt::encryptString(Json::encode($value))];
  38. }
  39. return null;
  40. }
  41. };
  42. }
  43. /**
  44. * Specify the collection for the cast.
  45. *
  46. * @param class-string $class
  47. * @return string
  48. */
  49. public static function using($class)
  50. {
  51. return static::class.':'.$class;
  52. }
  53. }