Logo
  • About Zuul
    • Zuul Concepts
    • Project Gating
      • Testing in parallel
        • Pipeline Window
      • Cross Project Testing
      • Cross-Project Dependencies
        • Dependent Pipeline
        • Independent Pipeline
        • Multiple Changes
        • Cycles
        • Global Repo State
  • Quick-Start Installation and Tutorial
    • Start Zuul Containers
    • Add Your Gerrit Account
    • Configure Zuul Pipelines
    • Test Zuul Pipelines
    • Configure a Base Job
    • Further Steps
  • Project Configuration
    • Security Contexts
    • Configuration Loading
    • Regular Expressions
    • Encryption
    • Configuration Items
      • Pipeline
      • Job
      • Project
      • Project Template
      • Queue
      • Secret
        • Data Secrets
        • Token Secrets
        • Usage
      • Nodeset
      • Semaphore
      • Pragma
  • Job Content
    • Working Directory
    • Git Repositories
    • Variables
      • Site-wide Variables
      • Job Extra Variables
      • Secrets
      • Job Variables
      • Project Variables
      • File Variables
      • Parent Job Results
    • Zuul Variables
      • Job Ref
      • Item
      • Job
      • Working Directory
    • SSH Keys
      • Nodepool Key
      • Project Key
    • Return Values
      • Returning the log url
      • Returning artifact URLs
      • Skipping dependent jobs
      • Leaving warnings
      • Leaving file comments
      • Pausing the job
      • Skipping retries
    • Ansible Groups
    • Build Status
  • Service Administration
    • Installation
      • External Dependencies
        • Nodepool
        • ZooKeeper
      • Executor Deployment
      • Web Deployment
        • Reverse Proxy
        • Static Offload
        • Sub directory serving
        • White Labeled Tenant
        • Static External
    • Upgrading
      • Rolling Upgrades
      • Skipping Versions
    • Component Overview
    • Configuration
      • Common Options
        • Statsd
        • Tracing
        • ZooKeeper
        • Database
        • OIDC
      • Scheduler
      • Merger
      • Executor
        • Trusted and Untrusted Playbooks
        • Security Considerations
        • Configuration
      • Web Server
        • Authentication
          • Driver-specific attributes
            • HS256
            • RS256
            • RS256withJWKS
            • OpenIDConnect
      • Client
      • Finger Gateway
    • Connections
    • Drivers
      • Gerrit
        • Connection Configuration
          • SSH Configuration
          • HTTP Configuration
          • Kafka Event Support
          • AWS Kinesis Event Support
          • Google Cloud Pub/Sub Event Support
        • Trigger Configuration
        • Reporter Configuration
        • Requirements Configuration
        • Reference Pipelines Configuration
        • Checks Plugin Support (Deprecated)
      • GitHub
        • Configure GitHub
          • Web-Hook
          • Application
        • Connection Configuration
        • Trigger Configuration
        • Reporter Configuration
        • Requirements Configuration
        • Reference pipelines configuration
          • Branch protection rules
          • Reference pipelines
        • Github Checks API
          • Design decisions
          • Behaviour in Zuul
            • Reporting
            • Trigger
            • Requirements
          • Actions / Events
          • File comments (annotations)
            • Custom actions
          • Restrictions and Recommendations
      • Pagure
        • Configure Pagure
        • Connection Configuration
        • Trigger Configuration
        • Reporter Configuration
        • Requirements Configuration
        • Reference pipelines configuration
      • GitLab
        • Configure GitLab
          • web-hooks
          • API
        • Connection Configuration
        • Trigger Configuration
        • Reporter Configuration
        • Requirements Configuration
        • Reference pipelines configuration
      • Git
        • Connection Configuration
        • Trigger Configuration
      • MQTT
        • Message Schema
        • Connection Configuration
        • Reporter Configuration
      • Elasticsearch
        • Connection Configuration
        • Reporter Configuration
      • SMTP
        • Connection Configuration
        • Reporter Configuration
      • Timer
        • Trigger Configuration
      • Zuul
        • Trigger Configuration
    • Tenant Configuration
      • Tenant
      • Global Semaphore
      • Authorization Rule
      • Authorization Rule Templating
      • API Root
    • Operation
      • Scheduler
        • Operation
        • Reconfiguration
        • Advanced Options
        • Managing Event Processing
        • Backup and Restoration
      • Merger
        • Operation
      • Executor
        • Operation
        • Ansible and Python 3
        • Log Streaming
          • Posix Log Streaming
          • Windows Log Streaming
      • Web Server
        • Operation
      • Finger Gateway
        • Operation
    • Authenticated Access
      • Important Security Considerations
      • Configuration
      • JWT Format
      • Manually Generating a JWT
      • Debugging
      • Interfacing with Other Systems
        • Configuring Google Authentication
          • Prerequisites
          • Setting up credentials with Google
            • Create OAuth client ID
            • Configure Zuul
          • Further Reading
        • Configuring Keycloak Authentication
          • Prerequisites
          • Setting up Keycloak
            • Create a client
            • Create a client scope
            • (Optional) Set up a social identity provider
          • Setting up Zuul
          • Further Reading
        • Configuring Microsoft Authentication
          • Prerequisites
          • Creating the App Registration
            • Optional: Include Groups Claim
          • Setting up Zuul
        • Keycloak Tutorial
          • Update /etc/hosts
          • Restart Zuul Containers
          • Start Keycloak
          • Log Into Zuul
    • Monitoring
      • Statsd reporting
        • Configuration
        • Metrics
      • Prometheus monitoring
        • Configuration
        • Metrics
        • Liveness Probes
    • Tracing
      • Configuration
      • Tutorial
        • Jaeger Tracing Tutorial
          • Restart Zuul Containers
          • Start Jaeger
          • Recheck a change
    • Zuul Admin Client
      • Configuration
      • Usage
        • tenant-conf-check
        • create-auth-token
        • export-keys
        • import-keys
        • copy-keys
        • delete-keys
        • delete-oidc-signing-keys
        • delete-state
        • delete-pipeline-state
        • prune-database
      • Deprecated commands
        • Autohold
        • Autohold Delete
        • Autohold Info
        • Autohold List
        • Dequeue
        • Enqueue
        • Enqueue-ref
          • Manual enqueue examples
        • Promote
    • Troubleshooting
      • Thread Dumps and Profiling
  • REST API
  • How-To Guides
    • Project Testing Interface
      • Projects layout
        • org-config
        • org-jobs
      • Projects content
      • Usage
        • Project tests
        • Updating PTI test
      • Cross project gating
    • Badges
    • Chatting with Matrix
      • Why Use Matrix?
      • Create An Account
      • Join the #zuul Room
      • Optional Next Steps
        • Optional: Save Encryption Keys
        • Optional: Register with an Identity Provider
        • Optional: Join an IRC Room
    • ZooKeeper Administration
      • Configuration
      • Encrypted Connections
  • Developer’s Guide
    • Scheduler
    • Data Model
      • Pipeline
      • PipelineManager
      • DependentPipelineManager
      • IndependentPipelineManager
      • ChangeQueue
      • Job
      • JobGraph
      • Build
      • QueueItem
      • BuildSet
      • Changes
        • Change
        • Ref
      • Filters
        • RefFilter
        • EventFilter
      • Tenants
        • Tenant
        • UnparsedAbideConfig
        • UnparsedConfig
        • ParsedConfig
      • Other Global Objects
        • Project
        • Layout
        • RepoFiles
        • TriggerEvent
    • Drivers
      • Driver
        • Driver.reconfigure()
        • Driver.registerScheduler()
        • Driver.stop()
      • ConnectionInterface
        • ConnectionInterface.getConnection()
      • SourceInterface
        • SourceInterface.getRejectSchema()
        • SourceInterface.getRequireSchema()
        • SourceInterface.getSource()
      • TriggerInterface
        • TriggerInterface.getTrigger()
        • TriggerInterface.getTriggerEventClass()
        • TriggerInterface.getTriggerSchema()
      • ReporterInterface
        • ReporterInterface.getReporter()
        • ReporterInterface.getReporterSchema()
    • Triggers
      • BaseTrigger
        • BaseTrigger.getEventFilters()
        • BaseTrigger.onChangeEnqueued()
        • BaseTrigger.onChangeMerged()
        • BaseTrigger.postConfig()
      • GerritTrigger
        • GerritTrigger.getEventFilters()
      • TimerTrigger
        • TimerTrigger.getEventFilters()
      • ZuulTrigger
        • ZuulTrigger.getEventFilters()
    • Testing
      • simple_layout()
      • ZuulTestCase
        • ZuulTestCase.addEvent()
        • ZuulTestCase.assertBuilds()
        • ZuulTestCase.assertHistory()
        • ZuulTestCase.assertReportedStat()
        • ZuulTestCase.commitConfigUpdate()
        • ZuulTestCase.getSortedBuilds()
        • ZuulTestCase.getUpstreamRepos()
        • ZuulTestCase.logState()
        • ZuulTestCase.newTenantConfig()
        • ZuulTestCase.printHistory()
        • ZuulTestCase.setUp()
        • ZuulTestCase.waitUntilNodeCacheSync()
      • FakeGerritConnection
        • FakeGerritConnection.addFakeChange()
        • FakeGerritConnection.checkBranchCache()
        • FakeGerritConnection.cleanupCache()
        • FakeGerritConnection.clearBranchCache()
        • FakeGerritConnection.clearConnectionCacheOnBranchEvent()
        • FakeGerritConnection.getEventQueue()
        • FakeGerritConnection.getProjectBranches()
        • FakeGerritConnection.getProjectDefaultBranch()
        • FakeGerritConnection.getProjectMergeModes()
        • FakeGerritConnection.getWebController()
        • FakeGerritConnection.isBranchProtected()
        • FakeGerritConnection.maintainCache()
        • FakeGerritConnection.toDict()
        • FakeGerritConnection.updateProjectBranches()
        • FakeGerritConnection.validateWebConfig()
      • RecordingExecutorServer
        • RecordingExecutorServer.failJob()
        • RecordingExecutorServer.release()
        • RecordingExecutorServer.retryJob()
        • RecordingExecutorServer.returnData()
      • FakeBuild
        • FakeBuild.getWorkspaceRepos()
        • FakeBuild.hasChanges()
        • FakeBuild.isWaiting()
        • FakeBuild.release()
      • BuildHistory
    • Metrics
      • Event Overview
    • Documentation
      • ReStructuredText Conventions
        • Code Blocks
        • Literal Values
        • Terminology
      • Zuul Sphinx Directives
        • zuul:attr::
        • zuul:value::
        • zuul:var::
      • Zuul Sphinx Roles
        • :zuul:attr:
        • :zuul:value:
        • :zuul:var:
    • Ansible Integration
      • Streaming job output
        • CallbackModule
        • LogStreamer
        • LogStreamHandler
        • ZuulWeb
        • CallbackModule
      • Capturing live command output
    • Zuul Dashboard Javascript
      • For the impatient who don’t want deal with javascript toolchains
      • yarn dependency management
      • Dealing with yarn.lock merge conflicts
      • React Components and Styling
      • Development
        • Authentication
      • Deploying
    • Specifications
      • Nodepool in Zuul
        • Introduction
        • Image Management
          • Snapshot Images
        • Node Management
          • Quota Handling & Rate Limiting
        • Configuration
        • Upgrade Process
        • Library Requirements
        • Diskimage-Builder Testing
        • Work Items
    • ZooKeeper
      • Overview
      • Driver Event Ingestion
        • Active Event Gathering
        • Passive Event Gathering
      • Configuration Storage
      • Executor and Merger Queues
      • Zookeeper Map
    • Data Model Changelog
      • Version 0
      • Version 1
      • Version 2
      • Version 3
      • Version 4
      • Version 5
      • Version 6
      • Version 7
      • Version 8
      • Version 9
      • Version 10
      • Version 11
      • Version 12
      • Version 13
      • Version 14
      • Version 15
      • Version 16
      • Version 17
      • Version 18
      • Version 19
      • Version 20
      • Version 21
      • Version 22
      • Version 23
      • Version 24
      • Version 25
      • Version 26
      • Version 27
      • Version 28
      • Version 29
      • Version 30
      • Version 31
      • Version 32
      • Version 33
      • Version 34
      • Version 35
    • Release Notes
      • Installing reno
      • Adding a new release note
  • Zuul Project Governance
    • Zuul Maintainers
    • Zuul Project Lead
    • Zuul-Jobs Maintainers
  • Vulnerability Reporting
    • Create a Private Story in StoryBoard
    • Report via Encrypted E-mail
  • Release Notes
    • 13.0.0+acme3
      • Security Issues
      • Bug Fixes
    • 13.0.0+acme1
      • New Features
    • 13.0.0
      • New Features
      • Upgrade Notes
    • 12.1.0
      • New Features
    • 12.0.0
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 11.3.0
      • New Features
      • Upgrade Notes
    • 11.2.0
      • New Features
      • Upgrade Notes
    • 11.1.0
      • New Features
      • Deprecation Notes
      • Bug Fixes
    • 11.0.1
      • Bug Fixes
    • 11.0.0
      • Upgrade Notes
      • Deprecation Notes
      • Security Issues
    • 10.2.0
      • New Features
      • Deprecation Notes
      • Bug Fixes
      • Other Notes
    • 10.1.0
      • New Features
      • Deprecation Notes
      • Bug Fixes
    • 10.0.0
      • Prelude
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 9.5.0
      • Upgrade Notes
    • 9.4.0
      • New Features
      • Bug Fixes
    • 9.3.0
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 9.2.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 9.1.0
      • New Features
      • Deprecation Notes
      • Bug Fixes
    • 9.0.0
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 8.3.1
      • Security Issues
    • 8.3.0
      • New Features
      • Deprecation Notes
      • Bug Fixes
    • 8.2.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 8.1.0
      • New Features
      • Upgrade Notes
      • Security Issues
    • 8.0.1
      • Bug Fixes
    • 8.0.0
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 7.1.0
      • New Features
      • Upgrade Notes
    • 7.0.0
      • New Features
      • Upgrade Notes
    • 6.4.0
      • New Features
      • Upgrade Notes
    • 6.3.0
      • New Features
    • 6.2.0
      • New Features
      • Bug Fixes
    • 6.1.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 6.0.0
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 5.2.5
      • Bug Fixes
    • 5.2.4
      • Bug Fixes
    • 5.2.3
      • Bug Fixes
    • 5.2.2
      • Bug Fixes
    • 5.2.1
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 5.2.0
      • New Features
      • Upgrade Notes
      • Security Issues
    • 5.1.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
      • Bug Fixes
    • 5.0.0
      • Upgrade Notes
    • 4.12.0
      • Upgrade Notes
    • 4.11.0
      • New Features
      • Upgrade Notes
    • 4.10.4
      • Bug Fixes
    • 4.10.3
      • Bug Fixes
    • 4.10.2
      • Bug Fixes
    • 4.10.1
      • New Features
      • Bug Fixes
    • 4.10.0
      • Upgrade Notes
    • 4.9.0
      • New Features
    • 4.8.1+acme1
      • New Features
      • Upgrade Notes
    • 4.8.1
      • Upgrade Notes
      • Bug Fixes
    • 4.8.0
      • New Features
    • 4.6.0
      • New Features
      • Security Issues
    • 4.5.1+acme1
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 4.5.1
      • Bug Fixes
    • 4.5.0
      • Prelude
    • 4.4.0
      • New Features
      • Deprecation Notes
    • 4.3.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
      • Bug Fixes
    • 4.2.0
      • Prelude
    • 4.1.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
      • Bug Fixes
    • 4.0.0
      • Prelude
      • New Features
      • Upgrade Notes
      • Deprecation Notes
      • Bug Fixes
    • 3.19.1
      • Security Issues
      • Bug Fixes
    • 3.19.0
      • Prelude
      • New Features
      • Upgrade Notes
      • Security Issues
      • Bug Fixes
    • 3.18.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
      • Security Issues
      • Bug Fixes
    • 3.17.0
      • New Features
      • Security Issues
    • 3.16.1
      • Bug Fixes
    • 3.16.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 3.15.0
      • Bug Fixes
    • 3.14.0
      • New Features
      • Upgrade Notes
    • 3.13.0
      • New Features
      • Upgrade Notes
    • 3.12.0
      • New Features
      • Upgrade Notes
      • Other Notes
    • 3.11.1
      • Bug Fixes
    • 3.11.0
      • New Features
      • Upgrade Notes
    • 3.10.2
      • New Features
      • Security Issues
      • Bug Fixes
    • 3.10.1
      • Bug Fixes
    • 3.10.0
      • New Features
      • Upgrade Notes
    • 3.9.0
      • New Features
    • 3.8.1
      • Bug Fixes
    • 3.8.0
      • New Features
      • Security Issues
      • Bug Fixes
    • 3.7.1
      • Bug Fixes
    • 3.7.0
      • New Features
      • Upgrade Notes
    • 3.6.1
      • Security Issues
    • 3.6.0
      • New Features
      • Upgrade Notes
    • 3.5.0
      • New Features
      • Upgrade Notes
      • Security Issues
      • Bug Fixes
    • 3.4.0
      • New Features
      • Upgrade Notes
    • 3.3.1
      • New Features
      • Upgrade Notes
      • Security Issues
      • Bug Fixes
    • 3.3.0
      • New Features
      • Upgrade Notes
      • Deprecation Notes
    • 3.2.0
      • New Features
      • Bug Fixes
    • 3.1.0
      • New Features
      • Upgrade Notes
      • Security Issues
      • Bug Fixes
    • 3.0.3
      • New Features
      • Deprecation Notes
      • Bug Fixes
    • 3.0.2
      • New Features
      • Upgrade Notes
      • Bug Fixes
    • 3.0.1
      • New Features
      • Upgrade Notes
      • Bug Fixes
  • Glossary
