Update .woodpecker.yml
This commit is contained in:
@@ -116,26 +116,20 @@ steps:
|
|||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
> projects-to-build.txt
|
> projects-to-build.txt
|
||||||
|
|
||||||
echo "=== DEBUG: Szukam plików .csproj ==="
|
|
||||||
find . -name "*.csproj" -type f
|
|
||||||
|
|
||||||
find . -name "*.csproj" -type f | while read csproj; do
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
echo "→ Sprawdzam: $csproj"
|
|
||||||
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
echo " ProjectType = $PROJECT_TYPE"
|
|
||||||
|
|
||||||
if [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
|
if [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
|
||||||
echo " → Pomijam (typ: $PROJECT_TYPE)"
|
:
|
||||||
else
|
else
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
PROJECT_DIR=$(dirname "$csproj")
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
echo "$PROJECT_DIR|$PROJECT_NAME" >> projects-to-build.txt
|
echo "$PROJECT_DIR|$PROJECT_NAME" >> projects-to-build.txt
|
||||||
echo " → Dodaję: $PROJECT_DIR|$PROJECT_NAME"
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
echo "=== DEBUG: Zawartość projects-to-build.txt ==="
|
echo "Znaleziono projektow do budowy:"
|
||||||
cat projects-to-build.txt
|
wc -l < projects-to-build.txt
|
||||||
depends_on: [publish-datamodels-to-baget]
|
depends_on: [publish-datamodels-to-baget]
|
||||||
containerize-apps:
|
containerize-apps:
|
||||||
image: docker:27-cli
|
image: docker:27-cli
|
||||||
@@ -149,67 +143,48 @@ steps:
|
|||||||
set -euf
|
set -euf
|
||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
echo "=== DEBUG: Zawartość projects-to-build.txt ==="
|
|
||||||
cat projects-to-build.txt || echo "Plik nie istnieje!"
|
|
||||||
|
|
||||||
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
||||||
|
|
||||||
if [ ! -s projects-to-build.txt ]; then
|
if [ ! -s projects-to-build.txt ]; then
|
||||||
echo "Brak projektów do zbudowania"
|
echo "Brak projektow"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
while IFS='|' read -r PROJECT_DIR PROJECT_NAME; do
|
cat projects-to-build.txt | while IFS='|' read -r PDIR PNAME; do
|
||||||
PROJECT_DIR=$(echo "$PROJECT_DIR" | xargs)
|
PDIR=$(echo "$PDIR" | xargs)
|
||||||
PROJECT_NAME=$(echo "$PROJECT_NAME" | xargs)
|
PNAME=$(echo "$PNAME" | xargs)
|
||||||
|
|
||||||
if [ -z "$PROJECT_NAME" ]; then
|
test -z "$PNAME" && continue
|
||||||
echo "OSTRZEŻENIE: Pusta nazwa projektu, pomijam"
|
test ! -d "$PDIR" && continue
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
PROJECT_NAME_LOWER=$(echo "$PROJECT_NAME" | tr '[:upper:]' '[:lower:]')
|
LOWER=$(echo "$PNAME" | tr 'A-Z' 'a-z')
|
||||||
|
TAG="git.modwad.pl/faapp/${LOWER}"
|
||||||
|
|
||||||
# Buduj string po kawałku, żeby uniknąć cenzurowania
|
cat > "${PDIR}/Dockerfile.temp" <<DOCKERFILEEND
|
||||||
ORG_NAME="faapp"
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
||||||
REGISTRY="git.modwad.pl"
|
WORKDIR /app
|
||||||
FULL_IMAGE="${REGISTRY}/${ORG_NAME}/${PROJECT_NAME_LOWER}"
|
EXPOSE 8080
|
||||||
|
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
||||||
|
WORKDIR /src
|
||||||
|
COPY . .
|
||||||
|
RUN dotnet restore "${PNAME}.csproj"
|
||||||
|
RUN dotnet publish "${PNAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
|
||||||
|
FROM base AS final
|
||||||
|
WORKDIR /app
|
||||||
|
COPY --from=build /app/publish .
|
||||||
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
|
ENTRYPOINT ["dotnet", "${PNAME}.dll"]
|
||||||
|
DOCKERFILEEND
|
||||||
|
|
||||||
echo "Projekt: ${PROJECT_NAME}"
|
|
||||||
echo "Obraz: ${FULL_IMAGE}"
|
|
||||||
|
|
||||||
if [ ! -d "$PROJECT_DIR" ]; then
|
|
||||||
echo "ERROR: Katalog $PROJECT_DIR nie istnieje!"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
|
|
||||||
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
|
||||||
WORKDIR /app
|
|
||||||
EXPOSE 8080
|
|
||||||
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
|
||||||
WORKDIR /src
|
|
||||||
COPY . .
|
|
||||||
RUN dotnet restore "${PROJECT_NAME}.csproj"
|
|
||||||
RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
|
|
||||||
FROM base AS final
|
|
||||||
WORKDIR /app
|
|
||||||
COPY --from=build /app/publish .
|
|
||||||
ENV ASPNETCORE_URLS=http://+:8080
|
|
||||||
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"]
|
|
||||||
EOF
|
|
||||||
|
|
||||||
echo "Buduję obraz..."
|
|
||||||
docker buildx build --platform linux/amd64 \
|
docker buildx build --platform linux/amd64 \
|
||||||
-t "${FULL_IMAGE}:${CI_COMMIT_SHA}" \
|
-t "${TAG}:${CI_COMMIT_SHA}" \
|
||||||
-t "${FULL_IMAGE}:latest" \
|
-t "${TAG}:latest" \
|
||||||
-f "${PROJECT_DIR}/Dockerfile.temp" \
|
-f "${PDIR}/Dockerfile.temp" \
|
||||||
"${PROJECT_DIR}"
|
"${PDIR}" 2>&1 | head -20
|
||||||
|
|
||||||
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
docker push "${TAG}:${CI_COMMIT_SHA}" 2>&1 | head -10
|
||||||
docker push "${FULL_IMAGE}:latest"
|
docker push "${TAG}:latest" 2>&1 | head -10
|
||||||
|
|
||||||
rm -f "${PROJECT_DIR}/Dockerfile.temp"
|
rm -f "${PDIR}/Dockerfile.temp"
|
||||||
echo "Opublikowano: ${FULL_IMAGE}:latest"
|
done
|
||||||
done < projects-to-build.txt
|
|
||||||
depends_on: [select-projects-for-container]
|
depends_on: [select-projects-for-container]
|
||||||
|
|||||||
Reference in New Issue
Block a user