mirror of
https://github.com/billsonnn/nitro-renderer.git
synced 2025-01-19 06:46:28 +01:00
Move communication interfaces
This commit is contained in:
parent
d8fca7188f
commit
e24ed2eb3b
@ -1,6 +1,6 @@
|
||||
import { IEventDispatcher } from '../events/IEventDispatcher';
|
||||
import { IDisposable } from './disposable/IDisposable';
|
||||
import { INitroLogger } from './logger/INitroLogger';
|
||||
import { IEventDispatcher } from '../events';
|
||||
import { IDisposable } from './IDisposable';
|
||||
import { INitroLogger } from './INitroLogger';
|
||||
|
||||
export interface INitroManager extends IDisposable
|
||||
{
|
||||
@ -9,4 +9,4 @@ export interface INitroManager extends IDisposable
|
||||
events: IEventDispatcher;
|
||||
isLoaded: boolean;
|
||||
isLoading: boolean;
|
||||
}
|
||||
}
|
@ -1,6 +1,6 @@
|
||||
import { IDisposable } from './disposable/IDisposable';
|
||||
import { IDisposable } from './IDisposable';
|
||||
|
||||
export interface IUpdateReceiver extends IDisposable
|
||||
{
|
||||
update(time: number): void;
|
||||
}
|
||||
}
|
4
src/api/common/index.ts
Normal file
4
src/api/common/index.ts
Normal file
@ -0,0 +1,4 @@
|
||||
export * from './IDisposable';
|
||||
export * from './INitroLogger';
|
||||
export * from './INitroManager';
|
||||
export * from './IUpdateReceiver';
|
12
src/api/communication/IBinaryReader.ts
Normal file
12
src/api/communication/IBinaryReader.ts
Normal file
@ -0,0 +1,12 @@
|
||||
export interface IBinaryReader
|
||||
{
|
||||
readBytes(length: number): IBinaryReader;
|
||||
readByte(): number;
|
||||
readShort(): number;
|
||||
readInt(): number;
|
||||
readFloat(): number;
|
||||
readDouble(): number;
|
||||
remaining(): number;
|
||||
toString(encoding?: string): string;
|
||||
toArrayBuffer(): ArrayBuffer;
|
||||
}
|
11
src/api/communication/IBinaryWriter.ts
Normal file
11
src/api/communication/IBinaryWriter.ts
Normal file
@ -0,0 +1,11 @@
|
||||
export interface IBinaryWriter
|
||||
{
|
||||
writeByte(byte: number): IBinaryWriter;
|
||||
writeBytes(bytes: ArrayBuffer | number[]): IBinaryWriter;
|
||||
writeShort(short: number): IBinaryWriter;
|
||||
writeInt(integer: number): IBinaryWriter;
|
||||
writeString(string: string, includeLength?: boolean): IBinaryWriter;
|
||||
getBuffer(): ArrayBuffer;
|
||||
position: number;
|
||||
toString(encoding?: string): string;
|
||||
}
|
9
src/api/communication/ICodec.ts
Normal file
9
src/api/communication/ICodec.ts
Normal file
@ -0,0 +1,9 @@
|
||||
import { IBinaryWriter } from './IBinaryWriter';
|
||||
import { IConnection } from './IConnection';
|
||||
import { IMessageDataWrapper } from './IMessageDataWrapper';
|
||||
|
||||
export interface ICodec
|
||||
{
|
||||
encode(header: number, messages: any[]): IBinaryWriter;
|
||||
decode(connection: IConnection): IMessageDataWrapper[];
|
||||
}
|
8
src/api/communication/ICommunicationManager.ts
Normal file
8
src/api/communication/ICommunicationManager.ts
Normal file
@ -0,0 +1,8 @@
|
||||
import { IDisposable } from '../common';
|
||||
import { IConnection } from './IConnection';
|
||||
import { IConnectionStateListener } from './IConnectionStateListener';
|
||||
|
||||
export interface ICommunicationManager extends IDisposable
|
||||
{
|
||||
createConnection(stateListener?: IConnectionStateListener): IConnection;
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
import { IEventDispatcher } from '../../events/IEventDispatcher';
|
||||
import { IMessageComposer } from '../messages/IMessageComposer';
|
||||
import { IMessageConfiguration } from '../messages/IMessageConfiguration';
|
||||
import { IMessageEvent } from '../messages/IMessageEvent';
|
||||
import { IEventDispatcher } from '../events';
|
||||
import { IMessageComposer } from './IMessageComposer';
|
||||
import { IMessageConfiguration } from './IMessageConfiguration';
|
||||
import { IMessageEvent } from './IMessageEvent';
|
||||
|
||||
export interface IConnection extends IEventDispatcher
|
||||
{
|
||||
@ -16,4 +16,4 @@ export interface IConnection extends IEventDispatcher
|
||||
removeMessageEvent(event: IMessageEvent): void;
|
||||
isAuthenticated: boolean;
|
||||
dataBuffer: ArrayBuffer;
|
||||
}
|
||||
}
|
@ -1,9 +1,9 @@
|
||||
import { BinaryReader } from '../codec/BinaryReader';
|
||||
import { IBinaryReader } from './IBinaryReader';
|
||||
|
||||
export interface IMessageDataWrapper
|
||||
{
|
||||
readByte(): number;
|
||||
readBytes(length: number): BinaryReader;
|
||||
readBytes(length: number): IBinaryReader;
|
||||
readBoolean(): boolean;
|
||||
readShort(): number;
|
||||
readInt(): number;
|
@ -1,4 +1,4 @@
|
||||
import { IConnection } from '../connections/IConnection';
|
||||
import { IConnection } from './IConnection';
|
||||
import { IMessageParser } from './IMessageParser';
|
||||
|
||||
export interface IMessageEvent
|
||||
@ -8,4 +8,4 @@ export interface IMessageEvent
|
||||
parserClass: Function;
|
||||
parser: IMessageParser;
|
||||
connection: IConnection;
|
||||
}
|
||||
}
|
12
src/api/communication/index.ts
Normal file
12
src/api/communication/index.ts
Normal file
@ -0,0 +1,12 @@
|
||||
export * from './enums';
|
||||
export * from './IBinaryReader';
|
||||
export * from './IBinaryWriter';
|
||||
export * from './ICodec';
|
||||
export * from './ICommunicationManager';
|
||||
export * from './IConnection';
|
||||
export * from './IConnectionStateListener';
|
||||
export * from './IMessageComposer';
|
||||
export * from './IMessageConfiguration';
|
||||
export * from './IMessageDataWrapper';
|
||||
export * from './IMessageEvent';
|
||||
export * from './IMessageParser';
|
@ -1,12 +1,11 @@
|
||||
import { INitroLogger } from '../common';
|
||||
import { IDisposable } from '../common/disposable/IDisposable';
|
||||
import { NitroEvent } from './NitroEvent';
|
||||
import { IDisposable, INitroLogger } from '../common';
|
||||
import { INitroEvent } from './INitroEvent';
|
||||
|
||||
export interface IEventDispatcher extends IDisposable
|
||||
{
|
||||
addEventListener(type: string, callback: Function): void
|
||||
removeEventListener(type: string, callback: Function): void;
|
||||
removeAllListeners(): void;
|
||||
dispatchEvent(event: NitroEvent): boolean;
|
||||
dispatchEvent(event: INitroEvent): boolean;
|
||||
logger: INitroLogger;
|
||||
}
|
4
src/api/events/INitroEvent.ts
Normal file
4
src/api/events/INitroEvent.ts
Normal file
@ -0,0 +1,4 @@
|
||||
export interface INitroEvent
|
||||
{
|
||||
type: string;
|
||||
}
|
4
src/api/events/index.ts
Normal file
4
src/api/events/index.ts
Normal file
@ -0,0 +1,4 @@
|
||||
export * from './IEventDispatcher';
|
||||
export * from './ILinkEventTracker';
|
||||
export * from './INitroEvent';
|
||||
export * from './IWorkerEventTracker';
|
@ -9,3 +9,6 @@ export * from './asset/visualization/animation';
|
||||
export * from './asset/visualization/color';
|
||||
export * from './asset/visualization/gestures';
|
||||
export * from './asset/visualization/postures';
|
||||
export * from './common';
|
||||
export * from './communication';
|
||||
export * from './events';
|
||||
|
@ -1,6 +1,4 @@
|
||||
import { IAssetManager } from '../api';
|
||||
import { IDisposable } from './common/disposable/IDisposable';
|
||||
import { ICommunicationManager } from './communication/ICommunicationManager';
|
||||
import { IAssetManager, ICommunicationManager, IDisposable } from '../api';
|
||||
import { IConfigurationManager } from './configuration/IConfigurationManager';
|
||||
|
||||
export interface INitroCore extends IDisposable
|
||||
|
@ -1,8 +1,7 @@
|
||||
import { IAssetManager } from '../api';
|
||||
import { IAssetManager, ICommunicationManager } from '../api';
|
||||
import { AssetManager } from './asset/AssetManager';
|
||||
import { Disposable } from './common/disposable/Disposable';
|
||||
import { Disposable } from './common/Disposable';
|
||||
import { CommunicationManager } from './communication/CommunicationManager';
|
||||
import { ICommunicationManager } from './communication/ICommunicationManager';
|
||||
import { ConfigurationManager } from './configuration/ConfigurationManager';
|
||||
import { IConfigurationManager } from './configuration/IConfigurationManager';
|
||||
import { INitroCore } from './INitroCore';
|
||||
|
@ -1,11 +1,10 @@
|
||||
import { BaseTexture, Resource, Texture } from '@pixi/core';
|
||||
import { Loader, LoaderResource } from '@pixi/loaders';
|
||||
import { Spritesheet } from '@pixi/spritesheet';
|
||||
import { IAssetData, IAssetManager, IGraphicAsset, IGraphicAssetCollection } from '../../api';
|
||||
import { IAssetData, IAssetManager, IGraphicAsset, IGraphicAssetCollection, INitroLogger } from '../../api';
|
||||
import { GraphicAssetCollection } from '../../room/object/visualization/utils/GraphicAssetCollection';
|
||||
import { Disposable } from '../common/disposable/Disposable';
|
||||
import { INitroLogger } from '../common/logger/INitroLogger';
|
||||
import { NitroLogger } from '../common/logger/NitroLogger';
|
||||
import { Disposable } from '../common/Disposable';
|
||||
import { NitroLogger } from '../common/NitroLogger';
|
||||
import { ArrayBufferToBase64 } from '../utils';
|
||||
import { NitroBundle } from './NitroBundle';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IDisposable } from './IDisposable';
|
||||
import { IDisposable } from '../../api';
|
||||
|
||||
export class Disposable implements IDisposable
|
||||
{
|
||||
@ -13,7 +13,7 @@ export class Disposable implements IDisposable
|
||||
|
||||
public dispose(): void
|
||||
{
|
||||
if(this._isDisposed || this._isDisposing) return;
|
||||
if (this._isDisposed || this._isDisposing) return;
|
||||
|
||||
this._isDisposing = true;
|
||||
|
||||
@ -37,4 +37,4 @@ export class Disposable implements IDisposable
|
||||
{
|
||||
return this._isDisposing;
|
||||
}
|
||||
}
|
||||
}
|
@ -1,4 +1,4 @@
|
||||
import { INitroLogger } from './INitroLogger';
|
||||
import { INitroLogger } from '../../api';
|
||||
|
||||
export class NitroLogger implements INitroLogger
|
||||
{
|
||||
@ -30,7 +30,7 @@ export class NitroLogger implements INitroLogger
|
||||
|
||||
public printMessage(modus: string, ...message: any[]): void
|
||||
{
|
||||
if(!this._print) return;
|
||||
if (!this._print) return;
|
||||
|
||||
NitroLogger.log(this._name, modus, ...message);
|
||||
}
|
||||
@ -39,7 +39,7 @@ export class NitroLogger implements INitroLogger
|
||||
{
|
||||
const logPrefix = `[Nitro] [${name}]`;
|
||||
|
||||
switch(modus)
|
||||
switch (modus)
|
||||
{
|
||||
case 'error':
|
||||
console.error(logPrefix, ...message);
|
@ -1,9 +1,7 @@
|
||||
import { IEventDispatcher, INitroLogger, INitroManager } from '../../api';
|
||||
import { EventDispatcher } from '../events/EventDispatcher';
|
||||
import { IEventDispatcher } from '../events/IEventDispatcher';
|
||||
import { Disposable } from './disposable/Disposable';
|
||||
import { INitroManager } from './INitroManager';
|
||||
import { INitroLogger } from './logger/INitroLogger';
|
||||
import { NitroLogger } from './logger/NitroLogger';
|
||||
import { Disposable } from './Disposable';
|
||||
import { NitroLogger } from './NitroLogger';
|
||||
|
||||
export class NitroManager extends Disposable implements INitroManager
|
||||
{
|
||||
@ -28,7 +26,7 @@ export class NitroManager extends Disposable implements INitroManager
|
||||
|
||||
public init(): void
|
||||
{
|
||||
if(this._isLoaded || this._isLoading || this.isDisposing) return;
|
||||
if (this._isLoaded || this._isLoading || this.isDisposing) return;
|
||||
|
||||
this._isLoading = true;
|
||||
|
||||
@ -45,7 +43,7 @@ export class NitroManager extends Disposable implements INitroManager
|
||||
|
||||
protected onDispose(): void
|
||||
{
|
||||
if(this._events) this._events.dispose();
|
||||
if (this._events) this._events.dispose();
|
||||
|
||||
super.onDispose();
|
||||
}
|
||||
@ -75,4 +73,4 @@ export class NitroManager extends Disposable implements INitroManager
|
||||
{
|
||||
return this._isLoading;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,2 +0,0 @@
|
||||
export * from './Disposable';
|
||||
export * from './IDisposable';
|
@ -1,5 +1,3 @@
|
||||
export * from './disposable';
|
||||
export * from './INitroManager';
|
||||
export * from './IUpdateReceiver';
|
||||
export * from './logger';
|
||||
export * from './Disposable';
|
||||
export * from './NitroLogger';
|
||||
export * from './NitroManager';
|
||||
|
@ -1,2 +0,0 @@
|
||||
export * from './INitroLogger';
|
||||
export * from './NitroLogger';
|
@ -1,9 +1,6 @@
|
||||
import { Disposable } from '../common/disposable/Disposable';
|
||||
import { IUpdateReceiver } from '../common/IUpdateReceiver';
|
||||
import { IConnection } from './connections/IConnection';
|
||||
import { IConnectionStateListener } from './connections/IConnectionStateListener';
|
||||
import { ICommunicationManager, IConnection, IConnectionStateListener, IUpdateReceiver } from '../../api';
|
||||
import { Disposable } from '../common/Disposable';
|
||||
import { SocketConnection } from './connections/SocketConnection';
|
||||
import { ICommunicationManager } from './ICommunicationManager';
|
||||
|
||||
export class CommunicationManager extends Disposable implements ICommunicationManager, IUpdateReceiver
|
||||
{
|
||||
@ -18,16 +15,16 @@ export class CommunicationManager extends Disposable implements ICommunicationMa
|
||||
|
||||
protected onDispose(): void
|
||||
{
|
||||
if(!this._connections || !this._connections.length) return;
|
||||
if (!this._connections || !this._connections.length) return;
|
||||
|
||||
for(const connection of this._connections.values()) connection && connection.dispose();
|
||||
for (const connection of this._connections.values()) connection && connection.dispose();
|
||||
}
|
||||
|
||||
public createConnection(stateListener: IConnectionStateListener = null): IConnection
|
||||
{
|
||||
const connection = new SocketConnection(this, stateListener);
|
||||
|
||||
if(!connection) return;
|
||||
if (!connection) return;
|
||||
|
||||
this._connections.push(connection);
|
||||
|
||||
@ -38,16 +35,16 @@ export class CommunicationManager extends Disposable implements ICommunicationMa
|
||||
{
|
||||
let index = 0;
|
||||
|
||||
while(index < this._connections.length)
|
||||
while (index < this._connections.length)
|
||||
{
|
||||
const connection = this._connections[index];
|
||||
|
||||
connection.processReceivedData();
|
||||
|
||||
if(this.disposed) return;
|
||||
if (this.disposed) return;
|
||||
|
||||
if(connection.disposed) this._connections.splice(index, 1);
|
||||
if (connection.disposed) this._connections.splice(index, 1);
|
||||
else index++;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,8 +0,0 @@
|
||||
import { IDisposable } from '../common/disposable/IDisposable';
|
||||
import { IConnection } from './connections/IConnection';
|
||||
import { IConnectionStateListener } from './connections/IConnectionStateListener';
|
||||
|
||||
export interface ICommunicationManager extends IDisposable
|
||||
{
|
||||
createConnection(stateListener?: IConnectionStateListener): IConnection;
|
||||
}
|
@ -1,9 +0,0 @@
|
||||
import { BinaryWriter } from './BinaryWriter';
|
||||
import { IConnection } from '../connections/IConnection';
|
||||
import { IMessageDataWrapper } from '../messages/IMessageDataWrapper';
|
||||
|
||||
export interface ICodec
|
||||
{
|
||||
encode(header: number, messages: any[]): BinaryWriter;
|
||||
decode(connection: IConnection): IMessageDataWrapper[];
|
||||
}
|
@ -1,27 +1,26 @@
|
||||
import { IMessageDataWrapper } from '../../messages/IMessageDataWrapper';
|
||||
import { BinaryReader } from '../BinaryReader';
|
||||
import { IBinaryReader, IMessageDataWrapper } from '../../../../api';
|
||||
|
||||
export class EvaWireDataWrapper implements IMessageDataWrapper
|
||||
{
|
||||
private _header: number;
|
||||
private _buffer: BinaryReader;
|
||||
private _buffer: IBinaryReader;
|
||||
|
||||
constructor(header: number, buffer: BinaryReader)
|
||||
constructor(header: number, buffer: IBinaryReader)
|
||||
{
|
||||
this._header = header;
|
||||
this._buffer = buffer;
|
||||
}
|
||||
|
||||
public readBytes(length: number): BinaryReader
|
||||
public readBytes(length: number): IBinaryReader
|
||||
{
|
||||
if(!this._buffer) return null;
|
||||
if (!this._buffer) return null;
|
||||
|
||||
return this._buffer.readBytes(length);
|
||||
}
|
||||
|
||||
public readByte(): number
|
||||
{
|
||||
if(!this._buffer) return -1;
|
||||
if (!this._buffer) return -1;
|
||||
|
||||
return this._buffer.readByte();
|
||||
}
|
||||
@ -33,28 +32,28 @@ export class EvaWireDataWrapper implements IMessageDataWrapper
|
||||
|
||||
public readShort(): number
|
||||
{
|
||||
if(!this._buffer) return -1;
|
||||
if (!this._buffer) return -1;
|
||||
|
||||
return this._buffer.readShort();
|
||||
}
|
||||
|
||||
public readInt(): number
|
||||
{
|
||||
if(!this._buffer) return -1;
|
||||
if (!this._buffer) return -1;
|
||||
|
||||
return this._buffer.readInt();
|
||||
}
|
||||
|
||||
public readFloat(): number
|
||||
{
|
||||
if(!this._buffer) return -1;
|
||||
if (!this._buffer) return -1;
|
||||
|
||||
return this._buffer.readFloat();
|
||||
}
|
||||
|
||||
public readDouble(): number
|
||||
{
|
||||
if(!this._buffer) return -1;
|
||||
if (!this._buffer) return -1;
|
||||
|
||||
return this._buffer.readDouble();
|
||||
}
|
||||
|
@ -1,33 +1,31 @@
|
||||
import { IConnection } from '../../connections/IConnection';
|
||||
import { IMessageDataWrapper } from '../../messages/IMessageDataWrapper';
|
||||
import { IBinaryWriter, ICodec, IConnection, IMessageDataWrapper } from '../../../../api';
|
||||
import { BinaryReader } from '../BinaryReader';
|
||||
import { BinaryWriter } from '../BinaryWriter';
|
||||
import { Byte } from '../Byte';
|
||||
import { ICodec } from '../ICodec';
|
||||
import { Short } from '../Short';
|
||||
import { EvaWireDataWrapper } from './EvaWireDataWrapper';
|
||||
|
||||
export class EvaWireFormat implements ICodec
|
||||
{
|
||||
public encode(header: number, messages: any[]): BinaryWriter
|
||||
public encode(header: number, messages: any[]): IBinaryWriter
|
||||
{
|
||||
const writer = new BinaryWriter();
|
||||
|
||||
writer.writeShort(header);
|
||||
|
||||
for(const value of messages)
|
||||
for (const value of messages)
|
||||
{
|
||||
let type: string = typeof value;
|
||||
|
||||
if(type === 'object')
|
||||
if (type === 'object')
|
||||
{
|
||||
if(value === null) type = 'null';
|
||||
else if(value instanceof Byte) type = 'byte';
|
||||
else if(value instanceof Short) type = 'short';
|
||||
else if(value instanceof ArrayBuffer) type = 'arraybuffer';
|
||||
if (value === null) type = 'null';
|
||||
else if (value instanceof Byte) type = 'byte';
|
||||
else if (value instanceof Short) type = 'short';
|
||||
else if (value instanceof ArrayBuffer) type = 'arraybuffer';
|
||||
}
|
||||
|
||||
switch(type)
|
||||
switch (type)
|
||||
{
|
||||
case 'undefined':
|
||||
case 'null':
|
||||
@ -46,7 +44,7 @@ export class EvaWireFormat implements ICodec
|
||||
writer.writeByte(value ? 1 : 0);
|
||||
break;
|
||||
case 'string':
|
||||
if(!value) writer.writeShort(0);
|
||||
if (!value) writer.writeShort(0);
|
||||
else
|
||||
{
|
||||
writer.writeString(value, true);
|
||||
@ -60,25 +58,25 @@ export class EvaWireFormat implements ICodec
|
||||
|
||||
const buffer = writer.getBuffer();
|
||||
|
||||
if(!buffer) return null;
|
||||
if (!buffer) return null;
|
||||
|
||||
return new BinaryWriter().writeInt(buffer.byteLength).writeBytes(buffer);
|
||||
}
|
||||
|
||||
public decode(connection: IConnection): IMessageDataWrapper[]
|
||||
{
|
||||
if(!connection || !connection.dataBuffer || !connection.dataBuffer.byteLength) return null;
|
||||
if (!connection || !connection.dataBuffer || !connection.dataBuffer.byteLength) return null;
|
||||
|
||||
const wrappers: IMessageDataWrapper[] = [];
|
||||
|
||||
while(connection.dataBuffer.byteLength)
|
||||
while (connection.dataBuffer.byteLength)
|
||||
{
|
||||
if(connection.dataBuffer.byteLength < 4) break;
|
||||
if (connection.dataBuffer.byteLength < 4) break;
|
||||
|
||||
const container = new BinaryReader(connection.dataBuffer);
|
||||
const length = container.readInt();
|
||||
|
||||
if(length > (connection.dataBuffer.byteLength - 4)) break;
|
||||
if (length > (connection.dataBuffer.byteLength - 4)) break;
|
||||
|
||||
const extracted = container.readBytes(length);
|
||||
|
||||
|
@ -2,5 +2,4 @@ export * from './BinaryReader';
|
||||
export * from './BinaryWriter';
|
||||
export * from './Byte';
|
||||
export * from './evawire';
|
||||
export * from './ICodec';
|
||||
export * from './Short';
|
||||
|
@ -1,17 +1,9 @@
|
||||
import { ICodec, ICommunicationManager, IConnection, IConnectionStateListener, IMessageComposer, IMessageConfiguration, IMessageDataWrapper, IMessageEvent, WebSocketEventEnum } from '../../../api';
|
||||
import { Nitro } from '../../../nitro/Nitro';
|
||||
import { EventDispatcher } from '../../events/EventDispatcher';
|
||||
import { EvaWireFormat } from '../codec/evawire/EvaWireFormat';
|
||||
import { ICodec } from '../codec/ICodec';
|
||||
import { SocketConnectionEvent } from '../events/SocketConnectionEvent';
|
||||
import { ICommunicationManager } from '../ICommunicationManager';
|
||||
import { IMessageComposer } from '../messages/IMessageComposer';
|
||||
import { IMessageConfiguration } from '../messages/IMessageConfiguration';
|
||||
import { IMessageDataWrapper } from '../messages/IMessageDataWrapper';
|
||||
import { IMessageEvent } from '../messages/IMessageEvent';
|
||||
import { MessageClassManager } from '../messages/MessageClassManager';
|
||||
import { WebSocketEventEnum } from './enums/WebSocketEventEnum';
|
||||
import { IConnection } from './IConnection';
|
||||
import { IConnectionStateListener } from './IConnectionStateListener';
|
||||
|
||||
export class SocketConnection extends EventDispatcher implements IConnection
|
||||
{
|
||||
@ -53,7 +45,7 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
public init(socketUrl: string): void
|
||||
{
|
||||
if(this._stateListener)
|
||||
if (this._stateListener)
|
||||
{
|
||||
this._stateListener.connectionInit(socketUrl);
|
||||
}
|
||||
@ -76,13 +68,13 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
public onReady(): void
|
||||
{
|
||||
if(this._isReady) return;
|
||||
if (this._isReady) return;
|
||||
|
||||
this._isReady = true;
|
||||
|
||||
if(this._pendingServerMessages && this._pendingServerMessages.length) this.processWrappers(...this._pendingServerMessages);
|
||||
if (this._pendingServerMessages && this._pendingServerMessages.length) this.processWrappers(...this._pendingServerMessages);
|
||||
|
||||
if(this._pendingClientMessages && this._pendingClientMessages.length) this.send(...this._pendingClientMessages);
|
||||
if (this._pendingClientMessages && this._pendingClientMessages.length) this.send(...this._pendingClientMessages);
|
||||
|
||||
this._pendingServerMessages = [];
|
||||
this._pendingClientMessages = [];
|
||||
@ -90,7 +82,7 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private createSocket(socketUrl: string): void
|
||||
{
|
||||
if(!socketUrl) return;
|
||||
if (!socketUrl) return;
|
||||
|
||||
this.destroySocket();
|
||||
|
||||
@ -105,14 +97,14 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private destroySocket(): void
|
||||
{
|
||||
if(!this._socket) return;
|
||||
if (!this._socket) return;
|
||||
|
||||
this._socket.removeEventListener(WebSocketEventEnum.CONNECTION_OPENED, this.onOpen);
|
||||
this._socket.removeEventListener(WebSocketEventEnum.CONNECTION_CLOSED, this.onClose);
|
||||
this._socket.removeEventListener(WebSocketEventEnum.CONNECTION_ERROR, this.onError);
|
||||
this._socket.removeEventListener(WebSocketEventEnum.CONNECTION_MESSAGE, this.onMessage);
|
||||
|
||||
if(this._socket.readyState === WebSocket.OPEN) this._socket.close();
|
||||
if (this._socket.readyState === WebSocket.OPEN) this._socket.close();
|
||||
|
||||
this._socket = null;
|
||||
}
|
||||
@ -134,7 +126,7 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private onMessage(event: MessageEvent): void
|
||||
{
|
||||
if(!event) return;
|
||||
if (!event) return;
|
||||
|
||||
//this.dispatchConnectionEvent(SocketConnectionEvent.CONNECTION_MESSAGE, event);
|
||||
|
||||
@ -162,28 +154,28 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
public send(...composers: IMessageComposer<unknown[]>[]): boolean
|
||||
{
|
||||
if(this.disposed || !composers) return false;
|
||||
if (this.disposed || !composers) return false;
|
||||
|
||||
composers = [...composers];
|
||||
|
||||
if(this._isAuthenticated && !this._isReady)
|
||||
if (this._isAuthenticated && !this._isReady)
|
||||
{
|
||||
if(!this._pendingClientMessages) this._pendingClientMessages = [];
|
||||
if (!this._pendingClientMessages) this._pendingClientMessages = [];
|
||||
|
||||
this._pendingClientMessages.push(...composers);
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
for(const composer of composers)
|
||||
for (const composer of composers)
|
||||
{
|
||||
if(!composer) continue;
|
||||
if (!composer) continue;
|
||||
|
||||
const header = this._messages.getComposerId(composer);
|
||||
|
||||
if(header === -1)
|
||||
if (header === -1)
|
||||
{
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log(`Unknown Composer: ${composer.constructor.name}`);
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log(`Unknown Composer: ${composer.constructor.name}`);
|
||||
|
||||
continue;
|
||||
}
|
||||
@ -191,14 +183,14 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
const message = composer.getMessageArray();
|
||||
const encoded = this._codec.encode(header, message);
|
||||
|
||||
if(!encoded)
|
||||
if (!encoded)
|
||||
{
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('Encoding Failed', composer.constructor.name);
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('Encoding Failed', composer.constructor.name);
|
||||
|
||||
continue;
|
||||
}
|
||||
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('OutgoingComposer', header, composer.constructor.name, message);
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('OutgoingComposer', header, composer.constructor.name, message);
|
||||
|
||||
this.write(encoded.getBuffer());
|
||||
}
|
||||
@ -208,7 +200,7 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private write(buffer: ArrayBuffer): void
|
||||
{
|
||||
if(this._socket.readyState !== WebSocket.OPEN) return;
|
||||
if (this._socket.readyState !== WebSocket.OPEN) return;
|
||||
|
||||
this._socket.send(buffer);
|
||||
}
|
||||
@ -230,11 +222,11 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
{
|
||||
const wrappers = this.splitReceivedMessages();
|
||||
|
||||
if(!wrappers || !wrappers.length) return;
|
||||
if (!wrappers || !wrappers.length) return;
|
||||
|
||||
if(this._isAuthenticated && !this._isReady)
|
||||
if (this._isAuthenticated && !this._isReady)
|
||||
{
|
||||
if(!this._pendingServerMessages) this._pendingServerMessages = [];
|
||||
if (!this._pendingServerMessages) this._pendingServerMessages = [];
|
||||
|
||||
this._pendingServerMessages.push(...wrappers);
|
||||
|
||||
@ -246,17 +238,17 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private processWrappers(...wrappers: IMessageDataWrapper[]): void
|
||||
{
|
||||
if(!wrappers || !wrappers.length) return;
|
||||
if (!wrappers || !wrappers.length) return;
|
||||
|
||||
for(const wrapper of wrappers)
|
||||
for (const wrapper of wrappers)
|
||||
{
|
||||
if(!wrapper) continue;
|
||||
if (!wrapper) continue;
|
||||
|
||||
const messages = this.getMessagesForWrapper(wrapper);
|
||||
|
||||
if(!messages || !messages.length) continue;
|
||||
if (!messages || !messages.length) continue;
|
||||
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('IncomingMessage', wrapper.header, messages[0].constructor.name, messages[0].parser);
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('IncomingMessage', wrapper.header, messages[0].constructor.name, messages[0].parser);
|
||||
|
||||
this.handleMessages(...messages);
|
||||
}
|
||||
@ -264,7 +256,7 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private splitReceivedMessages(): IMessageDataWrapper[]
|
||||
{
|
||||
if(!this._dataBuffer || !this._dataBuffer.byteLength) return null;
|
||||
if (!this._dataBuffer || !this._dataBuffer.byteLength) return null;
|
||||
|
||||
return this._codec.decode(this);
|
||||
}
|
||||
@ -281,13 +273,13 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
|
||||
private getMessagesForWrapper(wrapper: IMessageDataWrapper): IMessageEvent[]
|
||||
{
|
||||
if(!wrapper) return null;
|
||||
if (!wrapper) return null;
|
||||
|
||||
const events = this._messages.getEvents(wrapper.header);
|
||||
|
||||
if(!events || !events.length)
|
||||
if (!events || !events.length)
|
||||
{
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('IncomingMessage', wrapper.header, 'UNREGISTERED', wrapper);
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.packet.log')) this.logger.log('IncomingMessage', wrapper.header, 'UNREGISTERED', wrapper);
|
||||
|
||||
return;
|
||||
}
|
||||
@ -297,9 +289,9 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
//@ts-ignore
|
||||
const parser = new events[0].parserClass();
|
||||
|
||||
if(!parser || !parser.flush() || !parser.parse(wrapper)) return null;
|
||||
if (!parser || !parser.flush() || !parser.parse(wrapper)) return null;
|
||||
|
||||
for(const event of events) (event.parser = parser);
|
||||
for (const event of events) (event.parser = parser);
|
||||
}
|
||||
|
||||
catch (e)
|
||||
@ -316,33 +308,33 @@ export class SocketConnection extends EventDispatcher implements IConnection
|
||||
{
|
||||
messages = [...messages];
|
||||
|
||||
for(const message of messages)
|
||||
for (const message of messages)
|
||||
{
|
||||
if(!message) continue;
|
||||
if (!message) continue;
|
||||
|
||||
message.connection = this;
|
||||
|
||||
if(message.callBack) message.callBack(message);
|
||||
if (message.callBack) message.callBack(message);
|
||||
}
|
||||
}
|
||||
|
||||
public registerMessages(configuration: IMessageConfiguration): void
|
||||
{
|
||||
if(!configuration) return;
|
||||
if (!configuration) return;
|
||||
|
||||
this._messages.registerMessages(configuration);
|
||||
}
|
||||
|
||||
public addMessageEvent(event: IMessageEvent): void
|
||||
{
|
||||
if(!event || !this._messages) return;
|
||||
if (!event || !this._messages) return;
|
||||
|
||||
this._messages.registerMessageEvent(event);
|
||||
}
|
||||
|
||||
public removeMessageEvent(event: IMessageEvent): void
|
||||
{
|
||||
if(!event || !this._messages) return;
|
||||
if (!event || !this._messages) return;
|
||||
|
||||
this._messages.removeMessageEvent(event);
|
||||
}
|
||||
|
@ -1,4 +1 @@
|
||||
export * from './enums';
|
||||
export * from './IConnection';
|
||||
export * from './IConnectionStateListener';
|
||||
export * from './SocketConnection';
|
||||
|
@ -1,5 +1,5 @@
|
||||
import { IConnection } from '../../../api';
|
||||
import { NitroEvent } from '../../events/NitroEvent';
|
||||
import { IConnection } from '../connections/IConnection';
|
||||
|
||||
export class SocketConnectionEvent extends NitroEvent
|
||||
{
|
||||
@ -28,4 +28,4 @@ export class SocketConnectionEvent extends NitroEvent
|
||||
{
|
||||
return this._originalEvent;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -2,5 +2,4 @@ export * from './codec';
|
||||
export * from './CommunicationManager';
|
||||
export * from './connections';
|
||||
export * from './events';
|
||||
export * from './ICommunicationManager';
|
||||
export * from './messages';
|
||||
|
@ -1,6 +1,4 @@
|
||||
import { IMessageComposer } from './IMessageComposer';
|
||||
import { IMessageConfiguration } from './IMessageConfiguration';
|
||||
import { IMessageEvent } from './IMessageEvent';
|
||||
import { IMessageComposer, IMessageConfiguration, IMessageEvent } from '../../../api';
|
||||
import { MessageEvent } from './MessageEvent';
|
||||
|
||||
export class MessageClassManager
|
||||
@ -25,36 +23,36 @@ export class MessageClassManager
|
||||
|
||||
public registerMessages(configuration: IMessageConfiguration): void
|
||||
{
|
||||
for(const [ header, handler ] of configuration.events) this.registerMessageEventClass(header, handler);
|
||||
for (const [header, handler] of configuration.events) this.registerMessageEventClass(header, handler);
|
||||
|
||||
for(const [ header, handler ] of configuration.composers) this.registerMessageComposerClass(header, handler);
|
||||
for (const [header, handler] of configuration.composers) this.registerMessageComposerClass(header, handler);
|
||||
}
|
||||
|
||||
private registerMessageEventClass(header: number, handler: Function): void
|
||||
{
|
||||
if(!header || !handler) return;
|
||||
if (!header || !handler) return;
|
||||
|
||||
this._messageIdByEvent.set(handler, header);
|
||||
}
|
||||
|
||||
private registerMessageComposerClass(header: number, handler: Function): void
|
||||
{
|
||||
if(!header || !handler) return;
|
||||
if (!header || !handler) return;
|
||||
|
||||
this._messageIdByComposer.set(handler, header);
|
||||
}
|
||||
|
||||
public registerMessageEvent(event: IMessageEvent): void
|
||||
{
|
||||
if(!event) return;
|
||||
if (!event) return;
|
||||
|
||||
const header = this.getEventId(event);
|
||||
|
||||
if(!header) return;
|
||||
if (!header) return;
|
||||
|
||||
let existing = this._messageInstancesById.get(header);
|
||||
|
||||
if(!existing || !existing.length)
|
||||
if (!existing || !existing.length)
|
||||
{
|
||||
existing = [];
|
||||
|
||||
@ -66,25 +64,25 @@ export class MessageClassManager
|
||||
|
||||
public removeMessageEvent(event: IMessageEvent): void
|
||||
{
|
||||
if(!event) return;
|
||||
if (!event) return;
|
||||
|
||||
const header = this.getEventId(event);
|
||||
|
||||
if(!header) return;
|
||||
if (!header) return;
|
||||
|
||||
const existing = this._messageInstancesById.get(header);
|
||||
|
||||
if(!existing) return;
|
||||
if (!existing) return;
|
||||
|
||||
for(const [ index, message ] of existing.entries())
|
||||
for (const [index, message] of existing.entries())
|
||||
{
|
||||
if(!message) continue;
|
||||
if (!message) continue;
|
||||
|
||||
if(message !== event) continue;
|
||||
if (message !== event) continue;
|
||||
|
||||
existing.splice(index, 1);
|
||||
|
||||
if(existing.length === 0) this._messageInstancesById.delete(header);
|
||||
if (existing.length === 0) this._messageInstancesById.delete(header);
|
||||
|
||||
message.dispose();
|
||||
|
||||
@ -94,36 +92,36 @@ export class MessageClassManager
|
||||
|
||||
public getEvents(header: number): IMessageEvent[]
|
||||
{
|
||||
if(!header) return;
|
||||
if (!header) return;
|
||||
|
||||
const existing = this._messageInstancesById.get(header);
|
||||
|
||||
if(!existing) return;
|
||||
if (!existing) return;
|
||||
|
||||
return existing;
|
||||
}
|
||||
|
||||
public getEventId(event: IMessageEvent): number
|
||||
{
|
||||
if(!event) return -1;
|
||||
if (!event) return -1;
|
||||
|
||||
//@ts-ignore
|
||||
const name = (event instanceof MessageEvent ? event.constructor : event) as Function;
|
||||
|
||||
const existing = this._messageIdByEvent.get(name);
|
||||
|
||||
if(!existing) return -1;
|
||||
if (!existing) return -1;
|
||||
|
||||
return existing;
|
||||
}
|
||||
|
||||
public getComposerId(composer: IMessageComposer<unknown[]>): number
|
||||
{
|
||||
if(!composer) return -1;
|
||||
if (!composer) return -1;
|
||||
|
||||
const existing = this._messageIdByComposer.get(composer.constructor);
|
||||
|
||||
if(!existing) return -1;
|
||||
if (!existing) return -1;
|
||||
|
||||
return existing;
|
||||
}
|
||||
|
@ -1,6 +1,4 @@
|
||||
import { IConnection } from '../connections/IConnection';
|
||||
import { IMessageEvent } from './IMessageEvent';
|
||||
import { IMessageParser } from './IMessageParser';
|
||||
import { IConnection, IMessageEvent, IMessageParser } from '../../../api';
|
||||
|
||||
export class MessageEvent implements IMessageEvent
|
||||
{
|
||||
@ -54,4 +52,4 @@ export class MessageEvent implements IMessageEvent
|
||||
{
|
||||
this._connection = connection;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,2 @@
|
||||
export * from './IMessageComposer';
|
||||
export * from './IMessageConfiguration';
|
||||
export * from './IMessageDataWrapper';
|
||||
export * from './IMessageEvent';
|
||||
export * from './IMessageParser';
|
||||
export * from './MessageClassManager';
|
||||
export * from './MessageEvent';
|
||||
|
@ -5,6 +5,7 @@ import { IConfigurationManager } from './IConfigurationManager';
|
||||
export class ConfigurationManager extends NitroManager implements IConfigurationManager
|
||||
{
|
||||
private _definitions: Map<string, unknown>;
|
||||
private _config: any;
|
||||
private _pendingUrls: string[];
|
||||
private _missingKeys: string[];
|
||||
|
||||
@ -13,6 +14,7 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
super();
|
||||
|
||||
this._definitions = new Map();
|
||||
this._config = [];
|
||||
this._pendingUrls = [];
|
||||
this._missingKeys = [];
|
||||
|
||||
@ -30,7 +32,7 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
|
||||
private loadNextConfiguration(): void
|
||||
{
|
||||
if(!this._pendingUrls.length)
|
||||
if (!this._pendingUrls.length)
|
||||
{
|
||||
this.dispatchConfigurationEvent(ConfigurationEvent.LOADED);
|
||||
|
||||
@ -42,7 +44,7 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
|
||||
public loadConfigurationFromUrl(url: string): void
|
||||
{
|
||||
if(!url || (url === ''))
|
||||
if (!url || (url === ''))
|
||||
{
|
||||
this.dispatchConfigurationEvent(ConfigurationEvent.FAILED);
|
||||
|
||||
@ -57,13 +59,13 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
|
||||
private onConfigurationLoaded(data: { [index: string]: any }, url: string): void
|
||||
{
|
||||
if(!data) return;
|
||||
if (!data) return;
|
||||
|
||||
if(this.parseConfiguration(data))
|
||||
if (this.parseConfiguration(data))
|
||||
{
|
||||
const index = this._pendingUrls.indexOf(url);
|
||||
|
||||
if(index >= 0) this._pendingUrls.splice(index, 1);
|
||||
if (index >= 0) this._pendingUrls.splice(index, 1);
|
||||
|
||||
this.loadNextConfiguration();
|
||||
|
||||
@ -85,21 +87,21 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
|
||||
private parseConfiguration(data: { [index: string]: any }, overrides: boolean = false): boolean
|
||||
{
|
||||
if(!data) return false;
|
||||
if (!data) return false;
|
||||
|
||||
try
|
||||
{
|
||||
const regex = new RegExp(/\${(.*?)}/g);
|
||||
|
||||
for(const key in data)
|
||||
for (const key in data)
|
||||
{
|
||||
let value = data[key];
|
||||
|
||||
if(typeof value === 'string') value = this.interpolate((value as string), regex);
|
||||
if (typeof value === 'string') value = this.interpolate((value as string), regex);
|
||||
|
||||
if(this._definitions.has(key))
|
||||
if (this._definitions.has(key))
|
||||
{
|
||||
if(overrides) this.setValue(key, value);
|
||||
if (overrides) this.setValue(key, value);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -120,17 +122,17 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
|
||||
public interpolate(value: string, regex: RegExp = null): string
|
||||
{
|
||||
if(!regex) regex = new RegExp(/\${(.*?)}/g);
|
||||
if (!regex) regex = new RegExp(/\${(.*?)}/g);
|
||||
|
||||
const pieces = value.match(regex);
|
||||
|
||||
if(pieces && pieces.length)
|
||||
if (pieces && pieces.length)
|
||||
{
|
||||
for(const piece of pieces)
|
||||
for (const piece of pieces)
|
||||
{
|
||||
const existing = (this._definitions.get(this.removeInterpolateKey(piece)) as string);
|
||||
|
||||
if(existing) (value = value.replace(piece, existing));
|
||||
if (existing) (value = value.replace(piece, existing));
|
||||
}
|
||||
}
|
||||
|
||||
@ -146,12 +148,12 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
{
|
||||
let existing = this._definitions.get(key);
|
||||
|
||||
if(existing === undefined)
|
||||
if (existing === undefined)
|
||||
{
|
||||
if(this._missingKeys.indexOf(key) >= 0) return value;
|
||||
if (this._missingKeys.indexOf(key) >= 0) return value;
|
||||
|
||||
this._missingKeys.push(key);
|
||||
this.logger.warn(`Missing configuration key: ${ key }`);
|
||||
this.logger.warn(`Missing configuration key: ${key}`);
|
||||
|
||||
existing = value;
|
||||
}
|
||||
@ -161,6 +163,26 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
|
||||
|
||||
public setValue<T>(key: string, value: T): void
|
||||
{
|
||||
const parts = key.split('.');
|
||||
|
||||
let last = this._config;
|
||||
|
||||
for (let i = 0; i < parts.length; i++)
|
||||
{
|
||||
const part = parts[i].toString();
|
||||
|
||||
if (i !== (parts.length - 1))
|
||||
{
|
||||
if (!last[part]) last[part] = {};
|
||||
|
||||
last = last[part];
|
||||
|
||||
continue;
|
||||
}
|
||||
|
||||
last[part] = value;
|
||||
}
|
||||
|
||||
this._definitions.set(key, value);
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { INitroManager } from '../common/INitroManager';
|
||||
import { INitroManager } from '../../api';
|
||||
|
||||
export interface IConfigurationManager extends INitroManager
|
||||
{
|
||||
|
@ -1,9 +1,7 @@
|
||||
import { IDisposable, IEventDispatcher, INitroLogger } from '../../api';
|
||||
import { Nitro } from '../../nitro/Nitro';
|
||||
import { Disposable } from '../common/disposable/Disposable';
|
||||
import { IDisposable } from '../common/disposable/IDisposable';
|
||||
import { INitroLogger } from '../common/logger/INitroLogger';
|
||||
import { NitroLogger } from '../common/logger/NitroLogger';
|
||||
import { IEventDispatcher } from './IEventDispatcher';
|
||||
import { Disposable } from '../common/Disposable';
|
||||
import { NitroLogger } from '../common/NitroLogger';
|
||||
import { NitroEvent } from './NitroEvent';
|
||||
|
||||
export class EventDispatcher extends Disposable implements IEventDispatcher, IDisposable
|
||||
@ -28,11 +26,11 @@ export class EventDispatcher extends Disposable implements IEventDispatcher, IDi
|
||||
|
||||
public addEventListener(type: string, callback: Function): void
|
||||
{
|
||||
if(!type || !callback) return;
|
||||
if (!type || !callback) return;
|
||||
|
||||
const existing = this._listeners.get(type);
|
||||
|
||||
if(!existing)
|
||||
if (!existing)
|
||||
{
|
||||
this._listeners.set(type, [callback]);
|
||||
|
||||
@ -44,19 +42,19 @@ export class EventDispatcher extends Disposable implements IEventDispatcher, IDi
|
||||
|
||||
public removeEventListener(type: string, callback: any): void
|
||||
{
|
||||
if(!type || !callback) return;
|
||||
if (!type || !callback) return;
|
||||
|
||||
const existing = this._listeners.get(type);
|
||||
|
||||
if(!existing || !existing.length) return;
|
||||
if (!existing || !existing.length) return;
|
||||
|
||||
for(const [i, cb] of existing.entries())
|
||||
for (const [i, cb] of existing.entries())
|
||||
{
|
||||
if(!cb || (cb !== callback)) continue;
|
||||
if (!cb || (cb !== callback)) continue;
|
||||
|
||||
existing.splice(i, 1);
|
||||
|
||||
if(!existing.length) this._listeners.delete(type);
|
||||
if (!existing.length) this._listeners.delete(type);
|
||||
|
||||
return;
|
||||
}
|
||||
@ -64,9 +62,9 @@ export class EventDispatcher extends Disposable implements IEventDispatcher, IDi
|
||||
|
||||
public dispatchEvent(event: NitroEvent): boolean
|
||||
{
|
||||
if(!event) return false;
|
||||
if (!event) return false;
|
||||
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.dispatcher.log')) this._logger.log('Dispatched Event', event.type);
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.dispatcher.log')) this._logger.log('Dispatched Event', event.type);
|
||||
|
||||
this.processEvent(event);
|
||||
|
||||
@ -77,18 +75,18 @@ export class EventDispatcher extends Disposable implements IEventDispatcher, IDi
|
||||
{
|
||||
const existing = this._listeners.get(event.type);
|
||||
|
||||
if(!existing || !existing.length) return;
|
||||
if (!existing || !existing.length) return;
|
||||
|
||||
const callbacks = [];
|
||||
|
||||
for(const callback of existing)
|
||||
for (const callback of existing)
|
||||
{
|
||||
if(!callback) continue;
|
||||
if (!callback) continue;
|
||||
|
||||
callbacks.push(callback);
|
||||
}
|
||||
|
||||
while(callbacks.length)
|
||||
while (callbacks.length)
|
||||
{
|
||||
const callback = callbacks.shift();
|
||||
|
||||
|
@ -1,5 +1,2 @@
|
||||
export * from './EventDispatcher';
|
||||
export * from './IEventDispatcher';
|
||||
export * from './ILinkEventTracker';
|
||||
export * from './IWorkerEventTracker';
|
||||
export * from './NitroEvent';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IDisposable } from '../common/disposable/IDisposable';
|
||||
import { IDisposable } from '../../api';
|
||||
|
||||
export class AdvancedMap<T, U> implements IDisposable
|
||||
{
|
||||
@ -14,7 +14,7 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
this._array = [];
|
||||
this._keys = [];
|
||||
|
||||
if(map) for(const [ key, value ] of map.entries()) this.add(key, value);
|
||||
if (map) for (const [key, value] of map.entries()) this.add(key, value);
|
||||
}
|
||||
|
||||
public get length(): number
|
||||
@ -29,9 +29,9 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
|
||||
public dispose(): void
|
||||
{
|
||||
if(!this._dictionary)
|
||||
if (!this._dictionary)
|
||||
{
|
||||
for(const key of this._dictionary.keys()) this._dictionary.delete(key);
|
||||
for (const key of this._dictionary.keys()) this._dictionary.delete(key);
|
||||
|
||||
this._dictionary = null;
|
||||
}
|
||||
@ -43,7 +43,7 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
|
||||
public reset(): void
|
||||
{
|
||||
for(const key of this._dictionary.keys()) this._dictionary.delete(key);
|
||||
for (const key of this._dictionary.keys()) this._dictionary.delete(key);
|
||||
|
||||
this._length = 0;
|
||||
this._array = [];
|
||||
@ -52,7 +52,7 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
|
||||
public unshift(key: T, value: U): boolean
|
||||
{
|
||||
if(this._dictionary.get(key) !== null) return false;
|
||||
if (this._dictionary.get(key) !== null) return false;
|
||||
|
||||
this._dictionary.set(key, value);
|
||||
|
||||
@ -66,7 +66,7 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
|
||||
public add(key: T, value: U): boolean
|
||||
{
|
||||
if(this._dictionary.get(key) !== undefined) return false;
|
||||
if (this._dictionary.get(key) !== undefined) return false;
|
||||
|
||||
this._dictionary.set(key, value);
|
||||
|
||||
@ -82,11 +82,11 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
{
|
||||
const value = this._dictionary.get(key);
|
||||
|
||||
if(!value) return null;
|
||||
if (!value) return null;
|
||||
|
||||
const index = this._array.indexOf(value);
|
||||
|
||||
if(index >= 0)
|
||||
if (index >= 0)
|
||||
{
|
||||
this._array.splice(index, 1);
|
||||
this._keys.splice(index, 1);
|
||||
@ -101,14 +101,14 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
|
||||
public getWithIndex(index: number): U
|
||||
{
|
||||
if((index < 0) || (index >= this._length)) return null;
|
||||
if ((index < 0) || (index >= this._length)) return null;
|
||||
|
||||
return this._array[index];
|
||||
}
|
||||
|
||||
public getKey(index: number): T
|
||||
{
|
||||
if((index < 0) || (index >= this._length)) return null;
|
||||
if ((index < 0) || (index >= this._length)) return null;
|
||||
|
||||
return this._keys[index];
|
||||
}
|
||||
@ -145,7 +145,7 @@ export class AdvancedMap<T, U> implements IDisposable
|
||||
|
||||
public concatenate(newValues: AdvancedMap<T, U>): void
|
||||
{
|
||||
for(const k of newValues._keys) this.add(k, newValues.getValue(k));
|
||||
for (const k of newValues._keys) this.add(k, newValues.getValue(k));
|
||||
}
|
||||
|
||||
public clone(): AdvancedMap<T, U>
|
||||
|
@ -1,8 +1,6 @@
|
||||
import { Application } from '@pixi/app';
|
||||
import { Ticker } from '@pixi/ticker';
|
||||
import { IEventDispatcher } from '../core/events/IEventDispatcher';
|
||||
import { ILinkEventTracker } from '../core/events/ILinkEventTracker';
|
||||
import { IWorkerEventTracker } from '../core/events/IWorkerEventTracker';
|
||||
import { IEventDispatcher, ILinkEventTracker, IWorkerEventTracker } from '../api';
|
||||
import { INitroCore } from '../core/INitroCore';
|
||||
import { NitroTimer } from '../core/utils/NitroTimer';
|
||||
import { IRoomManager } from '../room/IRoomManager';
|
||||
|
@ -2,11 +2,9 @@ import { Application, IApplicationOptions } from '@pixi/app';
|
||||
import { SCALE_MODES } from '@pixi/constants';
|
||||
import { settings } from '@pixi/settings';
|
||||
import { Ticker } from '@pixi/ticker';
|
||||
import { IEventDispatcher, ILinkEventTracker, IWorkerEventTracker } from '../api';
|
||||
import { ConfigurationEvent } from '../core/configuration/ConfigurationEvent';
|
||||
import { EventDispatcher } from '../core/events/EventDispatcher';
|
||||
import { IEventDispatcher } from '../core/events/IEventDispatcher';
|
||||
import { ILinkEventTracker } from '../core/events/ILinkEventTracker';
|
||||
import { IWorkerEventTracker } from '../core/events/IWorkerEventTracker';
|
||||
import { NitroEvent } from '../core/events/NitroEvent';
|
||||
import { INitroCore } from '../core/INitroCore';
|
||||
import { NitroCore } from '../core/NitroCore';
|
||||
@ -72,7 +70,7 @@ export class Nitro extends Application implements INitro
|
||||
{
|
||||
super(options);
|
||||
|
||||
if(!Nitro.INSTANCE) Nitro.INSTANCE = this;
|
||||
if (!Nitro.INSTANCE) Nitro.INSTANCE = this;
|
||||
|
||||
this._nitroTimer = new NitroTimer();
|
||||
this._worker = null;
|
||||
@ -96,12 +94,12 @@ export class Nitro extends Application implements INitro
|
||||
this._core.configuration.events.addEventListener(ConfigurationEvent.LOADED, this.onConfigurationLoadedEvent.bind(this));
|
||||
this._roomEngine.events.addEventListener(RoomEngineEvent.ENGINE_INITIALIZED, this.onRoomEngineReady.bind(this));
|
||||
|
||||
if(this._worker) this._worker.onmessage = this.createWorkerEvent.bind(this);
|
||||
if (this._worker) this._worker.onmessage = this.createWorkerEvent.bind(this);
|
||||
}
|
||||
|
||||
public static bootstrap(): void
|
||||
{
|
||||
if(Nitro.INSTANCE)
|
||||
if (Nitro.INSTANCE)
|
||||
{
|
||||
Nitro.INSTANCE.dispose();
|
||||
|
||||
@ -123,25 +121,25 @@ export class Nitro extends Application implements INitro
|
||||
|
||||
public init(): void
|
||||
{
|
||||
if(this._isReady || this._isDisposed) return;
|
||||
if (this._isReady || this._isDisposed) return;
|
||||
|
||||
if(this._avatar) this._avatar.init();
|
||||
if (this._avatar) this._avatar.init();
|
||||
|
||||
if(this._soundManager) this._soundManager.init();
|
||||
if (this._soundManager) this._soundManager.init();
|
||||
|
||||
if(this._roomEngine)
|
||||
if (this._roomEngine)
|
||||
{
|
||||
this._roomEngine.sessionDataManager = this._sessionDataManager;
|
||||
this._roomEngine.roomSessionManager = this._roomSessionManager;
|
||||
this._roomEngine.roomManager = this._roomManager;
|
||||
|
||||
if(this._sessionDataManager) this._sessionDataManager.init();
|
||||
if(this._roomSessionManager) this._roomSessionManager.init();
|
||||
if (this._sessionDataManager) this._sessionDataManager.init();
|
||||
if (this._roomSessionManager) this._roomSessionManager.init();
|
||||
|
||||
this._roomEngine.init();
|
||||
}
|
||||
|
||||
if(!this._communication.connection)
|
||||
if (!this._communication.connection)
|
||||
{
|
||||
throw new Error('No connection found');
|
||||
}
|
||||
@ -153,51 +151,51 @@ export class Nitro extends Application implements INitro
|
||||
|
||||
public dispose(): void
|
||||
{
|
||||
if(this._isDisposed) return;
|
||||
if (this._isDisposed) return;
|
||||
|
||||
if(this._roomManager)
|
||||
if (this._roomManager)
|
||||
{
|
||||
this._roomManager.dispose();
|
||||
|
||||
this._roomManager = null;
|
||||
}
|
||||
|
||||
if(this._roomSessionManager)
|
||||
if (this._roomSessionManager)
|
||||
{
|
||||
this._roomSessionManager.dispose();
|
||||
|
||||
this._roomSessionManager = null;
|
||||
}
|
||||
|
||||
if(this._sessionDataManager)
|
||||
if (this._sessionDataManager)
|
||||
{
|
||||
this._sessionDataManager.dispose();
|
||||
|
||||
this._sessionDataManager = null;
|
||||
}
|
||||
|
||||
if(this._roomEngine)
|
||||
if (this._roomEngine)
|
||||
{
|
||||
this._roomEngine.dispose();
|
||||
|
||||
this._roomEngine = null;
|
||||
}
|
||||
|
||||
if(this._avatar)
|
||||
if (this._avatar)
|
||||
{
|
||||
this._avatar.dispose();
|
||||
|
||||
this._avatar = null;
|
||||
}
|
||||
|
||||
if(this._soundManager)
|
||||
if (this._soundManager)
|
||||
{
|
||||
this._soundManager.dispose();
|
||||
|
||||
this._soundManager = null;
|
||||
}
|
||||
|
||||
if(this._communication)
|
||||
if (this._communication)
|
||||
{
|
||||
this._communication.dispose();
|
||||
|
||||
@ -215,7 +213,7 @@ export class Nitro extends Application implements INitro
|
||||
const animationFPS = this.getConfiguration<number>('system.animation.fps', 24);
|
||||
const limitsFPS = this.getConfiguration<boolean>('system.limits.fps', true);
|
||||
|
||||
if(limitsFPS) Nitro.instance.ticker.maxFPS = animationFPS;
|
||||
if (limitsFPS) Nitro.instance.ticker.maxFPS = animationFPS;
|
||||
}
|
||||
|
||||
private onRoomEngineReady(event: RoomEngineEvent): void
|
||||
@ -245,7 +243,7 @@ export class Nitro extends Application implements INitro
|
||||
|
||||
public addWorkerEventTracker(tracker: IWorkerEventTracker): void
|
||||
{
|
||||
if(this._workerTrackers.indexOf(tracker) >= 0) return;
|
||||
if (this._workerTrackers.indexOf(tracker) >= 0) return;
|
||||
|
||||
this._workerTrackers.push(tracker);
|
||||
}
|
||||
@ -254,20 +252,20 @@ export class Nitro extends Application implements INitro
|
||||
{
|
||||
const index = this._workerTrackers.indexOf(tracker);
|
||||
|
||||
if(index === -1) return;
|
||||
if (index === -1) return;
|
||||
|
||||
this._workerTrackers.splice(index, 1);
|
||||
}
|
||||
|
||||
public createWorkerEvent(message: MessageEvent): void
|
||||
{
|
||||
if(!message) return;
|
||||
if (!message) return;
|
||||
|
||||
const data: { [index: string]: any } = message.data;
|
||||
|
||||
for(const tracker of this._workerTrackers)
|
||||
for (const tracker of this._workerTrackers)
|
||||
{
|
||||
if(!tracker) continue;
|
||||
if (!tracker) continue;
|
||||
|
||||
tracker.workerMessageReceived(data);
|
||||
}
|
||||
@ -275,14 +273,14 @@ export class Nitro extends Application implements INitro
|
||||
|
||||
public sendWorkerEvent(message: { [index: string]: any }): void
|
||||
{
|
||||
if(!message || !this._worker) return;
|
||||
if (!message || !this._worker) return;
|
||||
|
||||
this._worker.postMessage(message);
|
||||
}
|
||||
|
||||
public addLinkEventTracker(tracker: ILinkEventTracker): void
|
||||
{
|
||||
if(this._linkTrackers.indexOf(tracker) >= 0) return;
|
||||
if (this._linkTrackers.indexOf(tracker) >= 0) return;
|
||||
|
||||
this._linkTrackers.push(tracker);
|
||||
}
|
||||
@ -291,24 +289,24 @@ export class Nitro extends Application implements INitro
|
||||
{
|
||||
const index = this._linkTrackers.indexOf(tracker);
|
||||
|
||||
if(index === -1) return;
|
||||
if (index === -1) return;
|
||||
|
||||
this._linkTrackers.splice(index, 1);
|
||||
}
|
||||
|
||||
public createLinkEvent(link: string): void
|
||||
{
|
||||
if(!link || (link === '')) return;
|
||||
if (!link || (link === '')) return;
|
||||
|
||||
for(const tracker of this._linkTrackers)
|
||||
for (const tracker of this._linkTrackers)
|
||||
{
|
||||
if(!tracker) continue;
|
||||
if (!tracker) continue;
|
||||
|
||||
const prefix = tracker.eventUrlPrefix;
|
||||
|
||||
if(prefix.length > 0)
|
||||
if (prefix.length > 0)
|
||||
{
|
||||
if(link.substr(0, prefix.length) === prefix) tracker.linkReceived(link);
|
||||
if (link.substr(0, prefix.length) === prefix) tracker.linkReceived(link);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { IDisposable } from '../../core/common/disposable/IDisposable';
|
||||
import { IDisposable } from '../../api';
|
||||
|
||||
export interface IAvatarEffectListener extends IDisposable
|
||||
{
|
||||
resetEffect(effect: number): void;
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,6 @@
|
||||
import { RenderTexture } from '@pixi/core';
|
||||
import { Sprite } from '@pixi/sprite';
|
||||
import { IGraphicAsset } from '../../api';
|
||||
import { IDisposable } from '../../core/common/disposable/IDisposable';
|
||||
import { IDisposable, IGraphicAsset } from '../../api';
|
||||
import { IAnimationLayerData } from './animation/IAnimationLayerData';
|
||||
import { IAvatarDataContainer } from './animation/IAvatarDataContainer';
|
||||
import { ISpriteDataContainer } from './animation/ISpriteDataContainer';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IDisposable } from '../../core/common/disposable/IDisposable';
|
||||
import { IDisposable } from '../../api';
|
||||
|
||||
export interface IAvatarImageListener extends IDisposable
|
||||
{
|
||||
|
@ -1,5 +1,4 @@
|
||||
import { IAssetManager, IGraphicAsset } from '../../api';
|
||||
import { INitroManager } from '../../core/common/INitroManager';
|
||||
import { IAssetManager, IGraphicAsset, INitroManager } from '../../api';
|
||||
import { AvatarAssetDownloadManager } from './AvatarAssetDownloadManager';
|
||||
import { AvatarStructure } from './AvatarStructure';
|
||||
import { IAvatarEffectListener } from './IAvatarEffectListener';
|
||||
|
@ -1,5 +1,5 @@
|
||||
import { Resource, Texture } from '@pixi/core';
|
||||
import { IEventDispatcher } from '../../core';
|
||||
import { IEventDispatcher } from '../../api';
|
||||
import { IRoomCameraWidgetEffect } from './IRoomCameraWidgetEffect';
|
||||
import { IRoomCameraWidgetSelectedEffect } from './IRoomCameraWidgetSelectedEffect';
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
import { Texture } from '@pixi/core';
|
||||
import { ColorMatrix, ColorMatrixFilter } from '@pixi/filter-color-matrix';
|
||||
import { EventDispatcher, IEventDispatcher, NitroContainer, NitroSprite } from '../../core';
|
||||
import { IEventDispatcher } from '../../api';
|
||||
import { EventDispatcher, NitroContainer, NitroSprite } from '../../core';
|
||||
import { TextureUtils } from '../../room';
|
||||
import { Nitro } from '../Nitro';
|
||||
import { RoomCameraWidgetManagerEvent } from './events/RoomCameraWidgetManagerEvent';
|
||||
|
@ -1,6 +1,4 @@
|
||||
import { IMessageEvent } from '../../core';
|
||||
import { INitroManager } from '../../core/common/INitroManager';
|
||||
import { IConnection } from '../../core/communication/connections/IConnection';
|
||||
import { IConnection, IMessageEvent, INitroManager } from '../../api';
|
||||
import { NitroCommunicationDemo } from './demo/NitroCommunicationDemo';
|
||||
|
||||
export interface INitroCommunicationManager extends INitroManager
|
||||
|
@ -1,10 +1,6 @@
|
||||
import { IMessageEvent } from '../../core';
|
||||
import { ICommunicationManager, IConnection, IConnectionStateListener, IMessageConfiguration, IMessageEvent } from '../../api';
|
||||
import { NitroManager } from '../../core/common/NitroManager';
|
||||
import { IConnection } from '../../core/communication/connections/IConnection';
|
||||
import { IConnectionStateListener } from '../../core/communication/connections/IConnectionStateListener';
|
||||
import { SocketConnectionEvent } from '../../core/communication/events/SocketConnectionEvent';
|
||||
import { ICommunicationManager } from '../../core/communication/ICommunicationManager';
|
||||
import { IMessageConfiguration } from '../../core/communication/messages/IMessageConfiguration';
|
||||
import { NitroEvent } from '../../core/events/NitroEvent';
|
||||
import { Nitro } from '../Nitro';
|
||||
import { NitroCommunicationDemo } from './demo/NitroCommunicationDemo';
|
||||
@ -38,7 +34,7 @@ export class NitroCommunicationManager extends NitroManager implements INitroCom
|
||||
|
||||
protected onInit(): void
|
||||
{
|
||||
if(this._connection) return;
|
||||
if (this._connection) return;
|
||||
|
||||
Nitro.instance.events.addEventListener(NitroCommunicationDemoEvent.CONNECTION_AUTHENTICATED, this.onConnectionAuthenticatedEvent);
|
||||
|
||||
@ -50,16 +46,16 @@ export class NitroCommunicationManager extends NitroManager implements INitroCom
|
||||
this._connection.addEventListener(SocketConnectionEvent.CONNECTION_CLOSED, this.onConnectionClosedEvent);
|
||||
this._connection.addEventListener(SocketConnectionEvent.CONNECTION_ERROR, this.onConnectionErrorEvent);
|
||||
|
||||
if(this._demo) this._demo.init();
|
||||
if (this._demo) this._demo.init();
|
||||
|
||||
this._connection.init(Nitro.instance.getConfiguration<string>('socket.url'));
|
||||
}
|
||||
|
||||
protected onDispose(): void
|
||||
{
|
||||
if(this._demo) this._demo.dispose();
|
||||
if (this._demo) this._demo.dispose();
|
||||
|
||||
if(this._connection)
|
||||
if (this._connection)
|
||||
{
|
||||
this._connection.removeEventListener(SocketConnectionEvent.CONNECTION_OPENED, this.onConnectionOpenedEvent);
|
||||
this._connection.removeEventListener(SocketConnectionEvent.CONNECTION_CLOSED, this.onConnectionClosedEvent);
|
||||
@ -90,24 +86,24 @@ export class NitroCommunicationManager extends NitroManager implements INitroCom
|
||||
{
|
||||
this.logger.log('Connection Authenticated');
|
||||
|
||||
if(this._connection) this._connection.authenticated();
|
||||
if (this._connection) this._connection.authenticated();
|
||||
}
|
||||
|
||||
public connectionInit(socketUrl: string): void
|
||||
{
|
||||
this.logger.log(`Initializing Connection: ${ socketUrl }`);
|
||||
this.logger.log(`Initializing Connection: ${socketUrl}`);
|
||||
}
|
||||
|
||||
public registerMessageEvent(event: IMessageEvent): IMessageEvent
|
||||
{
|
||||
if(this._connection) this._connection.addMessageEvent(event);
|
||||
if (this._connection) this._connection.addMessageEvent(event);
|
||||
|
||||
return event;
|
||||
}
|
||||
|
||||
public removeMessageEvent(event: IMessageEvent): void
|
||||
{
|
||||
if(!this._connection) return;
|
||||
if (!this._connection) return;
|
||||
|
||||
this._connection.removeMessageEvent(event);
|
||||
}
|
||||
|
File diff suppressed because one or more lines are too long
@ -1,5 +1,5 @@
|
||||
import { IConnection } from '../../../api';
|
||||
import { NitroManager } from '../../../core/common/NitroManager';
|
||||
import { IConnection } from '../../../core/communication/connections/IConnection';
|
||||
import { SocketConnectionEvent } from '../../../core/communication/events/SocketConnectionEvent';
|
||||
import { Nitro } from '../../Nitro';
|
||||
import { INitroCommunicationManager } from '../INitroCommunicationManager';
|
||||
@ -41,7 +41,7 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
{
|
||||
const connection = this._communication.connection;
|
||||
|
||||
if(connection)
|
||||
if (connection)
|
||||
{
|
||||
connection.addEventListener(SocketConnectionEvent.CONNECTION_OPENED, this.onConnectionOpenedEvent);
|
||||
connection.addEventListener(SocketConnectionEvent.CONNECTION_CLOSED, this.onConnectionClosedEvent);
|
||||
@ -56,7 +56,7 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
{
|
||||
const connection = this._communication.connection;
|
||||
|
||||
if(connection)
|
||||
if (connection)
|
||||
{
|
||||
connection.removeEventListener(SocketConnectionEvent.CONNECTION_OPENED, this.onConnectionOpenedEvent);
|
||||
connection.removeEventListener(SocketConnectionEvent.CONNECTION_CLOSED, this.onConnectionClosedEvent);
|
||||
@ -74,13 +74,13 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
{
|
||||
const connection = this._communication.connection;
|
||||
|
||||
if(!connection) return;
|
||||
if (!connection) return;
|
||||
|
||||
this._didConnect = true;
|
||||
|
||||
this.dispatchCommunicationDemoEvent(NitroCommunicationDemoEvent.CONNECTION_ESTABLISHED, connection);
|
||||
|
||||
if(Nitro.instance.getConfiguration<boolean>('system.pong.manually', false)) this.startPonging();
|
||||
if (Nitro.instance.getConfiguration<boolean>('system.pong.manually', false)) this.startPonging();
|
||||
|
||||
this.startHandshake(connection);
|
||||
|
||||
@ -93,18 +93,18 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
{
|
||||
const connection = this._communication.connection;
|
||||
|
||||
if(!connection) return;
|
||||
if (!connection) return;
|
||||
|
||||
this.stopPonging();
|
||||
|
||||
if(this._didConnect) this.dispatchCommunicationDemoEvent(NitroCommunicationDemoEvent.CONNECTION_CLOSED, connection);
|
||||
if (this._didConnect) this.dispatchCommunicationDemoEvent(NitroCommunicationDemoEvent.CONNECTION_CLOSED, connection);
|
||||
}
|
||||
|
||||
private onConnectionErrorEvent(event: CloseEvent): void
|
||||
{
|
||||
const connection = this._communication.connection;
|
||||
|
||||
if(!connection) return;
|
||||
if (!connection) return;
|
||||
|
||||
this.stopPonging();
|
||||
|
||||
@ -113,9 +113,9 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
|
||||
private tryAuthentication(connection: IConnection): void
|
||||
{
|
||||
if(!connection || !this.getSSO())
|
||||
if (!connection || !this.getSSO())
|
||||
{
|
||||
if(!this.getSSO())
|
||||
if (!this.getSSO())
|
||||
{
|
||||
this.logger.error('Login without an SSO ticket is not supported');
|
||||
}
|
||||
@ -130,14 +130,14 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
|
||||
private onClientPingEvent(event: ClientPingEvent): void
|
||||
{
|
||||
if(!event || !event.connection) return;
|
||||
if (!event || !event.connection) return;
|
||||
|
||||
this.sendPong(event.connection);
|
||||
}
|
||||
|
||||
private onAuthenticatedEvent(event: AuthenticatedEvent): void
|
||||
{
|
||||
if(!event || !event.connection) return;
|
||||
if (!event || !event.connection) return;
|
||||
|
||||
this.completeHandshake(event.connection);
|
||||
|
||||
@ -169,7 +169,7 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
|
||||
private stopPonging(): void
|
||||
{
|
||||
if(!this._pongInterval) return;
|
||||
if (!this._pongInterval) return;
|
||||
|
||||
clearInterval(this._pongInterval);
|
||||
|
||||
@ -180,7 +180,7 @@ export class NitroCommunicationDemo extends NitroManager
|
||||
{
|
||||
connection = ((connection || this._communication.connection) || null);
|
||||
|
||||
if(!connection) return;
|
||||
if (!connection) return;
|
||||
|
||||
connection.send(new PongMessageComposer());
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IConnection } from '../../../core/communication/connections/IConnection';
|
||||
import { IConnection } from '../../../api';
|
||||
import { NitroEvent } from '../../../core/events/NitroEvent';
|
||||
|
||||
export class NitroCommunicationDemoEvent extends NitroEvent
|
||||
@ -24,4 +24,4 @@ export class NitroCommunicationDemoEvent extends NitroEvent
|
||||
{
|
||||
return this._connection;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { InterstitialMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { RoomAdErrorMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { AvailabilityStatusMessageParser } from '../../parser/availability/AvailabilityStatusMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { AvailabilityTimeMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { HotelClosedAndOpensMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { HotelClosesAndWillOpenAtMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { HotelWillCloseInMinutesMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { MaintenanceStatusMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { ChangeUserNameResultMessageParser } from '../../parser/avatar/ChangeUserNameResultMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CheckUserNameResultMessageParser } from '../../parser/avatar/CheckUserNameResultMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { FigureUpdateParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageDataWrapper } from '../../../../../core';
|
||||
import { IMessageDataWrapper } from '../../../../../api';
|
||||
|
||||
export class OutfitData
|
||||
{
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { WardrobeMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { BotAddedToInventoryParser } from '../../parser/bots/BotAddedToInventoryParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { BotInventoryMessageParser } from '../../parser/bots/BotInventoryMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { BotReceivedMessageParser } from '../../parser/bots/BotReceivedMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { BotRemovedFromInventoryParser } from '../../parser/bots/BotRemovedFromInventoryParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IDisposable, IMessageDataWrapper } from '../../../../../core';
|
||||
import { IDisposable, IMessageDataWrapper } from '../../../../../api';
|
||||
import { INamed } from '../moderation';
|
||||
import { CallForHelpTopicData } from './CallForHelpTopicData';
|
||||
|
||||
@ -15,7 +15,7 @@ export class CallForHelpCategoryData implements INamed, IDisposable
|
||||
|
||||
let count = wrapper.readInt();
|
||||
|
||||
while(count > 0)
|
||||
while (count > 0)
|
||||
{
|
||||
this._topics.push(new CallForHelpTopicData(wrapper));
|
||||
|
||||
@ -25,7 +25,7 @@ export class CallForHelpCategoryData implements INamed, IDisposable
|
||||
|
||||
public dispose(): void
|
||||
{
|
||||
if(this._disposed) return;
|
||||
if (this._disposed) return;
|
||||
|
||||
this._disposed = true;
|
||||
this._topics = null;
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageDataWrapper } from '../../../../../core';
|
||||
import { IMessageDataWrapper } from '../../../../../api';
|
||||
import { INamed } from '../moderation';
|
||||
|
||||
export class CallForHelpTopicData implements INamed
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CfhSanctionMessageParser } from '../../parser/callforhelp/CfhSanctionMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageDataWrapper } from '../../../../../core';
|
||||
import { IMessageDataWrapper } from '../../../../../api';
|
||||
import { INamed } from '../moderation';
|
||||
|
||||
export class CfhSanctionTypeData implements INamed
|
||||
@ -17,9 +17,9 @@ export class CfhSanctionTypeData implements INamed
|
||||
this._probationDays = wrapper.readInt();
|
||||
this._avatarOnly = wrapper.readBoolean();
|
||||
|
||||
if(wrapper.bytesAvailable) this._tradeLockInfo = wrapper.readString();
|
||||
if (wrapper.bytesAvailable) this._tradeLockInfo = wrapper.readString();
|
||||
|
||||
if(wrapper.bytesAvailable) this._machineBanInfo = wrapper.readString();
|
||||
if (wrapper.bytesAvailable) this._machineBanInfo = wrapper.readString();
|
||||
}
|
||||
|
||||
public get name(): string
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CfhTopicsInitMessageParser } from '../../parser/callforhelp/CfhTopicsInitMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { SanctionStatusMessageParser } from '../../parser/callforhelp';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CameraPublishStatusMessageParser } from '../../parser/camera/CameraPublishStatusMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CameraPurchaseOKMessageParser } from '../../parser/camera/CameraPurchaseOKMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CameraStorageUrlMessageParser } from '../../parser/camera/CameraStorageUrlMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CompetitionStatusMessageParser } from '../../parser/camera/CompetitionStatusMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { InitCameraMessageParser } from '../../parser/camera/InitCameraMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { ThumbnailStatusMessageParser } from '../../parser/camera/ThumbnailStatusMessageParser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CampaignCalendarDataMessageParser } from '../../parser/campaign';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { CampaignCalendarDoorOpenedMessageParser } from '../../parser/campaign';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { BonusRareInfoMessageParser } from '../../parser';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { IMessageEvent } from '../../../../../core/communication/messages/IMessageEvent';
|
||||
import { IMessageEvent } from '../../../../../api';
|
||||
import { MessageEvent } from '../../../../../core/communication/messages/MessageEvent';
|
||||
import { BuildersClubFurniCountMessageParser } from '../../parser';
|
||||
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user