Skip to content

Latest commit

 

History

History
85 lines (67 loc) · 3.76 KB

index.md

File metadata and controls

85 lines (67 loc) · 3.76 KB
<style> .agregore-logo { width: 50%; animation-name: pulse; animation-duration: 1.5s; animation-timing-function: linear; animation-direction: alternate; animation-iteration-count: infinite; animation-play-state: running; } @keyframes pulse { 0% { transform: scale(1); } 100% { transform: scale(1.05); } } </style>

Agregore

Explore the distributed web

Explore Blog Docs Videos Download Mobile

Features

Screenshot showing Agregore Browser loading a hyper:// URL

Watch the 5 Minute Intro

<iframe width="560" height="315" src="https://archive.org/embed/dweb-meetup-dec-2020-dweb-lightning-talks?start=4212" title="Agregore 4 minute intro" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>

How does it work?

Agregore works by letting you load web pages and content from peer to peer protocols the same way you would load them from a website.

In the same way as you can navigate to http://example.com, you can navigate to hyper://blog.mauve.moe and have it load from anybody on the network that has a copy. This can be done via the different protocols that Agregore supports like BitTorrent, IPFS, and Hypercore Protocol. The web contents are rendered via Chromium using the Electron framework. Electron is useful since it's what allows us to publish Agregore on Windows, MacOS, and Linux.

How do I share stuff?

Agregore not only supports loading data through custom protocols, but it also provides APIs for uploading data into peer to peer protocols. This is done via the browser's fetch() API which is what web developers use to talk to web servers over HTTP or HTTPS.

You can create your own peer to peer website using this simple code snippet:

// Upload your website page
url = 'ipfs://bafyaabakaieac/example.txt'
response = await fetch(url, {
  method: 'PUT',
  body: 'Hello World! 👋 🌎🌍🌏'
})// Navigate to the website
window.location.href = response.headers.get('Location')

For more details and demos, check out the the Videos page, or read the Fetch API Docs.

Source Code Contact Discord Matrix Mastodon Twitter