Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add cleanupEmptyNamespaces option #1

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 7 additions & 0 deletions lib/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,11 @@ interface ServerOptions extends EngineOptions, AttachOptions {
*/
skipMiddlewares?: boolean;
};
/**
* whether or not to remove namespaces that have no sockets connected to them
* @default false
*/
cleanupEmptyNamespaces;
}

/**
Expand Down Expand Up @@ -153,6 +158,7 @@ export class Server<
*
*/
public engine: BaseServer;
public readonly cleanupEmptyNamespaces: boolean;

/** @private */
readonly _parser: typeof parser;
Expand Down Expand Up @@ -226,6 +232,7 @@ export class Server<
this.path(opts.path || "/socket.io");
this.connectTimeout(opts.connectTimeout || 45000);
this.serveClient(false !== opts.serveClient);
this.cleanupEmptyNamespaces = !!opts.cleanupEmptyNamespaces;
this._parser = opts.parser || parser;
this.encoder = new this._parser.Encoder();
this.opts = opts;
Expand Down
19 changes: 19 additions & 0 deletions lib/namespace.ts
Original file line number Diff line number Diff line change
Expand Up @@ -694,4 +694,23 @@ export class Namespace<
this.adapter
).disconnectSockets(close);
}

/**
* Cleans up the namespace if necessary (if the server option cleanupEmptyNamespace is true and there are no sockets connected to the namespace).
*
* @param nsp - this namespace to cleanup
*
*/
cleanupNamespace() {
if (!this.server.cleanupEmptyNamespaces) {
return;
}

if (this.sockets.size !== 0) {
return;
}

this.adapter.close();
this.server._nsps.delete(this.name);
}
}
1 change: 1 addition & 0 deletions lib/socket.ts
Original file line number Diff line number Diff line change
Expand Up @@ -713,6 +713,7 @@ export class Socket<
this.client._remove(this);
this.connected = false;
this.emitReserved("disconnect", reason);
this.nsp.cleanupNamespace();
return;
}

Expand Down