Skip to content
This repository has been archived by the owner on Apr 13, 2020. It is now read-only.

Tool for generating HTML from SMS Backup & Restore archives.

License

Notifications You must be signed in to change notification settings

brokensandals/sms_backup_renderer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SmsBackupRenderer

Build Status

This tool reads backup files created by SMS Backup & Restore and generates static HTML files for viewing their contents.

It supports both SMS and MMS messages, including images and videos. It attempts to create readable conversation-style views.

(I am not affiliated with Carbonite in any way.)

Installation

$ gem install sms_backup_renderer

Usage

$ sms_backup_renderer PATH_TO_XML_ARCHIVE PATH_TO_OUTPUT_DIRECTORY

I suggest creating a new, empty directory to use as the output directory the first time you run this, since multiple files and subdirectories will be created within it.

After the command runs, the output directory will contain an index.html file you can open in your browser.

Output

You can browse sample pages generated by the tool at this link. Screenshot:

screenshot of generated conversation page

Caveats

The backup files may represent the same number in different ways (e.g +1 (234) 567-8901 and 2345678901) at different times. In order to group all messages for the same number into the same conversation, sms_backup_renderer must try to normalize the numbers into a consistent format. Currently, the way this is done is pretty hacky and only knows about the US country code. Non-US numbers might be grouped incorrectly in some cases.

Determining the contact names for group MMS messages also relies on some pretty hacky code. It probably won't work right if you have contact names containing commas. It may not work right anyway - I'm not sure if the assumptions it makes about the backup archive are always true, or if they are coincidental implementation details that may be affected by the messaging software on your phone.

Videos do not currently play in Chrome, and possibly other browsers, though they do in Safari. I haven't figured out why yet. You can still open the video file directly in the output directory (or download it through your browser) to play it.

Development

After checking out the repo, run bin/setup to install dependencies. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Testing

There are some very basic rspec tests which run the renderer on a sample archive. To view the generated HTML in your browser, run

$ KEEP_TEST_OUTPUT=1 bundle exec rspec

Then open tmp/test-output/index.html.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/brokensandals/sms_backup_renderer.

License

The gem is available as open source under the terms of the MIT License.

About

Tool for generating HTML from SMS Backup & Restore archives.

Resources

License

Stars

Watchers

Forks

Packages

No packages published