@adonisjs/session 7.5.0 → 7.6.0

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.
Files changed (49) hide show
  1. package/build/{chunk-WUWXIKIB.js → chunk-3AQCEGXQ.js} +29 -12
  2. package/build/chunk-3AQCEGXQ.js.map +1 -0
  3. package/build/chunk-5ECC6OWF.js +8 -0
  4. package/build/{chunk-ZVSEMDIC.js.map → chunk-5ECC6OWF.js.map} +1 -1
  5. package/build/{chunk-TZLOND27.js → chunk-CVMFYEYR.js} +2 -2
  6. package/build/{chunk-GB5FBZCV.js → chunk-GCO66PQD.js} +2 -2
  7. package/build/{chunk-OCQGCVXK.js → chunk-I6SY5ILN.js} +5 -3
  8. package/build/{chunk-OCQGCVXK.js.map → chunk-I6SY5ILN.js.map} +1 -1
  9. package/build/{chunk-ZVSEMDIC.js → chunk-PZ5AY32C.js} +2 -7
  10. package/build/chunk-PZ5AY32C.js.map +1 -0
  11. package/build/chunk-V3OAEXMJ.js +8 -0
  12. package/build/chunk-V3OAEXMJ.js.map +1 -0
  13. package/build/commands/commands.json +1 -0
  14. package/build/commands/main.d.ts +4 -0
  15. package/build/commands/main.js +36 -0
  16. package/build/commands/make_session_table.d.ts +9 -0
  17. package/build/commands/make_session_table.js +21 -0
  18. package/build/commands/make_session_table.js.map +1 -0
  19. package/build/{cookie-WBWYVEDW.js → cookie-3C33DMWA.js} +3 -2
  20. package/build/{cookie-WBWYVEDW.js.map → cookie-3C33DMWA.js.map} +1 -1
  21. package/build/database-55YUHLA6.js +89 -0
  22. package/build/database-55YUHLA6.js.map +1 -0
  23. package/build/{dynamodb-3PG52TE3.js → dynamodb-53YXEFIJ.js} +3 -2
  24. package/build/{dynamodb-3PG52TE3.js.map → dynamodb-53YXEFIJ.js.map} +1 -1
  25. package/build/factories/main.js +6 -4
  26. package/build/factories/main.js.map +1 -1
  27. package/build/{file-B6QKOZXW.js → file-K3GBSVSU.js} +5 -4
  28. package/build/{file-B6QKOZXW.js.map → file-K3GBSVSU.js.map} +1 -1
  29. package/build/index.js +7 -4
  30. package/build/make/migration/sessions.stub +25 -0
  31. package/build/providers/session_provider.js +4 -3
  32. package/build/providers/session_provider.js.map +1 -1
  33. package/build/{redis-CAY24YIA.js → redis-OJU6MUHZ.js} +3 -2
  34. package/build/{redis-CAY24YIA.js.map → redis-OJU6MUHZ.js.map} +1 -1
  35. package/build/src/client.js +3 -2
  36. package/build/src/define_config.d.ts +2 -1
  37. package/build/src/plugins/edge.js +2 -1
  38. package/build/src/plugins/edge.js.map +1 -1
  39. package/build/src/plugins/japa/api_client.js +3 -2
  40. package/build/src/plugins/japa/api_client.js.map +1 -1
  41. package/build/src/plugins/japa/browser_client.js +3 -2
  42. package/build/src/plugins/japa/browser_client.js.map +1 -1
  43. package/build/src/session_middleware.js +4 -3
  44. package/build/src/stores/database.d.ts +47 -0
  45. package/build/src/types.d.ts +17 -0
  46. package/package.json +49 -38
  47. package/build/chunk-WUWXIKIB.js.map +0 -1
  48. /package/build/{chunk-TZLOND27.js.map → chunk-CVMFYEYR.js.map} +0 -0
  49. /package/build/{chunk-GB5FBZCV.js.map → chunk-GCO66PQD.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["../../factories/session_middleware_factory.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 { Emitter } from '@adonisjs/core/events'\nimport { AppFactory } from '@adonisjs/core/factories/app'\nimport type { ApplicationService, EventsList } from '@adonisjs/core/types'\n\nimport { defineConfig } from '../index.js'\nimport SessionMiddleware from '../src/session_middleware.js'\nimport type { SessionConfig, SessionStoreFactory } from '../src/types.js'\n\n/**\n * Exposes the API to create an instance of the session middleware\n * without additional plumbing\n */\nexport class SessionMiddlewareFactory {\n #config: Partial<SessionConfig> & {\n store: string\n stores: Record<string, SessionStoreFactory>\n } = {\n store: 'memory',\n stores: {},\n }\n\n #emitter?: Emitter<EventsList>\n\n #getApp() {\n return new AppFactory().create(new URL('./', import.meta.url), () => {}) as ApplicationService\n }\n\n #getEmitter() {\n return this.#emitter || new Emitter<EventsList>(this.#getApp())\n }\n\n /**\n * Merge custom options\n */\n merge(options: {\n config?: Partial<SessionConfig> & {\n store: string\n stores: Record<string, SessionStoreFactory>\n }\n emitter?: Emitter<EventsList>\n }) {\n if (options.config) {\n this.#config = options.config\n }\n\n if (options.emitter) {\n this.#emitter = options.emitter\n }\n\n return this\n }\n\n /**\n * Creates an instance of the session middleware\n */\n async create() {\n const config = await defineConfig(this.#config).resolver(this.#getApp())\n return new SessionMiddleware(config, this.#getEmitter())\n }\n}\n"],"mappings":";;;;;;;;;;;AASA,SAAS,eAAe;AACxB,SAAS,kBAAkB;AAWpB,IAAM,2BAAN,MAA+B;AAAA,EACpC,UAGI;AAAA,IACF,OAAO;AAAA,IACP,QAAQ,CAAC;AAAA,EACX;AAAA,EAEA;AAAA,EAEA,UAAU;AACR,WAAO,IAAI,WAAW,EAAE,OAAO,IAAI,IAAI,MAAM,YAAY,GAAG,GAAG,MAAM;AAAA,IAAC,CAAC;AAAA,EACzE;AAAA,EAEA,cAAc;AACZ,WAAO,KAAK,YAAY,IAAI,QAAoB,KAAK,QAAQ,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,SAMH;AACD,QAAI,QAAQ,QAAQ;AAClB,WAAK,UAAU,QAAQ;AAAA,IACzB;AAEA,QAAI,QAAQ,SAAS;AACnB,WAAK,WAAW,QAAQ;AAAA,IAC1B;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,SAAS;AACb,UAAM,SAAS,MAAM,aAAa,KAAK,OAAO,EAAE,SAAS,KAAK,QAAQ,CAAC;AACvE,WAAO,IAAI,kBAAkB,QAAQ,KAAK,YAAY,CAAC;AAAA,EACzD;AACF;","names":[]}
1
+ {"version":3,"sources":["../../factories/session_middleware_factory.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 { Emitter } from '@adonisjs/core/events'\nimport { AppFactory } from '@adonisjs/core/factories/app'\nimport type { ApplicationService, EventsList } from '@adonisjs/core/types'\n\nimport { defineConfig } from '../index.js'\nimport SessionMiddleware from '../src/session_middleware.js'\nimport type { SessionConfig, SessionStoreFactory } from '../src/types.js'\n\n/**\n * Exposes the API to create an instance of the session middleware\n * without additional plumbing\n */\nexport class SessionMiddlewareFactory {\n #config: Partial<SessionConfig> & {\n store: string\n stores: Record<string, SessionStoreFactory>\n } = {\n store: 'memory',\n stores: {},\n }\n\n #emitter?: Emitter<EventsList>\n\n #getApp() {\n return new AppFactory().create(new URL('./', import.meta.url), () => {}) as ApplicationService\n }\n\n #getEmitter() {\n return this.#emitter || new Emitter<EventsList>(this.#getApp())\n }\n\n /**\n * Merge custom options\n */\n merge(options: {\n config?: Partial<SessionConfig> & {\n store: string\n stores: Record<string, SessionStoreFactory>\n }\n emitter?: Emitter<EventsList>\n }) {\n if (options.config) {\n this.#config = options.config\n }\n\n if (options.emitter) {\n this.#emitter = options.emitter\n }\n\n return this\n }\n\n /**\n * Creates an instance of the session middleware\n */\n async create() {\n const config = await defineConfig(this.#config).resolver(this.#getApp())\n return new SessionMiddleware(config, this.#getEmitter())\n }\n}\n"],"mappings":";;;;;;;;;;;;;AASA,SAAS,eAAe;AACxB,SAAS,kBAAkB;AAWpB,IAAM,2BAAN,MAA+B;AAAA,EACpC,UAGI;AAAA,IACF,OAAO;AAAA,IACP,QAAQ,CAAC;AAAA,EACX;AAAA,EAEA;AAAA,EAEA,UAAU;AACR,WAAO,IAAI,WAAW,EAAE,OAAO,IAAI,IAAI,MAAM,YAAY,GAAG,GAAG,MAAM;AAAA,IAAC,CAAC;AAAA,EACzE;AAAA,EAEA,cAAc;AACZ,WAAO,KAAK,YAAY,IAAI,QAAoB,KAAK,QAAQ,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,SAMH;AACD,QAAI,QAAQ,QAAQ;AAClB,WAAK,UAAU,QAAQ;AAAA,IACzB;AAEA,QAAI,QAAQ,SAAS;AACnB,WAAK,WAAW,QAAQ;AAAA,IAC1B;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,SAAS;AACb,UAAM,SAAS,MAAM,aAAa,KAAK,OAAO,EAAE,SAAS,KAAK,QAAQ,CAAC;AACvE,WAAO,IAAI,kBAAkB,QAAQ,KAAK,YAAY,CAAC;AAAA,EACzD;AACF;","names":[]}
@@ -1,12 +1,13 @@
1
1
  import {
2
2
  debug_default
3
- } from "./chunk-ZVSEMDIC.js";
3
+ } from "./chunk-5ECC6OWF.js";
4
+ import "./chunk-PZ5AY32C.js";
4
5
 
