smartuniverse/ts/smartuniverse.classes.universemessage.ts

116 lines
2.9 KiB
TypeScript
Raw Normal View History

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';
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';
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
* 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
/**
* the UniverseCache the message is attached to
2018-05-07 18:50:07 +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.
*/
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
*/
constructor(
messageArg: string,
requestedChannelNameArg: string,
passphraseArg: string,
attachedPayloadArg: any
) {
2018-03-13 06:15:40 +01:00
this.timestamp = new TimeStamp();
this.message = messageArg;
this.requestedChannelName = requestedChannelNameArg;
this.requestedChannelPassphrase = passphraseArg;
2018-03-13 06:15:40 +01:00
this.attachedPayload = attachedPayloadArg;
// prevent memory issues
2018-05-20 00:41:59 +02:00
this.fallBackDestruction();
}
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
// set up self destruction by removing this from the parent messageCache
2018-05-20 00:41:59 +02:00
this.destructionTimer.completed.then(async () => {
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
/**
* 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
}
}