diff --git a/network-poc/frontend/public/kipina-node b/network-poc/frontend/public/kipina-node index c9ea73d..22b1945 100644 --- a/network-poc/frontend/public/kipina-node +++ b/network-poc/frontend/public/kipina-node @@ -5,6 +5,7 @@ set -e BASE_URL="https://kipina.studio/download" HUB_URL="${KIPINA_HUB:-wss://kipina.studio/ws}" MODEL="${KIPINA_MODEL:-qwen2.5-coder:3b}" +OLLAMA_URL="${OLLAMA_URL:-http://localhost:11434}" # Tunnista OS ja arkkitehtuuri OS=$(uname -s | tr '[:upper:]' '[:lower:]') @@ -24,30 +25,83 @@ echo " ║ Kipinä Agentic Node ║" echo " ╚══════════════════════════════════════╝" echo "" echo " OS: $OS ($ARCH)" -echo " Hub: $HUB_URL" -echo " Malli: $MODEL" echo "" -# Tarkista Ollama -if ! command -v ollama &>/dev/null; then - echo " ✗ Ollama ei ole asennettu." - echo " Asenna: curl -fsSL https://ollama.ai/install.sh | sh" - echo " macOS: brew install ollama" - exit 1 +# Etsi Ollama-instanssit +CANDIDATES=( + "http://localhost:11434" + "http://127.0.0.1:11434" + "http://ollama:11434" + "http://host.docker.internal:11434" +) + +# Lisää OLLAMA_URL listaan jos asetettu ja ei jo mukana +if [ -n "$OLLAMA_URL" ]; then + ALREADY=false + for c in "${CANDIDATES[@]}"; do + [ "$c" = "$OLLAMA_URL" ] && ALREADY=true + done + $ALREADY || CANDIDATES=("$OLLAMA_URL" "${CANDIDATES[@]}") fi -# Varmista Ollama käynnissä -if ! curl -s http://localhost:11434/api/tags &>/dev/null; then - echo " Käynnistetään Ollama..." - ollama serve &>/dev/null & - sleep 3 -fi -echo " ✓ Ollama käynnissä" +echo " Etsitään Ollama-instansseja..." +FOUND=() +for url in "${CANDIDATES[@]}"; do + if curl -s --connect-timeout 1 "$url/api/tags" &>/dev/null; then + FOUND+=("$url") + fi +done -# Lataa malli -if ! ollama list 2>/dev/null | grep -q "$MODEL"; then +if [ ${#FOUND[@]} -eq 0 ]; then + # Ei löytynyt — yritä käynnistää lokaali + if command -v ollama &>/dev/null; then + echo " Käynnistetään Ollama..." + ollama serve &>/dev/null & + sleep 3 + if curl -s --connect-timeout 1 "http://localhost:11434/api/tags" &>/dev/null; then + OLLAMA_URL="http://localhost:11434" + echo " ✓ Ollama käynnistetty ($OLLAMA_URL)" + else + echo " ✗ Ollaman käynnistys epäonnistui." + exit 1 + fi + else + echo "" + echo " ✗ Ollamaa ei löytynyt." + echo " Kontti/remote: OLLAMA_URL=http://HOST:11434 ./kipina-node" + echo " Asenna: curl -fsSL https://ollama.ai/install.sh | sh" + exit 1 + fi +elif [ ${#FOUND[@]} -eq 1 ]; then + OLLAMA_URL="${FOUND[0]}" + echo " ✓ Ollama löytyi: $OLLAMA_URL" +else + echo "" + echo " Löytyi ${#FOUND[@]} Ollama-instanssia:" + echo "" + for i in "${!FOUND[@]}"; do + echo " $((i+1))) ${FOUND[$i]}" + done + echo "" + read -p " Valitse [1-${#FOUND[@]}]: " -r CHOICE + if [[ "$CHOICE" =~ ^[0-9]+$ ]] && [ "$CHOICE" -ge 1 ] && [ "$CHOICE" -le ${#FOUND[@]} ]; then + OLLAMA_URL="${FOUND[$((CHOICE-1))]}" + else + OLLAMA_URL="${FOUND[0]}" + echo " Käytetään oletusta: $OLLAMA_URL" + fi + echo " ✓ Valittu: $OLLAMA_URL" +fi + +echo "" +echo " Hub: $HUB_URL" +echo " Ollama: $OLLAMA_URL" +echo " Malli: $MODEL" + +# Lataa malli (toimii sekä lokaalilla binäärillä että API:n kautta) +if ! curl -s "$OLLAMA_URL/api/tags" | grep -q "$MODEL"; then echo " Ladataan $MODEL..." - ollama pull "$MODEL" + curl -s "$OLLAMA_URL/api/pull" -d "{\"name\":\"$MODEL\"}" > /dev/null fi echo " ✓ Malli $MODEL valmis" @@ -64,4 +118,4 @@ echo " ✓ Yhdistetään laskentaverkkoon..." echo " Ctrl+C pysäyttää" echo "" -HUB_URL="$HUB_URL" OLLAMA_MODEL="$MODEL" exec "$BIN_PATH" +HUB_URL="$HUB_URL" OLLAMA_URL="$OLLAMA_URL" OLLAMA_MODEL="$MODEL" exec "$BIN_PATH"