HTTP 420 · Flood
HTTP 420 Flood / Rate limits Parameterized

When & why it happens

Too many requests in too short a window. Wait the supplied number of seconds before retrying; the gogram client schedules this automatically.

Parameterized error

The wire code carries a parameter on its tail (literal you'll see: FLOOD_WAIT_42). Gogram parses it out and stores it on ErrResponseCode.AdditionalInfo with the right type.

Handling in gogram

Surfaced as *gogram.ErrResponseCode. Match on the message:

if err, ok := err.(*gogram.ErrResponseCode); ok { if strings.HasPrefix(err.Message, "FLOOD_WAIT") { secs := err.AdditionalInfo.(int) time.Sleep(time.Duration(secs) * time.Second) // retry } }