We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
github.com/gotd/td v0.99.1
Yes
I was downloading stickers using some code from this example. I'm using github.com/celestix/gotgproto as wrapper for gotd/td:
func downloadStickerMessagesProcessor(ctx *ext.Context, update *ext.Update) error { if update.EffectiveMessage.Media == nil { return nil } var buf bytes.Buffer _, err = ctx.DownloadMedia(update.EffectiveMessage.Media, ext.DownloadOutputStream{Writer: &buf}, nil) if err != nil { return errors.Wrap(err, "failed to download media") } // doing other things return nil
DownloadMedia works almost the same as in td example: downloader.NewDownloader().Download(api, loc).Stream(ctx, &buf)
DownloadMedia
downloader.NewDownloader().Download(api, loc).Stream(ctx, &buf)
If sticker is locating in the same DC as my main (2), the is no problem. If it's in other - code freezes with this logs:
2024-03-24T13:07:01.115+0300 DEBUG conn.mtproto mtproto/new_encrypted_msg.go:62 Request {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0xbe5335be", "type_name": "upload.getFile#be5335be", "msg_id": 7349869390778362016} 2024-03-24T13:07:01.185+0300 DEBUG conn.mtproto mtproto/handle_message.go:19 Handle message {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0xf35c6d01", "type_name": "rpc_result", "size_bytes": 36, "msg_id": 7349869391774926849} 2024-03-24T13:07:01.185+0300 DEBUG conn.mtproto mtproto/handle_result.go:24 Handle result {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0x2144ca19", "type_name": "rpc_error#2144ca19", "size_bytes": 24, "msg_id": 7349869390778362016} 2024-03-24T13:07:01.190+0300 DEBUG conn.mtproto mtproto/handle_result.go:53 Got error {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349869390778362016, "err_code": 303, "err_msg": "FILE_MIGRATE_4"} 2024-03-24T13:07:01.191+0300 DEBUG conn.mtproto.rpc rpc/engine.go:99 Handler called {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349869390778362016} 2024-03-24T13:07:01.192+0300 DEBUG conn.mtproto mtproto/rpc.go:44 Invoke end {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349869390778362016} 2024-03-24T13:07:01.192+0300 DEBUG conn manager/conn.go:113 Invoke {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "duration": "77.847208ms", "ongoing": 0} 2024-03-24T13:07:01.197+0300 DEBUG telegram/invoke.go:67 Invoking on target DC {"v": "v0.99.1", "error_type": "FILE_MIGRATE", "target_dc": 4} 2024-03-24T13:07:01.199+0300 DEBUG telegram/pool.go:61 Creating pool {"v": "v0.99.1", "dc_id": 4, "max": 1, "candidates": 5} 2024-03-24T13:07:09.344+0300 DEBUG conn.mtproto mtproto/new_encrypted_msg.go:62 Request {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0x62d6b459", "type_name": "msgs_ack#62d6b459", "msg_id": 7349869425367492384}
On sticker located in my DC I have this logs:
2024-03-24T13:17:25.449+0300 DEBUG conn.mtproto mtproto/handle_message.go:19 Handle message {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0x74ae4240", "type_name": "updates#74ae4240", "size_bytes": 796, "msg_id": 7349872072621388801} 2024-03-24T13:17:25.523+0300 DEBUG conn.mtproto mtproto/rpc.go:29 Invoke start {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349872071245901720} 2024-03-24T13:17:25.523+0300 DEBUG conn.mtproto.rpc rpc/engine.go:87 Do called {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349872071245901720} 2024-03-24T13:17:25.523+0300 DEBUG conn.mtproto.rpc rpc/ack.go:34 Waiting for acknowledge {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "ack_id": 7349872071245901720} 2024-03-24T13:17:25.524+0300 DEBUG conn.mtproto mtproto/new_encrypted_msg.go:62 Request {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0xbe5335be", "type_name": "upload.getFile#be5335be", "msg_id": 7349872071245901720} 2024-03-24T13:17:25.672+0300 DEBUG conn.mtproto mtproto/handle_message.go:19 Handle message {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0xf35c6d01", "type_name": "rpc_result", "size_bytes": 25124, "msg_id": 7349872073635940353} 2024-03-24T13:17:25.672+0300 DEBUG conn.mtproto mtproto/handle_result.go:24 Handle result {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "type_id": "0x96a18d5", "type_name": "upload.file#96a18d5", "size_bytes": 25112, "msg_id": 7349872071245901720} 2024-03-24T13:17:25.672+0300 DEBUG conn.mtproto.rpc rpc/engine.go:99 Handler called {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349872071245901720} 2024-03-24T13:17:25.675+0300 DEBUG conn.mtproto mtproto/rpc.go:47 Invoke end {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "msg_id": 7349872071245901720} 2024-03-24T13:17:25.675+0300 DEBUG conn manager/conn.go:113 Invoke {"v": "v0.99.1", "conn_id": 0, "dc_id": 2, "duration": "152.638917ms", "ongoing": 0}
Downloading completes successfully with stickers from any DC.
Downloading completes successfully with stickers from only on my DC.
go version go1.22.0 darwin/arm64
go env
$ go env
The text was updated successfully, but these errors were encountered:
I also freeze the client when I use gif search to send a trigger download, and send the same gif using a file to download normally
Sorry, something went wrong.
I'll try to reproduce this, but not sure how to do it easily. Most of my clients are on DC4, what is the simple way to trigger this>
ernado
No branches or pull requests
What version of gotd are you using?
github.com/gotd/td v0.99.1
Can this issue be reproduced with the latest version?
Yes
What did you do?
I was downloading stickers using some code from this example. I'm using github.com/celestix/gotgproto as wrapper for gotd/td:
DownloadMedia
works almost the same as in td example:downloader.NewDownloader().Download(api, loc).Stream(ctx, &buf)
If sticker is locating in the same DC as my main (2), the is no problem. If it's in other - code freezes with this logs:
On sticker located in my DC I have this logs:
What did you expect to see?
Downloading completes successfully with stickers from any DC.
What did you see instead?
Downloading completes successfully with stickers from only on my DC.
What Go version and environment are you using?
go version go1.22.0 darwin/arm64
go env
OutputGO111MODULE='on' GOARCH='amd64' GOBIN='' GOCACHE='/Users/teadove/Library/Caches/go-build' GOENV='/Users/teadove/Library/Application Support/go/env' GOEXE='' GOEXPERIMENT='' GOFLAGS='' GOHOSTARCH='arm64' GOHOSTOS='darwin' GOINSECURE='' GOMODCACHE='/Users/teadove/go/pkg/mod' GONOPROXY='gitlab.whoosh-cloud.com' GONOSUMDB='gitlab.whoosh-cloud.com' GOOS='darwin' GOPATH='/Users/teadove/go' GOPRIVATE='gitlab.whoosh-cloud.com' GOPROXY='https://proxy.golang.org,direct' GOROOT='/Users/teadove/go/go1.22.0' GOSUMDB='sum.golang.org' GOTMPDIR='' GOTOOLCHAIN='auto' GOTOOLDIR='/Users/teadove/go/go1.22.0/pkg/tool/darwin_arm64' GOVCS='' GOVERSION='go1.22.0' GCCGO='gccgo' GOAMD64='v1' AR='ar' CC='clang' CXX='clang++' CGO_ENABLED='0' GOMOD='/Users/teadove/projects/fun-telegram/go.mod' GOWORK='' CGO_CFLAGS='-O2 -g' CGO_CPPFLAGS='' CGO_CXXFLAGS='-O2 -g' CGO_FFLAGS='-O2 -g' CGO_LDFLAGS='-O2 -g' PKG_CONFIG='pkg-config' GOGCCFLAGS='-fPIC -arch x86_64 -m64 -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -ffile-prefix-map=/var/folders/1l/sljqjzq579vfs5tgztmg_x_w0000gn/T/go-build1516207097=/tmp/go-build -gno-record-gcc-switches -fno-common'
The text was updated successfully, but these errors were encountered: