GitXplorerGitXplorer
d

setup-git-credentials

public
91 stars
20 forks
2 issues

Commits

List of commits on branch main.
Unverified
67447d5ea81a0f4d0685f1c68c354e81d1784322

Bump version to 2.1.1.

dde-vri-es committed a year ago
Unverified
24475f38bd3e6b71f58e281f9c24bb5e3433e9d8

Downgrade node version to 16.

dde-vri-es committed a year ago
Unverified
953442f28f4a20cfdf8fa073f3293fa6ea2c41d6

Bump version to 2.1.0.

dde-vri-es committed a year ago
Verified
a018e7f35698a5065d8d16ddaf88158221156658

Merge pull request #27 from smlgbl/main

dde-vri-es committed a year ago
Unverified
4d73ff52ca43486bf936eb6b2566e47ff2f594f4

major: upgrade deps, node 20, actions

ssmlgbl committed a year ago
Verified
437c089dfafbbb421688162bf56d6613ca17c9d4

Merge pull request #24 from de-vri-es/more-windows-ci

dde-vri-es committed 2 years ago

README

The README file for this repository.

Configuring credentials

This action allows you to clone private git repositories using HTTP authentication. The credentials should be passed to the action through the credentials parameter. It is highly recommended to store the credentials in a secret and pass the secret to the action, rather than hard-coding the credentials in the configuration file.

Note that the checkout action already allows you to clone the main repository. This action is intended for downloading additional dependencies from private repositories.

The action stores the credentials in the file $XDG_CONFIG_HOME/git/credentials, and configures git to use it by calling git config --global credential.helper store/ The credentials should be list of URL patterns with authentication information. See man 7 git-credentials-store for more details.

Additionally, the action configures git to rewrite SSH URLs for GitHub repositories to HTTPS URLs. This allows dependencies to be specified using a SSH URLs for developers, while the CI system will automatically clone over HTTPS with the provided credentials.

It is advisable to generate an access token specifically for your workflow. Simply use the token in place of an account password in the credentials. Be sure to grant full access for the repo scope to the token, otherwise the token can not be used to clone private repositories. Without the right permissions, the clone will normally fail with a 404 error.

A sample configuration for a workflow is shown here:

name: Rust
on: [push]
jobs:
  build:
    runs-on: ubuntu-latest
    steps:
    - uses: de-vri-es/setup-git-credentials@v2
      with:
        credentials: ${{secrets.GIT_CREDENTIALS}}
    - uses: actions/checkout@v1
    - name: Build
      run: cargo +stable build --color=always
    - name: Run tests
      run: cargo +stable test --color=always

The credentials secret would contain something like this:

https://$username:$token@github.com/

It is also possible to provide additional credentials for different domains in the credentials list.

Why not use a plain SSH key?

In general, a plain SSH key would be a good solution too. However, at the moment Cargo (the Rust package manager) does not support SSH authentication other than through an SSH agent. SSH agents are not meant to be used non-interactively, so HTTPS authentication is a simpler solution.

If you can use plain SSH keys that may be easier.

Compatibility with custom runners

The latest version of this action runs on node20. If your custom runner doesn't support node20 yet, you can pin the action to v2.0 which runs on node16.