On a once a day user action: 24 Hours Reset vs. Midnight Reset [closed]












23














When a user is able to perform an action only once a day, for example getting a free ticket for a competition, there are two possibilities I came across in my experience.



1) 24 Hours Reset



If he performs the action on day 1 on 11:45 PM, he can only perform the action again on day 2 on or after 11:45. He won't be able to do it 11:44 on day 2.



2) Midnight Reset (or any fixed time)



No matter what time the user performs the action on day 1, as soon as it turns midnight and day 2 starts, he will be able to do it again.





Both limit the user in performing only one action a day, but I most often come across method 1, who I think is pretty inconvenient for two reasons:




  • First I have to wait for the time

  • and second over a long time period, the timestamp of me performing the action will become later and later, since I won't be able to perform the action exactly at that timestamp everyday, only a couple of seconds or minutes later.


Is there any technical reason, that one would prefer method 1, albeit the in my opinion important disadvantage for the user stated beforehand?





Edit, to specify: I'm especially talking about an example, where the actual timegap of 24 hours is not obviously needed, such as in the current free spin event of Theory11, where you get 1 free spin every 24 hours to get a chance at winning prizes.










share|improve this question















closed as too broad by gnat, BobDalgleish, svidgen, Blrfl, Greg Burghardt Dec 19 at 13:06


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.











  • 5




    There might be a reason to limit the actual time between the actions, which is why they would opt for a 24-hour lockout. For example, with option 2, you could perform the action at 23:59 and at 00:00 again.
    – Ivo Coumans
    Dec 18 at 10:32






  • 21




    The answer would be entirely problem-specific, and it isn't hard to come up with problems that suit either. Software is developed to implement business rules, not the other way around.
    – Blrfl
    Dec 18 at 11:25






  • 4




    Note that midnight is an arbitrary time. It could just as easily be any time you want.
    – David Starkey
    Dec 18 at 16:23






  • 2




    Kind of a sidenote, midnight can be problematic for night owls. To get around that, WoW, for instance, resets "daily" things at 3 or 4 am.
    – Kevin
    Dec 18 at 20:19






  • 6




    Note: There's a variety of games and such that only allow an Action every 21 hours. Theoretically one could abuse this to get >1 per day, but that means waking up mid-sleep, which is rare enough to usually not be that big of a deal for the servers. It then allows users to log in "every morning" without the timeout slowly advancing throughout the day.
    – Mooing Duck
    Dec 18 at 23:22


















23














When a user is able to perform an action only once a day, for example getting a free ticket for a competition, there are two possibilities I came across in my experience.



1) 24 Hours Reset



If he performs the action on day 1 on 11:45 PM, he can only perform the action again on day 2 on or after 11:45. He won't be able to do it 11:44 on day 2.



2) Midnight Reset (or any fixed time)



No matter what time the user performs the action on day 1, as soon as it turns midnight and day 2 starts, he will be able to do it again.





Both limit the user in performing only one action a day, but I most often come across method 1, who I think is pretty inconvenient for two reasons:




  • First I have to wait for the time

  • and second over a long time period, the timestamp of me performing the action will become later and later, since I won't be able to perform the action exactly at that timestamp everyday, only a couple of seconds or minutes later.


Is there any technical reason, that one would prefer method 1, albeit the in my opinion important disadvantage for the user stated beforehand?





Edit, to specify: I'm especially talking about an example, where the actual timegap of 24 hours is not obviously needed, such as in the current free spin event of Theory11, where you get 1 free spin every 24 hours to get a chance at winning prizes.










share|improve this question















closed as too broad by gnat, BobDalgleish, svidgen, Blrfl, Greg Burghardt Dec 19 at 13:06


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.











  • 5




    There might be a reason to limit the actual time between the actions, which is why they would opt for a 24-hour lockout. For example, with option 2, you could perform the action at 23:59 and at 00:00 again.
    – Ivo Coumans
    Dec 18 at 10:32






  • 21




    The answer would be entirely problem-specific, and it isn't hard to come up with problems that suit either. Software is developed to implement business rules, not the other way around.
    – Blrfl
    Dec 18 at 11:25






  • 4




    Note that midnight is an arbitrary time. It could just as easily be any time you want.
    – David Starkey
    Dec 18 at 16:23






  • 2




    Kind of a sidenote, midnight can be problematic for night owls. To get around that, WoW, for instance, resets "daily" things at 3 or 4 am.
    – Kevin
    Dec 18 at 20:19






  • 6




    Note: There's a variety of games and such that only allow an Action every 21 hours. Theoretically one could abuse this to get >1 per day, but that means waking up mid-sleep, which is rare enough to usually not be that big of a deal for the servers. It then allows users to log in "every morning" without the timeout slowly advancing throughout the day.
    – Mooing Duck
    Dec 18 at 23:22
















23












23








23


5





When a user is able to perform an action only once a day, for example getting a free ticket for a competition, there are two possibilities I came across in my experience.



1) 24 Hours Reset



If he performs the action on day 1 on 11:45 PM, he can only perform the action again on day 2 on or after 11:45. He won't be able to do it 11:44 on day 2.



2) Midnight Reset (or any fixed time)



No matter what time the user performs the action on day 1, as soon as it turns midnight and day 2 starts, he will be able to do it again.





Both limit the user in performing only one action a day, but I most often come across method 1, who I think is pretty inconvenient for two reasons:




  • First I have to wait for the time

  • and second over a long time period, the timestamp of me performing the action will become later and later, since I won't be able to perform the action exactly at that timestamp everyday, only a couple of seconds or minutes later.


Is there any technical reason, that one would prefer method 1, albeit the in my opinion important disadvantage for the user stated beforehand?





Edit, to specify: I'm especially talking about an example, where the actual timegap of 24 hours is not obviously needed, such as in the current free spin event of Theory11, where you get 1 free spin every 24 hours to get a chance at winning prizes.










share|improve this question















When a user is able to perform an action only once a day, for example getting a free ticket for a competition, there are two possibilities I came across in my experience.



1) 24 Hours Reset



If he performs the action on day 1 on 11:45 PM, he can only perform the action again on day 2 on or after 11:45. He won't be able to do it 11:44 on day 2.



2) Midnight Reset (or any fixed time)



No matter what time the user performs the action on day 1, as soon as it turns midnight and day 2 starts, he will be able to do it again.





Both limit the user in performing only one action a day, but I most often come across method 1, who I think is pretty inconvenient for two reasons:




  • First I have to wait for the time

  • and second over a long time period, the timestamp of me performing the action will become later and later, since I won't be able to perform the action exactly at that timestamp everyday, only a couple of seconds or minutes later.


Is there any technical reason, that one would prefer method 1, albeit the in my opinion important disadvantage for the user stated beforehand?





Edit, to specify: I'm especially talking about an example, where the actual timegap of 24 hours is not obviously needed, such as in the current free spin event of Theory11, where you get 1 free spin every 24 hours to get a chance at winning prizes.







design programming-practices coding






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Dec 19 at 15:15

























asked Dec 18 at 10:19









RUL

12117




12117




closed as too broad by gnat, BobDalgleish, svidgen, Blrfl, Greg Burghardt Dec 19 at 13:06


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.






