tool-db 2.2.0 → 2.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -201
- package/lib/adapters-base/networkAdapter.ts +215 -0
- package/lib/adapters-base/storageAdapter.ts +35 -0
- package/lib/adapters-base/userAdapter.ts +49 -0
- package/lib/crdt/baseCrdt.ts +21 -0
- package/lib/crdt/counterCrdt.ts +111 -0
- package/lib/crdt/listCrdt.ts +190 -0
- package/lib/crdt/mapCrdt.ts +119 -0
- package/{dist/index.d.ts → lib/index.ts} +16 -16
- package/lib/logger.ts +30 -0
- package/lib/messageHandlers/handleCrdtGet.ts +29 -0
- package/lib/messageHandlers/handleCrdtPut.ts +118 -0
- package/lib/messageHandlers/handleGet.ts +29 -0
- package/lib/messageHandlers/handlePing.ts +40 -0
- package/lib/messageHandlers/handlePong.ts +30 -0
- package/lib/messageHandlers/handlePut.ts +54 -0
- package/lib/messageHandlers/handleQuery.ts +25 -0
- package/lib/messageHandlers/handleSubscribe.ts +46 -0
- package/lib/server.ts +7 -0
- package/lib/shared.ts +5 -0
- package/lib/toolDbAnonSignIn.ts +5 -0
- package/lib/toolDbClientOnMessage.ts +75 -0
- package/lib/toolDbCrdtGet.ts +82 -0
- package/lib/toolDbCrdtPut.ts +77 -0
- package/lib/toolDbGet.ts +80 -0
- package/lib/toolDbKeysSignIn.ts +16 -0
- package/lib/toolDbPut.ts +83 -0
- package/lib/toolDbQueryKeys.ts +64 -0
- package/lib/toolDbSignIn.ts +31 -0
- package/lib/toolDbSignUp.ts +71 -0
- package/lib/toolDbSubscribe.ts +53 -0
- package/lib/toolDbVerificationWrapper.ts +55 -0
- package/lib/tooldb.ts +314 -0
- package/lib/types/message.ts +133 -0
- package/lib/types/tooldb.ts +89 -0
- package/lib/utils/catchReturn.ts +4 -0
- package/lib/utils/encoding/arrayBufferToHex.ts +18 -0
- package/lib/utils/encoding/arrayBufferToString.ts +8 -0
- package/lib/utils/encoding/hexToArrayBuffer.ts +13 -0
- package/lib/utils/encoding/hexToString.ts +8 -0
- package/lib/utils/encoding/hexToUint8.ts +5 -0
- package/lib/utils/encoding/stringToArrayBuffer.ts +8 -0
- package/lib/utils/getPeerSignature.ts +12 -0
- package/lib/utils/getTimestamp.ts +3 -0
- package/lib/utils/proofOfWork.ts +16 -0
- package/lib/utils/randomAnimal.ts +77 -0
- package/lib/utils/sha1.ts +7 -0
- package/lib/utils/sha256.ts +7 -0
- package/lib/utils/textRandom.ts +11 -0
- package/lib/utils/uniq.ts +3 -0
- package/lib/utils/verifyMessage.ts +88 -0
- package/lib/utils/verifyPeer.ts +15 -0
- package/package.json +31 -69
- package/tsconfig.json +10 -72
- package/.eslintrc.json +0 -74
- package/.github/workflows/main.yml +0 -29
- package/babel.config.js +0 -6
- package/bundle.js +0 -1
- package/custom-test-env.js +0 -28
- package/dist/__tests__ copy/base64.d.ts +0 -1
- package/dist/__tests__ copy/base64.js +0 -61
- package/dist/__tests__ copy/base64.js.map +0 -1
- package/dist/__tests__ copy/encryption.d.ts +0 -1
- package/dist/__tests__ copy/encryption.js +0 -68
- package/dist/__tests__ copy/encryption.js.map +0 -1
- package/dist/__tests__ copy/keys.d.ts +0 -1
- package/dist/__tests__ copy/keys.js +0 -238
- package/dist/__tests__ copy/keys.js.map +0 -1
- package/dist/__tests__ copy/network.d.ts +0 -1
- package/dist/__tests__ copy/network.js +0 -206
- package/dist/__tests__ copy/network.js.map +0 -1
- package/dist/__tests__ copy/pow.d.ts +0 -1
- package/dist/__tests__ copy/pow.js +0 -25
- package/dist/__tests__ copy/pow.js.map +0 -1
- package/dist/__tests__ copy/sha1.d.ts +0 -1
- package/dist/__tests__ copy/sha1.js +0 -16
- package/dist/__tests__ copy/sha1.js.map +0 -1
- package/dist/__tests__ copy/sha256.d.ts +0 -1
- package/dist/__tests__ copy/sha256.js +0 -16
- package/dist/__tests__ copy/sha256.js.map +0 -1
- package/dist/__tests__ copy/textRandom.d.ts +0 -1
- package/dist/__tests__ copy/textRandom.js +0 -17
- package/dist/__tests__ copy/textRandom.js.map +0 -1
- package/dist/bundle.js +0 -69086
- package/dist/chain/Block.d.ts +0 -29
- package/dist/chain/Block.js +0 -142
- package/dist/chain/Block.js.map +0 -1
- package/dist/chain/ToolChain.d.ts +0 -27
- package/dist/chain/ToolChain.js +0 -253
- package/dist/chain/ToolChain.js.map +0 -1
- package/dist/chain/Tx.d.ts +0 -50
- package/dist/chain/Tx.js +0 -54
- package/dist/chain/Tx.js.map +0 -1
- package/dist/chain/Wallet.d.ts +0 -9
- package/dist/chain/Wallet.js +0 -37
- package/dist/chain/Wallet.js.map +0 -1
- package/dist/chain/isValidChain.d.ts +0 -1
- package/dist/chain/isValidChain.js +0 -37
- package/dist/chain/isValidChain.js.map +0 -1
- package/dist/chain/mempool.d.ts +0 -0
- package/dist/chain/mempool.js +0 -2
- package/dist/chain/mempool.js.map +0 -1
- package/dist/crdt/baseCrdt.d.ts +0 -9
- package/dist/crdt/baseCrdt.js +0 -27
- package/dist/crdt/baseCrdt.js.map +0 -1
- package/dist/crdt/counterCrdt.d.ts +0 -30
- package/dist/crdt/counterCrdt.js +0 -124
- package/dist/crdt/counterCrdt.js.map +0 -1
- package/dist/crdt/listCrdt.d.ts +0 -42
- package/dist/crdt/listCrdt.js +0 -177
- package/dist/crdt/listCrdt.js.map +0 -1
- package/dist/crdt/mapCrdt.d.ts +0 -32
- package/dist/crdt/mapCrdt.js +0 -136
- package/dist/crdt/mapCrdt.js.map +0 -1
- package/dist/getCrypto.d.ts +0 -1
- package/dist/getCrypto.js +0 -10
- package/dist/getCrypto.js.map +0 -1
- package/dist/index.js +0 -99
- package/dist/index.js.map +0 -1
- package/dist/infuraFilecoin.d.ts +0 -0
- package/dist/infuraFilecoin.js +0 -2
- package/dist/infuraFilecoin.js.map +0 -1
- package/dist/loadCrdtDocument.d.ts +0 -3
- package/dist/loadCrdtDocument.js +0 -38
- package/dist/loadCrdtDocument.js.map +0 -1
- package/dist/makeTx.d.ts +0 -1
- package/dist/makeTx.js +0 -27
- package/dist/makeTx.js.map +0 -1
- package/dist/messageHandlers/handleCrdt.d.ts +0 -3
- package/dist/messageHandlers/handleCrdt.js +0 -11
- package/dist/messageHandlers/handleCrdt.js.map +0 -1
- package/dist/messageHandlers/handleCrdtGet.d.ts +0 -3
- package/dist/messageHandlers/handleCrdtGet.js +0 -32
- package/dist/messageHandlers/handleCrdtGet.js.map +0 -1
- package/dist/messageHandlers/handleCrdtPut.d.ts +0 -3
- package/dist/messageHandlers/handleCrdtPut.js +0 -88
- package/dist/messageHandlers/handleCrdtPut.js.map +0 -1
- package/dist/messageHandlers/handleGet.d.ts +0 -3
- package/dist/messageHandlers/handleGet.js +0 -31
- package/dist/messageHandlers/handleGet.js.map +0 -1
- package/dist/messageHandlers/handleJoin.d.ts +0 -3
- package/dist/messageHandlers/handleJoin.js +0 -36
- package/dist/messageHandlers/handleJoin.js.map +0 -1
- package/dist/messageHandlers/handlePing.d.ts +0 -3
- package/dist/messageHandlers/handlePing.js +0 -27
- package/dist/messageHandlers/handlePing.js.map +0 -1
- package/dist/messageHandlers/handlePong.d.ts +0 -3
- package/dist/messageHandlers/handlePong.js +0 -34
- package/dist/messageHandlers/handlePong.js.map +0 -1
- package/dist/messageHandlers/handlePut.d.ts +0 -3
- package/dist/messageHandlers/handlePut.js +0 -53
- package/dist/messageHandlers/handlePut.js.map +0 -1
- package/dist/messageHandlers/handleQuery.d.ts +0 -3
- package/dist/messageHandlers/handleQuery.js +0 -18
- package/dist/messageHandlers/handleQuery.js.map +0 -1
- package/dist/messageHandlers/handleServers.d.ts +0 -3
- package/dist/messageHandlers/handleServers.js +0 -23
- package/dist/messageHandlers/handleServers.js.map +0 -1
- package/dist/messageHandlers/handleSubscribe.d.ts +0 -3
- package/dist/messageHandlers/handleSubscribe.js +0 -43
- package/dist/messageHandlers/handleSubscribe.js.map +0 -1
- package/dist/server.d.ts +0 -1
- package/dist/server.js +0 -12
- package/dist/server.js.map +0 -1
- package/dist/shared.d.ts +0 -2
- package/dist/shared.js +0 -7
- package/dist/shared.js.map +0 -1
- package/dist/test.d.ts +0 -1
- package/dist/test.js +0 -17
- package/dist/test.js.map +0 -1
- package/dist/toolChainServer.d.ts +0 -8
- package/dist/toolChainServer.js +0 -60
- package/dist/toolChainServer.js.map +0 -1
- package/dist/toolDbAnonSignIn.d.ts +0 -2
- package/dist/toolDbAnonSignIn.js +0 -7
- package/dist/toolDbAnonSignIn.js.map +0 -1
- package/dist/toolDbClientOnMessage.d.ts +0 -3
- package/dist/toolDbClientOnMessage.js +0 -62
- package/dist/toolDbClientOnMessage.js.map +0 -1
- package/dist/toolDbCrdtGet.d.ts +0 -11
- package/dist/toolDbCrdtGet.js +0 -80
- package/dist/toolDbCrdtGet.js.map +0 -1
- package/dist/toolDbCrdtPut.d.ts +0 -11
- package/dist/toolDbCrdtPut.js +0 -68
- package/dist/toolDbCrdtPut.js.map +0 -1
- package/dist/toolDbGet.d.ts +0 -9
- package/dist/toolDbGet.js +0 -78
- package/dist/toolDbGet.js.map +0 -1
- package/dist/toolDbGetPubKey.d.ts +0 -2
- package/dist/toolDbGetPubKey.js +0 -18
- package/dist/toolDbGetPubKey.js.map +0 -1
- package/dist/toolDbKeysSignIn.d.ts +0 -2
- package/dist/toolDbKeysSignIn.js +0 -12
- package/dist/toolDbKeysSignIn.js.map +0 -1
- package/dist/toolDbNetwork.d.ts +0 -20
- package/dist/toolDbNetwork.js +0 -193
- package/dist/toolDbNetwork.js.map +0 -1
- package/dist/toolDbNetworkAdapter.d.ts +0 -57
- package/dist/toolDbNetworkAdapter.js +0 -192
- package/dist/toolDbNetworkAdapter.js.map +0 -1
- package/dist/toolDbPut.d.ts +0 -10
- package/dist/toolDbPut.js +0 -70
- package/dist/toolDbPut.js.map +0 -1
- package/dist/toolDbQueryKeys.d.ts +0 -8
- package/dist/toolDbQueryKeys.js +0 -69
- package/dist/toolDbQueryKeys.js.map +0 -1
- package/dist/toolDbSignIn.d.ts +0 -2
- package/dist/toolDbSignIn.js +0 -28
- package/dist/toolDbSignIn.js.map +0 -1
- package/dist/toolDbSignUp.d.ts +0 -3
- package/dist/toolDbSignUp.js +0 -97
- package/dist/toolDbSignUp.js.map +0 -1
- package/dist/toolDbSubscribe.d.ts +0 -8
- package/dist/toolDbSubscribe.js +0 -46
- package/dist/toolDbSubscribe.js.map +0 -1
- package/dist/toolDbVerificationWrapper.d.ts +0 -2
- package/dist/toolDbVerificationWrapper.js +0 -93
- package/dist/toolDbVerificationWrapper.js.map +0 -1
- package/dist/toolDbWeb3User.d.ts +0 -20
- package/dist/toolDbWeb3User.js +0 -75
- package/dist/toolDbWeb3User.js.map +0 -1
- package/dist/toolDbWebrtc.d.ts +0 -65
- package/dist/toolDbWebrtc.js +0 -489
- package/dist/toolDbWebrtc.js.map +0 -1
- package/dist/toolDbWebsocket.d.ts +0 -19
- package/dist/toolDbWebsocket.js +0 -193
- package/dist/toolDbWebsocket.js.map +0 -1
- package/dist/toolchain.d.ts +0 -1
- package/dist/toolchain.js +0 -8
- package/dist/toolchain.js.map +0 -1
- package/dist/tooldb.d.ts +0 -107
- package/dist/tooldb.js +0 -261
- package/dist/tooldb.js.map +0 -1
- package/dist/types/graph.d.ts +0 -0
- package/dist/types/graph.js +0 -2
- package/dist/types/graph.js.map +0 -1
- package/dist/types/message.d.ts +0 -106
- package/dist/types/message.js +0 -17
- package/dist/types/message.js.map +0 -1
- package/dist/types/tooldb.d.ts +0 -102
- package/dist/types/tooldb.js +0 -36
- package/dist/types/tooldb.js.map +0 -1
- package/dist/utils/arrayBufferToBase64.d.ts +0 -1
- package/dist/utils/arrayBufferToBase64.js +0 -12
- package/dist/utils/arrayBufferToBase64.js.map +0 -1
- package/dist/utils/arrayBufferToHex.d.ts +0 -1
- package/dist/utils/arrayBufferToHex.js +0 -19
- package/dist/utils/arrayBufferToHex.js.map +0 -1
- package/dist/utils/arrayBufferToString.d.ts +0 -1
- package/dist/utils/arrayBufferToString.js +0 -12
- package/dist/utils/arrayBufferToString.js.map +0 -1
- package/dist/utils/base64ToArrayBuffer.d.ts +0 -1
- package/dist/utils/base64ToArrayBuffer.js +0 -12
- package/dist/utils/base64ToArrayBuffer.js.map +0 -1
- package/dist/utils/base64ToBinaryChange.d.ts +0 -2
- package/dist/utils/base64ToBinaryChange.js +0 -18
- package/dist/utils/base64ToBinaryChange.js.map +0 -1
- package/dist/utils/base64ToBinaryDocument.d.ts +0 -2
- package/dist/utils/base64ToBinaryDocument.js +0 -18
- package/dist/utils/base64ToBinaryDocument.js.map +0 -1
- package/dist/utils/base64ToHex.d.ts +0 -1
- package/dist/utils/base64ToHex.js +0 -13
- package/dist/utils/base64ToHex.js.map +0 -1
- package/dist/utils/base64ToUint8.d.ts +0 -1
- package/dist/utils/base64ToUint8.js +0 -17
- package/dist/utils/base64ToUint8.js.map +0 -1
- package/dist/utils/catchReturn.d.ts +0 -1
- package/dist/utils/catchReturn.js +0 -8
- package/dist/utils/catchReturn.js.map +0 -1
- package/dist/utils/crypto/base64KeyToHex.d.ts +0 -1
- package/dist/utils/crypto/base64KeyToHex.js +0 -24
- package/dist/utils/crypto/base64KeyToHex.js.map +0 -1
- package/dist/utils/crypto/base64PublicKeyToHex.d.ts +0 -1
- package/dist/utils/crypto/base64PublicKeyToHex.js +0 -22
- package/dist/utils/crypto/base64PublicKeyToHex.js.map +0 -1
- package/dist/utils/crypto/decodeKeyString.d.ts +0 -1
- package/dist/utils/crypto/decodeKeyString.js +0 -12
- package/dist/utils/crypto/decodeKeyString.js.map +0 -1
- package/dist/utils/crypto/decryptData.d.ts +0 -1
- package/dist/utils/crypto/decryptData.js +0 -28
- package/dist/utils/crypto/decryptData.js.map +0 -1
- package/dist/utils/crypto/decryptWithPass.d.ts +0 -1
- package/dist/utils/crypto/decryptWithPass.js +0 -22
- package/dist/utils/crypto/decryptWithPass.js.map +0 -1
- package/dist/utils/crypto/deriveSecret.d.ts +0 -1
- package/dist/utils/crypto/deriveSecret.js +0 -18
- package/dist/utils/crypto/deriveSecret.js.map +0 -1
- package/dist/utils/crypto/encodeKeyString.d.ts +0 -1
- package/dist/utils/crypto/encodeKeyString.js +0 -12
- package/dist/utils/crypto/encodeKeyString.js.map +0 -1
- package/dist/utils/crypto/encryptData.d.ts +0 -1
- package/dist/utils/crypto/encryptData.js +0 -25
- package/dist/utils/crypto/encryptData.js.map +0 -1
- package/dist/utils/crypto/encryptWithPass.d.ts +0 -1
- package/dist/utils/crypto/encryptWithPass.js +0 -22
- package/dist/utils/crypto/encryptWithPass.js.map +0 -1
- package/dist/utils/crypto/exportKey.d.ts +0 -1
- package/dist/utils/crypto/exportKey.js +0 -14
- package/dist/utils/crypto/exportKey.js.map +0 -1
- package/dist/utils/crypto/exportKeyAsHex.d.ts +0 -1
- package/dist/utils/crypto/exportKeyAsHex.js +0 -18
- package/dist/utils/crypto/exportKeyAsHex.js.map +0 -1
- package/dist/utils/crypto/generateKeyFromPassword.d.ts +0 -1
- package/dist/utils/crypto/generateKeyFromPassword.js +0 -25
- package/dist/utils/crypto/generateKeyFromPassword.js.map +0 -1
- package/dist/utils/crypto/generateKeyPair.d.ts +0 -1
- package/dist/utils/crypto/generateKeyPair.js +0 -17
- package/dist/utils/crypto/generateKeyPair.js.map +0 -1
- package/dist/utils/crypto/generateKeysComb.d.ts +0 -4
- package/dist/utils/crypto/generateKeysComb.js +0 -60
- package/dist/utils/crypto/generateKeysComb.js.map +0 -1
- package/dist/utils/crypto/importKey.d.ts +0 -1
- package/dist/utils/crypto/importKey.js +0 -23
- package/dist/utils/crypto/importKey.js.map +0 -1
- package/dist/utils/crypto/loadKeysComb.d.ts +0 -5
- package/dist/utils/crypto/loadKeysComb.js +0 -90
- package/dist/utils/crypto/loadKeysComb.js.map +0 -1
- package/dist/utils/crypto/loadSignKeys.d.ts +0 -2
- package/dist/utils/crypto/loadSignKeys.js +0 -78
- package/dist/utils/crypto/loadSignKeys.js.map +0 -1
- package/dist/utils/crypto/recoverPubKey.d.ts +0 -1
- package/dist/utils/crypto/recoverPubKey.js +0 -33
- package/dist/utils/crypto/recoverPubKey.js.map +0 -1
- package/dist/utils/crypto/recoverPubKeyFromPrivate.d.ts +0 -1
- package/dist/utils/crypto/recoverPubKeyFromPrivate.js +0 -16
- package/dist/utils/crypto/recoverPubKeyFromPrivate.js.map +0 -1
- package/dist/utils/crypto/saveKeysComb.d.ts +0 -2
- package/dist/utils/crypto/saveKeysComb.js +0 -75
- package/dist/utils/crypto/saveKeysComb.js.map +0 -1
- package/dist/utils/crypto/saveSignKeys.d.ts +0 -2
- package/dist/utils/crypto/saveSignKeys.js +0 -67
- package/dist/utils/crypto/saveSignKeys.js.map +0 -1
- package/dist/utils/crypto/verifyData.d.ts +0 -1
- package/dist/utils/crypto/verifyData.js +0 -20
- package/dist/utils/crypto/verifyData.js.map +0 -1
- package/dist/utils/encoding/arrayBufferToBase64.d.ts +0 -1
- package/dist/utils/encoding/arrayBufferToBase64.js +0 -12
- package/dist/utils/encoding/arrayBufferToBase64.js.map +0 -1
- package/dist/utils/encoding/arrayBufferToHex.d.ts +0 -1
- package/dist/utils/encoding/arrayBufferToHex.js +0 -19
- package/dist/utils/encoding/arrayBufferToHex.js.map +0 -1
- package/dist/utils/encoding/arrayBufferToString.d.ts +0 -1
- package/dist/utils/encoding/arrayBufferToString.js +0 -12
- package/dist/utils/encoding/arrayBufferToString.js.map +0 -1
- package/dist/utils/encoding/base64ToArrayBuffer.d.ts +0 -1
- package/dist/utils/encoding/base64ToArrayBuffer.js +0 -12
- package/dist/utils/encoding/base64ToArrayBuffer.js.map +0 -1
- package/dist/utils/encoding/base64ToBinaryChange.d.ts +0 -2
- package/dist/utils/encoding/base64ToBinaryChange.js +0 -18
- package/dist/utils/encoding/base64ToBinaryChange.js.map +0 -1
- package/dist/utils/encoding/base64ToBinaryDocument.d.ts +0 -2
- package/dist/utils/encoding/base64ToBinaryDocument.js +0 -18
- package/dist/utils/encoding/base64ToBinaryDocument.js.map +0 -1
- package/dist/utils/encoding/base64ToHex.d.ts +0 -1
- package/dist/utils/encoding/base64ToHex.js +0 -13
- package/dist/utils/encoding/base64ToHex.js.map +0 -1
- package/dist/utils/encoding/base64ToUint8.d.ts +0 -1
- package/dist/utils/encoding/base64ToUint8.js +0 -17
- package/dist/utils/encoding/base64ToUint8.js.map +0 -1
- package/dist/utils/encoding/fromBase64.d.ts +0 -1
- package/dist/utils/encoding/fromBase64.js +0 -7
- package/dist/utils/encoding/fromBase64.js.map +0 -1
- package/dist/utils/encoding/hexToArrayBuffer.d.ts +0 -1
- package/dist/utils/encoding/hexToArrayBuffer.js +0 -15
- package/dist/utils/encoding/hexToArrayBuffer.js.map +0 -1
- package/dist/utils/encoding/hexToBase64.d.ts +0 -1
- package/dist/utils/encoding/hexToBase64.js +0 -12
- package/dist/utils/encoding/hexToBase64.js.map +0 -1
- package/dist/utils/encoding/hexToString.d.ts +0 -1
- package/dist/utils/encoding/hexToString.js +0 -12
- package/dist/utils/encoding/hexToString.js.map +0 -1
- package/dist/utils/encoding/hexToUint8.d.ts +0 -1
- package/dist/utils/encoding/hexToUint8.js +0 -11
- package/dist/utils/encoding/hexToUint8.js.map +0 -1
- package/dist/utils/encoding/stringToArrayBuffer.d.ts +0 -1
- package/dist/utils/encoding/stringToArrayBuffer.js +0 -12
- package/dist/utils/encoding/stringToArrayBuffer.js.map +0 -1
- package/dist/utils/encoding/toBase64.d.ts +0 -1
- package/dist/utils/encoding/toBase64.js +0 -7
- package/dist/utils/encoding/toBase64.js.map +0 -1
- package/dist/utils/encoding/uint8ArrayToHex.d.ts +0 -1
- package/dist/utils/encoding/uint8ArrayToHex.js +0 -7
- package/dist/utils/encoding/uint8ArrayToHex.js.map +0 -1
- package/dist/utils/encoding/uint8ToBase64.d.ts +0 -1
- package/dist/utils/encoding/uint8ToBase64.js +0 -15
- package/dist/utils/encoding/uint8ToBase64.js.map +0 -1
- package/dist/utils/fromBase64.d.ts +0 -1
- package/dist/utils/fromBase64.js +0 -7
- package/dist/utils/fromBase64.js.map +0 -1
- package/dist/utils/generateIv.d.ts +0 -1
- package/dist/utils/generateIv.js +0 -12
- package/dist/utils/generateIv.js.map +0 -1
- package/dist/utils/getPeerSignature.d.ts +0 -2
- package/dist/utils/getPeerSignature.js +0 -12
- package/dist/utils/getPeerSignature.js.map +0 -1
- package/dist/utils/getTimestamp.d.ts +0 -1
- package/dist/utils/getTimestamp.js +0 -7
- package/dist/utils/getTimestamp.js.map +0 -1
- package/dist/utils/hexToArrayBuffer.d.ts +0 -1
- package/dist/utils/hexToArrayBuffer.js +0 -15
- package/dist/utils/hexToArrayBuffer.js.map +0 -1
- package/dist/utils/hexToBase64.d.ts +0 -1
- package/dist/utils/hexToBase64.js +0 -12
- package/dist/utils/hexToBase64.js.map +0 -1
- package/dist/utils/hexToString.d.ts +0 -1
- package/dist/utils/hexToString.js +0 -12
- package/dist/utils/hexToString.js.map +0 -1
- package/dist/utils/hexToUint8.d.ts +0 -1
- package/dist/utils/hexToUint8.js +0 -8
- package/dist/utils/hexToUint8.js.map +0 -1
- package/dist/utils/indexedb.d.ts +0 -2
- package/dist/utils/indexedb.js +0 -116
- package/dist/utils/indexedb.js.map +0 -1
- package/dist/utils/leveldb.d.ts +0 -2
- package/dist/utils/leveldb.js +0 -85
- package/dist/utils/leveldb.js.map +0 -1
- package/dist/utils/proofOfWork.d.ts +0 -4
- package/dist/utils/proofOfWork.js +0 -19
- package/dist/utils/proofOfWork.js.map +0 -1
- package/dist/utils/randomAnimal.d.ts +0 -1
- package/dist/utils/randomAnimal.js +0 -77
- package/dist/utils/randomAnimal.js.map +0 -1
- package/dist/utils/sha1.d.ts +0 -1
- package/dist/utils/sha1.js +0 -13
- package/dist/utils/sha1.js.map +0 -1
- package/dist/utils/sha256.d.ts +0 -3
- package/dist/utils/sha256.js +0 -13
- package/dist/utils/sha256.js.map +0 -1
- package/dist/utils/signData.d.ts +0 -1
- package/dist/utils/signData.js +0 -19
- package/dist/utils/signData.js.map +0 -1
- package/dist/utils/stringToArrayBuffer.d.ts +0 -1
- package/dist/utils/stringToArrayBuffer.js +0 -12
- package/dist/utils/stringToArrayBuffer.js.map +0 -1
- package/dist/utils/textRandom.d.ts +0 -1
- package/dist/utils/textRandom.js +0 -15
- package/dist/utils/textRandom.js.map +0 -1
- package/dist/utils/toBase64.d.ts +0 -1
- package/dist/utils/toBase64.js +0 -7
- package/dist/utils/toBase64.js.map +0 -1
- package/dist/utils/uint8ArrayToHex.d.ts +0 -2
- package/dist/utils/uint8ArrayToHex.js +0 -7
- package/dist/utils/uint8ArrayToHex.js.map +0 -1
- package/dist/utils/uint8ToBase64.d.ts +0 -2
- package/dist/utils/uint8ToBase64.js +0 -15
- package/dist/utils/uint8ToBase64.js.map +0 -1
- package/dist/utils/verifyMessage.d.ts +0 -9
- package/dist/utils/verifyMessage.js +0 -129
- package/dist/utils/verifyMessage.js.map +0 -1
- package/dist/utils/verifyPeer.d.ts +0 -3
- package/dist/utils/verifyPeer.js +0 -18
- package/dist/utils/verifyPeer.js.map +0 -1
- package/jest.config.ts +0 -195
- package/jest.setup.js +0 -0
- package/test-alice/000663.ldb +0 -0
- package/test-alice/000665.ldb +0 -0
- package/test-alice/000668.ldb +0 -0
- package/test-alice/000669.log +0 -0
- package/test-alice/CURRENT +0 -1
- package/test-alice/LOCK +0 -0
- package/test-alice/LOG +0 -5
- package/test-alice/LOG.old +0 -5
- package/test-alice/MANIFEST-000667 +0 -0
- package/test-alice-speed/000035.log +0 -0
- package/test-alice-speed/000036.ldb +0 -0
- package/test-alice-speed/CURRENT +0 -1
- package/test-alice-speed/LOCK +0 -0
- package/test-alice-speed/LOG +0 -13
- package/test-alice-speed/LOG.old +0 -5
- package/test-alice-speed/MANIFEST-000033 +0 -0
- package/test-bob/000665.ldb +0 -0
- package/test-bob/000667.ldb +0 -0
- package/test-bob/000668.log +0 -0
- package/test-bob/CURRENT +0 -1
- package/test-bob/LOCK +0 -0
- package/test-bob/LOG +0 -5
- package/test-bob/LOG.old +0 -14
- package/test-bob/MANIFEST-000666 +0 -0
- package/test-node-a/000663.ldb +0 -0
- package/test-node-a/000665.ldb +0 -0
- package/test-node-a/000668.ldb +0 -0
- package/test-node-a/000669.log +0 -0
- package/test-node-a/CURRENT +0 -1
- package/test-node-a/LOCK +0 -0
- package/test-node-a/LOG +0 -5
- package/test-node-a/LOG.old +0 -5
- package/test-node-a/MANIFEST-000667 +0 -0
- package/test-node-b/000663.ldb +0 -0
- package/test-node-b/000665.ldb +0 -0
- package/test-node-b/000668.ldb +0 -0
- package/test-node-b/000669.log +0 -0
- package/test-node-b/CURRENT +0 -1
- package/test-node-b/LOCK +0 -0
- package/test-node-b/LOG +0 -5
- package/test-node-b/LOG.old +0 -5
- package/test-node-b/MANIFEST-000667 +0 -0
- package/test-verify-a/000026.ldb +0 -0
- package/test-verify-a/000029.ldb +0 -0
- package/test-verify-a/000031.ldb +0 -0
- package/test-verify-a/000033.ldb +0 -0
- package/test-verify-a/000250.log +0 -0
- package/test-verify-a/CURRENT +0 -1
- package/test-verify-a/LOCK +0 -0
- package/test-verify-a/LOG +0 -3
- package/test-verify-a/LOG.old +0 -3
- package/test-verify-a/MANIFEST-000249 +0 -0
- package/toolDbLibP2p.ts +0 -206
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { BaseCrdt, CRDT_LIST } from "..";
|
|
2
|
+
|
|
3
|
+
export type ListOperations = "INS" | "DEL";
|
|
4
|
+
|
|
5
|
+
export interface ChangeListBase<T> {
|
|
6
|
+
t: ListOperations; // Operation type
|
|
7
|
+
i: string; // "index", author + n
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export interface InsListChange<T> extends ChangeListBase<T> {
|
|
11
|
+
t: "INS";
|
|
12
|
+
v: T; // Value
|
|
13
|
+
p: string | undefined; // Previous index, if any
|
|
14
|
+
n: string | undefined; // Next index, if any
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export interface DelListChange<T> extends ChangeListBase<T> {
|
|
18
|
+
t: "DEL";
|
|
19
|
+
v: string; // target index to tombstone
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export type ListChanges<T> = InsListChange<T> | DelListChange<T>;
|
|
23
|
+
|
|
24
|
+
interface ListTempCursor<T> {
|
|
25
|
+
value: T;
|
|
26
|
+
index: string;
|
|
27
|
+
tomb: boolean;
|
|
28
|
+
prev: string | undefined;
|
|
29
|
+
next: string | undefined;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export class ListCrdt<T> extends BaseCrdt<T, ListChanges<T>, T[]> {
|
|
33
|
+
public type = CRDT_LIST;
|
|
34
|
+
|
|
35
|
+
public _changes: ListChanges<T>[] = [];
|
|
36
|
+
|
|
37
|
+
private _author = "";
|
|
38
|
+
|
|
39
|
+
private _value: T[] = [];
|
|
40
|
+
|
|
41
|
+
public _tempValues: ListTempCursor<T>[] = [];
|
|
42
|
+
|
|
43
|
+
private _lastUpdateSize: number = 0;
|
|
44
|
+
|
|
45
|
+
constructor(author: string, changes?: ListChanges<T>[]) {
|
|
46
|
+
super();
|
|
47
|
+
this._author = author;
|
|
48
|
+
if (changes) {
|
|
49
|
+
this.mergeChanges(changes);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
this.calculate();
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
changesSort(a: ListChanges<T>, b: ListChanges<T>) {
|
|
56
|
+
if (a.i > b.i) return 1;
|
|
57
|
+
if (a.i < b.i) return -1;
|
|
58
|
+
return 0; // Should never be equal!
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
calculate() {
|
|
62
|
+
const temp: ListTempCursor<T>[] = [];
|
|
63
|
+
// Only update if we have new changes
|
|
64
|
+
if (Object.values(this._changes).length !== this._lastUpdateSize) {
|
|
65
|
+
this._changes.sort(this.changesSort).forEach((change) => {
|
|
66
|
+
if (change.t === "INS") {
|
|
67
|
+
let poisitionToInsert = 0;
|
|
68
|
+
if (change.p) {
|
|
69
|
+
poisitionToInsert = temp.findIndex((v) => v.index === change.p) + 1;
|
|
70
|
+
} else if (change.n) {
|
|
71
|
+
poisitionToInsert = temp.findIndex((v) => v.index === change.n);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
const cursorValue: ListTempCursor<T> = {
|
|
75
|
+
value: change.v,
|
|
76
|
+
index: change.i,
|
|
77
|
+
tomb: false,
|
|
78
|
+
prev: change.p,
|
|
79
|
+
next: change.n,
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
temp.splice(poisitionToInsert, 0, cursorValue);
|
|
83
|
+
} else if (change.t === "DEL") {
|
|
84
|
+
const poisitionToInsert = temp.findIndex((v) => v.index === change.v);
|
|
85
|
+
temp[poisitionToInsert].tomb = true;
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
this._lastUpdateSize = Object.values(temp).length;
|
|
89
|
+
|
|
90
|
+
this._tempValues = temp;
|
|
91
|
+
|
|
92
|
+
this._value = temp.filter((v) => !v.tomb).map((v) => v.value);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
get value(): T[] {
|
|
97
|
+
this.calculate();
|
|
98
|
+
return this._value;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
public mergeChanges(newChanges: ListChanges<T>[]) {
|
|
102
|
+
newChanges.forEach((change) => {
|
|
103
|
+
// Filter by author and index
|
|
104
|
+
const filtered = this._changes.filter(
|
|
105
|
+
(c) => c.i === change.i && c.t === change.t && c.v === change.v
|
|
106
|
+
);
|
|
107
|
+
// Only add if there are not matches
|
|
108
|
+
if (filtered.length === 0) {
|
|
109
|
+
this._changes.push(change);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
this.calculate();
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
public getChanges(): ListChanges<T>[] {
|
|
116
|
+
return this._changes;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
public INS(value: T, index: number) {
|
|
120
|
+
const filterTombs = this._tempValues.filter((v) => !v.tomb);
|
|
121
|
+
|
|
122
|
+
let currentPrev = undefined;
|
|
123
|
+
let currentNext = undefined;
|
|
124
|
+
|
|
125
|
+
if (filterTombs.length !== 0) {
|
|
126
|
+
const currentIndex = filterTombs[index].index;
|
|
127
|
+
const currentIndexPosition = this._tempValues.findIndex(
|
|
128
|
+
(v) => v.index === currentIndex
|
|
129
|
+
);
|
|
130
|
+
currentPrev = this._tempValues[currentIndexPosition - 1];
|
|
131
|
+
currentNext = this._tempValues[currentIndexPosition];
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
const ourChanges = this._changes.filter((c) =>
|
|
135
|
+
c.i.startsWith(this._author)
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
this._changes.push({
|
|
139
|
+
t: "INS",
|
|
140
|
+
p: currentPrev?.index,
|
|
141
|
+
n: currentNext?.index,
|
|
142
|
+
v: value,
|
|
143
|
+
i: this._author + "-" + `${ourChanges.length}`.padStart(8, "0"),
|
|
144
|
+
});
|
|
145
|
+
this.calculate();
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
public PUSH(value: T) {
|
|
149
|
+
const filterTombs = this._tempValues.filter((v) => !v.tomb);
|
|
150
|
+
const currentIndex = filterTombs[filterTombs.length - 1]?.index;
|
|
151
|
+
const currentIndexPosition = this._tempValues.findIndex(
|
|
152
|
+
(v) => v.index === currentIndex
|
|
153
|
+
);
|
|
154
|
+
|
|
155
|
+
const currentPrev = this._tempValues[currentIndexPosition];
|
|
156
|
+
|
|
157
|
+
const ourChanges = this._changes.filter((c) =>
|
|
158
|
+
c.i.startsWith(this._author)
|
|
159
|
+
);
|
|
160
|
+
|
|
161
|
+
this._changes.push({
|
|
162
|
+
t: "INS",
|
|
163
|
+
p: currentPrev?.index,
|
|
164
|
+
n: undefined,
|
|
165
|
+
v: value,
|
|
166
|
+
i: this._author + "-" + `${ourChanges.length}`.padStart(8, "0"),
|
|
167
|
+
});
|
|
168
|
+
this.calculate();
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
public DEL(index: number) {
|
|
172
|
+
const currentIndex = this._tempValues.filter((v) => !v.tomb)[index].index;
|
|
173
|
+
const currentIndexPosition = this._tempValues.findIndex(
|
|
174
|
+
(v) => v.index === currentIndex
|
|
175
|
+
);
|
|
176
|
+
|
|
177
|
+
const current = this._tempValues[currentIndexPosition];
|
|
178
|
+
|
|
179
|
+
const ourChanges = this._changes.filter((c) =>
|
|
180
|
+
c.i.startsWith(this._author)
|
|
181
|
+
);
|
|
182
|
+
|
|
183
|
+
this._changes.push({
|
|
184
|
+
t: "DEL",
|
|
185
|
+
v: current.index,
|
|
186
|
+
i: this._author + "-" + `${ourChanges.length}`.padStart(8, "0"),
|
|
187
|
+
});
|
|
188
|
+
this.calculate();
|
|
189
|
+
}
|
|
190
|
+
}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { BaseCrdt, CRDT_MAP } from "..";
|
|
2
|
+
|
|
3
|
+
export type MapOperations = "SET" | "DEL";
|
|
4
|
+
|
|
5
|
+
export interface ChangeMapBase<T> {
|
|
6
|
+
t: MapOperations;
|
|
7
|
+
a: string;
|
|
8
|
+
k: string;
|
|
9
|
+
i: number;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export interface SetMapChange<T> extends ChangeMapBase<T> {
|
|
13
|
+
t: "SET";
|
|
14
|
+
v: T;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export interface DelMapChange<T> extends ChangeMapBase<T> {
|
|
18
|
+
t: "DEL";
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export type MapChanges<T> = SetMapChange<T> | DelMapChange<T>;
|
|
22
|
+
|
|
23
|
+
export class MapCrdt<T> extends BaseCrdt<T, MapChanges<T>, Record<string, T>> {
|
|
24
|
+
public type = CRDT_MAP;
|
|
25
|
+
|
|
26
|
+
private _changes: MapChanges<T>[] = [];
|
|
27
|
+
|
|
28
|
+
private _author = "";
|
|
29
|
+
|
|
30
|
+
private _value: Record<string, T> = {};
|
|
31
|
+
|
|
32
|
+
private _keyIndex: Record<string, number> = {};
|
|
33
|
+
|
|
34
|
+
private _lastUpdateSize: number = 0;
|
|
35
|
+
|
|
36
|
+
constructor(author: string, changes?: MapChanges<T>[]) {
|
|
37
|
+
super();
|
|
38
|
+
this._author = author;
|
|
39
|
+
if (changes) {
|
|
40
|
+
this.mergeChanges(changes);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
this.calculate();
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
changesSort(a: MapChanges<T>, b: MapChanges<T>) {
|
|
47
|
+
if (a.i < b.i) return -1;
|
|
48
|
+
if (a.i > b.i) return 1;
|
|
49
|
+
if (a.t === "SET" && b.t === "DEL") return -1;
|
|
50
|
+
if (a.t === "DEL" && b.t === "SET") return 1;
|
|
51
|
+
if (a.a < b.a) return -1;
|
|
52
|
+
if (a.a > b.a) return 1;
|
|
53
|
+
return 0; // Should never be equal!
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
calculate() {
|
|
57
|
+
const temp: Record<string, T> = {};
|
|
58
|
+
// Only update if we have new changes
|
|
59
|
+
if (Object.values(this._changes).length !== this._lastUpdateSize) {
|
|
60
|
+
this._changes.sort(this.changesSort).forEach((change) => {
|
|
61
|
+
// Here we apply the model properties
|
|
62
|
+
// Since this is a KV store we dont need much logic,
|
|
63
|
+
// except for the sorting of the changes. Then we just apply them.
|
|
64
|
+
if (change.t === "SET") {
|
|
65
|
+
temp[change.k] = change.v;
|
|
66
|
+
} else if (change.t === "DEL") {
|
|
67
|
+
delete temp[change.k];
|
|
68
|
+
}
|
|
69
|
+
this._keyIndex[change.k] = change.i;
|
|
70
|
+
});
|
|
71
|
+
this._lastUpdateSize = Object.values(temp).length;
|
|
72
|
+
this._value = temp;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
get value(): Record<string, T> {
|
|
77
|
+
this.calculate();
|
|
78
|
+
return this._value;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
public mergeChanges(newChanges: MapChanges<T>[]) {
|
|
82
|
+
newChanges.forEach((change) => {
|
|
83
|
+
// Filter by author and index
|
|
84
|
+
const filtered = this._changes.filter(
|
|
85
|
+
(c) => c.i === change.i && c.a === change.a && c.t === change.t
|
|
86
|
+
);
|
|
87
|
+
// Only add if there are not matches
|
|
88
|
+
if (filtered.length === 0) {
|
|
89
|
+
this._changes.push(change);
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
this.calculate();
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
public getChanges(): MapChanges<T>[] {
|
|
96
|
+
return this._changes;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
public SET(key: string, value: T) {
|
|
100
|
+
this._keyIndex[key] = (this._keyIndex[key] || 0) + 1;
|
|
101
|
+
this._changes.push({
|
|
102
|
+
t: "SET",
|
|
103
|
+
k: key,
|
|
104
|
+
a: this._author,
|
|
105
|
+
v: value,
|
|
106
|
+
i: this._keyIndex[key],
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
public DEL(key: string) {
|
|
111
|
+
this._keyIndex[key] = (this._keyIndex[key] || 0) + 1;
|
|
112
|
+
this._changes.push({
|
|
113
|
+
t: "DEL",
|
|
114
|
+
k: key,
|
|
115
|
+
a: this._author,
|
|
116
|
+
i: this._keyIndex[key],
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
}
|
|
@@ -1,36 +1,35 @@
|
|
|
1
|
-
export * from "./types/tooldb";
|
|
2
|
-
export * from "./types/message";
|
|
3
|
-
export { default as BaseCrdt } from "./crdt/baseCrdt";
|
|
4
|
-
export { default as CounterCrdt } from "./crdt/counterCrdt";
|
|
5
|
-
export { default as ListCrdt } from "./crdt/listCrdt";
|
|
6
|
-
export { default as MapCrdt } from "./crdt/mapCrdt";
|
|
7
1
|
export { default as proofOfWork } from "./utils/proofOfWork";
|
|
8
2
|
export { default as sha1 } from "./utils/sha1";
|
|
9
3
|
export { default as sha256 } from "./utils/sha256";
|
|
10
|
-
export { default as
|
|
4
|
+
export { default as uniq } from "./utils/uniq";
|
|
5
|
+
|
|
11
6
|
export { default as randomAnimal } from "./utils/randomAnimal";
|
|
12
|
-
export { default as textRandom } from "./utils/textRandom";
|
|
13
|
-
export { default as stringToArrayBuffer } from "./utils/encoding/stringToArrayBuffer";
|
|
14
7
|
export { default as verifyMessage } from "./utils/verifyMessage";
|
|
8
|
+
export { default as getPeerSignature } from "./utils/getPeerSignature";
|
|
15
9
|
export { default as verifyPeer } from "./utils/verifyPeer";
|
|
10
|
+
export { default as textRandom } from "./utils/textRandom";
|
|
11
|
+
|
|
12
|
+
export { default as catchReturn } from "./utils/catchReturn";
|
|
13
|
+
|
|
14
|
+
export { default as stringToArrayBuffer } from "./utils/encoding/stringToArrayBuffer";
|
|
16
15
|
export { default as arrayBufferToString } from "./utils/encoding/arrayBufferToString";
|
|
16
|
+
|
|
17
17
|
export { default as arrayBufferToHex } from "./utils/encoding/arrayBufferToHex";
|
|
18
18
|
export { default as hexToArrayBuffer } from "./utils/encoding/hexToArrayBuffer";
|
|
19
19
|
export { default as hexToString } from "./utils/encoding/hexToString";
|
|
20
20
|
export { default as hexToUint8 } from "./utils/encoding/hexToUint8";
|
|
21
|
-
|
|
22
|
-
export { default as
|
|
23
|
-
export { default as
|
|
24
|
-
export { default as
|
|
25
|
-
|
|
26
|
-
export { default as ToolDbWebrtc } from "./toolDbWebrtc";
|
|
21
|
+
|
|
22
|
+
export { default as ToolDbNetworkAdapter } from "./adapters-base/networkAdapter";
|
|
23
|
+
export { default as ToolDbStorageAdapter } from "./adapters-base/storageAdapter";
|
|
24
|
+
export { default as ToolDbUserAdapter } from "./adapters-base/userAdapter";
|
|
25
|
+
|
|
27
26
|
export * from "./types/tooldb";
|
|
28
27
|
export * from "./types/message";
|
|
29
28
|
export * from "./crdt/baseCrdt";
|
|
30
29
|
export * from "./crdt/counterCrdt";
|
|
31
30
|
export * from "./crdt/listCrdt";
|
|
32
31
|
export * from "./crdt/mapCrdt";
|
|
33
|
-
|
|
32
|
+
|
|
34
33
|
export { default as handleSubscribe } from "./messageHandlers/handleSubscribe";
|
|
35
34
|
export { default as handleCrdtGet } from "./messageHandlers/handleCrdtGet";
|
|
36
35
|
export { default as handleCrdtPut } from "./messageHandlers/handleCrdtPut";
|
|
@@ -39,4 +38,5 @@ export { default as handlePing } from "./messageHandlers/handlePing";
|
|
|
39
38
|
export { default as handlePong } from "./messageHandlers/handlePong";
|
|
40
39
|
export { default as handleGet } from "./messageHandlers/handleGet";
|
|
41
40
|
export { default as handlePut } from "./messageHandlers/handlePut";
|
|
41
|
+
|
|
42
42
|
export { default as ToolDb } from "./tooldb";
|
package/lib/logger.ts
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ToolDb, sha1 } from ".";
|
|
2
|
+
|
|
3
|
+
export default function logger(
|
|
4
|
+
this: ToolDb,
|
|
5
|
+
arg0: any,
|
|
6
|
+
arg1?: any,
|
|
7
|
+
arg2?: any,
|
|
8
|
+
arg3?: any,
|
|
9
|
+
arg4?: any,
|
|
10
|
+
arg5?: any
|
|
11
|
+
) {
|
|
12
|
+
if (this.options.debug) {
|
|
13
|
+
const isNode = typeof window === "undefined";
|
|
14
|
+
const title = isNode
|
|
15
|
+
? this.options.storageName
|
|
16
|
+
: "%c" + this.options.storageName;
|
|
17
|
+
|
|
18
|
+
const style = isNode
|
|
19
|
+
? ""
|
|
20
|
+
: "background: #" +
|
|
21
|
+
sha1(this.options.storageName).slice(-6) +
|
|
22
|
+
"; padding: 2px; color: black";
|
|
23
|
+
|
|
24
|
+
console.log(
|
|
25
|
+
title,
|
|
26
|
+
style,
|
|
27
|
+
...[arg0, arg1, arg2, arg3, arg4, arg4, arg5].slice(0, arguments.length)
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ToolDb, CrdtGetMessage, CrdtPutMessage } from "..";
|
|
2
|
+
|
|
3
|
+
export default function handleCrdtGet(
|
|
4
|
+
this: ToolDb,
|
|
5
|
+
message: CrdtGetMessage,
|
|
6
|
+
remotePeerId: string
|
|
7
|
+
) {
|
|
8
|
+
this.store
|
|
9
|
+
.get(message.key)
|
|
10
|
+
.then((data) => {
|
|
11
|
+
try {
|
|
12
|
+
// Use the id of the get so the other client knows we are replying
|
|
13
|
+
const oldData = {
|
|
14
|
+
type: "crdtPut",
|
|
15
|
+
data: JSON.parse(data),
|
|
16
|
+
to: [],
|
|
17
|
+
id: message.id,
|
|
18
|
+
} as CrdtPutMessage;
|
|
19
|
+
this.network.sendToClientId(remotePeerId, oldData);
|
|
20
|
+
} catch (e) {
|
|
21
|
+
// socket.send(data);
|
|
22
|
+
// do nothing
|
|
23
|
+
}
|
|
24
|
+
})
|
|
25
|
+
.catch((e) => {
|
|
26
|
+
this.logger("Local key not found, relay", JSON.stringify(message));
|
|
27
|
+
this.network.sendToAll(message, false);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ToolDb,
|
|
3
|
+
VerifyResult,
|
|
4
|
+
CrdtPutMessage,
|
|
5
|
+
VerificationData,
|
|
6
|
+
MapCrdt,
|
|
7
|
+
MapChanges,
|
|
8
|
+
CRDT_COUNTER,
|
|
9
|
+
CRDT_LIST,
|
|
10
|
+
CRDT_MAP,
|
|
11
|
+
ListCrdt,
|
|
12
|
+
ListChanges,
|
|
13
|
+
CounterCrdt,
|
|
14
|
+
CounterChanges,
|
|
15
|
+
} from "..";
|
|
16
|
+
|
|
17
|
+
import toolDbVerificationWrapper from "../toolDbVerificationWrapper";
|
|
18
|
+
|
|
19
|
+
export default function handleCrdtPut(
|
|
20
|
+
this: ToolDb,
|
|
21
|
+
message: CrdtPutMessage,
|
|
22
|
+
remotePeerId: string
|
|
23
|
+
) {
|
|
24
|
+
toolDbVerificationWrapper.call(this, message.data).then((value) => {
|
|
25
|
+
// this.logger("Verification wrapper result: ", value, message.k);
|
|
26
|
+
if (value === VerifyResult.Verified) {
|
|
27
|
+
this.emit("crdtput", message);
|
|
28
|
+
this.emit("data", message.data);
|
|
29
|
+
this.emit("verified", message);
|
|
30
|
+
// relay to other servers !!!
|
|
31
|
+
this.network.sendToAll(message, true);
|
|
32
|
+
|
|
33
|
+
this.store
|
|
34
|
+
.get(message.data.k)
|
|
35
|
+
.then((oldData) => {
|
|
36
|
+
try {
|
|
37
|
+
const parsedOldData: VerificationData<any> = JSON.parse(oldData);
|
|
38
|
+
|
|
39
|
+
let newMessage = message;
|
|
40
|
+
|
|
41
|
+
// Merge old document with new data incoming and save it
|
|
42
|
+
// Add handles for all kinds of CRDT we add
|
|
43
|
+
let oldDoc:
|
|
44
|
+
| MapCrdt<any>
|
|
45
|
+
| ListCrdt<any>
|
|
46
|
+
| CounterCrdt<any>
|
|
47
|
+
| undefined;
|
|
48
|
+
|
|
49
|
+
if (parsedOldData.c === CRDT_MAP) {
|
|
50
|
+
oldDoc = new MapCrdt(
|
|
51
|
+
this.userAccount.getAddress() || "",
|
|
52
|
+
parsedOldData.v
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (parsedOldData.c === CRDT_LIST) {
|
|
57
|
+
oldDoc = new ListCrdt(
|
|
58
|
+
this.userAccount.getAddress() || "",
|
|
59
|
+
parsedOldData.v
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
if (parsedOldData.c === CRDT_COUNTER) {
|
|
64
|
+
oldDoc = new CounterCrdt(
|
|
65
|
+
this.userAccount.getAddress() || "",
|
|
66
|
+
parsedOldData.v
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
let changesMerged:
|
|
71
|
+
| MapChanges<any>[]
|
|
72
|
+
| ListChanges<any>[]
|
|
73
|
+
| CounterChanges[] = [];
|
|
74
|
+
|
|
75
|
+
if (oldDoc) {
|
|
76
|
+
oldDoc.mergeChanges(message.data.v);
|
|
77
|
+
changesMerged = oldDoc.getChanges();
|
|
78
|
+
}
|
|
79
|
+
newMessage = {
|
|
80
|
+
...message,
|
|
81
|
+
};
|
|
82
|
+
newMessage.data.v = changesMerged;
|
|
83
|
+
|
|
84
|
+
if (parsedOldData.t < message.data.t) {
|
|
85
|
+
const key = newMessage.data.k;
|
|
86
|
+
this.triggerKeyListener(key, newMessage.data);
|
|
87
|
+
this.store
|
|
88
|
+
.put(newMessage.data.k, JSON.stringify(newMessage.data))
|
|
89
|
+
.catch((e) => {
|
|
90
|
+
// do nothing
|
|
91
|
+
});
|
|
92
|
+
} else {
|
|
93
|
+
const key = message.data.k;
|
|
94
|
+
this.triggerKeyListener(key, parsedOldData);
|
|
95
|
+
}
|
|
96
|
+
// } else {
|
|
97
|
+
// this.logger(
|
|
98
|
+
// `${message.k} has old data, but its newer. old ${parsedOldData.t} < new ${message.t}`
|
|
99
|
+
// );
|
|
100
|
+
// }
|
|
101
|
+
} catch (e) {
|
|
102
|
+
this.logger("Couldnt parse crdt data", oldData, e);
|
|
103
|
+
}
|
|
104
|
+
})
|
|
105
|
+
.catch((e) => {
|
|
106
|
+
const key = message.data.k;
|
|
107
|
+
this.triggerKeyListener(key, message.data);
|
|
108
|
+
this.store
|
|
109
|
+
.put(message.data.k, JSON.stringify(message.data))
|
|
110
|
+
.catch((e) => {
|
|
111
|
+
// do nothing
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
} else {
|
|
115
|
+
this.logger("unverified message: ", value, message);
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ToolDb, GetMessage, PutMessage } from "..";
|
|
2
|
+
|
|
3
|
+
export default function handleGet(
|
|
4
|
+
this: ToolDb,
|
|
5
|
+
message: GetMessage,
|
|
6
|
+
remotePeerId: string
|
|
7
|
+
) {
|
|
8
|
+
this.store
|
|
9
|
+
.get(message.key)
|
|
10
|
+
.then((data) => {
|
|
11
|
+
try {
|
|
12
|
+
// Use the id of the get so the other client knows we are replying
|
|
13
|
+
const oldData = {
|
|
14
|
+
type: "put",
|
|
15
|
+
data: JSON.parse(data),
|
|
16
|
+
to: [],
|
|
17
|
+
id: message.id,
|
|
18
|
+
} as PutMessage;
|
|
19
|
+
this.network.sendToClientId(remotePeerId, oldData);
|
|
20
|
+
} catch (e) {
|
|
21
|
+
// socket.send(data);
|
|
22
|
+
// do nothing
|
|
23
|
+
}
|
|
24
|
+
})
|
|
25
|
+
.catch((e) => {
|
|
26
|
+
this.logger("Local key not found, relay", JSON.stringify(message));
|
|
27
|
+
this.network.sendToAll(message, false);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ToolDb, verifyPeer, PingMessage, PongMessage } from "..";
|
|
2
|
+
|
|
3
|
+
export default function handlePing(
|
|
4
|
+
this: ToolDb,
|
|
5
|
+
message: PingMessage,
|
|
6
|
+
remotePeerId: string
|
|
7
|
+
) {
|
|
8
|
+
if (!this.isConnected) {
|
|
9
|
+
this.isConnected = true;
|
|
10
|
+
this.onConnect();
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
verifyPeer(this, message.peer).then((verified) => {
|
|
14
|
+
// Verify integrity and topic
|
|
15
|
+
if (verified && message.peer.topic === this.options.topic) {
|
|
16
|
+
// Add this peer to our list of peers
|
|
17
|
+
const filteredPeers = this.serverPeers.filter(
|
|
18
|
+
(p) => p.address === message.peer.address
|
|
19
|
+
);
|
|
20
|
+
if (filteredPeers.length === 0 && message.isServer) {
|
|
21
|
+
// Add this peer to the list
|
|
22
|
+
this.serverPeers.push(message.peer);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
this.network.sendToClientId(remotePeerId, {
|
|
26
|
+
type: "pong",
|
|
27
|
+
isServer: this.options.server,
|
|
28
|
+
clientId: this.network.getClientAddress(),
|
|
29
|
+
to: [],
|
|
30
|
+
servers: this.serverPeers,
|
|
31
|
+
id: message.id,
|
|
32
|
+
} as PongMessage);
|
|
33
|
+
|
|
34
|
+
this.onPeerConnect(this.peerAccount.getAddress() || "");
|
|
35
|
+
} else {
|
|
36
|
+
this.logger("Blocked a remote peer from joining; ", message);
|
|
37
|
+
// Drop connection here!
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ToolDb, verifyPeer, PongMessage } from "..";
|
|
2
|
+
|
|
3
|
+
export default function handlePong(
|
|
4
|
+
this: ToolDb,
|
|
5
|
+
message: PongMessage,
|
|
6
|
+
remotePeerId: string
|
|
7
|
+
) {
|
|
8
|
+
if (!this.isConnected) {
|
|
9
|
+
this.isConnected = true;
|
|
10
|
+
this.onConnect();
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
message.servers.forEach((peer) => {
|
|
14
|
+
verifyPeer(this, peer).then((verified) => {
|
|
15
|
+
// Verify integrity and topic
|
|
16
|
+
if (verified && peer.topic === this.options.topic) {
|
|
17
|
+
// Add this peer to our list of peers
|
|
18
|
+
const filteredPeers = this.serverPeers.filter(
|
|
19
|
+
(p) => p.address === peer.address
|
|
20
|
+
);
|
|
21
|
+
if (filteredPeers.length === 0 && peer.host && peer.port) {
|
|
22
|
+
// Add this peer to the list
|
|
23
|
+
this.serverPeers.push(peer);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
this.onPeerConnect(this.peerAccount.getAddress() || "");
|
|
30
|
+
}
|