From 74b69d7b91e8cf2711279228ad67f7abc20c00bb Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 12:18:08 +0000 Subject: updating deps --- mix.lock | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/mix.lock b/mix.lock index 97e7b95..123d113 100644 --- a/mix.lock +++ b/mix.lock @@ -1,16 +1,16 @@ -%{"bunt": {:hex, :bunt, "0.1.6", "5d95a6882f73f3b9969fdfd1953798046664e6f77ec4e486e6fafc7caad97c6f", [], []}, +%{"bunt": {:hex, :bunt, "0.1.6", "5d95a6882f73f3b9969fdfd1953798046664e6f77ec4e486e6fafc7caad97c6f", [:mix], []}, "certifi": {:hex, :certifi, "0.7.0", "861a57f3808f7eb0c2d1802afeaae0fa5de813b0df0979153cbafcd853ababaf", [:rebar3], []}, "credo": {:hex, :credo, "0.5.1", "2395862b94628cadf0f5c68975c1440393f425b955f1e70ce1aea267e00187a1", [:mix], [{:bunt, "~> 0.1.6", [hex: :bunt, optional: false]}]}, - "dialyxir": {:hex, :dialyxir, "0.3.5", "eaba092549e044c76f83165978979f60110dc58dd5b92fd952bf2312f64e9b14", [], []}, + "dialyxir": {:hex, :dialyxir, "0.3.5", "eaba092549e044c76f83165978979f60110dc58dd5b92fd952bf2312f64e9b14", [:mix], []}, "earmark": {:hex, :earmark, "1.0.2", "a0b0904d74ecc14da8bd2e6e0248e1a409a2bc91aade75fcf428125603de3853", [:mix], []}, "ex_doc": {:hex, :ex_doc, "0.14.3", "e61cec6cf9731d7d23d254266ab06ac1decbb7651c3d1568402ec535d387b6f7", [:mix], [{:earmark, "~> 1.0", [hex: :earmark, optional: false]}]}, "excoveralls": {:hex, :excoveralls, "0.5.7", "5d26e4a7cdf08294217594a1b0643636accc2ad30e984d62f1d166f70629ff50", [:mix], [{:exjsx, "~> 3.0", [hex: :exjsx, optional: false]}, {:hackney, ">= 0.12.0", [hex: :hackney, optional: false]}]}, "exjsx": {:hex, :exjsx, "3.2.1", "1bc5bf1e4fd249104178f0885030bcd75a4526f4d2a1e976f4b428d347614f0f", [:mix], [{:jsx, "~> 2.8.0", [hex: :jsx, optional: false]}]}, - "hackney": {:hex, :hackney, "1.6.3", "d489d7ca2d4323e307bedc4bfe684323a7bf773ecfd77938f3ee8074e488e140", [:mix, :rebar3], [{:certifi, "0.7.0", [hex: :certifi, optional: false]}, {:idna, "1.2.0", [hex: :idna, optional: false]}, {:metrics, "1.0.1", [hex: :metrics, optional: false]}, {:mimerl, "1.0.2", [hex: :mimerl, optional: false]}, {:ssl_verify_fun, "1.1.1", [hex: :ssl_verify_fun, optional: false]}]}, + "hackney": {:hex, :hackney, "1.6.3", "d489d7ca2d4323e307bedc4bfe684323a7bf773ecfd77938f3ee8074e488e140", [:rebar3, :mix], [{:certifi, "0.7.0", [hex: :certifi, optional: false]}, {:idna, "1.2.0", [hex: :idna, optional: false]}, {:metrics, "1.0.1", [hex: :metrics, optional: false]}, {:mimerl, "1.0.2", [hex: :mimerl, optional: false]}, {:ssl_verify_fun, "1.1.1", [hex: :ssl_verify_fun, optional: false]}]}, "httpoison": {:hex, :httpoison, "0.9.2", "a211a8e87403a043c41218e64df250d321f236ac57f786c6a0ccf3e9e817c819", [:mix], [{:hackney, "~> 1.6.0", [hex: :hackney, optional: false]}]}, - "idna": {:hex, :idna, "1.2.0", "ac62ee99da068f43c50dc69acf700e03a62a348360126260e87f2b54eced86b2", [], []}, + "idna": {:hex, :idna, "1.2.0", "ac62ee99da068f43c50dc69acf700e03a62a348360126260e87f2b54eced86b2", [:rebar3], []}, "jsx": {:hex, :jsx, "2.8.0", "749bec6d205c694ae1786d62cea6cc45a390437e24835fd16d12d74f07097727", [:mix, :rebar], []}, - "metrics": {:hex, :metrics, "1.0.1", "25f094dea2cda98213cecc3aeff09e940299d950904393b2a29d191c346a8486", [], []}, - "mimerl": {:hex, :mimerl, "1.0.2", "993f9b0e084083405ed8252b99460c4f0563e41729ab42d9074fd5e52439be88", [], []}, - "poison": {:hex, :poison, "2.2.0", "4763b69a8a77bd77d26f477d196428b741261a761257ff1cf92753a0d4d24a63", [], []}, - "ssl_verify_fun": {:hex, :ssl_verify_fun, "1.1.1", "28a4d65b7f59893bc2c7de786dec1e1555bd742d336043fe644ae956c3497fbe", [:make, :rebar], []}} + "metrics": {:hex, :metrics, "1.0.1", "25f094dea2cda98213cecc3aeff09e940299d950904393b2a29d191c346a8486", [:rebar3], []}, + "mimerl": {:hex, :mimerl, "1.0.2", "993f9b0e084083405ed8252b99460c4f0563e41729ab42d9074fd5e52439be88", [:rebar3], []}, + "poison": {:hex, :poison, "2.2.0", "4763b69a8a77bd77d26f477d196428b741261a761257ff1cf92753a0d4d24a63", [:mix], []}, + "ssl_verify_fun": {:hex, :ssl_verify_fun, "1.1.1", "28a4d65b7f59893bc2c7de786dec1e1555bd742d336043fe644ae956c3497fbe", [:rebar, :make], []}} -- cgit v1.2.1 From dcd0050be5fc05d0460c5cc6508808ba8ab1cc7e Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 12:42:12 +0000 Subject: adding exact return to in memory show user route --- lib/http_client/in_memory.ex | 37 +++++++++++++++++++++++++++++++++++-- test/zendex/user_test.exs | 37 +++++++++++++++++++++++++++++++++++-- 2 files changed, 70 insertions(+), 4 deletions(-) diff --git a/lib/http_client/in_memory.ex b/lib/http_client/in_memory.ex index a448afd..46a53f5 100644 --- a/lib/http_client/in_memory.ex +++ b/lib/http_client/in_memory.ex @@ -26,9 +26,42 @@ defmodule Zendex.HttpClient.InMemory do fake_response("users") end - def get!("#{@base_url}/api/v2/users/87.json", + def get!("#{@base_url}/api/v2/users/295204.json", [{"Authorization", _authentication}]) do - fake_response(%{"user": %{"id": 87, "name": "Quim Stroud"}}) + fake_response(%{"user" => %{"ticket_restriction" => nil, + "chat_only" => false, + "shared_phone_number" => nil, + "notes" => "", + "phone" => nil, + "organization_id" => 11129520411, + "last_login_at" => "2016-10-28T21:08:23Z", + "moderator" => true, + "shared" => false, + "id" => 295204, + "role" => "admin", + "external_id" => nil, + "shared_agent" => false, + "photo" => nil, + "verified" => true, + "active" => true, + "locale_id" => 1, + "suspended" => false, + "created_at" => "2015-05-28T09:12:45Z", + "name" => "Nikolao Aikema", + "restricted_agent" => false, + "locale" => "en-US", + "details" => "", + "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/295204.json", + "custom_role_id" => nil, + "email" => "nikolao.aikema@test.com", + "signature" => nil, + "two_factor_auth_enabled" => nil, + "time_zone" => "London", + "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, + "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}}) end def get!("#{@base_url}/api/v2/users/show_many.json?ids=6,67", diff --git a/test/zendex/user_test.exs b/test/zendex/user_test.exs index 2d9f04c..d6b99f6 100644 --- a/test/zendex/user_test.exs +++ b/test/zendex/user_test.exs @@ -13,8 +13,41 @@ defmodule Zendex.UserTest do end test "showing a user", context do - expected = %{"user" => %{"id" => 87, "name" => "Quim Stroud"}} - actual = Zendex.User.show(context[:conn], 87) + expected = %{"user" => %{"ticket_restriction" => nil, + "chat_only" => false, + "shared_phone_number" => nil, + "notes" => "", + "phone" => nil, + "organization_id" => 11129520411, + "last_login_at" => "2016-10-28T21:08:23Z", + "moderator" => true, + "shared" => false, + "id" => 295204, + "role" => "admin", + "external_id" => nil, + "shared_agent" => false, + "photo" => nil, + "verified" => true, + "active" => true, + "locale_id" => 1, + "suspended" => false, + "created_at" => "2015-05-28T09:12:45Z", + "name" => "Nikolao Aikema", + "restricted_agent" => false, + "locale" => "en-US", + "details" => "", + "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/295204.json", + "custom_role_id" => nil, + "email" => "nikolao.aikema@test.com", + "signature" => nil, + "two_factor_auth_enabled" => nil, + "time_zone" => "London", + "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, + "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}} + actual = Zendex.User.show(context[:conn], 295204) assert expected == actual end -- cgit v1.2.1 From 528754e77d49abc2408bd4431bcf51e7316582c1 Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 13:16:04 +0000 Subject: updating README with piping example --- README.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/README.md b/README.md index 786e2dc..2518bcd 100644 --- a/README.md +++ b/README.md @@ -42,6 +42,14 @@ An Elixir wrapper for the Zendesk API. %{"user": %{"id": 87, "name": "Quim Stroud", ...}} ``` + 3. Using pipes: + + ```elixir + "http://test.zendesk.com" + |> Zendex.Connection.setup("Username1", "password123") + |> Zendex.User.show(101) + ``` + ## Completeness and Contributions This package far from complete in terms of utilising all of the Zendesk API, any contributions will be welcome. Please keep the code consistent with what I have already written here. -- cgit v1.2.1 From 5c6913cfc6025c6f97a5be93c444cab0376022fc Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 13:18:59 +0000 Subject: adding link to ex doc in readme --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index 2518bcd..797603d 100644 --- a/README.md +++ b/README.md @@ -8,6 +8,8 @@ An Elixir wrapper for the Zendesk API. +[ExDoc Documentation](https://hexdocs.pm/zendex) + ## Installation 1. Add `zendex` to your list of dependencies in `mix.exs`: -- cgit v1.2.1 From 96cf6093809b049dd55efd6c10593b95ec2e5d03 Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 13:19:48 +0000 Subject: adding doctest and example to show user function --- lib/zendex/user.ex | 23 +++++++++++++++++++++++ test/zendex/user_test.exs | 2 ++ 2 files changed, 25 insertions(+) diff --git a/lib/zendex/user.ex b/lib/zendex/user.ex index 31c3a06..4cae662 100644 --- a/lib/zendex/user.ex +++ b/lib/zendex/user.ex @@ -20,6 +20,29 @@ defmodule Zendex.User do @doc """ Show a specific user, given their id. + + ## Examples + + iex> conn = Zendex.Connection.setup("http://test.zendesk.com", "ZendeskUser", "Password1") + %{authentication: "WmVuZGVza1VzZXI6UGFzc3dvcmQx", base_url: "http://test.zendesk.com"} + iex> Zendex.User.show(conn, 295204) + %{"user" => %{"ticket_restriction" => nil, "chat_only" => false, + "shared_phone_number" => nil, "notes" => "", "phone" => nil, + "organization_id" => 11129520411, + "last_login_at" => "2016-10-28T21:08:23Z", "moderator" => true, + "shared" => false, "id" => 295204, "role" => "admin", + "external_id" => nil, "shared_agent" => false, "photo" => nil, + "verified" => true, "active" => true, "locale_id" => 1, + "suspended" => false, "created_at" => "2015-05-28T09:12:45Z", + "name" => "Nikolao Aikema", "restricted_agent" => false, + "locale" => "en-US", "details" => "", "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/295204.json", + "custom_role_id" => nil, "email" => "nikolao.aikema@test.com", + "signature" => nil, "two_factor_auth_enabled" => nil, + "time_zone" => "London", "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}} + """ @spec show(Zendex.Connection.t, integer) :: map def show(connection, id) do diff --git a/test/zendex/user_test.exs b/test/zendex/user_test.exs index d6b99f6..5217cb9 100644 --- a/test/zendex/user_test.exs +++ b/test/zendex/user_test.exs @@ -1,6 +1,8 @@ defmodule Zendex.UserTest do use ExUnit.Case, async: true + doctest Zendex.User + setup do [conn: Zendex.Connection.setup("http://test.zendesk.com", "User1", "pass")] end -- cgit v1.2.1 From bfee6d82bd6b5a259482d6398b913e68d680792a Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 13:51:12 +0000 Subject: adding functionality to delete a user --- lib/http_client/in_memory.ex | 38 ++++++++++++++++++++++++++++++++++++++ lib/zendex/user.ex | 10 ++++++++++ test/zendex/user_test.exs | 40 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 88 insertions(+) diff --git a/lib/http_client/in_memory.ex b/lib/http_client/in_memory.ex index 46a53f5..b74450e 100644 --- a/lib/http_client/in_memory.ex +++ b/lib/http_client/in_memory.ex @@ -82,5 +82,43 @@ defmodule Zendex.HttpClient.InMemory do fake_response(%{user: %{id: 1234, name: "Roger", email: "roger@dodger.com"}}) end + def delete!("#{@base_url}/api/v2/users/49043.json", + [{"Authorization", _authentication}]) do + fake_response(%{"user" => %{"ticket_restriction" => nil, + "chat_only" => false, + "shared_phone_number" => nil, + "notes" => "", + "phone" => nil, + "organization_id" => 149043, + "last_login_at" => "2016-10-28T21:08:23Z", + "moderator" => true, + "shared" => false, + "id" => 49043, + "role" => "admin", + "external_id" => nil, + "shared_agent" => false, + "photo" => nil, + "verified" => true, + "active" => false, + "locale_id" => 1, + "suspended" => false, + "created_at" => "2015-05-28T09:12:45Z", + "name" => "Rian Hawkins", + "restricted_agent" => false, + "locale" => "en-US", + "details" => "", + "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/49043.json", + "custom_role_id" => nil, + "email" => "rian.hawkins@test.com", + "signature" => nil, + "two_factor_auth_enabled" => nil, + "time_zone" => "London", + "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, + "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}}) + end + defp fake_response(body), do: %{body: Poison.encode!(body)} end diff --git a/lib/zendex/user.ex b/lib/zendex/user.ex index 4cae662..6873fb3 100644 --- a/lib/zendex/user.ex +++ b/lib/zendex/user.ex @@ -75,4 +75,14 @@ defmodule Zendex.User do |> CommonHelpers.decode_response end + @doc """ + Delete a user. + """ + @spec show(Zendex.Connection.t, integer) :: map + def delete(connection, id) do + "#{connection.base_url}#{@url}/#{id}.json" + |> @http_client.delete!(CommonHelpers.get_headers(connection.authentication)) + |> CommonHelpers.decode_response + end + end diff --git a/test/zendex/user_test.exs b/test/zendex/user_test.exs index 5217cb9..b4aaaec 100644 --- a/test/zendex/user_test.exs +++ b/test/zendex/user_test.exs @@ -68,4 +68,44 @@ defmodule Zendex.UserTest do assert expected == actual end + + test "deleting a user", context do + expected = %{"user" => %{"ticket_restriction" => nil, + "chat_only" => false, + "shared_phone_number" => nil, + "notes" => "", + "phone" => nil, + "organization_id" => 149043, + "last_login_at" => "2016-10-28T21:08:23Z", + "moderator" => true, + "shared" => false, + "id" => 49043, + "role" => "admin", + "external_id" => nil, + "shared_agent" => false, + "photo" => nil, + "verified" => true, + "active" => false, + "locale_id" => 1, + "suspended" => false, + "created_at" => "2015-05-28T09:12:45Z", + "name" => "Rian Hawkins", + "restricted_agent" => false, + "locale" => "en-US", + "details" => "", + "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/49043.json", + "custom_role_id" => nil, + "email" => "rian.hawkins@test.com", + "signature" => nil, + "two_factor_auth_enabled" => nil, + "time_zone" => "London", + "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, + "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}} + actual = Zendex.User.delete(context[:conn], 49043) + + assert expected == actual + end end -- cgit v1.2.1 From dc3eabba821ff4f80ca417123629ca9ceb92eb51 Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 14:01:08 +0000 Subject: adding doctest for deleting a user. --- lib/zendex/user.ex | 92 ++++++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 76 insertions(+), 16 deletions(-) diff --git a/lib/zendex/user.ex b/lib/zendex/user.ex index 6873fb3..88487f3 100644 --- a/lib/zendex/user.ex +++ b/lib/zendex/user.ex @@ -26,22 +26,40 @@ defmodule Zendex.User do iex> conn = Zendex.Connection.setup("http://test.zendesk.com", "ZendeskUser", "Password1") %{authentication: "WmVuZGVza1VzZXI6UGFzc3dvcmQx", base_url: "http://test.zendesk.com"} iex> Zendex.User.show(conn, 295204) - %{"user" => %{"ticket_restriction" => nil, "chat_only" => false, - "shared_phone_number" => nil, "notes" => "", "phone" => nil, - "organization_id" => 11129520411, - "last_login_at" => "2016-10-28T21:08:23Z", "moderator" => true, - "shared" => false, "id" => 295204, "role" => "admin", - "external_id" => nil, "shared_agent" => false, "photo" => nil, - "verified" => true, "active" => true, "locale_id" => 1, - "suspended" => false, "created_at" => "2015-05-28T09:12:45Z", - "name" => "Nikolao Aikema", "restricted_agent" => false, - "locale" => "en-US", "details" => "", "alias" => nil, - "url" => "https://test.zendesk.com/api/v2/users/295204.json", - "custom_role_id" => nil, "email" => "nikolao.aikema@test.com", - "signature" => nil, "two_factor_auth_enabled" => nil, - "time_zone" => "London", "only_private_comments" => false, - "user_fields" => %{"customer_complaint" => nil}, "tags" => [], - "updated_at" => "2016-10-28T21:08:23Z"}} + %{"user" => %{"ticket_restriction" => nil, + "chat_only" => false, + "shared_phone_number" => nil, + "notes" => "", + "phone" => nil, + "organization_id" => 11129520411, + "last_login_at" => "2016-10-28T21:08:23Z", + "moderator" => true, + "shared" => false, + "id" => 295204, + "role" => "admin", + "external_id" => nil, + "shared_agent" => false, + "photo" => nil, + "verified" => true, + "active" => true, + "locale_id" => 1, + "suspended" => false, + "created_at" => "2015-05-28T09:12:45Z", + "name" => "Nikolao Aikema", + "restricted_agent" => false, + "locale" => "en-US", + "details" => "", + "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/295204.json", + "custom_role_id" => nil, + "email" => "nikolao.aikema@test.com", + "signature" => nil, + "two_factor_auth_enabled" => nil, + "time_zone" => "London", + "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, + "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}} """ @spec show(Zendex.Connection.t, integer) :: map @@ -77,6 +95,48 @@ defmodule Zendex.User do @doc """ Delete a user. + + ## Examples + + iex> conn = Zendex.Connection.setup("http://test.zendesk.com", "ZendeskUser", "Password1") + %{authentication: "WmVuZGVza1VzZXI6UGFzc3dvcmQx", base_url: "http://test.zendesk.com"} + iex> Zendex.User.delete(conn, 49043) + %{"user" => %{"ticket_restriction" => nil, + "chat_only" => false, + "shared_phone_number" => nil, + "notes" => "", + "phone" => nil, + "organization_id" => 149043, + "last_login_at" => "2016-10-28T21:08:23Z", + "moderator" => true, + "shared" => false, + "id" => 49043, + "role" => "admin", + "external_id" => nil, + "shared_agent" => false, + "photo" => nil, + "verified" => true, + "active" => false, + "locale_id" => 1, + "suspended" => false, + "created_at" => "2015-05-28T09:12:45Z", + "name" => "Rian Hawkins", + "restricted_agent" => false, + "locale" => "en-US", + "details" => "", + "alias" => nil, + "url" => "https://test.zendesk.com/api/v2/users/49043.json", + "custom_role_id" => nil, + "email" => "rian.hawkins@test.com", + "signature" => nil, + "two_factor_auth_enabled" => nil, + "time_zone" => "London", + "only_private_comments" => false, + "user_fields" => %{"customer_complaint" => nil}, + "tags" => [], + "updated_at" => "2016-10-28T21:08:23Z"}} + + """ @spec show(Zendex.Connection.t, integer) :: map def delete(connection, id) do -- cgit v1.2.1 From bf62e2d177726a5921b485988c89764dd34eae3f Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 14:19:53 +0000 Subject: adding ability to get related info on a user --- lib/http_client/in_memory.ex | 14 ++++++++++++++ lib/zendex/user.ex | 7 +++++++ test/zendex/user_test.exs | 14 ++++++++++++++ 3 files changed, 35 insertions(+) diff --git a/lib/http_client/in_memory.ex b/lib/http_client/in_memory.ex index b74450e..4c43211 100644 --- a/lib/http_client/in_memory.ex +++ b/lib/http_client/in_memory.ex @@ -70,6 +70,20 @@ defmodule Zendex.HttpClient.InMemory do %{id: 67, name: "Sarpedon Baumgartner"}]}) end + def get!("#{@base_url}/api/v2/users/649267/related.json", + [{"Authorization", _authentication}]) do + fake_response(%{"user_related" => %{"assigned_tickets" => 12, + "ccd_tickets" => 5, + "entry_subscriptions" => 1, + "forum_subscriptions" => 3, + "organization_subscriptions" => 1, + "requested_tickets" => 7, + "subscriptions" => 6, + "topic_comments" => 116, + "topics" => 5, + "votes" => 2001}}) + end + def post!(@base_url <> "/api/v2/tickets.json", "{\"ticket\":{}}", [{"Authorization", _authentication}, {"Content-Type", "application/json"}]) do diff --git a/lib/zendex/user.ex b/lib/zendex/user.ex index 88487f3..3983432 100644 --- a/lib/zendex/user.ex +++ b/lib/zendex/user.ex @@ -81,6 +81,13 @@ defmodule Zendex.User do |> CommonHelpers.decode_response end + @spec related_information(Zendex.Connection.t, integer) :: map + def related_information(connection, id) do + "#{connection.base_url}#{@url}/#{id}/related.json" + |> @http_client.get!(CommonHelpers.get_headers(connection.authentication)) + |> CommonHelpers.decode_response + end + @doc """ Create a new user. """ diff --git a/test/zendex/user_test.exs b/test/zendex/user_test.exs index b4aaaec..f260f62 100644 --- a/test/zendex/user_test.exs +++ b/test/zendex/user_test.exs @@ -62,6 +62,20 @@ defmodule Zendex.UserTest do assert expected == actual end + test "getting related info on a user", context do + expected = %{"user_related" => %{"assigned_tickets" => 12, + "ccd_tickets" => 5, + "entry_subscriptions" => 1, + "forum_subscriptions" => 3, + "organization_subscriptions" => 1, + "requested_tickets" => 7, + "subscriptions" => 6, + "topic_comments" => 116, + "topics" => 5, + "votes" => 2001}} + actual = Zendex.User.related_information(context[:conn], 649267) + end + test "creating a user", context do expected = %{"user" => %{"id" => 1234, "name" => "Roger", "email" => "roger@dodger.com"}} actual = Zendex.User.create(context[:conn], %{user: %{name: "Roger", email: "roger@dodger.com"}}) -- cgit v1.2.1 From 01b8203e4d97d08a6462c29bac8fccd11ee8fb97 Mon Sep 17 00:00:00 2001 From: Steven Blowers Date: Tue, 1 Nov 2016 14:29:44 +0000 Subject: adding doctest for user related info --- lib/zendex/user.ex | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/lib/zendex/user.ex b/lib/zendex/user.ex index 3983432..9112b7f 100644 --- a/lib/zendex/user.ex +++ b/lib/zendex/user.ex @@ -81,6 +81,26 @@ defmodule Zendex.User do |> CommonHelpers.decode_response end + @doc """ + Show information relating to the user, example: number of assigned tickets. + + ## Examples + + iex> conn = Zendex.Connection.setup("http://test.zendesk.com", "ZendeskUser", "Password1") + %{authentication: "WmVuZGVza1VzZXI6UGFzc3dvcmQx", base_url: "http://test.zendesk.com"} + iex> Zendex.User.related_information(conn, 649267) + %{"user_related" => %{"assigned_tickets" => 12, + "ccd_tickets" => 5, + "entry_subscriptions" => 1, + "forum_subscriptions" => 3, + "organization_subscriptions" => 1, + "requested_tickets" => 7, + "subscriptions" => 6, + "topic_comments" => 116, + "topics" => 5, + "votes" => 2001}} + + """ @spec related_information(Zendex.Connection.t, integer) :: map def related_information(connection, id) do "#{connection.base_url}#{@url}/#{id}/related.json" -- cgit v1.2.1