Getting started with Conductor
Documentation
- Quick Start Guide
- Environment-specific setup
- Composer Project Setup
- Composer Authentication
- Synchronizations
- Security Monitoring
- Update Review
- Conductor
- Suborganization Setup
- Vendors: Customer Setup
- API Documentation
- Cloud Changelog
Private Packagist Self-Hosted
- Self-Hosted Installation
- Maintenance
- Troubleshooting Guide
- Integration Setup
- Replicated Native (deprecated)
- Self-Hosted Changelog
Conductor will group and schedule automated dependency updates on your own continuous integration platform. If the update succeeds, Conductor will send you a pull request to your code hosting platform (GitHub, GitLab, Bitbucket) with the changed composer.lock file and, if necessary, other files modified by Composer plugins or scripts.
Prerequisites for receiving dependency update PRs from Conductor:
- Receive early access to Conductor. Join the waitlist and wait for approval.
- Set up an organization on Private Packagist Cloud either with a free trial or subscribe to the cloud plan.
- A synchronization in your Private Packagist organization with your code hosting platform.
- A workflow on your continuous integration platform to run Composer updates.
Set up synchronization
Once you have a Private Packagist organization and Conductor is enabled for you, log into your Private Packagist organization and head to the "Settings" tab in the main navigation. Under the "Synchronization" entry you can add one or more synchronizations with an organization on your code hosting platform. This is how you grant us access to your VCS repositories. The synchronization will automatically add any repository with a composer.json file in the root directory as a package to Private Packagist.
Configure Conductor for your packages
Access the "Conductor" tab in the main navigation to see a list of available packages that can have their dependencies updated by Conductor. Each package shown is linked to its VCS repository to which Conductor will send pull requests with dependency updates. Your Composer projects or applications are also a kind of package and must be added to Private Packagist as regular packages to use Conductor on them. Conductor can only manage dependencies for packages added to Private Packagist via synchronization that have a composer.lock file committed to the repository.
To get started, click on the configure link displayed next to the package which you would like Conductor to update. Follow the instructions for your continuous integration platform.
GitHub Actions
Create a new GitHub Actions workflow in .github/workflows/conductor.yaml
of your GitHub repository using the template below:
# See the Conductor setup guide at https://packagist.com/docs/conductor/getting-started on: repository_dispatch: types: - dependency_update name: Private Packagist Conductor permissions: contents: write jobs: conductor: name: Private Packagist Conductor runs-on: "ubuntu-latest" env: COMPOSER_AUTH: ${{ secrets.CONDUCTOR_COMPOSER_AUTH }} steps: - uses: actions/checkout@v4 - name: Install PHP uses: "shivammathur/setup-php@v2" with: php-version: "latest" # Set up any necessary config files or database here before composer install is run - name: "Running Conductor" uses: packagist/conductor-github-action@v1
- Adjust the PHP Version used in the "Install PHP" step
- Commit and push the workflow to your main branch of your package repository
Create a secret CONDUCTOR_COMPOSER_AUTH
with the Composer authentication configuration as described here to access Private Packagist.
We recommend to create a dedicated authentication token with update access. You can copy and paste the contents for the secret from the "Environment variable" tab in the Private Packagist UI while creating the token in "Settings" -> "Authentication Tokens". Remove the single quotes around the value.
data:image/s3,"s3://crabby-images/9c7d1/9c7d168253dc6036932e7554aa415e2c2cb1903d" alt="Create Authentication Token"
The contents of the variable should look like this:
{"http-basic": {"repo.packagist.com": {"username": "token", "password": "packagist_out_73a81c..." }}}
Conductor needs to verify your CI setup before you can start receiving PRs.
Verify your CI setup
- Navigate to the "Conductor" tab in your Private Packagist organization.
- Click on the name of your package.
data:image/s3,"s3://crabby-images/f7f28/f7f2889639e9aa2a9a0b21e8de5091acad755067" alt="Task list with verification task"
Right now all tasks are waiting for the CI verification task on top of the list. Conductor will not start with the regular schedule until this verification task was successful.
The verification task will only execute composer update nothing
and will not result in a PR to be sent to your code hosting platform.
- Click on the task "Verify the continuous integration setup"
- Use the "Schedule now" button to test your setup
You can see the state of your task and the last events for the task. Once the task is executed, watch your CI platform: You should see a run for the just added workflow. Examine the run to see if it succeeded.
If it was successful your CI configuration is verified and complete. Conductor will trigger your workflow with the next task in the list. This time it will send a pull request.
When you run into errors, troubleshoot and fix them. You can trigger the workflow again by restarting the CI verification task. The restart button is available after the first execution.
How scheduling works
The list shows groups of all available updates to be scheduled. Each group of updates is called a task. Conductor will schedule only one task at a time. All others are waiting for the task on top of the list to be successful or paused.
Once Conductor schedules a task it sends a payload to your CI platform that triggers the workflow you just added. The payload contains the commands Composer will run to update a group of dependencies from your package.
The workflow consists of several steps:
- Checkout the code from your repository
- Set up PHP
- Run
composer install
- Run Composer update commands
- Commit changed files (composer.lock, ...)
- Push commits to a new branch (or force push an existing branch)
- Send the status of the workflow to Private Packagist
If all these steps succeeded, Private Packagist creates a pull request for the newly pushed branch. The PR description will contain details about the update and changelogs from your dependencies. Conductor integrates with Update Review to present a reviewable list of all updated dependencies.
data:image/s3,"s3://crabby-images/9b71f/9b71f55d3de123448cdbd473f37ab9698e11054a" alt="Conductor Pull Request"
Once you reviewed the changes and merged the PR, Conductor will schedule the next task.
If you close the PR, the task will be paused and Conductor will schedule the next task. Clicking the "Pause" button in the UI has the same effect. Conductor won't attempt to update the dependency to this exact version again but it will schedule updates to newer versions.
If you want to schedule any other task in the list, click on its name and use the button "Schedule now to create a PR".
Tasks fixing security issues have a higher priority. They will be moved to the top of the list and scheduled right away even if there already is a PR for another task open.
Start Free Trial
Login to create an organization and start your free trial!