Files
EdgeNode/internal/nodes/http_request_page.go

125 lines
3.3 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"
"regexp"
)
var urlPrefixRegexp = regexp.MustCompile("^(?i)(http|https|ftp)://")
// 请求特殊页面
func (this *HTTPRequest) doPage(status int) (shouldStop bool) {
if len(this.web.Pages) == 0 {
return false
}
for _, page := range this.web.Pages {
if page.Match(status) {
2021-10-10 10:35:05 +08:00
if len(page.BodyType) == 0 || page.BodyType == shared.BodyTypeURL {
if urlPrefixRegexp.MatchString(page.URL) {
var newStatus = page.NewStatus
if newStatus <= 0 {
newStatus = status
}
this.doURL(http.MethodGet, page.URL, "", newStatus, true)
2021-10-10 10:35:05 +08:00
return true
} else {
file := Tea.Root + Tea.DS + page.URL
fp, err := os.Open(file)
if err != nil {
logs.Error(err)
msg := "404 page not found: '" + page.URL + "'"
this.writer.WriteHeader(http.StatusNotFound)
_, err := this.writer.Write([]byte(msg))
if err != nil {
logs.Error(err)
}
return true
}
2020-09-26 08:07:07 +08:00
2021-10-16 12:21:28 +08:00
stat, err := fp.Stat()
if err != nil {
logs.Error(err)
msg := "404 could not read page content: '" + page.URL + "'"
this.writer.WriteHeader(http.StatusNotFound)
_, err := this.writer.Write([]byte(msg))
if err != nil {
logs.Error(err)
}
return true
}
2021-10-10 10:35:05 +08:00
// 修改状态码
if page.NewStatus > 0 {
// 自定义响应Headers
this.processResponseHeaders(page.NewStatus)
2021-10-16 12:21:28 +08:00
this.writer.Prepare(stat.Size(), page.NewStatus)
2021-10-10 10:35:05 +08:00
this.writer.WriteHeader(page.NewStatus)
} else {
this.processResponseHeaders(status)
2021-10-16 12:21:28 +08:00
this.writer.Prepare(stat.Size(), status)
2021-10-10 10:35:05 +08:00
this.writer.WriteHeader(status)
}
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)
2021-10-10 10:35:05 +08:00
if err != nil {
if !this.canIgnore(err) {
remotelogs.Warn("HTTP_REQUEST_PAGE", "write to client failed: "+err.Error())
}
} else {
this.writer.SetOk()
}
err = fp.Close()
2020-09-26 08:07:07 +08:00
if err != nil {
logs.Error(err)
}
}
2021-10-10 10:35:05 +08:00
return true
} else if page.BodyType == shared.BodyTypeHTML {
// 这里需要实现设置Status因为在Format()中可以获取${status}等变量
if page.NewStatus > 0 {
this.writer.statusCode = page.NewStatus
} else {
this.writer.statusCode = status
}
2021-10-16 12:21:28 +08:00
var content = this.Format(page.Body)
2020-09-26 08:07:07 +08:00
// 修改状态码
if page.NewStatus > 0 {
// 自定义响应Headers
this.processResponseHeaders(page.NewStatus)
2021-10-16 12:21:28 +08:00
this.writer.Prepare(int64(len(content)), page.NewStatus)
2020-09-26 08:07:07 +08:00
this.writer.WriteHeader(page.NewStatus)
} else {
this.processResponseHeaders(status)
2021-10-16 12:21:28 +08:00
this.writer.Prepare(int64(len(content)), status)
2020-09-26 08:07:07 +08:00
this.writer.WriteHeader(status)
}
2021-10-10 10:35:05 +08:00
2021-10-16 12:21:28 +08:00
_, err := this.writer.WriteString(content)
2020-09-26 08:07:07 +08:00
if err != nil {
if !this.canIgnore(err) {
remotelogs.Warn("HTTP_REQUEST_PAGE", "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
return true
2020-09-26 08:07:07 +08:00
}
}
}
return false
}