1
0
mirror of https://github.com/tektoncd/catalog.git synced 2024-11-21 05:55:35 +00:00
catalog/stepaction/git-clone/0.1/README.md
Chitrang Patel 5168415df3 Add First StepAction git-clone to the catalog
This PR adds a first StepAction `git-clone` to the
catalog. It is based off the Task but with samples and
tests updated.
2024-03-08 13:39:32 +00:00

12 KiB

git-clone

Note: this StepAction is only compatible with Tekton Pipelines versions 0.54.0 and greater!

Note: this StepAction is not backwards compatible with the previous versions as it is now run as a non-root user!

This StepAction has two required inputs:

  1. The URL of a git repo to clone provided with the url param.
  2. A path called output-path which should be provided by a Workspace/Volume in a Task.

The git-clone StepAction will clone a repo from the provided url into the output-path directory. By default the repo will be cloned into the root of your directory. You can clone into a subdirectory by setting this StepAction's subdirectory param. If the directory where the repo will be cloned is already populated then by default the contents will be deleted before the clone takes place. This behaviour can be disabled by setting the deleteExisting param to "false".

Note: The git-clone StepAction is run as nonroot. The files cloned on to the output-path directory will end up owned by user 65532.

Workspace-Paths

Note: StepActions do not accept Workspaces. They only need the path to a directory which can be passed in via a param. The directory can be provided by the Task via a Workspace.

Note: This stepaction is executed in a Task as a non-root user with UID 65532 and GID 65532. Generally, the default permissions for storage volumes are configured for the root user. To make the volumes accessible by the non-root user, you will need to either configure the permissions manually or set the fsGroup field under PodSecurityContext in your TaskRun or PipelineRun.

An example PipelineRun will look like:

apiVersion: tekton.dev/v1beta1
kind: PipelineRun
metadata:
  generateName: git-clone-
spec:
  pipelineRef:
    name: git-clone-pipeline
  podTemplate:
    securityContext:
      fsGroup: 65532
...
...

An example TaskRun will look like:

apiVersion: tekton.dev/v1beta1
kind: TaskRun
metadata:
  name: taskrun
spec:
  taskRef:
    name: git-clone
  podTemplate:
    securityContext:
      fsGroup: 65532
...
...
  • output: An example workspace for this StepAction to fetch the git repository in to. Note: The underlying StepAction only needs the path which can be provided via the param as follows:

    params:
      - name: output-path
        value: $(workspaces.output.path)
    
  • ssh-directory: An optional workspace to provide SSH credentials. At minimum this should include a private key but can also include other common files from .ssh including config and known_hosts. It is strongly recommended that this workspace be bound to a Kubernetes Secret. Note: The underlying StepAction only needs the path which can be provided via the param as follows:

    params:
      - name: ssh-directory-path
        value: $(workspaces.ssh-directory.path)
    
  • ssl-ca-directory: An optional workspace to provide custom CA certificates. Like the /etc/ssl/certs path this directory can have any pem or cert files, this uses libcurl ssl capath directive. See this SO answer here https://stackoverflow.com/a/9880236 on how it works. Note: The underlying StepAction only needs the path which can be provided via the param as follows:

    params:
      - name: ssl-ca-directory-path
        value: $(workspaces.ssa-ca-directory.path)
    
  • basic-auth: An optional workspace containing .gitconfig and .git-credentials files. This allows username/password/access token to be provided for basic auth.

    It is strongly recommended that this workspace be bound to a Kubernetes Secret. For details on the correct format of the files in this Workspace see Using basic-auth Credentials below.

    Note: Settings provided as part of a .gitconfig file can affect the execution of git in ways that conflict with the parameters of this StepAction. For example, specifying proxy settings in .gitconfig could conflict with the httpProxy and httpsProxy parameters this StepAction provides. Nothing prevents you setting these parameters but it is not advised.

    Note: The underlying StepAction only needs the path which can be provided via the param as follows:

    params:
      - name: basic-auth-path
        value: $(workspaces.basic-auth.path)
    

Parameters

  • output-path: The git repo will be cloned onto this path
  • ssh-directory-path: A .ssh directory with private key, known_hosts, config, etc.
  • basic-auth-path: A directory path containing a .gitconfig and .git-credentials file.
  • ssl-ca-directory-path: A directory containing CA certificates, this will be used by Git to verify the peer with when fetching or pushing over HTTPS.
  • url: Repository URL to clone from. (required)
  • revision: Revision to checkout. (branch, tag, sha, ref, etc...) (default: "")
  • refspec: Refspec to fetch before checking out revision. (default:"")
  • submodules: Initialize and fetch git submodules. (default: true)
  • depth: Perform a shallow clone, fetching only the most recent N commits. (default: 1)
  • sslVerify: Set the http.sslVerify global git config. Setting this to false is not advised unless you are sure that you trust your git remote. (default: true)
  • crtFileName: If sslVerify is true and ssl-ca-directory workspace is given then set crtFileName if mounted file name is different than ca-bundle.crt. (default: "ca-bundle.crt")
  • subdirectory: Subdirectory inside the output workspace to clone the repo into. (default: "")
  • deleteExisting: Clean out the contents of the destination directory if it already exists before cloning. (default: true)
  • httpProxy: HTTP proxy server for non-SSL requests. (default: "")
  • httpsProxy: HTTPS proxy server for SSL requests. (default: "")
  • noProxy: Opt out of proxying HTTP/HTTPS requests. (default: "")
  • verbose: Log the commands that are executed during git-clone's operation. (default: true)
  • sparseCheckoutDirectories: Which directories to match or exclude when performing a sparse checkout (default: "")
  • gitInitImage: The image providing the git-init binary that this StepAction runs. (default: "gcr.io/tekton-releases/github.com/tektoncd/pipeline/cmd/git-init:TODO")
  • userHome: The user's home directory. (default: "/tekton/home")

