diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..d3752b4 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,29 @@ +name: Test action + +on: push + +jobs: + upload: + runs-on: self-hosted + steps: + - uses: actions/checkout@v4 + + - run: | + echo "Minio Test" >> test.txt + echo "Minio Test" >> test-wild.txt + + - uses: ./ + with: + url: https://s3.nubificus.com + access-key: ${{ secrets.AWS_ACCESS_KEY }} + secret-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + local-path: "./test.txt" + remote-path: "github/minio/" + + - uses: ./ + with: + url: https://s3.nubificus.com + access-key: ${{ secrets.AWS_ACCESS_KEY }} + secret-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + local-path: "./*.txt" + remote-path: "github/minio/" diff --git a/Dockerfile b/Dockerfile deleted file mode 100644 index 7e631b6..0000000 --- a/Dockerfile +++ /dev/null @@ -1,5 +0,0 @@ -FROM cloudkernels/mc - -COPY entrypoint.sh /entrypoint.sh - -ENTRYPOINT ["/entrypoint.sh"] diff --git a/action.yml b/action.yml index 70c2742..b6a9681 100644 --- a/action.yml +++ b/action.yml @@ -24,13 +24,52 @@ inputs: required: false runs: - using: 'docker' - image: 'Dockerfile' - entrypoint: '/entrypoint.sh' - args: - - ${{ inputs.url }} - - ${{ inputs.access-key }} - - ${{ inputs.secret-key }} - - ${{ inputs.local-path }} - - ${{ inputs.remote-path }} - - ${{ inputs.policy }} + using: composite + steps: + - name: Setup mc + working-directory: /usr/local/bin + run: | + [ -n "$(which mc)" ] && exit 0 + arch=$(dpkg --print-architecture | sed 's/armhf/arm/g') + sudo wget --progres=dot:binary \ + "https://dl.min.io/client/mc/release/linux-${arch}/mc" + sudo chmod +x mc + shell: bash + + - name: Setup s3 alias + run: | + mc alias set s3 "${{ inputs.url }}" \ + "${{ inputs.access-key }}" "${{ inputs.secret-key }}" + shell: bash + + - name: Upload objects + run: | + local_path=${{ inputs.local-path }} + if [ "${local_path#*'*'}" != "$local_path" ]; then + # Handle local_files with wildcards + local_dir=$(dirname "$local_path") + local_files=$(basename "$local_path") + path_depth=$(echo "$local_dir" | awk -F"/" '{print NF-1}') + IFS=$'\n' + for p in $(mc find "$local_dir" \ + --name "$local_files" --maxdepth "$path_depth"); do + echo "p: $p" + echo "-----------" + mc cp -r "$p" "s3/${{ inputs.remote-path }}" + done + unset IFS + else + mc cp -r "$local_path" "s3/${{ inputs.remote-path }}" + fi + shell: bash + + - name: Set policy + run: | + if [ "${{ inputs.policy }}" = 1 ] ; then + echo "Will make ${{ inputs.remote-path }} public" + mc anonymous -r set download "s3/${{ inputs.remote-path }}" + else + echo "Will make ${{ inputs.remote-path }} private" + mc anonymous -r set private "s3/${{ inputs.remote-path }}" || true + fi + shell: bash diff --git a/entrypoint.sh b/entrypoint.sh deleted file mode 100755 index 6328bd7..0000000 --- a/entrypoint.sh +++ /dev/null @@ -1,58 +0,0 @@ -#!/bin/bash - -LOG_NAME="minio" - -info() { - [ -t 1 ] && [ -n "$TERM" ] \ - && echo "$(tput setaf 2)[$LOG_NAME]$(tput sgr0) $*" \ - || echo "[$LOG_NAME] $*" -} - -err() { - [ -t 2 ] && [ -n "$TERM" ] \ - && echo -e "$(tput setaf 1)[$LOG_NAME]$(tput sgr0) $*" 1>&2 \ - || echo -e "[$LOG_NAME] $*" 1>&2 -} - -die() { - err "$@" - exit 1 -} - -ok_or_die() { - if [ $? -ne 0 ]; then - die "$1" - fi -} - -if [[ $# -lt 5 ]] ; then - die "Usage: $0 url access_key secret_key local_path remote_path" -fi - -url=$1 -access_key=$2 -secret_key=$3 -local_path=$4 -remote_path=$5 - -info "Will upload $local_path to $remote_path" - -mc alias set s3 "$url" "$access_key" "$secret_key" -ok_or_die "Could not set mc alias" - -IFS=$'\n' -for p in $(eval ls -d -1 "$local_path"); do - mc cp -r "$p" s3/"$remote_path"; -done -unset IFS -ok_or_die "Could not upload object" - -if [[ $# -eq 6 ]] ; then - if [[ $6 -eq 1 ]] ; then - info "Will make $remote_path public" - mc anonymous -r set download s3/"$remote_path" - else - info "Will make $remote_path private" - mc anonymous -r set private s3/"$remote_path" || true - fi -fi