Triggers
A Trigger
is resource that combines TriggerTemplate
, TriggerBindings
and interceptors
. The Trigger
is processed by EventListener which referenced it when it receives an incoming.
Syntax
To define a configuration file for an Trigger
resource, you can specify
the following fields:
- Required:
apiVersion
- Specifies the API version, for exampletriggers.tekton.dev/v1alpha1
.kind
- Specifies theTrigger
resource object.metadata
- Specifies data to uniquely identify theTrigger
resource object, for example aname
.spec
- Specifies the configuration information for your Trigger resource object. The spec include:- [
bindings
] - (Optional) A list of bindings to use. Can either be a reference to existingTriggerBinding
resources or embedded name/value pairs. - [
template
] - Either a reference to a TriggerTemplate object or an embedded TriggerTemplate spec. interceptors
- (Optional) list of interceptors to use- [
serviceAccountName
] - (Optional) Specifies the ServiceAccount provided to EventListener by Trigger to create resources
- [
apiVersion: triggers.tekton.dev/v1alpha1
kind: Trigger
metadata:
name: trigger
spec:
interceptors:
- cel:
filter: "header.match('X-GitHub-Event', 'pull_request')"
overlays:
- key: extensions.truncated_sha
expression: "body.pull_request.head.sha.truncate(7)"
bindings:
- ref: pipeline-binding
template:
ref: pipeline-template
template
The template
field inside a Trigger
can either point to an existing TriggerTemplate
object (using name
) or the template spec can be embedded inside the Trigger using the spec
field:
# Embedded Template Spec
triggers:
- name: "my-trigger"
template:
spec:
params:
- name: "my-param-name"
resourceTemplates:
- apiVersion: "tekton.dev/v1beta1"
kind: TaskRun
metadata:
generateName: "pr-run-"
spec:
taskSpec:
steps:
- image: ubuntu
script: echo "hello there"
Feedback
Was this page helpful?
Thanks! Tell us how we can further improve.
Sorry about that. Tell us how we can further improve.