Warehouses #22

Merged
trent merged 2 commits from Warehouses into master 2026-01-15 07:40:24 +00:00
Showing only changes of commit b309669102 - Show all commits

View File

@@ -11,14 +11,12 @@ steps:
- pwd - pwd
- ls -la - ls -la
- find /woodpecker -maxdepth 4 -type d 2>/dev/null - find /woodpecker -maxdepth 4 -type d 2>/dev/null
clone-manual: clone-manual:
image: woodpeckerci/plugin-git image: woodpeckerci/plugin-git
settings: settings:
remote: http://gitea:3000/FA/FA_WEB.git remote: http://gitea:3000/FA/FA_WEB.git
branch: master branch: master
depth: 1 depth: 1
restore: restore:
image: mcr.microsoft.com/dotnet/sdk:latest image: mcr.microsoft.com/dotnet/sdk:latest
commands: commands:
@@ -28,7 +26,6 @@ steps:
echo "Aktualna ścieżka: $(pwd)" echo "Aktualna ścieżka: $(pwd)"
echo "=== Restore wszystkich projektów ===" echo "=== Restore wszystkich projektów ==="
find . -name "*.csproj" -type f -exec dotnet restore "{}" \; find . -name "*.csproj" -type f -exec dotnet restore "{}" \;
test: test:
image: mcr.microsoft.com/dotnet/sdk:latest image: mcr.microsoft.com/dotnet/sdk:latest
commands: commands:
@@ -38,7 +35,6 @@ steps:
echo "=== Uruchamianie testów ===" echo "=== Uruchamianie testów ==="
dotnet test --no-restore --configuration Release --logger "trx" dotnet test --no-restore --configuration Release --logger "trx"
depends_on: [restore] depends_on: [restore]
pack-datamodels: pack-datamodels:
image: mcr.microsoft.com/dotnet/sdk:latest image: mcr.microsoft.com/dotnet/sdk:latest
commands: commands:
@@ -53,14 +49,11 @@ steps:
--minimum-major-minor 2.0 \ --minimum-major-minor 2.0 \
--default-pre-release-identifiers alpha.0 \ --default-pre-release-identifiers alpha.0 \
--verbosity info) --verbosity info)
echo "Wersja: $MINVER_VERSION" echo "Wersja: $MINVER_VERSION"
mkdir -p nupkg mkdir -p nupkg
echo "=== Pełniejsze fetch git (unshallow + tags) ===" echo "=== Pełniejsze fetch git (unshallow + tags) ==="
git fetch --prune --unshallow || echo "Już full clone OK" git fetch --prune --unshallow || echo "Już full clone OK"
git fetch --tags git fetch --tags
echo "=== Dostępne tagi ===" echo "=== Dostępne tagi ==="
git tag -l git tag -l
echo "=== Aktualny commit i opis ===" echo "=== Aktualny commit i opis ==="
@@ -85,7 +78,6 @@ steps:
echo "=== Spakowane pakiety ===" echo "=== Spakowane pakiety ==="
ls -la nupkg/ || echo "Brak spakowanych pakietów!" ls -la nupkg/ || echo "Brak spakowanych pakietów!"
depends_on: [test] depends_on: [test]
publish-datamodels-to-baget: publish-datamodels-to-baget:
image: mcr.microsoft.com/dotnet/sdk:latest image: mcr.microsoft.com/dotnet/sdk:latest
environment: environment:
@@ -116,78 +108,66 @@ steps:
--skip-duplicate --skip-duplicate
done done
depends_on: [pack-datamodels] depends_on: [pack-datamodels]
containerize-apps:
image: mcr.microsoft.com/dotnet/sdk:latest
privileged: true
volumes:
- /var/run/docker.sock:/var/run/docker.sock
environment:
GITEA_USER:
from_secret: gitea_registry_user
GITEA_TOKEN:
from_secret: gitea_registry_token
commands:
- |
set -euf
cd "${CI_WORKSPACE}"
containerize-apps: # Instalacja narzędzi Docker w kontenerze .NET (Alpine-based)
image: mcr.microsoft.com/dotnet/sdk:latest apk update && apk add --no-cache docker docker-cli-buildx
volumes:
- /var/run/docker.sock:/var/run/docker.sock
environment:
GITEA_USER:
from_secret: gitea_registry_user
GITEA_TOKEN:
from_secret: gitea_registry_token
commands:
- |
set -euf
cd "${CI_WORKSPACE}"
# Instalacja Docker CLI i buildx (potrzebne w kontenerze .NET) echo "DEBUG: Użytkownik = '$GITEA_USER'"
apk update && apk add --no-cache docker docker-cli-buildx echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN..."
# Uruchomienie dockerd jeśli potrzeba (nie zawsze wymagane przy sock)
# dockerd-entrypoint.sh & sleep 5 # opcjonalne, jeśli masz problemy z sock
echo "DEBUG: Użytkownik = '$GITEA_USER'" echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN:0:4..."
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin dotnet restore
dotnet restore find . -name "*.csproj" -type f | while read csproj; do
PROJECT_DIR=$(dirname "$csproj")
find . -name "*.csproj" -type f | while read csproj; do PROJECT_NAME=$(basename "$csproj" .csproj)
PROJECT_DIR=$(dirname "$csproj") PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
PROJECT_NAME=$(basename "$csproj" .csproj) DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
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
if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then IMAGE_NAME="trent/${PROJECT_NAME,,}"
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)" FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
continue cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
fi
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
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
WORKDIR /src WORKDIR /src
COPY . . COPY . .
RUN dotnet restore "${PROJECT_NAME}.csproj" RUN dotnet restore "${PROJECT_NAME}.csproj"
RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
FROM base AS final FROM base AS final
WORKDIR /app WORKDIR /app
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}:latest"
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}" rm -f "${PROJECT_DIR}/Dockerfile.temp"
docker push "${FULL_IMAGE}:latest" echo "Opublikowano: ${FULL_IMAGE}:latest"
done
rm -f "${PROJECT_DIR}/Dockerfile.temp" depends_on: [publish-datamodels-to-baget]
echo "Opublikowano: ${FULL_IMAGE}:latest"
done
depends_on: [publish-datamodels-to-baget]