Merge remote-tracking branch 'origin/master'
the build was successful Details

This commit is contained in:
kolaente 2018-09-17 18:25:17 +02:00
commit 24382f2dc0
Signed by: konrad
GPG Key ID: F40E70337AB24C9B
3 changed files with 16 additions and 25 deletions

View File

@ -58,11 +58,11 @@ func userAddOrUpdate(c echo.Context) error {
}
// Check if the user exists
var exists bool
var exists = true
_, err := models.GetUserByID(datUser.ID)
if err != nil {
if models.IsErrUserDoesNotExist(err) {
exists = true
exists = false
} else {
return c.JSON(http.StatusInternalServerError, models.Message{"Could not check if the user exists."})
}

View File

@ -4,29 +4,11 @@ import (
"code.vikunja.io/api/models"
"github.com/labstack/echo"
"net/http"
"strconv"
)
// UserShow gets all informations about a user
// UserShow gets all information about a user
func UserShow(c echo.Context) error {
// TODO: only allow users to show itself/with privacy options
user := c.Param("id")
if user == "" {
return c.JSON(http.StatusBadRequest, models.Message{"User ID cannot be empty."})
}
// Make int
userID, err := strconv.ParseInt(user, 10, 64)
if err != nil {
return c.JSON(http.StatusBadRequest, models.Message{"User ID is invalid."})
}
// Get User Infos
userInfos, err := models.GetUserByID(userID)
userInfos, err := models.GetCurrentUser(c)
if err != nil {
if models.IsErrUserDoesNotExist(err) {
return c.JSON(http.StatusNotFound, models.Message{"The user does not exist."})
@ -34,8 +16,15 @@ func UserShow(c echo.Context) error {
return c.JSON(http.StatusInternalServerError, models.Message{"Error getting user infos."})
}
// Obfucate his password
userInfos.Password = ""
user, err := models.GetUserByID(userInfos.ID)
if err != nil {
if models.IsErrUserDoesNotExist(err) {
return c.JSON(http.StatusNotFound, models.Message{"The user does not exist."})
}
return c.JSON(http.StatusInternalServerError, models.Message{"Error getting user infos."})
}
// Obfuscate his password
user.Password = ""
return c.JSON(http.StatusOK, userInfos)
return c.JSON(http.StatusOK, user)
}

View File

@ -139,4 +139,6 @@ func RegisterRoutes(e *echo.Echo) {
}
a.PUT("/teams/:team/members", teamMemberHandler.CreateWeb)
a.DELETE("/teams/:team/members/:user", teamMemberHandler.DeleteWeb)
a.GET("/user", apiv1.UserShow)
}