stargate

module
v0.0.0-...-c2c54f3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 30, 2024 License: Apache-2.0, MIT

README

[!WARNING]

⚠️ this project was a PoC that is no longer maintained

Since then:

If you want to run a production-grade HTTP Gateway consider migrating to Boxo SDK's boxo/gateway library or Rainbow daemon which support both of the above and more.

StarGate

A Robust Verifiable HTTP Protocol For Content Addressed Data

Table of Contents

Overview

StarGate is a specification to extend the IPFS gateway to support trustless, multipeer data transfer of fairly complex queries.

This repo is a prototype design and implementation of StarGate, containing a simple executable that implements a Stargate server and client (client still in development as of 1/18/2023).

For more information on how Stargate works and its core design goals see the StarGate talk from the Move The Bytes Working Group: https://www.youtube.com/watch?v=qbKZmmMZePs and the StarGate protocol specification

Setup

To install Stargate, run:

> go install github.com/ipfs/stargate/cmd/stargate@latest

Then, setup your repo with:

> stargate init

Note: You don't really have to run stargate init for the time being cause the other commands will initialize everything if it's not done.

Usage

Import data

Import the current directory, recursively:

> stargate --vv import .
Sending CID bafybeidwarsw46q7wx5jrojwzgg4smvmgvgj23chzmybidten3l7wjnrva through the Stargate!

Import a file:

> stargate --vv import ~/Downloads/testvideo.mp4 
Sending CID bafybeigkkzgkd6z33jaczjhrmjb5m3jwqyn7zbbfvmy2ekfm6dievp5kdy through the Stargate!
Run the Stargate Server
> stargate --vv server

(the server can start any time and you can import while the server is running)

Fetch (with CURL for now)

Fetch the root directory:

> curl -v http://localhost:7777/ipfs/bafybeidwarsw46q7wx5jrojwzgg4smvmgvgj23chzmybidten3l7wjnrva > root.car

Pathing:

> curl -v http://localhost:7777/ipfs/bafybeidwarsw46q7wx5jrojwzgg4smvmgvgj23chzmybidten3l7wjnrva/go.mod > go.mod.car

> curl -v http://localhost:7777/ipfs/bafybeidwarsw46q7wx5jrojwzgg4smvmgvgj23chzmybidten3l7wjnrva/pky/types.go > types.go.car

Fetch a file:

> curl -v http://localhost:7777/ipfs/bafybeigkkzgkd6z33jaczjhrmjb5m3jwqyn7zbbfvmy2ekfm6dievp5kdy > testvideo.mp4.car

Fetch a file, but don't send leaf blocks (useful for multipeer):

> curl -v http://localhost:7777/ipfs/bafybeigkkzgkd6z33jaczjhrmjb5m3jwqyn7zbbfvmy2ekfm6dievp5kdy?noleaves  > testvideo.mp4.dag.car

Fetch a range (of the flat file, not the car):

> curl -v http://localhost:7777/ipfs/bafybeigkkzgkd6z33jaczjhrmjb5m3jwqyn7zbbfvmy2ekfm6dievp5kdy?bytes=0-1000000  > testvideo.mp4.start.car

Documentation

See Go Doc

Roadmap

A list of things to do:

  • Complete Fetch Command
  • Add Tracing and Metrics
  • MOAR documentation
  • Measure Performance
  • Optimizations
  • Filecoin Chain Resolver

But sadly, little time for original author to complete them

Contribute

Early days PRs are welcome!

License

This library is dual-licensed under Apache 2.0 and MIT terms.

Copyright 2022. Protocol Labs, Inc.

Directories

Path Synopsis
cmd
internal
pkg
blockwriter
Package blockwriter is not currently used, but it's useful code we may need
Package blockwriter is not currently used, but it's useful code we may need
handler
Package handler implements the HTTP mechanics of sending StarGate responses
Package handler implements the HTTP mechanics of sending StarGate responses

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL