Compare commits
141 Commits
8ea4a4139e
...
Warehouses
| Author | SHA1 | Date | |
|---|---|---|---|
| 0af8e09075 | |||
| 5f5ffce5b9 | |||
| 0c93d9f755 | |||
| 7682656922 | |||
| c900ac19d3 | |||
| 858193dff5 | |||
| 06829c7455 | |||
| f27423c33f | |||
| 59415520fe | |||
| 448e9c554d | |||
| c5b6b10928 | |||
| 9a6f2040cf | |||
| f7926c78ad | |||
| c15b325950 | |||
| 1051e22ab3 | |||
| 6b985d2cf7 | |||
| 8f859e0cc7 | |||
| d007e36081 | |||
| d5c8e3a683 | |||
| 9efa5a132f | |||
| 0200cd4b61 | |||
| ed508765eb | |||
| b0f78e395f | |||
| 260897dd87 | |||
| 065744d15a | |||
| 78806115ba | |||
| cfe7924d25 | |||
| f3060013d3 | |||
| 3d59cb1b68 | |||
| 8b3d04c6aa | |||
| ea6c490edc | |||
| 353737bae0 | |||
| 89de720f93 | |||
| 492c70f384 | |||
| 7d8de5c78f | |||
| e9d6dbaa5c | |||
| c501a84d53 | |||
| 08800a4c10 | |||
| dfc405f4b0 | |||
| 29ef6383b1 | |||
| 86ff97b311 | |||
| cf878470a5 | |||
| a0451c42de | |||
| 76b069a51e | |||
| 606bd31e21 | |||
| e391d06085 | |||
| 216a966f39 | |||
| fa8c0f3eb2 | |||
| c064479a2f | |||
| 531260eb9c | |||
| 81af6f02d9 | |||
| 7c2001ad34 | |||
| 9aaeaa0548 | |||
| 7a8d3cf10c | |||
| 27dbb780ec | |||
| 4863d9120b | |||
| b04546260a | |||
| 6d1f87f9d9 | |||
| b309669102 | |||
| 69aaa4b143 | |||
| 3a8a566350 | |||
| 68e41a6620 | |||
| 18c8916d00 | |||
| df9c187f3d | |||
| d4c5a978e4 | |||
| dc88f4ef94 | |||
| 9a7d2e0ec5 | |||
| 6014547ce7 | |||
| 23167283b0 | |||
| 44efa3fa1b | |||
| b8199a3428 | |||
| 232cb0e00d | |||
| dfb6dbef93 | |||
| f1ce3c57e9 | |||
| eb95d41975 | |||
| 8d626356c7 | |||
| 9fd026ce71 | |||
| 0a81374164 | |||
| c586e2875a | |||
| 638d7faf56 | |||
| 792283f8e2 | |||
| 8eda96003f | |||
| 639a3547b2 | |||
| 7a55775562 | |||
| a4b5bced79 | |||
| c6dadb2d61 | |||
| 9ef085b582 | |||
| 815165b496 | |||
| 9b4b075b0c | |||
| 41c9c69eb1 | |||
| 42f5ef38c8 | |||
| ed93202fd4 | |||
| 7842696a34 | |||
| fe49432d0c | |||
| 865211131e | |||
| ad2268d642 | |||
| f2686188e0 | |||
| 048a2097c3 | |||
| 2fd327e3b8 | |||
| cb71d6abed | |||
| 9cedf4402e | |||
| 94c5c8c436 | |||
| 8cc1981305 | |||
| 8e9a2a0975 | |||
| 51a96f6c6a | |||
| 7d37b7744c | |||
| a26a52b078 | |||
| 2f80dbc13c | |||
| 929e41e312 | |||
| 1e7c6a6694 | |||
| 6297ae92eb | |||
| 14b83bf9d2 | |||
| 2c97c5054e | |||
| 6fed42ee64 | |||
| 1321c88a31 | |||
| 38ff2c1673 | |||
| 070b538cb2 | |||
| d832f1b960 | |||
| db03b35292 | |||
| 6f9b94a97c | |||
| c4a99e3c35 | |||
| 1e796e2c13 | |||
| 26d00213d2 | |||
| 03b28eed6e | |||
| 0baee2be8b | |||
| a49efec313 | |||
| 96bfccdd55 | |||
| 1f3a29b293 | |||
| 49f685f109 | |||
| 2c196c68d7 | |||
| f0c4fef3cb | |||
| 2b3bc03049 | |||
| 913a1ce49d | |||
| eb8dc3cd4f | |||
| 4368129802 | |||
| 5d64abace3 | |||
| 1f9ae3998c | |||
| 3c62579a49 | |||
| 9f0f0d703e | |||
| dae2a08390 | |||
| 4f40f33666 |
295
.woodpecker.yml
295
.woodpecker.yml
@@ -1,33 +1,31 @@
|
|||||||
skip_clone: true
|
skip_clone: true
|
||||||
|
when:
|
||||||
wwhen:
|
event: pull_request
|
||||||
event: push
|
action:
|
||||||
|
- merge
|
||||||
branch: master
|
branch: master
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
debug-location:
|
debug-location:
|
||||||
image: alpine
|
image: alpine
|
||||||
commands:
|
commands:
|
||||||
- pwd # gdzie aktualnie jesteśmy
|
- pwd
|
||||||
- ls -la # co jest w bieżącym katalogu
|
- 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/${CI_REPO}.git
|
||||||
branch: master
|
branch: ${CI_COMMIT_BRANCH}
|
||||||
depth: 1
|
depth: 1
|
||||||
|
|
||||||
restore:
|
restore:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
- |
|
- |
|
||||||
set -euf
|
set -euf
|
||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
echo "Aktualna ścieżka: $(pwd)"
|
echo "Aktualna ścieżka do pliku: $(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:
|
||||||
@@ -37,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:
|
||||||
@@ -52,15 +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
|
||||||
|
|
||||||
# Diagnostyka – sprawdź czy tag jest widoczny
|
|
||||||
echo "=== Dostępne tagi ==="
|
echo "=== Dostępne tagi ==="
|
||||||
git tag -l
|
git tag -l
|
||||||
echo "=== Aktualny commit i opis ==="
|
echo "=== Aktualny commit i opis ==="
|
||||||
@@ -79,13 +72,58 @@ steps:
|
|||||||
/p:PackageVersion=$MINVER_VERSION
|
/p:PackageVersion=$MINVER_VERSION
|
||||||
else
|
else
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
echo "→ Pomijam $PROJECT_NAME – brak <PackageId> (nie jest to biblioteka NuGet)"
|
echo "→ Pomijam $PROJECT_NAME – brak <PackageId>"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo "=== Spakowane pakiety (.nupkg) ==="
|
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-linux-local:
|
||||||
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
set -euf
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
mkdir -p linux-apps
|
||||||
|
|
||||||
|
echo "=== Konfiguracja NuGet sources ==="
|
||||||
|
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 "=== Publikacja aplikacji LinuxLocal ==="
|
||||||
|
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" = "LinuxLocal" ]; then
|
||||||
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
|
echo "→ Publishing $PROJECT_NAME"
|
||||||
|
|
||||||
|
dotnet publish "$csproj" \
|
||||||
|
--configuration Release \
|
||||||
|
--output "./linux-apps/$PROJECT_NAME" \
|
||||||
|
--runtime linux-x64 \
|
||||||
|
--self-contained false
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
if [ -d "./linux-apps" ] && [ "$(ls -A ./linux-apps)" ]; then
|
||||||
|
echo "Opublikowane aplikacje:"
|
||||||
|
ls -la linux-apps/
|
||||||
|
else
|
||||||
|
echo "Brak aplikacji LinuxLocal do publikacji"
|
||||||
|
fi
|
||||||
|
depends_on: [restore]
|
||||||
|
|
||||||
publish-datamodels-to-baget:
|
publish-datamodels-to-baget:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
environment:
|
environment:
|
||||||
@@ -97,7 +135,6 @@ steps:
|
|||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
echo "=== Test połączenia z BaGetter ==="
|
echo "=== Test połączenia z BaGetter ==="
|
||||||
curl -f http://baget:80/v3/index.json || echo "Nie można połączyć się 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
|
cat <<EOF > NuGet.Config
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<configuration>
|
<configuration>
|
||||||
@@ -108,8 +145,6 @@ steps:
|
|||||||
</packageSources>
|
</packageSources>
|
||||||
</configuration>
|
</configuration>
|
||||||
EOF
|
EOF
|
||||||
echo "=== Użyty NuGet.Config (tylko do odblokowania HTTP) ==="
|
|
||||||
cat NuGet.Config
|
|
||||||
echo "=== Publikacja pakietów do BaGetter ==="
|
echo "=== Publikacja pakietów do BaGetter ==="
|
||||||
find ./nupkg -name "*.nupkg" -type f | while read pkg; do
|
find ./nupkg -name "*.nupkg" -type f | while read pkg; do
|
||||||
echo "→ Push $(basename "$pkg")"
|
echo "→ Push $(basename "$pkg")"
|
||||||
@@ -118,35 +153,213 @@ steps:
|
|||||||
--api-key "$BAGETTER_API_KEY" \
|
--api-key "$BAGETTER_API_KEY" \
|
||||||
--skip-duplicate
|
--skip-duplicate
|
||||||
done
|
done
|
||||||
echo "Wszystkie pakiety DataModel opublikowane w BaGetter!"
|
|
||||||
depends_on: [pack-datamodels]
|
depends_on: [pack-datamodels]
|
||||||
|
|
||||||
build-and-publish-apps:
|
select-projects-for-container:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
- |
|
- |
|
||||||
set -euf
|
set -euf
|
||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
echo "=== Ponowny restore aplikacji (z najnowszymi pakietami z BaGetter) ==="
|
> projects-to-build.txt
|
||||||
find . -name "*.csproj" -type f -exec dotnet restore "{}" \;
|
|
||||||
echo "=== Publish aplikacji ==="
|
echo "=== Selekcja projektów do konteneryzacji ==="
|
||||||
find . -name "*.csproj" -type f | while read csproj; do
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
PROJECT_DIR=$(dirname "$csproj")
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
if [[ "$PROJECT_NAME" == *"Api"* ]] || [[ "$PROJECT_NAME" == *"Blazor"* ]] || [[ "$PROJECT_DIR" == *"/Api/"* ]] || [[ "$PROJECT_DIR" == *"/Blazor/"* ]]; then
|
|
||||||
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
if [ "$PROJECT_TYPE" = "Linux" ] || [ "$PROJECT_TYPE" = "Api" ] || [ "$PROJECT_TYPE" = "ServerProcess" ] || [ "$PROJECT_TYPE" = "Blazor" ] || [ "$PROJECT_TYPE" = "LinuxLocal" ]; then
|
||||||
if [ "$DEPLOY_TO_CENTRAL" != "true" ]; then
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
echo "Pomijam $PROJECT_NAME (DeployToCentral ≠ true)"
|
echo "→ Dodaję $PROJECT_NAME (typ: $PROJECT_TYPE)"
|
||||||
continue
|
echo "$PROJECT_DIR|$PROJECT_NAME" >> projects-to-build.txt
|
||||||
fi
|
|
||||||
echo "→ Publish $PROJECT_NAME ($csproj)"
|
|
||||||
dotnet publish "$csproj" --no-restore -c Release -o "./publish-$PROJECT_NAME"
|
|
||||||
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
|
||||||
# Tu wstaw swój kod deployu (rsync/ssh itp.)
|
|
||||||
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
|
||||||
else
|
else
|
||||||
echo "Pomijam $PROJECT_NAME (nie jest to Api ani Blazor)"
|
echo "→ Pomijam $PROJECT_NAME (typ: $PROJECT_TYPE)"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo "Pipeline zakończony pomyślnie!"
|
|
||||||
|
echo ""
|
||||||
|
if [ -s projects-to-build.txt ]; then
|
||||||
|
echo "Znalezione projekty:"
|
||||||
|
cat projects-to-build.txt
|
||||||
|
echo "Łącznie: $(wc -l < projects-to-build.txt)"
|
||||||
|
else
|
||||||
|
echo "BRAK PROJEKTÓW DO BUDOWY!"
|
||||||
|
fi
|
||||||
depends_on: [publish-datamodels-to-baget]
|
depends_on: [publish-datamodels-to-baget]
|
||||||
|
|
||||||
|
containerize-apps:
|
||||||
|
image: docker:27-cli
|
||||||
|
environment:
|
||||||
|
GITEA_USER:
|
||||||
|
from_secret: gitea_registry_user
|
||||||
|
GITEA_TOKEN:
|
||||||
|
from_secret: gitea_registry_token
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
set -euf
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
|
REGISTRY_ORG="fa"
|
||||||
|
|
||||||
|
echo "=== DEBUG: Zawartość projects-to-build.txt ==="
|
||||||
|
cat projects-to-build.txt || echo "Plik nie istnieje!"
|
||||||
|
echo "=== DEBUG: REGISTRY_ORG = '$REGISTRY_ORG' ==="
|
||||||
|
|
||||||
|
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
||||||
|
|
||||||
|
if [ ! -s projects-to-build.txt ]; then
|
||||||
|
echo "Brak projektow"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f NuGet.Config
|
||||||
|
|
||||||
|
cat > NuGet.Config <<EOF
|
||||||
|
<?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://127.0.0.1:8080/v3/index.json" />
|
||||||
|
</packageSources>
|
||||||
|
</configuration>
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat projects-to-build.txt | while IFS='|' read -r PDIR PNAME; do
|
||||||
|
PDIR=$(echo "$PDIR" | xargs)
|
||||||
|
PNAME=$(echo "$PNAME" | xargs)
|
||||||
|
|
||||||
|
echo "=== DEBUG: PDIR='$PDIR' PNAME='$PNAME' ==="
|
||||||
|
|
||||||
|
test -z "$PNAME" && continue
|
||||||
|
test ! -d "$PDIR" && continue
|
||||||
|
|
||||||
|
echo -n "git.modwad.pl/fa/" > /tmp/tag.txt
|
||||||
|
echo "$PNAME" | tr 'A-Z' 'a-z' | tr -d '\n' >> /tmp/tag.txt
|
||||||
|
|
||||||
|
echo "=== DEBUG: Generated tag: $(cat /tmp/tag.txt) ==="
|
||||||
|
|
||||||
|
echo "$PNAME" > /tmp/pname.txt
|
||||||
|
echo "$PDIR" | sed 's|^\./||' > /tmp/pdir.txt
|
||||||
|
|
||||||
|
cat > "Dockerfile.temp" <<'ENDOFDOCKERFILE'
|
||||||
|
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 "%%PROJECTDIR%%/%%PROJECTNAME%%.csproj"
|
||||||
|
RUN dotnet publish "%%PROJECTDIR%%/%%PROJECTNAME%%.csproj" -c Release -o /app/publish /p:UseAppHost=false --no-restore
|
||||||
|
FROM base AS final
|
||||||
|
WORKDIR /app
|
||||||
|
COPY --from=build /app/publish .
|
||||||
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
|
ENTRYPOINT ["dotnet", "%%PROJECTNAME%%.dll"]
|
||||||
|
ENDOFDOCKERFILE
|
||||||
|
|
||||||
|
REAL_PNAME=$(cat /tmp/pname.txt)
|
||||||
|
REAL_PDIR=$(cat /tmp/pdir.txt)
|
||||||
|
sed "s|%%PROJECTNAME%%|$REAL_PNAME|g; s|%%PROJECTDIR%%|$REAL_PDIR|g" "Dockerfile.temp" > "Dockerfile.final"
|
||||||
|
|
||||||
|
echo "=== Budowanie obrazu ==="
|
||||||
|
DOCKER_BUILDKIT=0 docker build \
|
||||||
|
--network=host \
|
||||||
|
-t "$(cat /tmp/tag.txt):${CI_COMMIT_SHA}" \
|
||||||
|
-t "$(cat /tmp/tag.txt):latest" \
|
||||||
|
-f "Dockerfile.final" \
|
||||||
|
.
|
||||||
|
|
||||||
|
echo "=== Pushing SHA tag ==="
|
||||||
|
docker push "$(cat /tmp/tag.txt):${CI_COMMIT_SHA}"
|
||||||
|
|
||||||
|
echo "=== Pushing latest tag ==="
|
||||||
|
docker push "$(cat /tmp/tag.txt):latest"
|
||||||
|
|
||||||
|
echo "=== SUCCESS: $(cat /tmp/tag.txt) ==="
|
||||||
|
|
||||||
|
rm -f "Dockerfile.temp" "Dockerfile.final"
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "=== WSZYSTKIE PROJEKTY ZAKONCZONE ==="
|
||||||
|
depends_on: [select-projects-for-container]
|
||||||
|
|
||||||
|
deploy-linux-local:
|
||||||
|
image: alpine:latest
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
|
echo "=== Sprawdzanie aplikacji LinuxLocal ==="
|
||||||
|
if [ ! -d "./linux-apps" ]; then
|
||||||
|
echo "Folder ./linux-apps nie istnieje"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "=== DEBUG: Zawartość ./linux-apps/ ==="
|
||||||
|
ls -la ./linux-apps/
|
||||||
|
|
||||||
|
echo "=== Wdrażanie aplikacji LinuxLocal do /opt/fa-apps/ ==="
|
||||||
|
mkdir -p /opt/fa-apps
|
||||||
|
|
||||||
|
cd ./linux-apps
|
||||||
|
|
||||||
|
for app in *; do
|
||||||
|
echo "→ DEBUG: Sprawdzam $app"
|
||||||
|
|
||||||
|
if [ ! -d "$app" ]; then
|
||||||
|
echo " → $app nie jest folderem, pomijam"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo " → Kopiuję $app"
|
||||||
|
echo " → Zawartość:"
|
||||||
|
ls -la "$app/"
|
||||||
|
|
||||||
|
rm -rf "/opt/fa-apps/$app"
|
||||||
|
cp -r "$app" "/opt/fa-apps/$app"
|
||||||
|
|
||||||
|
find "/opt/fa-apps/$app" -type f -executable -exec chmod +x {} \;
|
||||||
|
|
||||||
|
echo " → Skopiowano!"
|
||||||
|
done
|
||||||
|
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=== Wdrożone aplikacje ==="
|
||||||
|
ls -laR /opt/fa-apps/
|
||||||
|
depends_on: [publish-linux-local, containerize-apps]
|
||||||
|
|
||||||
|
cleanup-docker:
|
||||||
|
image: docker:27-cli
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
echo "=== Status przed czyszczeniem ==="
|
||||||
|
docker system df
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=== Usuwanie dangling images ==="
|
||||||
|
docker image prune -f
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=== Usuwanie starych wersji aplikacji ==="
|
||||||
|
docker images --format "{{.Repository}}:{{.Tag}}" | grep "git.modwad.pl/" | grep -v ":latest" | grep -v ":${CI_COMMIT_SHA}" | while read img; do
|
||||||
|
echo "Usuwam: $img"
|
||||||
|
docker rmi "$img" || true
|
||||||
|
done
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=== Usuwanie kontenerów ==="
|
||||||
|
docker container prune -f
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=== Usuwanie build cache ==="
|
||||||
|
docker builder prune -af
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "=== Status po czyszczeniu ==="
|
||||||
|
docker system df
|
||||||
|
depends_on: [deploy-linux-local]
|
||||||
|
when:
|
||||||
|
status: [success, failure]
|
||||||
@@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="BCrypt.Net-Core" Version="1.6.0" />
|
<PackageReference Include="BCrypt.Net-Core" Version="1.6.0" />
|
||||||
<PackageReference Include="FaKrosnoEfDataModel" Version="2.0.0" />
|
<PackageReference Include="FaKrosnoEfDataModel" Version="2.0.1-alpha.0.65" />
|
||||||
<PackageReference Include="Hangfire" Version="1.8.17" />
|
<PackageReference Include="Hangfire" Version="1.8.17" />
|
||||||
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="8.0.11" />
|
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="8.0.11" />
|
||||||
<PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.11" />
|
<PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.11" />
|
||||||
@@ -20,13 +20,10 @@
|
|||||||
</PackageReference>
|
</PackageReference>
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" />
|
||||||
<PackageReference Include="NSwag.AspNetCore" Version="14.2.0" />
|
<PackageReference Include="NSwag.AspNetCore" Version="14.2.0" />
|
||||||
|
<PackageReference Include="OrdersManagementDataModel" Version="2.0.0-alpha.0" />
|
||||||
<PackageReference Include="Syncfusion.XlsIO.Net.Core" Version="29.2.4" />
|
<PackageReference Include="Syncfusion.XlsIO.Net.Core" Version="29.2.4" />
|
||||||
<PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="8.3.0" />
|
<PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="8.3.0" />
|
||||||
<PackageReference Include="SytelineSaAppEfDataModel" Version="1.1.2" />
|
<PackageReference Include="SytelineSaAppEfDataModel" Version="2.0.1-alpha.0.65" />
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\OrdersManagementDataModel\OrdersManagementDataModel.csproj" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -10,6 +10,7 @@
|
|||||||
<Nullable>enable</Nullable>
|
<Nullable>enable</Nullable>
|
||||||
<MinVerAutoIncrement>patch</MinVerAutoIncrement>
|
<MinVerAutoIncrement>patch</MinVerAutoIncrement>
|
||||||
<MinVerMinimumMajorMinor>1.0</MinVerMinimumMajorMinor>
|
<MinVerMinimumMajorMinor>1.0</MinVerMinimumMajorMinor>
|
||||||
|
<GeneratePackageOnBuild>false</GeneratePackageOnBuild>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|||||||
@@ -10,9 +10,11 @@
|
|||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="BCrypt.Net-Core" Version="1.6.0" />
|
<PackageReference Include="BCrypt.Net-Core" Version="1.6.0" />
|
||||||
<PackageReference Include="Blazored.LocalStorage" Version="4.5.0" />
|
<PackageReference Include="Blazored.LocalStorage" Version="4.5.0" />
|
||||||
|
<PackageReference Include="FaKrosnoEfDataModel" Version="2.0.1-alpha.0.65" />
|
||||||
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="8.0.11" />
|
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="8.0.11" />
|
||||||
<PackageReference Include="Microsoft.IdentityModel.Protocols" Version="8.6.1" />
|
<PackageReference Include="Microsoft.IdentityModel.Protocols" Version="8.6.1" />
|
||||||
<PackageReference Include="Microsoft.IdentityModel.Protocols.OpenIdConnect" Version="8.6.1" />
|
<PackageReference Include="Microsoft.IdentityModel.Protocols.OpenIdConnect" Version="8.6.1" />
|
||||||
|
<PackageReference Include="OrdersManagementDataModel" Version="2.0.0-alpha.0" />
|
||||||
<PackageReference Include="Syncfusion.Blazor.Buttons" Version="28.2.3" />
|
<PackageReference Include="Syncfusion.Blazor.Buttons" Version="28.2.3" />
|
||||||
<PackageReference Include="Syncfusion.Blazor.Cards" Version="28.2.3" />
|
<PackageReference Include="Syncfusion.Blazor.Cards" Version="28.2.3" />
|
||||||
<PackageReference Include="Syncfusion.Blazor.Core" Version="28.2.3" />
|
<PackageReference Include="Syncfusion.Blazor.Core" Version="28.2.3" />
|
||||||
@@ -21,11 +23,7 @@
|
|||||||
<PackageReference Include="Syncfusion.Blazor.SplitButtons" Version="28.2.3" />
|
<PackageReference Include="Syncfusion.Blazor.SplitButtons" Version="28.2.3" />
|
||||||
<PackageReference Include="Syncfusion.Blazor.Themes" Version="28.2.3" />
|
<PackageReference Include="Syncfusion.Blazor.Themes" Version="28.2.3" />
|
||||||
<PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="8.6.1" />
|
<PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="8.6.1" />
|
||||||
<PackageReference Include="SytelineSaAppEfDataModel" Version="2.0.1-alpha.0.1" />
|
<PackageReference Include="SytelineSaAppEfDataModel" Version="2.0.1-alpha.0.65" />
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\OrdersManagementDataModel\OrdersManagementDataModel.csproj" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|||||||
@@ -5,6 +5,13 @@
|
|||||||
<ProjectType>DataModel</ProjectType>
|
<ProjectType>DataModel</ProjectType>
|
||||||
<ImplicitUsings>enable</ImplicitUsings>
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
<Nullable>enable</Nullable>
|
<Nullable>enable</Nullable>
|
||||||
|
|
||||||
|
<PackageId>OrdersManagementDataModel</PackageId>
|
||||||
|
<Authors>Piotr Kus</Authors>
|
||||||
|
<Description>OrdersManagement Entity Framework Data Model</Description>
|
||||||
|
<MinVerAutoIncrement>patch</MinVerAutoIncrement>
|
||||||
|
<MinVerMinimumMajorMinor>1.0</MinVerMinimumMajorMinor>
|
||||||
|
<GeneratePackageOnBuild>false</GeneratePackageOnBuild>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
<Description>Syteline Entity Framework Data Model</Description>
|
<Description>Syteline Entity Framework Data Model</Description>
|
||||||
<MinVerAutoIncrement>patch</MinVerAutoIncrement>
|
<MinVerAutoIncrement>patch</MinVerAutoIncrement>
|
||||||
<MinVerMinimumMajorMinor>1.0</MinVerMinimumMajorMinor>
|
<MinVerMinimumMajorMinor>1.0</MinVerMinimumMajorMinor>
|
||||||
|
<GeneratePackageOnBuild>false</GeneratePackageOnBuild>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|||||||
Reference in New Issue
Block a user