
Security Fundamentals
Turtles, Clams, and Cyber Threat Actors: Shell Usage
The Socket Threat Research Team uncovers how threat actors weaponize shell techniques across npm, PyPI, and Go ecosystems to maintain persistence and exfiltrate data.
blueprintjs
Advanced tools
If you work with a lot of generic objects ({}
) in your code and you want to give special behavior to some or all of them, then BlueprintJS is the right tool for you.
var User = blueprint({
name: "",
lastName: "",
fullName: function () {
"use strict";
// Never use this.name, always use the "get" and "set" methods
return this.get("name") + " " + this.get("lastName");
}
});
User
Blueprintvar someObjectIHaveInMyProject = {name: "Robert", lastName: "Baratheon"};
var user = new User(someObjectIHaveInMyProject);
// Now you get the "fullName" method for free. Bargain!
console.log(user.get("fullName")); // Robert Baratheon
user.set("lastName", "Downey Jr.");
console.log(user.get("fullName")); // Robert Downey Jr.
user
blueprintObject into a plain objectvar userPlainObject = blueprint.toPlainObject(user);
// Note that the fullName method is now a property with a value that is the
// result of that method
console.log(user.fullName); // Robert Downey Jr.
var listOfObjects = [
{name:"John", lastName: "Blue"},
{name:"Mary", lastName: "Red"},
{name:"Richard", lastName: "Green"},
{name:"Michael", lastName: "Gray"},
{name:"Agatha", lastName: "Orange"}
];
// blueprint.cast(Blueprint, object_or_list_of_objects)
var listOfUsers = blueprint.cast(User, listOfObjects);
console.log(listOfUsers[1].get("fullName")); // Mary Red
init
methodvar Car = blueprint({
init: function () {
this.set("model", "BMW"); // It will replace the default model
},
model: "Mercedes Benz"
});
// The object is created and the "init()" method is called
var car = new Car();
console.log(car.get("model")); // BMW
// Just require the package and you are set
var blueprint = require("blueprint");
var Car = blueprint({
// Using closure and IIFE to create the isExpensive method
isExpensive: (function (){
"use strict";
// "Static" list of expensive brands
var expensiveBrands = {
bmw: true,
mercedez: true
};
// The function that will be executed when the
// isExpensive method is called
return function () {
if (expensiveBrands[this.get("brand")]) {
return true;
}
return false;
};
}())
});
var car = new Car({brand:"bmw"});
console.log("Is the car expensive? " + car.get("isExpensive"));
// outputs: Is the car expensive? true
That's it. Any feedback will be appreciated.
FAQs
Treat generic objects with class
The npm package blueprintjs receives a total of 271 weekly downloads. As such, blueprintjs popularity was classified as not popular.
We found that blueprintjs 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 Fundamentals
The Socket Threat Research Team uncovers how threat actors weaponize shell techniques across npm, PyPI, and Go ecosystems to maintain persistence and exfiltrate data.
Security News
At VulnCon 2025, NIST scrapped its NVD consortium plans, admitted it can't keep up with CVEs, and outlined automation efforts amid a mounting backlog.
Product
We redesigned our GitHub PR comments to deliver clear, actionable security insights without adding noise to your workflow.