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…
	
	Add table
		Add a link
		
	
		Reference in a new issue