Skip to content

Commit

Permalink
Merge pull request #1 from belltoy/master
Browse files Browse the repository at this point in the history
Add support for the session api
  • Loading branch information
zolazhou committed Dec 5, 2015
2 parents 105cad1 + 2540061 commit 5edfc16
Showing 1 changed file with 64 additions and 0 deletions.
64 changes: 64 additions & 0 deletions lib/consul/session.ex
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
#
# The MIT License (MIT)
#
# Copyright (c) 2014-2015 Undead Labs, LLC
#

defmodule Consul.Session do
alias Consul.Endpoint
use Consul.Endpoint, handler: Consul.Handler.Base

@session "session"
@create "create"
@destroy "destroy"
@info "info"
@list "list"
@node "node"
@renew "renew"

@spec create(map, Keyword.t) :: Endpoint.response
def create(body, opts \\ []) do
build_url([@session, @create], opts)
|> req_put(Poison.encode!(body))
end

@spec create!(map, Keyword.t) :: binary | no_return
def create!(body, opts \\ []) do
case create(body, opts) do
{:ok, %{body: body}} ->
body["ID"]
{:error, response} ->
raise Consul.ResponseError, response
end
end

@spec destroy(binary, Keyword.t) :: Endpoint.response
def destroy(session_id, opts \\ []) do
build_url([@session, @destroy, session_id], opts)
|> req_put("")
end

@spec info(binary, Keyword.t) :: Endpoint.response
def info(session_id, opts \\ []) do
build_url([@session, @info, session_id], opts)
|> req_get()
end

@spec node(binary, Keyword.t) :: Endpoint.response
def node(node_id, opts \\ []) do
build_url([@session, @node, node_id], opts)
|> req_get()
end

@spec list(Keyword.t) :: Endpoint.response
def list(opts \\ []) do
build_url([@session, @list], opts)
|> req_get()
end

@spec renew(binary, Keyword.t) :: Endpoint.response
def renew(session_id, opts \\ []) do
build_url([@session, @renew, session_id], opts)
|> req_put("")
end
end

0 comments on commit 5edfc16

Please sign in to comment.