Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#1811 - Wrong file attachment detection in the chatroom #1812

Closed
wants to merge 498 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
498 commits
Select commit Hold shift + click to select a range
c4ea80f
EncryptedValue: ensure that it's a string
corrideat Oct 3, 2023
9a5b2f1
Refactor: logout handler
corrideat Oct 3, 2023
5dbbab2
Convert password to passwordFn to prevent logging
corrideat Oct 3, 2023
4b071b7
Fix issue (key rotation / private channel not working after rejoin)
corrideat Oct 4, 2023
c1e62e4
Fix: leaving private chat without being member
corrideat Oct 4, 2023
2b26e68
Documentation
corrideat Oct 4, 2023
47ffe18
#1742 Use 'submit-button' component for asynchronous actions (#1750)
SebinSong Oct 5, 2023
88e87df
Merge branch 'master' into e2e-protocol
taoeffect Oct 5, 2023
b76a61d
restore package.json wtf...
taoeffect Oct 5, 2023
213e29c
Bugfixes
corrideat Oct 5, 2023
2c704ba
Add UI prompt to login and re-order buttons
corrideat Oct 5, 2023
4a5e89d
Rename button names
corrideat Oct 5, 2023
bf166f8
Bugfix: null inner signing key when leaving chatroom
corrideat Oct 5, 2023
1c3161d
Add comments explaining the innerSigning attributes
corrideat Oct 5, 2023
c75f62a
Bugfix: race condition when joining due to skipActionProcessing
corrideat Oct 5, 2023
949da8d
Change bad previous head log level to warn
corrideat Oct 5, 2023
be616a9
Remove skipActionProcessing from respondToKeyRequests
corrideat Oct 5, 2023
e6dc093
Merge branch 'e2e-protocol-ricardo' into e2e-protocol
corrideat Oct 5, 2023
0a41d2d
add sw-manifest.json to the project / make sure no clinical errors in…
SebinSong Oct 6, 2023
ab85416
feat: added profile-card in payments table
Silver-IT Oct 6, 2023
4c3e61a
[e2e-protocol] Fix the welcome screen bug in /pending-approval page (…
SebinSong Oct 6, 2023
70e403e
Merge pull request #1753 from okTurtles/1746-show-user-profile-cards-…
taoeffect Oct 6, 2023
893a07b
Fixed error to save scroll position (#1730)
Silver-IT Oct 6, 2023
ac91c30
Bugfix: key rotation on watched contracts
corrideat Oct 6, 2023
f079b04
Fix message format for OP_KEY_SHARE
corrideat Oct 6, 2023
1fc3ec4
Merge pull request #1754 from okTurtles/e2e-protocol-ricardo
taoeffect Oct 6, 2023
d55847f
Rotate PEK when a group member leaves
corrideat Oct 6, 2023
3ecd689
Merge branch 'e2e-protocol' into e2e-protocol-ricardo
corrideat Oct 6, 2023
2d372c6
Generic definition for the various DB stores
corrideat Oct 7, 2023
8a5b5f7
Revert changes to frontend/model/database.js and use the identity con…
corrideat Oct 7, 2023
dad7003
Remove withEnv
corrideat Oct 7, 2023
0d0a581
update pwa manifest files with more square icons
SebinSong Oct 9, 2023
cee3003
register service-worker / add more icon dimensions
SebinSong Oct 10, 2023
79f0387
Merge branch 'master' into e2e-protocol
taoeffect Oct 10, 2023
e14d420
Handle encrypted and unencrypted invites (accounting)
corrideat Oct 10, 2023
39a3b38
Merge branch 'e2e-protocol' into e2e-protocol-ricardo
corrideat Oct 10, 2023
7071d99
fear: remove archived data when leave the group (#1747)
Silver-IT Oct 10, 2023
d2d36ab
Merge branch 'e2e-protocol' of github.com:okTurtles/group-income-simp…
corrideat Oct 10, 2023
5818f65
Add return
corrideat Oct 10, 2023
ee1c65f
Improvements to respondToKeyRequests
corrideat Oct 10, 2023
f5fdb61
Make sync no-op for existing contracts
corrideat Oct 11, 2023
58cbb69
Merge remote-tracking branch 'origin/e2e-protocol' into sebin/task/92…
SebinSong Oct 12, 2023
8e1701e
Listen for login event before calling postSubmit
corrideat Oct 12, 2023
0a1cd00
Await in the login form, documentation
corrideat Oct 12, 2023
c421eb8
Merge branch 'e2e-protocol' into e2e-protocol-ricardo
corrideat Oct 12, 2023
9f523ce
Updates to postSyncOps
corrideat Oct 12, 2023
fe490a7
basic route setup for /push/* path and test it in service-worker.js
SebinSong Oct 13, 2023
b7b9ed9
add /push/subscribe and /push/unsubscribe routes and make the service…
SebinSong Oct 13, 2023
c7920df
Split up syncContractAndWatchKeys
corrideat Oct 13, 2023
1b9e6dc
Add chelonia/private/enqueuePostSyncOps to blacklist
corrideat Oct 13, 2023
e548b2f
Merge branch 'e2e-protocol-ricardo-postsync' into e2e-protocol-ricardo
corrideat Oct 13, 2023
90a97ae
Closure for storeSecretKeys to prevent logging secrets
corrideat Oct 13, 2023
ed4c21a
Remove promiseAllSettled. Bugfixes.
corrideat Oct 13, 2023
caa79e1
add /push/send route , setup 'push' event listener in service-worker
SebinSong Oct 14, 2023
d465aec
add theme_color, background_color to the PWA manifest
SebinSong Oct 14, 2023
de345e3
Send test notification upon sign-up / log-in , update POST /push/send…
SebinSong Oct 15, 2023
2d1bd83
remove unused route POST /push/send/{subscriptionId}
SebinSong Oct 15, 2023
87190a6
add payload validations to /push/* routes
SebinSong Oct 18, 2023
d38ae7d
remove console.log
SebinSong Oct 18, 2023
3eebc25
Update okturtles.eventqueue
corrideat Oct 18, 2023
05cf522
Side-effects without await
corrideat Oct 18, 2023
9eba410
Fix invocation
corrideat Oct 18, 2023
7cc4400
Make sure we sync any identity contracts we haven't synced upon login…
Silver-IT Oct 18, 2023
531be95
Remove await on /out in internals.js
corrideat Oct 18, 2023
053103a
Remove queueInvocation for /out events
corrideat Oct 18, 2023
70e3c59
Merge branch 'e2e-protocol' into e2e-protocol-ricardo
corrideat Oct 18, 2023
58e6c31
Merge pull request #1758 from okTurtles/e2e-protocol-ricardo
taoeffect Oct 18, 2023
6556ad8
fix: disable change group settings unless group creator tries
Silver-IT Oct 19, 2023
c33085f
Make cannot leave if not a member error into a warning
corrideat Oct 19, 2023
44c85a2
Show login error prompt only for errors related to the identity contr…
corrideat Oct 19, 2023
976021d
Fix issue of removing two members (error on second removal)
corrideat Oct 19, 2023
cc98510
Update identity.js login logic, remove spurious sideEffect check
corrideat Oct 19, 2023
2cf36e5
pin contracts
corrideat Oct 19, 2023
5ce96a5
Merge pull request #1776 from okTurtles/e2e-protocol-ricardo
taoeffect Oct 19, 2023
293e12a
Implement a way to set default groupId (#1773)
Silver-IT Oct 20, 2023
95a946b
Fix inability to join after sharer signs out
corrideat Oct 20, 2023
cf4b7f4
Updated login error message (#1731)
Silver-IT Oct 20, 2023
04bb180
fix: error of Member Removal (#1764)
Silver-IT Oct 20, 2023
2a78c44
Fix infinite re-subscription due to foreign keys
corrideat Oct 20, 2023
29add18
Revert "Updated login error message (#1731)"
taoeffect Oct 20, 2023
8bcff5d
Updated login error message (#1731)
Silver-IT Oct 20, 2023
26d5179
Fix undefined in vmInvites
corrideat Oct 20, 2023
22139cc
Merge pull request #1778 from okTurtles/e2e-protocol-ricardo
taoeffect Oct 20, 2023
3b1987e
preSendCheck for outgoing messages; move hooks to publishEvent
corrideat Oct 24, 2023
ac29a74
Remove preSendCheckContract
corrideat Oct 24, 2023
a4d98a6
Remove await from call to leaveAllChatRoomsUponLeaving
corrideat Oct 24, 2023
35a8139
Merge pull request #1779 from okTurtles/e2e-protocol-ricardo
taoeffect Oct 24, 2023
834299d
merge the latest master in
SebinSong Oct 25, 2023
a10eb41
Merge remote-tracking branch 'origin/e2e-protocol' into sebin/task/92…
SebinSong Oct 25, 2023
5af73c9
re-run after merging the latest e2e-protocol
SebinSong Oct 25, 2023
45ee249
Login sync fixes
corrideat Oct 25, 2023
f3bed17
Fix various issues related to login and re-joining
corrideat Oct 26, 2023
71c7a71
Merge pull request #1775 from okTurtles/1707-should-block-updating-gr…
taoeffect Oct 27, 2023
abd54ab
Make saveOurLoginState async
corrideat Oct 27, 2023
889c43f
Various improvments and bugfixes
corrideat Oct 29, 2023
94188fe
Bugfixes. Revert changes to side-effects
corrideat Nov 3, 2023
028513f
bump
corrideat Nov 3, 2023
9364fdf
Address re-joining of chatrooms
corrideat Nov 4, 2023
51a9522
Address PR review feedback
corrideat Nov 7, 2023
c9d4c52
update for Ricardo's feedbabck
SebinSong Nov 8, 2023
d2cc960
Merge remote-tracking branch 'origin/e2e-protocol' into sebin/task/92…
SebinSong Nov 8, 2023
65a6d74
Deferred remove
corrideat Nov 8, 2023
0596f30
Fixes to "chelonia/private/deleteRevokedKeys"
corrideat Nov 8, 2023
2a6d64d
Re-add sync to publishEvent
corrideat Nov 8, 2023
db5b43b
Bugfix: reducer at deleteRevokedKeys
corrideat Nov 8, 2023
4f9f4ce
Test state.contracts[cID] instead of state[cID]
corrideat Nov 8, 2023
4f91d6b
Bugfixes:
corrideat Nov 9, 2023
9d47c5c
Move joining #General and adding group key into side-effect
corrideat Nov 9, 2023
d03fcc6
Bugfixes
corrideat Nov 10, 2023
99f6b9d
Clear deferredRemove flag
corrideat Nov 10, 2023
b77a024
Check if we have the decryption key first
corrideat Nov 10, 2023
5db6ff1
Updated error message
corrideat Nov 10, 2023
1695b6d
Remove debug logs and fix multiple join calls
corrideat Nov 11, 2023
d461dde
Remove unnecessary sync of identity contract
corrideat Nov 11, 2023
7653085
Update all test scenarios for updated workflow (#1782)
Silver-IT Nov 13, 2023
295e166
feat: resolved conflicts
Silver-IT Nov 13, 2023
d11b6b1
fix: errors
Silver-IT Nov 13, 2023
fa6d4e1
fix: error in switching chatroom as soon as it is created
Silver-IT Nov 13, 2023
e3d5977
fix: error in cypress test
Silver-IT Nov 14, 2023
c67ac54
Bugfixes
corrideat Nov 14, 2023
43db5e1
Fix UI inconsistency issues (wrong message when joining / leaving; sw…
corrideat Nov 15, 2023
e680374
Encrypt OP_KEY_SHARE envelope
corrideat Nov 15, 2023
661921d
restore RecordPayment.vue against e2e-protocol branch
SebinSong Nov 16, 2023
6236b44
work partially on Greg's CR
SebinSong Nov 16, 2023
f059664
chore: pushed the latest commit of e2e-protocol-ricardo-2023
Silver-IT Nov 16, 2023
b103de9
Add missing sync when added to chatroom
corrideat Nov 16, 2023
c124023
Remove extraneous logging
corrideat Nov 16, 2023
8ef6917
Add destructor to leave chatrooms
corrideat Nov 16, 2023
421233c
chore: merged the latest commit and fix erorr in cy.login
Silver-IT Nov 17, 2023
905bbbc
Leave chatrooms on removeOurselves
corrideat Nov 17, 2023
7b2a3a2
Remove JOINING_CHATROOM
corrideat Nov 17, 2023
baacd80
Merge pull request #1780 from okTurtles/e2e-protocol-ricardo-20231025…
taoeffect Nov 17, 2023
9458715
Merge pull request #1785 from okTurtles/e2e-protocol-ricardo
taoeffect Nov 17, 2023
6897da2
Merge branch 'master' into e2e-protocol
taoeffect Nov 17, 2023
2439ce5
Implement /joinGroup and /leaveGroup. TODO: Move PEK rotation (?), fi…
corrideat Nov 17, 2023
ee579d8
chore: updated the latest e2e-protocol branch
Silver-IT Nov 17, 2023
0ab2308
merge the latest e2e-protocol
SebinSong Nov 17, 2023
97b58aa
restore RecordPayment.vue against e2e-protocol
SebinSong Nov 18, 2023
60a014e
work on implementing immediate kickout permission
SebinSong Nov 18, 2023
446e408
fix: cypress error
Silver-IT Nov 19, 2023
0cfd760
fix the giconf.json error
SebinSong Nov 21, 2023
813ebca
Improvements to login using new actions
corrideat Nov 21, 2023
493dbca
feat: remove eventHandler
Silver-IT Nov 21, 2023
c5e1cad
fix: removed cy.wait
Silver-IT Nov 22, 2023
899d807
chore: reverted changes using browserify
Silver-IT Nov 22, 2023
98fa470
Bugfixes and refactoring
corrideat Nov 22, 2023
2301d12
Comments and fix to vuex/save error
corrideat Nov 22, 2023
b3002a9
feat: removed cy.wait
Silver-IT Nov 23, 2023
772ae32
create message handlers for push-notification in both client and server
SebinSong Nov 23, 2023
687d2a6
Use group's CEK for joining and leaving
corrideat Nov 23, 2023
c86e978
Fix navigation glitches when joining or creating a group
corrideat Nov 23, 2023
b450b07
Prevent flashing of no group name
corrideat Nov 23, 2023
92b836d
Add comments
corrideat Nov 23, 2023
e5428a1
Fix group creation buttons
corrideat Nov 23, 2023
906ad50
Fix steps header
corrideat Nov 23, 2023
7b4c97e
Fix proposals oneVoteToPass
corrideat Nov 23, 2023
1a48ab8
Remove VOTE_UNDECIDED
corrideat Nov 23, 2023
8402c0d
Merge pull request #1788 from okTurtles/e2e-protocol-ricardo
taoeffect Nov 23, 2023
33b57bd
feat: merged the latest commit and fix cypress errors
Silver-IT Nov 24, 2023
e17e5f9
chore: added comments and renamed helper function
Silver-IT Nov 24, 2023
cf50675
chore: added github discussion as comment
Silver-IT Nov 24, 2023
7e6af66
add various push-action handlers to the pubsub message handler on the…
SebinSong Nov 24, 2023
b177786
replace GET /push/publickey with the logic with pubsub system
SebinSong Nov 24, 2023
a227775
add handler logic for STORE_SUBSCRIPTION
SebinSong Nov 24, 2023
9f51f3b
replace all /push/* to the pubsub equivalents
SebinSong Nov 24, 2023
c35bbca
Remove return from /rotateKeys in group to avoid deadlock
corrideat Nov 24, 2023
e280fcf
Add missing import
corrideat Nov 24, 2023
2d32522
Remove second return from call to rotateKeys
corrideat Nov 24, 2023
0edaed5
Remove /wait from rotateKeys
corrideat Nov 24, 2023
961050a
Chatroom: ignore join / leave side-effects when rendering messages
corrideat Nov 24, 2023
b69ec4c
chore: merged the latest commit
Silver-IT Nov 24, 2023
61644b2
move push-subscription map to server object in createServer
SebinSong Nov 27, 2023
532016b
Merge branch 'e2e-protocol-ricardo' into 1719-fix-all-tests-on-e2e-pr…
corrideat Nov 27, 2023
1367acb
Publish queue and reset selector
corrideat Nov 27, 2023
3caca18
rename TO_SERVER/FROM_SERVER to PUSH_ACTION
SebinSong Nov 28, 2023
d78efd0
Merge remote-tracking branch 'origin/e2e-protocol' into sebin/task/92…
SebinSong Nov 28, 2023
6d12969
some optimisation in 'push' event handler in service-worker
SebinSong Nov 28, 2023
fa62fb6
correct the error sentence
SebinSong Nov 28, 2023
f58e1d4
add a TODO comment in push.js
SebinSong Nov 28, 2023
18ad3c6
Fix user count for non-joined chatrooms
corrideat Nov 28, 2023
d57779a
improve the error-handling logic for push actions
SebinSong Nov 29, 2023
cde2fe6
Bugfixes and simplification of /join
corrideat Nov 29, 2023
83485e5
Use on instead of once
corrideat Nov 29, 2023
478a7a0
updates for a couple of CRs from the PR review
SebinSong Nov 30, 2023
9f92acb
Remove delete pending
corrideat Nov 30, 2023
4e6e33f
Add queue for listenChatoomActions
corrideat Nov 30, 2023
ac8842f
a couple of fixes in service-worker.js
SebinSong Dec 1, 2023
6c53013
postpublish hook and internal-only id
corrideat Dec 1, 2023
218c42e
id-less chat refreshes
corrideat Dec 1, 2023
a8008a0
Remove GIMessage.id()
corrideat Dec 1, 2023
15fb085
Remove missing from GIMessage
corrideat Dec 1, 2023
624889a
Bugfix: onprocessed handler
corrideat Dec 1, 2023
c1da368
Remove the logic that asks server to send a test notification
SebinSong Dec 2, 2023
8929ff8
fix the undeleted logic
SebinSong Dec 2, 2023
9142f55
separate push-subscription logic from service-worker registration
SebinSong Dec 2, 2023
e775ae1
Add way for Chelonia to shut down
corrideat Dec 2, 2023
47239d9
move the push-setup logic into requestPermission() util method
SebinSong Dec 4, 2023
fb5f791
move '/send-push' into a then of Promise
SebinSong Dec 4, 2023
f7f54fc
Bugfixes for integration tests
corrideat Dec 5, 2023
8b9d60d
Fix duplicate messages and move removeImmediately to internals
corrideat Dec 5, 2023
91c2b21
onresolve for forceDistributionDate
corrideat Dec 5, 2023
b0895ed
Update to commands.js
corrideat Dec 5, 2023
a941b42
setup/send push-notification only after the permission has been granted.
SebinSong Dec 6, 2023
a1a5f9a
remove console.log()
SebinSong Dec 6, 2023
c8209af
merge the latest e2e-protocol in
SebinSong Dec 7, 2023
adb064d
Merge pull request #1786 from okTurtles/sebin/task/#1781-immediate-me…
taoeffect Dec 7, 2023
984c692
logic for exchanging a message btw the SW and the Client
SebinSong Dec 7, 2023
b0268dc
Fix Flow errors and make encryptedData test pass
corrideat Dec 7, 2023
9654168
Undo change to ChatMain
corrideat Dec 7, 2023
b974230
encryptedData: remove unnecessary multiple calls to rootState
corrideat Dec 7, 2023
c84de55
encryptedData: fix selector name
corrideat Dec 7, 2023
6790c99
Updates to make backend.test.js work; added null encryption and signa…
corrideat Dec 7, 2023
355402f
Add comments on eNULL and sNULL as well as environment variable
corrideat Dec 7, 2023
5ba1508
Merge remote-tracking branch 'origin/e2e-protocol' into sebin/task/92…
SebinSong Dec 8, 2023
9c1ae75
work on Greg's CR again
SebinSong Dec 8, 2023
2702b75
Write to contract state only after processing finished
corrideat Dec 8, 2023
4b10a2f
Update comment
corrideat Dec 8, 2023
aecca39
Feedback
corrideat Dec 8, 2023
409f7c3
Fix wrong selector
corrideat Dec 8, 2023
67ca3ad
Various bugfixes, atomic for sendMessage
corrideat Dec 9, 2023
e0f8896
comments and deserializeHEAD
corrideat Dec 9, 2023
fce148e
Remove unnecessary import
corrideat Dec 9, 2023
171d382
Fix Flow errors
corrideat Dec 9, 2023
037979e
Fix deserializeHEAD
corrideat Dec 9, 2023
067fb0b
Fix preSendCheck
corrideat Dec 9, 2023
7bc9b4b
Fix state
corrideat Dec 9, 2023
7163dc8
Duplicate proposal key prefix
corrideat Dec 9, 2023
b6558d0
fix check
corrideat Dec 9, 2023
f595687
Fixed race-conditions when joining a group
corrideat Dec 10, 2023
6ef6589
Improved check with both contracts
corrideat Dec 10, 2023
390d32d
Fix removing ourselves when re-added
corrideat Dec 11, 2023
6a7e5e7
Add duplicate check for previous volatile state; do so only if the
corrideat Dec 11, 2023
1e839d2
Readability and fixed check
corrideat Dec 11, 2023
c54ed0b
Remove unneeded logging
corrideat Dec 11, 2023
cab74db
Fixes to chatroom
corrideat Dec 11, 2023
8a484ed
Remove logging
corrideat Dec 11, 2023
a418db5
Merge branch 'e2e-protocol' into 1719-fix-all-tests-on-e2e-protocol-b…
corrideat Dec 11, 2023
88e5d41
Merge pull request #1787 from okTurtles/1719-fix-all-tests-on-e2e-pro…
taoeffect Dec 11, 2023
44d73ae
work on Greg/Snowteamer Feedbacks on the PR
SebinSong Dec 12, 2023
b3c9650
Merge pull request #1770 from okTurtles/sebin/task/926-create-pwa
taoeffect Dec 12, 2023
77eb415
fix the white-space issue
SebinSong Dec 12, 2023
477d9ff
Merge pull request #1795 from okTurtles/sebin/task/1790-fix-add-to-ch…
taoeffect Dec 12, 2023
8a40d0e
move the try ... catch block into the Promise callback
SebinSong Dec 13, 2023
5a45a93
Merge pull request #1796 from okTurtles/sebin/task/fix-cypress-error-…
taoeffect Dec 13, 2023
1c6cc39
Make the pubsub system more generic (#1792)
snowteamer Dec 30, 2023
78926a4
#1793 Dark theme status bar color in the PWA (#1800)
SebinSong Jan 11, 2024
3772bd1
Merge branch 'master' into e2e-protocol
taoeffect Jan 11, 2024
a6a24ac
#1791 - Immediately install new service worker on refresh (#1799)
SebinSong Jan 12, 2024
76cc6fc
#1665 Typing indicator in the chatroom (#1805)
SebinSong Jan 12, 2024
f584aee
fix the bug
SebinSong Jan 17, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion .flowconfig
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
.*/frontend/assets/.*
.*/frontend/controller/service-worker.js
.*/frontend/utils/blockies.js
.*/frontend/utils/crypto.js
.*/frontend/utils/vuexQueue.js
.*/frontend/model/contracts/misc/flowTyper.js
.*/historical/.*
Expand Down
15 changes: 10 additions & 5 deletions Gruntfile.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
'use strict'

if (process.env['CI']) process.exit(1)

// =======================
// Entry point.
//
Expand Down Expand Up @@ -39,7 +41,8 @@ const {
CI = '',
LIGHTWEIGHT_CLIENT = 'true',
NODE_ENV = 'development',
EXPOSE_SBP = ''
EXPOSE_SBP = '',
ENABLE_UNSAFE_NULL_CRYPTO = 'false'
} = process.env

if (!['development', 'production'].includes(NODE_ENV)) {
Expand Down Expand Up @@ -205,7 +208,8 @@ module.exports = (grunt) => {
'process.env.GI_VERSION': `'${GI_VERSION}'`,
'process.env.LIGHTWEIGHT_CLIENT': `'${LIGHTWEIGHT_CLIENT}'`,
'process.env.NODE_ENV': `'${NODE_ENV}'`,
'process.env.EXPOSE_SBP': `'${EXPOSE_SBP}'`
'process.env.EXPOSE_SBP': `'${EXPOSE_SBP}'`,
'process.env.ENABLE_UNSAFE_NULL_CRYPTO': `'${ENABLE_UNSAFE_NULL_CRYPTO}'`
},
external: ['crypto', '*.eot', '*.ttf', '*.woff', '*.woff2'],
format: 'esm',
Expand All @@ -232,7 +236,7 @@ module.exports = (grunt) => {
},
// Native options used when building our service worker(s).
serviceWorkers: {
entryPoints: ['./frontend/controller/serviceworkers/primary.js']
entryPoints: ['./frontend/controller/serviceworkers/sw-primary.js']
}
}
esbuildOptionBags.contracts = {
Expand All @@ -246,7 +250,7 @@ module.exports = (grunt) => {
// },
splitting: false,
outdir: distContracts,
entryPoints: [`${contractsDir}/group.js`, `${contractsDir}/chatroom.js`, `${contractsDir}/identity.js`, `${contractsDir}/mailbox.js`],
entryPoints: [`${contractsDir}/group.js`, `${contractsDir}/chatroom.js`, `${contractsDir}/identity.js`],
external: ['@sbp/sbp']
}
// prevent contract hash from changing each time we build them
Expand Down Expand Up @@ -375,7 +379,7 @@ module.exports = (grunt) => {
// The `--require` flag ensures custom Babel support in our test files.
test: {
cmd: 'node node_modules/mocha/bin/mocha --require ./scripts/mocha-helper.js --exit -R spec --bail "./{test/,!(node_modules|ignored|dist|historical|test)/**/}*.test.js"',
options: { env: process.env }
options: { env: { ...process.env, ENABLE_UNSAFE_NULL_CRYPTO: 'true' } }
},
chelDeployAll: 'find contracts -iname "*.manifest.json" | xargs -r ./node_modules/.bin/chel deploy ./data'
}
Expand Down Expand Up @@ -648,6 +652,7 @@ module.exports = (grunt) => {

grunt.registerTask('test', ['build', 'exec:chelDeployAll', 'backend:launch', 'exec:test', 'cypress'])
grunt.registerTask('test:unit', ['backend:launch', 'exec:test'])
grunt.registerTask('test:cypress', ['build', 'exec:chelDeployAll', 'backend:launch', 'cypress'])

// -------------------------------------------------------------------------
// Process event handlers
Expand Down
1 change: 0 additions & 1 deletion backend/dashboard/views/pages/Contracts.vue
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,6 @@ export default {
contractFilter: { id: 'all-contracts', name: L('All contracts') },
filterOptions: [
{ id: 'all-contracts', name: L('All contracts') },
{ id: 'mailbox', name: L('Mailbox') },
{ id: 'chatroom', name: L('Chatroom') },
{ id: 'identity', name: L('Identity') },
{ id: 'group', name: L('Group') }
Expand Down
3 changes: 1 addition & 2 deletions backend/dashboard/views/utils/dummy-data.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,14 @@ const randomHash = () => blake32Hash(Math.random().toString(16).slice(2))
const contractDummyData = []
const manifestDummy = {
'gi.contracts/identity': {"head":{"manifestVersion":"1.0.0"},"body":"{\"version\":\"0.0.1\",\"contract\":{\"hash\":\"21XWnNVpDxBCmdcQvko21FoGWpTXhNydrWfsCxB1VdfWg2wtxA\",\"file\":\"identity.js\"},\"authors\":[{\"cipher\":\"algo\",\"key\":\"<pubkey from deploy-key.json>\"},{\"cipher\":\"algo\",\"key\":\"<pubkey from alex.json>\"}],\"contractSlim\":{\"file\":\"identity-slim.js\",\"hash\":\"21XWnNSeKaQFg61hqcw9FvNV3TPZpqdBnNYQSVz3tKPVWygToL\"}}","signature":{"key":"<which of the \'authors\' keys was used to sign \'body\'>","signature":"<signature>"}},
'gi.contracts/mailbox': {"head":{"manifestVersion":"1.0.0"},"body":"{\"version\":\"0.0.1\",\"contract\":{\"hash\":\"21XWnNQjQwf4fPBBqBJtPee3SMVbHrQSju4tu6SRjHNPfDBo8Q\",\"file\":\"mailbox.js\"},\"authors\":[{\"cipher\":\"algo\",\"key\":\"<pubkey from deploy-key.json>\"},{\"cipher\":\"algo\",\"key\":\"<pubkey from alex.json>\"}],\"contractSlim\":{\"file\":\"mailbox-slim.js\",\"hash\":\"21XWnNXUFWQDPrqeADPHPyYueAtVRoAdmwsMT9XBCWfPtP8DLb\"}}","signature":{"key":"<which of the \'authors\' keys was used to sign \'body\'>","signature":"<signature>"}},
'gi.contracts/chatroom': {"head":{"manifestVersion":"1.0.0"},"body":"{\"version\":\"0.0.1\",\"contract\":{\"hash\":\"21XWnNPTjY6GrUyqb7GzsLstF5JZhs9b5jADnSVufZipPvtQeA\",\"file\":\"chatroom.js\"},\"authors\":[{\"cipher\":\"algo\",\"key\":\"<pubkey from deploy-key.json>\"},{\"cipher\":\"algo\",\"key\":\"<pubkey from alex.json>\"}],\"contractSlim\":{\"file\":\"chatroom-slim.js\",\"hash\":\"21XWnNRT58PL4Hj1BUv2SaJYZHVFkFAF8bS2FTwQy7XvuXB1QE\"}}","signature":{"key":"<which of the \'authors\' keys was used to sign \'body\'>","signature":"<signature>"}},
'gi.contracts/group': {"head":{"manifestVersion":"1.0.0"},"body":"{\"version\":\"0.0.1\",\"contract\":{\"hash\":\"21XWnNXo4eU77dCQuWkPZtNTXST4hxd1DGnGMiBsaBB6vkdTZk\",\"file\":\"group.js\"},\"authors\":[{\"cipher\":\"algo\",\"key\":\"<pubkey from deploy-key.json>\"},{\"cipher\":\"algo\",\"key\":\"<pubkey from alex.json>\"}],\"contractSlim\":{\"file\":\"group-slim.js\",\"hash\":\"21XWnNSmnNSZZ6oZfsRmss2KKCSQS5QqVh62Ub7iojRAYwcxRr\"}}","signature":{"key":"<which of the \'authors\' keys was used to sign \'body\'>","signature":"<signature>"}}
}

for (let i=0; i<20; i++) {
const item = {
contractId: randomHash(),
type: randomFromArray(['gi.contracts/identity', 'gi.contracts/mailbox', 'gi.contracts/chatroom', 'gi.contracts/group']),
type: randomFromArray(['gi.contracts/identity', 'gi.contracts/chatroom', 'gi.contracts/group']),
size: 3 + 10 * Math.random(),
spaceUsed: 10 + 20 * Math.random(),
createdDate: randomPastDate()
Expand Down
11 changes: 6 additions & 5 deletions backend/database.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,10 +38,11 @@ if (!fs.existsSync(dataFolder)) {

sbp('sbp/selectors/register', {
'backend/db/streamEntriesAfter': async function (contractID: string, hash: string): Promise<*> {
let currentHEAD = await sbp('chelonia/db/latestHash', contractID)
if (!currentHEAD) {
const latestHEADinfo = await sbp('chelonia/db/latestHEADinfo', contractID)
if (!latestHEADinfo) {
throw Boom.notFound(`contractID ${contractID} doesn't exist!`)
}
let { HEAD: currentHEAD } = latestHEADinfo
let prefix = '['
// NOTE: if this ever stops working you can also try Readable.from():
// https://nodejs.org/api/stream.html#stream_stream_readable_from_iterable_options
Expand All @@ -52,7 +53,7 @@ sbp('sbp/selectors/register', {
const json = `"${strToB64(entry.serialize())}"`
if (currentHEAD !== hash) {
this.push(prefix + json)
currentHEAD = entry.message().previousHEAD
currentHEAD = entry.head().previousHEAD
prefix = ','
} else {
this.push(prefix + json + ']')
Expand Down Expand Up @@ -88,7 +89,7 @@ sbp('sbp/selectors/register', {
this.push(prefix + json)
prefix = ','
limit--
currentHEAD = entry.message().previousHEAD
currentHEAD = entry.head().previousHEAD
}
} catch (e) {
// TODO: properly return an error to caller, see https://nodejs.org/api/stream.html#errors-while-reading
Expand Down Expand Up @@ -123,7 +124,7 @@ sbp('sbp/selectors/register', {
offset--
}

currentHEAD = entry.message().previousHEAD
currentHEAD = entry.head().previousHEAD
if (!currentHEAD || (isMet && !offset)) {
this.push(']')
this.push(null)
Expand Down
140 changes: 74 additions & 66 deletions backend/pubsub.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
/* globals logger */
'use strict'

/*
* Pub/Sub server implementation using the `ws` library.
* See https://github.com/websockets/ws#api-docs
Expand All @@ -16,18 +15,24 @@ import {
} from '~/shared/pubsub.js'

import type {
Message, SubMessage, UnsubMessage,
NotificationTypeEnum, ResponseTypeEnum
Message, PubMessage, SubMessage, UnsubMessage,
NotificationTypeEnum
} from '~/shared/pubsub.js'

import type { JSONType } from '~/shared/types.js'
import type { JSONType, JSONObject } from '~/shared/types.js'

const { bold } = require('chalk')
const WebSocket = require('ws')

const { PING, PONG, PUB, SUB, UNSUB } = NOTIFICATION_TYPE
const { ERROR, SUCCESS } = RESPONSE_TYPE
const { ERROR, OK } = RESPONSE_TYPE

const defaultOptions = {
logPingRounds: process.env.NODE_ENV !== 'production' && !process.env.CI,
logPongMessages: false,
maxPayload: 6 * 1024 * 1024,
pingInterval: 30000
}
// Used to tag console output.
const tag = '[pubsub]'

Expand All @@ -53,12 +58,22 @@ export function createErrorResponse (data: JSONType): string {
return JSON.stringify({ type: ERROR, data })
}

export function createPushErrorResponse (data: JSONObject): string {
return JSON.stringify({
type: ERROR,
data: {
...data,
type: REQUEST_TYPE.PUSH_ACTION
}
})
}

export function createNotification (type: NotificationTypeEnum, data: JSONType): string {
return JSON.stringify({ type, data })
}

export function createResponse (type: ResponseTypeEnum, data: JSONType): string {
return JSON.stringify({ type, data })
export function createOkResponse (data: JSONType): string {
return JSON.stringify({ type: OK, data })
}

/**
Expand Down Expand Up @@ -86,11 +101,13 @@ export function createServer (httpServer: Object, options?: Object = {}): Object
...{ clientTracking: true },
server: httpServer
})
server.channels = new Set()
server.customServerEventHandlers = { ...options.serverHandlers }
server.customSocketEventHandlers = { ...options.socketHandlers }
server.messageHandlers = { ...defaultMessageHandlers, ...options.messageHandlers }
server.pingIntervalID = undefined
server.subscribersByContractID = Object.create(null)
server.subscribersByChannelID = Object.create(null)
server.pushSubscriptions = Object.create(null)

// Add listeners for server events, i.e. events emitted on the server object.
Object.keys(defaultServerHandlers).forEach((name) => {
Expand Down Expand Up @@ -127,13 +144,6 @@ export function createServer (httpServer: Object, options?: Object = {}): Object
return Object.assign(server, publicMethods)
}

const defaultOptions = {
logPingRounds: process.env.NODE_ENV !== 'production' && !process.env.CI,
logPongMessages: false,
maxPayload: 6 * 1024 * 1024,
pingInterval: 30000
}

// Default handlers for server events.
// The `this` binding refers to the server object.
const defaultServerHandlers = {
Expand Down Expand Up @@ -193,15 +203,11 @@ const defaultServerHandlers = {
const defaultSocketEventHandlers = {
close (code: string, reason: string) {
const socket = this
const { server, id: socketID } = this

// Notify other client sockets that this one has left any room they shared.
for (const contractID of socket.subscriptions) {
const subscribers = server.subscribersByContractID[contractID]
// Remove this socket from the subscribers of the given contract.
subscribers.delete(socket)
const notification = createNotification(UNSUB, { contractID, socketID })
server.broadcast(notification, { to: subscribers })
const { server } = this

for (const channelID of socket.subscriptions) {
// Remove this socket from the channel subscribers.
server.subscribersByChannelID[channelID].delete(socket)
}
socket.subscriptions.clear()
},
Expand Down Expand Up @@ -251,52 +257,54 @@ const defaultMessageHandlers = {
socket.activeSinceLastPing = true
},

[PUB] (msg: Message) {
// Currently unused.
[PUB] (msg: PubMessage) {
const { server } = this
const subscribers = server.subscribersByChannelID[msg.channelID]
server.broadcast(msg, { to: subscribers ?? [] })
},

[SUB] ({ contractID, dontBroadcast }: SubMessage) {
[SUB] ({ channelID }: SubMessage) {
const socket = this
const { server, id: socketID } = this

if (!socket.subscriptions.has(contractID)) {
log('Already subscribed to', contractID)
// Add the given contract ID to our subscriptions.
socket.subscriptions.add(contractID)
if (!server.subscribersByContractID[contractID]) {
server.subscribersByContractID[contractID] = new Set()
}
const subscribers = server.subscribersByContractID[contractID]
// Add this socket to the subscribers of the given contract.
subscribers.add(socket)
if (!dontBroadcast) {
// Broadcast a notification to every other open subscriber.
const notification = createNotification(SUB, { contractID, socketID })
server.broadcast(notification, { to: subscribers, except: socket })
const { server } = this

if (!server.channels.has(channelID)) {
socket.send(createErrorResponse(
{ type: SUB, channelID, reason: `Unknown channel id: ${channelID}` }
))
return
}
if (!socket.subscriptions.has(channelID)) {
// Add the given channel ID to our subscriptions.
socket.subscriptions.add(channelID)
if (!server.subscribersByChannelID[channelID]) {
server.subscribersByChannelID[channelID] = new Set()
}
// Add this socket to the channel subscribers.
server.subscribersByChannelID[channelID].add(socket)
} else {
log('Already subscribed to', channelID)
}
socket.send(createResponse(SUCCESS, { type: SUB, contractID }))
socket.send(createOkResponse({ type: SUB, channelID }))
},

[UNSUB] ({ contractID, dontBroadcast }: UnsubMessage) {
[UNSUB] ({ channelID }: UnsubMessage) {
const socket = this
const { server, id: socketID } = this

if (socket.subscriptions.has(contractID)) {
// Remove the given contract ID from our subscriptions.
socket.subscriptions.delete(contractID)
if (server.subscribersByContractID[contractID]) {
const subscribers = server.subscribersByContractID[contractID]
// Remove this socket from the subscribers of the given contract.
subscribers.delete(socket)
if (!dontBroadcast) {
const notification = createNotification(UNSUB, { contractID, socketID })
// Broadcast a notification to every other open subscriber.
server.broadcast(notification, { to: subscribers, except: socket })
}
const { server } = this

if (!server.channels.has(channelID)) {
socket.send(createErrorResponse(
{ type: UNSUB, channelID, reason: `Unknown channel id: ${channelID}` }
))
}
if (socket.subscriptions.has(channelID)) {
// Remove the given channel ID from our subscriptions.
socket.subscriptions.delete(channelID)
if (server.subscribersByChannelID[channelID]) {
// Remove this socket from the channel subscribers.
server.subscribersByChannelID[channelID].delete(socket)
}
}
socket.send(createResponse(SUCCESS, { type: UNSUB, contractID }))
socket.send(createOkResponse({ type: UNSUB, channelID }))
}
}

Expand All @@ -309,24 +317,24 @@ const publicMethods = {
* @param except - A recipient to exclude. Optional.
*/
broadcast (
message: Message,
message: Message | string,
{ to, except }: { to?: Iterable<Object>, except?: Object }
) {
const server = this

for (const client of to || server.clients) {
if (client.readyState === WebSocket.OPEN && client !== except) {
client.send(message)
client.send(typeof message === 'string' ? message : JSON.stringify(message))
}
}
},

// Enumerates the subscribers of a given contract.
* enumerateSubscribers (contractID: string): Iterable<Object> {
// Enumerates the subscribers of a given channel.
* enumerateSubscribers (channelID: string): Iterable<Object> {
const server = this

if (contractID in server.subscribersByContractID) {
yield * server.subscribersByContractID[contractID]
if (channelID in server.subscribersByChannelID) {
yield * server.subscribersByChannelID[channelID]
}
},

Expand Down
Loading
Loading