Skip to content
This repository was archived by the owner on Aug 30, 2024. It is now read-only.

chore: expose API Token and BaseURL #252

Merged
merged 2 commits into from
Feb 25, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions coder-sdk/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -116,3 +116,13 @@ type DefaultClient struct {
// token is the API Token credential.
token string
}

// Token returns the API Token used to authenticate.
func (c *DefaultClient) Token() string {
return c.token
}

// BaseURL returns the BaseURL configured for this Client.
func (c *DefaultClient) BaseURL() url.URL {
return *c.baseURL
}
25 changes: 17 additions & 8 deletions coder-sdk/client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ func TestAuthentication(t *testing.T) {
t.Parallel()

const token = "g4mtIPUaKt-pPl9Q0xmgKs7acSypHt4Jf"

server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
gotToken := r.Header.Get("Session-Token")
require.Equal(t, token, gotToken, "token does not match")
Expand All @@ -37,28 +38,35 @@ func TestAuthentication(t *testing.T) {
})
require.NoError(t, err, "failed to create coder.Client")

require.Equal(t, token, client.Token(), "expected Token to match")
require.EqualValues(t, *u, client.BaseURL(), "expected BaseURL to match")

_, err = client.APIVersion(context.Background())
require.NoError(t, err, "failed to get API version information")
}

func TestPasswordAuthentication(t *testing.T) {
t.Parallel()

const email = "[email protected]"
const password = "coder4all"
const token = "g4mtIPUaKt-pPl9Q0xmgKs7acSypHt4Jf"

mux := http.NewServeMux()
mux.HandleFunc("/auth/basic/login", func(w http.ResponseWriter, r *http.Request) {
require.Equal(t, r.Method, http.MethodPost, "login is a POST")

expected := map[string]interface{}{
"email": "[email protected]",
"password": "coder4all",
"email": email,
"password": password,
}
var request map[string]interface{}
err := json.NewDecoder(r.Body).Decode(&request)
require.NoError(t, err, "error decoding JSON")
require.EqualValues(t, expected, request, "unexpected request data")

response := map[string]interface{}{
"session_token": "g4mtIPUaKt-pPl9Q0xmgKs7acSypHt4Jf",
"session_token": token,
}

w.WriteHeader(http.StatusOK)
Expand All @@ -68,11 +76,11 @@ func TestPasswordAuthentication(t *testing.T) {
mux.HandleFunc("/api/v0/users/me", func(w http.ResponseWriter, r *http.Request) {
require.Equal(t, http.MethodGet, r.Method, "Users is a GET")

require.Equal(t, "g4mtIPUaKt-pPl9Q0xmgKs7acSypHt4Jf", r.Header.Get("Session-Token"), "expected session token to match return of login")
require.Equal(t, token, r.Header.Get("Session-Token"), "expected session token to match return of login")

user := map[string]interface{}{
"id": "default",
"email": "[email protected]",
"email": email,
"username": "charlie",
"name": "Charlie Root",
"roles": []coder.Role{coder.SiteAdmin},
Expand All @@ -99,14 +107,15 @@ func TestPasswordAuthentication(t *testing.T) {
client, err := coder.NewClient(coder.ClientOptions{
BaseURL: u,
HTTPClient: server.Client(),
Email: "[email protected]",
Password: "coder4all",
Email: email,
Password: password,
})
require.NoError(t, err, "failed to create Client")
require.Equal(t, token, client.Token(), "expected token to match")

user, err := client.Me(context.Background())
require.NoError(t, err, "failed to get information about current user")
require.Equal(t, "[email protected]", user.Email, "expected test user")
require.Equal(t, email, user.Email, "expected test user")
}

func TestContextRoot(t *testing.T) {
Expand Down
6 changes: 6 additions & 0 deletions coder-sdk/interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -213,4 +213,10 @@ type Client interface {

// DeleteWorkspaceProviderByID deletes a workspace provider entity from the Coder control plane.
DeleteWorkspaceProviderByID(ctx context.Context, id string) error

// Token returns the API Token used to authenticate.
Token() string

// BaseURL returns the BaseURL configured for this Client.
BaseURL() url.URL
}
22 changes: 14 additions & 8 deletions coder-sdk/users_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ import (
func TestUsers(t *testing.T) {
t.Parallel()

const username = "root"
const name = "Charlie Root"

server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
require.Equal(t, http.MethodGet, r.Method, "Users is a GET")
require.Equal(t, "/api/v0/users", r.URL.Path)
Expand All @@ -25,8 +28,8 @@ func TestUsers(t *testing.T) {
{
"id": "default",
"email": "[email protected]",
"username": "root",
"name": "Charlie Root",
"username": username,
"name": name,
"roles": []coder.Role{coder.SiteAdmin},
"temporary_password": false,
"login_type": coder.LoginTypeBuiltIn,
Expand Down Expand Up @@ -56,20 +59,23 @@ func TestUsers(t *testing.T) {
users, err := client.Users(context.Background())
require.NoError(t, err, "error getting Users")
require.Len(t, users, 1, "users should return a single user")
require.Equal(t, "Charlie Root", users[0].Name)
require.Equal(t, "root", users[0].Username)
require.Equal(t, name, users[0].Name)
require.Equal(t, username, users[0].Username)
}

func TestUserUpdatePassword(t *testing.T) {
t.Parallel()

const oldPassword = "vt9g9rxsptrq"
const newPassword = "wmf39jw2f7pk"

server := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
require.Equal(t, http.MethodPatch, r.Method, "Users is a PATCH")
require.Equal(t, "/api/v0/users/me", r.URL.Path)

expected := map[string]interface{}{
"old_password": "vt9g9rxsptrq",
"password": "wmf39jw2f7pk",
"old_password": oldPassword,
"password": newPassword,
}
var request map[string]interface{}
err := json.NewDecoder(r.Body).Decode(&request)
Expand All @@ -94,8 +100,8 @@ func TestUserUpdatePassword(t *testing.T) {

err = client.UpdateUser(context.Background(), "me", coder.UpdateUserReq{
UserPasswordSettings: &coder.UserPasswordSettings{
OldPassword: "vt9g9rxsptrq",
Password: "wmf39jw2f7pk",
OldPassword: oldPassword,
Password: newPassword,
Temporary: false,
},
})
Expand Down