2018-10-30 01:20:13 -05:00
// Copyright 2018 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 private includes all internal routes. The package name internal is ideal but Golang is not allowed, so we use private as package name instead.
package private
import (
2019-12-16 20:49:07 -05:00
"net/http"
2018-10-30 01:20:13 -05:00
"code.gitea.io/gitea/models"
2021-01-26 10:36:53 -05:00
"code.gitea.io/gitea/modules/context"
2019-08-15 09:46:21 -05:00
"code.gitea.io/gitea/modules/timeutil"
2018-10-30 01:20:13 -05:00
)
2019-06-01 10:00:21 -05:00
// UpdatePublicKeyInRepo update public key and deploy key updates
2021-01-26 10:36:53 -05:00
func UpdatePublicKeyInRepo ( ctx * context . PrivateContext ) {
2018-10-30 01:20:13 -05:00
keyID := ctx . ParamsInt64 ( ":id" )
2019-06-01 10:00:21 -05:00
repoID := ctx . ParamsInt64 ( ":repoid" )
2018-10-30 01:20:13 -05:00
if err := models . UpdatePublicKeyUpdated ( keyID ) ; err != nil {
2019-12-16 20:49:07 -05:00
ctx . JSON ( http . StatusInternalServerError , map [ string ] interface { } {
2018-10-30 01:20:13 -05:00
"err" : err . Error ( ) ,
} )
return
}
2019-06-01 10:00:21 -05:00
deployKey , err := models . GetDeployKeyByRepo ( keyID , repoID )
2018-10-30 01:20:13 -05:00
if err != nil {
2019-06-01 10:00:21 -05:00
if models . IsErrDeployKeyNotExist ( err ) {
ctx . PlainText ( 200 , [ ] byte ( "success" ) )
return
}
2019-12-16 20:49:07 -05:00
ctx . JSON ( http . StatusInternalServerError , map [ string ] interface { } {
2018-10-30 01:20:13 -05:00
"err" : err . Error ( ) ,
} )
return
}
2019-08-15 09:46:21 -05:00
deployKey . UpdatedUnix = timeutil . TimeStampNow ( )
2019-06-01 10:00:21 -05:00
if err = models . UpdateDeployKeyCols ( deployKey , "updated_unix" ) ; err != nil {
2019-12-16 20:49:07 -05:00
ctx . JSON ( http . StatusInternalServerError , map [ string ] interface { } {
2019-02-03 18:56:53 -05:00
"err" : err . Error ( ) ,
} )
return
}
2019-12-16 20:49:07 -05:00
ctx . PlainText ( http . StatusOK , [ ] byte ( "success" ) )
}
// AuthorizedPublicKeyByContent searches content as prefix (leak e-mail part)
// and returns public key found.
2021-01-26 10:36:53 -05:00
func AuthorizedPublicKeyByContent ( ctx * context . PrivateContext ) {
2019-12-16 20:49:07 -05:00
content := ctx . Query ( "content" )
publicKey , err := models . SearchPublicKeyByContent ( content )
if err != nil {
ctx . JSON ( http . StatusInternalServerError , map [ string ] interface { } {
"err" : err . Error ( ) ,
} )
return
}
ctx . PlainText ( http . StatusOK , [ ] byte ( publicKey . AuthorizedString ( ) ) )
2018-10-30 01:20:13 -05:00
}