5
6
  // src/stores/file.ts
6
- import { dirname, join } from "node:path";
7
+ import { dirname, join } from "path";
7
8
  import string from "@poppinss/utils/string";
8
9
  import { MessageBuilder } from "@adonisjs/core/helpers";
9
- import { access, mkdir, readFile, rm, writeFile, utimes, stat } from "node:fs/promises";
10
+ import { access, mkdir, readFile, rm, writeFile, utimes, stat } from "fs/promises";
10
11
  var FileStore = class {
11
12
  #config;
12
13
  #age;
@@ -113,4 +114,4 @@ var FileStore = class {
113
114
  export {
114
115
  FileStore
115
116
  };
116
- //# sourceMappingURL=file-B6QKOZXW.js.map
117
+ //# sourceMappingURL=file-K3GBSVSU.js.map
@@ -1 +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":[]}
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.js CHANGED
@@ -1,18 +1,21 @@
1
1
  import {
2
2
  configure,
3
3
  defineConfig,
4
- stores,
4
+ stores
5
+ } from "./chunk-3AQCEGXQ.js";
6
+ import {
5
7
  stubsRoot
6
- } from "./chunk-WUWXIKIB.js";
8
+ } from "./chunk-V3OAEXMJ.js";
7
9
  import {
8
10
  Session,
9
11
  errors_exports
10
- } from "./chunk-OCQGCVXK.js";
12
+ } from "./chunk-I6SY5ILN.js";
11
13
  import {
12
14
  ReadOnlyValuesStore,
13
15
  ValuesStore
14
16
  } from "./chunk-TE5JP3SX.js";
15
- import "./chunk-ZVSEMDIC.js";
17
+ import "./chunk-5ECC6OWF.js";
18
+ import "./chunk-PZ5AY32C.js";
16
19
  export {
17
20
  ReadOnlyValuesStore,
18
21
  Session,
@@ -0,0 +1,25 @@
1
+ {{{
2
+ exports({
3
+ to: app.makePath(
4
+ 'database/migrations',
5
+ `${migration.prefix}_create_${migration.tableName}_table.ts`
6
+ )
7
+ })
8
+ }}}
9
+ import { BaseSchema } from '@adonisjs/lucid/schema'
10
+
11
+ export default class extends BaseSchema {
12
+ protected tableName = '{{ migration.tableName }}'
13
+
14
+ async up() {
15
+ this.schema.createTable(this.tableName, (table) => {
16
+ table.string('id').primary()
17
+ table.text('data').notNullable()
18
+ table.timestamp('expires_at').notNullable().index()
19
+ })
20
+ }
21
+
22
+ async down() {
23
+ this.schema.dropTable(this.tableName)
24
+ }
25
+ }
@@ -1,9 +1,10 @@
1
1
  import {
2
2
  SessionMiddleware
3
- } from "../chunk-TZLOND27.js";
4
- import "../chunk-OCQGCVXK.js";
3
+ } from "../chunk-CVMFYEYR.js";
4
+ import "../chunk-I6SY5ILN.js";
5
5
  import "../chunk-TE5JP3SX.js";
6
- import "../chunk-ZVSEMDIC.js";
6
+ import "../chunk-5ECC6OWF.js";
7
+ import "../chunk-PZ5AY32C.js";
7
8
 
8
9
  // providers/session_provider.ts
9
10
  import { configProvider } from "@adonisjs/core";
@@ -1 +1 @@
1
- {"version":3,"sources":["../../providers/session_provider.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 { configProvider } from '@adonisjs/core'\nimport { RuntimeException } from '@poppinss/utils'\nimport type { ApplicationService } from '@adonisjs/core/types'\n\nimport type { Session } from '../src/session.js'\nimport SessionMiddleware from '../src/session_middleware.js'\n\n/**\n * Events emitted by the session class\n */\ndeclare module '@adonisjs/core/types' {\n interface EventsList {\n 'session:initiated': { session: Session }\n 'session:committed': { session: Session }\n 'session:migrated': { fromSessionId: string; toSessionId: string; session: Session }\n }\n}\n\n/**\n * Session provider configures the session management inside an\n * AdonisJS application\n */\nexport default class SessionProvider {\n constructor(protected app: ApplicationService) {}\n\n /**\n * Registers edge plugin when edge is installed\n * in the user application.\n */\n protected async registerEdgePlugin() {\n if (this.app.usingEdgeJS) {\n const edge = await import('edge.js')\n const { edgePluginSession } = await import('../src/plugins/edge.js')\n edge.default.use(edgePluginSession)\n }\n }\n\n /**\n * Registering muddleware\n */\n register() {\n this.app.container.singleton(SessionMiddleware, async (resolver) => {\n const sessionConfigProvider = this.app.config.get('session', {})\n\n /**\n * Resolve config from the provider\n */\n const config = await configProvider.resolve<any>(this.app, sessionConfigProvider)\n if (!config) {\n throw new RuntimeException(\n 'Invalid \"config/session.ts\" file. Make sure you are using the \"defineConfig\" method'\n )\n }\n\n const emitter = await resolver.make('emitter')\n return new SessionMiddleware(config, emitter)\n })\n }\n\n /**\n * Adding edge tags (if edge is installed)\n */\n async boot() {\n await this.registerEdgePlugin()\n }\n}\n"],"mappings":";;;;;;;;AASA,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAqBjC,IAAqB,kBAArB,MAAqC;AAAA,EACnC,YAAsB,KAAyB;AAAzB;AAAA,EAA0B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMhD,MAAgB,qBAAqB;AACnC,QAAI,KAAK,IAAI,aAAa;AACxB,YAAM,OAAO,MAAM,OAAO,SAAS;AACnC,YAAM,EAAE,kBAAkB,IAAI,MAAM,OAAO,wBAAwB;AACnE,WAAK,QAAQ,IAAI,iBAAiB;AAAA,IACpC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,WAAW;AACT,SAAK,IAAI,UAAU,UAAU,mBAAmB,OAAO,aAAa;AAClE,YAAM,wBAAwB,KAAK,IAAI,OAAO,IAAI,WAAW,CAAC,CAAC;AAK/D,YAAM,SAAS,MAAM,eAAe,QAAa,KAAK,KAAK,qBAAqB;AAChF,UAAI,CAAC,QAAQ;AACX,cAAM,IAAI;AAAA,UACR;AAAA,QACF;AAAA,MACF;AAEA,YAAM,UAAU,MAAM,SAAS,KAAK,SAAS;AAC7C,aAAO,IAAI,kBAAkB,QAAQ,OAAO;AAAA,IAC9C,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,OAAO;AACX,UAAM,KAAK,mBAAmB;AAAA,EAChC;AACF;","names":[]}
1
+ {"version":3,"sources":["../../providers/session_provider.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 { configProvider } from '@adonisjs/core'\nimport { RuntimeException } from '@poppinss/utils'\nimport type { ApplicationService } from '@adonisjs/core/types'\n\nimport type { Session } from '../src/session.js'\nimport SessionMiddleware from '../src/session_middleware.js'\n\n/**\n * Events emitted by the session class\n */\ndeclare module '@adonisjs/core/types' {\n interface EventsList {\n 'session:initiated': { session: Session }\n 'session:committed': { session: Session }\n 'session:migrated': { fromSessionId: string; toSessionId: string; session: Session }\n }\n}\n\n/**\n * Session provider configures the session management inside an\n * AdonisJS application\n */\nexport default class SessionProvider {\n constructor(protected app: ApplicationService) {}\n\n /**\n * Registers edge plugin when edge is installed\n * in the user application.\n */\n protected async registerEdgePlugin() {\n if (this.app.usingEdgeJS) {\n const edge = await import('edge.js')\n const { edgePluginSession } = await import('../src/plugins/edge.js')\n edge.default.use(edgePluginSession)\n }\n }\n\n /**\n * Registering muddleware\n */\n register() {\n this.app.container.singleton(SessionMiddleware, async (resolver) => {\n const sessionConfigProvider = this.app.config.get('session', {})\n\n /**\n * Resolve config from the provider\n */\n const config = await configProvider.resolve<any>(this.app, sessionConfigProvider)\n if (!config) {\n throw new RuntimeException(\n 'Invalid \"config/session.ts\" file. Make sure you are using the \"defineConfig\" method'\n )\n }\n\n const emitter = await resolver.make('emitter')\n return new SessionMiddleware(config, emitter)\n })\n }\n\n /**\n * Adding edge tags (if edge is installed)\n */\n async boot() {\n await this.registerEdgePlugin()\n }\n}\n"],"mappings":";;;;;;;;;AASA,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAqBjC,IAAqB,kBAArB,MAAqC;AAAA,EACnC,YAAsB,KAAyB;AAAzB;AAAA,EAA0B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMhD,MAAgB,qBAAqB;AACnC,QAAI,KAAK,IAAI,aAAa;AACxB,YAAM,OAAO,MAAM,OAAO,SAAS;AACnC,YAAM,EAAE,kBAAkB,IAAI,MAAM,OAAO,wBAAwB;AACnE,WAAK,QAAQ,IAAI,iBAAiB;AAAA,IACpC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,WAAW;AACT,SAAK,IAAI,UAAU,UAAU,mBAAmB,OAAO,aAAa;AAClE,YAAM,wBAAwB,KAAK,IAAI,OAAO,IAAI,WAAW,CAAC,CAAC;AAK/D,YAAM,SAAS,MAAM,eAAe,QAAa,KAAK,KAAK,qBAAqB;AAChF,UAAI,CAAC,QAAQ;AACX,cAAM,IAAI;AAAA,UACR;AAAA,QACF;AAAA,MACF;AAEA,YAAM,UAAU,MAAM,SAAS,KAAK,SAAS;AAC7C,aAAO,IAAI,kBAAkB,QAAQ,OAAO;AAAA,IAC9C,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,OAAO;AACX,UAAM,KAAK,mBAAmB;AAAA,EAChC;AACF;","names":[]}
@@ -1,6 +1,7 @@
1
1
  import {
2
2
  debug_default
3
- } from "./chunk-ZVSEMDIC.js";
3
+ } from "./chunk-5ECC6OWF.js";
4
+ import "./chunk-PZ5AY32C.js";
4
5
 
