Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/achedeuzot/ecto_commons
Ecto common validators for Date, Time, URLs, Emails, PostalCodes, Phone Numbers, Luhn checks, etc.
https://github.com/achedeuzot/ecto_commons
changeset ecto elixir hacktoberfest hex
Last synced: 1 day ago
JSON representation
Ecto common validators for Date, Time, URLs, Emails, PostalCodes, Phone Numbers, Luhn checks, etc.
- Host: GitHub
- URL: https://github.com/achedeuzot/ecto_commons
- Owner: achedeuzot
- License: mit
- Created: 2020-09-06T14:10:12.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-08-08T09:09:46.000Z (5 months ago)
- Last Synced: 2024-12-25T10:04:32.154Z (9 days ago)
- Topics: changeset, ecto, elixir, hacktoberfest, hex
- Language: Elixir
- Homepage:
- Size: 136 KB
- Stars: 51
- Watchers: 4
- Forks: 15
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# EctoCommons
[![Build Status](https://github.com/achedeuzot/ecto_commons/workflows/tests/badge.svg)](https://github.com/achedeuzot/ecto_commons/actions?query=workflow%3Atests+branch%3Amaster) [![Coverage Status](https://coveralls.io/repos/github/achedeuzot/ecto_commons/badge.svg?branch=master)](https://coveralls.io/github/achedeuzot/ecto_commons?branch=master) [![Hex Version](https://img.shields.io/hexpm/v/ecto_commons.svg)](https://hex.pm/packages/ecto_commons) [![License](http://img.shields.io/badge/license-MIT-brightgreen.svg)](http://opensource.org/licenses/MIT)
Ecto common helpers such as validators and formatters.
## Installation
The package is available on [hex](https://hex.pm/), so it can be installed
by adding `ecto_commons` to your list of dependencies in `mix.exs`:```elixir
def deps do
[
{:ecto_commons, "~> 0.3.4"}
]
end
```## Incompatibility Warning
In order to check whether URLs are parseable,
this library requires either a recent (>= 1.13.0) of Elixir,
or an older (< 26) version of OTP.## Documentation
Documentation is published on [HexDocs](https://hexdocs.pm) and can
be found at [https://hexdocs.pm/ecto_commons](https://hexdocs.pm/ecto_commons).## Summary
The package contains common ecto helpers:
### Changeset validators
- `EctoCommons.DateValidator`:
- `validate_date(changeset, field, opts)`: validates an equality (with
approximation), before or after a given date.
- `EctoCommons.DateTimeValidator`
- `validate_datetime(changeset, field, opts)`: validates an equality (with
approximation), before or after a given date time.
- `EctoCommons.TimeValidator`
- `validate_time(changeset, field, opts)`: validates an equality (with
approximation), before or after a given time.
- `EctoCommons.EmailValidator`
- `validate_email(changeset, field, opts)`: validates emails. As there is no
perfect validation possible, multiple options are available depending
on your requirements. Can also reject temporary/burner emails.
- `EctoCommons.URLValidator`
- `validate_url(changeset, field, opts)`: validates if an URL is correct. Here
too, there is no perfection possible. Multiple options are available
depending on the precision required.
- `EctoCommons.StringValidator`
- `validate_has_prefix(changeset, field, opts)`: validates if a string starts
with a given prefix. The prefix itself can depend on another field or
on a dynamic value.
- `EctoCommons.PostalCodeValidator`
- `validate_postal_code(changeset, field, opts)`: validates postal code formatting
using regular expressions depending on the country. This only ensures the postal
code "looks ok" but doesn't check it really exists (that will need a complete
database of all postal codes worldwide).
- `EctoCommons.SocialSecurityValidator`
- `validate_social_security(changeset, field, opts)`: validates social security
numbers (SSN) depending on the country. This only validates french SSNs for now.
- `EctoCommons.LuhnValidator`
- `validate_luhn(changeset, field, opts)`: validates a string with Luhn's
algorithm such as credit card numbers and other administrative codes.
- `EctoCommons.PhoneNumberValidator`
- `validate_phone_number(changeset, field, opts)`: validates a phone number
using libphonenumber.## Changeset helpers
- `EctoCommons.Helpers`
- `validate_many(changeset, field, opts)`: validates multiple fields with the same
validation function as well as the same options.## Changelog
`ecto_commons` follows semantic versioning. See [`CHANGELOG.md`](https://github.com/achedeuzot/ecto_commons/blob/master/CHANGELOG.md) for more information.
## Development
Use [Earthly](https://earthly.dev/) to run tests against various versions of Elixir and Erlang.
```sh
earthly +all
```## License
MIT. Please see [LICENSE](https://github.com/achedeuzot/ecto_commons/blob/master/LICENSE) for licensing details.