Add ci
This commit is contained in:
@ -2,10 +2,52 @@
|
||||
set -euo pipefail
|
||||
|
||||
# Publish Docker image to GitHub Container Registry
|
||||
# Usage: ./publish-docker.sh [tag] [username]
|
||||
# Usage: ./publish-docker.sh [tag] [username] [--platform=platform] [--build-and-push]
|
||||
|
||||
GITHUB_USERNAME="anosatsuk124"
|
||||
TAG="latest"
|
||||
PLATFORM=""
|
||||
BUILD_AND_PUSH=false
|
||||
BUILD_ARGS=()
|
||||
|
||||
# Parse arguments
|
||||
while [[ $# -gt 0 ]]; do
|
||||
case $1 in
|
||||
--platform=*)
|
||||
PLATFORM="${1#*=}"
|
||||
shift
|
||||
;;
|
||||
--platform)
|
||||
PLATFORM="$2"
|
||||
shift 2
|
||||
;;
|
||||
--build-and-push)
|
||||
BUILD_AND_PUSH=true
|
||||
shift
|
||||
;;
|
||||
--username=*)
|
||||
GITHUB_USERNAME="${1#*=}"
|
||||
shift
|
||||
;;
|
||||
-*)
|
||||
BUILD_ARGS+=("$1")
|
||||
shift
|
||||
;;
|
||||
*)
|
||||
if [[ -z "${TAG_SET:-}" ]]; then
|
||||
TAG="$1"
|
||||
TAG_SET=true
|
||||
elif [[ -z "${USERNAME_SET:-}" ]]; then
|
||||
GITHUB_USERNAME="$1"
|
||||
USERNAME_SET=true
|
||||
else
|
||||
BUILD_ARGS+=("$1")
|
||||
fi
|
||||
shift
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
GITHUB_USERNAME="${2:-anosatsuk124}"
|
||||
TAG="${1:-latest}"
|
||||
LOCAL_IMAGE="voice-rss-summary:${TAG}"
|
||||
GHCR_IMAGE_1="ghcr.io/${GITHUB_USERNAME}/voice-rss-summary:${TAG}"
|
||||
GHCR_IMAGE_2="ghcr.io/${GITHUB_USERNAME}/voicersssummary:${TAG}"
|
||||
@ -13,11 +55,37 @@ GHCR_IMAGE_2="ghcr.io/${GITHUB_USERNAME}/voicersssummary:${TAG}"
|
||||
echo "Publishing Docker image to GitHub Container Registry"
|
||||
echo "Local image: ${LOCAL_IMAGE}"
|
||||
echo "GHCR images: ${GHCR_IMAGE_1}, ${GHCR_IMAGE_2}"
|
||||
if [[ -n "$PLATFORM" ]]; then
|
||||
echo "Target platform: ${PLATFORM}"
|
||||
fi
|
||||
|
||||
# Build image if requested
|
||||
if [[ "$BUILD_AND_PUSH" == "true" ]]; then
|
||||
echo "Building image first..."
|
||||
BUILD_CMD=(./build-docker-image.sh "$TAG")
|
||||
if [[ -n "$PLATFORM" ]]; then
|
||||
BUILD_CMD+=(--platform "$PLATFORM")
|
||||
fi
|
||||
if [[ ${#BUILD_ARGS[@]} -gt 0 ]]; then
|
||||
BUILD_CMD+=("${BUILD_ARGS[@]}")
|
||||
fi
|
||||
|
||||
echo "Running: ${BUILD_CMD[*]}"
|
||||
if ! "${BUILD_CMD[@]}"; then
|
||||
echo "Error: Failed to build image"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
# Check if local image exists
|
||||
if ! docker image inspect "${LOCAL_IMAGE}" >/dev/null 2>&1; then
|
||||
echo "Error: Local Docker image '${LOCAL_IMAGE}' not found"
|
||||
echo "Build it first with: ./build-docker-image.sh ${TAG}"
|
||||
if [[ -n "$PLATFORM" ]]; then
|
||||
echo "Build it first with: ./build-docker-image.sh ${TAG} --platform=${PLATFORM}"
|
||||
else
|
||||
echo "Build it first with: ./build-docker-image.sh ${TAG}"
|
||||
fi
|
||||
echo "Or use --build-and-push flag to build and push in one command"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
@ -62,9 +130,16 @@ echo ""
|
||||
echo "Images available at:"
|
||||
echo " - ${GHCR_IMAGE_1}"
|
||||
echo " - ${GHCR_IMAGE_2}"
|
||||
if [[ -n "$PLATFORM" ]]; then
|
||||
echo "Platform: ${PLATFORM}"
|
||||
fi
|
||||
echo ""
|
||||
echo "To run from GHCR:"
|
||||
echo " docker run -p 3000:3000 -p 3001:3001 ${GHCR_IMAGE_1}"
|
||||
if [[ -n "$PLATFORM" && "$PLATFORM" != "$(uname -m)" ]]; then
|
||||
echo " docker run --platform ${PLATFORM} -p 3000:3000 -p 3001:3001 ${GHCR_IMAGE_1}"
|
||||
else
|
||||
echo " docker run -p 3000:3000 -p 3001:3001 ${GHCR_IMAGE_1}"
|
||||
fi
|
||||
echo ""
|
||||
echo "To update run-docker.sh to use GHCR:"
|
||||
echo "To use with run-docker.sh:"
|
||||
echo " ./run-docker.sh container-name ${TAG} --from-ghcr"
|
Reference in New Issue
Block a user