class Athena::Validator::Constraints::File
inherits Athena::Validator::Constraint
#
Validates that a value is a valid file.
If the underlying value is a ::File, then its path is used as the value.
Otherwise the value is converted to a string via #to_s
before being validated, which is assumed to be a path to a file.
Note
As with most other constraints, nil
and empty strings are considered valid values, in order to allow the value to be optional.
If the value is required, consider combining this constraint with AVD::Constraints::NotBlank
.
class Profile
include AVD::Validatable
def initialize(@resume : ::File); end
@[Assert::File]
property resume : ::File
end
Configuration#
Optional Arguments#
max_size#
Type: Int | String | Nil
Default: nil
Defines that maximum size the file must be in order to be considered valid. The value may be an integer representing the size in bytes, or a format string in one of the following formats:
Suffix | Unit Name | Value | Example |
---|---|---|---|
(none) | byte | 1 byte | 4096 |
k |
kilobyte | 1,000 bytes | "200k" |
M |
megabyte | 1,000,000 bytes | "2M" |
Ki |
kibibyte | 1,024 bytes | "32Ki" |
Mi |
mebibyte | 1,048,576 bytes | "8Mi" |
mime_types#
Type: Enumerable(String)?
Default: nil
If set, allows checking that the MIME type of the file is one of an allowed set of types. This value is ignored if the MIME type of the file could not be determined.
binary_format#
Type: Bool?
Default: nil
When true
, the sizes will be displayed in messages with binary-prefixed units (KiB, MiB).
When false
, the sizes will be displayed with SI-prefixed units (kB, MB).
When nil
, then the binaryFormat will be guessed from the value defined in the max_size option.
max_size_message#
Type: String
Default: The file is too large ({{ size }} {{ suffix }}). Allowed maximum size is {{ limit }} {{ suffix }}.
The message that will be shown if the file is greater than the max_size.
Placeholders#
The following placeholders can be used in this message:
{{ file }}
- Absolute path to the invalid file.{{ limit }}
- Maximum file size allowed.{{ name }}
- Basename of the invalid file.{{ size }}
- The size of the invalid file.{{ suffix }}
- Suffix for the used file size unit.
not_found_message#
Type: String
Default: The file could not be found.
The message that will be shown if no file could be found at the given path.
Placeholders#
The following placeholders can be used in this message:
{{ file }}
- Absolute path to the invalid file.
empty_message#
Type: String
Default: An empty file is not allowed.
The message that will be shown if the file is empty.
Placeholders#
The following placeholders can be used in this message:
{{ file }}
- Absolute path to the invalid file.{{ name }}
- Basename of the invalid file.
not_readable_message#
Type: String
Default: The file is not readable.
The message that will be shown if the file is not readable.
Placeholders#
The following placeholders can be used in this message:
{{ file }}
- Absolute path to the invalid file.{{ name }}
- Basename of the invalid file.
mime_type_message#
Type: String
Default: The mime type of the file is invalid ({{ type }}). Allowed mime types are {{ types }}.
The message that will be shown if the MIME type of the file is not one of the valid mime_types.
Placeholders#
The following placeholders can be used in this message:
{{ file }}
- Absolute path to the invalid file.{{ name }}
- Basename of the invalid file.{{ type }}
- The MIME type of the invalid file.{{ types }}
- The list of allowed MIME types.
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.
Direct known subclasses
Athena::Validator::Constraints::Image
Constants#
EMPTY_ERROR = "de1a4b3c-a69f-46bd-b017-4a60361a1765"
#
INVALID_MIME_TYPE_ERROR = "96c8591c-e990-48f6-b82b-75c878ae9fd9"
#
NOT_FOUND_ERROR = "b6ae563c-4aec-4dfa-b268-2bb282912ed8"
#
NOT_READABLE_ERROR = "e9f18a3d-f968-469f-868e-2331c8c982c2"
#
TOO_LARGE_ERROR = "4ce61d7c-43a0-44c2-bfe0-a59072b6cd17"
#
Constructors#
.new(max_size : Int | String | Nil = nil, binary_format : Bool | Nil = nil, mime_types : Enumerable(String) | Nil = nil, 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 = "The mime type of the file is invalid ({{ type }}). Allowed mime types are {{ types }}.", groups : Array(String) | String | Nil = nil, payload : Hash(String, String) | Nil = nil)
#
Methods#
#binary_format? : Bool
#
#empty_message : String
#
#max_size : Int64 | ::Nil
#
#max_size_message : String
#
#mime_type_message : String
#
#mime_types : Set(String) | ::Nil
#
#not_found_message : String
#
#not_readable_message : String
#
#validated_by : AVD::ConstraintValidator.class
#
Returns the AVD::ConstraintValidator.class
that should handle validating self
.