mirror of
https://github.com/coder/coder.git
synced 2025-07-15 22:20:27 +00:00
docs: clone git repositories (#14090)
This commit is contained in:
72
docs/guides/cloning-git-repositories.md
Normal file
72
docs/guides/cloning-git-repositories.md
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
# Cloning Git Repositories
|
||||||
|
|
||||||
|
<div style="padding: 0px; margin: 0px;">
|
||||||
|
<span style="vertical-align:middle;">Author: </span>
|
||||||
|
<a href="https://github.com/BrunoQuaresma" style="text-decoration: none; color: inherit; margin-bottom: 0px;">
|
||||||
|
<span style="vertical-align:middle;">Bruno Quaresma</span>
|
||||||
|
<img src="https://avatars.githubusercontent.com/u/3165839?v=4" width="24px" height="24px" style="vertical-align:middle; margin: 0px;"/>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
August 06, 2024
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
When starting to work on a project, engineers usually need to clone a Git
|
||||||
|
repository. Even though this is often a quick step, it can be automated using
|
||||||
|
the [Coder Registry](https://registry.coder.com/) to make a seamless Git-first
|
||||||
|
workflow.
|
||||||
|
|
||||||
|
The first step to enable Coder to clone a repository is to provide
|
||||||
|
authorization. This can be achieved by using the Git provider, such as GitHub,
|
||||||
|
as an authentication method. If you don't know how to do that, we have written
|
||||||
|
documentation to help you:
|
||||||
|
|
||||||
|
- [GitHub](https://coder.com/docs/admin/auth#github)
|
||||||
|
- [GitLab self-managed](https://coder.com/docs/admin/external-auth#gitlab-self-managed)
|
||||||
|
- [Self-managed git providers](https://coder.com/docs/admin/external-auth#self-managed-git-providers)
|
||||||
|
|
||||||
|
With the authentication in place, it is time to set up the template to use the
|
||||||
|
[Git Clone module](https://registry.coder.com/modules/git-clone) from the
|
||||||
|
[Coder Registry](https://registry.coder.com/) by adding it to our template's
|
||||||
|
Terraform configuration.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
module "git-clone" {
|
||||||
|
source = "registry.coder.com/modules/git-clone/coder"
|
||||||
|
version = "1.0.12"
|
||||||
|
agent_id = coder_agent.example.id
|
||||||
|
url = "https://github.com/coder/coder"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> You can edit the template using an IDE or terminal of your preference, or by
|
||||||
|
> going into the
|
||||||
|
> [template editor UI](https://coder.com/docs/templates/creating#editing-templates).
|
||||||
|
|
||||||
|
You can also use
|
||||||
|
[template parameters](https://coder.com/docs/templates/parameters) to customize
|
||||||
|
the Git URL and make it dynamic for use cases where a template supports multiple
|
||||||
|
projects.
|
||||||
|
|
||||||
|
```hcl
|
||||||
|
data "coder_parameter" "git_repo" {
|
||||||
|
name = "git_repo"
|
||||||
|
display_name = "Git repository"
|
||||||
|
default = "https://github.com/coder/coder"
|
||||||
|
}
|
||||||
|
|
||||||
|
module "git-clone" {
|
||||||
|
source = "registry.coder.com/modules/git-clone/coder"
|
||||||
|
version = "1.0.12"
|
||||||
|
agent_id = coder_agent.example.id
|
||||||
|
url = data.coder_parameter.git_repo.value
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> If you need more customization, you can read the
|
||||||
|
> [Git Clone module](https://registry.coder.com/modules/git-clone) documentation
|
||||||
|
> to learn more about the module.
|
||||||
|
|
||||||
|
Don't forget to build and publish the template changes before creating a new
|
||||||
|
workspace. You can check if the repository is cloned by accessing the workspace
|
||||||
|
terminal and listing the directories.
|
@ -1172,6 +1172,11 @@
|
|||||||
"title": "Scanning Coder Workspaces with JFrog Xray",
|
"title": "Scanning Coder Workspaces with JFrog Xray",
|
||||||
"description": "Integrate Coder with JFrog Xray",
|
"description": "Integrate Coder with JFrog Xray",
|
||||||
"path": "./guides/xray-integration.md"
|
"path": "./guides/xray-integration.md"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": "Cloning Git Repositories",
|
||||||
|
"description": "Automatically clone Git repositories into your workspace",
|
||||||
|
"path": "./guides/cloning-git-repositories.md"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user