pipelines

package
v0.0.0-...-d892afd Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 30, 2022 License: MIT Imports: 24 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Dependencies

type Dependencies struct {
	Scheduler       service.BelaurScheduler
	PipelineService pipeline.Servicer
	SettingsStore   store.SettingsStore
}

Dependencies define providers and services which this service needs.

type Hook

type Hook struct {
	Signature string
	Event     string
	ID        string
	Payload   []byte
}

Hook represent a github based webhook context.

type Payload

type Payload struct {
	Repo Repository `json:"repository"`
}

Payload contains information about the event like, user, commit id and so on. All we care about for the sake of identification is the repository.

type PipelineProvider

type PipelineProvider struct {
	// contains filtered or unexported fields
}

PipelineProvider is a provider for all pipeline related operations.

func NewPipelineProvider

func NewPipelineProvider(deps Dependencies) *PipelineProvider

NewPipelineProvider creates a new provider with the needed dependencies.

func (*PipelineProvider) CreatePipeline

func (pp *PipelineProvider) CreatePipeline(c echo.Context) error

CreatePipeline accepts all data needed to create a pipeline. It then starts the create pipeline execution process async. @Summary Create pipeline. @Description Starts creating a pipeline given all the data asynchronously. @Tags pipelines @Accept json @Produce plain @Security ApiKeyAuth @Param CreatePipelineRequest body belaur.CreatePipeline true "Create pipeline details" @Success 200 @Failure 400 {string} string "Failed to bind, validation error and invalid details" @Failure 500 {string} string "Internal error while saving create pipeline run" @Router /pipeline [post]

func (*PipelineProvider) CreatePipelineGetAll

func (pp *PipelineProvider) CreatePipelineGetAll(c echo.Context) error

CreatePipelineGetAll returns a json array of all pipelines which are about to get compiled and all pipelines which have been compiled. @Summary Get all create pipelines. @Description Get a list of all pipelines which are about to be compiled and which have been compiled. @Tags pipelines @Produce json @Security ApiKeyAuth @Success 200 {array} belaur.CreatePipeline @Failure 500 {string} string "Internal error while retrieving create pipeline data." @Router /pipeline/created [get]

func (*PipelineProvider) GetJobLogs

func (pp *PipelineProvider) GetJobLogs(c echo.Context) error

GetJobLogs returns logs from a pipeline run.

Required parameters: pipelineid - Related pipeline id pipelinerunid - Related pipeline run id @Summary Get logs for pipeline run. @Description Returns logs from a pipeline run. @Tags pipelinerun @Accept plain @Produce json @Security ApiKeyAuth @Param pipelineid query string true "ID of the pipeline" @Param runid query string true "ID of the run" @Success 200 {object} jobLogs "logs" @Failure 400 {string} string "Invalid pipeline id or run id or pipeline not found" @Failure 500 {string} string "cannot read pipeline run log file" @Router /pipelinerun/{pipelineid}/{runid}/log [get]

func (*PipelineProvider) GitWebHook

func (pp *PipelineProvider) GitWebHook(c echo.Context) error

GitWebHook handles callbacks from GitHub's webhook system. @Summary Handle github webhook callbacks. @Description This is the global endpoint which will handle all github webhook callbacks. @Tags pipelines @Accept json @Produce plain @Param payload body Payload true "A github webhook payload" @Success 200 {string} string "successfully processed event" @Failure 400 {string} string "Bind error and schedule errors" @Failure 500 {string} string "Various internal errors running and triggering and rebuilding pipelines. Please check the logs for more information." @Router /pipeline/githook [post]

func (*PipelineProvider) PipelineCheckPeriodicSchedules

func (pp *PipelineProvider) PipelineCheckPeriodicSchedules(c echo.Context) error

PipelineCheckPeriodicSchedules validates the added periodic schedules. @Summary Returns the latest run. @Description Returns the latest of all registered pipelines included with the latest run. @Tags pipelines @Accept json @Produce json @Security ApiKeyAuth @Param schedules body []string true "A list of valid cronjob specs" @Success 200 @Failure 400 {string} string "Bind error and schedule errors" @Router /pipeline/periodicschedules [post]

func (*PipelineProvider) PipelineDelete

func (pp *PipelineProvider) PipelineDelete(c echo.Context) error

