Triggering Code Manager with custom scripts

Sections

Custom scripts are a good way to trigger deployments if you can't use webhooks. For example, if you have privately hosted Git repositories, custom notifications, or existing continuous integration systems (like Continuous Delivery for Puppet Enterprise (PE)).

Triggering Code Manager with a webhook is simpler than using a custom script. If you can use a webhook, we recommend it.

To create a script that triggers Code Manager to deploy your environments, you can use either the puppet-code command or a curl statement that hits the Code Manager API endpoints. We recommend using the puppet-code command, if possible.

After pushing new code to your control repo, run your script to trigger Code Manager to deploy your code.

The following instructions assume you've Set up Code Manager.

Scripting the puppet-code command

The puppet-code command can deploy environments from the command line. You can use this command in custom Code Manager scripts.

Using puppet-code in Code Manager scripts is much the same as Triggering Code Manager on the command line. The benefit to using a script is that you don't need to rebuild the commands from scratch each time, since they are stored in scripts.

Build your desired puppet-code command with the relevant action, environment (or --all for all environments), custom puppet-code.conf settings, and other options. Then, incorporate the command into your complete script.

After pushing new code to your control repo, run your script to trigger Code Manager to deploy your code.

Scripting deploys curl commands

The Code Manager API deploys endpoint can trigger code deployments. You can use a curl command in your custom scripts to hit this endpoint.

Calling the deploys endpoint in a script is similar to forming a one-time call to the endpoint. By storing commands in scripts, you don't need to rebuild the commands from scratch each time.

Build your desired curl command with the relevant URI path, parameters, and authentication, as described in POST /v1/deploys. Then, incorporate the command into your complete script.

Scripting deploys/status curl commands

The Code Manager API deploys/status endpoint can check a deployment's status. You can use a curl command in your custom scripts to hit this endpoint.

Calling the deploys/status endpoint in a script is similar to forming a one-time call to the endpoint. By storing commands in scripts, you don't need to rebuild the commands from scratch each time.

Build your desired curl command with the relevant URI path, parameters, and authentication, as described in GET /v1/deploys/status. Then, incorporate the command into your complete script.