A TriggerTemplate is a resource that can template resources.
TriggerTemplates have parameters that can be substituted anywhere
within the resource template.
apiVersion: tekton.dev/v1alpha1
kind: TriggerTemplate
metadata:
name: pipeline-template
spec:
params:
- name: gitrevision
description: The git revision
default: master
- name: gitrepositoryurl
description: The git repository url
- name: message
description: The message to print
default: This is the default message
- name: contenttype
description: The Content-Type of the event
resourcetemplates:
- apiVersion: tekton.dev/v1alpha1
kind: PipelineResource
metadata:
name: git-source-$(uid)
spec:
type: git
params:
- name: revision
value: $(params.gitrevision)
- name: url
value: $(params.gitrepositoryurl)
- apiVersion: tekton.dev/v1alpha1
kind: PipelineRun
metadata:
generateName: simple-pipeline-run
spec:
pipelineRef:
name: simple-pipeline
params:
- name: message
value: $(params.message)
- name: contenttype
value: $(params.contenttype)
resources:
- name: git-source
resourceRef:
name: git-source-$(uid)Similar to Pipelines,TriggerTemplates do not do any actual work, but instead act as the blueprint for what resources should be created.
If the namespace is omitted, it will be resolved to the EventListener's namespace.
The $(uid) variable is implicitly available throughout a TriggerTemplate's resource templates.
A random string value is assigned to $(uid) like the postfix generated by the Kubernetes generateName metadata field.
One instance where there is useful is when resources in a TriggerTemplate have internal references.
The following are additional labels added to all TriggerTemplate resource templates:
- To help with housekeeping/garbage collection:
tekton.dev/eventlistener:<EventListenerName> - To track resources created by the same event:
tekton.dev/triggers-eventid:<EventID>
To enable support for arbitrary resource types, the resource templates are internally resolved as byte blobs.
As a result, validation on these resources is only done at event processing time (rather than during TriggerTemplate creation).
As on now, only Tekton resources can be defined within a TriggerTemplate.
TriggerTemplates can declare parameters that are supplied by a
TriggerBinding and/or EventListener. params must have a name, and can have an optional
description and default value.
params can be referenced in the TriggerTemplate using the following
variable substitution syntax, where <name> is the name of the parameter:
$(params.<name>)params can be referenced in the resourceTemplates section of a
TriggerTemplate. The purpose of params is to make TriggerTemplates
reusable.