mirror of
https://github.com/labstack/echo.git
synced 2024-12-22 20:06:21 +02:00
175 lines
3.3 KiB
Go
175 lines
3.3 KiB
Go
package test
|
|
|
|
import (
|
|
"errors"
|
|
"io"
|
|
"io/ioutil"
|
|
"mime/multipart"
|
|
"net"
|
|
"net/http"
|
|
"strings"
|
|
|
|
"github.com/ipfans/echo"
|
|
"github.com/labstack/echo/engine"
|
|
)
|
|
|
|
type (
|
|
Request struct {
|
|
request *http.Request
|
|
url engine.URL
|
|
header engine.Header
|
|
}
|
|
)
|
|
|
|
const (
|
|
defaultMemory = 32 << 20 // 32 MB
|
|
)
|
|
|
|
func NewRequest(method, url string, body io.Reader) engine.Request {
|
|
r, _ := http.NewRequest(method, url, body)
|
|
r.RequestURI = url
|
|
return &Request{
|
|
request: r,
|
|
url: &URL{url: r.URL},
|
|
header: &Header{r.Header},
|
|
}
|
|
}
|
|
|
|
func (r *Request) IsTLS() bool {
|
|
return r.request.TLS != nil
|
|
}
|
|
|
|
func (r *Request) Scheme() string {
|
|
if r.IsTLS() {
|
|
return "https"
|
|
}
|
|
return "http"
|
|
}
|
|
|
|
func (r *Request) Host() string {
|
|
return r.request.Host
|
|
}
|
|
|
|
func (r *Request) URL() engine.URL {
|
|
return r.url
|
|
}
|
|
|
|
func (r *Request) Header() engine.Header {
|
|
return r.header
|
|
}
|
|
|
|
func (r *Request) Referer() string {
|
|
return r.request.Referer()
|
|
}
|
|
|
|
// func Proto() string {
|
|
// return r.request.Proto()
|
|
// }
|
|
//
|
|
// func ProtoMajor() int {
|
|
// return r.request.ProtoMajor()
|
|
// }
|
|
//
|
|
// func ProtoMinor() int {
|
|
// return r.request.ProtoMinor()
|
|
// }
|
|
|
|
func (r *Request) ContentLength() int64 {
|
|
return r.request.ContentLength
|
|
}
|
|
|
|
func (r *Request) UserAgent() string {
|
|
return r.request.UserAgent()
|
|
}
|
|
|
|
func (r *Request) RemoteAddress() string {
|
|
return r.request.RemoteAddr
|
|
}
|
|
|
|
func (r *Request) RemoteIP() string {
|
|
ra := r.RemoteAddress()
|
|
if ip := r.Header().Get(echo.HeaderXForwardedFor); ip != "" {
|
|
ra = ip
|
|
} else if ip := r.Header().Get(echo.HeaderXRealIP); ip != "" {
|
|
ra = ip
|
|
} else {
|
|
ra, _, _ = net.SplitHostPort(ra)
|
|
}
|
|
return ra
|
|
}
|
|
|
|
func (r *Request) Method() string {
|
|
return r.request.Method
|
|
}
|
|
|
|
func (r *Request) SetMethod(method string) {
|
|
r.request.Method = method
|
|
}
|
|
|
|
func (r *Request) URI() string {
|
|
return r.request.RequestURI
|
|
}
|
|
|
|
func (r *Request) SetURI(uri string) {
|
|
r.request.RequestURI = uri
|
|
}
|
|
|
|
func (r *Request) Body() io.Reader {
|
|
return r.request.Body
|
|
}
|
|
|
|
func (r *Request) SetBody(reader io.Reader) {
|
|
r.request.Body = ioutil.NopCloser(reader)
|
|
}
|
|
|
|
func (r *Request) FormValue(name string) string {
|
|
return r.request.FormValue(name)
|
|
}
|
|
|
|
func (r *Request) FormParams() map[string][]string {
|
|
if strings.HasPrefix(r.header.Get("Content-Type"), "multipart/form-data") {
|
|
if err := r.request.ParseMultipartForm(defaultMemory); err != nil {
|
|
panic(err)
|
|
}
|
|
} else {
|
|
if err := r.request.ParseForm(); err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
return map[string][]string(r.request.Form)
|
|
}
|
|
|
|
func (r *Request) FormFile(name string) (*multipart.FileHeader, error) {
|
|
_, fh, err := r.request.FormFile(name)
|
|
return fh, err
|
|
}
|
|
|
|
func (r *Request) MultipartForm() (*multipart.Form, error) {
|
|
err := r.request.ParseMultipartForm(defaultMemory)
|
|
return r.request.MultipartForm, err
|
|
}
|
|
|
|
func (r *Request) Cookie(name string) (engine.Cookie, error) {
|
|
c, err := r.request.Cookie(name)
|
|
if err != nil {
|
|
return nil, errors.New("cookie not found")
|
|
}
|
|
return &Cookie{c}, nil
|
|
}
|
|
|
|
// Cookies implements `engine.Request#Cookies` function.
|
|
func (r *Request) Cookies() []engine.Cookie {
|
|
cs := r.request.Cookies()
|
|
cookies := make([]engine.Cookie, len(cs))
|
|
for i, c := range cs {
|
|
cookies[i] = &Cookie{c}
|
|
}
|
|
return cookies
|
|
}
|
|
|
|
func (r *Request) reset(req *http.Request, h engine.Header, u engine.URL) {
|
|
r.request = req
|
|
r.header = h
|
|
r.url = u
|
|
}
|