Haruue Icymoon
45fbdec453
chore: swap the const value of server hello reply
...
by setting StatusTCPOnly == 1, when a new version client connect to an
old version server, the client will treat the server as udp disabled and
will not submit a udp request or open a udp control stream.
this make the upgrade much more smoothly even if we don't change the
protocolVersion.
2022-08-28 20:25:50 +08:00
Haruue Icymoon
955a8a7470
feat: 1xRTT UDP relay
...
this commit makes changes on the hysteria protocol, although old clients
still be able to connect to a newer server, newer clients will fail if
they connect to older servers and trying to submit a udp request, so the
protocolVersion should be bumped if this commit finally get merged.
this commit changes the way to handle hyClient.DialUDP(). in the past,
the hysteria client asks the server to create the sessionID in every
call to hyClient.DialUDP(), which requires a extra RTT to wait the
server reply. to avoid this extra RTT, the hysteria client just
generates and manages the sessionID by theirselves. the server checks
the sessionID sent from clients in every udpMessage, and open & initiate
a new udp session for every sessionID it not recognized.
the way to release udp sessions is also changed in this commit, as every
udp session no longer maintains a quic stream, now the client will open
a dedicated quic stream to notify the server to release specified udp
session. this also changes the behavior of "max_conn_client" in the
server config.
this commit can be a partial fix for #348 , #352 and #414 .
2022-08-28 17:55:40 +08:00
Haruue Icymoon
f7de18fd43
chore: a better approach for http proxy error log
2022-08-25 00:53:52 +08:00
Haruue Icymoon
2fb70bdb58
feat: log http proxy error
...
goproxy actually discard all upstream errors, you can find its error
handling here [1], the upstream error from proxy.connectDial() is always
hidden in the two if branches, and never got logged. we need to log
hysteria layer errors by ourselves.
[1] 8ea89ba920/https.go (L321-L328)
according to some bug reports (such like #404 and the resolve_preference
one report via telegram private message), some users use http proxy, got a
http 502 error without any useful logs.
2022-08-25 00:42:36 +08:00
Haruue Icymoon
7c9fbf22dd
feat: tcp buffer size options for tun mode
...
close : #407
2022-08-24 23:26:56 +08:00
Toby
a31f826a1e
fix: use bootstrap address in routedns resolvers to avoid loopback ( closes #408 )
2022-08-21 19:40:47 -07:00
Toby
a10abd473f
Merge pull request #409 from HyNetwork/dependabot/go_modules/github.com/caddyserver/certmagic-0.16.3
...
chore(deps): bump github.com/caddyserver/certmagic from 0.16.2 to 0.16.3
2022-08-20 15:01:05 -07:00
Toby
8960aefca3
chore: update module names (hysteria & quic-go fork)
2022-08-20 11:44:12 -07:00
dependabot[bot]
ac8a27df6e
chore(deps): bump github.com/caddyserver/certmagic from 0.16.2 to 0.16.3
...
Bumps [github.com/caddyserver/certmagic](https://github.com/caddyserver/certmagic ) from 0.16.2 to 0.16.3.
- [Release notes](https://github.com/caddyserver/certmagic/releases )
- [Commits](https://github.com/caddyserver/certmagic/compare/v0.16.2...v0.16.3 )
---
updated-dependencies:
- dependency-name: github.com/caddyserver/certmagic
dependency-type: direct:production
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-08-19 06:08:20 +00:00
Toby
aad4c44b3d
chore: update CHANGELOG for 1.2.0
2022-08-13 18:58:23 -07:00
Toby
944c0ecf64
fix: resolve_preference should only assign each ip once 2
2022-08-13 11:48:09 -07:00
Toby
88099ee72d
fix: resolve_preference should only assign each ip once
2022-08-13 11:39:40 -07:00
Toby
1462cadfdc
format: gofumpt
2022-08-13 11:04:28 -07:00
Haruue Icymoon
4747be198e
fix: resolve_preference not work
2022-08-13 22:05:07 +08:00
Toby
1b2eb49da1
Merge pull request #398 from HyNetwork/wip-log-ipmask
...
feat: IP masks
2022-08-12 18:03:50 -07:00
Toby
fbfd933fac
feat: ip mask for client side
2022-08-11 21:25:47 -07:00
Toby
ab2ad4aa6d
chore: fix license badge
2022-08-10 22:00:11 -07:00
Toby
ad095e4545
feat: ip mask (wip, server only atm)
2022-08-10 21:56:47 -07:00
Toby
12c20211b0
Merge pull request #392 from HyNetwork/dependabot/go_modules/github.com/oschwald/geoip2-golang-1.8.0
...
chore(deps): bump github.com/oschwald/geoip2-golang from 1.7.0 to 1.8.0
2022-08-10 21:54:31 -07:00
Toby
e5e45720bd
Merge branch 'master' into dependabot/go_modules/github.com/oschwald/geoip2-golang-1.8.0
2022-08-10 21:45:26 -07:00
Toby
8f5ec1aac2
Merge pull request #393 from HyNetwork/dependabot/github_actions/docker/build-push-action-3.1.1
...
chore(deps): bump docker/build-push-action from 3.1.0 to 3.1.1
2022-08-10 21:44:42 -07:00
Toby
cdc874a608
Merge pull request #391 from HyNetwork/dependabot/go_modules/github.com/prometheus/client_golang-1.13.0
...
chore(deps): bump github.com/prometheus/client_golang from 1.12.2 to 1.13.0
2022-08-10 21:44:30 -07:00
dependabot[bot]
634eb26a4b
chore(deps): bump github.com/oschwald/geoip2-golang from 1.7.0 to 1.8.0
...
Bumps [github.com/oschwald/geoip2-golang](https://github.com/oschwald/geoip2-golang ) from 1.7.0 to 1.8.0.
- [Release notes](https://github.com/oschwald/geoip2-golang/releases )
- [Commits](https://github.com/oschwald/geoip2-golang/compare/v1.7.0...v1.8.0 )
---
updated-dependencies:
- dependency-name: github.com/oschwald/geoip2-golang
dependency-type: direct:production
update-type: version-update:semver-minor
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-08-11 03:53:07 +00:00
dependabot[bot]
943603eb20
chore(deps): bump github.com/prometheus/client_golang
...
Bumps [github.com/prometheus/client_golang](https://github.com/prometheus/client_golang ) from 1.12.2 to 1.13.0.
- [Release notes](https://github.com/prometheus/client_golang/releases )
- [Changelog](https://github.com/prometheus/client_golang/blob/main/CHANGELOG.md )
- [Commits](https://github.com/prometheus/client_golang/compare/v1.12.2...v1.13.0 )
---
updated-dependencies:
- dependency-name: github.com/prometheus/client_golang
dependency-type: direct:production
update-type: version-update:semver-minor
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-08-11 03:53:05 +00:00
Toby
bd9f3e5846
Merge pull request #395 from HyNetwork/wip-newtun-license
...
Switch tun2socks implementation to xjasonlyu/tun2socks for TUN mode
2022-08-10 20:52:11 -07:00
Toby
45eacaf886
ci: remove xgo usage (as we no longer need cgo)
2022-08-10 20:30:49 -07:00
Toby
b3608956be
chore: minor change to log text
2022-08-10 20:30:26 -07:00
Haruue Icymoon
0ba4c36bc6
Merge remote-tracking branch 'origin/master' into wip-newtun-license
2022-08-10 18:05:45 +08:00
Haruue Icymoon
0bd4574988
ci: release build changes for newtun
...
remove notun and GOFLAGS="-tags=gpl"
2022-08-10 17:45:35 +08:00
Haruue Icymoon
4947af7fa8
docs: update LICENSE.md
2022-08-10 12:45:39 +08:00
Haruue Icymoon
720b97da67
chore: solve license conflict against tun2socks
2022-08-10 12:24:06 +08:00
Haruue Icymoon
80b0c87654
chore: log tun2socks internal warn as info
2022-08-10 11:39:29 +08:00
Haruue Icymoon
4abb30620a
fix: tun device not closed when killed
2022-08-10 11:39:10 +08:00
Toby
a4c61e285e
chore: minor log format change
2022-08-09 20:23:22 -07:00
Haruue Icymoon
f3f604b59a
refactor(tun): switch to xjasonlyu/tun2socks
...
fix : #306 , #394 , #185 , #161
break changes:
we won't create or maintain the interface now, so it is user's duty to
create the tun interface, for example, with command like
ip tuntap add dev hytun mode tun
(or maybe we can use songgao/water to keep this behavior unchanged).
correspondingly, the "address", "gateway", "mask", "dns", "persist"
options in the "tun" config have been removed.
in addition, please note xjasonlyu/tun2socks is licensed under GPLv3 and
hysteria is licensed under MIT, I don't ensure is it legal to use it as
a go mod, but there are too many requests related on it so whatever...
2022-08-10 02:43:07 +08:00
dependabot[bot]
a5b7bc7707
chore(deps): bump docker/build-push-action from 3.1.0 to 3.1.1
...
Bumps [docker/build-push-action](https://github.com/docker/build-push-action ) from 3.1.0 to 3.1.1.
- [Release notes](https://github.com/docker/build-push-action/releases )
- [Commits](https://github.com/docker/build-push-action/compare/v3.1.0...v3.1.1 )
---
updated-dependencies:
- dependency-name: docker/build-push-action
dependency-type: direct:production
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-08-08 06:10:18 +00:00
Toby
af2e0e9676
Merge pull request #390 from HyNetwork/resolver-rework
...
feat: rework resolver support
2022-08-07 12:08:11 -07:00
Toby
562d8402f5
ci: bump go version to 1.19
2022-08-07 11:58:22 -07:00
Toby
3e63cede8a
chore: use upstream routedns since they merged my changes
2022-08-06 20:06:37 -07:00
Toby
3f0953ffdd
feat: rework resolver support
2022-08-06 19:58:05 -07:00
Toby
a2ab9e0425
ci: xgo does not support freebsd targets
2022-08-06 11:57:10 -07:00
Toby
21382fe39c
ci: add freebsd build targets
2022-08-06 11:19:37 -07:00
Toby
345836abc4
Update README.md
2022-08-04 16:00:11 -07:00
Toby
b84b4b77af
Merge pull request #386 from HyNetwork/dependabot/go_modules/github.com/caddyserver/certmagic-0.16.2
...
chore(deps): bump github.com/caddyserver/certmagic from 0.16.1 to 0.16.2
2022-08-03 11:21:29 -07:00
dependabot[bot]
e0d7a297a6
chore(deps): bump github.com/caddyserver/certmagic from 0.16.1 to 0.16.2
...
Bumps [github.com/caddyserver/certmagic](https://github.com/caddyserver/certmagic ) from 0.16.1 to 0.16.2.
- [Release notes](https://github.com/caddyserver/certmagic/releases )
- [Commits](https://github.com/caddyserver/certmagic/compare/v0.16.1...v0.16.2 )
---
updated-dependencies:
- dependency-name: github.com/caddyserver/certmagic
dependency-type: direct:production
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-08-03 06:09:37 +00:00
Toby
b9d0108af3
Merge pull request #378 from HyNetwork/dependabot/github_actions/crazy-max/ghaction-xgo-2.1.0
...
chore(deps): bump crazy-max/ghaction-xgo from 2.0.0 to 2.1.0
2022-07-22 10:51:21 -07:00
Toby
7051e229d8
Merge pull request #379 from HyNetwork/dependabot/go_modules/github.com/sirupsen/logrus-1.9.0
...
chore(deps): bump github.com/sirupsen/logrus from 1.8.1 to 1.9.0
2022-07-22 10:51:10 -07:00
Toby
056643f343
Merge pull request #380 from HyNetwork/dependabot/github_actions/docker/build-push-action-3.1.0
...
chore(deps): bump docker/build-push-action from 3.0.0 to 3.1.0
2022-07-22 10:50:57 -07:00
dependabot[bot]
9fb43fbc43
chore(deps): bump docker/build-push-action from 3.0.0 to 3.1.0
...
Bumps [docker/build-push-action](https://github.com/docker/build-push-action ) from 3.0.0 to 3.1.0.
- [Release notes](https://github.com/docker/build-push-action/releases )
- [Commits](https://github.com/docker/build-push-action/compare/v3.0.0...v3.1.0 )
---
updated-dependencies:
- dependency-name: docker/build-push-action
dependency-type: direct:production
update-type: version-update:semver-minor
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-07-20 06:15:17 +00:00
dependabot[bot]
a83494da78
chore(deps): bump github.com/sirupsen/logrus from 1.8.1 to 1.9.0
...
Bumps [github.com/sirupsen/logrus](https://github.com/sirupsen/logrus ) from 1.8.1 to 1.9.0.
- [Release notes](https://github.com/sirupsen/logrus/releases )
- [Changelog](https://github.com/sirupsen/logrus/blob/master/CHANGELOG.md )
- [Commits](https://github.com/sirupsen/logrus/compare/v1.8.1...v1.9.0 )
---
updated-dependencies:
- dependency-name: github.com/sirupsen/logrus
dependency-type: direct:production
update-type: version-update:semver-minor
...
Signed-off-by: dependabot[bot] <support@github.com>
2022-07-20 06:14:53 +00:00