Skip to content

Commit e8255bd

Browse files
committed
Use CreateAPIErrReader for error_page middleware
1 parent b8fb930 commit e8255bd

File tree

5 files changed

+49
-15
lines changed

5 files changed

+49
-15
lines changed

handlers/error_page.go

+29-2
Original file line numberDiff line numberDiff line change
@@ -2,10 +2,14 @@ package handlers
22

33
import (
44
"embed"
5+
"encoding/json"
56
"fmt"
67
"html/template"
8+
"io"
9+
"net/http"
710
"strings"
811

12+
"github.com/everywall/ladder/proxychain/responsemodifiers/api"
913
"github.com/gofiber/fiber/v2"
1014
)
1115

@@ -20,12 +24,35 @@ func RenderErrorPage() fiber.Handler {
2024
}
2125
return func(c *fiber.Ctx) error {
2226
if err := c.Next(); err != nil {
27+
c.Response().SetStatusCode(500)
28+
29+
errReader := api.CreateAPIErrReader(err)
30+
errMessageBytes, err := io.ReadAll(errReader)
31+
if err != nil {
32+
return err
33+
}
34+
35+
var errMsg api.Error
36+
if err := json.Unmarshal(errMessageBytes, &errMsg); err != nil {
37+
return err
38+
}
39+
40+
if strings.Contains(c.Get("Accept"), "text/plain") {
41+
c.Set("Content-Type", "text/plain")
42+
return c.SendString(errMsg.Error.Message)
43+
}
2344
if strings.Contains(c.Get("Accept"), "text/html") {
2445
c.Set("Content-Type", "text/html")
25-
tmpl.Execute(c.Response().BodyWriter(), err.Error())
46+
tmpl.Execute(c.Response().BodyWriter(), fiber.Map{
47+
"Status": http.StatusText(c.Response().StatusCode()) + ": " + fmt.Sprint(c.Response().StatusCode()),
48+
"Message": errMsg.Error.Message,
49+
"Type": errMsg.Error.Type,
50+
"Cause": errMsg.Error.Cause,
51+
})
2652
return nil
2753
}
28-
return c.SendString(err.Error())
54+
c.Set("Content-Type", "text/json")
55+
return c.JSON(errMsg)
2956
}
3057
return err
3158
}

handlers/error_page.html

+8-1
Original file line numberDiff line numberDiff line change
@@ -214,7 +214,14 @@
214214
<div class="flex flex-col space-y-3">
215215
<h1>Error</h1>
216216
<div class="my-4"></div>
217-
<code class="p-4 mx-auto text-red-500 dark:text-red-400"> {{.}} </code>
217+
<pre
218+
class="mx-auto px-6 py-4 space-y-3 whitespace-normal break-all text-red-500 dark:text-red-400"
219+
>
220+
<div><span class="underline">{{.Status}}</span></div>
221+
<div>{{.Message}}</div>
222+
<div><span class="underline">Type</span>:&nbsp;{{.Type}}</div>
223+
<div><span class="underline">Cause</span>:&nbsp;{{.Cause}}</div>
224+
</pre>
218225
</div>
219226

220227
<footer class="mx-4 my-2 text-center text-slate-600 dark:text-slate-400">

handlers/styles.css

+1-1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

proxychain/proxychain.go

+10-10
Original file line numberDiff line numberDiff line change
@@ -390,18 +390,18 @@ func (chain *ProxyChain) SetDebugLogging(isDebugMode bool) *ProxyChain {
390390
// this will prevent Execute from firing and reset the state
391391
// returns the initial error enriched with context
392392
func (chain *ProxyChain) abort(err error) error {
393-
// defer chain._reset()
393+
defer chain._reset()
394394
chain.abortErr = err
395-
chain.Context.Response().SetStatusCode(500)
396-
var e error
397-
if chain.Request.URL != nil {
398-
e = fmt.Errorf("ProxyChain error for '%s': %s", chain.Request.URL.String(), err.Error())
399-
} else {
400-
e = fmt.Errorf("ProxyChain error: '%s'", err.Error())
401-
}
395+
// chain.Context.Response().SetStatusCode(500)
396+
// var e error
397+
// if chain.Request.URL != nil {
398+
// e = fmt.Errorf("ProxyChain error for '%s': %s", chain.Request.URL.String(), err.Error())
399+
// } else {
400+
// e = fmt.Errorf("ProxyChain error: '%s'", err.Error())
401+
// }
402402
// chain.Context.SendString(e.Error()) // <- RenderErrorPage middleware to render error
403-
log.Println(e.Error())
404-
return e
403+
// log.Println(e.Error())
404+
return err
405405
}
406406

407407
// internal function to reset state of ProxyChain for reuse

styles/input.css

+1-1
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@
2626
kbd,
2727
pre,
2828
code {
29-
@apply relative whitespace-break-spaces rounded bg-slate-200 dark:bg-slate-800 py-[0.2rem] font-mono text-sm font-semibold;
29+
@apply relative whitespace-break-spaces break-words rounded bg-slate-200 dark:bg-slate-800 py-[0.2rem] font-mono text-sm font-semibold;
3030
}
3131
blockquote {
3232
@apply mt-6 border-l-2 pl-6 italic;

0 commit comments

Comments
 (0)