Add Wildberries product fetching and rate limiting functionality
This commit is contained in:
		@@ -11,6 +11,7 @@ var Client *rueidis.Client
 | 
			
		||||
func InitClient(ctx context.Context) error {
 | 
			
		||||
	var err error
 | 
			
		||||
	host := os.Getenv("REDIS_HOST")
 | 
			
		||||
	//host := "redis"
 | 
			
		||||
	port := os.Getenv("REDIS_PORT")
 | 
			
		||||
	password := os.Getenv("REDIS_PASSWORD")
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										29
									
								
								internal/redis/lock.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								internal/redis/lock.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
package redis
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/redis/rueidis"
 | 
			
		||||
	"github.com/redis/rueidis/rueidislock"
 | 
			
		||||
	"os"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var Locker *rueidislock.Locker
 | 
			
		||||
 | 
			
		||||
func InitLocker() error {
 | 
			
		||||
	redisAddr := os.Getenv("REDIS_ADDR")
 | 
			
		||||
	password := os.Getenv("REDIS_PASSWORD")
 | 
			
		||||
	locker, err := rueidislock.NewLocker(rueidislock.LockerOption{
 | 
			
		||||
		ClientOption: rueidis.ClientOption{InitAddress: []string{redisAddr}, Password: password},
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	Locker = &locker
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
func CloseLocker() {
 | 
			
		||||
	if Locker != nil {
 | 
			
		||||
		(*Locker).Close()
 | 
			
		||||
	}
 | 
			
		||||
	Locker = nil
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user