Warehouses #13

Merged
trent merged 6 commits from Warehouses into master 2026-01-14 20:56:45 +00:00

View File

@@ -119,21 +119,13 @@ steps:
containerize-apps: containerize-apps:
image: woodpeckerci/plugin-docker-buildx:latest image: woodpeckerci/plugin-docker-buildx:latest
settings:
registry: git.modwad.pl
username:
from_secret: gitea_registry_user
password:
from_secret: gitea_registry_token
commands: commands:
- | - |
set -euf set -euf
cd "${CI_WORKSPACE}" cd "${CI_WORKSPACE}"
# Logowanie do rejestru echo "${GITEA_REGISTRY_TOKEN}" | docker login git.modwad.pl -u "${GITEA_REGISTRY_USER}" --password-stdin
echo "${PLUGIN_PASSWORD}" | docker login "${PLUGIN_REGISTRY}" -u "${PLUGIN_USERNAME}" --password-stdin
# Restore raz jeszcze bo w tym kroku nie mamy zależności od wcześniejszego restore
dotnet restore dotnet restore
find . -name "*.csproj" -type f | while read csproj; do find . -name "*.csproj" -type f | while read csproj; do
@@ -144,31 +136,30 @@ steps:
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false") 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 if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
echo "Pomijam konteneryzację $PROJECT_NAME ($PROJECT_TYPE)" echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)"
continue continue
fi fi
IMAGE_NAME="projekty/${PROJECT_NAME,,}" # np. projekty/customerapi IMAGE_NAME="projekty/${PROJECT_NAME,,}"
FULL_IMAGE="${PLUGIN_REGISTRY}/${IMAGE_NAME}" FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
# Generujemy tymczasowy Dockerfile cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
cat <<'EOF' > "${PROJECT_DIR}/Dockerfile.temp" 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 \