mirror of
				https://github.com/TeaOSLab/EdgeNode.git
				synced 2025-11-04 07:40:56 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package nodes
 | 
						|
 | 
						|
import (
 | 
						|
	"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/shared"
 | 
						|
	"github.com/TeaOSLab/EdgeNode/internal/remotelogs"
 | 
						|
	"github.com/TeaOSLab/EdgeNode/internal/utils"
 | 
						|
	"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) {
 | 
						|
			if len(page.BodyType) == 0 || page.BodyType == shared.BodyTypeURL {
 | 
						|
				if urlPrefixRegexp.MatchString(page.URL) {
 | 
						|
					this.doURL(http.MethodGet, page.URL, "", page.NewStatus, true)
 | 
						|
					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
 | 
						|
					}
 | 
						|
 | 
						|
					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
 | 
						|
					}
 | 
						|
 | 
						|
					// 修改状态码
 | 
						|
					if page.NewStatus > 0 {
 | 
						|
						// 自定义响应Headers
 | 
						|
						this.processResponseHeaders(page.NewStatus)
 | 
						|
						this.writer.Prepare(stat.Size(), page.NewStatus)
 | 
						|
						this.writer.WriteHeader(page.NewStatus)
 | 
						|
					} else {
 | 
						|
						this.processResponseHeaders(status)
 | 
						|
						this.writer.Prepare(stat.Size(), status)
 | 
						|
						this.writer.WriteHeader(status)
 | 
						|
					}
 | 
						|
					buf := bytePool1k.Get()
 | 
						|
					_, err = utils.CopyWithFilter(this.writer, fp, buf, func(p []byte) []byte {
 | 
						|
						return []byte(this.Format(string(p)))
 | 
						|
					})
 | 
						|
					bytePool1k.Put(buf)
 | 
						|
					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()
 | 
						|
					if err != nil {
 | 
						|
						logs.Error(err)
 | 
						|
					}
 | 
						|
				}
 | 
						|
 | 
						|
				return true
 | 
						|
			} else if page.BodyType == shared.BodyTypeHTML {
 | 
						|
				var content = this.Format(page.Body)
 | 
						|
 | 
						|
				// 修改状态码
 | 
						|
				if page.NewStatus > 0 {
 | 
						|
					// 自定义响应Headers
 | 
						|
					this.processResponseHeaders(page.NewStatus)
 | 
						|
					this.writer.Prepare(int64(len(content)), page.NewStatus)
 | 
						|
					this.writer.WriteHeader(page.NewStatus)
 | 
						|
				} else {
 | 
						|
					this.processResponseHeaders(status)
 | 
						|
					this.writer.Prepare(int64(len(content)), status)
 | 
						|
					this.writer.WriteHeader(status)
 | 
						|
				}
 | 
						|
 | 
						|
				_, err := this.writer.WriteString(content)
 | 
						|
				if err != nil {
 | 
						|
					if !this.canIgnore(err) {
 | 
						|
						remotelogs.Warn("HTTP_REQUEST_PAGE", "write to client failed: "+err.Error())
 | 
						|
					}
 | 
						|
				} else {
 | 
						|
					this.writer.SetOk()
 | 
						|
				}
 | 
						|
				return true
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return false
 | 
						|
}
 |