--- display_name: Git Clone description: Clone a Git repository by URL and skip if it exists. icon: ../.icons/git.svg maintainer_github: coder verified: true tags: [git, helper] --- # Git Clone This module allows you to automatically clone a repository by URL and skip if it exists in the base directory provided. ```tf module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.2" agent_id = coder_agent.example.id url = "https://github.com/coder/coder" } ``` ## Examples ### Custom Path ```tf module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.2" agent_id = coder_agent.example.id url = "https://github.com/coder/coder" base_dir = "~/projects/coder" } ``` ### Git Authentication To use with [Git Authentication](https://coder.com/docs/v2/latest/admin/git-providers), add the provider by ID to your template: ```tf module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.2" agent_id = coder_agent.example.id url = "https://github.com/coder/coder" } data "coder_git_auth" "github" { id = "github" } ``` ## GitHub clone with branch name To GitHub clone with a specific branch like `feat/example` ```tf # Prompt the user for the git repo URL data "coder_parameter" "git_repo" { name = "git_repo" display_name = "Git repository" default = "https://github.com/coder/coder/tree/feat/example" } module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.11" agent_id = coder_agent.example.id url = data.coder_parameter.git_repo.value } ``` Configuring `git-clone` for a self-hosted GitHub Enterprise Server running at `github.example.com` ```tf module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.11" agent_id = coder_agent.example.id url = "https://github.example.com/coder/coder/tree/feat/example" git_providers = { "https://github.example.com/" = { tree_path = "github" } } } ``` ## GitLab clone with branch name To GitLab clone with a specific branch like `feat/example` ```tf module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.11" agent_id = coder_agent.example.id url = "https://gitlab.com/coder/coder/-/tree/feat/example" } ``` Configuring `git-clone` for a self-hosted GitLab running at `gitlab.example.com` ```tf module "git-clone" { source = "registry.coder.com/modules/git-clone/coder" version = "1.0.11" agent_id = coder_agent.example.id url = "https://gitlab.example.com/coder/coder/-/tree/feat/example" git_providers = { "https://gitlab.example.com/" = { tree_path = "gitlab" } } } ```