Commit graph

1322 commits

Author SHA1 Message Date
orignal 64ec7dd559 narrow down random range 2021-08-03 19:26:09 -04:00
orignal 367df4d0db RAND_bytes from random router selection 2021-08-03 15:43:58 -04:00
orignal da7e41c188 use Tag<64> for ratechet tags 2021-08-01 18:42:13 -04:00
R4SAS d88fe203e1
[tunnels] count outbound traffic for zero-hop tunnels
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-08-01 09:25:02 +03:00
orignal 1e01c30e63 set pool for zero-hops tunnels 2021-07-30 14:12:50 -04:00
orignal 7a55d1fc38 don't insert garlic tag for short tunnel build reply if the same router 2021-07-28 21:14:03 -04:00
orignal f8623b6121 consistent path for explicit peers 2021-07-28 19:08:55 -04:00
orignal 9a3c22f47d don't encrypt ShortTunnelBuild and ShortTunnelBuildReply if on the same router 2021-07-28 15:06:24 -04:00
orignal e68cff8bba try routers before random router 2021-07-27 18:35:30 -04:00
orignal 513493fa78 fixed typo 2021-07-26 18:46:29 -04:00
orignal a6937c792f more precise router selection 2021-07-26 17:51:32 -04:00
orignal 99c7d5c23a don't create enryptor for ECIES record encryption 2021-07-25 22:30:54 -04:00
orignal cd8e8970de NTP request through compatible address 2021-07-24 16:01:11 -04:00
orignal 26d5ced2ef optimal padding for one-time messages 2021-07-23 20:28:55 -04:00
orignal c7234f705a let NTCP sync through ipv6 2021-07-23 18:34:51 -04:00
orignal c153471c49 use short tunnel build if possible 2021-07-22 20:58:35 -04:00
orignal f28024cfe8 decline transit tunnels from short tunnel build message 2021-07-21 18:12:37 -04:00
orignal 911ab9813e handle encrypteed I2NPShortTunnelBuildReply in destination 2021-07-21 14:55:38 -04:00
orignal cfbf5862f9 set pool for tunnel before build 2021-07-21 13:08:12 -04:00
orignal 5cb1f5986d use msgID from ECIESx25519 block 2021-07-20 22:00:06 -04:00
orignal 0b14c810fb handle ShortTunnelBuildReply 2021-07-20 19:38:36 -04:00
orignal c2334db8f8 correct reply key for short tunnel build record 2021-07-20 18:02:48 -04:00
orignal 4807092df6 fixed typo 2021-07-20 15:17:58 -04:00
orignal bdc1107c96 correct message type for ShortTunnelBuild 2021-07-20 14:35:02 -04:00
orignal db9223b0d5 set minimal version for floodfill to 0.9.38 2021-07-19 17:50:55 -04:00
orignal 6ecfe0789f don't allocate payload buffer for every single ECIESx25519 message 2021-07-18 18:45:08 -04:00
orignal a37cf058cd router with expired introducer is still valid 2021-07-16 20:12:41 -04:00
orignal f4902e6642 eligble floodfill must be reachable by ipv4 2021-07-16 13:53:12 -04:00
orignal 5d022c25ba don't send datetime for one time key message 2021-07-16 09:44:22 -04:00
orignal 0cd9f1b002 precalculate padding sizes 2021-07-15 19:01:43 -04:00
orignal cd0751d3f1 padding block for message for router 2021-07-15 18:30:32 -04:00
orignal a1d1a5df74 datetime block for message for router 2021-07-15 18:18:55 -04:00
orignal 197f13f9c0 rollback 2021-07-15 14:02:20 -04:00
orignal 41bfc7899d keep own RouterInfo in netdb 2021-07-14 14:46:56 -04:00
orignal 2c129b6d39 create and handle short tunnel build reply 2021-07-12 19:40:40 -04:00
orignal dbe427d5eb set reply code for short tunnel build messages 2021-07-11 19:29:16 -04:00
orignal 15c3d46492 encrypt inbound tunnel build message for short tunnel build only 2021-07-10 17:28:18 -04:00
orignal 6a467a09bd fixed build error 2021-07-10 16:47:28 -04:00
orignal ba1b8c7c2b WrapECIESX25519MessageForRouter wihout session 2021-07-10 16:15:15 -04:00
orignal 1e9eb30aa3 garlic encryption of inbound tunnel build message 2021-07-10 14:33:23 -04:00
orignal d47bf1bada different tunnel build record size 2021-07-09 19:26:14 -04:00
orignal 59dd60f5cb genarate keys in CreateBuildRequestRecord 2021-07-09 19:24:28 -04:00
orignal c02a0c4da9 process DELAY_REQUESTED option 2021-07-08 22:22:00 -04:00
orignal 84f6024cc9 locate record to build inside CreateBuildRequestRecord 2021-07-08 19:00:25 -04:00
orignal d73b42b726 extract ret code per hop 2021-07-08 16:39:38 -04:00
orignal ed0c2e68a5 DecryptRecord per tunnel hop 2021-07-07 21:16:30 -04:00
orignal 847225c6bf more yggdrasil reseeds added 2021-07-07 08:24:01 -04:00
orignal a6294df9e8 decrypt one-time message encrypted with tag on router 2021-07-06 20:15:55 -04:00
orignal 9000b3df4e KDF for short tunnel build messages 2021-07-05 14:31:07 -04:00
orignal a717542733 update yggdrasil reseed to 0.4 2021-07-04 07:33:28 -04:00
orignal aace644815 added ShortECIESTunnelHopConfig 2021-07-02 22:06:24 -04:00
orignal 0ae170531e different ElGamal and ECIES hops configs 2021-07-02 15:41:33 -04:00
orignal 8b35ce3320 separate decryption between own record and other records 2021-07-02 13:20:24 -04:00
orignal 5781335814 save and check last stream 2021-06-29 19:08:11 -04:00
orignal 25f63ac22a create different I2NP tunnel messages for endpoint and non-endpoint 2021-06-27 15:49:57 -04:00
orignal 66422d6d83 double size tunnel message 2021-06-26 21:44:51 -04:00
orignal b9476791f4 eliminated extra I2NP messages for fragments 2021-06-26 17:40:25 -04:00
orignal d0c5732e16 eliminate extra lookups for sequential fragments 2021-06-26 07:18:42 -04:00
orignal 3c07665479 use unordered_map for incomplete messages 2021-06-22 15:35:44 -04:00
orignal f7f50d049b reduce short tunnel build record length 2021-06-22 13:11:02 -04:00
R4SAS 6971b1e9da fix typo in config option description
Kudos @iBicha
https://github.com/PurpleI2P/i2pd/pull/1662#pullrequestreview-687850246

Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-06-20 20:03:33 +03:00
orignal fed04c1a19 requsted router to send to if not in netdb 2021-06-19 14:44:33 -04:00
orignal f5e7d87f5b don't disable floodfill if still reachable by ipv6 2021-06-19 14:25:50 -04:00
orignal 6ca28adcbb set address caps and available transports for new address 2021-06-18 18:19:05 -04:00
R4SAS e8ad7b4f79
rework of storing certificates path (#1642)
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-06-18 10:04:48 +03:00
R4SAS d3a49e513c
remove repeatable type definition, add include (#1642)
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-06-18 06:45:12 +03:00
R4SAS 5bfab0a796
add certsdir option (#1642)
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-06-18 06:38:10 +03:00
orignal 2185019b59 check if router is reachable by transport before obtaining address 2021-06-17 19:46:05 -04:00
orignal 81c83f0d54 pick ECIES routers only for non-x64 2021-06-17 19:10:57 -04:00
orignal 08a82a0bcd don't try to connect to a router not reachable from us 2021-06-17 12:12:06 -04:00
orignal a6af4908d5 use m_ReachableTransports bitmask 2021-06-16 18:14:33 -04:00
orignal dc75868bd3 check Alice's IP address in PeerTest 2021-06-15 19:09:36 -04:00
orignal 631c8c9870 use correct address type for NTCP2 acceptors 2021-06-14 21:19:44 -04:00
orignal bce6685d0c correct check of ipv4/ipv6 address 2021-06-14 12:36:54 -04:00
orignal e412b17f70 don't publish slow tunnel in LeaseSet if possible 2021-06-11 08:34:56 -04:00
orignal a92b93192d reg.i2p for subscriptions 2021-06-10 13:24:04 -04:00
R4SAS 8708a0076f fix build with boost < 1.55.0 (closes #1661)
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-06-09 22:23:33 +03:00
orignal 83fd289e46 don't re-create noise state for every message 2021-06-09 12:49:50 -04:00
orignal 3b051dbba3 send OutboundTunnelBuildReply 2021-06-08 15:36:27 -04:00
orignal 8571830485 create transit tunnel and reply for short tunnel build 2021-06-07 18:28:36 -04:00
orignal 5fb426b336 decrypt and encrypt reply for short tunnel build message 2021-06-06 13:55:38 -04:00
orignal d752a83eb5 handle i2cp.dontPublishLeaseSet for all destinations 2021-06-04 18:28:30 -04:00
orignal e740d5fc4f try to pick non-slow tunnel 2021-06-04 12:16:50 -04:00
orignal 8e3e35a36d decrypt short request record 2021-06-02 19:50:29 -04:00
orignal 5ce9c0f1e2 build new tunnels instead slow 2021-06-02 14:45:21 -04:00
orignal ef8c4389e1 reachable transports added 2021-06-02 12:55:08 -04:00
R4SAS 0547d590e1
fix typo
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-31 00:24:54 +03:00
R4SAS be31640010
fix ipv6 preference on linux
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-31 00:23:50 +03:00
R4SAS ed42948051 prefer public ipv6 instead rfc4941 (closes #1251)
Wokrs only on linux-based systems. Not tested on other *nix systems, and
not works on windows.

Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-30 03:25:13 +03:00
orignal a0e545a6f1 always create new tunnel from exploratory pool 2021-05-28 12:11:24 -04:00
R4SAS 779f2fa451
[i18n] rework localization system
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-25 22:03:29 +03:00
orignal 08fafe267a rekey all routers to ECIES 2021-05-23 17:27:14 -04:00
orignal d06924b339 LeaseSet type 3 by default 2021-05-23 14:28:10 -04:00
orignal 7ed440ba75
Merge pull request #1657 from PurpleI2P/i18n
I18n
2021-05-23 08:26:11 -04:00
R4SAS df66c2d2dc
[i18n] translate HTTP proxy
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-23 06:06:04 +03:00
orignal f321eb66c0 rename DatabaseLookupTageSet to SymmetricKeyTagset 2021-05-22 18:41:25 -04:00
R4SAS 80b44fc9a9
Support multilang, update code
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-22 18:29:05 +03:00
R4SAS 0e68fe4a57 [i18n] start multilang support for webconsole
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-22 08:39:29 +03:00
orignal 59b471b9a2 i2cp.leaseSetPrivKey for HTTP and SOCKS proxy 2021-05-20 14:10:31 -04:00
orignal f22eaa6db5 2.38.0 2021-05-16 14:26:00 -04:00
R4SAS c359c6e634
update config file example, add v6 status to windows daemon window, code cleanup
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-05-15 16:31:53 +03:00
orignal baec22610e always set expiration time for NSR tagset 2021-05-12 07:57:37 -04:00
orignal 43b587636b delete tags of termiated session right away 2021-05-11 18:49:17 -04:00
orignal c6cdb26f47 reduce range for extra tags 2021-05-10 20:20:25 -04:00
orignal 1285e30b3e more pre-calculated x25519 2021-05-10 18:55:39 -04:00
orignal d6f5640685 attach updated LeaseSet to ECIESx25519 incoming sessions 2021-05-09 07:33:26 -04:00
orignal 79dbf2a43e request encrypted LeaseSet if expired 2021-05-07 22:15:12 -04:00
orignal 5ad4c2a65e run ipv6 peer test again if still testing 2021-05-04 14:59:25 -04:00
orignal fffa550bb0 SAM subsessions 2021-05-04 14:27:06 -04:00
orignal 0b9cb4e75b check identity and signature length for SessionConfirmed 2021-05-03 19:05:25 -04:00
orignal 7f143a7f23 support EdDSA for blinding 2021-05-02 15:02:52 -04:00
orignal d8d8a68814 rekey all routers but floodfills 2021-04-30 15:19:31 -04:00
orignal e091eba831 don't cleanup ipv6 introducers list twice 2021-04-25 17:55:13 -04:00
orignal 4a0dbec4fb recognize non-published NTCP2 address 2021-04-25 16:42:09 -04:00
orignal 90dee900f0 fixed crash 2021-04-25 10:57:31 -04:00
orignal 94555b9c43 don't select next introducers from existing sessions 2021-04-24 14:56:34 -04:00
orignal db93a7315f find new introducers to connect 2021-04-24 11:11:12 -04:00
orignal 7a19533380 reuse current introducers if no more available 2021-04-23 12:17:48 -04:00
orignal 9d79b26506 check if port if specified 2021-04-22 19:32:47 -04:00
orignal b5618af308 find all introducers at the time 2021-04-21 15:41:04 -04:00
orignal 9c8c3b9174 select few introducers at the time 2021-04-21 10:56:39 -04:00
orignal 01e591b261 find ipv6 intrioducer session 2021-04-21 09:55:36 -04:00
orignal 060e30d283 select ipv6 random introducer 2021-04-21 08:16:13 -04:00
orignal ad019da553 publish ipv6 introducers 2021-04-20 20:02:30 -04:00
orignal ca77ca6ef0 reseed from compatible address 2021-04-18 17:27:50 -04:00
orignal d5b61ed544 select different routers for peer test 2021-04-17 14:33:53 -04:00
orignal 5edb256990 check if our external IP is valid 2021-04-16 19:31:49 -04:00
orignal 74d0c04314 ipv6 address for relay reponse and relay intro 2021-04-15 16:06:02 -04:00
orignal 39d4464be0 make sure that introducer or peer test router is reachable by SSU 2021-04-15 11:43:43 -04:00
orignal be48dc6e87 pick correct local address for intro key 2021-04-13 15:11:37 -04:00
orignal 2783337284 require ipv4 for IBGW 2021-04-13 09:16:52 -04:00
orignal df858d9143 publish iexp 2021-04-09 13:29:07 -04:00
orignal ac47c9c673 don't check U cap 2021-04-09 10:56:46 -04:00
orignal b9a2d5df02 send HolePunch back based on actual address type 2021-04-08 21:07:14 -04:00
orignal 3e873f88c9 don't drop introducers without iExp 2021-04-07 15:55:38 -04:00
orignal 277cef5ec4 eliminate cost field 2021-04-07 13:05:38 -04:00
orignal 5c9b478e46 published field for SSU addresses 2021-04-05 21:45:48 -04:00
orignal ff89edf127 pick random introducer 2021-04-05 18:22:48 -04:00
orignal 2cc9791bf2 exclude already expired introducers 2021-04-04 10:36:22 -04:00
orignal 67b32005f6 check if host if unspecified 2021-04-03 22:18:09 -04:00
orignal 0f166973ca check ureachable cap and actual introducers separately 2021-04-03 20:03:19 -04:00
orignal 4f3333c841 don't check range ffor unspecified address 2021-04-03 19:24:07 -04:00
orignal bea384abea recongnize v4 and v6 SSU addresses without host 2021-04-03 18:56:50 -04:00
orignal 43033695f6 select apropriate address for peer test 2021-04-02 21:31:14 -04:00
orignal 51ef7ef61c don't publish LeaseSet without tunnels 2021-04-01 13:37:21 -04:00
orignal 823b499a02 remove already expired LeaseSets 2021-04-01 11:45:50 -04:00
orignal bb5ed0b40c assign correct 6 or 4 cap to unpublished address 2021-04-01 11:02:29 -04:00
orignal 94ca2514af set zero expiration timeout if no tunnels 2021-04-01 10:29:03 -04:00
orignal 5412352dec publish ipv6 introducers for ipv6 addresses 2021-03-31 13:42:57 -04:00
orignal bd7328345f Don't change Yddrasil address if router becomes unreachable through ipv6 2021-03-30 19:27:40 -04:00
orignal 25eae3c116 return relay tag for ipv6 introducer 2021-03-30 11:31:11 -04:00
orignal 5cca5472e6 don't handle unsilicited HolePunch 2021-03-29 15:50:33 -04:00
orignal 8462d382f4 don't create SSU session for HolePunch 2021-03-29 15:16:39 -04:00
orignal 2b0d18a6d7 don't change router status from ipv6 2021-03-29 14:44:50 -04:00
orignal 167d3a0e3c don't create BN_CTX for ECIES tunnel build record decryption 2021-03-28 12:14:02 -04:00
orignal 86415bc61f publish introducer cap for ipv6 address 2021-03-27 18:49:35 -04:00
orignal a6ea37a21e set ipv6 address caps depending on peer test 2021-03-27 15:16:56 -04:00
orignal 3695aa924b doesn't send peer test to a reserved address 2021-03-24 10:32:15 -04:00
orignal 9e050d1a23 peer test for ipv6 2021-03-23 15:36:57 -04:00
orignal 34eee2fc26 fixed #1644. check leaseset buffer size 2021-03-22 20:12:58 -04:00
orignal ac10f3055d pick correct local SSU address for sending peer test 2021-03-19 21:51:45 -04:00
orignal 991b74f036 bind ipv6 or yggdrasil acceptor to specified address 2021-03-19 13:10:24 -04:00
orignal 589049ef0f connect to ipv6 address through introducer 2021-03-19 10:20:02 -04:00
orignal 6b0c7c2313 handle ipv6 address in RelayResponse 2021-03-18 21:29:39 -04:00
orignal a9c7d0d598 common ExtractIPAddressAndPort 2021-03-18 20:11:24 -04:00
orignal ef1dfb153c handle ipv6 address for RelayIntro 2021-03-18 18:37:02 -04:00
orignal 820a365474 select random peer for first hop for outbound tunnel if number of connections < 100 2021-03-16 18:45:51 -04:00
orignal 1d5d06f731 find actual router for peer 2021-03-16 15:23:00 -04:00
orignal 43d458cf72 publish and upublish NTCP2 and yggdrasil addresses separatly 2021-03-16 13:08:10 -04:00
orignal 7015bad905 2.37.0 2021-03-15 08:30:04 -04:00
orignal cf8665748b network sattus Mesh added 2021-03-13 10:28:03 -05:00
orignal 1b8da90cbb more precise compatibility check 2021-03-12 20:51:12 -05:00
orignal 6012585067 eliminate false positive symmetric NAT 2021-03-12 17:41:41 -05:00
orignal f162876600 insert ipv4 address if enabled back 2021-03-12 16:13:01 -05:00
orignal 6555ae5b0a support authorization for reseed proxy 2021-03-11 17:02:56 -05:00
R4SAS cb8651ec68 [win32] drop service code, fix start with daemon option. Throw notification when unable to parse config
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-03-11 14:40:06 +03:00
orignal 7c0b0a4e3e common HTTP basic authorization string 2021-03-10 22:47:31 -05:00
orignal 880d1a7ccd NTCP2 proxy with authorization 2021-03-10 20:00:21 -05:00
orignal 744b25190a don't set proxy if ntcp2 is disabled 2021-03-10 15:36:10 -05:00
R4SAS 9049902ced [webconsole] add address registration line generator
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-03-10 01:48:54 +03:00
orignal 5f93dc72fd convert ifname* params to address* 2021-03-09 15:28:07 -05:00
orignal 09dadd7e01
Merge pull request #1640 from brain5lug/openssl
logging opimization
2021-03-09 07:46:28 -05:00
orignal 60b92f98db OBEP must be ipv4 compatible 2021-03-08 18:54:17 -05:00
orignal 97f315d488 set correct 4 and 6 caps for unreachable addresses 2021-03-08 15:57:05 -05:00
brain5lug f3676d7f18 logging opimization 2021-03-08 11:31:00 +03:00
orignal 742dbdb68a rekey low badwidth routers to ECIES 2021-03-07 10:07:51 -05:00
orignal 2d59c968ca don't publish NTCP2 address connected through proxy 2021-03-06 18:43:50 -05:00
orignal ad22247c9e start other acceptors if connected through a proxy 2021-03-06 15:35:31 -05:00
orignal f38920c338 Status: Proxy 2021-03-06 08:50:47 -05:00
orignal 8f90b21a5d fixed typo 2021-03-05 22:40:27 -05:00
orignal ff0e6813c6 fixed typo 2021-03-05 21:53:19 -05:00
orignal fa5e4d57fd correct caps for SSU address without host 2021-03-05 19:40:37 -05:00
orignal 876973f071 remove coreVersion 2021-03-05 09:29:28 -05:00
orignal b994af9209 check reachability of floodfill to request from 2021-03-05 08:41:44 -05:00
orignal 1f6cde652e check caps for SSU address 2021-03-04 22:47:56 -05:00
R4SAS 3bf6db1c08 enable yggdrasil address finding for android
Signed-off-by: R4SAS <r4sas@i2pmail.org>
2021-03-05 03:20:12 +03:00
orignal e70ffc9d7c re-shedule introducers updates if router becomes firewalled 2021-03-04 15:55:51 -05:00
orignal 065cfe3b9d separate ratchet session for ECIES router 2021-03-03 15:30:13 -05:00
orignal def9873a70 request multiple introducers at the time 2021-03-02 21:10:19 -05:00
orignal 618aa26454 allow some unreachable floodfills 2021-03-02 14:13:28 -05:00