package premium import ( "time" "github.com/debridmediamanager/zurg/pkg/logutil" "github.com/debridmediamanager/zurg/pkg/realdebrid" ) const PREMIUM_THRESHOLD = 172800 func MonitorPremiumStatus(rd *realdebrid.RealDebrid, zurglog *logutil.Logger) { go func() { for { userInfo, err := rd.GetUserInformation() if err != nil { zurglog.Errorf("Failed to get user information: %v", err) time.Sleep(5 * time.Minute) continue } if userInfo.Premium <= 0 { zurglog.Fatal("Your account is no longer premium, exiting...") } else { if userInfo.Premium <= PREMIUM_THRESHOLD { zurglog.Warnf("Your account will expire in %d hours", userInfo.Premium/3600) } else { zurglog.Infof("Your account will expire in %d days", userInfo.Premium/86400) } } remaining := userInfo.Premium - PREMIUM_THRESHOLD sleepDuration := time.Duration(remaining) * time.Second time.Sleep(sleepDuration) } }() }