Update dotnet-pipeline.yml
This commit is contained in:
@@ -23,7 +23,7 @@ steps:
|
|||||||
- |
|
- |
|
||||||
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:
|
||||||
@@ -86,21 +86,32 @@ steps:
|
|||||||
set -euf
|
set -euf
|
||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
mkdir -p linux-apps
|
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 ==="
|
echo "=== Publikacja aplikacji LinuxLocal ==="
|
||||||
find . -name "*.csproj" -type f | while read csproj; do
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
|
|
||||||
if [ "$PROJECT_TYPE" = "LinuxLocal" ]; then
|
if [ "$PROJECT_TYPE" = "LinuxLocal" ]; then
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
echo "→ Publishing $PROJECT_NAME"
|
echo "→ Publishing $PROJECT_NAME"
|
||||||
|
|
||||||
dotnet publish "$csproj" \
|
dotnet publish "$csproj" \
|
||||||
--configuration Release \
|
--configuration Release \
|
||||||
--output "./linux-apps/$PROJECT_NAME" \
|
--output "./linux-apps/$PROJECT_NAME" \
|
||||||
--runtime linux-x64 \
|
--runtime linux-x64 \
|
||||||
--self-contained false \
|
--self-contained false
|
||||||
--no-restore
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -156,7 +167,7 @@ steps:
|
|||||||
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_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
|
|
||||||
if [ "$PROJECT_TYPE" = "Linux" ] || [ "$PROJECT_TYPE" = "Api" ] || [ "$PROJECT_TYPE" = "ServerProcess" ] || [ "$PROJECT_TYPE" = "Blazor" ] || [ "$PROJECT_TYPE" = "LinuxLocal" ]; then
|
if [ "$PROJECT_TYPE" = "Linux" ] || [ "$PROJECT_TYPE" = "Api" ] || [ "$PROJECT_TYPE" = "ServerProcess" ] || [ "$PROJECT_TYPE" = "Blazor" ] || [ "$PROJECT_TYPE" = "LinuxLocal" ]; then
|
||||||
PROJECT_DIR=$(dirname "$csproj")
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
echo "→ Dodaję $PROJECT_NAME (typ: $PROJECT_TYPE)"
|
echo "→ Dodaję $PROJECT_NAME (typ: $PROJECT_TYPE)"
|
||||||
@@ -217,20 +228,20 @@ steps:
|
|||||||
cat projects-to-build.txt | while IFS='|' read -r PDIR PNAME; do
|
cat projects-to-build.txt | while IFS='|' read -r PDIR PNAME; do
|
||||||
PDIR=$(echo "$PDIR" | xargs)
|
PDIR=$(echo "$PDIR" | xargs)
|
||||||
PNAME=$(echo "$PNAME" | xargs)
|
PNAME=$(echo "$PNAME" | xargs)
|
||||||
|
|
||||||
echo "=== DEBUG: PDIR='$PDIR' PNAME='$PNAME' ==="
|
echo "=== DEBUG: PDIR='$PDIR' PNAME='$PNAME' ==="
|
||||||
|
|
||||||
test -z "$PNAME" && continue
|
test -z "$PNAME" && continue
|
||||||
test ! -d "$PDIR" && continue
|
test ! -d "$PDIR" && continue
|
||||||
|
|
||||||
echo -n "git.modwad.pl/fa/" > /tmp/tag.txt
|
echo -n "git.modwad.pl/fa/" > /tmp/tag.txt
|
||||||
echo "$PNAME" | tr 'A-Z' 'a-z' | tr -d '\n' >> /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 "=== DEBUG: Generated tag: $(cat /tmp/tag.txt) ==="
|
||||||
|
|
||||||
echo "$PNAME" > /tmp/pname.txt
|
echo "$PNAME" > /tmp/pname.txt
|
||||||
echo "$PDIR" | sed 's|^\./||' > /tmp/pdir.txt
|
echo "$PDIR" | sed 's|^\./||' > /tmp/pdir.txt
|
||||||
|
|
||||||
cat > "Dockerfile.temp" <<'ENDOFDOCKERFILE'
|
cat > "Dockerfile.temp" <<'ENDOFDOCKERFILE'
|
||||||
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
@@ -246,11 +257,11 @@ steps:
|
|||||||
ENV ASPNETCORE_URLS=http://+:8080
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
ENTRYPOINT ["dotnet", "%%PROJECTNAME%%.dll"]
|
ENTRYPOINT ["dotnet", "%%PROJECTNAME%%.dll"]
|
||||||
ENDOFDOCKERFILE
|
ENDOFDOCKERFILE
|
||||||
|
|
||||||
REAL_PNAME=$(cat /tmp/pname.txt)
|
REAL_PNAME=$(cat /tmp/pname.txt)
|
||||||
REAL_PDIR=$(cat /tmp/pdir.txt)
|
REAL_PDIR=$(cat /tmp/pdir.txt)
|
||||||
sed "s|%%PROJECTNAME%%|$REAL_PNAME|g; s|%%PROJECTDIR%%|$REAL_PDIR|g" "Dockerfile.temp" > "Dockerfile.final"
|
sed "s|%%PROJECTNAME%%|$REAL_PNAME|g; s|%%PROJECTDIR%%|$REAL_PDIR|g" "Dockerfile.temp" > "Dockerfile.final"
|
||||||
|
|
||||||
echo "=== Budowanie obrazu ==="
|
echo "=== Budowanie obrazu ==="
|
||||||
DOCKER_BUILDKIT=0 docker build \
|
DOCKER_BUILDKIT=0 docker build \
|
||||||
--network=host \
|
--network=host \
|
||||||
@@ -258,15 +269,15 @@ steps:
|
|||||||
-t "$(cat /tmp/tag.txt):latest" \
|
-t "$(cat /tmp/tag.txt):latest" \
|
||||||
-f "Dockerfile.final" \
|
-f "Dockerfile.final" \
|
||||||
.
|
.
|
||||||
|
|
||||||
echo "=== Pushing SHA tag ==="
|
echo "=== Pushing SHA tag ==="
|
||||||
docker push "$(cat /tmp/tag.txt):${CI_COMMIT_SHA}"
|
docker push "$(cat /tmp/tag.txt):${CI_COMMIT_SHA}"
|
||||||
|
|
||||||
echo "=== Pushing latest tag ==="
|
echo "=== Pushing latest tag ==="
|
||||||
docker push "$(cat /tmp/tag.txt):latest"
|
docker push "$(cat /tmp/tag.txt):latest"
|
||||||
|
|
||||||
echo "=== SUCCESS: $(cat /tmp/tag.txt) ==="
|
echo "=== SUCCESS: $(cat /tmp/tag.txt) ==="
|
||||||
|
|
||||||
rm -f "Dockerfile.temp" "Dockerfile.final"
|
rm -f "Dockerfile.temp" "Dockerfile.final"
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -277,30 +288,47 @@ steps:
|
|||||||
image: alpine:latest
|
image: alpine:latest
|
||||||
commands:
|
commands:
|
||||||
- |
|
- |
|
||||||
set -euf
|
|
||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
if [ ! -d "./linux-apps" ] || [ ! "$(ls -A ./linux-apps)" ]; then
|
echo "=== Sprawdzanie aplikacji LinuxLocal ==="
|
||||||
echo "Brak aplikacji LinuxLocal do wdrożenia"
|
if [ ! -d "./linux-apps" ]; then
|
||||||
|
echo "Folder ./linux-apps nie istnieje"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echo "=== DEBUG: Zawartość ./linux-apps/ ==="
|
||||||
|
ls -la ./linux-apps/
|
||||||
|
|
||||||
echo "=== Wdrażanie aplikacji LinuxLocal do /opt/fa-apps/ ==="
|
echo "=== Wdrażanie aplikacji LinuxLocal do /opt/fa-apps/ ==="
|
||||||
mkdir -p /opt/fa-apps
|
mkdir -p /opt/fa-apps
|
||||||
|
|
||||||
for app in ./linux-apps/*; do
|
cd ./linux-apps
|
||||||
APP_NAME=$(basename "$app")
|
|
||||||
echo "→ Kopiuję $APP_NAME"
|
for app in *; do
|
||||||
|
echo "→ DEBUG: Sprawdzam $app"
|
||||||
|
|
||||||
rm -rf "/opt/fa-apps/$APP_NAME"
|
if [ ! -d "$app" ]; then
|
||||||
cp -r "$app" "/opt/fa-apps/$APP_NAME"
|
echo " → $app nie jest folderem, pomijam"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
chmod +x "/opt/fa-apps/$APP_NAME/$APP_NAME"
|
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
|
done
|
||||||
|
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "=== Wdrożone aplikacje ==="
|
echo "=== Wdrożone aplikacje ==="
|
||||||
ls -la /opt/fa-apps/
|
ls -laR /opt/fa-apps/
|
||||||
depends_on: [publish-linux-local, containerize-apps]
|
depends_on: [publish-linux-local, containerize-apps]
|
||||||
|
|
||||||
cleanup-docker:
|
cleanup-docker:
|
||||||
@@ -335,3 +363,4 @@ steps:
|
|||||||
depends_on: [deploy-linux-local]
|
depends_on: [deploy-linux-local]
|
||||||
when:
|
when:
|
||||||
status: [success, failure]
|
status: [success, failure]
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user