mirror of https://github.com/Requarks/wiki.git
Browse Source
misc: add support for VSCode remote development (#1533)
misc: add support for VSCode remote development (#1533)
* Add support for VSCode remote development * misc: remote dev containers fixes Co-authored-by: Nicolas Giard <github@ngpixel.com>pull/1548/head
Lukas Frischknecht
4 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
21 changed files with 52 additions and 507 deletions
Unified View
Diff Options
-
33.devcontainer/devcontainer.json
-
5dev/containers/Dockerfile
-
0dev/containers/config.yml
-
38dev/containers/docker-compose.yml
-
178dev/docker-common/wait.sh
-
21dev/docker-mariadb/Dockerfile
-
10dev/docker-mariadb/config.yml
-
50dev/docker-mariadb/docker-compose.yml
-
6dev/docker-mariadb/init.sh
-
21dev/docker-mssql/Dockerfile
-
10dev/docker-mssql/config.yml
-
40dev/docker-mssql/docker-compose.yml
-
6dev/docker-mssql/init.sh
-
21dev/docker-mysql/Dockerfile
-
10dev/docker-mysql/config.yml
-
50dev/docker-mysql/docker-compose.yml
-
6dev/docker-mysql/init.sh
-
6dev/docker-postgres/init.sh
-
20dev/docker-sqlite/Dockerfile
-
6dev/docker-sqlite/config.yml
-
22dev/docker-sqlite/docker-compose.yml
@ -0,0 +1,33 @@ |
|||||
|
// How to get remote container development working with VSCode: |
||||
|
// 1. Install "Remote Development" extension pack (ms-vscode-remote.vscode-remote-extensionpack) |
||||
|
// 2. Select "Remote Containers - Reopen in container" |
||||
|
|
||||
|
{ |
||||
|
"name": "Wiki.js", |
||||
|
"dockerComposeFile": [ |
||||
|
"../dev/containers/docker-compose.yml" |
||||
|
], |
||||
|
"forwardPorts": [3000, 3001], |
||||
|
"service": "wiki", |
||||
|
"workspaceFolder": "/wiki", |
||||
|
"settings": { |
||||
|
"terminal.integrated.shell.linux": "/bin/bash" |
||||
|
}, |
||||
|
"extensions": [ |
||||
|
"EditorConfig.editorconfig", |
||||
|
"dbaeumer.vscode-eslint", |
||||
|
"christian-kohler.path-intellisense", |
||||
|
"mrmlnc.vscode-puglint", |
||||
|
"octref.vetur", |
||||
|
"dzannotti.vscode-babel-coloring", |
||||
|
"wayou.vscode-todo-highlight", |
||||
|
"visualstudioexptteam.vscodeintellicode", |
||||
|
"lukas-tr.materialdesignicons-intellisense", |
||||
|
"codezombiech.gitignore", |
||||
|
"kumar-harsh.graphql-for-vscode", |
||||
|
"mrmlnc.vscode-duplicate", |
||||
|
"oderwat.indent-rainbow", |
||||
|
"christian-kohler.npm-intellisense" |
||||
|
], |
||||
|
"postCreateCommand": ["yarn", "install"] |
||||
|
} |
@ -1,178 +0,0 @@ |
|||||
#!/usr/bin/env bash |
|
||||
# Use this script to test if a given TCP host/port are available |
|
||||
|
|
||||
WAITFORIT_cmdname=${0##*/} |
|
||||
|
|
||||
echoerr() { if [[ $WAITFORIT_QUIET -ne 1 ]]; then echo "$@" 1>&2; fi } |
|
||||
|
|
||||
usage() |
|
||||
{ |
|
||||
cat << USAGE >&2 |
|
||||
Usage: |
|
||||
$WAITFORIT_cmdname host:port [-s] [-t timeout] [-- command args] |
|
||||
-h HOST | --host=HOST Host or IP under test |
|
||||
-p PORT | --port=PORT TCP port under test |
|
||||
Alternatively, you specify the host and port as host:port |
|
||||
-s | --strict Only execute subcommand if the test succeeds |
|
||||
-q | --quiet Don't output any status messages |
|
||||
-t TIMEOUT | --timeout=TIMEOUT |
|
||||
Timeout in seconds, zero for no timeout |
|
||||
-- COMMAND ARGS Execute command with args after the test finishes |
|
||||
USAGE |
|
||||
exit 1 |
|
||||
} |
|
||||
|
|
||||
wait_for() |
|
||||
{ |
|
||||
if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then |
|
||||
echoerr "$WAITFORIT_cmdname: waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" |
|
||||
else |
|
||||
echoerr "$WAITFORIT_cmdname: waiting for $WAITFORIT_HOST:$WAITFORIT_PORT without a timeout" |
|
||||
fi |
|
||||
WAITFORIT_start_ts=$(date +%s) |
|
||||
while : |
|
||||
do |
|
||||
if [[ $WAITFORIT_ISBUSY -eq 1 ]]; then |
|
||||
nc -z $WAITFORIT_HOST $WAITFORIT_PORT |
|
||||
WAITFORIT_result=$? |
|
||||
else |
|
||||
(echo > /dev/tcp/$WAITFORIT_HOST/$WAITFORIT_PORT) >/dev/null 2>&1 |
|
||||
WAITFORIT_result=$? |
|
||||
fi |
|
||||
if [[ $WAITFORIT_result -eq 0 ]]; then |
|
||||
WAITFORIT_end_ts=$(date +%s) |
|
||||
echoerr "$WAITFORIT_cmdname: $WAITFORIT_HOST:$WAITFORIT_PORT is available after $((WAITFORIT_end_ts - WAITFORIT_start_ts)) seconds" |
|
||||
break |
|
||||
fi |
|
||||
sleep 1 |
|
||||
done |
|
||||
return $WAITFORIT_result |
|
||||
} |
|
||||
|
|
||||
wait_for_wrapper() |
|
||||
{ |
|
||||
# In order to support SIGINT during timeout: http://unix.stackexchange.com/a/57692 |
|
||||
if [[ $WAITFORIT_QUIET -eq 1 ]]; then |
|
||||
timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --quiet --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & |
|
||||
else |
|
||||
timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & |
|
||||
fi |
|
||||
WAITFORIT_PID=$! |
|
||||
trap "kill -INT -$WAITFORIT_PID" INT |
|
||||
wait $WAITFORIT_PID |
|
||||
WAITFORIT_RESULT=$? |
|
||||
if [[ $WAITFORIT_RESULT -ne 0 ]]; then |
|
||||
echoerr "$WAITFORIT_cmdname: timeout occurred after waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" |
|
||||
fi |
|
||||
return $WAITFORIT_RESULT |
|
||||
} |
|
||||
|
|
||||
# process arguments |
|
||||
while [[ $# -gt 0 ]] |
|
||||
do |
|
||||
case "$1" in |
|
||||
*:* ) |
|
||||
WAITFORIT_hostport=(${1//:/ }) |
|
||||
WAITFORIT_HOST=${WAITFORIT_hostport[0]} |
|
||||
WAITFORIT_PORT=${WAITFORIT_hostport[1]} |
|
||||
shift 1 |
|
||||
;; |
|
||||
--child) |
|
||||
WAITFORIT_CHILD=1 |
|
||||
shift 1 |
|
||||
;; |
|
||||
-q | --quiet) |
|
||||
WAITFORIT_QUIET=1 |
|
||||
shift 1 |
|
||||
;; |
|
||||
-s | --strict) |
|
||||
WAITFORIT_STRICT=1 |
|
||||
shift 1 |
|
||||
;; |
|
||||
-h) |
|
||||
WAITFORIT_HOST="$2" |
|
||||
if [[ $WAITFORIT_HOST == "" ]]; then break; fi |
|
||||
shift 2 |
|
||||
;; |
|
||||
--host=*) |
|
||||
WAITFORIT_HOST="${1#*=}" |
|
||||
shift 1 |
|
||||
;; |
|
||||
-p) |
|
||||
WAITFORIT_PORT="$2" |
|
||||
if [[ $WAITFORIT_PORT == "" ]]; then break; fi |
|
||||
shift 2 |
|
||||
;; |
|
||||
--port=*) |
|
||||
WAITFORIT_PORT="${1#*=}" |
|
||||
shift 1 |
|
||||
;; |
|
||||
-t) |
|
||||
WAITFORIT_TIMEOUT="$2" |
|
||||
if [[ $WAITFORIT_TIMEOUT == "" ]]; then break; fi |
|
||||
shift 2 |
|
||||
;; |
|
||||
--timeout=*) |
|
||||
WAITFORIT_TIMEOUT="${1#*=}" |
|
||||
shift 1 |
|
||||
;; |
|
||||
--) |
|
||||
shift |
|
||||
WAITFORIT_CLI=("$@") |
|
||||
break |
|
||||
;; |
|
||||
--help) |
|
||||
usage |
|
||||
;; |
|
||||
*) |
|
||||
echoerr "Unknown argument: $1" |
|
||||
usage |
|
||||
;; |
|
||||
esac |
|
||||
done |
|
||||
|
|
||||
if [[ "$WAITFORIT_HOST" == "" || "$WAITFORIT_PORT" == "" ]]; then |
|
||||
echoerr "Error: you need to provide a host and port to test." |
|
||||
usage |
|
||||
fi |
|
||||
|
|
||||
WAITFORIT_TIMEOUT=${WAITFORIT_TIMEOUT:-15} |
|
||||
WAITFORIT_STRICT=${WAITFORIT_STRICT:-0} |
|
||||
WAITFORIT_CHILD=${WAITFORIT_CHILD:-0} |
|
||||
WAITFORIT_QUIET=${WAITFORIT_QUIET:-0} |
|
||||
|
|
||||
# check to see if timeout is from busybox? |
|
||||
WAITFORIT_TIMEOUT_PATH=$(type -p timeout) |
|
||||
WAITFORIT_TIMEOUT_PATH=$(realpath $WAITFORIT_TIMEOUT_PATH 2>/dev/null || readlink -f $WAITFORIT_TIMEOUT_PATH) |
|
||||
if [[ $WAITFORIT_TIMEOUT_PATH =~ "busybox" ]]; then |
|
||||
WAITFORIT_ISBUSY=1 |
|
||||
WAITFORIT_BUSYTIMEFLAG="-t" |
|
||||
|
|
||||
else |
|
||||
WAITFORIT_ISBUSY=0 |
|
||||
WAITFORIT_BUSYTIMEFLAG="" |
|
||||
fi |
|
||||
|
|
||||
if [[ $WAITFORIT_CHILD -gt 0 ]]; then |
|
||||
wait_for |
|
||||
WAITFORIT_RESULT=$? |
|
||||
exit $WAITFORIT_RESULT |
|
||||
else |
|
||||
if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then |
|
||||
wait_for_wrapper |
|
||||
WAITFORIT_RESULT=$? |
|
||||
else |
|
||||
wait_for |
|
||||
WAITFORIT_RESULT=$? |
|
||||
fi |
|
||||
fi |
|
||||
|
|
||||
if [[ $WAITFORIT_CLI != "" ]]; then |
|
||||
if [[ $WAITFORIT_RESULT -ne 0 && $WAITFORIT_STRICT -eq 1 ]]; then |
|
||||
echoerr "$WAITFORIT_cmdname: strict mode, refusing to execute subprocess" |
|
||||
exit $WAITFORIT_RESULT |
|
||||
fi |
|
||||
exec "${WAITFORIT_CLI[@]}" |
|
||||
else |
|
||||
exit $WAITFORIT_RESULT |
|
||||
fi |
|
@ -1,21 +0,0 @@ |
|||||
# -- DEV DOCKERFILE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
FROM node:10-alpine |
|
||||
LABEL maintainer "requarks.io" |
|
||||
|
|
||||
RUN apk update && \ |
|
||||
apk add bash curl git python make g++ nano openssh gnupg --no-cache && \ |
|
||||
mkdir -p /wiki |
|
||||
|
|
||||
WORKDIR /wiki |
|
||||
COPY package.json . |
|
||||
RUN yarn --silent |
|
||||
COPY ./dev/docker-mariadb/init.sh ./init.sh |
|
||||
|
|
||||
ENV dockerdev 1 |
|
||||
ENV DEVDB mariadb |
|
||||
|
|
||||
EXPOSE 3000 |
|
||||
|
|
||||
CMD ["tail", "-f", "/dev/null"] |
|
@ -1,10 +0,0 @@ |
|||||
port: 3000 |
|
||||
bindIP: 0.0.0.0 |
|
||||
db: |
|
||||
type: mariadb |
|
||||
host: db |
|
||||
port: 3306 |
|
||||
user: wikijs |
|
||||
pass: wikijsrocks |
|
||||
db: wiki |
|
||||
logLevel: info |
|
@ -1,50 +0,0 @@ |
|||||
# -- DEV DOCKER-COMPOSE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
version: "3" |
|
||||
services: |
|
||||
db: |
|
||||
image: mariadb:10.3 |
|
||||
environment: |
|
||||
MYSQL_DATABASE: wiki |
|
||||
MYSQL_PASSWORD: wikijsrocks |
|
||||
MYSQL_USER: wikijs |
|
||||
MYSQL_ROOT_PASSWORD: wikijsrocks |
|
||||
logging: |
|
||||
driver: "none" |
|
||||
volumes: |
|
||||
- db-data:/var/lib/mysql |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "13306:3306" |
|
||||
|
|
||||
adminer: |
|
||||
image: adminer:latest |
|
||||
logging: |
|
||||
driver: "none" |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "3001:8080" |
|
||||
|
|
||||
wiki: |
|
||||
build: |
|
||||
context: . |
|
||||
dockerfile: dev/docker-mariadb/Dockerfile |
|
||||
depends_on: |
|
||||
- db |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "3000:3000" |
|
||||
volumes: |
|
||||
- .:/wiki |
|
||||
- /wiki/node_modules |
|
||||
command: ["sh", "./dev/docker-mariadb/init.sh"] |
|
||||
|
|
||||
networks: |
|
||||
wikinet: |
|
||||
|
|
||||
volumes: |
|
||||
db-data: |
|
@ -1,6 +0,0 @@ |
|||||
#!/bin/sh |
|
||||
|
|
||||
echo "Waiting for mariadb to start up..." |
|
||||
bash ./dev/docker-common/wait.sh db:3306 |
|
||||
echo "=== READY ===" |
|
||||
tail -f /dev/null |
|
@ -1,21 +0,0 @@ |
|||||
# -- DEV DOCKERFILE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
FROM node:10-alpine |
|
||||
LABEL maintainer "requarks.io" |
|
||||
|
|
||||
RUN apk update && \ |
|
||||
apk add bash curl git python make g++ nano openssh gnupg --no-cache && \ |
|
||||
mkdir -p /wiki |
|
||||
|
|
||||
WORKDIR /wiki |
|
||||
COPY package.json . |
|
||||
RUN yarn --silent |
|
||||
COPY ./dev/docker-mssql/init.sh ./init.sh |
|
||||
|
|
||||
ENV dockerdev 1 |
|
||||
ENV DEVDB mssql |
|
||||
|
|
||||
EXPOSE 3000 |
|
||||
|
|
||||
CMD ["tail", "-f", "/dev/null"] |
|
@ -1,10 +0,0 @@ |
|||||
port: 3000 |
|
||||
bindIP: 0.0.0.0 |
|
||||
db: |
|
||||
type: mssql |
|
||||
host: db |
|
||||
port: 1433 |
|
||||
user: SA |
|
||||
pass: W1kiJSR0cks! |
|
||||
db: wiki |
|
||||
logLevel: info |
|
@ -1,40 +0,0 @@ |
|||||
# -- DEV DOCKER-COMPOSE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
version: "3" |
|
||||
services: |
|
||||
db: |
|
||||
image: mcr.microsoft.com/mssql/server:2017-latest |
|
||||
environment: |
|
||||
ACCEPT_EULA: 'Y' |
|
||||
MSSQL_PID: Developer |
|
||||
SA_PASSWORD: W1kiJSR0cks! |
|
||||
logging: |
|
||||
driver: "none" |
|
||||
volumes: |
|
||||
- db-data:/var/opt/mssql |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "11433:1433" |
|
||||
|
|
||||
wiki: |
|
||||
build: |
|
||||
context: . |
|
||||
dockerfile: dev/docker-mssql/Dockerfile |
|
||||
depends_on: |
|
||||
- db |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "3000:3000" |
|
||||
volumes: |
|
||||
- .:/wiki |
|
||||
- /wiki/node_modules |
|
||||
command: ["sh", "./dev/docker-mssql/init.sh"] |
|
||||
|
|
||||
networks: |
|
||||
wikinet: |
|
||||
|
|
||||
volumes: |
|
||||
db-data: |
|
@ -1,6 +0,0 @@ |
|||||
#!/bin/sh |
|
||||
|
|
||||
echo "Waiting for mssql to start up..." |
|
||||
bash ./dev/docker-common/wait.sh db:1433 |
|
||||
echo "=== READY ===" |
|
||||
tail -f /dev/null |
|
@ -1,21 +0,0 @@ |
|||||
# -- DEV DOCKERFILE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
FROM node:10-alpine |
|
||||
LABEL maintainer "requarks.io" |
|
||||
|
|
||||
RUN apk update && \ |
|
||||
apk add bash curl git python make g++ nano openssh gnupg --no-cache && \ |
|
||||
mkdir -p /wiki |
|
||||
|
|
||||
WORKDIR /wiki |
|
||||
COPY package.json . |
|
||||
RUN yarn --silent |
|
||||
COPY ./dev/docker-mysql/init.sh ./init.sh |
|
||||
|
|
||||
ENV dockerdev 1 |
|
||||
ENV DEVDB mysql |
|
||||
|
|
||||
EXPOSE 3000 |
|
||||
|
|
||||
CMD ["tail", "-f", "/dev/null"] |
|
@ -1,10 +0,0 @@ |
|||||
port: 3000 |
|
||||
bindIP: 0.0.0.0 |
|
||||
db: |
|
||||
type: mysql |
|
||||
host: db |
|
||||
port: 3306 |
|
||||
user: wikijs |
|
||||
pass: wikijsrocks |
|
||||
db: wiki |
|
||||
logLevel: info |
|
@ -1,50 +0,0 @@ |
|||||
# -- DEV DOCKER-COMPOSE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
version: "3" |
|
||||
services: |
|
||||
db: |
|
||||
image: mysql:5.7 |
|
||||
environment: |
|
||||
MYSQL_DATABASE: wiki |
|
||||
MYSQL_PASSWORD: wikijsrocks |
|
||||
MYSQL_USER: wikijs |
|
||||
MYSQL_ROOT_PASSWORD: wikijsrocks |
|
||||
logging: |
|
||||
driver: "none" |
|
||||
volumes: |
|
||||
- db-data:/var/lib/mysql |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "13306:3306" |
|
||||
|
|
||||
adminer: |
|
||||
image: adminer:latest |
|
||||
logging: |
|
||||
driver: "none" |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "3001:8080" |
|
||||
|
|
||||
wiki: |
|
||||
build: |
|
||||
context: . |
|
||||
dockerfile: dev/docker-mysql/Dockerfile |
|
||||
depends_on: |
|
||||
- db |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "3000:3000" |
|
||||
volumes: |
|
||||
- .:/wiki |
|
||||
- /wiki/node_modules |
|
||||
command: ["sh", "./dev/docker-mysql/init.sh"] |
|
||||
|
|
||||
networks: |
|
||||
wikinet: |
|
||||
|
|
||||
volumes: |
|
||||
db-data: |
|
@ -1,6 +0,0 @@ |
|||||
#!/bin/sh |
|
||||
|
|
||||
echo "Waiting for mysql to start up..." |
|
||||
bash ./dev/docker-common/wait.sh db:3306 |
|
||||
echo "=== READY ===" |
|
||||
tail -f /dev/null |
|
@ -1,6 +0,0 @@ |
|||||
#!/bin/sh |
|
||||
|
|
||||
echo "Waiting for postgres to start up..." |
|
||||
bash ./dev/docker-common/wait.sh db:5432 |
|
||||
echo "=== READY ===" |
|
||||
tail -f /dev/null |
|
@ -1,20 +0,0 @@ |
|||||
# -- DEV DOCKERFILE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
FROM node:10-alpine |
|
||||
LABEL maintainer "requarks.io" |
|
||||
|
|
||||
RUN apk update && \ |
|
||||
apk add bash curl git python make g++ nano openssh gnupg sqlite --no-cache && \ |
|
||||
mkdir -p /wiki |
|
||||
|
|
||||
WORKDIR /wiki |
|
||||
COPY package.json . |
|
||||
RUN yarn --silent |
|
||||
|
|
||||
ENV dockerdev 1 |
|
||||
ENV DEVDB sqlite |
|
||||
|
|
||||
EXPOSE 3000 |
|
||||
|
|
||||
CMD ["tail", "-f", "/dev/null"] |
|
@ -1,6 +0,0 @@ |
|||||
port: 3000 |
|
||||
bindIP: 0.0.0.0 |
|
||||
db: |
|
||||
type: sqlite |
|
||||
storage: /wiki/db.sqlite |
|
||||
logLevel: info |
|
@ -1,22 +0,0 @@ |
|||||
# -- DEV DOCKER-COMPOSE -- |
|
||||
# -- DO NOT USE IN PRODUCTION! -- |
|
||||
|
|
||||
version: "3" |
|
||||
services: |
|
||||
wiki: |
|
||||
build: |
|
||||
context: . |
|
||||
dockerfile: dev/docker-sqlite/Dockerfile |
|
||||
networks: |
|
||||
- wikinet |
|
||||
ports: |
|
||||
- "3000:3000" |
|
||||
volumes: |
|
||||
- .:/wiki |
|
||||
- /wiki/node_modules |
|
||||
|
|
||||
networks: |
|
||||
wikinet: |
|
||||
|
|
||||
volumes: |
|
||||
db-data: |
|
Write
Preview
Loading…
Cancel
Save