2015-11-04 17:05:27 +01:00
# IPFS Boards
2015-12-20 21:29:37 +01:00
The easy to use Social Platform that runs in modern web browsers but requires _no servers_ and
2015-12-04 12:30:04 +01:00
_no external applications_ to work.
2015-11-24 20:38:57 +01:00
2015-12-20 21:29:37 +01:00
This Application aims to allow users to:
- __Share Data__ with the world, in a distributed and permanent way, whether it is documents, media, posts or files and folders
- __Discover__ other user's content by visiting a link to their profiles, and then seeding the content they like the most
- __Connect__ with other people, building communities and merging boards.
All of these in a fully distributed way: servers help by seeding content, but they are not necessary for the application to work.
The App is being developed to be versatile: it will run in web browsers, and it will bundle a viewer that will understand and display
_any file or folder_ already hosted via IPFS, with a nice user interface and optionally social features on top.
2015-12-04 12:24:46 +01:00
![Board view screenshot ](https://ipfs.pics/ipfs/QmezECALggzJLK89j4hhDVPwVv5gzmZMLbYi8zbjpXWvVH )
2015-12-20 21:29:37 +01:00
This is how the Board view looks in the current prototype. You can see that markdown syntax is supported in all text bodies,
and the administrator name `fazo96` and also the other allowed posters,
in this case only one. Posts are shown in chronological order, but other sorting methods are planned.
2015-12-04 12:24:46 +01:00
![Post view screenshot ](https://ipfs.pics/ipfs/QmZntzNLyRgTPfaNhc4B23AWKQxPcwmjjBv3WPMh78ieeQ )
This is the Post view with reddit style comments.
2016-03-25 20:33:15 +01:00
## State of development
2015-12-04 12:24:46 +01:00
2016-09-29 21:39:11 +02:00
Even though the application kind of works, __the project needs quite a rewrite__ . Development has been paused for months because I didn't have time, meanwhile I've grown a bit as a programmer and quickly realized I made many bad mistakes when writing this. Also, ipfs now supposedly works in the browser so I'd probably rewrite the lib around it and drop support for the http gateway, while using Redux or something like that to handle the state and lifecycle, then separating react components containing logic from the stateless rendering ones.
2016-03-25 20:33:15 +01:00
2016-09-29 21:39:11 +02:00
Anyway, this project already accomplished many things, like having a kind of working prototype and being a great proof of
2016-04-11 16:25:23 +02:00
concept. I hope to resume development soon and update it, but __pull requests are still very welcome, as I'd probably review them with pleasure.__
2016-03-25 20:33:15 +01:00
## Why this project?
2015-11-24 20:38:57 +01:00
2015-12-20 21:29:37 +01:00
Discussion boards, forums and other social platforms have many problems:
2015-11-04 21:15:58 +01:00
2015-12-20 21:29:37 +01:00
- __Centralized__
2015-11-04 21:15:58 +01:00
- What if it gets shut down?
- What if the servers are down?
2015-12-20 21:29:37 +01:00
- __Fragile__
2015-11-24 20:38:57 +01:00
- 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?
2015-12-20 21:29:37 +01:00
- __Limited__
2015-11-24 20:38:57 +01:00
- What if you want new functionality or restore old features?
- What if you want to build custom clients or extensions to the service?
- What if you want to use it in a Local Network with no Internet access and no servers?
- What if you want to do more than what the service was designed for, or truly be in control of your data?
This project was conceived to solve that. With the help of:
2015-11-04 21:15:58 +01:00
2015-11-24 20:38:57 +01:00
- the [IPFS ](https://github.com/ipfs/ipfs ) and IPNS protocols for efficient distributed data storage
- IPLD and [POST ](https://github.com/ipfs/POST ) protocols for a common, universal data structure
- Modern browsers and web technologies for a portable, accessible user interface
2015-11-04 21:15:58 +01:00
2015-12-20 21:29:37 +01:00
We can solve these problems and create a _truly universal social platform_ which can act as:
2015-11-04 21:15:58 +01:00
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
2015-12-20 21:29:37 +01:00
- File Sharing platform, like dropbox.
2015-11-24 20:38:57 +01:00
- Forum
2015-11-14 16:26:03 +01:00
- (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
2015-12-20 21:29:37 +01:00
architecture or, _optionally_ , none of these!
2015-11-04 21:15:58 +01:00
2015-11-22 00:10:46 +01:00
## Get Started
2015-11-11 15:51:17 +01:00
2015-12-20 21:29:37 +01:00
__The App is not ready yet__, but you're welcome to take a look at the prototype,
even though it has limited functionality and is cumbersome to set up at the
moment.
2015-11-14 00:16:45 +01:00
2015-12-04 11:07:19 +01:00
Also keep in mind that due to issues with the current implementation of IPNS in
go-ipfs, real world usage of the prototype is very limited. This will all be
sorted out as soon as go-ipfs' next version, 0.4, is out.
2015-11-14 00:16:45 +01:00
2015-12-21 16:44:34 +01:00
__Check it out here:__ http://ipfs.ydns.eu
__Tip:__ http://ipfs.ydns.eu is also a full IPFS gateway for IPFS 0.4. You can
also use it to access the 0.3.x network by visiting http://ipfs-0.3.ydns.eu
2015-12-20 21:29:37 +01:00
If you want to really use the prototype, you can take a look at `CONTRIBUTING.md`
to set up a developer environment and try it out.
2015-12-04 11:07:19 +01:00
2015-12-20 21:29:37 +01:00
__Note about current status:__ almost every feature is _not_ optimized, _not_
efficient, but almost all solutions to current problems are already well defined,
frozen, and being developed, _expecially_ regarding __IPFS__ .
2015-12-04 11:07:19 +01:00
2015-12-22 15:33:22 +01:00
__Note about short term future:__ after `go-ipfs 0.4` comes out, a public demo will be available and you'll
2015-12-20 21:29:37 +01:00
just have to open a link to try the app!
2015-12-04 11:07:19 +01:00
2015-12-20 21:29:37 +01:00
__Note about long term future:__ a javascript implementation of IPFS is in progress. As soon as it's done, you will not need
2015-12-04 12:30:04 +01:00
go-ipfs anymore and this application will truly run in the browser without external dependencies.
2015-11-22 00:10:46 +01:00
## FAQ
See `FAQ.md`
2015-12-20 21:29:37 +01:00
If you have any questions not already answered, please open an issue and
consider contributing to the documentation and FAQs.
2015-11-22 00:10:46 +01:00
### How does it work?
See `PROTOCOL.md`
2015-12-20 21:29:37 +01:00
### How do I set up a development environment and contribute?
2015-11-15 21:35:37 +01:00
2015-12-04 11:07:19 +01:00
See `CONTRIBUTING.md`
2015-11-15 21:35:37 +01:00
2015-11-04 17:05:27 +01:00
## Components
- __Client__
- a static web application to access IPFS Boards
2015-12-11 16:13:56 +01:00
- work in progress, some features are already done, see above
- maybe a desktop version (which would be the wrapped web application, using Electron)
- will be able to do everything in any modern browser
- __Cache Server and/or Backend__
- __Not started yet__: no code has been written yet!
- __Completely Optional__: you don't need this to be able to use the App
- automagically caches content 24/7 so that it's always available
- fully configurable, for example only cache content from users you want to support.
- can serve data via HTTP API
2015-11-14 00:16:45 +01:00
- 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-12-11 16:13:56 +01:00
- __[go-ipfs](https://github.com/ipfs/go-ipfs)__
- needed to use the app until [js-ipfs ](https://github.com/ipfs/js-ipfs ) is ready!
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.
2015-12-11 16:13:56 +01:00
- the cache server (written in node) requires go-ipfs.
2015-11-04 21:15:58 +01:00
### License
2015-11-30 17:13:56 +01:00
The MIT License (MIT)
Copyright (c) 2015 Enrico Fasoli (fazo96)
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.