diff --git a/README.md b/README.md
index e38440b4b81a342ce668fe76cd578abcdb4644b7..3cfba466191afb315b2e18483a0bfa628425f2dd 100644
--- a/README.md
+++ b/README.md
@@ -1,258 +1,24 @@
 Duniter4j
 =========
 
-Duniter4j is a Java Client API for [Duniter](http://duniter.org).
+Duniter4j is a Java Toolkit for [Duniter](http://duniter.org).
 
-## Components
+<img src="./src/site/resources/images/logos/logo_duniter.png"/>
 
-Duniter4j has tree main components :
+> See the [documentation web site](http://doc.e-is.pro/duniter4j/)
 
- - a command line tool (duniter4j-client), to execute basic operation on a Duniter currency : transfer, view peers, ... 
-  
- - an API (duniter4j-core-client), that allow developer to access to a Duniter network.
+## Modules
 
- - a ElastiSearch node (duniter4j-elasticsearch), to add store & full-text capabilities, on blockchain data, user profiles (Cesium+) and more (private message).
-
-## Command line tool
-
- - Download the file `duniter4j-client-<version>-full-<platform>.zip` from the [lastest releases page](/releases)
- 
- - Unzip the archive
+ Duniter4j has tree main modules :
  
- - The open a terminal and call duniter4j.sh
+ - `duniter4j-client`: [a command line tool](./src/site/markdown/CLI.md), to execute basic operation on a Duniter currency: transfer, view peers, ... 
    
-
-## ElastiSearch node
-
-### Prerequisites
-#### Install Java 
-
- - Install Java JRE 8 or more.
+ - `duniter4j-core-client`: [a Java API](./src/site/markdown/Java_API.md) to help Java developers to communicate with a Duniter network.
  
-    - Windows: see [Oracle web site](http://oracle.com/java/index.html)
+ - `duniter4j-elasticsearch`:  [a ElastiSearch node](./src/site/markdown/ES.md) used to store (with full-text capabilities) all blockchain data, and additional user data. 
     
-    - Linux (Ubuntu):
- 
-```bash
-sudo apt-get install openjdk-8-jre 
-```
-
-### Install libsodium 
-
-[The Sodium crypto library (libsodium)](https://download.libsodium.org/doc/installation/) is a modern, easy-to-use software library for encryption, decryption, signatures, password hashing and more. 
-
-- Get libsodium (version 1.0.11 or newer)
-```
-    wget -kL https://github.com/jedisct1/libsodium/releases/download/1.0.14/libsodium-1.0.14.tar.gz
-    tar -xvf libsodium-1.0.14.tar.gz
-```
-
-- Installation:
-```
-    cd libsodium-1.0.14
-    sudo apt-get install build-essential
-    sudo ./configure
-    sudo make && make check
-    sudo make install        
-```
-
-### Install bundle (ElasticSearch + Duniter4j)  
-
-   - Download [lastest release](https://github.com/duniter/duniter4j/releases) of file duniter4j-es-X.Y-standalone.zip
- 
- - Unzip
- 
-```bash
-unzip duniter4j-es-X.Y-standalone.zip
-cd duniter4j-es-X.Y/config
-```
-
- - Edit the configuration file `config/elasticsearch.yml`, in particular this properties:
-
-```bash
-# Your ES cluster name
-cluster.name: duniter4j-elasticsearch
-
-# Use a descriptive name for the node:
-node.name: ES-NODE-1
-
-# Set the bind address to a specific IP (IPv4 or IPv6):
-network.host: 192.168.0.28
-
-# Set a custom port for HTTP:
-http.port: 9203
-
-# Duniter node to connect with
-duniter.host: g1-test.duniter.org
-duniter.port: 10900
-
-# Initial list of hosts to perform synchronization
-duniter.p2p.ping.endpoints: [
-   "g1-test:ES_USER_API g1-test.data.duniter.fr 443",
-   "g1-test:ES_SUBSCRIPTION_API g1-test.data.duniter.fr 443"
-]
-
-```
- 
- - Launch the node
- 
-```bash
-cd duniter4j-es-X.Y/bin
-./elasticsearch
-```
-
-Output example (on [G1-test](http://g1-test.duniter.fr) currency):
-
-```bash
-$ ./elasticsearch
-[2016-09-24 00:16:45,803][INFO ][node                     ] [ES-NODE-1] version[2.3.3], pid[15365], build[218bdf1/2016-05-17T15:40:04Z]
-[2016-09-24 00:16:45,804][INFO ][node                     ] [ES-NODE-1] initializing ...
-[2016-09-24 00:16:46,257][INFO ][plugins                  ] [ES-NODE-1] modules [reindex, lang-expression, lang-groovy], plugins [mapper-attachments, duniter4j-elasticsearch], sites [duniter4j-elasticsearch]
-[2016-09-24 00:16:46,270][INFO ][env                      ] [ES-NODE-1] using [1] data paths, mounts [[/home (/dev/mapper/isw_defjaaicfj_Volume1p1)]], net usable_space [1tb], net total_space [1.7tb], spins? [possibly], types [ext4]
-[2016-09-24 00:16:46,270][INFO ][env                      ] [ES-NODE-1] heap size [989.8mb], compressed ordinary object pointers [true]
-[2016-09-24 00:16:47,757][INFO ][node                     ] [ES-NODE-1] initialized
-[2016-09-24 00:16:47,757][INFO ][node                     ] [ES-NODE-1] starting ...
-[2016-09-24 00:16:47,920][INFO ][transport                ] [ES-NODE-1] publish_address {192.168.0.5:9300}, bound_addresses {192.168.0.5:9300}
-[2016-09-24 00:16:47,924][INFO ][discovery                ] [ES-NODE-1] duniter4j-elasticsearch/jdzzh_jUTbuN26Enl-9whQ
-[2016-09-24 00:16:50,982][INFO ][cluster.service          ] [ES-NODE-1] detected_master {EIS-DEV}{FD0IzkxETM6tyOqzrKuVYw}{192.168.0.28}{192.168.0.28:9300}, added {{EIS-DEV}{FD0IzkxETM6tyOqzrKuVYw}{192.168.0.28}{192.168.0.28:9300},}, reason: zen-disco-receive(from master [{EIS-DEV}{FD0IzkxETM6tyOqzrKuVYw}{192.168.0.28}{192.168.0.28:9300}])
-[2016-09-24 00:16:53,570][INFO ][http                     ] [ES-NODE-1] publish_address {192.168.0.5:9203}, bound_addresses {192.168.0.5:9203}
-[2016-09-24 00:16:53,570][INFO ][node                     ] [ES-NODE-1] started
-[2016-09-24 00:16:57,850][INFO ][node                     ] Checking Duniter indices...
-[2016-09-24 00:16:57,859][INFO ][node                     ] Checking Duniter indices... [OK]
-[2016-09-24 00:17:08,026][INFO ][duniter.blockchain       ] [g1-test] [g1-test.duniter.org:10900] Indexing last blocks...
-[2016-09-24 00:17:08,026][INFO ][duniter.blockchain       ] [g1-test] [g1-test.duniter.org:10900] Indexing block #999 / 41282 (2%)...
-[2016-09-24 00:17:08,045][INFO ][duniter.blockchain       ] [g1-test] [g1-test.duniter.org:10900] Indexing block #1998 / 41282 (4%)...
-[2016-09-24 00:17:09,026][INFO ][duniter.blockchain       ] [g1-test] [g1-test.duniter.org:10900] Indexing block #2997 / 41282 (6%)...
-[2016-09-24 00:17:10,057][INFO ][duniter.blockchain       ] [g1-test] [g1-test.duniter.org:10900] Indexing block #3996 / 41282 (8%)...
-...
-[2016-09-24 00:17:11,026][INFO ][duniter.blockchain       ] [g1-gtest] [g1-test.duniter.org:10900] Indexing block #41282 - hash [00000AAD73B0E76B870E6779CD7ACCCE175802D7867C13B5C8ED077F380548C5]
-```
-
-### Test your node
-
-#### Using a web browser 
-
-The following web address should works: http://localhost:9200/node/summary
-
-#### Using Cesium
-
-You should also be able to use your node in the [Cesium](https://github.com/duniter/cesium) application:
- 
- - in the Cesium+ settings, replace the data node address;
- - check if graph and profil avatar are display correctly.  
-
-
-## Request the ES node
-
-When a blockchain currency has been indexed, you can test some fun queries :
-
- - get a block by number (e.g the block #0):
+    * It comes with an [HTTP API](./src/site/markdown/ES_API.md) to store and retrieve all this data.
     
-    http://localhost:9200/g1-test/block/0 -> with some additional metadata given by ES
-    
-    http://localhost:9200/gtest/block/0/_source -> the original JSON block
-        
- - Block #125 with only hash, dividend and memberCount:
- 
-    http://localhost:9200/gtest/block/125/_source?_source=number,hash,dividend,membersCount
-      
- - All blocks using a pubkey (or whatever):
- 
-    http://localhost:9200/gtest/block/_search?q=9sbUKBMvJVxtEVhC4N9zV1GFTdaempezehAmtwA8zjKQ1
-       
- - All blocks with a dividend, with only some selected fields (like dividend, number, hahs).
-   Note : Query executed in command line, using CURL:
-
-```bash
-curl -XGET 'http://localhost:9200/gtest/block/_search' -d '{
-"query": {
-        "filtered" : {
-            "filter": {
-                "exists" : { "field" : "dividend" }
-            }
-        }
-    },
-    "_source": ["number", "dividend", "hash", "membersCount"]
- }'
-```
-
-
-More documentation here :
-
-  - ElasticSearch [official web site](http://www.elastic.co/guide/en/elasticsearch/reference/1.3/docs-get.html#get-source-filtering)
-  
-  - a good [tutorial](http://okfnlabs.org/blog/2013/07/01/elasticsearch-query-tutorial.html) 
-
-
-## Compile from source
- 
- Install required dependencies:
- 
-  - Install Java JDK (8 or more) 
-  
-  - Install [libsodium](http://doc.libsodium.org/installation/index.html)
- 
-    - Linux: after [installation](http://doc.libsodium.org/installation/index.html), make sure the file 'libsodium.so' exists on: /usr/local/lib or /opt/local/lib.
-      If not, create a symbolic link.
- 
-    - Windows: copy the file 'sodium.dll' into directory 'duniter4j-core/lib/'
- 
-  - Install [Maven 3](http://maven.apache.org/).
-```
-    sudo apt-get install maven
-```
- 
-  - Get the source code, then compile using Maven:
-
-```
-	git clone https://github.com/duniter/duniter4j.git
-	cd duniter4j
-	git submodule init
-	git submodule sync
-	git submodule update
-	
-    mvn install -DskipTests
-```
- 
- To package binaries :
-
-```bash
-$ mvn install -DskipTests -DperformRelease
-```
-
-## Roadmap
-
- - Maintain a updated list of peers  
- 
- - Add a new index for TX, with validation percentage 
- 
- - Enable P2P synchronisation between Duniter4j ES nodes
-
-
-## Troubleshooting
-
-### Could not find an implementation class.
-
-Message:
-
-```
-java.lang.RuntimeException: java.lang.RuntimeException: Could not find an implementation class.
-        at org.duniter.core.util.websocket.WebsocketClientEndpoint.<init>(WebsocketClientEndpoint.java:56)
-        at org.duniter.core.client.service.bma.BlockchainRemoteServiceImpl.addNewBlockListener(BlockchainRemoteServiceImpl.java:545)
-        at org.duniter.elasticsearch.service.BlockchainService.listenAndIndexNewBlock(BlockchainService.java:106)
-```
-
-Cause:
-
-Plugin use Websocket to get notification from a Duniter nodes. The current library ([Tyrus](https://tyrus.java.net/)) is loaded throw java Service Loader, that need access to file `META-INF/services/javax.websocket.ContainerProvider` contains by Tyrus.
-ElasticSearch use separated classloader, for each plugin, that disable access to META-INF resource.
-
-Solution :
+    * This API is used by [Cesium+](https://www.github.com/duniter/cesium) (a Duniter wallet).  
 
-Move Tyrus libraries into elasticsearch `lib/` directory :
 
-```
-    cd <ES_HOME>
-    mv plugins/duniter4j-elasticsearch/tyrus-*.jar lib
-    mv plugins/duniter4j-elasticsearch/javax.websocket-api-*.jar lib
-```
\ No newline at end of file
diff --git a/pom.xml b/pom.xml
index 2da59a99e84aa5cd08c00728e59becfa393a64e1..8bf6460219b1d3f32ba5ed1e53ab407bad819c79 100644
--- a/pom.xml
+++ b/pom.xml
@@ -43,7 +43,7 @@
     <stringtemplate.version>4.0.2</stringtemplate.version>
     <jTextUtilsVersion>0.3.3</jTextUtilsVersion>
 
-    <nuitonConfigVersion>3.1</nuitonConfigVersion>
+    <nuitonConfigVersion>3.0</nuitonConfigVersion>
     <nuitonVersionVersion>1.0-rc-2</nuitonVersionVersion>
     <nuitonI18nVersion>3.6.3</nuitonI18nVersion>
 
diff --git a/src/site/markdown/ES.md b/src/site/markdown/ES.md
index 22702a1aa42592833609d86da656fac064428245..0eb04d1fc885a03576d0bd2da4c5fc3bbd47f281 100644
--- a/src/site/markdown/ES.md
+++ b/src/site/markdown/ES.md
@@ -158,19 +158,11 @@ curl -XGET 'http://localhost:9200/gtest/block/_search' -d '{
 
 More documentation here :
 
-  - ElasticSearch [official web site](http://www.elastic.co/guide/en/elasticsearch/reference/1.3/docs-get.html#get-source-filtering)
+- [a development tutorial](./development_tutorial.html) (french);
   
-  - a good [tutorial](http://okfnlabs.org/blog/2013/07/01/elasticsearch-query-tutorial.html) 
-
-
-
-## Roadmap
-
- - Maintain a updated list of peers  
- 
- - Add a new index for TX, with validation percentage 
- 
- - Enable P2P synchronisation between Duniter4j ES nodes
+- [ElasticSearch official web site](http://www.elastic.co/guide/en/elasticsearch/reference/1.3/docs-get.html#get-source-filtering)
+  
+- [a good tutorial on ES query](http://okfnlabs.org/blog/2013/07/01/elasticsearch-query-tutorial.html) 
 
 
 ## Troubleshooting
diff --git a/src/site/markdown/index.md b/src/site/markdown/index.md
index 99935e5cb0eb8848b1ca0f3ffa21e0dd25047ac0..528a3f5886759ea23cd45401d52606eb750b94bf 100644
--- a/src/site/markdown/index.md
+++ b/src/site/markdown/index.md
@@ -18,4 +18,4 @@ Duniter4j has tree main modules :
    
    * It comes with an [HTTP API](./ES_API.html) to store and retrieve all this data.
    
-   * This API is used by [Cesium+](https://www.github.com/duniter/cesium) (a Duniter wallet client software).  
+   * This API is used by [Cesium+](https://www.github.com/duniter/cesium) (a Duniter wallet).