Warehouses #22
@@ -117,41 +117,48 @@ steps:
|
|||||||
done
|
done
|
||||||
depends_on: [pack-datamodels]
|
depends_on: [pack-datamodels]
|
||||||
|
|
||||||
containerize-apps:
|
containerize-apps:
|
||||||
image: woodpeckerci/plugin-docker-buildx:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
environment:
|
volumes:
|
||||||
GITEA_USER:
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
from_secret: gitea_registry_user
|
environment:
|
||||||
GITEA_TOKEN:
|
GITEA_USER:
|
||||||
from_secret: gitea_registry_token
|
from_secret: gitea_registry_user
|
||||||
commands:
|
GITEA_TOKEN:
|
||||||
- |
|
from_secret: gitea_registry_token
|
||||||
set -euf
|
commands:
|
||||||
cd "${CI_WORKSPACE}"
|
- |
|
||||||
|
set -euf
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
echo "DEBUG: Użytkownik = '$GITEA_USER'"
|
# Instalacja Docker CLI i buildx (potrzebne w kontenerze .NET)
|
||||||
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN..."
|
apk update && apk add --no-cache docker docker-cli-buildx
|
||||||
|
# Uruchomienie dockerd jeśli potrzeba (nie zawsze wymagane przy sock)
|
||||||
|
# dockerd-entrypoint.sh & sleep 5 # opcjonalne, jeśli masz problemy z sock
|
||||||
|
|
||||||
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
echo "DEBUG: Użytkownik = '$GITEA_USER'"
|
||||||
|
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN:0:4..."
|
||||||
|
|
||||||
dotnet restore
|
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
||||||
|
|
||||||
find . -name "*.csproj" -type f | while read csproj; do
|
dotnet restore
|
||||||
PROJECT_DIR=$(dirname "$csproj")
|
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
|
||||||
|
|
||||||
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
|
|
||||||
if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)"
|
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
IMAGE_NAME="trent/${PROJECT_NAME,,}"
|
if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
|
||||||
FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
|
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
|
IMAGE_NAME="trent/${PROJECT_NAME,,}"
|
||||||
|
FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
|
||||||
|
|
||||||
|
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
|
||||||
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
EXPOSE 8080
|
EXPOSE 8080
|
||||||
@@ -167,20 +174,20 @@ steps:
|
|||||||
COPY --from=build /app/publish .
|
COPY --from=build /app/publish .
|
||||||
ENV ASPNETCORE_URLS=http://+:8080
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"]
|
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"]
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
echo "Buduję → ${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
echo "Buduję → ${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
||||||
docker buildx build --platform linux/amd64 \
|
docker buildx build --platform linux/amd64 \
|
||||||
-t "${FULL_IMAGE}:${CI_COMMIT_SHA}" \
|
-t "${FULL_IMAGE}:${CI_COMMIT_SHA}" \
|
||||||
-t "${FULL_IMAGE}:latest" \
|
-t "${FULL_IMAGE}:latest" \
|
||||||
-f "${PROJECT_DIR}/Dockerfile.temp" \
|
-f "${PROJECT_DIR}/Dockerfile.temp" \
|
||||||
"${PROJECT_DIR}"
|
"${PROJECT_DIR}"
|
||||||
|
|
||||||
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
||||||
docker push "${FULL_IMAGE}:latest"
|
docker push "${FULL_IMAGE}:latest"
|
||||||
|
|
||||||
rm -f "${PROJECT_DIR}/Dockerfile.temp"
|
rm -f "${PROJECT_DIR}/Dockerfile.temp"
|
||||||
|
|
||||||
echo "Opublikowano: ${FULL_IMAGE}:latest"
|
echo "Opublikowano: ${FULL_IMAGE}:latest"
|
||||||
done
|
done
|
||||||
depends_on: [publish-datamodels-to-baget]
|
depends_on: [publish-datamodels-to-baget]
|
||||||
Reference in New Issue
Block a user