Skip to main content

File sync utility

Project description

Synecure

Synecure provides a command line program called sy that allows easy synchronization of files and directories over SSH between different machines. It is mostly a wrapper around bsync, which is itself based on the standard UNIX tool rsync.

This is beta software and comes with NO GUARANTEES that it will keep your data safe. It should not be used as backup solution.

Install

pip install synecure

Usage

# Sync local ~/directory with remote $HOME/directory on me@awesome.person
sy ~/directory -r me@awesome.person

# Sync current directory with the same path on me@awesome.person, port 2222
sy -r me@awesome.person -p 2222

# Synchronize to a named remote from your SSH config
sy -r me

# Synchronize the current directory to the last used remote (for that directory)
sy

By default, sy can take on any path within your $HOME and will set the corresponding path on the remote's $HOME. It is possible to change this behavior or synchronize paths outside of $HOME using the sy-config add-path command.

sy with no argument will sync the current directory using the last remote for that directory (you will need to use the -r flag the first time, but not subsequently).

Howto

Ignore files

Add a .bsync-ignore file in the root directory to sync with a filename or glob pattern on each line, and they will be ignored. It works more or less like .gitignore.

Putting .bsync-ignore files in subdirectories to ignore files in these subdirectories will unfortunately not work, so sy ~/x and sy ~/x/y may synchronize the contents of ~/x/y differently if both directories contain different .bsync-ignore files, or if one has an ignore file and the other does not.

Global ignores

The sy-config ignore command can be used to generally ignore files or directories:

# Edit the ignore file using $EDITOR, if it is set
sy-config ignore

# List all existing ignores
sy-config ignore -l

# Ignore all files that end with ~
# Do not forget the single quotes here, to avoid shell expansion!
sy-config ignore '*~'

# Unignore files that end with ~
sy-config ignore -r '*~'

The ignores work mostly like .gitignore or .bsync-ignore above, but they apply globally. Note that sy will also read remote-side global ignores when syncing to a remote. Global ignores are located at $HOME/.config/synecure/ignore, so a remote can define some global ignores even without installing sy remote-side. Global ignores local-side, remote-side, as well as .bsync-ignore files local-side and remote-side are all merged together.

Customize synchronization paths

To synchronize local /etc to remote /etcetera, for named remote desktop:

sy-config add-path desktop /etc /etcetera

Obviously, this will only work if the remote user has the permissions to write to /etcetera. You can have multiple remotes for the same host with different users, if that helps.

To synchronize local ~/hello to remote ~/bonjour:

sy-config add-path desktop ~/hello bonjour

Don't use ~ for the remote path, it will complete to the wrong thing.

To list available remotes and paths:

sy-config list

Sync local directories

sy-config add dropbox file://~/Dropbox

Other options

Dry run

Use the -n flag to perform a "dry run": sy (well, bsync) will report all the transfers that would occur but it will not perform them.

Use --show-plan to get the sequence of commands that sy will run.

Conflict resolution

Whenever a file was modified on both ends since the last sync, sy will ask which one you want to keep.

Use sy <options> --resolve local (or sy <options> -1) to always keep the local file without prompting, or --resolve remote (or -2) to always keep the remote file.

List directories

sy -l will list all directories that have been previously synced using the tool, along with the last remote they were synced to (remember that sy without the -r option will sync to the last remote).

Configuration files

  • ~/.config/synecure/remotes.json defines protocols and paths for named remotes.
    • You can open an editor for that file with sy-config edit
  • ~/.config/synecure/ignore lists global ignores.
    • You can open an editor for that file with sy-config ignore
  • ~/.config/synecure/directories.json maps directories to last used remotes.
  • ~/.ssh/config is the standard location to define host information for ssh.
    • For convenience, you can open an editor for that file with sy-config ssh

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

synecure-0.2.1.tar.gz (21.5 kB view hashes)

Uploaded Source

Built Distribution

synecure-0.2.1-py3-none-any.whl (20.6 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page