From 4cb7dc2d3084348dc13911bf2b22b79fe6896f55 Mon Sep 17 00:00:00 2001
From: Thomas Miceli <27960254+thomiceli@users.noreply.github.com>
Date: Tue, 2 Jan 2024 05:11:49 +0100
Subject: [PATCH] Fix reverse proxy subpath support (#192)
---
config.yml | 3 +-
docs/administration/nginx-reverse-proxy.md | 32 +++++++++++++++++++---
docs/configuration/cheat-sheet.md | 2 +-
internal/web/gist.go | 16 +++++++++--
public/admin.ts | 3 +-
templates/base/base_header.html | 7 +++--
templates/base/gist_header.html | 6 ++--
templates/pages/admin_gists.html | 2 +-
templates/pages/admin_index.html | 6 ++--
templates/pages/admin_users.html | 2 +-
templates/pages/auth_form.html | 2 +-
templates/pages/create.html | 2 +-
templates/pages/edit.html | 6 ++--
templates/pages/settings.html | 12 ++++----
14 files changed, 69 insertions(+), 32 deletions(-)
diff --git a/config.yml b/config.yml
index f32293a..5984055 100644
--- a/config.yml
+++ b/config.yml
@@ -8,8 +8,7 @@ log-level: warn
# Set the log output to one or more of the following: `stdout`, `file`. Default: stdout,file
log-output: stdout,file
-# Public URL for the Git HTTP/SSH connection.
-# If not set, uses the URL from the request
+# Public URL to access to Opengist
external-url:
# Directory where Opengist will store its data. Default: ~/.opengist/
diff --git a/docs/administration/nginx-reverse-proxy.md b/docs/administration/nginx-reverse-proxy.md
index 9accdb6..fdbdc80 100644
--- a/docs/administration/nginx-reverse-proxy.md
+++ b/docs/administration/nginx-reverse-proxy.md
@@ -1,6 +1,10 @@
# Use Nginx as a reverse proxy
-Configure Nginx to proxy requests to Opengist. Here is an example configuration file :
+Configure Nginx to proxy requests to Opengist. Here are example configuration file to use Opengist on a subdomain or on a subpath.
+
+Make sure you set the base url for Opengist via the [configuration](/docs/configuration/cheat-sheet.md).
+
+### Subdomain
```
server {
listen 80;
@@ -16,7 +20,27 @@ server {
}
```
-Then run :
-```shell
-service nginx restart
+### Subpath
+```
+server {
+ listen 80;
+ server_name example.com;
+
+ location /opengist/ {
+ rewrite ^/opengist(/.*)$ $1 break;
+ proxy_pass http://127.0.0.1:6157;
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_set_header X-Forwarded-Proto $scheme;
+ proxy_set_header X-Forwarded-Prefix /opengist;
+ }
+}
+```
+
+---
+
+To apply changes:
+```shell
+sudo systemctl restart nginx
```
diff --git a/docs/configuration/cheat-sheet.md b/docs/configuration/cheat-sheet.md
index 67320a4..7368156 100644
--- a/docs/configuration/cheat-sheet.md
+++ b/docs/configuration/cheat-sheet.md
@@ -4,7 +4,7 @@
|-----------------------|--------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| log-level | OG_LOG_LEVEL | `warn` | Set the log level to one of the following: `trace`, `debug`, `info`, `warn`, `error`, `fatal`, `panic`. |
| log-output | OG_LOG_OUTPUT | `stdout,file` | Set the log output to one or more of the following: `stdout`, `file`. |
-| external-url | OG_EXTERNAL_URL | none | Public URL for the Git HTTP/SSH connection. If not set, uses the URL from the request. |
+| external-url | OG_EXTERNAL_URL | none | Public URL to access to Opengist. |
| opengist-home | OG_OPENGIST_HOME | home directory | Path to the directory where Opengist stores its data. |
| db-filename | OG_DB_FILENAME | `opengist.db` | Name of the SQLite database file. |
| git.default-branch | OG_GIT_DEFAULT_BRANCH | none | Default branch name used by Opengist when initializing Git repositories. If not set, uses the Git default branch name. More info [here](https://git-scm.com/book/en/v2/Getting-Started-First-Time-Git-Setup#_new_default_branch) |
diff --git a/internal/web/gist.go b/internal/web/gist.go
index ec8da50..beb51d0 100644
--- a/internal/web/gist.go
+++ b/internal/web/gist.go
@@ -323,7 +323,12 @@ func gistJson(ctx echo.Context) error {
jsUrl, err := url.JoinPath(getData(ctx, "baseHttpUrl").(string), gist.User.Username, gist.Identifier()+".js")
if err != nil {
- return errorRes(500, "Error joining url", err)
+ return errorRes(500, "Error joining js url", err)
+ }
+
+ cssUrl, err := url.JoinPath(getData(ctx, "baseHttpUrl").(string), manifestEntries["embed.css"].File)
+ if err != nil {
+ return errorRes(500, "Error joining css url", err)
}
return ctx.JSON(200, map[string]interface{}{
@@ -337,7 +342,7 @@ func gistJson(ctx echo.Context) error {
"files": renderedFiles,
"embed": map[string]string{
"html": htmlbuf.String(),
- "css": getData(ctx, "baseHttpUrl").(string) + asset("embed.css"),
+ "css": cssUrl,
"js": jsUrl,
"js_dark": jsUrl + "?dark",
},
@@ -365,10 +370,15 @@ func gistJs(ctx echo.Context) error {
}
_ = w.Flush()
+ cssUrl, err := url.JoinPath(getData(ctx, "baseHttpUrl").(string), manifestEntries["embed.css"].File)
+ if err != nil {
+ return errorRes(500, "Error joining css url", err)
+ }
+
js := `document.write('')
document.write('%s')
`
- js = fmt.Sprintf(js, getData(ctx, "baseHttpUrl").(string)+asset("embed.css"),
+ js = fmt.Sprintf(js, cssUrl,
strings.Replace(htmlbuf.String(), "\n", `\n`, -1))
ctx.Response().Header().Set("Content-Type", "application/javascript")
return plainText(ctx, 200, js)
diff --git a/public/admin.ts b/public/admin.ts
index a044a8d..56fa0ea 100644
--- a/public/admin.ts
+++ b/public/admin.ts
@@ -8,13 +8,14 @@ document.addEventListener('DOMContentLoaded', () => {
});
const setSetting = (key: string, value: string) => {
+ const baseUrl = window.opengist_base_url || '';
const data = new URLSearchParams();
data.append('key', key);
data.append('value', value);
if (document.getElementsByName('_csrf').length !== 0) {
data.append('_csrf', ((document.getElementsByName('_csrf')[0] as HTMLInputElement).value));
}
- return fetch('/admin-panel/set-config', {
+ return fetch(`${baseUrl}/admin-panel/set-config`, {
method: 'PUT',
credentials: 'same-origin',
body: data,
diff --git a/templates/base/base_header.html b/templates/base/base_header.html
index 4a571c6..565f62a 100644
--- a/templates/base/base_header.html
+++ b/templates/base/base_header.html
@@ -7,7 +7,10 @@
{{ end }}
+
+