Merge branch 'oobjectt-disconnect-reason'

This commit is contained in:
dank074 2022-12-26 16:56:13 -06:00
commit 5fffd3fdc3
7 changed files with 117 additions and 1 deletions

File diff suppressed because one or more lines are too long

View File

@ -417,6 +417,7 @@ export class IncomingHeader
public static PET_RESPECTED = 2788;
public static PET_SUPPLEMENT = 3441;
public static NOOBNESS_LEVEL = 3738;
public static DISCONNECT_REASON = 4000;
public static CAN_CREATE_ROOM_EVENT = 2599;
public static FAVORITE_GROUP_UDPATE = 3403;
public static NO_SUCH_FLAT = 84;

View File

@ -0,0 +1,46 @@
export class DisconnectReasonEnum
{
public static readonly LOGOUT: number = 0;
public static readonly JUST_BANNED: number = 1;
public static readonly CONCURRENT_LOGIN: number = 2;
public static readonly CONNECTION_LOST_TO_PEER: number = 3;
public static readonly AVATAR_IDENTITY_CHANGE: number = 4;
public static readonly REMOVE_FURNITURE_TOOL: number = 5;
public static readonly STILL_BANNED: number = 10;
public static readonly DUAL_LOGIN_BY_USERID: number = 11;
public static readonly HOTEL_CLOSED: number = 12;
public static readonly DUAL_LOGIN_BY_IP: number = 13;
public static readonly PEER_CONNECTION_MISSING: number = 16;
public static readonly NO_LOGIN_PERMISSION: number = 17;
public static readonly DUPLICATE_CONNECTION: number = 18;
public static readonly HOTEL_CLOSING: number = 19;
public static readonly INCORRECT_PASSWORD: number = 20;
public static readonly INVALID_LOGIN_TICKET: number = 22;
public static readonly VERSION_CHECK_URL: number = 23;
public static readonly VERSION_CHECK_PROPERTY: number = 24;
public static readonly VERSION_CHECK_MACHINE_ID: number = 25;
public static readonly NO_MESSENGER_SESSION: number = 26;
public static readonly USER_NOT_FOUND: number = 27;
public static readonly CRYPTO_NOT_INITIALIZED: number = 28;
public static readonly DEV_CRYPTO_NOT_ALLOWED: number = 29;
public static readonly DUPLICATE_UUID_DETECTED: number = 100;
public static readonly OLD_SESSION_IN_PROXY: number = 101;
public static readonly PUBLIC_KEY_NOT_NUMERIC: number = 102;
public static readonly PUBLIC_KEY_TOO_SHORT: number = 103;
public static readonly SOCKET_READ_GENERIC: number = 104;
public static readonly SOCKET_READ_FIRST_BYTE: number = 105;
public static readonly SOCKET_READ_LENGTH: number = 106;
public static readonly SOCKET_READ_BODY: number = 107;
public static readonly SOCKET_READ_POLICY: number = 108;
public static readonly SOCKET_IO_EXCEPTION: number = 109;
public static readonly SOCKET_WRONG_CRYPTO: number = 110;
public static readonly PROXY_RUNTIME_EXCEPTION: number = 111;
public static readonly IDLE_CONNECTION: number = 112;
public static readonly PONG_TIMEOUT: number = 113;
public static readonly IDLE_CONNECTION_NOT_AUTH: number = 114;
public static readonly IDLE_CONNECTION_NO_USER_ID: number = 115;
public static readonly WRITE_CLOSED_CHANNEL: number = 116;
public static readonly SOCKET_WRITE_EXCEPTION_1: number = 117;
public static readonly SOCKET_WRITE_EXCEPTION_2: number = 118;
public static readonly SOCKET_WRITE_EXCEPTION_3: number = 119;
}

View File

@ -0,0 +1,33 @@
import { DisconnectReasonEnum } from '.';
import { IMessageEvent } from '../../../../../api';
import { MessageEvent } from '../../../../../events';
import { DisconnectReasonParser } from '../../parser';
export class DisconnectReasonEvent extends MessageEvent implements IMessageEvent
{
constructor(callBack: Function)
{
super(callBack, DisconnectReasonParser);
}
public getParser(): DisconnectReasonParser
{
return this.parser as DisconnectReasonParser;
}
public get reasonString(): string
{
switch(this.getParser().reason)
{
case DisconnectReasonEnum.JUST_BANNED:
case DisconnectReasonEnum.STILL_BANNED:
return 'banned';
case DisconnectReasonEnum.CONCURRENT_LOGIN:
return 'concurrentlogin';
case DisconnectReasonEnum.INCORRECT_PASSWORD:
return 'incorrectpassword';
default:
return 'logout';
}
}
}

View File

@ -1 +1,3 @@
export * from './DisconnectReasonEnum';
export * from './DisconnectReasonEvent';
export * from './NoobnessLevelMessageEvent';

View File

@ -0,0 +1,32 @@
import { IMessageDataWrapper, IMessageParser } from '../../../../../api';
export class DisconnectReasonParser implements IMessageParser
{
private _reason: number;
public flush(): boolean
{
this._reason = -1;
return true;
}
public parse(wrapper: IMessageDataWrapper): boolean
{
if(!wrapper) return false;
this._reason = 0;
if(wrapper.bytesAvailable)
{
this._reason = wrapper.readInt();
}
return true;
}
public get reason(): number
{
return this._reason;
}
}

View File

@ -1 +1,2 @@
export * from './DisconnectReasonParser';
export * from './NoobnessLevelMessageParser';