From 3046655b1e1099b477fe6cffb481f0048b56feb3 Mon Sep 17 00:00:00 2001 From: Jan Romann Date: Tue, 9 May 2023 22:32:57 +0200 Subject: [PATCH] refactor(binding-coap): refactor server's destroy method --- packages/binding-coap/src/coap-server.ts | 30 ++++++++++-------------- 1 file changed, 13 insertions(+), 17 deletions(-) diff --git a/packages/binding-coap/src/coap-server.ts b/packages/binding-coap/src/coap-server.ts index 52969f88c..ba2a643dd 100644 --- a/packages/binding-coap/src/coap-server.ts +++ b/packages/binding-coap/src/coap-server.ts @@ -194,25 +194,21 @@ export default class CoapServer implements ProtocolServer { }); } - public destroy(thingId: string): Promise { + public async destroy(thingId: string): Promise { debug(`CoapServer on port ${this.getPort()} destroying thingId '${thingId}'`); - return new Promise((resolve, reject) => { - let removedThing: ExposedThing; - for (const name of Array.from(this.things.keys())) { - const expThing = this.things.get(name); - if (expThing?.id === thingId) { - this.things.delete(name); - this.coreResources.delete(name); - removedThing = expThing; - } - } - if (removedThing) { - info(`CoapServer succesfully destroyed '${removedThing.title}'`); - } else { - info(`CoapServer failed to destroy thing with thingId '${thingId}'`); + for (const name of this.things.keys()) { + const exposedThing = this.things.get(name); + if (exposedThing?.id === thingId) { + this.things.delete(name); + this.coreResources.delete(name); + + info(`CoapServer succesfully destroyed '${exposedThing.title}'`); + return true; } - resolve(removedThing !== undefined); - }); + } + + info(`CoapServer failed to destroy thing with thingId '${thingId}'`); + return false; } private formatCoreLinkFormatResources() {