Research
Security News
Malicious PyPI Package ‘pycord-self’ Targets Discord Developers with Token Theft and Backdoor Exploit
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
backbone.intactmodel
Advanced tools
Keep your Backbone models intact using strict property declaration without loosing flexibility with session and derived attributes.
IntactModel is in most part inspired by Henrik Joreteg's HumanModel and would not have been made was it not for the pressing need for legacy support (I'm looking at you, IE8). IntactModel aims to help you keep your models intact by forcing strictly typed properties set to the model and at the same time allow for session attributes such as states or arbitrary data without persisting them to the server.
Properties declaration aim to follow the JSON Schema for testing types. In no way is this a complete implementation of the JSON schema, only type
is implemented at this time.
The aim is to support JSON schema but not at the price of excessive code bloat, hence, as of now IntactModel only tests against the type
property. More properties could very well be added on later.
var Model = new Backbone.IntactModel({
properties: {
'foo': {type: 'string'}
}
});
var model = new Model({
'foo': []
});
model.attributes; // {}
IntactModel aims to be graceful in how it handles your attributes. If you try to set an attribute that is not declared on beforehand IntactModel simply sets it as a session attribute and allows you to get
is just as if it were a "native" attribute. You never have to bother with separating "native" attributes from session attributes, IntactModel does that for you.
var Model = new Backbone.IntactModel({
properties: {
'foo': {type: 'string'}
}
});
var model = new Model({
'foo': 'foo',
'bar': 'bar'
});
JSON.stringify(model); // {"foo": "foo", "bar": "bar"}
model.attributes; // {"foo": "foo"}
model.session; // {"bar": "bar"}
model.save(); // Payload: {"foo": "foo"}
IntactModel supports derived attributes that can compute and compile a value based on the model's other properties. This is best explained with an example:
var Model = new Backbone.IntactModel({
properties: {
'first': {type: 'string'},
'second': {type: 'string'}
},
derived: {
'greeting': function () {
return this.get('first') + ' ' + this.get('last');
}
}
});
var model = new Model({
'first': 'Hello',
'second': 'world!'
});
model.get('greeting'); // "Hello world!"
A common pattern is to extend upon common model classes. To be able to extend on the model's properties
and derived
attributes without overwriting them, a custom deep extend is the default extend method for IntactModel. In short, IntactModel.extend
performs a regular Backbone.Model.extend
and also manually extends on it's super's properties
, derived
and defaults
.
If this behaviour is not what you want, simply call the default Backbone.Model
's extend method, as so:
var MyModel = Backbone.Model.extend.call(SomeOtherModel, {
properties: {
'someAttribute': {type: 'string'}
}
});
A utility function for checking whether a model has all it's declared properties as defined attributes. Useful for determining if the model ought to be fetched to ensure complete data.
The compile
method is a way of getting all the model's data. Compile returns the the model's attributes
, session
and derived
properties, all merged in to one object, in that order (meaning colliding attribute names we be overridden).
The toJSON method is unaltered, meaning it only returns a clone of the model attributes.
IntactModel has the function it uses for testing properties assigned as it's default validate
method. Override this if you have other needs regarding validation.
The clone method is unaltered, meaning it only clones model.attributes.
Clearing a model behaves in essence in the same way as a default Backbone Model. Calling clear on a model simply unsets all its "native" and session attributes. However, passing in the option graceful
unsets only the session attributes, leaving the model.attributes
untouched.
var Model = new Backbone.IntactModel({
properties: {
'foo': {type: 'string'}
}
});
var model = new Model({
'foo': 'foo',
'bar': 'bar'
});
// Gracefully clear the model
model.clear({graceful: true});
model.attributes; // {"foo": "foo"}
model.session; // {}
// Completely clear the model
model.clear();
model.attributes; // {}
FAQs
Keep your Backbone models intact using strict property declaration without loosing flexibility with session and derived attributes.
The npm package backbone.intactmodel receives a total of 11 weekly downloads. As such, backbone.intactmodel popularity was classified as not popular.
We found that backbone.intactmodel 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.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.