From cd3e17a563b5e293b04fe8389d3973e2d00e6483 Mon Sep 17 00:00:00 2001 From: jiro4989 Date: Wed, 5 Jan 2022 12:57:26 +0900 Subject: [PATCH 1/6] =?UTF-8?q?fix:=20Nginx=E3=81=8B=E3=82=89websh=5Fserve?= =?UTF-8?q?r=E3=81=AB=E7=96=8E=E9=80=9A=E3=81=A7=E3=81=8D=E3=81=A6?= =?UTF-8?q?=E3=81=AA=E3=81=8B=E3=81=A3=E3=81=9F=E3=81=AE=E3=82=92=E4=BF=AE?= =?UTF-8?q?=E6=AD=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docker-compose.yml | 2 +- nginx/conf.d/nginx.conf | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docker-compose.yml b/docker-compose.yml index 16f1687..56bcf9e 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -30,6 +30,7 @@ services: websh_server: build: *app-build + container_name: websh_server volumes: - "./websh_server:/work" environment: @@ -37,7 +38,6 @@ services: entrypoint: ./entrypoint.sh ports: - "5000:5000" - network_mode: "host" websh_remover: build: *app-build diff --git a/nginx/conf.d/nginx.conf b/nginx/conf.d/nginx.conf index 056a70e..dc4ec84 100644 --- a/nginx/conf.d/nginx.conf +++ b/nginx/conf.d/nginx.conf @@ -33,7 +33,7 @@ server { proxy_set_header X-Forwarded-for $remote_addr; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $http_host; - proxy_pass http://127.0.1.1:5000/; + proxy_pass http://websh_server:5000/; } location = /favicon.ico { From 8ada0f0dac0e3a1609dc9349eca3de6f598d8e3c Mon Sep 17 00:00:00 2001 From: jiro4989 Date: Tue, 4 Jan 2022 23:49:33 +0900 Subject: [PATCH 2/6] =?UTF-8?q?fix:=20websh=5Ffront=E3=81=AEUI=E3=82=92?= =?UTF-8?q?=E5=A4=89=E6=9B=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- websh_front/public/index.html | 51 ++++- websh_front/src/index.nim | 361 ++++++++++++++++++++-------------- 2 files changed, 260 insertions(+), 152 deletions(-) diff --git a/websh_front/public/index.html b/websh_front/public/index.html index 14968ff..d25f4fc 100644 --- a/websh_front/public/index.html +++ b/websh_front/public/index.html @@ -4,17 +4,62 @@ websh - diff --git a/websh_front/src/index.nim b/websh_front/src/index.nim index 91c07fc..c095659 100644 --- a/websh_front/src/index.nim +++ b/websh_front/src/index.nim @@ -22,6 +22,14 @@ type MediaObj = object name, data: cstring + ContentType = enum + ctInfo, ctHistory, ctStdout, ctStderr + + Content = object + ## 画面に表示するコンテンツ + typ: ContentType + text: string + const statusOk = cint(0) statusTimeout = cint(1) @@ -59,6 +67,11 @@ var hashTag = cstring"シェル芸" shellHistory: seq[string] + contents = @[ + Content(typ: ctInfo, text: "Welcome to websh!"), + Content(typ: ctInfo, text: "Run: `websh help`"), + ] + # localstorageにシェルの履歴が存在するときだけ取得 if localstorage.hasItem("history"): let hist = localstorage.getItem("history").`$`.parseJson.to(seq[string]) @@ -76,12 +89,14 @@ if 1 < query.len: proc respCb(httpStatus: int, response: cstring) = let resp = fromJson[ResponseResult](response) - outputStatus = resp.status - outputSystemMessage = resp.system_message - outputStdout = resp.stdout - outputStderr = resp.stderr - outputImages = resp.images - outputElapsedTime = resp.elapsed_time + contents.add(Content(typ: ctStdout, text: $resp.stdout)) + contents.add(Content(typ: ctStderr, text: $resp.stderr)) + # outputStatus = resp.status + # outputSystemMessage = resp.system_message + # outputStdout = resp.stdout + # outputStderr = resp.stderr + # outputImages = resp.images + # outputElapsedTime = resp.elapsed_time # シェルの実行中表示 OFF isProgress = false @@ -89,6 +104,7 @@ proc sendShellButtonOnClick(ev: Event, n: VNode) = # シェルの実行中表示 isProgress = true let images = inputImages.filterIt(it.name != cstring"").mapIt(it.data) let body = %*{"code": inputShell, "images": images} + contents.add(Content(typ: ctHistory, text: $inputShell)) ajaxPost(apiUrl, headers = @[ (cstring"mode", cstring"cors"), @@ -154,149 +170,196 @@ proc croppedUrl(): string = result = result[0..