closed as too broad by gnat, BobDalgleish, svidgen, Blrfl, Greg Burghardt Dec 19 at 13:06


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.










  • 5




    There might be a reason to limit the actual time between the actions, which is why they would opt for a 24-hour lockout. For example, with option 2, you could perform the action at 23:59 and at 00:00 again.
    – Ivo Coumans
    Dec 18 at 10:32






  • 21




    The answer would be entirely problem-specific, and it isn't hard to come up with problems that suit either. Software is developed to implement business rules, not the other way around.
    – Blrfl
    Dec 18 at 11:25






  • 4




    Note that midnight is an arbitrary time. It could just as easily be any time you want.
    – David Starkey
    Dec 18 at 16:23






  • 2




    Kind of a sidenote, midnight can be problematic for night owls. To get around that, WoW, for instance, resets "daily" things at 3 or 4 am.
    – Kevin
    Dec 18 at 20:19






  • 6




    Note: There's a variety of games and such that only allow an Action every 21 hours. Theoretically one could abuse this to get >1 per day, but that means waking up mid-sleep, which is rare enough to usually not be that big of a deal for the servers. It then allows users to log in "every morning" without the timeout slowly advancing throughout the day.
    – Mooing Duck
    Dec 18 at 23:22
















  • 5




    There might be a reason to limit the actual time between the actions, which is why they would opt for a 24-hour lockout. For example, with option 2, you could perform the action at 23:59 and at 00:00 again.
    – Ivo Coumans
    Dec 18 at 10:32






  • 21




    The answer would be entirely problem-specific, and it isn't hard to come up with problems that suit either. Software is developed to implement business rules, not the other way around.
    – Blrfl
    Dec 18 at 11:25






  • 4




    Note that midnight is an arbitrary time. It could just as easily be any time you want.
    – David Starkey
    Dec 18 at 16:23






  • 2




    Kind of a sidenote, midnight can be problematic for night owls. To get around that, WoW, for instance, resets "daily" things at 3 or 4 am.
    – Kevin
    Dec 18 at 20:19






  • 6




    Note: There's a variety of games and such that only allow an Action every 21 hours. Theoretically one could abuse this to get >1 per day, but that means waking up mid-sleep, which is rare enough to usually not be that big of a deal for the servers. It then allows users to log in "every morning" without the timeout slowly advancing throughout the day.
    – Mooing Duck
    Dec 18 at 23:22










5




5




There might be a reason to limit the actual time between the actions, which is why they would opt for a 24-hour lockout. For example, with option 2, you could perform the action at 23:59 and at 00:00 again.
– Ivo Coumans
Dec 18 at 10:32




There might be a reason to limit the actual time between the actions, which is why they would opt for a 24-hour lockout. For example, with option 2, you could perform the action at 23:59 and at 00:00 again.
– Ivo Coumans
Dec 18 at 10:32




21




21




The answer would be entirely problem-specific, and it isn't hard to come up with problems that suit either. Software is developed to implement business rules, not the other way around.
– Blrfl
Dec 18 at 11:25




The answer would be entirely problem-specific, and it isn't hard to come up with problems that suit either. Software is developed to implement business rules, not the other way around.
– Blrfl
Dec 18 at 11:25




4




4




Note that midnight is an arbitrary time. It could just as easily be any time you want.
– David Starkey
Dec 18 at 16:23




Note that midnight is an arbitrary time. It could just as easily be any time you want.
– David Starkey
Dec 18 at 16:23




2




2




Kind of a sidenote, midnight can be problematic for night owls. To get around that, WoW, for instance, resets "daily" things at 3 or 4 am.
– Kevin
Dec 18 at 20:19




Kind of a sidenote, midnight can be problematic for night owls. To get around that, WoW, for instance, resets "daily" things at 3 or 4 am.
– Kevin
Dec 18 at 20:19




6




6




Note: There's a variety of games and such that only allow an Action every 21 hours. Theoretically one could abuse this to get >1 per day, but that means waking up mid-sleep, which is rare enough to usually not be that big of a deal for the servers. It then allows users to log in "every morning" without the timeout slowly advancing throughout the day.
– Mooing Duck
Dec 18 at 23:22






Note: There's a variety of games and such that only allow an Action every 21 hours. Theoretically one could abuse this to get >1 per day, but that means waking up mid-sleep, which is rare enough to usually not be that big of a deal for the servers. It then allows users to log in "every morning" without the timeout slowly advancing throughout the day.
– Mooing Duck
Dec 18 at 23:22












8 Answers
8






active

oldest

votes


















21














I'm am surprised as usually I would expect the midnight reset.



However, It does come with a major disadvantage, in that there is more than one midnight every 24h. You need to choose your timezone.



Maybe this is why the universal once per 24h is chosen, you can imagine the company might not want to accept that users half in different countries might have non midnight local end times, or rather than they might consider that saying "per day" implied midnight and thus they change the marketing to "per 24h" and the software spec to match



Although I think this is fairly common to see "ends at 2pm GMT" or similar these days.



I would have thought the challenge of storing a last action date for every user would be harder than that of assigning a timezone to users or action types.



Edit I think its worth noting the differences between the two methods



24h rule




  • I will get a constant stream of events, rate limited to less than 1 per 24h.

  • When I end the thing, some users will get less events.

  • I need to store every users last event

  • When daylight savings causes a long or short day I wont have 1 event per day

  • Humans wont be able to hit exactly 24h on the dot, so I will naturally get less than 1 per day on average


1 per calendar day rule




  • I get bucketed events over a 50h(? UTC+14 to -12 ?) period assigned to a calendar day

  • realistically I still have to store every users last event as 'days' over lap

  • I do have a definite end of a day where I can say all the events after now are not in the day.

  • I need to know the location of the user to know which day their event applies to

  • Some people are awake far earlier in the 'day' than others


1 per calendar day in UTC rule




  • I get nice uniform 24h long days

  • I can bucket my events

  • I know when the start and end of a day is

  • Daylight savings are going to confuse people.

  • Humans can have 1 event per day

  • Humans not living near Greenwich will have funny start and end times

  • Maybe I can do a clever optimisation and just store a list of users who have entered? (probably I will end up storing every users event and time)


*Bucketing the events is going to be super useful for various reporting purposes. eg. say I have 10 prizes to be won each 24h period and they differ over time. How many students entered on day 10? etc






share|improve this answer























  • You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
    – RUL
    Dec 18 at 11:57










  • hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
    – Ewan
    Dec 18 at 12:42










  • I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
    – RUL
    Dec 18 at 12:48








  • 4




    I think it's less complex to explain
    – Ewan
    Dec 18 at 13:20






  • 10




    This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
    – cmaster
    Dec 18 at 17:18



















14














Off the top of my head:




  • It may be easier to implement the "24-hours since last action" version

  • If the user does not perform the action exactly 24 hours after the last time, then eventually they may miss a whole 24-hour period because the reset must happen when they are asleep, or working. Perhaps they do it at 7 am before leaving for work, and leave for work at 8 pm. The next day they do it at at 7:15, then 7:30, then 7:45, and on the last day stay until until 8:00 to perform the action just before leaving. The next day they are not willing to stay until until 8:15, so just miss that morning and do it after returning home from work at 6 pm, a gap of 34 hours. If the result of the action is expensive for the company the saving might be more important than the inconvenience.






share|improve this answer

















  • 3




    Good point on the sneaky marketing reason, to get the users to miss one day.
    – RUL
    Dec 18 at 11:59






  • 1




    @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
    – TripeHound
    Dec 18 at 14:37










  • I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
    – Cort Ammon
    Dec 18 at 16:02






  • 2




    Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
    – Adonalsium
    Dec 18 at 18:29






  • 7




    It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
    – Delioth
    Dec 18 at 19:35



















8














As other answers have mentioned, the 24hr method is more friendly to multiple time zones, and is just as easy to code, as you just store the last successful timestamp for each user.



It also has the added "benefit" of actually requiring the user to interact with the app each day to get all of daily actions. If there is say a midnight reset, then a user may do an action at 11:59PM, and then again at 12:00AM. They could do this every other day and still get all the actions. For some apps the purpose of daily actions is to get the user to interact with the app on a daily basis so this is less ideal.



There's a third alternative that avoids the UI pitfalls of both, but is a bit harder to code.



3) No streaks of more than n actions in (n-0.75)*24 hours



It does require two variables to store, but it allows someone who's not trying to abuse the system to use their one action at anytime during their day without having to worry about timezones and resets.



It also prevents anyone from using more than 1 "extra" action.



So actually implement the algorithm you'd need to store the start time of the streak, the last play time, and the number of actions in your streak.



Keeping track of the last action time allows you to reject two actions that are too close together. You can make this limit less than 24 hours though because the streak prevents creeping earlier in the day.



A streak keeps going as long as you take your action every day. If taking an action would mean you'd have more actions than days in your streak then it gets rejected. This prevents slowly creeping forward, packing in "extra" actions because the start time of your streak doesn't change.



some pseudo code to implement the check and track the times:



//precondition: streakStart and  lastAction are initialized as in the far past
// streakCount is initialized as 0
graceHours=18;
checkAllowed(currentTime,&streakStart,&streakCount, &lastAction){
diffhours=hoursDifferent(lastAction,currentTime);
if(diffhours< 24 - graceHours){
return false;
}
diffhours=hoursDifferent(streakStart,currentTime);
if(diffhours <= 24*streakCount - graceHours){
return false;
}
if(diffhours > 24*(streakCount+2)-graceHours){
streakStart=currentTime;
streakCount=0;
}
streakCount++;
lastActionTime=currentTime;
return true;
}


As an added bonus, you get a streak counter, if you want one.






share|improve this answer























  • I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
    – rtpax
    Dec 18 at 21:45










  • Interesting approach, alltough, could you elaborate more in words, how this one works?
    – RUL
    Dec 19 at 8:24










  • @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
    – Jacob Raihle
    Dec 19 at 16:43



















5














About your problem with the 24h duration between actions, some companies instead use a 22h duration, this way the users get a bit of leeway on the exact moment of the day where the action is required and still get to encourage users to actually perform the action once per day -no 23:59 - 00:00 loophole.



Not an answer but I don't have enough points to comment.






share|improve this answer





















  • I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
    – vlaz
    Dec 19 at 8:57










  • Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
    – vlaz
    Dec 19 at 8:58












  • This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
    – Rick
    Dec 19 at 13:06



















3














tl/dr: 24 hour resets are the lazy man's way of minimizing load spikes


In addition to the above answers, the midnight-reset encourages surges of traffic.
If the action becomes available to all participators at a particular time, then there is going to be an incentive for many people to attempt the action at the same time. This is the same reason why most states have your drivers license expire on your birthday instead of on a fixed date (USA): the DMV wouldn't be able to keep up if everyone had their driver's license expire on January 1st.



Small Aside: if a computer system needs to take action once a day for a large number of users, you can ask the same question, and I typically design it to be a combination of both. You could imagine two cron tasks:




  1. Run at midnight, find all records, take action

  2. Run every every minute (or some regular frequency), find all records that haven't taken action since 00:00 yesterday, take action, record that action was taken


In practice I have found the former to be brittle. If a cron task breaks while running then some number may not have the action applied, and additional work may be needed for the system to remember where it was and pick up where it left off. It can also cause problems if you get enough records that your cron task can't process them all in a reasonable time limit, and it gets shut down before finishing.



