• This is CVE-2017-9208.
    
    The QPDF library uses object ID 0 internally as a sentinel to
    represent a direct object, but prior to this fix, was not blocking
    handling of 0 0 obj or 0 0 R as a special case. Creating an object in
    the file with 0 0 obj could cause various infinite loops. The PDF spec
    doesn't allow for object 0. Having qpdf handle object 0 might be a
    better fix, but changing all the places in the code that assumes objid
    == 0 means direct would be risky.
    Jay Berkenbilt authored
     
    Browse File »
  • This is CVE-2017-9209.
    Jay Berkenbilt authored
     
    Browse File »
  • This is CVE-2017-9210.
    
    The description string for an error message included unparsing an
    object, which is too complex of a thing to try to do while throwing an
    exception. There was only one example of this in the entire codebase,
    so it is not a pervasive problem. Fixing this eliminated one class of
    infinite loop errors.
    Jay Berkenbilt authored
     
    Browse File »





  • Pushing inherited objects to pages and getting all pages were both
    prone to stack overflow infinite loops if there were loops in the
    Pages dictionary. There is a general weakness in the code in that any
    part of the code that traverses the Pages structure would be prone to
    this and would have to implement its own loop detection. A more robust
    fix may provide some general method for handling the Pages structure,
    but it's probably not worth doing.
    
    Note: addition of *Internal2 private functions was done rather than
    changing signatures of existing methods to avoid breaking
    compatibility.
    Jay Berkenbilt authored
     
    Browse File »
  • Converting a password to an encryption key is supposed to copy up to a
    certain number of bytes from a digest. Make sure never to copy more
    than the size of the digest.
    Jay Berkenbilt authored
     
    Browse File »
  • When checking two objects preceding R while parsing, ensure that the
    objects are direct. This avoids stuff like 1 0 obj containing 1 0 R 0 R
    from causing an infinite loop in object resolution.
    Jay Berkenbilt authored
     
    Browse File »

  • Original reported here:
    https://bugs.launchpad.net/ubuntu/+source/qpdf/+bug/1397413
    
    The PDF specification says that the /Type key for nodes in the pages
    dictionary (both /Page and /Pages) is required, but some PDF files
    omit them. Use the presence of other keys to determine the type of
    pages tree node this is if the type key is not found.
    Jay Berkenbilt authored
     
    Browse File »