[http.upgrade.request.private] clean 'parseHeader()' with using [internal.http.request.parser.reqline]
This commit is contained in:
parent
3f5dee7818
commit
b3ccc911ee
|
@ -1,7 +1,6 @@
|
||||||
package request
|
package request
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
@ -13,48 +12,22 @@ func (r *T) parseHeader(b []byte) {
|
||||||
---------------------------------------------------------*/
|
---------------------------------------------------------*/
|
||||||
if !r.first {
|
if !r.first {
|
||||||
|
|
||||||
/* (1) Split by ' ' */
|
err := r.request.Parse(b)
|
||||||
parts := strings.Split(string(b), " ")
|
|
||||||
|
|
||||||
/* (2) Abort on failure */
|
|
||||||
if len(parts) != 3 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
/* (3) Store method */
|
|
||||||
r.httpMethod = parts[0]
|
|
||||||
|
|
||||||
/* (4) Store URI */
|
|
||||||
r.uri = parts[1]
|
|
||||||
|
|
||||||
/* (5) Fail if wrong version format */
|
|
||||||
if len(parts[2]) < len("HTTP/0") {
|
|
||||||
r.Err = fmt.Errorf("Invalid HTTP version [%s] expected [HTTP/] prefix")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
/* (6) Extract version part */
|
|
||||||
versionString := parts[2][len("HTTP/"):]
|
|
||||||
version, err := strconv.ParseFloat(versionString, 32)
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
r.Err = fmt.Errorf("Cannot parse HTTP version as float")
|
r.Err = fmt.Errorf("Error while parsing first line: %s", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (7) Store HTTP version */
|
|
||||||
r.httpVersion = float32(version)
|
|
||||||
|
|
||||||
|
|
||||||
r.first = true
|
r.first = true
|
||||||
return
|
return
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* (2) Other lines -> Header-Name: Header-Value
|
/* (2) Other lines -> Header-Name: Header-Value
|
||||||
---------------------------------------------------------*/
|
---------------------------------------------------------*/
|
||||||
|
|
||||||
/* (1) Split by ': ' */
|
/* (1) Split by ': ' */
|
||||||
parts := strings.Split(string(b), ": ")
|
parts := strings.Split(string(b), ": ")
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue