@theia/core
Version:
Theia is a cloud & desktop IDE framework implemented in TypeScript.
47 lines (44 loc) • 2.23 kB
text/typescript
// *****************************************************************************
// Copyright (C) 2018 TypeFox and others.
//
// This program and the accompanying materials are made available under the
// terms of the Eclipse Public License v. 2.0 which is available at
// http://www.eclipse.org/legal/epl-2.0.
//
// This Source Code may also be made available under the following Secondary
// Licenses when the conditions for such availability set forth in the Eclipse
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
// with the GNU Classpath Exception which is available at
// https://www.gnu.org/software/classpath/license.html.
//
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
// *****************************************************************************
import { Socket } from 'socket.io';
import { Channel } from '../../common/message-rpc/channel';
export interface MessagingService {
/**
* Accept a web socket channel on the given path.
* A path supports the route syntax: https://github.com/rcs/route-parser#what-can-i-use-in-my-routes.
*/
wsChannel(path: string, callback: (params: MessagingService.PathParams, channel: Channel) => void): void;
/**
* Accept a web socket connection on the given path.
* A path supports the route syntax: https://github.com/rcs/route-parser#what-can-i-use-in-my-routes.
*
* #### Important
* Prefer using web socket channels over establishing new web socket connection. Clients can handle only limited amount of web sockets
* and excessive amount can cause performance degradation. All web socket channels share a single web socket connection.
*/
ws(path: string, callback: (params: MessagingService.PathParams, socket: Socket) => void): void;
}
export namespace MessagingService {
/** Inversify container identifier for the `MessagingService` component. */
export const Identifier = Symbol('MessagingService');
export interface PathParams {
[name: string]: string
}
export const Contribution = Symbol('MessagingService.Contribution');
export interface Contribution {
configure(service: MessagingService): void;
}
}