-
Notifications
You must be signed in to change notification settings - Fork 939
New issue
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
draft: premium: provide 3d grace period after slot removed #1804
base: dev
Are you sure you want to change the base?
Conversation
4e4905f
to
bc99432
Compare
https://github.com/botlabs-gg/yagpdb/blob/master/premium/patreonpremiumsource/patreonpremiumsource.go#L137 |
Sorry, I don't fully understand your suggested approach. It seems (?) like it might be an addon to the existing patch rather than a replacement--is that correct? Edit: I think I understand what you're suggesting. I would prefer to leave the implementation of that to Des, if he likes the idea, since it's difficult for me to test such an addition, even moreso than the current code--I don't have Patreon set up :-) |
In poller.go I can simply check if a payment is pending or declined and next charge date was 3 days from now, and send an alert, no need for a complicated event system or a schema change.
|
Or rather this is sufficient, no need for alerting as patreon will alert the user. @@ -188,16 +188,12 @@ func (p *Poller) Poll() {
continue
}
- if attributes.PatronStatus != "active_patron" {
+ if len(attributes.LastChargeStatus) > 0 && attributes.LastChargeStatus != patreonapi.ChargeStatusPaid && attributes.LastChargeStatus != patreonapi.
ChargeStatusPending && attributes.LastChargeStatus != patreonapi.ChargeStatusDeclined {
continue
}
- if len(attributes.LastChargeStatus) > 0 && attributes.LastChargeStatus != patreonapi.ChargeStatusPaid && attributes.LastChargeStatus != patreonapi.
ChargeStatusPending {
- continue
- }
-
- // Skip if the next charge date is in the past
- if attributes.NextChargeDate != nil && attributes.NextChargeDate.Before(time.Now()) {
+ // Skip if the next charge date is passed by 3 days
+ if attributes.NextChargeDate != nil && attributes.NextChargeDate.Before(time.Now().Add(-1*3*24*time.Hour)) {
continue
} |
Sounds reasonable. I will close this draft then. |
The above plan has an issue, the entitled cents amount is 0, and hence the user isn't assigned a slot, and there doesn't seem too be a way to figure out how much the user paid in the last charge. I could possible get the users current set of slots and calculate it myself, or mark the slots to be removed after 3 days, and if a current entitled users slot is marked for removal after three days undo it. |
The latter idea is somewhat like what I implemented here (and is, I think, the easiest way to go), so feel free to reuse code from this PR as needed or reopen and modify directly, whichever is easiest. Unfortunately, I will not have time to work on this more for the time being. |
Here is a possible implementation of a grace period before which premium features--additional custom commands, feeds, and so on--are disabled after a guild loses its premium slot.
It is intended really only as a possible starting point and has not been tested very thoroughly (though it works in the simple cases I have tried): I'm happy to see parts of this code cherry-picked and included in the final implementation and the original PR abandoned.
One important issue to note with this and similar approaches is that, as is, users can assign a premium slot to a server, then immediately unlink it to get 3 free days of premium while keeping their premium slot available for use on other servers. In other words, this code does not distinguish between users deliberately unlinking their premium slot from a server and a premium slot expiring naturally--it probably should.