docs/integrations/prefect-gitlab/index.mdx
The prefect-gitlab library makes it easy to interact with GitLab repositories and credentials.
prefect-gitlabThe following command will install a version of prefect-gitlab compatible with your installed version of prefect.
If you don't already have prefect installed, it will install the newest version of prefect as well.
pip install "prefect[gitlab]"
Upgrade to the latest versions of prefect and prefect-gitlab:
pip install -U "prefect[gitlab]"
Register the block types in the prefect-gitlab module to make them available for use.
prefect block register -m prefect_gitlab
In the examples below, you create blocks with Python code. Alternatively, blocks can be created through the Prefect UI.
To create a deployment where the flow code is stored in a private GitLab repository, you can use the GitLabCredentials block.
A deployment can use flow code stored in a GitLab repository without using this library in either of the following cases:
Code to create a GitLab Credentials block:
from prefect_gitlab import GitLabCredentials
gitlab_credentials_block = GitLabCredentials(token="my_token")
gitlab_credentials_block.save(name="my-gitlab-credentials-block")
Use the credentials block you created above to pass the GitLab access token during deployment creation. The code below assumes there's flow code in your private GitLab repository.
from prefect import flow
from prefect.runner.storage import GitRepository
from prefect_gitlab import GitLabCredentials
if __name__ == "__main__":
source = GitRepository(
url="https://gitlab.com/org/private-repo.git",
credentials=GitLabCredentials.load("my-gitlab-credentials-block")
)
source = GitRepository(
flow.from_source(
source=source,
entrypoint="my_file.py:my_flow",
).deploy(
name="private-gitlab-deploy",
work_pool_name="my_pool",
)
Alternatively, if you use a prefect.yaml file to create the deployment, reference the GitLab Credentials block in the pull step:
pull:
- prefect.deployments.steps.git_clone:
repository: https://github.com/org/repo.git
credentials: "{{ prefect.blocks.gitlab-credentials.my-gitlab-credentials-block }}"
The code below shows how to reference a particular branch or tag of a GitLab repository.
from prefect_gitlab import GitLabRepository
def save_private_gitlab_block():
private_gitlab_block = GitLabRepository(
repository="https://gitlab.com/testing/my-repository.git",
access_token="YOUR_GITLAB_PERSONAL_ACCESS_TOKEN",
reference="branch-or-tag-name",
)
private_gitlab_block.save("my-private-gitlab-block")
if __name__ == "__main__":
save_private_gitlab_block()
Exclude the access_token field if the repository is public and exclude the reference field to use the default branch.
Use the newly created block to interact with the GitLab repository.
For example, download the repository contents with the .get_directory() method like this:
from prefect_gitlab.repositories import GitLabRepository
def fetch_repo():
private_gitlab_block = GitLabRepository.load("my-gitlab-block")
private_gitlab_block.get_directory()
if __name__ == "__main__":
fetch_repo()
For assistance using GitLab, consult the GitLab documentation.
Refer to the prefect-gitlab SDK documentation to explore all the capabilities of the prefect-gitlab library.