Skip to content

Latest commit

 

History

History
387 lines (322 loc) · 38.2 KB

CHANGELOG.md

File metadata and controls

387 lines (322 loc) · 38.2 KB

v0.30.12

v0.30.11

  • [TeamMsgExtractor #249] Fixed an error with opening the body causing the file to throw an uncaught exception in the __init__ function of MessageBase. The error may still come up later, but you will still have general access to the instance.
  • Fixed an issue with part of the command line documentation.

v0.30.10

  • [TeamMsgExtractor #249] Fixed exception catching not properly accessing the exception (forgot to go through one of the submodules to access exception).
  • Updated docstring for MessageBase.deencapsulatedRtf.

v0.30.9

  • Fixed the behavior of Properties.get so it actually behaves like a dict (that was the intent of it, but I did it the wrong way for some reason).
  • Fixed a type that caused an exception when no HTML body could be found nor generated.

v0.30.8

  • Update imapclient requirement to >=2.1.0 instead of ==2.1.0. Currently there are no changes that would prevent current future versions from working.

v0.30.7

  • [TeamMsgExtractor #239] Fixed msg.py not having import pathlib.
  • After going through the details of the example MSG files provided with the module, specifically unicode.msg, I now am glad I decided to put in some fail-safes in the HTML body processing. One of them does not have an <html>, <head>, nor <body> tag, and so would have had an error. This will actually prevent the header from injecting properly as well, so a bit of validation before was made necessary to ensure the HTML saving would still work.
  • Added new exception BadHtmlError.
  • Added new function utils.validateHtml.
  • Updated README credits.
  • Changed header logic to generate manually if the header data has been stripped (filled with null bytes) and not just if the stream does not exist.

v0.30.6

  • Small adjustments to internal code to make it a bit better.
  • Added Message.getSaveBody, Message.getSaveHtmlBody, and Message.getSaveRtfBody. These three functions generate their respective bodies that will be used when saving the file, allowing you to retrieve the final products without having to write them to the disk first. All arguments that are passed to Message.save that would influence the respective bodies are passed to their respective functions.
  • I thought I added the documentation for attachmentsOnly to Message.save but apparently it was missing. Not sure what happened there but I made sure it was added this time.
  • Added new option to Message.save called charset. This is used in the preparation of the HTML body when using preparedHtml. This is also usable with --charset CHARSET from the command line.

v0.30.5

  • [TeamMsgExtractor #225] Added the ability to generate the HTML body from the RTF body if it is encapsulated HTML. If there is no RTF body, then it will do a very basic generation from the plain text body. This process is automatically performed if the HTML body is missing.
  • Added the ability for the plain text body to sometimes generate from the RTF body if the plain text body does not exist.
  • Added documentation to Message.save for the attachmentsOnly option.

v0.30.4

  • [TeamMsgExtractor #233] Added option to Message.save to only save the attachments (attachmentsOnly). This can also be used from the command line with the option --attachments-only.
  • Corrected error string for incompatible options in Message.save.
  • Fixed if blocks being nested weirdly in Message.save instead of being chained with elif. Probably an artifact left from adding support for HTML and RTF.

v0.30.3

  • [TeamMsgExtractor #232] Updated list of known MSG class types so the module would correctly give UnsupportedMSGTypeError instead of UnrecognizedMSGTypeError.

v0.30.2

  • Fixed typo in utils.knownMsgClass.
  • Updated contributing guidelines and pull request template. Pull requests were updated to match the new structure of the module while the guidelines were updated for clarity.

v0.30.1

  • [TeamMsgExtractor #102] Added property MessageBase.htmlBodyPrepared which provides the HTML body that has been prepared for actual use or conversion to PDF. All attachments that can be injected into the body directly will be injected.
  • Corrected a mistake in the documentation of Message.save.
  • Fixed issue where the command line parser was not checking for raw in conjunction with other saving options.
  • Changed utils.setupLogging to use pathlib.
  • Improved reliability of the logic in utils.setupLogging.
  • Removed function utils.getContFileDir.
  • Cleaned up plain Exception being raised at the end of utils.injectRtfHeader if the injection failed. This now raises RuntimeError, an error that should be reported so the injection system can be improved.
  • Added parsing for PtypServerId to utils.parseType.
  • Added FolderID, MessageID, and ServerID to data.
  • Added zip output to the command line.
  • Added support for PtypMultipleFloatingTime to utils.parseType.
  • Improved documentation of many functions with the exceptions they may raise.
  • Changed the way zip files are handled so that files written to them actually have a modification date now.

v0.30.0

  • Removed all support for Python 2. This caused a lot of things to be moved around and changed from indirect references to direct references, so it's possible something fell through the cracks. I'm doing my best to test it, but let me know if you have an issue.
  • Changed classes to now prefer super() over direct superclass initialization.
  • Removed explicit object subclassing (it's implicit in Python 3 so we don't need it anymore).
  • Converted most .formats into f strings.
  • Improved consistency of docstrings. It's not perfect, but it should at least be better.
  • Started the addition of type hints to functions and methods.
  • Updated utils.bytesToGuid to make it faster and more efficient.
  • Renamed utils.msgEpoch to utils.filetimeToUtc to be more descriptive.
  • Updated internal variable names to be more consistent.
  • Improvements to the way __main__ works. This does not affect the output it will generate, only the efficiency and readability.

v0.29.3

  • [TeamMsgExtractor #226] Fix typo in command parsing that prevented the usage of allowFallback.
  • Fixed main still manually navigating to a new directory with os.chdir instead of using customPath.
  • Fixed issue in main where the --html option was being using for both html and rtf. This meant if you wanted rtf it would not have used it, and if you wanted html it would have thrown an error.
  • Fixed --out-name having no effect.
  • Fixed --out having no effect.

v0.29.2

  • Fixed issue where the RTF injection was accidentally doing HTML escapes for non-encapsulated streams and not doing escapes for encapsulated streams.
  • Fixed name error in Message.save causing bad logic. For context, the internal variable zip was renamed to _zip to avoid a name conflict with the built-in function. Some instances of it were missed.

v0.29.1

  • [TeamMsgExtractor #198] Added a feature to save the header in it's own file (prefers the full raw header if it can find it, otherwise puts in a generated one) that was actually supposed to be in v0.29.0 but I forgot, lol.

v0.29.0

  • [TeamMsgExtractor #207] Made it so that unspecified dates are handled properly. For clarification, an unspecified date is a custom value in MSG files for dates that means that the date is unspecified. It is distinctly different from a property not existing, which will still return None. For unspecified dates, datetime.datetime.max is returned. While perhaps not the best solution, it will have to do for now.
  • Fixed an issue where utils.parseType was returning a string for the date when it makes more sense to return an actual datetime instance.
  • [TeamMsgExtractor #165] [TeamMsgExtractor #191] Completely redesigned all existing save functions. You can now properly save to custom locations under custom file names. This change may break existing code for several reasons. First, all arguments have been changed to keyword arguments. Second, a few keyword arguments have been renamed to better fit the naming conventions.
  • [TeamMsgExtractor #200] Changed imports to use relative imports instead of hard imports where applicable.
  • Updated the save functions to no longer rely on the current working directory to save things. The module now does what it can to use hard pathing so that if you spontaneously change working directory it will not cause problems. This should also allow for saving to be threaded, if I am correct.
  • [TeamMsgExtractor #197] Added new property Message.defaultFolderName. This property returns the default name to be used for a Message if none of the options change the name.
  • [TeamMsgExtractor #201] Fixed an issue where if the class type was all caps it would not be recognized. According to the documentation the comparisons should have been case insensitive, but I must have misread it at some point.
  • [TeamMsgExtractor #202] Module will now handle path lengths in a semi-intelligent way to determine how best to save the MSG files. Default path length max is 255.
  • [TeamMsgExtractor #203] Fixed an issue where having multiple "." characters in your file name would cause the directories to be incorrectly named when using the useFileName (now useMsgFilename) argument in the save function.
  • [TeamMsgExtractor #204] Fixed an issue where the failsafe name used by attachments wasn't being encoded before hand causing encoding errors.
  • MSG files with a type of simply IPM will now be returned as MSGFile by openMsg, as this specifies that no format has been specified.
  • [TeamMsgExtractor #214] Attachments that error because the MSG class type wasn't recognized or isn't supported will now correctly be UnsupportedAttachment instead of BrokenAttachment.
  • Improved internal code in many functions to make them faster and more efficient.
  • openMsg will now tell you if a class type is simply unsupported rather than unrecognized. If it is found in the list, the function will raise UnsupportedMSGTypeError.
  • Added caching to MSGFile.listDir. I found that if you have larger files this single function might be taking up over half of the processing time because of how many times it is used in the module.
  • Fully implemented raw saving.
  • Extended the Contact class to have more properties.
  • Added new function MSGFile._ensureSetTyped which acts like the other ensure set functions but doesn't require you to know the type. Prefer to use other ensure set function when you know exactly what type it will be.
  • Changed Message.saveRaw to MSGFile.saveRaw.
  • Changed MSGFile.saveRaw to take a path and save the contents to a zip file.
  • Corrected the help doc to reflect the current repository (was still on mattgwwalker).
  • Fixed a bug that would cause an exception on trying to access the RTF body on a file that didn't have one. This is now correctly returning None.
  • The raw keyword of Message.save now actually works.
  • Added property Attachment.randomFilename which allows you to get the randomly generated name for attachments that don't have a usable one otherwise.
  • Added function Attachment.regenerateRandomName for creating a new random name if necessary.
  • Added function Attachment.getFilename. This function is used to get the name an attachment will be saved with given the specified arguments. Arguments are identical to Attachment.save.
  • Changed pull requests to reflect new style.
  • Added additional properties for defined MSG file fields.
  • Added zip file support for the Attachment.save and Message.save. Simply pass a path for the zip keyword argument and it will create a new ZipFile instance and save all of it's data inside there. Alternatively, you can pass an instance of a class that is either a ZipFile or ZipFile-like and it will simply use that. When this argument is defined, the customPath argument refers to the path inside the zip file.
  • Added the html and rtf keywords to Message.save. These will attempt to save the body in the html or rtf format, respectively. If the program cannot save in those formats, it will raise an exception unless the allowFallback keyword argument is True.
  • Changed utils.hasLen to use hasattr instead of the try-except method it was using.
  • Added new option recipientSeparator to MessageBase allowing you to specify a custom recipient separator (default is ";" to match Microsoft Outlook).
  • Changed the openMsg function in Attachment to not be strict. This allows you to actually open the MSG file even if we don't recognize the type of embedded MSG that is being used.
  • Attempted to normalize encoding names throughout the module so that a certain encoding will only show up using one name and not multiple.
  • Finally figured out what CRC32 algorithm is used in named properties after directly asking in a Microsoft forum (see the thread here). Fortunately the is already defined in the compressed-rtf module so we can take advantage of that.
  • Reworked MessageBase._genRecipient to improve it (because what on earth was that code it was using before?). Variables in the function are now more descriptive. Added comments in several places.
  • Many renames to better fit naming convention:
    • dev.setup_dev_logger to dev.setupDevLogger.
    • MSGFile.fix_path to MSGFile.fixPath.
    • MessageBase.save_attachments to MessageBase.saveAttachments.
    • *.Exists to exists.
    • *.ExistsTypedProperty to *.existsTypedProperty.
    • prop.create_prop to prop.createProp.
    • Properties.attachment_count to Properties.attachmentCount.
    • Properties.next_attachment_id to Properties.nextAttachmentId.
    • Properties.next_recipient_id to Properties.nextRecipientId.
    • Properties.recipient_count to Properties.recipientCount.
    • utils.get_command_args to utils.getCommandArgs.
    • utils.get_full_class_name to utils.getFullClassName.
    • utils.get_input to utils.getInput.
    • utils.has_len to utils.hasLen.
    • utils.setup_logging to utils.setupLogging.
    • constants.int_to_data_type to constants.intToDataType.
    • constants.int_to_intelligence to constants.intToIntelligence.
    • constants.int_to_recipient_type to constants.intToRecipientType.
    • Misc internal function variables.

v0.28.7

  • Added hex versions of the MULTIPLE_X_BYTES constants.
  • Added 1048 to constants.MULTIPLE_16_BYTES
  • [TeamMsgExtractor #173] rewrote the parsing of the length in VariableLengthProp.__init__ to use constants rather than values coded directly into the function. This should fix this issue.

v0.28.6

  • [TeamMsgExtractor #191] This feature was never properly implemented, so it's not officially supported. However, this specific issue should be fixed. This is a temporary patch until I can get around to rewriting the way the module saves files in general.
  • Added venv to the .gitignore list.
  • Added information to the readme.

v0.28.5

  • [TeamMsgExtractor #189] Forgot to import prepareFilename in attachment.py.
  • Fixed bad link in the changelog.

v0.28.4

  • [TeamMsgExtractor #184] Added code to Message to ensure subjects with null characters get stripped of them.
  • Moved code for stripping subjects of bad characters to prepareFilename in utils.

v0.28.3

  • Fixed minor typo in an exception description.
  • Updated the README this time. Forgot to do it for at least 1 update.

v0.28.2

  • Started preparing more of the code for when HTML and RTF saving are fully implemented. Please note that they do not work at all right now. Commented out the code for this because it wasn't meant to be uncommented.
  • [TeamMsgExtractor #184] Added code to ensure file names don't have null characters when saving an attachment.
  • Minor improvement to the section of the save code that checks if you have provided incompatible options.
  • [TeamMsgExtractor #185] Added the IncompatibleOptionsError. It was supposed to be added a few updates ago, but was accidentally left out.
  • Modified Message.save to return the current Message instance to allow for chained commands. This allows you to do something like extract_msg.openMsg("path/to/message.msg").save().close() where you could not before.

v0.28.1

  • [TeamMsgExtractor #181] Fixed issue in Attachment that arose when moving some of the code to a base class.
  • Fixed small error in utils.parse_type that caused it to incorrectly compare expected and actual length. Fortunately, this had no actual effect aside from a warning.
  • Added the ebcdic module to the requirements to add more supported encodings.

v0.28.0

  • [TeamMsgExtractor #87] Added a new system to handle NotImplementedError and other exceptions. All msg classes now have an option called attachmentErrorBehavior that tells the class what to do if it has an error. The value should be one of three constants: ATTACHMENT_ERROR_THROW, ATTACHMENT_ERROR_NOT_IMPLEMENTED, or ATTACHMENT_ERROR_BROKEN. ATTACHMENT_ERROR_THROW tells the class to not catch and exceptions and just let the user handle them. ATTACHMENT_ERROR_NOT_IMPLEMENTED tells the class to catch NotImplementedError exceptions and put an instance of UnsupportedAttachment in place of a regular attachment. ATTACHMENT_ERROR_BROKEN tells the class to catch all exceptions and either replace the attachment with UnsupportedAttachment if it is a NotImplementedError or BrokenAttachment for all other exceptions. With both of those options, caught exceptions will be logged.
  • In making the previous point work, much code from Attachment has been moved to a new class called AttachmentBase. Both BrokenAttachment and UnsupportedAttachment are subclasses of AttachmentBase meaning data can be extracted from their streams in the same way as a functioning attachment.
  • [TeamMsgExtractor #162] Pretty sure I actually got it this time. The execution flag should be applied by pip now.
  • Fixed typos in some exceptions

v0.27.16

  • [TeamMsgExtractor #177] Fixed incorrect struct being used. It should be the correct one now, but further testing will be required to confirm this.
  • Fixed log error message in extract_msg.prop to actually format a value into the message.

v0.27.15

v0.27.14

  • [TeamMsgExtractor #173] Fixed typo that I made in the last version that broke things. I didn't have the resources to test this one myself, unfortunately.
  • Fixed a typo in an exception message.

v0.27.13

  • [TeamMsgExtractor #173] Moved some data used in checks into constants so that I can make sure they get changed every where that they are used. Hopefully I can close this issue.

v0.27.12

  • [TeamMsgExtractor #173] Made an assumption about where an exception was thrown from and was wrong. While that location would have throw an exception, the function that called that code was the one to actually throw the exception in question. This issue should be fixed...
  • [TeamMsgExtractor #162] Made another attempt to fix the execution flag on the wrapper script.

v0.27.11

  • [TeamMsgExtractor #173] Tentatively implemented type 0x1014 (PtypMultipleInteger64). Apparently I forgot to do it earlier.

v0.27.10

  • [TeamMsgExtractor #162] Fixed line endings in the wrapper script to be UNIX line endings rather than Windows line endings. Attempted to add the execution flag to the runnable script.

v0.27.9

  • [TeamMsgExtractor #161] Added commands to the command line that will allow the user to specify that they want the message data to be output to stdout rather than to a file.
  • [TeamMsgExtractor #162] Added a wrapper for extract_msg that will be installed.
  • Fixed some of the encoding names to allow them to actually be used in Python. The names they previously held were not aliases that currently exist.
  • Added more documentation to constants.CODE_PAGES to give more information about what it is. As it is a list of the possible encodings an msg file can use, I also specified which ones were supported by Python 3.
  • Moved the main code into a function so it is now callable from outside of the file.

v0.27.8

  • [TeamMsgExtractor #158] Fixed a spelling error in a function name that was causing it to not be seen. The function was called ceilDiv but was accidentally called as cielDiv.

v0.27.7

  • Fixed an issue in the new bitwise adjustment functions. One of the variable names was incorrect.

v0.27.6

  • Fixed a few lines in data.py.

v0.27.5

  • Fixed an error in utils.divide that would cause it to drop the extra data if there was not enough to create a full division. For example, if you had a string that was 10 characters, and divided by 3, you would only receive a total of 9 characters back.
  • Added some useful functions that will be used in the future.
  • [TeamMsgExtractor #155] Updated to use new version of tzlocal.
  • Updated changelog to fit new repository.

v0.27.4

v0.27.3

  • [TeamMsgExtractor #105] Added code to fix an internal msg issue that had recipient lists being split up in the header after a certain amount of characters. This was now a bug on our part, but an issue with the generation of the msg file itself.
  • Exposed the MessageBase class directly from extract_msg. I forgot to do this when I created it.
  • Added MessageBase.bcc. I think it used to exist but got erased somehow on accident. Either way, it exists now.

v0.27.2

  • After much debate, I have finally decided to allow an option to override the string encoding in message files. This Was something I reserved solely for dev_classes.Message because it felt like it didn't fit with how msg files were supposed to work. I also didn't want messages from people about them running into errors after they overrode the encoding. You can now do this by providing the overrideEncoding option on any MSGFile class as well as the openMsg function.
  • [TeamMsgExtractor #103] Implemented correct detection of encodings. If you have any more issues with "'X' codec can't decode bytes" it is likely because the encoding specified inside the msg file is wrong.

v0.27.1

  • [TeamMsgExtractor #147] Fixed an issue in Message.save caused by it attempting to directly access a private variable that was moved to the base class MessageBase.

v0.27.0

  • [TeamMsgExtractor #143] Added new class Appointment that can handle outlook appointments or meetings.
  • [TeamMsgExtractor #143] Added new class MessageBase for classes that end up being mostly like the Message class. Currently subclassed by Message and Appointment. This should not have a direct effect on any code that uses this module.
  • Added support for PtypFloatingTime in utils.parseType.
  • Added proper support for PtypTime in FixedLengthProp.parseType
  • Added pretty print functions to the Properties class and the Named class.
  • Added new function MSGFile._ensureSetProperty that acts like MSGFile._ensureSet except that it works with properties from the Properties instance.
  • Added equivalent of the previously mentioned function to the Attachment class and the Recipient class.

v0.26.4

  • Added new function MSGFile._ensureSetNamed which acts like MSGFile._ensureSet except that it works with named properties.
  • Added a version of the previous function to the Attachment and Recipient classes.
  • Added new file data.py that contains various data structures that are used for specific properties.
  • Expanded the functionality of the Recipient class by adding more properties.
  • Added new functions Named.getNamed and Named.getNamedValue which retrieves a named property or the value of a named property, respectively, based on its name.

v0.26.3

  • Added new function MSGFile.save that causes it and subclasses to raise a NotImplementedError if they do not override it.
  • Fixed some issues in the changelog.
  • Added some additional constants for future use.

v0.26.2

  • Fixed error in Message._registerNamedProperty where I put the exception KeyError instead of AttributeError.

v0.26.1

  • Fixed an issue in openMsg that would leave the basic MSGFile instance open with the function returned, even if the function was returning a specific msg instance.

v0.26.0

  • [TheElementalOfDestruction #3] Implementation of Named properties has finally been added. This allows us to access certain data that was not available to us before through regular methods.
  • Added new function MSGFile.slistDir that acts like MSGFile.listDir, except that it returns a list of strings rather than a list of lists.
  • [TheElementalOfDestruction #6] Added new function MSGFile._getTypedStream which, based on a path formatted in the same way as you would give to MSGFile._getStringStream, will return the data in the specified stream without the user needing to know the type before hand. However, if you DO know the type before hand, you can provide this function with one of the values in constants.FIXED_LENGTH_PROPS_STRING or constants.VARIABLE_LENGTH_PROPS_STRING.
  • [TheElementalOfDestruction #6] Added new function MSGFile._getTypedProperty which, based on a 4 digit hexadecimal string, will return the property in the properties file that matches that string without the type needing to be specified. However, if you DO know the type before hand, you can provide this function with one of the values in constants.FIXED_LENGTH_PROPS_STRING or constants.VARIABLE_LENGTH_PROPS_STRING.
  • [TheElementalOfDestruction #6] Added new function MSGFile._getTypedData which is a combination of the two previously stated functions.
  • Added new function MSGFile.ExistsTypedProperty which determines if a property with the specified id exists in the specified location. If you are looking for a property that may be in the properties file of an attachment or a recipient, please use the corresponding function from that class.
  • Added an equivalent of the previous 4 functions for the Recipient and Attachment classes.
  • [TheElementalOfDestruction #2] Finished partial implementation of utils.parseType which was necessary for the proper implementation of named properties. This function is not fully implemented because there are some types we do not fully understand.

v0.25.3

v0.25.2

  • [TeamMsgExtractor #134] Fixed a typo that caused Message.headerDict to raise an exception.
  • Upgraded code for Message.headerDict to avoid accidentally raising a key error if the header is ever missing the "Received" property.
  • Fixed an error in the changelog that caused some issue links to link to the wrong place.

v0.25.1

  • [TeamMsgExtractor #132] Fixed an issue caused by unfinished code being left in the __main__ file.
  • Cleaned up the imports to only be what is needed.

v0.25.0

  • Added new class MSGFile. The Message class now inherits from this. This class is the base for all MSG files, not just Messages. It somewhat recently came to our attention that MSG files are used for a variety of things, including the storage of contacts, leading us to the next part of the changelog.
  • [TeamMsgExtractor #110] Added new class Contact for extracting the data from MSG files storing contacts.
  • Added new function openMsg to the module to be used to open MSG files in which it is not certain what type of MSG is being opened.
  • Modified the Attachment class to use the openMsg function to open embedded MSG files.
  • Added option delayAttachments to the Message class that will stop it from initializing attachments until the user is ready. This allows users to open Messages that have unimplemented attachment types without having to worry about the exception stopping them. This is also an option in the new openMsg function.

v0.24.4

  • Added new property Message.isRead to show whether the email has been marked as read.
  • Renamed Message.header_dict to Message.headerDict to better match naming conventions.
  • Renamed Message.message_id to Message.messageId to better match naming conventions.

v0.24.3

  • Added new close function to the Message class to ensure that all embedded Message instances get closed as well. Not having this was causing issues with trying to modify the msg file after the user thought that it had been closed.

v0.24.2

  • Fixed bug that somehow escaped detection that caused certain properties to not work.
  • Fixed bug with embedded msg files introduced in v0.24.0

v0.24.0

  • [TeamMsgExtractor #107] Rewrote the Messsage.save function to fix many errors arising from it and to extend its functionality.
  • Added new function isEmptyString to check if a string passed to it is None or is empty.

v0.23.4

v0.23.3

  • Fixed issues in readme.
  • [TheElementalOfDestruction #22] Updated dev_classes.Message to better match the current Message class.
  • Fixed bad links in changelog.
  • [TeamMsgExtractor #95] Added fallback encoding as well as manual encoding change to dev_classes.Message.

v0.23.1

  • Fixed issue with embedded msg files caused by the changes in v0.23.0.

v0.23.0

  • [TeamMsgExtractor #75] & [TheElementalOfDestruction #19] Completely rewrote the function Message._getStringStream. This was done for two reasons. The first was to make it actually work with msg files that have their strings encoded in a non-Unicode encoding. The second reason was to make it so that it better reflected msg specification which says that ALL strings in a file will be either Unicode or non-Unicode, but not both. Because of the second part, the prefer option has been removed.
  • As part of fixing the two issues in the previous change, we have added two new properties:
    1. a boolean Message.areStringsUnicode which tells if the strings are Unicode encoded.
    2. A string Message.stringEncoding which tells what the encoding is. This is used by the Message._getStringStream to determine how to decode the data into a string.

v0.22.1

  • [TeamMsgExtractor #69] Fixed date format not being up to standard.
  • Fixed a minor spelling error in the code.

v0.22.0

  • [TheElementalOfDestruction #18] Added --validate option.
  • [TheElementalOfDestruction #16] Moved all dev code into its own scripts. Use --dev to use from the command line.
  • [TeamMsgExtractor #67] Added compatibility module to enforce Unicode os functions.
  • Added new function to Message class: Message.sExists. This function checks if a string stream exists. It's input should be formatted identically to that of Message._getStringStream.
  • Added new function to Message class: Message.fix_path. This function will add the proper prefix to the path (if the prefix parameter is true) and adjust the path to be a string rather than a list or tuple.
  • Added new function to utils.py: get_full_class_name. This function returns a string containing the module name and the class name of any instance of any class. It is returned in the format of {module}.{class}.
  • Added a sort of alias of Message._getStream, Message._getStringStream, Message.Exists, and Message.sExists to Attachment and Recipient. These functions run inside the associated attachment directory or recipient directory, respectively.
  • Added a fix to an issue introduced in an earlier version caused by accidentally deleting a letter in the code.

v0.21.0

  • [TheElementalOfDestruction #12] Changed debug code to use logging module.
  • [TheElementalOfDestruction #17] Fixed Attachment class using wrong properties file location in embedded msg files.
  • [TheElementalOfDestruction #11] Improved handling of command line arguments using argparse module.
  • [TheElementalOfDestruction #16] Started work on moving developer code into its own script.
  • [TeamMsgExtractor #63] Fixed JSON saving not applying to embedded msg files.
  • [TeamMsgExtractor #55] Added fix for recipient sometimes missing email address.
  • [TeamMsgExtractor #65] Added fix for special characters in recipient names.
  • Module now raises a custom exception (instead of just IOError) if the input is not a valid OLE file.
  • Added header_dict property to the Message class.
  • General minor bug fixes.
  • Fixed a section in the Recipient class that I have no idea why I did it that way. If errors start randomly occurring with it, this fix is why.

v0.20.8

  • Fixed a tab issue and parameter type in message.py.

v0.20.7

  • Separated classes into their own files to make things more manageable.
  • Placed __doc__ back inside of __init__.py.
  • Rewrote the Prop class to be two different classes that extend from a base class.
  • Made decent progress on completing the parse_type function of the FixedLengthProp class (formerly a function of the Prop class).
  • Improved exception handling code throughout most of the module.
  • Updated the .gitignore.
  • Updated README.
  • Added # DEBUG comments before debugging lines to make them easier to find in the future.
  • Added function create_prop in prop.py which should be used for creating what used to be an instance of the Prop class.
  • Added more constants to reflect some of the changes made.
  • Fixed a major bug that was causing the header to generate after things like "to" and "cc" which would force those fields to not use the header.
  • Fixed the debug variable.
  • Fixed many small bugs in many of the classes.
  • [TheElementalOfDestruction #13] Various loose ends to enhance the workflow in the repo.