mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 00:11:04 +00:00 
			
		
		
		
	- Massive replacement of changing `code.gitea.io/gitea` to `forgejo.org`. - Resolves forgejo/discussions#258 Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7337 Reviewed-by: Earl Warren <earl-warren@noreply.codeberg.org> Reviewed-by: Michael Kriese <michael.kriese@gmx.de> Reviewed-by: Beowulf <beowulf@beocode.eu> Reviewed-by: Panagiotis "Ivory" Vasilopoulos <git@n0toose.net> Co-authored-by: Gusted <postmaster@gusted.xyz> Co-committed-by: Gusted <postmaster@gusted.xyz>
		
			
				
	
	
		
			76 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2023 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package misc
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"net/http"
 | 
						|
	"net/url"
 | 
						|
 | 
						|
	"forgejo.org/modules/options"
 | 
						|
	repo_module "forgejo.org/modules/repository"
 | 
						|
	"forgejo.org/modules/setting"
 | 
						|
	api "forgejo.org/modules/structs"
 | 
						|
	"forgejo.org/modules/util"
 | 
						|
	"forgejo.org/services/context"
 | 
						|
)
 | 
						|
 | 
						|
// Returns a list of all License templates
 | 
						|
func ListLicenseTemplates(ctx *context.APIContext) {
 | 
						|
	// swagger:operation GET /licenses miscellaneous listLicenseTemplates
 | 
						|
	// ---
 | 
						|
	// summary: Returns a list of all license templates
 | 
						|
	// produces:
 | 
						|
	// - application/json
 | 
						|
	// responses:
 | 
						|
	//   "200":
 | 
						|
	//     "$ref": "#/responses/LicenseTemplateList"
 | 
						|
	response := make([]api.LicensesTemplateListEntry, len(repo_module.Licenses))
 | 
						|
	for i, license := range repo_module.Licenses {
 | 
						|
		response[i] = api.LicensesTemplateListEntry{
 | 
						|
			Key:  license,
 | 
						|
			Name: license,
 | 
						|
			URL:  fmt.Sprintf("%sapi/v1/licenses/%s", setting.AppURL, url.PathEscape(license)),
 | 
						|
		}
 | 
						|
	}
 | 
						|
	ctx.JSON(http.StatusOK, response)
 | 
						|
}
 | 
						|
 | 
						|
// Returns information about a gitignore template
 | 
						|
func GetLicenseTemplateInfo(ctx *context.APIContext) {
 | 
						|
	// swagger:operation GET /licenses/{name} miscellaneous getLicenseTemplateInfo
 | 
						|
	// ---
 | 
						|
	// summary: Returns information about a license template
 | 
						|
	// produces:
 | 
						|
	// - application/json
 | 
						|
	// parameters:
 | 
						|
	// - name: name
 | 
						|
	//   in: path
 | 
						|
	//   description: name of the license
 | 
						|
	//   type: string
 | 
						|
	//   required: true
 | 
						|
	// responses:
 | 
						|
	//   "200":
 | 
						|
	//     "$ref": "#/responses/LicenseTemplateInfo"
 | 
						|
	//   "404":
 | 
						|
	//     "$ref": "#/responses/notFound"
 | 
						|
	name := util.PathJoinRelX(ctx.Params("name"))
 | 
						|
 | 
						|
	text, err := options.License(name)
 | 
						|
	if err != nil {
 | 
						|
		ctx.NotFound()
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	response := api.LicenseTemplateInfo{
 | 
						|
		Key:  name,
 | 
						|
		Name: name,
 | 
						|
		URL:  fmt.Sprintf("%sapi/v1/licenses/%s", setting.AppURL, url.PathEscape(name)),
 | 
						|
		Body: string(text),
 | 
						|
		// This is for combatibilty with the GitHub API. This Text is for some reason added to each License response.
 | 
						|
		Implementation: "Create a text file (typically named LICENSE or LICENSE.txt) in the root of your source code and copy the text of the license into the file",
 | 
						|
	}
 | 
						|
 | 
						|
	ctx.JSON(http.StatusOK, response)
 | 
						|
}
 |