summaryrefslogtreecommitdiffstats
path: root/django/engagementmanager/bus/handlers/daily_resend_notifications_handler.py
diff options
context:
space:
mode:
authorPaul McGoldrick <paul.mcgoldrick@att.com>2017-09-28 10:03:40 -0700
committerPaul McGoldrick <paul.mcgoldrick@att.com>2017-09-28 10:14:55 -0700
commitbd886d918ef2adbabd16c61fdd2e47984e21dfd7 (patch)
treed41683dffa58fd698df450d148fab3cc2521b0c5 /django/engagementmanager/bus/handlers/daily_resend_notifications_handler.py
parent474554adad912f3edb7ddc3ad14406abb369fb3c (diff)
initial seed code commit VVP-5
Change-Id: I6560c87ef48a6d0d1fe8197c7c6439c7e6ad653f Signed-off-by: Paul McGoldrick <paul.mcgoldrick@att.com>
Diffstat (limited to 'django/engagementmanager/bus/handlers/daily_resend_notifications_handler.py')
-rwxr-xr-xdjango/engagementmanager/bus/handlers/daily_resend_notifications_handler.py75
1 files changed, 75 insertions, 0 deletions
diff --git a/django/engagementmanager/bus/handlers/daily_resend_notifications_handler.py b/django/engagementmanager/bus/handlers/daily_resend_notifications_handler.py
new file mode 100755
index 0000000..9919cad
--- /dev/null
+++ b/django/engagementmanager/bus/handlers/daily_resend_notifications_handler.py
@@ -0,0 +1,75 @@
+#
+# ============LICENSE_START==========================================
+# org.onap.vvp/engagementmgr
+# ===================================================================
+# Copyright © 2017 AT&T Intellectual Property. All rights reserved.
+# ===================================================================
+#
+# Unless otherwise specified, all software contained herein is licensed
+# under the Apache License, Version 2.0 (the “License”);
+# you may not use this software except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+#
+#
+# Unless otherwise specified, all documentation contained herein is licensed
+# under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
+# you may not use this documentation except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# https://creativecommons.org/licenses/by/4.0/
+#
+# Unless required by applicable law or agreed to in writing, documentation
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# ============LICENSE_END============================================
+#
+# ECOMP is a trademark and service mark of AT&T Intellectual Property.
+import json
+from django.template.loader import get_template
+from engagementmanager import mail
+from engagementmanager.bus.handlers.service_bus_base_handler import ServiceBusBaseHandler
+from engagementmanager.mail import sendMail
+from engagementmanager.models import Notification
+from engagementmanager.utils.constants import Constants
+from engagementmanager.service.logging_service import LoggingServiceFactory
+
+logger = LoggingServiceFactory.get_logger()
+
+
+class DailyResendNotificationsHandler(ServiceBusBaseHandler):
+ def handle_message(self, bus_message):
+ logger.debug("New resend notifications message arrived - emails is about to sent to the "
+ "all unsent notifications")
+ unsent_notifications = Notification.objects.filter(is_sent=False)
+ for notification in unsent_notifications:
+ if notification.user.email_updates_on_every_notification:
+ try:
+ subject_template = get_template("{notification_template_dir}notification_mail_subject.html".format(
+ notification_template_dir=Constants.notification_template_dir))
+ msg_template = get_template("{notification_template_dir}notification_mail_body.html".format(
+ notification_template_dir=Constants.notification_template_dir))
+
+ sendMail(notification.user.email, json.loads(notification.activity.metadata),
+ msg_template, subject_template, mail_from=mail.ice_admin_mail_from)
+ notification.is_sent = True
+ notification.save()
+ except Exception as e:
+ msg = "Something went wrong while trying to resend bulk mail " \
+ "as part of the notifications daily resend"
+ logger.error(msg + " " + e)
+ else:
+ notification.is_sent = True
+ notification.save()
+ logger.info("User choose not to get email on every notification, set it as sent.")