Zuul
  • Service Administration
  • Drivers
  • View page source

Drivers

Drivers may support any of the following functions:

  • Sources – hosts git repositories for projects. Zuul can clone git repos for projects and fetch refs.

  • Triggers – emits events to which Zuul may respond. Triggers are configured in pipelines to cause changes or other refs to be enqueued.

  • Reporters – outputs information when a pipeline is finished processing an item.

Zuul includes the following drivers:

  • Gerrit
    • Connection Configuration
    • Trigger Configuration
    • Reporter Configuration
    • Requirements Configuration
    • Reference Pipelines Configuration
    • Checks Plugin Support (Deprecated)
  • GitHub
    • Configure GitHub
    • Connection Configuration
    • Trigger Configuration
    • Reporter Configuration
    • Requirements Configuration
    • Reference pipelines configuration
    • Github Checks API
  • Pagure
    • Configure Pagure
    • Connection Configuration
    • Trigger Configuration
    • Reporter Configuration
    • Requirements Configuration
    • Reference pipelines configuration
  • GitLab
    • Configure GitLab
    • Connection Configuration
    • Trigger Configuration
    • Reporter Configuration
    • Requirements Configuration
    • Reference pipelines configuration
  • Git
    • Connection Configuration
    • Trigger Configuration
  • MQTT
    • Message Schema
    • Connection Configuration
    • Reporter Configuration
  • Elasticsearch
    • Connection Configuration
    • Reporter Configuration
  • SMTP
    • Connection Configuration
    • Reporter Configuration
  • Timer
    • Trigger Configuration
  • Zuul
    • Trigger Configuration
