mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	Add admin edit user
This commit is contained in:
		@@ -8,8 +8,8 @@ RUN_MODE = dev
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
[repository]
 | 
					[repository]
 | 
				
			||||||
ROOT = /Users/%(RUN_USER)s/git/gogs-repositories
 | 
					ROOT = /Users/%(RUN_USER)s/git/gogs-repositories
 | 
				
			||||||
LANG_IGNS = Google Go|C|Python|Ruby|C Sharp
 | 
					LANG_IGNS = Google Go|C|C++|Python|Ruby|C Sharp
 | 
				
			||||||
LICENSES = Apache v2 License|GPL v2|MIT License|Affero GPL|BSD (3-Clause) License
 | 
					LICENSES = Apache v2 License|GPL v2|MIT License|Affero GPL|Artistic License 2.0|BSD (3-Clause) License
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[server]
 | 
					[server]
 | 
				
			||||||
DOMAIN = localhost
 | 
					DOMAIN = localhost
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										13
									
								
								conf/gitignore/C++
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								conf/gitignore/C++
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,13 @@
 | 
				
			|||||||
 | 
					# Compiled Object files
 | 
				
			||||||
 | 
					*.slo
 | 
				
			||||||
 | 
					*.lo
 | 
				
			||||||
 | 
					*.o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Compiled Dynamic libraries
 | 
				
			||||||
 | 
					*.so
 | 
				
			||||||
 | 
					*.dylib
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Compiled Static libraries
 | 
				
			||||||
 | 
					*.lai
 | 
				
			||||||
 | 
					*.la
 | 
				
			||||||
 | 
					*.a
 | 
				
			||||||
							
								
								
									
										201
									
								
								conf/license/Artistic License 2.0
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								conf/license/Artistic License 2.0
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,201 @@
 | 
				
			|||||||
 | 
					The Artistic License 2.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					           Copyright (c) 2014
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     Everyone is permitted to copy and distribute verbatim copies
 | 
				
			||||||
 | 
					      of this license document, but changing it is not allowed.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Preamble
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					This license establishes the terms under which a given free software
 | 
				
			||||||
 | 
					Package may be copied, modified, distributed, and/or redistributed.
 | 
				
			||||||
 | 
					The intent is that the Copyright Holder maintains some artistic
 | 
				
			||||||
 | 
					control over the development of that Package while still keeping the
 | 
				
			||||||
 | 
					Package available as open source and free software.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					You are always permitted to make arrangements wholly outside of this
 | 
				
			||||||
 | 
					license directly with the Copyright Holder of a given Package.  If the
 | 
				
			||||||
 | 
					terms of this license do not permit the full use that you propose to
 | 
				
			||||||
 | 
					make of the Package, you should contact the Copyright Holder and seek
 | 
				
			||||||
 | 
					a different licensing arrangement.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Definitions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Copyright Holder" means the individual(s) or organization(s)
 | 
				
			||||||
 | 
					    named in the copyright notice for the entire Package.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Contributor" means any party that has contributed code or other
 | 
				
			||||||
 | 
					    material to the Package, in accordance with the Copyright Holder's
 | 
				
			||||||
 | 
					    procedures.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "You" and "your" means any person who would like to copy,
 | 
				
			||||||
 | 
					    distribute, or modify the Package.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Package" means the collection of files distributed by the
 | 
				
			||||||
 | 
					    Copyright Holder, and derivatives of that collection and/or of
 | 
				
			||||||
 | 
					    those files. A given Package may consist of either the Standard
 | 
				
			||||||
 | 
					    Version, or a Modified Version.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Distribute" means providing a copy of the Package or making it
 | 
				
			||||||
 | 
					    accessible to anyone else, or in the case of a company or
 | 
				
			||||||
 | 
					    organization, to others outside of your company or organization.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Distributor Fee" means any fee that you charge for Distributing
 | 
				
			||||||
 | 
					    this Package or providing support for this Package to another
 | 
				
			||||||
 | 
					    party.  It does not mean licensing fees.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Standard Version" refers to the Package if it has not been
 | 
				
			||||||
 | 
					    modified, or has been modified only in ways explicitly requested
 | 
				
			||||||
 | 
					    by the Copyright Holder.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Modified Version" means the Package, if it has been changed, and
 | 
				
			||||||
 | 
					    such changes were not explicitly requested by the Copyright
 | 
				
			||||||
 | 
					    Holder.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Original License" means this Artistic License as Distributed with
 | 
				
			||||||
 | 
					    the Standard Version of the Package, in its current version or as
 | 
				
			||||||
 | 
					    it may be modified by The Perl Foundation in the future.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Source" form means the source code, documentation source, and
 | 
				
			||||||
 | 
					    configuration files for the Package.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    "Compiled" form means the compiled bytecode, object code, binary,
 | 
				
			||||||
 | 
					    or any other form resulting from mechanical transformation or
 | 
				
			||||||
 | 
					    translation of the Source form.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Permission for Use and Modification Without Distribution
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(1)  You are permitted to use the Standard Version and create and use
 | 
				
			||||||
 | 
					Modified Versions for any purpose without restriction, provided that
 | 
				
			||||||
 | 
					you do not Distribute the Modified Version.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Permissions for Redistribution of the Standard Version
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(2)  You may Distribute verbatim copies of the Source form of the
 | 
				
			||||||
 | 
					Standard Version of this Package in any medium without restriction,
 | 
				
			||||||
 | 
					either gratis or for a Distributor Fee, provided that you duplicate
 | 
				
			||||||
 | 
					all of the original copyright notices and associated disclaimers.  At
 | 
				
			||||||
 | 
					your discretion, such verbatim copies may or may not include a
 | 
				
			||||||
 | 
					Compiled form of the Package.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(3)  You may apply any bug fixes, portability changes, and other
 | 
				
			||||||
 | 
					modifications made available from the Copyright Holder.  The resulting
 | 
				
			||||||
 | 
					Package will still be considered the Standard Version, and as such
 | 
				
			||||||
 | 
					will be subject to the Original License.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Distribution of Modified Versions of the Package as Source
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(4)  You may Distribute your Modified Version as Source (either gratis
 | 
				
			||||||
 | 
					or for a Distributor Fee, and with or without a Compiled form of the
 | 
				
			||||||
 | 
					Modified Version) provided that you clearly document how it differs
 | 
				
			||||||
 | 
					from the Standard Version, including, but not limited to, documenting
 | 
				
			||||||
 | 
					any non-standard features, executables, or modules, and provided that
 | 
				
			||||||
 | 
					you do at least ONE of the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (a)  make the Modified Version available to the Copyright Holder
 | 
				
			||||||
 | 
					    of the Standard Version, under the Original License, so that the
 | 
				
			||||||
 | 
					    Copyright Holder may include your modifications in the Standard
 | 
				
			||||||
 | 
					    Version.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (b)  ensure that installation of your Modified Version does not
 | 
				
			||||||
 | 
					    prevent the user installing or running the Standard Version. In
 | 
				
			||||||
 | 
					    addition, the Modified Version must bear a name that is different
 | 
				
			||||||
 | 
					    from the name of the Standard Version.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (c)  allow anyone who receives a copy of the Modified Version to
 | 
				
			||||||
 | 
					    make the Source form of the Modified Version available to others
 | 
				
			||||||
 | 
					    under
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (i)  the Original License or
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (ii)  a license that permits the licensee to freely copy,
 | 
				
			||||||
 | 
					    modify and redistribute the Modified Version using the same
 | 
				
			||||||
 | 
					    licensing terms that apply to the copy that the licensee
 | 
				
			||||||
 | 
					    received, and requires that the Source form of the Modified
 | 
				
			||||||
 | 
					    Version, and of any works derived from it, be made freely
 | 
				
			||||||
 | 
					    available in that license fees are prohibited but Distributor
 | 
				
			||||||
 | 
					    Fees are allowed.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Distribution of Compiled Forms of the Standard Version
 | 
				
			||||||
 | 
					or Modified Versions without the Source
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(5)  You may Distribute Compiled forms of the Standard Version without
 | 
				
			||||||
 | 
					the Source, provided that you include complete instructions on how to
 | 
				
			||||||
 | 
					get the Source of the Standard Version.  Such instructions must be
 | 
				
			||||||
 | 
					valid at the time of your distribution.  If these instructions, at any
 | 
				
			||||||
 | 
					time while you are carrying out such distribution, become invalid, you
 | 
				
			||||||
 | 
					must provide new instructions on demand or cease further distribution.
 | 
				
			||||||
 | 
					If you provide valid instructions or cease distribution within thirty
 | 
				
			||||||
 | 
					days after you become aware that the instructions are invalid, then
 | 
				
			||||||
 | 
					you do not forfeit any of your rights under this license.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(6)  You may Distribute a Modified Version in Compiled form without
 | 
				
			||||||
 | 
					the Source, provided that you comply with Section 4 with respect to
 | 
				
			||||||
 | 
					the Source of the Modified Version.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Aggregating or Linking the Package
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(7)  You may aggregate the Package (either the Standard Version or
 | 
				
			||||||
 | 
					Modified Version) with other packages and Distribute the resulting
 | 
				
			||||||
 | 
					aggregation provided that you do not charge a licensing fee for the
 | 
				
			||||||
 | 
					Package.  Distributor Fees are permitted, and licensing fees for other
 | 
				
			||||||
 | 
					components in the aggregation are permitted. The terms of this license
 | 
				
			||||||
 | 
					apply to the use and Distribution of the Standard or Modified Versions
 | 
				
			||||||
 | 
					as included in the aggregation.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(8) You are permitted to link Modified and Standard Versions with
 | 
				
			||||||
 | 
					other works, to embed the Package in a larger work of your own, or to
 | 
				
			||||||
 | 
					build stand-alone binary or bytecode versions of applications that
 | 
				
			||||||
 | 
					include the Package, and Distribute the result without restriction,
 | 
				
			||||||
 | 
					provided the result does not expose a direct interface to the Package.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Items That are Not Considered Part of a Modified Version
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(9) Works (including, but not limited to, modules and scripts) that
 | 
				
			||||||
 | 
					merely extend or make use of the Package, do not, by themselves, cause
 | 
				
			||||||
 | 
					the Package to be a Modified Version.  In addition, such works are not
 | 
				
			||||||
 | 
					considered parts of the Package itself, and are not subject to the
 | 
				
			||||||
 | 
					terms of this license.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					General Provisions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(10)  Any use, modification, and distribution of the Standard or
 | 
				
			||||||
 | 
					Modified Versions is governed by this Artistic License. By using,
 | 
				
			||||||
 | 
					modifying or distributing the Package, you accept this license. Do not
 | 
				
			||||||
 | 
					use, modify, or distribute the Package, if you do not accept this
 | 
				
			||||||
 | 
					license.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(11)  If your Modified Version has been derived from a Modified
 | 
				
			||||||
 | 
					Version made by someone other than you, you are nevertheless required
 | 
				
			||||||
 | 
					to ensure that your Modified Version complies with the requirements of
 | 
				
			||||||
 | 
					this license.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(12)  This license does not grant you the right to use any trademark,
 | 
				
			||||||
 | 
					service mark, tradename, or logo of the Copyright Holder.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(13)  This license includes the non-exclusive, worldwide,
 | 
				
			||||||
 | 
					free-of-charge patent license to make, have made, use, offer to sell,
 | 
				
			||||||
 | 
					sell, import and otherwise transfer the Package with respect to any
 | 
				
			||||||
 | 
					patent claims licensable by the Copyright Holder that are necessarily
 | 
				
			||||||
 | 
					infringed by the Package. If you institute patent litigation
 | 
				
			||||||
 | 
					(including a cross-claim or counterclaim) against any party alleging
 | 
				
			||||||
 | 
					that the Package constitutes direct or contributory patent
 | 
				
			||||||
 | 
					infringement, then this Artistic License to you shall terminate on the
 | 
				
			||||||
 | 
					date that such litigation is filed.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(14)  Disclaimer of Warranty:
 | 
				
			||||||
 | 
					THE PACKAGE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS "AS
 | 
				
			||||||
 | 
					IS' AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES. THE IMPLIED
 | 
				
			||||||
 | 
					WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR
 | 
				
			||||||
 | 
					NON-INFRINGEMENT ARE DISCLAIMED TO THE EXTENT PERMITTED BY YOUR LOCAL
 | 
				
			||||||
 | 
					LAW. UNLESS REQUIRED BY LAW, NO COPYRIGHT HOLDER OR CONTRIBUTOR WILL
 | 
				
			||||||
 | 
					BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
 | 
				
			||||||
 | 
					DAMAGES ARISING IN ANY WAY OUT OF THE USE OF THE PACKAGE, EVEN IF
 | 
				
			||||||
 | 
					ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
				
			||||||
							
								
								
									
										55
									
								
								modules/auth/admin.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								modules/auth/admin.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,55 @@
 | 
				
			|||||||
 | 
					// Copyright 2014 The Gogs 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 auth
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"net/http"
 | 
				
			||||||
 | 
						"reflect"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/codegangsta/martini"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/gogits/binding"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/gogits/gogs/modules/base"
 | 
				
			||||||
 | 
						"github.com/gogits/gogs/modules/log"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type AdminEditUserForm struct {
 | 
				
			||||||
 | 
						Email    string `form:"email" binding:"Required;Email;MaxSize(50)"`
 | 
				
			||||||
 | 
						Website  string `form:"website" binding:"MaxSize(50)"`
 | 
				
			||||||
 | 
						Location string `form:"location" binding:"MaxSize(50)"`
 | 
				
			||||||
 | 
						Avatar   string `form:"avatar" binding:"Required;Email;MaxSize(50)"`
 | 
				
			||||||
 | 
						Active   string `form:"active"`
 | 
				
			||||||
 | 
						Admin    string `form:"admin"`
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (f *AdminEditUserForm) Name(field string) string {
 | 
				
			||||||
 | 
						names := map[string]string{
 | 
				
			||||||
 | 
							"Email":    "E-mail address",
 | 
				
			||||||
 | 
							"Website":  "Website",
 | 
				
			||||||
 | 
							"Location": "Location",
 | 
				
			||||||
 | 
							"Avatar":   "Gravatar Email",
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return names[field]
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (f *AdminEditUserForm) Validate(errors *binding.Errors, req *http.Request, context martini.Context) {
 | 
				
			||||||
 | 
						if req.Method == "GET" || errors.Count() == 0 {
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						data := context.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)
 | 
				
			||||||
 | 
						data["HasError"] = true
 | 
				
			||||||
 | 
						AssignForm(f, data)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if len(errors.Overall) > 0 {
 | 
				
			||||||
 | 
							for _, err := range errors.Overall {
 | 
				
			||||||
 | 
								log.Error("AdminEditUserForm.Validate: %v", err)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						validate(errors, data, f)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -79,7 +79,7 @@ type UpdateProfileForm struct {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
func (f *UpdateProfileForm) Name(field string) string {
 | 
					func (f *UpdateProfileForm) Name(field string) string {
 | 
				
			||||||
	names := map[string]string{
 | 
						names := map[string]string{
 | 
				
			||||||
		"Email":    "Email address",
 | 
							"Email":    "E-mail address",
 | 
				
			||||||
		"Website":  "Website",
 | 
							"Website":  "Website",
 | 
				
			||||||
		"Location": "Location",
 | 
							"Location": "Location",
 | 
				
			||||||
		"Avatar":   "Gravatar Email",
 | 
							"Avatar":   "Gravatar Email",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -7,8 +7,11 @@ package admin
 | 
				
			|||||||
import (
 | 
					import (
 | 
				
			||||||
	"strings"
 | 
						"strings"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/codegangsta/martini"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/gogits/gogs/models"
 | 
						"github.com/gogits/gogs/models"
 | 
				
			||||||
	"github.com/gogits/gogs/modules/auth"
 | 
						"github.com/gogits/gogs/modules/auth"
 | 
				
			||||||
 | 
						"github.com/gogits/gogs/modules/base"
 | 
				
			||||||
	"github.com/gogits/gogs/modules/log"
 | 
						"github.com/gogits/gogs/modules/log"
 | 
				
			||||||
	"github.com/gogits/gogs/modules/middleware"
 | 
						"github.com/gogits/gogs/modules/middleware"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
@@ -61,3 +64,44 @@ func NewUser(ctx *middleware.Context, form auth.RegisterForm) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ctx.Redirect("/admin/users")
 | 
						ctx.Redirect("/admin/users")
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func EditUser(ctx *middleware.Context, params martini.Params, form auth.AdminEditUserForm) {
 | 
				
			||||||
 | 
						ctx.Data["Title"] = "Edit Account"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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 ctx.Req.Method == "GET" {
 | 
				
			||||||
 | 
							ctx.Data["User"] = u
 | 
				
			||||||
 | 
							ctx.HTML(200, "admin/users/edit")
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						u.Email = form.Email
 | 
				
			||||||
 | 
						u.Website = form.Website
 | 
				
			||||||
 | 
						u.Location = form.Location
 | 
				
			||||||
 | 
						u.Avatar = base.EncodeMd5(form.Avatar)
 | 
				
			||||||
 | 
						u.AvatarEmail = form.Avatar
 | 
				
			||||||
 | 
						u.IsActive = form.Active == "on"
 | 
				
			||||||
 | 
						u.IsAdmin = form.Admin == "on"
 | 
				
			||||||
 | 
						if err := models.UpdateUser(u); err != nil {
 | 
				
			||||||
 | 
							ctx.Handle(200, "admin.user.EditUser", err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ctx.Data["IsSuccess"] = true
 | 
				
			||||||
 | 
						ctx.Data["User"] = u
 | 
				
			||||||
 | 
						ctx.HTML(200, "admin/users/edit")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						log.Trace("%s User profile updated by admin(%s): %s", ctx.Req.RequestURI,
 | 
				
			||||||
 | 
							ctx.User.LowerName, ctx.User.LowerName)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -46,6 +46,7 @@ func Setting(ctx *middleware.Context, form auth.UpdateProfileForm) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	ctx.Data["IsSuccess"] = true
 | 
						ctx.Data["IsSuccess"] = true
 | 
				
			||||||
	ctx.HTML(200, "user/setting")
 | 
						ctx.HTML(200, "user/setting")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	log.Trace("%s User setting updated: %s", ctx.Req.RequestURI, ctx.User.LowerName)
 | 
						log.Trace("%s User setting updated: %s", ctx.Req.RequestURI, ctx.User.LowerName)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,6 +20,7 @@
 | 
				
			|||||||
                            <th>Admin</th>
 | 
					                            <th>Admin</th>
 | 
				
			||||||
                            <th>Repos</th>
 | 
					                            <th>Repos</th>
 | 
				
			||||||
                            <th>Join</th>
 | 
					                            <th>Join</th>
 | 
				
			||||||
 | 
					                            <th>Edit</th>
 | 
				
			||||||
                        </tr>
 | 
					                        </tr>
 | 
				
			||||||
                    </thead>
 | 
					                    </thead>
 | 
				
			||||||
                    <tbody>
 | 
					                    <tbody>
 | 
				
			||||||
@@ -32,6 +33,7 @@
 | 
				
			|||||||
                            <td><i class="fa fa{{if .IsAdmin}}-check{{end}}-square-o"></i></td>
 | 
					                            <td><i class="fa fa{{if .IsAdmin}}-check{{end}}-square-o"></i></td>
 | 
				
			||||||
                            <td>{{.NumRepos}}</td>
 | 
					                            <td>{{.NumRepos}}</td>
 | 
				
			||||||
                            <td>{{DateFormat .Created "M d, Y"}}</td>
 | 
					                            <td>{{DateFormat .Created "M d, Y"}}</td>
 | 
				
			||||||
 | 
					                            <td><a href="/admin/users/{{.Id}}"><i class="fa fa-pencil-square-o"></i></a></td>
 | 
				
			||||||
                        </tr>
 | 
					                        </tr>
 | 
				
			||||||
                        {{end}}
 | 
					                        {{end}}
 | 
				
			||||||
                    </tbody>
 | 
					                    </tbody>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										83
									
								
								templates/admin/users/edit.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								templates/admin/users/edit.tmpl
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,83 @@
 | 
				
			|||||||
 | 
					{{template "base/head" .}}
 | 
				
			||||||
 | 
					{{template "base/navbar" .}}
 | 
				
			||||||
 | 
					<div id="gogs-body" class="container" data-page="admin">
 | 
				
			||||||
 | 
					    {{template "admin/nav" .}}
 | 
				
			||||||
 | 
					    <div id="gogs-admin-container" class="col-md-9">
 | 
				
			||||||
 | 
					        <div class="panel panel-default">
 | 
				
			||||||
 | 
					            <div class="panel-heading">
 | 
				
			||||||
 | 
					                Edit Account
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            <div class="panel-body">
 | 
				
			||||||
 | 
					            	<br/>
 | 
				
			||||||
 | 
									<form action="/admin/users/{{.User.Id}}" method="post" class="form-horizontal">
 | 
				
			||||||
 | 
									    {{if .IsSuccess}}<p class="alert alert-success">Your profile has been successfully updated.</p>{{else if .HasError}}<p class="alert alert-danger form-error">{{.ErrorMsg}}</p>{{end}}
 | 
				
			||||||
 | 
					                	<input type="hidden" value="{{.User.Id}}" name="userId"/>
 | 
				
			||||||
 | 
										<div class="form-group">
 | 
				
			||||||
 | 
											<label class="col-md-3 control-label">Username: </label>
 | 
				
			||||||
 | 
											<label class="control-label">{{.User.Name}}</label>
 | 
				
			||||||
 | 
										</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										<div class="form-group {{if .Err_Email}}has-error has-feedback{{end}}">
 | 
				
			||||||
 | 
											<label class="col-md-3 control-label">Email<strong class="text-danger">*</strong></label>
 | 
				
			||||||
 | 
											<div class="col-md-7">
 | 
				
			||||||
 | 
												<input name="email" class="form-control" placeholder="Type account's e-mail address" value="{{.User.Email}}" required="required">
 | 
				
			||||||
 | 
											</div>
 | 
				
			||||||
 | 
										</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						                <div class="form-group">
 | 
				
			||||||
 | 
						                    <label class="col-md-3 control-label">Website</label>
 | 
				
			||||||
 | 
						                    <div class="col-md-7">
 | 
				
			||||||
 | 
						                        <input name="website" class="form-control" placeholder="Type account's website URL" value="{{.User.Website}}">
 | 
				
			||||||
 | 
						                    </div>
 | 
				
			||||||
 | 
						                </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						                <div class="form-group">
 | 
				
			||||||
 | 
						                    <label class="col-md-3 control-label">Location</label>
 | 
				
			||||||
 | 
						                    <div class="col-md-7">
 | 
				
			||||||
 | 
						                        <input name="location" class="form-control" placeholder="Type account's current location" value="{{.User.Location}}">
 | 
				
			||||||
 | 
						                    </div>
 | 
				
			||||||
 | 
						                </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						                <div class="form-group {{if .Err_Avatar}}has-error has-feedback{{end}}">
 | 
				
			||||||
 | 
						                    <label class="col-md-3 control-label">Gravatar Email<strong class="text-danger">*</strong></label>
 | 
				
			||||||
 | 
						                    <div class="col-md-7">
 | 
				
			||||||
 | 
						                        <input name="avatar" class="form-control" placeholder="Type account's Gravatar e-mail address" required="required" value="{{.User.AvatarEmail}}">
 | 
				
			||||||
 | 
						                    </div>
 | 
				
			||||||
 | 
						                </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						                <div class="form-group">
 | 
				
			||||||
 | 
								            <div class="col-md-7 col-md-offset-3">
 | 
				
			||||||
 | 
								                <div class="checkbox">
 | 
				
			||||||
 | 
								                    <label>
 | 
				
			||||||
 | 
								                        <input type="checkbox" name="active" {{if .User.IsActive}}checked{{end}}>
 | 
				
			||||||
 | 
								                        <strong>This account has activated</strong>
 | 
				
			||||||
 | 
								                    </label>
 | 
				
			||||||
 | 
								                </div>
 | 
				
			||||||
 | 
								            </div>
 | 
				
			||||||
 | 
						                </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						                <div class="form-group">
 | 
				
			||||||
 | 
								            <div class="col-md-7 col-md-offset-3">
 | 
				
			||||||
 | 
								                <div class="checkbox">
 | 
				
			||||||
 | 
								                    <label>
 | 
				
			||||||
 | 
								                        <input type="checkbox" name="admin" {{if .User.IsAdmin}}checked{{end}}>
 | 
				
			||||||
 | 
								                        <strong>This account has administor permisson</strong>
 | 
				
			||||||
 | 
								                    </label>
 | 
				
			||||||
 | 
								                </div>
 | 
				
			||||||
 | 
								            </div>
 | 
				
			||||||
 | 
						                </div>
 | 
				
			||||||
 | 
										<hr/>
 | 
				
			||||||
 | 
										<div class="form-group">
 | 
				
			||||||
 | 
										    <div class="col-md-offset-3 col-md-6">
 | 
				
			||||||
 | 
										    	<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> -->
 | 
				
			||||||
 | 
										    </div>
 | 
				
			||||||
 | 
										</div>
 | 
				
			||||||
 | 
									</form>
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						</div>
 | 
				
			||||||
 | 
					</div>
 | 
				
			||||||
 | 
					{{template "base/footer" .}}
 | 
				
			||||||
@@ -13,35 +13,35 @@
 | 
				
			|||||||
				<form action="/admin/users/new" method="post" class="form-horizontal">
 | 
									<form action="/admin/users/new" method="post" class="form-horizontal">
 | 
				
			||||||
				    <div class="alert alert-danger form-error{{if .HasError}}{{else}} hidden{{end}}">{{.ErrorMsg}}</div>
 | 
									    <div class="alert alert-danger form-error{{if .HasError}}{{else}} hidden{{end}}">{{.ErrorMsg}}</div>
 | 
				
			||||||
					<div class="form-group {{if .Err_UserName}}has-error has-feedback{{end}}">
 | 
										<div class="form-group {{if .Err_UserName}}has-error has-feedback{{end}}">
 | 
				
			||||||
						<label class="col-md-4 control-label">Username: </label>
 | 
											<label class="col-md-3 control-label">Username: </label>
 | 
				
			||||||
						<div class="col-md-6">
 | 
											<div class="col-md-7">
 | 
				
			||||||
							<input name="username" class="form-control" placeholder="Type account's username" value="{{.username}}" required="required">
 | 
												<input name="username" class="form-control" placeholder="Type account's username" value="{{.username}}" required="required">
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
					<div class="form-group {{if .Err_Email}}has-error has-feedback{{end}}">
 | 
										<div class="form-group {{if .Err_Email}}has-error has-feedback{{end}}">
 | 
				
			||||||
						<label class="col-md-4 control-label">Email: </label>
 | 
											<label class="col-md-3 control-label">Email: </label>
 | 
				
			||||||
						<div class="col-md-6">
 | 
											<div class="col-md-7">
 | 
				
			||||||
							<input name="email" class="form-control" placeholder="Type account's e-mail address" value="{{.email}}" required="required" title="Email is not valid">
 | 
												<input name="email" class="form-control" placeholder="Type account's e-mail address" value="{{.email}}" required="required" title="Email is not valid">
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
					<div class="form-group {{if .Err_Password}}has-error has-feedback{{end}}">
 | 
										<div class="form-group {{if .Err_Password}}has-error has-feedback{{end}}">
 | 
				
			||||||
						<label class="col-md-4 control-label">Password: </label>
 | 
											<label class="col-md-3 control-label">Password: </label>
 | 
				
			||||||
						<div class="col-md-6">
 | 
											<div class="col-md-7">
 | 
				
			||||||
							<input name="passwd" type="password" class="form-control" placeholder="Type account's password" required="required" title="Password must contain at least 6 characters">
 | 
												<input name="passwd" type="password" class="form-control" placeholder="Type account's password" required="required" title="Password must contain at least 6 characters">
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
					<div class="form-group {{if .Err_RetypePasswd}}has-error has-feedback{{end}}">
 | 
										<div class="form-group {{if .Err_RetypePasswd}}has-error has-feedback{{end}}">
 | 
				
			||||||
						<label class="col-md-4 control-label">Re-type: </label>
 | 
											<label class="col-md-3 control-label">Re-type: </label>
 | 
				
			||||||
						<div class="col-md-6">
 | 
											<div class="col-md-7">
 | 
				
			||||||
							<input name="retypepasswd" type="password" class="form-control" placeholder="Re-type account's password" required="required" title="Re-type Password must be same to Password">
 | 
												<input name="retypepasswd" type="password" class="form-control" placeholder="Re-type account's password" required="required" title="Re-type Password must be same to Password">
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
 | 
										<hr/>
 | 
				
			||||||
					<div class="form-group">
 | 
										<div class="form-group">
 | 
				
			||||||
					    <div class="col-md-offset-4 col-md-6">
 | 
										    <div class="col-md-offset-3 col-md-7">
 | 
				
			||||||
					    	<button type="submit" class="btn btn-lg btn-primary">Create new account</button>
 | 
										    	<button type="submit" class="btn btn-lg btn-primary">Create new account</button>
 | 
				
			||||||
					    </div>
 | 
										    </div>
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,8 +5,8 @@
 | 
				
			|||||||
    <div id="gogs-user-setting-container" class="col-md-9">
 | 
					    <div id="gogs-user-setting-container" class="col-md-9">
 | 
				
			||||||
        <div id="gogs-setting-pwd">
 | 
					        <div id="gogs-setting-pwd">
 | 
				
			||||||
            <h4>Account Profile</h4>
 | 
					            <h4>Account Profile</h4>
 | 
				
			||||||
            <form class="form-horizontal" id="gogs-password-form" method="post" action="/user/setting">{{if .IsSuccess}}
 | 
					            <form class="form-horizontal" id="gogs-password-form" method="post" action="/user/setting">
 | 
				
			||||||
                <p class="alert alert-success">Your profile has been successfully updated.</p>{{else if .HasError}}<p class="alert alert-danger form-error">{{.ErrorMsg}}</p>{{end}}
 | 
					                {{if .IsSuccess}}<p class="alert alert-success">Your profile has been successfully updated.</p>{{else if .HasError}}<p class="alert alert-danger form-error">{{.ErrorMsg}}</p>{{end}}
 | 
				
			||||||
                <p>Your Email will be public and used for Account related notifications and any web based operations made via the web.</p>
 | 
					                <p>Your Email will be public and used for Account related notifications and any web based operations made via the web.</p>
 | 
				
			||||||
                <div class="form-group">
 | 
					                <div class="form-group">
 | 
				
			||||||
                    <label class="col-md-2 control-label">Email</label>
 | 
					                    <label class="col-md-2 control-label">Email</label>
 | 
				
			||||||
@@ -29,7 +29,7 @@
 | 
				
			|||||||
                    </div>
 | 
					                    </div>
 | 
				
			||||||
                </div>
 | 
					                </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                <div class="form-group">
 | 
					                <div class="form-group {{if .Err_Avatar}}has-error has-feedback{{end}}">
 | 
				
			||||||
                    <label class="col-md-2 control-label">Gravatar Email<strong class="text-danger">*</strong></label>
 | 
					                    <label class="col-md-2 control-label">Gravatar Email<strong class="text-danger">*</strong></label>
 | 
				
			||||||
                    <div class="col-md-8">
 | 
					                    <div class="col-md-8">
 | 
				
			||||||
                        <input type="text" name="avatar" class="form-control" placeholder="Type your Gravatar e-mail address" required="required" value="{{.Owner.AvatarEmail}}">
 | 
					                        <input type="text" name="avatar" class="form-control" placeholder="Type your Gravatar e-mail address" required="required" value="{{.Owner.AvatarEmail}}">
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										1
									
								
								web.go
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								web.go
									
									
									
									
									
								
							@@ -118,6 +118,7 @@ func runWeb(*cli.Context) {
 | 
				
			|||||||
	m.Get("/admin", reqSignIn, adminReq, admin.Dashboard)
 | 
						m.Get("/admin", reqSignIn, adminReq, admin.Dashboard)
 | 
				
			||||||
	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.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