mirror of
https://github.com/dstotijn/hetty.git
synced 2025-07-01 18:47:29 -04:00
Fix missing HTTP/1.0
proto enums
This commit is contained in:
@ -39,13 +39,15 @@ enum HttpMethod {
|
|||||||
}
|
}
|
||||||
|
|
||||||
enum HttpProto {
|
enum HttpProto {
|
||||||
Http1 = "HTTP/1.1",
|
Http10 = "HTTP/1.0",
|
||||||
Http2 = "HTTP/2.0",
|
Http11 = "HTTP/1.1",
|
||||||
|
Http20 = "HTTP/2.0",
|
||||||
}
|
}
|
||||||
|
|
||||||
const httpProtoMap = new Map([
|
const httpProtoMap = new Map([
|
||||||
[HttpProto.Http1, HttpProtocol.Http1],
|
[HttpProto.Http10, HttpProtocol.Http10],
|
||||||
[HttpProto.Http2, HttpProtocol.Http2],
|
[HttpProto.Http11, HttpProtocol.Http11],
|
||||||
|
[HttpProto.Http20, HttpProtocol.Http20],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
function updateKeyPairItem(key: string, value: string, idx: number, items: KeyValuePair[]): KeyValuePair[] {
|
function updateKeyPairItem(key: string, value: string, idx: number, items: KeyValuePair[]): KeyValuePair[] {
|
||||||
@ -92,7 +94,7 @@ function EditRequest(): JSX.Element {
|
|||||||
|
|
||||||
const [method, setMethod] = useState(HttpMethod.Get);
|
const [method, setMethod] = useState(HttpMethod.Get);
|
||||||
const [url, setURL] = useState("");
|
const [url, setURL] = useState("");
|
||||||
const [proto, setProto] = useState(HttpProto.Http2);
|
const [proto, setProto] = useState(HttpProto.Http20);
|
||||||
const [queryParams, setQueryParams] = useState<KeyValuePair[]>([{ key: "", value: "" }]);
|
const [queryParams, setQueryParams] = useState<KeyValuePair[]>([{ key: "", value: "" }]);
|
||||||
const [headers, setHeaders] = useState<KeyValuePair[]>([{ key: "", value: "" }]);
|
const [headers, setHeaders] = useState<KeyValuePair[]>([{ key: "", value: "" }]);
|
||||||
const [body, setBody] = useState("");
|
const [body, setBody] = useState("");
|
||||||
|
@ -12,9 +12,11 @@ type ResponseStatusProps = {
|
|||||||
|
|
||||||
function mapProto(proto: HttpProtocol): string {
|
function mapProto(proto: HttpProtocol): string {
|
||||||
switch (proto) {
|
switch (proto) {
|
||||||
case HttpProtocol.Http1:
|
case HttpProtocol.Http10:
|
||||||
|
return "HTTP/1.0";
|
||||||
|
case HttpProtocol.Http11:
|
||||||
return "HTTP/1.1";
|
return "HTTP/1.1";
|
||||||
case HttpProtocol.Http2:
|
case HttpProtocol.Http20:
|
||||||
return "HTTP/2.0";
|
return "HTTP/2.0";
|
||||||
default:
|
default:
|
||||||
return proto;
|
return proto;
|
||||||
|
@ -62,8 +62,9 @@ export enum HttpMethod {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export enum HttpProtocol {
|
export enum HttpProtocol {
|
||||||
Http1 = 'HTTP1',
|
Http10 = 'HTTP10',
|
||||||
Http2 = 'HTTP2'
|
Http11 = 'HTTP11',
|
||||||
|
Http20 = 'HTTP20'
|
||||||
}
|
}
|
||||||
|
|
||||||
export type HttpRequestLog = {
|
export type HttpRequestLog = {
|
||||||
|
@ -897,8 +897,9 @@ enum HttpMethod {
|
|||||||
}
|
}
|
||||||
|
|
||||||
enum HttpProtocol {
|
enum HttpProtocol {
|
||||||
HTTP1
|
HTTP10
|
||||||
HTTP2
|
HTTP11
|
||||||
|
HTTP20
|
||||||
}
|
}
|
||||||
|
|
||||||
scalar Time
|
scalar Time
|
||||||
|
@ -186,18 +186,20 @@ func (e HTTPMethod) MarshalGQL(w io.Writer) {
|
|||||||
type HTTPProtocol string
|
type HTTPProtocol string
|
||||||
|
|
||||||
const (
|
const (
|
||||||
HTTPProtocolHTTP1 HTTPProtocol = "HTTP1"
|
HTTPProtocolHTTP10 HTTPProtocol = "HTTP10"
|
||||||
HTTPProtocolHTTP2 HTTPProtocol = "HTTP2"
|
HTTPProtocolHTTP11 HTTPProtocol = "HTTP11"
|
||||||
|
HTTPProtocolHTTP20 HTTPProtocol = "HTTP20"
|
||||||
)
|
)
|
||||||
|
|
||||||
var AllHTTPProtocol = []HTTPProtocol{
|
var AllHTTPProtocol = []HTTPProtocol{
|
||||||
HTTPProtocolHTTP1,
|
HTTPProtocolHTTP10,
|
||||||
HTTPProtocolHTTP2,
|
HTTPProtocolHTTP11,
|
||||||
|
HTTPProtocolHTTP20,
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e HTTPProtocol) IsValid() bool {
|
func (e HTTPProtocol) IsValid() bool {
|
||||||
switch e {
|
switch e {
|
||||||
case HTTPProtocolHTTP1, HTTPProtocolHTTP2:
|
case HTTPProtocolHTTP10, HTTPProtocolHTTP11, HTTPProtocolHTTP20:
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
|
@ -22,13 +22,15 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var httpProtocolMap = map[string]HTTPProtocol{
|
var httpProtocolMap = map[string]HTTPProtocol{
|
||||||
sender.HTTPProto1: HTTPProtocolHTTP1,
|
sender.HTTPProto10: HTTPProtocolHTTP10,
|
||||||
sender.HTTPProto2: HTTPProtocolHTTP2,
|
sender.HTTPProto11: HTTPProtocolHTTP11,
|
||||||
|
sender.HTTPProto20: HTTPProtocolHTTP20,
|
||||||
}
|
}
|
||||||
|
|
||||||
var revHTTPProtocolMap = map[HTTPProtocol]string{
|
var revHTTPProtocolMap = map[HTTPProtocol]string{
|
||||||
HTTPProtocolHTTP1: sender.HTTPProto1,
|
HTTPProtocolHTTP10: sender.HTTPProto10,
|
||||||
HTTPProtocolHTTP2: sender.HTTPProto2,
|
HTTPProtocolHTTP11: sender.HTTPProto11,
|
||||||
|
HTTPProtocolHTTP20: sender.HTTPProto20,
|
||||||
}
|
}
|
||||||
|
|
||||||
type Resolver struct {
|
type Resolver struct {
|
||||||
|
@ -157,8 +157,9 @@ enum HttpMethod {
|
|||||||
}
|
}
|
||||||
|
|
||||||
enum HttpProtocol {
|
enum HttpProtocol {
|
||||||
HTTP1
|
HTTP10
|
||||||
HTTP2
|
HTTP11
|
||||||
|
HTTP20
|
||||||
}
|
}
|
||||||
|
|
||||||
scalar Time
|
scalar Time
|
||||||
|
@ -126,7 +126,7 @@ func (svc *service) CreateOrUpdateRequest(ctx context.Context, req Request) (Req
|
|||||||
}
|
}
|
||||||
|
|
||||||
if req.Proto == "" {
|
if req.Proto == "" {
|
||||||
req.Proto = HTTPProto2
|
req.Proto = HTTPProto20
|
||||||
}
|
}
|
||||||
|
|
||||||
if !isValidProto(req.Proto) {
|
if !isValidProto(req.Proto) {
|
||||||
@ -157,7 +157,7 @@ func (svc *service) CloneFromRequestLog(ctx context.Context, reqLogID ulid.ULID)
|
|||||||
SourceRequestLogID: reqLogID,
|
SourceRequestLogID: reqLogID,
|
||||||
Method: reqLog.Method,
|
Method: reqLog.Method,
|
||||||
URL: reqLog.URL,
|
URL: reqLog.URL,
|
||||||
Proto: HTTPProto2, // Attempt HTTP/2.
|
Proto: HTTPProto20, // Attempt HTTP/2.
|
||||||
Header: reqLog.Header,
|
Header: reqLog.Header,
|
||||||
Body: reqLog.Body,
|
Body: reqLog.Body,
|
||||||
}
|
}
|
||||||
|
@ -12,8 +12,9 @@ type HTTPTransport struct{}
|
|||||||
type protoCtxKey struct{}
|
type protoCtxKey struct{}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
HTTPProto1 = "HTTP/1.1"
|
HTTPProto10 = "HTTP/1.0"
|
||||||
HTTPProto2 = "HTTP/2.0"
|
HTTPProto11 = "HTTP/1.1"
|
||||||
|
HTTPProto20 = "HTTP/2.0"
|
||||||
)
|
)
|
||||||
|
|
||||||
// h1OnlyTransport mimics `http.DefaultTransport`, but with HTTP/2 disabled.
|
// h1OnlyTransport mimics `http.DefaultTransport`, but with HTTP/2 disabled.
|
||||||
@ -38,7 +39,7 @@ var h1OnlyTransport = &http.Transport{
|
|||||||
func (t *HTTPTransport) RoundTrip(req *http.Request) (*http.Response, error) {
|
func (t *HTTPTransport) RoundTrip(req *http.Request) (*http.Response, error) {
|
||||||
proto, ok := req.Context().Value(protoCtxKey{}).(string)
|
proto, ok := req.Context().Value(protoCtxKey{}).(string)
|
||||||
|
|
||||||
if ok && proto == HTTPProto1 {
|
if ok && proto == HTTPProto10 || proto == HTTPProto11 {
|
||||||
return h1OnlyTransport.RoundTrip(req)
|
return h1OnlyTransport.RoundTrip(req)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,5 +47,5 @@ func (t *HTTPTransport) RoundTrip(req *http.Request) (*http.Response, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func isValidProto(proto string) bool {
|
func isValidProto(proto string) bool {
|
||||||
return proto == HTTPProto1 || proto == HTTPProto2
|
return proto == HTTPProto10 || proto == HTTPProto11 || proto == HTTPProto20
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user