| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 | // Copyright 2015 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 userimport (	"net/http"	api "github.com/gogs/go-gogs-client"	"github.com/pkg/errors"	"gogs.io/gogs/internal/conf"	"gogs.io/gogs/internal/context"	"gogs.io/gogs/internal/database"	"gogs.io/gogs/internal/route/api/v1/convert"	"gogs.io/gogs/internal/route/api/v1/repo")func GetUserByParamsName(c *context.APIContext, name string) *database.User {	user, err := database.Handle.Users().GetByUsername(c.Req.Context(), c.Params(name))	if err != nil {		c.NotFoundOrError(err, "get user by name")		return nil	}	return user}// GetUserByParams returns user whose name is presented in URL parameter.func GetUserByParams(c *context.APIContext) *database.User {	return GetUserByParamsName(c, ":username")}func composePublicKeysAPILink() string {	return conf.Server.ExternalURL + "api/v1/user/keys/"}func listPublicKeys(c *context.APIContext, uid int64) {	keys, err := database.ListPublicKeys(uid)	if err != nil {		c.Error(err, "list public keys")		return	}	apiLink := composePublicKeysAPILink()	apiKeys := make([]*api.PublicKey, len(keys))	for i := range keys {		apiKeys[i] = convert.ToPublicKey(apiLink, keys[i])	}	c.JSONSuccess(&apiKeys)}func ListMyPublicKeys(c *context.APIContext) {	listPublicKeys(c, c.User.ID)}func ListPublicKeys(c *context.APIContext) {	user := GetUserByParams(c)	if c.Written() {		return	}	listPublicKeys(c, user.ID)}func GetPublicKey(c *context.APIContext) {	key, err := database.GetPublicKeyByID(c.ParamsInt64(":id"))	if err != nil {		c.NotFoundOrError(err, "get public key by ID")		return	}	apiLink := composePublicKeysAPILink()	c.JSONSuccess(convert.ToPublicKey(apiLink, key))}// CreateUserPublicKey creates new public key to given user by ID.func CreateUserPublicKey(c *context.APIContext, form api.CreateKeyOption, uid int64) {	content, err := database.CheckPublicKeyString(form.Key)	if err != nil {		repo.HandleCheckKeyStringError(c, err)		return	}	key, err := database.AddPublicKey(uid, form.Title, content)	if err != nil {		repo.HandleAddKeyError(c, err)		return	}	apiLink := composePublicKeysAPILink()	c.JSON(http.StatusCreated, convert.ToPublicKey(apiLink, key))}func CreatePublicKey(c *context.APIContext, form api.CreateKeyOption) {	CreateUserPublicKey(c, form, c.User.ID)}func DeletePublicKey(c *context.APIContext) {	if err := database.DeletePublicKey(c.User, c.ParamsInt64(":id")); err != nil {		if database.IsErrKeyAccessDenied(err) {			c.ErrorStatus(http.StatusForbidden, errors.New("You do not have access to this key."))		} else {			c.Error(err, "delete public key")		}		return	}	c.NoContent()}
 |