|
|
@@ -5,6 +5,7 @@ import (
|
|
|
"net/url"
|
|
|
"os"
|
|
|
"strings"
|
|
|
+ "time"
|
|
|
|
|
|
"v2ray.com/core/common"
|
|
|
"v2ray.com/core/common/buf"
|
|
|
@@ -23,46 +24,53 @@ func (c *FetchCommand) Description() Description {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-func (c *FetchCommand) isValidScheme(scheme string) bool {
|
|
|
- scheme = strings.ToLower(scheme)
|
|
|
- return scheme == "http" || scheme == "https"
|
|
|
-}
|
|
|
-
|
|
|
func (c *FetchCommand) Execute(args []string) error {
|
|
|
if len(args) < 1 {
|
|
|
return newError("empty url")
|
|
|
}
|
|
|
- target := args[0]
|
|
|
+ content, err := FetchHTTPContent(args[0])
|
|
|
+ if err != nil {
|
|
|
+ return newError("failed to read HTTP response").Base(err)
|
|
|
+ }
|
|
|
+
|
|
|
+ os.Stdout.Write(content)
|
|
|
+ return nil
|
|
|
+}
|
|
|
+
|
|
|
+func FetchHTTPContent(target string) ([]byte, error) {
|
|
|
+
|
|
|
parsedTarget, err := url.Parse(target)
|
|
|
if err != nil {
|
|
|
- return newError("invalid URL: ", target).Base(err)
|
|
|
+ return nil, newError("invalid URL: ", target).Base(err)
|
|
|
}
|
|
|
- if !c.isValidScheme(parsedTarget.Scheme) {
|
|
|
- return newError("invalid scheme: ", parsedTarget.Scheme)
|
|
|
+
|
|
|
+ if s := strings.ToLower(parsedTarget.Scheme); s != "http" && s != "https" {
|
|
|
+ return nil, newError("invalid scheme: ", parsedTarget.Scheme)
|
|
|
}
|
|
|
|
|
|
- client := &http.Client{}
|
|
|
+ client := &http.Client{
|
|
|
+ Timeout: 30 * time.Second,
|
|
|
+ }
|
|
|
resp, err := client.Do(&http.Request{
|
|
|
Method: "GET",
|
|
|
URL: parsedTarget,
|
|
|
Close: true,
|
|
|
})
|
|
|
if err != nil {
|
|
|
- return newError("failed to dial to ", target).Base(err)
|
|
|
+ return nil, newError("failed to dial to ", target).Base(err)
|
|
|
}
|
|
|
+ defer resp.Body.Close()
|
|
|
|
|
|
if resp.StatusCode != 200 {
|
|
|
- return newError("unexpected HTTP status code: ", resp.StatusCode)
|
|
|
+ return nil, newError("unexpected HTTP status code: ", resp.StatusCode)
|
|
|
}
|
|
|
|
|
|
content, err := buf.ReadAllToBytes(resp.Body)
|
|
|
if err != nil {
|
|
|
- return newError("failed to read HTTP response").Base(err)
|
|
|
+ return nil, newError("failed to read HTTP response").Base(err)
|
|
|
}
|
|
|
|
|
|
- os.Stdout.Write(content)
|
|
|
-
|
|
|
- return nil
|
|
|
+ return content, nil
|
|
|
}
|
|
|
|
|
|
func init() {
|