
- Complete NestJS TypeScript implementation with WebSocket support - Direct messaging (DM) and group chat functionality - End-to-end encryption with AES encryption and key pairs - Media file support (images, videos, audio, documents) up to 100MB - Push notifications with Firebase Cloud Messaging integration - Mention alerts and real-time typing indicators - User authentication with JWT and Passport - SQLite database with TypeORM entities and relationships - Comprehensive API documentation with Swagger/OpenAPI - File upload handling with secure access control - Online/offline status tracking and presence management - Message editing, deletion, and reply functionality - Notification management with automatic cleanup - Health check endpoint for monitoring - CORS configuration for cross-origin requests - Environment-based configuration management - Structured for Flutter SDK integration Features implemented: ✅ Real-time messaging with Socket.IO ✅ User registration and authentication ✅ Direct messages and group chats ✅ Media file uploads and management ✅ End-to-end encryption ✅ Push notifications ✅ Mention alerts ✅ Typing indicators ✅ Message read receipts ✅ Online status tracking ✅ File access control ✅ Comprehensive API documentation Ready for Flutter SDK development and production deployment.
52 lines
2.7 KiB
JavaScript
52 lines
2.7 KiB
JavaScript
import { ValidationExecutor } from './ValidationExecutor';
|
|
/**
|
|
* Validator performs validation of the given object based on its metadata.
|
|
*/
|
|
export class Validator {
|
|
/**
|
|
* Performs validation of the given object based on decorators or validation schema.
|
|
*/
|
|
validate(objectOrSchemaName, objectOrValidationOptions, maybeValidatorOptions) {
|
|
return this.coreValidate(objectOrSchemaName, objectOrValidationOptions, maybeValidatorOptions);
|
|
}
|
|
/**
|
|
* Performs validation of the given object based on decorators or validation schema and reject on error.
|
|
*/
|
|
async validateOrReject(objectOrSchemaName, objectOrValidationOptions, maybeValidatorOptions) {
|
|
const errors = await this.coreValidate(objectOrSchemaName, objectOrValidationOptions, maybeValidatorOptions);
|
|
if (errors.length)
|
|
return Promise.reject(errors);
|
|
}
|
|
/**
|
|
* Performs validation of the given object based on decorators or validation schema.
|
|
*/
|
|
validateSync(objectOrSchemaName, objectOrValidationOptions, maybeValidatorOptions) {
|
|
const object = typeof objectOrSchemaName === 'string' ? objectOrValidationOptions : objectOrSchemaName;
|
|
const options = typeof objectOrSchemaName === 'string' ? maybeValidatorOptions : objectOrValidationOptions;
|
|
const schema = typeof objectOrSchemaName === 'string' ? objectOrSchemaName : undefined;
|
|
const executor = new ValidationExecutor(this, options);
|
|
executor.ignoreAsyncValidations = true;
|
|
const validationErrors = [];
|
|
executor.execute(object, schema, validationErrors);
|
|
return executor.stripEmptyErrors(validationErrors);
|
|
}
|
|
// -------------------------------------------------------------------------
|
|
// Private Properties
|
|
// -------------------------------------------------------------------------
|
|
/**
|
|
* Performs validation of the given object based on decorators or validation schema.
|
|
* Common method for `validateOrReject` and `validate` methods.
|
|
*/
|
|
coreValidate(objectOrSchemaName, objectOrValidationOptions, maybeValidatorOptions) {
|
|
const object = typeof objectOrSchemaName === 'string' ? objectOrValidationOptions : objectOrSchemaName;
|
|
const options = typeof objectOrSchemaName === 'string' ? maybeValidatorOptions : objectOrValidationOptions;
|
|
const schema = typeof objectOrSchemaName === 'string' ? objectOrSchemaName : undefined;
|
|
const executor = new ValidationExecutor(this, options);
|
|
const validationErrors = [];
|
|
executor.execute(object, schema, validationErrors);
|
|
return Promise.all(executor.awaitingPromises).then(() => {
|
|
return executor.stripEmptyErrors(validationErrors);
|
|
});
|
|
}
|
|
}
|
|
//# sourceMappingURL=Validator.js.map
|