@adonisjs/session 7.3.0 → 7.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/{chunk-S6P3TBEK.js → chunk-GB5FBZCV.js} +2 -2
- package/build/{chunk-EQQI5S2T.js → chunk-OCQGCVXK.js} +25 -45
- package/build/chunk-OCQGCVXK.js.map +1 -0
- package/build/chunk-TZLOND27.js +44 -0
- package/build/chunk-TZLOND27.js.map +1 -0
- package/build/{chunk-7YIO32ZH.js → chunk-Y3BSCW5X.js} +5 -5
- package/build/{chunk-WBAYBMJJ.js → chunk-ZVSEMDIC.js} +1 -1
- package/build/{cookie-H7KRZB4T.js → cookie-WBWYVEDW.js} +2 -2
- package/build/factories/main.js +4 -4
- package/build/{file-YO7C2QWO.js → file-B6QKOZXW.js} +7 -3
- package/build/file-B6QKOZXW.js.map +1 -0
- package/build/index.d.ts +2 -0
- package/build/index.js +11 -3
- package/build/providers/session_provider.js +3 -3
- package/build/{redis-KDWIBKUQ.js → redis-CAY24YIA.js} +2 -2
- package/build/src/client.js +2 -2
- package/build/src/plugins/edge.js +1 -1
- package/build/src/plugins/japa/api_client.js +2 -2
- package/build/src/plugins/japa/browser_client.js +2 -2
- package/build/src/session.d.ts +2 -1
- package/build/src/session_middleware.js +3 -3
- package/build/src/stores/file.d.ts +5 -0
- package/package.json +28 -27
- package/build/chunk-2X5L327N.js +0 -28
- package/build/chunk-2X5L327N.js.map +0 -1
- package/build/chunk-EQQI5S2T.js.map +0 -1
- package/build/file-YO7C2QWO.js.map +0 -1
- /package/build/{chunk-S6P3TBEK.js.map → chunk-GB5FBZCV.js.map} +0 -0
- /package/build/{chunk-7YIO32ZH.js.map → chunk-Y3BSCW5X.js.map} +0 -0
- /package/build/{chunk-WBAYBMJJ.js.map → chunk-ZVSEMDIC.js.map} +0 -0
- /package/build/{cookie-H7KRZB4T.js.map → cookie-WBWYVEDW.js.map} +0 -0
- /package/build/{redis-KDWIBKUQ.js.map → redis-CAY24YIA.js.map} +0 -0
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
} from "./chunk-TE5JP3SX.js";
|
|
4
4
|
import {
|
|
5
5
|
debug_default
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-ZVSEMDIC.js";
|
|
7
7
|
|
|
8
8
|
// src/client.ts
|
|
9
9
|
import { cuid } from "@adonisjs/core/helpers";
|
|
@@ -82,4 +82,4 @@ var SessionClient = class {
|
|
|
82
82
|
export {
|
|
83
83
|
SessionClient
|
|
84
84
|
};
|
|
85
|
-
//# sourceMappingURL=chunk-
|
|
85
|
+
//# sourceMappingURL=chunk-GB5FBZCV.js.map
|
|
@@ -1,23 +1,37 @@
|
|
|
1
|
-
import {
|
|
2
|
-
E_SESSION_NOT_MUTABLE,
|
|
3
|
-
E_SESSION_NOT_READY
|
|
4
|
-
} from "./chunk-2X5L327N.js";
|
|
5
1
|
import {
|
|
6
2
|
ReadOnlyValuesStore,
|
|
7
3
|
ValuesStore
|
|
8
4
|
} from "./chunk-TE5JP3SX.js";
|
|
9
5
|
import {
|
|
6
|
+
__export,
|
|
10
7
|
debug_default
|
|
11
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-ZVSEMDIC.js";
|
|
12
9
|
|
|
13
|
-
// src/
|
|
14
|
-
|
|
10
|
+
// src/errors.ts
|
|
11
|
+
var errors_exports = {};
|
|
12
|
+
__export(errors_exports, {
|
|
13
|
+
E_SESSION_NOT_MUTABLE: () => E_SESSION_NOT_MUTABLE,
|
|
14
|
+
E_SESSION_NOT_READY: () => E_SESSION_NOT_READY
|
|
15
|
+
});
|
|
16
|
+
import { createError } from "@poppinss/utils";
|
|
17
|
+
var E_SESSION_NOT_MUTABLE = createError(
|
|
18
|
+
"Session store is in readonly mode and cannot be mutated",
|
|
19
|
+
"E_SESSION_NOT_MUTABLE",
|
|
20
|
+
500
|
|
21
|
+
);
|
|
22
|
+
var E_SESSION_NOT_READY = createError(
|
|
23
|
+
"Session store has not been initiated. Make sure you have registered the session middleware",
|
|
24
|
+
"E_SESSION_NOT_READY",
|
|
25
|
+
500
|
|
26
|
+
);
|
|
15
27
|
|
|
16
28
|
// src/session.ts
|
|
29
|
+
import Macroable from "@poppinss/macroable";
|
|
17
30
|
import lodash from "@poppinss/utils/lodash";
|
|
18
31
|
import { cuid } from "@adonisjs/core/helpers";
|
|
19
|
-
var Session = class {
|
|
32
|
+
var Session = class extends Macroable {
|
|
20
33
|
constructor(config, storeFactory, emitter, ctx) {
|
|
34
|
+
super();
|
|
21
35
|
this.config = config;
|
|
22
36
|
this.#ctx = ctx;
|
|
23
37
|
this.#emitter = emitter;
|
|
@@ -373,42 +387,8 @@ var Session = class {
|
|
|
373
387
|
}
|
|
374
388
|
};
|
|
375
389
|
|
|
376
|
-
// src/session_middleware.ts
|
|
377
|
-
var originalErrorHandler = ExceptionHandler.prototype.renderValidationErrorAsHTML;
|
|
378
|
-
ExceptionHandler.macro("renderValidationErrorAsHTML", async function(error, ctx) {
|
|
379
|
-
if (ctx.session) {
|
|
380
|
-
ctx.session.flashValidationErrors(error);
|
|
381
|
-
ctx.response.redirect("back", true);
|
|
382
|
-
} else {
|
|
383
|
-
return originalErrorHandler(error, ctx);
|
|
384
|
-
}
|
|
385
|
-
});
|
|
386
|
-
var SessionMiddleware = class {
|
|
387
|
-
#config;
|
|
388
|
-
#emitter;
|
|
389
|
-
constructor(config, emitter) {
|
|
390
|
-
this.#config = config;
|
|
391
|
-
this.#emitter = emitter;
|
|
392
|
-
}
|
|
393
|
-
async handle(ctx, next) {
|
|
394
|
-
if (!this.#config.enabled) {
|
|
395
|
-
return next();
|
|
396
|
-
}
|
|
397
|
-
ctx.session = new Session(
|
|
398
|
-
this.#config,
|
|
399
|
-
this.#config.stores[this.#config.store],
|
|
400
|
-
// reference to store factory
|
|
401
|
-
this.#emitter,
|
|
402
|
-
ctx
|
|
403
|
-
);
|
|
404
|
-
await ctx.session.initiate(false);
|
|
405
|
-
const response = await next();
|
|
406
|
-
await ctx.session.commit();
|
|
407
|
-
return response;
|
|
408
|
-
}
|
|
409
|
-
};
|
|
410
|
-
|
|
411
390
|
export {
|
|
412
|
-
|
|
391
|
+
errors_exports,
|
|
392
|
+
Session
|
|
413
393
|
};
|
|
414
|
-
//# sourceMappingURL=chunk-
|
|
394
|
+
//# sourceMappingURL=chunk-OCQGCVXK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/errors.ts","../src/session.ts"],"sourcesContent":["/*\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport { createError } from '@poppinss/utils'\n\n/**\n * Raised when session store is not mutable\n */\nexport const E_SESSION_NOT_MUTABLE = createError(\n 'Session store is in readonly mode and cannot be mutated',\n 'E_SESSION_NOT_MUTABLE',\n 500\n)\n\n/**\n * Raised when session store has been initiated\n */\nexport const E_SESSION_NOT_READY = createError(\n 'Session store has not been initiated. Make sure you have registered the session middleware',\n 'E_SESSION_NOT_READY',\n 500\n)\n","/*\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport type { I18n } from '@adonisjs/i18n'\nimport Macroable from '@poppinss/macroable'\nimport lodash from '@poppinss/utils/lodash'\nimport { cuid } from '@adonisjs/core/helpers'\nimport type { HttpContext } from '@adonisjs/core/http'\nimport type { EmitterService } from '@adonisjs/core/types'\nimport type { HttpError } from '@adonisjs/core/types/http'\n\nimport debug from './debug.js'\nimport * as errors from './errors.js'\nimport { ReadOnlyValuesStore, ValuesStore } from './values_store.js'\nimport type {\n SessionData,\n SessionConfig,\n SessionStoreFactory,\n AllowedSessionValues,\n SessionStoreContract,\n} from './types.js'\n\n/**\n * The session class exposes the API to read and write values to\n * the session store.\n *\n * A session instance is isolated between requests but\n * uses a centralized persistence store and\n */\nexport class Session extends Macroable {\n #store: SessionStoreContract\n #emitter: EmitterService\n #ctx: HttpContext\n #readonly: boolean = false\n\n /**\n * Session values store\n */\n #valuesStore?: ValuesStore\n\n /**\n * Session id refers to the session id that will be committed\n * as a cookie during the response.\n */\n #sessionId: string\n\n /**\n * Session id from cookie refers to the value we read from the\n * cookie during the HTTP request.\n *\n * This only might not exist during the first request. Also during\n * session id re-generation, this value will be different from\n * the session id.\n */\n #sessionIdFromCookie?: string\n\n /**\n * Store of flash messages that be written during the\n * HTTP request\n */\n responseFlashMessages = new ValuesStore({})\n\n /**\n * Store of flash messages for the current HTTP request.\n */\n flashMessages = new ValuesStore({})\n\n /**\n * The key to use for storing flash messages inside\n * the session store.\n */\n flashKey: string = '__flash__'\n\n /**\n * Session id for the current HTTP request\n */\n get sessionId() {\n return this.#sessionId\n }\n\n /**\n * A boolean to know if a fresh session is created during\n * the request\n */\n get fresh(): boolean {\n return this.#sessionIdFromCookie === undefined\n }\n\n /**\n * A boolean to know if session is in readonly\n * state\n */\n get readonly() {\n return this.#readonly\n }\n\n /**\n * A boolean to know if session store has been initiated\n */\n get initiated() {\n return !!this.#valuesStore\n }\n\n /**\n * A boolean to know if the session id has been re-generated\n * during the current request\n */\n get hasRegeneratedSession() {\n return !!(this.#sessionIdFromCookie && this.#sessionIdFromCookie !== this.#sessionId)\n }\n\n /**\n * A boolean to know if the session store is empty\n */\n get isEmpty() {\n return this.#valuesStore?.isEmpty ?? true\n }\n\n /**\n * A boolean to know if the session store has been\n * modified\n */\n get hasBeenModified() {\n return this.#valuesStore?.hasBeenModified ?? false\n }\n\n constructor(\n public config: SessionConfig,\n storeFactory: SessionStoreFactory,\n emitter: EmitterService,\n ctx: HttpContext\n ) {\n super()\n this.#ctx = ctx\n this.#emitter = emitter\n this.#store = storeFactory(ctx, config)\n this.#sessionIdFromCookie = ctx.request.cookie(config.cookieName, undefined)\n this.#sessionId = this.#sessionIdFromCookie || cuid()\n }\n\n /**\n * Returns the flash messages store for a given\n * mode\n */\n #getFlashStore(mode: 'write' | 'read'): ValuesStore {\n if (!this.#valuesStore) {\n throw new errors.E_SESSION_NOT_READY()\n }\n\n if (mode === 'write' && this.readonly) {\n throw new errors.E_SESSION_NOT_MUTABLE()\n }\n\n return this.responseFlashMessages\n }\n\n /**\n * Returns the store instance for a given mode\n */\n #getValuesStore(mode: 'write' | 'read'): ValuesStore {\n if (!this.#valuesStore) {\n throw new errors.E_SESSION_NOT_READY()\n }\n\n if (mode === 'write' && this.readonly) {\n throw new errors.E_SESSION_NOT_MUTABLE()\n }\n\n return this.#valuesStore\n }\n\n /**\n * Initiates the session store. The method results in a noop\n * when called multiple times\n */\n async initiate(readonly: boolean): Promise<void> {\n if (this.#valuesStore) {\n return\n }\n\n debug('initiating session (readonly: %s)', readonly)\n\n this.#readonly = readonly\n const contents = await this.#store.read(this.#sessionId)\n this.#valuesStore = new ValuesStore(contents)\n\n /**\n * Extract flash messages from the store and keep a local\n * copy of it.\n */\n if (this.has(this.flashKey)) {\n debug('reading flash data')\n if (this.#readonly) {\n this.flashMessages.update(this.get(this.flashKey, null))\n } else {\n this.flashMessages.update(this.pull(this.flashKey, null))\n }\n }\n\n /**\n * Share session with the templates. We assume the view property\n * is a reference to edge templates\n */\n if ('view' in this.#ctx) {\n this.#ctx.view.share({\n session: new ReadOnlyValuesStore(this.#valuesStore.all()),\n flashMessages: new ReadOnlyValuesStore(this.flashMessages.all()),\n old: function (key: string, defaultValue?: any) {\n return this.flashMessages.get(key, defaultValue)\n },\n })\n }\n\n this.#emitter.emit('session:initiated', { session: this })\n }\n\n /**\n * Put a key-value pair to the session data store\n */\n put(key: string, value: AllowedSessionValues) {\n this.#getValuesStore('write').set(key, value)\n }\n\n /**\n * Check if a key exists inside the datastore\n */\n has(key: string): boolean {\n return this.#getValuesStore('read').has(key)\n }\n\n /**\n * Get the value of a key from the session datastore.\n * You can specify a default value to use, when key\n * does not exists or has undefined value.\n */\n get(key: string, defaultValue?: any) {\n return this.#getValuesStore('read').get(key, defaultValue)\n }\n\n /**\n * Get everything from the session store\n */\n all() {\n return this.#getValuesStore('read').all()\n }\n\n /**\n * Remove a key from the session datastore\n */\n forget(key: string) {\n return this.#getValuesStore('write').unset(key)\n }\n\n /**\n * Read value for a key from the session datastore\n * and remove it simultaneously.\n */\n pull(key: string, defaultValue?: any) {\n return this.#getValuesStore('write').pull(key, defaultValue)\n }\n\n /**\n * Increment the value of a key inside the session\n * store.\n *\n * A new key will be defined if does not exists already.\n * The value of a new key will be 1\n */\n increment(key: string, steps: number = 1) {\n return this.#getValuesStore('write').increment(key, steps)\n }\n\n /**\n * Increment the value of a key inside the session\n * store.\n *\n * A new key will be defined if does not exists already.\n * The value of a new key will be -1\n */\n decrement(key: string, steps: number = 1) {\n return this.#getValuesStore('write').decrement(key, steps)\n }\n\n /**\n * Empty the session store\n */\n clear() {\n return this.#getValuesStore('write').clear()\n }\n\n /**\n * Add a key-value pair to flash messages\n */\n flash(key: string, value: AllowedSessionValues): void\n flash(keyValue: SessionData): void\n flash(key: string | SessionData, value?: AllowedSessionValues): void {\n if (typeof key === 'string') {\n if (value) {\n this.#getFlashStore('write').set(key, value)\n }\n } else {\n this.#getFlashStore('write').merge(key)\n }\n }\n\n /**\n * Flash errors to the errorsBag. You can read these\n * errors via the \"@error\" tag.\n *\n * Appends new messages to the existing collection.\n */\n flashErrors(errorsCollection: Record<string, string | string[]>) {\n this.flash({ errorsBag: errorsCollection })\n }\n\n /**\n * Flash validation error messages. Make sure the error\n * is an instance of VineJS ValidationException.\n *\n * Overrides existing inputErrors\n */\n flashValidationErrors(error: HttpError) {\n const errorsBag = error.messages.reduce((result: Record<string, string[]>, message: any) => {\n if (result[message.field]) {\n result[message.field].push(message.message)\n } else {\n result[message.field] = [message.message]\n }\n return result\n }, {})\n\n this.flashExcept(['_csrf', '_method', 'password', 'password_confirmation'])\n\n /**\n * Adding the error summary to the \"errorsBag\" so that\n * we display the validation error globally using\n * the \"@error\" tag.\n */\n let summary = 'The form could not be saved. Please check the errors below.'\n if ('i18n' in this.#ctx) {\n summary = (this.#ctx.i18n as I18n).t(\n `errors.${error.code}`,\n {\n count: error.messages.length,\n },\n summary\n )\n }\n\n this.flashErrors({\n [String(error.code)]: summary,\n })\n\n /**\n * Adding to inputErrorsBag for \"@inputError\" tag\n * to read validation errors\n */\n this.flash('inputErrorsBag', errorsBag)\n\n /**\n * For legacy support and not to break apps using\n * the older version of @adonisjs/session package\n */\n this.flash('errors', errorsBag)\n }\n\n /**\n * Flash form input data to the flash messages store\n */\n flashAll() {\n return this.#getFlashStore('write').set('input', this.#ctx.request.original())\n }\n\n /**\n * Flash form input data (except some keys) to the flash messages store\n */\n flashExcept(keys: string[]): void {\n this.#getFlashStore('write').set('input', lodash.omit(this.#ctx.request.original(), keys))\n }\n\n /**\n * Flash form input data (only some keys) to the flash messages store\n */\n flashOnly(keys: string[]): void {\n this.#getFlashStore('write').set('input', lodash.pick(this.#ctx.request.original(), keys))\n }\n\n /**\n * Reflash messages from the last request in the current response\n */\n reflash(): void {\n this.#getFlashStore('write').set('reflashed', this.flashMessages.all())\n }\n\n /**\n * Reflash messages (only some keys) from the last\n * request in the current response\n */\n reflashOnly(keys: string[]) {\n this.#getFlashStore('write').set('reflashed', lodash.pick(this.flashMessages.all(), keys))\n }\n\n /**\n * Reflash messages (except some keys) from the last\n * request in the current response\n */\n reflashExcept(keys: string[]) {\n this.#getFlashStore('write').set('reflashed', lodash.omit(this.flashMessages.all(), keys))\n }\n\n /**\n * Re-generate the session id and migrate data to it.\n */\n regenerate() {\n this.#sessionId = cuid()\n }\n\n /**\n * Commit session changes. No more mutations will be\n * allowed after commit.\n */\n async commit() {\n if (!this.#valuesStore || this.readonly) {\n return\n }\n\n /**\n * If the flash messages store is not empty, we should put\n * its messages inside main session store.\n */\n if (!this.responseFlashMessages.isEmpty) {\n const { input, reflashed, ...others } = this.responseFlashMessages.all()\n this.put(this.flashKey, { ...reflashed, ...input, ...others })\n }\n\n debug('committing session data')\n\n /**\n * Touch the session id cookie to stay alive\n */\n this.#ctx.response.cookie(this.config.cookieName, this.#sessionId, this.config.cookie!)\n\n /**\n * Delete the session data when the session store\n * is empty.\n *\n * Also we only destroy the session id we read from the cookie.\n * If there was no session id in the cookie, there won't be\n * any data inside the store either.\n */\n if (this.isEmpty) {\n if (this.#sessionIdFromCookie) {\n await this.#store.destroy(this.#sessionIdFromCookie)\n }\n this.#emitter.emit('session:committed', { session: this })\n return\n }\n\n /**\n * Touch the store expiry when the session store was\n * not modified.\n */\n if (!this.hasBeenModified) {\n if (this.#sessionIdFromCookie && this.#sessionIdFromCookie !== this.#sessionId) {\n await this.#store.destroy(this.#sessionIdFromCookie)\n await this.#store.write(this.#sessionId, this.#valuesStore.toJSON())\n this.#emitter.emit('session:migrated', {\n fromSessionId: this.#sessionIdFromCookie,\n toSessionId: this.sessionId,\n session: this,\n })\n } else {\n await this.#store.touch(this.#sessionId)\n }\n this.#emitter.emit('session:committed', { session: this })\n return\n }\n\n /**\n * Otherwise commit to the session store\n */\n if (this.#sessionIdFromCookie && this.#sessionIdFromCookie !== this.#sessionId) {\n await this.#store.destroy(this.#sessionIdFromCookie)\n await this.#store.write(this.#sessionId, this.#valuesStore.toJSON())\n this.#emitter.emit('session:migrated', {\n fromSessionId: this.#sessionIdFromCookie,\n toSessionId: this.sessionId,\n session: this,\n })\n } else {\n await this.#store.write(this.#sessionId, this.#valuesStore.toJSON())\n }\n\n this.#emitter.emit('session:committed', { session: this })\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Session
|
|
3
|
+
} from "./chunk-OCQGCVXK.js";
|
|
4
|
+
|
|
5
|
+
// src/session_middleware.ts
|
|
6
|
+
import { ExceptionHandler } from "@adonisjs/core/http";
|
|
7
|
+
var originalErrorHandler = ExceptionHandler.prototype.renderValidationErrorAsHTML;
|
|
8
|
+
ExceptionHandler.macro("renderValidationErrorAsHTML", async function(error, ctx) {
|
|
9
|
+
if (ctx.session) {
|
|
10
|
+
ctx.session.flashValidationErrors(error);
|
|
11
|
+
ctx.response.redirect("back", true);
|
|
12
|
+
} else {
|
|
13
|
+
return originalErrorHandler(error, ctx);
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
var SessionMiddleware = class {
|
|
17
|
+
#config;
|
|
18
|
+
#emitter;
|
|
19
|
+
constructor(config, emitter) {
|
|
20
|
+
this.#config = config;
|
|
21
|
+
this.#emitter = emitter;
|
|
22
|
+
}
|
|
23
|
+
async handle(ctx, next) {
|
|
24
|
+
if (!this.#config.enabled) {
|
|
25
|
+
return next();
|
|
26
|
+
}
|
|
27
|
+
ctx.session = new Session(
|
|
28
|
+
this.#config,
|
|
29
|
+
this.#config.stores[this.#config.store],
|
|
30
|
+
// reference to store factory
|
|
31
|
+
this.#emitter,
|
|
32
|
+
ctx
|
|
33
|
+
);
|
|
34
|
+
await ctx.session.initiate(false);
|
|
35
|
+
const response = await next();
|
|
36
|
+
await ctx.session.commit();
|
|
37
|
+
return response;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export {
|
|
42
|
+
SessionMiddleware
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=chunk-TZLOND27.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/session_middleware.ts"],"sourcesContent":["/*\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport { EmitterService } from '@adonisjs/core/types'\nimport type { NextFn } from '@adonisjs/core/types/http'\nimport { ExceptionHandler, HttpContext } from '@adonisjs/core/http'\n\nimport { Session } from './session.js'\nimport type { SessionConfig, SessionStoreFactory } from './types.js'\n\n/**\n * HttpContext augmentations\n */\ndeclare module '@adonisjs/core/http' {\n export interface HttpContext {\n session: Session\n }\n}\n\n/**\n * Overwriting validation exception renderer\n */\nconst originalErrorHandler = ExceptionHandler.prototype.renderValidationErrorAsHTML\nExceptionHandler.macro('renderValidationErrorAsHTML', async function (error, ctx) {\n if (ctx.session) {\n ctx.session.flashValidationErrors(error)\n ctx.response.redirect('back', true)\n } else {\n return originalErrorHandler(error, ctx)\n }\n})\n\n/**\n * Session middleware is used to initiate the session store\n * and commit its values during an HTTP request\n */\nexport default class SessionMiddleware<KnownStores extends Record<string, SessionStoreFactory>> {\n #config: SessionConfig & {\n store: keyof KnownStores\n stores: KnownStores\n }\n #emitter: EmitterService\n\n constructor(\n config: SessionConfig & {\n store: keyof KnownStores\n stores: KnownStores\n },\n emitter: EmitterService\n ) {\n this.#config = config\n this.#emitter = emitter\n }\n\n async handle(ctx: HttpContext, next: NextFn) {\n if (!this.#config.enabled) {\n return next()\n }\n\n ctx.session = new Session(\n this.#config,\n this.#config.stores[this.#config.store], // reference to store factory\n this.#emitter,\n ctx\n )\n\n /**\n * Initiate session store\n */\n await ctx.session.initiate(false)\n\n /**\n * Call next middlewares or route handler\n */\n const response = await next()\n\n /**\n * Commit store mutations\n */\n await ctx.session.commit()\n\n /**\n * Return response\n */\n return response\n }\n}\n"],"mappings":";;;;;AAWA,SAAS,wBAAqC;AAiB9C,IAAM,uBAAuB,iBAAiB,UAAU;AACxD,iBAAiB,MAAM,+BAA+B,eAAgB,OAAO,KAAK;AAChF,MAAI,IAAI,SAAS;AACf,QAAI,QAAQ,sBAAsB,KAAK;AACvC,QAAI,SAAS,SAAS,QAAQ,IAAI;AAAA,EACpC,OAAO;AACL,WAAO,qBAAqB,OAAO,GAAG;AAAA,EACxC;AACF,CAAC;AAMD,IAAqB,oBAArB,MAAgG;AAAA,EAC9F;AAAA,EAIA;AAAA,EAEA,YACE,QAIA,SACA;AACA,SAAK,UAAU;AACf,SAAK,WAAW;AAAA,EAClB;AAAA,EAEA,MAAM,OAAO,KAAkB,MAAc;AAC3C,QAAI,CAAC,KAAK,QAAQ,SAAS;AACzB,aAAO,KAAK;AAAA,IACd;AAEA,QAAI,UAAU,IAAI;AAAA,MAChB,KAAK;AAAA,MACL,KAAK,QAAQ,OAAO,KAAK,QAAQ,KAAK;AAAA;AAAA,MACtC,KAAK;AAAA,MACL;AAAA,IACF;AAKA,UAAM,IAAI,QAAQ,SAAS,KAAK;AAKhC,UAAM,WAAW,MAAM,KAAK;AAK5B,UAAM,IAAI,QAAQ,OAAO;AAKzB,WAAO;AAAA,EACT;AACF;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
debug_default
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-ZVSEMDIC.js";
|
|
4
4
|
|
|
5
5
|
// stubs/main.ts
|
|
6
6
|
import { getDirname } from "@poppinss/utils";
|
|
@@ -100,7 +100,7 @@ function defineConfig(config) {
|
|
|
100
100
|
var stores = {
|
|
101
101
|
file: (config) => {
|
|
102
102
|
return configProvider.create(async () => {
|
|
103
|
-
const { FileStore } = await import("./file-
|
|
103
|
+
const { FileStore } = await import("./file-B6QKOZXW.js");
|
|
104
104
|
return (_, sessionConfig) => {
|
|
105
105
|
return new FileStore(config, sessionConfig.age);
|
|
106
106
|
};
|
|
@@ -108,7 +108,7 @@ var stores = {
|
|
|
108
108
|
},
|
|
109
109
|
redis: (config) => {
|
|
110
110
|
return configProvider.create(async (app) => {
|
|
111
|
-
const { RedisStore } = await import("./redis-
|
|
111
|
+
const { RedisStore } = await import("./redis-CAY24YIA.js");
|
|
112
112
|
const redis = await app.container.make("redis");
|
|
113
113
|
return (_, sessionConfig) => {
|
|
114
114
|
return new RedisStore(redis.connection(config.connection), sessionConfig.age);
|
|
@@ -117,7 +117,7 @@ var stores = {
|
|
|
117
117
|
},
|
|
118
118
|
cookie: () => {
|
|
119
119
|
return configProvider.create(async () => {
|
|
120
|
-
const { CookieStore } = await import("./cookie-
|
|
120
|
+
const { CookieStore } = await import("./cookie-WBWYVEDW.js");
|
|
121
121
|
return (ctx, sessionConfig) => {
|
|
122
122
|
return new CookieStore(sessionConfig.cookie, ctx);
|
|
123
123
|
};
|
|
@@ -131,4 +131,4 @@ export {
|
|
|
131
131
|
defineConfig,
|
|
132
132
|
stores
|
|
133
133
|
};
|
|
134
|
-
//# sourceMappingURL=chunk-
|
|
134
|
+
//# sourceMappingURL=chunk-Y3BSCW5X.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
debug_default
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-ZVSEMDIC.js";
|
|
4
4
|
|
|
5
5
|
// src/stores/cookie.ts
|
|
6
6
|
var CookieStore = class {
|
|
@@ -53,4 +53,4 @@ var CookieStore = class {
|
|
|
53
53
|
export {
|
|
54
54
|
CookieStore
|
|
55
55
|
};
|
|
56
|
-
//# sourceMappingURL=cookie-
|
|
56
|
+
//# sourceMappingURL=cookie-WBWYVEDW.js.map
|
package/build/factories/main.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
defineConfig
|
|
3
|
-
} from "../chunk-
|
|
3
|
+
} from "../chunk-Y3BSCW5X.js";
|
|
4
4
|
import {
|
|
5
5
|
SessionMiddleware
|
|
6
|
-
} from "../chunk-
|
|
7
|
-
import "../chunk-
|
|
6
|
+
} from "../chunk-TZLOND27.js";
|
|
7
|
+
import "../chunk-OCQGCVXK.js";
|
|
8
8
|
import "../chunk-TE5JP3SX.js";
|
|
9
|
-
import "../chunk-
|
|
9
|
+
import "../chunk-ZVSEMDIC.js";
|
|
10
10
|
|
|
11
11
|
// factories/session_middleware_factory.ts
|
|
12
12
|
import { Emitter } from "@adonisjs/core/events";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
debug_default
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-ZVSEMDIC.js";
|
|
4
4
|
|
|
5
5
|
// src/stores/file.ts
|
|
6
6
|
import { dirname, join } from "node:path";
|
|
@@ -10,6 +10,10 @@ import { access, mkdir, readFile, rm, writeFile, utimes, stat } from "node:fs/pr
|
|
|
10
10
|
var FileStore = class {
|
|
11
11
|
#config;
|
|
12
12
|
#age;
|
|
13
|
+
/**
|
|
14
|
+
* @param {FileStoreConfig} config
|
|
15
|
+
* @param {string|number} The age must be in seconds or a time expression
|
|
16
|
+
*/
|
|
13
17
|
constructor(config, age) {
|
|
14
18
|
this.#config = config;
|
|
15
19
|
this.#age = age;
|
|
@@ -65,7 +69,7 @@ var FileStore = class {
|
|
|
65
69
|
if (!stats) {
|
|
66
70
|
return null;
|
|
67
71
|
}
|
|
68
|
-
const sessionWillExpireAt = stats.mtimeMs + string.
|
|
72
|
+
const sessionWillExpireAt = stats.mtimeMs + string.seconds.parse(this.#age) * 1e3;
|
|
69
73
|
if (Date.now() > sessionWillExpireAt) {
|
|
70
74
|
debug_default("file store: expired session data %s", sessionId);
|
|
71
75
|
return null;
|
|
@@ -109,4 +113,4 @@ var FileStore = class {
|
|
|
109
113
|
export {
|
|
110
114
|
FileStore
|
|
111
115
|
};
|
|
112
|
-
//# sourceMappingURL=file-
|
|
116
|
+
//# sourceMappingURL=file-B6QKOZXW.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/stores/file.ts"],"sourcesContent":["/**\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport type { Stats } from 'node:fs'\nimport { dirname, join } from 'node:path'\nimport string from '@poppinss/utils/string'\nimport { MessageBuilder } from '@adonisjs/core/helpers'\nimport { access, mkdir, readFile, rm, writeFile, utimes, stat } from 'node:fs/promises'\n\nimport debug from '../debug.js'\nimport type { FileStoreConfig, SessionData, SessionStoreContract } from '../types.js'\n\n/**\n * File store writes the session data on the file system as. Each session\n * id gets its own file.\n *\n */\nexport class FileStore implements SessionStoreContract {\n #config: FileStoreConfig\n #age: string | number\n\n /**\n * @param {FileStoreConfig} config\n * @param {string|number} The age must be in seconds or a time expression\n */\n constructor(config: FileStoreConfig, age: string | number) {\n this.#config = config\n this.#age = age\n debug('initiating file store %O', this.#config)\n }\n\n /**\n * Returns an absolute path to the session id file\n */\n #getFilePath(sessionId: string): string {\n return join(this.#config.location, `${sessionId}.txt`)\n }\n\n /**\n * Check if a file exists at a given path or not\n */\n async #pathExists(path: string) {\n try {\n await access(path)\n return true\n } catch {\n return false\n }\n }\n\n /**\n * Returns stats for a file and ignoring missing\n * files.\n */\n async #stats(path: string): Promise<Stats | null> {\n try {\n const stats = await stat(path)\n return stats\n } catch {\n return null\n }\n }\n\n /**\n * Output file with contents to the given path\n */\n async #outputFile(path: string, contents: string) {\n const pathDirname = dirname(path)\n\n const dirExists = await this.#pathExists(pathDirname)\n if (!dirExists) {\n await mkdir(pathDirname, { recursive: true })\n }\n\n await writeFile(path, contents, 'utf-8')\n }\n\n /**\n * Reads the session data from the disk.\n */\n async read(sessionId: string): Promise<SessionData | null> {\n const filePath = this.#getFilePath(sessionId)\n debug('file store: reading session data %', sessionId)\n\n /**\n * Return null when no session id file exists in first\n * place\n */\n const stats = await this.#stats(filePath)\n if (!stats) {\n return null\n }\n\n /**\n * Check if the file has been expired and return null (if expired)\n */\n const sessionWillExpireAt = stats.mtimeMs + string.seconds.parse(this.#age) * 1000\n if (Date.now() > sessionWillExpireAt) {\n debug('file store: expired session data %s', sessionId)\n return null\n }\n\n /**\n * Reading the file contents if the file exists\n */\n let contents = await readFile(filePath, 'utf-8')\n contents = contents.trim()\n if (!contents) {\n return null\n }\n\n /**\n * Verify contents with the session id and return them as an object. The verify\n * method can fail when the contents is not JSON>\n */\n try {\n return new MessageBuilder().verify<SessionData>(contents, sessionId)\n } catch {\n return null\n }\n }\n\n /**\n * Writes the session data to the disk as a string\n */\n async write(sessionId: string, values: SessionData): Promise<void> {\n debug('file store: writing session data %s: %O', sessionId, values)\n\n const filePath = this.#getFilePath(sessionId)\n const message = new MessageBuilder().build(values, undefined, sessionId)\n\n await this.#outputFile(filePath, message)\n }\n\n /**\n * Removes the session file from the disk\n */\n async destroy(sessionId: string): Promise<void> {\n debug('file store: destroying session data %s', sessionId)\n await rm(this.#getFilePath(sessionId), { force: true })\n }\n\n /**\n * Updates the session expiry by rewriting it to the\n * persistence store\n */\n async touch(sessionId: string): Promise<void> {\n debug('file store: touching session data %s', sessionId)\n await utimes(this.#getFilePath(sessionId), new Date(), new Date())\n }\n}\n"],"mappings":";;;;;AAUA,SAAS,SAAS,YAAY;AAC9B,OAAO,YAAY;AACnB,SAAS,sBAAsB;AAC/B,SAAS,QAAQ,OAAO,UAAU,IAAI,WAAW,QAAQ,YAAY;AAU9D,IAAM,YAAN,MAAgD;AAAA,EACrD;AAAA,EACA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,YAAY,QAAyB,KAAsB;AACzD,SAAK,UAAU;AACf,SAAK,OAAO;AACZ,kBAAM,4BAA4B,KAAK,OAAO;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA,EAKA,aAAa,WAA2B;AACtC,WAAO,KAAK,KAAK,QAAQ,UAAU,GAAG,SAAS,MAAM;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAY,MAAc;AAC9B,QAAI;AACF,YAAM,OAAO,IAAI;AACjB,aAAO;AAAA,IACT,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,OAAO,MAAqC;AAChD,QAAI;AACF,YAAM,QAAQ,MAAM,KAAK,IAAI;AAC7B,aAAO;AAAA,IACT,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAY,MAAc,UAAkB;AAChD,UAAM,cAAc,QAAQ,IAAI;AAEhC,UAAM,YAAY,MAAM,KAAK,YAAY,WAAW;AACpD,QAAI,CAAC,WAAW;AACd,YAAM,MAAM,aAAa,EAAE,WAAW,KAAK,CAAC;AAAA,IAC9C;AAEA,UAAM,UAAU,MAAM,UAAU,OAAO;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,KAAK,WAAgD;AACzD,UAAM,WAAW,KAAK,aAAa,SAAS;AAC5C,kBAAM,sCAAsC,SAAS;AAMrD,UAAM,QAAQ,MAAM,KAAK,OAAO,QAAQ;AACxC,QAAI,CAAC,OAAO;AACV,aAAO;AAAA,IACT;AAKA,UAAM,sBAAsB,MAAM,UAAU,OAAO,QAAQ,MAAM,KAAK,IAAI,IAAI;AAC9E,QAAI,KAAK,IAAI,IAAI,qBAAqB;AACpC,oBAAM,uCAAuC,SAAS;AACtD,aAAO;AAAA,IACT;AAKA,QAAI,WAAW,MAAM,SAAS,UAAU,OAAO;AAC/C,eAAW,SAAS,KAAK;AACzB,QAAI,CAAC,UAAU;AACb,aAAO;AAAA,IACT;AAMA,QAAI;AACF,aAAO,IAAI,eAAe,EAAE,OAAoB,UAAU,SAAS;AAAA,IACrE,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,MAAM,WAAmB,QAAoC;AACjE,kBAAM,2CAA2C,WAAW,MAAM;AAElE,UAAM,WAAW,KAAK,aAAa,SAAS;AAC5C,UAAM,UAAU,IAAI,eAAe,EAAE,MAAM,QAAQ,QAAW,SAAS;AAEvE,UAAM,KAAK,YAAY,UAAU,OAAO;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QAAQ,WAAkC;AAC9C,kBAAM,0CAA0C,SAAS;AACzD,UAAM,GAAG,KAAK,aAAa,SAAS,GAAG,EAAE,OAAO,KAAK,CAAC;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,MAAM,WAAkC;AAC5C,kBAAM,wCAAwC,SAAS;AACvD,UAAM,OAAO,KAAK,aAAa,SAAS,GAAG,oBAAI,KAAK,GAAG,oBAAI,KAAK,CAAC;AAAA,EACnE;AACF;","names":[]}
|
package/build/index.d.ts
CHANGED
|
@@ -8,5 +8,7 @@
|
|
|
8
8
|
*/
|
|
9
9
|
export * as errors from './src/errors.js';
|
|
10
10
|
export { configure } from './configure.js';
|
|
11
|
+
export { Session } from './src/session.js';
|
|
11
12
|
export { stubsRoot } from './stubs/main.js';
|
|
12
13
|
export { defineConfig, stores } from './src/define_config.js';
|
|
14
|
+
export { ReadOnlyValuesStore, ValuesStore } from './src/values_store.js';
|
package/build/index.js
CHANGED
|
@@ -3,12 +3,20 @@ import {
|
|
|
3
3
|
defineConfig,
|
|
4
4
|
stores,
|
|
5
5
|
stubsRoot
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-Y3BSCW5X.js";
|
|
7
7
|
import {
|
|
8
|
+
Session,
|
|
8
9
|
errors_exports
|
|
9
|
-
} from "./chunk-
|
|
10
|
-
import
|
|
10
|
+
} from "./chunk-OCQGCVXK.js";
|
|
11
|
+
import {
|
|
12
|
+
ReadOnlyValuesStore,
|
|
13
|
+
ValuesStore
|
|
14
|
+
} from "./chunk-TE5JP3SX.js";
|
|
15
|
+
import "./chunk-ZVSEMDIC.js";
|
|
11
16
|
export {
|
|
17
|
+
ReadOnlyValuesStore,
|
|
18
|
+
Session,
|
|
19
|
+
ValuesStore,
|
|
12
20
|
configure,
|
|
13
21
|
defineConfig,
|
|
14
22
|
errors_exports as errors,
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SessionMiddleware
|
|
3
|
-
} from "../chunk-
|
|
4
|
-
import "../chunk-
|
|
3
|
+
} from "../chunk-TZLOND27.js";
|
|
4
|
+
import "../chunk-OCQGCVXK.js";
|
|
5
5
|
import "../chunk-TE5JP3SX.js";
|
|
6
|
-
import "../chunk-
|
|
6
|
+
import "../chunk-ZVSEMDIC.js";
|
|
7
7
|
|
|
8
8
|
// providers/session_provider.ts
|
|
9
9
|
import { configProvider } from "@adonisjs/core";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
debug_default
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-ZVSEMDIC.js";
|
|
4
4
|
|
|
5
5
|
// src/stores/redis.ts
|
|
6
6
|
import string from "@poppinss/utils/string";
|
|
@@ -55,4 +55,4 @@ var RedisStore = class {
|
|
|
55
55
|
export {
|
|
56
56
|
RedisStore
|
|
57
57
|
};
|
|
58
|
-
//# sourceMappingURL=redis-
|
|
58
|
+
//# sourceMappingURL=redis-CAY24YIA.js.map
|
package/build/src/client.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SessionClient
|
|
3
|
-
} from "../../../chunk-
|
|
3
|
+
} from "../../../chunk-GB5FBZCV.js";
|
|
4
4
|
import "../../../chunk-TE5JP3SX.js";
|
|
5
|
-
import "../../../chunk-
|
|
5
|
+
import "../../../chunk-ZVSEMDIC.js";
|
|
6
6
|
|
|
7
7
|
// src/plugins/japa/api_client.ts
|
|
8
8
|
import lodash from "@poppinss/utils/lodash";
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SessionClient
|
|
3
|
-
} from "../../../chunk-
|
|
3
|
+
} from "../../../chunk-GB5FBZCV.js";
|
|
4
4
|
import "../../../chunk-TE5JP3SX.js";
|
|
5
|
-
import "../../../chunk-
|
|
5
|
+
import "../../../chunk-ZVSEMDIC.js";
|
|
6
6
|
|
|
7
7
|
// src/plugins/japa/browser_client.ts
|
|
8
8
|
import { configProvider } from "@adonisjs/core";
|
package/build/src/session.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import Macroable from '@poppinss/macroable';
|
|
1
2
|
import type { HttpContext } from '@adonisjs/core/http';
|
|
2
3
|
import type { EmitterService } from '@adonisjs/core/types';
|
|
3
4
|
import type { HttpError } from '@adonisjs/core/types/http';
|
|
@@ -10,7 +11,7 @@ import type { SessionData, SessionConfig, SessionStoreFactory, AllowedSessionVal
|
|
|
10
11
|
* A session instance is isolated between requests but
|
|
11
12
|
* uses a centralized persistence store and
|
|
12
13
|
*/
|
|
13
|
-
export declare class Session {
|
|
14
|
+
export declare class Session extends Macroable {
|
|
14
15
|
#private;
|
|
15
16
|
config: SessionConfig;
|
|
16
17
|
/**
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SessionMiddleware
|
|
3
|
-
} from "../chunk-
|
|
4
|
-
import "../chunk-
|
|
3
|
+
} from "../chunk-TZLOND27.js";
|
|
4
|
+
import "../chunk-OCQGCVXK.js";
|
|
5
5
|
import "../chunk-TE5JP3SX.js";
|
|
6
|
-
import "../chunk-
|
|
6
|
+
import "../chunk-ZVSEMDIC.js";
|
|
7
7
|
export {
|
|
8
8
|
SessionMiddleware as default
|
|
9
9
|
};
|
|
@@ -10,9 +10,14 @@ import type { FileStoreConfig, SessionData, SessionStoreContract } from '../type
|
|
|
10
10
|
/**
|
|
11
11
|
* File store writes the session data on the file system as. Each session
|
|
12
12
|
* id gets its own file.
|
|
13
|
+
*
|
|
13
14
|
*/
|
|
14
15
|
export declare class FileStore implements SessionStoreContract {
|
|
15
16
|
#private;
|
|
17
|
+
/**
|
|
18
|
+
* @param {FileStoreConfig} config
|
|
19
|
+
* @param {string|number} The age must be in seconds or a time expression
|
|
20
|
+
*/
|
|
16
21
|
constructor(config: FileStoreConfig, age: string | number);
|
|
17
22
|
/**
|
|
18
23
|
* Reads the session data from the disk.
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@adonisjs/session",
|
|
3
3
|
"description": "Session provider for AdonisJS",
|
|
4
|
-
"version": "7.
|
|
4
|
+
"version": "7.4.1",
|
|
5
5
|
"engines": {
|
|
6
6
|
"node": ">=18.16.0"
|
|
7
7
|
},
|
|
@@ -43,52 +43,53 @@
|
|
|
43
43
|
"quick:test": "node --enable-source-maps --loader=ts-node/esm bin/test.ts"
|
|
44
44
|
},
|
|
45
45
|
"devDependencies": {
|
|
46
|
-
"@adonisjs/assembler": "^7.
|
|
47
|
-
"@adonisjs/core": "^6.
|
|
46
|
+
"@adonisjs/assembler": "^7.7.0",
|
|
47
|
+
"@adonisjs/core": "^6.9.1",
|
|
48
48
|
"@adonisjs/eslint-config": "^1.3.0",
|
|
49
|
-
"@adonisjs/i18n": "^2.0
|
|
49
|
+
"@adonisjs/i18n": "^2.1.0",
|
|
50
50
|
"@adonisjs/prettier-config": "^1.3.0",
|
|
51
51
|
"@adonisjs/redis": "^8.0.1",
|
|
52
52
|
"@adonisjs/tsconfig": "^1.3.0",
|
|
53
|
-
"@japa/api-client": "^2.0.
|
|
54
|
-
"@japa/assert": "^
|
|
55
|
-
"@japa/browser-client": "^2.0.
|
|
56
|
-
"@japa/file-system": "^2.
|
|
57
|
-
"@japa/plugin-adonisjs": "^3.0.
|
|
58
|
-
"@japa/runner": "^3.1.
|
|
59
|
-
"@japa/snapshot": "^2.0.
|
|
60
|
-
"@swc/core": "^1.
|
|
61
|
-
"@types/node": "^20.
|
|
53
|
+
"@japa/api-client": "^2.0.3",
|
|
54
|
+
"@japa/assert": "^3.0.0",
|
|
55
|
+
"@japa/browser-client": "^2.0.3",
|
|
56
|
+
"@japa/file-system": "^2.3.0",
|
|
57
|
+
"@japa/plugin-adonisjs": "^3.0.1",
|
|
58
|
+
"@japa/runner": "^3.1.4",
|
|
59
|
+
"@japa/snapshot": "^2.0.5",
|
|
60
|
+
"@swc/core": "^1.5.25",
|
|
61
|
+
"@types/node": "^20.14.1",
|
|
62
62
|
"@types/set-cookie-parser": "^2.4.7",
|
|
63
63
|
"@types/supertest": "^6.0.2",
|
|
64
|
-
"@vinejs/vine": "^1.
|
|
64
|
+
"@vinejs/vine": "^2.1.0",
|
|
65
65
|
"c8": "^9.1.0",
|
|
66
66
|
"copyfiles": "^2.4.1",
|
|
67
67
|
"cross-env": "^7.0.3",
|
|
68
68
|
"del-cli": "^5.0.0",
|
|
69
69
|
"edge.js": "^6.0.2",
|
|
70
70
|
"eslint": "^8.57.0",
|
|
71
|
-
"get-port": "^7.
|
|
71
|
+
"get-port": "^7.1.0",
|
|
72
72
|
"github-label-sync": "^2.3.1",
|
|
73
73
|
"husky": "^9.0.11",
|
|
74
|
-
"np": "^10.0.
|
|
75
|
-
"playwright": "^1.
|
|
76
|
-
"prettier": "^3.
|
|
74
|
+
"np": "^10.0.5",
|
|
75
|
+
"playwright": "^1.44.1",
|
|
76
|
+
"prettier": "^3.3.0",
|
|
77
77
|
"set-cookie-parser": "^2.6.0",
|
|
78
|
-
"supertest": "^
|
|
78
|
+
"supertest": "^7.0.0",
|
|
79
79
|
"ts-node": "^10.9.2",
|
|
80
|
-
"tsup": "^8.0
|
|
81
|
-
"typescript": "^5.4.
|
|
80
|
+
"tsup": "^8.1.0",
|
|
81
|
+
"typescript": "^5.4.5"
|
|
82
82
|
},
|
|
83
83
|
"dependencies": {
|
|
84
|
-
"@poppinss/
|
|
84
|
+
"@poppinss/macroable": "^1.0.2",
|
|
85
|
+
"@poppinss/utils": "^6.7.3"
|
|
85
86
|
},
|
|
86
87
|
"peerDependencies": {
|
|
87
|
-
"@adonisjs/core": "^6.
|
|
88
|
-
"@adonisjs/redis": "^8.0.
|
|
89
|
-
"@japa/api-client": "^2.0.
|
|
90
|
-
"@japa/browser-client": "^2.0.
|
|
91
|
-
"edge.js": "^6.0.
|
|
88
|
+
"@adonisjs/core": "^6.6.0",
|
|
89
|
+
"@adonisjs/redis": "^8.0.1",
|
|
90
|
+
"@japa/api-client": "^2.0.3",
|
|
91
|
+
"@japa/browser-client": "^2.0.3",
|
|
92
|
+
"edge.js": "^6.0.2"
|
|
92
93
|
},
|
|
93
94
|
"peerDependenciesMeta": {
|
|
94
95
|
"@adonisjs/redis": {
|
package/build/chunk-2X5L327N.js
DELETED
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
__export
|
|
3
|
-
} from "./chunk-WBAYBMJJ.js";
|
|
4
|
-
|
|
5
|
-
// src/errors.ts
|
|
6
|
-
var errors_exports = {};
|
|
7
|
-
__export(errors_exports, {
|
|
8
|
-
E_SESSION_NOT_MUTABLE: () => E_SESSION_NOT_MUTABLE,
|
|
9
|
-
E_SESSION_NOT_READY: () => E_SESSION_NOT_READY
|
|
10
|
-
});
|
|
11
|
-
import { createError } from "@poppinss/utils";
|
|
12
|
-
var E_SESSION_NOT_MUTABLE = createError(
|
|
13
|
-
"Session store is in readonly mode and cannot be mutated",
|
|
14
|
-
"E_SESSION_NOT_MUTABLE",
|
|
15
|
-
500
|
|
16
|
-
);
|
|
17
|
-
var E_SESSION_NOT_READY = createError(
|
|
18
|
-
"Session store has not been initiated. Make sure you have registered the session middleware",
|
|
19
|
-
"E_SESSION_NOT_READY",
|
|
20
|
-
500
|
|
21
|
-
);
|
|
22
|
-
|
|
23
|
-
export {
|
|
24
|
-
E_SESSION_NOT_MUTABLE,
|
|
25
|
-
E_SESSION_NOT_READY,
|
|
26
|
-
errors_exports
|
|
27
|
-
};
|
|
28
|
-
//# sourceMappingURL=chunk-2X5L327N.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/errors.ts"],"sourcesContent":["/*\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport { createError } from '@poppinss/utils'\n\n/**\n * Raised when session store is not mutable\n */\nexport const E_SESSION_NOT_MUTABLE = createError(\n 'Session store is in readonly mode and cannot be mutated',\n 'E_SESSION_NOT_MUTABLE',\n 500\n)\n\n/**\n * Raised when session store has been initiated\n */\nexport const E_SESSION_NOT_READY = createError(\n 'Session store has not been initiated. Make sure you have registered the session middleware',\n 'E_SESSION_NOT_READY',\n 500\n)\n"],"mappings":";;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,SAAS,mBAAmB;AAKrB,IAAM,wBAAwB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AACF;AAKO,IAAM,sBAAsB;AAAA,EACjC;AAAA,EACA;AAAA,EACA;AACF;","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/session_middleware.ts","../src/session.ts"],"sourcesContent":["/*\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport { EmitterService } from '@adonisjs/core/types'\nimport type { NextFn } from '@adonisjs/core/types/http'\nimport { ExceptionHandler, HttpContext } from '@adonisjs/core/http'\n\nimport { Session } from './session.js'\nimport type { SessionConfig, SessionStoreFactory } from './types.js'\n\n/**\n * HttpContext augmentations\n */\ndeclare module '@adonisjs/core/http' {\n export interface HttpContext {\n session: Session\n }\n}\n\n/**\n * Overwriting validation exception renderer\n */\nconst originalErrorHandler = ExceptionHandler.prototype.renderValidationErrorAsHTML\nExceptionHandler.macro('renderValidationErrorAsHTML', async function (error, ctx) {\n if (ctx.session) {\n ctx.session.flashValidationErrors(error)\n ctx.response.redirect('back', true)\n } else {\n return originalErrorHandler(error, ctx)\n }\n})\n\n/**\n * Session middleware is used to initiate the session store\n * and commit its values during an HTTP request\n */\nexport default class SessionMiddleware<KnownStores extends Record<string, SessionStoreFactory>> {\n #config: SessionConfig & {\n store: keyof KnownStores\n stores: KnownStores\n }\n #emitter: EmitterService\n\n constructor(\n config: SessionConfig & {\n store: keyof KnownStores\n stores: KnownStores\n },\n emitter: EmitterService\n ) {\n this.#config = config\n this.#emitter = emitter\n }\n\n async handle(ctx: HttpContext, next: NextFn) {\n if (!this.#config.enabled) {\n return next()\n }\n\n ctx.session = new Session(\n this.#config,\n this.#config.stores[this.#config.store], // reference to store factory\n this.#emitter,\n ctx\n )\n\n /**\n * Initiate session store\n */\n await ctx.session.initiate(false)\n\n /**\n * Call next middlewares or route handler\n */\n const response = await next()\n\n /**\n * Commit store mutations\n */\n await ctx.session.commit()\n\n /**\n * Return response\n */\n return response\n }\n}\n","/*\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport type { I18n } from '@adonisjs/i18n'\nimport lodash from '@poppinss/utils/lodash'\nimport { cuid } from '@adonisjs/core/helpers'\nimport type { HttpContext } from '@adonisjs/core/http'\nimport type { EmitterService } from '@adonisjs/core/types'\nimport type { HttpError } from '@adonisjs/core/types/http'\n\nimport debug from './debug.js'\nimport * as errors from './errors.js'\nimport { ReadOnlyValuesStore, ValuesStore } from './values_store.js'\nimport type {\n SessionData,\n SessionConfig,\n SessionStoreFactory,\n AllowedSessionValues,\n SessionStoreContract,\n} from './types.js'\n\n/**\n * The session class exposes the API to read and write values to\n * the session store.\n *\n * A session instance is isolated between requests but\n * uses a centralized persistence store and\n */\nexport class Session {\n #store: SessionStoreContract\n #emitter: EmitterService\n #ctx: HttpContext\n #readonly: boolean = false\n\n /**\n * Session values store\n */\n #valuesStore?: ValuesStore\n\n /**\n * Session id refers to the session id that will be committed\n * as a cookie during the response.\n */\n #sessionId: string\n\n /**\n * Session id from cookie refers to the value we read from the\n * cookie during the HTTP request.\n *\n * This only might not exist during the first request. Also during\n * session id re-generation, this value will be different from\n * the session id.\n */\n #sessionIdFromCookie?: string\n\n /**\n * Store of flash messages that be written during the\n * HTTP request\n */\n responseFlashMessages = new ValuesStore({})\n\n /**\n * Store of flash messages for the current HTTP request.\n */\n flashMessages = new ValuesStore({})\n\n /**\n * The key to use for storing flash messages inside\n * the session store.\n */\n flashKey: string = '__flash__'\n\n /**\n * Session id for the current HTTP request\n */\n get sessionId() {\n return this.#sessionId\n }\n\n /**\n * A boolean to know if a fresh session is created during\n * the request\n */\n get fresh(): boolean {\n return this.#sessionIdFromCookie === undefined\n }\n\n /**\n * A boolean to know if session is in readonly\n * state\n */\n get readonly() {\n return this.#readonly\n }\n\n /**\n * A boolean to know if session store has been initiated\n */\n get initiated() {\n return !!this.#valuesStore\n }\n\n /**\n * A boolean to know if the session id has been re-generated\n * during the current request\n */\n get hasRegeneratedSession() {\n return !!(this.#sessionIdFromCookie && this.#sessionIdFromCookie !== this.#sessionId)\n }\n\n /**\n * A boolean to know if the session store is empty\n */\n get isEmpty() {\n return this.#valuesStore?.isEmpty ?? true\n }\n\n /**\n * A boolean to know if the session store has been\n * modified\n */\n get hasBeenModified() {\n return this.#valuesStore?.hasBeenModified ?? false\n }\n\n constructor(\n public config: SessionConfig,\n storeFactory: SessionStoreFactory,\n emitter: EmitterService,\n ctx: HttpContext\n ) {\n this.#ctx = ctx\n this.#emitter = emitter\n this.#store = storeFactory(ctx, config)\n this.#sessionIdFromCookie = ctx.request.cookie(config.cookieName, undefined)\n this.#sessionId = this.#sessionIdFromCookie || cuid()\n }\n\n /**\n * Returns the flash messages store for a given\n * mode\n */\n #getFlashStore(mode: 'write' | 'read'): ValuesStore {\n if (!this.#valuesStore) {\n throw new errors.E_SESSION_NOT_READY()\n }\n\n if (mode === 'write' && this.readonly) {\n throw new errors.E_SESSION_NOT_MUTABLE()\n }\n\n return this.responseFlashMessages\n }\n\n /**\n * Returns the store instance for a given mode\n */\n #getValuesStore(mode: 'write' | 'read'): ValuesStore {\n if (!this.#valuesStore) {\n throw new errors.E_SESSION_NOT_READY()\n }\n\n if (mode === 'write' && this.readonly) {\n throw new errors.E_SESSION_NOT_MUTABLE()\n }\n\n return this.#valuesStore\n }\n\n /**\n * Initiates the session store. The method results in a noop\n * when called multiple times\n */\n async initiate(readonly: boolean): Promise<void> {\n if (this.#valuesStore) {\n return\n }\n\n debug('initiating session (readonly: %s)', readonly)\n\n this.#readonly = readonly\n const contents = await this.#store.read(this.#sessionId)\n this.#valuesStore = new ValuesStore(contents)\n\n /**\n * Extract flash messages from the store and keep a local\n * copy of it.\n */\n if (this.has(this.flashKey)) {\n debug('reading flash data')\n if (this.#readonly) {\n this.flashMessages.update(this.get(this.flashKey, null))\n } else {\n this.flashMessages.update(this.pull(this.flashKey, null))\n }\n }\n\n /**\n * Share session with the templates. We assume the view property\n * is a reference to edge templates\n */\n if ('view' in this.#ctx) {\n this.#ctx.view.share({\n session: new ReadOnlyValuesStore(this.#valuesStore.all()),\n flashMessages: new ReadOnlyValuesStore(this.flashMessages.all()),\n old: function (key: string, defaultValue?: any) {\n return this.flashMessages.get(key, defaultValue)\n },\n })\n }\n\n this.#emitter.emit('session:initiated', { session: this })\n }\n\n /**\n * Put a key-value pair to the session data store\n */\n put(key: string, value: AllowedSessionValues) {\n this.#getValuesStore('write').set(key, value)\n }\n\n /**\n * Check if a key exists inside the datastore\n */\n has(key: string): boolean {\n return this.#getValuesStore('read').has(key)\n }\n\n /**\n * Get the value of a key from the session datastore.\n * You can specify a default value to use, when key\n * does not exists or has undefined value.\n */\n get(key: string, defaultValue?: any) {\n return this.#getValuesStore('read').get(key, defaultValue)\n }\n\n /**\n * Get everything from the session store\n */\n all() {\n return this.#getValuesStore('read').all()\n }\n\n /**\n * Remove a key from the session datastore\n */\n forget(key: string) {\n return this.#getValuesStore('write').unset(key)\n }\n\n /**\n * Read value for a key from the session datastore\n * and remove it simultaneously.\n */\n pull(key: string, defaultValue?: any) {\n return this.#getValuesStore('write').pull(key, defaultValue)\n }\n\n /**\n * Increment the value of a key inside the session\n * store.\n *\n * A new key will be defined if does not exists already.\n * The value of a new key will be 1\n */\n increment(key: string, steps: number = 1) {\n return this.#getValuesStore('write').increment(key, steps)\n }\n\n /**\n * Increment the value of a key inside the session\n * store.\n *\n * A new key will be defined if does not exists already.\n * The value of a new key will be -1\n */\n decrement(key: string, steps: number = 1) {\n return this.#getValuesStore('write').decrement(key, steps)\n }\n\n /**\n * Empty the session store\n */\n clear() {\n return this.#getValuesStore('write').clear()\n }\n\n /**\n * Add a key-value pair to flash messages\n */\n flash(key: string, value: AllowedSessionValues): void\n flash(keyValue: SessionData): void\n flash(key: string | SessionData, value?: AllowedSessionValues): void {\n if (typeof key === 'string') {\n if (value) {\n this.#getFlashStore('write').set(key, value)\n }\n } else {\n this.#getFlashStore('write').merge(key)\n }\n }\n\n /**\n * Flash errors to the errorsBag. You can read these\n * errors via the \"@error\" tag.\n *\n * Appends new messages to the existing collection.\n */\n flashErrors(errorsCollection: Record<string, string | string[]>) {\n this.flash({ errorsBag: errorsCollection })\n }\n\n /**\n * Flash validation error messages. Make sure the error\n * is an instance of VineJS ValidationException.\n *\n * Overrides existing inputErrors\n */\n flashValidationErrors(error: HttpError) {\n const errorsBag = error.messages.reduce((result: Record<string, string[]>, message: any) => {\n if (result[message.field]) {\n result[message.field].push(message.message)\n } else {\n result[message.field] = [message.message]\n }\n return result\n }, {})\n\n this.flashExcept(['_csrf', '_method', 'password', 'password_confirmation'])\n\n /**\n * Adding the error summary to the \"errorsBag\" so that\n * we display the validation error globally using\n * the \"@error\" tag.\n */\n let summary = 'The form could not be saved. Please check the errors below.'\n if ('i18n' in this.#ctx) {\n summary = (this.#ctx.i18n as I18n).t(\n `errors.${error.code}`,\n {\n count: error.messages.length,\n },\n summary\n )\n }\n\n this.flashErrors({\n [String(error.code)]: summary,\n })\n\n /**\n * Adding to inputErrorsBag for \"@inputError\" tag\n * to read validation errors\n */\n this.flash('inputErrorsBag', errorsBag)\n\n /**\n * For legacy support and not to break apps using\n * the older version of @adonisjs/session package\n */\n this.flash('errors', errorsBag)\n }\n\n /**\n * Flash form input data to the flash messages store\n */\n flashAll() {\n return this.#getFlashStore('write').set('input', this.#ctx.request.original())\n }\n\n /**\n * Flash form input data (except some keys) to the flash messages store\n */\n flashExcept(keys: string[]): void {\n this.#getFlashStore('write').set('input', lodash.omit(this.#ctx.request.original(), keys))\n }\n\n /**\n * Flash form input data (only some keys) to the flash messages store\n */\n flashOnly(keys: string[]): void {\n this.#getFlashStore('write').set('input', lodash.pick(this.#ctx.request.original(), keys))\n }\n\n /**\n * Reflash messages from the last request in the current response\n */\n reflash(): void {\n this.#getFlashStore('write').set('reflashed', this.flashMessages.all())\n }\n\n /**\n * Reflash messages (only some keys) from the last\n * request in the current response\n */\n reflashOnly(keys: string[]) {\n this.#getFlashStore('write').set('reflashed', lodash.pick(this.flashMessages.all(), keys))\n }\n\n /**\n * Reflash messages (except some keys) from the last\n * request in the current response\n */\n reflashExcept(keys: string[]) {\n this.#getFlashStore('write').set('reflashed', lodash.omit(this.flashMessages.all(), keys))\n }\n\n /**\n * Re-generate the session id and migrate data to it.\n */\n regenerate() {\n this.#sessionId = cuid()\n }\n\n /**\n * Commit session changes. No more mutations will be\n * allowed after commit.\n */\n async commit() {\n if (!this.#valuesStore || this.readonly) {\n return\n }\n\n /**\n * If the flash messages store is not empty, we should put\n * its messages inside main session store.\n */\n if (!this.responseFlashMessages.isEmpty) {\n const { input, reflashed, ...others } = this.responseFlashMessages.all()\n this.put(this.flashKey, { ...reflashed, ...input, ...others })\n }\n\n debug('committing session data')\n\n /**\n * Touch the session id cookie to stay alive\n */\n this.#ctx.response.cookie(this.config.cookieName, this.#sessionId, this.config.cookie!)\n\n /**\n * Delete the session data when the session store\n * is empty.\n *\n * Also we only destroy the session id we read from the cookie.\n * If there was no session id in the cookie, there won't be\n * any data inside the store either.\n */\n if (this.isEmpty) {\n if (this.#sessionIdFromCookie) {\n await this.#store.destroy(this.#sessionIdFromCookie)\n }\n this.#emitter.emit('session:committed', { session: this })\n return\n }\n\n /**\n * Touch the store expiry when the session store was\n * not modified.\n */\n if (!this.hasBeenModified) {\n if (this.#sessionIdFromCookie && this.#sessionIdFromCookie !== this.#sessionId) {\n await this.#store.destroy(this.#sessionIdFromCookie)\n await this.#store.write(this.#sessionId, this.#valuesStore.toJSON())\n this.#emitter.emit('session:migrated', {\n fromSessionId: this.#sessionIdFromCookie,\n toSessionId: this.sessionId,\n session: this,\n })\n } else {\n await this.#store.touch(this.#sessionId)\n }\n this.#emitter.emit('session:committed', { session: this })\n return\n }\n\n /**\n * Otherwise commit to the session store\n */\n if (this.#sessionIdFromCookie && this.#sessionIdFromCookie !== this.#sessionId) {\n await this.#store.destroy(this.#sessionIdFromCookie)\n await this.#store.write(this.#sessionId, this.#valuesStore.toJSON())\n this.#emitter.emit('session:migrated', {\n fromSessionId: this.#sessionIdFromCookie,\n toSessionId: this.sessionId,\n session: this,\n })\n } else {\n await this.#store.write(this.#sessionId, this.#valuesStore.toJSON())\n }\n\n this.#emitter.emit('session:committed', { session: this })\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/stores/file.ts"],"sourcesContent":["/**\n * @adonisjs/session\n *\n * (c) AdonisJS\n *\n * For the full copyright and license information, please view the LICENSE\n * file that was distributed with this source code.\n */\n\nimport type { Stats } from 'node:fs'\nimport { dirname, join } from 'node:path'\nimport string from '@poppinss/utils/string'\nimport { MessageBuilder } from '@adonisjs/core/helpers'\nimport { access, mkdir, readFile, rm, writeFile, utimes, stat } from 'node:fs/promises'\n\nimport debug from '../debug.js'\nimport type { FileStoreConfig, SessionData, SessionStoreContract } from '../types.js'\n\n/**\n * File store writes the session data on the file system as. Each session\n * id gets its own file.\n */\nexport class FileStore implements SessionStoreContract {\n #config: FileStoreConfig\n #age: string | number\n\n constructor(config: FileStoreConfig, age: string | number) {\n this.#config = config\n this.#age = age\n debug('initiating file store %O', this.#config)\n }\n\n /**\n * Returns an absolute path to the session id file\n */\n #getFilePath(sessionId: string): string {\n return join(this.#config.location, `${sessionId}.txt`)\n }\n\n /**\n * Check if a file exists at a given path or not\n */\n async #pathExists(path: string) {\n try {\n await access(path)\n return true\n } catch {\n return false\n }\n }\n\n /**\n * Returns stats for a file and ignoring missing\n * files.\n */\n async #stats(path: string): Promise<Stats | null> {\n try {\n const stats = await stat(path)\n return stats\n } catch {\n return null\n }\n }\n\n /**\n * Output file with contents to the given path\n */\n async #outputFile(path: string, contents: string) {\n const pathDirname = dirname(path)\n\n const dirExists = await this.#pathExists(pathDirname)\n if (!dirExists) {\n await mkdir(pathDirname, { recursive: true })\n }\n\n await writeFile(path, contents, 'utf-8')\n }\n\n /**\n * Reads the session data from the disk.\n */\n async read(sessionId: string): Promise<SessionData | null> {\n const filePath = this.#getFilePath(sessionId)\n debug('file store: reading session data %', sessionId)\n\n /**\n * Return null when no session id file exists in first\n * place\n */\n const stats = await this.#stats(filePath)\n if (!stats) {\n return null\n }\n\n /**\n * Check if the file has been expired and return null (if expired)\n */\n const sessionWillExpireAt = stats.mtimeMs + string.milliseconds.parse(this.#age)\n if (Date.now() > sessionWillExpireAt) {\n debug('file store: expired session data %s', sessionId)\n return null\n }\n\n /**\n * Reading the file contents if the file exists\n */\n let contents = await readFile(filePath, 'utf-8')\n contents = contents.trim()\n if (!contents) {\n return null\n }\n\n /**\n * Verify contents with the session id and return them as an object. The verify\n * method can fail when the contents is not JSON>\n */\n try {\n return new MessageBuilder().verify<SessionData>(contents, sessionId)\n } catch {\n return null\n }\n }\n\n /**\n * Writes the session data to the disk as a string\n */\n async write(sessionId: string, values: SessionData): Promise<void> {\n debug('file store: writing session data %s: %O', sessionId, values)\n\n const filePath = this.#getFilePath(sessionId)\n const message = new MessageBuilder().build(values, undefined, sessionId)\n\n await this.#outputFile(filePath, message)\n }\n\n /**\n * Removes the session file from the disk\n */\n async destroy(sessionId: string): Promise<void> {\n debug('file store: destroying session data %s', sessionId)\n await rm(this.#getFilePath(sessionId), { force: true })\n }\n\n /**\n * Updates the session expiry by rewriting it to the\n * persistence store\n */\n async touch(sessionId: string): Promise<void> {\n debug('file store: touching session data %s', sessionId)\n await utimes(this.#getFilePath(sessionId), new Date(), new Date())\n }\n}\n"],"mappings":";;;;;AAUA,SAAS,SAAS,YAAY;AAC9B,OAAO,YAAY;AACnB,SAAS,sBAAsB;AAC/B,SAAS,QAAQ,OAAO,UAAU,IAAI,WAAW,QAAQ,YAAY;AAS9D,IAAM,YAAN,MAAgD;AAAA,EACrD;AAAA,EACA;AAAA,EAEA,YAAY,QAAyB,KAAsB;AACzD,SAAK,UAAU;AACf,SAAK,OAAO;AACZ,kBAAM,4BAA4B,KAAK,OAAO;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA,EAKA,aAAa,WAA2B;AACtC,WAAO,KAAK,KAAK,QAAQ,UAAU,GAAG,SAAS,MAAM;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAY,MAAc;AAC9B,QAAI;AACF,YAAM,OAAO,IAAI;AACjB,aAAO;AAAA,IACT,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,OAAO,MAAqC;AAChD,QAAI;AACF,YAAM,QAAQ,MAAM,KAAK,IAAI;AAC7B,aAAO;AAAA,IACT,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YAAY,MAAc,UAAkB;AAChD,UAAM,cAAc,QAAQ,IAAI;AAEhC,UAAM,YAAY,MAAM,KAAK,YAAY,WAAW;AACpD,QAAI,CAAC,WAAW;AACd,YAAM,MAAM,aAAa,EAAE,WAAW,KAAK,CAAC;AAAA,IAC9C;AAEA,UAAM,UAAU,MAAM,UAAU,OAAO;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,KAAK,WAAgD;AACzD,UAAM,WAAW,KAAK,aAAa,SAAS;AAC5C,kBAAM,sCAAsC,SAAS;AAMrD,UAAM,QAAQ,MAAM,KAAK,OAAO,QAAQ;AACxC,QAAI,CAAC,OAAO;AACV,aAAO;AAAA,IACT;AAKA,UAAM,sBAAsB,MAAM,UAAU,OAAO,aAAa,MAAM,KAAK,IAAI;AAC/E,QAAI,KAAK,IAAI,IAAI,qBAAqB;AACpC,oBAAM,uCAAuC,SAAS;AACtD,aAAO;AAAA,IACT;AAKA,QAAI,WAAW,MAAM,SAAS,UAAU,OAAO;AAC/C,eAAW,SAAS,KAAK;AACzB,QAAI,CAAC,UAAU;AACb,aAAO;AAAA,IACT;AAMA,QAAI;AACF,aAAO,IAAI,eAAe,EAAE,OAAoB,UAAU,SAAS;AAAA,IACrE,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,MAAM,WAAmB,QAAoC;AACjE,kBAAM,2CAA2C,WAAW,MAAM;AAElE,UAAM,WAAW,KAAK,aAAa,SAAS;AAC5C,UAAM,UAAU,IAAI,eAAe,EAAE,MAAM,QAAQ,QAAW,SAAS;AAEvE,UAAM,KAAK,YAAY,UAAU,OAAO;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QAAQ,WAAkC;AAC9C,kBAAM,0CAA0C,SAAS;AACzD,UAAM,GAAG,KAAK,aAAa,SAAS,GAAG,EAAE,OAAO,KAAK,CAAC;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,MAAM,WAAkC;AAC5C,kBAAM,wCAAwC,SAAS;AACvD,UAAM,OAAO,KAAK,aAAa,SAAS,GAAG,oBAAI,KAAK,GAAG,oBAAI,KAAK,CAAC;AAAA,EACnE;AACF;","names":[]}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|