A fast, one-way file synchronization tool for your projects.
Local changes can be transferred on the remote infrastructure using the SCP or SSH protocols. Other notable features include:
- password and key pair authentication
- support for key pairs with and without passphrases
- timestamp preserving
- file filtering
- user-friendly UI with support for IntelliJ's New UI feature
- synchronization of single or multi-selection files as well as VCS changes
Upgrade to Sourcesync Pro for more features and a more streamlined way of transferring code.
Features | Sourcesync | Sourcesync Pro |
---|---|---|
License | Free & opensource | Starts at $5.99 USD per user/month |
SCP File Upload | Yes | Yes |
SCP Folder Upload | No | Yes - Recursive Upload |
SSH/SFTP File Upload | Yes | Yes |
SSH/SFTP Folder Upload | No | Yes - Recursive Upload |
Auto Transfer On File Save | No | Yes |
Support For Comparing Local vs Remote Files | No | Yes |
SCP/SSH Password Authentication | Yes | Yes |
SCP/SSH Key-Pair Authentication With & Without Passphrase | Yes | Yes |
SCP/SSH timestamp preserving | Modification Time | Permissions, Access & Modification times |
File Filtering | Yes | Yes |
User-friendly UI with support for IntelliJ's New UI feature | Yes | Yes |
Customizable keyboard shortcuts | Yes | Yes |
VCS Changes Upload | Yes | Yes |
Multi-selection File Upload | Yes | Yes |
Multi-selection Folder Upload | No | Yes |
Editor File Upload | Yes | Yes |
Sourcesync plugin can be found at http://plugins.jetbrains.com/plugin/7374?pr=idea_ce
Details about how to install a plugin from JetBrains plugin repository can be found at: http://www.jetbrains.com/idea/webhelp/installing-updating-and-uninstalling-repository-plugins.html
-
Launch the IDE and install the plugin.
-
Restart the IDE.
-
Configure one or more remote sync configurations to target the remote environment where you would like to transfer your changes. To create or edit your sync configurations you would have to:
-
locate the Sourcesync Configurations combo box in the IntelliJ's main toolbar panel.
-
Click the combo box drop down icon and then hit the Edit Sourcesync Configurations button.
-
In the new Sourcesync Remote Configurations dialog, click + on the toolbar or press
Alt + Insert
. The list shows the SCP&SSH templates available for configuration. -
Specify the sync configuration name in the Name field. This name will be shown in the list of the available sync configurations.
-
Fill in the connection details like host, username and password or certificate, depending on the desired authentication type.
-
Specify the remote base path (excluding the project name) where your files will be transferred.
-
Apply the changes and close the dialog.
-
-
From the Sourcesync Configurations combo box select a sync configuration as primary target
-
Select one or more files, right click, and in the context menu select Sync selected files to target name. Alternatively, press
Ctrl + Shift + F2
-
Alternatively only the file under edit (focused editor) could be transferred by right click in the editor, and in the context menu select Sync this file to target name or just press
Ctrl + Shift + F1
-
A third option is to sync all Git changed files by right click in the editor or Project toolbar, and then select Sync changed files to target name. Alternatively, press
Ctrl + Shift + F3
-
Where are my files transferred?
Files are transferred on the remote host selected as the main target in the Sourcesync Configurations combo box. Sourcesync keeps the remote project structure similar to the local one, except the project's base path which will be replaced on the remote target with the Workspace configuration value.
For example, say the Workspace remote path is configured to
/home/ifaur/workspace
, and your local project is placed inC:\\Users\\ifaur\\IdeaProjects\\my-awesome-project
then a local file placed insrc\\main\\kotlin\\com\\mypackage\\MyFile.kt
will be transferred to/home/ifaur/workspace/my-awesome-project/src/main/kotlin/com/mypackage/MyFile.kt
-
Where are the sync configurations stored?
Sourcesync keeps sync configurations per project, and it stores its data in the project's
.idea/sourcesync.xml
-
Where are passwords and certificate passphrases stored?
Sourcesync makes use of IntelliJ's own credential store framework to securely save sensitive data. IntelliJ IDEA does not have its own password store. It uses either the native password management system or KeePass.
-
There are errors when trying to load or persist sync configurations. What do I do next?
You can simply remove
.idea/sourcesync.xml
from the project's folder and restart IntelliJ. You will have to reconfigure your sync targets.
Sourcesync is licensed under MIT License. Please take a look at the LICENSE file for more informations.
Bugs can be reported at https://github.com/fioan89/sourcesync/issues