1. Docs
  2. Pulumi Cloud
  3. Deployments
  4. REST API

Pulumi Deployments REST API

    The Pulumi Deployments REST API provides a fully-managed remote execution interface for your Pulumi programs.

    Pulumi Deployments is now generally available!

    We have created new routes for the Pulumi Deployments REST API, which are documented below. The preview routes will continue to work for now, but should be considered deprecated and will be removed on October 10th, 2024.

    Migrating from the Preview API

    For the majority of cases, the new API is a drop-in replacement for the preview API and the only change is that the route itself has changed (i.e. replace with /api/preview with /api/stacks).

    However, there are a few cases where the new API has changed the behavior of the preview API. These changes are as follows:

    • The Create Deployment endpoint now defaults to using the stack’s deployment settings (i.e. inheritSettings: true). To use only the deployment settings present in the request, set inheritSettings to false.
    • The List Stack Deployments endpoint now returns an object with a deployments property instead of a list of deployments.
    • The List Stack Deployments endpoint now returns deployments in descending order (most recent first). To return deployments in ascending order (oldest first), set asc to true.
    • The Deployment Settings routes have changed. In addition to replacing api/preview with api/stacks, also replace deployment/settings with deployments/settings in the URL.

    Authentication

    All requests must be authenticated using a token via the Authorization HTTP header.

    The Authorization header must be in the form below with the literal string token, then a space, then your access token value.

    Authorization: token {token}
    

    To view your access tokens, or create a new one, view the Access Tokens page. You will see a list of past tokens, when they were last used, and have the ability to revoke them.

    The Pulumi Deployments REST API will return a 401 status code if the token is missing or invalid.

    Deployment Settings

    Several endpoints accept or return deployment settings. Deployment settings are composed of several parts:

    • An ExecutorContext that defines information about the executor where the Pulumi operation is executed.
    • A SourceContext that defines where the source code for your project is located. Currently, only git repos are supported.
    • An OperationContext that defines how the Pulumi project is to be executed (i.e. the Pulumi operation to execute and any associated context it requires).
    • An optional GitHub block that contains information for GitHub integration.

    ExecutorContext

    The executor context defines information about the executor where the Pulumi operation is executed. If unspecified, the default pulumi/pulumi image is used.

    • executorImage (Optional[string]): Allows overriding the default executor image with a custom image.

    Image requirements:

    • It must be a unix-based image which includes curl.
    • It must include the pulumi CLI in its $PATH.
    • It must include the required SDK runtime(s) for your Pulumi program.
    Using a custom image may result in slower execution due to time spent pulling the image.

    Example

    {
        "executorImage": "pulumi/pulumi-nodejs:latest"
    }
    

    SourceContext

    The source context contains information about where the source code for your project is located. Currently, only git repos are supported as a source.

    • repoURL (Optional[string]): The URL of the git repository where the source code is located. Must not be specified if a GitHub block is present.
    • branch (Optional[string]): The repository branch to use.
    • repoDir (Optional[string]): The directory where Pulumi.yaml is located, if not in the project source root.
    • commit (Optional[string]): The hash of the commit to deploy. If used, HEAD will be in detached mode. This is mutually exclusive with the branch setting. Either value must be specified.
    • gitAuth (Optional[object]): The authentication information for the git repo. If not specified, the repo is assumed to be public. Only one type is supported at a time.
      • sshAuth (Optional[object]): SSHAuth is the authentication information for the git repo
        • sshPrivateKey (Secret): The private key to use
        • password (Optional[Secret]): The password to use
      • basicAuth (Optional[object]): Basic auth information
        • userName (string): The username to use for authentication
        • password (Secret): The password to use for authentication

    Secret types should have the following structure:

      "key": { "secret": "value" }
    

    Examples

    No authentication required (public repo)
    {
      "git": {
        "repoURL": "https://github.com/pulumi/examples.git",
        "branch": "refs/heads/master",
        "repoDir": "aws-ts-s3-folder"
      }
    }
    
    Using SSH authentication
    {
      "git": {
        "repoURL": "https://github.com/pulumi/examples.git",
        "branch": "refs/heads/master",
        "repoDir": "aws-ts-s3-folder",
        "gitAuth": {
          "sshAuth": {
            "sshPrivateKey": {
              "secret": "myPrivateKey"
            },
            "password": {
              "secret": "myPassword"
            }
          }
        }
      }
    }
    
    Using basic authentication
    {
      "git": {
        "repoURL": "https://github.com/pulumi/examples.git",
        "branch": "refs/heads/master",
        "repoDir": "aws-ts-s3-folder",
        "gitAuth": {
          "basicAuth": {
            "userName": "myUserName",
            "password": {
              "secret": "myPassword"
            }
          }
        }
      }
    }
    
    Using an access token
    {
      "git": {
        "repoURL": "https://github.com/pulumi/examples.git",
        "branch": "refs/heads/master",
        "repoDir": "aws-ts-s3-folder",
        "gitAuth": {
          "basicAuth": {
            "userName": "git",
            "password": {
              "secret": "myAccessToken"
            }
          }
        }
      }
    }
    

    OperationContext

    The operation context describes any context required for Pulumi operations to execute such as pre-run commands and environment variables.

    • preRunCommands (Optional[list[string]]): A list of commands to run before the Pulumi command is executed. Each command is run in a separate subshell. A command may export environment variables by writing them as NAME=value pairs to a file named PULUMI_ENV. For example, a pre-run command could set the HELLO environment variable to world as follows:

      echo HELLO=world >PULUMI_ENV
      
    • environmentVariables (Optional[map[string]EnvironmentVariable]): A list of environment variables to set for the operation.

    • options (Optional[OperationContextOptions]): Options is a bag of settings that allows you to set or override default behavior.

    OperationContextOptions has the following structure:

    • skipInstallDependencies: Allows you to skip the automated dependency installation. You can then customize your dependency installation step in preRunCommands.

    EnvironmentVariable types can have either of the following structures:

      "key": {
        "secret": "value" <-- secret environment variable
      },
      "key": "value" <-- plaintext environment variable
    

    The following environment variables are used internally by Pulumi Deployments, and therefore should not be used as they will be overwritten:

    • PULUMI_CI_BUILD_URL
    • PULUMI_CI_SYSTEM
    • PULUMI_CI_BUILD_NUMBER
    • PULUMI_CI_BUILD_ID
    • PULUMI_ACCESS_TOKEN
    • PULUMI_BACKEND_URL
    • oidc (Optional[OIDCConfiguration]): Allows the deployment to exchange an OIDC token for short-term credentials from a cloud provider.

    OIDCConfiguration has the following structure:

    • aws (Optional[AWSOIDCConfiguration]): Configures OIDC for AWS.
    • azure (Optional[AzureOIDCConfiguration]): Configures OIDC for Azure.
    • gcp: (Optional[GCPOIDCConfiguration]): Configures OIDC for GCP.

    AWSOIDCConfiguration has the following structure:

    • duration (Optional[string]): The duration of the assume-role session in “XhYmZs” format.
    • policyArns (Optional[list[string]]): A set of IAM policy ARNs that further restrict the assume-role session.
    • roleArn (string): The ARN of the role to assume using the OIDC token.
    • sessionName (string): The name of the assume-role session.

    AzureOIDCConfiguration has the following structure:

    • clientId (string): The client ID of the federated workload identity.
    • tenantId (string): The tenant ID of the federated workload identity.
    • subscriptionId (string): The ID of the subscription to use.

    GCPOIDCConfiguration has the following structure:

    • projectId (string): The numerical ID of the Google Cloud project.
    • region (Optional[string]): The region of the Google Cloud project.
    • workloadPoolId (string): The ID of the workload pool to use.
    • providerId (string): The ID of the identity provider associated with the workload pool.
    • serviceAccount (string): The email address of the service account to use.
    • tokenLifetime (Optional[string]): The lifetime of the temporary credentials in “XhYmZs” format.

    Examples

    Pre-run commands and environment variables
    {
      "preRunCommands": [
        "go get sigs.k8s.io/kind@v0.16.0"
      ],
      "environmentVariables": {
        "AWS_REGION": "us-east-2",
        "CUSTOM_VARIABLE": "foo",
        "MY_PASSWORD": {
          "secret": "my-secret-password"
        }
      }
    }
    
    Override default dependency installation step to use poetry
    {
      "preRunCommands": [
          "curl -sSL https://install.python-poetry.org | python3",
          "poetry install"
      ],
      "environmentVariables": {
          "POETRY_HOME": "/usr/local"
      },
      "options": {
        "skipInstallDependencies": true
      }
    }
    
    Override default dependency installation step to use a different version of node
    {
      "preRunCommands": [
        "node --version",
        "curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.2/install.sh | bash",
        "nvm use 17 && yarn"
      ],
      "environmentVariables": {
        "NODE_VERSION": "17"
      },
      "options": {
        "skipInstallDependencies": true
      }
    }
    
    Use OIDC with AWS
    {
      "environmentVariables": {
        "AWS_REGION": "us-west-2"
      },
      "oidc": {
        "aws": {
          "roleArn": "arn:aws:iam::123456789000:role/pulumi-deploy-role",
          "sessionName": "pulumi-deploy-session"
        }
      }
    }
    
    Environment variables may be automatically marked secret by the API even if they are not explicitly marked as such in the request if they “look” like secrets. We evaluate “secretness” based on specific key terms and the entropy of the associated value.

    GitHub

    The GitHub block describes settings for Pulumi Deployments’ GitHub integration.

    • repository (string): The GitHub repository that contains the Pulumi program to deploy.
    • deployCommits (boolean): True to run update deployments for each commit pushed to the configured branch.
    • previewPullRequests (boolean): True to run preview deployments for each pull request that targets the configured branch.
    • pullRequestTemplate (boolean): True to enable Review Stacks for this branch, and use this stack as a template.
    • paths (Optional[list[string]]): A list of path filters that determine whether a commit or pull request should trigger a deployment based on the paths affected by the commit or pull request. Path filters may use the * and ** elements to match a single path component or any number of path components, respectively. If a path filter begins with a !, it excludes matching paths rather than including matching paths. If all filters are excludes, there is an implicit ** filter. A deployment will run if any non-excluded file is modified. Note that the list of changed paths returned by GitHub is limited to 300 files. If there are files changed that aren’t matched in the first 300 files returned by the filter, a deployment will not run. You may need to create additional filters so that a deployment will run.

    Examples

    Use GitHub integration for push-to-deploy, PR previews, and Review Stacks with path filters
    {
      "repository": "pulumi/deploy-demos",
      "deployCommits": true,
      "previewPullRequests": true,
      "pullRequestTemplate": false,
      "paths": [ "pulumi-programs/bucket-time/**", "!pulumi/programs/bucket-time/README.md" ]
    }
    
    Use GitHub integration but disable push-to-deploy and Review Stacks
    {
      "repository": "pulumi/deploy-demos",
      "deployCommits": false,
      "previewPullRequests": true,
      "pullRequestTemplate": false,
      "paths": [ "pulumi-programs/bucket-time/**", "!pulumi/programs/bucket-time/README.md" ]
    }
    
    Use GitHub integration for source control only
    {
      "repository": "pulumi/deploy-demos"
    }
    

    Endpoints

    Get Settings

    Gets the deployment settings associated with a stack.

    GET https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/settings
    

    Example

    Request
    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/settings"
    
    Response
    {
      "sourceContext": {
        "git": {
          "repoURL": "https://github.com/pulumi/deploy-demos.git",
          "branch": "refs/heads/demo",
          "repoDir": "pulumi-programs/aws-ts-s3"
        }
      },
      "operationContext": {
        "preRunCommands": [
          "echo \"hello world\""
        ],
        "environmentVariables": {
          "AWS_REGION": "us-west-2",
          "AWS_ACCESS_KEY_ID": "$AWS_ACCESS_KEY_ID",
          "AWS_SECRET_ACCESS_KEY": "$AWS_SECRET_ACCESS_KEY",
          "AWS_SESSION_TOKEN": "$AWS_SESSION_TOKEN"
        }
      }
    }
    

    Patch Settings

    Patches the deployment settings associated with a stack.

    POST https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/settings
    

    The final settings for the stack are calculated by merging the settings present in the request with the stack’s current settings according to the following rules:

    • For object properties:
      • Start with a copy of the current property value
      • Remove all properties that are explicitly set to null in the patch value
      • Merge all non-null properties from the patch value that exist in the current property value
      • Add all non-null properties from the patch value that do not exist in the current property value
    • For other properties, replace the current value with the patch value

    For example, if the current settings for a stack are:

    {
      "sourceContext": {
        "git": {
          "repoURL": "https://github.com/pulumi/deploy-demos.git",
          "branch": "refs/heads/demo",
          "repoDir": "pulumi-programs/aws-ts-s3"
        }
      },
      "operationContext": {
        "preRunCommands": [
          "echo \"hello world\""
        ],
        "environmentVariables": {
          "AWS_REGION": "us-west-2",
          "AWS_ACCESS_KEY_ID": "$AWS_ACCESS_KEY_ID",
          "AWS_SECRET_ACCESS_KEY": "$AWS_SECRET_ACCESS_KEY",
          "AWS_SESSION_TOKEN": "$AWS_SESSION_TOKEN"
        }
      }
    }
    

    And we apply this patch:

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3/dev/deployments/settings" \
    -d '{
      "sourceContext": {
        "git": {
          "repoURL": null,
        }
      },
      "operationContext": {
        "preRunCommands": [
          "echo \"bonjour\""
        ],
        "environmentVariables": {
          "AWS_ACCESS_KEY_ID": null,
          "AWS_SECRET_ACCESS_KEY": null,
          "AWS_SESSION_TOKEN": null
        },
        "oidc": {
          "aws" {
            "roleArn": "my-role-arn",
            "sessionName": "pulumi-deploy"
          }
        }
      },
      "gitHub": {
        "repository": "pulumi/deploy-demos"
      }
    }'
    

    Then the new settings for the stack are:

    {
      "sourceContext": {
        "git": {
          "branch": "refs/heads/demo",
          "repoDir": "pulumi-programs/aws-ts-s3"
        }
      },
      "operationContext": {
        "preRunCommands": [
          "echo \"bonjour\""
        ],
        "environmentVariables": {
          "AWS_REGION": "us-west-2"
        },
        "oidc": {
          "aws": {
            "roleArn": "my-role-arn",
            "sessionName": "pulumi-deploy"
          }
        }
      },
      "gitHub": {
        "repository": "pulumi/deploy-demos"
      }
    }
    

    Clear Settings

    Clears the deployment settings associated with a stack.

    DELETE https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/settings
    

    Example

    curl -i -XDELETE -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3/dev/deployments/settings"
    

    Create Deployment

    Creates a new deployment to execute a Pulumi program via the Pulumi Cloud.

    POST https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments
    
    The stack must exist before a deployment can be created for it. If you attempt to create a deployment for a stack that does not exist, the request will return an error stating as such.

    A deployment request consists of optional deployment settings and the operation to perform.

    Examples

    Stack deployment settings

    The following request will create a deployment in the “my-org” Pulumi organization for “aws-ts-s3” project and “dev” stack. It will use only the settings associated with the stack.

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3/dev/deployments" \
    -d '{
    	"operation": "update"
    }'
    
    Merged stack and request deployment settings

    The following request will create a deployment in the “my-org” Pulumi organization for “aws-ts-s3” project and “dev” stack. It will merge the settings associated with the stack with the settings present in the request according to the rules used by the Patch Settings endpoint.

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3/dev/deployments" \
    -d '{
    	"operation": "update",
        "operationContext": {
            "environmentVariables": {
                "AWS_REGION": "us-east-1"
            }
        }
    }'
    
    Request deployment settings only

    The following request will create a deployment in the “my-org” Pulumi organization for “aws-ts-s3” project and “dev” stack. Any deployment settings associated with the stack will be ignored; instead, the deployment will use only the deployment settings present in the request. The request uses the Pulumi examples repo as a source, specifically targeting aws-ts-s3-folder program. First, any pre-run commands defined in the request are run, in this case printing the string “hello world”. Finally, it will run a pulumi update against the stack, as specified in the “operation”.

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3/dev/deployments" \
    -d '{
    	"operation": "update",
    	"inheritSettings": false,
        "sourceContext": {
            "git": {
                "repoURL": "https://github.com/pulumi/deploy-demos.git",
                "branch": "refs/heads/demo",
                "repoDir": "pulumi-programs/aws-ts-s3"
            }
        },
        "operationContext": {
            "preRunCommands": [
                "echo \"hello world\""
            ],
            "environmentVariables": {
                "AWS_REGION": "us-west-2",
                "AWS_ACCESS_KEY_ID": "$AWS_ACCESS_KEY_ID",
                "AWS_SECRET_ACCESS_KEY": "$AWS_SECRET_ACCESS_KEY",
                "AWS_SESSION_TOKEN": "$AWS_SESSION_TOKEN"
            }
        }
    }'
    

    Get Deployment

    Gets details for a specific deployment.

    // Get deployment by ID
    GET https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/{deploymentID}
    
    // Get deployment by version
    GET https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/version/{deploymentVersion}
    

    Example

    Request
    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/9e5e1331-a018-4845-8714-1598ba8dc52e"
    
    Response
    {
      "id": "9e5e1331-a018-4845-8714-1598ba8dc52e",
      "created": "2022-10-17 22:12:34.834",
      "modified": "2022-10-17 22:12:42.411",
      "status": "running",
      "version": 34,
      "requestedBy": {
        "name": "my-org",
        "githubLogin": "my-org",
        "avatarUrl": "https://avatars.githubusercontent.com/u/1234567?v=4",
        "email": "example@gmail.com"
      },
      "jobs": [
        {
          "status": "running",
          "started": "2022-10-17T22:12:41.191646Z",
          "lastUpdated": "2022-10-17T22:12:42.411732Z",
          "steps": [
            {
              "name": "Download deployment executor",
              "status": "succeeded",
              "started": "2022-10-17T22:12:41.191646Z",
              "lastUpdated": "2022-10-17T22:12:42.244429Z"
            },
            {
              "name": "Get source",
              "status": "running",
              "started": "2022-10-17T22:12:42.411732Z",
              "lastUpdated": "2022-10-17T22:12:42.411732Z"
            },
            {
              "name": "Download dependencies",
              "status": "not-started",
              "started": "0001-01-01T00:00:00Z",
              "lastUpdated": "0001-01-01T00:00:00Z"
            },
            {
              "name": "Pre-run command 1",
              "status": "not-started",
              "started": "0001-01-01T00:00:00Z",
              "lastUpdated": "0001-01-01T00:00:00Z"
            },
            {
              "name": "Pulumi operation",
              "status": "not-started",
              "started": "0001-01-01T00:00:00Z",
              "lastUpdated": "0001-01-01T00:00:00Z"
            }
          ]
        }
      ],
      "latestVersion": 34,
      "configuration": {
        "environmentVariables": [
          {
            "name": "AWS_REGION",
            "value": "us-west-2",
            "secret": false
          },
          {
            "name": "AWS_SECRET_ACCESS_KEY",
            "secret": true
          },
          {
            "name": "PULUMI_CI_BUILD_ID",
            "value": "9e5e1331-a018-4845-8714-1598ba8dc52e",
            "secret": false
          },
          {
            "name": "PULUMI_CI_BUILD_NUMBER",
            "value": "34",
            "secret": false
          },
          {
            "name": "PULUMI_CI_SYSTEM",
            "value": "Pulumi Deploy",
            "secret": false
          },
          {
            "name": "AWS_ACCESS_KEY_ID",
            "secret": true
          },
          {
            "name": "PULUMI_ACCESS_TOKEN",
            "secret": true
          },
          {
            "name": "PULUMI_BACKEND_URL",
            "value": "https://api.pulumi.com/",
            "secret": false
          },
          {
            "name": "AWS_SESSION_TOKEN",
            "secret": true
          }
        ],
        "source": {
          "git": {
            "repoURL": "https://github.com/pulumi/examples.git",
            "branch": "refs/heads/master",
            "repoDir": "aws-ts-s3-folder"
          }
        }
      },
      "pulumiOperation": "update"
    }
    

    List Stack Deployments

    Gets a list of deployments for a stack.

    GET https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments
    

    The following query parameters may be used for pagination.

    • page (Optional[int]): The page of results to return (min: 1, default: 1)
    • pageSize (Optional[int]): The number of results to return per page (min: 1, max: 100, default: 10)
    • asc (Optional[bool]): Whether to sort the results in ascending order (default: false)
    • status (Optional[string]): The deployment status to filter by. If not specified, all statuses are returned.

    Example

    Request
    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments?page=1&pageSize=5"
    
    Response
    {
        "deployments": [
            {
                "id": "9e007591-277d-43c6-b256-9f0af0ebdc1b",
                "created": "2023-09-19 05:49:43.002",
                "modified": "2023-09-19 05:50:48.516",
                "status": "succeeded",
                "version": 959,
                "requestedBy": {
                    "name": "Beep Boop",
                    "githubLogin": "beepbooplogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/12345.png",
                    "email": "beep@boop.com"
                },
                "projectName": "simple-resource",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [
                    {
                        "id": "9dc85505-113f-4c6f-a023-8f80f4bc36b8",
                        "updateID": "df60a4c7-69dc-426d-8987-39e8544fe983",
                        "version": 1217,
                        "startTime": 1694820531,
                        "endTime": 1694820540,
                        "result": "succeeded",
                        "kind": "update",
                        "message": "",
                        "environment": {
                            "key": "value",
                            ...
                        }
                    }
                ],
                "jobs": [
                    {
                        "status": "succeeded",
                        "started": "2023-09-15T23:28:17.644409853Z",
                        "lastUpdated": "2023-09-15T23:29:02.883538271Z",
                        "steps": [
                            {
                                "name": "Setup",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:17.644409853Z",
                                "lastUpdated": "2023-09-15T23:28:20.730268067Z"
                            },
                            {
                                "name": "Download deployment executor",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:22.318042694Z",
                                "lastUpdated": "2023-09-15T23:28:25.36490801Z"
                            },
                            {
                                "name": "Fetch provider credentials via OIDC",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:25.519842902Z",
                                "lastUpdated": "2023-09-15T23:28:25.729177668Z"
                            },
                            {
                                "name": "Get source",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:25.890605613Z",
                                "lastUpdated": "2023-09-15T23:28:31.455532053Z"
                            },
                            {
                                "name": "Download dependencies",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:31.69949523Z",
                                "lastUpdated": "2023-09-15T23:28:50.343866319Z"
                            },
                            {
                                "name": "pulumi update",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:50.561534112Z",
                                "lastUpdated": "2023-09-15T23:29:02.883538271Z"
                            }
                        ]
                    }
                ],
                "initiator": "console"
            },
            {
                "id": "717e0c15-b3aa-48e3-a280-a988b28327cf",
                "created": "2023-09-18 22:01:09.128",
                "modified": "2023-09-18 22:01:11.287",
                "status": "failed",
                "version": 957,
                "requestedBy": {
                    "name": "Beep Boop",
                    "githubLogin": "beepbooplogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/12345.png",
                    "email": "beep@boop.com"
                },
                "projectName": "simple-resource",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [],
                "jobs": [...],
                "initiator": "console"
            },
            {
                "id": "48b63246-7c5f-49ff-a9bc-6131d051ae4b",
                "created": "2023-09-18 21:08:16.656",
                "modified": "2023-09-18 21:25:39.359",
                "status": "failed",
                "version": 956,
                "requestedBy": {
                    "name": "Foo Bar",
                    "githubLogin": "foobarlogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/3r2fn32ofn.png",
                    "email": "foo@bar.com"
                },
                "projectName": "simple-resource",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [],
                "jobs": [...],
                "initiator": "console"
            },
            {
                "id": "130e4135-aec1-40b3-af66-9b434c16a24b",
                "created": "2023-09-18 17:49:13.979",
                "modified": "2023-09-18 17:49:15.805",
                "status": "failed",
                "version": 955,
                "requestedBy": {
                    "name": "Foo Bar",
                    "githubLogin": "foobarlogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/3r2fn32ofn.png",
                    "email": "foo@bar.com"
                },
                "projectName": "simple-resource",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [],
                "jobs": [...],
                "initiator": "console"
            },
            {
                "id": "44621244-da37-46d7-82a7-97a6c198c363",
                "created": "2023-09-15 23:25:21.101",
                "modified": "2023-09-15 23:29:02.883",
                "status": "succeeded",
                "version": 954,
                "requestedBy": {
                    "name": "Foo Bar",
                    "githubLogin": "foobarlogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/3r2fn32ofn.png",
                    "email": "foo@bar.com"
                },
                "projectName": "simple-resource",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [...],
                "jobs": [...],
                "initiator": "console"
            }
        ],
        "itemsPerPage": 5,
        "total": 67
    }
    

    List Organization Deployments

    Gets a list of deployments for the entire organization. Only deployments belonging to stacks that the user has access to will be returned.

    GET https://api.pulumi.com/api/orgs/{organization}/deployments
    

    The following query parameters may be used for pagination.

    • page (Optional[int]): The page of results to return (min: 1, default: 1)
    • pageSize (Optional[int]): The number of results to return per page (min: 1, max: 100, default: 10)
    • asc (Optional[bool]): Whether to sort the results in ascending order (default: false)
    • status (Optional[string]): The deployment status to filter by. If not specified, all statuses are returned.

    Example

    Request
    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/orgs/my-org/deployments?page=1&pageSize=5"
    
    Response
    {
        "deployments": [
            {
                "id": "9e007591-277d-43c6-b256-9f0af0ebdc1b",
                "created": "2023-09-19 05:49:43.002",
                "modified": "2023-09-19 05:50:48.516",
                "status": "succeeded",
                "version": 5,
                "requestedBy": {
                    "name": "Beep Boop",
                    "githubLogin": "beepbooplogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/12345.png",
                    "email": "beep@boop.com"
                },
                "projectName": "project-1",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [
                    {
                        "id": "9dc85505-113f-4c6f-a023-8f80f4bc36b8",
                        "updateID": "df60a4c7-69dc-426d-8987-39e8544fe983",
                        "version": 1217,
                        "startTime": 1694820531,
                        "endTime": 1694820540,
                        "result": "succeeded",
                        "kind": "update",
                        "message": "",
                        "environment": {
                            "key": "value",
                            ...
                        }
                    }
                ],
                "jobs": [
                    {
                        "status": "succeeded",
                        "started": "2023-09-15T23:28:17.644409853Z",
                        "lastUpdated": "2023-09-15T23:29:02.883538271Z",
                        "steps": [
                            {
                                "name": "Setup",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:17.644409853Z",
                                "lastUpdated": "2023-09-15T23:28:20.730268067Z"
                            },
                            {
                                "name": "Download deployment executor",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:22.318042694Z",
                                "lastUpdated": "2023-09-15T23:28:25.36490801Z"
                            },
                            {
                                "name": "Fetch provider credentials via OIDC",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:25.519842902Z",
                                "lastUpdated": "2023-09-15T23:28:25.729177668Z"
                            },
                            {
                                "name": "Get source",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:25.890605613Z",
                                "lastUpdated": "2023-09-15T23:28:31.455532053Z"
                            },
                            {
                                "name": "Download dependencies",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:31.69949523Z",
                                "lastUpdated": "2023-09-15T23:28:50.343866319Z"
                            },
                            {
                                "name": "pulumi update",
                                "status": "succeeded",
                                "started": "2023-09-15T23:28:50.561534112Z",
                                "lastUpdated": "2023-09-15T23:29:02.883538271Z"
                            }
                        ]
                    }
                ],
                "initiator": "console"
            },
            {
                "id": "717e0c15-b3aa-48e3-a280-a988b28327cf",
                "created": "2023-09-18 22:01:09.128",
                "modified": "2023-09-18 22:01:11.287",
                "status": "failed",
                "version": 5,
                "requestedBy": {
                    "name": "Beep Boop",
                    "githubLogin": "beepbooplogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/12345.png",
                    "email": "beep@boop.com"
                },
                "projectName": "project-2",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [],
                "jobs": [...],
                "initiator": "console"
            },
            {
                "id": "48b63246-7c5f-49ff-a9bc-6131d051ae4b",
                "created": "2023-09-18 21:08:16.656",
                "modified": "2023-09-18 21:25:39.359",
                "status": "failed",
                "version": 4,
                "requestedBy": {
                    "name": "Foo Bar",
                    "githubLogin": "foobarlogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/3r2fn32ofn.png",
                    "email": "foo@bar.com"
                },
                "projectName": "project-1",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [],
                "jobs": [...],
                "initiator": "console"
            },
            {
                "id": "130e4135-aec1-40b3-af66-9b434c16a24b",
                "created": "2023-09-18 17:49:13.979",
                "modified": "2023-09-18 17:49:15.805",
                "status": "failed",
                "version": 3,
                "requestedBy": {
                    "name": "Foo Bar",
                    "githubLogin": "foobarlogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/3r2fn32ofn.png",
                    "email": "foo@bar.com"
                },
                "projectName": "project-1",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [],
                "jobs": [...],
                "initiator": "console"
            },
            {
                "id": "44621244-da37-46d7-82a7-97a6c198c363",
                "created": "2023-09-15 23:25:21.101",
                "modified": "2023-09-15 23:29:02.883",
                "status": "succeeded",
                "version": 2,
                "requestedBy": {
                    "name": "Foo Bar",
                    "githubLogin": "foobarlogin",
                    "avatarUrl": "https://api.pulumi.com/static/avatars/3r2fn32ofn.png",
                    "email": "foo@bar.com"
                },
                "projectName": "project-1",
                "stackName": "dev",
                "pulumiOperation": "update",
                "updates": [...],
                "jobs": [...],
                "initiator": "console"
            }
        ],
        "itemsPerPage": 5,
        "total": 67
    }
    

    Get Deployment Logs

    Gets logs for a specific deployment.

    GET https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/{deploymentID}/logs
    

    Streaming logs

    Streaming logs provide a simple interface to get all logs for a deployment, starting at the beginning. Each response includes a token which can be used to get the next set of logs, until no more logs are available. The token is a string that contains the job, offset and step of the next set of logs, but the requester doesn’t need to be concerned with the details.

    The following query parameters are available:

    • nextToken: A string returned by the previous response, that can be used to get the next set of logs.
    Example

    Request

    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/6b1ec06b-4f41-4cce-a7c9-13ceded14db2/logs"
    

    Response

    {
        "lines": [
            {
                "header": "Download deployment executor",
                "timestamp": "0001-01-01T00:00:00Z"
            },
            {
                "timestamp": "2022-10-06T22:34:02.058756202Z",
                "line": "  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\n"
            },
            {
                "timestamp": "2022-10-06T22:34:02.059046831Z",
                "line": "                                 Dload  Upload   Total   Spent    Left  Speed\n"
            },
            {
                "timestamp": "2022-10-06T22:34:02.736395042Z",
                "line": "\r  0     0    0     0    0     0      0     0 --:--:-- --:--:-- --:--:--     0\r100  3905    0  3905    0     0  10728      0 --:--:-- --:--:-- --:--:-- 10698\r100 11.9M    0 11.9M    0     0  17.6M      0 --:--:-- --:--:-- --:--:-- 17.6M\n"
            },
            {
                "header": "Get Source",
                "timestamp": "0001-01-01T00:00:00Z"
            },
            {
                "timestamp": "2022-10-06T22:34:22.732527584Z",
                "line": "Successfully cloned: https://github.com/pulumi/examples.git\n"
            },
            {
                "header": "Download Dependencies",
                "timestamp": "0001-01-01T00:00:00Z"
            }
        ],
        "nextToken": "0.2.1"
    }
    

    Following request (using nextToken)

    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/6b1ec06b-4f41-4cce-a7c9-13ceded14db2/logs?nextToken=0.2.1"
    

    Response

    {
      "lines": [
        {
          "timestamp": "2022-10-06T22:34:43.207012804Z",
          "line": "npm WARN deprecated querystring@0.2.0: The querystring API is considered Legacy. new code should use the URLSearchParams API instead.\n"
        },
        {
          "timestamp": "2022-10-06T22:34:43.236380318Z",
          "line": "npm WARN deprecated read-package-tree@5.3.1: The functionality that this package provided is now in @npmcli/arborist\n"
        },
        {
          "timestamp": "2022-10-06T22:34:50.108263451Z",
          "line": "\n"
        },
        {
          "timestamp": "2022-10-06T22:34:50.108270709Z",
          "line": "added 163 packages, and audited 164 packages in 12s\n"
        }
      ]
    }
    

    Getting logs for individual steps

    Step logs return logs for individual steps of the deployment. This is helpful to walk through logs of a single step, or start requesting logs in the middle of the deployment.

    There are no more logs in the step if there is no nextOffset included in the response.

    The following query parameters are available:

    • job: The zero-indexed job number to request logs for (currently always 0).
    • step: The step of the deployment to return logs for (starts at 1).
    • offset: The line offset from the beginning of the step logs (returned as nextOffset in the response).
    • count: The batch size of lines to return (defaults to 100).
    Example

    Request

    # Get logs for a deployment starting at the zero offset and a count size of 10
    curl -i -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/2ee5b292-28bb-44a5-8532-b6ac32f4ec49/logs/?step=5&count=10&offset=0"
    

    Response

    {
        "nextOffset": 10,
        "lines": [
            {
                "timestamp": "2022-09-14T18:07:26.012974756Z",
                "line": "Updating (k8s/dev)\n"
            },
            {
                "timestamp": "2022-09-14T18:07:26.013002465Z",
                "line": "\n"
            },
            {
                "timestamp": "2022-09-14T18:07:26.637569798Z",
                "line": "\n"
            },
            {
                "timestamp": "2022-09-14T18:07:30.834521134Z",
                "line": "    pulumi:pulumi:Stack resource-test-dev running \n"
            },
            {
                "timestamp": "2022-09-14T18:07:39.927540055Z",
                "line": "    pulumi:pulumi:Stack resource-test-dev running Done!\n"
            },
            {
                "timestamp": "2022-09-14T18:07:40.210973346Z",
                "line": "    pulumi:pulumi:Stack resource-test-dev  1 message\n"
            },
            {
                "timestamp": "2022-09-14T18:07:40.211008513Z",
                "line": " \n"
            },
            {
                "timestamp": "2022-09-14T18:07:40.211811513Z",
                "line": "Diagnostics:\n"
            },
            {
                "timestamp": "2022-09-14T18:07:40.211861221Z",
                "line": "  pulumi:pulumi:Stack (resource-test-dev):\n"
            },
            {
                "timestamp": "2022-09-14T18:07:40.211863638Z",
                "line": "    Done!\n"
            }
        ]
    }
    

    Pause Deployments

    Pauses all queued deployments for a stack or organization. Deployments that are already running are allowed to complete and are not paused. New deployments are queued, and will run when the stack or organization’s deployments are resumed.

    Only organization administrators can pause deployments for an organization.

    Note that you can only pause deployments for a stack that has deployment settings configured.

    // Pauses new deployments for a stack
    POST https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/pause
    
    // Pauses new deployments for an organization
    POST https://api.pulumi.com/api/orgs/{organization}/deployments/pause
    

    Example

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/pause"
    

    Resume Deployments

    Resumes deployments for a stack or organization. This will cause queued deployments to start being processed.

    // Resumes deployment for a stack
    POST https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/resume
    
    // Resumes deployments for an organization
    POST https://api.pulumi.com/api/orgs/{organization}/deployments/resume
    

    Example

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stack/my-org/aws-ts-s3-folder/dev/deployments/resume"
    

    Get Deployments Metadata

    Get metadata related to deployments for a stack or organization. This includes information such as if deployments are paused, and why they’re paused.

    // Get deployments metadata for a stack
    GET https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/metadata
    
    // Get deployments metadata for an organization
    GET https://api.pulumi.com/api/orgs/{organization}/deployments/metadata
    

    Example

    Request
    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stack/my-org/aws-ts-s3-folder/dev/deployments/metadata"
    
    Response
    {
      "paused": true,
      "stackPaused": false,
      "organizationPaused": true
    }
    
    Request
    curl -XGET -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/orgs/my-org/deployments/metadata"
    
    Response
    {
      "paused": false,
      "pausedStacks": ["aws-ts-s3-folder/dev", "aws-ts-s3-folder/staging"],
      "concurrency": 1,
      "deploymentCounts": {
        "notStarted": 2,
        "accepted": 0,
        "running": 0,
        "failed": 0,
        "succeeded": 5,
        "skipped": 0,
        "total": 7
      }
    }
    

    Cancel Deployment

    Cancels an in-progress deployment.

    Canceling a deployment is a very dangerous action and may leave the stack in an inconsistent state if the deployment is canceled during the execution of a Pulumi operation.
    POST https://api.pulumi.com/api/stacks/{organization}/{project}/{stack}/deployments/{deploymentID}/cancel
    

    Example

    curl -i -XPOST -H "Content-Type: application/json" \
    -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
    --location "https://api.pulumi.com/api/stacks/my-org/aws-ts-s3-folder/dev/deployments/2ee5b292-28bb-44a5-8532-b6ac32f4ec49/cancel"
    
      PulumiUP - September 18, 2024. Register Now.