mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-18 23:16:49 +00:00
* Initial rework of rework of requester - WIP * Implementing and checking rate limits - WIP * implemented coinbene rate limiting shenanigans * add in remaining WIP * fixy * use authenticated rate limit * drop ceiling as this can be done with a counter later * add functionality to struct * purge config options for rate limiting so as to keep things minimal * prepare futures and swap rate limiting for implementation * Address linter issues * Addressed nits, fixed race * fix linter issue * remove global var as this was only setting when newrequester was called * moved rate limit functionality into its own file * Update Bitfinex with correct rate limit and test endpoints (WIP) * finish off bitfinex adjustments * fixes * fix linter issues * slowed rate for coinbasepro * drop rate limit for huobi as the doc times have intermittent 429 issues. * Set MACOSX_DEPLOYMENT_TARGET to remove linking warning * Addr Thrasher nits * Addr glorious nits * unexport do request function * fixed nitorinos * Fixed something I missed * move disabled rate limiter into loadexchange and use interface functionality * Add temp quick fix
43 lines
1.0 KiB
Go
43 lines
1.0 KiB
Go
package poloniex
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/request"
|
|
"golang.org/x/time/rate"
|
|
)
|
|
|
|
const (
|
|
poloniexRateInterval = time.Second
|
|
poloniexAuthRate = 6
|
|
poloniexUnauthRate = 6
|
|
)
|
|
|
|
// RateLimit implements the request.Limiter interface
|
|
type RateLimit struct {
|
|
Auth *rate.Limiter
|
|
UnAuth *rate.Limiter
|
|
}
|
|
|
|
// Limit limits outbound calls
|
|
func (r *RateLimit) Limit(f request.EndpointLimit) error {
|
|
if f == request.Auth {
|
|
time.Sleep(r.Auth.Reserve().Delay())
|
|
return nil
|
|
}
|
|
time.Sleep(r.UnAuth.Reserve().Delay())
|
|
return nil
|
|
}
|
|
|
|
// SetRateLimit returns the rate limit for the exchange
|
|
// If your account's volume is over $5 million in 30 day volume,
|
|
// you may be eligible for an API rate limit increase.
|
|
// Please email poloniex@circle.com.
|
|
// As per https://docs.poloniex.com/#http-api
|
|
func SetRateLimit() *RateLimit {
|
|
return &RateLimit{
|
|
Auth: request.NewRateLimit(poloniexRateInterval, poloniexAuthRate),
|
|
UnAuth: request.NewRateLimit(poloniexRateInterval, poloniexUnauthRate),
|
|
}
|
|
}
|