Commit graph

918 commits

Author SHA1 Message Date
orignal c4dffa4dc8 remove obsolete reseeds 2019-06-01 09:37:02 -04:00
orignal 5e10549543 disable NTCP by default 2019-05-30 19:18:56 -04:00
orignal 685f45bd76 publish/unpublish NTCP2 address depending on network status 2019-05-30 17:52:44 -04:00
orignal 61d84dd4c1 publish/unpublish NTCP2 address depending on network status 2019-05-30 17:48:49 -04:00
orignal 4d10593bb1 publish/unpublish NTCP2 address depending on network status 2019-05-30 16:11:35 -04:00
orignal fbb8903774 correct buffer size for ECDSA blinding 2019-05-30 13:57:43 -04:00
orignal e8cac91bb7 blind ECDSA public key 2019-05-29 15:48:35 -04:00
orignal 8e3d16e9fb update ipv6 addresses from SSU rather than NTCP or NTCP2 2019-05-29 11:36:58 -04:00
orignal 07405e57b9 fixed typo 2019-05-25 14:58:10 -04:00
orignal 354c9187db detect our ipv6 address 2019-05-23 15:59:44 -04:00
orignal af33df3004 common buffer size 2019-05-23 11:49:54 -04:00
orignal 78bfde237f allocate actual RouterInfo's buffer size 2019-05-23 09:34:04 -04:00
orignal 7b9033d678 allocate actual RouterInfo's buffer size 2019-05-23 09:32:07 -04:00
orignal f784cfad46 correct RouterInfo buffer size 2019-05-23 06:56:41 -04:00
orignal e40c139ff1 blind ECDSA private key 2019-05-22 16:15:11 -04:00
orignal 60ec03237e blidning for ECDSA 2019-05-16 15:49:07 -04:00
R4SAS a91641e427 fix #823, reindent code 2019-05-16 09:39:22 +03:00
orignal 743fa745b7 show b33 address for encrypted LeaseSet2 2019-05-14 14:42:10 -04:00
orignal 39400fd381 move key blinding code from LeaseSet.cpp to Blinding.cpp 2019-05-14 11:42:25 -04:00
orignal 5299ac35a6 create NTCP2 ipv6 address 2019-05-13 11:40:08 -04:00
orignal ef76ed394c publish SSU ipv6 address if NTCP if disabled 2019-05-12 13:36:26 -04:00
orignal 1472637de7 skip introducers for non-SSU address 2019-05-11 07:27:34 -04:00
orignal 3b8baa85a3 2.25.0 2019-05-09 10:21:11 -04:00
R4SAS 73921b1024 fix ipv6 fallback address 2019-05-08 00:45:52 +03:00
orignal 5e42947fbd always lookup SSU session if peer's endpoint doesn't match 2019-04-25 12:54:44 -04:00
orignal 1bfb9b02f5 make sure remote endpoint matches stored with 2019-04-24 11:40:58 -04:00
orignal f6199c6c17 print store hash for encrypted LeaseSet 2019-04-20 09:44:16 -04:00
orignal d7e7f06e88 re-request encrypted LeaseSet 2019-04-17 15:53:07 -04:00
orignal 4c4e856a1a ntcp2.addressv6 parameter 2019-04-17 14:40:00 -04:00
orignal 07bbbbaf61 fixed gcc 4.7 build 2019-04-17 12:42:43 -04:00
orignal 3236827781 add/removed NTCP addresses 2019-04-16 21:04:04 -04:00
orignal 0be664cc3d publish NTCP2 address instead NTCP if NTCP is disabled 2019-04-15 16:32:16 -04:00
orignal 6cc6849ccc use published timestamp for blinding 2019-04-12 14:05:07 -04:00
orignal 5d5cd71714 limit expiration by next midnight for encrypted LS2 2019-04-12 11:13:46 -04:00
orignal d248343517 Handle CreateLeaseSet2 I2CP message for encrypted leasesets 2019-04-11 14:06:53 -04:00
orignal 64d800427f allow HTTP headers without value 2019-04-10 15:25:09 -04:00
orignal c4c896a833 publish encrypted LS2 2019-04-10 12:04:19 -04:00
orignal b6b5bb3f75 publish LeaseSet with store hash 2019-04-09 15:36:10 -04:00
orignal 5d69bb7383 correct ecrypted LS2 layout 2019-04-09 10:34:05 -04:00
orignal 76e222079a Merge branch 'openssl' of https://github.com/PurpleI2P/i2pd into openssl 2019-04-09 09:21:47 -04:00
orignal 73abb9278d correct ecrypted LS2 size 2019-04-09 09:21:38 -04:00
orignal 8fd843e7ce
Merge pull request #1334 from rex4539/fix-typos
Fix typos
2019-04-08 17:36:55 -04:00
Dimitris Apostolou 6a497a23d9
Fix typos 2019-04-08 22:22:42 +03:00
orignal 3ac74e1091 create encrypted LS2 2019-04-08 13:27:21 -04:00
orignal ef0fb48f1f blind private keys 2019-04-05 16:03:58 -04:00
orignal ea791309ad moved credential and blinding to BlindedPublicKey 2019-04-02 16:32:18 -04:00
orignal 5b56f4007b counter is always in Little Endian 2019-03-29 18:45:31 -04:00
orignal e2071542bf use 16 bytes iv for chacha20 2019-03-29 16:18:51 -04:00
orignal cdb217b774 always initialize m_Pkey 2019-03-29 13:15:32 -04:00
orignal 3fd9d5f641 save b33 addresses 2019-03-28 16:06:53 -04:00
orignal 00b5fdce03 create stream to blinded dest 2019-03-27 16:04:46 -04:00
orignal ff44bcc489 complete implementation of RedDSA 2019-03-24 18:42:52 -04:00
orignal 3d4d260a34 extract b33 address 2019-03-22 16:04:47 -04:00
orignal 8e4b9da97d pass blinded key instead identity for encrypted LS2 2019-03-22 15:32:13 -04:00
orignal cdfd411df7 2.24.0 2019-03-21 10:58:59 -04:00
orignal aa4bddd6ec common HKDF 2019-03-15 12:25:20 -04:00
orignal 8ec12a1b65 fixed race condition for publishing 2019-03-10 09:22:42 -04:00
orignal 0fbf552e95 lookup and handle encrypted LeaseSet2 2019-03-07 14:52:59 -05:00
orignal 09b1b120d7 update LeaseSet2 if store type changed 2019-03-07 14:51:05 -05:00
orignal 557244bc3f verify blinding key for encrypted LS2 2019-03-07 11:55:47 -05:00
orignal 24c5ed1cff calculate store hash for encrypted LeaseSet2 2019-03-06 16:08:04 -05:00
orignal 32e55ebd0c blind public key for encrypted LeaseSet2 2019-03-05 15:51:24 -05:00
orignal ea3070d02b derivation of subcredentials for LeaseSet2 2019-03-05 12:41:01 -05:00
orignal 9aaba49a9f decrypt and handle Layer 2 of encrypted LeaseSet 2 2019-03-04 15:47:35 -05:00
orignal 9b64be07a9 set chacha20 counter to 1 2019-03-04 15:08:03 -05:00
orignal 560ebcec8d persist.addressbook parameter added 2019-03-01 14:42:20 -05:00
orignal 9b1fe4338b reuse_address for ipv6 acceptor 2019-02-28 16:00:26 -05:00
orignal 9188e3ad3f ChaCha20 decrypt 2019-02-28 13:31:51 -05:00
orignal af65af5be9 H and HKDF for encrypted LeaseSet2 2019-02-27 15:52:47 -05:00
orignal 2f0115c300 handle RedDSA as EdDSA 2019-02-27 13:18:09 -05:00
orignal 0646461342 check published timestamp for LeaseSet2 2019-02-26 16:20:24 -05:00
orignal 846eac29dc filter out unspecified addresses. Check floodfill status change 2019-02-24 18:26:58 -05:00
orignal 0f9e3c5b33 fix crash if public key is null 2019-02-22 13:17:43 -05:00
orignal aa27746982 remove address string 2019-02-22 11:03:31 -05:00
R4SAS d8a4954bf1 [NetDb] check PersistProfiles on load
* tabulation fixes
2019-02-22 18:37:32 +03:00
orignal d40a029dae eliminate extra copy 2019-02-20 12:36:05 -05:00
orignal 96d961c393 correct public key for EdDSA trasient key 2019-02-15 15:03:58 -05:00
orignal 7b6814e32d correct flags 2019-02-14 21:22:49 -05:00
orignal 6fee2d3536 correct options szie 2019-02-14 17:49:23 -05:00
orignal 636fc633d4 send offline signature in streaming 2019-02-14 12:11:25 -05:00
orignal 72a239838e publish offline signature 2019-02-12 14:56:39 -05:00
R4SAS 7d0d421724 [windows] handle unexpected conditions (#1185) 2019-02-12 04:27:09 +03:00
orignal 80ffe13f3e correct offline signature layout 2019-02-08 15:12:51 -05:00
orignal 1eb726c9bb create offline keys 2019-02-08 12:19:51 -05:00
orignal 1fa3ba8b42 read offline info 2019-02-07 16:04:31 -05:00
orignal b6bfd66a49 use identity from LeaseSet 2019-02-06 21:19:44 -05:00
orignal 2cac9b03ff common code for offline signatures 2019-02-06 13:36:03 -05:00
R4SAS f5f4190803 catch error 10045 on stopping SAM acceptor (#1233), fix warning in util 2019-02-06 03:03:37 +03:00
R4SAS a14d554947 fix tray icon disappearing, var type warning, code tabulation 2019-02-06 00:24:01 +03:00
orignal 6d9e5147b5 handle offline signature 2019-02-05 15:32:18 -05:00
R4SAS 9c76368dbc inet_pton for winxp 2019-02-05 14:13:23 +03:00
orignal bd5122c6ea fixed build error 2019-02-01 17:41:12 -05:00
orignal 6643258618 implement Update for LeaseSet2 2019-02-01 12:55:13 -05:00
orignal bc3f02cb6b fix #1290. copy correct size if message didn't fit previous 2019-01-31 16:03:10 -05:00
orignal d848ae332a encryption keys priority 2019-01-30 14:10:40 -05:00
orignal 08ddc98303 initial LeaseSet2 support in I2CP 2019-01-29 11:30:31 -05:00
orignal 22c1ce3ea5 don't pick port 9150 (Tor browser) 2019-01-23 09:53:30 -05:00
orignal 60a282826c 2.23.0 2019-01-21 10:33:22 -05:00
orignal 65c2c7d80b re-create LeaseSet if store type has changed 2019-01-16 19:00:17 -05:00
orignal 468a32a819 check LS2 transient key expires time 2019-01-15 18:56:26 -05:00
orignal b89cf73ae2 correct encryption key type for LS2 2019-01-15 18:41:00 -05:00
orignal 9cf43dea1a handle i2cp.leaseSetEncType 2019-01-15 15:43:21 -05:00
orignal 884cf756ed remove invalid leasesets 2019-01-14 18:37:17 -05:00
orignal 3712749a94 extract timestamp for LS2 2019-01-14 13:49:27 -05:00
orignal 6569c4aa03 actual key size for LS2 2019-01-13 19:17:02 -05:00
orignal d6b2b3c996 take key type for LS2 from identity 2019-01-13 08:34:34 -05:00
orignal 52a6a12a9a correct LS2 creation 2019-01-12 18:25:10 -05:00
orignal e647603dce handle i2cp.leaseSetType parameter 2019-01-11 13:58:02 -05:00
orignal dadf6174ba create standard LS2 2019-01-10 11:52:34 -05:00
orignal 84de7675c4 don't copy LS2 for signature verification 2019-01-10 10:57:57 -05:00
orignal 9504e69598 LocalLeaseSet2 added 2019-01-09 14:51:47 -05:00
orignal 5398b651f7 handle LS2 in destinations 2019-01-09 12:47:47 -05:00
orignal b5596c4596 handle encrypted LS2 2019-01-08 11:26:50 -05:00
orignal 8ca8bc810d take elgamal percomputation from config 2019-01-08 09:23:14 -05:00
Rosen Penev 90f2b2d249 Fix compilation without deprecated OpenSSL APIs 2019-01-06 15:39:24 -08:00
orignal f74b27c58c check if chacha20 and poly1305 is presented in openssl build 2019-01-06 17:43:05 -05:00
orignal e55e15693d update LS2 leases 2019-01-02 15:40:48 -05:00
orignal c54e6bafdb process meta LS2 2019-01-02 14:19:10 -05:00
orignal 2e56c4895d transient key signature verification 2019-01-02 09:43:18 -05:00
orignal bce4224d6e extract and verify LS2 transient key 2019-01-01 17:00:37 -05:00
orignal 812e2814bc read flags from LS2 header 2018-12-31 14:23:48 -05:00
r4sas 7cd17f8e1f build android app with llvm 2018-12-27 03:16:38 +03:00
orignal 6193b06708 LS2 signature verification and store type 2018-12-26 15:27:32 -05:00
orignal 12af68bdb5 initial support of LeaseSet2 2018-12-21 15:00:03 -05:00
orignal 1933e44719 reseeds update 2018-12-17 20:14:12 -05:00
orignal 8a987af244 initialize m_Pkey 2018-12-11 15:14:51 -05:00
orignal 65cbb06080 create ephemeral keys after getting connected 2018-12-07 19:24:46 -05:00
orignal 979ea9c252 removed address resolvers as discontinued 2018-12-07 12:27:06 -05:00
orignal c7af2889fa removed dummy initializer 2018-12-05 14:56:40 -05:00
orignal 5ab3390434 don't create dummy initializer for android 2018-12-05 11:39:48 -05:00
orignal 67f60f1889 set openssl no_config before boost::asio:ssl 2018-12-04 21:20:12 -05:00
orignal 985a468d0f don't read openssl config file 2018-12-04 18:39:49 -05:00
orignal 34dc6fbdc1 check if session is terminated before sending 2018-12-04 16:10:52 -05:00
orignal b57152cc25 common code for padding and sending termination and RouterInfo messages 2018-12-04 15:56:55 -05:00
orignal dc9562e430 padding for termination message 2018-12-04 15:23:43 -05:00
orignal 05689fe183 padding for short messages 2018-12-04 15:00:10 -05:00
orignal 8f6f95211e eliminate extra copy of RouterInfo 2018-12-04 12:56:49 -05:00
orignal f30b6c9e6e const reference to vector of buffers 2018-12-04 12:54:48 -05:00
orignal 12ac7d6a00 enable sending I2NP messages 2018-12-03 18:47:20 -05:00
orignal 10251a6447 fixed typo 2018-12-03 15:54:35 -05:00
orignal 089cbbc20a rollback 2018-12-03 14:51:27 -05:00
orignal 95ab68acd1 don't copy I2NP messages to NTCP2 frame 2018-12-03 14:14:36 -05:00
orignal abc4f6c70b fixed bug with chacha20 encryption of short messages 2018-12-03 13:36:17 -05:00
orignal 8fc3a1f9c9 correct frame size for I2NP msgs 2018-12-03 12:29:24 -05:00
orignal 5c3d0fc02c create I2NP blocks 2018-12-02 17:24:31 -05:00
orignal 7efb47fed4 send NTCP2 frame from I2NP messages 2018-12-02 14:24:39 -05:00
orignal 7692332f0e don't inialize Chacha20 state twice 2018-11-30 21:31:06 -05:00
orignal ef6db64e9f correct chacha20 for multiple messages 2018-11-30 16:21:11 -05:00
orignal e68f1dbc99 AEAD/Chacha20/Poly1305 encrypt multiple buffers 2018-11-30 14:41:14 -05:00
orignal 0c9ebc36d4 remove AVX and SSE for CipherBlock XOR 2018-11-27 14:33:31 -05:00
orignal 328c2182c2 alignment for tunnel message AES decryption 2018-11-27 10:35:17 -05:00
orignal 08706f5dfb fixed typo 2018-11-25 18:49:59 -05:00
orignal d49f165f0d fixed build warning 2018-11-25 15:59:00 -05:00
orignal cf0fc3a4a9 some performance improvements 2018-11-25 10:33:48 -05:00
orignal 72c8fd257c eliminate extra buffer for Poly1305 2018-11-24 15:39:37 -05:00
orignal fa620e41a4 correct alignment for polyKey 2018-11-24 14:41:17 -05:00
Jeff Becker 16b3108719
Merge remote-tracking branch 'purple/openssl' into openssl 2018-11-24 10:08:12 -05:00
Jeff Becker f385c624c7
expose poly1305 digester 2018-11-24 10:07:17 -05:00
orignal f7e9975192 restore BlockCipher XOR using SSE 2018-11-24 09:43:30 -05:00
orignal cde989b59d don't compile compatibility code if openssl 1.1.1 2018-11-22 12:13:16 -05:00
orignal c0e263abd3 default value for m_PersistProfiles 2018-11-22 11:30:44 -05:00
R4SAS 79c0c11e80 configure persist of peer profiles
* If persist.profiles = false, peer profiles not stored on disk
* remove inet_pton for windows
* update configs
2018-11-22 00:13:23 +03:00
orignal ca671551c8 flood NTCP2 RouterInfo if requested 2018-11-21 13:24:54 -05:00
orignal 42ed312384 handle NTCP2 RouterInfo flag 2018-11-21 11:23:48 -05:00
orignal 0e9074aaba reduce start and stop time 2018-11-20 13:57:51 -05:00
orignal 8a549b83a2 NTP sync in separate thread 2018-11-16 12:49:04 -05:00
orignal d7081c5f23 handle RouterInfo from NTCP2 in netdb's thread 2018-11-14 20:52:54 -05:00
orignal 588d64a30b more NTP logging 2018-11-14 12:27:11 -05:00
orignal 8335bdf3d4 correct ntp servers 2018-11-14 11:47:50 -05:00
orignal 85394f2438 NTP time sync 2018-11-14 11:06:53 -05:00
asokolov a26ed6fe6c Merge remote-tracking branch 'upstream/openssl' into webroot 2018-11-09 16:30:54 +03:00
R4SAS 779228857e 2.22.0 2018-11-09 02:22:55 +00:00
asokolov 23ae220aa7 add webroot setting 2018-11-07 18:07:05 +03:00
orignal b3fd8bd0ae check if keys are available before sending termination message 2018-11-04 18:51:25 -05:00
orignal bffeb237de termination might be send for non-established session 2018-11-04 15:32:31 -05:00
orignal 23e3602ea1 common MixHash 2018-11-01 16:06:39 -04:00
orignal 34cfd205f6 create new static keys by X25519Keys 2018-11-01 10:43:31 -04:00
l-n-s a141678119 Add --version flag to display i2pd and system libraries versions 2018-10-28 10:52:22 -04:00
orignal 96d109af81 fixed typo 2018-10-27 19:55:23 -04:00
orignal a309eb9f3c faster CipherBlock XOR implementation for non-AVX 2018-10-27 18:41:05 -04:00
orignal d034dab265 fill m3p2 with SessionRequest 2018-10-26 09:58:18 -04:00
orignal a2e84e5a1e 2.21.1 2018-10-22 09:19:39 -04:00
orignal 9439621849 fixed #1259. read extra tunnels from tunnels.d 2018-10-19 15:23:46 -04:00
orignal 15ded89618 set cost=14 for unpublished NTCP2 addresses 2018-10-11 13:00:37 -04:00
orignal b84f74c167 limit SSU message size to 32K 2018-10-11 11:17:14 -04:00
orignal a97300f8be fixed #1256 I2NP messages up to 64K 2018-10-10 11:31:55 -04:00
orignal 15899c10b2 2.21.0 2018-10-04 09:38:04 -04:00
orignal af793395f0 don't publish O with X or P 2018-09-30 16:08:26 -04:00
orignal 8f41776858 check send queue size 2018-09-28 09:54:42 -04:00
orignal 5f7dda5ba8 treat extra bandwidth as high bandwidth 2018-09-22 14:12:46 -04:00
orignal 2dfa1ca0f2 check RouterInfo's timestamp in SessionConfirmed 2018-09-21 11:45:04 -04:00
orignal 358cdcf4c4 removed RSA signatures completly 2018-09-21 11:16:38 -04:00
orignal c8f4ace5c4 update timestamp before publishing 2018-09-21 10:13:18 -04:00
orignal 5cac6ca8bb read message body immediatly after length 2018-09-17 13:08:49 -04:00
orignal fccad71df1 temporary buffer for EdDSA signature for openssl 1.1.1 2018-09-16 18:08:59 -04:00
orignal 97ae2674dc always use EdDsa signer fallback 2018-09-14 21:54:45 -04:00
orignal 7c70affd7f eddsa signer fallback 2018-09-14 21:23:16 -04:00
orignal 52ff568d86 fixed incorrect second signature 2018-09-14 18:58:40 -04:00
orignal 8de443ec4c siphash from openssl 1.1.1 2018-09-11 13:26:29 -04:00
orignal 7d9893c614 fixed build error 2018-09-09 17:27:53 -04:00
orignal 3540712517 some cleanup 2018-09-09 08:38:12 -04:00
orignal a8b1a86bd7 X25519Keys for static key 2018-09-08 22:08:08 -04:00
orignal 1babd3a5a2 separate X25519Keys 2018-09-08 16:52:42 -04:00
orignal 33aa8e2471 use x25519 from openssl 1.1.1 for ephemeral keys 2018-09-05 11:19:58 -04:00
orignal 2c58fe736b fixed build error with openssl 1.1.1 2018-09-05 09:51:03 -04:00
orignal 2c3b19a539 use EdDSA from openssl 1.1.1 2018-09-03 17:39:49 -04:00
orignal b67424643d done insert NTCP2 ipv6 address twice 2018-08-27 18:56:57 -04:00
orignal 575a4c01c9 publish NTCP2 adress if port is specified 2018-08-27 18:35:35 -04:00
orignal f0d4ee6618 pass NTCP2 ipv6 address 2018-08-27 16:01:47 -04:00
orignal 8753186a0d publish NTCP2 ipv6 address if applicable 2018-08-27 15:01:43 -04:00
orignal 9dd38b99d6 check NTCP2 for addreses comparison 2018-08-26 09:40:27 -04:00
orignal 71ac0286b1 2.20.0 2018-08-23 10:24:44 -04:00
orignal 022f4d2c11 don't send message to not established session 2018-08-23 07:23:50 -04:00
orignal b259ee89aa send RouterInfo from NTCP2Server's thread 2018-08-22 12:33:43 -04:00
orignal d9476fb5ca set correct IV when NTCP2 address gets published 2018-08-19 16:17:57 -04:00
orignal 2d758ce963 change cost for NTCP and NTCP2 2018-08-18 13:52:35 -04:00
orignal 1dd003d26a check m2p3len 2018-08-18 08:27:36 -04:00
orignal 5e110e9f7b enable NTCP2 by default 2018-08-16 13:48:47 -04:00
orignal 77a409935d license added 2018-08-16 13:46:59 -04:00
orignal 11142690a0 show correct value of time drift 2018-08-16 10:13:32 -04:00
orignal 02e8c5faca fixed typo 2018-08-15 13:23:10 -04:00
orignal c41081d35c check timestamps 2018-08-15 11:42:56 -04:00
orignal e4ab51329d move handshake messages processing to NTCP2Establisher 2018-08-14 14:01:04 -04:00
orignal 86782aeb1b don't send RouterInfo twice 2018-08-14 11:27:27 -04:00
orignal 49a44fc92e assume siphash IV in Litte Endian 2018-08-13 14:07:57 -04:00
orignal cd39a52c25 correct endianness for siphash length 2018-08-13 13:43:51 -04:00
l-n-s 29b91075d2 Don't add SSU/NTCP addresses to RI if they are disabled in config (#1220) 2018-08-12 02:36:00 -04:00
orignal 6d46fc9f9f check send frame error code 2018-08-11 16:08:21 -04:00
orignal a2c41c9e36 allow NTCP2 only transports 2018-08-10 15:35:43 -04:00
orignal ee700ac861 fixed incorrect iv for published NTCP2 addresses 2018-08-10 15:14:07 -04:00
orignal 9884a4336f don't connect to NTCP2 only address using NTCP 2018-08-10 13:42:59 -04:00
orignal 5b83d4bef8 move handshake messages creation to NTCP2Establisher 2018-08-10 10:53:34 -04:00
orignal d320a89590 don't copy buffer to ifself 2018-08-09 16:32:43 -04:00
orignal f7e4afc282 use same buffer for input and output for AEAD/Chacha20/Poly1305 2018-08-09 15:47:02 -04:00
orignal 88e87d589b add incoming NTCP2 session to the sessions list 2018-08-09 14:20:10 -04:00
orignal d8c6dede7e moved NTCP2 handshake buffers to establisher 2018-08-09 12:53:36 -04:00
orignal 5cc84133e3 fixed incorrect lenght 2018-08-08 17:38:21 -04:00
orignal f7728aa1f6 reuse NTCP2 frame buffers 2018-08-08 16:23:44 -04:00
orignal 2b61f9a731 fixed #1217. verify decryption result 2018-08-07 10:35:25 -04:00
orignal f407022fe6 connect to NTCP2 address if presented 2018-08-04 13:48:09 -04:00
orignal 41b9f19b01 get unpublished NTCP2 address 2018-08-04 08:47:58 -04:00
orignal 09c6faf923 don't overwrite NTCP2 keys 2018-08-03 21:16:35 -04:00
orignal 26d0177c01 always make NTCP address first 2018-08-03 20:28:29 -04:00
orignal f7415c8a8f enable/disable NTCP2 address 2018-08-03 14:49:28 -04:00
orignal 4cf79088f9 NTCP2 idle timeout 2018-08-03 13:19:35 -04:00
orignal 50cd321818 NTCP2 idle timeout 2018-08-03 13:10:32 -04:00
orignal 0a33c18e36 send termination message 2018-08-02 15:31:15 -04:00
orignal 6cf158ac63 check RouterInfo from SessionConfirmed 2018-08-02 13:58:47 -04:00
orignal f96bfa6afa send RouterInfo 2018-08-02 12:42:39 -04:00
orignal 2b64cf9126 publish i in correct place for NTCP2 2018-08-01 12:28:34 -04:00
orignal a8dcfc44f5 handle termination message 2018-08-01 09:43:48 -04:00
orignal 0ff9c9da27 complete Bob side of NTCP2 2018-07-31 15:41:13 -04:00
orignal 07e7c2d852 ntcp2.published and ntcp2.port parameters 2018-07-31 12:59:38 -04:00
orignal 10e4b5b2a3 ignore NTCP2 addresses 2018-07-23 15:44:36 -04:00
orignal 998653ea9d NTCP2 acceptors 2018-07-23 15:30:51 -04:00
orignal 1a38e925bf publish NTCP2 address 2018-07-23 13:51:29 -04:00
orignal c8f51380e6 publish NTCP2 for new routers 2018-07-21 16:59:58 -04:00
orignal 5bedfc1c84 post I2NP messages to NTCP2 thread 2018-07-19 12:46:19 -04:00
orignal 5001592fb4 replace ntcp2 by ntcp2.enabled 2018-07-19 09:45:24 -04:00
orignal f6495e59c5 better MixHash 2018-07-19 09:27:59 -04:00
orignal 66bf431481 correct KDF1 calculation 2018-07-18 16:27:43 -04:00
orignal d9685e991e handle RouterInfo block 2018-07-18 15:57:18 -04:00
orignal e0790700cd don't connect to unpublished NTCP2 addresses 2018-07-18 14:19:12 -04:00
orignal 910a9600bd display NTCP2 session in web console 2018-07-18 12:58:29 -04:00
orignal fc52b2b940 fixed typo 2018-07-18 12:56:46 -04:00
orignal b99f828583 send I2NP messages through NTCP2 2018-07-18 11:16:40 -04:00
orignal f38891cace fixed build for gcc < 4.8 2018-07-18 11:15:27 -04:00
orignal 8c5111e11a handle NTCP2 I2NP messages 2018-07-17 15:17:05 -04:00
orignal 5575b981c8 enable NTCP2 as transport 2018-07-13 15:59:28 -04:00
yangfl 52f3081a40 fix typo 2018-07-10 17:39:21 +08:00
orignal 00c71dc26a handle SessionConfirmed 2018-07-09 15:56:23 -04:00
orignal 5218c8584f some refactoring of NTCP2 code 2018-07-04 14:15:40 -04:00
orignal 6054bd6621 NTCP2 session establisher 2018-07-03 16:26:02 -04:00
Dmitry Marakasov 4ffbb46cf9 Fix "macro expansion producing 'defined' has undefined behavior" clang warning 2018-06-27 22:31:01 +03:00
yangfl dec848f072 use builtin __AVX__ and __AES__ macros and reduce code duplication 2018-06-27 17:32:38 +08:00
orignal 00df3f8d4e 2.19.0 2018-06-26 13:36:30 -04:00
orignal 5bc157eb19 send data frame for NTCP2 2018-06-25 12:28:07 -04:00
orignal 0aa618b938 process AEAD/Chacha20/Poly1305 frame for data phase of NTCP2 2018-06-22 15:02:49 -04:00
orignal 5884852612 correct usage of sipkeys 2018-06-22 12:20:35 -04:00
orignal 5b29592174 generate sipkeys for data pahse of NTCP2 2018-06-21 16:24:19 -04:00
orignal 96411cc93e derive keys for siphash 2018-06-21 12:39:24 -04:00
R4SAS 7d862d8eba service and daemon works as bool without values, other requires true/false 2018-06-21 09:40:53 +03:00
R4SAS dd392941d0 update Config.cpp, links to examples, manpage 2018-06-21 09:40:53 +03:00
orignal 3cec5235c9 NTCP2 according to new specs 2018-06-20 16:09:22 -04:00
orignal b5682012d3 process SessionRequest and send SessionCreated for NTCP2 2018-06-19 15:43:47 -04:00
orignal 9c7cadb191 better implementation of x25519 2018-06-19 11:14:22 -04:00
orignal 58c92b8405 aead/chacha20/poly1305 from openssl 1.1 2018-06-18 12:56:47 -04:00
R4SAS 985b618932 addng forgotten bracket 2018-06-16 23:07:03 +03:00
R4SAS bdc7acffbe remove zero_tokens(), update manpage 2018-06-16 22:38:59 +03:00
R4SAS 6bd73cdea2 Update help message, debian manpage. Prepare changelog message 2018-06-16 18:11:46 +03:00
orignal e05110ff44 send RouterInfo in SessionConfirmed 2018-06-15 14:56:03 -04:00
orignal 706b976a28 handle and publish NTCP2 address 2018-06-15 12:52:43 -04:00
orignal 2bd7a92d20 send SessionConfirmed 2018-06-14 15:29:36 -04:00
orignal 6b37a41e00 correct ad calculation for SessionCreated 2018-06-14 10:45:25 -04:00
orignal 5447259e1a AEAD/ChaCha20/Poly1305 decryption and SessionCreate prcessing 2018-06-13 16:16:23 -04:00
orignal ee0ae0b74b decrypt Y for NTCP2 2018-06-13 14:56:51 -04:00
orignal 966256ac32 correct Poly1305 calculation 2018-06-13 12:58:32 -04:00
orignal 6b9061515f AEAD/ChaCha20/Poly1305 test added 2018-06-13 12:25:32 -04:00
orignal df60e78766 AEAD/Chacha20/Poly1305 encryption 2018-06-13 11:41:46 -04:00
orignal 3b46e9f351 fixed typo 2018-06-12 14:55:40 -04:00
orignal 046a80cfe4 scalar multiplication for x25519 2018-06-12 12:42:20 -04:00
orignal a8278fc78b router's NTCP2 private keys 2018-06-11 15:33:48 -04:00
orignal 7f3127ac89 pass unencrypted X to KDF 2018-06-11 14:32:15 -04:00
orignal 7cdb021a1f pass correct nonce to chacha20 2018-06-11 14:05:30 -04:00
orignal 74c0b729c2 connect to NTCP2 2018-06-11 12:29:30 -04:00
orignal 5cb81f8532 send SessionRequest message 2018-06-06 15:38:18 -04:00
orignal 4f23d7b7df recognize routers with NTCP2 2018-06-06 11:51:34 -04:00
orignal a70d0edf2e encrypt SessionRequest options block 2018-06-05 16:15:33 -04:00
orignal 8c9eaccc11 KeyDerivationFunction for NTCP2 2018-06-05 15:37:08 -04:00
orignal 86c1984982 NTCP2 added 2018-06-05 12:53:13 -04:00
orignal cd0f75106a moved Ed25519 away from signature 2018-06-04 16:06:38 -04:00
orignal 4cedaa9e80 fixed android build 2018-05-28 09:49:59 -04:00
orignal 5d86c1c9a6 ntcp2 crypto added 2018-05-24 14:27:26 -04:00
mewmew@i2p ed2818eaa2 qt log viewer now works 2018-05-19 23:06:06 +08:00
orignal db03595473
correct message size 2018-04-29 18:05:28 -04:00
Jeff Becker a63bc1cdca
correct sizes 2018-04-29 11:41:03 -04:00
Jeff Becker 6265d452e9
more bounds checking 2018-04-29 11:34:23 -04:00
orignal 0df68872ab
Merge pull request #1169 from majestrate/master
SAM fixes
2018-04-25 12:02:51 -04:00
Jeff Becker 0ced38cdcb
tabify 2018-04-25 11:27:56 -04:00
Sammael 97127e86dc
Delete some for correct compilation 2018-04-25 01:59:11 +07:00
Arm64 plaz 66de7ad049 for first time disable aesenc for arm64 2018-04-24 18:23:40 +00:00
Jeff Becker 4643c92d33
Initial SAM cleanup 2018-04-24 09:45:16 -04:00
Jeff Becker fa154cc4d6
Merge remote-tracking branch 'purple/openssl' 2018-04-22 07:52:49 -04:00
R4SAS e2da16e9c3
moved reseed out 2018-04-19 19:46:00 +03:00
Jeff Becker eefbbd4efe
remove all related streaming limit members 2018-04-16 09:47:35 -04:00
Jeff Becker 83932a6f02
remove streaming bans 2018-04-16 09:38:32 -04:00
orignal ff4e254618 0.9.34 2018-04-11 10:30:13 -04:00
Jeff Becker 571a13f0a7
Merge remote-tracking branch 'purple/master' 2018-04-08 19:56:48 -04:00
orignal 2cb6283d00 outproxy authorization 2018-04-06 15:23:56 -04:00
orignal f4056e57bb rollback 2018-04-05 07:16:41 -04:00
Hypnosis-mewmew e80da3cbeb fixes for i2pd_qt MSYS2 mingw32 2018-04-05 15:40:44 +08:00
Jeff Becker ff5c26adf2
Merge remote-tracking branch 'purple/openssl' into fix-ntcp-threading-race 2018-03-24 07:56:49 -04:00
Jeff Becker 5361e11395
fix race 2018-03-24 07:53:06 -04:00
orignal b041bcdc65 publish updated LeaseSet in destination's thread 2018-03-23 11:41:36 -04:00
orignal b7c350202d always create EdDSA RouterInfo 2018-03-20 20:43:47 -04:00
orignal b1a6c5ddf7 fixed build for gcc 4.7 2018-03-16 11:12:18 -04:00
orignal 182ffe4495 use croorect encryption type for tunnel build 2018-03-09 14:56:06 -05:00
orignal 066f8863fd pass zero padding parameter to ECEIS encryption 2018-03-07 16:08:44 -05:00
orignal e58aaa3f32 make sure tunnelID is non-zero 2018-03-07 12:36:38 -05:00
orignal 5a2b795440 fixed crash 2018-02-26 19:41:24 -05:00
Jeff Becker 7b4fc19fca
be concise 2018-02-26 08:18:01 -05:00
Jeff Becker 008a064764
revert 2018-02-26 08:12:15 -05:00
Jeff Becker 82a4630061
use correct function 2018-02-26 08:09:26 -05:00
Jeff Becker 2f7cfddfc4
Merge remote-tracking branch 'purple/openssl' into i2cp-session-reconfig 2018-02-26 07:58:03 -05:00
orignal c7accd4a5c
Merge pull request #1122 from majestrate/ntcp-threadpool
NTCP threadpool
2018-02-20 14:49:01 -05:00
Jeff Becker b469080cd7
make ntcp worker threads configurable in number 2018-02-20 13:18:57 -05:00
Jeff Becker 547a0057e6
whitespace cleanup 2018-02-20 13:04:39 -05:00
Jeff Becker b980ca4a9e
whitespace cleanup 2018-02-20 13:03:34 -05:00
Jeff Becker 098b2e968e
whitespace cleanup 2018-02-20 13:03:01 -05:00
Jeff Becker cd59ca8376
whitespace cleanup 2018-02-20 12:59:39 -05:00
Jeff Becker f2e6fad104
make it work 2018-02-20 12:40:28 -05:00
Jeff Becker 8d7fde0287
more 2018-02-20 11:43:13 -05:00
Jeff Becker 91fdb038d9
add threadpool for ntcp dh 2018-02-20 11:38:48 -05:00
Jeff b64878f4fa use std::move 2018-02-19 10:45:02 -05:00
Jeff a5cc2f3b5d define bit_* if not already defined 2018-02-19 10:15:39 -05:00
Jeff 9c93d6f931 Revert "define cpu_* if not set"
This reverts commit a077d7671f.
2018-02-19 10:15:26 -05:00
Jeff a077d7671f define cpu_* if not set 2018-02-19 10:15:03 -05:00
orignal 30fb0f5a94
Merge pull request #1116 from majestrate/netbsd
NetBSD support
2018-02-17 07:22:51 -05:00
Jeff Becker b02464990b
work around netbsd quarkyness 2018-02-16 18:54:34 -05:00
Jeff Becker 4988a32d33
make endian work with netbsd 2018-02-16 18:27:30 -05:00
orignal b3e5874631 fixed android build error 2018-02-16 13:56:44 -05:00
orignal f5349dcef9
Merge pull request #1115 from majestrate/aesni-avx-runtime-detect
AESNI/AVX runtime detection [WIP]
2018-02-16 12:40:28 -05:00
Jeff Becker a618a01b1e
don 2018-02-16 11:26:07 -05:00
Jeff Becker 7e60069968
add uncommitted files 2018-02-16 11:01:04 -05:00
Jeff Becker 91e45d9a4a
initial code for runtime detection of aesni/avx 2018-02-16 11:00:33 -05:00
orignal b7596b7f70
Merge pull request #1112 from majestrate/dns-rebind
mitigate dns rebinding in webui
2018-02-15 09:57:16 -05:00
Jeff Becker 0309b574e8
mitigate dns rebinding in webui 2018-02-15 09:52:20 -05:00
orignal f2a14047eb
Merge pull request #1108 from majestrate/fix-issue-1107
Fix issue 1107
2018-02-11 06:48:01 -05:00
Jeff Becker 124a9cb030
correction 2018-02-11 06:07:43 -05:00
Jeff Becker 3ec000d0f8
fix issue #1107 2018-02-11 06:06:14 -05:00
Jeff Becker aac1141ca6
fix issue #1107 2018-02-11 06:05:41 -05:00
hagen 5225e1d7d1 * HTTP.cpp : use bare snprintf() instead locale-dependent strftime() 2018-02-10 12:40:01 +00:00
orignal e77037c2b8 fixed warning 2018-02-05 11:13:25 -05:00
R4SAS 4af0caa506 fix build on GCC 8.0.1
https://bugzilla.redhat.com/show_bug.cgi?id=1541688
2018-02-05 05:07:26 +03:00
orignal 0728991821
Merge pull request #1092 from majestrate/master
fix federoa rawhide build with gcc 8
2018-02-03 15:18:15 -05:00
Jeff Becker 21c35f770b
fix federoa rawhide build with gcc 8 2018-02-03 13:46:22 -05:00
yangfl 4f84d687e4 add endian detection for glibc 2018-02-03 02:27:22 +08:00
orignal 4901434209 2.18.0 2018-01-30 10:41:35 -05:00
orignal 8c2de4973c rollback 2018-01-26 14:33:06 -05:00
orignal e1527dc137 update LeaseSet if a tunnel was deleted 2018-01-26 14:07:51 -05:00
orignal 7db2e9dc4a don't verify signature twice 2018-01-25 10:32:08 -05:00
orignal b1c701085b don't verify signature twice 2018-01-25 10:09:34 -05:00
orignal e8d6c803cd
Merge pull request #1076 from majestrate/fix-streaming-race-2018-01-25
try streaming race condition fix
2018-01-25 09:35:58 -05:00
Jeff Becker f4a2dda94e
try streaming race condition fix 2018-01-25 09:00:00 -05:00
Jeff Becker 4a77a03033
* Add LeaseSetBufferValidate which checks lease validity and extracts timestamp
* check for leases with LeaseSetBufferValidate before update in floodfill code as to prevent malicous nodes removing good LS
2018-01-24 10:16:51 -05:00
Jeff Becker 3820b51960
Revert "check for valid LS before updating"
This reverts commit e070ce4e34.
2018-01-24 09:44:55 -05:00
Jeff Becker e070ce4e34
check for valid LS before updating 2018-01-24 09:36:09 -05:00
Jeff Becker 06020b8f54
re-enable packet pool 2018-01-20 13:06:08 -05:00
Jeff Becker b3b38015c2
check max buffer size in Stream::Send 2018-01-20 07:31:58 -05:00
Jeff Becker 43a751ee0b
Merge remote-tracking branch 'purple/openssl' into streaming_race_fix_2018_01_15 2018-01-15 08:25:58 -05:00
Jeff Becker 207212557e
fix sam race conditions 2018-01-15 08:19:57 -05:00
yangfl 50ba52756f fix mixing tabs and spaces 2018-01-13 22:51:02 +08:00
yangfl 46f62e1af9 remove trailing whitespaces 2018-01-06 22:24:03 +08:00
Jeff Becker 68b1afa2df
Merge remote-tracking branch 'purple/openssl' into i2cp-session-reconfig 2018-01-04 08:33:06 -05:00
orignal 34c98e03c1 Merge branch 'openssl' of https://github.com/PurpleI2P/i2pd into openssl 2018-01-03 12:53:05 -05:00
orignal 41e40bbc0d fixed typo 2018-01-03 12:52:29 -05:00
Jeff Becker 80149342f2
proper bounds check 2018-01-03 10:02:11 -05:00
Jeff Becker 1967dee50c
don't recreate tunnels of different size 2018-01-02 12:59:16 -05:00
Jeff Becker ab80def94b
use reference instead of copy 2018-01-02 12:06:10 -05:00
Jeff Becker 938d5d901a
implement i2cp session reconfigure 2018-01-02 11:34:58 -05:00
Jeff Becker 7b00d828b2
fix lambda capture, don't capture copy 2018-01-01 09:35:32 -05:00
Jeff Becker d5e9fc7677
fix race condition 2018-01-01 08:28:42 -05:00
orignal 6db7c5733d use outbound.nickname as tunnel name if inbound.nickname is not set 2017-12-20 11:38:35 -05:00
orignal b0f6d81f57
Merge pull request #1037 from PurpleI2P/openssl
recent changes
2017-12-15 22:00:09 -05:00
Kenan Sulayman 614101c4b8
Fix typo (confrimed -> confirmed) 2017-12-16 02:36:01 +01:00
Dmitry Marakasov 0f2d2156e6 Don't use deprecated boost::asio::ssl::context ctor
This was removed in boost 1.66, in prior versions the service
argument was not used
2017-12-11 22:34:48 +03:00
Dmitry Marakasov 511499d950 Reorder preprocessor conditions in libi2pd/I2PEndian.h
The problem is that __FreeBSD_kernel__ may be defined on FreeBSD as
well, while it always needs <sys/endian.h>
2017-12-11 19:59:06 +03:00
yangfl 18b6353803 fix typo 2017-12-07 21:26:28 +08:00
orignal 6636e432d7 2.17.0 2017-12-04 13:05:04 -05:00
orignal df18692af9 check I2NP messsage buffer size 2017-12-01 12:57:05 -05:00
orignal 272090fc8f don't accept streams from RSA detinations 2017-11-28 11:33:51 -05:00
orignal ab6bc52a0f don't create destination with RSA signature 2017-11-28 10:59:11 -05:00
orignal a5b1b24fee implement i2p.streaming.connectDelay option 2017-11-24 15:37:17 -05:00
Jeff Becker ffad1ecd6d
reduce buffer size 2017-11-23 13:46:04 -05:00
Jeff Becker e1b5803902
fix overflow 2017-11-23 12:27:28 -05:00
Jeff Becker 65db96e663
reseed proxy 2017-11-18 09:50:30 -05:00
orignal 5109d40d8e don't publish unknown crypto type to Java floodfill again 2017-11-17 14:28:48 -05:00
R4SAS 1ba1fa37f9
update travis-ci stuff (#1006)
* enable osx in travis config
* fix brew commands, change comiler
* disable clang build with make on linux
* update README
* tabulation fix in Crypto.cpp
2017-11-17 20:43:00 +03:00
R4SAS 7477d2c219 fix forgotten log colors 2017-11-15 21:51:03 +03:00
R4SAS a6fb3b602e add loglevel none (closing #998) 2017-11-15 21:46:20 +03:00
R4SAS 100f3380c4
fix upnp definitions and make cmake silent (#999) 2017-11-14 08:38:45 +03:00
orignal 847fd15af2 0.2.16 2017-11-13 13:59:41 -05:00
orignal a21fb17d73 renamed ECIES-P256 2017-11-13 11:50:17 -05:00
orignal 0c34bd440b reject routers with RSA signatures 2017-11-13 11:25:42 -05:00
Jeff Becker a4b39a3648
disable connection limiting by default 2017-11-13 07:26:27 -05:00
orignal 80a3bd6a3b correct new key pair 2017-11-12 17:31:00 -05:00
orignal 7fb8ee60b4 correct random padding for ICIES public key 2017-11-11 22:10:54 -05:00
orignal a4ce224cd1 pass correct crypto type to identity 2017-11-09 15:49:27 -05:00
orignal ab1cd3f5cf ECIES for GOST R 34.10 2017-11-09 15:01:07 -05:00
orignal 1e75de9bb8 514 bytes ECIES block 2017-11-08 21:06:58 -05:00
orignal 19a03c42a5 use generic Decrypt instead ElGamalDecrypt 2017-11-08 20:45:53 -05:00
orignal c5f784719d implement Decrypt for all local destination 2017-11-08 13:49:48 -05:00
orignal 60aa459dfc 0.9.32 2017-11-08 11:01:00 -05:00
orignal 53d71d29ff call RoutingDestination::Encrypt instead ElGamalEncrypt 2017-11-07 20:30:05 -05:00
orignal 81658d2ff9 generic encryption for RoutingDestination 2017-11-07 15:05:22 -05:00
orignal 9fa67b0e0a crypto key encryptor and decryptor 2017-11-06 15:54:18 -05:00
orignal efacfced45 CryptoKey added 2017-11-06 13:40:58 -05:00
orignal e634c89995 generate non-ElGamal encryption keys pair 2017-11-02 16:13:10 -04:00
orignal 5aa53eee43 GetIdentity for RoutingDestination 2017-11-02 14:50:57 -04:00
orignal 00bbb81375 ECICS gerenarate keys 2017-11-01 14:06:55 -04:00
orignal 5271cdacf2 ECICSDecrypt 2017-11-01 10:59:36 -04:00
orignal 6d01726961 use AES-CBC for ECICS 2017-11-01 10:20:11 -04:00
orignal 12feac1f50 fixed build error for wheezy 2017-10-31 21:25:52 -04:00
orignal 39c1c3567b ECICSEncrypt added 2017-10-30 16:16:21 -04:00
orignal 63ae6850d3 Fix #979. Router without host but with introducers is considered as SSU v4 2017-10-30 12:58:20 -04:00
Jeff Becker 91eb2b2c4a
fix limits when not specififed 2017-10-30 09:53:41 -04:00
Jeff Becker 42ec6db746
Merge remote-tracking branch 'purple/openssl' into i2np-transport-limits 2017-10-30 08:39:58 -04:00
Jeff Becker 7a9dc0eec0
use terminate 2017-10-30 08:37:54 -04:00
Jeff Becker 6441c9d5d8
initial ntcp soft/hard limits 2017-10-30 08:27:55 -04:00
Jeff Becker 1500e805dd
add is_i2p 2017-10-29 09:56:51 -04:00