Syncweb: an offline-first distributed web
Project description
Syncweb
An offline-first distributed web
This ‘World Wide Web’ was just a lame text format and a lot of connected directories.
Ted Nelson
Install
Requires syncthing v2 to be installed in the PATH (or as a static binary in the same folder that you run syncweb commands in)
pip install syncweb
Usage
Start your syncweb cluster by creating your first folder
$ syncweb create audio/
sync://audio#CKTVWGQ-XBRFFRH-YTRPQ5G-YDA5YXI-N66GA5J-XVBGEZ3-PD56G6Y-N7TEAQC
Share your new folder with someone else
$ syncweb join sync://audio#CKTVWGQ-XBRFFRH-YTRPQ5G-YDA5YXI-N66GA5J-XVBGEZ3-PD56G6Y-N7TEAQC
Local Device ID: NXL7XBL-VPNDOSR-QXU7WI7-NEUI65A-TWN7YGT-WS2U457-NTZNGB4-J6IYDQH
...you will also need to accept their device ID
$ syncweb accept NXL7XBL-VPNDOSR-QXU7WI7-NEUI65A-TWN7YGT-WS2U457-NTZNGB4-J6IYDQH
List files
$ syncweb ls --long audio/
Type Size Modified Name
-----------------------------------
d 2.7GiB 06 Oct 20:56 Recordings/
d 3.2MiB 28 Jul 2022 Documentation/
Find files
$ syncweb find --type=f --ext MKA --size=-20M --min-depth=2 Test
audio/Recordings/TestRecording_1.mka
audio/Recordings/TestRecording_22.mka
audio/Recordings/TestRecording_23.mka
...
# shorthand
$ syncweb find -tf -eMKA -S=-20M -d=+2 Test
Sort
$ syncweb find -tf -eMKA -S=-20M -d=+2 Test | syncweb sort "balanced,frecency" | tee download_list.txt
audio/Recordings/TestRecording_23.mka
audio/Recordings/TestRecording_22.mka
audio/Recordings/TestRecording_1.mka
Download
$ cat download_list.txt | syncweb download --yes
Download Summary:
---------------------------------------------------------------------------------------
Folder ID Files Total Size Usable Pending Buffer Shared Status
---------------------------------------------------------------------------------------
audio 87 216.9MiB 114.6GiB - 18.4GiB (1%) No OK
---------------------------------------------------------------------------------------
TOTAL 87 216.9MiB
---------------------------------------------------------------------------------------
Mark 87 files (216.9MiB) for download? [y/N]:
Debugging
You can start another instance of Syncweb like this:
syncweb --home=/tmp/1/ join sync://test#CKTVWGQ-XBRFFRH-YTRPQ5G-YDA5YXI-N66GA5J-XVBGEZ3-PD56G6Y-N7TEAQC
syncweb --home=/tmp/1/ repl
Future Aspirations
What Syncweb is
Syncweb builds on top of Syncthing as an opinionated selective-sync configuration helper.
The advantages to using it are that it is offline first. You can download a whole website and use the site fully offline. When you come back online the new changes and updates will be synced and your comments and interactions will be automatically uploaded. It is delay-tolerant.
The disadvantage is that browser support for Syncweb URLs is virtually non-existant at this time. I have no plans to work on this aspect. Feel free to lead the charge!
The other really big disadvantage is that Syncweb is fragmented. But this limitation encourages small, productive, file-sharing groups! See what other people are sharing and find a group that matches your interests.
What Syncweb is not
Syncweb will never replace your online banking app. While it may be possible to write something equivalent, I imagine doing so will be very clunky. The traditional web has very mature patterns for building. Requests are atomically mapped out across multiple services.
The traditional web has a robust line of authority via the Domain Name System so you can easily know whether you are on your bank's website or not. Syncweb has left this authority up to the community. Syncthing does not have a built-in certificate revocation mechanism like Certificate Authorities (CAs) do. You control the trust relationships of your devices directly.
Links
For example, a browser can be used in AFS by using “file://” rather than “http://” in addresses. All of the powerful caching and consistence-maintenance machinery that is built into AFS would then have been accessible through a user-friendly tool that has eventually proved to be enormously valuable. It is possible that the browser and AFS could have had a much more symbiotic evolution, as HTTP and browsers eventually did.
Mahadev Satyanarayanan
_____________
'-------------.`-.
/..---..--.\\ `._________________________________________
//|| || \\\ `-\\-----\\-----\\-----\\-----\\-----\\--\
__.'/ || || \\\ \\ \\ \\ \\ \\ \\ \
/ /__||___||___.' \\ \\ \\ \\ \\ \\ \\ |
| | -| \\ \\ \\ \\ \\ \\ \\/
| |___|________ \\ \\ \\ \\ \\ \\_.-'
[ ____ /.-----------.\ \\ \\ \\ \\ \\ .'
| |____|/ .-'''''''-. \\ \\ \\ \\ .-'''''''-.\\_/
| |____|.' '.\\ \\____....----.' '.
| |___ / .-----. \\\______....---/ .-----. \
| |___| / o o o \ \|============| / o o o \ \
| |__ | | o o | ||____________| | o o | |
[_.|___\ \ o o o / | LGB\ \ o o o / |
. . \ '-----' / . .. . . \ '-----' / . .
. . . '. .' . . . . '. .' . .
.. . . '-._ _ _.-' . . . . . '-._ _ _.-' . .
UNDER CONSTRUCTION
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file syncweb-0.0.5.tar.gz.
File metadata
- Download URL: syncweb-0.0.5.tar.gz
- Upload date:
- Size: 46.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: pdm/2.26.0 CPython/3.13.7 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
884622fdb8be0872380668b681ea5fa2c353dbb31072866b54dfccd68ac65261
|
|
| MD5 |
71b34a0c7b8e5117cd0cffc53f693e8a
|
|
| BLAKE2b-256 |
f7ab068d205211c8c1c660066bb58b1f4339e8b5ff748451676c29f76b68691d
|
File details
Details for the file syncweb-0.0.5-py3-none-any.whl.
File metadata
- Download URL: syncweb-0.0.5-py3-none-any.whl
- Upload date:
- Size: 45.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: pdm/2.26.0 CPython/3.13.7 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d745a2ad3803b16bd20f0d71affa9c154a7222e5c4bb4f374e6a7de504d53b96
|
|
| MD5 |
b7c1a9d35fac2b15feaad64b597b8e18
|
|
| BLAKE2b-256 |
c9f317e64ef4547f1b3aaa092da3e669e109886788db41b8eb78eeb66c5966b2
|