From df7919120e263ce2f081b8b6bcbd4fc817e60991 Mon Sep 17 00:00:00 2001
From: Giulio Dell'Oro
Date: Tue, 24 Oct 2023 10:09:09 +0200
Subject: [PATCH 1/2] Add nextJSTypescriptTemplate
---
nextJSTypeScript/.conf/deps.json | 8 +
nextJSTypeScript/.conf/id_rsa | 27 ++
nextJSTypeScript/.conf/id_rsa.pub | 1 +
nextJSTypeScript/.conf/update.json | 6 +
nextJSTypeScript/.dockerignore | 7 +
nextJSTypeScript/.eslintrc.json | 3 +
nextJSTypeScript/.gitignore | 35 ++
nextJSTypeScript/.vscode/launch.json | 122 +++++++
nextJSTypeScript/.vscode/settings.json | 18 ++
nextJSTypeScript/.vscode/tasks.json | 432 +++++++++++++++++++++++++
nextJSTypeScript/Dockerfile | 76 +++++
nextJSTypeScript/next.config.js | 7 +
nextJSTypeScript/package.json | 27 ++
nextJSTypeScript/pages/_app.tsx | 6 +
nextJSTypeScript/pages/_document.tsx | 13 +
nextJSTypeScript/pages/api/hello.ts | 13 +
nextJSTypeScript/pages/index.tsx | 118 +++++++
nextJSTypeScript/postcss.config.js | 6 +
nextJSTypeScript/public/favicon.ico | Bin 0 -> 25931 bytes
nextJSTypeScript/public/next.svg | 1 +
nextJSTypeScript/public/vercel.svg | 1 +
nextJSTypeScript/styles/globals.css | 3 +
nextJSTypeScript/tailwind.config.ts | 11 +
nextJSTypeScript/tsconfig.json | 22 ++
24 files changed, 963 insertions(+)
create mode 100644 nextJSTypeScript/.conf/deps.json
create mode 100644 nextJSTypeScript/.conf/id_rsa
create mode 100644 nextJSTypeScript/.conf/id_rsa.pub
create mode 100644 nextJSTypeScript/.conf/update.json
create mode 100644 nextJSTypeScript/.dockerignore
create mode 100644 nextJSTypeScript/.eslintrc.json
create mode 100644 nextJSTypeScript/.gitignore
create mode 100644 nextJSTypeScript/.vscode/launch.json
create mode 100644 nextJSTypeScript/.vscode/settings.json
create mode 100644 nextJSTypeScript/.vscode/tasks.json
create mode 100644 nextJSTypeScript/Dockerfile
create mode 100644 nextJSTypeScript/next.config.js
create mode 100644 nextJSTypeScript/package.json
create mode 100644 nextJSTypeScript/pages/_app.tsx
create mode 100644 nextJSTypeScript/pages/_document.tsx
create mode 100644 nextJSTypeScript/pages/api/hello.ts
create mode 100644 nextJSTypeScript/pages/index.tsx
create mode 100644 nextJSTypeScript/postcss.config.js
create mode 100644 nextJSTypeScript/public/favicon.ico
create mode 100644 nextJSTypeScript/public/next.svg
create mode 100644 nextJSTypeScript/public/vercel.svg
create mode 100644 nextJSTypeScript/styles/globals.css
create mode 100644 nextJSTypeScript/tailwind.config.ts
create mode 100644 nextJSTypeScript/tsconfig.json
diff --git a/nextJSTypeScript/.conf/deps.json b/nextJSTypeScript/.conf/deps.json
new file mode 100644
index 000000000..b213dfed7
--- /dev/null
+++ b/nextJSTypeScript/.conf/deps.json
@@ -0,0 +1,8 @@
+{
+ "packages": [
+ "openssh-client",
+ "sshpass",
+ "nodejs",
+ "npm"
+ ]
+}
diff --git a/nextJSTypeScript/.conf/id_rsa b/nextJSTypeScript/.conf/id_rsa
new file mode 100644
index 000000000..eef640ef6
--- /dev/null
+++ b/nextJSTypeScript/.conf/id_rsa
@@ -0,0 +1,27 @@
+-----BEGIN RSA PRIVATE KEY-----
+MIIEpQIBAAKCAQEAqpUaOa6i/TaSKwpdsHzLfGK95dDcFYpmYH5hUj0cBhVEVdl8
+JAG0MEDcZsjQHiBlfUiHmyU2iOWBoKUytpMnzYF6ggdZBv5hBMv3RcTlnNijxzxg
+KvbjTm3LqAY8uu4SF9I8oDXVOn7xwZYgiC7s3XRGOP6TowSVEHsLB+cehWs4Y5io
+3BngOlcOYZtVrh+i3A7xSHWP7n2IetJEo5C425oaOCZXUJT2egau6ODmvBItZjpG
+mNdwVwrEI2H3o+LLI9tieNfyFcUFPNDRXbku1V0mXU9VjZ7WFihZXob11XNCEkY7
+Bg3SpzTntSRn9hZD7i3xDU9MSJz90rnn56ID1wIDAQABAoIBACI239i7/3Mcc/rw
+DFSu4z2irIYg+1PSu7AVCT4uhaVutJMnmS+7q8GV8N8o3h18z/5uAs0KjMKuje6D
+1AUsxOoCU2krQh8V/K2yn3k+AfQQu+DlakCT3onHmfassZeo0rY2c/SKd6dQ+Pqk
+Owg1qUrN3Jvn7ALhk2iH1XGTWNrXj44AxVVhK3zADd/688stubo+mhj1vLJvk3IJ
+j/cb9UtCnWDZ6U6E4C+5tfXqzrqbtlrWnIBe0qAwYI6+f4bSQxnNa42wNUh0v0mX
+tiY9wnHEmE7nCQNQ8sBeBLEJm3xmFRhABNA+iAglsjfeBIbPNpy7rXty412CmHp0
+mLG0RskCgYEA4t4Ca3EDq/scg7fiplLjhk2AtsZumkYT/N+42x4VlioKfoaivLKf
+6mjWUSr+c7Aq0Ssx9GdOFU0epNGbuvymCGBhq6v27SADMJTP2Dmg83FpcV6opOUM
+SBz1tnrL9j74Eo9jGdnBjgxHOl4biO+uCjCZxcLoVjsfPpGnCeNSpFUCgYEAwHzM
+GfiBR9wl+7cVrtP4YQgmzyZ6YCnqkfFasVAe6cN/0if5sqQRn3Fg3YFrP9GlKkkn
+EMvow56nTWUmpx4KG4yanrocEYIsA4uv4kwyFOC/YD+67SQpgTEOjD0seDJoOgpz
+ekkxNjMro8RJCK+DrV17qk3/dGY4b3u2M66P03sCgYEAhHCcswJX5WeD/vUzkGtl
+PfsywADZgqCUfJRSg0Bt06sZU0Hf8Q7KQnsPWnUh9IGMjW2NDSPdtpu93vQq2J8z
+gkJZ4nFShp2gnxTQvWbvKg80QiXDh/fbEqItY2kOduPNyHACp42y6+0JC+7yXh+l
+13cF3ihpoCWFmO5IuIIHtb0CgYEAk5acwEUEi17HWOuWmog4591iNG8iYd2B2Akh
+Ktdt/HtD5JV2JX0bbg924CA9ZZ+Pbo7Mf1p5zJQ3X2Zxbq3fviPe4ll88AfJS6at
+Y2xc8hkpY9k5sF6L3F0K9IhrMnYj6GzfAiJgs1gk29rCzQAWjLUi/v/zIQLHvuMy
+Xwo3iUUCgYEAo/27Qkb5nOdL8sJwFggDrdB1pPrxXN20KmYCJF1P9wPDhnj1fJ7+
+0Z/56XYzPA2rQx0vf5idvoGQ3KZS7QkOClLtcyevH3b38fnmAqv+dPLRHmrSd+3G
+BspdMlr3rwZK8RKwXjDzLYpwSvjmf7PTGTPO3C7WTzg+m0U9RbSJKi4=
+-----END RSA PRIVATE KEY-----
diff --git a/nextJSTypeScript/.conf/id_rsa.pub b/nextJSTypeScript/.conf/id_rsa.pub
new file mode 100644
index 000000000..86f8fe63f
--- /dev/null
+++ b/nextJSTypeScript/.conf/id_rsa.pub
@@ -0,0 +1 @@
+ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCqlRo5rqL9NpIrCl2wfMt8Yr3l0NwVimZgfmFSPRwGFURV2XwkAbQwQNxmyNAeIGV9SIebJTaI5YGgpTK2kyfNgXqCB1kG/mEEy/dFxOWc2KPHPGAq9uNObcuoBjy67hIX0jygNdU6fvHBliCILuzddEY4/pOjBJUQewsH5x6FazhjmKjcGeA6Vw5hm1WuH6LcDvFIdY/ufYh60kSjkLjbmho4JldQlPZ6Bq7o4Oa8Ei1mOkaY13BXCsQjYfej4ssj22J41/IVxQU80NFduS7VXSZdT1WNntYWKFlehvXVc0ISRjsGDdKnNOe1JGf2FkPuLfENT0xInP3SuefnogPX
\ No newline at end of file
diff --git a/nextJSTypeScript/.conf/update.json b/nextJSTypeScript/.conf/update.json
new file mode 100644
index 000000000..1da61ec5c
--- /dev/null
+++ b/nextJSTypeScript/.conf/update.json
@@ -0,0 +1,6 @@
+[
+ {
+ "source": ".vscode/launch.json",
+ "target": ".vscode/launch.json"
+ }
+]
diff --git a/nextJSTypeScript/.dockerignore b/nextJSTypeScript/.dockerignore
new file mode 100644
index 000000000..c5500558b
--- /dev/null
+++ b/nextJSTypeScript/.dockerignore
@@ -0,0 +1,7 @@
+Dockerfile
+.dockerignore
+node_modules
+npm-debug.log
+README.md
+.next
+.git
diff --git a/nextJSTypeScript/.eslintrc.json b/nextJSTypeScript/.eslintrc.json
new file mode 100644
index 000000000..bffb357a7
--- /dev/null
+++ b/nextJSTypeScript/.eslintrc.json
@@ -0,0 +1,3 @@
+{
+ "extends": "next/core-web-vitals"
+}
diff --git a/nextJSTypeScript/.gitignore b/nextJSTypeScript/.gitignore
new file mode 100644
index 000000000..8f322f0d8
--- /dev/null
+++ b/nextJSTypeScript/.gitignore
@@ -0,0 +1,35 @@
+# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
+
+# dependencies
+/node_modules
+/.pnp
+.pnp.js
+
+# testing
+/coverage
+
+# next.js
+/.next/
+/out/
+
+# production
+/build
+
+# misc
+.DS_Store
+*.pem
+
+# debug
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+
+# local env files
+.env*.local
+
+# vercel
+.vercel
+
+# typescript
+*.tsbuildinfo
+next-env.d.ts
diff --git a/nextJSTypeScript/.vscode/launch.json b/nextJSTypeScript/.vscode/launch.json
new file mode 100644
index 000000000..5a453f170
--- /dev/null
+++ b/nextJSTypeScript/.vscode/launch.json
@@ -0,0 +1,122 @@
+{
+ "version": "0.2.0",
+ "configurations": [
+ {
+ "name": "Next.js Proxy Server",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port}",
+ "cwd": "${workspaceFolder}",
+ "sourceMaps": true,
+ "autoAttachChildProcesses": true,
+ "attachExistingChildren": true,
+ "preLaunchTask": "run-nextjs-local",
+ "postDebugTask": "kill-nextjs-local"
+ },
+ {
+ "name": "Next.js Routing Server",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port2}",
+ "cwd": "${workspaceFolder}",
+ "sourceMaps": true,
+ "autoAttachChildProcesses": true,
+ "attachExistingChildren": true,
+ "preLaunchTask": "wait-for-run-local"
+ },
+ {
+ "name": "Next.js Pages Server",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port3}",
+ "cwd": "${workspaceFolder}",
+ "sourceMaps": true,
+ "autoAttachChildProcesses": true,
+ "attachExistingChildren": true,
+ "preLaunchTask": "wait-for-run-local"
+ },
+ {
+ "name": "Torizon AMD64",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port}",
+ "address": "${config:torizon_ip}",
+ "restart": false,
+ "sourceMaps": true,
+ "continueOnAttach": true,
+ "localRoot": "${workspaceFolder}",
+ "remoteRoot": "${config:torizon_app_root}/app/",
+ "preLaunchTask": "start-torizon-debug-amd64"
+ },
+ {
+ "name": "Torizon ARMv7",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port}",
+ "address": "${config:torizon_ip}",
+ "restart": false,
+ "sourceMaps": true,
+ "continueOnAttach": true,
+ "localRoot": "${workspaceFolder}",
+ "remoteRoot": "${config:torizon_app_root}/app/",
+ "preLaunchTask": "start-torizon-debug-arm"
+ },
+ {
+ "name": "Torizon ARMv8 Proxy Server",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port}",
+ "address": "${config:torizon_ip}",
+ "sourceMaps": true,
+ "autoAttachChildProcesses": true,
+ "attachExistingChildren": true,
+ "remoteRoot": "${config:torizon_app_root}/app/out/",
+ "localRoot": "${workspaceFolder}/",
+ "preLaunchTask": "wait-for-run"
+ },
+ {
+ "name": "Torizon ARMv8 Routing Server",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port2}",
+ "address": "${config:torizon_ip}",
+ "sourceMaps": true,
+ "autoAttachChildProcesses": true,
+ "attachExistingChildren": true,
+ "remoteRoot": "${config:torizon_app_root}/app/out/",
+ "localRoot": "${workspaceFolder}/",
+ "preLaunchTask": "wait-for-run"
+ },
+ {
+ "name": "Torizon ARMv8 Server Pages",
+ "type": "node",
+ "request": "attach",
+ "port": "${config:torizon_debug_port3}",
+ "address": "${config:torizon_ip}",
+ "sourceMaps": true,
+ "autoAttachChildProcesses": true,
+ "attachExistingChildren": true,
+ "remoteRoot": "${config:torizon_app_root}/app/out/",
+ "localRoot": "${workspaceFolder}/",
+ "preLaunchTask": "start-torizon-debug-arm64"
+ },
+ ],
+ "compounds": [
+ {
+ "name": "Next.js Local",
+ "configurations": [
+ "Next.js Proxy Server",
+ "Next.js Routing Server",
+ "Next.js Pages Server"
+ ]
+ },
+ {
+ "name": "Torizon ARMv8",
+ "configurations": [
+ "Torizon ARMv8 Server Pages",
+ "Torizon ARMv8 Proxy Server",
+ "Torizon ARMv8 Routing Server",
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/nextJSTypeScript/.vscode/settings.json b/nextJSTypeScript/.vscode/settings.json
new file mode 100644
index 000000000..e2a9869ce
--- /dev/null
+++ b/nextJSTypeScript/.vscode/settings.json
@@ -0,0 +1,18 @@
+{
+ "torizon_psswd": "",
+ "torizon_login": "",
+ "torizon_ip": "",
+ "host_ip": "",
+ "torizon_workspace": "${workspaceFolder}",
+ "torizon_debug_port": "9229",
+ "torizon_debug_ssh_port": "2229",
+ "torizon_debug_port2": "9230",
+ "torizon_debug_port3": "9231",
+ "torizon_gpu": "",
+ "torizon_arch": "",
+ "wait_sync": "1",
+ "torizon_run_as": "torizon",
+ "torizon_app_root": "/home/torizon",
+ "tcb.packageName": "__change__",
+ "tcb.version": "early-access"
+}
\ No newline at end of file
diff --git a/nextJSTypeScript/.vscode/tasks.json b/nextJSTypeScript/.vscode/tasks.json
new file mode 100644
index 000000000..952dcc52e
--- /dev/null
+++ b/nextJSTypeScript/.vscode/tasks.json
@@ -0,0 +1,432 @@
+{
+ "version": "2.0.0",
+ "tasks": [
+ {
+ "label": "build-nextjs-local",
+ "detail": "hide",
+ "command": "npm",
+ "type": "process",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "run",
+ "build"
+ ],
+ "problemMatcher": [
+ "$tsc"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ },
+ "dependsOn": [
+ "npm-install"
+ ]
+ },
+ {
+ "label": "run-nextjs-local",
+ "detail": "hide",
+ "command": "npm",
+ "type": "shell",
+ "isBackground": true,
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "run",
+ "dev"
+ ],
+ "problemMatcher": [
+ {
+ "pattern": [
+ {
+ "regexp": ".",
+ "file": 1,
+ "location": 2,
+ "severity": 3,
+ "code": 4,
+ "message": 5
+ }
+ ],
+ "background": {
+ "activeOnStart": true,
+ "beginsPattern": ".",
+ "endsPattern": "for pages should be inspected at port"
+ }
+ }
+ ],
+ "presentation": {
+ "reveal": "always"
+ },
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ },
+ "dependsOn": [
+ "npm-install"
+ ]
+ },
+ {
+ "label": "kill-nextjs-local",
+ "detail": "hide",
+ "command": "pkill",
+ "type": "shell",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "-9",
+ "npm run dev"
+ ],
+ "problemMatcher": [
+ "$tsc"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ },
+ },
+ {
+ "label": "wait-for-run-local",
+ "command": "until $(curl --output /dev/null --silent --head --fail http://localhost:3000); do printf '.'; sleep 1; done",
+ "type": "shell",
+ "args": [],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "watch",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "npm-install",
+ "type": "shell",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "command": "[ ! -d 'node_modules' ] && npm install || true",
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "npm-install-remote",
+ "command": "ssh",
+ "type": "process",
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-p",
+ "${config:torizon_debug_ssh_port}",
+ "${config:torizon_run_as}@${config:torizon_ip}",
+ "cd ${config:torizon_app_root}/app && npm install"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "build-nextjs-arm",
+ "detail": "hide",
+ "command": "npm",
+ "type": "process",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "run",
+ "output-arm"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "deploy-torizon-arm",
+ "detail": "hide",
+ "command": "scp",
+ "type": "process",
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-P",
+ "${config:torizon_debug_ssh_port}",
+ "-pr",
+ "${workspaceFolder}/.next/standalone",
+ "${config:torizon_run_as}@${config:torizon_ip}:~/app"
+ ],
+ "dependsOrder": "sequence",
+ "problemMatcher": "$msCompile",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "start-torizon-debug-arm",
+ "detail": "hide",
+ "command": "ssh",
+ "type": "process",
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-p",
+ "${config:torizon_debug_ssh_port}",
+ "${config:torizon_run_as}@${config:torizon_ip}",
+ "npm run dev"
+ ],
+ "dependsOn": [
+ "validate-settings",
+ "validate-arch-arm",
+ "apply-torizon-packages",
+ "npm-install",
+ "build-nextjs-arm",
+ "copy-docker-compose",
+ "pre-cleanup-arm",
+ "package-torizon-arm",
+ "build-container-torizon-debug-arm",
+ "push-container-torizon-debug-arm",
+ "pull-container-torizon-debug-arm",
+ "run-container-torizon-debug-arm",
+ "wait-a-bit",
+ "pos-cleanup",
+ "deploy-torizon-arm"
+ ],
+ "dependsOrder": "sequence",
+ "problemMatcher": "$msCompile",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "build-nextjs-arm64",
+ "detail": "hide",
+ "command": "npm",
+ "type": "process",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "run",
+ "output-arm64"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "output-nextjs-arm64",
+ "detail": "",
+ "command": "npm",
+ "type": "shell",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "run",
+ "output-arm64"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "deploy-torizon-arm64",
+ "detail": "hide",
+ "command": "scp",
+ "type": "process",
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-P",
+ "${config:torizon_debug_ssh_port}",
+ "-pr",
+ "${workspaceFolder}/.next/standalone",
+ "${config:torizon_run_as}@${config:torizon_ip}:~/app"
+ ],
+ "dependsOrder": "sequence",
+ "problemMatcher": "$msCompile",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "start-torizon-debug-arm64",
+ "detail": "",
+ "command": "ssh",
+ "type": "process",
+ "isBackground": true,
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-p",
+ "${config:torizon_debug_ssh_port}",
+ "${config:torizon_run_as}@${config:torizon_ip}",
+ "cd ${config:torizon_app_root}/app && npm run dev"
+ ],
+ "problemMatcher": [
+ {
+ "pattern": [
+ {
+ "regexp": ".",
+ "file": 1,
+ "location": 2,
+ "severity": 3,
+ "code": 4,
+ "message": 5
+ }
+ ],
+ "background": {
+ "activeOnStart": true,
+ "beginsPattern": ".",
+ "endsPattern": "for pages should be inspected at port",
+ }
+ }
+ ],
+ "presentation": {
+ "reveal": "always"
+ },
+ "dependsOn": [
+ "validate-settings",
+ "validate-arch-arm64",
+ "apply-torizon-packages",
+ "output-nextjs-arm64",
+ "copy-docker-compose",
+ "pre-cleanup-arm64",
+ "build-container-torizon-debug-arm64",
+ "push-container-torizon-debug-arm64",
+ "pull-container-torizon-debug-arm64",
+ "run-container-torizon-debug-arm64",
+ "wait-a-bit",
+ "pos-cleanup",
+ "deploy-torizon-arm64",
+ "npm-install-remote"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "build-nextjs-amd64",
+ "detail": "hide",
+ "command": "npm",
+ "type": "process",
+ "options": {
+ "cwd": "${workspaceFolder}"
+ },
+ "args": [
+ "run",
+ "output-amd64"
+ ],
+ "dependsOrder": "sequence",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "deploy-torizon-amd64",
+ "detail": "hide",
+ "command": "scp",
+ "type": "process",
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-P",
+ "${config:torizon_debug_ssh_port}",
+ "-pr",
+ "${workspaceFolder}/.next/standalone",
+ "${config:torizon_run_as}@${config:torizon_ip}:~/app"
+ ],
+ "dependsOrder": "sequence",
+ "problemMatcher": "$msCompile",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ },
+ {
+ "label": "start-torizon-debug-amd64",
+ "detail": "hide",
+ "command": "ssh",
+ "type": "process",
+ "args": [
+ "-i",
+ "${workspaceFolder}/.conf/id_rsa",
+ "-o",
+ "UserKnownHostsFile=/dev/null",
+ "-o",
+ "StrictHostKeyChecking=no",
+ "-p",
+ "${config:torizon_debug_ssh_port}",
+ "${config:torizon_run_as}@${config:torizon_ip}",
+ "npm run dev"
+ ],
+ "dependsOn": [
+ "validate-settings",
+ "validate-arch-amd64",
+ "apply-torizon-packages",
+ "npm-install",
+ "build-nextjs-amd64",
+ "copy-docker-compose",
+ "pre-cleanup-amd64",
+ "package-torizon-amd64",
+ "build-container-torizon-debug-amd64",
+ "push-container-torizon-debug-amd64",
+ "pull-container-torizon-debug-amd64",
+ "run-container-torizon-debug-amd64",
+ "wait-a-bit",
+ "pos-cleanup",
+ "deploy-torizon-amd64"
+ ],
+ "dependsOrder": "sequence",
+ "problemMatcher": "$msCompile",
+ "icon": {
+ "id": "flame",
+ "color": "terminal.ansiYellow"
+ }
+ }
+ ],
+ "inputs": []
+}
\ No newline at end of file
diff --git a/nextJSTypeScript/Dockerfile b/nextJSTypeScript/Dockerfile
new file mode 100644
index 000000000..e2b99d56c
--- /dev/null
+++ b/nextJSTypeScript/Dockerfile
@@ -0,0 +1,76 @@
+
+ARG IMAGE=arm64v8/node:18-alpine
+
+# Install dependencies only when needed
+FROM ${IMAGE} AS deps
+# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
+RUN apk add --no-cache libc6-compat
+WORKDIR /app
+
+
+## -> SET ACCORDING TO PACKAGE MANAGER
+
+# -> YARN
+COPY package.json yarn.lock ./
+RUN yarn install --frozen-lockfile
+
+# -> NPM
+# If using npm with a `package-lock.json` comment out above and use below instead
+# COPY package.json package-lock.json ./
+# RUN npm install
+
+
+# -> PNPM
+# RUN curl -L https://unpkg.com/@pnpm/self-installer | node
+# COPY package.json pnpm-lock.yaml ./
+# RUN pnpm install --frozen-lockfile
+
+# Rebuild the source code only when needed
+FROM ${IMAGE} AS builder
+WORKDIR /app
+COPY --from=deps /app/node_modules ./node_modules
+COPY . .
+
+## -> SET ACCORDING TO PACKAGE MANAGER
+
+# -> YARN
+RUN yarn build
+
+# -> NPM
+# RUN npm run build
+
+# -> PNPM
+# RUN pnpm run build
+
+# If using npm comment out above and use below instead
+# RUN npm run build
+
+# Production image, copy all the files and run next
+FROM ${IMAGE} AS runner
+WORKDIR /app
+
+ENV NODE_ENV production
+# Uncomment the following line in case you want to disable telemetry during runtime.
+# ENV NEXT_TELEMETRY_DISABLED 1
+
+RUN addgroup --system --gid 1001 nodejs
+RUN adduser --system --uid 1001 nextjs
+
+# You only need to copy next.config.js if you are NOT using the default configuration
+# COPY --from=builder /app/next.config.js ./
+COPY --from=builder /app/public ./public
+COPY --from=builder /app/package.json ./package.json
+
+
+# Automatically leverage output traces to reduce image size
+# https://nextjs.org/docs/advanced-features/output-file-tracing
+COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
+COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
+
+USER nextjs
+
+EXPOSE 3000
+
+ENV PORT 3000
+
+CMD ["node", "server.js"]
\ No newline at end of file
diff --git a/nextJSTypeScript/next.config.js b/nextJSTypeScript/next.config.js
new file mode 100644
index 000000000..793352b7b
--- /dev/null
+++ b/nextJSTypeScript/next.config.js
@@ -0,0 +1,7 @@
+/** @type {import('next').NextConfig} */
+const nextConfig = {
+ reactStrictMode: true,
+ output: "standalone",
+};
+
+module.exports = nextConfig;
diff --git a/nextJSTypeScript/package.json b/nextJSTypeScript/package.json
new file mode 100644
index 000000000..ac0f6aaf2
--- /dev/null
+++ b/nextJSTypeScript/package.json
@@ -0,0 +1,27 @@
+{
+ "name": "nextjs_typescript_template",
+ "version": "0.1.0",
+ "private": true,
+ "scripts": {
+ "dev": "next dev",
+ "build": "next build",
+ "start": "next start",
+ "lint": "next lint"
+ },
+ "dependencies": {
+ "react": "^18",
+ "react-dom": "^18",
+ "next": "13.5.6"
+ },
+ "devDependencies": {
+ "typescript": "^5",
+ "@types/node": "^20",
+ "@types/react": "^18",
+ "@types/react-dom": "^18",
+ "autoprefixer": "^10",
+ "postcss": "^8",
+ "tailwindcss": "^3",
+ "eslint": "^8",
+ "eslint-config-next": "13.5.6"
+ }
+}
\ No newline at end of file
diff --git a/nextJSTypeScript/pages/_app.tsx b/nextJSTypeScript/pages/_app.tsx
new file mode 100644
index 000000000..021681f4d
--- /dev/null
+++ b/nextJSTypeScript/pages/_app.tsx
@@ -0,0 +1,6 @@
+import '@/styles/globals.css'
+import type { AppProps } from 'next/app'
+
+export default function App({ Component, pageProps }: AppProps) {
+ return
+}
diff --git a/nextJSTypeScript/pages/_document.tsx b/nextJSTypeScript/pages/_document.tsx
new file mode 100644
index 000000000..54e8bf3e2
--- /dev/null
+++ b/nextJSTypeScript/pages/_document.tsx
@@ -0,0 +1,13 @@
+import { Html, Head, Main, NextScript } from 'next/document'
+
+export default function Document() {
+ return (
+
+
+
+
+
+
+
+ )
+}
diff --git a/nextJSTypeScript/pages/api/hello.ts b/nextJSTypeScript/pages/api/hello.ts
new file mode 100644
index 000000000..f8bcc7e5c
--- /dev/null
+++ b/nextJSTypeScript/pages/api/hello.ts
@@ -0,0 +1,13 @@
+// Next.js API route support: https://nextjs.org/docs/api-routes/introduction
+import type { NextApiRequest, NextApiResponse } from 'next'
+
+type Data = {
+ name: string
+}
+
+export default function handler(
+ req: NextApiRequest,
+ res: NextApiResponse
+) {
+ res.status(200).json({ name: 'John Doe' })
+}
diff --git a/nextJSTypeScript/pages/index.tsx b/nextJSTypeScript/pages/index.tsx
new file mode 100644
index 000000000..000a75138
--- /dev/null
+++ b/nextJSTypeScript/pages/index.tsx
@@ -0,0 +1,118 @@
+import Image from 'next/image'
+import { Inter } from 'next/font/google'
+
+const inter = Inter({ subsets: ['latin'] })
+
+export default function Home() {
+ return (
+
+
+
+ Get started by editing
+ pages/index.tsx
+
+
+
+
+
+
+
+
+
+
+ )
+}
diff --git a/nextJSTypeScript/postcss.config.js b/nextJSTypeScript/postcss.config.js
new file mode 100644
index 000000000..33ad091d2
--- /dev/null
+++ b/nextJSTypeScript/postcss.config.js
@@ -0,0 +1,6 @@
+module.exports = {
+ plugins: {
+ tailwindcss: {},
+ autoprefixer: {},
+ },
+}
diff --git a/nextJSTypeScript/public/favicon.ico b/nextJSTypeScript/public/favicon.ico
new file mode 100644
index 0000000000000000000000000000000000000000..718d6fea4835ec2d246af9800eddb7ffb276240c
GIT binary patch
literal 25931
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
LrJugUA?W`A8`#=m
literal 0
HcmV?d00001
diff --git a/nextJSTypeScript/public/next.svg b/nextJSTypeScript/public/next.svg
new file mode 100644
index 000000000..5174b28c5
--- /dev/null
+++ b/nextJSTypeScript/public/next.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/nextJSTypeScript/public/vercel.svg b/nextJSTypeScript/public/vercel.svg
new file mode 100644
index 000000000..d2f842227
--- /dev/null
+++ b/nextJSTypeScript/public/vercel.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/nextJSTypeScript/styles/globals.css b/nextJSTypeScript/styles/globals.css
new file mode 100644
index 000000000..b5c61c956
--- /dev/null
+++ b/nextJSTypeScript/styles/globals.css
@@ -0,0 +1,3 @@
+@tailwind base;
+@tailwind components;
+@tailwind utilities;
diff --git a/nextJSTypeScript/tailwind.config.ts b/nextJSTypeScript/tailwind.config.ts
new file mode 100644
index 000000000..b7d25c617
--- /dev/null
+++ b/nextJSTypeScript/tailwind.config.ts
@@ -0,0 +1,11 @@
+import type { Config } from "tailwindcss";
+
+const config: Config = {
+ content: [
+ "./pages/**/*.{js,ts,jsx,tsx,mdx}",
+ "./components/**/*.{js,ts,jsx,tsx,mdx}",
+ "./app/**/*.{js,ts,jsx,tsx,mdx}",
+ ],
+ plugins: [],
+};
+export default config;
diff --git a/nextJSTypeScript/tsconfig.json b/nextJSTypeScript/tsconfig.json
new file mode 100644
index 000000000..670224f3e
--- /dev/null
+++ b/nextJSTypeScript/tsconfig.json
@@ -0,0 +1,22 @@
+{
+ "compilerOptions": {
+ "target": "es5",
+ "lib": ["dom", "dom.iterable", "esnext"],
+ "allowJs": true,
+ "skipLibCheck": true,
+ "strict": true,
+ "noEmit": true,
+ "esModuleInterop": true,
+ "module": "esnext",
+ "moduleResolution": "bundler",
+ "resolveJsonModule": true,
+ "isolatedModules": true,
+ "jsx": "preserve",
+ "incremental": true,
+ "paths": {
+ "@/*": ["./*"]
+ }
+ },
+ "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"],
+ "exclude": ["node_modules"]
+}
From 7a506598dc12a50bd2ff6e7cf8a4e0af4c251518 Mon Sep 17 00:00:00 2001
From: Giulio Dell'Oro
Date: Tue, 24 Oct 2023 10:15:44 +0200
Subject: [PATCH 2/2] add Dockerfile.debug
---
nextJSTypeScript/Dockerfile.debug | 136 ++++++++++++++++++++++++++++++
1 file changed, 136 insertions(+)
create mode 100644 nextJSTypeScript/Dockerfile.debug
diff --git a/nextJSTypeScript/Dockerfile.debug b/nextJSTypeScript/Dockerfile.debug
new file mode 100644
index 000000000..30251978a
--- /dev/null
+++ b/nextJSTypeScript/Dockerfile.debug
@@ -0,0 +1,136 @@
+# ARGUMENTS --------------------------------------------------------------------
+##
+# Board architecture
+##
+ARG IMAGE_ARCH=
+# For armv7 use:
+#ARG IMAGE_ARCH=arm
+
+##
+# Base container version
+##
+ARG BASE_VERSION=3-bookworm
+
+##
+# Application Name
+##
+ARG APP_EXECUTABLE=__change__
+
+##
+# Debug port
+##
+ARG SSH_DEBUG_PORT=
+
+##
+# Run as
+##
+ARG SSHUSERNAME=
+
+##
+# Board GPU vendor prefix
+##
+ARG GPU=
+
+# BUILD ------------------------------------------------------------------------
+##
+# Deploy Step
+##
+FROM --platform=linux/${IMAGE_ARCH} \
+ torizon/wayland-base${GPU}:${BASE_VERSION} AS Debug
+
+ARG IMAGE_ARCH
+ARG GPU
+ARG SSH_DEBUG_PORT
+ARG APP_EXECUTABLE
+ARG SSHUSERNAME
+ENV APP_EXECUTABLE ${APP_EXECUTABLE}
+
+# SSH for remote debug
+EXPOSE ${SSH_DEBUG_PORT}
+EXPOSE 9229
+
+# WORKDIR instruction sets the working directory for any RUN, CMD, ENTRYPOINT, COPY and ADD instructions that follow it in the Dockerfile
+WORKDIR /app
+
+# Make sure we don't get notifications we can't answer during building.
+ENV DEBIAN_FRONTEND="noninteractive"
+
+# for vivante GPU we need some "special" sauce
+RUN apt-get -q -y update && \
+ if [ "${GPU}" = "-vivante" ]; then \
+ apt-get -q -y install \
+ imx-gpu-viv-wayland-dev \
+ ; else \
+ apt-get -q -y install \
+ libgl1 \
+ ; fi \
+ && \
+ apt-get clean && apt-get autoremove && \
+ rm -rf /var/lib/apt/lists/*
+
+# your regular RUN statements here
+# Install required packages
+RUN apt-get -q -y update && \
+ apt-get -q -y install \
+ gcc \
+ g++ \
+ make \
+ openssl \
+ openssh-server \
+ rsync \
+ file \
+ curl \
+ && \
+ apt-get clean && apt-get autoremove && \
+ rm -rf /var/lib/apt/lists/*
+
+# automate for torizonPackages.json
+RUN apt-get -q -y update && \
+ apt-get -q -y install \
+ # DOES NOT REMOVE THIS LABEL: this is used for VS Code automation
+ # __torizon_packages_dev_start__
+ # __torizon_packages_dev_end__
+ # DOES NOT REMOVE THIS LABEL: this is used for VS Code automation
+ && \
+ apt-get clean && apt-get autoremove && \
+ rm -rf /var/lib/apt/lists/*
+
+# install the node.js v18
+RUN curl -fsSL https://deb.nodesource.com/setup_18.x | bash - && \
+ apt-get install -y nodejs
+
+RUN npm config set registry https://registry.npmjs.org/
+
+# Install app dependencies
+# A wildcard is used to ensure both package.json AND package-lock.json are copied
+# where available (npm@5+)
+COPY package*.json ./
+RUN npm install --target_arch=${IMAGE_ARCH}
+
+# Next.js port
+EXPOSE 3000
+ENV PORT 3000
+
+# ⚠️ DEBUG PURPOSES ONLY!!
+# copies RSA key to enable SSH login for user
+COPY .conf/id_rsa.pub /id_rsa.pub
+
+# create folders needed for the different components
+# configures SSH access to the container and sets environment by default
+RUN mkdir /var/run/sshd && \
+ sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' \
+ -i /etc/pam.d/sshd && \
+ if test $SSHUSERNAME != root ; \
+ then mkdir -p /home/$SSHUSERNAME/.ssh ; \
+ else mkdir -p /root/.ssh ; fi && \
+ if test $SSHUSERNAME != root ; \
+ then cp /id_rsa.pub /home/$SSHUSERNAME/.ssh/authorized_keys ; \
+ else cp /id_rsa.pub /root/.ssh/authorized_keys ; fi && \
+ echo "PermitUserEnvironment yes" >> /etc/ssh/sshd_config && \
+ echo "Port ${SSH_DEBUG_PORT}" >> /etc/ssh/sshd_config && \
+ su -c "env" $SSHUSERNAME > /etc/environment
+
+RUN rm -r /etc/ssh/ssh*key && \
+ dpkg-reconfigure openssh-server
+
+CMD [ "/usr/sbin/sshd", "-D" ]
\ No newline at end of file
|