Update .woodpecker.yml
This commit is contained in:
199
.woodpecker.yml
199
.woodpecker.yml
@@ -1,133 +1,134 @@
|
|||||||
# .woodpecker.yml – monorepo .NET z poprawną kolejnością budowania
|
skip_clone: true
|
||||||
|
|
||||||
when:
|
when:
|
||||||
event: [push, tag, manual]
|
event: [push, tag, manual]
|
||||||
branch: [master]
|
branch: [master]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
|
clone-manual:
|
||||||
|
image: woodpeckerci/plugin-git
|
||||||
|
settings:
|
||||||
|
remote: http://gitea:3000/FA/FA_WEB.git
|
||||||
|
branch: master
|
||||||
|
depth: 1
|
||||||
|
|
||||||
restore:
|
restore:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
- dotnet restore
|
- |
|
||||||
|
set -euf
|
||||||
|
CODE_DIR="/woodpecker/src/srv51.mikr.us/git/FA/FA_WEB"
|
||||||
|
cd "$CODE_DIR"
|
||||||
|
echo "=== Restore wszystkich projektów ==="
|
||||||
|
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:
|
||||||
- dotnet test --no-restore --configuration Release --logger "trx"
|
- |
|
||||||
|
set -euf
|
||||||
|
CODE_DIR="/woodpecker/src/srv51.mikr.us/git/FA/FA_WEB"
|
||||||
|
cd "$CODE_DIR"
|
||||||
|
echo "=== Uruchamianie testów ==="
|
||||||
|
dotnet test --no-restore --configuration Release --logger "trx"
|
||||||
|
depends_on: [restore]
|
||||||
|
|
||||||
build-and-pack-datamodels:
|
pack-datamodels:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
- |
|
- |
|
||||||
set -euo pipefail
|
set -euf
|
||||||
|
CODE_DIR="/woodpecker/src/srv51.mikr.us/git/FA/FA_WEB"
|
||||||
# Odczytujemy typy projektów w solution (zakładamy, że każdy ma <ProjectType> w csproj)
|
cd "$CODE_DIR"
|
||||||
echo "=== Wykrywanie projektów DataModel ==="
|
echo "=== Diagnostyka projektów ==="
|
||||||
|
find . -name "*.csproj" -type f | sort
|
||||||
LOCAL_NUGET="/tmp/local-nuget"
|
mkdir -p nupkg
|
||||||
mkdir -p "$LOCAL_NUGET"
|
echo "=== Pakowanie projektów DataModel (wykrywane po obecności <PackageId>) ==="
|
||||||
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
for csproj in *.csproj; do
|
if grep -q '<PackageId>' "$csproj"; then
|
||||||
[ -f "$csproj" ] || continue
|
|
||||||
|
|
||||||
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
|
||||||
|
|
||||||
if [[ "$PROJECT_TYPE" == "DataModel" ]]; then
|
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
echo "→ Pakuję DataModel: $PROJECT_NAME"
|
echo "→ Pakuję $PROJECT_NAME ($csproj)"
|
||||||
|
dotnet pack "$csproj" --configuration Release -o "$CODE_DIR/nupkg"
|
||||||
dotnet pack "$csproj" --no-build --configuration Release -o "$LOCAL_NUGET"
|
else
|
||||||
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
echo " Pakiet zapisany w $LOCAL_NUGET"
|
echo "→ Pomijam $PROJECT_NAME – brak <PackageId> (nie jest to biblioteka NuGet)"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
echo "=== Spakowane pakiety (.nupkg) ==="
|
||||||
|
ls -la nupkg/ || echo "Brak spakowanych pakietów!"
|
||||||
|
depends_on: [test]
|
||||||
|
|
||||||
# Dodajemy lokalny folder jako źródło NuGet dla kolejnych kroków
|
publish-datamodels-to-baget:
|
||||||
dotnet nuget add source "$LOCAL_NUGET" --name local-temp-nuget
|
|
||||||
|
|
||||||
echo "Lokalne źródło NuGet dodane: $LOCAL_NUGET"
|
|
||||||
ls -la "$LOCAL_NUGET"
|
|
||||||
|
|
||||||
deploy:
|
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
environment:
|
environment:
|
||||||
BAGET_API_KEY:
|
BAGETTER_API_KEY:
|
||||||
from_secret: baget_api_key
|
from_secret: baget_api_key
|
||||||
BAGET_URL:
|
commands:
|
||||||
from_secret: baget_url
|
- |
|
||||||
|
set -euf
|
||||||
|
CODE_DIR="/woodpecker/src/srv51.mikr.us/git/FA/FA_WEB"
|
||||||
|
cd "$CODE_DIR"
|
||||||
|
|
||||||
|
echo "=== Test połączenia z BaGetter ==="
|
||||||
|
curl -f http://baget:80/v3/index.json || echo "Nie można połączyć się z BaGetter!"
|
||||||
|
|
||||||
|
# Tworzymy minimalny NuGet.Config tylko po to, żeby odblokować HTTP dla nazwanego źródła
|
||||||
|
cat <<EOF > NuGet.Config
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<configuration>
|
||||||
|
<packageSources>
|
||||||
|
<clear />
|
||||||
|
<add key="nuget.org" value="https://api.nuget.org/v3/index.json" />
|
||||||
|
<add key="BaGet" value="http://baget:80/v3/index.json" allowInsecureConnections="true" />
|
||||||
|
</packageSources>
|
||||||
|
</configuration>
|
||||||
|
EOF
|
||||||
|
|
||||||
|
echo "=== Użyty NuGet.Config (tylko do odblokowania HTTP) ==="
|
||||||
|
cat NuGet.Config
|
||||||
|
|
||||||
|
echo "=== Publikacja pakietów do BaGetter ==="
|
||||||
|
find ./nupkg -name "*.nupkg" -type f | while read pkg; do
|
||||||
|
echo "→ Push $(basename "$pkg")"
|
||||||
|
dotnet nuget push "$pkg" \
|
||||||
|
--source "BaGet" \
|
||||||
|
--api-key "hfsa853nc9vfap53285ybndfahi58325hie242dsafa954" \
|
||||||
|
--skip-duplicate
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Wszystkie pakiety DataModel opublikowane w BaGetter!"
|
||||||
|
depends_on: [pack-datamodels]
|
||||||
|
|
||||||
|
build-and-publish-apps:
|
||||||
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
|
environment:
|
||||||
DEPLOY_SSH_KEY:
|
DEPLOY_SSH_KEY:
|
||||||
from_secret: deploy_ssh_key
|
from_secret: deploy_ssh_key
|
||||||
commands:
|
commands:
|
||||||
- |
|
- |
|
||||||
set -euo pipefail
|
set -euf
|
||||||
|
CODE_DIR="/woodpecker/src/srv51.mikr.us/git/FA/FA_WEB"
|
||||||
echo "=== Informacje o projekcie (monorepo) ==="
|
cd "$CODE_DIR"
|
||||||
echo "Repo: ${CI_REPO_NAME}"
|
echo "=== Ponowny restore aplikacji (z najnowszymi pakietami z BaGetter) ==="
|
||||||
echo "Commit: ${CI_COMMIT_SHA:0:8}"
|
find . -name "*.csproj" -type f -exec dotnet restore "{}" \;
|
||||||
echo "Branch/Tag: ${CI_COMMIT_REF}"
|
echo "=== Publish aplikacji ==="
|
||||||
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
# Publikujemy wszystkie projekty (oprócz DataModel – one już spakowane)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
LOCAL_NUGET="/tmp/local-nuget"
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
|
if [[ "$PROJECT_NAME" == *"Api"* ]] || [[ "$PROJECT_NAME" == *"Blazor"* ]] || [[ "$PROJECT_DIR" == *"/Api/"* ]] || [[ "$PROJECT_DIR" == *"/Blazor/"* ]]; then
|
||||||
for csproj in *.csproj; do
|
|
||||||
[ -f "$csproj" ] || continue
|
|
||||||
|
|
||||||
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")
|
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
||||||
|
if [ "$DEPLOY_TO_CENTRAL" != "true" ]; then
|
||||||
case "$PROJECT_TYPE" in
|
echo "Pomijam $PROJECT_NAME (DeployToCentral ≠ true)"
|
||||||
DataModel)
|
|
||||||
# Opcjonalnie: publikuj do BaGet na koniec (po udanym buildzie całego solution)
|
|
||||||
if [[ -n "${BAGET_URL:-}" ]]; then
|
|
||||||
echo "→ Publikacja $PROJECT_TYPE do BaGet"
|
|
||||||
for pkg in "$LOCAL_NUGET"/*.nupkg; do
|
|
||||||
if [[ "$pkg" == *$(basename "$csproj" .csproj)* ]]; then
|
|
||||||
dotnet nuget push "$pkg" --api-key "$BAGET_API_KEY" --source "$BAGET_URL" --skip-duplicate
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
ConsoleApp|Api|Blazor)
|
|
||||||
if [[ "$DEPLOY_TO_CENTRAL" != "true" ]]; then
|
|
||||||
echo "Projekt $PROJECT_TYPE: DeployToCentral=false – pomijam"
|
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
echo "→ Publish $PROJECT_NAME ($csproj)"
|
||||||
echo "→ Publikacja $PROJECT_TYPE"
|
dotnet publish "$csproj" --no-restore -c Release -o "$CODE_DIR/publish-$PROJECT_NAME"
|
||||||
|
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
||||||
PUBLISH_ARGS="-c Release -o /tmp/publish-$(basename "$csproj" .csproj)"
|
# Tu wstaw swój kod deployu (rsync/ssh itp.)
|
||||||
|
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
||||||
if [[ "$PROJECT_TYPE" == "ConsoleApp" ]]; then
|
|
||||||
RID=$(dotnet msbuild "$csproj" -getProperty:RuntimeIdentifier -noLogo || echo "linux-x64")
|
|
||||||
SELF_CONTAINED=$(dotnet msbuild "$csproj" -getProperty:SelfContained -noLogo || echo "true")
|
|
||||||
SINGLE_FILE=$(dotnet msbuild "$csproj" -getProperty:PublishSingleFile -noLogo || echo "true")
|
|
||||||
PUBLISH_ARGS="$PUBLISH_ARGS --self-contained $SELF_CONTAINED -r $RID -p:PublishSingleFile=$SINGLE_FILE"
|
|
||||||
else
|
else
|
||||||
TRIMMED=$(dotnet msbuild "$csproj" -getProperty:PublishTrimmed -noLogo || echo "true")
|
echo "Pomijam $PROJECT_NAME (nie jest to Api ani Blazor)"
|
||||||
PUBLISH_ARGS="$PUBLISH_ARGS -p:PublishTrimmed=$TRIMMED"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dotnet publish "$csproj" --no-restore $PUBLISH_ARGS
|
|
||||||
|
|
||||||
# Deploy via SSH
|
|
||||||
mkdir -p ~/.ssh
|
|
||||||
echo "$DEPLOY_SSH_KEY" > ~/.ssh/id_rsa
|
|
||||||
chmod 600 ~/.ssh/id_rsa
|
|
||||||
ssh-keyscan -H localhost >> ~/.ssh/known_hosts 2>/dev/null
|
|
||||||
|
|
||||||
TARGET_DIR="/opt/deployment/$PROJECT_TYPE/${CI_REPO_NAME}-$(basename "$csproj" .csproj)"
|
|
||||||
rsync -avz --delete "/tmp/publish-$(basename "$csproj" .csproj)/" " $(whoami)@localhost:$TARGET_DIR/"
|
|
||||||
|
|
||||||
ssh "$(whoami)@localhost" "find '$TARGET_DIR' -type f \\( -name '*.dll' -o -name '*.exe' -o -perm /111 \\) -exec chmod +x {} \\; || true"
|
|
||||||
|
|
||||||
echo "Deploy $PROJECT_TYPE zakończony → $TARGET_DIR"
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Projekt $(basename "$csproj") – nieznany typ ($PROJECT_TYPE), pomijam"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
done
|
||||||
|
echo "Pipeline zakończony pomyślnie!"
|
||||||
echo "Cały pipeline monorepo zakończony pomyślnie."
|
depends_on: [publish-datamodels-to-baget]
|
||||||
Reference in New Issue
Block a user