commit dc136f54056bafc02aef75cedb9bd86f9b439799 Author: fnkit Date: Tue Feb 17 16:45:14 2026 +0000 initial commit - dotnet function diff --git a/.forgejo/workflows/deploy.yml b/.forgejo/workflows/deploy.yml new file mode 100644 index 0000000..f50a66a --- /dev/null +++ b/.forgejo/workflows/deploy.yml @@ -0,0 +1,83 @@ +# FnKit Deploy โ€” Forgejo Actions +# Builds and deploys this function container on every push to main +# Requires: Forgejo runner with Docker socket access (fnkit deploy runner) +# +# Pipeline: git push โ†’ build image โ†’ deploy container โ†’ health check + +on: + push: + branches: [main] + +jobs: + deploy: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + + - name: Build image + run: | + FUNCTION_NAME="fn-dotnet" + IMAGE_NAME="fnkit-fn-${FUNCTION_NAME}:latest" + IMAGE_PREV="fnkit-fn-${FUNCTION_NAME}:prev" + + echo "๐Ÿ”จ Building ${FUNCTION_NAME}..." + docker build -t $IMAGE_NAME . + + echo "IMAGE_NAME=$IMAGE_NAME" >> $GITHUB_ENV + echo "IMAGE_PREV=$IMAGE_PREV" >> $GITHUB_ENV + echo "FUNCTION_NAME=$FUNCTION_NAME" >> $GITHUB_ENV + + - name: Deploy container + run: | + echo "๐ŸŒ Ensuring fnkit-network exists..." + docker network create fnkit-network 2>/dev/null || true + + # Tag current image as :prev for rollback + docker tag $IMAGE_NAME $IMAGE_PREV 2>/dev/null || true + + echo "โ™ป๏ธ Replacing running container..." + docker stop $FUNCTION_NAME 2>/dev/null || true + docker rm $FUNCTION_NAME 2>/dev/null || true + + echo "๐Ÿš€ Starting ${FUNCTION_NAME}..." + docker run -d \ + --name $FUNCTION_NAME \ + --network fnkit-network \ + --label fnkit.fn=true \ + --label fnkit.deployed="$(date -u +%Y-%m-%dT%H:%M:%SZ)" \ + --restart unless-stopped \ + $IMAGE_NAME + + - name: Health check + run: | + echo "๐Ÿฅ Checking container health..." + sleep 3 + + if docker ps --filter "name=$FUNCTION_NAME" --filter "status=running" -q | grep -q .; then + echo "โœ… ${FUNCTION_NAME} is running" + echo "๐ŸŒ Available at gateway: /${FUNCTION_NAME}" + else + echo "โŒ Container failed to start โ€” rolling back..." + docker logs $FUNCTION_NAME 2>&1 || true + + # Rollback to previous image if available + if docker image inspect $IMAGE_PREV >/dev/null 2>&1; then + echo "๐Ÿ”„ Rolling back to previous image..." + docker rm $FUNCTION_NAME 2>/dev/null || true + docker run -d \ + --name $FUNCTION_NAME \ + --network fnkit-network \ + --label fnkit.fn=true \ + --label fnkit.deployed="$(date -u +%Y-%m-%dT%H:%M:%SZ)" \ + --label fnkit.rollback=true \ + --restart unless-stopped \ + $IMAGE_PREV + echo "โš ๏ธ Rolled back to previous version" + fi + exit 1 + fi + + - name: Cleanup old images + run: | + echo "๐Ÿงน Cleaning up dangling images..." + docker image prune -f --filter "label=fnkit.fn=true" 2>/dev/null || true diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1786095 --- /dev/null +++ b/.gitignore @@ -0,0 +1,16 @@ +# IDE +.idea/ +.vscode/ +*.swp +*.swo + +# OS +.DS_Store +Thumbs.db + +# Docker +Dockerfile.local +# .NET +bin/ +obj/ +*.user diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..fa2237d --- /dev/null +++ b/Dockerfile @@ -0,0 +1,12 @@ +FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build +LABEL fnkit.fn="true" +WORKDIR /src +COPY *.csproj ./ +RUN dotnet restore +COPY . . +RUN dotnet publish -c Release -o /app + +FROM mcr.microsoft.com/dotnet/aspnet:8.0 +WORKDIR /app +COPY --from=build /app . +ENTRYPOINT ["dotnet", "fn-dotnet.dll"] diff --git a/Function.cs b/Function.cs new file mode 100644 index 0000000..b675b5e --- /dev/null +++ b/Function.cs @@ -0,0 +1,13 @@ +using Google.Cloud.Functions.Framework; +using Microsoft.AspNetCore.Http; +using System.Threading.Tasks; + +namespace fn_dotnet; + +public class Function : IHttpFunction +{ + public async Task HandleAsync(HttpContext context) + { + await context.Response.WriteAsync("Hello, World!"); + } +} diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..e719106 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,36 @@ +# Docker Compose for FnKit function with gateway integration +# Requires: docker network create fnkit-network +# Requires: fnkit-gateway running (fnkit gateway init && fnkit gateway build && fnkit gateway start) + +version: '3.8' + +services: + fn-dotnet: + build: . + container_name: fn-dotnet + networks: + - fnkit-network + depends_on: + fnkit-gateway: + condition: service_started + restart: unless-stopped + + # Uncomment to include gateway in this compose file + # fnkit-gateway: + # image: fnkit-gateway:latest + # container_name: fnkit-gateway + # ports: + # - "8080:8080" + # environment: + # - FNKIT_AUTH_TOKEN=${FNKIT_AUTH_TOKEN:-} + # networks: + # - fnkit-network + +networks: + fnkit-network: + name: fnkit-network + external: true + +# Usage: +# docker-compose up -d +# curl -H "Authorization: Bearer " http://localhost:8080/fn-dotnet diff --git a/fn-dotnet.csproj b/fn-dotnet.csproj new file mode 100644 index 0000000..c29a262 --- /dev/null +++ b/fn-dotnet.csproj @@ -0,0 +1,10 @@ + + + Exe + net8.0 + + + + + +