Files
EdgeNode/internal/nodes/http_request_shutdown.go

105 lines
2.8 KiB
Go
Raw Normal View History

2020-09-26 08:07:07 +08:00
package nodes
import (
2021-10-10 10:35:05 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/shared"
"github.com/TeaOSLab/EdgeNode/internal/remotelogs"
2021-09-21 09:29:17 +08:00
"github.com/TeaOSLab/EdgeNode/internal/utils"
2020-09-26 08:07:07 +08:00
"github.com/iwind/TeaGo/Tea"
"github.com/iwind/TeaGo/logs"
"net/http"
"os"
)
// 调用临时关闭页面
func (this *HTTPRequest) doShutdown() {
shutdown := this.web.Shutdown
if shutdown == nil {
return
}
2021-10-10 10:35:05 +08:00
if len(shutdown.BodyType) == 0 || shutdown.BodyType == shared.BodyTypeURL {
// URL
if urlSchemeRegexp.MatchString(shutdown.URL) {
this.doURL(http.MethodGet, shutdown.URL, "", shutdown.Status, true)
return
}
2021-10-10 10:35:05 +08:00
// URL为空则显示文本
if len(shutdown.URL) == 0 {
// 自定义响应Headers
if shutdown.Status > 0 {
this.ProcessResponseHeaders(this.writer.Header(), shutdown.Status)
2021-10-10 10:35:05 +08:00
this.writer.WriteHeader(shutdown.Status)
} else {
this.ProcessResponseHeaders(this.writer.Header(), http.StatusOK)
2021-10-10 10:35:05 +08:00
this.writer.WriteHeader(http.StatusOK)
}
_, err := this.writer.WriteString("The site have been shutdown.")
if err != nil {
logs.Error(err)
}
return
}
// 从本地文件中读取
file := Tea.Root + Tea.DS + shutdown.URL
fp, err := os.Open(file)
if err != nil {
logs.Error(err)
msg := "404 page not found: '" + shutdown.URL + "'"
this.writer.WriteHeader(http.StatusNotFound)
_, err = this.writer.Write([]byte(msg))
if err != nil {
logs.Error(err)
}
return
}
2020-09-26 08:07:07 +08:00
// 自定义响应Headers
if shutdown.Status > 0 {
this.ProcessResponseHeaders(this.writer.Header(), shutdown.Status)
2020-09-26 08:07:07 +08:00
this.writer.WriteHeader(shutdown.Status)
} else {
this.ProcessResponseHeaders(this.writer.Header(), http.StatusOK)
2020-09-26 08:07:07 +08:00
this.writer.WriteHeader(http.StatusOK)
}
2021-12-19 11:32:26 +08:00
buf := utils.BytePool1k.Get()
2021-10-10 10:35:05 +08:00
_, err = utils.CopyWithFilter(this.writer, fp, buf, func(p []byte) []byte {
return []byte(this.Format(string(p)))
})
2021-12-19 11:32:26 +08:00
utils.BytePool1k.Put(buf)
2020-09-26 08:07:07 +08:00
if err != nil {
2021-10-10 10:35:05 +08:00
if !this.canIgnore(err) {
remotelogs.Warn("HTTP_REQUEST_SHUTDOWN", "write to client failed: "+err.Error())
}
} else {
this.writer.SetOk()
2020-09-26 08:07:07 +08:00
}
2021-10-10 10:35:05 +08:00
err = fp.Close()
2020-09-26 08:07:07 +08:00
if err != nil {
2021-10-10 10:35:05 +08:00
remotelogs.Warn("HTTP_REQUEST_SHUTDOWN", "close file failed: "+err.Error())
2020-09-26 08:07:07 +08:00
}
2021-10-10 10:35:05 +08:00
} else if shutdown.BodyType == shared.BodyTypeHTML {
// 自定义响应Headers
if shutdown.Status > 0 {
this.ProcessResponseHeaders(this.writer.Header(), shutdown.Status)
2021-10-10 10:35:05 +08:00
this.writer.WriteHeader(shutdown.Status)
} else {
this.ProcessResponseHeaders(this.writer.Header(), http.StatusOK)
2021-10-10 10:35:05 +08:00
this.writer.WriteHeader(http.StatusOK)
}
2021-10-10 10:35:05 +08:00
_, err := this.writer.WriteString(this.Format(shutdown.Body))
if err != nil {
if !this.canIgnore(err) {
remotelogs.Warn("HTTP_REQUEST_SHUTDOWN", "write to client failed: "+err.Error())
}
} else {
this.writer.SetOk()
}
2020-09-26 08:07:07 +08:00
}
}