
Research
Security News
Lazarus Strikes npm Again with New Wave of Malicious Packages
The Socket Research Team has discovered six new malicious npm packages linked to North Korea’s Lazarus Group, designed to steal credentials and deploy backdoors.
@blockedprotocol/points-sdk
Advanced tools
Use the SDK to integrate Blocked Points SDK into your app in minutes. The SDK is available in Typescript and Javascript.
Contact Blocked Protocol team to receive your private keys
npm add @blockedprotocol/points-sdk
Use the newBlockedSdk
method to initialize the client, providing your API key and point system id.
import { newBlockedSdk } from "@blockedprotocol/points-sdk";
const blockedSdk = newBlockedSdk({
apiKey: "YOUR_API_KEY",
pointsSystemId: "YOUR_POINT_SYSTEM_ID",
});
By default it'll use production environment, but you can pass env: "development"
to use development environment.
Tagging each point assignment with an event name is important for tracking and analytics.
await blockedSdk.points.track("login", {
points: 100,
account: "11111111111111111111111111111111",
});
await blockedSdk.points.track("transfer_eth_cosmos", {
points: 515,
account: "22222222222222222222222222222222",
});
You can substract points for account using the negative value. The following example will decrement 50 points:
await blockedSdk.points.track("penalty", {
points: -50,
account: "11111111111111111111111111111111",
});
You can multiply points. The following example will multiply points by 1.5:
await blockedSdk.points.track("top_user", {
account: "11111111111111111111111111111111",
multiplicator: 1.5,
});
Get the points for an account using the getPoints method, providing the account address.
await blockedSdk.points.getPoints("11111111111111111111111111111111");
// => { points: 100 }
Get the leaderboard using the getLeaderboard method. The response defaults to the top 100 users. Pagination support coming soon
await blockedSdk.points.getLeaderboard();
// => [
// { account: "11111111111111111111111111111111", points: 100 },
// { account: "22222222222222222222222222222222", points: 515 }
// ]
Get the rank of an account in the leaderboard using the getLeaderboardRank method.
await blockedSdk.points.getLeaderboardRank("11111111111111111111111111111111");
// {
// account: '11111111111111111111111111111111',
// rank: 1,
// points: 100
// }
Get the events for a specific event name using the getEvents method.
await blockedSdk.points.getEvents({
account: "11111111111111111111111111111111", // filter by address
event: "login", // filter by event name
});
// Returns an array of events
// => [
// {
// event: 'login',
// account: '11111111111111111111111111111111',
// timestamp: 1712326918956,
// points: 100,
// }
// ]
If you don't specify the event
field, it'll return all events for a given account
User
- is an entity allows to link multiple accounts and utilize referral system
Here's how you can create user:
await blockedSdk.users.create(["11111111111111111111111111111111"]);
// => { id: "<USER_ID>" }
Note: if account already linked to another user, error will be thrown.
If you know that account A
has referred account B
, you can create a user entity and provide the referral information.
Follow the code snippet to create user and specify referrer:
// 1. find referrer user
// if user doesn't exist for account, error will be thrown
// see step above on how to create user without referrer
const referrerUser = blockedSdk.users.findByAccount("A");
// 2. create user
await blockedSdk.users.create(["B"], referrerUser.id);
// => { id: "<USER_ID>" }
As a result you craeted user B
referred by user A
.
You can link accounts to a user even after user entity was created.
If you know that user with account abc
has also accounts aaa
and bbb
.
// 1. Find user with account `abc`
// if user doesn't exist for account, error will be thrown
// see step above on how to create user
const user = await blockedApi.users.findByAccount("abc");
// 2. Link accounts `aaa` and `bbb` to the same user
await blockedApi.users.linkAccounts(user.id, ["aaa", "bbb"]);
Returns cumulutive value for all accounts linked to user
const user = blockedSdk.users.findByAccount("11111111111111111111111111111111");
await blockedSdk.points.getPointsForUser(user.id);
// => { points: 100 }
FAQs
# Using the SDK
We found that @blockedprotocol/points-sdk demonstrated a healthy version release cadence and project activity because the last version was released less than 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.
Research
Security News
The Socket Research Team has discovered six new malicious npm packages linked to North Korea’s Lazarus Group, designed to steal credentials and deploy backdoors.
Security News
Socket CEO Feross Aboukhadijeh discusses the open web, open source security, and how Socket tackles software supply chain attacks on The Pair Program podcast.
Security News
Opengrep continues building momentum with the alpha release of its Playground tool, demonstrating the project's rapid evolution just two months after its initial launch.