API: Move AllowedReactions endpoint into GetGenneralUI endpoint + creat new swagger section settings (#11854)
* move Setting function into its own package * swagger add&use new section "settings" * move api AllowedReactions into general UI-Settings endpoint * prepare TEST * lint
This commit is contained in:
		
							parent
							
								
									b948ecb2d2
								
							
						
					
					
						commit
						fc2f2c7602
					
				
					 7 changed files with 81 additions and 41 deletions
				
			
		|  | @ -20,16 +20,14 @@ import ( | |||
| func TestAPIAllowedReactions(t *testing.T) { | ||||
| 	defer prepareTestEnv(t)() | ||||
| 
 | ||||
| 	type allowed []string | ||||
| 	a := new(api.GeneralUISettings) | ||||
| 
 | ||||
| 	a := new(allowed) | ||||
| 
 | ||||
| 	req := NewRequest(t, "GET", "/api/v1/settings/allowed_reactions") | ||||
| 	req := NewRequest(t, "GET", "/api/v1/settings/ui") | ||||
| 	resp := MakeRequest(t, req, http.StatusOK) | ||||
| 
 | ||||
| 	DecodeJSON(t, resp, &a) | ||||
| 	assert.Len(t, *a, len(setting.UI.Reactions)) | ||||
| 	assert.ElementsMatch(t, setting.UI.Reactions, *a) | ||||
| 	assert.Len(t, a.AllowedReactions, len(setting.UI.Reactions)) | ||||
| 	assert.ElementsMatch(t, setting.UI.Reactions, a.AllowedReactions) | ||||
| } | ||||
| 
 | ||||
| func TestAPIIssuesReactions(t *testing.T) { | ||||
|  |  | |||
|  | @ -9,3 +9,8 @@ type GeneralRepoSettings struct { | |||
| 	MirrorsDisabled bool `json:"mirrors_disabled"` | ||||
| 	HTTPGitDisabled bool `json:"http_git_disabled"` | ||||
| } | ||||
| 
 | ||||
| // GeneralUISettings contains global ui settings exposed by API
 | ||||
| type GeneralUISettings struct { | ||||
| 	AllowedReactions []string `json:"allowed_reactions"` | ||||
| } | ||||
|  |  | |||
|  | @ -73,6 +73,7 @@ import ( | |||
| 	"code.gitea.io/gitea/routers/api/v1/notify" | ||||
| 	"code.gitea.io/gitea/routers/api/v1/org" | ||||
| 	"code.gitea.io/gitea/routers/api/v1/repo" | ||||
| 	"code.gitea.io/gitea/routers/api/v1/settings" | ||||
| 	_ "code.gitea.io/gitea/routers/api/v1/swagger" // for swagger generation
 | ||||
| 	"code.gitea.io/gitea/routers/api/v1/user" | ||||
| 
 | ||||
|  | @ -513,8 +514,8 @@ func RegisterRoutes(m *macaron.Macaron) { | |||
| 		m.Post("/markdown", bind(api.MarkdownOption{}), misc.Markdown) | ||||
| 		m.Post("/markdown/raw", misc.MarkdownRaw) | ||||
| 		m.Group("/settings", func() { | ||||
| 			m.Get("/allowed_reactions", misc.SettingGetsAllowedReactions) | ||||
| 			m.Get("/repository", misc.GetGeneralRepoSettings) | ||||
| 			m.Get("/ui", settings.GetGeneralUISettings) | ||||
| 			m.Get("/repository", settings.GetGeneralRepoSettings) | ||||
| 		}) | ||||
| 
 | ||||
| 		// Notifications
 | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| // Use of this source code is governed by a MIT-style
 | ||||
| // license that can be found in the LICENSE file.
 | ||||
| 
 | ||||
| package misc | ||||
| package settings | ||||
| 
 | ||||
| import ( | ||||
| 	"net/http" | ||||
|  | @ -12,22 +12,24 @@ import ( | |||
| 	api "code.gitea.io/gitea/modules/structs" | ||||
| ) | ||||
| 
 | ||||
| // SettingGetsAllowedReactions return allowed reactions
 | ||||
| func SettingGetsAllowedReactions(ctx *context.APIContext) { | ||||
| 	// swagger:operation GET /settings/allowed_reactions miscellaneous getAllowedReactions
 | ||||
| // GetGeneralUISettings returns instance's global settings for ui
 | ||||
| func GetGeneralUISettings(ctx *context.APIContext) { | ||||
| 	// swagger:operation GET /settings/ui settings getGeneralUISettings
 | ||||
| 	// ---
 | ||||
| 	// summary: Returns string array of allowed reactions
 | ||||
| 	// summary: Get instance's global settings for ui
 | ||||
| 	// produces:
 | ||||
| 	// - application/json
 | ||||
| 	// responses:
 | ||||
| 	//   "200":
 | ||||
| 	//     "$ref": "#/responses/StringSlice"
 | ||||
| 	ctx.JSON(http.StatusOK, setting.UI.Reactions) | ||||
| 	//     "$ref": "#/responses/GeneralUISettings"
 | ||||
| 	ctx.JSON(http.StatusOK, api.GeneralUISettings{ | ||||
| 		AllowedReactions: setting.UI.Reactions, | ||||
| 	}) | ||||
| } | ||||
| 
 | ||||
| // GetGeneralRepoSettings returns instance's global settings for repositories
 | ||||
| func GetGeneralRepoSettings(ctx *context.APIContext) { | ||||
| 	// swagger:operation GET /settings/repository miscellaneous getGeneralRepositorySettings
 | ||||
| 	// swagger:operation GET /settings/repository settings getGeneralRepositorySettings
 | ||||
| 	// ---
 | ||||
| 	// summary: Get instance's global settings for repositories
 | ||||
| 	// produces:
 | ||||
|  | @ -21,10 +21,3 @@ type swaggerResponseStringSlice struct { | |||
| 	// in:body
 | ||||
| 	Body []string `json:"body"` | ||||
| } | ||||
| 
 | ||||
| // GeneralRepoSettings
 | ||||
| // swagger:response GeneralRepoSettings
 | ||||
| type swaggerResponseGeneralRepoSettings struct { | ||||
| 	// in:body
 | ||||
| 	Body api.GeneralRepoSettings `json:"body"` | ||||
| } | ||||
|  |  | |||
							
								
								
									
										21
									
								
								routers/api/v1/swagger/settings.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								routers/api/v1/swagger/settings.go
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,21 @@ | |||
| // Copyright 2020 The Gitea 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 swagger | ||||
| 
 | ||||
| import api "code.gitea.io/gitea/modules/structs" | ||||
| 
 | ||||
| // GeneralRepoSettings
 | ||||
| // swagger:response GeneralRepoSettings
 | ||||
| type swaggerResponseGeneralRepoSettings struct { | ||||
| 	// in:body
 | ||||
| 	Body api.GeneralRepoSettings `json:"body"` | ||||
| } | ||||
| 
 | ||||
| // GeneralUISettings
 | ||||
| // swagger:response GeneralUISettings
 | ||||
| type swaggerResponseGeneralUISettings struct { | ||||
| 	// in:body
 | ||||
| 	Body api.GeneralUISettings `json:"body"` | ||||
| } | ||||
|  | @ -8470,30 +8470,13 @@ | |||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "/settings/allowed_reactions": { | ||||
|       "get": { | ||||
|         "produces": [ | ||||
|           "application/json" | ||||
|         ], | ||||
|         "tags": [ | ||||
|           "miscellaneous" | ||||
|         ], | ||||
|         "summary": "Returns string array of allowed reactions", | ||||
|         "operationId": "getAllowedReactions", | ||||
|         "responses": { | ||||
|           "200": { | ||||
|             "$ref": "#/responses/StringSlice" | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "/settings/repository": { | ||||
|       "get": { | ||||
|         "produces": [ | ||||
|           "application/json" | ||||
|         ], | ||||
|         "tags": [ | ||||
|           "miscellaneous" | ||||
|           "settings" | ||||
|         ], | ||||
|         "summary": "Get instance's global settings for repositories", | ||||
|         "operationId": "getGeneralRepositorySettings", | ||||
|  | @ -8504,6 +8487,23 @@ | |||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "/settings/ui": { | ||||
|       "get": { | ||||
|         "produces": [ | ||||
|           "application/json" | ||||
|         ], | ||||
|         "tags": [ | ||||
|           "settings" | ||||
|         ], | ||||
|         "summary": "Get instance's global settings for ui", | ||||
|         "operationId": "getGeneralUISettings", | ||||
|         "responses": { | ||||
|           "200": { | ||||
|             "$ref": "#/responses/GeneralUISettings" | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "/signing-key.gpg": { | ||||
|       "get": { | ||||
|         "produces": [ | ||||
|  | @ -12753,6 +12753,20 @@ | |||
|       }, | ||||
|       "x-go-package": "code.gitea.io/gitea/modules/structs" | ||||
|     }, | ||||
|     "GeneralUISettings": { | ||||
|       "description": "GeneralUISettings contains global ui settings exposed by API", | ||||
|       "type": "object", | ||||
|       "properties": { | ||||
|         "allowed_reactions": { | ||||
|           "type": "array", | ||||
|           "items": { | ||||
|             "type": "string" | ||||
|           }, | ||||
|           "x-go-name": "AllowedReactions" | ||||
|         } | ||||
|       }, | ||||
|       "x-go-package": "code.gitea.io/gitea/modules/structs" | ||||
|     }, | ||||
|     "GitBlobResponse": { | ||||
|       "description": "GitBlobResponse represents a git blob", | ||||
|       "type": "object", | ||||
|  | @ -14928,6 +14942,12 @@ | |||
|         "$ref": "#/definitions/GeneralRepoSettings" | ||||
|       } | ||||
|     }, | ||||
|     "GeneralUISettings": { | ||||
|       "description": "GeneralUISettings", | ||||
|       "schema": { | ||||
|         "$ref": "#/definitions/GeneralUISettings" | ||||
|       } | ||||
|     }, | ||||
|     "GitBlobResponse": { | ||||
|       "description": "GitBlobResponse", | ||||
|       "schema": { | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue