2018-03-13 06:15:40 +01:00
|
|
|
import * as plugins from './smartuniverse.plugins';
|
|
|
|
|
2019-01-31 02:52:18 +01:00
|
|
|
import { Objectmap } from '@pushrocks/lik';
|
2018-05-26 13:44:32 +02:00
|
|
|
|
2019-01-31 02:52:18 +01:00
|
|
|
import { Timer, TimeStamp } from '@pushrocks/smarttime';
|
2018-05-24 00:14:57 +02:00
|
|
|
import { Universe } from './smartuniverse.classes.universe';
|
2018-05-26 13:44:32 +02:00
|
|
|
import { UniverseChannel } from './smartuniverse.classes.universechannel';
|
|
|
|
import { UniverseCache } from './smartuniverse.classes.universecache';
|
2018-03-13 06:15:40 +01:00
|
|
|
|
2018-04-13 15:45:48 +02:00
|
|
|
/**
|
|
|
|
* represents a message within a universe
|
2018-05-26 13:44:32 +02:00
|
|
|
* acts as a container to save message states like authentication status
|
2018-04-13 15:45:48 +02:00
|
|
|
*/
|
2018-03-13 06:15:40 +01:00
|
|
|
export class UniverseMessage {
|
|
|
|
/**
|
|
|
|
* public and unique id
|
|
|
|
* numeric ascending
|
|
|
|
* adheres to time in milliseconds
|
|
|
|
* avoids duplications though
|
|
|
|
*/
|
|
|
|
public id: number;
|
2018-05-07 18:50:07 +02:00
|
|
|
|
|
|
|
/**
|
2018-05-26 13:44:32 +02:00
|
|
|
* the UniverseCache the message is attached to
|
2018-05-07 18:50:07 +02:00
|
|
|
*/
|
2018-05-26 13:44:32 +02:00
|
|
|
public universeCache: UniverseCache;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* requestedChannelName
|
|
|
|
*/
|
|
|
|
public requestedChannelName: string;
|
|
|
|
public requestedChannelPassphrase: string;
|
|
|
|
|
2018-05-20 00:41:59 +02:00
|
|
|
/**
|
|
|
|
* enables unprotected grouping of messages for efficiency purposes.
|
|
|
|
*/
|
2018-05-26 13:44:32 +02:00
|
|
|
public universeChannelList = new Objectmap<UniverseChannel>();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* wether the message is authenticated
|
|
|
|
*/
|
|
|
|
public authenticated: boolean = null;
|
2018-05-07 18:50:07 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* time of creation
|
|
|
|
*/
|
|
|
|
public timestamp: TimeStamp;
|
|
|
|
|
|
|
|
/**
|
2018-05-20 00:41:59 +02:00
|
|
|
* the actual message
|
2018-05-07 18:50:07 +02:00
|
|
|
*/
|
2018-05-20 00:41:59 +02:00
|
|
|
public message: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* any attached payloads. Can be of binary format.
|
|
|
|
*/
|
|
|
|
public attachedPayload: any;
|
2018-04-29 14:17:26 +02:00
|
|
|
public destructionTimer: Timer; // a timer to take care of message destruction
|
2018-03-13 06:15:40 +01:00
|
|
|
|
2018-04-29 14:17:26 +02:00
|
|
|
/**
|
|
|
|
* the constructor to create a universe message
|
2018-05-07 18:50:07 +02:00
|
|
|
* @param messageArg
|
|
|
|
* @param attachedPayloadArg
|
2018-04-29 14:17:26 +02:00
|
|
|
*/
|
2018-05-26 13:44:32 +02:00
|
|
|
constructor(
|
|
|
|
messageArg: string,
|
|
|
|
requestedChannelNameArg: string,
|
|
|
|
passphraseArg: string,
|
|
|
|
attachedPayloadArg: any
|
|
|
|
) {
|
2018-03-13 06:15:40 +01:00
|
|
|
this.timestamp = new TimeStamp();
|
|
|
|
this.message = messageArg;
|
2018-05-26 13:44:32 +02:00
|
|
|
this.requestedChannelName = requestedChannelNameArg;
|
|
|
|
this.requestedChannelPassphrase = passphraseArg;
|
2018-03-13 06:15:40 +01:00
|
|
|
this.attachedPayload = attachedPayloadArg;
|
2018-05-26 13:44:32 +02:00
|
|
|
// prevent memory issues
|
2018-05-20 00:41:59 +02:00
|
|
|
this.fallBackDestruction();
|
|
|
|
}
|
|
|
|
|
2018-05-26 13:44:32 +02:00
|
|
|
public setUniverseCache(universeCacheArg: UniverseCache) {
|
|
|
|
this.universeCache = universeCacheArg;
|
2018-05-20 00:41:59 +02:00
|
|
|
}
|
|
|
|
|
2018-05-23 23:50:45 +02:00
|
|
|
public setDestructionTimer(selfdestructAfterArg: number) {
|
2018-05-20 00:41:59 +02:00
|
|
|
if (selfdestructAfterArg) {
|
|
|
|
this.destructionTimer = new Timer(selfdestructAfterArg);
|
|
|
|
this.destructionTimer.start();
|
2018-03-13 06:15:40 +01:00
|
|
|
|
2018-05-26 13:44:32 +02:00
|
|
|
// set up self destruction by removing this from the parent messageCache
|
2018-05-20 00:41:59 +02:00
|
|
|
this.destructionTimer.completed.then(async () => {
|
2018-05-28 12:07:25 +02:00
|
|
|
this.universeCache.messageMap.remove(this);
|
2018-05-20 00:41:59 +02:00
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.fallBackDestruction();
|
|
|
|
}
|
2018-05-23 23:50:45 +02:00
|
|
|
}
|
2018-05-20 00:41:59 +02:00
|
|
|
|
2018-05-26 13:44:32 +02:00
|
|
|
/**
|
|
|
|
* handles bad messages for further analysis
|
|
|
|
*/
|
|
|
|
handleAsBadMessage() {
|
|
|
|
console.log('received a bad message');
|
|
|
|
}
|
|
|
|
|
2018-05-20 00:41:59 +02:00
|
|
|
/**
|
2018-05-23 23:50:45 +02:00
|
|
|
* prevents memory leaks if channels have no default
|
2018-05-20 00:41:59 +02:00
|
|
|
*/
|
2018-05-23 23:50:45 +02:00
|
|
|
private fallBackDestruction() {
|
2018-05-20 00:41:59 +02:00
|
|
|
plugins.smartdelay.delayFor(1000).then(() => {
|
|
|
|
if (!this.destructionTimer) {
|
|
|
|
this.setDestructionTimer(6000);
|
|
|
|
}
|
2018-03-20 08:16:54 +01:00
|
|
|
});
|
2018-03-13 06:15:40 +01:00
|
|
|
}
|
|
|
|
}
|