Add endpoint to retrieve user by userId
This commit is contained in:
@@ -80,6 +80,7 @@ func Register(extend HandlerExtender) {
|
|||||||
}).Methods("GET")
|
}).Methods("GET")
|
||||||
|
|
||||||
r.HandleFunc("/users/me", LoggedInUser).Methods("GET")
|
r.HandleFunc("/users/me", LoggedInUser).Methods("GET")
|
||||||
|
r.HandleFunc("/users/{userId}", GetUser).Methods("GET")
|
||||||
r.HandleFunc("/oauth/providers", ListProviders).Methods("GET")
|
r.HandleFunc("/oauth/providers", ListProviders).Methods("GET")
|
||||||
r.HandleFunc("/oauth/providers/{provider}/login", Login).Methods("GET")
|
r.HandleFunc("/oauth/providers/{provider}/login", Login).Methods("GET")
|
||||||
r.HandleFunc("/oauth/providers/{provider}/callback", LoginCallback).Methods("GET")
|
r.HandleFunc("/oauth/providers/{provider}/callback", LoginCallback).Methods("GET")
|
||||||
|
|||||||
23
handlers/user.go
Normal file
23
handlers/user.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package handlers
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/gorilla/mux"
|
||||||
|
)
|
||||||
|
|
||||||
|
func GetUser(rw http.ResponseWriter, req *http.Request) {
|
||||||
|
vars := mux.Vars(req)
|
||||||
|
userId := vars["userId"]
|
||||||
|
|
||||||
|
u, err := core.UserGet(userId)
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
rw.WriteHeader(http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
json.NewEncoder(rw).Encode(u)
|
||||||
|
}
|
||||||
@@ -351,7 +351,7 @@ func (store *storage) UserPut(user *types.User) error {
|
|||||||
store.db.UsersByProvider[fmt.Sprintf("%s_%s", user.Provider, user.ProviderUserId)] = user.Id
|
store.db.UsersByProvider[fmt.Sprintf("%s_%s", user.Provider, user.ProviderUserId)] = user.Id
|
||||||
store.db.Users[user.Id] = user
|
store.db.Users[user.Id] = user
|
||||||
|
|
||||||
return nil
|
return store.save()
|
||||||
}
|
}
|
||||||
func (store *storage) UserGet(id string) (*types.User, error) {
|
func (store *storage) UserGet(id string) (*types.User, error) {
|
||||||
store.rw.Lock()
|
store.rw.Lock()
|
||||||
|
|||||||
Reference in New Issue
Block a user