Automated Action 545563e776 Implement comprehensive real-time chat API with NestJS
- 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.
2025-06-21 17:13:05 +00:00

59 lines
1.3 KiB
JavaScript

import isViablePhoneNumber from './isViablePhoneNumber.js'
// https://www.ietf.org/rfc/rfc3966.txt
/**
* @param {string} text - Phone URI (RFC 3966).
* @return {object} `{ ?number, ?ext }`.
*/
export function parseRFC3966(text) {
let number
let ext
// Replace "tel:" with "tel=" for parsing convenience.
text = text.replace(/^tel:/, 'tel=')
for (const part of text.split(';')) {
const [name, value] = part.split('=')
switch (name) {
case 'tel':
number = value
break
case 'ext':
ext = value
break
case 'phone-context':
// Only "country contexts" are supported.
// "Domain contexts" are ignored.
if (value[0] === '+') {
number = value + number
}
break
}
}
// If the phone number is not viable, then abort.
if (!isViablePhoneNumber(number)) {
return {}
}
const result = { number }
if (ext) {
result.ext = ext
}
return result
}
/**
* @param {object} - `{ ?number, ?extension }`.
* @return {string} Phone URI (RFC 3966).
*/
export function formatRFC3966({ number, ext }) {
if (!number) {
return ''
}
if (number[0] !== '+') {
throw new Error(`"formatRFC3966()" expects "number" to be in E.164 format.`)
}
return `tel:${number}${ext ? ';ext=' + ext : ''}`
}