# Talos
[data:image/s3,"s3://crabby-images/2b36c/2b36cd127100310c834fe5a0373a5dd23979e37f" alt="hex.pm"](https://hexdocs.pm/talos)
[data:image/s3,"s3://crabby-images/b1131/b1131a7a51ec945a3479c4c0a488d68e3b17a59b" alt="hex.pm"](https://hex.pm/packages/talos)
[data:image/s3,"s3://crabby-images/21683/21683cc187d30198ce2a8481c748bc953418a0ff" alt="hex.pm"](https://hex.pm/packages/talos)
[data:image/s3,"s3://crabby-images/dad4f/dad4fce2630339bbc892f74c40facaabf7274a79" alt="hex.pm"](https://hex.pm/packages/talos)
[data:image/s3,"s3://crabby-images/ff9e9/ff9e9ac9838625195a56a3cb1a3fb3447e5f372e" alt="github.com"](https://github.com/balance-platform/talos/commits/master)
data:image/s3,"s3://crabby-images/c0c83/c0c830425cbc7afe210e493c7ec14501e6dbdd6d" alt="Elixir CI"
Talos is simple parameters validation library
Documentation can be found at [ExDoc](https://hexdocs.pm/talos/)
## Why another one validation library?
I needed more checks than just whether the value belonged to a particular data type.
This library allows you to define your own checks and use typical checks with a simple setup.
## Usage
```elixir
defmodule CheckUserSignUp do
import Talos
@schema map(fields: [
field(key: "action", type: const(value: "sign-up")),
field(key: "email", type: string(min_length: 5, max_length: 255, regexp: ~r/.*@.*/)),
field(key: "age", type: integer(gteq: 18, allow_nil: true))
])
def validate(%{} = map_data) do
params = Talos.permit(map_data)
errors = Talos.errors(@schema, params)
case errors == %{} do
true -> {:ok, params}
false -> {:error, errors}
end
end
end
```
Somewhere in UserController
```elixir
...
def sign_up(conn, params)
case CheckUserSignUp.valid?(params) do
:ok ->
result = MyApp.register_user!(params)
render_json(%{"ok" => true | result})
{:error, errors} ->
render_errors(errors)
end
end
...
```
## Flow
data:image/s3,"s3://crabby-images/8096d/8096d6225ec29988cb6abb404d17a1d6bb1236c7" alt=""
## Own Type definition
If you want define own Type, just create module with `Talos.Types` behavior
```elixir
defmodule ZipCodeType do
@behaviour Talos.Types
defstruct [length: 6]
def valid?(%__MODULE__{length: len}, value) do
String.valid?(value) && String.match?(value, ~r/\d{len}/)
end
def errors(__MODULE__, value) do
case valid?(__MODULE__,value) do
true -> []
false -> ["#{value} is not zipcode"]
end
end
end
# And use it
Talos.valid?(%ZipCodeType{}, "123456") # => true
Talos.valid?(%ZipCodeType{}, "1234") # => false
Talos.valid?(%ZipCodeType{}, 123456) # => false
```
## Installation
```elixir
def deps do
[
{:talos, "~> 1.12"}
]
end
```
# Contribution
Feel free to make a pull request. All contributions are appreciated!