feat: minio-upload
This commit is contained in:
parent
ebd9608380
commit
0ad61179b5
4 changed files with 101 additions and 0 deletions
5
minio-upload/Dockerfile
Normal file
5
minio-upload/Dockerfile
Normal file
|
@ -0,0 +1,5 @@
|
|||
FROM minio/mc:RELEASE.2024-06-24T19-40-33Z.fips
|
||||
|
||||
COPY entrypoint.sh /entrypoint.sh
|
||||
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
7
minio-upload/README.md
Normal file
7
minio-upload/README.md
Normal file
|
@ -0,0 +1,7 @@
|
|||
# minio Action
|
||||
|
||||
This action allows you to upload objects to a MinIO server
|
||||
|
||||
|
||||
---
|
||||
forked from https://github.com/cloudkernels/minio-upload
|
35
minio-upload/action.yml
Normal file
35
minio-upload/action.yml
Normal file
|
@ -0,0 +1,35 @@
|
|||
# action.yml
|
||||
|
||||
name: minio-upload
|
||||
description: "Action that lets you upload objects from a MinIO server"
|
||||
inputs:
|
||||
url:
|
||||
description: "URL of the MinIO server"
|
||||
required: true
|
||||
access-key:
|
||||
description: "Access Key for the MinIO server"
|
||||
required: true
|
||||
secret-key:
|
||||
description: "Secret Key for the MinIO server"
|
||||
required: true
|
||||
local-path:
|
||||
description: 'Path of the local object'
|
||||
required: true
|
||||
default: './'
|
||||
remote-path:
|
||||
description: 'Path to remote object'
|
||||
required: true
|
||||
policy:
|
||||
description: 'Policy'
|
||||
required: false
|
||||
|
||||
runs:
|
||||
using: 'docker'
|
||||
image: 'Dockerfile'
|
||||
args:
|
||||
- ${{ inputs.url }}
|
||||
- ${{ inputs.access-key }}
|
||||
- ${{ inputs.secret-key }}
|
||||
- ${{ inputs.local-path }}
|
||||
- ${{ inputs.remote-path }}
|
||||
- ${{ inputs.policy }}
|
54
minio-upload/entrypoint.sh
Executable file
54
minio-upload/entrypoint.sh
Executable file
|
@ -0,0 +1,54 @@
|
|||
#!/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"
|
||||
|
||||
mc cp -r $local_path s3/$remote_path
|
||||
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
|
Loading…
Add table
Reference in a new issue