Source code for shuup.admin.modules.orders.views.log

# -*- coding: utf-8 -*-
# This file is part of Shuup.
#
# Copyright (c) 2012-2021, Shuup Commerce Inc. All rights reserved.
#
# This source code is licensed under the OSL-3.0 license found in the
# LICENSE file in the root directory of this source tree.
from django.contrib.auth import get_user_model
from django.http.response import Http404, JsonResponse
from django.views.generic import View

from shuup.core.models import Order, OrderLogEntry, Shop
from shuup.utils.analog import LogEntryKind
from shuup.utils.django_compat import force_text
from shuup.utils.i18n import get_locally_formatted_datetime


[docs]class NewLogEntryView(View): """ Create a log `note` item associated with a particular order. """
[docs] def post(self, request, *args, **kwargs): shop_ids = Shop.objects.get_for_user(self.request.user).values_list("id", flat=True) order = Order.objects.filter(pk=kwargs["pk"], shop_id__in=shop_ids).first() if not order: raise Http404() message = request.POST["message"] entry = OrderLogEntry.objects.create( target=order, message=message, kind=LogEntryKind.NOTE, user=request.user, ) return JsonResponse( { "message": entry.message, "kind": force_text(entry.kind.label), "created_on": get_locally_formatted_datetime(entry.created_on), "user": force_text(getattr(entry.user, get_user_model().USERNAME_FIELD)), } )