-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* feat: Add celery settings * feat: fix celery settings * feat: update lock file * feat: add close metrics task * feat: add custom queue to run the close metrics task * feat: change default value of metrics custom queue to celery * feat: make it a choice to run the tasks in celery or synchronous * feat: remove apm from docker compose * feat: add debug task
- Loading branch information
1 parent
ef7ae13
commit 086d8fb
Showing
9 changed files
with
331 additions
and
48 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# This will make sure the app is always imported when | ||
# Django starts so that shared_task will use this app. | ||
from .celery import app as celery_app | ||
|
||
__all__ = ("celery_app",) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
from chats.apps.dashboard.models import RoomMetrics | ||
from chats.apps.rooms.models import Room | ||
from chats.celery import app | ||
|
||
|
||
def generate_metrics(room: str): | ||
room = Room.objects.get(pk=room) | ||
messages_contact = ( | ||
room.messages.filter(contact__isnull=False).order_by("created_on").first() | ||
) | ||
messages_agent = ( | ||
room.messages.filter(user__isnull=False).order_by("created_on").first() | ||
) | ||
|
||
time_message_contact = 0 | ||
time_message_agent = 0 | ||
|
||
if messages_agent and messages_contact: | ||
time_message_agent = messages_agent.created_on.timestamp() | ||
time_message_contact = messages_contact.created_on.timestamp() | ||
else: | ||
time_message_agent = 0 | ||
time_message_contact = 0 | ||
|
||
difference_time = time_message_agent - time_message_contact | ||
interaction_time = room.ended_at - room.created_on | ||
|
||
metric_room = RoomMetrics.objects.get_or_create(room=room)[0] | ||
metric_room.message_response_time = difference_time | ||
metric_room.interaction_time = interaction_time.total_seconds() | ||
metric_room.save() | ||
|
||
|
||
@app.task(name="close_metrics") | ||
def close_metrics(room: str): | ||
generate_metrics(room) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
import os | ||
|
||
from celery import Celery | ||
|
||
# Set the default Django settings module for the "celery" program. | ||
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "chats.settings") | ||
|
||
app = Celery("chats") | ||
|
||
# Using a string here means the worker doesn't have to serialize | ||
# the configuration object to child processes. | ||
# - namespace="CELERY" means all celery-related configuration keys | ||
# should have a `CELERY_` prefix. | ||
app.config_from_object("django.conf:settings", namespace="CELERY") | ||
|
||
# Load task modules from all registered Django apps. | ||
app.autodiscover_tasks() | ||
|
||
|
||
@app.task(bind=True) | ||
def debug_task(self): | ||
print("Request: {0!r}".format(self.request)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.