commit bb7d3188841a142d5e34a29574be8a0fd44c51f7 Author: fnkit Date: Tue Feb 17 16:45:13 2026 +0000 initial commit - java function diff --git a/.forgejo/workflows/deploy.yml b/.forgejo/workflows/deploy.yml new file mode 100644 index 0000000..8b975b4 --- /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-java" + 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..409240f --- /dev/null +++ b/.gitignore @@ -0,0 +1,16 @@ +# IDE +.idea/ +.vscode/ +*.swp +*.swo + +# OS +.DS_Store +Thumbs.db + +# Docker +Dockerfile.local +# Java +target/ +*.class +*.jar diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..7e2dd55 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,10 @@ +FROM maven:3.9-eclipse-temurin-17 +LABEL fnkit.fn="true" +WORKDIR /app +COPY pom.xml . +RUN mvn dependency:go-offline +COPY src ./src +RUN mvn package -DskipTests +EXPOSE 8080 +CMD ["mvn", "function:run", "-Drun.port=8080"] + diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..3cf2af5 --- /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-java: + build: . + container_name: fn-java + 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-java diff --git a/pom.xml b/pom.xml new file mode 100644 index 0000000..52c3d1e --- /dev/null +++ b/pom.xml @@ -0,0 +1,38 @@ + + + 4.0.0 + + com.example + fn-java + 1.0-SNAPSHOT + jar + + + 17 + 17 + + + + + com.google.cloud.functions + functions-framework-api + 1.1.4 + provided + + + + + + + com.google.cloud.functions + function-maven-plugin + 0.10.1 + + com.example.HelloWorld + + + + + diff --git a/src/main/java/com/example/HelloWorld.java b/src/main/java/com/example/HelloWorld.java new file mode 100644 index 0000000..c971b2a --- /dev/null +++ b/src/main/java/com/example/HelloWorld.java @@ -0,0 +1,13 @@ +package com.example; + +import com.google.cloud.functions.HttpFunction; +import com.google.cloud.functions.HttpRequest; +import com.google.cloud.functions.HttpResponse; + +public class HelloWorld implements HttpFunction { + @Override + public void service(HttpRequest request, HttpResponse response) + throws Exception { + response.getWriter().write("Hello, World!\n"); + } +}