The latter takes care of both of those concerns. It doesn't aim to get everything processed exactly 24 hours apart, but as long as your cron task can easily run through all actions each day, they will be pretty close and you'll guarantee that everyone gets run on each actual day (i.e. you won't have things slowly drifting apart by more than 24 hours). Most importantly though, it will easily pick up where it left off if things break down for some reason.



https://www.youtube.com/watch?v=hoMO1yYC7pQ






share|improve this answer





























    0














    Daily bus/train tickets at TfL (Transport for London) are valid from 4:30am to 4:30am. Do the switch when people are asleep. Plenty of people will want to use a service say from 8:30 to an hour past midnight






    share|improve this answer

















    • 4




      This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
      – Corey
      Dec 19 at 2:34










    • @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
      – vlaz
      Dec 19 at 8:51



















    0














    The midnight reset has a specific condition that could be either desirable or detrimental, depending on what problem you are trying to solve and that is: I can perform the action one day at 11:59:58 and again at 00:00:01. If the problem space is any kind of competition, this could impart an unfair advantage to people choosing to perform their actions close to midnight. The 24-hour reset rule is the only way to ensure a fair distribution of available actions regardless of what time of day someone has available to them.



    The consequence of the 24-hour reset becoming later and later can be mitigated by providing for a tolerance, for example accepting an action request within 15 minutes of the reset occurring so long as the action isn't actually recorded (or doesn't take effect) until the reset occurs. This introduces a bit more complexity into the solution, but I can't think of any mitigation strategy for being able to take two daily actions seconds apart as in the midnight reset case.






    share|improve this answer





























      0














      I haven’t seen anyon mention the fact that the 24 hour rule encourages routine regular visits. A lot of games have a once a day login/victory reward that resets after 24 hours because they would rather you check in for a short time every 24 hours rather than for twice as long every 48 hours. I’d imagine it’s similar for websites hosting ticket giveaways.






      share|improve this answer

















      • 1




        Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
        – RUL
        Dec 19 at 8:31










      • @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
        – Rick
        Dec 19 at 13:02










      protected by gnat Dec 19 at 10:31



      Thank you for your interest in this question.
      Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).



      Would you like to answer one of these unanswered questions instead?














      8 Answers
      8






      active

      oldest

      votes








      8 Answers
      8






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      21














      I'm am surprised as usually I would expect the midnight reset.



      However, It does come with a major disadvantage, in that there is more than one midnight every 24h. You need to choose your timezone.



      Maybe this is why the universal once per 24h is chosen, you can imagine the company might not want to accept that users half in different countries might have non midnight local end times, or rather than they might consider that saying "per day" implied midnight and thus they change the marketing to "per 24h" and the software spec to match



      Although I think this is fairly common to see "ends at 2pm GMT" or similar these days.



      I would have thought the challenge of storing a last action date for every user would be harder than that of assigning a timezone to users or action types.



      Edit I think its worth noting the differences between the two methods



      24h rule




      • I will get a constant stream of events, rate limited to less than 1 per 24h.

      • When I end the thing, some users will get less events.

      • I need to store every users last event

      • When daylight savings causes a long or short day I wont have 1 event per day

      • Humans wont be able to hit exactly 24h on the dot, so I will naturally get less than 1 per day on average


      1 per calendar day rule




      • I get bucketed events over a 50h(? UTC+14 to -12 ?) period assigned to a calendar day

      • realistically I still have to store every users last event as 'days' over lap

      • I do have a definite end of a day where I can say all the events after now are not in the day.

      • I need to know the location of the user to know which day their event applies to

      • Some people are awake far earlier in the 'day' than others


      1 per calendar day in UTC rule




      • I get nice uniform 24h long days

      • I can bucket my events

      • I know when the start and end of a day is

      • Daylight savings are going to confuse people.

      • Humans can have 1 event per day

      • Humans not living near Greenwich will have funny start and end times

      • Maybe I can do a clever optimisation and just store a list of users who have entered? (probably I will end up storing every users event and time)


      *Bucketing the events is going to be super useful for various reporting purposes. eg. say I have 10 prizes to be won each 24h period and they differ over time. How many students entered on day 10? etc






      share|improve this answer























      • You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
        – RUL
        Dec 18 at 11:57










      • hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
        – Ewan
        Dec 18 at 12:42










      • I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
        – RUL
        Dec 18 at 12:48








      • 4




        I think it's less complex to explain
        – Ewan
        Dec 18 at 13:20






      • 10




        This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
        – cmaster
        Dec 18 at 17:18
















      21














      I'm am surprised as usually I would expect the midnight reset.



      However, It does come with a major disadvantage, in that there is more than one midnight every 24h. You need to choose your timezone.



      Maybe this is why the universal once per 24h is chosen, you can imagine the company might not want to accept that users half in different countries might have non midnight local end times, or rather than they might consider that saying "per day" implied midnight and thus they change the marketing to "per 24h" and the software spec to match



      Although I think this is fairly common to see "ends at 2pm GMT" or similar these days.



      I would have thought the challenge of storing a last action date for every user would be harder than that of assigning a timezone to users or action types.



      Edit I think its worth noting the differences between the two methods



      24h rule




      • I will get a constant stream of events, rate limited to less than 1 per 24h.

      • When I end the thing, some users will get less events.

      • I need to store every users last event

      • When daylight savings causes a long or short day I wont have 1 event per day

      • Humans wont be able to hit exactly 24h on the dot, so I will naturally get less than 1 per day on average


      1 per calendar day rule




      • I get bucketed events over a 50h(? UTC+14 to -12 ?) period assigned to a calendar day

      • realistically I still have to store every users last event as 'days' over lap

      • I do have a definite end of a day where I can say all the events after now are not in the day.

      • I need to know the location of the user to know which day their event applies to

      • Some people are awake far earlier in the 'day' than others


      1 per calendar day in UTC rule




      • I get nice uniform 24h long days

      • I can bucket my events

      • I know when the start and end of a day is

      • Daylight savings are going to confuse people.

      • Humans can have 1 event per day

      • Humans not living near Greenwich will have funny start and end times

      • Maybe I can do a clever optimisation and just store a list of users who have entered? (probably I will end up storing every users event and time)


      *Bucketing the events is going to be super useful for various reporting purposes. eg. say I have 10 prizes to be won each 24h period and they differ over time. How many students entered on day 10? etc






      share|improve this answer























      • You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
        – RUL
        Dec 18 at 11:57










      • hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
        – Ewan
        Dec 18 at 12:42










      • I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
        – RUL
        Dec 18 at 12:48








      • 4




        I think it's less complex to explain
        – Ewan
        Dec 18 at 13:20






      • 10




        This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
        – cmaster
        Dec 18 at 17:18














      21












      21








      21






      I'm am surprised as usually I would expect the midnight reset.



      However, It does come with a major disadvantage, in that there is more than one midnight every 24h. You need to choose your timezone.



      Maybe this is why the universal once per 24h is chosen, you can imagine the company might not want to accept that users half in different countries might have non midnight local end times, or rather than they might consider that saying "per day" implied midnight and thus they change the marketing to "per 24h" and the software spec to match



      Although I think this is fairly common to see "ends at 2pm GMT" or similar these days.



      I would have thought the challenge of storing a last action date for every user would be harder than that of assigning a timezone to users or action types.



      Edit I think its worth noting the differences between the two methods



      24h rule




      • I will get a constant stream of events, rate limited to less than 1 per 24h.

      • When I end the thing, some users will get less events.

      • I need to store every users last event

      • When daylight savings causes a long or short day I wont have 1 event per day

      • Humans wont be able to hit exactly 24h on the dot, so I will naturally get less than 1 per day on average


      1 per calendar day rule




      • I get bucketed events over a 50h(? UTC+14 to -12 ?) period assigned to a calendar day

      • realistically I still have to store every users last event as 'days' over lap

      • I do have a definite end of a day where I can say all the events after now are not in the day.

      • I need to know the location of the user to know which day their event applies to

      • Some people are awake far earlier in the 'day' than others


      1 per calendar day in UTC rule




      • I get nice uniform 24h long days

      • I can bucket my events

      • I know when the start and end of a day is

      • Daylight savings are going to confuse people.

      • Humans can have 1 event per day

      • Humans not living near Greenwich will have funny start and end times

      • Maybe I can do a clever optimisation and just store a list of users who have entered? (probably I will end up storing every users event and time)


      *Bucketing the events is going to be super useful for various reporting purposes. eg. say I have 10 prizes to be won each 24h period and they differ over time. How many students entered on day 10? etc






      share|improve this answer














      I'm am surprised as usually I would expect the midnight reset.



      However, It does come with a major disadvantage, in that there is more than one midnight every 24h. You need to choose your timezone.



      Maybe this is why the universal once per 24h is chosen, you can imagine the company might not want to accept that users half in different countries might have non midnight local end times, or rather than they might consider that saying "per day" implied midnight and thus they change the marketing to "per 24h" and the software spec to match



      Although I think this is fairly common to see "ends at 2pm GMT" or similar these days.



      I would have thought the challenge of storing a last action date for every user would be harder than that of assigning a timezone to users or action types.



      Edit I think its worth noting the differences between the two methods



      24h rule




      • I will get a constant stream of events, rate limited to less than 1 per 24h.

      • When I end the thing, some users will get less events.

      • I need to store every users last event

      • When daylight savings causes a long or short day I wont have 1 event per day

      • Humans wont be able to hit exactly 24h on the dot, so I will naturally get less than 1 per day on average


      1 per calendar day rule




      • I get bucketed events over a 50h(? UTC+14 to -12 ?) period assigned to a calendar day

      • realistically I still have to store every users last event as 'days' over lap

      • I do have a definite end of a day where I can say all the events after now are not in the day.

      • I need to know the location of the user to know which day their event applies to

      • Some people are awake far earlier in the 'day' than others


      1 per calendar day in UTC rule




      • I get nice uniform 24h long days

      • I can bucket my events

      • I know when the start and end of a day is

      • Daylight savings are going to confuse people.

      • Humans can have 1 event per day

      • Humans not living near Greenwich will have funny start and end times

      • Maybe I can do a clever optimisation and just store a list of users who have entered? (probably I will end up storing every users event and time)


      *Bucketing the events is going to be super useful for various reporting purposes. eg. say I have 10 prizes to be won each 24h period and they differ over time. How many students entered on day 10? etc







      share|improve this answer














      share|improve this answer



      share|improve this answer








      edited Dec 18 at 22:50

























      answered Dec 18 at 11:39









      Ewan

      38.3k32984




      38.3k32984












      • You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
        – RUL
        Dec 18 at 11:57










      • hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
        – Ewan
        Dec 18 at 12:42










      • I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
        – RUL
        Dec 18 at 12:48








      • 4




        I think it's less complex to explain
        – Ewan
        Dec 18 at 13:20






      • 10




        This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
        – cmaster
        Dec 18 at 17:18


















      • You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
        – RUL
        Dec 18 at 11:57










      • hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
        – Ewan
        Dec 18 at 12:42










      • I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
        – RUL
        Dec 18 at 12:48








      • 4




        I think it's less complex to explain
        – Ewan
        Dec 18 at 13:20






      • 10




        This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
        – cmaster
        Dec 18 at 17:18
















      You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
      – RUL
      Dec 18 at 11:57




      You clearly touch my train of thoughts as I'm equally surprized. I think it would be fairly lazy to go for the 24 hour reset, but as @Richard Ward's answer states, it might be more difficult to respect all the time zones and might even spark communication problems as of when the event starts and ends.
      – RUL
      Dec 18 at 11:57












      hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
      – Ewan
      Dec 18 at 12:42




      hmm i think you got your answers confused. But on reflection I'm thinking that its most likely a business/developer communication issue. I can just imagine the planning meeting... Sales: "So users must only be allowed to take the offer once per day.." Dev: "what if they are flying and cross the international date line? can they place two orders?" Sales: ".....no... lets say 1 per 24h" Dev: "OK, hmm gona need more tables to store all that data!" Sales: "whateves"
      – Ewan
      Dec 18 at 12:42












      I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
      – RUL
      Dec 18 at 12:48






      I see, you think the 24 hour approach is less complex? Because I don't think so apart from having an additional table it's far more simple to just say 24 hours than checking and calculating in different time zones. But you got a good point there: with leaving the timezone you could actually get more than one spin.
      – RUL
      Dec 18 at 12:48






      4




      4




      I think it's less complex to explain
      – Ewan
      Dec 18 at 13:20




      I think it's less complex to explain
      – Ewan
      Dec 18 at 13:20




      10




      10




      This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
      – cmaster
      Dec 18 at 17:18




      This. Timezone dependent stuff opens a whole can of worms that you can just leave closed by using the 24h timeout rule. And it's not exactly harder to store when an action happened than to store that it happened on a specific day.
      – cmaster
      Dec 18 at 17:18













      14














      Off the top of my head:




      • It may be easier to implement the "24-hours since last action" version

      • If the user does not perform the action exactly 24 hours after the last time, then eventually they may miss a whole 24-hour period because the reset must happen when they are asleep, or working. Perhaps they do it at 7 am before leaving for work, and leave for work at 8 pm. The next day they do it at at 7:15, then 7:30, then 7:45, and on the last day stay until until 8:00 to perform the action just before leaving. The next day they are not willing to stay until until 8:15, so just miss that morning and do it after returning home from work at 6 pm, a gap of 34 hours. If the result of the action is expensive for the company the saving might be more important than the inconvenience.






      share|improve this answer

















      • 3




        Good point on the sneaky marketing reason, to get the users to miss one day.
        – RUL
        Dec 18 at 11:59






      • 1




        @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
        – TripeHound
        Dec 18 at 14:37










      • I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
        – Cort Ammon
        Dec 18 at 16:02






      • 2




        Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
        – Adonalsium
        Dec 18 at 18:29






      • 7




        It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
        – Delioth
        Dec 18 at 19:35
















      14














      Off the top of my head:




      • It may be easier to implement the "24-hours since last action" version

      • If the user does not perform the action exactly 24 hours after the last time, then eventually they may miss a whole 24-hour period because the reset must happen when they are asleep, or working. Perhaps they do it at 7 am before leaving for work, and leave for work at 8 pm. The next day they do it at at 7:15, then 7:30, then 7:45, and on the last day stay until until 8:00 to perform the action just before leaving. The next day they are not willing to stay until until 8:15, so just miss that morning and do it after returning home from work at 6 pm, a gap of 34 hours. If the result of the action is expensive for the company the saving might be more important than the inconvenience.






      share|improve this answer

















      • 3




        Good point on the sneaky marketing reason, to get the users to miss one day.
        – RUL
        Dec 18 at 11:59






      • 1




        @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
        – TripeHound
        Dec 18 at 14:37










      • I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
        – Cort Ammon
        Dec 18 at 16:02






      • 2




        Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
        – Adonalsium
        Dec 18 at 18:29






      • 7




        It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
        – Delioth
        Dec 18 at 19:35














      14












      14








      14






      Off the top of my head:




      • It may be easier to implement the "24-hours since last action" version

      • If the user does not perform the action exactly 24 hours after the last time, then eventually they may miss a whole 24-hour period because the reset must happen when they are asleep, or working. Perhaps they do it at 7 am before leaving for work, and leave for work at 8 pm. The next day they do it at at 7:15, then 7:30, then 7:45, and on the last day stay until until 8:00 to perform the action just before leaving. The next day they are not willing to stay until until 8:15, so just miss that morning and do it after returning home from work at 6 pm, a gap of 34 hours. If the result of the action is expensive for the company the saving might be more important than the inconvenience.






      share|improve this answer












      Off the top of my head:




      • It may be easier to implement the "24-hours since last action" version

      • If the user does not perform the action exactly 24 hours after the last time, then eventually they may miss a whole 24-hour period because the reset must happen when they are asleep, or working. Perhaps they do it at 7 am before leaving for work, and leave for work at 8 pm. The next day they do it at at 7:15, then 7:30, then 7:45, and on the last day stay until until 8:00 to perform the action just before leaving. The next day they are not willing to stay until until 8:15, so just miss that morning and do it after returning home from work at 6 pm, a gap of 34 hours. If the result of the action is expensive for the company the saving might be more important than the inconvenience.







      share|improve this answer












      share|improve this answer



      share|improve this answer










      answered Dec 18 at 10:32









      Richard Ward

      24915




      24915








      • 3




        Good point on the sneaky marketing reason, to get the users to miss one day.
        – RUL
        Dec 18 at 11:59






      • 1




        @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
        – TripeHound
        Dec 18 at 14:37










      • I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
        – Cort Ammon
        Dec 18 at 16:02






      • 2




        Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
        – Adonalsium
        Dec 18 at 18:29






      • 7




        It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
        – Delioth
        Dec 18 at 19:35














      • 3




        Good point on the sneaky marketing reason, to get the users to miss one day.
        – RUL
        Dec 18 at 11:59






      • 1




        @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
        – TripeHound
        Dec 18 at 14:37










      • I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
        – Cort Ammon
        Dec 18 at 16:02






      • 2




        Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
        – Adonalsium
        Dec 18 at 18:29






      • 7




        It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
        – Delioth
        Dec 18 at 19:35








      3




      3




      Good point on the sneaky marketing reason, to get the users to miss one day.
      – RUL
      Dec 18 at 11:59




      Good point on the sneaky marketing reason, to get the users to miss one day.
      – RUL
      Dec 18 at 11:59




      1




      1




      @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
      – TripeHound
      Dec 18 at 14:37




      @RUL Or, probably more to the point, a user is more likely to buy a "paid extra spin" (or whatever) if they miss out on a free one. The cost of giving spins away might be trivial, but the occasional extra sales may be worth it.
      – TripeHound
      Dec 18 at 14:37












      I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
      – Cort Ammon
      Dec 18 at 16:02




      I played a game based on Zulu time when I was in the USA. It was not trivial to keep straight when I could or could not do an activitiy.
      – Cort Ammon
      Dec 18 at 16:02




      2




      2




      Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
      – Adonalsium
      Dec 18 at 18:29




      Point 2 is why Blizzard (etc) avoid the 24 hour reset timer in WoW and other MMORPGs and instead do a daily reset.
      – Adonalsium
      Dec 18 at 18:29




      7




      7




      It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
      – Delioth
      Dec 18 at 19:35




      It might be worth noting that some companies just use a less strict "daily" - League of Legends uses a 21-hour lockout for the "first win of the day". Sufficient to keep the bonuses roughly daily, while being convenient for players. Might be partially because of the idea that you won't always win your first game and games take ~30-50 minutes, so a strict clock would be really annoying (since you're likely to push back the time by 30 minutes or so a day, at which point it's not enticing because you only have playtime to get the first win every 3 days on a busy schedule).
      – Delioth
      Dec 18 at 19:35











      8














      As other answers have mentioned, the 24hr method is more friendly to multiple time zones, and is just as easy to code, as you just store the last successful timestamp for each user.



      It also has the added "benefit" of actually requiring the user to interact with the app each day to get all of daily actions. If there is say a midnight reset, then a user may do an action at 11:59PM, and then again at 12:00AM. They could do this every other day and still get all the actions. For some apps the purpose of daily actions is to get the user to interact with the app on a daily basis so this is less ideal.



      There's a third alternative that avoids the UI pitfalls of both, but is a bit harder to code.



      3) No streaks of more than n actions in (n-0.75)*24 hours



      It does require two variables to store, but it allows someone who's not trying to abuse the system to use their one action at anytime during their day without having to worry about timezones and resets.



      It also prevents anyone from using more than 1 "extra" action.



      So actually implement the algorithm you'd need to store the start time of the streak, the last play time, and the number of actions in your streak.



      Keeping track of the last action time allows you to reject two actions that are too close together. You can make this limit less than 24 hours though because the streak prevents creeping earlier in the day.



      A streak keeps going as long as you take your action every day. If taking an action would mean you'd have more actions than days in your streak then it gets rejected. This prevents slowly creeping forward, packing in "extra" actions because the start time of your streak doesn't change.



      some pseudo code to implement the check and track the times:



      //precondition: streakStart and  lastAction are initialized as in the far past
      // streakCount is initialized as 0
      graceHours=18;
      checkAllowed(currentTime,&streakStart,&streakCount, &lastAction){
      diffhours=hoursDifferent(lastAction,currentTime);
      if(diffhours< 24 - graceHours){
      return false;
      }
      diffhours=hoursDifferent(streakStart,currentTime);
      if(diffhours <= 24*streakCount - graceHours){
      return false;
      }
      if(diffhours > 24*(streakCount+2)-graceHours){
      streakStart=currentTime;
      streakCount=0;
      }
      streakCount++;
      lastActionTime=currentTime;
      return true;
      }


      As an added bonus, you get a streak counter, if you want one.






      share|improve this answer























      • I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
        – rtpax
        Dec 18 at 21:45










      • Interesting approach, alltough, could you elaborate more in words, how this one works?
        – RUL
        Dec 19 at 8:24










      • @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
        – Jacob Raihle
        Dec 19 at 16:43
















      8














      As other answers have mentioned, the 24hr method is more friendly to multiple time zones, and is just as easy to code, as you just store the last successful timestamp for each user.



      It also has the added "benefit" of actually requiring the user to interact with the app each day to get all of daily actions. If there is say a midnight reset, then a user may do an action at 11:59PM, and then again at 12:00AM. They could do this every other day and still get all the actions. For some apps the purpose of daily actions is to get the user to interact with the app on a daily basis so this is less ideal.



      There's a third alternative that avoids the UI pitfalls of both, but is a bit harder to code.



      3) No streaks of more than n actions in (n-0.75)*24 hours



      It does require two variables to store, but it allows someone who's not trying to abuse the system to use their one action at anytime during their day without having to worry about timezones and resets.



      It also prevents anyone from using more than 1 "extra" action.



      So actually implement the algorithm you'd need to store the start time of the streak, the last play time, and the number of actions in your streak.



      Keeping track of the last action time allows you to reject two actions that are too close together. You can make this limit less than 24 hours though because the streak prevents creeping earlier in the day.



      A streak keeps going as long as you take your action every day. If taking an action would mean you'd have more actions than days in your streak then it gets rejected. This prevents slowly creeping forward, packing in "extra" actions because the start time of your streak doesn't change.



      some pseudo code to implement the check and track the times:



      //precondition: streakStart and  lastAction are initialized as in the far past
      // streakCount is initialized as 0
      graceHours=18;
      checkAllowed(currentTime,&streakStart,&streakCount, &lastAction){
      diffhours=hoursDifferent(lastAction,currentTime);
      if(diffhours< 24 - graceHours){
      return false;
      }
      diffhours=hoursDifferent(streakStart,currentTime);
      if(diffhours <= 24*streakCount - graceHours){
      return false;
      }
      if(diffhours > 24*(streakCount+2)-graceHours){
      streakStart=currentTime;
      streakCount=0;
      }
      streakCount++;
      lastActionTime=currentTime;
      return true;
      }


      As an added bonus, you get a streak counter, if you want one.






      share|improve this answer























      • I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
        – rtpax
        Dec 18 at 21:45










      • Interesting approach, alltough, could you elaborate more in words, how this one works?
        – RUL
        Dec 19 at 8:24










      • @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
        – Jacob Raihle
        Dec 19 at 16:43














      8












      8








      8






      As other answers have mentioned, the 24hr method is more friendly to multiple time zones, and is just as easy to code, as you just store the last successful timestamp for each user.



      It also has the added "benefit" of actually requiring the user to interact with the app each day to get all of daily actions. If there is say a midnight reset, then a user may do an action at 11:59PM, and then again at 12:00AM. They could do this every other day and still get all the actions. For some apps the purpose of daily actions is to get the user to interact with the app on a daily basis so this is less ideal.



      There's a third alternative that avoids the UI pitfalls of both, but is a bit harder to code.



      3) No streaks of more than n actions in (n-0.75)*24 hours



      It does require two variables to store, but it allows someone who's not trying to abuse the system to use their one action at anytime during their day without having to worry about timezones and resets.



      It also prevents anyone from using more than 1 "extra" action.



      So actually implement the algorithm you'd need to store the start time of the streak, the last play time, and the number of actions in your streak.



      Keeping track of the last action time allows you to reject two actions that are too close together. You can make this limit less than 24 hours though because the streak prevents creeping earlier in the day.



      A streak keeps going as long as you take your action every day. If taking an action would mean you'd have more actions than days in your streak then it gets rejected. This prevents slowly creeping forward, packing in "extra" actions because the start time of your streak doesn't change.



      some pseudo code to implement the check and track the times:



      //precondition: streakStart and  lastAction are initialized as in the far past
      // streakCount is initialized as 0
      graceHours=18;
      checkAllowed(currentTime,&streakStart,&streakCount, &lastAction){
      diffhours=hoursDifferent(lastAction,currentTime);
      if(diffhours< 24 - graceHours){
      return false;
      }
      diffhours=hoursDifferent(streakStart,currentTime);
      if(diffhours <= 24*streakCount - graceHours){
      return false;
      }
      if(diffhours > 24*(streakCount+2)-graceHours){
      streakStart=currentTime;
      streakCount=0;
      }
      streakCount++;
      lastActionTime=currentTime;
      return true;
      }


      As an added bonus, you get a streak counter, if you want one.






      share|improve this answer














      As other answers have mentioned, the 24hr method is more friendly to multiple time zones, and is just as easy to code, as you just store the last successful timestamp for each user.



      It also has the added "benefit" of actually requiring the user to interact with the app each day to get all of daily actions. If there is say a midnight reset, then a user may do an action at 11:59PM, and then again at 12:00AM. They could do this every other day and still get all the actions. For some apps the purpose of daily actions is to get the user to interact with the app on a daily basis so this is less ideal.



      There's a third alternative that avoids the UI pitfalls of both, but is a bit harder to code.



      3) No streaks of more than n actions in (n-0.75)*24 hours



      It does require two variables to store, but it allows someone who's not trying to abuse the system to use their one action at anytime during their day without having to worry about timezones and resets.



      It also prevents anyone from using more than 1 "extra" action.



      So actually implement the algorithm you'd need to store the start time of the streak, the last play time, and the number of actions in your streak.



      Keeping track of the last action time allows you to reject two actions that are too close together. You can make this limit less than 24 hours though because the streak prevents creeping earlier in the day.



      A streak keeps going as long as you take your action every day. If taking an action would mean you'd have more actions than days in your streak then it gets rejected. This prevents slowly creeping forward, packing in "extra" actions because the start time of your streak doesn't change.



      some pseudo code to implement the check and track the times:



      //precondition: streakStart and  lastAction are initialized as in the far past
      // streakCount is initialized as 0
      graceHours=18;
      checkAllowed(currentTime,&streakStart,&streakCount, &lastAction){
      diffhours=hoursDifferent(lastAction,currentTime);
      if(diffhours< 24 - graceHours){
      return false;
      }
      diffhours=hoursDifferent(streakStart,currentTime);
      if(diffhours <= 24*streakCount - graceHours){
      return false;
      }
      if(diffhours > 24*(streakCount+2)-graceHours){
      streakStart=currentTime;
      streakCount=0;
      }
      streakCount++;
      lastActionTime=currentTime;
      return true;
      }


      As an added bonus, you get a streak counter, if you want one.







      share|improve this answer














      share|improve this answer



      share|improve this answer








      edited Dec 19 at 12:59

























      answered Dec 18 at 21:09









      Rick

      1894




      1894












      • I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
        – rtpax
        Dec 18 at 21:45










      • Interesting approach, alltough, could you elaborate more in words, how this one works?
        – RUL
        Dec 19 at 8:24










      • @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
        – Jacob Raihle
        Dec 19 at 16:43


















      • I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
        – rtpax
        Dec 18 at 21:45










      • Interesting approach, alltough, could you elaborate more in words, how this one works?
        – RUL
        Dec 19 at 8:24










      • @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
        – Jacob Raihle
        Dec 19 at 16:43
















      I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
      – rtpax
      Dec 18 at 21:45




      I think this is probably the best answer since it "just works" for the user. The only downside is that it might be hard to understand, but that should only ever affect people trying to game the system. The 18 graceHours could be explained in the text, since I think it is important to making this work (I think it should be lower though)
      – rtpax
      Dec 18 at 21:45












      Interesting approach, alltough, could you elaborate more in words, how this one works?
      – RUL
      Dec 19 at 8:24




      Interesting approach, alltough, could you elaborate more in words, how this one works?
      – RUL
      Dec 19 at 8:24












      @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
      – Jacob Raihle
      Dec 19 at 16:43




      @RUL The fundamental idea is that the reset time for a user is locked in once they take their first action. It's not locked in at the exact time they take their action, but a bit before then (18 hours before, in this case) to provide a better user experience. This lets a user get slightly ahead (they can perform their first two actions in just 6 hours), but there is no cumulative error since the start is still locked in - if they have maxed out the grace period, they will have to wait at least 24 hours for the next action.
      – Jacob Raihle
      Dec 19 at 16:43











      5














      About your problem with the 24h duration between actions, some companies instead use a 22h duration, this way the users get a bit of leeway on the exact moment of the day where the action is required and still get to encourage users to actually perform the action once per day -no 23:59 - 00:00 loophole.



      Not an answer but I don't have enough points to comment.






      share|improve this answer





















      • I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
        – vlaz
        Dec 19 at 8:57










      • Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
        – vlaz
        Dec 19 at 8:58












      • This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
        – Rick
        Dec 19 at 13:06
















      5














      About your problem with the 24h duration between actions, some companies instead use a 22h duration, this way the users get a bit of leeway on the exact moment of the day where the action is required and still get to encourage users to actually perform the action once per day -no 23:59 - 00:00 loophole.



      Not an answer but I don't have enough points to comment.






      share|improve this answer





















      • I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
        – vlaz
        Dec 19 at 8:57










      • Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
        – vlaz
        Dec 19 at 8:58












      • This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
        – Rick
        Dec 19 at 13:06














      5












      5








      5






      About your problem with the 24h duration between actions, some companies instead use a 22h duration, this way the users get a bit of leeway on the exact moment of the day where the action is required and still get to encourage users to actually perform the action once per day -no 23:59 - 00:00 loophole.



      Not an answer but I don't have enough points to comment.






      share|improve this answer












      About your problem with the 24h duration between actions, some companies instead use a 22h duration, this way the users get a bit of leeway on the exact moment of the day where the action is required and still get to encourage users to actually perform the action once per day -no 23:59 - 00:00 loophole.



      Not an answer but I don't have enough points to comment.







      share|improve this answer












      share|improve this answer



      share|improve this answer










      answered Dec 18 at 20:24









      TheNaturalTanuki

      591




      591












      • I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
        – vlaz
        Dec 19 at 8:57










      • Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
        – vlaz
        Dec 19 at 8:58












      • This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
        – Rick
        Dec 19 at 13:06


















      • I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
        – vlaz
        Dec 19 at 8:57










      • Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
        – vlaz
        Dec 19 at 8:58












      • This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
        – Rick
        Dec 19 at 13:06
















      I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
      – vlaz
      Dec 19 at 8:57




      I think this website does this with expendable things like votes. They don't reset every 24 hours but every 16 or so (not sure on the exact number). I guess it makes sense - let's say you start your day at 8 AM and start voting up/down - you run out of votes in 6 hours at 2PM. With a strict 24-hours-from-action reset, if you pick the reset time on the last vote, you'd need to wait until 2PM again to start voting instead of your usual time and you might not have time then. If you pick the first vote, then you have a problem if one day you start voting at 10 AM but 8AM the next one.
      – vlaz
      Dec 19 at 8:57












      Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
      – vlaz
      Dec 19 at 8:58






      Although now that I think about it - I'm not sure if it's really 16 hours reset time keyed off the actions. It might be 24 hours and I happen to have caught it 8 hours after the daily reset. But I guess the logic holds - if you have a 24 individual timers, then it might not be convenient for a user.
      – vlaz
      Dec 19 at 8:58














      This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
      – Rick
      Dec 19 at 13:06




      This does have the opposite problem of the 34 hour reset, of users being able to pack in extra actions if they always act as soon as they can (of course that would require an awful sleep schedule...)
      – Rick
      Dec 19 at 13:06











      3














      tl/dr: 24 hour resets are the lazy man's way of minimizing load spikes


      In addition to the above answers, the midnight-reset encourages surges of traffic.
      If the action becomes available to all participators at a particular time, then there is going to be an incentive for many people to attempt the action at the same time. This is the same reason why most states have your drivers license expire on your birthday instead of on a fixed date (USA): the DMV wouldn't be able to keep up if everyone had their driver's license expire on January 1st.



      Small Aside: if a computer system needs to take action once a day for a large number of users, you can ask the same question, and I typically design it to be a combination of both. You could imagine two cron tasks:




      1. Run at midnight, find all records, take action

      2. Run every every minute (or some regular frequency), find all records that haven't taken action since 00:00 yesterday, take action, record that action was taken


      In practice I have found the former to be brittle. If a cron task breaks while running then some number may not have the action applied, and additional work may be needed for the system to remember where it was and pick up where it left off. It can also cause problems if you get enough records that your cron task can't process them all in a reasonable time limit, and it gets shut down before finishing.



      The latter takes care of both of those concerns. It doesn't aim to get everything processed exactly 24 hours apart, but as long as your cron task can easily run through all actions each day, they will be pretty close and you'll guarantee that everyone gets run on each actual day (i.e. you won't have things slowly drifting apart by more than 24 hours). Most importantly though, it will easily pick up where it left off if things break down for some reason.



      https://www.youtube.com/watch?v=hoMO1yYC7pQ






      share|improve this answer


























        3














        tl/dr: 24 hour resets are the lazy man's way of minimizing load spikes


        In addition to the above answers, the midnight-reset encourages surges of traffic.
        If the action becomes available to all participators at a particular time, then there is going to be an incentive for many people to attempt the action at the same time. This is the same reason why most states have your drivers license expire on your birthday instead of on a fixed date (USA): the DMV wouldn't be able to keep up if everyone had their driver's license expire on January 1st.



        Small Aside: if a computer system needs to take action once a day for a large number of users, you can ask the same question, and I typically design it to be a combination of both. You could imagine two cron tasks:




        1. Run at midnight, find all records, take action

        2. Run every every minute (or some regular frequency), find all records that haven't taken action since 00:00 yesterday, take action, record that action was taken


        In practice I have found the former to be brittle. If a cron task breaks while running then some number may not have the action applied, and additional work may be needed for the system to remember where it was and pick up where it left off. It can also cause problems if you get enough records that your cron task can't process them all in a reasonable time limit, and it gets shut down before finishing.



        The latter takes care of both of those concerns. It doesn't aim to get everything processed exactly 24 hours apart, but as long as your cron task can easily run through all actions each day, they will be pretty close and you'll guarantee that everyone gets run on each actual day (i.e. you won't have things slowly drifting apart by more than 24 hours). Most importantly though, it will easily pick up where it left off if things break down for some reason.



        https://www.youtube.com/watch?v=hoMO1yYC7pQ






        share|improve this answer
























          3












          3








          3






          tl/dr: 24 hour resets are the lazy man's way of minimizing load spikes


          In addition to the above answers, the midnight-reset encourages surges of traffic.
          If the action becomes available to all participators at a particular time, then there is going to be an incentive for many people to attempt the action at the same time. This is the same reason why most states have your drivers license expire on your birthday instead of on a fixed date (USA): the DMV wouldn't be able to keep up if everyone had their driver's license expire on January 1st.



          Small Aside: if a computer system needs to take action once a day for a large number of users, you can ask the same question, and I typically design it to be a combination of both. You could imagine two cron tasks:




          1. Run at midnight, find all records, take action

          2. Run every every minute (or some regular frequency), find all records that haven't taken action since 00:00 yesterday, take action, record that action was taken


          In practice I have found the former to be brittle. If a cron task breaks while running then some number may not have the action applied, and additional work may be needed for the system to remember where it was and pick up where it left off. It can also cause problems if you get enough records that your cron task can't process them all in a reasonable time limit, and it gets shut down before finishing.



          The latter takes care of both of those concerns. It doesn't aim to get everything processed exactly 24 hours apart, but as long as your cron task can easily run through all actions each day, they will be pretty close and you'll guarantee that everyone gets run on each actual day (i.e. you won't have things slowly drifting apart by more than 24 hours). Most importantly though, it will easily pick up where it left off if things break down for some reason.



          https://www.youtube.com/watch?v=hoMO1yYC7pQ






          share|improve this answer












          tl/dr: 24 hour resets are the lazy man's way of minimizing load spikes


          In addition to the above answers, the midnight-reset encourages surges of traffic.
          If the action becomes available to all participators at a particular time, then there is going to be an incentive for many people to attempt the action at the same time. This is the same reason why most states have your drivers license expire on your birthday instead of on a fixed date (USA): the DMV wouldn't be able to keep up if everyone had their driver's license expire on January 1st.



          Small Aside: if a computer system needs to take action once a day for a large number of users, you can ask the same question, and I typically design it to be a combination of both. You could imagine two cron tasks:




          1. Run at midnight, find all records, take action

          2. Run every every minute (or some regular frequency), find all records that haven't taken action since 00:00 yesterday, take action, record that action was taken


          In practice I have found the former to be brittle. If a cron task breaks while running then some number may not have the action applied, and additional work may be needed for the system to remember where it was and pick up where it left off. It can also cause problems if you get enough records that your cron task can't process them all in a reasonable time limit, and it gets shut down before finishing.



          The latter takes care of both of those concerns. It doesn't aim to get everything processed exactly 24 hours apart, but as long as your cron task can easily run through all actions each day, they will be pretty close and you'll guarantee that everyone gets run on each actual day (i.e. you won't have things slowly drifting apart by more than 24 hours). Most importantly though, it will easily pick up where it left off if things break down for some reason.



          https://www.youtube.com/watch?v=hoMO1yYC7pQ







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Dec 18 at 20:28









          Conor Mancone

          321110




          321110























              0














              Daily bus/train tickets at TfL (Transport for London) are valid from 4:30am to 4:30am. Do the switch when people are asleep. Plenty of people will want to use a service say from 8:30 to an hour past midnight






              share|improve this answer

















              • 4




                This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
                – Corey
                Dec 19 at 2:34










              • @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
                – vlaz
                Dec 19 at 8:51
















              0














              Daily bus/train tickets at TfL (Transport for London) are valid from 4:30am to 4:30am. Do the switch when people are asleep. Plenty of people will want to use a service say from 8:30 to an hour past midnight






              share|improve this answer

















              • 4




                This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
                – Corey
                Dec 19 at 2:34










              • @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
                – vlaz
                Dec 19 at 8:51














              0












              0








              0






              Daily bus/train tickets at TfL (Transport for London) are valid from 4:30am to 4:30am. Do the switch when people are asleep. Plenty of people will want to use a service say from 8:30 to an hour past midnight






              share|improve this answer












              Daily bus/train tickets at TfL (Transport for London) are valid from 4:30am to 4:30am. Do the switch when people are asleep. Plenty of people will want to use a service say from 8:30 to an hour past midnight







              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered Dec 18 at 16:01









              gnasher729

              19.9k22559




              19.9k22559








              • 4




                This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
                – Corey
                Dec 19 at 2:34










              • @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
                – vlaz
                Dec 19 at 8:51














              • 4




                This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
                – Corey
                Dec 19 at 2:34










              • @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
                – vlaz
                Dec 19 at 8:51








              4




              4




              This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
              – Corey
              Dec 19 at 2:34




              This is fine for strictly local use, but if you are expecting interactions from the internet then you can't pick a reset time that fits everybody. Even locally people have different sleep times - shift workers, etc. Minor objection, not enough for a -1.
              – Corey
              Dec 19 at 2:34












              @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
              – vlaz
              Dec 19 at 8:51




              @Corey Steam does tie most of their timers to 10 AM Pacific time. More specifically, that's changing over any promotions - Daily (10 AM every day), Midweek (10 AM on Tuesday - 10 AM Friday) or Weekend (10AM Friday - 10AM Monday). As an international store, that is applied accross everybody - that would be 19:00 Central European time or 13:00 in New York. Perhaps it's not convenient to every timezone but it's consistent. And, frankly, even were I using PT, then 10 in the morning would not be very convenient - I'm in Europe, so the evening is better for me.
              – vlaz
              Dec 19 at 8:51











              0














              The midnight reset has a specific condition that could be either desirable or detrimental, depending on what problem you are trying to solve and that is: I can perform the action one day at 11:59:58 and again at 00:00:01. If the problem space is any kind of competition, this could impart an unfair advantage to people choosing to perform their actions close to midnight. The 24-hour reset rule is the only way to ensure a fair distribution of available actions regardless of what time of day someone has available to them.



              The consequence of the 24-hour reset becoming later and later can be mitigated by providing for a tolerance, for example accepting an action request within 15 minutes of the reset occurring so long as the action isn't actually recorded (or doesn't take effect) until the reset occurs. This introduces a bit more complexity into the solution, but I can't think of any mitigation strategy for being able to take two daily actions seconds apart as in the midnight reset case.






              share|improve this answer


























                0














                The midnight reset has a specific condition that could be either desirable or detrimental, depending on what problem you are trying to solve and that is: I can perform the action one day at 11:59:58 and again at 00:00:01. If the problem space is any kind of competition, this could impart an unfair advantage to people choosing to perform their actions close to midnight. The 24-hour reset rule is the only way to ensure a fair distribution of available actions regardless of what time of day someone has available to them.



                The consequence of the 24-hour reset becoming later and later can be mitigated by providing for a tolerance, for example accepting an action request within 15 minutes of the reset occurring so long as the action isn't actually recorded (or doesn't take effect) until the reset occurs. This introduces a bit more complexity into the solution, but I can't think of any mitigation strategy for being able to take two daily actions seconds apart as in the midnight reset case.






                share|improve this answer
























                  0












                  0








                  0






                  The midnight reset has a specific condition that could be either desirable or detrimental, depending on what problem you are trying to solve and that is: I can perform the action one day at 11:59:58 and again at 00:00:01. If the problem space is any kind of competition, this could impart an unfair advantage to people choosing to perform their actions close to midnight. The 24-hour reset rule is the only way to ensure a fair distribution of available actions regardless of what time of day someone has available to them.



                  The consequence of the 24-hour reset becoming later and later can be mitigated by providing for a tolerance, for example accepting an action request within 15 minutes of the reset occurring so long as the action isn't actually recorded (or doesn't take effect) until the reset occurs. This introduces a bit more complexity into the solution, but I can't think of any mitigation strategy for being able to take two daily actions seconds apart as in the midnight reset case.






                  share|improve this answer












                  The midnight reset has a specific condition that could be either desirable or detrimental, depending on what problem you are trying to solve and that is: I can perform the action one day at 11:59:58 and again at 00:00:01. If the problem space is any kind of competition, this could impart an unfair advantage to people choosing to perform their actions close to midnight. The 24-hour reset rule is the only way to ensure a fair distribution of available actions regardless of what time of day someone has available to them.



                  The consequence of the 24-hour reset becoming later and later can be mitigated by providing for a tolerance, for example accepting an action request within 15 minutes of the reset occurring so long as the action isn't actually recorded (or doesn't take effect) until the reset occurs. This introduces a bit more complexity into the solution, but I can't think of any mitigation strategy for being able to take two daily actions seconds apart as in the midnight reset case.







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Dec 18 at 20:27









                  Jeff Lambert

                  32918




                  32918























                      0














                      I haven’t seen anyon mention the fact that the 24 hour rule encourages routine regular visits. A lot of games have a once a day login/victory reward that resets after 24 hours because they would rather you check in for a short time every 24 hours rather than for twice as long every 48 hours. I’d imagine it’s similar for websites hosting ticket giveaways.






                      share|improve this answer

















                      • 1




                        Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
                        – RUL
                        Dec 19 at 8:31










                      • @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
                        – Rick
                        Dec 19 at 13:02
















                      0














                      I haven’t seen anyon mention the fact that the 24 hour rule encourages routine regular visits. A lot of games have a once a day login/victory reward that resets after 24 hours because they would rather you check in for a short time every 24 hours rather than for twice as long every 48 hours. I’d imagine it’s similar for websites hosting ticket giveaways.






                      share|improve this answer

















                      • 1




                        Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
                        – RUL
                        Dec 19 at 8:31










                      • @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
                        – Rick
                        Dec 19 at 13:02














                      0












                      0








                      0






                      I haven’t seen anyon mention the fact that the 24 hour rule encourages routine regular visits. A lot of games have a once a day login/victory reward that resets after 24 hours because they would rather you check in for a short time every 24 hours rather than for twice as long every 48 hours. I’d imagine it’s similar for websites hosting ticket giveaways.






                      share|improve this answer












                      I haven’t seen anyon mention the fact that the 24 hour rule encourages routine regular visits. A lot of games have a once a day login/victory reward that resets after 24 hours because they would rather you check in for a short time every 24 hours rather than for twice as long every 48 hours. I’d imagine it’s similar for websites hosting ticket giveaways.







                      share|improve this answer












                      share|improve this answer



                      share|improve this answer










                      answered Dec 18 at 23:35









                      Carl

                      211




                      211








                      • 1




                        Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
                        – RUL
                        Dec 19 at 8:31










                      • @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
                        – Rick
                        Dec 19 at 13:02














                      • 1




                        Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
                        – RUL
                        Dec 19 at 8:31










                      • @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
                        – Rick
                        Dec 19 at 13:02








                      1




                      1




                      Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
                      – RUL
                      Dec 19 at 8:31




                      Both methods force a 24 hour revisit, except for few people, who wait the 48 hours and perform the action on 23:59:59 and on 00:00:01, but I think it's fairly unrelevant.
                      – RUL
                      Dec 19 at 8:31












                      @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
                      – Rick
                      Dec 19 at 13:02




                      @RUL I use the check in twice in a row method for a lot of games that have reset times in a convenient time zone for me. So I don't think this is as irrelevant as you think. I generally won't log on every 48 hours, but I pretty much always get 2 actions every time I log on.
                      – Rick
                      Dec 19 at 13:02





                      protected by gnat Dec 19 at 10:31



                      Thank you for your interest in this question.
                      Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).



                      Would you like to answer one of these unanswered questions instead?



                      Popular posts from this blog

                      Morgemoulin

                      Scott Moir

                      Souastre