
- 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.
22 lines
988 B
TypeScript
22 lines
988 B
TypeScript
import type { IncomingMessage } from 'http';
|
|
/**
|
|
* Type alias to keep compatibility with @types/body-parser
|
|
* @see https://github.com/DefinitelyTyped/DefinitelyTyped/blob/dcd1673c4fa18a15ea8cd8ff8af7d563bb6dc8e6/types/body-parser/index.d.ts#L48-L66#L48-L66
|
|
* @publicApi
|
|
*/
|
|
export interface NestExpressBodyParserOptions {
|
|
/** When set to true, then deflated (compressed) bodies will be inflated; when false, deflated bodies are rejected. Defaults to true. */
|
|
inflate?: boolean | undefined;
|
|
/**
|
|
* Controls the maximum request body size. If this is a number,
|
|
* then the value specifies the number of bytes; if it is a string,
|
|
* the value is passed to the bytes library for parsing. Defaults to '100kb'.
|
|
*/
|
|
limit?: number | string | undefined;
|
|
/**
|
|
* The type option is used to determine what media type the middleware will parse
|
|
*/
|
|
type?: string | string[] | ((req: IncomingMessage) => any) | undefined;
|
|
[key: string]: unknown;
|
|
}
|