mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-24 13:53:42 +09:00 
			
		
		
		
	Fix updating user visibility (#35036)
Fix #35030 --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -28,6 +28,13 @@ func FromPtr[T any](v *T) Option[T] { | |||||||
| 	return Some(*v) | 	return Some(*v) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func FromMapLookup[K comparable, V any](m map[K]V, k K) Option[V] { | ||||||
|  | 	if v, ok := m[k]; ok { | ||||||
|  | 		return Some(v) | ||||||
|  | 	} | ||||||
|  | 	return None[V]() | ||||||
|  | } | ||||||
|  |  | ||||||
| func FromNonDefault[T comparable](v T) Option[T] { | func FromNonDefault[T comparable](v T) Option[T] { | ||||||
| 	var zero T | 	var zero T | ||||||
| 	if v == zero { | 	if v == zero { | ||||||
|   | |||||||
| @@ -56,6 +56,12 @@ func TestOption(t *testing.T) { | |||||||
| 	opt3 := optional.FromNonDefault(1) | 	opt3 := optional.FromNonDefault(1) | ||||||
| 	assert.True(t, opt3.Has()) | 	assert.True(t, opt3.Has()) | ||||||
| 	assert.Equal(t, int(1), opt3.Value()) | 	assert.Equal(t, int(1), opt3.Value()) | ||||||
|  |  | ||||||
|  | 	opt4 := optional.FromMapLookup(map[string]int{"a": 1}, "a") | ||||||
|  | 	assert.True(t, opt4.Has()) | ||||||
|  | 	assert.Equal(t, 1, opt4.Value()) | ||||||
|  | 	opt4 = optional.FromMapLookup(map[string]int{"a": 1}, "b") | ||||||
|  | 	assert.False(t, opt4.Has()) | ||||||
| } | } | ||||||
|  |  | ||||||
| func Test_ParseBool(t *testing.T) { | func Test_ParseBool(t *testing.T) { | ||||||
|   | |||||||
| @@ -240,7 +240,7 @@ func EditUser(ctx *context.APIContext) { | |||||||
| 		Description:             optional.FromPtr(form.Description), | 		Description:             optional.FromPtr(form.Description), | ||||||
| 		IsActive:                optional.FromPtr(form.Active), | 		IsActive:                optional.FromPtr(form.Active), | ||||||
| 		IsAdmin:                 user_service.UpdateOptionFieldFromPtr(form.Admin), | 		IsAdmin:                 user_service.UpdateOptionFieldFromPtr(form.Admin), | ||||||
| 		Visibility:              optional.FromNonDefault(api.VisibilityModes[form.Visibility]), | 		Visibility:              optional.FromMapLookup(api.VisibilityModes, form.Visibility), | ||||||
| 		AllowGitHook:            optional.FromPtr(form.AllowGitHook), | 		AllowGitHook:            optional.FromPtr(form.AllowGitHook), | ||||||
| 		AllowImportLocal:        optional.FromPtr(form.AllowImportLocal), | 		AllowImportLocal:        optional.FromPtr(form.AllowImportLocal), | ||||||
| 		MaxRepoCreation:         optional.FromPtr(form.MaxRepoCreation), | 		MaxRepoCreation:         optional.FromPtr(form.MaxRepoCreation), | ||||||
|   | |||||||
| @@ -391,7 +391,7 @@ func Edit(ctx *context.APIContext) { | |||||||
| 		Description:               optional.Some(form.Description), | 		Description:               optional.Some(form.Description), | ||||||
| 		Website:                   optional.Some(form.Website), | 		Website:                   optional.Some(form.Website), | ||||||
| 		Location:                  optional.Some(form.Location), | 		Location:                  optional.Some(form.Location), | ||||||
| 		Visibility:                optional.FromNonDefault(api.VisibilityModes[form.Visibility]), | 		Visibility:                optional.FromMapLookup(api.VisibilityModes, form.Visibility), | ||||||
| 		RepoAdminChangeTeamAccess: optional.FromPtr(form.RepoAdminChangeTeamAccess), | 		RepoAdminChangeTeamAccess: optional.FromPtr(form.RepoAdminChangeTeamAccess), | ||||||
| 	} | 	} | ||||||
| 	if err := user_service.UpdateUser(ctx, ctx.Org.Organization.AsUser(), opts); err != nil { | 	if err := user_service.UpdateUser(ctx, ctx.Org.Organization.AsUser(), opts); err != nil { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user