
- 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.
87 lines
2.8 KiB
TypeScript
87 lines
2.8 KiB
TypeScript
/*
|
|
* Copyright 2022 gRPC authors.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
*/
|
|
|
|
import { SubchannelRef } from "./channelz";
|
|
import { ConnectivityState } from "./connectivity-state";
|
|
import { Subchannel } from "./subchannel";
|
|
|
|
export type ConnectivityStateListener = (
|
|
subchannel: SubchannelInterface,
|
|
previousState: ConnectivityState,
|
|
newState: ConnectivityState,
|
|
keepaliveTime: number
|
|
) => void;
|
|
|
|
/**
|
|
* This is an interface for load balancing policies to use to interact with
|
|
* subchannels. This allows load balancing policies to wrap and unwrap
|
|
* subchannels.
|
|
*
|
|
* Any load balancing policy that wraps subchannels must unwrap the subchannel
|
|
* in the picker, so that other load balancing policies consistently have
|
|
* access to their own wrapper objects.
|
|
*/
|
|
export interface SubchannelInterface {
|
|
getConnectivityState(): ConnectivityState;
|
|
addConnectivityStateListener(listener: ConnectivityStateListener): void;
|
|
removeConnectivityStateListener(listener: ConnectivityStateListener): void;
|
|
startConnecting(): void;
|
|
getAddress(): string;
|
|
throttleKeepalive(newKeepaliveTime: number): void;
|
|
ref(): void;
|
|
unref(): void;
|
|
getChannelzRef(): SubchannelRef;
|
|
/**
|
|
* If this is a wrapper, return the wrapped subchannel, otherwise return this
|
|
*/
|
|
getRealSubchannel(): Subchannel;
|
|
}
|
|
|
|
export abstract class BaseSubchannelWrapper implements SubchannelInterface {
|
|
constructor(protected child: SubchannelInterface) {}
|
|
|
|
getConnectivityState(): ConnectivityState {
|
|
return this.child.getConnectivityState();
|
|
}
|
|
addConnectivityStateListener(listener: ConnectivityStateListener): void {
|
|
this.child.addConnectivityStateListener(listener);
|
|
}
|
|
removeConnectivityStateListener(listener: ConnectivityStateListener): void {
|
|
this.child.removeConnectivityStateListener(listener);
|
|
}
|
|
startConnecting(): void {
|
|
this.child.startConnecting();
|
|
}
|
|
getAddress(): string {
|
|
return this.child.getAddress();
|
|
}
|
|
throttleKeepalive(newKeepaliveTime: number): void {
|
|
this.child.throttleKeepalive(newKeepaliveTime);
|
|
}
|
|
ref(): void {
|
|
this.child.ref();
|
|
}
|
|
unref(): void {
|
|
this.child.unref();
|
|
}
|
|
getChannelzRef(): SubchannelRef {
|
|
return this.child.getChannelzRef();
|
|
}
|
|
getRealSubchannel(): Subchannel {
|
|
return this.child.getRealSubchannel();
|
|
}
|
|
} |