
- 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.
36 lines
1.4 KiB
JavaScript
36 lines
1.4 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.getInjectionProviders = getInjectionProviders;
|
|
const shared_utils_1 = require("../../utils/shared.utils");
|
|
/**
|
|
* @param value
|
|
* @returns `true` if value is `OptionalFactoryDependency`
|
|
*/
|
|
function isOptionalFactoryDependency(value) {
|
|
return (!(0, shared_utils_1.isUndefined)(value.token) &&
|
|
!(0, shared_utils_1.isUndefined)(value.optional) &&
|
|
!value.prototype);
|
|
}
|
|
const mapInjectToTokens = (t) => isOptionalFactoryDependency(t) ? t.token : t;
|
|
/**
|
|
*
|
|
* @param providers List of a module's providers
|
|
* @param tokens Injection tokens needed for a useFactory function (usually the module's options' token)
|
|
* @returns All the providers needed for the tokens' injection (searched recursively)
|
|
*/
|
|
function getInjectionProviders(providers, tokens) {
|
|
const result = [];
|
|
let search = tokens.map(mapInjectToTokens);
|
|
while (search.length > 0) {
|
|
const match = (providers ?? []).filter(p => !result.includes(p) && // this prevents circular loops and duplication
|
|
(search.includes(p) || search.includes(p?.provide)));
|
|
result.push(...match);
|
|
// get injection tokens of the matched providers, if any
|
|
search = match
|
|
.filter(p => p?.inject)
|
|
.flatMap(p => p.inject)
|
|
.map(mapInjectToTokens);
|
|
}
|
|
return result;
|
|
}
|