- Notifications
You must be signed in to change notification settings - Fork168
The InterPlanetary File System (IPFS), implemented in Rust.
License
Apache-2.0, MIT licenses found
Licenses found
rs-ipfs/rust-ipfs
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
The Interplanetary File System (IPFS), implemented in Rust
This repository contains the crates for the IPFS core implementation which includes a blockstore, a libp2p integration which includes DHT content discovery and pubsub support, and HTTP API bindings. Our goal is to leverage both the unique properties of Rust to create powerful, performant software that works even in resource-constrained environments, while also maximizing interoperability with the other "flavors" of IPFS, namely JavaScript and Go.
You can see details about what's implemented, what's not, and also learn about other ecosystem projects, atAre We IPFS Yet?
For more information about IPFS see:https://docs.ipfs.io/introduction/overview/
Rust IPFS depends onprotoc
andopenssl
.
First, install the dependencies.
With apt:
$ apt-get install protobuf-compiler libssl-dev zlib1g-dev
With yum:
$ yum install protobuf-compiler libssl-dev zlib1g-dev
Therust-ipfs
binaries can be built from source. Our goal is to always be compatible with thestable release of Rust.
$ git clone https://github.com/rs-ipfs/rust-ipfs&&cd rust-ipfs$ cargo build --workspace
You will then find the binaries inside of the project root's/target/debug
folder.
We recommend browsing theexamples, thehttp crate tutorial andtests in order to see how to use Rust-IPFS in different scenarios.
The project currently features unit, integration, conformance and interoperability tests. Unit and integation tests can be run with:
$ cargotest --workspace
The--workspace
flag ensures the tests from the http and unixfs crates are also run.
Explanations on how to run the conformance tests can be foundhere. The Go and JS interoperability tests are behind a feature flag and can be run with:
$ cargotest --feature=test_go_interop$ cargotest --feature=test_js_interop
These are mutually exclusive, i.e.--all-features
won't work as expected.
Note: you will need to set theGO_IPFS_PATH
and theJS_IPFS_PATH
environment variables to point to the relevant IPFS binary.
Seethe contributing docs for more info.
If you have any questions on the use of the library or other inquiries, you are welcome to submit an issue.
Special thanks to the Web3 Foundation and Protocol Labs for their devgrant support.
- Project Setup
- Testing Setup
- Conformance testing
- HTTP API Scaffolding
- UnixFS Support
/pubsub/{publish,subscribe,peers,ls}
/swarm/{connect,peers,addrs,addrs/local,disconnect}
/id
/version
/shutdown
/block/{get,put,rm,stat}
/dag/{put,resolve}
/refs
and/refs/local
/bitswap/{stat,wantlist}
/cat
/get
/resolve
/bootstrap
/dht
- interop testing
/name
/ping
/key
/config
/stats
/files
(regular and mfs)- a few other miscellaneous endpoints not enumerated here
Rust IPFS was originally authored by @dvc94ch and was maintained by @koivunej, and @aphelionz. Special thanks is given toProtocol Labs andEquilibrium.
It’s been noted that the Rust-IPFS name and popularity may serve its organization from a "first-mover" perspective. However, alternatives with different philosophies do exist, and we believe that supporting a diverse IPFS community is important and will ultimately help produce the best solution possible.
rust-ipfs-api
- A Rust client for an existing IPFS HTTP API. Supports both hyper and actix.ipfs-embed
- An implementation based onsled
rust-ipld
- Basic rust ipld library supportingdag-cbor
,dag-json
anddag-pb
formats.- PolkaX's own
rust-ipfs
- Parity's
rust-libp2p
, which does a lot the of heavy lifting here
If you know of another implementation or another cool project adjacent to these efforts, let us know!
This project exists thanks to all the people who contribute. [Contribute].
Become a financial contributor and help us sustain our community. [Contribute]
Support this project with your organization. Your logo will show up here with a link to your website. [Contribute]
Dual licensed under MIT or Apache License (Version 2.0). SeeLICENSE-MIT andLICENSE-APACHE for more details.
TheRust logo and wordmark are trademarks owned and protected by theMozilla Foundation. The Rust and Cargo logos (bitmap and vector) are owned by Mozilla and distributed under the terms of theCreative Commons Attribution license (CC-BY).
About
The InterPlanetary File System (IPFS), implemented in Rust.