Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/traitify/traitify_elixir
An Elixir client library for the Traitify API
https://github.com/traitify/traitify_elixir
Last synced: 8 days ago
JSON representation
An Elixir client library for the Traitify API
- Host: GitHub
- URL: https://github.com/traitify/traitify_elixir
- Owner: traitify
- License: apache-2.0
- Created: 2014-10-27T15:53:54.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2014-10-27T16:49:58.000Z (about 10 years ago)
- Last Synced: 2024-11-01T09:35:00.444Z (3 months ago)
- Language: Elixir
- Size: 145 KB
- Stars: 2
- Watchers: 14
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - An Elixir client library for the Traitify Developer's API. (Third Party APIs)
- fucking-awesome-elixir - traitify_elixir - An Elixir client library for the Traitify Developer's API. (Third Party APIs)
- awesome-elixir - traitify_elixir - An Elixir client library for the Traitify Developer's API. (Third Party APIs)
README
# Traitify Elixir
An Elixir client library for the Traitify Developer's API
## Using
It is simple to add to any project. If you are using the hex package manager, just add the following to your mix file:
``` elixir
def deps do
[ { :traitify_elixir, '~> 0.1.1' } ]
end
```If you aren't using hex, add the a reference to the github repo.
``` elixir
def deps do
[ { :traitify_elixir, github: "traitify/traitify_elixir" } ]
end
```Then run `mix deps.get` in the shell to fetch and compile the dependencies.
## Configuration
Next, set the environment variables for the API host and your secret key. You can obtain a secret key from
the [developer portal](http://developer.traitify.com). Once you register on the site, you will be provided
a key as well as information on the API host.``` bash
$ export TRAITIFY_API_HOST=https://api-sandbox.traitify.com
$ export TRAITIFY_API_KEY=```
## Example Usage### Decks
Retrieving a list of available decks is simple. Just call the all function on the Client module and pass it `:decks`.
``` shell
$ iex -S mix
iex(1)> decks = Traitify.Client.all(:decks)
```The all function returns the JSON response body from the Traitify API.
``` shell
iex(2)> deck = List.first(decks)
iex(3)> deck["id"]
"career-deck"
```### Assessments
Once you have a deck id, you can then create an assessment.
``` shell
iex(4)> assessment = Traitify.Client.create(:assessments, %{deck_id: deck["id"]})
%{"completed_at" => nil, "created_at" => 1414427522010,
"deck_id" => "career-deck", "id" => "3668590b-f32f-4db0-94e3-d35703b28820",
"tags" => nil}
```### Slides
Now that you have an assessment, it's time to get a list of the slides for that assessment
``` shell
iex(5)> slides = Traitify.Client.all(:slides, assessment_id: assessment["id"]})
```For each slide you can send the user's response or you can send a bulk set of responses. Here is an example of
updating for a single slide:``` shell
iex(6)> Client.update(:slides, %{response: , time_taken: 2},
assessment_id: assessment["id"],
slide_id: )
```### Results
Finally you can retrieve the personality types/traits results for a completed assessment. If the assessment is not complete, you will receive an 'Assessment Not Found' message.
``` shell
iex(7)> personality_types = Traitify.Client.all(:personality_types, [assessment_id: assessment["id"]])
iex(8)> personality_traits = Traitify.Client.all(:personality_traits, [assessment_id: assessment["id"]])
```### More Examples
You can check out the Elixir [example](http://github.com/traitify/example_elixir) application to get ideas for your own implementation. If you have questions, please contact [[email protected]](mailto:[email protected])