From deb2a5a06561135d5e3e6e8275e848bdcdf158f5 Mon Sep 17 00:00:00 2001 From: KnorpelSenf Date: Wed, 13 Nov 2024 18:16:58 +0100 Subject: [PATCH] refactor: deduplicate code --- src/convenience/session.ts | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/src/convenience/session.ts b/src/convenience/session.ts index 48bb4dc1..b1257781 100644 --- a/src/convenience/session.ts +++ b/src/convenience/session.ts @@ -229,7 +229,7 @@ export function session( function strictSingleSession( options: SessionOptions, ): MiddlewareFn> { - const { initial, storage, prefix, getSessionKey, custom } = fillDefaults( + const { initial, storage, getSessionKey, custom } = fillDefaults( options, ); return async (ctx, next) => { @@ -239,7 +239,7 @@ function strictSingleSession( "session", initial, ); - const key = prefix + await getSessionKey(ctx); + const key = await getSessionKey(ctx); await propSession.init(key, { custom, lazy: false }); await next(); // no catch: do not write back if middleware throws await propSession.finish(); @@ -255,8 +255,7 @@ function strictMultiSession( return async (ctx, next) => { ctx.session = {} as S; const propSessions = await Promise.all(props.map(async (prop) => { - const { initial, storage, prefix, getSessionKey, custom } = - defaults[prop]; + const { initial, storage, getSessionKey, custom } = defaults[prop]; const s = new PropertySession( // @ts-expect-error cannot express that the storage works for a concrete prop storage, @@ -264,7 +263,7 @@ function strictMultiSession( prop, initial, ); - const key = prefix + await getSessionKey(ctx); + const key = await getSessionKey(ctx); await s.init(key, { custom, lazy: false }); return s; })); @@ -312,7 +311,7 @@ export function lazySession( if (options.type !== undefined && options.type !== "single") { throw new Error("Cannot use lazy multi sessions!"); } - const { initial, storage, prefix, getSessionKey, custom } = fillDefaults( + const { initial, storage, getSessionKey, custom } = fillDefaults( options, ); return async (ctx, next) => { @@ -323,7 +322,7 @@ export function lazySession( "session", initial, ); - const key = prefix + await getSessionKey(ctx); + const key = await getSessionKey(ctx); await propSession.init(key, { custom, lazy: true }); await next(); // no catch: do not write back if middleware throws await propSession.finish(); @@ -451,7 +450,15 @@ function fillDefaults(opts: SessionOptions = {}) { storage = new MemorySessionStorage(); } const custom = getSessionKey !== defaultGetSessionKey; - return { initial, storage, prefix, getSessionKey, custom }; + return { + initial, + storage, + getSessionKey: async (ctx: C) => { + const key = await getSessionKey(ctx); + return key === undefined ? undefined : prefix + key; + }, + custom, + }; } /** Stores session data per chat by default */