2021-01-26 23:36:53 +08:00
|
|
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
2022-11-27 13:20:29 -05:00
|
|
|
// SPDX-License-Identifier: MIT
|
2021-01-26 23:36:53 +08:00
|
|
|
|
2021-01-30 16:55:53 +08:00
|
|
|
package middleware
|
2021-01-26 23:36:53 +08:00
|
|
|
|
2024-02-15 05:48:45 +08:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"html/template"
|
|
|
|
"net/url"
|
2024-12-24 11:43:57 +08:00
|
|
|
|
|
|
|
"code.gitea.io/gitea/modules/reqctx"
|
2024-02-15 05:48:45 +08:00
|
|
|
)
|
2021-01-26 23:36:53 +08:00
|
|
|
|
|
|
|
// Flash represents a one time data transfer between two requests.
|
|
|
|
type Flash struct {
|
2024-12-24 11:43:57 +08:00
|
|
|
DataStore reqctx.RequestDataStore
|
2021-01-26 23:36:53 +08:00
|
|
|
url.Values
|
|
|
|
ErrorMsg, WarningMsg, InfoMsg, SuccessMsg string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *Flash) set(name, msg string, current ...bool) {
|
2021-01-27 13:33:32 +00:00
|
|
|
if f.Values == nil {
|
|
|
|
f.Values = make(map[string][]string)
|
|
|
|
}
|
2023-07-15 16:52:03 +08:00
|
|
|
showInCurrentPage := len(current) > 0 && current[0]
|
|
|
|
if showInCurrentPage {
|
|
|
|
// assign it to the context data, then the template can use ".Flash.XxxMsg" to render the message
|
2023-05-04 14:36:34 +08:00
|
|
|
f.DataStore.GetData()["Flash"] = f
|
2021-01-26 23:36:53 +08:00
|
|
|
} else {
|
2023-07-15 16:52:03 +08:00
|
|
|
// the message map will be saved into the cookie and be shown in next response (a new page response which decodes the cookie)
|
2021-01-26 23:36:53 +08:00
|
|
|
f.Set(name, msg)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-15 05:48:45 +08:00
|
|
|
func flashMsgStringOrHTML(msg any) string {
|
|
|
|
switch v := msg.(type) {
|
|
|
|
case string:
|
|
|
|
return v
|
|
|
|
case template.HTML:
|
|
|
|
return string(v)
|
|
|
|
}
|
|
|
|
panic(fmt.Sprintf("unknown type: %T", msg))
|
|
|
|
}
|
|
|
|
|
2021-01-26 23:36:53 +08:00
|
|
|
// Error sets error message
|
2024-02-15 05:48:45 +08:00
|
|
|
func (f *Flash) Error(msg any, current ...bool) {
|
|
|
|
f.ErrorMsg = flashMsgStringOrHTML(msg)
|
|
|
|
f.set("error", f.ErrorMsg, current...)
|
2021-01-26 23:36:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Warning sets warning message
|
2024-02-15 05:48:45 +08:00
|
|
|
func (f *Flash) Warning(msg any, current ...bool) {
|
|
|
|
f.WarningMsg = flashMsgStringOrHTML(msg)
|
|
|
|
f.set("warning", f.WarningMsg, current...)
|
2021-01-26 23:36:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Info sets info message
|
2024-02-15 05:48:45 +08:00
|
|
|
func (f *Flash) Info(msg any, current ...bool) {
|
|
|
|
f.InfoMsg = flashMsgStringOrHTML(msg)
|
|
|
|
f.set("info", f.InfoMsg, current...)
|
2021-01-26 23:36:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Success sets success message
|
2024-02-15 05:48:45 +08:00
|
|
|
func (f *Flash) Success(msg any, current ...bool) {
|
|
|
|
f.SuccessMsg = flashMsgStringOrHTML(msg)
|
|
|
|
f.set("success", f.SuccessMsg, current...)
|
2021-01-26 23:36:53 +08:00
|
|
|
}
|