mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 19:38:23 +00:00 
			
		
		
		
	
							
								
								
									
										174
									
								
								routers/api/v1/admin/hooks.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										174
									
								
								routers/api/v1/admin/hooks.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,174 @@ | ||||
| // 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) | ||||
| 	// TODO in body params | ||||
| 	if !utils.CheckCreateHookOption(ctx, form) { | ||||
| 		return | ||||
| 	} | ||||
| 	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) | ||||
| } | ||||
		Reference in New Issue
	
	Block a user