Browse Source

Add debug option in the script for sending email before the api token expires

Vivek Anand 8 years ago
parent
commit
0a1f5d17e0
1 changed files with 38 additions and 21 deletions
  1. 38 21
      files/api_key_expire_mail.py

+ 38 - 21
files/api_key_expire_mail.py

@@ -1,10 +1,12 @@
 #!/usr/bin/env python
 
 import os
+import argparse
 from datetime import datetime, timedelta
 
 from sqlalchemy.exc import SQLAlchemyError
 
+
 if 'PAGURE_CONFIG' not in os.environ \
         and os.path.exists('/etc/pagure/pagure.cfg'):
     print 'Using configuration file `/etc/pagure/pagure.cfg`'
@@ -15,24 +17,39 @@ from pagure import SESSION
 from pagure.lib import model
 
 
-current_time = datetime.utcnow()
-day_diff_for_mail = [5, 3, 1]
-email_dates = [email_day.date() for email_day in [current_time + timedelta(days=i)\
-        for i in day_diff_for_mail]]
-
-tokens = SESSION.query(model.Token).all()
-
-for token in tokens:
-    if token.expiration.date() in email_dates:
-        user = token.user
-        user_email = user.default_email
-        project = token.project
-        days_left = token.expiration.day - datetime.utcnow().day
-        subject = 'Pagure API key expiration date is near!'
-        text = '''Hi %s, \nYour Pagure API key for the project %s will expire
-in %s day(s). Please get a new key for non-interrupted service. \n
-Thanks, \nYour Pagure Admin. ''' % (user.fullname, project.name, days_left)
-        msg = pagure.lib.notify.send_email(text, subject, user_email)
-        print 'Sent mail to %s' % user.fullname
-
-print 'Done'
+def main(debug=False):
+    ''' The function that actually sends the email
+    in case the expiration date is near'''
+
+    current_time = datetime.utcnow()
+    day_diff_for_mail = [5, 3, 1]
+    email_dates = [email_day.date() for email_day in \
+            [current_time + timedelta(days=i) for i in day_diff_for_mail]]
+
+    tokens = SESSION.query(model.Token).all()
+
+    for token in tokens:
+        if token.expiration.date() in email_dates:
+            user = token.user
+            user_email = user.default_email
+            project = token.project
+            days_left = token.expiration.day - datetime.utcnow().day
+            subject = 'Pagure API key expiration date is near!'
+            text = '''Hi %s, \nYour Pagure API key for the project %s will expire
+    in %s day(s). Please get a new key for non-interrupted service. \n
+    Thanks, \nYour Pagure Admin. ''' % (user.fullname, project.name, days_left)
+            msg = pagure.lib.notify.send_email(text, subject, user_email)
+            if debug:
+                print 'Sent mail to %s' % user.fullname
+    if debug:
+        print 'Done'
+
+
+if __name__ == '__main__':
+    parser = argparse.ArgumentParser(
+            description='Script to send email before the api token expires')
+    parser.add_argument(
+            '--debug', dest='debug', action='store_true', default=False,
+            help='Print the debugging output')
+    args = parser.parse_args()
+    main(debug=args.debug)