Alexander Bondarenko
097cec1c35
utils: add stateless compress1 ( #1053 )
2024-03-19 12:13:42 +00:00
spaced4ndy
293a2ca3f1
agent: remove withStoreCtx ( #1044 )
2024-03-13 13:33:59 +04:00
Alexander Bondarenko
2cad0cb201
core: check ACK handling with return type ( #1041 )
...
* core: check ACK handling with return type
* fix ratchet sync
* add SQL Locked to dbBusyLoop
* rename
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-03-11 19:06:53 +00:00
Evgeny Poberezkin
b4c90781bb
pqdr: update envelope sizes
2024-03-10 17:53:57 +00:00
Evgeny Poberezkin
851ed2d02e
pqdr: more tests, pass e2e version to rcEncrypt from config ( #1040 )
...
* pqdr: more tests, pass e2e version to rcEncrypt from config
* fix
2024-03-10 13:29:03 +00:00
Evgeny Poberezkin
054b6edb14
pqdr: clean up ( #1039 )
2024-03-10 11:27:31 +00:00
Evgeny Poberezkin
dab55e0a9b
pqdr: return agent version from connection request version & PQ support check api
2024-03-08 23:13:21 +00:00
Alexander Bondarenko
8cdd49b912
core: restore Eq instances ( #1038 )
...
* core: restore Eq instances
* remove duplicates from tests
2024-03-08 13:43:33 +00:00
Alexander Bondarenko
b4e55146b8
core: fix VersionRange JSON instances ( #1037 )
2024-03-08 10:58:45 +00:00
Evgeny Poberezkin
03d73f442f
JSON instance for VersionRange ( #1036 )
2024-03-08 10:01:58 +00:00
Evgeny Poberezkin
8ff4c628b5
pqdr: make envelope sizes dependent on version, test enabling PQ ( #1035 )
2024-03-08 08:28:15 +00:00
spaced4ndy
5e23fa6cfc
agent pq: connRequestPQSupport api ( #1034 )
2024-03-07 19:44:48 +04:00
Alexander Bondarenko
dd22b5c823
core: tweak compress api ( #1029 )
...
* convert compress to a wrapper with passthrough fallback
* add compress1 for non-batched compression
* use original size as upper bound for scratch
* refactor
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-03-07 14:17:32 +00:00
Evgeny Poberezkin
11288866f9
pqdr: refactor
2024-03-07 12:41:10 +00:00
Evgeny Poberezkin
07fa75ec49
pqdr: agent api to confirm PQ encryption support during connection handshake, fix incorrect PQ support ( #1032 )
...
* pqdr: agent api to confirm PQ encryption support during connection handshake
* fix CONF, tests
* fix REQ, tests
* remove unused
2024-03-07 08:35:40 +00:00
Evgeny Poberezkin
4ffb6a348a
pqdr: use different newtypes for supporting and enabling PQ encryption in connections ( #1031 )
...
* pqdr: use different newtypes for supporting and enabling PQ encryption in connections
* rename field, fix test
* refactor
2024-03-06 21:28:03 +00:00
Evgeny Poberezkin
b435a4dacb
envelope sizes dependent on PQ encryption ( #1028 )
...
* envelope sizes dependent on PQ encryption (WIP)
* add "supported" flag to ratchets, update this flag on ratchet resync
* change connection PQ status on sendMessage
* comment, fix
* refactor
2024-03-06 16:38:30 +00:00
Alexander Bondarenko
e04705d9c5
utils: add generic batching and compression ( #1018 )
...
* extract batchTransmissions_
* add Simplex.Messaging.Compression
* add combined compression/batching
* force NonEmpty for batching
* hide FFI and allocation related IO
* split packing
* remove batch compression, tweak API
* OCD over API
* remove Empty, extract passthrough const
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-03-06 09:10:49 +00:00
Evgeny Poberezkin
b050cf5027
double ratchet versioning for post-quantum encryption ( #1025 )
...
* correctly parse new Ratchet fields when omitted
* rfc: migrating connection versions to pqdr
* update rfc
* WIP (dont commit)
* rename versions
* update ratchet version based on PQ encryption feature flag
* remove duplicate function
* synchronize ratchet, fix tests, refactor
* comments
* test
* pattern
2024-03-05 17:07:15 +00:00
Evgeny Poberezkin
52a67daea6
agent: pass PQ encryption flag separately for each message in batch APIs ( #1027 )
2024-03-05 11:09:07 +00:00
Evgeny Poberezkin
ba1bfaa5aa
Merge branch 'master' into pq
2024-03-04 20:13:01 +00:00
Evgeny Poberezkin
dd2bd11584
parameterize version scopes with phantom types ( #1026 )
...
* parameterize version scopes with phantom types
* move Version to another module
* parens
2024-03-04 19:06:51 +00:00
Evgeny Poberezkin
e06e22328f
agent: quantum-resistant double ratchet encryption ( #939 )
...
* doc
* diff
* ratchet header
* types
* ratchet step with PQ KEM, message header with KEM
* comment
* update types, remove Eq instances, store KEM keys to database
* pqx3dh
* PQ double ratchet test
* pqdr tests pass
* fix most tests
* refactor
* allow KEM proposals from both sides
* test names
* agent API parameters to use PQ KEM
* initialize ratchet state for enabling KEM
* fix/test KEM state machine to support disabling/enabling via messages
* more tests
* diff
* diff2
* refactor
* refactor
* refactor
* refactor
* remove Maybe
* rename
* add PQ encryption status to CON, MID and MSG events and sendMessage API results
* different PQ parameter when creating connection
* rename/reorganize types for PQ encryption modes
* rename
* fix testWaitDeliveryTimeout
* rename
* rename2
* ghc8107
* rename
* increase timeouts for concurrent send/receive test
* enable all tests
---------
Co-authored-by: spaced4ndy <8711996+spaced4ndy@users.noreply.github.com >
2024-03-03 19:40:49 +00:00
Evgeny Poberezkin
ce78646c7f
refactor creating connection record ( #1021 )
2024-03-02 18:27:51 +00:00
spaced4ndy
294d7ec8dd
agent: delay connection deletion to finish delivery of pending messages ( #1015 )
...
* agent: delay connection deletion to finish delivery of pending messages (wip)
* fixes, test
* notify, test
* add tests
* comment
* add test
* timeout
* test timeout
* up
* more tests
* rename
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-02-29 18:08:58 +00:00
Evgeny Poberezkin
c9ec7ea274
Merge branch 'stable'
2024-02-27 18:07:30 +00:00
Evgeny Poberezkin
5011ac2e7c
Merge branch 'v5522' into stable
2024-02-27 17:58:08 +00:00
Alexander Bondarenko
2e3c961dab
agent: optimize execution performance of slow memory operations during (re)subscriptions ( #1013 )
...
* agent: remove redundant set building
* tests: add tRcvQueuesTests (#1016 )
* double accounting
* unit tests for invariants
* batch add queues
* ghc8107 compatibility
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com >
2024-02-27 00:00:29 +00:00
spaced4ndy
050a921fbb
agent: batch db operations for deleting connections and xftp files ( #1009 )
...
* agent: batch db operations for deleting connections
* batch delete rcv files
* snd files
* refactor
* refactor2
* lines
* refactor
* fix prefix path
* refactor
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-02-26 10:28:50 +00:00
Evgeny Poberezkin
e2ec737c68
stop using public keys from table ( #1014 )
...
* stop using public keys from table
* comment
2024-02-25 16:19:04 +00:00
Alexander Bondarenko
95c0914809
agent: speed up SMP clientDisconnected ( #1011 )
2024-02-24 14:59:14 +00:00
Alexander Bondarenko
385463192b
agent: extend worker summary ( #1007 )
...
* agent: extend worker summary with active/idle split
* simplify
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-02-24 13:29:36 +00:00
Evgeny Poberezkin
d7394aa762
fix ntf server version range in the client
2024-02-22 19:33:14 +00:00
Evgeny Poberezkin
0d843ea4ce
Merge branch 'stable'
2024-02-21 20:33:06 +00:00
Evgeny Poberezkin
a34da38966
Merge branch 'stable' into v5521
2024-02-21 19:28:30 +00:00
Evgeny Poberezkin
5c1519df7f
optimize: use IntMap ( #1005 )
2024-02-21 11:52:24 +00:00
Evgeny Poberezkin
03c24c3ada
agent: fix performance leak, smp server: optimize and fix potential memory leak ( #1004 )
...
* fix agent performance leak when re-connecting clients, optimize SMP server
* let the clients remove themselves from their clientvars
* fix another test
* do not call removeSubs when AgentClient is not active
* revert some changes
* revert more, refactor
* comment
* rename
* refactor
* refactor
---------
Co-authored-by: Alexander Bondarenko <486682+dpwiz@users.noreply.github.com >
2024-02-21 11:45:34 +00:00
Evgeny Poberezkin
9b38f69e7e
smp server: add stats for queues deleted before and after they were secured ( #1002 )
2024-02-18 16:25:32 +00:00
Evgeny Poberezkin
89140e0ff0
use package version for all servers ( #1001 )
2024-02-18 08:56:35 +00:00
Evgeny Poberezkin
caeeb2df9c
fix protocol in NTF server error
2024-02-17 15:32:44 +00:00
Evgeny Poberezkin
51be2fea20
agent: test NTF server ( #1000 )
2024-02-17 14:55:40 +00:00
Evgeny Poberezkin
f6acc5c240
remove test chunk after XFTP server test ( #999 )
2024-02-16 23:24:57 +00:00
Alexander Bondarenko
194a7bb58e
agent: remove redirect entries when deleting rcv files ( #995 )
...
* agent: remove redirect entries when deleting rcv files
* update schema dump
* use rcv_file primary key for redirect lookup
* allow multiple redirects
2024-02-16 19:49:50 +04:00
Evgeny Poberezkin
c179073260
remove support for old versions ( #990 )
...
* remove support for old versions (WIP)
* fix
* updates
* use version var
2024-02-16 13:28:50 +00:00
Evgeny Poberezkin
416f1b1721
smp: command authorization ( #982 )
...
* smp: command authorization
* fix encoding, most tests
* remove old tests
* authorize via crypto_box
* extract authenticator to Crypto module
* make TransmissionAuth Maybe
* rfc
* support authenticators in NTF protocol, test matrix (no backwards compatibility yet from new clients to old servers)
* fix/add tests, add version config to "small" agent
* separate client and server versions for SMP protocol
* test batching SMP v7
* do not send session ID in each transmission
* refactor auth verification in the server, split tests
* server "warm up" fixes timing test
* uncomment SUB timing test
* comments, disable two timing tests
* rename version
* increase auth timing test failure threshold
* use different algorithms to authorize snd/rcv commands, use random correlation ID
* transport: fetch and store server certificate (#985 )
* THandleParams (WIP, does not compile)
* transport: fetch and store server certificate
* smp: add getOnlinePubKey example to smpClientHandshake
* add server certs and sign authPub
* cleanup
* update
* style
* load server certs from test fixtures
* sign ntf authPubKey
* fix onServerCertificate
* increase delay before sending messages
* require certificate with key in SMP server handshake
---------
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
* remove dhSecret from THandle
* remove v8, merge all changes to one version
* parameterize THandle
* rfc: transmission ecnryption
* Revert "parameterize THandle"
This reverts commit 75adfc94fb .
* use batch syntax for ntf server commands
* separate encodeTransmission when there is no key
* typo
Co-authored-by: spaced4ndy <8711996+spaced4ndy@users.noreply.github.com >
* rename
* diff
---------
Co-authored-by: Alexander Bondarenko <486682+dpwiz@users.noreply.github.com >
Co-authored-by: spaced4ndy <8711996+spaced4ndy@users.noreply.github.com >
2024-02-16 11:45:54 +00:00
Evgeny Poberezkin
9254d8dac5
v5.5.3
2024-02-16 11:33:56 +00:00
Alexander Bondarenko
9ab34bca7d
cli: add cert command to xftp and ntf servers ( #991 )
...
Co-authored-by: Evgeny Poberezkin <evgeny@poberezkin.com >
2024-02-16 10:56:54 +00:00
spaced4ndy
6f62d7ff05
agent: add numRecipients parameter to send description ( #993 )
2024-02-15 13:24:46 +04:00
Alexander Bondarenko
7275714b8e
cli: configure server paths from env ( #992 )
2024-02-14 20:31:06 +00:00
spaced4ndy
004597c764
agent: add index to file redirect migration ( #988 )
2024-02-14 18:47:39 +04:00