#1058 Send email before api token expires
Merged 7 years ago by pingou. Opened 7 years ago by vivekanand1101.
vivekanand1101/pagure api_email  into  master

@@ -0,0 +1,55 @@ 

+ #!/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`'

+     os.environ['PAGURE_CONFIG'] = '/etc/pagure/pagure.cfg'

+ 

+ import pagure

+ from pagure import SESSION

+ from pagure.lib import model

+ 

+ 

+ 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)

no initial comment

checked it using datetime.datetime.utcnow().minute

If you use ''' then you shouldn't include \n, they won't be rendered.

Actually, I seem to be wrong here :)

This will be ran by a cron job which we likely do not want to send an email everytime it runs, could we have a --debug option that prints something and otherwise doesn't print anything?

Maybe we could convert email_days to dates earlier so we do not have to do it for every token we process?

Few comments but looking good, thanks for looking into this! :)

rebased

7 years ago

Looks good to me, thanks! :)

Pull-Request has been merged by pingou

7 years ago
Metadata