Security News
Supply Chain Attack Detected in Solana's web3.js Library
A supply chain attack has been detected in versions 1.95.6 and 1.95.7 of the popular @solana/web3.js library.
Mesh networking with peer-to-peer messaging for NodeJS and the browser. Ataraxia connects different instances together and allows messages to be passed between these instances. Some instances may act as routers for other instances to create a partially connected mesh network.
import { Network, AnonymousAuth } from 'ataraxia';
import { TCPTransport, TCPPeerMDNSDiscovery } from 'ataraxia-tcp';
// Setup a network with anonymous authentication
const net = new Network({
name: 'name-of-your-app-or-network',
authentication: [
new AnonymousAuth()
]
});
// Setup a TCP transport that will discover other peers on the same network using mDNS
net.addTransport(new TCPTransport({
discovery: new TCPPeerMDNSDiscovery()
}));
net.onNodeAvailable(node => {
console.log('A new node is available:', node.id);
node.send('hello');
});
net.onMessage(msg => {
console.log('A message was received', msg.type, 'with data', msg.data, 'from', msg.source.id);
});
// Start the network
await net.start();
This example creates a network where instances on the same machine connect to each other locally first and then elects one instance to handle connections to other machines on the same network.
import { Network, AnonymousAuth } from 'ataraxia';
import { TCPTransport, TCPPeerMDNSDiscovery } from 'ataraxia-tcp';
import { MachineLocalTransport } from 'ataraxia-local';
// Setup a network with anonymous authentication
const net = new Network({
name: 'name-of-your-app-or-network',
authentication: [
new AnonymousAuth()
]
});
const local = new MachineLocalTransport();
local.onLeader(() => {
/*
* The leader event is emitted when this instance becomes the leader
* of the machine-local network. This instance will now handle
* connections to other machines in the network.
*/
net.addTransport(new TCPTransport({
discovery: new TCPPeerMDNSDiscovery()
}));
});
net.addTransport(local);
await net.start();
new Network(options)
- create a new network using the given options. Options may be:
name
- Required. The name of the network, should be short and describe the app or library.endpoint
- Request that the local node is an endpoint that should not perform routing.start()
- start the network and its transportsstop()
- stop the network and its transportsaddTransport(transport)
- add a transport that should be usedonNodeAvailable(node => ...)
- a node has been found and messages can now be sent and received to/from itonNodeUnavailable(node => ...)
- a node is no longer availableonMessage((message: Message) => ...)
- a message has been received from a nodeid
- get the id of the nodeonUnavailable(() => ...)
- node is no longer availablesend(type, data)
- send a message of the given type with the specified data to the nodeonMessage((message: Message) => ...)
- a message has been received from this nodesource: Node
- the node that sent the messagetype: string
- the type of the messagedata: any
- the data of the messageFAQs
P2P messaging over mesh networks
The npm package ataraxia receives a total of 37 weekly downloads. As such, ataraxia popularity was classified as not popular.
We found that ataraxia demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Security News
A supply chain attack has been detected in versions 1.95.6 and 1.95.7 of the popular @solana/web3.js library.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.