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).