Socket
Socket
Sign inDemoInstall

@wireapp/proteus

Package Overview
Dependencies
Maintainers
5
Versions
312
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@wireapp/proteus

Axolotl protocol implementation for TypeScript.


Version published
Maintainers
5
Created
Source

Wire

This repository is part of the source code of Wire. You can find more information at wire.com or by contacting opensource@wire.com.

You can find the published source code at github.com/wireapp.

For licensing information, see the attached LICENSE file and the list of third-party licenses at wire.com/legal/licenses/.

Proteus

Installation

yarn add @wireapp/proteus

Usage

import {init, keys} from '@wireapp/proteus';

await init();

const yourIdentity = keys.IdentityKeyPair.new();

Performance Benchmark

Run benchmark on main thread:

yarn start:benchmark

Run benchmark with worker threads:

yarn start:benchmark --workers [amount]

Results:

ScenarioMacBook Air M1 (2020) A2337
(8C CPU, 16 GB RAM)
Node v16.0.0
Generating "4000" pre-key bundles (single-threaded)1461ms
Initializing "4000" sessions (single-threaded)2967ms
Encrypting "4000" texts (single-threaded)200ms

Decryption Errors

Error CodeType/ErrorReason
2RangeError
Offset is outside the bounds of the DataView
Remote side failed to encrypt message (undefined text or similar error), thus we receive a 💣 from Cryptobox.
200DecryptError
Unknown message type
Remote side does not follow proteus specification
201DecryptError.InvalidMessage
Can't initialise a session from a CipherMessage.
Occurs when the remote party thinks we have an initialised session, but it does not/no longer exist locally. We must have confirmed the session with the remote party by sending them a message. Until then then they continue to send us PreKeyMessages instead of CipherMessages. We prematurely deleted the session before decrypting all events.
202DecryptError.InvalidMessage
Unknown message format: The message is neither a "CipherMessage" nor a "PreKeyMessage".
Remote side does not follow proteus specification
203DecryptError.PrekeyNotFound
Could not delete PreKey
204DecryptError.RemoteIdentityChanged
Remote identity changed
Client of the user has changed without informing us (Man in the middle attack? or database conflicts on the remote side: sessions get mixed with new client)
205DecryptError.InvalidMessage
No matching session tag.
Usually happens when we receive a message intended for another client.
206DecryptError.InvalidSignature
Decryption of a message in sync failed
Envelope mac key verification failed
207DecryptError.InvalidSignature
Decryption of a newer message failed
Envelope mac key verification failed. Session broken or out of sync. Reset the session and decryption is likely to work again!
208DecryptError.OutdatedMessage
Message is out of sync
Opposite of "Too distant future" error
209DecryptError.DuplicateMessage
Duplicate message
Happens if an encrypted message is decrypted twice
210DecryptError.InvalidSignature
Decryption of a previous (older) message failed
Envelope mac key verification
211DecryptError.TooDistantFuture
Message is from too distant in the future
More than 1000 messages at the beginning of the receive chain were skipped
212DecryptError.TooDistantFuture
Message is from too distant in the future
More than 1000 messages on the receive chain were skipped
213DecryptError.InvalidMessage
Sender failed to encrypt a message.
Error on receiver side when remote side sends a 💣
300DecryptError.InvalidMessage
The received message was too big.

FAQs

Package last updated on 21 Mar 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc