| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | // Copyright 2023 The Gitea Authors. All rights reserved. | 
					
						
							|  |  |  | // SPDX-License-Identifier: MIT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package user | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 	"errors" | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 	"net/http" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-27 19:40:14 +00:00
										 |  |  | 	actions_model "forgejo.org/models/actions" | 
					
						
							|  |  |  | 	"forgejo.org/models/db" | 
					
						
							|  |  |  | 	api "forgejo.org/modules/structs" | 
					
						
							|  |  |  | 	"forgejo.org/modules/util" | 
					
						
							|  |  |  | 	"forgejo.org/modules/web" | 
					
						
							|  |  |  | 	"forgejo.org/routers/api/v1/utils" | 
					
						
							|  |  |  | 	actions_service "forgejo.org/services/actions" | 
					
						
							|  |  |  | 	"forgejo.org/services/context" | 
					
						
							|  |  |  | 	secret_service "forgejo.org/services/secrets" | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // create or update one secret of the user scope | 
					
						
							|  |  |  | func CreateOrUpdateSecret(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation PUT /user/actions/secrets/{secretname} user updateUserSecret | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Create or Update a secret value in a user scope | 
					
						
							|  |  |  | 	// consumes: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// produces: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// parameters: | 
					
						
							|  |  |  | 	// - name: secretname | 
					
						
							|  |  |  | 	//   in: path | 
					
						
							|  |  |  | 	//   description: name of the secret | 
					
						
							|  |  |  | 	//   type: string | 
					
						
							|  |  |  | 	//   required: true | 
					
						
							|  |  |  | 	// - name: body | 
					
						
							|  |  |  | 	//   in: body | 
					
						
							|  |  |  | 	//   schema: | 
					
						
							|  |  |  | 	//     "$ref": "#/definitions/CreateOrUpdateSecretOption" | 
					
						
							|  |  |  | 	// responses: | 
					
						
							|  |  |  | 	//   "201": | 
					
						
							|  |  |  | 	//     description: response when creating a secret | 
					
						
							|  |  |  | 	//   "204": | 
					
						
							|  |  |  | 	//     description: response when updating a secret | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	opt := web.GetForm(ctx).(*api.CreateOrUpdateSecretOption) | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	_, created, err := secret_service.CreateOrUpdateSecret(ctx, ctx.Doer.ID, 0, ctx.Params("secretname"), opt.Data) | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 		if errors.Is(err, util.ErrInvalidArgument) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusBadRequest, "CreateOrUpdateSecret", err) | 
					
						
							|  |  |  | 		} else if errors.Is(err, util.ErrNotExist) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusNotFound, "CreateOrUpdateSecret", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "CreateOrUpdateSecret", err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if created { | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 		ctx.Status(http.StatusCreated) | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		ctx.Status(http.StatusNoContent) | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // DeleteSecret delete one secret of the user scope | 
					
						
							|  |  |  | func DeleteSecret(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation DELETE /user/actions/secrets/{secretname} user deleteUserSecret | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Delete a secret in a user scope | 
					
						
							|  |  |  | 	// consumes: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// produces: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// parameters: | 
					
						
							|  |  |  | 	// - name: secretname | 
					
						
							|  |  |  | 	//   in: path | 
					
						
							|  |  |  | 	//   description: name of the secret | 
					
						
							|  |  |  | 	//   type: string | 
					
						
							|  |  |  | 	//   required: true | 
					
						
							|  |  |  | 	// responses: | 
					
						
							|  |  |  | 	//   "204": | 
					
						
							|  |  |  | 	//     description: delete one secret of the user | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 	err := secret_service.DeleteSecretByName(ctx, ctx.Doer.ID, 0, ctx.Params("secretname")) | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2023-09-05 17:21:02 +02:00
										 |  |  | 		if errors.Is(err, util.ErrInvalidArgument) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusBadRequest, "DeleteSecret", err) | 
					
						
							|  |  |  | 		} else if errors.Is(err, util.ErrNotExist) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusNotFound, "DeleteSecret", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "DeleteSecret", err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2023-09-05 22:02:50 +08:00
										 |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ctx.Status(http.StatusNoContent) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // CreateVariable create a user-level variable | 
					
						
							|  |  |  | func CreateVariable(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation POST /user/actions/variables/{variablename} user createUserVariable | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Create a user-level variable | 
					
						
							|  |  |  | 	// consumes: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// produces: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// parameters: | 
					
						
							|  |  |  | 	// - name: variablename | 
					
						
							|  |  |  | 	//   in: path | 
					
						
							|  |  |  | 	//   description: name of the variable | 
					
						
							|  |  |  | 	//   type: string | 
					
						
							|  |  |  | 	//   required: true | 
					
						
							|  |  |  | 	// - name: body | 
					
						
							|  |  |  | 	//   in: body | 
					
						
							|  |  |  | 	//   schema: | 
					
						
							|  |  |  | 	//     "$ref": "#/definitions/CreateVariableOption" | 
					
						
							|  |  |  | 	// responses: | 
					
						
							|  |  |  | 	//   "201": | 
					
						
							|  |  |  | 	//     description: response when creating a variable | 
					
						
							|  |  |  | 	//   "204": | 
					
						
							|  |  |  | 	//     description: response when creating a variable | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	opt := web.GetForm(ctx).(*api.CreateVariableOption) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ownerID := ctx.Doer.ID | 
					
						
							|  |  |  | 	variableName := ctx.Params("variablename") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	v, err := actions_service.GetVariable(ctx, actions_model.FindVariablesOpts{ | 
					
						
							|  |  |  | 		OwnerID: ownerID, | 
					
						
							|  |  |  | 		Name:    variableName, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 	if err != nil && !errors.Is(err, util.ErrNotExist) { | 
					
						
							|  |  |  | 		ctx.Error(http.StatusInternalServerError, "GetVariable", err) | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if v != nil && v.ID > 0 { | 
					
						
							|  |  |  | 		ctx.Error(http.StatusConflict, "VariableNameAlreadyExists", util.NewAlreadyExistErrorf("variable name %s already exists", variableName)) | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if _, err := actions_service.CreateVariable(ctx, ownerID, 0, variableName, opt.Value); err != nil { | 
					
						
							|  |  |  | 		if errors.Is(err, util.ErrInvalidArgument) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusBadRequest, "CreateVariable", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "CreateVariable", err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ctx.Status(http.StatusNoContent) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // UpdateVariable update a user-level variable which is created by current doer | 
					
						
							|  |  |  | func UpdateVariable(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation PUT /user/actions/variables/{variablename} user updateUserVariable | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Update a user-level variable which is created by current doer | 
					
						
							|  |  |  | 	// consumes: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// produces: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// parameters: | 
					
						
							|  |  |  | 	// - name: variablename | 
					
						
							|  |  |  | 	//   in: path | 
					
						
							|  |  |  | 	//   description: name of the variable | 
					
						
							|  |  |  | 	//   type: string | 
					
						
							|  |  |  | 	//   required: true | 
					
						
							|  |  |  | 	// - name: body | 
					
						
							|  |  |  | 	//   in: body | 
					
						
							|  |  |  | 	//   schema: | 
					
						
							|  |  |  | 	//     "$ref": "#/definitions/UpdateVariableOption" | 
					
						
							|  |  |  | 	// responses: | 
					
						
							|  |  |  | 	//   "201": | 
					
						
							|  |  |  | 	//     description: response when updating a variable | 
					
						
							|  |  |  | 	//   "204": | 
					
						
							|  |  |  | 	//     description: response when updating a variable | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	opt := web.GetForm(ctx).(*api.UpdateVariableOption) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	v, err := actions_service.GetVariable(ctx, actions_model.FindVariablesOpts{ | 
					
						
							|  |  |  | 		OwnerID: ctx.Doer.ID, | 
					
						
							|  |  |  | 		Name:    ctx.Params("variablename"), | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		if errors.Is(err, util.ErrNotExist) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusNotFound, "GetVariable", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "GetVariable", err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if opt.Name == "" { | 
					
						
							|  |  |  | 		opt.Name = ctx.Params("variablename") | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2025-01-25 15:10:03 +01:00
										 |  |  | 	if _, err := actions_service.UpdateVariable(ctx, v.ID, ctx.Doer.ID, 0, opt.Name, opt.Value); err != nil { | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 		if errors.Is(err, util.ErrInvalidArgument) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusBadRequest, "UpdateVariable", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "UpdateVariable", err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ctx.Status(http.StatusNoContent) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // DeleteVariable delete a user-level variable which is created by current doer | 
					
						
							|  |  |  | func DeleteVariable(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation DELETE /user/actions/variables/{variablename} user deleteUserVariable | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Delete a user-level variable which is created by current doer | 
					
						
							|  |  |  | 	// produces: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// parameters: | 
					
						
							|  |  |  | 	// - name: variablename | 
					
						
							|  |  |  | 	//   in: path | 
					
						
							|  |  |  | 	//   description: name of the variable | 
					
						
							|  |  |  | 	//   type: string | 
					
						
							|  |  |  | 	//   required: true | 
					
						
							|  |  |  | 	// responses: | 
					
						
							|  |  |  | 	//   "201": | 
					
						
							|  |  |  | 	//     description: response when deleting a variable | 
					
						
							|  |  |  | 	//   "204": | 
					
						
							|  |  |  | 	//     description: response when deleting a variable | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if err := actions_service.DeleteVariableByName(ctx, ctx.Doer.ID, 0, ctx.Params("variablename")); err != nil { | 
					
						
							|  |  |  | 		if errors.Is(err, util.ErrInvalidArgument) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusBadRequest, "DeleteVariableByName", err) | 
					
						
							|  |  |  | 		} else if errors.Is(err, util.ErrNotExist) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusNotFound, "DeleteVariableByName", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "DeleteVariableByName", err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ctx.Status(http.StatusNoContent) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // GetVariable get a user-level variable which is created by current doer | 
					
						
							|  |  |  | func GetVariable(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation GET /user/actions/variables/{variablename} user getUserVariable | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Get a user-level variable which is created by current doer | 
					
						
							|  |  |  | 	// produces: | 
					
						
							|  |  |  | 	// - application/json | 
					
						
							|  |  |  | 	// parameters: | 
					
						
							|  |  |  | 	// - name: variablename | 
					
						
							|  |  |  | 	//   in: path | 
					
						
							|  |  |  | 	//   description: name of the variable | 
					
						
							|  |  |  | 	//   type: string | 
					
						
							|  |  |  | 	//   required: true | 
					
						
							|  |  |  | 	// responses: | 
					
						
							|  |  |  | 	//   "200": | 
					
						
							|  |  |  | 	//			"$ref": "#/responses/ActionVariable" | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	v, err := actions_service.GetVariable(ctx, actions_model.FindVariablesOpts{ | 
					
						
							|  |  |  | 		OwnerID: ctx.Doer.ID, | 
					
						
							|  |  |  | 		Name:    ctx.Params("variablename"), | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		if errors.Is(err, util.ErrNotExist) { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusNotFound, "GetVariable", err) | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ctx.Error(http.StatusInternalServerError, "GetVariable", err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	variable := &api.ActionVariable{ | 
					
						
							|  |  |  | 		OwnerID: v.OwnerID, | 
					
						
							|  |  |  | 		RepoID:  v.RepoID, | 
					
						
							|  |  |  | 		Name:    v.Name, | 
					
						
							|  |  |  | 		Data:    v.Data, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ctx.JSON(http.StatusOK, variable) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // ListVariables list user-level variables | 
					
						
							|  |  |  | func ListVariables(ctx *context.APIContext) { | 
					
						
							|  |  |  | 	// swagger:operation GET /user/actions/variables user getUserVariablesList | 
					
						
							|  |  |  | 	// --- | 
					
						
							|  |  |  | 	// summary: Get the user-level list of variables which is created by current doer | 
					
						
							|  |  |  | 	// 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/VariableList" | 
					
						
							|  |  |  | 	//   "400": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/error" | 
					
						
							| 
									
										
										
										
											2024-11-23 10:33:55 +01:00
										 |  |  | 	//   "401": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/unauthorized" | 
					
						
							|  |  |  | 	//   "403": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/forbidden" | 
					
						
							| 
									
										
										
										
											2024-03-29 04:40:35 +08:00
										 |  |  | 	//   "404": | 
					
						
							|  |  |  | 	//     "$ref": "#/responses/notFound" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	vars, count, err := db.FindAndCount[actions_model.ActionVariable](ctx, &actions_model.FindVariablesOpts{ | 
					
						
							|  |  |  | 		OwnerID:     ctx.Doer.ID, | 
					
						
							|  |  |  | 		ListOptions: utils.GetListOptions(ctx), | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		ctx.Error(http.StatusInternalServerError, "FindVariables", err) | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	variables := make([]*api.ActionVariable, len(vars)) | 
					
						
							|  |  |  | 	for i, v := range vars { | 
					
						
							|  |  |  | 		variables[i] = &api.ActionVariable{ | 
					
						
							|  |  |  | 			OwnerID: v.OwnerID, | 
					
						
							|  |  |  | 			RepoID:  v.RepoID, | 
					
						
							|  |  |  | 			Name:    v.Name, | 
					
						
							|  |  |  | 			Data:    v.Data, | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ctx.SetTotalCountHeader(count) | 
					
						
							|  |  |  | 	ctx.JSON(http.StatusOK, variables) | 
					
						
							|  |  |  | } |