2015-11-04 17:05:27 +01:00
|
|
|
# IPFS Boards
|
|
|
|
|
2015-11-04 21:15:58 +01:00
|
|
|
Image and discussion boards, forums and the like have many problems:
|
|
|
|
|
|
|
|
- Centralized
|
|
|
|
- What if it gets shut down?
|
|
|
|
- What if the servers are down?
|
|
|
|
- What if a phisical network link breaks and the data is on the other side?
|
|
|
|
- What if the owners of the board get eaten by aliens?
|
|
|
|
|
|
|
|
- Fragile
|
|
|
|
- what if there's a DoS attack?
|
|
|
|
- what if there is a usage explosion and the servers can't handle it?
|
|
|
|
- what if the datacenter is flooded and data is lost?
|
|
|
|
|
|
|
|
- Closed Down, limited in possibilities
|
2015-11-05 14:38:10 +01:00
|
|
|
- What if I want to write a custom client and there is no API?
|
2015-11-04 21:15:58 +01:00
|
|
|
- What if I want to change the user interface?
|
2015-11-05 14:38:10 +01:00
|
|
|
- What if I want to use it in a LAN with no Internet access?
|
2015-11-04 21:15:58 +01:00
|
|
|
- What if I want a name that someone else already has?
|
|
|
|
- What if I want to move my data to another service/subreddit/forum ?
|
|
|
|
- What if I want more control (think a private forum), or less control (think 4chan) ?
|
|
|
|
- What if I want <feature> ?
|
|
|
|
|
|
|
|
This project was conceived to solve that. With the help of modern web technologies, the IPFS and IPNS protocols
|
|
|
|
and some optional cache servers, we can solve these problems and create a true universal platform which can act as:
|
|
|
|
|
2015-11-14 16:26:03 +01:00
|
|
|
- Discussion board, like reddit or 4chan
|
|
|
|
- Blog with dynamic comments
|
2015-11-04 21:15:58 +01:00
|
|
|
- Wiki
|
|
|
|
- File Sharing platform
|
2015-11-14 16:26:03 +01:00
|
|
|
- (Maybe) Forum (not sure because it would require some changes, but maybe)
|
|
|
|
- (Maybe) E-Learning platform
|
2015-11-04 21:15:58 +01:00
|
|
|
|
2015-11-14 00:16:45 +01:00
|
|
|
With security, control, reliability, rock solid stability, fully distributed
|
|
|
|
architecture or, optionally, none of these!
|
2015-11-04 21:15:58 +01:00
|
|
|
|
2015-11-14 00:16:45 +01:00
|
|
|
## FAQ
|
2015-11-11 15:51:17 +01:00
|
|
|
|
2015-11-14 00:16:45 +01:00
|
|
|
See `FAQ.md`
|
|
|
|
|
|
|
|
### How does it work?
|
|
|
|
|
|
|
|
See `PROTOCOL.md`
|
|
|
|
|
2015-11-14 16:26:03 +01:00
|
|
|
## Demo / Prototype
|
2015-11-14 00:16:45 +01:00
|
|
|
|
2015-11-15 19:03:44 +01:00
|
|
|
You can find a working build [here](http://localhost:8080/ipfs/QmX7AnVBcujwKQRrfVnFw6uHLSTsSE8WsyLS7ajtn4AnvH).
|
|
|
|
You need a local instance of go-ipfs running to see it. You also need to set
|
|
|
|
CORS settings right or it won't work. However, in that case, it will complain to
|
|
|
|
you and provide instructions.
|
|
|
|
|
|
|
|
Keep in mind that it's a _very early_ prototype, nothing is finished, nothing
|
|
|
|
is polished, but something works. It's also probably full of security holes,
|
|
|
|
very inefficient, slow, etc. You're welcome to help in any way though!
|
|
|
|
|
|
|
|
Also, remember that __it doesn't have__:
|
2015-11-11 15:51:17 +01:00
|
|
|
|
2015-11-14 19:13:13 +01:00
|
|
|
- Ability to post and create a profile from the web app (it's read only for now)
|
|
|
|
- Aggregation (only the admin can post, for now)
|
|
|
|
- Advanced customization, control, user profile customization
|
2015-11-11 15:51:17 +01:00
|
|
|
- Media support
|
|
|
|
- Votes
|
|
|
|
- Comments
|
2015-11-14 16:26:03 +01:00
|
|
|
- Actually nice user interface
|
2015-11-15 19:03:44 +01:00
|
|
|
- Ability to run without a full IPFS node. That would require either a backend or the (currently not done) js implementation of IPFS
|
2015-11-14 16:26:03 +01:00
|
|
|
|
|
|
|
Ability to publish stuff in the browser won't be implemented until go-ipfs 0.4
|
2015-11-15 19:03:44 +01:00
|
|
|
is ready. It will maybe be ready before the new year.
|
|
|
|
You will be able to publish your boards/profile/posts using a CLI though.
|
2015-11-11 15:51:17 +01:00
|
|
|
|
2015-11-04 17:05:27 +01:00
|
|
|
## Components
|
|
|
|
|
|
|
|
- __Client__
|
|
|
|
- a static web application to access IPFS Boards
|
2015-11-14 00:16:45 +01:00
|
|
|
- maybe a desktop version (which would be a wrapped web application)
|
|
|
|
- will be able to do everything in a simple browser
|
|
|
|
- __Server__
|
|
|
|
- __Completely Optional__ (not right now, but it will be)
|
|
|
|
- can cache content so that it doesn't get lost
|
|
|
|
- fully configurable
|
|
|
|
- can serve the Client
|
|
|
|
- can render the client application so that search engines can index content
|
|
|
|
- can provide content over an HTTP API or web sockets so that devices can save bandwidth
|
2015-11-04 17:05:27 +01:00
|
|
|
|
|
|
|
__Note:__ until the __IPFS Javascript Implementation__ is done:
|
|
|
|
|
|
|
|
- the client (a static web application) requires a full IPFS node because it needs to be able to discover content via the IPFS API.
|
|
|
|
- the cache server (written in node) requires a full IPFS node.
|
|
|
|
|
2015-11-14 00:16:45 +01:00
|
|
|
__Note:__ if you want to write data, your __IPNS__ needs to be taken over
|
|
|
|
by the application. This problem will be solved after go-ipfs 0.4 with the files
|
|
|
|
API is released.
|
2015-11-04 21:15:58 +01:00
|
|
|
|
|
|
|
### License
|
|
|
|
|
|
|
|
GPLv3? MIT? Something else? Needs to be chosen
|