2017-12-04 12:15:47 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2016-11-10 15:54:21 +00:00
|
|
|
|
|
|
|
from celery import shared_task
|
2018-11-22 10:02:12 +00:00
|
|
|
|
|
|
|
from ops.celery.utils import (
|
|
|
|
create_or_update_celery_periodic_tasks,
|
|
|
|
after_app_ready_start
|
|
|
|
)
|
|
|
|
from .models import User
|
|
|
|
from common.utils import get_logger
|
|
|
|
from .utils import write_login_log, send_password_expiration_reminder_mail
|
|
|
|
|
|
|
|
|
|
|
|
logger = get_logger(__file__)
|
2016-11-10 15:54:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
@shared_task
|
|
|
|
def write_login_log_async(*args, **kwargs):
|
2016-11-11 01:48:47 +00:00
|
|
|
write_login_log(*args, **kwargs)
|
|
|
|
|
2018-11-22 10:02:12 +00:00
|
|
|
|
|
|
|
@shared_task
|
|
|
|
def check_password_expired():
|
|
|
|
users = User.objects.exclude(role=User.ROLE_APP)
|
|
|
|
for user in users:
|
|
|
|
if not user.password_will_expired:
|
|
|
|
continue
|
|
|
|
|
|
|
|
send_password_expiration_reminder_mail(user)
|
|
|
|
logger.info("The user {} password expires in {} days".format(
|
|
|
|
user, user.password_expired_remain_days)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@shared_task
|
|
|
|
@after_app_ready_start
|
|
|
|
def check_password_expired_periodic():
|
|
|
|
tasks = {
|
|
|
|
'check_password_expired_periodic': {
|
|
|
|
'task': check_password_expired.name,
|
|
|
|
'interval': None,
|
|
|
|
'crontab': '0 10 * * *',
|
|
|
|
'enabled': True,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
create_or_update_celery_periodic_tasks(tasks)
|