forked from ooni/oohttp
-
Notifications
You must be signed in to change notification settings - Fork 1
/
stdlibwrapper.go
65 lines (60 loc) · 2.03 KB
/
stdlibwrapper.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package http
import "net/http"
// StdlibTransport is an adapter for integrating net/http dependend code.
// It looks like an http.RoundTripper but uses this fork internally.
type StdlibTransport struct {
*Transport
}
// RoundTrip implements the http.RoundTripper interface.
func (txp *StdlibTransport) RoundTrip(stdReq *http.Request) (*http.Response, error) {
req := &Request{
Method: stdReq.Method,
URL: stdReq.URL,
Proto: stdReq.Proto,
ProtoMajor: stdReq.ProtoMajor,
ProtoMinor: stdReq.ProtoMinor,
Header: Header(stdReq.Header),
Body: stdReq.Body,
GetBody: stdReq.GetBody,
ContentLength: stdReq.ContentLength,
TransferEncoding: stdReq.TransferEncoding,
Close: stdReq.Close,
Host: stdReq.Host,
Form: stdReq.Form,
PostForm: stdReq.PostForm,
MultipartForm: stdReq.MultipartForm,
Trailer: Header(stdReq.Trailer),
RemoteAddr: stdReq.RemoteAddr,
RequestURI: stdReq.RequestURI,
TLS: stdReq.TLS,
Cancel: stdReq.Cancel,
Response: nil, // cannot assign this field
ctx: stdReq.Context(),
}
// http.NoBody is a global var with oohttp.NoBody being its analogue
// this guards against undefined content length in case when stdReq.Body == http.NoBody
if req.Body == http.NoBody {
req.Body = NoBody
}
resp, err := txp.Transport.RoundTrip(req)
if err != nil {
return nil, err
}
stdResp := &http.Response{
Status: resp.Status,
StatusCode: resp.StatusCode,
Proto: resp.Proto,
ProtoMinor: resp.ProtoMinor,
ProtoMajor: resp.ProtoMajor,
Header: http.Header(resp.Header),
Body: resp.Body,
ContentLength: resp.ContentLength,
TransferEncoding: resp.TransferEncoding,
Close: resp.Close,
Uncompressed: resp.Uncompressed,
Trailer: http.Header(resp.Trailer),
Request: stdReq,
TLS: resp.TLS,
}
return stdResp, nil
}