1
0
mirror of https://github.com/therootcompany/sclient synced 2024-11-16 17:09:00 +00:00
sclient/doc.go

45 lines
1.2 KiB
Go
Raw Normal View History

2019-05-21 18:54:02 -06:00
/*
2019-05-21 19:15:43 -06:00
sclient unwraps SSL.
2019-05-21 18:54:02 -06:00
It makes secure remote connections (such as HTTPS) available locally as plain-text connections -
similar to `stunnel` or `openssl s_client`.
There are a variety of reasons that you might want to do that,
but we created it specifically to be able to upgrade applications with legacy
2019-05-21 19:15:43 -06:00
security protocols - like SSH, OpenVPN, and Postgres - to take
advantage of the features of modern TLS, such as ALPN and SNI
2019-05-21 18:54:02 -06:00
(which makes them routable through almost every type of firewall).
See https://telebit.cloud/sclient for more info.
Try the CLI
2019-05-21 19:15:43 -06:00
If you'd like to better understand what sclient does, you can try it out with `go run`:
2019-05-21 18:54:02 -06:00
go get git.rootprojects.org/root/sclient.go/cmd/sclient
go run git.rootprojects.org/root/sclient.go/cmd/sclient example.com:443 localhost:3000
2019-05-21 19:15:43 -06:00
curl http://localhost:3000 -H "Host: example.com"
Pre-built versions for various platforms are also available at
https://telebit.cloud/sclient
2019-05-21 18:54:02 -06:00
Package Basics
2019-05-21 19:15:43 -06:00
The general use of
2019-05-21 18:54:02 -06:00
servername := "example.com"
sclient := &sclient.Tunnel{
ServerName: servername,
RemoteAddress: servername,
RemotePort: 443,
LocalAddress: "localhost",
LocalPort: 3000,
}
err := sclient.DialAndListen()
*/
package sclient