-
Notifications
You must be signed in to change notification settings - Fork 58
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Sending unseen notifications as email periodically. #1058
Conversation
a294bb8
to
354abd0
Compare
Sound like a good idea, but you picked a tough topic :D
As mentioned inline, it will only work for actions with the request type "WEB". For other actions a button could be shown which just opens the web so the user could interact with the action buttons there.
No setting, either we do it or we don't
yeah not sure either. We can not sent unlimited length, so I guess a limit of 50-100 makes sense and then say X-more
good enough
yeah, I also see the confusion happening. The question is if we even want to go as far. I could also imagine having only a single check box for this which is "Remind me with an email about notifications which are older than 7 days" and then only send the mail in that case. In the future a second setting is planned (whether or not to play a sound), and for that I would have liked the setting to be inside the popover somehow.
I don't think we need a admin default setting option for this one. |
I realize that, haha. I picked what was most needed to me at the moment. I appreciate the detailed notes and will try to address them soon.
Do you mean that you don't think it's necessary to adjust frequency? It seems quite useful to me to be able to adjust how many email you like to get vs. how timely your notifications are. |
Maybe this is a bit because I see the other use side. I receive tons of notifications and with instant emails we can't even group them anymore even when it's within 5 seconds. Which is why I would only do a reminder on old notifications, not live emails. |
Well, I've expressed my personal preference and I like having precise control over such settings, but I won't go against your judgement if you feel reminder email once a week are enough. It's not exactly what I'd like but is a lot better than no email ever. This is good in the sense that if you forgot the instance was there for a long time and someone suddenly wants to talk, even with the 1 week setting, you'll get a timely reminder. Hopefully after that message you have a good chance to keep checking the instance for the next week. On the other hand it might be a bit weird that if you get many notifications every week, the timing of the email you're getting every week will be based on the arbitrary time and day you got the first notification, not based on something predictable like for the "Send daily activity summary in the morning" setting. It might not be that bad though. In the end since you wanted to have the notification sound setting elsewhere, are you saying you'd rather not have a settings page for Notifications at all? From a user's perspective, I would expect these to be somewhere in settings, but I would expect it to be on the same page as the current Activity settings if it could be renamed to something more general. However they're 2 different apps so I don't know if they can share a settings page with separate sections and still work if one or the other is disabled. |
Another approach would be "send me an email only when I have a notification that I have not seen after a full week". |
Personally, I'd vote for a reminder mail once a day. cc @jancborchardt and @nimisha-vijay on this |
So from my POV those are 2 different things @jbarnoin But let's see what the designers say about it. |
Agreed with @nickvergessen that immediate notifications by email might be a bit much, since this is regarding just a reminder or nudge about unread notifications, not live email notifications itself. So maybe something like this in the settings can work Remind me about unread notifications: Daily / Weekly / Never
What do you think? |
Yeah, I understand the point about not mixing live notifications with wanting reminders for people who forget about the instance. I liked the idea of getting the benefit of both but the important thing is reminders for me as well. If there's options shorter than one week, such as daily, I'd be fine with the reminder being setup so that it's only sent once you have a notification that has reached the age of the period, I just feel always waiting a week is a bit much. However, I would add that if we're already offering options for Daily / Weekly / Never, I don't see the harm in adding Hourly / As Soon As Possible as well since that's clearly the user's choice at this point, it would not be a default for anyone, and it's clear to the user what they'll get if they select it (and the email includes a link to the page to change the frequency if they get tired of it). It's just a number in the system at that point so there's no extra implementation cost either - I was going to remove the immediate path in any case as requested, so it's all the same code path triggered when the background job runs, every 15 min at the moment. The only potential drawback I can see is in terms of performance concerns if too many people on a server enable "As soon as possible" notifications, but I would argue that if so many people volontarily enable this that it becomes a performance issue, you'll have a clear signal that there's enough demand to spend time optimizing it.
To be clear though, at the moment I don't ever re-send an email for an unseen notificaiton if it's been sent already. If we want that it can be done easily, but I assumed getting one email per notification would be enough. For update notifications, if you don't act on it for a while you'll probably get another one for a new update at some point anyway. |
One more thought: Even if we default to Never for everyone else, could it make sense to default to at least weekly notifications for admins? Setting up a server, forgetting about it after a while and leaving it live never updating it could be a security risk that this could mitigate at least a bit. |
This is nothing that should be done via the notification app from my POV. It's a valid case, but can totally come with an out of line solution: there is another ticket about sending regular emails about pending updates (nextcloud/server#3596) and even about disabling outdated servers (nextcloud/server#14230). |
Got it. At least until that system is up there'll be a way for admins to get these notifications if they enable it, which will cover at least some of them, so I consider that's still progress in the right direction. By the way, it sounds like there's going to be a number of separate background jobs for sending email doing similar checks and actions, at some point this might call for unifying this under a common background email service that apps can plug into. |
f0435ef
to
b4991a5
Compare
I pushed a revised commit with the following main changes:
This should be ready for another round of review. |
3acf40c
to
1b4133c
Compare
The eslint / php / unit test validation errors should be fixed. However I also fetched latest from master branch and now I'm getting differences in js/notifications-main.js* which I haven't touched, so I haven't committed these changes as it sounds fishy. There was also one about appinfo/info.xml not liking the |
1b4133c
to
fe8d04f
Compare
…er settings page for notifications to configure this option. Signed-off-by: Julien Barnoin <[email protected]>
fe8d04f
to
2e7f09c
Compare
Ignore that for now, we can fix it in the end. |
|
||
export default new Vue({ | ||
el: '#notifications-user-settings', | ||
// eslint-disable-next-line vue/match-component-file-name |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should fix that instead, but we can take care of it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I wasn't sure if I should deviate from the naming conventions / capitalization that I saw from the code in another app I used as an example so I copied that as well, I agree it's not great.
So apart from the node giving me a different output, this is now passing validation.
|
This change adds support for sending users an email about their unseen notifications. This should close #314 .
It's my first contribution, I did my best to respect guidelines but I'll adjust whatever I might have missed of course.
A new Notifications personal settings page allows enabling the feature and selecting the maximum mailing frequency.
A new background job checks for new emails due to be sent.
It also does an instant check at the moment a notification is sent, and sends the email right away if the user has the "as soon as possible" frequency set (but not more than once per background job cycle to avoid excessive spamming). Longer frequencies are sent at the next background job period, but not more often than the desired period.
The email format can probably be improved, but here's how it looks like at the moment:
data:image/s3,"s3://crabby-images/b8713/b871394439ca5895fb2d53e8dd9f5834404d8176" alt="MailNotificationContents"
The notification settings page is very simple for now. I don't think there's categories we can filter like for Activities?
data:image/s3,"s3://crabby-images/72414/724146b5ea03d5530c73460015aae40c99f2fb7c" alt="NotificationSettings"
The naming of things when comparing the user Activity settings versus Notifications settings pages is confusing, since the Activity settings page has a heading that says "Notifications" and a setting labeled "Send notification emails". I'm not sure how to clarify this, but I imagine it would involve changes to the Activity settings, so I can't do anything about it here.
There's currently no admin settings page. There probably should be one. The Activities app allows admins to allow the email notifications feature or not, I'm guessing this would be good to have here too. I am reading the notifications app setting 'enable_email' with a default to 'yes', in the same way the Activities app does it, but there's currently no interface to disable it.