Nikita Poberezkin
63532c8b45
simplex-messaging.md reformulation of key pairs handling part ( #141 )
2021-05-15 16:04:51 +01:00
Evgeny Poberezkin
44bec887fe
0.3.1 ( #135 )
...
Co-authored-by: Efim Poberezkin <8711996+efim-poberezkin@users.noreply.github.com >
v0.3.1
2021-05-10 15:14:06 +04:00
Efim Poberezkin
8bd42035aa
reorganize sqlite store test suite ( #138 )
2021-05-10 15:10:32 +04:00
Efim Poberezkin
f7f419224f
reduce transaction retry back-off factor to 1.125 ( #137 )
2021-05-10 14:24:08 +04:00
Evgeny Poberezkin
8ac47b9bbf
reduce transaction retry back-off factor to 1.25 (31 retries) ( #136 )
2021-05-09 12:49:52 +01:00
Evgeny Poberezkin
305bc5cb0a
update package categories ( #134 )
2021-05-09 11:24:40 +01:00
Efim Poberezkin
fa5a8cb5cd
agent: change sqlite busy retry handling; set journal_mode = WAL ( #132 )
...
* agent: change sqlite busy retry handling; set journal_mode = WAL
* fix accumulation
* add exponential back-off (*1.5) to transaction retries
Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com >
2021-05-09 10:24:02 +01:00
Evgeny Poberezkin
5d59e4b2bd
package and module docs, remove Simplex.Markdown (moved to simplex-chat), rename Agent.Transmission to Agent.Protocol ( #133 )
...
* package and module docs, remove Simplex.Markdown (moved to simplex-chat), rename Agent.Transmission to Agent.Protocol
* move errors.md to haddock comments, Transport docs
* add CHANGELOG.md, add missing package versions
* changelog, copyright
* docs for Simplex.Messaging.Crypto
* consistent punctuation
* use absolute URLs in readme
* correction
2021-05-09 09:36:08 +01:00
Efim Poberezkin
ad87442811
sqlite busy stress test ( #131 )
...
* sqlite busy stress test
* refactor withStore2
* refactor withStore2
* pragmas
* swith to IMMEDIATE sqlite transactions and add retry on ErrorBusy
* refactor
* increase timeout, print errors and results
* remove logging errors/results
Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com >
2021-05-08 16:30:40 +01:00
Evgeny Poberezkin
7aacee405e
agent: send CON to user when the 1st party responds HELLO; fix REPLY vulnerability ( #130 )
...
* agent: send CON to user when the 1st party responds HELLO; fix REPLY vulnerability
* test for getRcvConn
* add commented OK response to JOIN command
* store: use Only newtype to select one field
2021-05-07 06:57:53 +01:00
Evgeny Poberezkin
4b9ebbbab2
move SMP server from agent commands NEW/JOIN to agent config ( #129 )
...
* move SMP server from agent commands NEW/JOIN to agent config
* fix SMPServer parser
* update agent protocol - server management
* enable agent test
* agent test with 2 servers
* create reply queue on the configured server
* choose random server
* swap bind
2021-05-06 18:53:34 +01:00
Efim Poberezkin
f09c77cd31
docs: correct agent protocol abnf ( #128 )
2021-05-04 21:48:54 +04:00
Evgeny Poberezkin
2b0950e78e
0.3.0
v0.3.0
2021-05-04 08:38:52 +01:00
Evgeny Poberezkin
aff2d73e45
build SMP server on tags ( #127 )
...
* build SMP server on tags
* stack test -> stack build --test
2021-05-04 08:37:48 +01:00
Evgeny Poberezkin
377b166d8e
SimplexMQ readme, remove chat client ( #125 )
...
* SimplexMQ readme, remove chat client
* link to license
* add roadmap, corrections
* corrections
* strange dot -> colon
* corrections
Co-authored-by: Efim Poberezkin <8711996+efim-poberezkin@users.noreply.github.com >
2021-05-04 07:11:48 +01:00
Evgeny Poberezkin
1c7d7e5083
base64 encode keyhash in DB ( #126 )
2021-05-03 15:52:41 +01:00
Evgeny Poberezkin
772b38d154
simplify KeyHash type, store key hash in DB as binary ( #122 )
2021-05-03 12:38:31 +01:00
Evgeny Poberezkin
b517d793d8
only allow correct key and signature sizes, improve timing mitigation ( #121 )
2021-05-03 12:31:23 +01:00
Evgeny Poberezkin
76e81e1cf0
fix duplex connection diagram link
2021-05-03 10:13:55 +01:00
Evgeny Poberezkin
4ec548f8b8
fix diagram links
2021-05-03 10:12:33 +01:00
Evgeny Poberezkin
885dda21ec
Merge branch 'master' of simplex-chat (protocol)
2021-05-03 10:09:56 +01:00
Evgeny Poberezkin
8aabb6f0e6
move files to protocol folder
2021-05-03 10:06:16 +01:00
Evgeny Poberezkin
d4378461ab
package.yaml: rename simplex-messaging to simplexmq and update version ( #124 )
2021-05-02 21:07:45 +01:00
Efim Poberezkin
28ddef2d9c
docs, smp: align with implementation ( #43 )
...
* adjust out-of-band message abnf
* define hostname and encoded using prose-val
* elaborate on base64
* corrections up to SMP procedure
* fix CONN -> NEW
* update SMP protocol to align with the implementation
* remove Possible extensions from TOC
* lists
* corrections
Co-authored-by: Efim Poberezkin <8711996+efim-poberezkin@users.noreply.github.com >
2021-05-02 19:15:40 +01:00
Evgeny Poberezkin
7df39e9db3
update SMP version ( #123 )
2021-05-02 18:56:08 +01:00
Evgeny Poberezkin
aac23c6481
SMP agent protocol commands semantics ( #44 )
2021-05-02 18:47:16 +01:00
Evgeny Poberezkin
af408d50bf
Merge pull request #82 from simplex-chat/v2
2021-05-02 11:34:24 +01:00
Evgeny Poberezkin
93956b65c2
Merge branch 'master' into v2
2021-05-02 11:23:41 +01:00
Efim Poberezkin
b7902ee4c8
agent sqlite: store msg hashes and integrity ( #118 , #119 , #120 )
...
Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com >
2021-05-02 10:48:31 +04:00
Evgeny Poberezkin
633b3a4bda
mitigate timing attack to determine if queue exists ( #117 )
...
* mitigate timing attack to determine if queue exists
* remove timing for authenticated SEND command
Co-authored-by: Efim Poberezkin <8711996+efim-poberezkin@users.noreply.github.com >
2021-05-01 22:07:25 +01:00
Evgeny Poberezkin
829c198e5f
reserve block size (32 bit) and protocol (16 bit) in client handshake block ( #116 )
...
* reserve block size (32 bit) and protocol (16 bit) in client handshake block
* update function names
* fix abnf
2021-05-01 21:58:35 +01:00
Efim Poberezkin
6be4839703
agent: verify msg integrity based on previous msg hash and id ( #110 )
...
Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com >
2021-05-02 00:38:32 +04:00
Evgeny Poberezkin
6ceeb2c9db
save keys as binary to db, remove legacy encoding ( #114 )
...
* save keys as binary to db, remove legacy encoding
* import list
2021-04-30 09:13:18 +01:00
Evgeny Poberezkin
bf6e652e41
reduce help size ( #113 )
2021-04-30 09:06:59 +01:00
Mark Aleksander Hil
9a8570c59c
Updated ChatHelpInfo ( #112 )
2021-04-29 10:27:07 +01:00
Evgeny Poberezkin
729cf10ad8
test: SMP server store log ( #109 )
...
* test: SMP server store log
* test: extend store log test: queue deletion, log compacted
* test: check store log length in lines
2021-04-29 07:23:32 +01:00
Evgeny Poberezkin
afc09a6ec4
Store log ( #108 )
...
* StoreLog (WIP)
* add log records to map
* revert Protocol change
* revert Server change
* fix parseLogRecord
* optionally save/restore queues to/from store log
* refactor
* refactor delQueueAndMsgs
* move store log to /var/opt/simplex
* use ini file
2021-04-26 20:34:28 +01:00
Evgeny Poberezkin
816703527a
set different default server ( #107 )
...
* set different default server
* remove comment
2021-04-26 20:18:20 +01:00
Evgeny Poberezkin
5fec6c1755
Sign and verify agent messages ( #106 )
...
* sign and verify agent messages with key sent in HELLO (TODO: hardcoded block size - should use size from handshake; verify signature of HELLO message itself; possibly, different MSG status if signature was not verified (currently ignored) or failed to verify (currently fails with AGENT A_ENCRYPTION - alternatively, change it to AGENT A_SIGNATURE))
* remove hardcoded block size, make it 4096 bytes
* verify signature of HELLO message before it is added to RcvQueue
* refactor
* update doc
* rename functions
2021-04-26 20:05:46 +01:00
Evgeny Poberezkin
cddff78719
binary X509 encoding for RSA key send during transport handshake ( #105 )
2021-04-24 12:46:57 +01:00
Efim Poberezkin
65ad2eb6a8
docs, smp, chore: remove multiline sentences line breaks; uniform lists ( #42 )
2021-04-19 23:14:40 +04:00
Evgeny Poberezkin
3187bc8140
chat: add connection errors in chat, fix catch ( #103 )
2021-04-19 08:40:23 +01:00
Efim Poberezkin
40ad6db51a
return error on creation of duplicate connection ( #102 )
...
Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com >
2021-04-19 00:46:01 +04:00
Evgeny Poberezkin
5e3bc7ee6c
improve error handling ( #101 )
...
* inventory of error handling problems and types
* Change SMP protocol errors syntax
* connection errors in agent protocol (ERR CONN), STORE error -> AGENT error
* include exception in SEInternal error
* add MESSAGE errors, remove CRYPTO and SIZE errors
* agent protocol SYNTAX and AGENT errors
* BROKER errors
* group all client command (and agent response) errors
* BROKER TRANSPORT error
* simplify Client
* clean up
* transport errors
* simplify client
* parse / serialize agent errors
* differentiate crypto errors
* update errors.md
* make agent and SMP protocol errors consistent, simplify
* update doc
* test: parse / serialize protocol errors with QuickCheck
* add String to internal error
* exponential back-off when retrying to send HELLO
* refactor Client.hs
* replace fold with recursion in startTCPClient
* fail test if server did not start, refactor
* test: wait till TCP server stops
* test: refactor waiting for server to stop
* test: fail with error if server did not start/stop
2021-04-18 18:37:54 +01:00
Evgeny Poberezkin
9104ff0c4a
Merge branch 'master' into v2
2021-04-18 17:03:25 +01:00
Evgeny Poberezkin
65db5cfa18
duplex procedure, update diagram ( #41 )
...
* duplex procedure, update diagram
* reduce svg whitespace
* update svg
2021-04-18 07:34:47 +01:00
Evgeny Poberezkin
5c1e9682c8
streams rfc draft ( #64 )
...
* streams rfc draft
* typos
* update streams RFC
Co-authored-by: Efim Poberezkin <efim.poberezkin@gmail.com >
2021-04-17 08:10:23 +01:00
Evgeny Poberezkin
36dad0ba86
SMP agent protocol - duplex messaging ( #39 )
...
* duplex messaging commands syntax
* update duplex messaging commands
* update duplex commands/responses
* SMP messages between agents
* error for multiple skipped messages
* more syntax
* more syntax
* add diagram: creating duplex connection
* fix diagram link
* update diagram
* update duplex diagram
* add queue statuses to the diagram
* add "try sending" periods to duplex diagram
* diagram: queue status (receive/send)
* update queue status
* simplify duplex connection to only have two queues
* remove error notification sent to another agent, only notify user
* remove unused commands, add "unsubscribed" notification
* simplified commands and added connection invitation syntax
* update SMP agent protocol
* duplex protocol correction
* corrections (#40 )
* SMP agent protocol
* rename duplex-messaging to agent-protocol
* minor fixes
* SMP agent protocol corrections
Co-authored-by: Efim Poberezkin <8711996+efim-poberezkin@users.noreply.github.com >
2021-04-16 19:56:53 +01:00
Evgeny Poberezkin
417066c462
change missing IDs message status syntax ( #100 )
2021-04-16 18:48:13 +01:00
Evgeny Poberezkin
326050651a
Merge branch 'master' into v2
2021-04-14 21:30:30 +01:00