Movatterモバイル変換


[0]ホーム

URL:


homepage

Issue32072

This issue trackerhas been migrated toGitHub, and is currentlyread-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title:Issues with binary plists
Type:securityStage:resolved
Components:Library (Lib)Versions:Python 3.7, Python 3.6, Python 3.4, Python 3.5
process
Status:closedResolution:fixed
Dependencies:Superseder:
Assigned To: serhiy.storchakaNosy List: larry, ned.deily, ronaldoussoren, serhiy.storchaka
Priority:normalKeywords:patch

Created on2017-11-18 19:06 byserhiy.storchaka, last changed2022-04-11 14:58 byadmin. This issue is nowclosed.

Pull Requests
URLStatusLinkedEdit
PR 4455mergedserhiy.storchaka,2017-11-18 19:16
PR 4654mergedpython-dev,2017-11-30 21:26
PR 4656mergedserhiy.storchaka,2017-11-30 21:43
PR 4658mergedserhiy.storchaka,2017-11-30 21:50
Messages (10)
msg306493 -(view)Author: Serhiy Storchaka (serhiy.storchaka)*(Python committer)Date: 2017-11-18 19:06
plistlib creates a new objects when read references instead of usingalready read object.As result it doesn't preserve identity:>>> import plistlib>>> a = [['spam']]*2>>> a[0] is a[1]True>>> b = plistlib.loads(plistlib.dumps(a, fmt=plistlib.FMT_BINARY))>>> b == aTrue>>> b[0] is b[1]FalseAnd plistlib.loads() is vulnerable to plists containing cyclicreferences (as was exposed inissue31897). For example,plistlib.loads(b'bplist00\xa1\x00\x08\x00\x00\x00\x00\x00\x00\x01\x01\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x0a')could return a list containing itself, but it is failed withRecursionError.plistlib.dumps() preserves reference in the output, but it savesredundant copies. For example plistlib.dumps([[]]*5,fmt=plistlib.FMT_BINARY) saves a list containing 5 identical emptylists, but it saves an empty list 5 times, and only the last copy isused. The other 4 copies are not referenced and just spent the filevolume and the space of reference numbers. Saving[[[[['spam']*100]*100]*100]*100]*100 will result in a multigigabyte,while less than a kilobyte would be enough for saving it. Loadingproperly saved [[[[['spam']*100]*100]*100]*100]*100 withe the currentplistlib.loads() will cause consuming many gigabytes of memory.1. The issues with plistlib.dumps() are:1a) Inefficient saving data with references. This is minor resource usage issue.1b) Impossibility to save a data with cyclic references. This is alack of a feature.2. The issues with plistlib.loads() are:2a) Inefficient loading data with references. This can be not just aresource usage issue, but a security issue. Loading an malicious inputdata smaller than 100 byte ([[[...]*2]*2]*2) can cause consuming manygigabytes of memory.2b) Impossibility to load a data with cyclic references. This is alack of a feature, but can be lesser security issue. Small maliciousinput can cause RecursionError. If the recursion limit is set high andyou are unlucky it can cause a stack overflow.Security issues affect you only when you load plists from untrusted sources.Adding the proper support of references could be considered a newfeature, but taking to account security issues it should be backportedup to 3.4 when the support of binary plists was added.
msg307145 -(view)Author: Serhiy Storchaka (serhiy.storchaka)*(Python committer)Date: 2017-11-28 17:09
Ronald, could you please make a review? I want to merge this before 3.7.0a3.
msg307344 -(view)Author: Serhiy Storchaka (serhiy.storchaka)*(Python committer)Date: 2017-11-30 21:26
New changeseta897aeeef647259a938a36cb5eb6680c86021c6a by Serhiy Storchaka in branch 'master':bpo-32072: Fix issues with binary plists. (#4455)https://github.com/python/cpython/commit/a897aeeef647259a938a36cb5eb6680c86021c6a
msg307347 -(view)Author: Serhiy Storchaka (serhiy.storchaka)*(Python committer)Date: 2017-11-30 22:15
New changeset8cd31082fba88cf0064590fd3d55b6c1c964f11c by Serhiy Storchaka (Miss Islington (bot)) in branch '3.6':bpo-32072: Fix issues with binary plists. (GH-4455) (#4654)https://github.com/python/cpython/commit/8cd31082fba88cf0064590fd3d55b6c1c964f11c
msg309059 -(view)Author: Serhiy Storchaka (serhiy.storchaka)*(Python committer)Date: 2017-12-26 11:03
For example:a = []for i in range(22):    a = [a, a]b = plistlib.dumps(a, fmt=plistlib.FMT_BINARY)The result is 130 bytes long on patched plistlib. But plistlib.dumps(b) will expand to a structure consuming almost a gigabyte of memory on unpatched plistlib. Increasing the level of nesting by one will duplicate memory consumption, so it is easy to consume all available memory on any computer.
msg310411 -(view)Author: Larry Hastings (larry)*(Python committer)Date: 2018-01-22 10:18
New changesetc59731d92dc73111d224876f1caa064097aad786 by larryhastings (Serhiy Storchaka) in branch '3.4':[3.4]bpo-32072: Fix issues with binary plists. (GH-4455) (#4658)https://github.com/python/cpython/commit/c59731d92dc73111d224876f1caa064097aad786
msg310497 -(view)Author: Larry Hastings (larry)*(Python committer)Date: 2018-01-23 11:21
New changeset43f014d3f12468edf61046f0612edc7660042fd5 by larryhastings (Serhiy Storchaka) in branch '3.5':[3.5]bpo-32072: Fix issues with binary plists. (GH-4455) (#4656)https://github.com/python/cpython/commit/43f014d3f12468edf61046f0612edc7660042fd5
msg311336 -(view)Author: Serhiy Storchaka (serhiy.storchaka)*(Python committer)Date: 2018-01-31 15:42
Thanks Larry.
msg311339 -(view)Author: Larry Hastings (larry)*(Python committer)Date: 2018-01-31 16:06
Thank you for the fix!  I just wish I knew what plists were ;-)
msg311595 -(view)Author: Ronald Oussoren (ronaldoussoren)*(Python committer)Date: 2018-02-04 10:33
@larry: plists are Apple's equivalent to Windows INI files ;-)
History
DateUserActionArgs
2022-04-11 14:58:54adminsetgithub: 76253
2019-05-10 18:17:40ned.deilysetmessages: -msg342093
2019-05-10 17:36:38ned.deilysetmessages: +msg342093
2018-02-04 10:33:45ronaldoussorensetmessages: +msg311595
2018-01-31 16:06:43larrysetmessages: +msg311339
2018-01-31 15:42:32serhiy.storchakasetstatus: open -> closed
resolution: fixed
messages: +msg311336

stage: patch review -> resolved
2018-01-23 11:21:23larrysetmessages: +msg310497
2018-01-22 10:18:07larrysetmessages: +msg310411
2017-12-26 11:03:38serhiy.storchakasetmessages: +msg309059
2017-12-25 09:32:28serhiy.storchakalinkissue31988 superseder
2017-11-30 22:15:35serhiy.storchakasetmessages: +msg307347
2017-11-30 21:50:34serhiy.storchakasetpull_requests: +pull_request4570
2017-11-30 21:43:52serhiy.storchakasetpull_requests: +pull_request4568
2017-11-30 21:28:49serhiy.storchakasetnosy: +larry
2017-11-30 21:26:20python-devsetpull_requests: +pull_request4566
2017-11-30 21:26:13serhiy.storchakasetmessages: +msg307344
2017-11-28 17:09:37serhiy.storchakasetmessages: +msg307145
2017-11-18 19:16:37serhiy.storchakasetkeywords: +patch
stage: patch review
pull_requests: +pull_request4393
2017-11-18 19:06:16serhiy.storchakacreate
Supported byThe Python Software Foundation,
Powered byRoundup
Copyright © 1990-2022,Python Software Foundation
Legal Statements

[8]ページ先頭

©2009-2026 Movatter.jp