#36768: File.__iter__() Quadratic-time DoS
-------------------------------------+-------------------------------------
     Reporter:  wooseokdotkim        |                    Owner:  (none)
         Type:  Bug                  |                   Status:  new
    Component:  File                 |                  Version:
  uploads/storage                    |
     Severity:  Normal               |               Resolution:
     Keywords:  DoS                  |             Triage Stage:
                                     |  Unreviewed
    Has patch:  0                    |      Needs documentation:  0
  Needs tests:  0                    |  Patch needs improvement:  0
Easy pickings:  0                    |                    UI/UX:  0
-------------------------------------+-------------------------------------
Changes (by Tim Graham):

 * component:  Uncategorized => File uploads/storage


Old description:

> I thought the code below could generate DoS, so I made a bug report
> However, File._iter__ was not recognized as a bug because only one line
> was buffered and only worked for chunks returned from File.chunks, but it
> was determined that verification code for input should be added, so it
> was created as an open ticket.
>
> The code pattern is similar to CVE-2023-36053, which is already released,
> so I think it needs to be modified.
>
> code: django/core/files/base.py:89
>
> {{{
> def __iter__(self):
>     buffer_ = None
>     for chunk in self.chunks():
>         for line in chunk.splitlines(True):
>             if buffer_:
>                 line = buffer_ + line  # < Code!
> }}}
>

> How should I patch it?

New description:

 I thought the code below could generate DoS, so I made a bug report
 However, `File._iter__()` was not recognized as a bug because only one
 line was buffered and only worked for chunks returned from `File.chunks`,
 but it was determined that verification code for input should be added, so
 it was created as an open ticket.

 The code pattern is similar to CVE-2023-36053, which is already released,
 so I think it needs to be modified.

 code: django/core/files/base.py:89

 {{{
 def __iter__(self):
     buffer_ = None
     for chunk in self.chunks():
         for line in chunk.splitlines(True):
             if buffer_:
                 line = buffer_ + line  # < Code!
 }}}


 How should I patch it?

--
-- 
Ticket URL: <https://code.djangoproject.com/ticket/36768#comment:3>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.

-- 
You received this message because you are subscribed to the Google Groups 
"Django updates" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion visit 
https://groups.google.com/d/msgid/django-updates/0107019ae5582b19-6c4e6683-d98b-4be6-ba23-89355a3fb9b1-000000%40eu-central-1.amazonses.com.

Reply via email to