DevOpsToolBox
CICD's
Bitbucket Cicd

πŸš€ Bitbucket Deployment Approval Process Setup Guide

This document outlines the setup for deployment approvals in Bitbucket Pipelines using deployment environments with access controls, instead of manual triggers in the pipeline YAML.


πŸ“Œ Why Use Deployment Environments?

Bitbucket’s deployment feature allows you to:

  • Control who can deploy to staging or production
  • Require pull request approval before deployment
  • Maintain an audit log of deployments
  • Reduce the risk of unauthorized production pushes

This is far more secure and auditable compared to trigger: manual.


βš™οΈ Step 1 – Define Environments in bitbucket-pipelines.yml

Update your pipeline to use deployment: instead of trigger: manual.

pipelines:
  branches:
    staging:
      - step:
          name: Build and Prepare
          script:
            - echo "Building app..."
            - go build -o app
          artifacts:
            - app
      - step:
          name: Deploy to Staging
          deployment: staging   # Link to "staging" environment
          runs-on:
            - self.hosted
            - linux.shell
            - nsestaging
          script:
            - echo "Deploying to STAGING..."
            - cp app /path/to/application/code
 
  tags:
    v*:
      - step:
          name: Build for Production
          script:
            - go build -o app
          artifacts:
            - app
      - step:
          name: Deploy to Production
          deployment: production   # Link to "production" environment
          runs-on:
            - self.hosted
            - linux.shell
            - nseprod
          script:
            - echo "Deploying to PRODUCTION..."
            - cp app /path/to/application/code

βš™οΈ Step 2 – Configure Deployment Environments in Bitbucket

  1. Navigate to Repository Settings β†’ Deployments

  2. Add new environments:

    • staging
    • production
  3. Each environment will now be available in Pipelines.


πŸ”’ Step 3 – Set Deployment Permissions

For each environment:

  1. Go to Repository Settings β†’ Deployments β†’ [Environment] β†’ Permissions

  2. Define which groups or users can deploy:

    • Staging: Allow DevOps + Senior Developers
    • Production: Allow only Release Managers or Ops
  3. Optionally, enable:

    • βœ… Require pull request approval before deployment
    • βœ… Restrict deployments from specific branches (e.g., only main)

πŸ“ Example Approval Flow

  1. A developer merges a feature branch into main.
  2. The pipeline builds the artifact.
  3. For staging, only approved users can run the deploy step.
  4. For production, a tag (v1.0.0) must be created, and only authorized approvers can deploy.

πŸ“Š Benefits

  • Audit trail – Who deployed, what commit, when.
  • Access control – Only specific users can trigger staging/production releases.
  • Reduced risk – No accidental deploys by unauthorized users.
  • Governance – Enforced approval workflows aligned with DevOps best practices.

βœ… With this setup, deployments are secure, auditable, and approval-gated by role, not just by repository access.


πŸ§™ AI Wizard - Instant Page Insights

Click the button below to analyze this page.
Get an AI-generated summary and key insights in seconds.
Powered by Perplexity AI!