Update .woodpecker.yml #23

Open
trent wants to merge 58 commits from Warehouses into master
Showing only changes of commit 08800a4c10 - Show all commits

View File

@@ -108,9 +108,28 @@ steps:
--skip-duplicate --skip-duplicate
done done
depends_on: [pack-datamodels] depends_on: [pack-datamodels]
select-projects-for-container:
image: mcr.microsoft.com/dotnet/sdk:latest
commands:
- |
set -euf
cd "${CI_WORKSPACE}"
> projects-to-build.txt
find . -name "*.csproj" -type f | while read csproj; do
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
if [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
:
else
PROJECT_NAME=$(basename "$csproj" .csproj)
PROJECT_DIR=$(dirname "$csproj")
echo "$PROJECT_DIR|$PROJECT_NAME" >> projects-to-build.txt
fi
done
depends_on: [publish-datamodels-to-baget]
containerize-apps: containerize-apps:
image: woodpeckerci/plugin-docker-buildx:latest image: woodpeckerci/plugin-docker-buildx:latest
environment: environment:
DOCKER_HOST: unix:///var/run/docker.sock
GITEA_USER: GITEA_USER:
from_secret: gitea_registry_user from_secret: gitea_registry_user
GITEA_TOKEN: GITEA_TOKEN:
@@ -119,18 +138,18 @@ steps:
- | - |
set -euf set -euf
cd "${CI_WORKSPACE}" cd "${CI_WORKSPACE}"
echo "DEBUG: DOCKER_HOST = $DOCKER_HOST"
echo "DEBUG: ls /var/run/docker.sock:"
ls -l /var/run/docker.sock || echo "Socket NIE widoczny"
echo "DEBUG: Użytkownik = '$GITEA_USER'" echo "DEBUG: Użytkownik = '$GITEA_USER'"
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN..." echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN..."
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
find . -name "*.csproj" -type f | while read csproj; do if [ ! -s projects-to-build.txt ]; then
PROJECT_DIR=$(dirname "$csproj") echo "Brak projektów do zbudowania"
PROJECT_NAME=$(basename "$csproj" .csproj) exit 0
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
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
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)"
continue
fi fi
while IFS='|' read -r PROJECT_DIR PROJECT_NAME; do
if [ -z "$PROJECT_NAME" ]; then continue; fi
IMAGE_NAME="trent/${PROJECT_NAME,,}" IMAGE_NAME="trent/${PROJECT_NAME,,}"
FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}" FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
@@ -158,5 +177,5 @@ steps:
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 < projects-to-build.txt
depends_on: [publish-datamodels-to-baget] depends_on: [select-projects-for-container]