
Security News
AI Slop Is Polluting Bug Bounty Platforms with Fake Vulnerability Reports
AI-generated slop reports are making bug bounty triage harder, wasting maintainer time, and straining trust in vulnerability disclosure programs.
bitsharesjs-ws
Advanced tools
Pure JavaScript BitShares websocket interface for node.js and browsers.
Pure JavaScript Bitshares websocket library for node.js and browsers. Can be used to easily connect to and obtain data from the Bitshares blockchain via public apis or local nodes.
Credit for the original implementation goes to jcalfeee.
This library can be obtained through npm:
npm install bitsharesjs-ws
Several examples are available in the /examples folder, and the tests in /test also show how to use the library.
Browser bundles are provided in /build/, for testing purposes you can access this from rawgit:
<script type="text/javascript" src="https://cdn.rawgit.com/bitshares/bitsharesjs-ws/build/bitsharesjs-ws.js" />
A variable bitshares_ws will be available in window.
For use in a webpack/browserify context, see the example below for how to open a websocket connection to the Openledger API and subscribe to any object updates:
var {Apis} = require("bitsharesjs-ws");
Apis.instance("wss://bitshares.openledger.info/ws", true).init_promise.then((res) => {
console.log("connected to:", res[0].network);
Apis.db.set_subscribe_callback( updateListener, true )
});
function updateListener(object) {
console.log("set_subscribe_callback:\n", object);
}
The set_subscribe_callback
callback (updateListener) will be called whenever an object on the blockchain changes or is removed. This is very powerful and can be used to listen to updates for specific accounts, assets or most anything else, as all state changes happen through object updates. Be aware though that you will receive quite a lot of data this way.
This is a non-exhaustive list of endpoints available from the witness_node executable, which provides the API server of Bitshares.
Please see all available methods in the official documentation.
To access the Database API, you can use the Apis.db
object.
Usage example
Apis.db.get_objects(["1.3.0", "2.0.0", "2.1.0"])
To access the Account History API, you can use the Apis.history
object.
Usage example
Apis.history.get_account_history("1.2.849826", "1.11.0", 10, "1.11.0")
The tests show several use cases, to run, simply type npm run test
. The tests require a local witness node to be running, as well as an active internet connection.
FAQs
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
AI-generated slop reports are making bug bounty triage harder, wasting maintainer time, and straining trust in vulnerability disclosure programs.
Research
Security News
The Socket Research team investigates a malicious Python package disguised as a Discord error logger that executes remote commands and exfiltrates data via a covert C2 channel.
Research
Socket uncovered npm malware campaign mimicking popular Node.js libraries and packages from other ecosystems; packages steal data and execute remote code.