Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dreamingechoes/randomuser_ex
Elixir wrapper to consume randomuser.me API.
https://github.com/dreamingechoes/randomuser_ex
elixir elixir-wrapper package randomuser
Last synced: about 2 months ago
JSON representation
Elixir wrapper to consume randomuser.me API.
- Host: GitHub
- URL: https://github.com/dreamingechoes/randomuser_ex
- Owner: dreamingechoes
- License: mit
- Created: 2017-08-16T11:31:57.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-08-26T23:27:44.000Z (over 7 years ago)
- Last Synced: 2024-09-21T08:48:02.486Z (3 months ago)
- Topics: elixir, elixir-wrapper, package, randomuser
- Language: Elixir
- Homepage: https://hex.pm/packages/randomuser_ex
- Size: 20.5 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# RandomuserEx
[![Docs](https://img.shields.io/badge/docs-latest-brightgreen.svg?style=flat)](http://hexdocs.pm/randomuser_ex/)
[![CircleCI](https://circleci.com/gh/dreamingechoes/randomuser_ex.svg?style=shield)](https://circleci.com/gh/dreamingechoes/randomuser_ex)
[![Hex.pm](https://img.shields.io/hexpm/v/giphy_ex.svg)](https://hex.pm/packages/randomuser_ex)
[![Ebert](https://ebertapp.io/github/dreamingechoes/randomuser_ex.svg)](https://ebertapp.io/github/dreamingechoes/randomuser_ex)Elixir wrapper to consume [randomuser.me](https://randomuser.me) API. This is just a way to make easier the use of this service in your Phoenix applications, all the credits of the development of the service are of their creators.
You can see the complete documentation of the API [here](https://randomuser.me/documentation).
## Installation
Add ``randomuser_ex`` to your dependencies in your ``mix.exs``:
```elixir
defp deps do
[
{:randomuser_ex, "~> 0.1.1"}
]
end
```and run `mix deps.get`.
## Usage
There's two main functions which we'll use in order to get some random users from the API. This two functions will return:
* `{:ok, user(s)}`: in case of sucess.
* `{:error, reason}`: in case of error.### RandomuserEx.get_one/1
This will allow us to get just one random user matching the options specified in the params. For example:
```elixir
iex(1)> {:ok, user} = RandomuserEx.get_one(%{gender: :male})
iex(2)> user.name
%RandomuserEx.Name{first: "frederikke", last: "hansen", title: "mr"}
iex(3)> user.name.last
"hansen"
```### RandomuserEx.get_many/2
This will allow us to get N random users matching the options specified in the params. For example:
```elixir
iex(1)> {:ok, users} = RandomuserEx.get_many(%{nat: :es}, 20)
iex(2)> length(users)
20
iex(3)> Enum.at(users, 0)
%RandomuserEx.RandomUser{cell: "653-661-792", email: "[email protected]",
gender: "male", ...}
```Here you have a list of some options that you can use to get random users:
| param | description | values |
|---|---|---|
| `:gender` | The gender of the user(s) | `:male` or `:female` |
| `:password` | Format of the password generated for the user(s) | string of combinations of `upper`, `lower`, `special` and number. E.g: "upper,special,1-8" |
| `:nat` | Nationality of the user(s) by the ISO code | `:au`, `:br`, `:ca`, `:ch`, `:de`, `:dk`, `:es`, `:fi`, `:fr`, `:gb`, `:ie`, `:ir`, `:nl`, `:nz`, `:tr`, `:us` |You can find the complete list of options [here](https://randomuser.me/documentation).
You can see the documentation of the package on the [hexdocs website](http://hexdocs.pm/randomuser_ex/0.1.0/).
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/dreamingechoes/randomuser_ex. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](https://contributor-covenant.org) code of conduct.
## License
The package is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).