@imqueue/core
Version:
Simple JSON-based messaging queue for inter service communication
41 lines (40 loc) • 1.78 kB
TypeScript
/*!
* Clustered messaging queue over Redis implementation
*
* I'm Queue Software Project
* Copyright (C) 2025 imqueue.com <support@imqueue.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* If you want to use this code in a closed source (commercial) project, you can
* purchase a proprietary commercial license. Please contact us at
* <support@imqueue.com> to get commercial licensing options.
*/
import { IMessageQueueConnection, IServerInput } from './IMessageQueue';
export interface ICluster {
add: <T extends IMessageQueueConnection>(server: IServerInput) => T;
remove: (server: IServerInput) => void;
find: <T extends IMessageQueueConnection>(server: IServerInput) => T | undefined;
}
export interface InitializedCluster extends ICluster {
id: string;
}
export declare abstract class ClusterManager {
protected clusters: InitializedCluster[];
protected constructor();
init(cluster: ICluster): InitializedCluster;
anyCluster(fn: (cluster: InitializedCluster) => Promise<void> | void): Promise<void>;
remove(cluster: string | InitializedCluster, destroy?: boolean): Promise<void>;
abstract destroy(): Promise<void>;
}