
- 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.
29 lines
826 B
JavaScript
29 lines
826 B
JavaScript
/*
|
|
Copyright 2014 Google LLC
|
|
|
|
Use of this source code is governed by the MIT License, available in this package's LICENSE file
|
|
or at http://opensource.org/licenses/MIT.
|
|
*/
|
|
const _ = require('lodash');
|
|
const Requizzle = require('./lib/requizzle');
|
|
|
|
module.exports = function requizzle(options) {
|
|
let instance;
|
|
|
|
if (!options || typeof options !== 'object') {
|
|
throw new TypeError("Requizzle's options parameter must be a non-null object.");
|
|
}
|
|
options = _.clone(options);
|
|
options.parent = module.parent;
|
|
|
|
return (filepath) => {
|
|
instance = instance || new Requizzle(options);
|
|
|
|
return instance.requizzle(filepath);
|
|
};
|
|
};
|
|
module.exports.Requizzle = Requizzle;
|
|
|
|
// force Node.js to reload this module each time it's required, so module.parent is always correct
|
|
delete require.cache[__filename];
|