https://github.com/markhilton/docker-git-clone
Docker image to clone requested github or bitbucket repository
https://github.com/markhilton/docker-git-clone
bitbucket deployment git github init-containers kubernetes rsa-key ssh-key
Last synced: 4 months ago
JSON representation
Docker image to clone requested github or bitbucket repository
- Host: GitHub
- URL: https://github.com/markhilton/docker-git-clone
- Owner: markhilton
- License: mit
- Created: 2018-04-24T14:15:18.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-04-25T00:19:17.000Z (almost 8 years ago)
- Last Synced: 2025-04-22T18:26:01.489Z (9 months ago)
- Topics: bitbucket, deployment, git, github, init-containers, kubernetes, rsa-key, ssh-key
- Language: Shell
- Size: 3.91 KB
- Stars: 3
- Watchers: 1
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# docker-git-clone
Docker image to clone requested github or bitbucket repository.
## Use case
Kubernetes deployments where init containers usually copy/move code from docker container into emptyDir volume to share between other deployment containers.
In case of push to deploy instead of waiting for the Docker container to be build with a specific repository tag, use this universal container to specify deployment SSH key file authorized to clone requested repository code from specified branch or tag.
## Environment variables
### required
`REPO_LINK` - github or bitbucket repository SSH clone link
It is also required to mount a volume where the repository will be cloned from local file system into container `/repository` folder.
In case of private repositories you also have to mount deployment SSH key authorized to clone code repository
### optional
`TAG` - clone specified tag
`BRANCH` - clone specified branch (defaults to master)
`REPO_KEY` - RSA key filename (defaults to id_rsa)
if cloning using repository username/password instead SSH deployment key, please provide `REPO_LINK` without leading `https://`
`REPO_USER` - authorized user to clone requested repository
`REPO_PASS` - authorized user password to clone requested repository
## Example run
```
docker run --rm -ti \
-v /path/to/clone/repository:/repository \
-v /path/to/authorized/id_rsa:/key:ro \
-e REPO_LINK=crunchgeek/git-clone
-e REPO_BRANCH=master
-e REPO_TAG=1.0.0
crunchgeek/git-clone
```