mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00:00 
			
		
		
		
	Currently we can add webhooks for organizations but not for users. This PR adds the latter. You can access it from the current users settings. 
		
			
				
	
	
		
			171 lines
		
	
	
	
		
			4.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			171 lines
		
	
	
	
		
			4.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2021 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package admin
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/webhook"
 | |
| 	"code.gitea.io/gitea/modules/context"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	api "code.gitea.io/gitea/modules/structs"
 | |
| 	"code.gitea.io/gitea/modules/util"
 | |
| 	"code.gitea.io/gitea/modules/web"
 | |
| 	"code.gitea.io/gitea/routers/api/v1/utils"
 | |
| 	webhook_service "code.gitea.io/gitea/services/webhook"
 | |
| )
 | |
| 
 | |
| // ListHooks list system's webhooks
 | |
| func ListHooks(ctx *context.APIContext) {
 | |
| 	// swagger:operation GET /admin/hooks admin adminListHooks
 | |
| 	// ---
 | |
| 	// summary: List system's webhooks
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: page
 | |
| 	//   in: query
 | |
| 	//   description: page number of results to return (1-based)
 | |
| 	//   type: integer
 | |
| 	// - name: limit
 | |
| 	//   in: query
 | |
| 	//   description: page size of results
 | |
| 	//   type: integer
 | |
| 	// responses:
 | |
| 	//   "200":
 | |
| 	//     "$ref": "#/responses/HookList"
 | |
| 
 | |
| 	sysHooks, err := webhook.GetSystemWebhooks(ctx, util.OptionalBoolNone)
 | |
| 	if err != nil {
 | |
| 		ctx.Error(http.StatusInternalServerError, "GetSystemWebhooks", err)
 | |
| 		return
 | |
| 	}
 | |
| 	hooks := make([]*api.Hook, len(sysHooks))
 | |
| 	for i, hook := range sysHooks {
 | |
| 		h, err := webhook_service.ToHook(setting.AppURL+"/admin", hook)
 | |
| 		if err != nil {
 | |
| 			ctx.Error(http.StatusInternalServerError, "convert.ToHook", err)
 | |
| 			return
 | |
| 		}
 | |
| 		hooks[i] = h
 | |
| 	}
 | |
| 	ctx.JSON(http.StatusOK, hooks)
 | |
| }
 | |
| 
 | |
| // GetHook get an organization's hook by id
 | |
| func GetHook(ctx *context.APIContext) {
 | |
| 	// swagger:operation GET /admin/hooks/{id} admin adminGetHook
 | |
| 	// ---
 | |
| 	// summary: Get a hook
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: id
 | |
| 	//   in: path
 | |
| 	//   description: id of the hook to get
 | |
| 	//   type: integer
 | |
| 	//   format: int64
 | |
| 	//   required: true
 | |
| 	// responses:
 | |
| 	//   "200":
 | |
| 	//     "$ref": "#/responses/Hook"
 | |
| 
 | |
| 	hookID := ctx.ParamsInt64(":id")
 | |
| 	hook, err := webhook.GetSystemOrDefaultWebhook(ctx, hookID)
 | |
| 	if err != nil {
 | |
| 		ctx.Error(http.StatusInternalServerError, "GetSystemOrDefaultWebhook", err)
 | |
| 		return
 | |
| 	}
 | |
| 	h, err := webhook_service.ToHook("/admin/", hook)
 | |
| 	if err != nil {
 | |
| 		ctx.Error(http.StatusInternalServerError, "convert.ToHook", err)
 | |
| 		return
 | |
| 	}
 | |
| 	ctx.JSON(http.StatusOK, h)
 | |
| }
 | |
| 
 | |
| // CreateHook create a hook for an organization
 | |
| func CreateHook(ctx *context.APIContext) {
 | |
| 	// swagger:operation POST /admin/hooks admin adminCreateHook
 | |
| 	// ---
 | |
| 	// summary: Create a hook
 | |
| 	// consumes:
 | |
| 	// - application/json
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: body
 | |
| 	//   in: body
 | |
| 	//   required: true
 | |
| 	//   schema:
 | |
| 	//     "$ref": "#/definitions/CreateHookOption"
 | |
| 	// responses:
 | |
| 	//   "201":
 | |
| 	//     "$ref": "#/responses/Hook"
 | |
| 
 | |
| 	form := web.GetForm(ctx).(*api.CreateHookOption)
 | |
| 
 | |
| 	utils.AddSystemHook(ctx, form)
 | |
| }
 | |
| 
 | |
| // EditHook modify a hook of a repository
 | |
| func EditHook(ctx *context.APIContext) {
 | |
| 	// swagger:operation PATCH /admin/hooks/{id} admin adminEditHook
 | |
| 	// ---
 | |
| 	// summary: Update a hook
 | |
| 	// consumes:
 | |
| 	// - application/json
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: id
 | |
| 	//   in: path
 | |
| 	//   description: id of the hook to update
 | |
| 	//   type: integer
 | |
| 	//   format: int64
 | |
| 	//   required: true
 | |
| 	// - name: body
 | |
| 	//   in: body
 | |
| 	//   schema:
 | |
| 	//     "$ref": "#/definitions/EditHookOption"
 | |
| 	// responses:
 | |
| 	//   "200":
 | |
| 	//     "$ref": "#/responses/Hook"
 | |
| 
 | |
| 	form := web.GetForm(ctx).(*api.EditHookOption)
 | |
| 
 | |
| 	// TODO in body params
 | |
| 	hookID := ctx.ParamsInt64(":id")
 | |
| 	utils.EditSystemHook(ctx, form, hookID)
 | |
| }
 | |
| 
 | |
| // DeleteHook delete a system hook
 | |
| func DeleteHook(ctx *context.APIContext) {
 | |
| 	// swagger:operation DELETE /amdin/hooks/{id} admin adminDeleteHook
 | |
| 	// ---
 | |
| 	// summary: Delete a hook
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: id
 | |
| 	//   in: path
 | |
| 	//   description: id of the hook to delete
 | |
| 	//   type: integer
 | |
| 	//   format: int64
 | |
| 	//   required: true
 | |
| 	// responses:
 | |
| 	//   "204":
 | |
| 	//     "$ref": "#/responses/empty"
 | |
| 
 | |
| 	hookID := ctx.ParamsInt64(":id")
 | |
| 	if err := webhook.DeleteDefaultSystemWebhook(ctx, hookID); err != nil {
 | |
| 		if webhook.IsErrWebhookNotExist(err) {
 | |
| 			ctx.NotFound()
 | |
| 		} else {
 | |
| 			ctx.Error(http.StatusInternalServerError, "DeleteDefaultSystemWebhook", err)
 | |
| 		}
 | |
| 		return
 | |
| 	}
 | |
| 	ctx.Status(http.StatusNoContent)
 | |
| }
 |