From 88accfdaa18dbc7972b29608c46112f8633f09ea Mon Sep 17 00:00:00 2001 From: Henrique Pimentel Date: Wed, 10 Apr 2024 21:49:24 +0100 Subject: [PATCH] Increased limit to 100k lines, warning message is now on bottom and linked to raw --- custom/conf/app.example.ini | 2 +- modules/markup/csv/csv.go | 20 +++++++++----------- modules/setting/ui.go | 2 +- 3 files changed, 11 insertions(+), 13 deletions(-) diff --git a/custom/conf/app.example.ini b/custom/conf/app.example.ini index 63308b1e72e2b..b8799f6e9b57f 100644 --- a/custom/conf/app.example.ini +++ b/custom/conf/app.example.ini @@ -1336,7 +1336,7 @@ LEVEL = Info ;MAX_FILE_SIZE = 524288 ;; ;; Maximum allowed rows to render CSV files. (Set to 0 for no limit) -;MAX_ROWS = 5000 +;MAX_ROWS = 100000 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; diff --git a/modules/markup/csv/csv.go b/modules/markup/csv/csv.go index 8b49f3da4446e..9c2e4aeebbf87 100644 --- a/modules/markup/csv/csv.go +++ b/modules/markup/csv/csv.go @@ -39,8 +39,8 @@ func (Renderer) SanitizerRules() []setting.MarkupSanitizerRule { {Element: "table", AllowAttr: "class", Regexp: regexp.MustCompile(`data-table`)}, {Element: "th", AllowAttr: "class", Regexp: regexp.MustCompile(`line-num`)}, {Element: "td", AllowAttr: "class", Regexp: regexp.MustCompile(`line-num`)}, - {Element: "div", AllowAttr: "class", Regexp: regexp.MustCompile(`tw-flex tw-justify-center tw-items-center`)}, - {Element: "a", AllowAttr: "href", Regexp: regexp.MustCompile(`\?display=source`)}, + {Element: "div", AllowAttr: "class", Regexp: regexp.MustCompile(`tw-flex tw-justify-center tw-items-center tw-py-4 tw-text-14`)}, + {Element: "a", AllowAttr: "href", Regexp: regexp.MustCompile(``)}, } } @@ -81,7 +81,6 @@ func writeField(w io.Writer, element, class, field string) error { // Render implements markup.Renderer func (r Renderer) Render(ctx *markup.RenderContext, input io.Reader, output io.Writer) error { tmpBlock := bufio.NewWriter(output) - warnBlock := bufio.NewWriter(tmpBlock) maxSize := setting.UI.CSV.MaxFileSize maxRows := setting.UI.CSV.MaxRows @@ -129,23 +128,22 @@ func (r Renderer) Render(ctx *markup.RenderContext, input io.Reader, output io.W row++ } + if _, err = tmpBlock.WriteString(""); err != nil { + return err + } + // Check if maxRows or maxSize is reached, and if true, warn. if (row >= maxRows && maxRows != 0) || (rd.InputOffset() >= maxSize && maxSize != 0) { locale := ctx.Ctx.Value(translation.ContextKey).(translation.Locale) // Construct the HTML string - warn := `
` + locale.TrString("repo.file_too_large") + ` ` + locale.TrString("repo.file_view_source") + `
` + warn := `
` + locale.TrString("repo.file_too_large") + ` ` + locale.TrString("repo.file_view_raw") + `
` // Write the HTML string to the output - if _, err := warnBlock.WriteString(warn); err != nil { - return err - } - if err = warnBlock.Flush(); err != nil { + if _, err := tmpBlock.WriteString(warn); err != nil { return err } } - if _, err = tmpBlock.WriteString(""); err != nil { - return err - } + return tmpBlock.Flush() } diff --git a/modules/setting/ui.go b/modules/setting/ui.go index 669d792c14bbc..e0cd710f7219c 100644 --- a/modules/setting/ui.go +++ b/modules/setting/ui.go @@ -111,7 +111,7 @@ var UI = struct { MaxRows int }{ MaxFileSize: 524288, - MaxRows: 5000, + MaxRows: 100000, }, Admin: struct { UserPagingNum int