feat: add clearing cache to switchUser
This commit is contained in:
parent
fc1c87bd62
commit
2d6ffdf55f
@ -424,6 +424,13 @@ class Client extends BaseClient {
|
|||||||
*/
|
*/
|
||||||
async switchUser(options) {
|
async switchUser(options) {
|
||||||
await this.logout();
|
await this.logout();
|
||||||
|
// There is a better way to code this but it's a temp fix - TheDevYellowy
|
||||||
|
await this.clearCache(this.channels.cache);
|
||||||
|
await this.clearCache(this.guilds.cache);
|
||||||
|
await this.clearCache(this.relationships.cache);
|
||||||
|
await this.clearCache(this.sessions.cache);
|
||||||
|
await this.clearCache(this.users.cache);
|
||||||
|
await this.clearCache(this.voiceStates.cache);
|
||||||
if (typeof options == 'string') {
|
if (typeof options == 'string') {
|
||||||
await this.login(options);
|
await this.login(options);
|
||||||
} else {
|
} else {
|
||||||
@ -570,6 +577,7 @@ class Client extends BaseClient {
|
|||||||
this.sweepers.destroy();
|
this.sweepers.destroy();
|
||||||
this.ws.destroy();
|
this.ws.destroy();
|
||||||
this.token = null;
|
this.token = null;
|
||||||
|
this.password = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -583,7 +591,7 @@ class Client extends BaseClient {
|
|||||||
voip_provider: null,
|
voip_provider: null,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
this.destroy();
|
await this.destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -765,6 +773,16 @@ class Client extends BaseClient {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear a cache
|
||||||
|
* @param {Collection} cache The cache to clear
|
||||||
|
*/
|
||||||
|
async clearCache(cache) {
|
||||||
|
await cache.forEach(async (V, K) => {
|
||||||
|
await cache.delete(K);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sweeps all text-based channels' messages and removes the ones older than the max message lifetime.
|
* Sweeps all text-based channels' messages and removes the ones older than the max message lifetime.
|
||||||
* If the message has been edited, the time of the edit is used rather than the time of the original message.
|
* If the message has been edited, the time of the edit is used rather than the time of the original message.
|
||||||
|
1
typings/index.d.ts
vendored
1
typings/index.d.ts
vendored
@ -932,6 +932,7 @@ export class Client<Ready extends boolean = boolean> extends BaseClient {
|
|||||||
public customStatusAuto(client?: this): undefined;
|
public customStatusAuto(client?: this): undefined;
|
||||||
public authorizeURL(url: string, options?: object): Promise<boolean>;
|
public authorizeURL(url: string, options?: object): Promise<boolean>;
|
||||||
public sleep(milliseconds: number): Promise<void> | null;
|
public sleep(milliseconds: number): Promise<void> | null;
|
||||||
|
public clearCache(cache: Collection<any, any>): void;
|
||||||
public toJSON(): unknown;
|
public toJSON(): unknown;
|
||||||
|
|
||||||
public on<K extends keyof ClientEvents>(event: K, listener: (...args: ClientEvents[K]) => Awaitable<void>): this;
|
public on<K extends keyof ClientEvents>(event: K, listener: (...args: ClientEvents[K]) => Awaitable<void>): this;
|
||||||
|
Loading…
Reference in New Issue
Block a user