Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Convenient BitTorrent Client based on the aria2 JSON RPC Interface and aria2c CLI application with Web UI.
Introduction blog post 构建一个易用的 aria2 客户端包和 CLI 应用 in Chinese.
It is used in the same way as aria2c.
$ npm i -g naria2c
$ naria2c --version
naria2c/0.0.26
--------------
...
$ naria2c --help
You can also launch a Web UI to manage aria2 using the --ui
option. This feature is provided by this package, not the original aria2.
$ naria2c --ui
...
10/29 21:22:46 [NOTICE] WebUI is listening on the http://127.0.0.1:6801?port=6800&secret=123456
...
npm i naria2
Using WebSocket:
import { createClient } from 'naria2'
const client = await createClient(
new WebSocket('ws://localhost:6800/jsonrpc')
)
Using HTTP:
import { createClient } from 'naria2'
import { createHTTP } from 'naria2/transport'
const client = await createClient(
createHTTP('http://localhost:6800/jsonrpc')
)
If you want to use naria2 in the Node.js standalone, you can install @naria2/node
. It has included a prebuilt aria2 binary according to your architecture, so that there is no need to install a aria2 on your own.
npm i naria2 @naria2/node
You can use the createChildProcess
API to spawn an aria2 child process, and connect to it in WebScoket under the hood.
import { createClient } from 'naria2'
import { createChildProcess } from '@naria2/node'
const client = await createClient(createChildProcess())
Warning
You should close the client on your own, otherwise the aria2 process may not be killed even if your program finished or crashed.
See my blog post (in Chinese) or The Death of a Node.js Process (in English) on how to handle the exit of a Node.js process.
import { createClient } from 'naria2'
import { createChildProcess } from '@naria2/node'
// Initialize a client
const client = await createClient(createChildProcess())
// Start downloading a magnet
const torrent = await client.downloadUri('...')
// Wait for torrent download finished
await torrent.watchTorrent(
// Watch metadata progress
(task) => {
console.log(`Downloading [MEATADATA]`)
},
// Watch torrent progress
(task) => {
console.log(`Downloading torrent`)
},
// Wait for the target event being fired
// 'bt-complete': downloading finished
// 'complete': seeding finished
'bt-complete'
)
// Shutdown client
await client.shutdown()
You can find detailed examples using Node.js here: examples/magnet.mjs, examples/torrent.mjs, examples/http.mjs.
Due to the implementation of aria2, the downloading progress of a magnet uri includes two steps:
- Download the torrent metadata which contains a special file name with prefix
[METADATA]
;- Download the torrent content itself.
So that, in the above code, the first callback is to wait for downloading metadata, and then the second callback is to wait for downloading the followed by task which is the torrent content itself.
MIT License © 2024 XLor
FAQs
Convenient BitTorrent Client based on the aria2 JSON-RPC
The npm package naria2 receives a total of 35 weekly downloads. As such, naria2 popularity was classified as not popular.
We found that naria2 demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers 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.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.