Previous Next

© Copyright 2012-2025, Zuul project contributors.

Built with Sphinx using a theme provided by Read the Docs.
Versions v: 13.0.0+acme3
latest
13.0.0+acme3
13.0.0+acme2
13.0.0+acme1
13.0.0
12.1.0+acme8
12.1.0+acme7
12.1.0+acme6
12.1.0+acme5
12.1.0+acme4
12.1.0+acme3
12.1.0+acme2
12.1.0+acme1
12.1.0
12.0.0+acme9
12.0.0+acme8
12.0.0+acme7
12.0.0+acme6
12.0.0+acme5
12.0.0+acme4
12.0.0+acme3
12.0.0+acme2
12.0.0+acme1
12.0.0
11.3.0+acme3
11.3.0+acme2
11.3.0+acme1
11.3.0
11.2.0+acme6
11.2.0+acme5
11.2.0+acme4
11.2.0+acme3
11.2.0+acme2
11.2.0+acme1
11.2.0
11.1.0+acme11
11.1.0+acme10
11.1.0+acme9
11.1.0+acme8
11.1.0+acme7
11.1.0+acme6
11.1.0+acme5
11.1.0+acme4
11.1.0+acme3
11.1.0+acme2
11.1.0+acme1
11.1.0
11.0.1
11.0.0+acme2
11.0.0+acme1
11.0.0
10.2.0+acme5
10.2.0+acme4
10.2.0+acme3
10.2.0+acme2
10.2.0+acme1
10.2.0
10.1.0+acme1
10.1.0
10.0.0+acme1
10.0.0
9.5.0+acme2
9.5.0+acme1
9.5.0
9.4.0
9.3.0+acme2
9.3.0+acme1
9.3.0
9.2.0+acme14
9.2.0+acme13
9.2.0+acme12
9.2.0+acme11
9.2.0+acme10
9.2.0+acme9
9.2.0+acme8
9.2.0+acme7
9.2.0+acme6
9.2.0+acme5
9.2.0+acme4
9.2.0+acme3
9.2.0+acme2
9.2.0+acme1
9.2.0
9.1.0
9.0.0+acme3
9.0.0+acme2
9.0.0+acme1
9.0.0
8.3.1+acme8
8.3.1+acme7
8.3.1+acme6
8.3.1+acme5
8.3.1+acme4
8.3.1+acme3
8.3.1+acme2
8.3.1+acme1
8.3.1
8.3.0
8.2.0+acme9
8.2.0+acme8
8.2.0+acme7
8.2.0+acme6
8.2.0+acme5
8.2.0+acme4
8.2.0+acme3
8.2.0+acme2
8.2.0+acme1
8.2.0
8.1.0+acme4
8.1.0+acme3
8.1.0+acme2
8.1.0+acme1
8.1.0
8.0.1+acme1
8.0.1
8.0.0
7.1.0
7.0.0
6.4.0+acme5
6.4.0+acme4
6.4.0+acme3
6.4.0+acme2
6.4.0+acme1
6.4.0
6.3.0
6.2.0+acme5
6.2.0+acme4
6.2.0+acme3
6.2.0+acme2
6.2.0+acme1
6.2.0
6.1.0+acme2
6.1.0+acme1
6.1.0
6.0.0+acme4
6.0.0+acme3
6.0.0+acme2
6.0.0+acme1
6.0.0
5.2.5
5.2.4
5.2.3
5.2.2+acme3
5.2.2+acme2
5.2.2+acme1
5.2.2
5.2.1+acme1
5.2.1
5.2.0+acme3
5.2.0+acme2
5.2.0+acme1
5.2.0
5.1.0+acme1
5.1.0
5.0.0+acme9
5.0.0+acme8
5.0.0+acme7
5.0.0+acme6
5.0.0+acme5
5.0.0+acme4
5.0.0+acme3
5.0.0+acme2
5.0.0+acme1
5.0.0