Cloning another Bitbucket repository in Bitbucket Pipelines
I recently had a use-case where I wanted to clone another Bitbucket repository during a Pipelines execution. Doing this is very simple, but there is a lot of conflicting information online, so I thought I would document the steps here.
Imagine a very simple Pipeline that looks like this:
pipelines:
default:
- step:
script:
- git clone git@bitbucket.org:ayushsharma/my-submodules.git
The repository that triggers the Pipeline will need permission to clone my-submodules
.
Create SSH keys for the main repository
In Bitbucket, go to the repository SSH keys page under Settings > Pipelines > SSH keys
.
data:image/s3,"s3://crabby-images/a50bb/a50bb973b412fa8bf6c2a3f1df2dc4ee60679b95" alt="Cloning another Bitbucket repository in Bitbucket Pipelines - Settings > Pipelines > SSH keys"
Next, click on Generate keys
to let Bitbucket auto-generate a random, secure SSH key-pair. You can also upload a custom key-pair if you want.
data:image/s3,"s3://crabby-images/8f0bb/8f0bb6ab951b42b051830e38563d04fd6165e446" alt="Cloning another Bitbucket repository in Bitbucket Pipelines - Generate keys"
Once completed, click Copy public key
. We will need to paste this in the next step.
Add SSH public key in the target repository
Go to the my-submodules
repository. Under Settings > General > Access keys
, you should see the option to add SSH public keys to gain read-only access.
data:image/s3,"s3://crabby-images/3294a/3294a41b281ac6d171e70220710ba2d06443d0d2" alt="Cloning another Bitbucket repository in Bitbucket Pipelines - Settings > General > Access keys"
Click Add key
, enter a label, and paste the public key we copied in the previous step.
data:image/s3,"s3://crabby-images/a6ce1/a6ce18cc093725c6a6f33f596492e3b23fd08295" alt="Cloning another Bitbucket repository in Bitbucket Pipelines - Add key"
Our main repository now has read-only permissions to clone my-submodules
from within its Pipelines. After the above configuration, executing a build for the repository will show all-green.
data:image/s3,"s3://crabby-images/54457/544575332e33a272dad863228d74df56793e7777" alt="Cloning another Bitbucket repository in Bitbucket Pipelines - Successful deployment!"