Skip to content

Commit

Permalink
Handle user not found error and only return user's public info
Browse files Browse the repository at this point in the history
  • Loading branch information
xetorthio committed Oct 17, 2017
1 parent b99c047 commit 71464cf
Showing 1 changed file with 14 additions and 1 deletion.
15 changes: 14 additions & 1 deletion handlers/user.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,31 @@ import (
"net/http"

"github.com/gorilla/mux"
"github.com/play-with-docker/play-with-docker/storage"
)

type PublicUserInfo struct {
Id string `json:"id"`
Avatar string `json:"avatar"`
Name string `json:"name"`
}

func GetUser(rw http.ResponseWriter, req *http.Request) {
vars := mux.Vars(req)
userId := vars["userId"]

u, err := core.UserGet(userId)
if err != nil {
if storage.NotFound(err) {
log.Printf("User with id %s was not found\n", userId)
rw.WriteHeader(http.StatusNotFound)
return
}
log.Println(err)
rw.WriteHeader(http.StatusInternalServerError)
return
}

json.NewEncoder(rw).Encode(u)
pui := PublicUserInfo{Id: u.Id, Avatar: u.Avatar, Name: u.Name}
json.NewEncoder(rw).Encode(pui)
}

0 comments on commit 71464cf

Please sign in to comment.