mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 17:08:25 +00:00 
			
		
		
		
	Improve swagger generation (#33664)
Remove most "sed" tricks --------- Co-authored-by: silverwind <me@silverwind.io>
This commit is contained in:
		| @@ -17,6 +17,7 @@ insert_final_newline = false | |||||||
|  |  | ||||||
| [templates/swagger/v1_json.tmpl] | [templates/swagger/v1_json.tmpl] | ||||||
| indent_style = space | indent_style = space | ||||||
|  | insert_final_newline = false | ||||||
|  |  | ||||||
| [templates/user/auth/oidc_wellknown.tmpl] | [templates/user/auth/oidc_wellknown.tmpl] | ||||||
| indent_style = space | indent_style = space | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								.github/workflows/files-changed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/files-changed.yml
									
									
									
									
										vendored
									
									
								
							| @@ -85,6 +85,7 @@ jobs: | |||||||
|  |  | ||||||
|             swagger: |             swagger: | ||||||
|               - "templates/swagger/v1_json.tmpl" |               - "templates/swagger/v1_json.tmpl" | ||||||
|  |               - "templates/swagger/v1_input.json" | ||||||
|               - "Makefile" |               - "Makefile" | ||||||
|               - "package.json" |               - "package.json" | ||||||
|               - "package-lock.json" |               - "package-lock.json" | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								Makefile
									
									
									
									
									
								
							| @@ -165,10 +165,8 @@ ifdef DEPS_PLAYWRIGHT | |||||||
| endif | endif | ||||||
|  |  | ||||||
| SWAGGER_SPEC := templates/swagger/v1_json.tmpl | SWAGGER_SPEC := templates/swagger/v1_json.tmpl | ||||||
| SWAGGER_SPEC_S_TMPL := s|"basePath": *"/api/v1"|"basePath": "{{AppSubUrl \| JSEscape}}/api/v1"|g | SWAGGER_SPEC_INPUT := templates/swagger/v1_input.json | ||||||
| SWAGGER_SPEC_S_JSON := s|"basePath": *"{{AppSubUrl \| JSEscape}}/api/v1"|"basePath": "/api/v1"|g |  | ||||||
| SWAGGER_EXCLUDE := code.gitea.io/sdk | SWAGGER_EXCLUDE := code.gitea.io/sdk | ||||||
| SWAGGER_NEWLINE_COMMAND := -e '$$a\' |  | ||||||
|  |  | ||||||
| TEST_MYSQL_HOST ?= mysql:3306 | TEST_MYSQL_HOST ?= mysql:3306 | ||||||
| TEST_MYSQL_DBNAME ?= testgitea | TEST_MYSQL_DBNAME ?= testgitea | ||||||
| @@ -271,10 +269,8 @@ endif | |||||||
| .PHONY: generate-swagger | .PHONY: generate-swagger | ||||||
| generate-swagger: $(SWAGGER_SPEC) ## generate the swagger spec from code comments | generate-swagger: $(SWAGGER_SPEC) ## generate the swagger spec from code comments | ||||||
|  |  | ||||||
| $(SWAGGER_SPEC): $(GO_SOURCES_NO_BINDATA) | $(SWAGGER_SPEC): $(GO_SOURCES_NO_BINDATA) $(SWAGGER_SPEC_INPUT) | ||||||
| 	$(GO) run $(SWAGGER_PACKAGE) generate spec -x "$(SWAGGER_EXCLUDE)" -o './$(SWAGGER_SPEC)' | 	$(GO) run $(SWAGGER_PACKAGE) generate spec --exclude "$(SWAGGER_EXCLUDE)" --input "$(SWAGGER_SPEC_INPUT)" --output './$(SWAGGER_SPEC)' | ||||||
| 	$(SED_INPLACE) '$(SWAGGER_SPEC_S_TMPL)' './$(SWAGGER_SPEC)' |  | ||||||
| 	$(SED_INPLACE) $(SWAGGER_NEWLINE_COMMAND) './$(SWAGGER_SPEC)' |  | ||||||
|  |  | ||||||
| .PHONY: swagger-check | .PHONY: swagger-check | ||||||
| swagger-check: generate-swagger | swagger-check: generate-swagger | ||||||
| @@ -287,9 +283,11 @@ swagger-check: generate-swagger | |||||||
|  |  | ||||||
| .PHONY: swagger-validate | .PHONY: swagger-validate | ||||||
| swagger-validate: ## check if the swagger spec is valid | swagger-validate: ## check if the swagger spec is valid | ||||||
| 	$(SED_INPLACE) '$(SWAGGER_SPEC_S_JSON)' './$(SWAGGER_SPEC)' | 	@# swagger "validate" requires that the "basePath" must start with a slash, but we are using Golang template "{{...}}" | ||||||
|  | 	@$(SED_INPLACE) -E -e 's|"basePath":( *)"(.*)"|"basePath":\1"/\2"|g' './$(SWAGGER_SPEC)' # add a prefix slash to basePath | ||||||
|  | 	@# FIXME: there are some warnings | ||||||
| 	$(GO) run $(SWAGGER_PACKAGE) validate './$(SWAGGER_SPEC)' | 	$(GO) run $(SWAGGER_PACKAGE) validate './$(SWAGGER_SPEC)' | ||||||
| 	$(SED_INPLACE) '$(SWAGGER_SPEC_S_TMPL)' './$(SWAGGER_SPEC)' | 	@$(SED_INPLACE) -E -e 's|"basePath":( *)"/(.*)"|"basePath":\1"\2"|g' './$(SWAGGER_SPEC)' # remove the prefix slash from basePath | ||||||
|  |  | ||||||
| .PHONY: checks | .PHONY: checks | ||||||
| checks: checks-frontend checks-backend ## run various consistency checks | checks: checks-frontend checks-backend ## run various consistency checks | ||||||
| @@ -380,6 +378,7 @@ lint-go-gopls: ## lint go files with gopls | |||||||
|  |  | ||||||
| .PHONY: lint-editorconfig | .PHONY: lint-editorconfig | ||||||
| lint-editorconfig: | lint-editorconfig: | ||||||
|  | 	@echo "Running editorconfig check..." | ||||||
| 	@$(GO) run $(EDITORCONFIG_CHECKER_PACKAGE) $(EDITORCONFIG_FILES) | 	@$(GO) run $(EDITORCONFIG_CHECKER_PACKAGE) $(EDITORCONFIG_FILES) | ||||||
|  |  | ||||||
| .PHONY: lint-actions | .PHONY: lint-actions | ||||||
|   | |||||||
| @@ -7,8 +7,6 @@ | |||||||
| // This documentation describes the Gitea API. | // This documentation describes the Gitea API. | ||||||
| // | // | ||||||
| //	Schemes: https, http | //	Schemes: https, http | ||||||
| //	BasePath: /api/v1 |  | ||||||
| //	Version: {{AppVer | JSEscape}} |  | ||||||
| //	License: MIT http://opensource.org/licenses/MIT | //	License: MIT http://opensource.org/licenses/MIT | ||||||
| // | // | ||||||
| //	Consumes: | //	Consumes: | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								templates/swagger/v1_input.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								templates/swagger/v1_input.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | { | ||||||
|  |   "info": { | ||||||
|  |     "version": "{{AppVer | JSEscape}}" | ||||||
|  |   }, | ||||||
|  |   "basePath": "{{AppSubUrl | JSEscape}}/api/v1" | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user