2017-12-04 12:15:47 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2023-10-10 09:39:41 +00:00
|
|
|
import uuid
|
2023-09-15 08:39:49 +00:00
|
|
|
from datetime import timedelta
|
2016-11-10 15:54:21 +00:00
|
|
|
|
2023-10-10 09:39:41 +00:00
|
|
|
from celery import shared_task, current_task
|
2023-08-07 06:55:17 +00:00
|
|
|
from django.conf import settings
|
2023-10-10 09:39:41 +00:00
|
|
|
from django.db.models import Q
|
2022-06-28 09:23:20 +00:00
|
|
|
from django.utils import timezone
|
2023-10-10 09:39:41 +00:00
|
|
|
from django.utils.translation import gettext_lazy as _, gettext_noop
|
2018-11-22 10:02:12 +00:00
|
|
|
|
2023-10-10 09:39:41 +00:00
|
|
|
from audits.const import ActivityChoices
|
2023-02-19 09:57:48 +00:00
|
|
|
from common.const.crontab import CRONTAB_AT_AM_TEN, CRONTAB_AT_PM_TWO
|
|
|
|
from common.utils import get_logger
|
2023-08-07 06:55:17 +00:00
|
|
|
from ops.celery.decorator import after_app_ready_start, register_as_period_task
|
|
|
|
from ops.celery.utils import create_or_update_celery_periodic_tasks
|
|
|
|
from orgs.utils import tmp_to_root_org
|
2023-02-19 09:57:48 +00:00
|
|
|
from users.notifications import PasswordExpirationReminderMsg
|
2021-08-24 06:20:54 +00:00
|
|
|
from users.notifications import UserExpirationReminderMsg
|
2023-02-19 09:57:48 +00:00
|
|
|
from .models import User
|
2018-11-22 10:02:12 +00:00
|
|
|
|
|
|
|
logger = get_logger(__file__)
|
2016-11-10 15:54:21 +00:00
|
|
|
|
|
|
|
|
2023-02-02 07:57:06 +00:00
|
|
|
@shared_task(verbose_name=_('Check password expired'))
|
2018-11-22 10:02:12 +00:00
|
|
|
def check_password_expired():
|
2022-02-17 12:13:31 +00:00
|
|
|
users = User.get_nature_users().filter(source=User.Source.local)
|
2018-11-22 10:02:12 +00:00
|
|
|
for user in users:
|
2019-07-30 04:52:45 +00:00
|
|
|
if not user.is_valid:
|
|
|
|
continue
|
2018-11-22 10:02:12 +00:00
|
|
|
if not user.password_will_expired:
|
|
|
|
continue
|
2019-07-30 04:52:45 +00:00
|
|
|
msg = "The user {} password expires in {} days"
|
|
|
|
logger.info(msg.format(user, user.password_expired_remain_days))
|
2021-08-24 06:20:54 +00:00
|
|
|
|
|
|
|
PasswordExpirationReminderMsg(user).publish_async()
|
2018-11-22 10:02:12 +00:00
|
|
|
|
|
|
|
|
2023-02-02 07:57:06 +00:00
|
|
|
@shared_task(verbose_name=_('Periodic check password expired'))
|
2018-11-22 10:02:12 +00:00
|
|
|
@after_app_ready_start
|
|
|
|
def check_password_expired_periodic():
|
|
|
|
tasks = {
|
|
|
|
'check_password_expired_periodic': {
|
|
|
|
'task': check_password_expired.name,
|
|
|
|
'interval': None,
|
2022-10-10 08:31:45 +00:00
|
|
|
'crontab': CRONTAB_AT_AM_TEN,
|
2018-11-22 10:02:12 +00:00
|
|
|
'enabled': True,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
create_or_update_celery_periodic_tasks(tasks)
|
2019-03-04 02:39:44 +00:00
|
|
|
|
|
|
|
|
2023-02-02 07:57:06 +00:00
|
|
|
@shared_task(verbose_name=_('Check user expired'))
|
2019-07-31 08:57:21 +00:00
|
|
|
def check_user_expired():
|
2022-06-28 09:23:20 +00:00
|
|
|
date_expired_lt = timezone.now() + timezone.timedelta(days=User.DATE_EXPIRED_WARNING_DAYS)
|
2023-02-02 07:57:06 +00:00
|
|
|
users = User.get_nature_users() \
|
|
|
|
.filter(source=User.Source.local) \
|
2022-06-28 09:23:20 +00:00
|
|
|
.filter(date_expired__lt=date_expired_lt)
|
|
|
|
|
2019-07-31 08:57:21 +00:00
|
|
|
for user in users:
|
|
|
|
if not user.is_valid:
|
|
|
|
continue
|
|
|
|
if not user.will_expired:
|
|
|
|
continue
|
2020-03-13 04:33:09 +00:00
|
|
|
msg = "The user {} will expires in {} days"
|
|
|
|
logger.info(msg.format(user, user.expired_remain_days))
|
2021-08-24 06:20:54 +00:00
|
|
|
UserExpirationReminderMsg(user).publish_async()
|
2019-07-31 08:57:21 +00:00
|
|
|
|
|
|
|
|
2023-02-02 07:57:06 +00:00
|
|
|
@shared_task(verbose_name=_('Periodic check user expired'))
|
2019-07-31 08:57:21 +00:00
|
|
|
@after_app_ready_start
|
|
|
|
def check_user_expired_periodic():
|
|
|
|
tasks = {
|
|
|
|
'check_user_expired_periodic': {
|
|
|
|
'task': check_user_expired.name,
|
|
|
|
'interval': None,
|
2022-10-10 08:31:45 +00:00
|
|
|
'crontab': CRONTAB_AT_PM_TWO,
|
2019-07-31 08:57:21 +00:00
|
|
|
'enabled': True,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
create_or_update_celery_periodic_tasks(tasks)
|
2023-08-07 06:55:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
@shared_task(verbose_name=_('Check unused users'))
|
|
|
|
@register_as_period_task(crontab=CRONTAB_AT_PM_TWO)
|
|
|
|
@tmp_to_root_org()
|
|
|
|
def check_unused_users():
|
2023-09-15 08:39:49 +00:00
|
|
|
uncommon_users_ttl = settings.SECURITY_UNCOMMON_USERS_TTL
|
2024-01-23 09:15:34 +00:00
|
|
|
if not uncommon_users_ttl:
|
2023-12-12 07:28:24 +00:00
|
|
|
return
|
|
|
|
|
|
|
|
uncommon_users_ttl = int(uncommon_users_ttl)
|
|
|
|
if uncommon_users_ttl <= 0 or uncommon_users_ttl >= 999:
|
|
|
|
return
|
|
|
|
|
2023-09-15 08:39:49 +00:00
|
|
|
seconds_to_subtract = uncommon_users_ttl * 24 * 60 * 60
|
2023-10-10 09:39:41 +00:00
|
|
|
t = timezone.now() - timedelta(seconds=seconds_to_subtract)
|
2023-11-17 07:37:23 +00:00
|
|
|
last_login_q = Q(last_login__lte=t) | (Q(last_login__isnull=True) & Q(date_joined__lte=t))
|
|
|
|
api_key_q = Q(date_api_key_last_used__lte=t) | (Q(date_api_key_last_used__isnull=True) & Q(date_joined__lte=t))
|
2023-10-10 09:39:41 +00:00
|
|
|
|
|
|
|
users = User.objects \
|
|
|
|
.filter(date_joined__lt=t) \
|
|
|
|
.filter(is_active=True) \
|
|
|
|
.filter(last_login_q) \
|
2023-12-15 10:28:24 +00:00
|
|
|
.filter(api_key_q) \
|
|
|
|
.exclude(username='admin')
|
2023-10-10 09:39:41 +00:00
|
|
|
|
|
|
|
if not users:
|
|
|
|
return
|
2023-11-17 07:37:23 +00:00
|
|
|
|
2023-10-10 09:39:41 +00:00
|
|
|
print("Some users are not used for a long time, and they will be disabled.")
|
|
|
|
resource_ids = []
|
|
|
|
for user in users:
|
|
|
|
resource_ids.append(user.id)
|
|
|
|
print(' - {}'.format(user.name))
|
|
|
|
|
|
|
|
users.update(is_active=False)
|
|
|
|
from audits.signal_handlers import create_activities
|
|
|
|
if current_task:
|
|
|
|
task_id = current_task.request.id
|
|
|
|
else:
|
|
|
|
task_id = str(uuid.uuid4())
|
|
|
|
detail = gettext_noop('The user has not logged in recently and has been disabled.')
|
|
|
|
create_activities(resource_ids, detail, task_id, action=ActivityChoices.task, org_id='')
|