Skip to content

Commit

Permalink
refactor(binding-coap): refactor server's destroy method
Browse files Browse the repository at this point in the history
  • Loading branch information
JKRhb committed May 9, 2023
1 parent 09dfd6a commit 7b6b060
Showing 1 changed file with 14 additions and 18 deletions.
32 changes: 14 additions & 18 deletions packages/binding-coap/src/coap-server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ export default class CoapServer implements ProtocolServer {
}
}

public expose(thing: ExposedThing, tdTemplate?: WoT.ExposedThingInit): Promise<void> {
public async expose(thing: ExposedThing, tdTemplate?: WoT.ExposedThingInit): Promise<void> {
let urlPath = slugify(thing.title, { lower: true });

if (this.things.has(urlPath)) {
Expand Down Expand Up @@ -194,25 +194,21 @@ export default class CoapServer implements ProtocolServer {
});
}

public destroy(thingId: string): Promise<boolean> {
public async destroy(thingId: string): Promise<boolean> {
debug(`CoapServer on port ${this.getPort()} destroying thingId '${thingId}'`);
return new Promise<boolean>((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 Array.from(this.things.keys())) {
const expThing = this.things.get(name);
if (expThing?.id === thingId) {
this.things.delete(name);
this.coreResources.delete(name);

info(`CoapServer succesfully destroyed '${expThing.title}'`);
return true;
}
resolve(removedThing !== undefined);
});
}

info(`CoapServer failed to destroy thing with thingId '${thingId}'`);
return false;
}

private formatCoreLinkFormatResources() {
Expand Down

0 comments on commit 7b6b060

Please sign in to comment.