Skip to content
This repository was archived by the owner on Feb 12, 2024. It is now read-only.

Commit b2afbf4

Browse files
dignifiedquiredaviddias
authored andcommitted
docs: Tutorial: transfer-files (previsously #714) (#774)
1 parent de627b9 commit b2afbf4

15 files changed

+788
-0
lines changed

examples/transfer-files/.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
public/js/ipfs.js

examples/transfer-files/README.md

+164
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,164 @@
1+
# Tutorial - Transfer files between the browser and other IPFS nodes
2+
3+
> Welcome! This tutorial will help you exchange files between browser nodes and go-ipfs nodes.
4+
5+
There are a couple of caveats:
6+
7+
- js-ipfs currently doesn't support DHT peer discovery, the peer from which you are fetching data should be within the reach (local or in public IP) of the browser node.
8+
- We need to use a signalling server to establish the WebRTC connections, this won't be necessary as soon as libp2p-relay gets developed
9+
10+
That being said, we will explain throughout this tutorial to circunvent the caveats and once they are fixed, we will update the tutorial as well.
11+
12+
## Application diagram
13+
14+
The goal of this tutorial is to create a application with a IPFS node that dials to other instances of it using WebRTC, and at the same time dial and transfer files from a Desktop IPFS node using WebSockets as the transport.
15+
16+
```
17+
┌──────────────┐ ┌──────────────┐
18+
│ Browser │ │ Browser │
19+
│ │ WebRTC │ │
20+
│ │◀─────────────────▶│ │
21+
└──────────────┘ └──────────────┘
22+
▲ ▲
23+
│ │
24+
│WebSockets WebSockets│
25+
│ ┌──────────────┐ │
26+
│ │ Desktop │ │
27+
└───────▶│ │◀─────────┘
28+
└──────────────┘
29+
```
30+
31+
## Check out the final state
32+
33+
In the end, you should get an app running, something like this:
34+
35+
![](https://ipfs.io/ipfs/Qmbti2nBZWxQLhpggB7tC3HvcxTMivmMo3MVwQveAsHBAE)
36+
37+
## Step-by-step instructions
38+
39+
Here's what we are going to be doing, today:
40+
41+
- 1. Set up, install a go-ipfs node in your machine
42+
- 2. Make your daemons listen on WebSockets
43+
- 3. Start the WebApp
44+
- 4. Dial to a node using WebSockets (your Desktop ones)
45+
- 5. Transfer files between all of your nodes, have fun!
46+
47+
Let's go.
48+
49+
### 1. Set up
50+
51+
You'll need to have an implementation of IPFS running on your machine. Currently, this means either go-ipfs or js-ipfs.
52+
53+
Installing go-ipfs can be done by installing the binary [here](https://ipfs.io/ipns/dist.ipfs.io/#go-ipfs). Alternatively, you could follow the instructions in the README at [ipfs/go-ipfs](https://github.com./ipfs/go-ipfs).
54+
55+
Installing js-ipfs requires you to have node and [npm](https://www.npmjs.com). Then, you simply run:
56+
57+
```sh
58+
> npm install --global ipfs
59+
...
60+
> jsipfs --help
61+
Commands:
62+
...
63+
```
64+
65+
This will alias `jsipfs` on your machine; this is to avoid issues with `go-ipfs` being called `ipfs`.
66+
67+
At this point, you have either js-ipfs or go-ipfs running. Now, initialize it:
68+
69+
```sh
70+
> ipfs init
71+
# or
72+
> jsipfs init
73+
```
74+
75+
This will set up your IPFS repo in your home directory.
76+
77+
### 2. Make your daemons listen on WebSockets
78+
79+
At this point, you need to edit your `config` file, the one you just set up with `{js}ipfs init`. It should be in either `~/.jsipfs/config` or `~/.ipfs/config`, depending on whether you're using JS or Go.
80+
81+
Note: js-ipfs sets up a websocket listener by default, if you are just using js-ipfs you can skip this test.
82+
83+
Since websockets support is currently not on by default, you'll need to add a WebSockets address manually. Look into your config file and find the `Addresses` section:
84+
85+
```json
86+
"Addresses": {
87+
"Swarm": [
88+
"/ip4/0.0.0.0/tcp/4002"
89+
],
90+
"API": "/ip4/127.0.0.1/tcp/5002",
91+
"Gateway": "/ip4/127.0.0.1/tcp/9090"
92+
}
93+
```
94+
95+
Add the following entry to your `Swarm` array: `/ip4/127.0.0.1/tcp/9999/ws`. Now, it should look like this:
96+
97+
```json
98+
"Addresses": {
99+
"Swarm": [
100+
"/ip4/0.0.0.0/tcp/4002",
101+
"/ip4/127.0.0.1/tcp/9999/ws"
102+
],
103+
"API": "/ip4/127.0.0.1/tcp/5002",
104+
"Gateway": "/ip4/127.0.0.1/tcp/9090"
105+
}
106+
```
107+
108+
Now it should listen on Websockets. We're ready to start the daemon.
109+
110+
```sh
111+
> ipfs daemon
112+
```
113+
114+
(Again, either `jsipfs` or `ipfs` works. I'll stop repeting this from here on out.)
115+
116+
You should see the Websocket address in the output:
117+
118+
```sh
119+
Initializing daemon...
120+
Swarm listening on /ip4/127.0.0.1/tcp/4001
121+
Swarm listening on /ip4/127.0.0.1/tcp/9999/ws
122+
Swarm listening on /ip4/192.168.10.38/tcp/4001
123+
Swarm listening on /ip4/192.168.10.38/tcp/9999/ws
124+
API server listening on /ip4/127.0.0.1/tcp/5001
125+
Gateway (readonly) server listening on /ip4/0.0.0.0/tcp/8080
126+
Daemon is ready
127+
```
128+
129+
It's there in line 5 - see the `/ws`? Good. that means it is listening.
130+
131+
### 3. Start the WebApp project
132+
133+
Now, you'll need to make sure you are in `js-ipfs/examples/transfer-files`. You'll see a `package.json`: this manifest holds the information for which packages you'll need to install to run the webapp. Let's install them, and then start the project:
134+
135+
```sh
136+
> npm install
137+
> npm start
138+
```
139+
140+
You should see this text:
141+
142+
```sh
143+
Starting up http-server, serving public
144+
Available on:
145+
http://127.0.0.1:12345
146+
http://192.168.1.24:12345
147+
Hit CTRL-C to stop the server
148+
```
149+
150+
Go to http://127.0.0.1:12345 in your browser; you're now in the webapp, if all went well.
151+
152+
### 4. Dial to a node using WebSockets (your Desktop ones)
153+
154+
On your local node, run `ipfs id` to find the WebSockets address that it is listening on. Should look like this: `"/ip4/127.0.0.1/tcp/4003/ws/ipfs/<your peer id>".
155+
156+
![](https://ipfs.io/ipfs/Qme9RM3SSyb57PGA7n5bEhwhMwS8fDrMZ8zzKkrwncRcfm)
157+
![](https://ipfs.io/ipfs/QmdFX4wJkKpryisjGQGt88Yr8zaQM9zMPL3xzK2YGTUMNM)
158+
159+
### 5. Transfer files between all of your nodes, have fun!
160+
161+
Now you can drag an drop files on the browser or add them through the CLI with `ipfs add <file>` and with the fetch file box, you can retrieve the file to the browser or other browser tabs!
162+
163+
![](https://ipfs.io/ipfs/QmcVNbhmMFzz9x2mY33GPGetibFGXXD7dYd3kDa7eKEUyw)
164+
![](https://ipfs.io/ipfs/QmZcRvGQtM7mnSWKqFwptCYoBitBJaGBKLLjvzENfzXFMi)
214 KB
Loading
205 KB
Loading
1.53 KB
Binary file not shown.
+19
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
┌──────────────┐ ┌──────────────┐
2+
│ Browser │ │ Browser │
3+
│ │ WebRTC │ │
4+
│ │◀─────────────────▶│ │
5+
│ │ │ │
6+
└──────────────┘ └──────────────┘
7+
▲ ▲
8+
│ │
9+
│ │
10+
│ │
11+
│WebSockets WebSockets│
12+
│ │
13+
│ │
14+
│ ┌──────────────┐ │
15+
│ │ Desktop │ │
16+
│ │ │ │
17+
└───────▶│ │◀─────────┘
18+
│ │
19+
└──────────────┘
20 KB
Loading
40.8 KB
Loading

examples/transfer-files/img/final.png

198 KB
Loading

examples/transfer-files/package.json

+14
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
{
2+
"name": "transfer-files",
3+
"version": "1.0.0",
4+
"scripts": {
5+
"check-bundle": "test -f ../../dist/index.js && npm run copy-bundle || (echo \"js-ipfs dist file not found, go up two dirs and run 'npm run build' first\" && exit 1)",
6+
"copy-bundle": "cp ../../dist/index.js ./public/js/ipfs.js",
7+
"serve": "http-server -c-1 -p 12345 public",
8+
"start": "npm run check-bundle && npm run serve"
9+
},
10+
"license": "MIT",
11+
"devDependencies": {
12+
"http-server": "^0.9.0"
13+
}
14+
}

0 commit comments

Comments
 (0)