PipelineDelete accepts a pipeline id and deletes it from the store. It also removes the binary inside the pipeline folder. @Summary Delete a pipeline. @Description Accepts a pipeline id and deletes it from the store. It also removes the binary inside the pipeline folder. @Tags pipelines @Accept plain @Produce plain @Security ApiKeyAuth @Param pipelineid query string true "The ID of the pipeline." @Success 200 {string} string "Pipeline has been deleted" @Failure 400 {string} string "Error while deleting the pipeline" @Failure 404 {string} string "The pipeline with the given ID was not found" @Failure 500 {string} string "Internal error while deleting and removing the pipeline from store and disk" @Router /pipeline/{pipelineid} [delete]

func (*PipelineProvider) PipelineGet

func (pp *PipelineProvider) PipelineGet(c echo.Context) error

PipelineGet accepts a pipeline id and returns the pipeline object. @Summary Get pipeline information. @Description Get pipeline information based on ID. @Tags pipelines @Accept plain @Produce json @Security ApiKeyAuth @Param pipelineid query string true "The ID of the pipeline" @Success 200 {object} belaur.Pipeline @Failure 400 {string} string "The given pipeline id is not valid" @Failure 404 {string} string "Pipeline not found with the given id" @Router /pipeline/{pipelineid} [get]

func (*PipelineProvider) PipelineGetAll

func (pp *PipelineProvider) PipelineGetAll(c echo.Context) error

PipelineGetAll returns all registered pipelines. @Summary Returns all registered pipelines. @Description Returns all registered pipelines. @Tags pipelines @Produce json @Security ApiKeyAuth @Success 200 {array} belaur.Pipeline @Router /pipeline/name [get]

func (*PipelineProvider) PipelineGetAllRuns

func (pp *PipelineProvider) PipelineGetAllRuns(c echo.Context) error

PipelineGetAllRuns returns all runs about the given pipeline. @Summary Get all pipeline runs. @Description Returns all runs about the given pipeline. @Tags pipelinerun @Accept plain @Produce json @Security ApiKeyAuth @Param pipelineid query string true "ID of the pipeline" @Success 200 {array} belaur.PipelineRun "a list of pipeline runes" @Failure 400 {string} string "Invalid pipeline id" @Failure 500 {string} string "Error retrieving all pipeline runs." @Router /pipelinerun/{pipelineid} [get]

func (*PipelineProvider) PipelineGetAllWithLatestRun

func (pp *PipelineProvider) PipelineGetAllWithLatestRun(c echo.Context) error

PipelineGetAllWithLatestRun returns the latest of all registered pipelines included with the latest run. @Summary Returns the latest run. @Description Returns the latest of all registered pipelines included with the latest run. @Tags pipelines @Produce json @Security ApiKeyAuth @Success 200 {object} getAllWithLatestRun @Failure 500 {string} string "Internal error while getting latest run" @Router /pipeline/latest [get]

func (*PipelineProvider) PipelineGetLatestRun

func (pp *PipelineProvider) PipelineGetLatestRun(c echo.Context) error

PipelineGetLatestRun returns the latest run of a pipeline, given by id. @Summary Get latest pipeline runs. @Description Returns the latest run of a pipeline, given by id. @Tags pipelinerun @Accept plain @Produce json @Security ApiKeyAuth @Param pipelineid query string true "ID of the pipeline" @Success 200 {object} belaur.PipelineRun "the latest pipeline run" @Failure 400 {string} string "Invalid pipeline id" @Failure 500 {string} string "error getting latest run or cannot read pipeline run log file" @Router /pipelinerun/{pipelineid}/latest [get]

func (*PipelineProvider) PipelineGitLSRemote

func (pp *PipelineProvider) PipelineGitLSRemote(c echo.Context) error

PipelineGitLSRemote checks for available git remote branches. This is the perfect way to check if we have access to a given repo. @Summary Check for repository access. @Description Checks for available git remote branches which in turn verifies repository access. @Tags pipelines @Accept json @Produce json @Security ApiKeyAuth @Param PipelineGitLSRemoteRequest body belaur.GitRepo true "The repository details" @Success 200 {array} string "Available branches" @Failure 400 {string} string "Failed to bind body" @Failure 403 {string} string "No access" @Router /pipeline/gitlsremote [post]

func (*PipelineProvider) PipelineNameAvailable

func (pp *PipelineProvider) PipelineNameAvailable(c echo.Context) error

PipelineNameAvailable looks up if the given pipeline name is available and valid. @Summary Pipeline name validation. @Description Looks up if the given pipeline name is available and valid. @Tags pipelines @Accept plain @Produce json @Security ApiKeyAuth @Param name query string true "The name of the pipeline to validate" @Success 200 @Failure 400 {string} string "Pipeline name validation errors" @Router /pipeline/name [get]

func (*PipelineProvider) PipelinePull

func (pp *PipelineProvider) PipelinePull(c echo.Context) error

PipelinePull does a pull on the remote repository which contains the code for this pipeline. This is so the user won't have to wait for polling or a hook. @Summary Update the underlying repository of the pipeline. @Description Pull new code using the repository of the pipeline. @Tags pipelines @Accept plain @Produce plain @Security ApiKeyAuth @Param pipelineid query string true "The ID of the pipeline." @Success 200 @Failure 400 {string} string @Router /pipeline/{pipelineid}/pull [post]

func (*PipelineProvider) PipelineResetToken

func (pp *PipelineProvider) PipelineResetToken(c echo.Context) error

PipelineResetToken generates a new remote trigger token for a given pipeline. @Summary Reset trigger token. @Description Generates a new remote trigger token for a given pipeline. @Tags pipelines @Accept plain @Produce plain @Security ApiKeyAuth @Param pipelineid query string true "The ID of the pipeline." @Success 200 {string} string "Trigger successful for pipeline: {pipelinename}" @Failure 400 {string} string "Invalid pipeline id" @Failure 404 {string} string "Pipeline not found" @Failure 500 {string} string "Internal storage error" @Router /pipeline/{pipelineid}/reset-trigger-token [put]

func (*PipelineProvider) PipelineRunGet

func (pp *PipelineProvider) PipelineRunGet(c echo.Context) error

PipelineRunGet returns details about a specific pipeline run. Required parameters are pipelineid and runid. @Summary Get Pipeline run. @Description Returns details about a specific pipeline run. @Tags pipelinerun @Accept plain @Produce json @Security ApiKeyAuth @Param pipelineid query string true "ID of the pipeline" @Param runid query string true "ID of the pipeline run" @Success 200 {object} belaur.PipelineRun @Failure 400 {string} string "Invalid pipeline or pipeline not found." @Failure 404 {string} string "Pipeline Run not found." @Failure 500 {string} string "Something went wrong while getting pipeline run." @Router /pipelinerun/{pipelineid}/{runid} [get]

func (*PipelineProvider) PipelineStart

func (pp *PipelineProvider) PipelineStart(c echo.Context) error

PipelineStart starts a pipeline by the given id. It accepts arguments for the given pipeline. Afterwards it returns the created/scheduled pipeline run. @Summary Start a pipeline. @Description Starts a pipeline with a given ID and arguments for that pipeline and returns created/scheduled status. @Tags pipelines @Accept json @Produce json @Security ApiKeyAuth @Param pipelineid query string true "The ID of the pipeline." @Param args body belaur.Argument false "Optional arguments of the pipeline." @Success 200 {object} belaur.PipelineRun @Failure 400 {string} string "Various failures regarding starting the pipeline like: invalid id, invalid docker value and schedule errors" @Failure 404 {string} string "Pipeline not found" @Router /pipeline/{pipelineid}/start [post]

func (*PipelineProvider) PipelineStop

func (pp *PipelineProvider) PipelineStop(c echo.Context) error

PipelineStop stops a running pipeline. @Summary Stop a pipeline run. @Description Stops a pipeline run. @Tags pipelinerun @Accept plain @Produce plain @Security ApiKeyAuth @Param pipelineid query string true "ID of the pipeline" @Param runid query string true "ID of the pipeline run" @Success 200 {string} string "pipeline successfully stopped" @Failure 400 {string} string "Invalid pipeline id or run id" @Failure 404 {string} string "Pipeline Run not found." @Router /pipelinerun/{pipelineid}/{runid}/stop [post]

func (*PipelineProvider) PipelineTrigger

func (pp *PipelineProvider) PipelineTrigger(c echo.Context) error

PipelineTrigger allows for a remote running of a pipeline. This endpoint does not require authentication. It will use a TOKEN that is specific to a pipeline. It can only be used by the `auto` user. @Summary Trigger a pipeline. @Description Using a trigger token, start a pipeline run. This endpoint does not require authentication. @Tags pipelines @Accept plain @Produce plain @Param pipelineid query string true "The ID of the pipeline." @Param pipelinetoken query string true "The trigger token for this pipeline." @Success 200 {string} string "Trigger successful for pipeline: {pipelinename}" @Failure 400 {string} string "Error while triggering pipeline" @Failure 403 {string} string "Invalid trigger token" @Router /pipeline/{pipelineid}/{pipelinetoken}/trigger [post]

func (*PipelineProvider) PipelineTriggerAuth

func (pp *PipelineProvider) PipelineTriggerAuth(c echo.Context) error

PipelineTriggerAuth is a barrier before remote trigger which checks if the user is `auto`.

func (*PipelineProvider) PipelineUpdate

func (pp *PipelineProvider) PipelineUpdate(c echo.Context) error

PipelineUpdate updates the given pipeline. @Summary Update pipeline. @Description Update a pipeline by its ID. @Tags pipelines @Accept json @Produce json @Security ApiKeyAuth @Param PipelineUpdateRequest body belaur.Pipeline true "PipelineUpdate request" @Success 200 {string} string "Pipeline has been updated" @Failure 400 {string} string "Error while updating the pipeline" @Failure 404 {string} string "The pipeline with the given ID was not found" @Failure 500 {string} string "Internal error while updating and building the new pipeline information" @Router /pipeline/{pipelineid} [put]

func (*PipelineProvider) SettingsPollGet

func (pp *PipelineProvider) SettingsPollGet(c echo.Context) error

SettingsPollGet get status of polling functionality. @Summary Get the status of the poll setting. @Description Gets the status of the poll setting. @Tags settings @Produce json @Security ApiKeyAuth @Success 200 {object} pollStatus "Poll status" @Failure 500 {string} string "Internal server error while getting setting." @Router /settings/poll [get]

func (*PipelineProvider) SettingsPollOff

func (pp *PipelineProvider) SettingsPollOff(c echo.Context) error

SettingsPollOff turn off polling functionality. @Summary Turn off polling functionality. @Description Turns off the polling functionality for Bhojpur Belaur which periodically checks if there is new code to deploy for all pipelines. @Tags settings @Produce plain @Security ApiKeyAuth @Success 200 {string} string "Polling is turned off." @Failure 400 {string} string "Error while toggling poll setting." @Failure 500 {string} string "Internal server error while getting setting." @Router /settings/poll/off [post]

func (*PipelineProvider) SettingsPollOn

func (pp *PipelineProvider) SettingsPollOn(c echo.Context) error

SettingsPollOn turn on polling functionality @Summary Turn on polling functionality. @Description Turns on the polling functionality for Bhojpur Belaur which periodically checks if there is new code to deploy for all pipelines. @Tags settings @Produce plain @Security ApiKeyAuth @Success 200 {string} string "Polling is turned on." @Failure 400 {string} string "Error while toggling poll setting." @Failure 500 {string} string "Internal server error while getting setting." @Router /settings/poll/on [post]

type PipelineProviderer

type PipelineProviderer interface {
	PipelineGitLSRemote(c echo.Context) error
	CreatePipeline(c echo.Context) error
	CreatePipelineGetAll(c echo.Context) error
	PipelineNameAvailable(c echo.Context) error
	PipelineGet(c echo.Context) error
	PipelineGetAll(c echo.Context) error
	PipelineUpdate(c echo.Context) error
	PipelinePull(c echo.Context) error
	PipelineDelete(c echo.Context) error
	PipelineTrigger(c echo.Context) error
	PipelineResetToken(c echo.Context) error
	PipelineTriggerAuth(c echo.Context) error
	PipelineStart(c echo.Context) error
	PipelineGetAllWithLatestRun(c echo.Context) error
	PipelineCheckPeriodicSchedules(c echo.Context) error
	PipelineStop(c echo.Context) error
	PipelineRunGet(c echo.Context) error
	PipelineGetAllRuns(c echo.Context) error
	PipelineGetLatestRun(c echo.Context) error
	GetJobLogs(c echo.Context) error
	GitWebHook(c echo.Context) error
	SettingsPollOn(c echo.Context) error
	SettingsPollOff(c echo.Context) error
	SettingsPollGet(c echo.Context) error
}

PipelineProviderer defines functionality which this provider provides. These are used by the handler service.

type Repository

type Repository struct {
	GitURL  string `json:"git_url"`
	SSHURL  string `json:"ssh_url"`
	HTMLURL string `json:"html_url"`
}

Repository contains information about the repository. All we care about here are the possible urls for identification.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL