57 Commits

Author SHA1 Message Date
6f50c200ee Added import/export to the demo app
- discovered private key length was wrong - fixed
- as things are broken anyway, refactored flyway migrations - you'll need to delete ~/jabit.*.db
2015-07-03 11:28:06 +02:00
65fdd7d408 Dropped obsolete table and set lower POW target for test (there is no need) 2015-07-03 09:04:35 +02:00
7f4c67f43e Removing IV of received objects from requested objects list (I forgot that one) 2015-07-03 07:56:18 +02:00
2c4d95af2f smarter network code, fixed various issues
- deciding on the stream at creation time is just silly - it should be done based on the identities (this part is TODO)
- changed NodeRegistry so it doesn't store nodes - this should help to connect faster
- inventory items shouldn't be advertised to nodes that are already aware of them (issue #13)
- objects shouldn't be requested more than once (issue #9)
2015-07-01 06:57:30 +02:00
c8960df2b3 issues #11 and #12 - import and export for Wallet Import Format 2015-06-27 07:52:28 +02:00
b150d08188 Fixed NPE 2015-06-23 22:29:44 +02:00
fefefe6809 Added some stuff necessary to publish to maven central - I hope it still builds on travis 2015-06-21 08:58:49 +02:00
027efe43df Version 0.1.2 bump - fixed problem where IPv4 Addresses weren't converted correctly. 2015-06-20 08:09:51 +02:00
72d0fbe550 Version 0.1.0 bump
Updated Gradle file structure so the version and a few other things are only defined once
2015-06-18 21:26:08 +02:00
1eb6851798 Updated and fixed JavaDoc 2015-06-18 18:25:47 +02:00
6be8d51f6d Distributable JAR build
- connection manager should now be rock stable
- does try to create new connections as long as there are less than eight active connections, which might result in more than eight outgoing connections, but this shouldn't be a problem
- some minor improvements and bug fixes
2015-06-18 13:41:11 +02:00
9b0de83706 Issue # 5: initialize node repository if there are no nodes in DB 2015-06-17 06:00:03 +02:00
c0a7acc609 Greatly improved network code - the "manage the node repository" part of issue #5 should now be OK 2015-06-16 06:41:59 +02:00
ed0d1c2911 issue #4: prevent connections to self, select random nodes to connect to 2015-06-13 17:37:55 +02:00
bd5bf76904 Improved connection management, preventing multiple connections to the same node, and improved broadcast handling. 2015-06-12 06:57:20 +02:00
b40d2e9f73 Fixed issue #8 - search for MAGIC bytes instead of just checking
(NOW it should work)
2015-06-11 20:00:37 +02:00
a053b64fe6 Fixed issue #8 - search for MAGIC bytes instead of just checking 2015-06-11 19:42:44 +02:00
effb2ac2fb Fixing issue #4 - leading zeroes must be omitted on writing the coordinate components 2015-06-10 02:46:45 +02:00
0566b27ce3 Fixed sending broadcasts 2015-06-10 01:02:03 +02:00
35996019a2 There's something wrong with the V5 broadcast signature. I'm not quite shure what it is, so I made a test. 2015-06-10 00:49:44 +02:00
b4683bba68 Broadcasts. Receiving seems to work, but there still seems to be a problem with sending them. 2015-06-09 22:45:24 +02:00
f76864eebd Added tests for all repositories, fixed some bugs and made database configurable 2015-06-05 13:43:56 +02:00
274c16b748 Implemented sending messages (and fixed a few bugs on the way)
This closes issue #3
2015-05-29 13:17:00 +02:00
593eebb33b Added some JavaDoc 2015-05-27 19:06:46 +02:00
f0d4f3f81f Updated version to 0.0.1 (I don't know why 1.0 is default for new projects/modules) 2015-05-26 17:30:45 +02:00
245ca22743 Updated documentation, added German translation 2015-05-24 21:55:37 +02:00
b347214b66 Introduced some custom exceptions 2015-05-23 16:01:18 +02:00
b793526f2f Inventory items are now saved only if processing didn't fail. Receiving messages works, but there seems to be a problem with the POW check in some circumstances. 2015-05-23 10:27:05 +02:00
6b3b361aa3 A simple command line application (WIP), and a few tests. Unfotrunately, receiving messages doesn't seem to work yet. 2015-05-22 20:51:57 +02:00
1fbc4a1d74 Major refactoring 2015-05-19 19:16:20 +02:00
07f185be35 Finally fixed address creation and private key import 2015-05-16 16:33:26 +02:00
cb1392e0f4 Signatures work 2015-05-15 15:25:06 +02:00
ed14e95d70 Signature check works 2015-05-15 12:36:57 +02:00
b996774ffb Some code cleanup 2015-05-12 19:37:42 +02:00
46bb00c0aa I don't believe it - encryption works!!! 2015-05-12 19:04:00 +02:00
f23f432f07 Decryption works now!
(well, for v4 pubkeys at least)
2015-05-09 17:27:45 +02:00
5d6484cdf3 Pubkey import now works properly
(well theoretically - practically we still need client support to store them)
2015-05-06 20:36:42 +02:00
fde6398156 Fixed some stuff and broke some other - my goal is to solely use the java.security API 2015-05-05 20:48:42 +02:00
a65907f13b Some work on addresses and private keys that still doesn't work. As a side effect, sending objects now works basically. 2015-05-01 17:14:43 +02:00
08c46b3a97 Some work on addresses, unfortunately it doesn't work yet. 2015-04-29 20:08:59 +02:00
00bd6a08b7 Added SerializationTest for object payload (which is probably the most important) 2015-04-28 18:36:07 +02:00
f00c6018e7 Some refactoring
- I didn't like the way the context was initialized
- The DatabaseRepository got too complicated
2015-04-24 11:11:08 +02:00
d3499c9627 Added some address generation and handling 2015-04-24 09:53:58 +02:00
51c1ecfd41 Minor refactoring
I think having the read method in the same place as the write method might help preventing some errors
There are some people who are strictly against using static methods. I suppose I'm not experienced enough yet.
2015-04-18 16:44:00 +02:00
2cd857dd36 If we compare IVs, they of course must properly implement the equals method
This fixes the bug where we would request objects again that were already stored.
2015-04-18 14:34:04 +02:00
ceae11b5c6 Minor DB updates
A node can support multiple streams. Unfortunately, an address can't so there might be multiple entries of the same address for different streams.
Also, store object types. I think we'll need them later, specially in search for public keys we requested.
2015-04-18 14:32:09 +02:00
e611e5e20a More or less properly shutdown client / network node 2015-04-17 13:01:46 +02:00
8d7b9f6457 Improved POW to use all cores. Interestingly, speed up factor seems to be greater than the number of cores (but still quite slow for real word application) 2015-04-17 11:17:39 +02:00
388a10fe8a Moved POW to its own port so it will be easily possible to create other (faster) implementations 2015-04-14 21:52:21 +02:00
32de01bbf5 Some basics seem to work now like storing messages, addresses, inventory vectors etc. 2015-04-14 19:47:53 +02:00