Results

  • commit: The precise commit SHA that was fetched by this StepAction
  • url: The precise URL that was fetched by this StepAction
  • committer-date: The epoch timestamp of the commit that was fetched by this StepAction

Platforms

The StepAction can be run on linux/amd64, linux/s390x, linux/arm64, and linux/ppc64le platforms.

Usage

If the revision is not provided in the param of the taskrun then it will auto-detect the branch as specified by the default in the respective git repository.

The following pipelines demonstrate usage of the git-clone StepAction:

Cloning Private Repositories

This StepAction supports fetching private repositories. There are three ways to authenticate:

  1. The simplest approach is to bind an ssh-directory workspace to this StepAction. The workspace should contain private keys (e.g. id_rsa), config and known_hosts files - anything you need to interact with your git remote via SSH. It's strongly recommended that you use Kubernetes Secrets to hold your credentials and bind to this workspace.

    In a TaskRun that would look something like this:

    kind: TaskRun
    spec:
      workspaces:
      - name: ssh-directory
        secret:
          secretName: my-ssh-credentials
    

    And in a Pipeline and PipelineRun it would look like this:

    kind: Pipeline
    spec:
      workspaces:
      - name: ssh-creds
      # ...
      tasks:
      - name: fetch-source
        taskSpec:
          workspaces:
            - name: ssh-creds
          steps:
          - ref:
              name: git-clone
            params:
              - name: ssh-directory-path
                value: $(workspaces.ssh-creds.path)
        workspaces:
          -name: ssh-creds
      # ...
    ---
    kind: PipelineRun
    spec:
      workspaces:
      - name: ssh-creds
        secret:
          secretName: my-ssh-credentials
      # ...
    

    The Secret would appear the same in both cases - structured like a .ssh directory:

    kind: Secret
    apiVersion: v1
    metadata:
      name: my-ssh-credentials
    data:
      id_rsa: # ... base64-encoded private key ...
      known_hosts: # ... base64-encoded known_hosts file ...
      config: # ... base64-encoded ssh config file ...
    

    Including known_hosts is optional but strongly recommended. Without it the git-clone StepAction will blindly accept the remote server's identity.

  2. Use Tekton Pipelines' built-in credentials support as documented in Pipelines' auth.md.

  3. Another approach is to bind an ssl-ca-directory workspace to this StepAction. The workspace should contain crt keys (e.g. ca-bundle.crt)files - anything you need to interact with your git remote via custom CA . It's strongly recommended that you use Kubernetes Secrets to hold your credentials and bind to this workspace.

    In a TaskRun that would look something like this:

    kind: TaskRun
    spec:
      workspaces:
      - name: ssl-ca-directory
        secret:
          secretName: my-ssl-credentials
    

    And in a Pipeline and PipelineRun it would look like this:

    kind: Pipeline
    spec:
      workspaces:
      - name: ssl-creds
      # ...
      tasks:
      - name: fetch-source
        workspaces:
        - name: ssl-creds
        taskSpec:
          workspaces:
            - name: ssl-creds
          steps:
          - ref:
              name: git-clone
            params:
              - name: ssl-ca-directory-path
                value: $(workspaces.ssl-creds.path)
      # ...
    ---
    kind: PipelineRun
    spec:
      workspaces:
      - name: ssl-creds
        secret:
          secretName: my-ssl-credentials
      # ...
    

    The Secret would appear like below:

    kind: Secret
    apiVersion: v1
    metadata:
      name: my-ssl-credentials
    data:
      ca-bundle.crt: # ... base64-encoded crt ...  # If key/filename is other than ca-bundle.crt then set crtFileName param as explained under Parameters section
    

Using basic-auth Credentials

Note: It is strongly advised that you use ssh credentials when the option is available to you before using basic auth. You can generate a short lived token from WebVCS platforms (Github, Gitlab, Bitbucket etc..) to be used as a password and generally be able to use git as the username. On bitbucket server the token may have a / into it so you would need to urlquote them before in the Secret, see this stackoverflow answer :

https://stackoverflow.com/a/24719496

To support basic-auth this StepAction exposes an optional basic-auth Workspace. The bound Workspace must contain a .gitconfig and .git-credentials file. Any other files on this Workspace are ignored. A typical Secret containing these credentials looks as follows:

kind: Secret
apiVersion: v1
metadata:
  name: my-basic-auth-secret
type: Opaque
stringData:
  .gitconfig: |
    [credential "https://<hostname>"]
      helper = store    
  .git-credentials: |
    https://<user>:<pass>@<hostname>