Skip to content

Commit

Permalink
Release: ✨ Small Bugfix for ForceHTTP1 and Doc updates [1.0.24] (#288)
Browse files Browse the repository at this point in the history
  • Loading branch information
Danny-Dasilva committed Nov 28, 2023
1 parent 000594c commit dfe97e5
Show file tree
Hide file tree
Showing 9 changed files with 93 additions and 182 deletions.
34 changes: 21 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -443,17 +443,25 @@ install npm packages (this command handles the above)
`npm run build`
### To recompile Golang files in the golang folder
All
`npm run build:go`
Windows
`npm run build:windows`
`npm run build:go:windows:amd64`
Linux
`npm run build:linux`
`npm run build:go:linux:amd64`
Mac
`npm run build:mac:`
`npm run build:go:mac:arm64`
You can view the available compile options within the `package.json`
## Questions
Expand Down Expand Up @@ -672,9 +680,9 @@ import (
func main() {
client := cycletls.Init()
jar, err := cookiejar.New(nil)
if err != nil {
log.Fatal(err)
}
if err != nil {
log.Fatal(err)
}
// First request to set cookie
firstResponse, err := client.Do("https://httpbin.org/cookies/set?a=1&b=2&c=3", cycletls.Options{
Body: "",
Expand All @@ -687,17 +695,17 @@ func main() {
log.Fatal(err)
}
firstURL, _ := url.Parse(firstResponse.FinalUrl)
jar.SetCookies( firstURL, firstResponse.Cookies)
jar.SetCookies( firstURL, firstResponse.Cookies)


// Second request to verify cookies, including the cookies from the first response
secondResponse, err := client.Do("https://httpbin.org/cookies", cycletls.Options{
Body: "",
Ja3: "771,4865-4866-4867-49195-49199-49196-49200-52393-52392-49171-49172-156-157-47-53,0-23-65281-10-11-35-16-5-13-18-51-45-43-27-17513,29-23-24,0",
UserAgent: "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.54 Safari/537.36",
Headers: map[string]string{
"Cookie": getHeadersFromJar(jar, firstURL),
},
Body: "",
Ja3: "771,4865-4866-4867-49195-49199-49196-49200-52393-52392-49171-49172-156-157-47-53,0-23-65281-10-11-35-16-5-13-18-51-45-43-27-17513,29-23-24,0",
UserAgent: "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.54 Safari/537.36",
Headers: map[string]string{
"Cookie": getHeadersFromJar(jar, firstURL),
},
}, "GET")
if err != nil {
log.Fatal(err)
Expand Down
7 changes: 3 additions & 4 deletions cycletls/index.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
"flag"
http "github.com/Danny-Dasilva/fhttp"
"github.com/gorilla/websocket"
"io/ioutil"
"io"
"log"
nhttp "net/http"
"net/url"
Expand Down Expand Up @@ -176,7 +176,6 @@ func processRequest(request cycleTLSRequest) (result fullRequest) {
func dispatcher(res fullRequest) (response Response, err error) {
defer res.client.CloseIdleConnections()
finalUrl := res.options.Options.URL

resp, err := res.client.Do(res.req)
if err != nil {

Expand All @@ -195,8 +194,8 @@ func dispatcher(res fullRequest) (response Response, err error) {

encoding := resp.Header["Content-Encoding"]
content := resp.Header["Content-Type"]
bodyBytes, err := io.ReadAll(resp.Body)

bodyBytes, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Print("Parse Bytes" + err.Error())
return response, err
Expand Down Expand Up @@ -353,7 +352,7 @@ func WSEndpoint(w nhttp.ResponseWriter, r *nhttp.Request) {
if err != nil {
//Golang Received a non-standard request to this port, printing request
var data map[string]interface{}
bodyBytes, err := ioutil.ReadAll(r.Body)
bodyBytes, err := io.ReadAll(r.Body)
if err != nil {
log.Print("Invalid Request: Body Read Error" + err.Error())
}
Expand Down
2 changes: 1 addition & 1 deletion cycletls/roundtripper.go
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ func (rt *roundTripper) dialTLS(ctx context.Context, network, addr string) (net.
rt.cachedTransports[addr] = &t2
default:
// Assume the remote peer is speaking HTTP 1.x + TLS.
rt.cachedTransports[addr] = &http.Transport{DialTLSContext: rt.dialTLS}
rt.cachedTransports[addr] = &http.Transport{DialTLSContext: rt.dialTLS, DisableKeepAlives: true}

}

Expand Down
7 changes: 3 additions & 4 deletions cycletls/tests/integration/images_test.go
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
package cycletls_test

import (
"runtime"
"bytes"
"encoding/base64"
"io/ioutil"
"log"
"os"
"runtime"
"testing"

cycletls "github.com/Danny-Dasilva/CycleTLS/cycletls"
Expand Down Expand Up @@ -66,13 +65,13 @@ func WriteFile(Body string, Filepath string) {
}

func CompareFiles(filepath1 string, filepath2 string) bool {
f1, err1 := ioutil.ReadFile(filepath1)
f1, err1 := os.ReadFile(filepath1)

if err1 != nil {
log.Fatal(err1)
}

f2, err2 := ioutil.ReadFile(filepath2)
f2, err2 := os.ReadFile(filepath2)

if err2 != nil {
log.Fatal(err2)
Expand Down
9 changes: 4 additions & 5 deletions cycletls/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,9 @@ import (
"crypto/sha256"
"encoding/base64"
"encoding/json"
"io/ioutil"
"strconv"
"strings"

"io"
"github.com/andybalholm/brotli"
utls "github.com/refraction-networking/utls"
)
Expand Down Expand Up @@ -85,7 +84,7 @@ func gUnzipData(data []byte) (resData []byte, err error) {
return []byte{}, err
}
defer gz.Close()
respBody, err := ioutil.ReadAll(gz)
respBody, err := io.ReadAll(gz)
return respBody, err
}
func enflateData(data []byte) (resData []byte, err error) {
Expand All @@ -94,12 +93,12 @@ func enflateData(data []byte) (resData []byte, err error) {
return []byte{}, err
}
defer zr.Close()
enflated, err := ioutil.ReadAll(zr)
enflated, err := io.ReadAll(zr)
return enflated, err
}
func unBrotliData(data []byte) (resData []byte, err error) {
br := brotli.NewReader(bytes.NewReader(data))
respBody, err := ioutil.ReadAll(br)
respBody, err := io.ReadAll(br)
return respBody, err
}

Expand Down
11 changes: 11 additions & 0 deletions docs/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,16 @@
# CycleTLS Changelog

## 1.0.24 - (11-27-2023)
### Release Highlights
Small bugfixes and ReadMe updates

### Enhancements
- Update docs
- Add tests for forceHTTP1
- update to using io instead of ioutil
### Bug Fixes
- Fix issue with keepalives on closed connections when http1 is forced

## 1.0.23 - (11-27-2023)
### Release Highlights
Switch to UTLS
Expand Down
2 changes: 1 addition & 1 deletion src/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ go 1.20
replace github.com/Danny-Dasilva/CycleTLS/cycletls => ../cycletls

require (
github.com/Danny-Dasilva/CycleTLS/cycletls v0.0.0-20231128002513-4df48e6bd744 // indirect
github.com/Danny-Dasilva/CycleTLS/cycletls v1.0.23 // indirect
github.com/Danny-Dasilva/fhttp v0.0.0-20231127034941-9494939f30fa // indirect
github.com/andybalholm/brotli v1.0.6 // indirect
github.com/cloudflare/circl v1.3.6 // indirect
Expand Down
49 changes: 49 additions & 0 deletions tests/forceHTTP1.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import initCycleTLS, { CycleTLSClient } from "../dist/index.js";

describe("CycleTLS HTTP Version Tests", () => {
let cycleTLS: CycleTLSClient;
let ja3 = "771,4865-4866-4867-49195-49199-49196-49200-52393-52392-49171-49172-156-157-47-53,0-23-65281-10-11-35-16-5-13-18-51-45-43-27-21,29-23-24,0";
let userAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.106 Safari/537.36";

beforeAll(async () => {
cycleTLS = await initCycleTLS({ port: 9134 });
});

afterAll(() => {
cycleTLS.exit();
});

test("Should use HTTP/2 by default", async () => {
const response = await cycleTLS(
"https://tls.peet.ws/api/all",
{
body: "",
ja3: ja3,
userAgent: userAgent,
forceHTTP1: false,
},
"get"
);

expect(response.status).toBe(200);
let fullResp = response.body as { http_version: string };
expect(fullResp.http_version).toBe("h2");
});

test("Should force HTTP/1.1 when specified", async () => {
const response = await cycleTLS(
"https://tls.peet.ws/api/all",
{
body: "",
ja3: ja3,
userAgent: userAgent,
forceHTTP1: true,
},
"get"
);

expect(response.status).toBe(200);
let fullResp = response.body as { http_version: string };
expect(fullResp.http_version).toBe("HTTP/1.1");
});
});
Loading

0 comments on commit dfe97e5

Please sign in to comment.