2018-10-30 07:20:13 +01:00
// Copyright 2018 The Gitea Authors. All rights reserved.
2022-11-27 13:20:29 -05:00
// SPDX-License-Identifier: MIT
2018-10-30 07:20:13 +01:00
package private
import (
2019-12-17 01:49:07 +00:00
"net/http"
2021-12-10 16:14:24 +08:00
asymkey_model "code.gitea.io/gitea/models/asymkey"
2021-06-23 21:38:19 +02:00
"code.gitea.io/gitea/modules/private"
2019-08-15 22:46:21 +08:00
"code.gitea.io/gitea/modules/timeutil"
2024-02-27 15:12:22 +08:00
"code.gitea.io/gitea/services/context"
2018-10-30 07:20:13 +01:00
)
2019-06-01 16:00:21 +01:00
// UpdatePublicKeyInRepo update public key and deploy key updates
2021-01-26 23:36:53 +08:00
func UpdatePublicKeyInRepo ( ctx * context . PrivateContext ) {
2024-06-19 06:32:45 +08:00
keyID := ctx . PathParamInt64 ( ":id" )
repoID := ctx . PathParamInt64 ( ":repoid" )
2023-10-11 06:24:07 +02:00
if err := asymkey_model . UpdatePublicKeyUpdated ( ctx , keyID ) ; err != nil {
2021-06-23 21:38:19 +02:00
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
2018-10-30 07:20:13 +01:00
} )
return
}
2022-05-20 22:08:52 +08:00
deployKey , err := asymkey_model . GetDeployKeyByRepo ( ctx , keyID , repoID )
2018-10-30 07:20:13 +01:00
if err != nil {
2021-12-10 16:14:24 +08:00
if asymkey_model . IsErrDeployKeyNotExist ( err ) {
2021-12-15 14:59:57 +08:00
ctx . PlainText ( http . StatusOK , "success" )
2019-06-01 16:00:21 +01:00
return
}
2021-06-23 21:38:19 +02:00
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
2018-10-30 07:20:13 +01:00
} )
return
}
2019-08-15 22:46:21 +08:00
deployKey . UpdatedUnix = timeutil . TimeStampNow ( )
2023-10-14 10:37:24 +02:00
if err = asymkey_model . UpdateDeployKeyCols ( ctx , deployKey , "updated_unix" ) ; err != nil {
2021-06-23 21:38:19 +02:00
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
2019-02-03 23:56:53 +00:00
} )
return
}
2021-12-15 14:59:57 +08:00
ctx . PlainText ( http . StatusOK , "success" )
2019-12-17 01:49:07 +00:00
}
// AuthorizedPublicKeyByContent searches content as prefix (leak e-mail part)
// and returns public key found.
2021-01-26 23:36:53 +08:00
func AuthorizedPublicKeyByContent ( ctx * context . PrivateContext ) {
2021-08-11 02:31:13 +02:00
content := ctx . FormString ( "content" )
2019-12-17 01:49:07 +00:00
2022-05-20 22:08:52 +08:00
publicKey , err := asymkey_model . SearchPublicKeyByContent ( ctx , content )
2019-12-17 01:49:07 +00:00
if err != nil {
2021-06-23 21:38:19 +02:00
ctx . JSON ( http . StatusInternalServerError , private . Response {
Err : err . Error ( ) ,
2019-12-17 01:49:07 +00:00
} )
return
}
2021-12-15 14:59:57 +08:00
ctx . PlainText ( http . StatusOK , publicKey . AuthorizedString ( ) )
2018-10-30 07:20:13 +01:00
}