mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 12:27:06 +00:00 
			
		
		
		
	Add admin delete user
This commit is contained in:
		
							
								
								
									
										2
									
								
								gogs.go
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								gogs.go
									
									
									
									
									
								
							| @@ -20,7 +20,7 @@ import ( | |||||||
| // Test that go1.2 tag above is included in builds. main.go refers to this definition. | // Test that go1.2 tag above is included in builds. main.go refers to this definition. | ||||||
| const go12tag = true | const go12tag = true | ||||||
|  |  | ||||||
| const APP_VER = "0.1.5.0321" | const APP_VER = "0.1.5.0322" | ||||||
|  |  | ||||||
| func init() { | func init() { | ||||||
| 	base.AppVer = APP_VER | 	base.AppVer = APP_VER | ||||||
|   | |||||||
| @@ -7,6 +7,8 @@ package models | |||||||
| import ( | import ( | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 	"time" | 	"time" | ||||||
|  |  | ||||||
|  | 	"github.com/gogits/gogs/modules/log" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| // Operation types of user action. | // Operation types of user action. | ||||||
| @@ -89,6 +91,8 @@ func CommitRepoAction(userId int64, userName string, | |||||||
| 	if err = UpdateRepository(repo); err != nil { | 	if err = UpdateRepository(repo); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	log.Trace("action.CommitRepoAction: %d/%s", userId, repo.LowerName) | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -102,6 +106,8 @@ func NewRepoAction(user *User, repo *Repository) error { | |||||||
| 		RepoId:      repo.Id, | 		RepoId:      repo.Id, | ||||||
| 		RepoName:    repo.Name, | 		RepoName:    repo.Name, | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
|  | 	log.Trace("action.NewRepoAction: %s/%s", user.LowerName, repo.LowerName) | ||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -107,3 +107,38 @@ func EditUser(ctx *middleware.Context, params martini.Params, form auth.AdminEdi | |||||||
| 	log.Trace("%s User profile updated by admin(%s): %s", ctx.Req.RequestURI, | 	log.Trace("%s User profile updated by admin(%s): %s", ctx.Req.RequestURI, | ||||||
| 		ctx.User.LowerName, ctx.User.LowerName) | 		ctx.User.LowerName, ctx.User.LowerName) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func DeleteUser(ctx *middleware.Context, params martini.Params) { | ||||||
|  | 	ctx.Data["Title"] = "Edit Account" | ||||||
|  | 	ctx.Data["PageIsUsers"] = true | ||||||
|  |  | ||||||
|  | 	uid, err := base.StrTo(params["userid"]).Int() | ||||||
|  | 	if err != nil { | ||||||
|  | 		ctx.Handle(200, "admin.user.EditUser", err) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	u, err := models.GetUserById(int64(uid)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		ctx.Handle(200, "admin.user.EditUser", err) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if err = models.DeleteUser(u); err != nil { | ||||||
|  | 		ctx.Data["HasError"] = true | ||||||
|  | 		switch err { | ||||||
|  | 		case models.ErrUserOwnRepos: | ||||||
|  | 			ctx.Data["ErrorMsg"] = "This account still has ownership of repository, owner has to delete or transfer them first." | ||||||
|  | 			ctx.Data["User"] = u | ||||||
|  | 			ctx.HTML(200, "admin/users/edit") | ||||||
|  | 		default: | ||||||
|  | 			ctx.Handle(200, "admin.user.DeleteUser", err) | ||||||
|  | 		} | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	log.Trace("%s User deleted by admin(%s): %s", ctx.Req.RequestURI, | ||||||
|  | 		ctx.User.LowerName, ctx.User.LowerName) | ||||||
|  |  | ||||||
|  | 	ctx.Redirect("/admin/users", 302) | ||||||
|  | } | ||||||
|   | |||||||
| @@ -71,7 +71,7 @@ | |||||||
| 					<div class="form-group"> | 					<div class="form-group"> | ||||||
| 					    <div class="col-md-offset-3 col-md-6"> | 					    <div class="col-md-offset-3 col-md-6"> | ||||||
| 					    	<button type="submit" class="btn btn-lg btn-primary btn-block">Update account profile</button> | 					    	<button type="submit" class="btn btn-lg btn-primary btn-block">Update account profile</button> | ||||||
| 					    	<!-- <a type="button" href="/admin/users/{{.User.Id}}/delete" class="btn btn-lg btn-danger btn-block">Delete this account</a> --> | 					    	<a type="button" href="/admin/users/{{.User.Id}}/delete" class="btn btn-lg btn-danger btn-block">Delete this account</a> | ||||||
| 					    </div> | 					    </div> | ||||||
| 					</div> | 					</div> | ||||||
| 				</form> | 				</form> | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								web.go
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								web.go
									
									
									
									
									
								
							| @@ -119,6 +119,7 @@ func runWeb(*cli.Context) { | |||||||
| 	m.Get("/admin/users", reqSignIn, adminReq, admin.Users) | 	m.Get("/admin/users", reqSignIn, adminReq, admin.Users) | ||||||
| 	m.Any("/admin/users/new", reqSignIn, adminReq, binding.BindIgnErr(auth.RegisterForm{}), admin.NewUser) | 	m.Any("/admin/users/new", reqSignIn, adminReq, binding.BindIgnErr(auth.RegisterForm{}), admin.NewUser) | ||||||
| 	m.Any("/admin/users/:userid", reqSignIn, adminReq, binding.BindIgnErr(auth.AdminEditUserForm{}), admin.EditUser) | 	m.Any("/admin/users/:userid", reqSignIn, adminReq, binding.BindIgnErr(auth.AdminEditUserForm{}), admin.EditUser) | ||||||
|  | 	m.Any("/admin/users/:userid/delete", reqSignIn, adminReq, admin.DeleteUser) | ||||||
| 	m.Get("/admin/repos", reqSignIn, adminReq, admin.Repositories) | 	m.Get("/admin/repos", reqSignIn, adminReq, admin.Repositories) | ||||||
| 	m.Get("/admin/config", reqSignIn, adminReq, admin.Config) | 	m.Get("/admin/config", reqSignIn, adminReq, admin.Config) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Unknown
					Unknown