Merge pull request #35 from zzorica/allow-private-helm-repo-auth-in-dependencies

Allow private helm repo auth in dependencies
This commit is contained in:
Stefan Prodan 2022-11-16 11:10:07 +02:00 committed by GitHub
commit 0ad2bb3773
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 17 additions and 8 deletions

View file

@ -20,7 +20,7 @@ Inputs:
* `chart_version` Explicitly specify chart version in package. If not defined then used chart values. * `chart_version` Explicitly specify chart version in package. If not defined then used chart values.
* `index_dir` The location of `index.yaml` file in the repo, defaults to the same value as `target_dir` * `index_dir` The location of `index.yaml` file in the repo, defaults to the same value as `target_dir`
* `enterprise_url` The URL of enterprise github server in the format `<server-url>/<organisation>` * `enterprise_url` The URL of enterprise github server in the format `<server-url>/<organisation>`
* `dependencies` A list of helm repositories required to verify dependencies in the format `<name>,<url>;<name>,<url>` * `dependencies` A list of helm repositories required to verify dependencies in the format `<name>,<url>;<name>,<url>` or if using private repositories `<name>,<username>,<password>,<url>;<name>,<username>,<password>,<url>`. Combinations are allowed.
## Examples ## Examples

View file

@ -35,7 +35,7 @@ inputs:
commit_username: commit_username:
description: "The user name used for the commit user" description: "The user name used for the commit user"
required: false required: false
default: ${{ github.actor }} default: ${{ github.actor }}
commit_email: commit_email:
description: "The email used for the commit user" description: "The email used for the commit user"
required: false required: false
@ -54,7 +54,7 @@ inputs:
required: false required: false
dependencies: dependencies:
description: "A list of helm repositories required to verify dependencies in the format '<name>,<url>;<name>,<url>'" description: "A list of helm repositories required to verify dependencies in the format '<name>,<url>;<name>,<url>'"
required: false required: false
runs: runs:
using: 'docker' using: 'docker'
image: 'Dockerfile' image: 'Dockerfile'

View file

@ -75,9 +75,9 @@ main() {
if [[ -z "$REPO_URL" ]]; then if [[ -z "$REPO_URL" ]]; then
if [[ -z "$ENTERPRISE_URL" ]]; then if [[ -z "$ENTERPRISE_URL" ]]; then
REPO_URL="https://x-access-token:${GITHUB_TOKEN}@github.com/${OWNER}/${REPOSITORY}" REPO_URL="https://x-access-token:${GITHUB_TOKEN}@github.com/${OWNER}/${REPOSITORY}"
else else
REPO_URL="https://x-access-token:${GITHUB_TOKEN}@${ENTERPRISE_URL}/${REPOSITORY}" REPO_URL="https://x-access-token:${GITHUB_TOKEN}@${ENTERPRISE_URL}/${REPOSITORY}"
fi fi
fi fi
if [[ -z "$COMMIT_USERNAME" ]]; then if [[ -z "$COMMIT_USERNAME" ]]; then
@ -129,9 +129,18 @@ download() {
get_dependencies() { get_dependencies() {
IFS=';' read -ra dependency <<< "$DEPENDENCIES" IFS=';' read -ra dependency <<< "$DEPENDENCIES"
for repos in ${dependency[@]}; do for repos in ${dependency[@]}; do
name=$(cut -f 1 -d, <<< "$repos") result=$( echo $repos|awk -F',' '{print NF}' )
url=$(cut -f 2 -d, <<< "$repos") if [[ $result -gt 2 ]]; then
helm repo add ${name} ${url} name=$(cut -f 1 -d, <<< "$repos")
username=$(cut -f 2 -d, <<< "$repos")
password=$(cut -f 3 -d, <<< "$repos")
url=$(cut -f 4 -d, <<< "$repos")
helm repo add ${name} --username ${username} --password ${password} ${url}
else
name=$(cut -f 1 -d, <<< "$repos")
url=$(cut -f 2 -d, <<< "$repos")
helm repo add ${name} ${url}
fi
done done
} }