2017-03-16 04:27:35 +03:00
// Copyright 2017 The Gitea 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 (
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
2019-08-23 19:40:30 +03:00
api "code.gitea.io/gitea/modules/structs"
2017-03-16 04:27:35 +03:00
"code.gitea.io/gitea/routers/api/v1/convert"
)
func listGPGKeys ( ctx * context . APIContext , uid int64 ) {
keys , err := models . ListGPGKeys ( uid )
if err != nil {
ctx . Error ( 500 , "ListGPGKeys" , err )
return
}
apiKeys := make ( [ ] * api . GPGKey , len ( keys ) )
for i := range keys {
apiKeys [ i ] = convert . ToGPGKey ( keys [ i ] )
}
ctx . JSON ( 200 , & apiKeys )
}
//ListGPGKeys get the GPG key list of a user
func ListGPGKeys ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation GET /users/{username}/gpg_keys user userListGPGKeys
// ---
// summary: List the given user's GPG keys
// produces:
// - application/json
// parameters:
// - name: username
// in: path
// description: username of user
// type: string
// required: true
// responses:
// "200":
// "$ref": "#/responses/GPGKeyList"
2017-03-16 04:27:35 +03:00
user := GetUserByParams ( ctx )
if ctx . Written ( ) {
return
}
listGPGKeys ( ctx , user . ID )
}
2017-11-13 10:02:25 +03:00
//ListMyGPGKeys get the GPG key list of the authenticated user
2017-03-16 04:27:35 +03:00
func ListMyGPGKeys ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation GET /user/gpg_keys user userCurrentListGPGKeys
// ---
// summary: List the authenticated user's GPG keys
// produces:
// - application/json
// responses:
// "200":
// "$ref": "#/responses/GPGKeyList"
2017-03-16 04:27:35 +03:00
listGPGKeys ( ctx , ctx . User . ID )
}
//GetGPGKey get the GPG key based on a id
func GetGPGKey ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation GET /user/gpg_keys/{id} user userCurrentGetGPGKey
// ---
// summary: Get a GPG key
// produces:
// - application/json
// parameters:
// - name: id
// in: path
// description: id of key to get
// type: integer
2018-10-21 06:40:42 +03:00
// format: int64
2017-11-13 10:02:25 +03:00
// required: true
// responses:
// "200":
// "$ref": "#/responses/GPGKey"
// "404":
// "$ref": "#/responses/notFound"
2017-03-16 04:27:35 +03:00
key , err := models . GetGPGKeyByID ( ctx . ParamsInt64 ( ":id" ) )
if err != nil {
if models . IsErrGPGKeyNotExist ( err ) {
2019-03-19 05:29:43 +03:00
ctx . NotFound ( )
2017-03-16 04:27:35 +03:00
} else {
ctx . Error ( 500 , "GetGPGKeyByID" , err )
}
return
}
ctx . JSON ( 200 , convert . ToGPGKey ( key ) )
}
// CreateUserGPGKey creates new GPG key to given user by ID.
func CreateUserGPGKey ( ctx * context . APIContext , form api . CreateGPGKeyOption , uid int64 ) {
key , err := models . AddGPGKey ( uid , form . ArmoredKey )
if err != nil {
HandleAddGPGKeyError ( ctx , err )
return
}
ctx . JSON ( 201 , convert . ToGPGKey ( key ) )
}
2017-11-13 10:02:25 +03:00
// swagger:parameters userCurrentPostGPGKey
type swaggerUserCurrentPostGPGKey struct {
// in:body
Form api . CreateGPGKeyOption
}
2017-05-02 16:35:59 +03:00
2017-11-13 10:02:25 +03:00
//CreateGPGKey create a GPG key belonging to the authenticated user
func CreateGPGKey ( ctx * context . APIContext , form api . CreateGPGKeyOption ) {
// swagger:operation POST /user/gpg_keys user userCurrentPostGPGKey
// ---
// summary: Create a GPG key
// consumes:
// - application/json
// produces:
// - application/json
// responses:
// "201":
// "$ref": "#/responses/GPGKey"
// "422":
// "$ref": "#/responses/validationError"
2017-03-16 04:27:35 +03:00
CreateUserGPGKey ( ctx , form , ctx . User . ID )
}
2017-11-13 10:02:25 +03:00
//DeleteGPGKey remove a GPG key belonging to the authenticated user
2017-03-16 04:27:35 +03:00
func DeleteGPGKey ( ctx * context . APIContext ) {
2017-11-13 10:02:25 +03:00
// swagger:operation DELETE /user/gpg_keys/{id} user userCurrentDeleteGPGKey
// ---
// summary: Remove a GPG key
// produces:
// - application/json
// parameters:
// - name: id
// in: path
// description: id of key to delete
// type: integer
2018-10-21 06:40:42 +03:00
// format: int64
2017-11-13 10:02:25 +03:00
// required: true
// responses:
// "204":
// "$ref": "#/responses/empty"
// "403":
// "$ref": "#/responses/forbidden"
2017-03-16 04:27:35 +03:00
if err := models . DeleteGPGKey ( ctx . User , ctx . ParamsInt64 ( ":id" ) ) ; err != nil {
if models . IsErrGPGKeyAccessDenied ( err ) {
ctx . Error ( 403 , "" , "You do not have access to this key" )
} else {
ctx . Error ( 500 , "DeleteGPGKey" , err )
}
return
}
ctx . Status ( 204 )
}
// HandleAddGPGKeyError handle add GPGKey error
func HandleAddGPGKeyError ( ctx * context . APIContext , err error ) {
switch {
case models . IsErrGPGKeyAccessDenied ( err ) :
2017-11-13 10:02:25 +03:00
ctx . Error ( 422 , "" , "You do not have access to this GPG key" )
2017-03-16 04:27:35 +03:00
case models . IsErrGPGKeyIDAlreadyUsed ( err ) :
2017-11-13 10:02:25 +03:00
ctx . Error ( 422 , "" , "A key with the same id already exists" )
2017-03-16 04:27:35 +03:00
default :
ctx . Error ( 500 , "AddGPGKey" , err )
}
}