Realtime and cross-platform (Windows, Linux, OSX) files and folders synchronisation using NodeJs. Ideal for developers who want source code synchronization between two machines.
In short, it's like linux rsync
but bilateral, cross-platform, real-time and websocket-based.
WIP Warning not fully battle-tested, this package may contain bugs, please do not use in production and backup your files regullary.
- ✌️ Easy - NodeJs cli app for client and server with simple config.
- ⚡ Fast - Good transfer speed with websocket stream :
- Multiples small files (npm packages, long nested folders ...)
- Big files (with file streaming)
- 💡 Flexible - Multiple named folders to sync with regex exclusion
Install the package globally with npm or yarn:
npm global install @ifnot/fly-sync
- (or)
yarn add -g @ifnot/fly-sync
Copy and configure config.server.json
and start your server :
node index.js --config=/path/to/config.server.json
Copy and configure config.client.json
and start your client :
node index.js --config=/path/to/config.client.json
- server
boolean
: Tells the app to act as a server (port
became required) - port
numeric
: The port to use for the server - client
boolean
: Tells the app to act as a client (remote
became required) - remote
string
: The complete WebSocket URL where the client should attempt to connect (example:ws://127.0.0.1:6666
) - temp_path
string
: The temporary folder to use for receiving file streams - paths
array
: list of all paths to sync- id
string
: The id of the folder to sync (ids should match between server and client) - path
string
: The absolute path of the folder to sync - only
string
: The whitelist regex for filtering relative files paths - except
string
: The blacklist regex for filtering relative files paths
- id
- File change detection using a native C++ Node module for querying and subscribing to filesystem events. The same as Parcel 2 with the @parcel/watcher package.
- Fast transfer with WebSocket client and server implementation ws
- Add ping-pong strategy for :
- Detecting lost clients from server
- Reconnecting clients when connection is lost
- Improve the event ownership system for a hash based ?
- Add hashing and time based verification before doing disk actions
- Add an initial full folder sync on connection (what strategy ?)
- Add reading buffer for accepting multiple clients & servers (using a reading cache)
- Improve receiving message stream using real Stream