5
6
  // src/stores/redis.ts
6
7
  import string from "@poppinss/utils/string";
@@ -55,4 +56,4 @@ var RedisStore = class {
55
56
  export {
56
57
  RedisStore
57
58
  };
58
- //# sourceMappingURL=redis-CAY24YIA.js.map
59
+ //# sourceMappingURL=redis-OJU6MUHZ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/stores/redis.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 string from '@poppinss/utils/string'\nimport { MessageBuilder } from '@adonisjs/core/helpers'\nimport type { Connection } from '@adonisjs/redis/types'\n\nimport debug from '../debug.js'\nimport type { SessionStoreContract, SessionData } from '../types.js'\n\n/**\n * File store to read/write session to filesystem\n */\nexport class RedisStore implements SessionStoreContract {\n #connection: Connection\n #ttlSeconds: number\n\n constructor(connection: Connection, age: string | number) {\n this.#connection = connection\n this.#ttlSeconds = string.seconds.parse(age)\n debug('initiating redis store')\n }\n\n /**\n * Returns file contents. A new file will be created if it's\n * missing.\n */\n async read(sessionId: string): Promise<SessionData | null> {\n debug('redis store: reading session data %s', sessionId)\n\n const contents = await this.#connection.get(sessionId)\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 * Write session values to a file\n */\n async write(sessionId: string, values: Object): Promise<void> {\n debug('redis store: writing session data %s, %O', sessionId, values)\n\n const message = new MessageBuilder().build(values, undefined, sessionId)\n await this.#connection.setex(sessionId, this.#ttlSeconds, message)\n }\n\n /**\n * Cleanup session file by removing it\n */\n async destroy(sessionId: string): Promise<void> {\n debug('redis store: destroying session data %s', sessionId)\n await this.#connection.del(sessionId)\n }\n\n /**\n * Updates the value expiry\n */\n async touch(sessionId: string): Promise<void> {\n debug('redis store: touching session data %s', sessionId)\n await this.#connection.expire(sessionId, this.#ttlSeconds)\n }\n}\n"],"mappings":";;;;;AASA,OAAO,YAAY;AACnB,SAAS,sBAAsB;AASxB,IAAM,aAAN,MAAiD;AAAA,EACtD;AAAA,EACA;AAAA,EAEA,YAAY,YAAwB,KAAsB;AACxD,SAAK,cAAc;AACnB,SAAK,cAAc,OAAO,QAAQ,MAAM,GAAG;AAC3C,kBAAM,wBAAwB;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,KAAK,WAAgD;AACzD,kBAAM,wCAAwC,SAAS;AAEvD,UAAM,WAAW,MAAM,KAAK,YAAY,IAAI,SAAS;AACrD,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,QAA+B;AAC5D,kBAAM,4CAA4C,WAAW,MAAM;AAEnE,UAAM,UAAU,IAAI,eAAe,EAAE,MAAM,QAAQ,QAAW,SAAS;AACvE,UAAM,KAAK,YAAY,MAAM,WAAW,KAAK,aAAa,OAAO;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QAAQ,WAAkC;AAC9C,kBAAM,2CAA2C,SAAS;AAC1D,UAAM,KAAK,YAAY,IAAI,SAAS;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,MAAM,WAAkC;AAC5C,kBAAM,yCAAyC,SAAS;AACxD,UAAM,KAAK,YAAY,OAAO,WAAW,KAAK,WAAW;AAAA,EAC3D;AACF;","names":[]}
1
+ {"version":3,"sources":["../src/stores/redis.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 string from '@poppinss/utils/string'\nimport { MessageBuilder } from '@adonisjs/core/helpers'\nimport type { Connection } from '@adonisjs/redis/types'\n\nimport debug from '../debug.js'\nimport type { SessionStoreContract, SessionData } from '../types.js'\n\n/**\n * File store to read/write session to filesystem\n */\nexport class RedisStore implements SessionStoreContract {\n #connection: Connection\n #ttlSeconds: number\n\n constructor(connection: Connection, age: string | number) {\n this.#connection = connection\n this.#ttlSeconds = string.seconds.parse(age)\n debug('initiating redis store')\n }\n\n /**\n * Returns file contents. A new file will be created if it's\n * missing.\n */\n async read(sessionId: string): Promise<SessionData | null> {\n debug('redis store: reading session data %s', sessionId)\n\n const contents = await this.#connection.get(sessionId)\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 * Write session values to a file\n */\n async write(sessionId: string, values: Object): Promise<void> {\n debug('redis store: writing session data %s, %O', sessionId, values)\n\n const message = new MessageBuilder().build(values, undefined, sessionId)\n await this.#connection.setex(sessionId, this.#ttlSeconds, message)\n }\n\n /**\n * Cleanup session file by removing it\n */\n async destroy(sessionId: string): Promise<void> {\n debug('redis store: destroying session data %s', sessionId)\n await this.#connection.del(sessionId)\n }\n\n /**\n * Updates the value expiry\n */\n async touch(sessionId: string): Promise<void> {\n debug('redis store: touching session data %s', sessionId)\n await this.#connection.expire(sessionId, this.#ttlSeconds)\n }\n}\n"],"mappings":";;;;;;AASA,OAAO,YAAY;AACnB,SAAS,sBAAsB;AASxB,IAAM,aAAN,MAAiD;AAAA,EACtD;AAAA,EACA;AAAA,EAEA,YAAY,YAAwB,KAAsB;AACxD,SAAK,cAAc;AACnB,SAAK,cAAc,OAAO,QAAQ,MAAM,GAAG;AAC3C,kBAAM,wBAAwB;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,KAAK,WAAgD;AACzD,kBAAM,wCAAwC,SAAS;AAEvD,UAAM,WAAW,MAAM,KAAK,YAAY,IAAI,SAAS;AACrD,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,QAA+B;AAC5D,kBAAM,4CAA4C,WAAW,MAAM;AAEnE,UAAM,UAAU,IAAI,eAAe,EAAE,MAAM,QAAQ,QAAW,SAAS;AACvE,UAAM,KAAK,YAAY,MAAM,WAAW,KAAK,aAAa,OAAO;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,QAAQ,WAAkC;AAC9C,kBAAM,2CAA2C,SAAS;AAC1D,UAAM,KAAK,YAAY,IAAI,SAAS;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,MAAM,WAAkC;AAC5C,kBAAM,yCAAyC,SAAS;AACxD,UAAM,KAAK,YAAY,OAAO,WAAW,KAAK,WAAW;AAAA,EAC3D;AACF;","names":[]}
@@ -1,8 +1,9 @@
1
1
  import {
2
2
  SessionClient
3
- } from "../chunk-GB5FBZCV.js";
3
+ } from "../chunk-GCO66PQD.js";
4
4
  import "../chunk-TE5JP3SX.js";
5
- import "../chunk-ZVSEMDIC.js";
5
+ import "../chunk-5ECC6OWF.js";
6
+ import "../chunk-PZ5AY32C.js";
6
7
  export {
7
8
  SessionClient
8
9
  };
@@ -1,6 +1,6 @@
1
1
  import type { ConfigProvider } from '@adonisjs/core/types';
2
2
  import type { CookieOptions } from '@adonisjs/core/types/http';
3
- import type { SessionConfig, FileStoreConfig, RedisStoreConfig, SessionStoreFactory, DynamoDBStoreConfig } from './types.js';
3
+ import type { SessionConfig, FileStoreConfig, RedisStoreConfig, SessionStoreFactory, DynamoDBStoreConfig, DatabaseStoreConfig } from './types.js';
4
4
  /**
5
5
  * Resolved config with stores
6
6
  */
@@ -26,5 +26,6 @@ export declare const stores: {
26
26
  redis: (config: RedisStoreConfig) => ConfigProvider<SessionStoreFactory>;
27
27
  cookie: () => ConfigProvider<SessionStoreFactory>;
28
28
  dynamodb: (config: DynamoDBStoreConfig) => ConfigProvider<SessionStoreFactory>;
29
+ database: (config?: DatabaseStoreConfig) => ConfigProvider<SessionStoreFactory>;
29
30
  };
30
31
  export {};
@@ -1,6 +1,7 @@
1
1
  import {
2
2
  debug_default
3
- } from "../../chunk-ZVSEMDIC.js";
3
+ } from "../../chunk-5ECC6OWF.js";
4
+ import "../../chunk-PZ5AY32C.js";
4
5
 
5
6
  // src/plugins/edge.ts
