Skip to content

class Athena::Validator::Constraints::Image
inherits Athena::Validator::Constraints::File #

An extension of AVD::Constraints::File whose AVD::Constraints::File#mime_types and AVD::Constraints::File#mime_type_message are setup to specifically handle image files. This constraint also provides the ability to validate against various image specific parameters.

See AVD::Constraints::File for common documentation.

class Profile
  include AVD::Validatable

  def initialize(@avatar : ::File); end

  @[Assert::Image]
  property avatar : ::File
end

Configuration#

Optional Arguments#

mime_types#

Type: Enumerable(String)? Default: {"image/*"}

Requires the file to have a valid image MIME type. See IANA website for the full listing.

mime_type_message#

Type: String Default: This file is not a valid image.

The message that will be shown if the file is not an image.

min_height#

Type: Int32 Default: nil

If set, the image's height in pixels must be greater than or equal to this value.

min_height_message#

Type: String Default: The image height is too small ({{ height }}px). Minimum height expected is {{ min_height }}px.

The message that will be shown if the height of the image is less than #min_height.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The current (invalid) height.
  • {{ min_height }} - The minimum required height.

max_height#

Type: Int32 Default: nil

If set, the image's height in pixels must be less than or equal to this value.

max_height_message#

Type: String Default: The image height is too big ({{ height }}px). Allowed maximum height is {{ max_height }}px.

The message that will be shown if the height of the image exceeds #max_height.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The current (invalid) height.
  • {{ max_height }} - The maximum allowed height.

min_width#

Type: Int32 Default: nil

If set, the image's width in pixels must be greater than or equal to this value.

min_width_message#

Type: String Default: The image width is too small ({{ width }}px). Minimum width expected is {{ min_width }}px.

The message that will be shown if the width of the image is less than #min_width.

Placeholders#

The following placeholders can be used in this message:

  • {{ width }} - The current (invalid) width.
  • {{ min_width }} - The minimum required width.

max_width#

Type: Int32 Default: nil

If set, the image's width in pixels must be less than or equal to this value.

max_width_message#

Type: String Default: The image width is too big ({{ width }}px). Allowed maximum width is {{ max_width }}px.

The message that will be shown if the width of the image exceeds #max_width.

Placeholders#

The following placeholders can be used in this message:

  • {{ width }} - The current (invalid) width.
  • {{ max_width }} - The maximum allowed width.

size_not_detected_message#

Type: String Default: The size of the image could not be detected.

The message that will be shown if the size of the image is unable to be determined. Will only occur if at least one of the size related options has been set.

min_ratio#

Type: Float64 Default: nil

If set, the image's aspect ratio (width / height) must be greater than or equal to this value.

min_ratio_message#

Type: String Default: The image ratio is too small ({{ ratio }}). Minimum ratio expected is {{ min_ratio }}.

The message that will be shown if the aspect ratio of the image is less than #min_ratio.

Placeholders#

The following placeholders can be used in this message:

  • {{ ratio }} - The current (invalid) ratio.
  • {{ min_ratio }} - The minimum required ratio.

max_ratio#

Type: Float64 Default: nil

If set, the image's aspect ratio (width / height) must be less than or equal to this value.

max_ratio_message#

Type: String Default: The image ratio is too big ({{ ratio }}). Allowed maximum ratio is {{ max_ratio }}.

The message that will be shown if the aspect ratio of the image exceeds #max_ratio.

Placeholders#

The following placeholders can be used in this message:

  • {{ ratio }} - The current (invalid) ratio.
  • {{ max_ratio }} - The maximum allowed ratio.

min_pixels#

Type: Float64 Default: nil

If set, the amount of pixels of the image file must be greater than or equal to this value.

min_pixels_message#

Type: String Default: The image has too few pixels ({{ pixels }} pixels). Minimum amount expected is {{ min_pixels }} pixels.

The message that will be shown if the amount of pixels of the image is less than #min_pixels.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The image's height.
  • {{ width }} - The image's width.
  • {{ pixels }} - The image's pixels.
  • {{ min_pixels }} - The minimum required pixels.

max_pixels#

Type: Float64 Default: nil

If set, the amount of pixels of the image file must be less than or equal to this value.

max_pixels_message#

Type: String Default: The image has too many pixels ({{ pixels }} pixels). Maximum amount expected is {{ max_pixels }} pixels.

The message that will be shown if the amount of pixels of the image is greater than #max_pixels.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The image's height.
  • {{ width }} - The image's width.
  • {{ pixels }} - The image's pixels.
  • {{ max_pixels }} - The maximum allowed pixels.

allow_landscape#

Type: Bool Default: true

If false, the image cannot be landscape oriented.

allow_landscape_message#

Type: String Default: The image is landscape oriented ({{ width }}x{{ height }}px). Landscape oriented images are not allowed.

The message that will be shown if the #allow_landscape is false and the image is landscape oriented.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The image's height.
  • {{ width }} - The image's width.

allow_portrait#

Type: Bool Default: true

If false, the image cannot be portrait oriented.

allow_portrait_message#

Type: String Default: The image is portrait oriented ({{ width }}x{{ height }}px). Portrait oriented images are not allowed.

The message that will be shown if the #allow_portrait is false and the image is portrait oriented.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The image's height.
  • {{ width }} - The image's width.

allow_square#

Type: Bool Default: true

If false, the image cannot be a square. If you want to force the image to be a square, keep this as is and set #allow_landscape and #allow_portrait to false.

allow_square_message#

Type: String Default: The image is square ({{ width }}x{{ height }}px). Square images are not allowed.

The message that will be shown if the #allow_square is false and the image is square.

Placeholders#

The following placeholders can be used in this message:

  • {{ height }} - The image's height.
  • {{ width }} - The image's width.

groups#

Type: Array(String) | String | Nil Default: nil

The validation groups this constraint belongs to. AVD::Constraint::DEFAULT_GROUP is assumed if nil.

payload#

Type: Hash(String, String)? Default: nil

Any arbitrary domain-specific data that should be stored with this constraint. The payload is not used by Athena::Validator, but its processing is completely up to you.

Constants#

CORRUPTED_IMAGE_ERROR = "5d4163f3-648f-4e39-87fd-cc5ea7aad2d1"#

LANDSCAPE_NOT_ALLOWED_ERROR = "6f895685-7cf2-4d65-b3da-9029c5581d88"#

PORTRAIT_NOT_ALLOWED_ERROR = "65608156-77da-4c79-a88c-02ef6d18c782"#

RATIO_TOO_BIG_ERROR = "70cafca6-168f-41c9-8c8c-4e47a52be643"#

RATIO_TOO_SMALL_ERROR = "59b8c6ef-bcf2-4ceb-afff-4642ed92f12e"#

SIZE_NOT_DETECTED_ERROR = "6d55c3f4-e58e-4fe3-91ee-74b492199956"#

SQUARE_NOT_ALLOWED_ERROR = "5d41425b-facb-47f7-a55a-de9fbe45cb46"#

TOO_FEW_PIXEL_ERROR = "1b06b97d-ae48-474e-978f-038a74854c43"#

TOO_HIGH_ERROR = "7efae81c-4877-47ba-aa65-d01ccb0d4645"#

TOO_LOW_ERROR = "aef0cb6a-c07f-4894-bc08-1781420d7b4c"#

TOO_MANY_PIXEL_ERROR = "ee0804e8-44db-4eac-9775-be91aaf72ce1"#

TOO_NARROW_ERROR = "9afbd561-4f90-4a27-be62-1780fc43604a"#

TOO_WIDE_ERROR = "7f87163d-878f-47f5-99ba-a8eb723a1ab2"#

Constructors#

.new(min_width : Int32 | Nil = nil, max_width : Int32 | Nil = nil, min_height : Int32 | Nil = nil, max_height : Int32 | Nil = nil, min_ratio : Float64 | Nil = nil, max_ratio : Float64 | Nil = nil, min_pixels : Float64 | Nil = nil, max_pixels : Float64 | Nil = nil, allow_square : Bool = true, allow_landscape : Bool = true, allow_portrait : Bool = true, size_not_detected_message : String = "The size of the image could not be detected.", min_width_message : String = "The image width is too small ({{ width }}px). Minimum width expected is {{ min_width }}px.", max_width_message : String = "The image width is too big ({{ width }}px). Allowed maximum width is {{ max_width }}px.", min_height_message : String = "The image height is too small ({{ height }}px). Minimum height expected is {{ min_height }}px.", max_height_message : String = "The image height is too big ({{ height }}px). Allowed maximum height is {{ max_height }}px.", min_pixels_message : String = "The image has too few pixels ({{ pixels }} pixels). Minimum amount expected is {{ min_pixels }} pixels.", max_pixels_message : String = "The image has too many pixels ({{ pixels }} pixels). Maximum amount expected is {{ max_pixels }} pixels.", min_ratio_message : String = "The image ratio is too small ({{ ratio }}). Minimum ratio expected is {{ min_ratio }}.", max_ratio_message : String = "The image ratio is too big ({{ ratio }}). Allowed maximum ratio is {{ max_ratio }}.", allow_square_message : String = "The image is square ({{ width }}x{{ height }}px). Square images are not allowed.", allow_landscape_message : String = "The image is landscape oriented ({{ width }}x{{ height }}px). Landscape oriented images are not allowed.", allow_portrait_message : String = "The image is portrait oriented ({{ width }}x{{ height }}px). Portrait oriented images are not allowed.", max_size : Int | String | Nil = nil, binary_format : Bool | Nil = nil, mime_types : Enumerable(String) | Nil = {"image/*"}, not_found_message : String = "The file could not be found.", not_readable_message : String = "The file is not readable.", empty_message : String = "An empty file is not allowed.", max_size_message : String = "The file is too large ({{ size }} {{ suffix }}). Allowed maximum size is {{ limit }} {{ suffix }}.", mime_type_message : String = "This file is not a valid image.", groups : Array(String) | String | Nil = nil, payload : Hash(String, String) | Nil = nil)#

Methods#

#allow_landscape? : Bool#

#allow_landscape_message : String#

#allow_portrait? : Bool#

#allow_portrait_message : String#

#allow_square? : Bool#

#allow_square_message : String#

#max_height : Int32 | ::Nil#

#max_height_message : String#

#max_pixels : Float64 | ::Nil#

#max_pixels_message : String#

#max_ratio : Float64 | ::Nil#

#max_ratio_message : String#

#max_width : Int32 | ::Nil#

#max_width_message : String#

#min_height : Int32 | ::Nil#

#min_height_message : String#

#min_pixels : Float64 | ::Nil#

#min_pixels_message : String#

#min_ratio : Float64 | ::Nil#

#min_ratio_message : String#

#min_width : Int32 | ::Nil#

#min_width_message : String#

#size_not_detected_message : String#

#validated_by : AVD::ConstraintValidator.class#

:inherit: