]> source.dussan.org Git - gitea.git/commitdiff
fix incorrect repo url when changed the case of ownername (#25733)
authorhiifong <i@hiif.ong>
Fri, 14 Jul 2023 05:42:10 +0000 (13:42 +0800)
committerGitHub <noreply@github.com>
Fri, 14 Jul 2023 05:42:10 +0000 (13:42 +0800)
When only the case of the username changes and the new username is
consistent with the lowercase username of the old user name, update the
owner name of the repo, and keep the original logic consistent with
other conditions.

example: your username is `gitea`, lowercase username is `gitea`,repo
url is `.../gitea/{repo}`, you changed username to `Gitea` or `GiTea` or
other, but the lowercase username is still `gitea`, the repo url is
still `.../gitea/{repo}`.

this pr fixed it,keep username and repo url consistent.

Before:

![image](https://github.com/go-gitea/gitea/assets/89133723/84177296-f0ff-4176-84f1-1f9ec3f5b86f)

![image](https://github.com/go-gitea/gitea/assets/89133723/8f8f4a12-ecdd-4dec-af89-85c009b0ccfe)

After:

![image](https://github.com/go-gitea/gitea/assets/89133723/0564edb6-9467-405a-8cd4-d6f70e6f614b)

![image](https://github.com/go-gitea/gitea/assets/89133723/554ecd6e-e5a1-43bc-a46d-99e988c2ff58)

routers/web/org/setting.go
services/user/user.go

index b5653160a26d588ea7f40bf65a64d12d94c9d1c2..bd558f78b89a11990b32844fb335a03aa733699e 100644 (file)
@@ -89,7 +89,6 @@ func SettingsPost(ctx *context.Context) {
                // reset ctx.org.OrgLink with new name
                ctx.Org.OrgLink = setting.AppSubURL + "/org/" + url.PathEscape(form.Name)
                log.Trace("Organization name changed: %s -> %s", org.Name, form.Name)
-               nameChanged = false
        }
 
        // In case it's just a case change.
@@ -130,11 +129,6 @@ func SettingsPost(ctx *context.Context) {
                                return
                        }
                }
-       } else if nameChanged {
-               if err := repo_model.UpdateRepositoryOwnerNames(org.ID, org.Name); err != nil {
-                       ctx.ServerError("UpdateRepository", err)
-                       return
-               }
        }
 
        log.Trace("Organization setting updated: %s", org.Name)
index e0815bd86079102cd3b0ed3bd219734ff13a575b..bb3dd002ea06f56c368a2f82fc394484d4412518 100644 (file)
@@ -58,7 +58,7 @@ func RenameUser(ctx context.Context, u *user_model.User, newUserName string) err
                        u.Name = oldUserName
                        return err
                }
-               return nil
+               return repo_model.UpdateRepositoryOwnerNames(u.ID, newUserName)
        }
 
        ctx, committer, err := db.TxContext(ctx)