
- 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
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.TestingInjector = void 0;
|
|
const constants_1 = require("@nestjs/core/injector/constants");
|
|
const injector_1 = require("@nestjs/core/injector/injector");
|
|
const instance_wrapper_1 = require("@nestjs/core/injector/instance-wrapper");
|
|
/**
|
|
* @publicApi
|
|
*/
|
|
class TestingInjector extends injector_1.Injector {
|
|
setMocker(mocker) {
|
|
this.mocker = mocker;
|
|
}
|
|
setContainer(container) {
|
|
this.container = container;
|
|
}
|
|
async resolveComponentInstance(moduleRef, name, dependencyContext, wrapper, contextId = constants_1.STATIC_CONTEXT, inquirer, keyOrIndex) {
|
|
try {
|
|
const existingProviderWrapper = await super.resolveComponentInstance(moduleRef, name, dependencyContext, wrapper, contextId, inquirer, keyOrIndex);
|
|
return existingProviderWrapper;
|
|
}
|
|
catch (err) {
|
|
if (this.mocker) {
|
|
const mockedInstance = this.mocker(name);
|
|
if (!mockedInstance) {
|
|
throw err;
|
|
}
|
|
const newWrapper = new instance_wrapper_1.InstanceWrapper({
|
|
name,
|
|
isAlias: false,
|
|
scope: wrapper.scope,
|
|
instance: mockedInstance,
|
|
isResolved: true,
|
|
host: moduleRef,
|
|
metatype: wrapper.metatype,
|
|
});
|
|
const internalCoreModule = this.container.getInternalCoreModuleRef();
|
|
internalCoreModule.addCustomProvider({
|
|
provide: name,
|
|
useValue: mockedInstance,
|
|
}, internalCoreModule.providers);
|
|
internalCoreModule.addExportedProvider(name);
|
|
return newWrapper;
|
|
}
|
|
else {
|
|
throw err;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
exports.TestingInjector = TestingInjector;
|