
Product
Rust Support in Socket Is Now Generally Available
Socket’s Rust and Cargo support is now generally available, providing dependency analysis and supply chain visibility for Rust projects.
A tiny rules framework that can be used to validate any value, either by you creating a rules/schema object or applying validations to a single value. In both cases a fluent interface is used.
You create an object to declare the rules/invariants you want to apply (something akin to a schema). A fluent interface makes it easy to specify the invariants for each property:
var nameRules = {
first : mustBe().populated().string({ minLength: 5, maxLength: 20}), [1]
second : mustBe().populated().string({ minLength: 5, maxLength: 20}),
}
var personRules = {
name: nameRules,
weight: mustBe().populated().numeric({min : 0, max: 130}),
dateOfBirth: function() {
this.populated().date({ before: now.subtract("years", 1) });
} [2]
}
As shown you can access this fluent interface using two approaches:
The function based approach is designed primarily for use with CoffeeScript:
# This schema is not showing how to validate a real address, it just shows a few validators
addressRules = {
streetOne: mustBe().populated()
streetTwo: -> @.populated().string( minLength: 10, maxLength : 50 )
streetThree: -> @.populated().string( minLength : 10, maxLength: 50)
town: -> @.populated()
postCode: -> @.populated().matchFor(/.../)
}
The same validators are available for use validating individual values:
var doSomeStuff = function(name, age) {
ensure(name).populated().string();
ensure(age, "age").integer();
...
}
You trigger validation using:
result = rules.apply(person, personRules)
The returned object has the per-property details of any validation failures, e.g.:
{
name: {
first: {
message: 'The value must be populated.',
type: 'not_populated',
value: ''
},
second: {
message: 'The value must be populated.',
type: 'not_populated',
value: undefined }
},
weight: {
message: 'The value must be populated.',
type: 'not_populated',
value: undefined
}
}
Note in this case both the first name (e.g. person.name.first) and second name (person.name.second) needed to be populated, along with the weight.
The framework comes with several validators, to understand them further you may want to run the examples.
populated - Checks the value is not null, undefined, "", or an empty array.arraynumeric - Optionally you can also pass in object with min and/or max valuesintegermatchFor - You can pass in an object with pattern and optionally flags, alternatively you can pass in the RegExp object to use.date - Optionally you can specify that the date must be before and/or after specified dates. To make this easier you use now.add or now.subtract to specify the dates to use for before/after.string - Optionally you can pass in minLength and/or maxLength.The project comes with examples in the examples directory.
mocha -R spec spec/testFixture spec/ --recursive
FAQs
Validate objects against predefined rules (node.js).
The npm package rules receives a total of 192 weekly downloads. As such, rules popularity was classified as not popular.
We found that rules 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.

Product
Socket’s Rust and Cargo support is now generally available, providing dependency analysis and supply chain visibility for Rust projects.

Security News
Chrome 144 introduces the Temporal API, a modern approach to date and time handling designed to fix long-standing issues with JavaScript’s Date object.

Research
Five coordinated Chrome extensions enable session hijacking and block security controls across enterprise HR and ERP platforms.