/backup-java

A simple command-line based backup tool for backing up an organization's Smartsheet data.

Primary LanguageJavaOtherNOASSERTION

Smartsheet Account Backup Utility

License and Warranty

Copyright 2013 Smartsheet.com

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Overview

This command-line backup utility takes a snapshot of the data in a Smartsheet Team or Enterprise account and saves it to local storage. Only the sheets (including attachments and discussions) owned by users of the account are backed up.

Release History

  • Nov 9, 2018 - version 1.6.2:
  • Updated vulnerable dependencies.
  • Apr 28 2016 - version 1.6.1:
  • Changed extension of generated files from .xls to .xlsx Updated to support Smartsheet API version 2.0
  • Mar 2 2016 - version 1.6.0:
  • Updated to support Smartsheet API version 2.0
  • Feb 11 2015 - version 1.5.2:
  • Added the api error code and error response to the log if a request fails.
  • Apr 23 2014 - version 1.5.1:
  • Changed the generated backup folder name to contain a 24 hour format instead of 12 hour.
  • Mar 14 2014 - version 1.5:
  • Increased wait time for the backup to finish downloading attachments. It will now wait a very long time (2^63 days).
  • Mar 11 2014 - version 1.4:
  • Sheet attachments are now created at the time of download, not any earlier.
  • On 500 errors the backup utility will wait and try to retrieve the data multiple times.
  • Increased error logging.
  • Better handling of unique names for attachments with duplicate file names.
  • Enhanced sheet attachment handling so that two threads will not try to write to the same file at the same time.
  • Feb 27 2014 - version 1.3:
  • Fixed issue where some files were downloading with a file size of 0 bytes.
  • Changed default download timeout to over 2 days.
  • Files are now backed up to a time stamped sub-folder in the backup directory
  • Better error handling when a file or attachment is deleted while the backup is running.
  • Added a user agent to API requests.
  • Feb 24 2014 - version 1.2: Added explicit flushing to disk.
  • Oct 24 2013 - version 1.1: improved logging, improved file download, "continueOnError" option
  • Jun 6 2013 - version 1.0

Requirements

Limitations

  • Only multi-user plans (Team and Enterprise) are supported. Single-user plans (Basic and Advanced) are not supported at this time.
  • Incremental backups are not supported at this time.
  • Sheets which have been shared to the members of the Smartsheet account, but are not owned by them, will not be backed up.
  • Workspace discussions and attachments are not backed up.

How it works

  • The backup utility will create a new folder with a timestamp in the user defined back up directory. This folder is used as the base folder for the backup process.
  • For each active user in the account, the backup utility first creates a local directory that matches the user's email address, and then retrieves and backs up all the sheets owned by that user.
  • Within each user's directory, the sheets are organized hierarchically (by folders and workspaces) to match the user's Home tab hierarchy in Smartsheet.
  • Each sheet is saved as an XLS file that matches the Sheet's name, with discussions saved on a second tab inside the XLS file. All file attachments are saved in a directory named "[Sheet Name] - attachments".
  • Non-file attachments (Google Drive files, Box files, and web URLs) are stored in a file called "[Sheet Name] - non-file attachments.csv" in the same directory as the file attachments. The following properties are provided for each non-file attachment: Name, URL, and AttachmentType.

Usage

First, download the backup zipped archive here. Unzip the archive - it will contain the JAR executable and a sample properties file.

The tool will look for smartsheet-backup.properties file in the current directory (the directory from which it is being executed). Edit the properties file to set the following parameters:

  • accessToken (required) - access token that belongs to your Smartsheet account administrator. See the Requirements section above on how to get an access token
  • outputDir (required) - desired output directory. You can provide an absolute * path (e.g., "C:\some\directory") or a path relative to the directory in which the backup utility resides (e.g., "some\directory"). Note that backslashes need to be escaped in the path by using two backslashes. UNC paths are also supported and a UNC path like \Server01\backup\ would need be escaped to look like \\server01\backup.
  • zipOutputDir (optional, default is false) - set to true to create a zipped archive of the outputDir
  • continueOnError* (optional, default is false) - set to true to continue on error (instead of terminating the backup)
  • downloadThreads (optional, default is 4) - set to desired number of threads used to download attachments
  • allDownloadsDoneTimeout* (optional, default is 2^32-1) - The total number of minutes to wait for the attachment downloads to finish.

To execute the backup, run the following command java -jar smartsheet-org-backup.jar. Please replace with the current version of the backup tool - for instance, "1.5.1". You can determine the version easily by simply listing the contents of the directory and looking for the .jar file. Since it's a runnable jar, you don't need to set classpath or copy other jars. Everything you need is in the runnable jar.

Logging

  • All the messages, including what is backed up as well as the folders and files being created, are logged to stdout.
  • A divider line is logged for each active user backed up by the tool. Inactive users are skipped.
  • All the waits and retries resulting from 503 Service Unavailable errors are logged.
  • All asynchronous download requests as well as the attachments downloaded are logged.
  • The tool exits with exit code 0 on success, and -1 on failure.
  • Errors are prepended "***ERROR***" and logged.
  • Upon successful completion (no errors), the tool will output a brief summary including "*** Org backup done... ***" along with the number of users backed up and time elapsed.
  • If the "continueOnError" option is enabled, the last line will instead be a summary of the number of errors encountered, plus the path to an error log file. The error log file will contain timestamped logs of each error, with details provided to allow you to attempt manual recovery of a specific user's sheet or attachment skipped in the backup, or to simply try running the tool again.

Contributing

The source code for this utility is available on Github at https://github.com/smartsheet-platform/backup-java. If you want to contribute a fix or an enhancement, please fork the Github repository and create a pull request with your changes.

githalytics.com alpha