From f8e13cca55eda35384510cd7a11dc6e748401531 Mon Sep 17 00:00:00 2001 From: Vincent Fiduccia Date: Thu, 22 Feb 2024 12:17:12 -0700 Subject: [PATCH] Separate Docker UI build --- ui/.ackrc => .ackrc | 1 + Dockerfile | 18 +++++++++++++----- Makefile | 4 ++++ ui/Makefile | 3 --- ui/nuxt.config.ts | 4 +++- ui/pages/index.vue | 2 +- ui/stores/gpts.ts | 4 ++-- ui/stores/runs.ts | 2 +- ui/stores/socket.ts | 8 +++++++- 9 files changed, 32 insertions(+), 14 deletions(-) rename ui/.ackrc => .ackrc (92%) diff --git a/ui/.ackrc b/.ackrc similarity index 92% rename from ui/.ackrc rename to .ackrc index ac2947fe..ec8b5d11 100644 --- a/ui/.ackrc +++ b/.ackrc @@ -7,6 +7,7 @@ --ignore-dir=coverage --ignore-dir=dist --ignore-dir=node_modules +--ignore-dir=static/ui --ignore-dir=tmp --ignore-dir=vendor --ignore-file=ext:svg diff --git a/Dockerfile b/Dockerfile index 7663b808..3faae117 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,10 +1,18 @@ -FROM golang:1.22.0-alpine3.19 AS build -RUN apk add -U --no-cache make git npm +FROM node:18-alpine as build-ui +RUN apk add -U --no-cache make git +COPY ui /src +WORKDIR /src +RUN make + +FROM golang:1.22.0-alpine3.19 AS build-go +RUN apk add -U --no-cache make git COPY . /src/gptscript +COPY --from=build-ui /src/.output/public /src/gptscript/static/ui WORKDIR /src/gptscript - -RUN make all +RUN make build FROM alpine AS release -COPY --from=build /src/gptscript/bin /usr/local/bin/ +WORKDIR /src +COPY --from=build-go /src/gptscript/bin /usr/local/bin/ +COPY --from=build-go /src/gptscript/examples /src/examples ENTRYPOINT ["/usr/local/bin/gptscript"] diff --git a/Makefile b/Makefile index 72cea724..afd7fe96 100644 --- a/Makefile +++ b/Makefile @@ -2,6 +2,10 @@ all: build-ui build build-ui: $(MAKE) -C ui + rm -rf static/ui + mkdir -p static/ui/_nuxt + touch static/ui/placeholder static/ui/_nuxt/_placeholder + cp -rp ui/.output/public/* static/ui/ build: CGO_ENABLED=0 go build -o bin/gptscript -tags "${GO_TAGS}" -ldflags "-s -w" . diff --git a/ui/Makefile b/ui/Makefile index 37fe81de..0035859d 100644 --- a/ui/Makefile +++ b/ui/Makefile @@ -1,9 +1,6 @@ build: clean npm install npm run generate - rm -rf ../static/ui/_nuxt - cp -rp .output/public/* ../static/ui/ - touch ../static/ui/_nuxt/_placeholder clean: npm run clean diff --git a/ui/nuxt.config.ts b/ui/nuxt.config.ts index c3b9357d..068ad4e6 100644 --- a/ui/nuxt.config.ts +++ b/ui/nuxt.config.ts @@ -4,6 +4,8 @@ import pkg from './package.json' dotenv.config() const port = 9091 +const isDev = process.env.NODE_ENV === 'development' +const api = process.env.NUXT_PUBLIC_API || (isDev ? 'http://localhost:9090/' : '/') // https://nuxt.com/docs/api/configuration/nuxt-config export default defineNuxtConfig({ @@ -35,7 +37,7 @@ export default defineNuxtConfig({ nitro: { sourceMap: true }, runtimeConfig: { public: { - api: (process.env.NUXT_PUBLIC_API || 'http://localhost:9090/').replace(/\/+$/,'')+'/', + api: api.replace(/\/+$/,'')+'/', }, }, sourcemap: true, diff --git a/ui/pages/index.vue b/ui/pages/index.vue index c3889ec1..e532ff2b 100644 --- a/ui/pages/index.vue +++ b/ui/pages/index.vue @@ -4,6 +4,6 @@ -

Choose a script to get started.

+

Choose a script to get started.

diff --git a/ui/stores/gpts.ts b/ui/stores/gpts.ts index bc483017..d7023121 100644 --- a/ui/stores/gpts.ts +++ b/ui/stores/gpts.ts @@ -18,7 +18,7 @@ export const useGpts = defineStore('gpts', { } const url = useRuntimeConfig().public.api + id - const data = reactive(await $fetch(url)) + const data = reactive(await $fetch(url, {baseURL: '/'})) this.list.push(data) this.map[id] = data @@ -27,7 +27,7 @@ export const useGpts = defineStore('gpts', { async listAll() { const url = useRuntimeConfig().public.api - const data = await $fetch(url, {headers: {'X-Requested-With': 'fetch'} }) as string[] + const data = await $fetch(url, {baseURL: '/', headers: {'X-Requested-With': 'fetch'} }) as string[] return reactive(data) } } diff --git a/ui/stores/runs.ts b/ui/stores/runs.ts index f72169a5..03c9bddf 100644 --- a/ui/stores/runs.ts +++ b/ui/stores/runs.ts @@ -41,7 +41,7 @@ export const useRuns = defineStore('runs', { url = addParam(url, 'tool', toolName) } - const res = await $fetch(url, {method: 'POST', body: args}) as {id: string} + const res = await $fetch(url, {baseURL: '/', method: 'POST', body: args}) as {id: string} const id = res.id const obj: Run = reactive({ diff --git a/ui/stores/socket.ts b/ui/stores/socket.ts index 96f6a643..7fdac0de 100644 --- a/ui/stores/socket.ts +++ b/ui/stores/socket.ts @@ -12,7 +12,13 @@ interface SocketState { export const useSocket = defineStore('socket', { state: () => { - const url = useRuntimeConfig().public.api.replace(/^http/,'ws') + let url = useRuntimeConfig().public.api + if ( url.startsWith('/') ) { + url = `${window.location.origin}${url}` + } + + url = url.replace(/^http/,'ws') + const sock = useWebSocket(url, { immediate: false, autoReconnect: true,