// 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 (
"net/http"
asymkey_model "code.gitea.io/gitea/models/asymkey"
"code.gitea.io/gitea/modules/context"
"code.gitea.io/gitea/modules/private"
"code.gitea.io/gitea/modules/timeutil"
)
// UpdatePublicKeyInRepo update public key and deploy key updates
func UpdatePublicKeyInRepo ( ctx * context . PrivateContext ) {
keyID := ctx . ParamsInt64 ( ":id" )
repoID := ctx . ParamsInt64 ( ":repoid" )
if err := asymkey_model . UpdatePublicKeyUpdated ( keyID ) ; err != nil {
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
} )
return
}
deployKey , err := asymkey_model . GetDeployKeyByRepo ( keyID , repoID )
if err != nil {
if asymkey_model . IsErrDeployKeyNotExist ( err ) {
ctx . PlainText ( http . StatusOK , [ ] byte ( "success" ) )
return
}
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
} )
return
}
deployKey . UpdatedUnix = timeutil . TimeStampNow ( )
if err = asymkey_model . UpdateDeployKeyCols ( deployKey , "updated_unix" ) ; err != nil {
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
} )
return
}
ctx . PlainText ( http . StatusOK , [ ] byte ( "success" ) )
}
// AuthorizedPublicKeyByContent searches content as prefix (leak e-mail part)
// and returns public key found.
func AuthorizedPublicKeyByContent ( ctx * context . PrivateContext ) {
content := ctx . FormString ( "content" )
publicKey , err := asymkey_model . SearchPublicKeyByContent ( content )
if err != nil {
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
} )
return
}
ctx . PlainText ( http . StatusOK , [ ] byte ( publicKey . AuthorizedString ( ) ) )
}