6
7
  var edgePluginSession = (edge) => {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/plugins/edge.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 { PluginFn } from 'edge.js/types'\nimport debug from '../debug.js'\n\n/**\n * The edge plugin for AdonisJS Session adds tags to read\n * flash messages\n */\nexport const edgePluginSession: PluginFn<undefined> = (edge) => {\n debug('registering session tags with edge')\n\n edge.registerTag({\n tagName: 'flashMessage',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n const expression = parser.utils.transformAst(\n parser.utils.generateAST(token.properties.jsArg, token.loc, token.filename),\n token.filename,\n parser\n )\n\n const key = parser.utils.stringify(expression)\n\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (state.flashMessages.has(${key})) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $message = state.flashMessages.get(${key})`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"message\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$message')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n\n edge.registerTag({\n tagName: 'inputError',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n const expression = parser.utils.transformAst(\n parser.utils.generateAST(token.properties.jsArg, token.loc, token.filename),\n token.filename,\n parser\n )\n\n const key = parser.utils.stringify(expression)\n\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (!!state.flashMessages.get('inputErrorsBag', {})[${key}]) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $messages = state.flashMessages.get('inputErrorsBag', {})[${key}]`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"messages\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$messages')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n\n edge.registerTag({\n tagName: 'error',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n const expression = parser.utils.transformAst(\n parser.utils.generateAST(token.properties.jsArg, token.loc, token.filename),\n token.filename,\n parser\n )\n\n const key = parser.utils.stringify(expression)\n\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (state.flashMessages.has(['errorsBag', ${key}])) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $message = state.flashMessages.get(['errorsBag', ${key}])`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"messages\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$message')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n\n edge.registerTag({\n tagName: 'errors',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (state.flashMessages.has('errorsBag')) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $messages = state.flashMessages.get('errorsBag')`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"messages\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$messages')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../../src/plugins/edge.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 { PluginFn } from 'edge.js/types'\nimport debug from '../debug.js'\n\n/**\n * The edge plugin for AdonisJS Session adds tags to read\n * flash messages\n */\nexport const edgePluginSession: PluginFn<undefined> = (edge) => {\n debug('registering session tags with edge')\n\n edge.registerTag({\n tagName: 'flashMessage',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n const expression = parser.utils.transformAst(\n parser.utils.generateAST(token.properties.jsArg, token.loc, token.filename),\n token.filename,\n parser\n )\n\n const key = parser.utils.stringify(expression)\n\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (state.flashMessages.has(${key})) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $message = state.flashMessages.get(${key})`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"message\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$message')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n\n edge.registerTag({\n tagName: 'inputError',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n const expression = parser.utils.transformAst(\n parser.utils.generateAST(token.properties.jsArg, token.loc, token.filename),\n token.filename,\n parser\n )\n\n const key = parser.utils.stringify(expression)\n\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (!!state.flashMessages.get('inputErrorsBag', {})[${key}]) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $messages = state.flashMessages.get('inputErrorsBag', {})[${key}]`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"messages\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$messages')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n\n edge.registerTag({\n tagName: 'error',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n const expression = parser.utils.transformAst(\n parser.utils.generateAST(token.properties.jsArg, token.loc, token.filename),\n token.filename,\n parser\n )\n\n const key = parser.utils.stringify(expression)\n\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (state.flashMessages.has(['errorsBag', ${key}])) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $message = state.flashMessages.get(['errorsBag', ${key}])`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"messages\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$message')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n\n edge.registerTag({\n tagName: 'errors',\n seekable: true,\n block: true,\n compile(parser, buffer, token) {\n /**\n * Write an if statement\n */\n buffer.writeStatement(\n `if (state.flashMessages.has('errorsBag')) {`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Define a local variable\n */\n buffer.writeExpression(\n `let $messages = state.flashMessages.get('errorsBag')`,\n token.filename,\n token.loc.start.line\n )\n\n /**\n * Create a local variables scope and tell the parser about\n * the existence of the \"messages\" variable\n */\n parser.stack.defineScope()\n parser.stack.defineVariable('$messages')\n\n /**\n * Process component children using the parser\n */\n token.children.forEach((child) => {\n parser.processToken(child, buffer)\n })\n\n /**\n * Clear the scope of the local variables before we\n * close the if statement\n */\n parser.stack.clearScope()\n\n /**\n * Close if statement\n */\n buffer.writeStatement(`}`, token.filename, token.loc.start.line)\n },\n })\n}\n"],"mappings":"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","names":[]}
@@ -1,8 +1,9 @@
1
1
  import {
2
2
  SessionClient
3
- } from "../../../chunk-GB5FBZCV.js";
3
+ } from "../../../chunk-GCO66PQD.js";
4
4
  import "../../../chunk-TE5JP3SX.js";
5
- import "../../../chunk-ZVSEMDIC.js";
5
+ import "../../../chunk-5ECC6OWF.js";
6
+ import "../../../chunk-PZ5AY32C.js";
6
7
 
7
8
  // src/plugins/japa/api_client.ts
8
9
  import lodash from "@poppinss/utils/lodash";
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/plugins/japa/api_client.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 lodash from '@poppinss/utils/lodash'\nimport { configProvider } from '@adonisjs/core'\nimport { RuntimeException } from '@poppinss/utils'\nimport type { PluginFn } from '@japa/runner/types'\nimport type { ApplicationService } from '@adonisjs/core/types'\nimport { ApiClient, ApiRequest, ApiResponse } from '@japa/api-client'\n\nimport { SessionClient } from '../../client.js'\nimport type { SessionData } from '../../types.js'\n\ndeclare module '@japa/api-client' {\n export interface ApiRequest {\n sessionClient: SessionClient\n\n /**\n * Make HTTP request along with the provided session data\n */\n withSession(values: SessionData): this\n\n /**\n * Make HTTP request along with the provided session flash\n * messages.\n */\n withFlashMessages(values: SessionData): this\n }\n\n export interface ApiResponse {\n sessionBag: {\n values: SessionData\n flashMessages: SessionData\n }\n\n /**\n * Get session data from the HTTP response\n */\n session(key?: string): any\n\n /**\n * Get flash messages from the HTTP response\n */\n flashMessages(): SessionData\n\n /**\n * Get flash messages for a specific key from the HTTP response\n */\n flashMessage(key: string): SessionData\n\n /**\n * Assert session key-value pair exists\n */\n assertSession(key: string, value?: any): void\n\n /**\n * Assert key is missing in session store\n */\n assertSessionMissing(key: string): void\n\n /**\n * Assert flash message key-value pair exists\n */\n assertFlashMessage(key: string, value?: any): void\n\n /**\n * Assert key is missing flash messages store\n */\n assertFlashMissing(key: string): void\n\n /**\n * Assert flash messages has validation errors for\n * the given field\n */\n assertHasValidationError(field: string): void\n\n /**\n * Assert flash messages does not have validation errors\n * for the given field\n */\n assertDoesNotHaveValidationError(field: string): void\n\n /**\n * Assert error message for a given field\n */\n assertValidationError(field: string, message: string): void\n\n /**\n * Assert all error messages for a given field\n */\n assertValidationErrors(field: string, messages: string[]): void\n }\n}\n\n/**\n * Hooks AdonisJS Session with the Japa API client\n * plugin\n */\nexport const sessionApiClient = (app: ApplicationService) => {\n const pluginFn: PluginFn = async function () {\n const sessionConfigProvider = app.config.get('session', {})\n\n /**\n * Resolve config from the provider\n */\n const config = await configProvider.resolve<any>(app, sessionConfigProvider)\n if (!config) {\n throw new RuntimeException(\n 'Invalid \"config/session.ts\" file. Make sure you are using the \"defineConfig\" method'\n )\n }\n\n /**\n * Stick an singleton session client to APIRequest. The session\n * client is used to keep a track of session data we have\n * to send during the request.\n */\n ApiRequest.getter(\n 'sessionClient',\n function () {\n return new SessionClient(config.stores.memory())\n },\n true\n )\n\n /**\n * Define session data\n */\n ApiRequest.macro('withSession', function (this: ApiRequest, data) {\n this.sessionClient.merge(data)\n return this\n })\n\n /**\n * Define flash messages\n */\n ApiRequest.macro('withFlashMessages', function (this: ApiRequest, data) {\n this.sessionClient.flash(data)\n return this\n })\n\n /**\n * Get session data\n */\n ApiResponse.macro('session', function (this: ApiResponse, key) {\n return key ? lodash.get(this.sessionBag.values, key) : this.sessionBag.values\n })\n\n /**\n * Get flash messages\n */\n ApiResponse.macro('flashMessages', function (this: ApiResponse) {\n return this.sessionBag.flashMessages\n })\n ApiResponse.macro('flashMessage', function (this: ApiResponse, key) {\n return lodash.get(this.sessionBag.flashMessages, key)\n })\n\n /**\n * Response session assertions\n */\n ApiResponse.macro('assertSession', function (this: ApiResponse, key, value) {\n this.assert!.property(this.session(), key)\n if (value !== undefined) {\n this.assert!.deepEqual(this.session(key), value)\n }\n })\n ApiResponse.macro('assertSessionMissing', function (this: ApiResponse, key) {\n this.assert!.notProperty(this.session(), key)\n })\n ApiResponse.macro('assertFlashMessage', function (this: ApiResponse, key, value) {\n this.assert!.property(this.flashMessages(), key)\n if (value !== undefined) {\n this.assert!.deepEqual(this.flashMessage(key), value)\n }\n })\n ApiResponse.macro('assertFlashMissing', function (this: ApiResponse, key) {\n this.assert!.notProperty(this.flashMessages(), key)\n })\n ApiResponse.macro('assertHasValidationError', function (this: ApiResponse, field) {\n this.assert!.property(this.flashMessage('errors'), field)\n })\n ApiResponse.macro('assertDoesNotHaveValidationError', function (this: ApiResponse, field) {\n this.assert!.notProperty(this.flashMessage('errors'), field)\n })\n ApiResponse.macro('assertValidationError', function (this: ApiResponse, field, message) {\n this.assert!.include(this.flashMessage('errors')?.[field] || [], message)\n })\n ApiResponse.macro('assertValidationErrors', function (this: ApiResponse, field, messages) {\n this.assert!.deepEqual(this.flashMessage('errors')?.[field] || [], messages)\n })\n\n /**\n * We define the hook using the \"request.setup\" method because we\n * want to allow other Japa hooks to mutate the session store\n * without running into race conditions\n */\n ApiClient.onRequest((request) => {\n request.setup(async () => {\n /**\n * Set cookie\n */\n request.withCookie(config.cookieName, request.sessionClient.sessionId)\n\n /**\n * Persist data\n */\n await request.sessionClient.commit()\n\n /**\n * Cleanup if request fails\n */\n return async (error: any) => {\n if (error) {\n await request.sessionClient.destroy()\n }\n }\n })\n\n request.teardown(async (response) => {\n const sessionId = response.cookie(config.cookieName)\n\n /**\n * Reading session data from the response cookie\n */\n response.sessionBag = sessionId\n ? await response.request.sessionClient.load(sessionId.value)\n : {\n values: {},\n flashMessages: {},\n }\n\n /**\n * Cleanup state\n */\n await request.sessionClient.destroy(sessionId?.value)\n })\n })\n }\n\n return pluginFn\n}\n"],"mappings":";;;;;;;AASA,OAAO,YAAY;AACnB,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAGjC,SAAS,WAAW,YAAY,mBAAmB;AA0F5C,IAAM,mBAAmB,CAAC,QAA4B;AAC3D,QAAM,WAAqB,iBAAkB;AAC3C,UAAM,wBAAwB,IAAI,OAAO,IAAI,WAAW,CAAC,CAAC;AAK1D,UAAM,SAAS,MAAM,eAAe,QAAa,KAAK,qBAAqB;AAC3E,QAAI,CAAC,QAAQ;AACX,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAOA,eAAW;AAAA,MACT;AAAA,MACA,WAAY;AACV,eAAO,IAAI,cAAc,OAAO,OAAO,OAAO,CAAC;AAAA,MACjD;AAAA,MACA;AAAA,IACF;AAKA,eAAW,MAAM,eAAe,SAA4B,MAAM;AAChE,WAAK,cAAc,MAAM,IAAI;AAC7B,aAAO;AAAA,IACT,CAAC;AAKD,eAAW,MAAM,qBAAqB,SAA4B,MAAM;AACtE,WAAK,cAAc,MAAM,IAAI;AAC7B,aAAO;AAAA,IACT,CAAC;AAKD,gBAAY,MAAM,WAAW,SAA6B,KAAK;AAC7D,aAAO,MAAM,OAAO,IAAI,KAAK,WAAW,QAAQ,GAAG,IAAI,KAAK,WAAW;AAAA,IACzE,CAAC;AAKD,gBAAY,MAAM,iBAAiB,WAA6B;AAC9D,aAAO,KAAK,WAAW;AAAA,IACzB,CAAC;AACD,gBAAY,MAAM,gBAAgB,SAA6B,KAAK;AAClE,aAAO,OAAO,IAAI,KAAK,WAAW,eAAe,GAAG;AAAA,IACtD,CAAC;AAKD,gBAAY,MAAM,iBAAiB,SAA6B,KAAK,OAAO;AAC1E,WAAK,OAAQ,SAAS,KAAK,QAAQ,GAAG,GAAG;AACzC,UAAI,UAAU,QAAW;AACvB,aAAK,OAAQ,UAAU,KAAK,QAAQ,GAAG,GAAG,KAAK;AAAA,MACjD;AAAA,IACF,CAAC;AACD,gBAAY,MAAM,wBAAwB,SAA6B,KAAK;AAC1E,WAAK,OAAQ,YAAY,KAAK,QAAQ,GAAG,GAAG;AAAA,IAC9C,CAAC;AACD,gBAAY,MAAM,sBAAsB,SAA6B,KAAK,OAAO;AAC/E,WAAK,OAAQ,SAAS,KAAK,cAAc,GAAG,GAAG;AAC/C,UAAI,UAAU,QAAW;AACvB,aAAK,OAAQ,UAAU,KAAK,aAAa,GAAG,GAAG,KAAK;AAAA,MACtD;AAAA,IACF,CAAC;AACD,gBAAY,MAAM,sBAAsB,SAA6B,KAAK;AACxE,WAAK,OAAQ,YAAY,KAAK,cAAc,GAAG,GAAG;AAAA,IACpD,CAAC;AACD,gBAAY,MAAM,4BAA4B,SAA6B,OAAO;AAChF,WAAK,OAAQ,SAAS,KAAK,aAAa,QAAQ,GAAG,KAAK;AAAA,IAC1D,CAAC;AACD,gBAAY,MAAM,oCAAoC,SAA6B,OAAO;AACxF,WAAK,OAAQ,YAAY,KAAK,aAAa,QAAQ,GAAG,KAAK;AAAA,IAC7D,CAAC;AACD,gBAAY,MAAM,yBAAyB,SAA6B,OAAO,SAAS;AACtF,WAAK,OAAQ,QAAQ,KAAK,aAAa,QAAQ,IAAI,KAAK,KAAK,CAAC,GAAG,OAAO;AAAA,IAC1E,CAAC;AACD,gBAAY,MAAM,0BAA0B,SAA6B,OAAO,UAAU;AACxF,WAAK,OAAQ,UAAU,KAAK,aAAa,QAAQ,IAAI,KAAK,KAAK,CAAC,GAAG,QAAQ;AAAA,IAC7E,CAAC;AAOD,cAAU,UAAU,CAAC,YAAY;AAC/B,cAAQ,MAAM,YAAY;AAIxB,gBAAQ,WAAW,OAAO,YAAY,QAAQ,cAAc,SAAS;AAKrE,cAAM,QAAQ,cAAc,OAAO;AAKnC,eAAO,OAAO,UAAe;AAC3B,cAAI,OAAO;AACT,kBAAM,QAAQ,cAAc,QAAQ;AAAA,UACtC;AAAA,QACF;AAAA,MACF,CAAC;AAED,cAAQ,SAAS,OAAO,aAAa;AACnC,cAAM,YAAY,SAAS,OAAO,OAAO,UAAU;AAKnD,iBAAS,aAAa,YAClB,MAAM,SAAS,QAAQ,cAAc,KAAK,UAAU,KAAK,IACzD;AAAA,UACE,QAAQ,CAAC;AAAA,UACT,eAAe,CAAC;AAAA,QAClB;AAKJ,cAAM,QAAQ,cAAc,QAAQ,WAAW,KAAK;AAAA,MACtD,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AAEA,SAAO;AACT;","names":[]}
1
+ {"version":3,"sources":["../../../../src/plugins/japa/api_client.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 lodash from '@poppinss/utils/lodash'\nimport { configProvider } from '@adonisjs/core'\nimport { RuntimeException } from '@poppinss/utils'\nimport type { PluginFn } from '@japa/runner/types'\nimport type { ApplicationService } from '@adonisjs/core/types'\nimport { ApiClient, ApiRequest, ApiResponse } from '@japa/api-client'\n\nimport { SessionClient } from '../../client.js'\nimport type { SessionData } from '../../types.js'\n\ndeclare module '@japa/api-client' {\n export interface ApiRequest {\n sessionClient: SessionClient\n\n /**\n * Make HTTP request along with the provided session data\n */\n withSession(values: SessionData): this\n\n /**\n * Make HTTP request along with the provided session flash\n * messages.\n */\n withFlashMessages(values: SessionData): this\n }\n\n export interface ApiResponse {\n sessionBag: {\n values: SessionData\n flashMessages: SessionData\n }\n\n /**\n * Get session data from the HTTP response\n */\n session(key?: string): any\n\n /**\n * Get flash messages from the HTTP response\n */\n flashMessages(): SessionData\n\n /**\n * Get flash messages for a specific key from the HTTP response\n */\n flashMessage(key: string): SessionData\n\n /**\n * Assert session key-value pair exists\n */\n assertSession(key: string, value?: any): void\n\n /**\n * Assert key is missing in session store\n */\n assertSessionMissing(key: string): void\n\n /**\n * Assert flash message key-value pair exists\n */\n assertFlashMessage(key: string, value?: any): void\n\n /**\n * Assert key is missing flash messages store\n */\n assertFlashMissing(key: string): void\n\n /**\n * Assert flash messages has validation errors for\n * the given field\n */\n assertHasValidationError(field: string): void\n\n /**\n * Assert flash messages does not have validation errors\n * for the given field\n */\n assertDoesNotHaveValidationError(field: string): void\n\n /**\n * Assert error message for a given field\n */\n assertValidationError(field: string, message: string): void\n\n /**\n * Assert all error messages for a given field\n */\n assertValidationErrors(field: string, messages: string[]): void\n }\n}\n\n/**\n * Hooks AdonisJS Session with the Japa API client\n * plugin\n */\nexport const sessionApiClient = (app: ApplicationService) => {\n const pluginFn: PluginFn = async function () {\n const sessionConfigProvider = app.config.get('session', {})\n\n /**\n * Resolve config from the provider\n */\n const config = await configProvider.resolve<any>(app, sessionConfigProvider)\n if (!config) {\n throw new RuntimeException(\n 'Invalid \"config/session.ts\" file. Make sure you are using the \"defineConfig\" method'\n )\n }\n\n /**\n * Stick an singleton session client to APIRequest. The session\n * client is used to keep a track of session data we have\n * to send during the request.\n */\n ApiRequest.getter(\n 'sessionClient',\n function () {\n return new SessionClient(config.stores.memory())\n },\n true\n )\n\n /**\n * Define session data\n */\n ApiRequest.macro('withSession', function (this: ApiRequest, data) {\n this.sessionClient.merge(data)\n return this\n })\n\n /**\n * Define flash messages\n */\n ApiRequest.macro('withFlashMessages', function (this: ApiRequest, data) {\n this.sessionClient.flash(data)\n return this\n })\n\n /**\n * Get session data\n */\n ApiResponse.macro('session', function (this: ApiResponse, key) {\n return key ? lodash.get(this.sessionBag.values, key) : this.sessionBag.values\n })\n\n /**\n * Get flash messages\n */\n ApiResponse.macro('flashMessages', function (this: ApiResponse) {\n return this.sessionBag.flashMessages\n })\n ApiResponse.macro('flashMessage', function (this: ApiResponse, key) {\n return lodash.get(this.sessionBag.flashMessages, key)\n })\n\n /**\n * Response session assertions\n */\n ApiResponse.macro('assertSession', function (this: ApiResponse, key, value) {\n this.assert!.property(this.session(), key)\n if (value !== undefined) {\n this.assert!.deepEqual(this.session(key), value)\n }\n })\n ApiResponse.macro('assertSessionMissing', function (this: ApiResponse, key) {\n this.assert!.notProperty(this.session(), key)\n })\n ApiResponse.macro('assertFlashMessage', function (this: ApiResponse, key, value) {\n this.assert!.property(this.flashMessages(), key)\n if (value !== undefined) {\n this.assert!.deepEqual(this.flashMessage(key), value)\n }\n })\n ApiResponse.macro('assertFlashMissing', function (this: ApiResponse, key) {\n this.assert!.notProperty(this.flashMessages(), key)\n })\n ApiResponse.macro('assertHasValidationError', function (this: ApiResponse, field) {\n this.assert!.property(this.flashMessage('errors'), field)\n })\n ApiResponse.macro('assertDoesNotHaveValidationError', function (this: ApiResponse, field) {\n this.assert!.notProperty(this.flashMessage('errors'), field)\n })\n ApiResponse.macro('assertValidationError', function (this: ApiResponse, field, message) {\n this.assert!.include(this.flashMessage('errors')?.[field] || [], message)\n })\n ApiResponse.macro('assertValidationErrors', function (this: ApiResponse, field, messages) {\n this.assert!.deepEqual(this.flashMessage('errors')?.[field] || [], messages)\n })\n\n /**\n * We define the hook using the \"request.setup\" method because we\n * want to allow other Japa hooks to mutate the session store\n * without running into race conditions\n */\n ApiClient.onRequest((request) => {\n request.setup(async () => {\n /**\n * Set cookie\n */\n request.withCookie(config.cookieName, request.sessionClient.sessionId)\n\n /**\n * Persist data\n */\n await request.sessionClient.commit()\n\n /**\n * Cleanup if request fails\n */\n return async (error: any) => {\n if (error) {\n await request.sessionClient.destroy()\n }\n }\n })\n\n request.teardown(async (response) => {\n const sessionId = response.cookie(config.cookieName)\n\n /**\n * Reading session data from the response cookie\n */\n response.sessionBag = sessionId\n ? await response.request.sessionClient.load(sessionId.value)\n : {\n values: {},\n flashMessages: {},\n }\n\n /**\n * Cleanup state\n */\n await request.sessionClient.destroy(sessionId?.value)\n })\n })\n }\n\n return pluginFn\n}\n"],"mappings":"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","names":[]}
@@ -1,8 +1,9 @@
1
1
  import {
2
2
  SessionClient
3
- } from "../../../chunk-GB5FBZCV.js";
3
+ } from "../../../chunk-GCO66PQD.js";
4
4
  import "../../../chunk-TE5JP3SX.js";
5
- import "../../../chunk-ZVSEMDIC.js";
5
+ import "../../../chunk-5ECC6OWF.js";
6
+ import "../../../chunk-PZ5AY32C.js";
6
7
 
7
8
  // src/plugins/japa/browser_client.ts
8
9
  import { configProvider } from "@adonisjs/core";
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/plugins/japa/browser_client.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 { configProvider } from '@adonisjs/core'\nimport { RuntimeException } from '@poppinss/utils'\nimport type { PluginFn } from '@japa/runner/types'\nimport { decoratorsCollection } from '@japa/browser-client'\nimport type { ApplicationService } from '@adonisjs/core/types'\nimport type { CookieOptions as AdonisCookieOptions } from '@adonisjs/core/types/http'\n\nimport { SessionClient } from '../../client.js'\nimport type { SessionConfig, SessionData } from '../../types.js'\n\ndeclare module 'playwright' {\n export interface BrowserContext {\n sessionClient: SessionClient\n\n /**\n * Initiate session. The session id cookie will be defined\n * if missing\n */\n initiateSession(options?: Partial<AdonisCookieOptions>): Promise<void>\n\n /**\n * Returns data from the session store\n */\n getSession(): Promise<any>\n\n /**\n * Returns data from the session store\n */\n getFlashMessages(): Promise<any>\n\n /**\n * Set session data\n */\n setSession(values: SessionData): Promise<void>\n\n /**\n * Set flash messages\n */\n setFlashMessages(values: SessionData): Promise<void>\n }\n}\n\n/**\n * Transforming AdonisJS same site option to playwright\n * same site option.\n */\nfunction transformSameSiteOption(sameSite?: AdonisCookieOptions['sameSite']) {\n if (!sameSite) {\n return\n }\n\n if (sameSite === true || sameSite === 'strict') {\n return 'Strict' as const\n }\n\n if (sameSite === 'lax') {\n return 'Lax' as const\n }\n\n if (sameSite === 'none') {\n return 'None' as const\n }\n}\n\n/**\n * Transforming AdonisJS session config to playwright cookie options.\n */\nfunction getSessionCookieOptions(\n config: SessionConfig,\n cookieOptions?: Partial<AdonisCookieOptions>\n) {\n const options = { ...config.cookie, ...cookieOptions }\n return {\n ...options,\n expires: undefined,\n sameSite: transformSameSiteOption(options.sameSite),\n }\n}\n\n/**\n * Hooks AdonisJS Session with the Japa browser client\n * plugin\n */\nexport const sessionBrowserClient = (app: ApplicationService) => {\n const pluginFn: PluginFn = async function () {\n const sessionConfigProvider = app.config.get('session', {})\n\n /**\n * Resolve config from the provider\n */\n const config = await configProvider.resolve<any>(app, sessionConfigProvider)\n if (!config) {\n throw new RuntimeException(\n 'Invalid \"config/session.ts\" file. Make sure you are using the \"defineConfig\" method'\n )\n }\n\n decoratorsCollection.register({\n context(context) {\n /**\n * Reference to session client per browser context\n */\n context.sessionClient = new SessionClient(config.stores.memory())\n\n /**\n * Initiating session store\n */\n context.initiateSession = async function (options) {\n const sessionId = await context.getCookie(config.cookieName)\n if (sessionId) {\n context.sessionClient.sessionId = sessionId\n return\n }\n\n await context.setCookie(\n config.cookieName,\n context.sessionClient.sessionId,\n getSessionCookieOptions(config, options)\n )\n }\n\n /**\n * Returns session data\n */\n context.getSession = async function () {\n await context.initiateSession()\n const sessionData = await context.sessionClient.load()\n return sessionData.values\n }\n\n /**\n * Returns flash messages from the data store\n */\n context.getFlashMessages = async function () {\n await context.initiateSession()\n const sessionData = await context.sessionClient.load()\n return sessionData.flashMessages\n }\n\n /**\n * Set session data\n */\n context.setSession = async function (values) {\n await context.initiateSession()\n context.sessionClient.merge(values)\n await context.sessionClient.commit()\n }\n\n /**\n * Set flash messages\n */\n context.setFlashMessages = async function (values) {\n await context.initiateSession()\n context.sessionClient.flash(values)\n await context.sessionClient.commit()\n }\n\n /**\n * Destroy session when context is closed\n */\n context.on('close', async function () {\n await context.sessionClient.destroy()\n })\n },\n })\n }\n\n return pluginFn\n}\n"],"mappings":";;;;;;;AASA,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAEjC,SAAS,4BAA4B;AA2CrC,SAAS,wBAAwB,UAA4C;AAC3E,MAAI,CAAC,UAAU;AACb;AAAA,EACF;AAEA,MAAI,aAAa,QAAQ,aAAa,UAAU;AAC9C,WAAO;AAAA,EACT;AAEA,MAAI,aAAa,OAAO;AACtB,WAAO;AAAA,EACT;AAEA,MAAI,aAAa,QAAQ;AACvB,WAAO;AAAA,EACT;AACF;AAKA,SAAS,wBACP,QACA,eACA;AACA,QAAM,UAAU,EAAE,GAAG,OAAO,QAAQ,GAAG,cAAc;AACrD,SAAO;AAAA,IACL,GAAG;AAAA,IACH,SAAS;AAAA,IACT,UAAU,wBAAwB,QAAQ,QAAQ;AAAA,EACpD;AACF;AAMO,IAAM,uBAAuB,CAAC,QAA4B;AAC/D,QAAM,WAAqB,iBAAkB;AAC3C,UAAM,wBAAwB,IAAI,OAAO,IAAI,WAAW,CAAC,CAAC;AAK1D,UAAM,SAAS,MAAM,eAAe,QAAa,KAAK,qBAAqB;AAC3E,QAAI,CAAC,QAAQ;AACX,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAEA,yBAAqB,SAAS;AAAA,MAC5B,QAAQ,SAAS;AAIf,gBAAQ,gBAAgB,IAAI,cAAc,OAAO,OAAO,OAAO,CAAC;AAKhE,gBAAQ,kBAAkB,eAAgB,SAAS;AACjD,gBAAM,YAAY,MAAM,QAAQ,UAAU,OAAO,UAAU;AAC3D,cAAI,WAAW;AACb,oBAAQ,cAAc,YAAY;AAClC;AAAA,UACF;AAEA,gBAAM,QAAQ;AAAA,YACZ,OAAO;AAAA,YACP,QAAQ,cAAc;AAAA,YACtB,wBAAwB,QAAQ,OAAO;AAAA,UACzC;AAAA,QACF;AAKA,gBAAQ,aAAa,iBAAkB;AACrC,gBAAM,QAAQ,gBAAgB;AAC9B,gBAAM,cAAc,MAAM,QAAQ,cAAc,KAAK;AACrD,iBAAO,YAAY;AAAA,QACrB;AAKA,gBAAQ,mBAAmB,iBAAkB;AAC3C,gBAAM,QAAQ,gBAAgB;AAC9B,gBAAM,cAAc,MAAM,QAAQ,cAAc,KAAK;AACrD,iBAAO,YAAY;AAAA,QACrB;AAKA,gBAAQ,aAAa,eAAgB,QAAQ;AAC3C,gBAAM,QAAQ,gBAAgB;AAC9B,kBAAQ,cAAc,MAAM,MAAM;AAClC,gBAAM,QAAQ,cAAc,OAAO;AAAA,QACrC;AAKA,gBAAQ,mBAAmB,eAAgB,QAAQ;AACjD,gBAAM,QAAQ,gBAAgB;AAC9B,kBAAQ,cAAc,MAAM,MAAM;AAClC,gBAAM,QAAQ,cAAc,OAAO;AAAA,QACrC;AAKA,gBAAQ,GAAG,SAAS,iBAAkB;AACpC,gBAAM,QAAQ,cAAc,QAAQ;AAAA,QACtC,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AAEA,SAAO;AACT;","names":[]}
1
+ {"version":3,"sources":["../../../../src/plugins/japa/browser_client.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 { configProvider } from '@adonisjs/core'\nimport { RuntimeException } from '@poppinss/utils'\nimport type { PluginFn } from '@japa/runner/types'\nimport { decoratorsCollection } from '@japa/browser-client'\nimport type { ApplicationService } from '@adonisjs/core/types'\nimport type { CookieOptions as AdonisCookieOptions } from '@adonisjs/core/types/http'\n\nimport { SessionClient } from '../../client.js'\nimport type { SessionConfig, SessionData } from '../../types.js'\n\ndeclare module 'playwright' {\n export interface BrowserContext {\n sessionClient: SessionClient\n\n /**\n * Initiate session. The session id cookie will be defined\n * if missing\n */\n initiateSession(options?: Partial<AdonisCookieOptions>): Promise<void>\n\n /**\n * Returns data from the session store\n */\n getSession(): Promise<any>\n\n /**\n * Returns data from the session store\n */\n getFlashMessages(): Promise<any>\n\n /**\n * Set session data\n */\n setSession(values: SessionData): Promise<void>\n\n /**\n * Set flash messages\n */\n setFlashMessages(values: SessionData): Promise<void>\n }\n}\n\n/**\n * Transforming AdonisJS same site option to playwright\n * same site option.\n */\nfunction transformSameSiteOption(sameSite?: AdonisCookieOptions['sameSite']) {\n if (!sameSite) {\n return\n }\n\n if (sameSite === true || sameSite === 'strict') {\n return 'Strict' as const\n }\n\n if (sameSite === 'lax') {\n return 'Lax' as const\n }\n\n if (sameSite === 'none') {\n return 'None' as const\n }\n}\n\n/**\n * Transforming AdonisJS session config to playwright cookie options.\n */\nfunction getSessionCookieOptions(\n config: SessionConfig,\n cookieOptions?: Partial<AdonisCookieOptions>\n) {\n const options = { ...config.cookie, ...cookieOptions }\n return {\n ...options,\n expires: undefined,\n sameSite: transformSameSiteOption(options.sameSite),\n }\n}\n\n/**\n * Hooks AdonisJS Session with the Japa browser client\n * plugin\n */\nexport const sessionBrowserClient = (app: ApplicationService) => {\n const pluginFn: PluginFn = async function () {\n const sessionConfigProvider = app.config.get('session', {})\n\n /**\n * Resolve config from the provider\n */\n const config = await configProvider.resolve<any>(app, sessionConfigProvider)\n if (!config) {\n throw new RuntimeException(\n 'Invalid \"config/session.ts\" file. Make sure you are using the \"defineConfig\" method'\n )\n }\n\n decoratorsCollection.register({\n context(context) {\n /**\n * Reference to session client per browser context\n */\n context.sessionClient = new SessionClient(config.stores.memory())\n\n /**\n * Initiating session store\n */\n context.initiateSession = async function (options) {\n const sessionId = await context.getCookie(config.cookieName)\n if (sessionId) {\n context.sessionClient.sessionId = sessionId\n return\n }\n\n await context.setCookie(\n config.cookieName,\n context.sessionClient.sessionId,\n getSessionCookieOptions(config, options)\n )\n }\n\n /**\n * Returns session data\n */\n context.getSession = async function () {\n await context.initiateSession()\n const sessionData = await context.sessionClient.load()\n return sessionData.values\n }\n\n /**\n * Returns flash messages from the data store\n */\n context.getFlashMessages = async function () {\n await context.initiateSession()\n const sessionData = await context.sessionClient.load()\n return sessionData.flashMessages\n }\n\n /**\n * Set session data\n */\n context.setSession = async function (values) {\n await context.initiateSession()\n context.sessionClient.merge(values)\n await context.sessionClient.commit()\n }\n\n /**\n * Set flash messages\n */\n context.setFlashMessages = async function (values) {\n await context.initiateSession()\n context.sessionClient.flash(values)\n await context.sessionClient.commit()\n }\n\n /**\n * Destroy session when context is closed\n */\n context.on('close', async function () {\n await context.sessionClient.destroy()\n })\n },\n })\n }\n\n return pluginFn\n}\n"],"mappings":";;;;;;;;AASA,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAEjC,SAAS,4BAA4B;AA2CrC,SAAS,wBAAwB,UAA4C;AAC3E,MAAI,CAAC,UAAU;AACb;AAAA,EACF;AAEA,MAAI,aAAa,QAAQ,aAAa,UAAU;AAC9C,WAAO;AAAA,EACT;AAEA,MAAI,aAAa,OAAO;AACtB,WAAO;AAAA,EACT;AAEA,MAAI,aAAa,QAAQ;AACvB,WAAO;AAAA,EACT;AACF;AAKA,SAAS,wBACP,QACA,eACA;AACA,QAAM,UAAU,EAAE,GAAG,OAAO,QAAQ,GAAG,cAAc;AACrD,SAAO;AAAA,IACL,GAAG;AAAA,IACH,SAAS;AAAA,IACT,UAAU,wBAAwB,QAAQ,QAAQ;AAAA,EACpD;AACF;AAMO,IAAM,uBAAuB,CAAC,QAA4B;AAC/D,QAAM,WAAqB,iBAAkB;AAC3C,UAAM,wBAAwB,IAAI,OAAO,IAAI,WAAW,CAAC,CAAC;AAK1D,UAAM,SAAS,MAAM,eAAe,QAAa,KAAK,qBAAqB;AAC3E,QAAI,CAAC,QAAQ;AACX,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAEA,yBAAqB,SAAS;AAAA,MAC5B,QAAQ,SAAS;AAIf,gBAAQ,gBAAgB,IAAI,cAAc,OAAO,OAAO,OAAO,CAAC;AAKhE,gBAAQ,kBAAkB,eAAgB,SAAS;AACjD,gBAAM,YAAY,MAAM,QAAQ,UAAU,OAAO,UAAU;AAC3D,cAAI,WAAW;AACb,oBAAQ,cAAc,YAAY;AAClC;AAAA,UACF;AAEA,gBAAM,QAAQ;AAAA,YACZ,OAAO;AAAA,YACP,QAAQ,cAAc;AAAA,YACtB,wBAAwB,QAAQ,OAAO;AAAA,UACzC;AAAA,QACF;AAKA,gBAAQ,aAAa,iBAAkB;AACrC,gBAAM,QAAQ,gBAAgB;AAC9B,gBAAM,cAAc,MAAM,QAAQ,cAAc,KAAK;AACrD,iBAAO,YAAY;AAAA,QACrB;AAKA,gBAAQ,mBAAmB,iBAAkB;AAC3C,gBAAM,QAAQ,gBAAgB;AAC9B,gBAAM,cAAc,MAAM,QAAQ,cAAc,KAAK;AACrD,iBAAO,YAAY;AAAA,QACrB;AAKA,gBAAQ,aAAa,eAAgB,QAAQ;AAC3C,gBAAM,QAAQ,gBAAgB;AAC9B,kBAAQ,cAAc,MAAM,MAAM;AAClC,gBAAM,QAAQ,cAAc,OAAO;AAAA,QACrC;AAKA,gBAAQ,mBAAmB,eAAgB,QAAQ;AACjD,gBAAM,QAAQ,gBAAgB;AAC9B,kBAAQ,cAAc,MAAM,MAAM;AAClC,gBAAM,QAAQ,cAAc,OAAO;AAAA,QACrC;AAKA,gBAAQ,GAAG,SAAS,iBAAkB;AACpC,gBAAM,QAAQ,cAAc,QAAQ;AAAA,QACtC,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AAEA,SAAO;AACT;","names":[]}
@@ -1,9 +1,10 @@
1
1
  import {
2
2
  SessionMiddleware
3
- } from "../chunk-TZLOND27.js";
4
- import "../chunk-OCQGCVXK.js";
3
+ } from "../chunk-CVMFYEYR.js";
4
+ import "../chunk-I6SY5ILN.js";
5
5
  import "../chunk-TE5JP3SX.js";
6
- import "../chunk-ZVSEMDIC.js";
6
+ import "../chunk-5ECC6OWF.js";
7
+ import "../chunk-PZ5AY32C.js";
7
8
  export {
8
9
  SessionMiddleware as default
9
10
  };
@@ -0,0 +1,47 @@
1
+ /**
2
+ * @adonisjs/session
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+ import type { QueryClientContract } from '@adonisjs/lucid/types/database';
10
+ import type { SessionStoreContract, SessionData } from '../types.js';
11
+ /**
12
+ * Database store to read/write session to SQL databases using Lucid
13
+ */
14
+ export declare class DatabaseStore implements SessionStoreContract {
15
+ #private;
16
+ constructor(client: QueryClientContract, age: string | number, options?: {
17
+ /**
18
+ * Defaults to "sessions"
19
+ */
20
+ tableName?: string;
21
+ /**
22
+ * The probability (in percent) that garbage collection will be
23
+ * triggered on any given request. For example, 2 means 2% chance.
24
+ *
25
+ * Set to 0 to disable garbage collection.
26
+ *
27
+ * Defaults to 2 (2% chance)
28
+ */
29
+ gcProbability?: number;
30
+ });
31
+ /**
32
+ * Returns session data
33
+ */
34
+ read(sessionId: string): Promise<SessionData | null>;
35
+ /**
36
+ * Write session values to the database
37
+ */
38
+ write(sessionId: string, values: Object): Promise<void>;
39
+ /**
40
+ * Cleanup session by removing it
41
+ */
42
+ destroy(sessionId: string): Promise<void>;
43
+ /**
44
+ * Updates the session expiry
45
+ */
46
+ touch(sessionId: string): Promise<void>;
47
+ }
@@ -92,6 +92,23 @@ export type DynamoDBStoreConfig = ({
92
92
  tableName?: string;
93
93
  keyAttribute?: string;
94
94
  };
95
+ /**
96
+ * Configuration used by the database store.
97
+ */
98
+ export interface DatabaseStoreConfig {
99
+ connectionName?: string;
100
+ tableName?: string;
101
+ /**
102
+ * The probability (in percent) that garbage collection of expired
103
+ * sessions will be triggered on any given request.
104
+ *
105
+ * For example, 2 means 2% chance.
106
+ * Set to 0 to disable garbage collection.
107
+ *
108
+ * Defaults to 2 (2% chance)
109
+ */
110
+ gcProbability?: number;
111
+ }
95
112
  /**
96
113
  * Factory function to instantiate session store
97
114
  */
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.5.0",
4
+ "version": "7.6.0",
5
5
  "engines": {
6
6
  "node": ">=18.16.0"
7
7
  },
@@ -22,7 +22,8 @@
22
22
  "./plugins/api_client": "./build/src/plugins/japa/api_client.js",
23
23
  "./plugins/browser_client": "./build/src/plugins/japa/browser_client.js",
24
24
  "./client": "./build/src/client.js",
25
- "./types": "./build/src/types.js"
25
+ "./types": "./build/src/types.js",
26
+ "./commands": "./build/commands/main.js"
26
27
  },
27
28
  "scripts": {
28
29
  "pretest": "npm run lint",
@@ -33,7 +34,8 @@
33
34
  "copy:templates": "copyfiles \"stubs/**/*.stub\" --up=\"1\" build",
34
35
  "precompile": "npm run lint",
35
36
  "compile": "tsup-node && tsc --emitDeclarationOnly --declaration",
36
- "postcompile": "npm run copy:templates",
37
+ "postcompile": "npm run copy:templates && npm run index:commands",
38
+ "index:commands": "adonis-kit index build/commands",
37
39
  "build": "npm run compile",
38
40
  "version": "npm run build",
39
41
  "prepublishOnly": "npm run build",
@@ -42,56 +44,64 @@
42
44
  },
43
45
  "devDependencies": {
44
46
  "@adonisjs/assembler": "^7.8.2",
45
- "@adonisjs/core": "^6.14.0",
46
- "@adonisjs/eslint-config": "^2.0.0-beta.7",
47
- "@adonisjs/i18n": "^2.1.1",
48
- "@adonisjs/prettier-config": "^1.4.0",
49
- "@adonisjs/redis": "^9.1.0",
50
- "@adonisjs/tsconfig": "^1.4.0",
51
- "@aws-sdk/client-dynamodb": "^3.658.0",
52
- "@aws-sdk/util-dynamodb": "^3.658.0",
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.6",
60
- "@release-it/conventional-changelog": "^8.0.2",
61
- "@swc/core": "^1.7.28",
62
- "@types/node": "^22.7.0",
47
+ "@adonisjs/core": "^6.18.0",
48
+ "@adonisjs/eslint-config": "^2.1.0",
49
+ "@adonisjs/i18n": "^2.2.0",
50
+ "@adonisjs/lucid": "^21.6.0",
51
+ "better-sqlite3": "^12.5.0",
52
+ "mysql2": "^3.15.3",
53
+ "pg": "^8.16.3",
54
+ "@adonisjs/prettier-config": "^1.4.5",
55
+ "@adonisjs/redis": "^9.2.0",
56
+ "@adonisjs/tsconfig": "^1.4.1",
57
+ "@aws-sdk/client-dynamodb": "^3.830.0",
58
+ "@aws-sdk/util-dynamodb": "^3.830.0",
59
+ "@japa/api-client": "^3.1.0",
60
+ "@japa/assert": "^4.0.1",
61
+ "@japa/browser-client": "^2.1.1",
62
+ "@japa/file-system": "^2.3.2",
63
+ "@japa/plugin-adonisjs": "^4.0.0",
64
+ "@japa/runner": "^4.2.0",
65
+ "@japa/snapshot": "^2.0.8",
66
+ "@release-it/conventional-changelog": "^10.0.1",
67
+ "@swc/core": "1.10.7",
68
+ "@types/node": "^24.0.3",
63
69
  "@types/set-cookie-parser": "^2.4.10",
64
- "@types/supertest": "^6.0.2",
65
- "@vinejs/vine": "^2.1.0",
66
- "c8": "^10.1.2",
70
+ "@types/supertest": "^6.0.3",
71
+ "@vinejs/vine": "^3.0.1",
72
+ "c8": "^10.1.3",
67
73
  "copyfiles": "^2.4.1",
68
74
  "cross-env": "^7.0.3",
69
- "edge.js": "^6.2.0",
70
- "eslint": "^9.11.1",
75
+ "edge.js": "^6.2.1",
76
+ "eslint": "^9.29.0",
71
77
  "get-port": "^7.1.0",
72
- "playwright": "^1.47.2",
73
- "prettier": "^3.3.3",
74
- "release-it": "^17.6.0",
75
- "set-cookie-parser": "^2.7.0",
76
- "supertest": "^7.0.0",
77
- "ts-node-maintained": "^10.9.4",
78
- "tsup": "^8.3.0",
79
- "typescript": "^5.6.2"
78
+ "playwright": "^1.53.0",
79
+ "prettier": "^3.5.3",
80
+ "release-it": "^19.0.3",
81
+ "set-cookie-parser": "^2.7.1",
82
+ "supertest": "^7.1.1",
83
+ "ts-node-maintained": "^10.9.5",
84
+ "tsup": "^8.5.0",
85
+ "typescript": "^5.8.3"
80
86
  },
81
87
  "dependencies": {
82
- "@poppinss/macroable": "^1.0.3",
83
- "@poppinss/utils": "^6.8.3"
88
+ "@poppinss/macroable": "^1.0.4",
89
+ "@poppinss/utils": "^6.10.0"
84
90
  },
85
91
  "peerDependencies": {
86
92
  "@adonisjs/core": "^6.6.0",
93
+ "@adonisjs/lucid": "^21.0.0",
87
94
  "@adonisjs/redis": "^8.0.1 || ^9.0.0",
88
95
  "@aws-sdk/client-dynamodb": "^3.658.0",
89
96
  "@aws-sdk/util-dynamodb": "^3.658.0",
90
- "@japa/api-client": "^2.0.3",
97
+ "@japa/api-client": "^2.0.3 || ^3.0.0",
91
98
  "@japa/browser-client": "^2.0.3",
92
99
  "edge.js": "^6.0.2"
93
100
  },
94
101
  "peerDependenciesMeta": {
102
+ "@adonisjs/lucid": {
103
+ "optional": true
104
+ },
95
105
  "@adonisjs/redis": {
96
106
  "optional": true
97
107
  },
@@ -139,7 +149,8 @@
139
149
  "./src/plugins/edge.ts",
140
150
  "./src/plugins/japa/api_client.ts",
141
151
  "./src/plugins/japa/browser_client.ts",
142
- "./src/client.ts"
152
+ "./src/client.ts",
153
+ "./commands/make_session_table.ts"
143
154
  ],
144
155
  "outDir": "./build",
145
156
  "clean": true,