mirror of
https://github.com/jumpserver/jumpserver.git
synced 2025-09-10 03:39:59 +00:00
perf: 优化禁用用户
This commit is contained in:
@@ -1,15 +1,17 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
#
|
||||
import uuid
|
||||
from datetime import timedelta
|
||||
|
||||
from celery import shared_task
|
||||
from celery import shared_task, current_task
|
||||
from django.conf import settings
|
||||
from django.db.models import Q
|
||||
from django.utils import timezone
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from django.utils.translation import gettext_lazy as _, gettext_noop
|
||||
|
||||
from audits.const import ActivityChoices
|
||||
from common.const.crontab import CRONTAB_AT_AM_TEN, CRONTAB_AT_PM_TWO
|
||||
from common.utils import get_logger
|
||||
from common.utils.timezone import utc_now
|
||||
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
|
||||
@@ -85,5 +87,29 @@ def check_user_expired_periodic():
|
||||
def check_unused_users():
|
||||
uncommon_users_ttl = settings.SECURITY_UNCOMMON_USERS_TTL
|
||||
seconds_to_subtract = uncommon_users_ttl * 24 * 60 * 60
|
||||
t = utc_now() - timedelta(seconds=seconds_to_subtract)
|
||||
User.objects.filter(last_login__lte=t).update(is_active=False)
|
||||
t = timezone.now() - timedelta(seconds=seconds_to_subtract)
|
||||
last_login_q = Q(last_login__lte=t) | Q(last_login__isnull=True)
|
||||
api_key_q = Q(date_api_key_last_used__lte=t) | Q(date_api_key_last_used__isnull=True)
|
||||
|
||||
users = User.objects \
|
||||
.filter(date_joined__lt=t) \
|
||||
.filter(is_active=True) \
|
||||
.filter(last_login_q) \
|
||||
.filter(api_key_q)
|
||||
|
||||
if not users:
|
||||
return
|
||||
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='')
|
||||
|
Reference in New Issue
Block a user