Skip to content

traktion/sn_httpd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

sn_httpd

Background

Autonomi (a.k.a. Safe Network) is a distributed data network where both mutable and immutable data can be stored. It can considered as a best of class web3 experience.

sn_httpd is a HTTP service which serves data from Autonomi over conventional HTTP connections. This allows regular web browsers (and other apps) to retrieve data from Autonomi without needing any client libraries, CLIs, etc.

Users can either spin up a local sn_httpd service or deploy one to a public environment. This enables developers to integrate with Autonomi in a more conventional way and gives end users a conventional browsing experience.

Features

sn_httpd currently provides the following:

  • Data retrieval from Autonomi using /xor/[XOR_ADDRESS]. Data is streamed directly from Autonomi to reduce latency and allows clients to immediately consume the data.
  • Data retrieval from Autonomic using archives for human readable naming /[ARCHIVE_XOR_ADDRESS]/[MY_FILE_NAME]. Enables regular static sites to be uploaded as an archive, with files browsed by file name.
  • Routing from URLs to specific [XOR_ADDRESS] or [FILE_NAME]. Enables SPA (single page apps) such as Angular or React to be hosted (once a routeMap is provided - see example-config (DISABLED TEMPORARILY!)
  • Experimental support for DNS style lookups, using registers to provide /[DNS_NAME]/[MY_FILE_NAME]. More to follow!
  • Hosting of conventional static files using /static.
  • Native integration of the sn_client libraries into Actix web framework. These are both written in Rust to provide smooth integration. As Actix is core to sn_httpd, it can be extended for specific use cases easily.

TODO

  • Built-in accounting features to allow hosts fund bandwidth usage via Autonomi Network Tokens. While Autonomi doesn't have any bandwidth usage fees, traffic too/from sn_httpd may be subject to charges by your hosting company. This will allow self-service for site authors to publish their site on your sn_httpd instance - the backend data is always on Autonomi, irrespective of where sn_httpd is hosted!
  • Refactoring, performance, stability - sn_httpd is highly experimental and should only be used by the adventurous!

Build Instructions

Linux Target

It is recommended that the MUSL target is used to prevent runtime dependency issues.

On Ubuntu:

sudo apt-get install musl-tools

Then add target:

rustup target add x86_64-unknown-linux-musl

Then build release:

cargo build --release --target x86_64-unknown-linux-musl

Windows Target

On Ubuntu:

sudo apt-get install mingw-w64

Then add target:

rustup target add x86_64-pc-windows-gnu

Then build release:

cargo build --release --target x86_64-pc-windows-gnu

ARM Target

On Ubuntu:

sudo apt install gcc make gcc-arm* gcc-aarch64* binutils-arm* binutils-aarch64* pkg-config libssl-dev

Then add target:

rustup target add arm-unknown-linux-musleabi rustup target add gcc-arm-linux-gnueabi

Then update the environment:

export CARGO_TARGET_AARCH64_UNKNOWN_LINUX_MUSL_LINKER=aarch64-linux-gnu-gcc export CC=aarch64-linux-gnu-gcc

Then build release:

cargo build --release --target aarch64-unknown-linux-musl

Run instructions

cargo run 127.0.0.1:8080 static https://sn-testnet.s3.eu-west-2.amazonaws.com/network-contacts 4b4a0fa14f00ffdcc2c3dabef49721bdde81e9263cde5e2f4885459685d1f75d9099ecd71284c151e2a835e01b9a3847ea9676560620b9c038f9c6d623384ab1359ebd7ed1ff8add5c8d6e81d75d2742

Where:

  • https://sn-testnet.s3.eu-west-2.amazonaws.com/network-contacts is a URL containing a list of peer addresses.
  • 4b4a0fa14f00ffdcc2c3dabef49721bdde81e9263cde5e2f4885459685d1f75d9099ecd71284c151e2a835e01b9a3847ea9676560620b9c038f9c6d623384ab1359ebd7ed1ff8add5c8d6e81d75d2742 is a DNS_REGISTER.

Archive Upload

To upload a current directory to Autonomi as an archive, do the following:

  • cd your/directory
  • autonomi file upload -p -x ./

This command will return information about the uploads and summarise with something like:

Uploading file: "./1_bYTCL7G4KbcR_Y4rd78OhA.png" Upload completed in 5.57326318s Successfully uploaded: ./ At address: 387f61da64d2a4c5d2e02ca34660fa2ac4fa6b3604ed8b67a58a3cba6e8ae787

The 'At address' is the archive address and you can now reference the uploaded files like:

Via a proxy with DNS set to 6d70bf50aec7ebb0f1b9ff5a98e2be2f9deb2017515a28d6aea0c6f80a9f44dda43d61a01fd64bc32265b41842ad4c8ef51b22748de068f550e39ebf88495a3e99c4481019d10ad513d0157fb2e679b3: http://traktion.autonomi/1_bYTCL7G4KbcR_Y4rd78OhA.png

Or via direct request: http://localhost:8082/387f61da64d2a4c5d2e02ca34660fa2ac4fa6b3604ed8b67a58a3cba6e8ae787/1_SxkGLnSNsMtu0SDrsWW8Wg.jpeg

App Configuration

See example-config for customising how your web site/app behaves on sn_httpd.

The config should be uploaded to Autonomi and the corresponding XOR_ADDRESS can then be used as the site root, e.g. /[XOR_ADDRESS]/[OTHER_FILES]. The config can have any file name as only the XOR address is important to sn_httpd.

Given each change to the App Configuration will result in a different XOR address, a form of DNS can be used to map a name to an XOR address.

At the time of writing, only a single name can be referenced per sn_httpd instance. This will change once the register interface has been finalised, to allow register history to be retrieved.

To create a site register (for the specific site/app):

autonomi register create [SITE_REGISTER]

To point the register at your App Configuration:

autonomi register edit [SITE_REGISTER] [CONFIG_XOR_ADDRESS]

When the App Configuration is updated, repeat the above with its new XOR address.

To create a DNS register for the sn_httpd instance, use the CLI:

autonomi register create [DNS_REGISTER]

To add/edit a name, edit the register to append the site register:

autonomi register edit [REGISTER_ADDRESS] "[APP_NAME],[APP_ADDRESS]"

Once completed, /[APP_NAME] will resolve to the App Configuration and any path after this point will reference the App Configuration, e.g. with /myapp/myfile, myfile can be in the dataMap and route to an XOR address.

Example site - IMIM!

I maintain a blog using the IMIM platform, which allows authors to write Markup text files and publish them on Autonomi. Using sn_httpd, these blogs can be viewed anywhere that an instance is running.

Why not take a look and start your own immutable blog today?

About

Safe Network httpd gateway server

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages