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: