mirror of
				https://github.com/woodpecker-ci/woodpecker.git
				synced 2025-10-24 23:34:50 +00:00 
			
		
		
		
	This is just a first step, the final goal is to have an API endpoint to prune Repo Pipelines older than the given date. @woodpecker-ci/maintainers Can I get some feedback if this is the right direction? --------- Co-authored-by: 6543 <m.huber@kithara.com>
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2022 Woodpecker Authors
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //      http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package api
 | |
| 
 | |
| import (
 | |
| 	"errors"
 | |
| 	"net/http"
 | |
| 
 | |
| 	"github.com/gin-gonic/gin"
 | |
| 	"github.com/rs/zerolog/log"
 | |
| 
 | |
| 	"go.woodpecker-ci.org/woodpecker/v2/server"
 | |
| 	"go.woodpecker-ci.org/woodpecker/v2/server/forge"
 | |
| 	"go.woodpecker-ci.org/woodpecker/v2/server/model"
 | |
| 	"go.woodpecker-ci.org/woodpecker/v2/server/pipeline"
 | |
| 	"go.woodpecker-ci.org/woodpecker/v2/server/store"
 | |
| 	"go.woodpecker-ci.org/woodpecker/v2/server/store/types"
 | |
| )
 | |
| 
 | |
| func handlePipelineErr(c *gin.Context, err error) {
 | |
| 	switch {
 | |
| 	case errors.Is(err, &pipeline.ErrNotFound{}):
 | |
| 		c.String(http.StatusNotFound, "%s", err)
 | |
| 	case errors.Is(err, &pipeline.ErrBadRequest{}):
 | |
| 		c.String(http.StatusBadRequest, "%s", err)
 | |
| 	case errors.Is(err, pipeline.ErrFiltered):
 | |
| 		// for debugging purpose we add a header
 | |
| 		c.Writer.Header().Add("Pipeline-Filtered", "true")
 | |
| 		c.Status(http.StatusNoContent)
 | |
| 	default:
 | |
| 		_ = c.AbortWithError(http.StatusInternalServerError, err)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func handleDBError(c *gin.Context, err error) {
 | |
| 	if errors.Is(err, types.RecordNotExist) {
 | |
| 		c.AbortWithStatus(http.StatusNotFound)
 | |
| 		return
 | |
| 	}
 | |
| 	_ = c.AbortWithError(http.StatusInternalServerError, err)
 | |
| }
 | |
| 
 | |
| // If the forge has a refresh token, the current access token may be stale.
 | |
| // Therefore, we should refresh prior to dispatching the job.
 | |
| func refreshUserToken(c *gin.Context, user *model.User) {
 | |
| 	_store := store.FromContext(c)
 | |
| 	_forge, err := server.Config.Services.Manager.ForgeFromUser(user)
 | |
| 	if err != nil {
 | |
| 		log.Error().Err(err).Msg("Cannot get forge from user")
 | |
| 		c.AbortWithStatus(http.StatusInternalServerError)
 | |
| 		return
 | |
| 	}
 | |
| 	forge.Refresh(c, _forge, _store, user)
 | |
| }
 | |
| 
 | |
| // pipelineDeleteAllowed checks if the given pipeline can be deleted based on its status.
 | |
| // It returns a bool indicating if delete is allowed, and the pipeline's status.
 | |
| func pipelineDeleteAllowed(pl *model.Pipeline) bool {
 | |
| 	switch pl.Status {
 | |
| 	case model.StatusRunning, model.StatusPending, model.StatusBlocked:
 | |
| 		return false
 | |
| 	}
 | |
| 
 | |
| 	return true
 | |
| }
 |