@queenanya/baileys 7.3.7 → 7.4.1
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/LICENSE +21 -0
- package/README.md +931 -0
- package/WAProto/GenerateStatics.sh +4 -0
- package/WAProto/WAProto.proto +3344 -0
- package/WAProto/index.d.ts +37016 -0
- package/WAProto/index.js +101044 -0
- package/WASignalGroup/GroupProtocol.js +1697 -0
- package/WASignalGroup/ciphertext_message.js +16 -0
- package/WASignalGroup/group_cipher.js +120 -0
- package/WASignalGroup/group_session_builder.js +46 -0
- package/WASignalGroup/index.js +5 -0
- package/WASignalGroup/keyhelper.js +21 -0
- package/WASignalGroup/protobufs.js +3 -0
- package/WASignalGroup/queue_job.js +69 -0
- package/WASignalGroup/sender_chain_key.js +50 -0
- package/WASignalGroup/sender_key_distribution_message.js +78 -0
- package/WASignalGroup/sender_key_message.js +92 -0
- package/WASignalGroup/sender_key_name.js +70 -0
- package/WASignalGroup/sender_key_record.js +56 -0
- package/WASignalGroup/sender_key_state.js +129 -0
- package/WASignalGroup/sender_message_key.js +39 -0
- package/lib/Defaults/baileys-version.json +3 -0
- package/lib/Defaults/index.d.ts +53 -0
- package/lib/Defaults/index.js +106 -0
- package/lib/Signal/libsignal.d.ts +3 -0
- package/lib/Signal/libsignal.js +152 -0
- package/lib/Socket/Client/index.d.ts +2 -0
- package/lib/Socket/Client/index.js +18 -0
- package/lib/Socket/Client/types.d.ts +17 -0
- package/lib/Socket/Client/types.js +13 -0
- package/lib/Socket/Client/websocket.d.ts +12 -0
- package/lib/Socket/Client/websocket.js +62 -0
- package/lib/Socket/business.d.ts +177 -0
- package/lib/Socket/business.js +260 -0
- package/lib/Socket/chats.d.ts +91 -0
- package/lib/Socket/chats.js +949 -0
- package/lib/Socket/groups.d.ts +131 -0
- package/lib/Socket/groups.js +314 -0
- package/lib/Socket/index.d.ts +177 -0
- package/lib/Socket/index.js +10 -0
- package/lib/Socket/messages-recv.d.ts +164 -0
- package/lib/Socket/messages-recv.js +918 -0
- package/lib/Socket/messages-send.d.ts +157 -0
- package/lib/Socket/messages-send.js +794 -0
- package/lib/Socket/newsletter.d.ts +143 -0
- package/lib/Socket/newsletter.js +249 -0
- package/lib/Socket/socket.d.ts +45 -0
- package/lib/Socket/socket.js +615 -0
- package/lib/Store/index.d.ts +3 -0
- package/lib/Store/index.js +10 -0
- package/lib/Store/make-cache-manager-store.d.ts +14 -0
- package/lib/Store/make-cache-manager-store.js +83 -0
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +420 -0
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/make-ordered-dictionary.js +81 -0
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Store/object-repository.js +27 -0
- package/lib/Types/Auth.d.ts +105 -0
- package/lib/Types/Auth.js +2 -0
- package/lib/Types/Call.d.ts +13 -0
- package/lib/Types/Call.js +2 -0
- package/lib/Types/Chat.d.ts +107 -0
- package/lib/Types/Chat.js +4 -0
- package/lib/Types/Contact.d.ts +19 -0
- package/lib/Types/Contact.js +2 -0
- package/lib/Types/Events.d.ts +199 -0
- package/lib/Types/Events.js +2 -0
- package/lib/Types/GroupMetadata.d.ts +56 -0
- package/lib/Types/GroupMetadata.js +2 -0
- package/lib/Types/Label.d.ts +46 -0
- package/lib/Types/Label.js +27 -0
- package/lib/Types/LabelAssociation.d.ts +29 -0
- package/lib/Types/LabelAssociation.js +9 -0
- package/lib/Types/Message.d.ts +280 -0
- package/lib/Types/Message.js +9 -0
- package/lib/Types/Newsletter.d.ts +79 -0
- package/lib/Types/Newsletter.js +18 -0
- package/lib/Types/Product.d.ts +78 -0
- package/lib/Types/Product.js +2 -0
- package/lib/Types/Signal.d.ts +57 -0
- package/lib/Types/Signal.js +2 -0
- package/lib/Types/Socket.d.ts +118 -0
- package/lib/Types/Socket.js +2 -0
- package/lib/Types/State.d.ts +27 -0
- package/lib/Types/State.js +2 -0
- package/lib/Types/index.d.ts +65 -0
- package/lib/Types/index.js +42 -0
- package/lib/Utils/auth-utils.d.ts +18 -0
- package/lib/Utils/auth-utils.js +200 -0
- package/lib/Utils/baileys-event-stream.d.ts +16 -0
- package/lib/Utils/baileys-event-stream.js +63 -0
- package/lib/Utils/business.d.ts +22 -0
- package/lib/Utils/business.js +234 -0
- package/lib/Utils/chat-utils.d.ts +72 -0
- package/lib/Utils/chat-utils.js +745 -0
- package/lib/Utils/crypto.d.ts +42 -0
- package/lib/Utils/crypto.js +153 -0
- package/lib/Utils/decode-wa-message.d.ts +20 -0
- package/lib/Utils/decode-wa-message.js +218 -0
- package/lib/Utils/event-buffer.d.ts +35 -0
- package/lib/Utils/event-buffer.js +520 -0
- package/lib/Utils/generics.d.ts +119 -0
- package/lib/Utils/generics.js +467 -0
- package/lib/Utils/history.d.ts +19 -0
- package/lib/Utils/history.js +94 -0
- package/lib/Utils/index.d.ts +17 -0
- package/lib/Utils/index.js +33 -0
- package/lib/Utils/link-preview.d.ts +21 -0
- package/lib/Utils/link-preview.js +116 -0
- package/lib/Utils/logger.d.ts +2 -0
- package/lib/Utils/logger.js +7 -0
- package/lib/Utils/lt-hash.d.ts +12 -0
- package/lib/Utils/lt-hash.js +51 -0
- package/lib/Utils/make-mutex.d.ts +7 -0
- package/lib/Utils/make-mutex.js +44 -0
- package/lib/Utils/messages-media.d.ts +131 -0
- package/lib/Utils/messages-media.js +786 -0
- package/lib/Utils/messages.d.ts +78 -0
- package/lib/Utils/messages.js +767 -0
- package/lib/Utils/noise-handler.d.ts +21 -0
- package/lib/Utils/noise-handler.js +150 -0
- package/lib/Utils/process-message.d.ts +42 -0
- package/lib/Utils/process-message.js +355 -0
- package/lib/Utils/signal.d.ts +32 -0
- package/lib/Utils/signal.js +158 -0
- package/lib/Utils/use-multi-file-auth-state.d.ts +12 -0
- package/lib/Utils/use-multi-file-auth-state.js +94 -0
- package/lib/Utils/validate-connection.d.ts +10 -0
- package/lib/Utils/validate-connection.js +171 -0
- package/lib/WABinary/constants.d.ts +27 -0
- package/lib/WABinary/constants.js +40 -0
- package/lib/WABinary/decode.d.ts +8 -0
- package/lib/WABinary/decode.js +254 -0
- package/lib/WABinary/encode.d.ts +2 -0
- package/lib/WABinary/encode.js +230 -0
- package/lib/WABinary/generic-utils.d.ts +16 -0
- package/lib/WABinary/generic-utils.js +110 -0
- package/lib/WABinary/index.d.ts +5 -0
- package/lib/WABinary/index.js +21 -0
- package/lib/WABinary/jid-utils.d.ts +31 -0
- package/lib/WABinary/jid-utils.js +62 -0
- package/lib/WABinary/types.d.ts +18 -0
- package/lib/WABinary/types.js +2 -0
- package/lib/WAM/BinaryInfo.d.ts +18 -0
- package/lib/WAM/BinaryInfo.js +13 -0
- package/lib/WAM/constants.d.ts +39 -0
- package/lib/WAM/constants.js +15350 -0
- package/lib/WAM/encode.d.ts +4 -0
- package/lib/WAM/encode.js +155 -0
- package/lib/WAM/index.d.ts +3 -0
- package/lib/WAM/index.js +19 -0
- package/lib/index.d.ts +11 -0
- package/lib/index.js +30 -0
- package/package.json +101 -2
- package/.anya-md/.replit +0 -2
- package/.anya-md/.temp/.temp +0 -1
- package/.anya-md/Dockerfile +0 -16
- package/.anya-md/LICENCE +0 -674
- package/.anya-md/README.md +0 -301
- package/.anya-md/app.json +0 -81
- package/.anya-md/config.js +0 -74
- package/.anya-md/heroku.yml +0 -5
- package/.anya-md/index.js +0 -47
- package/.anya-md/koyeb.yaml +0 -14
- package/.anya-md/lib/.dev.js +0 -47
- package/.anya-md/lib/Assets/aliveMedia.mp4 +0 -0
- package/.anya-md/lib/Assets/goodbyeBG.jpg +0 -0
- package/.anya-md/lib/Assets/image_1.jpg +0 -0
- package/.anya-md/lib/Assets/image_2.jpg +0 -0
- package/.anya-md/lib/Assets/menuMedia.mp4 +0 -0
- package/.anya-md/lib/Assets/ownerMentionMp3.mp3 +0 -0
- package/.anya-md/lib/Assets/port.html +0 -36
- package/.anya-md/lib/Assets/reaction/angry/angry108202410.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202412.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202413.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202414.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202415.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202416.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202417.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202418.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202419.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202420.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202421.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202423.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202425.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202426.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202427.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202428.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202429.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202430.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202431.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry108202469.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry10820249.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry11.mp4 +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry12.mp4 +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry14.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry2.mp4 +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry3.mp4 +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry5.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry6.png +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry8.png +0 -0
- package/.anya-md/lib/Assets/reaction/angry/angry9.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused1.png +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused2.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused3.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused4.mp4 +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused5.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused6.webp +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused7.png +0 -0
- package/.anya-md/lib/Assets/reaction/confused/confused8.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry1.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry12.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry13.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry14.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry15.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry16.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry17.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry18.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry19.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry22.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry23.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry5.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/cry/cry9.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/happy/happyrect1.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/no/_pika +0 -1
- package/.anya-md/lib/Assets/reaction/no/no1.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/no/no2.png +0 -0
- package/.anya-md/lib/Assets/reaction/no/no3.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/no/no4.png +0 -0
- package/.anya-md/lib/Assets/reaction/no/no5.png +0 -0
- package/.anya-md/lib/Assets/reaction/no/no6.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/no/no7.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/no/no8.jpg +0 -0
- package/.anya-md/lib/Assets/reaction/no/no9.mp4 +0 -0
- package/.anya-md/lib/Assets/reaction/smug/059e1bdc-e62a-4943-b85e-ea372709f6a7.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/smug/8fda90b3-bc98-4d24-ac10-4402c4e7be93.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/smug/Aqua.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/smug/Karasuma Chitose.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/smug/Smug Face - Fibel Sistine.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/smug/bf8d78ec-4fcc-4ff7-b3c3-91a0c5f22567.jpeg +0 -0
- package/.anya-md/lib/Assets/reaction/smug//330/247/330/255/331/204/330/247/331/213 /330/247/330/250/330/252/330/263/330/247/331/205/331/207 /330/264/330/261/331/212/330/261/331/207/360/237/230/255/360/237/230/255/360/237/230/255.jpeg +0 -0
- package/.anya-md/lib/Assets/verifyIMG.jpg +0 -0
- package/.anya-md/lib/Assets/welcomeGIF.mp4 +0 -0
- package/.anya-md/lib/database/categories.json +0 -77
- package/.anya-md/lib/database/cooldown.json +0 -1
- package/.anya-md/lib/database/disk/main.js +0 -43
- package/.anya-md/lib/database/emoji.js +0 -23
- package/.anya-md/lib/database/games/quiz/Questions.js +0 -44
- package/.anya-md/lib/database/games/quiz/Quiz.js +0 -169
- package/.anya-md/lib/database/games/quiz/database.json +0 -1
- package/.anya-md/lib/database/games/quiz/index.js +0 -7
- package/.anya-md/lib/database/json/.pika.js +0 -3
- package/.anya-md/lib/database/json/animeQuotes.json +0 -51062
- package/.anya-md/lib/database/json/bioQuotes.json +0 -5744
- package/.anya-md/lib/database/json/cogan.json +0 -102
- package/.anya-md/lib/database/json/countries.json +0 -21210
- package/.anya-md/lib/database/json/countries2.json +0 -1
- package/.anya-md/lib/database/json/couplepp.json +0 -725
- package/.anya-md/lib/database/json/flaming.json +0 -7
- package/.anya-md/lib/database/json/ganpati.json +0 -102
- package/.anya-md/lib/database/json/husbu.json +0 -1967
- package/.anya-md/lib/database/json/islamicWall.json +0 -501
- package/.anya-md/lib/database/json/pickupLines.json +0 -118
- package/.anya-md/lib/database/json/shreeram.json +0 -49
- package/.anya-md/lib/database/json/truthDare.json +0 -643
- package/.anya-md/lib/database/mongodb/README.md +0 -142
- package/.anya-md/lib/database/mongodb/bot.js +0 -12
- package/.anya-md/lib/database/mongodb/cmd.js +0 -17
- package/.anya-md/lib/database/mongodb/group.js +0 -22
- package/.anya-md/lib/database/mongodb/index.js +0 -24
- package/.anya-md/lib/database/mongodb/plugins.js +0 -124
- package/.anya-md/lib/database/mongodb/system.js +0 -34
- package/.anya-md/lib/database/mongodb/ui.js +0 -15
- package/.anya-md/lib/database/mongodb/user.js +0 -17
- package/.anya-md/lib/database/mongodb/warn.js +0 -136
- package/.anya-md/lib/database/sessions/.pika.js +0 -3
- package/.anya-md/lib/frameworks/index.js +0 -5
- package/.anya-md/lib/frameworks/reactionMedia.js +0 -91
- package/.anya-md/lib/lib/README.md +0 -29
- package/.anya-md/lib/lib/ai/README.md +0 -35
- package/.anya-md/lib/lib/ai/aiArt.js +0 -47
- package/.anya-md/lib/lib/ai/index.js +0 -7
- package/.anya-md/lib/lib/buttons.js +0 -530
- package/.anya-md/lib/lib/connectionMsg.js +0 -72
- package/.anya-md/lib/lib/converter.js +0 -355
- package/.anya-md/lib/lib/cooldown.js +0 -46
- package/.anya-md/lib/lib/events.js +0 -47
- package/.anya-md/lib/lib/functions.js +0 -47
- package/.anya-md/lib/lib/greeting.js +0 -115
- package/.anya-md/lib/lib/index.js +0 -381
- package/.anya-md/lib/lib/logger.js +0 -7
- package/.anya-md/lib/lib/maker/remini.js +0 -35
- package/.anya-md/lib/lib/mongoUrlFix.js +0 -46
- package/.anya-md/lib/lib/myfunc.js +0 -47
- package/.anya-md/lib/lib/plugins.js +0 -20
- package/.anya-md/lib/lib/prefix.js +0 -47
- package/.anya-md/lib/lib/scraper/README.md +0 -35
- package/.anya-md/lib/lib/scraper/SoundCloud.js +0 -47
- package/.anya-md/lib/lib/scraper/WebToons.js +0 -47
- package/.anya-md/lib/lib/scraper/android1.js +0 -47
- package/.anya-md/lib/lib/scraper/happymodSearch.js +0 -47
- package/.anya-md/lib/lib/scraper/index.js +0 -27
- package/.anya-md/lib/lib/scraper/konaChanSearch.js +0 -47
- package/.anya-md/lib/lib/scraper/pinterest.js +0 -47
- package/.anya-md/lib/lib/scraper/playstore.js +0 -47
- package/.anya-md/lib/lib/scraper/ringtone.js +0 -47
- package/.anya-md/lib/lib/scraper/steam.js +0 -47
- package/.anya-md/lib/lib/scraper/trendingTwitter.js +0 -51
- package/.anya-md/lib/lib/scraper/wattpad.js +0 -61
- package/.anya-md/lib/lib/scraper/wikipediaSearch.js +0 -42
- package/.anya-md/lib/lib/scraper.js +0 -47
- package/.anya-md/lib/lib/session.js +0 -47
- package/.anya-md/lib/lib/session2.js +0 -47
- package/.anya-md/lib/lib/similar.js +0 -47
- package/.anya-md/lib/lib/stylish-font.js +0 -2302
- package/.anya-md/lib/lib/unicode.js +0 -877
- package/.anya-md/lib/lib/upload/index.js +0 -3
- package/.anya-md/lib/lib/upload/webp2mp4File.js +0 -56
- package/.anya-md/lib/lib/ytdl-core.js +0 -47
- package/.anya-md/lib/plugins/README.md +0 -83
- package/.anya-md/lib/plugins/_menu.js +0 -810
- package/.anya-md/lib/plugins/_plugins.js +0 -239
- package/.anya-md/lib/plugins/admins.js +0 -689
- package/.anya-md/lib/plugins/ai.js +0 -160
- package/.anya-md/lib/plugins/autoreply.js +0 -101
- package/.anya-md/lib/plugins/broadcast.js +0 -204
- package/.anya-md/lib/plugins/convert.js +0 -293
- package/.anya-md/lib/plugins/core.js +0 -941
- package/.anya-md/lib/plugins/download.js +0 -373
- package/.anya-md/lib/plugins/fun.js +0 -75
- package/.anya-md/lib/plugins/games.js +0 -33
- package/.anya-md/lib/plugins/gcswitches.js +0 -204
- package/.anya-md/lib/plugins/general.js +0 -456
- package/.anya-md/lib/plugins/maker.js +0 -41
- package/.anya-md/lib/plugins/owner.js +0 -1049
- package/.anya-md/lib/plugins/religious.js +0 -81
- package/.anya-md/lib/plugins/search.js +0 -902
- package/.anya-md/lib/plugins/stalker.js +0 -187
- package/.anya-md/lib/plugins/sticker.js +0 -125
- package/.anya-md/lib/plugins/tools.js +0 -193
- package/.anya-md/lib/plugins/youtube.js +0 -204
- package/.anya-md/package.json +0 -75
- package/.anya-md/railway.json +0 -12
- package/.anya-md/render.yaml +0 -48
- package/.anya-md/replit.nix +0 -18
- package/.bash_history +0 -500
- package/.config/gh/config.yml +0 -19
- package/.config/gh/hosts.yml +0 -11
- package/.config/ngrok/ngrok.yml +0 -3
- package/.config/yarn/global/package.json +0 -5
- package/.gitconfig +0 -772
- package/.node_repl_history +0 -0
- package/.npm/_cacache/content-v2/sha512/02/b3/d1abf5af06222f7de440ab1b057deb21f9dfb0ce0a8f5064b2ba00595933bbcbbaa040b4616f951d9f8ba48d67491df1198a4831fbd8ee26eb27dde36511 +0 -0
- package/.npm/_cacache/content-v2/sha512/49/7b/0cdbb4861f7c9358a7367ca478498371b269efb8143d75de901ed1169a267f56a68e60f008952f3ebcc727dbb60bb401011af3514a1dd33cdbed8d981fa8 +0 -0
- package/.npm/_cacache/content-v2/sha512/54/3a/647bceb49b7632e6e700cb9f1b66f0f528d4ca71f4f73e76a1e7c8c50b563a2d0bb7734c18f93e6c03b7ea93167db35db0e1999ab13b08ed6b250eed2d2a +0 -1
- package/.npm/_cacache/content-v2/sha512/56/7c/4d5820233a7278225351642f7355d9889af42e7efbbfe27d6b201727efad972a59fa32063c7e1159d01dbf27ba014095ca1349ec0d0767746c39441178fa +0 -1
- package/.npm/_cacache/content-v2/sha512/89/88/d295c7e4f4d0f4621676d4c499bea2a1c72b0c31a84ff78a8bb8f83042da2bcf596e664c021d21025b296cdd4aecb57a036ea366e39466df5a129fa471df +0 -0
- package/.npm/_cacache/content-v2/sha512/8b/46/42882ebb46a975b0ce6b9cdea357190c41b51bb59a21df41c575418850b28115921e130709846d8ff9cabeae72544ec37a48ee7ccb074fe94da925250e55 +0 -1
- package/.npm/_cacache/content-v2/sha512/dd/0d/f856b793da0619d18260556498dfff13391593abb6d6a582bf052f03ba35a03a1444bf5c2d40b7515d268ec2cb3e67a17a42f09f5e668c3bb9b743e3b8a7 +0 -1
- package/.npm/_cacache/content-v2/sha512/dd/15/702501c36ce653a003d2b101034a0cb9c0fd262fa77797f1a286a161a0b2dce51ef13199e9a3fa58008bdbbf4646a33b6f1a24a2807691093cb89beefb00 +0 -1
- package/.npm/_cacache/index-v5/35/f9/e8cc076ef93c1bc40804d3fe05171053366095c922f515b1fab2b580116f +0 -4
- package/.npm/_cacache/index-v5/6a/a2/780c77f928115d4dad58a9dc4fa241de8d914abfff994e44602cc93a697c +0 -2
- package/.npm/_cacache/index-v5/71/ba/d0bb16fddeb617bbbb3713f46750d1bf5b57742abb6feb6dee4d16c68da4 +0 -4
- package/.npm/_cacache/index-v5/72/ae/c69532318093b3bd13618450ca5c26adc018a4afc0e020786207068593cf +0 -2
- package/.npm/_cacache/index-v5/7e/5e/9683ad4854f4201d7e53bf9beb2aefafa7b1efbb2c6ac7b36b78d0b218c8 +0 -2
- package/.npm/_cacache/index-v5/eb/a0/19e529094c594367a9e1aa68096a313d3dc5509d410761bf50122826a6d2 +0 -4
- package/.npm/_cacache/index-v5/f1/fa/2d2f12de549683d1275ec0f2ff15610b408fd89d1b7a755ddb7b77c00371 +0 -2
- package/.npm/_logs/2024-10-03T05_52_01_853Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-03T05_52_08_135Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-03T05_52_14_087Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-03T05_52_22_730Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-03T05_52_29_410Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-03T05_52_35_375Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-03T15_32_57_465Z-debug-0.log +0 -20
- package/.npm/_logs/2024-10-10T05_40_23_847Z-debug-0.log +0 -254
- package/.npm/_logs/2024-10-10T05_40_50_397Z-debug-0.log +0 -73
- package/.npm/_logs/2024-10-10T05_40_59_931Z-debug-0.log +0 -52
- package/.npm/_logs/2024-10-10T05_42_07_969Z-debug-0.log +0 -52
- package/.pm2/logs/anya-error.log +0 -0
- package/.pm2/logs/anya-out.log +0 -59
- package/.pm2/logs/anya-v2-error.log +0 -2184
- package/.pm2/logs/anya-v2-out.log +0 -362
- package/.pm2/module_conf.json +0 -1
- package/.pm2/pm2.log +0 -919
- package/.pm2/pm2.pid +0 -1
- package/.pm2/touch +0 -1
- package/.ssh/authorized_keys +0 -0
- package/.termux/termux.properties +0 -180
- package/.wget-hsts +0 -5
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
class CiphertextMessage {
|
|
2
|
+
UNSUPPORTED_VERSION = 1;
|
|
3
|
+
|
|
4
|
+
CURRENT_VERSION = 3;
|
|
5
|
+
|
|
6
|
+
WHISPER_TYPE = 2;
|
|
7
|
+
|
|
8
|
+
PREKEY_TYPE = 3;
|
|
9
|
+
|
|
10
|
+
SENDERKEY_TYPE = 4;
|
|
11
|
+
|
|
12
|
+
SENDERKEY_DISTRIBUTION_TYPE = 5;
|
|
13
|
+
|
|
14
|
+
ENCRYPTED_MESSAGE_OVERHEAD = 53;
|
|
15
|
+
}
|
|
16
|
+
module.exports = CiphertextMessage;
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
const queue_job = require('./queue_job');
|
|
2
|
+
const SenderKeyMessage = require('./sender_key_message');
|
|
3
|
+
const crypto = require('libsignal/src/crypto');
|
|
4
|
+
|
|
5
|
+
class GroupCipher {
|
|
6
|
+
constructor(senderKeyStore, senderKeyName) {
|
|
7
|
+
this.senderKeyStore = senderKeyStore;
|
|
8
|
+
this.senderKeyName = senderKeyName;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
queueJob(awaitable) {
|
|
12
|
+
return queue_job(this.senderKeyName.toString(), awaitable)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
async encrypt(paddedPlaintext) {
|
|
16
|
+
return await this.queueJob(async () => {
|
|
17
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
18
|
+
if (!record) {
|
|
19
|
+
throw new Error("No SenderKeyRecord found for encryption")
|
|
20
|
+
}
|
|
21
|
+
const senderKeyState = record.getSenderKeyState();
|
|
22
|
+
if (!senderKeyState) {
|
|
23
|
+
throw new Error("No session to encrypt message");
|
|
24
|
+
}
|
|
25
|
+
const iteration = senderKeyState.getSenderChainKey().getIteration()
|
|
26
|
+
const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1)
|
|
27
|
+
|
|
28
|
+
const ciphertext = await this.getCipherText(
|
|
29
|
+
senderKey.getIv(),
|
|
30
|
+
senderKey.getCipherKey(),
|
|
31
|
+
paddedPlaintext
|
|
32
|
+
);
|
|
33
|
+
|
|
34
|
+
const senderKeyMessage = new SenderKeyMessage(
|
|
35
|
+
senderKeyState.getKeyId(),
|
|
36
|
+
senderKey.getIteration(),
|
|
37
|
+
ciphertext,
|
|
38
|
+
senderKeyState.getSigningKeyPrivate()
|
|
39
|
+
);
|
|
40
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
41
|
+
return senderKeyMessage.serialize()
|
|
42
|
+
})
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
async decrypt(senderKeyMessageBytes) {
|
|
46
|
+
return await this.queueJob(async () => {
|
|
47
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
48
|
+
if (!record) {
|
|
49
|
+
throw new Error("No SenderKeyRecord found for decryption")
|
|
50
|
+
}
|
|
51
|
+
const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
|
|
52
|
+
const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
|
|
53
|
+
if (!senderKeyState) {
|
|
54
|
+
throw new Error("No session found to decrypt message")
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
|
|
58
|
+
const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
|
|
59
|
+
// senderKeyState.senderKeyStateStructure.senderSigningKey.private =
|
|
60
|
+
|
|
61
|
+
const plaintext = await this.getPlainText(
|
|
62
|
+
senderKey.getIv(),
|
|
63
|
+
senderKey.getCipherKey(),
|
|
64
|
+
senderKeyMessage.getCipherText()
|
|
65
|
+
);
|
|
66
|
+
|
|
67
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
68
|
+
|
|
69
|
+
return plaintext;
|
|
70
|
+
})
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
getSenderKey(senderKeyState, iteration) {
|
|
74
|
+
let senderChainKey = senderKeyState.getSenderChainKey();
|
|
75
|
+
if (senderChainKey.getIteration() > iteration) {
|
|
76
|
+
if (senderKeyState.hasSenderMessageKey(iteration)) {
|
|
77
|
+
return senderKeyState.removeSenderMessageKey(iteration);
|
|
78
|
+
}
|
|
79
|
+
throw new Error(
|
|
80
|
+
`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
if (iteration - senderChainKey.getIteration() > 2000) {
|
|
85
|
+
throw new Error('Over 2000 messages into the future!');
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
while (senderChainKey.getIteration() < iteration) {
|
|
89
|
+
senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
|
|
90
|
+
senderChainKey = senderChainKey.getNext();
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
senderKeyState.setSenderChainKey(senderChainKey.getNext());
|
|
94
|
+
return senderChainKey.getSenderMessageKey();
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
getPlainText(iv, key, ciphertext) {
|
|
98
|
+
try {
|
|
99
|
+
const plaintext = crypto.decrypt(key, ciphertext, iv);
|
|
100
|
+
return plaintext;
|
|
101
|
+
} catch (e) {
|
|
102
|
+
//console.log(e.stack);
|
|
103
|
+
throw new Error('InvalidMessageException');
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
getCipherText(iv, key, plaintext) {
|
|
108
|
+
try {
|
|
109
|
+
iv = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
|
|
110
|
+
key = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
|
|
111
|
+
const crypted = crypto.encrypt(key, Buffer.from(plaintext), iv);
|
|
112
|
+
return crypted;
|
|
113
|
+
} catch (e) {
|
|
114
|
+
//console.log(e.stack);
|
|
115
|
+
throw new Error('InvalidMessageException');
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
module.exports = GroupCipher;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
//const utils = require('../../common/utils');
|
|
2
|
+
const SenderKeyDistributionMessage = require('./sender_key_distribution_message');
|
|
3
|
+
|
|
4
|
+
const keyhelper = require("./keyhelper");
|
|
5
|
+
class GroupSessionBuilder {
|
|
6
|
+
constructor(senderKeyStore) {
|
|
7
|
+
this.senderKeyStore = senderKeyStore;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
async process(senderKeyName, senderKeyDistributionMessage) {
|
|
11
|
+
//console.log('GroupSessionBuilder process', senderKeyName, senderKeyDistributionMessage);
|
|
12
|
+
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
|
|
13
|
+
senderKeyRecord.addSenderKeyState(
|
|
14
|
+
senderKeyDistributionMessage.getId(),
|
|
15
|
+
senderKeyDistributionMessage.getIteration(),
|
|
16
|
+
senderKeyDistributionMessage.getChainKey(),
|
|
17
|
+
senderKeyDistributionMessage.getSignatureKey()
|
|
18
|
+
);
|
|
19
|
+
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// [{"senderKeyId":1742199468,"senderChainKey":{"iteration":0,"seed":"yxMY9VFQcXEP34olRAcGCtsgx1XoKsHfDIh+1ea4HAQ="},"senderSigningKey":{"public":""}}]
|
|
23
|
+
async create(senderKeyName) {
|
|
24
|
+
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
|
|
25
|
+
//console.log('GroupSessionBuilder create session', senderKeyName, senderKeyRecord);
|
|
26
|
+
|
|
27
|
+
if (senderKeyRecord.isEmpty()) {
|
|
28
|
+
const keyId = keyhelper.generateSenderKeyId();
|
|
29
|
+
const senderKey = keyhelper.generateSenderKey();
|
|
30
|
+
const signingKey = keyhelper.generateSenderSigningKey();
|
|
31
|
+
|
|
32
|
+
senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey);
|
|
33
|
+
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const state = senderKeyRecord.getSenderKeyState();
|
|
37
|
+
|
|
38
|
+
return new SenderKeyDistributionMessage(
|
|
39
|
+
state.getKeyId(),
|
|
40
|
+
state.getSenderChainKey().getIteration(),
|
|
41
|
+
state.getSenderChainKey().getSeed(),
|
|
42
|
+
state.getSigningKeyPublic()
|
|
43
|
+
);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
module.exports = GroupSessionBuilder;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
module.exports.GroupSessionBuilder = require('./group_session_builder')
|
|
2
|
+
module.exports.SenderKeyDistributionMessage = require('./sender_key_distribution_message')
|
|
3
|
+
module.exports.SenderKeyRecord = require('./sender_key_record')
|
|
4
|
+
module.exports.SenderKeyName = require('./sender_key_name')
|
|
5
|
+
module.exports.GroupCipher = require('./group_cipher')
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
const curve = require('libsignal/src/curve');
|
|
2
|
+
const nodeCrypto = require('crypto');
|
|
3
|
+
|
|
4
|
+
exports.generateSenderKey = function() {
|
|
5
|
+
return nodeCrypto.randomBytes(32);
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
exports.generateSenderKeyId = function() {
|
|
9
|
+
return nodeCrypto.randomInt(2147483647);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
exports.generateSenderSigningKey = function(key) {
|
|
13
|
+
if (!key) {
|
|
14
|
+
key = curve.generateKeyPair();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return {
|
|
18
|
+
public: key.pubKey,
|
|
19
|
+
private: key.privKey,
|
|
20
|
+
};
|
|
21
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
// vim: ts=4:sw=4:expandtab
|
|
2
|
+
|
|
3
|
+
/*
|
|
4
|
+
* jobQueue manages multiple queues indexed by device to serialize
|
|
5
|
+
* session io ops on the database.
|
|
6
|
+
*/
|
|
7
|
+
'use strict';
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
const _queueAsyncBuckets = new Map();
|
|
11
|
+
const _gcLimit = 10000;
|
|
12
|
+
|
|
13
|
+
async function _asyncQueueExecutor(queue, cleanup) {
|
|
14
|
+
let offt = 0;
|
|
15
|
+
while (true) {
|
|
16
|
+
let limit = Math.min(queue.length, _gcLimit); // Break up thundering hurds for GC duty.
|
|
17
|
+
for (let i = offt; i < limit; i++) {
|
|
18
|
+
const job = queue[i];
|
|
19
|
+
try {
|
|
20
|
+
job.resolve(await job.awaitable());
|
|
21
|
+
} catch (e) {
|
|
22
|
+
job.reject(e);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
if (limit < queue.length) {
|
|
26
|
+
/* Perform lazy GC of queue for faster iteration. */
|
|
27
|
+
if (limit >= _gcLimit) {
|
|
28
|
+
queue.splice(0, limit);
|
|
29
|
+
offt = 0;
|
|
30
|
+
} else {
|
|
31
|
+
offt = limit;
|
|
32
|
+
}
|
|
33
|
+
} else {
|
|
34
|
+
break;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
cleanup();
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
module.exports = function (bucket, awaitable) {
|
|
41
|
+
/* Run the async awaitable only when all other async calls registered
|
|
42
|
+
* here have completed (or thrown). The bucket argument is a hashable
|
|
43
|
+
* key representing the task queue to use. */
|
|
44
|
+
if (!awaitable.name) {
|
|
45
|
+
// Make debuging easier by adding a name to this function.
|
|
46
|
+
Object.defineProperty(awaitable, 'name', { writable: true });
|
|
47
|
+
if (typeof bucket === 'string') {
|
|
48
|
+
awaitable.name = bucket;
|
|
49
|
+
} else {
|
|
50
|
+
console.warn("Unhandled bucket type (for naming):", typeof bucket, bucket);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
let inactive;
|
|
54
|
+
if (!_queueAsyncBuckets.has(bucket)) {
|
|
55
|
+
_queueAsyncBuckets.set(bucket, []);
|
|
56
|
+
inactive = true;
|
|
57
|
+
}
|
|
58
|
+
const queue = _queueAsyncBuckets.get(bucket);
|
|
59
|
+
const job = new Promise((resolve, reject) => queue.push({
|
|
60
|
+
awaitable,
|
|
61
|
+
resolve,
|
|
62
|
+
reject
|
|
63
|
+
}));
|
|
64
|
+
if (inactive) {
|
|
65
|
+
/* An executor is not currently active; Start one now. */
|
|
66
|
+
_asyncQueueExecutor(queue, () => _queueAsyncBuckets.delete(bucket));
|
|
67
|
+
}
|
|
68
|
+
return job;
|
|
69
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
const SenderMessageKey = require('./sender_message_key');
|
|
2
|
+
//const HKDF = require('./hkdf');
|
|
3
|
+
const crypto = require('libsignal/src/crypto');
|
|
4
|
+
|
|
5
|
+
class SenderChainKey {
|
|
6
|
+
MESSAGE_KEY_SEED = Buffer.from([0x01]);
|
|
7
|
+
|
|
8
|
+
CHAIN_KEY_SEED = Buffer.from([0x02]);
|
|
9
|
+
|
|
10
|
+
iteration = 0;
|
|
11
|
+
|
|
12
|
+
chainKey = Buffer.alloc(0);
|
|
13
|
+
|
|
14
|
+
constructor(iteration, chainKey) {
|
|
15
|
+
this.iteration = iteration;
|
|
16
|
+
this.chainKey = chainKey;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
getIteration() {
|
|
20
|
+
return this.iteration;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
getSenderMessageKey() {
|
|
24
|
+
return new SenderMessageKey(
|
|
25
|
+
this.iteration,
|
|
26
|
+
this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey)
|
|
27
|
+
);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
getNext() {
|
|
31
|
+
return new SenderChainKey(
|
|
32
|
+
this.iteration + 1,
|
|
33
|
+
this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey)
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
getSeed() {
|
|
38
|
+
return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
getDerivative(seed, key) {
|
|
42
|
+
key = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
|
|
43
|
+
const hash = crypto.calculateMAC(key, seed);
|
|
44
|
+
//const hash = new Hash().hmac_hash(key, seed, 'sha256', '');
|
|
45
|
+
|
|
46
|
+
return hash;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
module.exports = SenderChainKey;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
const CiphertextMessage = require('./ciphertext_message');
|
|
2
|
+
const protobufs = require('./protobufs');
|
|
3
|
+
|
|
4
|
+
class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
5
|
+
constructor(
|
|
6
|
+
id = null,
|
|
7
|
+
iteration = null,
|
|
8
|
+
chainKey = null,
|
|
9
|
+
signatureKey = null,
|
|
10
|
+
serialized = null
|
|
11
|
+
) {
|
|
12
|
+
super();
|
|
13
|
+
if (serialized) {
|
|
14
|
+
try {
|
|
15
|
+
const version = serialized[0];
|
|
16
|
+
const message = serialized.slice(1);
|
|
17
|
+
|
|
18
|
+
const distributionMessage = protobufs.SenderKeyDistributionMessage.decode(
|
|
19
|
+
message
|
|
20
|
+
).toJSON();
|
|
21
|
+
this.serialized = serialized;
|
|
22
|
+
this.id = distributionMessage.id;
|
|
23
|
+
this.iteration = distributionMessage.iteration;
|
|
24
|
+
this.chainKey = distributionMessage.chainKey;
|
|
25
|
+
this.signatureKey = distributionMessage.signingKey;
|
|
26
|
+
} catch (e) {
|
|
27
|
+
throw new Error(e);
|
|
28
|
+
}
|
|
29
|
+
} else {
|
|
30
|
+
const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
|
|
31
|
+
this.id = id;
|
|
32
|
+
this.iteration = iteration;
|
|
33
|
+
this.chainKey = chainKey;
|
|
34
|
+
this.signatureKey = signatureKey;
|
|
35
|
+
const message = protobufs.SenderKeyDistributionMessage.encode(
|
|
36
|
+
protobufs.SenderKeyDistributionMessage.create({
|
|
37
|
+
id,
|
|
38
|
+
iteration,
|
|
39
|
+
chainKey,
|
|
40
|
+
signingKey: this.signatureKey,
|
|
41
|
+
})
|
|
42
|
+
).finish();
|
|
43
|
+
this.serialized = Buffer.concat([Buffer.from([version]), message]);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
intsToByteHighAndLow(highValue, lowValue) {
|
|
48
|
+
return (((highValue << 4) | lowValue) & 0xff) % 256;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
serialize() {
|
|
52
|
+
return this.serialized;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
getType() {
|
|
56
|
+
return this.SENDERKEY_DISTRIBUTION_TYPE;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
getIteration() {
|
|
60
|
+
return this.iteration;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
getChainKey() {
|
|
64
|
+
return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
getSignatureKey() {
|
|
68
|
+
return typeof this.signatureKey === 'string'
|
|
69
|
+
? Buffer.from(this.signatureKey, 'base64')
|
|
70
|
+
: this.signatureKey;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
getId() {
|
|
74
|
+
return this.id;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
module.exports = SenderKeyDistributionMessage;
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
const CiphertextMessage = require('./ciphertext_message');
|
|
2
|
+
const curve = require('libsignal/src/curve');
|
|
3
|
+
const protobufs = require('./protobufs');
|
|
4
|
+
|
|
5
|
+
class SenderKeyMessage extends CiphertextMessage {
|
|
6
|
+
SIGNATURE_LENGTH = 64;
|
|
7
|
+
|
|
8
|
+
constructor(
|
|
9
|
+
keyId = null,
|
|
10
|
+
iteration = null,
|
|
11
|
+
ciphertext = null,
|
|
12
|
+
signatureKey = null,
|
|
13
|
+
serialized = null
|
|
14
|
+
) {
|
|
15
|
+
super();
|
|
16
|
+
if (serialized) {
|
|
17
|
+
const version = serialized[0];
|
|
18
|
+
const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
|
|
19
|
+
const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
|
|
20
|
+
const senderKeyMessage = protobufs.SenderKeyMessage.decode(message).toJSON();
|
|
21
|
+
senderKeyMessage.ciphertext = Buffer.from(senderKeyMessage.ciphertext, 'base64');
|
|
22
|
+
|
|
23
|
+
this.serialized = serialized;
|
|
24
|
+
this.messageVersion = (version & 0xff) >> 4;
|
|
25
|
+
|
|
26
|
+
this.keyId = senderKeyMessage.id;
|
|
27
|
+
this.iteration = senderKeyMessage.iteration;
|
|
28
|
+
this.ciphertext = senderKeyMessage.ciphertext;
|
|
29
|
+
this.signature = signature;
|
|
30
|
+
} else {
|
|
31
|
+
const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
|
|
32
|
+
ciphertext = Buffer.from(ciphertext); // .toString('base64');
|
|
33
|
+
const message = protobufs.SenderKeyMessage.encode(
|
|
34
|
+
protobufs.SenderKeyMessage.create({
|
|
35
|
+
id: keyId,
|
|
36
|
+
iteration,
|
|
37
|
+
ciphertext,
|
|
38
|
+
})
|
|
39
|
+
).finish();
|
|
40
|
+
|
|
41
|
+
const signature = this.getSignature(
|
|
42
|
+
signatureKey,
|
|
43
|
+
Buffer.concat([Buffer.from([version]), message])
|
|
44
|
+
);
|
|
45
|
+
this.serialized = Buffer.concat([Buffer.from([version]), message, Buffer.from(signature)]);
|
|
46
|
+
this.messageVersion = this.CURRENT_VERSION;
|
|
47
|
+
this.keyId = keyId;
|
|
48
|
+
this.iteration = iteration;
|
|
49
|
+
this.ciphertext = ciphertext;
|
|
50
|
+
this.signature = signature;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
getKeyId() {
|
|
55
|
+
return this.keyId;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
getIteration() {
|
|
59
|
+
return this.iteration;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
getCipherText() {
|
|
63
|
+
return this.ciphertext;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
verifySignature(signatureKey) {
|
|
67
|
+
const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
|
|
68
|
+
const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
|
|
69
|
+
const res = curve.verifySignature(signatureKey, part1, part2);
|
|
70
|
+
if (!res) throw new Error('Invalid signature!');
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
getSignature(signatureKey, serialized) {
|
|
74
|
+
const signature = Buffer.from(
|
|
75
|
+
curve.calculateSignature(
|
|
76
|
+
signatureKey,
|
|
77
|
+
serialized
|
|
78
|
+
)
|
|
79
|
+
);
|
|
80
|
+
return signature;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
serialize() {
|
|
84
|
+
return this.serialized;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
getType() {
|
|
88
|
+
return 4;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
module.exports = SenderKeyMessage;
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
function isNull(str) {
|
|
2
|
+
return str === null || str.value === '';
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* java String hashCode 的实现
|
|
7
|
+
* @param strKey
|
|
8
|
+
* @return intValue
|
|
9
|
+
*/
|
|
10
|
+
function intValue(num) {
|
|
11
|
+
const MAX_VALUE = 0x7fffffff;
|
|
12
|
+
const MIN_VALUE = -0x80000000;
|
|
13
|
+
if (num > MAX_VALUE || num < MIN_VALUE) {
|
|
14
|
+
// eslint-disable-next-line
|
|
15
|
+
return (num &= 0xffffffff);
|
|
16
|
+
}
|
|
17
|
+
return num;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function hashCode(strKey) {
|
|
21
|
+
let hash = 0;
|
|
22
|
+
if (!isNull(strKey)) {
|
|
23
|
+
for (let i = 0; i < strKey.length; i++) {
|
|
24
|
+
hash = hash * 31 + strKey.charCodeAt(i);
|
|
25
|
+
hash = intValue(hash);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return hash;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* 将js页面的number类型转换为java的int类型
|
|
33
|
+
* @param num
|
|
34
|
+
* @return intValue
|
|
35
|
+
*/
|
|
36
|
+
|
|
37
|
+
class SenderKeyName {
|
|
38
|
+
constructor(groupId, sender) {
|
|
39
|
+
this.groupId = groupId;
|
|
40
|
+
this.sender = sender;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
getGroupId() {
|
|
44
|
+
return this.groupId;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
getSender() {
|
|
48
|
+
return this.sender;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
serialize() {
|
|
52
|
+
return `${this.groupId}::${this.sender.id}::${this.sender.deviceId}`;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
toString() {
|
|
56
|
+
return this.serialize();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
equals(other) {
|
|
60
|
+
if (other === null) return false;
|
|
61
|
+
if (!(other instanceof SenderKeyName)) return false;
|
|
62
|
+
return this.groupId === other.groupId && this.sender.toString() === other.sender.toString();
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
hashCode() {
|
|
66
|
+
return hashCode(this.groupId) ^ hashCode(this.sender.toString());
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
module.exports = SenderKeyName;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
const SenderKeyState = require('./sender_key_state');
|
|
2
|
+
|
|
3
|
+
class SenderKeyRecord {
|
|
4
|
+
MAX_STATES = 5;
|
|
5
|
+
|
|
6
|
+
constructor(serialized) {
|
|
7
|
+
this.senderKeyStates = [];
|
|
8
|
+
|
|
9
|
+
if (serialized) {
|
|
10
|
+
const list = serialized;
|
|
11
|
+
for (let i = 0; i < list.length; i++) {
|
|
12
|
+
const structure = list[i];
|
|
13
|
+
this.senderKeyStates.push(
|
|
14
|
+
new SenderKeyState(null, null, null, null, null, null, structure)
|
|
15
|
+
);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
isEmpty() {
|
|
21
|
+
return this.senderKeyStates.length === 0;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
getSenderKeyState(keyId) {
|
|
25
|
+
if (!keyId && this.senderKeyStates.length) return this.senderKeyStates[this.senderKeyStates.length - 1];
|
|
26
|
+
for (let i = 0; i < this.senderKeyStates.length; i++) {
|
|
27
|
+
const state = this.senderKeyStates[i];
|
|
28
|
+
if (state.getKeyId() === keyId) {
|
|
29
|
+
return state;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
addSenderKeyState(id, iteration, chainKey, signatureKey) {
|
|
35
|
+
this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, null, signatureKey));
|
|
36
|
+
if (this.senderKeyStates.length > 5) {
|
|
37
|
+
this.senderKeyStates.shift()
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
setSenderKeyState(id, iteration, chainKey, keyPair) {
|
|
42
|
+
this.senderKeyStates.length = 0;
|
|
43
|
+
this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, keyPair));
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
serialize() {
|
|
47
|
+
const recordStructure = [];
|
|
48
|
+
for (let i = 0; i < this.senderKeyStates.length; i++) {
|
|
49
|
+
const senderKeyState = this.senderKeyStates[i];
|
|
50
|
+
recordStructure.push(senderKeyState.getStructure());
|
|
51
|
+
}
|
|
52
|
+
return recordStructure;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
module.exports = SenderKeyRecord;
|