* Refactor and extend cleanup tasks for logs and versions - Consolidate API log deletion into cleanup_task.py - Add tasks to delete old email logs, page versions, and issue description versions - Update Celery schedule and imports for new tasks * chore: update cleanup task with mongo changes * fix: update log deletion task name for clarity * fix: enhance MongoDB archival error handling in cleanup task - Added a parameter to check MongoDB availability in the flush_to_mongo_and_delete function. - Implemented error logging for MongoDB archival failures. - Updated calls to flush_to_mongo_and_delete to include the new parameter. * fix: correct parameter name in cleanup task function call - Updated the parameter name from 'mode' to 'model' in the process_cleanup_task function to ensure consistency and clarity in the code. * fix: improve MongoDB connection parameter handling in MongoConnection class - Replaced direct access to settings with getattr for MONGO_DB_URL and MONGO_DB_DATABASE to enhance robustness. - Added warning logging for missing MongoDB connection parameters.
95 lines
3.4 KiB
Python
95 lines
3.4 KiB
Python
# Python imports
|
|
import os
|
|
import logging
|
|
|
|
# Third party imports
|
|
from celery import Celery
|
|
from pythonjsonlogger.jsonlogger import JsonFormatter
|
|
from celery.signals import after_setup_logger, after_setup_task_logger
|
|
from celery.schedules import crontab
|
|
|
|
# Module imports
|
|
from plane.settings.redis import redis_instance
|
|
|
|
# Set the default Django settings module for the 'celery' program.
|
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "plane.settings.production")
|
|
|
|
ri = redis_instance()
|
|
|
|
app = Celery("plane")
|
|
|
|
# Using a string here means the worker will not have to
|
|
# pickle the object when using Windows.
|
|
app.config_from_object("django.conf:settings", namespace="CELERY")
|
|
|
|
app.conf.beat_schedule = {
|
|
# Intra day recurring jobs
|
|
"check-every-five-minutes-to-send-email-notifications": {
|
|
"task": "plane.bgtasks.email_notification_task.stack_email_notification",
|
|
"schedule": crontab(minute="*/5"), # Every 5 minutes
|
|
},
|
|
"run-every-6-hours-for-instance-trace": {
|
|
"task": "plane.license.bgtasks.tracer.instance_traces",
|
|
"schedule": crontab(hour="*/6", minute=0), # Every 6 hours
|
|
},
|
|
# Occurs once every day
|
|
"check-every-day-to-delete-hard-delete": {
|
|
"task": "plane.bgtasks.deletion_task.hard_delete",
|
|
"schedule": crontab(hour=0, minute=0), # UTC 00:00
|
|
},
|
|
"check-every-day-to-archive-and-close": {
|
|
"task": "plane.bgtasks.issue_automation_task.archive_and_close_old_issues",
|
|
"schedule": crontab(hour=1, minute=0), # UTC 01:00
|
|
},
|
|
"check-every-day-to-delete_exporter_history": {
|
|
"task": "plane.bgtasks.exporter_expired_task.delete_old_s3_link",
|
|
"schedule": crontab(hour=1, minute=30), # UTC 01:30
|
|
},
|
|
"check-every-day-to-delete-file-asset": {
|
|
"task": "plane.bgtasks.file_asset_task.delete_unuploaded_file_asset",
|
|
"schedule": crontab(hour=2, minute=0), # UTC 02:00
|
|
},
|
|
"check-every-day-to-delete-api-logs": {
|
|
"task": "plane.bgtasks.cleanup_task.delete_api_logs",
|
|
"schedule": crontab(hour=2, minute=30), # UTC 02:30
|
|
},
|
|
"check-every-day-to-delete-email-notification-logs": {
|
|
"task": "plane.bgtasks.cleanup_task.delete_email_notification_logs",
|
|
"schedule": crontab(hour=3, minute=0), # UTC 03:00
|
|
},
|
|
"check-every-day-to-delete-page-versions": {
|
|
"task": "plane.bgtasks.cleanup_task.delete_page_versions",
|
|
"schedule": crontab(hour=3, minute=30), # UTC 03:30
|
|
},
|
|
"check-every-day-to-delete-issue-description-versions": {
|
|
"task": "plane.bgtasks.cleanup_task.delete_issue_description_versions",
|
|
"schedule": crontab(hour=4, minute=0), # UTC 04:00
|
|
},
|
|
}
|
|
|
|
|
|
# Setup logging
|
|
@after_setup_logger.connect
|
|
def setup_loggers(logger, *args, **kwargs):
|
|
formatter = JsonFormatter(
|
|
'"%(levelname)s %(asctime)s %(module)s %(name)s %(message)s'
|
|
)
|
|
handler = logging.StreamHandler()
|
|
handler.setFormatter(fmt=formatter)
|
|
logger.addHandler(handler)
|
|
|
|
|
|
@after_setup_task_logger.connect
|
|
def setup_task_loggers(logger, *args, **kwargs):
|
|
formatter = JsonFormatter(
|
|
'"%(levelname)s %(asctime)s %(module)s %(name)s %(message)s'
|
|
)
|
|
handler = logging.StreamHandler()
|
|
handler.setFormatter(fmt=formatter)
|
|
logger.addHandler(handler)
|
|
|
|
|
|
# Load task modules from all registered Django app configs.
|
|
app.autodiscover_tasks()
|
|
|
|
app.conf.beat_scheduler = "django_celery_beat.schedulers.DatabaseScheduler"
|