Add NewRequestFromURL function

This commit is contained in:
Adnan Maolood 2020-10-27 13:27:52 -04:00
parent c44f011b15
commit 8ab4064841
2 changed files with 18 additions and 10 deletions

View File

@ -7,6 +7,7 @@ import (
"crypto/tls" "crypto/tls"
"crypto/x509" "crypto/x509"
"fmt" "fmt"
"net/url"
"os" "os"
"time" "time"
@ -76,21 +77,23 @@ func sendRequest(req *gmi.Request) error {
case gmi.StatusClassInput: case gmi.StatusClassInput:
fmt.Printf("%s: ", resp.Meta) fmt.Printf("%s: ", resp.Meta)
scanner.Scan() scanner.Scan()
req.URL.RawQuery = scanner.Text() req.URL.RawQuery = url.QueryEscape(scanner.Text())
return sendRequest(req) return sendRequest(req)
case gmi.StatusClassSuccess: case gmi.StatusClassSuccess:
fmt.Print(string(resp.Body)) fmt.Print(string(resp.Body))
return nil return nil
case gmi.StatusClassRedirect: case gmi.StatusClassRedirect:
fmt.Println("Redirecting to", resp.Meta) fmt.Println("Redirecting to", resp.Meta)
// Make the request to the same host target, err := url.Parse(resp.Meta)
red, err := gmi.NewRequestTo(resp.Meta, req.Host)
if err != nil { if err != nil {
return err return err
} }
// Handle relative redirects // TODO: Prompt the user if the redirect is to another domain.
red.URL = req.URL.ResolveReference(red.URL) redirect, err := gmi.NewRequestFromURL(req.URL.ResolveReference(target))
return sendRequest(red) if err != nil {
return err
}
return sendRequest(redirect)
case gmi.StatusClassTemporaryFailure: case gmi.StatusClassTemporaryFailure:
return fmt.Errorf("Temporary failure: %s", resp.Meta) return fmt.Errorf("Temporary failure: %s", resp.Meta)
case gmi.StatusClassPermanentFailure: case gmi.StatusClassPermanentFailure:

View File

@ -42,22 +42,27 @@ func hostname(host string) string {
return hostname return hostname
} }
// NewRequest returns a new request. The host is inferred from the provided URL. // NewRequest returns a new request. The host is inferred from the URL.
func NewRequest(rawurl string) (*Request, error) { func NewRequest(rawurl string) (*Request, error) {
u, err := url.Parse(rawurl) u, err := url.Parse(rawurl)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return NewRequestFromURL(u)
}
// NewRequestFromURL returns a new request for the given URL.
// The host is inferred from the URL.
func NewRequestFromURL(url *url.URL) (*Request, error) {
// If there is no port, use the default port of 1965 // If there is no port, use the default port of 1965
host := u.Host host := url.Host
if u.Port() == "" { if url.Port() == "" {
host += ":1965" host += ":1965"
} }
return &Request{ return &Request{
Host: host, Host: host,
URL: u, URL: url,
}, nil }, nil
} }