Welcome to the Typso library, a comprehensive type-checking solution designed to provide robust runtime validation for JavaScript/Node.js environments, React, Express, and beyond. With Typso, you can enforce strict type checks on your functions, objects, and React components while maintaining flexibility for more dynamic and asynchronous use cases.
Typso enables:
- Runtime type-checking for variables, function arguments, return types, and object schemas.
- Integration with React for prop validation.
- Middleware for Express to validate request bodies and query parameters.
- Support for complex types like arrays, objects, and unions.
- Optional features like strict/loose modes, async validations, schema normalization, and lifecycle hooks.
Install Typso using npm:
npm install typso
Typso can enforce basic type checks for primitive types such as string
, number
, boolean
, and more.
const { TypeChecker } = require('typso');
TypeChecker.checkType('Hello', 'string'); // Passes
TypeChecker.checkType(123, 'string'); // Throws TypeError: Expected string but received number
Supported Types:
string
number
boolean
function
object
You can check if a variable is an instance of a particular class.
const { TypeChecker } = require('typso');
class MyClass {}
const instance = new MyClass();
TypeChecker.checkInstance(instance, MyClass); // Passes
TypeChecker.checkInstance({}, MyClass); // Throws TypeError: Expected instance of MyClass
Typso can check the type of elements inside an array.
const { TypeChecker } = require('typso');
const myArray = [1, 2, 3];
TypeChecker.checkArray(myArray, 'number'); // Passes
const invalidArray = [1, '2', 3];
TypeChecker.checkArray(invalidArray, 'number'); // Throws TypeError
For scenarios where variables can belong to multiple types, you can enforce union type checking.
const { TypeChecker } = require('typso');
TypeChecker.checkUnion(42, ['string', 'number']); // Passes
TypeChecker.checkUnion(true, ['string', 'number']); // Throws TypeError
Typso provides a mechanism to define a schema for objects and enforce type checks on each property of the object.
const { TypeChecker } = require('typso');
const userSchema = {
name: 'string',
age: 'number',
hobbies: ['array', 'string'],
};
const user = {
name: 'Alice',
age: 25,
hobbies: ['Reading', 'Coding']
};
TypeChecker.checkObject(user, userSchema); // Passes
You can enforce numeric ranges or string/array lengths.
TypeChecker.checkRange(50, 10, 100); // Passes
TypeChecker.checkRange(150, 10, 100); // Throws RangeError: Value should be between 10 and 100
TypeChecker.checkLength('hello', 1, 10); // Passes
TypeChecker.checkLength('too long string', 1, 10); // Throws LengthError
Typso allows you to create custom validations using functions.
const validColors = ['red', 'green', 'blue'];
TypeChecker.checkCustom('green', (value) => validColors.includes(value)); // Passes
TypeChecker.checkCustom('yellow', (value) => validColors.includes(value)); // Throws ValidationError
You can provide default values when some object properties are missing and normalize them.
const { normalize } = require('typso');
const userSchema = {
name: { type: 'string', default: 'Anonymous' },
age: { type: 'number', default: 18 },
};
const user = {
email: '[email protected]'
};
const normalizedUser = normalize(userSchema, user);
console.log(normalizedUser); // { name: 'Anonymous', age: 18, email: 'user@example.com' }
Typso supports async validations, which is useful for tasks like checking if a value exists in a database.
const { TypeChecker } = require('typso');
async function isUsernameAvailable(username) {
const availableUsernames = ['john', 'jane', 'doe'];
return availableUsernames.includes(username);
}
async function validateUsername(username) {
await TypeChecker.checkAsync(username, isUsernameAvailable); // Passes or throws error
}
validateUsername('john'); // Passes
validateUsername('nonexistent'); // Throws ValidationError
Typso can operate in strict mode (more rigorous checks) or loose mode (allows null
or undefined
values in some cases).
TypeChecker.enforceStrictMode(true); // Enable strict mode
TypeChecker.checkType(null, 'string'); // Throws error in strict mode
TypeChecker.enforceStrictMode(false); // Loose mode allows null values
You can define schemas with rules for validation, such as minimum length, maximum length, and patterns.
const schema = {
name: { type: 'string', minLength: 2, maxLength: 50 },
age: { type: 'number', min: 18, max: 100 },
email: { type: 'string', pattern: /^[^\s@]+@[^\s@]+\.[^\s@]+$/ }, // Email regex
};
TypeChecker.validateDeclarativeSchema(user, schema);
Typso supports lifecycle hooks like beforeValidate
and afterValidate
.
const schemaWithHooks = {
name: 'string',
beforeValidate: () => console.log('Starting validation...'),
afterValidate: () => console.log('Validation complete!'),
};
TypeChecker.validateWithLifecycle(user, schemaWithHooks);
Typso integrates seamlessly with React components for prop validation using higher-order components (HOCs).
import { withPropTypes } from 'typso';
const Greeting = ({ name, age }) => (
<div>
<h1>Hello, {name}!</h1>
<p>Age: {age}</p>
</div>
);
const GreetingWithTypes = withPropTypes(Greeting, {
name: 'string',
age: 'number',
});
export default GreetingWithTypes;
Typso provides middleware for validating request bodies or query parameters in Express.
const express = require('express');
const { validateRequestBody } = require('typso');
const app = express();
app.use(express.json());
const userSchema = {
name: 'string',
age: 'number',
email: 'string',
};
app.post('/user', validateRequestBody(userSchema), (req, res) => {
res.json({ success: true });
});
app.listen(3000);
Check if a number falls within a given range.
TypeChecker.checkRange(value, min, max);
Check the length of strings or arrays.
TypeChecker.checkLength(value, minLength, maxLength);
Perform custom validations using a function.
TypeChecker.checkCustom(value, validationFunction);
Perform asynchronous validations.
TypeChecker.checkAsync(value, asyncValidationFunction);
Automatically fill missing fields in objects with default values as defined in the schema.
normalize(schema, object);
Toggle strict or loose mode for type validation.
TypeChecker.enforceStrictMode(true); // Enable strict mode
TypeChecker.enforceStrictMode(false); // Enable loose mode
Enable or disable logging warnings instead of throwing errors.
TypeChecker.enableWarnings(true); // Enable warnings
TypeChecker.enableWarnings(false); // Disable warnings
Typso is a versatile and powerful type-checking library for JavaScript that works across various environments. It’s designed to be flexible, easy to integrate, and capable of handling simple to complex type validations, including async validations, schema normalization, and lifecycle hooks.
With Typso, you can enforce strong runtime validation and ensure that your data structures, function arguments, and component props adhere to expected types, making your applications more robust and reliable.