123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- // Copyright 2014 The Gogs Authors. All rights reserved.
- // Use of this source code is governed by a MIT-style
- // license that can be found in the LICENSE file.
-
- package user
-
- import (
- "net/http"
- "strings"
-
- "code.gitea.io/gitea/models"
- "code.gitea.io/gitea/modules/context"
- "code.gitea.io/gitea/modules/markup"
- api "code.gitea.io/sdk/gitea"
-
- "github.com/Unknwon/com"
- )
-
- // Search search users
- func Search(ctx *context.APIContext) {
- // swagger:operation GET /users/search user userSearch
- // ---
- // summary: Search for users
- // produces:
- // - application/json
- // parameters:
- // - name: q
- // in: query
- // description: keyword
- // type: string
- // - name: uid
- // in: query
- // description: ID of the user to search for
- // type: integer
- // format: int64
- // - name: limit
- // in: query
- // description: maximum number of users to return
- // type: integer
- // responses:
- // "200":
- // description: "SearchResults of a successful search"
- // schema:
- // type: object
- // properties:
- // ok:
- // type: boolean
- // data:
- // type: array
- // items:
- // "$ref": "#/definitions/User"
- opts := &models.SearchUserOptions{
- Keyword: strings.Trim(ctx.Query("q"), " "),
- UID: com.StrTo(ctx.Query("uid")).MustInt64(),
- Type: models.UserTypeIndividual,
- PageSize: com.StrTo(ctx.Query("limit")).MustInt(),
- }
- if opts.PageSize <= 0 {
- opts.PageSize = 10
- }
-
- users, _, err := models.SearchUsers(opts)
- if err != nil {
- ctx.JSON(500, map[string]interface{}{
- "ok": false,
- "error": err.Error(),
- })
- return
- }
-
- results := make([]*api.User, len(users))
- for i := range users {
- results[i] = &api.User{
- ID: users[i].ID,
- UserName: users[i].Name,
- AvatarURL: users[i].AvatarLink(),
- FullName: markup.Sanitize(users[i].FullName),
- IsAdmin: users[i].IsAdmin,
- }
- if ctx.IsSigned && (!users[i].KeepEmailPrivate || ctx.User.IsAdmin) {
- results[i].Email = users[i].Email
- }
- }
-
- ctx.JSON(200, map[string]interface{}{
- "ok": true,
- "data": results,
- })
- }
-
- // GetInfo get user's information
- func GetInfo(ctx *context.APIContext) {
- // swagger:operation GET /users/{username} user userGet
- // ---
- // summary: Get a user
- // produces:
- // - application/json
- // parameters:
- // - name: username
- // in: path
- // description: username of user to get
- // type: string
- // required: true
- // responses:
- // "200":
- // "$ref": "#/responses/User"
- // "404":
- // "$ref": "#/responses/notFound"
- u, err := models.GetUserByName(ctx.Params(":username"))
- if err != nil {
- if models.IsErrUserNotExist(err) {
- ctx.NotFound()
- } else {
- ctx.Error(500, "GetUserByName", err)
- }
- return
- }
-
- // Hide user e-mail when API caller isn't signed in.
- if !ctx.IsSigned {
- u.Email = ""
- }
- ctx.JSON(200, u.APIFormat())
- }
-
- // GetAuthenticatedUser get current user's information
- func GetAuthenticatedUser(ctx *context.APIContext) {
- // swagger:operation GET /user user userGetCurrent
- // ---
- // summary: Get the authenticated user
- // produces:
- // - application/json
- // responses:
- // "200":
- // "$ref": "#/responses/User"
- ctx.JSON(200, ctx.User.APIFormat())
- }
-
- // GetUserHeatmapData is the handler to get a users heatmap
- func GetUserHeatmapData(ctx *context.APIContext) {
- // swagger:operation GET /users/{username}/heatmap user userGetHeatmapData
- // ---
- // summary: Get a user's heatmap
- // produces:
- // - application/json
- // parameters:
- // - name: username
- // in: path
- // description: username of user to get
- // type: string
- // required: true
- // responses:
- // "200":
- // "$ref": "#/responses/UserHeatmapData"
- // "404":
- // "$ref": "#/responses/notFound"
-
- // Get the user to throw an error if it does not exist
- user, err := models.GetUserByName(ctx.Params(":username"))
- if err != nil {
- if models.IsErrUserNotExist(err) {
- ctx.Status(http.StatusNotFound)
- } else {
- ctx.Error(http.StatusInternalServerError, "GetUserByName", err)
- }
- return
- }
-
- heatmap, err := models.GetUserHeatmapDataByUser(user)
- if err != nil {
- ctx.Error(http.StatusInternalServerError, "GetUserHeatmapDataByUser", err)
- return
- }
- ctx.JSON(200, heatmap)
- }
|