Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Lifecycle.js provides conventions and helpers to manage the life cycles of Javascript instances.
Lifecycle.js provides conventions and helpers to manage the life cycles of Javascript instances.
#Download Latest (1.1.2):
Please see the release notes for upgrade pointers.
###Module Loading
Lifecycle.js is compatible with RequireJS, CommonJS, Brunch and AMD module loading. Module names:
If you need to write code that manages the lifecycle of some javascript objects, but you don't know ahead of time what type of lifecycle model they implement, Lifecycle.js is for you!
A good example of this is Backbone.Articulation. Backbone.Articulation will reconstruct instances of Dates or custom classes within you Backbone.Model's attributes irregardless of what lifecycle model they use (as long as they use one of the known conventions!)
Manages the lifecycle of individual instances, objects, arrays, and object properties that comply with some lifecycle conventions:
Run time determination of the correct lifecycle for an instance:
instance = new MyClass()
owned_copy_instance = LC.own(instance) # you don't need to know whether MyClass needs to get cloned, retained, etc
...
LC.disown(owned_copy_instance) # you don't need to know whether MyClass needs to get destroyed, released, etc
It also works for Javascript collection types:
# works for arrays containing instances or primitive types
an_array = [new Object(), ‘hello’, new Object()]
owned_copy_array = LC.own(an_array)
...
LC.disown(an_array)
# works for objects whose properties contain instances or primitive types
an_object = {one: new Object(), two: new Object(), three: ‘there’}
owned_copy_object = LC.own(an_object, {properties:true})
...
LC.disown(an_object);
Very basic implementation following the Coffeescript class pattern for a reference countable class.
CoffeeScript classes:
class MyClass extends LC.RefCountable
constructor: ->
super
@is_alive = true
__destroy: ->
@is_alive = false
instance = new MyClass() # ref_count = 1
instance.retain() # ref_count = 2
instance.release() # ref_count = 1
instance.release() # ref_count = 0 and __destroy() called
JavaScript classes using extend:
var MyClass = LC.RefCountable.extend({
constructor: function() {
LC.RefCountable.prototype.constructor.apply(this, arguments);
this.is_alive = true;
},
__destroy: function() {
this.is_alive = false;
}
});
var instance = new MyClass(); // ref_count = 1
instance.retain(); // ref_count = 2
instance.release(); // ref_count = 1
instance.release(); // ref_count = 0 and __destroy() called
###Installing:
###Commands:
FAQs
Lifecycle.js provides conventions and helpers to manage the life cycles of Javascript instances.
The npm package lifecycle receives a total of 4,993 weekly downloads. As such, lifecycle popularity was classified as popular.
We found that lifecycle 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 a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.