Fix repo creation (#3756)

This commit is contained in:
Anbraten 2024-06-10 12:28:54 +02:00 committed by GitHub
parent 9bc15a5f3b
commit 1953a0ec5a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -117,23 +117,6 @@ func PostRepo(c *gin.Context) {
) )
} }
// creates the jwt token used to verify the repository
t := token.New(token.HookToken)
t.Set("repo-id", strconv.FormatInt(repo.ID, 10))
sig, err := t.Sign(repo.Hash)
if err != nil {
msg := "could not generate new jwt token."
log.Error().Err(err).Msg(msg)
c.String(http.StatusInternalServerError, msg)
return
}
hookURL := fmt.Sprintf(
"%s/api/hook?access_token=%s",
server.Config.Server.WebhookHost,
sig,
)
// find org of repo // find org of repo
var org *model.Org var org *model.Org
org, err = _store.OrgFindByName(repo.Owner) org, err = _store.OrgFindByName(repo.Owner)
@ -164,14 +147,6 @@ func PostRepo(c *gin.Context) {
repo.OrgID = org.ID repo.OrgID = org.ID
err = _forge.Activate(c, user, repo, hookURL)
if err != nil {
msg := "could not create webhook in forge."
log.Error().Err(err).Msg(msg)
c.String(http.StatusInternalServerError, msg)
return
}
if enabledOnce { if enabledOnce {
err = _store.UpdateRepo(repo) err = _store.UpdateRepo(repo)
} else { } else {
@ -184,6 +159,32 @@ func PostRepo(c *gin.Context) {
c.String(http.StatusInternalServerError, msg) c.String(http.StatusInternalServerError, msg)
return return
} }
// creates the jwt token used to verify the repository
t := token.New(token.HookToken)
t.Set("repo-id", strconv.FormatInt(repo.ID, 10))
sig, err := t.Sign(repo.Hash)
if err != nil {
msg := "could not generate new jwt token."
log.Error().Err(err).Msg(msg)
c.String(http.StatusInternalServerError, msg)
return
}
hookURL := fmt.Sprintf(
"%s/api/hook?access_token=%s",
server.Config.Server.WebhookHost,
sig,
)
err = _forge.Activate(c, user, repo, hookURL)
if err != nil {
msg := "could not create webhook in forge."
log.Error().Err(err).Msg(msg)
c.String(http.StatusInternalServerError, msg)
return
}
repo.Perm = from.Perm repo.Perm = from.Perm
repo.Perm.Synced = time.Now().Unix() repo.Perm.Synced = time.Now().Unix()
repo.Perm.UserID = user.ID repo.Perm.UserID = user.ID