An Application Level program to keep two separate directories synced, similar to Dropbox, using sockets to support file download, index search, and file verification using md5 hashing
- Python3 (>=3.8)
- func-timeout==4.3.5
- humanize==3.10.0
- tabulate==0.8.9
- tqdm==4.61.2
pip install -r requirements.txt- 
folder1andfolder2represent two separate directories on the same or different machine according to the problem statement (seeproblem.pdffor more detail). I have included test data in both of them for testing purposes.
- 
scriptsdirectory contains all necessary programs needed to run the D-SYNC application
- 
Set following static variables before running any program 
| Variable | Default Value | Description | Target File | 
|---|---|---|---|
| CLI_PWD | Path of folder1andfolder2inclient1.pyandclient2.pyrespectively | First directory path | client1.py, client2.py | 
| SV_PWD | Path of folder2andfolder1inclient1.pyandclient2.pyrespectively | Second directory path | client1.py, client2.py | 
| PWD | folder1path inserver1.pyandfolder2inserver2.py | First/Second directory path. NOTE: PWD of server1.pyandserver2.pyare SV_PWD ofclient2.pyandclient1.pyrespectively. | server1.py , server2.py | 
| PORT | 1443 in client1.py, server2.pyand 1445 inclient2.py, server2.py | TCP port | ALL | 
| UDP_PORT | 1401 in client1.pyand 1403 inclient2.py | UDP PORT | client1.py, client2.py | 
| BUFFER_SIZE | 1024 in ALL | TCP buffer size. NOTE: This value must be same for very program | ALL | 
| UDP_BUFFER_SIZE | 32678 in ALL | UDP buffer size. NOTE: This value must be same for every program | ALL | 
| HASH_BUFFER_SIZE | 4096 in ALL | File chunk size to get MD5 checksum. NOTE: This value must be same for every program | ALL | 
| DELIM | :::in ALL | Delimeter to parse command line | ALL | 
| UDP_TIME_OUT | 10 in client1.py, client2.py | Time limit (in seconds) for UDP socket | client1.py, client2.py | 
| STDIN_TIMEOUT | 100 in client1.py, client2.py | Time out for input command (in seconds). NOTE: If the user is idle for STDIN_TIMEOUT, then auto-synchronization starts, and the user will be allowed to give input only after it gets completed | client1.py, client2.py | 
- 
The D-SYNCapplication uses the bash command: 'find' for extracting file information, and it is expected from the user to set the location of this command inserver1.pyandserver2.py. Without this, application won't work. NOTE: For windows, the application is tested on thecmderterminal, so make sure to install that before using this repository.
- 
Run following scripts in 4 separate terminals 
Run Servers:
$ python server1.py
$ python server2.py
Run Clients:
$ python client1.py
$ python client2.py- 
The client1.pyandclient2.pywill interact withserver2.pyandserver1.pyrespectively, and work in a synchronized environment.
- 
The auto sync feature is implemented into the application and does not have separate files. 
- index longlist
- index shorlist <start_time_stamp> <end_time_stamp>
- index regex <search_pattern>
- hash verfy <filename/filepath>
- hash checkall
- download TCP <filename/filepath>
- download UDP <filename/filepath>
- sync
- Data compression and archiving
- Encryption for security purposes
- Conflict detection for the scenerio where a file has been modified on both sources, as opposed to where it has only been modified on one (Preserve file versions).