@sapphire/plugin-api 6.1.2-next.fc6b7cf.0 → 7.0.0-next.d27dc1c

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 (99) hide show
  1. package/dist/cjs/index.cjs +1 -1
  2. package/dist/cjs/index.cjs.map +1 -1
  3. package/dist/cjs/index.d.cts +7 -5
  4. package/dist/cjs/lib/structures/MediaParser.cjs +4 -8
  5. package/dist/cjs/lib/structures/MediaParser.cjs.map +1 -1
  6. package/dist/cjs/lib/structures/Middleware.cjs +1 -4
  7. package/dist/cjs/lib/structures/Middleware.cjs.map +1 -1
  8. package/dist/cjs/lib/structures/MiddlewareStore.cjs +6 -14
  9. package/dist/cjs/lib/structures/MiddlewareStore.cjs.map +1 -1
  10. package/dist/cjs/lib/structures/Route.cjs +5 -7
  11. package/dist/cjs/lib/structures/Route.cjs.map +1 -1
  12. package/dist/cjs/lib/structures/RouteStore.cjs +5 -12
  13. package/dist/cjs/lib/structures/RouteStore.cjs.map +1 -1
  14. package/dist/cjs/lib/structures/api/ApiRequest.cjs +1 -4
  15. package/dist/cjs/lib/structures/api/ApiRequest.cjs.map +1 -1
  16. package/dist/cjs/lib/structures/api/ApiResponse.cjs +1 -4
  17. package/dist/cjs/lib/structures/api/ApiResponse.cjs.map +1 -1
  18. package/dist/cjs/lib/structures/api/CookieStore.cjs +3 -8
  19. package/dist/cjs/lib/structures/api/CookieStore.cjs.map +1 -1
  20. package/dist/cjs/lib/structures/http/Auth.cjs +13 -31
  21. package/dist/cjs/lib/structures/http/Auth.cjs.map +1 -1
  22. package/dist/cjs/lib/structures/http/Server.cjs +1 -4
  23. package/dist/cjs/lib/structures/http/Server.cjs.map +1 -1
  24. package/dist/cjs/lib/utils/RouteData.cjs +10 -21
  25. package/dist/cjs/lib/utils/RouteData.cjs.map +1 -1
  26. package/dist/cjs/listeners/PluginRouteError.cjs +1 -2
  27. package/dist/cjs/listeners/PluginRouteError.cjs.map +1 -1
  28. package/dist/cjs/listeners/PluginServerMiddlewareError.cjs +1 -2
  29. package/dist/cjs/listeners/PluginServerMiddlewareError.cjs.map +1 -1
  30. package/dist/cjs/listeners/PluginServerNoMatch.cjs +1 -2
  31. package/dist/cjs/listeners/PluginServerNoMatch.cjs.map +1 -1
  32. package/dist/cjs/middlewares/auth.cjs +2 -6
  33. package/dist/cjs/middlewares/auth.cjs.map +1 -1
  34. package/dist/cjs/middlewares/body.cjs +3 -8
  35. package/dist/cjs/middlewares/body.cjs.map +1 -1
  36. package/dist/cjs/middlewares/cookies.cjs +1 -4
  37. package/dist/cjs/middlewares/cookies.cjs.map +1 -1
  38. package/dist/cjs/middlewares/headers.cjs +1 -4
  39. package/dist/cjs/middlewares/headers.cjs.map +1 -1
  40. package/dist/cjs/routes/oauth/callback.cjs +2 -6
  41. package/dist/cjs/routes/oauth/callback.cjs.map +1 -1
  42. package/dist/cjs/routes/oauth/logout.cjs +3 -6
  43. package/dist/cjs/routes/oauth/logout.cjs.map +1 -1
  44. package/dist/esm/chunk-JTFKMR4I.mjs +15 -0
  45. package/dist/esm/index.d.mts +7 -5
  46. package/dist/esm/index.mjs +2 -2
  47. package/dist/esm/index.mjs.map +1 -1
  48. package/dist/esm/lib/structures/MediaParser.mjs +5 -9
  49. package/dist/esm/lib/structures/MediaParser.mjs.map +1 -1
  50. package/dist/esm/lib/structures/MediaParserStore.mjs +1 -1
  51. package/dist/esm/lib/structures/Middleware.mjs +1 -1
  52. package/dist/esm/lib/structures/MiddlewareStore.mjs +6 -11
  53. package/dist/esm/lib/structures/MiddlewareStore.mjs.map +1 -1
  54. package/dist/esm/lib/structures/Route.mjs +5 -4
  55. package/dist/esm/lib/structures/Route.mjs.map +1 -1
  56. package/dist/esm/lib/structures/RouteStore.mjs +5 -9
  57. package/dist/esm/lib/structures/RouteStore.mjs.map +1 -1
  58. package/dist/esm/lib/structures/api/ApiRequest.mjs +1 -1
  59. package/dist/esm/lib/structures/api/ApiResponse.mjs +1 -1
  60. package/dist/esm/lib/structures/api/CookieStore.mjs +3 -5
  61. package/dist/esm/lib/structures/api/CookieStore.mjs.map +1 -1
  62. package/dist/esm/lib/structures/http/Auth.mjs +6 -10
  63. package/dist/esm/lib/structures/http/Auth.mjs.map +1 -1
  64. package/dist/esm/lib/structures/http/HttpCodes.mjs +1 -1
  65. package/dist/esm/lib/structures/http/HttpMethods.mjs +1 -1
  66. package/dist/esm/lib/structures/http/Server.mjs +1 -1
  67. package/dist/esm/lib/utils/MimeTypes.mjs +1 -1
  68. package/dist/esm/lib/utils/RouteData.mjs +10 -18
  69. package/dist/esm/lib/utils/RouteData.mjs.map +1 -1
  70. package/dist/esm/listeners/PluginRouteError.mjs +2 -3
  71. package/dist/esm/listeners/PluginRouteError.mjs.map +1 -1
  72. package/dist/esm/listeners/PluginServerMatch.mjs +1 -1
  73. package/dist/esm/listeners/PluginServerMiddlewareError.mjs +2 -3
  74. package/dist/esm/listeners/PluginServerMiddlewareError.mjs.map +1 -1
  75. package/dist/esm/listeners/PluginServerMiddlewareSuccess.mjs +1 -1
  76. package/dist/esm/listeners/PluginServerNoMatch.mjs +2 -3
  77. package/dist/esm/listeners/PluginServerNoMatch.mjs.map +1 -1
  78. package/dist/esm/listeners/PluginServerRequest.mjs +1 -1
  79. package/dist/esm/listeners/_load.mjs +1 -1
  80. package/dist/esm/mediaParsers/_load.mjs +1 -1
  81. package/dist/esm/mediaParsers/applicationFormUrlEncoded.mjs +1 -1
  82. package/dist/esm/mediaParsers/applicationJson.mjs +1 -1
  83. package/dist/esm/mediaParsers/textPlain.mjs +1 -1
  84. package/dist/esm/middlewares/_load.mjs +1 -1
  85. package/dist/esm/middlewares/auth.mjs +2 -3
  86. package/dist/esm/middlewares/auth.mjs.map +1 -1
  87. package/dist/esm/middlewares/body.mjs +3 -5
  88. package/dist/esm/middlewares/body.mjs.map +1 -1
  89. package/dist/esm/middlewares/cookies.mjs +1 -1
  90. package/dist/esm/middlewares/headers.mjs +1 -1
  91. package/dist/esm/register.mjs +1 -1
  92. package/dist/esm/routes/_load.mjs +1 -1
  93. package/dist/esm/routes/oauth/callback.mjs +2 -3
  94. package/dist/esm/routes/oauth/callback.mjs.map +1 -1
  95. package/dist/esm/routes/oauth/logout.mjs +4 -7
  96. package/dist/esm/routes/oauth/logout.mjs.map +1 -1
  97. package/package.json +7 -7
  98. package/dist/esm/chunk-PYETHG4R.mjs +0 -29
  99. /package/dist/esm/{chunk-PYETHG4R.mjs.map → chunk-JTFKMR4I.mjs.map} +0 -0
@@ -13,10 +13,7 @@ var Auth_cjs = require('./Auth.cjs');
13
13
  var __defProp = Object.defineProperty;
14
14
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
15
15
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
16
- var __publicField = (obj, key, value) => {
17
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
18
- return value;
19
- };
16
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
20
17
  var ServerEvents = /* @__PURE__ */ ((ServerEvents2) => {
21
18
  ServerEvents2["Error"] = "error";
22
19
  ServerEvents2["Request"] = "request";
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/lib/structures/http/Server.ts"],"names":["ServerEvents","error"],"mappings":";;;;;;;;;AAAA,SAAS,iBAAiB;AAC1B,SAAS,oBAAoB;AAC7B,SAA+B,gBAAgB,wBAA2D;AAE1G,SAAS,wBAAwB;AACjC,SAAS,uBAAuB;AAChC,SAAS,kBAAmC;AAC5C,SAAS,kBAAkB;AAC3B,SAAS,mBAAmB;AAC5B,SAAS,YAAoC;AAEtC,IAAK,eAAL,kBAAKA,kBAAL;AACN,EAAAA,cAAA,WAAQ;AACR,EAAAA,cAAA,aAAU;AACV,EAAAA,cAAA,WAAQ;AACR,EAAAA,cAAA,aAAU;AACV,EAAAA,cAAA,gBAAa;AACb,EAAAA,cAAA,uBAAoB;AACpB,EAAAA,cAAA,qBAAkB;AAClB,EAAAA,cAAA,uBAAoB;AART,SAAAA;AAAA,GAAA;AAcL,IAAM,UAAN,MAAM,gBAAe,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,EAyCjC,YAAY,EAAE,MAAM,GAAG,QAAQ,IAAmB,CAAC,GAAG;AAC5D,UAAM;AArCP;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AASf,cAAU,SAAS;AAEnB,SAAK,UAAU;AACf,SAAK,SAAS,iBAAiB;AAAA,MAC9B,iBAAiB;AAAA,MACjB,gBAAgB;AAAA,MAChB,GAAI,QAAQ,UAAU,CAAC;AAAA,IACxB,CAAC;AACD,SAAK,SAAS,IAAI,WAAW;AAC7B,SAAK,cAAc,IAAI,gBAAgB;AACvC,SAAK,eAAe,IAAI,iBAAiB;AACzC,SAAK,OAAO,KAAK,OAAO,IAAI;AAC5B,SAAK,OAAO,GAAG,SAAS,KAAK,KAAK,KAAK,MAAM,mBAAkB,CAAC;AAChE,SAAK,OAAO,GAAG,WAAW,KAAK,KAAK,KAAK,MAAM,uBAAoB,CAAC;AAAA,EACrE;AAAA,EAEO,UAAU;AAChB,UAAM,EAAE,OAAO,IAAI;AACnB,WAAO,OAAO;AAAA,MACb,MAAM;AAAA,MACN,GAAI,KAAK,QAAQ,iBAAiB,CAAC;AAAA,IACpC,CAAC;AAED,WAAO,IAAI,QAAc,CAAC,SAAS,WAAW;AAC7C,eAAS,YAAY;AACpB,gBAAQ;AACR,gBAAQ;AAAA,MACT;AAHS;AAKT,eAAS,MAAMC,QAAc;AAC5B,gBAAQ;AACR,eAAOA,MAAK;AAAA,MACb;AAHS;AAKT,eAAS,QAAQ;AAChB,gBAAQ;AACR,eAAO,IAAI,MAAM,sBAAsB,CAAC;AAAA,MACzC;AAHS;AAKT,eAAS,UAAU;AAClB,eAAO,IAAI,aAAa,SAAS;AACjC,eAAO,IAAI,SAAS,KAAK;AACzB,eAAO,IAAI,SAAS,KAAK;AAAA,MAC1B;AAJS;AAMT,aAAO,GAAG,aAAa,SAAS;AAChC,aAAO,GAAG,SAAS,KAAK;AACxB,aAAO,GAAG,SAAS,KAAK;AAAA,IACzB,CAAC;AAAA,EACF;AAAA,EAEO,aAAa;AACnB,WAAO,IAAI,QAAc,CAAC,SAAS,WAAW;AAC7C,WAAK,OAAO,MAAM,CAAC,UAAW,QAAQ,QAAQ,IAAI,OAAO,KAAK,CAAE;AAAA,IACjE,CAAC;AAAA,EACF;AACD;AApGyC;AAAlC,IAAM,SAAN","sourcesContent":["import { container } from '@sapphire/pieces';\nimport { EventEmitter } from 'node:events';\nimport { Server as HttpServer, createServer as httpCreateServer, type ServerOptions as HttpOptions } from 'node:http';\nimport type { ListenOptions } from 'node:net';\nimport { MediaParserStore } from '../MediaParserStore';\nimport { MiddlewareStore } from '../MiddlewareStore';\nimport { RouteStore, type RouteMatch } from '../RouteStore';\nimport { ApiRequest } from '../api/ApiRequest';\nimport { ApiResponse } from '../api/ApiResponse';\nimport { Auth, type ServerOptionsAuth } from './Auth';\n\nexport enum ServerEvents {\n\tError = 'error',\n\tRequest = 'request',\n\tMatch = 'match',\n\tNoMatch = 'noMatch',\n\tRouteError = 'routeError',\n\tMiddlewareFailure = 'middlewareFailure',\n\tMiddlewareError = 'middlewareError',\n\tMiddlewareSuccess = 'middlewareSuccess'\n}\n\n/**\n * @since 1.0.0\n */\nexport class Server extends EventEmitter {\n\t/**\n\t * The routes this server holds.\n\t * @since 1.0.0\n\t */\n\tpublic readonly routes: RouteStore;\n\n\t/**\n\t * The middlewares this server holds.\n\t * @since 1.0.0\n\t */\n\tpublic readonly middlewares: MiddlewareStore;\n\n\t/**\n\t * The media parsers this server holds.\n\t * @since 1.3.0\n\t */\n\tpublic readonly mediaParsers: MediaParserStore;\n\n\t/**\n\t * The authentication system.\n\t * @since 1.0.0\n\t */\n\tpublic readonly auth: Auth | null;\n\n\t/**\n\t * The http.Server instance that manages the recieved HTTP requests.\n\t * @since 1.0.0\n\t */\n\tpublic readonly server: HttpServer;\n\n\t/**\n\t * The options for this server.\n\t * @since 1.0.0\n\t */\n\tpublic readonly options: AuthLessServerOptions;\n\n\t/**\n\t * @since 1.0.0\n\t * @param options The options for this server\n\t */\n\tpublic constructor({ auth, ...options }: ServerOptions = {}) {\n\t\tsuper();\n\n\t\tcontainer.server = this;\n\n\t\tthis.options = options;\n\t\tthis.server = httpCreateServer({\n\t\t\tIncomingMessage: ApiRequest,\n\t\t\tServerResponse: ApiResponse,\n\t\t\t...(options.server ?? {})\n\t\t});\n\t\tthis.routes = new RouteStore();\n\t\tthis.middlewares = new MiddlewareStore();\n\t\tthis.mediaParsers = new MediaParserStore();\n\t\tthis.auth = Auth.create(auth);\n\t\tthis.server.on('error', this.emit.bind(this, ServerEvents.Error));\n\t\tthis.server.on('request', this.emit.bind(this, ServerEvents.Request));\n\t}\n\n\tpublic connect() {\n\t\tconst { server } = this;\n\t\tserver.listen({\n\t\t\tport: 4000,\n\t\t\t...(this.options.listenOptions ?? {})\n\t\t});\n\n\t\treturn new Promise<void>((resolve, reject) => {\n\t\t\tfunction listening() {\n\t\t\t\tcleanup();\n\t\t\t\tresolve();\n\t\t\t}\n\n\t\t\tfunction error(error: Error) {\n\t\t\t\tcleanup();\n\t\t\t\treject(error);\n\t\t\t}\n\n\t\t\tfunction close() {\n\t\t\t\tcleanup();\n\t\t\t\treject(new Error('Closed unexpectedly.'));\n\t\t\t}\n\n\t\t\tfunction cleanup() {\n\t\t\t\tserver.off('listening', listening);\n\t\t\t\tserver.off('error', error);\n\t\t\t\tserver.off('close', close);\n\t\t\t}\n\n\t\t\tserver.on('listening', listening);\n\t\t\tserver.on('error', error);\n\t\t\tserver.on('close', close);\n\t\t});\n\t}\n\n\tpublic disconnect() {\n\t\treturn new Promise<void>((resolve, reject) => {\n\t\t\tthis.server.close((error) => (error ? resolve() : reject(error)));\n\t\t});\n\t}\n}\n\n/**\n * RFC 1341 4: Defines a Content-Type's type, which follows the following structure:\n *\n * - `type` = `text` | `multipart` | `message` | `image` | `audio` | `video` | `application` | x-token\n * - `x-token` = The two characters \"X-\" followed, with no intervening white space, by any token\n * @since 1.3.0\n */\nexport type ContentTypeType = 'text' | 'multipart' | 'message' | 'image' | 'audio' | 'video' | 'application' | `X-${string}`;\n\n/**\n * RFC 1341 4: Defines a Content-Type's parameter, which follows the following structure:\n *\n * - `parameter` = `attribute` \"=\" `value`\n * - `attribute` = `token`\n * - `value` = `token` / `quoted-string`\n * - `token` = `1*<any CHAR except \"SPACE\", \"CTLs\", or \"tspecials\">`\n * - `tspecials` = `(` | `)` | `<` | `>` | `@` | `,` | `;` | `:` | `\\` | `\"` | `/` | `[` | `]` | `?` | `.` | `=`\n *\n * @note `tspecials` must be in quoted-string, to use within parameter values.\n * @note The definition of `tspecials` is the same as the RFC 822 definition of `specials` with the addition of the\n * three characters `/`, `?`, and `=`.\n * @since 1.3.0\n */\nexport type ContentTypeParameter = `; ${string}=${string}`;\n\n/**\n * RFC 1341 4: Defines the syntax for a Content-Type field without parameters, which follows the following structure:\n * `type \"/\" subtype`.\n */\nexport type MimeTypeWithoutParameters = `${ContentTypeType}/${string}`;\n\n/**\n * RFC 1341 4: Defines the syntax for a Content-Type field, which follows the following structure:\n * `type \"/\" subtype *[\";\" parameter]`.\n * @since 1.3.0\n */\nexport type MimeType = `${MimeTypeWithoutParameters}${'' | ContentTypeParameter}`;\n\n/**\n * The API options.\n * @since 1.0.0\n */\nexport interface ServerOptions {\n\t/**\n\t * The prefix for all routes, e.g. `v1/`.\n\t * @since 1.0.0\n\t * @default ''\n\t */\n\tprefix?: string;\n\n\t/**\n\t * The origin header to be set on every request at 'Access-Control-Allow-Origin'.\n\t * @since 1.0.0\n\t * @default '*'\n\t */\n\torigin?: string;\n\n\t/**\n\t * (RFC 7230 3.3.2) The maximum decimal number of octets.\n\t * @since 1.0.0\n\t * @default 1024 * 1024 * 50\n\t */\n\tmaximumBodyLength?: number;\n\n\t/**\n\t * The accepted content types for this route. If set to null, the route will accept any data.\n\t * @since 1.3.0\n\t * @default null\n\t */\n\tacceptedContentMimeTypes?: MimeTypeWithoutParameters[] | null;\n\n\t/**\n\t * The HTTP server options.\n\t * @since 1.0.0\n\t * @default {}\n\t */\n\tserver?: HttpOptions;\n\n\t/**\n\t * The HTTP listen options.\n\t * @since 1.0.0\n\t * @default { port: 4000 }\n\t */\n\tlistenOptions?: ListenOptions;\n\n\t/**\n\t * The auth options. If neither `auth` nor `auth.secret` are defined, auth-related routes and middlewares will be\n\t * automatically disabled.\n\t * @since 1.0.0\n\t * @default {}\n\t */\n\tauth?: ServerOptionsAuth;\n\n\t/**\n\t * Whether the server should connect upon being when the plugin is loaded.\n\t * @since 3.2.0\n\t * @default true\n\t */\n\tautomaticallyConnect?: boolean;\n}\n\n/**\n * The {@link ServerOptions} without {@link ServerOptions.auth}.\n * @since 1.0.0\n */\nexport type AuthLessServerOptions = Omit<ServerOptions, 'auth'>;\n\n/**\n * The context sent in the error events.\n * @since 1.2.0\n */\nexport interface MiddlewareErrorContext {\n\t/**\n\t * The erroneous request.\n\t * @since 1.2.0\n\t */\n\trequest: ApiRequest;\n\n\t/**\n\t * The server's response.\n\t * @since 1.2.0\n\t */\n\tresponse: ApiResponse;\n\n\t/**\n\t * The route match.\n\t * @since 1.2.0\n\t */\n\tmatch: RouteMatch;\n}\n"]}
1
+ {"version":3,"sources":["../../../../../src/lib/structures/http/Server.ts"],"names":["ServerEvents","error"],"mappings":";;;;;;AAAA,SAAS,iBAAiB;AAC1B,SAAS,oBAAoB;AAC7B,SAA+B,gBAAgB,wBAA2D;AAE1G,SAAS,wBAAwB;AACjC,SAAS,uBAAuB;AAChC,SAAS,kBAAmC;AAC5C,SAAS,kBAAkB;AAC3B,SAAS,mBAAmB;AAC5B,SAAS,YAAoC;AAEtC,IAAK,eAAL,kBAAKA,kBAAL;AACN,EAAAA,cAAA,WAAQ;AACR,EAAAA,cAAA,aAAU;AACV,EAAAA,cAAA,WAAQ;AACR,EAAAA,cAAA,aAAU;AACV,EAAAA,cAAA,gBAAa;AACb,EAAAA,cAAA,uBAAoB;AACpB,EAAAA,cAAA,qBAAkB;AAClB,EAAAA,cAAA,uBAAoB;AART,SAAAA;AAAA,GAAA;AAcL,IAAM,UAAN,MAAM,gBAAe,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,EAyCjC,YAAY,EAAE,MAAM,GAAG,QAAQ,IAAmB,CAAC,GAAG;AAC5D,UAAM;AArCP;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AAMhB;AAAA;AAAA;AAAA;AAAA,wBAAgB;AASf,cAAU,SAAS;AAEnB,SAAK,UAAU;AACf,SAAK,SAAS,iBAAiB;AAAA,MAC9B,iBAAiB;AAAA,MACjB,gBAAgB;AAAA,MAChB,GAAI,QAAQ,UAAU,CAAC;AAAA,IACxB,CAAC;AACD,SAAK,SAAS,IAAI,WAAW;AAC7B,SAAK,cAAc,IAAI,gBAAgB;AACvC,SAAK,eAAe,IAAI,iBAAiB;AACzC,SAAK,OAAO,KAAK,OAAO,IAAI;AAC5B,SAAK,OAAO,GAAG,SAAS,KAAK,KAAK,KAAK,MAAM,mBAAkB,CAAC;AAChE,SAAK,OAAO,GAAG,WAAW,KAAK,KAAK,KAAK,MAAM,uBAAoB,CAAC;AAAA,EACrE;AAAA,EAEO,UAAU;AAChB,UAAM,EAAE,OAAO,IAAI;AACnB,WAAO,OAAO;AAAA,MACb,MAAM;AAAA,MACN,GAAI,KAAK,QAAQ,iBAAiB,CAAC;AAAA,IACpC,CAAC;AAED,WAAO,IAAI,QAAc,CAAC,SAAS,WAAW;AAC7C,eAAS,YAAY;AACpB,gBAAQ;AACR,gBAAQ;AAAA,MACT;AAHS;AAKT,eAAS,MAAMC,QAAc;AAC5B,gBAAQ;AACR,eAAOA,MAAK;AAAA,MACb;AAHS;AAKT,eAAS,QAAQ;AAChB,gBAAQ;AACR,eAAO,IAAI,MAAM,sBAAsB,CAAC;AAAA,MACzC;AAHS;AAKT,eAAS,UAAU;AAClB,eAAO,IAAI,aAAa,SAAS;AACjC,eAAO,IAAI,SAAS,KAAK;AACzB,eAAO,IAAI,SAAS,KAAK;AAAA,MAC1B;AAJS;AAMT,aAAO,GAAG,aAAa,SAAS;AAChC,aAAO,GAAG,SAAS,KAAK;AACxB,aAAO,GAAG,SAAS,KAAK;AAAA,IACzB,CAAC;AAAA,EACF;AAAA,EAEO,aAAa;AACnB,WAAO,IAAI,QAAc,CAAC,SAAS,WAAW;AAC7C,WAAK,OAAO,MAAM,CAAC,UAAW,QAAQ,QAAQ,IAAI,OAAO,KAAK,CAAE;AAAA,IACjE,CAAC;AAAA,EACF;AACD;AApGyC;AAAlC,IAAM,SAAN","sourcesContent":["import { container } from '@sapphire/pieces';\nimport { EventEmitter } from 'node:events';\nimport { Server as HttpServer, createServer as httpCreateServer, type ServerOptions as HttpOptions } from 'node:http';\nimport type { ListenOptions } from 'node:net';\nimport { MediaParserStore } from '../MediaParserStore';\nimport { MiddlewareStore } from '../MiddlewareStore';\nimport { RouteStore, type RouteMatch } from '../RouteStore';\nimport { ApiRequest } from '../api/ApiRequest';\nimport { ApiResponse } from '../api/ApiResponse';\nimport { Auth, type ServerOptionsAuth } from './Auth';\n\nexport enum ServerEvents {\n\tError = 'error',\n\tRequest = 'request',\n\tMatch = 'match',\n\tNoMatch = 'noMatch',\n\tRouteError = 'routeError',\n\tMiddlewareFailure = 'middlewareFailure',\n\tMiddlewareError = 'middlewareError',\n\tMiddlewareSuccess = 'middlewareSuccess'\n}\n\n/**\n * @since 1.0.0\n */\nexport class Server extends EventEmitter {\n\t/**\n\t * The routes this server holds.\n\t * @since 1.0.0\n\t */\n\tpublic readonly routes: RouteStore;\n\n\t/**\n\t * The middlewares this server holds.\n\t * @since 1.0.0\n\t */\n\tpublic readonly middlewares: MiddlewareStore;\n\n\t/**\n\t * The media parsers this server holds.\n\t * @since 1.3.0\n\t */\n\tpublic readonly mediaParsers: MediaParserStore;\n\n\t/**\n\t * The authentication system.\n\t * @since 1.0.0\n\t */\n\tpublic readonly auth: Auth | null;\n\n\t/**\n\t * The http.Server instance that manages the recieved HTTP requests.\n\t * @since 1.0.0\n\t */\n\tpublic readonly server: HttpServer;\n\n\t/**\n\t * The options for this server.\n\t * @since 1.0.0\n\t */\n\tpublic readonly options: AuthLessServerOptions;\n\n\t/**\n\t * @since 1.0.0\n\t * @param options The options for this server\n\t */\n\tpublic constructor({ auth, ...options }: ServerOptions = {}) {\n\t\tsuper();\n\n\t\tcontainer.server = this;\n\n\t\tthis.options = options;\n\t\tthis.server = httpCreateServer({\n\t\t\tIncomingMessage: ApiRequest,\n\t\t\tServerResponse: ApiResponse,\n\t\t\t...(options.server ?? {})\n\t\t});\n\t\tthis.routes = new RouteStore();\n\t\tthis.middlewares = new MiddlewareStore();\n\t\tthis.mediaParsers = new MediaParserStore();\n\t\tthis.auth = Auth.create(auth);\n\t\tthis.server.on('error', this.emit.bind(this, ServerEvents.Error));\n\t\tthis.server.on('request', this.emit.bind(this, ServerEvents.Request));\n\t}\n\n\tpublic connect() {\n\t\tconst { server } = this;\n\t\tserver.listen({\n\t\t\tport: 4000,\n\t\t\t...(this.options.listenOptions ?? {})\n\t\t});\n\n\t\treturn new Promise<void>((resolve, reject) => {\n\t\t\tfunction listening() {\n\t\t\t\tcleanup();\n\t\t\t\tresolve();\n\t\t\t}\n\n\t\t\tfunction error(error: Error) {\n\t\t\t\tcleanup();\n\t\t\t\treject(error);\n\t\t\t}\n\n\t\t\tfunction close() {\n\t\t\t\tcleanup();\n\t\t\t\treject(new Error('Closed unexpectedly.'));\n\t\t\t}\n\n\t\t\tfunction cleanup() {\n\t\t\t\tserver.off('listening', listening);\n\t\t\t\tserver.off('error', error);\n\t\t\t\tserver.off('close', close);\n\t\t\t}\n\n\t\t\tserver.on('listening', listening);\n\t\t\tserver.on('error', error);\n\t\t\tserver.on('close', close);\n\t\t});\n\t}\n\n\tpublic disconnect() {\n\t\treturn new Promise<void>((resolve, reject) => {\n\t\t\tthis.server.close((error) => (error ? resolve() : reject(error)));\n\t\t});\n\t}\n}\n\n/**\n * RFC 1341 4: Defines a Content-Type's type, which follows the following structure:\n *\n * - `type` = `text` | `multipart` | `message` | `image` | `audio` | `video` | `application` | x-token\n * - `x-token` = The two characters \"X-\" followed, with no intervening white space, by any token\n * @since 1.3.0\n */\nexport type ContentTypeType = 'text' | 'multipart' | 'message' | 'image' | 'audio' | 'video' | 'application' | `X-${string}`;\n\n/**\n * RFC 1341 4: Defines a Content-Type's parameter, which follows the following structure:\n *\n * - `parameter` = `attribute` \"=\" `value`\n * - `attribute` = `token`\n * - `value` = `token` / `quoted-string`\n * - `token` = `1*<any CHAR except \"SPACE\", \"CTLs\", or \"tspecials\">`\n * - `tspecials` = `(` | `)` | `<` | `>` | `@` | `,` | `;` | `:` | `\\` | `\"` | `/` | `[` | `]` | `?` | `.` | `=`\n *\n * @note `tspecials` must be in quoted-string, to use within parameter values.\n * @note The definition of `tspecials` is the same as the RFC 822 definition of `specials` with the addition of the\n * three characters `/`, `?`, and `=`.\n * @since 1.3.0\n */\nexport type ContentTypeParameter = `; ${string}=${string}`;\n\n/**\n * RFC 1341 4: Defines the syntax for a Content-Type field without parameters, which follows the following structure:\n * `type \"/\" subtype`.\n */\nexport type MimeTypeWithoutParameters = `${ContentTypeType}/${string}`;\n\n/**\n * RFC 1341 4: Defines the syntax for a Content-Type field, which follows the following structure:\n * `type \"/\" subtype *[\";\" parameter]`.\n * @since 1.3.0\n */\nexport type MimeType = `${MimeTypeWithoutParameters}${'' | ContentTypeParameter}`;\n\n/**\n * The API options.\n * @since 1.0.0\n */\nexport interface ServerOptions {\n\t/**\n\t * The prefix for all routes, e.g. `v1/`.\n\t * @since 1.0.0\n\t * @default ''\n\t */\n\tprefix?: string;\n\n\t/**\n\t * The origin header to be set on every request at 'Access-Control-Allow-Origin'.\n\t * @since 1.0.0\n\t * @default '*'\n\t */\n\torigin?: string;\n\n\t/**\n\t * (RFC 7230 3.3.2) The maximum decimal number of octets.\n\t * @since 1.0.0\n\t * @default 1024 * 1024 * 50\n\t */\n\tmaximumBodyLength?: number;\n\n\t/**\n\t * The accepted content types for this route. If set to null, the route will accept any data.\n\t * @since 1.3.0\n\t * @default null\n\t */\n\tacceptedContentMimeTypes?: MimeTypeWithoutParameters[] | null;\n\n\t/**\n\t * The HTTP server options.\n\t * @since 1.0.0\n\t * @default {}\n\t */\n\tserver?: HttpOptions;\n\n\t/**\n\t * The HTTP listen options.\n\t * @since 1.0.0\n\t * @default { port: 4000 }\n\t */\n\tlistenOptions?: ListenOptions;\n\n\t/**\n\t * The auth options. If neither `auth` nor `auth.secret` are defined, auth-related routes and middlewares will be\n\t * automatically disabled.\n\t * @since 1.0.0\n\t * @default {}\n\t */\n\tauth?: ServerOptionsAuth;\n\n\t/**\n\t * Whether the server should connect upon being when the plugin is loaded.\n\t * @since 3.2.0\n\t * @default true\n\t */\n\tautomaticallyConnect?: boolean;\n}\n\n/**\n * The {@link ServerOptions} without {@link ServerOptions.auth}.\n * @since 1.0.0\n */\nexport type AuthLessServerOptions = Omit<ServerOptions, 'auth'>;\n\n/**\n * The context sent in the error events.\n * @since 1.2.0\n */\nexport interface MiddlewareErrorContext {\n\t/**\n\t * The erroneous request.\n\t * @since 1.2.0\n\t */\n\trequest: ApiRequest;\n\n\t/**\n\t * The server's response.\n\t * @since 1.2.0\n\t */\n\tresponse: ApiResponse;\n\n\t/**\n\t * The route match.\n\t * @since 1.2.0\n\t */\n\tmatch: RouteMatch;\n}\n"]}
@@ -3,13 +3,9 @@
3
3
  var __defProp = Object.defineProperty;
4
4
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
5
5
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
- var __publicField = (obj, key, value) => {
7
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
8
- return value;
9
- };
6
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
10
7
 
11
8
  // src/lib/utils/RouteData.ts
12
- var [slash, colon] = [47, 58];
13
9
  var TypeState = /* @__PURE__ */ ((TypeState2) => {
14
10
  TypeState2[TypeState2["Static"] = 0] = "Static";
15
11
  TypeState2[TypeState2["Dynamic"] = 1] = "Dynamic";
@@ -21,21 +17,18 @@ var _RouteData = class _RouteData {
21
17
  __publicField(this, "static");
22
18
  __publicField(this, "parts");
23
19
  this.path = path;
24
- this.parts = _RouteData.split(path).map(_RouteData.parsePart.bind(null));
20
+ this.parts = _RouteData.split(path).map((value) => _RouteData.parsePart(value));
25
21
  this.static = this.parts.every((part) => part.type === 0 /* Static */);
26
22
  }
27
23
  match(split) {
28
- if (split.length !== this.parts.length)
29
- return null;
30
- if (this.static)
31
- return this.parts.every((part, index) => part.value === split[index]) ? {} : null;
24
+ if (split.length !== this.parts.length) return null;
25
+ if (this.static) return this.parts.every((part, index) => part.value === split[index]) ? {} : null;
32
26
  const parameters = [];
33
27
  for (let i = 0; i < this.parts.length; ++i) {
34
28
  const part = this.parts[i];
35
29
  const value = split[i];
36
30
  if (part.type === 0 /* Static */) {
37
- if (part.value === value)
38
- continue;
31
+ if (part.value === value) continue;
39
32
  return null;
40
33
  }
41
34
  parameters.push([part.value, value]);
@@ -46,21 +39,17 @@ var _RouteData = class _RouteData {
46
39
  * @since 1.0.0
47
40
  */
48
41
  static parsePart(value) {
49
- const type = value.charCodeAt(0) === colon ? 1 /* Dynamic */ : 0 /* Static */;
50
- if (type === 1 /* Dynamic */)
51
- value = value.substring(1);
42
+ const type = value.length > 2 && value.at(0) === "[" && value.at(-1) === "]" ? 1 /* Dynamic */ : 0 /* Static */;
43
+ if (type === 1 /* Dynamic */) value = value.slice(1, -1);
52
44
  return { value, type };
53
45
  }
54
46
  /**
55
47
  * @since 1.0.0
56
48
  */
57
49
  static split(url) {
58
- if (url.length === 1 && url.charCodeAt(0) === slash)
59
- return [""];
60
- if (url.charCodeAt(0) === slash)
61
- url = url.substring(1);
62
- if (url.length > 0 && url.charCodeAt(url.length - 1) === slash)
63
- url = url.substring(0, url.length - 1);
50
+ if (url.length === 1 && url.at(0) === "/") return [""];
51
+ if (url.at(0) === "/") url = url.slice(1);
52
+ if (url.length > 0 && url.at(-1) === "/") url = url.slice(0, -1);
64
53
  return url.split("/");
65
54
  }
66
55
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/utils/RouteData.ts"],"names":["TypeState"],"mappings":";;;;;;;;;AAAA,IAAM,CAAC,OAAO,KAAK,IAAsB,CAAC,IAAI,EAAE;AAKzC,IAAK,YAAL,kBAAKA,eAAL;AAIN,EAAAA,sBAAA;AAKA,EAAAA,sBAAA;AATW,SAAAA;AAAA,GAAA;AAcL,IAAM,aAAN,MAAM,WAAU;AAAA,EAKf,YAAY,MAAc;AAJjC,wBAAgB;AAChB,wBAAiB;AACjB,wBAAiB;AAGhB,SAAK,OAAO;AACZ,SAAK,QAAQ,WAAU,MAAM,IAAI,EAAE,IAAI,WAAU,UAAU,KAAK,IAAI,CAAC;AACrE,SAAK,SAAS,KAAK,MAAM,MAAM,CAAC,SAAS,KAAK,SAAS,cAAgB;AAAA,EACxE;AAAA,EAEO,MAAM,OAAqC;AACjD,QAAI,MAAM,WAAW,KAAK,MAAM;AAAQ,aAAO;AAC/C,QAAI,KAAK;AAAQ,aAAO,KAAK,MAAM,MAAM,CAAC,MAAM,UAAU,KAAK,UAAU,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI;AAE9F,UAAM,aAAiC,CAAC;AACxC,aAAS,IAAI,GAAG,IAAI,KAAK,MAAM,QAAQ,EAAE,GAAG;AAC3C,YAAM,OAAO,KAAK,MAAM,CAAC;AACzB,YAAM,QAAQ,MAAM,CAAC;AAErB,UAAI,KAAK,SAAS,gBAAkB;AACnC,YAAI,KAAK,UAAU;AAAO;AAC1B,eAAO;AAAA,MACR;AAEA,iBAAW,KAAK,CAAC,KAAK,OAAO,KAAK,CAAC;AAAA,IACpC;AAEA,WAAO,OAAO,YAAY,UAAU;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA,EAKA,OAAe,UAAU,OAA2B;AACnD,UAAM,OAAO,MAAM,WAAW,CAAC,MAAM,QAAQ,kBAAoB;AACjE,QAAI,SAAS;AAAmB,cAAQ,MAAM,UAAU,CAAC;AACzD,WAAO,EAAE,OAAO,KAAK;AAAA,EACtB;AAAA;AAAA;AAAA;AAAA,EAKA,OAAe,MAAM,KAAuB;AAC3C,QAAI,IAAI,WAAW,KAAK,IAAI,WAAW,CAAC,MAAM;AAAO,aAAO,CAAC,EAAE;AAC/D,QAAI,IAAI,WAAW,CAAC,MAAM;AAAO,YAAM,IAAI,UAAU,CAAC;AACtD,QAAI,IAAI,SAAS,KAAK,IAAI,WAAW,IAAI,SAAS,CAAC,MAAM;AAAO,YAAM,IAAI,UAAU,GAAG,IAAI,SAAS,CAAC;AACrG,WAAO,IAAI,MAAM,GAAG;AAAA,EACrB;AACD;AAjDuB;AAAhB,IAAM,YAAN","sourcesContent":["const [slash, colon]: [number, number] = [47, 58];\n\n/**\n * @since 1.0.0\n */\nexport enum TypeState {\n\t/**\n\t * @since 1.0.0\n\t */\n\tStatic,\n\n\t/**\n\t * @since 1.0.0\n\t */\n\tDynamic\n}\n\nexport type MatchData = Record<string, string> | null;\n\nexport class RouteData {\n\tpublic readonly path: string;\n\tprivate readonly static: boolean;\n\tprivate readonly parts: readonly ParsedPart[];\n\n\tpublic constructor(path: string) {\n\t\tthis.path = path;\n\t\tthis.parts = RouteData.split(path).map(RouteData.parsePart.bind(null));\n\t\tthis.static = this.parts.every((part) => part.type === TypeState.Static);\n\t}\n\n\tpublic match(split: readonly string[]): MatchData {\n\t\tif (split.length !== this.parts.length) return null;\n\t\tif (this.static) return this.parts.every((part, index) => part.value === split[index]) ? {} : null;\n\n\t\tconst parameters: [string, string][] = [];\n\t\tfor (let i = 0; i < this.parts.length; ++i) {\n\t\t\tconst part = this.parts[i];\n\t\t\tconst value = split[i];\n\n\t\t\tif (part.type === TypeState.Static) {\n\t\t\t\tif (part.value === value) continue;\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\tparameters.push([part.value, value]);\n\t\t}\n\n\t\treturn Object.fromEntries(parameters);\n\t}\n\n\t/**\n\t * @since 1.0.0\n\t */\n\tprivate static parsePart(value: string): ParsedPart {\n\t\tconst type = value.charCodeAt(0) === colon ? TypeState.Dynamic : TypeState.Static;\n\t\tif (type === TypeState.Dynamic) value = value.substring(1);\n\t\treturn { value, type };\n\t}\n\n\t/**\n\t * @since 1.0.0\n\t */\n\tprivate static split(url: string): string[] {\n\t\tif (url.length === 1 && url.charCodeAt(0) === slash) return [''];\n\t\tif (url.charCodeAt(0) === slash) url = url.substring(1);\n\t\tif (url.length > 0 && url.charCodeAt(url.length - 1) === slash) url = url.substring(0, url.length - 1);\n\t\treturn url.split('/');\n\t}\n}\n\nexport interface ParsedPart {\n\tvalue: string;\n\ttype: TypeState;\n}\n"]}
1
+ {"version":3,"sources":["../../../../src/lib/utils/RouteData.ts"],"names":["TypeState"],"mappings":";;;;;;AAGO,IAAK,YAAL,kBAAKA,eAAL;AAIN,EAAAA,sBAAA;AAKA,EAAAA,sBAAA;AATW,SAAAA;AAAA,GAAA;AAcL,IAAM,aAAN,MAAM,WAAU;AAAA,EAKf,YAAY,MAAc;AAJjC,wBAAgB;AAChB,wBAAiB;AACjB,wBAAiB;AAGhB,SAAK,OAAO;AACZ,SAAK,QAAQ,WAAU,MAAM,IAAI,EAAE,IAAI,CAAC,UAAU,WAAU,UAAU,KAAK,CAAC;AAC5E,SAAK,SAAS,KAAK,MAAM,MAAM,CAAC,SAAS,KAAK,SAAS,cAAgB;AAAA,EACxE;AAAA,EAEO,MAAM,OAAqC;AACjD,QAAI,MAAM,WAAW,KAAK,MAAM,OAAQ,QAAO;AAC/C,QAAI,KAAK,OAAQ,QAAO,KAAK,MAAM,MAAM,CAAC,MAAM,UAAU,KAAK,UAAU,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI;AAE9F,UAAM,aAAiC,CAAC;AACxC,aAAS,IAAI,GAAG,IAAI,KAAK,MAAM,QAAQ,EAAE,GAAG;AAC3C,YAAM,OAAO,KAAK,MAAM,CAAC;AACzB,YAAM,QAAQ,MAAM,CAAC;AAErB,UAAI,KAAK,SAAS,gBAAkB;AACnC,YAAI,KAAK,UAAU,MAAO;AAC1B,eAAO;AAAA,MACR;AAEA,iBAAW,KAAK,CAAC,KAAK,OAAO,KAAK,CAAC;AAAA,IACpC;AAEA,WAAO,OAAO,YAAY,UAAU;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA,EAKA,OAAe,UAAU,OAA2B;AACnD,UAAM,OAAO,MAAM,SAAS,KAAK,MAAM,GAAG,CAAC,MAAM,OAAO,MAAM,GAAG,EAAE,MAAM,MAAM,kBAAoB;AACnG,QAAI,SAAS,gBAAmB,SAAQ,MAAM,MAAM,GAAG,EAAE;AACzD,WAAO,EAAE,OAAO,KAAK;AAAA,EACtB;AAAA;AAAA;AAAA;AAAA,EAKA,OAAe,MAAM,KAAuB;AAC3C,QAAI,IAAI,WAAW,KAAK,IAAI,GAAG,CAAC,MAAM,IAAK,QAAO,CAAC,EAAE;AACrD,QAAI,IAAI,GAAG,CAAC,MAAM,IAAK,OAAM,IAAI,MAAM,CAAC;AACxC,QAAI,IAAI,SAAS,KAAK,IAAI,GAAG,EAAE,MAAM,IAAK,OAAM,IAAI,MAAM,GAAG,EAAE;AAC/D,WAAO,IAAI,MAAM,GAAG;AAAA,EACrB;AACD;AAjDuB;AAAhB,IAAM,YAAN","sourcesContent":["/**\n * @since 1.0.0\n */\nexport enum TypeState {\n\t/**\n\t * @since 1.0.0\n\t */\n\tStatic,\n\n\t/**\n\t * @since 1.0.0\n\t */\n\tDynamic\n}\n\nexport type MatchData = Record<string, string> | null;\n\nexport class RouteData {\n\tpublic readonly path: string;\n\tprivate readonly static: boolean;\n\tprivate readonly parts: readonly ParsedPart[];\n\n\tpublic constructor(path: string) {\n\t\tthis.path = path;\n\t\tthis.parts = RouteData.split(path).map((value) => RouteData.parsePart(value));\n\t\tthis.static = this.parts.every((part) => part.type === TypeState.Static);\n\t}\n\n\tpublic match(split: readonly string[]): MatchData {\n\t\tif (split.length !== this.parts.length) return null;\n\t\tif (this.static) return this.parts.every((part, index) => part.value === split[index]) ? {} : null;\n\n\t\tconst parameters: [string, string][] = [];\n\t\tfor (let i = 0; i < this.parts.length; ++i) {\n\t\t\tconst part = this.parts[i];\n\t\t\tconst value = split[i];\n\n\t\t\tif (part.type === TypeState.Static) {\n\t\t\t\tif (part.value === value) continue;\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\tparameters.push([part.value, value]);\n\t\t}\n\n\t\treturn Object.fromEntries(parameters);\n\t}\n\n\t/**\n\t * @since 1.0.0\n\t */\n\tprivate static parsePart(value: string): ParsedPart {\n\t\tconst type = value.length > 2 && value.at(0) === '[' && value.at(-1) === ']' ? TypeState.Dynamic : TypeState.Static;\n\t\tif (type === TypeState.Dynamic) value = value.slice(1, -1);\n\t\treturn { value, type };\n\t}\n\n\t/**\n\t * @since 1.0.0\n\t */\n\tprivate static split(url: string): string[] {\n\t\tif (url.length === 1 && url.at(0) === '/') return [''];\n\t\tif (url.at(0) === '/') url = url.slice(1);\n\t\tif (url.length > 0 && url.at(-1) === '/') url = url.slice(0, -1);\n\t\treturn url.split('/');\n\t}\n}\n\nexport interface ParsedPart {\n\tvalue: string;\n\ttype: TypeState;\n}\n"]}
@@ -12,8 +12,7 @@ var _PluginListener = class _PluginListener extends framework.Listener {
12
12
  }
13
13
  run(error, { response }) {
14
14
  this.container.logger.fatal(error);
15
- if (!response.writableEnded)
16
- response.status(HttpCodes_cjs.HttpCodes.InternalServerError).json({ error: error.message ?? error });
15
+ if (!response.writableEnded) response.status(HttpCodes_cjs.HttpCodes.InternalServerError).json({ error: error.message ?? error });
17
16
  }
18
17
  };
19
18
  __name(_PluginListener, "PluginListener");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/listeners/PluginRouteError.ts"],"names":[],"mappings":";;;;AAAA,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAC1B,SAAS,oBAAiD;AAEnD,IAAM,kBAAN,MAAM,wBAAuB,SAAS;AAAA,EACrC,YAAY,SAAiC;AACnD,UAAM,SAAS,EAAE,SAAS,UAAU,OAAO,aAAa,WAAW,CAAC;AAAA,EACrE;AAAA,EAEgB,IAAI,OAAc,EAAE,SAAS,GAA2B;AAEvE,SAAK,UAAU,OAAO,MAAM,KAAK;AAGjC,QAAI,CAAC,SAAS;AAAe,eAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,MAAM,WAAW,MAAM,CAAC;AAAA,EACnH;AACD;AAZ6C;AAAtC,IAAM,iBAAN","sourcesContent":["import { Listener } from '@sapphire/framework';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\nimport { ServerEvents, type MiddlewareErrorContext } from '../lib/structures/http/Server';\n\nexport class PluginListener extends Listener {\n\tpublic constructor(context: Listener.LoaderContext) {\n\t\tsuper(context, { emitter: 'server', event: ServerEvents.RouteError });\n\t}\n\n\tpublic override run(error: Error, { response }: MiddlewareErrorContext) {\n\t\t// Log the error to console:\n\t\tthis.container.logger.fatal(error);\n\n\t\t// Send a response to the client if none was sent:\n\t\tif (!response.writableEnded) response.status(HttpCodes.InternalServerError).json({ error: error.message ?? error });\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/listeners/PluginRouteError.ts"],"names":[],"mappings":";;;;AAAA,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAC1B,SAAS,oBAAiD;AAEnD,IAAM,kBAAN,MAAM,wBAAuB,SAAS;AAAA,EACrC,YAAY,SAAiC;AACnD,UAAM,SAAS,EAAE,SAAS,UAAU,OAAO,aAAa,WAAW,CAAC;AAAA,EACrE;AAAA,EAEgB,IAAI,OAAc,EAAE,SAAS,GAA2B;AAEvE,SAAK,UAAU,OAAO,MAAM,KAAK;AAGjC,QAAI,CAAC,SAAS,cAAe,UAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,MAAM,WAAW,MAAM,CAAC;AAAA,EACnH;AACD;AAZ6C;AAAtC,IAAM,iBAAN","sourcesContent":["import { Listener } from '@sapphire/framework';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\nimport { ServerEvents, type MiddlewareErrorContext } from '../lib/structures/http/Server';\n\nexport class PluginListener extends Listener {\n\tpublic constructor(context: Listener.LoaderContext) {\n\t\tsuper(context, { emitter: 'server', event: ServerEvents.RouteError });\n\t}\n\n\tpublic override run(error: Error, { response }: MiddlewareErrorContext) {\n\t\t// Log the error to console:\n\t\tthis.container.logger.fatal(error);\n\n\t\t// Send a response to the client if none was sent:\n\t\tif (!response.writableEnded) response.status(HttpCodes.InternalServerError).json({ error: error.message ?? error });\n\t}\n}\n"]}
@@ -12,8 +12,7 @@ var _PluginListener = class _PluginListener extends framework.Listener {
12
12
  }
13
13
  run(error, { response }) {
14
14
  this.container.logger.fatal(error);
15
- if (!response.writableEnded)
16
- response.status(HttpCodes_cjs.HttpCodes.InternalServerError).json({ error: error.message ?? error });
15
+ if (!response.writableEnded) response.status(HttpCodes_cjs.HttpCodes.InternalServerError).json({ error: error.message ?? error });
17
16
  }
18
17
  };
19
18
  __name(_PluginListener, "PluginListener");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/listeners/PluginServerMiddlewareError.ts"],"names":[],"mappings":";;;;AAAA,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAC1B,SAAS,oBAAiD;AAEnD,IAAM,kBAAN,MAAM,wBAAuB,SAAS;AAAA,EACrC,YAAY,SAAiC;AACnD,UAAM,SAAS,EAAE,SAAS,UAAU,OAAO,aAAa,gBAAgB,CAAC;AAAA,EAC1E;AAAA,EAEgB,IAAI,OAAc,EAAE,SAAS,GAA2B;AAEvE,SAAK,UAAU,OAAO,MAAM,KAAK;AAGjC,QAAI,CAAC,SAAS;AAAe,eAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,MAAM,WAAW,MAAM,CAAC;AAAA,EACnH;AACD;AAZ6C;AAAtC,IAAM,iBAAN","sourcesContent":["import { Listener } from '@sapphire/framework';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\nimport { ServerEvents, type MiddlewareErrorContext } from '../lib/structures/http/Server';\n\nexport class PluginListener extends Listener {\n\tpublic constructor(context: Listener.LoaderContext) {\n\t\tsuper(context, { emitter: 'server', event: ServerEvents.MiddlewareError });\n\t}\n\n\tpublic override run(error: Error, { response }: MiddlewareErrorContext) {\n\t\t// Log the error to console:\n\t\tthis.container.logger.fatal(error);\n\n\t\t// Send a response to the client if none was sent:\n\t\tif (!response.writableEnded) response.status(HttpCodes.InternalServerError).json({ error: error.message ?? error });\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/listeners/PluginServerMiddlewareError.ts"],"names":[],"mappings":";;;;AAAA,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAC1B,SAAS,oBAAiD;AAEnD,IAAM,kBAAN,MAAM,wBAAuB,SAAS;AAAA,EACrC,YAAY,SAAiC;AACnD,UAAM,SAAS,EAAE,SAAS,UAAU,OAAO,aAAa,gBAAgB,CAAC;AAAA,EAC1E;AAAA,EAEgB,IAAI,OAAc,EAAE,SAAS,GAA2B;AAEvE,SAAK,UAAU,OAAO,MAAM,KAAK;AAGjC,QAAI,CAAC,SAAS,cAAe,UAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,MAAM,WAAW,MAAM,CAAC;AAAA,EACnH;AACD;AAZ6C;AAAtC,IAAM,iBAAN","sourcesContent":["import { Listener } from '@sapphire/framework';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\nimport { ServerEvents, type MiddlewareErrorContext } from '../lib/structures/http/Server';\n\nexport class PluginListener extends Listener {\n\tpublic constructor(context: Listener.LoaderContext) {\n\t\tsuper(context, { emitter: 'server', event: ServerEvents.MiddlewareError });\n\t}\n\n\tpublic override run(error: Error, { response }: MiddlewareErrorContext) {\n\t\t// Log the error to console:\n\t\tthis.container.logger.fatal(error);\n\n\t\t// Send a response to the client if none was sent:\n\t\tif (!response.writableEnded) response.status(HttpCodes.InternalServerError).json({ error: error.message ?? error });\n\t}\n}\n"]}
@@ -10,8 +10,7 @@ var _PluginListener = class _PluginListener extends framework.Listener {
10
10
  super(context, { emitter: "server", event: Server_cjs.ServerEvents.NoMatch });
11
11
  }
12
12
  run(_, response) {
13
- if (!response.writableEnded)
14
- response.notFound();
13
+ if (!response.writableEnded) response.notFound();
15
14
  }
16
15
  };
17
16
  __name(_PluginListener, "PluginListener");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/listeners/PluginServerNoMatch.ts"],"names":[],"mappings":";;;;AAAA,SAAS,gBAAgB;AAGzB,SAAS,oBAAoB;AAEtB,IAAM,kBAAN,MAAM,wBAAuB,SAAS;AAAA,EACrC,YAAY,SAAiC;AACnD,UAAM,SAAS,EAAE,SAAS,UAAU,OAAO,aAAa,QAAQ,CAAC;AAAA,EAClE;AAAA,EAEgB,IAAI,GAAe,UAAuB;AACzD,QAAI,CAAC,SAAS;AAAe,eAAS,SAAS;AAAA,EAChD;AACD;AAR6C;AAAtC,IAAM,iBAAN","sourcesContent":["import { Listener } from '@sapphire/framework';\nimport type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { ServerEvents } from '../lib/structures/http/Server';\n\nexport class PluginListener extends Listener {\n\tpublic constructor(context: Listener.LoaderContext) {\n\t\tsuper(context, { emitter: 'server', event: ServerEvents.NoMatch });\n\t}\n\n\tpublic override run(_: ApiRequest, response: ApiResponse) {\n\t\tif (!response.writableEnded) response.notFound();\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/listeners/PluginServerNoMatch.ts"],"names":[],"mappings":";;;;AAAA,SAAS,gBAAgB;AAGzB,SAAS,oBAAoB;AAEtB,IAAM,kBAAN,MAAM,wBAAuB,SAAS;AAAA,EACrC,YAAY,SAAiC;AACnD,UAAM,SAAS,EAAE,SAAS,UAAU,OAAO,aAAa,QAAQ,CAAC;AAAA,EAClE;AAAA,EAEgB,IAAI,GAAe,UAAuB;AACzD,QAAI,CAAC,SAAS,cAAe,UAAS,SAAS;AAAA,EAChD;AACD;AAR6C;AAAtC,IAAM,iBAAN","sourcesContent":["import { Listener } from '@sapphire/framework';\nimport type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { ServerEvents } from '../lib/structures/http/Server';\n\nexport class PluginListener extends Listener {\n\tpublic constructor(context: Listener.LoaderContext) {\n\t\tsuper(context, { emitter: 'server', event: ServerEvents.NoMatch });\n\t}\n\n\tpublic override run(_: ApiRequest, response: ApiResponse) {\n\t\tif (!response.writableEnded) response.notFound();\n\t}\n}\n"]}
@@ -5,10 +5,7 @@ var Middleware_cjs = require('../lib/structures/Middleware.cjs');
5
5
  var __defProp = Object.defineProperty;
6
6
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
7
7
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
8
- var __publicField = (obj, key, value) => {
9
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
10
- return value;
11
- };
8
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
12
9
  var _PluginMiddleware = class _PluginMiddleware extends Middleware_cjs.Middleware {
13
10
  constructor(context) {
14
11
  super(context, { position: 40 });
@@ -24,8 +21,7 @@ var _PluginMiddleware = class _PluginMiddleware extends Middleware_cjs.Middlewar
24
21
  return;
25
22
  }
26
23
  request.auth = this.container.server.auth.decrypt(authorization);
27
- if (request.auth === null)
28
- response.cookies.remove(this.cookieName);
24
+ if (request.auth === null) response.cookies.remove(this.cookieName);
29
25
  }
30
26
  };
31
27
  __name(_PluginMiddleware, "PluginMiddleware");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/middlewares/auth.ts"],"names":[],"mappings":";;;;;;;;;AAEA,SAAS,kBAAkB;AAEpB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAGzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAHhC,wBAAiB;AAKhB,UAAM,EAAE,OAAO,IAAI,KAAK;AACxB,SAAK,aAAa,OAAO,MAAM,UAAU;AACzC,SAAK,UAAU,OAAO,SAAS;AAAA,EAChC;AAAA,EAEgB,IAAI,SAAqB,UAAuB;AAE/D,UAAM,gBAAgB,SAAS,QAAQ,IAAI,KAAK,UAAU;AAC1D,QAAI,CAAC,eAAe;AACnB,cAAQ,OAAO;AACf;AAAA,IACD;AAGA,YAAQ,OAAO,KAAK,UAAU,OAAO,KAAM,QAAQ,aAAa;AAChE,QAAI,QAAQ,SAAS;AAAM,eAAS,QAAQ,OAAO,KAAK,UAAU;AAAA,EACnE;AACD;AAvBiD;AAA1C,IAAM,mBAAN","sourcesContent":["import type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { Middleware } from '../lib/structures/Middleware';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly cookieName: string;\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 40 });\n\n\t\tconst { server } = this.container;\n\t\tthis.cookieName = server.auth?.cookie ?? 'SAPPHIRE_AUTH';\n\t\tthis.enabled = server.auth !== null;\n\t}\n\n\tpublic override run(request: ApiRequest, response: ApiResponse) {\n\t\t// If there are no cookies, set auth as null:\n\t\tconst authorization = response.cookies.get(this.cookieName);\n\t\tif (!authorization) {\n\t\t\trequest.auth = null;\n\t\t\treturn;\n\t\t}\n\n\t\t// Decrypt the cookie, and if the token is invalid, remove the cookie:\n\t\trequest.auth = this.container.server.auth!.decrypt(authorization);\n\t\tif (request.auth === null) response.cookies.remove(this.cookieName);\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/middlewares/auth.ts"],"names":[],"mappings":";;;;;;AAEA,SAAS,kBAAkB;AAEpB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAGzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAHhC,wBAAiB;AAKhB,UAAM,EAAE,OAAO,IAAI,KAAK;AACxB,SAAK,aAAa,OAAO,MAAM,UAAU;AACzC,SAAK,UAAU,OAAO,SAAS;AAAA,EAChC;AAAA,EAEgB,IAAI,SAAqB,UAAuB;AAE/D,UAAM,gBAAgB,SAAS,QAAQ,IAAI,KAAK,UAAU;AAC1D,QAAI,CAAC,eAAe;AACnB,cAAQ,OAAO;AACf;AAAA,IACD;AAGA,YAAQ,OAAO,KAAK,UAAU,OAAO,KAAM,QAAQ,aAAa;AAChE,QAAI,QAAQ,SAAS,KAAM,UAAS,QAAQ,OAAO,KAAK,UAAU;AAAA,EACnE;AACD;AAvBiD;AAA1C,IAAM,mBAAN","sourcesContent":["import type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { Middleware } from '../lib/structures/Middleware';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly cookieName: string;\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 40 });\n\n\t\tconst { server } = this.container;\n\t\tthis.cookieName = server.auth?.cookie ?? 'SAPPHIRE_AUTH';\n\t\tthis.enabled = server.auth !== null;\n\t}\n\n\tpublic override run(request: ApiRequest, response: ApiResponse) {\n\t\t// If there are no cookies, set auth as null:\n\t\tconst authorization = response.cookies.get(this.cookieName);\n\t\tif (!authorization) {\n\t\t\trequest.auth = null;\n\t\t\treturn;\n\t\t}\n\n\t\t// Decrypt the cookie, and if the token is invalid, remove the cookie:\n\t\trequest.auth = this.container.server.auth!.decrypt(authorization);\n\t\tif (request.auth === null) response.cookies.remove(this.cookieName);\n\t}\n}\n"]}
@@ -6,10 +6,7 @@ var Middleware_cjs = require('../lib/structures/Middleware.cjs');
6
6
  var __defProp = Object.defineProperty;
7
7
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
8
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
9
- var __publicField = (obj, key, value) => {
10
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
11
- return value;
12
- };
9
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
13
10
  var _PluginMiddleware = class _PluginMiddleware extends Middleware_cjs.Middleware {
14
11
  constructor(context) {
15
12
  super(context, { position: 20 });
@@ -18,11 +15,9 @@ var _PluginMiddleware = class _PluginMiddleware extends Middleware_cjs.Middlewar
18
15
  }
19
16
  async run(request, response, route) {
20
17
  const contentType = request.headers["content-type"];
21
- if (typeof contentType !== "string")
22
- return;
18
+ if (typeof contentType !== "string") return;
23
19
  const lengthString = request.headers["content-length"];
24
- if (typeof lengthString !== "string")
25
- return;
20
+ if (typeof lengthString !== "string") return;
26
21
  const length = Number(lengthString);
27
22
  const maximumLength = route.maximumBodyLength;
28
23
  if (length > maximumLength) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/middlewares/body.ts"],"names":[],"mappings":";;;;;;;;;AAEA,SAAS,iBAAiB;AAE1B,SAAS,kBAAkB;AAGpB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAGzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAHhC,wBAAiB;AAIhB,SAAK,eAAe,KAAK,UAAU,OAAO;AAAA,EAC3C;AAAA,EAEA,MAAsB,IAAI,SAAqB,UAAuB,OAAc;AAEnF,UAAM,cAAc,QAAQ,QAAQ,cAAc;AAClD,QAAI,OAAO,gBAAgB;AAAU;AAGrC,UAAM,eAAe,QAAQ,QAAQ,gBAAgB;AACrD,QAAI,OAAO,iBAAiB;AAAU;AAGtC,UAAM,SAAS,OAAO,YAAY;AAClC,UAAM,gBAAgB,MAAM;AAC5B,QAAI,SAAS,eAAe;AAC3B,eAAS,OAAO,UAAU,eAAe,EAAE,KAAK,EAAE,OAAO,mCAAmC,CAAC;AAC7F;AAAA,IACD;AAGA,UAAM,OAAO,KAAK,aAAa,iBAAiB,WAAW;AAC3D,UAAM,SAAS,KAAK,aAAa,IAAI,IAAI;AACzC,QAAI,CAAC,UAAU,CAAC,OAAO,QAAQ,KAAK,GAAG;AACtC,eAAS,OAAO,UAAU,oBAAoB,EAAE,KAAK,EAAE,OAAO,oBAAoB,IAAI,IAAI,CAAC;AAC3F;AAAA,IACD;AAEA,QAAI;AAEH,cAAQ,OAAO,MAAM,OAAO,IAAI,OAAO;AAAA,IACxC,QAAQ;AACP,eAAS,OAAO,UAAU,UAAU,EAAE,KAAK,EAAE,OAAO,gBAAgB,IAAI,SAAS,CAAC;AAAA,IACnF;AAAA,EACD;AACD;AAxCiD;AAA1C,IAAM,mBAAN","sourcesContent":["import type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\nimport type { MediaParserStore } from '../lib/structures/MediaParserStore';\nimport { Middleware } from '../lib/structures/Middleware';\nimport type { Route } from '../lib/structures/Route';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly mediaParsers: MediaParserStore;\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 20 });\n\t\tthis.mediaParsers = this.container.server.mediaParsers;\n\t}\n\n\tpublic override async run(request: ApiRequest, response: ApiResponse, route: Route) {\n\t\t// RFC 1341 4.\n\t\tconst contentType = request.headers['content-type'];\n\t\tif (typeof contentType !== 'string') return;\n\n\t\t// RFC 7230 3.3.2.\n\t\tconst lengthString = request.headers['content-length'];\n\t\tif (typeof lengthString !== 'string') return;\n\n\t\t// Verify if the content length is lower than accepted:\n\t\tconst length = Number(lengthString);\n\t\tconst maximumLength = route.maximumBodyLength;\n\t\tif (length > maximumLength) {\n\t\t\tresponse.status(HttpCodes.PayloadTooLarge).json({ error: 'Exceeded maximum content length.' });\n\t\t\treturn;\n\t\t}\n\n\t\t// Verify if the content type is supported by the parser:\n\t\tconst type = this.mediaParsers.parseContentType(contentType);\n\t\tconst parser = this.mediaParsers.get(type);\n\t\tif (!parser || !parser.accepts(route)) {\n\t\t\tresponse.status(HttpCodes.UnsupportedMediaType).json({ error: `Unsupported type ${type}.` });\n\t\t\treturn;\n\t\t}\n\n\t\ttry {\n\t\t\t// Parse the content body:\n\t\t\trequest.body = await parser.run(request);\n\t\t} catch {\n\t\t\tresponse.status(HttpCodes.BadRequest).json({ error: `Cannot parse ${type} data.` });\n\t\t}\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/middlewares/body.ts"],"names":[],"mappings":";;;;;;AAEA,SAAS,iBAAiB;AAE1B,SAAS,kBAAkB;AAGpB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAGzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAHhC,wBAAiB;AAIhB,SAAK,eAAe,KAAK,UAAU,OAAO;AAAA,EAC3C;AAAA,EAEA,MAAsB,IAAI,SAAqB,UAAuB,OAAc;AAEnF,UAAM,cAAc,QAAQ,QAAQ,cAAc;AAClD,QAAI,OAAO,gBAAgB,SAAU;AAGrC,UAAM,eAAe,QAAQ,QAAQ,gBAAgB;AACrD,QAAI,OAAO,iBAAiB,SAAU;AAGtC,UAAM,SAAS,OAAO,YAAY;AAClC,UAAM,gBAAgB,MAAM;AAC5B,QAAI,SAAS,eAAe;AAC3B,eAAS,OAAO,UAAU,eAAe,EAAE,KAAK,EAAE,OAAO,mCAAmC,CAAC;AAC7F;AAAA,IACD;AAGA,UAAM,OAAO,KAAK,aAAa,iBAAiB,WAAW;AAC3D,UAAM,SAAS,KAAK,aAAa,IAAI,IAAI;AACzC,QAAI,CAAC,UAAU,CAAC,OAAO,QAAQ,KAAK,GAAG;AACtC,eAAS,OAAO,UAAU,oBAAoB,EAAE,KAAK,EAAE,OAAO,oBAAoB,IAAI,IAAI,CAAC;AAC3F;AAAA,IACD;AAEA,QAAI;AAEH,cAAQ,OAAO,MAAM,OAAO,IAAI,OAAO;AAAA,IACxC,QAAQ;AACP,eAAS,OAAO,UAAU,UAAU,EAAE,KAAK,EAAE,OAAO,gBAAgB,IAAI,SAAS,CAAC;AAAA,IACnF;AAAA,EACD;AACD;AAxCiD;AAA1C,IAAM,mBAAN","sourcesContent":["import type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\nimport type { MediaParserStore } from '../lib/structures/MediaParserStore';\nimport { Middleware } from '../lib/structures/Middleware';\nimport type { Route } from '../lib/structures/Route';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly mediaParsers: MediaParserStore;\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 20 });\n\t\tthis.mediaParsers = this.container.server.mediaParsers;\n\t}\n\n\tpublic override async run(request: ApiRequest, response: ApiResponse, route: Route) {\n\t\t// RFC 1341 4.\n\t\tconst contentType = request.headers['content-type'];\n\t\tif (typeof contentType !== 'string') return;\n\n\t\t// RFC 7230 3.3.2.\n\t\tconst lengthString = request.headers['content-length'];\n\t\tif (typeof lengthString !== 'string') return;\n\n\t\t// Verify if the content length is lower than accepted:\n\t\tconst length = Number(lengthString);\n\t\tconst maximumLength = route.maximumBodyLength;\n\t\tif (length > maximumLength) {\n\t\t\tresponse.status(HttpCodes.PayloadTooLarge).json({ error: 'Exceeded maximum content length.' });\n\t\t\treturn;\n\t\t}\n\n\t\t// Verify if the content type is supported by the parser:\n\t\tconst type = this.mediaParsers.parseContentType(contentType);\n\t\tconst parser = this.mediaParsers.get(type);\n\t\tif (!parser || !parser.accepts(route)) {\n\t\t\tresponse.status(HttpCodes.UnsupportedMediaType).json({ error: `Unsupported type ${type}.` });\n\t\t\treturn;\n\t\t}\n\n\t\ttry {\n\t\t\t// Parse the content body:\n\t\t\trequest.body = await parser.run(request);\n\t\t} catch {\n\t\t\tresponse.status(HttpCodes.BadRequest).json({ error: `Cannot parse ${type} data.` });\n\t\t}\n\t}\n}\n"]}
@@ -6,10 +6,7 @@ var CookieStore_cjs = require('../lib/structures/api/CookieStore.cjs');
6
6
  var __defProp = Object.defineProperty;
7
7
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
8
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
9
- var __publicField = (obj, key, value) => {
10
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
11
- return value;
12
- };
9
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
13
10
  var _PluginMiddleware = class _PluginMiddleware extends Middleware_cjs.Middleware {
14
11
  constructor(context) {
15
12
  super(context, { position: 30 });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/middlewares/cookies.ts"],"names":[],"mappings":";;;;;;;;;AAAA,SAAS,kBAAkB;AAG3B,SAAS,mBAAmB;AAErB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAIzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAJhC,wBAAiB,cAAsB,QAAQ,IAAI,aAAa;AAChE,wBAAQ,mBAAiC;AAKxC,UAAM,EAAE,OAAO,IAAI,KAAK;AACxB,SAAK,kBAAkB,OAAO,MAAM,mBAAmB;AAAA,EACxD;AAAA,EAEgB,IAAI,SAAqB,UAAuB;AAC/D,aAAS,UAAU,IAAI,YAAY,SAAS,UAAU,KAAK,YAAY,KAAK,eAAe;AAAA,EAC5F;AACD;AAdiD;AAA1C,IAAM,mBAAN","sourcesContent":["import { Middleware } from '../lib/structures/Middleware';\nimport type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { CookieStore } from '../lib/structures/api/CookieStore';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly production: boolean = process.env.NODE_ENV === 'production';\n\tprivate domainOverwrite: string | null = null;\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 30 });\n\n\t\tconst { server } = this.container;\n\t\tthis.domainOverwrite = server.auth?.domainOverwrite ?? null;\n\t}\n\n\tpublic override run(request: ApiRequest, response: ApiResponse) {\n\t\tresponse.cookies = new CookieStore(request, response, this.production, this.domainOverwrite);\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/middlewares/cookies.ts"],"names":[],"mappings":";;;;;;AAAA,SAAS,kBAAkB;AAG3B,SAAS,mBAAmB;AAErB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAIzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAJhC,wBAAiB,cAAsB,QAAQ,IAAI,aAAa;AAChE,wBAAQ,mBAAiC;AAKxC,UAAM,EAAE,OAAO,IAAI,KAAK;AACxB,SAAK,kBAAkB,OAAO,MAAM,mBAAmB;AAAA,EACxD;AAAA,EAEgB,IAAI,SAAqB,UAAuB;AAC/D,aAAS,UAAU,IAAI,YAAY,SAAS,UAAU,KAAK,YAAY,KAAK,eAAe;AAAA,EAC5F;AACD;AAdiD;AAA1C,IAAM,mBAAN","sourcesContent":["import { Middleware } from '../lib/structures/Middleware';\nimport type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { CookieStore } from '../lib/structures/api/CookieStore';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly production: boolean = process.env.NODE_ENV === 'production';\n\tprivate domainOverwrite: string | null = null;\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 30 });\n\n\t\tconst { server } = this.container;\n\t\tthis.domainOverwrite = server.auth?.domainOverwrite ?? null;\n\t}\n\n\tpublic override run(request: ApiRequest, response: ApiResponse) {\n\t\tresponse.cookies = new CookieStore(request, response, this.production, this.domainOverwrite);\n\t}\n}\n"]}
@@ -7,10 +7,7 @@ var HttpCodes_cjs = require('../lib/structures/http/HttpCodes.cjs');
7
7
  var __defProp = Object.defineProperty;
8
8
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
9
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
10
- var __publicField = (obj, key, value) => {
11
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
12
- return value;
13
- };
10
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
14
11
  var _PluginMiddleware = class _PluginMiddleware extends Middleware_cjs.Middleware {
15
12
  constructor(context) {
16
13
  super(context, { position: 10 });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/middlewares/headers.ts"],"names":[],"mappings":";;;;;;;;;AAAA,SAAS,eAAe;AACxB,SAAS,kBAAkB;AAI3B,SAAS,iBAAiB;AAEnB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAIzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAJhC,wBAAiB;AACjB,wBAAiB,WAAkB,QAAQ,KAAK,IAAI;AAInD,SAAK,SAAS,KAAK,UAAU,OAAO,QAAQ,UAAU;AAAA,EACvD;AAAA,EAEgB,IAAI,SAAqB,UAAuB,OAAqB;AACpF,aAAS,UAAU,SAAQ,oBAAI,KAAK,GAAE,YAAY,CAAC;AACnD,aAAS,UAAU,oCAAoC,MAAM;AAC7D,aAAS,UAAU,+BAA+B,KAAK,MAAM;AAC7D,aAAS,UAAU,gCAAgC,yCAAyC;AAC5F,aAAS,UAAU,gCAAgC,KAAK,OAAO;AAE/D,SAAK,yBAAyB,SAAS,UAAU,KAAK;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBQ,yBAAyB,SAAqB,UAAuB,OAAqB;AACjG,QAAI,QAAQ,WAAW,WAAW;AACjC,UAAI,CAAC,SAAS,CAAC,MAAM,QAAQ,IAAI,SAAS,GAAG;AAC5C,iBAAS,IAAI;AAAA,MACd;AAAA,IACD,WAAW,UAAU,MAAM;AAC1B,eAAS,OAAO,UAAU,QAAQ,EAAE,IAAI;AAAA,IACzC;AAAA,EACD;AACD;AA3CiD;AAA1C,IAAM,mBAAN","sourcesContent":["import { METHODS } from 'node:http';\nimport { Middleware } from '../lib/structures/Middleware';\nimport type { Route } from '../lib/structures/Route';\nimport type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly origin: string;\n\tprivate readonly methods: string = METHODS.join(', ');\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 10 });\n\t\tthis.origin = this.container.server.options.origin ?? '*';\n\t}\n\n\tpublic override run(request: ApiRequest, response: ApiResponse, route: Route | null) {\n\t\tresponse.setHeader('Date', new Date().toUTCString());\n\t\tresponse.setHeader('Access-Control-Allow-Credentials', 'true');\n\t\tresponse.setHeader('Access-Control-Allow-Origin', this.origin);\n\t\tresponse.setHeader('Access-Control-Allow-Headers', 'Authorization, User-Agent, Content-Type');\n\t\tresponse.setHeader('Access-Control-Allow-Methods', this.methods);\n\n\t\tthis.ensurePotentialEarlyExit(request, response, route);\n\t}\n\n\t/**\n\t * **RFC 7231 4.3.7.**\n\t * > This method allows a client to determine the options and/or requirements associated with a\n\t * > resource, or the capabilities of a server, without implying a resource action.\n\t *\n\t * This method ensures that the request is exited early in case required\n\t * The conditions in which an early exit is required are:\n\t * 1. If the request method is 'OPTIONS'. In this case the request is returned with status code 200\n\t * 2. If the requested route isn't matched with any existing route in the RouteStore.\n\t * In this case the request is returned with a status code 404.\n\t *\n\t * @param request The API Request coming in\n\t * @param response The API response that will go out\n\t * @param route The route being requested by the request\n\t */\n\tprivate ensurePotentialEarlyExit(request: ApiRequest, response: ApiResponse, route: Route | null) {\n\t\tif (request.method === 'OPTIONS') {\n\t\t\tif (!route || !route.methods.has('OPTIONS')) {\n\t\t\t\tresponse.end();\n\t\t\t}\n\t\t} else if (route === null) {\n\t\t\tresponse.status(HttpCodes.NotFound).end();\n\t\t}\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/middlewares/headers.ts"],"names":[],"mappings":";;;;;;AAAA,SAAS,eAAe;AACxB,SAAS,kBAAkB;AAI3B,SAAS,iBAAiB;AAEnB,IAAM,oBAAN,MAAM,0BAAyB,WAAW;AAAA,EAIzC,YAAY,SAAmC;AACrD,UAAM,SAAS,EAAE,UAAU,GAAG,CAAC;AAJhC,wBAAiB;AACjB,wBAAiB,WAAkB,QAAQ,KAAK,IAAI;AAInD,SAAK,SAAS,KAAK,UAAU,OAAO,QAAQ,UAAU;AAAA,EACvD;AAAA,EAEgB,IAAI,SAAqB,UAAuB,OAAqB;AACpF,aAAS,UAAU,SAAQ,oBAAI,KAAK,GAAE,YAAY,CAAC;AACnD,aAAS,UAAU,oCAAoC,MAAM;AAC7D,aAAS,UAAU,+BAA+B,KAAK,MAAM;AAC7D,aAAS,UAAU,gCAAgC,yCAAyC;AAC5F,aAAS,UAAU,gCAAgC,KAAK,OAAO;AAE/D,SAAK,yBAAyB,SAAS,UAAU,KAAK;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBQ,yBAAyB,SAAqB,UAAuB,OAAqB;AACjG,QAAI,QAAQ,WAAW,WAAW;AACjC,UAAI,CAAC,SAAS,CAAC,MAAM,QAAQ,IAAI,SAAS,GAAG;AAC5C,iBAAS,IAAI;AAAA,MACd;AAAA,IACD,WAAW,UAAU,MAAM;AAC1B,eAAS,OAAO,UAAU,QAAQ,EAAE,IAAI;AAAA,IACzC;AAAA,EACD;AACD;AA3CiD;AAA1C,IAAM,mBAAN","sourcesContent":["import { METHODS } from 'node:http';\nimport { Middleware } from '../lib/structures/Middleware';\nimport type { Route } from '../lib/structures/Route';\nimport type { ApiRequest } from '../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../lib/structures/http/HttpCodes';\n\nexport class PluginMiddleware extends Middleware {\n\tprivate readonly origin: string;\n\tprivate readonly methods: string = METHODS.join(', ');\n\n\tpublic constructor(context: Middleware.LoaderContext) {\n\t\tsuper(context, { position: 10 });\n\t\tthis.origin = this.container.server.options.origin ?? '*';\n\t}\n\n\tpublic override run(request: ApiRequest, response: ApiResponse, route: Route | null) {\n\t\tresponse.setHeader('Date', new Date().toUTCString());\n\t\tresponse.setHeader('Access-Control-Allow-Credentials', 'true');\n\t\tresponse.setHeader('Access-Control-Allow-Origin', this.origin);\n\t\tresponse.setHeader('Access-Control-Allow-Headers', 'Authorization, User-Agent, Content-Type');\n\t\tresponse.setHeader('Access-Control-Allow-Methods', this.methods);\n\n\t\tthis.ensurePotentialEarlyExit(request, response, route);\n\t}\n\n\t/**\n\t * **RFC 7231 4.3.7.**\n\t * > This method allows a client to determine the options and/or requirements associated with a\n\t * > resource, or the capabilities of a server, without implying a resource action.\n\t *\n\t * This method ensures that the request is exited early in case required\n\t * The conditions in which an early exit is required are:\n\t * 1. If the request method is 'OPTIONS'. In this case the request is returned with status code 200\n\t * 2. If the requested route isn't matched with any existing route in the RouteStore.\n\t * In this case the request is returned with a status code 404.\n\t *\n\t * @param request The API Request coming in\n\t * @param response The API response that will go out\n\t * @param route The route being requested by the request\n\t */\n\tprivate ensurePotentialEarlyExit(request: ApiRequest, response: ApiResponse, route: Route | null) {\n\t\tif (request.method === 'OPTIONS') {\n\t\t\tif (!route || !route.methods.has('OPTIONS')) {\n\t\t\t\tresponse.end();\n\t\t\t}\n\t\t} else if (route === null) {\n\t\t\tresponse.status(HttpCodes.NotFound).end();\n\t\t}\n\t}\n}\n"]}
@@ -10,10 +10,7 @@ var HttpMethods_cjs = require('../../lib/structures/http/HttpMethods.cjs');
10
10
  var __defProp = Object.defineProperty;
11
11
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
12
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
13
- var __publicField = (obj, key, value) => {
14
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
15
- return value;
16
- };
13
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
17
14
  var _PluginRoute = class _PluginRoute extends Route_cjs.Route {
18
15
  constructor(context) {
19
16
  super(context, { route: "oauth/callback" });
@@ -65,8 +62,7 @@ var _PluginRoute = class _PluginRoute extends Route_cjs.Route {
65
62
  }
66
63
  });
67
64
  const json = await result.json();
68
- if (result.ok)
69
- return json;
65
+ if (result.ok) return json;
70
66
  this.container.logger.error(json);
71
67
  return null;
72
68
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/routes/oauth/callback.ts"],"names":[],"mappings":";;;;;;;;;AAAA,SAAS,oBAAwG;AACjH,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AACtB,SAAS,aAAa;AAGtB,SAAS,iBAAiB;AAC1B,SAAS,eAAe;AAEjB,IAAM,eAAN,MAAM,qBAAoB,MAAM;AAAA,EAG/B,YAAY,SAA8B;AAChD,UAAM,SAAS,EAAE,OAAO,iBAAiB,CAAC;AAH3C,wBAAiB;AAKhB,UAAM,EAAE,OAAO,IAAI,KAAK;AACxB,SAAK,UAAU,OAAO,SAAS;AAC/B,SAAK,cAAc,OAAO,MAAM;AAAA,EACjC;AAAA,EAEA,OAAuB,QAAQ,IAAI,EAAE,SAAqB,UAAuB;AAChF,UAAM,OAAO,QAAQ;AACrB,QAAI,OAAO,MAAM,SAAS,UAAU;AACnC,aAAO,SAAS,WAAW;AAAA,IAC5B;AAEA,UAAM,QAAQ,MAAM,KAAK,UAAU,IAAI;AACvC,QAAI,UAAU,MAAM;AACnB,aAAO,SAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,6BAA6B,CAAC;AAAA,IACnG;AAEA,UAAM,MAAM,KAAK,IAAI;AACrB,UAAM,OAAO,KAAK,UAAU,OAAO;AACnC,UAAM,OAAO,MAAM,KAAK,UAAU,MAAM,YAAY;AACpD,QAAI,CAAC,KAAK,MAAM;AACf,aAAO,SAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,4BAA4B,CAAC;AAAA,IAClG;AAEA,UAAM,QAAQ,KAAK,QAAQ;AAAA,MAC1B,IAAI,KAAK,KAAK;AAAA,MACd,SAAS,MAAM,MAAM,aAAa;AAAA,MAClC,SAAS,MAAM;AAAA,MACf,OAAO,MAAM;AAAA,IACd,CAAC;AAED,aAAS,QAAQ,IAAI,KAAK,QAAQ,OAAO,EAAE,QAAQ,MAAM,WAAW,CAAC;AACrE,WAAO,SAAS,KAAK,IAAI;AAAA,EAC1B;AAAA,EAEA,MAAc,UAAU,MAAsB;AAC7C,UAAM,EAAE,IAAI,OAAO,IAAI,KAAK,UAAU,OAAO;AAE7C,UAAM,OAAgD;AAAA;AAAA,MAErD,WAAW;AAAA,MACX,eAAe;AAAA,MACf,MAAM,KAAK;AAAA,MACX,YAAY;AAAA,MACZ,cAAc,KAAK,eAAe,KAAK;AAAA;AAAA,IAExC;AAEA,UAAM,SAAS,MAAM,MAAM,aAAa,UAAU;AAAA,MACjD,QAAQ;AAAA,MACR,MAAM,UAAU,IAAW;AAAA,MAC3B,SAAS;AAAA,QACR,gBAAgB;AAAA,MACjB;AAAA,IACD,CAAC;AAED,UAAM,OAAO,MAAM,OAAO,KAAK;AAC/B,QAAI,OAAO;AAAI,aAAO;AAEtB,SAAK,UAAU,OAAO,MAAM,IAAI;AAChC,WAAO;AAAA,EACR;AACD;AAnEuC;AAAhC,IAAM,cAAN","sourcesContent":["import { OAuth2Routes, type RESTPostOAuth2AccessTokenResult, type RESTPostOAuth2AccessTokenURLEncodedData } from 'discord.js';\nimport { stringify } from 'querystring';\nimport { fetch } from 'undici';\nimport { Route } from '../../lib/structures/Route';\nimport type { ApiRequest } from '../../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../../lib/structures/http/HttpCodes';\nimport { methods } from '../../lib/structures/http/HttpMethods';\n\nexport class PluginRoute extends Route {\n\tprivate readonly redirectUri: string | undefined;\n\n\tpublic constructor(context: Route.LoaderContext) {\n\t\tsuper(context, { route: 'oauth/callback' });\n\n\t\tconst { server } = this.container;\n\t\tthis.enabled = server.auth !== null;\n\t\tthis.redirectUri = server.auth?.redirect;\n\t}\n\n\tpublic override async [methods.POST](request: ApiRequest, response: ApiResponse) {\n\t\tconst body = request.body as OAuth2BodyData;\n\t\tif (typeof body?.code !== 'string') {\n\t\t\treturn response.badRequest();\n\t\t}\n\n\t\tconst value = await this.fetchAuth(body);\n\t\tif (value === null) {\n\t\t\treturn response.status(HttpCodes.InternalServerError).json({ error: 'Failed to fetch the token.' });\n\t\t}\n\n\t\tconst now = Date.now();\n\t\tconst auth = this.container.server.auth!;\n\t\tconst data = await auth.fetchData(value.access_token);\n\t\tif (!data.user) {\n\t\t\treturn response.status(HttpCodes.InternalServerError).json({ error: 'Failed to fetch the user.' });\n\t\t}\n\n\t\tconst token = auth.encrypt({\n\t\t\tid: data.user.id,\n\t\t\texpires: now + value.expires_in * 1000,\n\t\t\trefresh: value.refresh_token,\n\t\t\ttoken: value.access_token\n\t\t});\n\n\t\tresponse.cookies.add(auth.cookie, token, { maxAge: value.expires_in });\n\t\treturn response.json(data);\n\t}\n\n\tprivate async fetchAuth(body: OAuth2BodyData) {\n\t\tconst { id, secret } = this.container.server.auth!;\n\n\t\tconst data: RESTPostOAuth2AccessTokenURLEncodedData = {\n\t\t\t/* eslint-disable @typescript-eslint/naming-convention */\n\t\t\tclient_id: id,\n\t\t\tclient_secret: secret,\n\t\t\tcode: body.code,\n\t\t\tgrant_type: 'authorization_code',\n\t\t\tredirect_uri: this.redirectUri ?? body.redirectUri\n\t\t\t/* eslint-enable @typescript-eslint/naming-convention */\n\t\t};\n\n\t\tconst result = await fetch(OAuth2Routes.tokenURL, {\n\t\t\tmethod: 'POST',\n\t\t\tbody: stringify(data as any),\n\t\t\theaders: {\n\t\t\t\t'content-type': 'application/x-www-form-urlencoded'\n\t\t\t}\n\t\t});\n\n\t\tconst json = await result.json();\n\t\tif (result.ok) return json as RESTPostOAuth2AccessTokenResult;\n\n\t\tthis.container.logger.error(json);\n\t\treturn null;\n\t}\n}\n\n/**\n * The OAuth2 body data sent to the callback.\n * @since 1.2.0\n */\nexport interface OAuth2BodyData {\n\t/**\n\t * The code sent by the client.\n\t * @since 1.2.0\n\t */\n\tcode: string;\n\n\t/**\n\t * The client's ID.\n\t * @since 1.2.0\n\t */\n\tclientId: string;\n\n\t/**\n\t * The redirect URI.\n\t * @since 1.2.0\n\t */\n\tredirectUri: string;\n}\n"]}
1
+ {"version":3,"sources":["../../../../src/routes/oauth/callback.ts"],"names":[],"mappings":";;;;;;AAAA,SAAS,oBAAwG;AACjH,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AACtB,SAAS,aAAa;AAGtB,SAAS,iBAAiB;AAC1B,SAAS,eAAe;AAEjB,IAAM,eAAN,MAAM,qBAAoB,MAAM;AAAA,EAG/B,YAAY,SAA8B;AAChD,UAAM,SAAS,EAAE,OAAO,iBAAiB,CAAC;AAH3C,wBAAiB;AAKhB,UAAM,EAAE,OAAO,IAAI,KAAK;AACxB,SAAK,UAAU,OAAO,SAAS;AAC/B,SAAK,cAAc,OAAO,MAAM;AAAA,EACjC;AAAA,EAEA,OAAuB,QAAQ,IAAI,EAAE,SAAqB,UAAuB;AAChF,UAAM,OAAO,QAAQ;AACrB,QAAI,OAAO,MAAM,SAAS,UAAU;AACnC,aAAO,SAAS,WAAW;AAAA,IAC5B;AAEA,UAAM,QAAQ,MAAM,KAAK,UAAU,IAAI;AACvC,QAAI,UAAU,MAAM;AACnB,aAAO,SAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,6BAA6B,CAAC;AAAA,IACnG;AAEA,UAAM,MAAM,KAAK,IAAI;AACrB,UAAM,OAAO,KAAK,UAAU,OAAO;AACnC,UAAM,OAAO,MAAM,KAAK,UAAU,MAAM,YAAY;AACpD,QAAI,CAAC,KAAK,MAAM;AACf,aAAO,SAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,4BAA4B,CAAC;AAAA,IAClG;AAEA,UAAM,QAAQ,KAAK,QAAQ;AAAA,MAC1B,IAAI,KAAK,KAAK;AAAA,MACd,SAAS,MAAM,MAAM,aAAa;AAAA,MAClC,SAAS,MAAM;AAAA,MACf,OAAO,MAAM;AAAA,IACd,CAAC;AAED,aAAS,QAAQ,IAAI,KAAK,QAAQ,OAAO,EAAE,QAAQ,MAAM,WAAW,CAAC;AACrE,WAAO,SAAS,KAAK,IAAI;AAAA,EAC1B;AAAA,EAEA,MAAc,UAAU,MAAsB;AAC7C,UAAM,EAAE,IAAI,OAAO,IAAI,KAAK,UAAU,OAAO;AAE7C,UAAM,OAAgD;AAAA;AAAA,MAErD,WAAW;AAAA,MACX,eAAe;AAAA,MACf,MAAM,KAAK;AAAA,MACX,YAAY;AAAA,MACZ,cAAc,KAAK,eAAe,KAAK;AAAA;AAAA,IAExC;AAEA,UAAM,SAAS,MAAM,MAAM,aAAa,UAAU;AAAA,MACjD,QAAQ;AAAA,MACR,MAAM,UAAU,IAAW;AAAA,MAC3B,SAAS;AAAA,QACR,gBAAgB;AAAA,MACjB;AAAA,IACD,CAAC;AAED,UAAM,OAAO,MAAM,OAAO,KAAK;AAC/B,QAAI,OAAO,GAAI,QAAO;AAEtB,SAAK,UAAU,OAAO,MAAM,IAAI;AAChC,WAAO;AAAA,EACR;AACD;AAnEuC;AAAhC,IAAM,cAAN","sourcesContent":["import { OAuth2Routes, type RESTPostOAuth2AccessTokenResult, type RESTPostOAuth2AccessTokenURLEncodedData } from 'discord.js';\nimport { stringify } from 'querystring';\nimport { fetch } from 'undici';\nimport { Route } from '../../lib/structures/Route';\nimport type { ApiRequest } from '../../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../../lib/structures/http/HttpCodes';\nimport { methods } from '../../lib/structures/http/HttpMethods';\n\nexport class PluginRoute extends Route {\n\tprivate readonly redirectUri: string | undefined;\n\n\tpublic constructor(context: Route.LoaderContext) {\n\t\tsuper(context, { route: 'oauth/callback' });\n\n\t\tconst { server } = this.container;\n\t\tthis.enabled = server.auth !== null;\n\t\tthis.redirectUri = server.auth?.redirect;\n\t}\n\n\tpublic override async [methods.POST](request: ApiRequest, response: ApiResponse) {\n\t\tconst body = request.body as OAuth2BodyData;\n\t\tif (typeof body?.code !== 'string') {\n\t\t\treturn response.badRequest();\n\t\t}\n\n\t\tconst value = await this.fetchAuth(body);\n\t\tif (value === null) {\n\t\t\treturn response.status(HttpCodes.InternalServerError).json({ error: 'Failed to fetch the token.' });\n\t\t}\n\n\t\tconst now = Date.now();\n\t\tconst auth = this.container.server.auth!;\n\t\tconst data = await auth.fetchData(value.access_token);\n\t\tif (!data.user) {\n\t\t\treturn response.status(HttpCodes.InternalServerError).json({ error: 'Failed to fetch the user.' });\n\t\t}\n\n\t\tconst token = auth.encrypt({\n\t\t\tid: data.user.id,\n\t\t\texpires: now + value.expires_in * 1000,\n\t\t\trefresh: value.refresh_token,\n\t\t\ttoken: value.access_token\n\t\t});\n\n\t\tresponse.cookies.add(auth.cookie, token, { maxAge: value.expires_in });\n\t\treturn response.json(data);\n\t}\n\n\tprivate async fetchAuth(body: OAuth2BodyData) {\n\t\tconst { id, secret } = this.container.server.auth!;\n\n\t\tconst data: RESTPostOAuth2AccessTokenURLEncodedData = {\n\t\t\t/* eslint-disable @typescript-eslint/naming-convention */\n\t\t\tclient_id: id,\n\t\t\tclient_secret: secret,\n\t\t\tcode: body.code,\n\t\t\tgrant_type: 'authorization_code',\n\t\t\tredirect_uri: this.redirectUri ?? body.redirectUri\n\t\t\t/* eslint-enable @typescript-eslint/naming-convention */\n\t\t};\n\n\t\tconst result = await fetch(OAuth2Routes.tokenURL, {\n\t\t\tmethod: 'POST',\n\t\t\tbody: stringify(data as any),\n\t\t\theaders: {\n\t\t\t\t'content-type': 'application/x-www-form-urlencoded'\n\t\t\t}\n\t\t});\n\n\t\tconst json = await result.json();\n\t\tif (result.ok) return json as RESTPostOAuth2AccessTokenResult;\n\n\t\tthis.container.logger.error(json);\n\t\treturn null;\n\t}\n}\n\n/**\n * The OAuth2 body data sent to the callback.\n * @since 1.2.0\n */\nexport interface OAuth2BodyData {\n\t/**\n\t * The code sent by the client.\n\t * @since 1.2.0\n\t */\n\tcode: string;\n\n\t/**\n\t * The client's ID.\n\t * @since 1.2.0\n\t */\n\tclientId: string;\n\n\t/**\n\t * The redirect URI.\n\t * @since 1.2.0\n\t */\n\tredirectUri: string;\n}\n"]}
@@ -17,18 +17,15 @@ var _PluginRoute = class _PluginRoute extends Route_cjs.Route {
17
17
  this.enabled = this.container.server.auth !== null;
18
18
  }
19
19
  async [HttpMethods_cjs.methods.POST](request, response) {
20
- if (!request.auth)
21
- return response.status(HttpCodes_cjs.HttpCodes.Unauthorized).json({ error: "Unauthorized." });
20
+ if (!request.auth) return response.status(HttpCodes_cjs.HttpCodes.Unauthorized).json({ error: "Unauthorized." });
22
21
  const result = await this.revoke(request.auth.token);
23
- if (result.ok)
24
- return this.success(response);
22
+ if (result.ok) return this.success(response);
25
23
  if (result.status === HttpCodes_cjs.HttpCodes.ServiceUnavailable) {
26
24
  const retryAfter = this.processRetryAfter(result.headers.get("Retry-After"));
27
25
  if (retryAfter) {
28
26
  await sleep(retryAfter);
29
27
  const result2 = await this.revoke(request.auth.token);
30
- if (result2.ok)
31
- return this.success(response);
28
+ if (result2.ok) return this.success(response);
32
29
  }
33
30
  }
34
31
  return response.status(HttpCodes_cjs.HttpCodes.InternalServerError).json({ error: "Unexpected error from server." });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/routes/oauth/logout.ts"],"names":["result"],"mappings":";;;;AAAA,SAAS,oBAAoB;AAC7B,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AACtB,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AAGtB,SAAS,iBAAiB;AAC1B,SAAS,eAAe;AAExB,IAAM,QAAQ,UAAU,UAAU;AAE3B,IAAM,eAAN,MAAM,qBAAoB,MAAM;AAAA,EAC/B,YAAY,SAA8B;AAChD,UAAM,SAAS,EAAE,OAAO,eAAe,CAAC;AACxC,SAAK,UAAU,KAAK,UAAU,OAAO,SAAS;AAAA,EAC/C;AAAA,EAEA,OAAuB,QAAQ,IAAI,EAAE,SAAqB,UAAuB;AAChF,QAAI,CAAC,QAAQ;AAAM,aAAO,SAAS,OAAO,UAAU,YAAY,EAAE,KAAK,EAAE,OAAO,gBAAgB,CAAC;AAEjG,UAAM,SAAS,MAAM,KAAK,OAAO,QAAQ,KAAK,KAAK;AACnD,QAAI,OAAO;AAAI,aAAO,KAAK,QAAQ,QAAQ;AAM3C,QAAI,OAAO,WAAW,UAAU,oBAAoB;AAMnD,YAAM,aAAa,KAAK,kBAAkB,OAAO,QAAQ,IAAI,aAAa,CAAC;AAC3E,UAAI,YAAY;AACf,cAAM,MAAM,UAAU;AAEtB,cAAMA,UAAS,MAAM,KAAK,OAAO,QAAQ,KAAK,KAAK;AACnD,YAAIA,QAAO;AAAI,iBAAO,KAAK,QAAQ,QAAQ;AAAA,MAC5C;AAAA,IACD;AAQA,WAAO,SAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,gCAAgC,CAAC;AAAA,EACtG;AAAA,EAEQ,QAAQ,UAAuB;AAEtC,aAAS,QAAQ,OAAO,KAAK,UAAU,OAAO,KAAM,MAAM;AAC1D,WAAO,SAAS,KAAK,EAAE,SAAS,KAAK,CAAC;AAAA,EACvC;AAAA,EAEA,MAAc,OAAO,OAAe;AACnC,UAAM,OAAO,KAAK,UAAU,OAAO;AAkBnC,UAAM,SAAS,MAAM,MAAM,aAAa,oBAAoB;AAAA,MAC3D,QAAQ;AAAA,MACR,MAAM,UAAU;AAAA,QACf;AAAA;AAAA,QAEA,WAAW,KAAK;AAAA,QAChB,eAAe,KAAK;AAAA;AAAA,MAErB,CAAC;AAAA,MACD,SAAS;AAAA,QACR,gBAAgB;AAAA,MACjB;AAAA,IACD,CAAC;AAED,WAAO;AAAA,EACR;AAAA,EAEQ,kBAAkB,YAA2B;AAGpD,WAAO,eAAe,OAAO,MAAO,OAAO,UAAU,IAAI;AAAA,EAC1D;AACD;AAvFuC;AAAhC,IAAM,cAAN","sourcesContent":["import { OAuth2Routes } from 'discord.js';\nimport { stringify } from 'querystring';\nimport { fetch } from 'undici';\nimport { promisify } from 'util';\nimport { Route } from '../../lib/structures/Route';\nimport type { ApiRequest } from '../../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../../lib/structures/http/HttpCodes';\nimport { methods } from '../../lib/structures/http/HttpMethods';\n\nconst sleep = promisify(setTimeout);\n\nexport class PluginRoute extends Route {\n\tpublic constructor(context: Route.LoaderContext) {\n\t\tsuper(context, { route: 'oauth/logout' });\n\t\tthis.enabled = this.container.server.auth !== null;\n\t}\n\n\tpublic override async [methods.POST](request: ApiRequest, response: ApiResponse) {\n\t\tif (!request.auth) return response.status(HttpCodes.Unauthorized).json({ error: 'Unauthorized.' });\n\n\t\tconst result = await this.revoke(request.auth.token);\n\t\tif (result.ok) return this.success(response);\n\n\t\t// RFC 7009 2.2.1. If the server responds with HTTP status code 503, the client must assume the token still\n\t\t// exists and may retry after a reasonable delay.\n\t\t// The server may include a \"Retry-After\" header in the response to indicate how long the service is expected to\n\t\t// be unavailable to the requesting client.\n\t\tif (result.status === HttpCodes.ServiceUnavailable) {\n\t\t\t// RFC 7231 7.1.3. Servers send the \"Retry-After\" header field to indicate how long the user agent ought to\n\t\t\t// wait before making a follow-up request.\n\t\t\t//\n\t\t\t// The value of this field can be either an HTTP-date or a number of seconds to delay after the response is\n\t\t\t// received.\n\t\t\tconst retryAfter = this.processRetryAfter(result.headers.get('Retry-After'));\n\t\t\tif (retryAfter) {\n\t\t\t\tawait sleep(retryAfter);\n\n\t\t\t\tconst result = await this.revoke(request.auth.token);\n\t\t\t\tif (result.ok) return this.success(response);\n\t\t\t}\n\t\t}\n\n\t\t// RFC 7009 2.2. The authorization server responds with HTTP status code 200 if the token has been revoked\n\t\t// successfully or if the client submitted an invalid token.\n\t\t//\n\t\t// Note: invalid tokens do not cause an error response since the client cannot handle such an error in a\n\t\t// reasonable way. Moreover, the purpose of the revocation request, invalidating the particular token, is\n\t\t// already achieved.\n\t\treturn response.status(HttpCodes.InternalServerError).json({ error: 'Unexpected error from server.' });\n\t}\n\n\tprivate success(response: ApiResponse) {\n\t\t// Sending an empty cookie with \"expires\" set to 1970-01-01 makes the browser instantly remove the cookie.\n\t\tresponse.cookies.remove(this.container.server.auth!.cookie);\n\t\treturn response.json({ success: true });\n\t}\n\n\tprivate async revoke(token: string) {\n\t\tconst auth = this.container.server.auth!;\n\n\t\t// RFC 7009 2.1.\n\t\t// The following parameters must be formatted as \"application/x-www-form-urlencoded\" in the HTTP request-body:\n\t\t//\n\t\t// - token: The token the client wants to be revoked.\n\t\t// - token_type_hint: [Optional]: `access_token` (RFC 6749 1.4), `refresh_token` (RFC 6749 1.5)\n\t\t//\n\t\t// The client also includes its authentication credentials, as described in RFC 6749 2.3.\n\t\t//\n\t\t// RFC 6749 2.3.1.\n\t\t// The authorization server MAY include the client credentials in the request - body using the following parameters:\n\t\t//\n\t\t// - client_id: The client identifier issued to the client during the registration process (RFC 6749 2.2)\n\t\t// - client_secret: The client secret.\n\t\t//\n\t\t// RFC 7009 2.2.\n\t\t// The content of the response body is ignored by the client as all necessary information is conveyed in the response code.\n\t\tconst result = await fetch(OAuth2Routes.tokenRevocationURL, {\n\t\t\tmethod: 'POST',\n\t\t\tbody: stringify({\n\t\t\t\ttoken,\n\t\t\t\t/* eslint-disable @typescript-eslint/naming-convention */\n\t\t\t\tclient_id: auth.id,\n\t\t\t\tclient_secret: auth.secret\n\t\t\t\t/* eslint-enable @typescript-eslint/naming-convention */\n\t\t\t}),\n\t\t\theaders: {\n\t\t\t\t'content-type': 'application/x-www-form-urlencoded'\n\t\t\t}\n\t\t});\n\n\t\treturn result;\n\t}\n\n\tprivate processRetryAfter(retryAfter: string | null) {\n\t\t// Discord sends Retry-After in seconds, never an HTTP-date, therefore, we will assume this behaviour.\n\t\t// Either way, if it's not present, we will retry in 5 seconds.\n\t\treturn retryAfter === null ? 5000 : Number(retryAfter) * 1000;\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../../src/routes/oauth/logout.ts"],"names":["result"],"mappings":";;;;AAAA,SAAS,oBAAoB;AAC7B,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AACtB,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AAGtB,SAAS,iBAAiB;AAC1B,SAAS,eAAe;AAExB,IAAM,QAAQ,UAAU,UAAU;AAE3B,IAAM,eAAN,MAAM,qBAAoB,MAAM;AAAA,EAC/B,YAAY,SAA8B;AAChD,UAAM,SAAS,EAAE,OAAO,eAAe,CAAC;AACxC,SAAK,UAAU,KAAK,UAAU,OAAO,SAAS;AAAA,EAC/C;AAAA,EAEA,OAAuB,QAAQ,IAAI,EAAE,SAAqB,UAAuB;AAChF,QAAI,CAAC,QAAQ,KAAM,QAAO,SAAS,OAAO,UAAU,YAAY,EAAE,KAAK,EAAE,OAAO,gBAAgB,CAAC;AAEjG,UAAM,SAAS,MAAM,KAAK,OAAO,QAAQ,KAAK,KAAK;AACnD,QAAI,OAAO,GAAI,QAAO,KAAK,QAAQ,QAAQ;AAM3C,QAAI,OAAO,WAAW,UAAU,oBAAoB;AAMnD,YAAM,aAAa,KAAK,kBAAkB,OAAO,QAAQ,IAAI,aAAa,CAAC;AAC3E,UAAI,YAAY;AACf,cAAM,MAAM,UAAU;AAEtB,cAAMA,UAAS,MAAM,KAAK,OAAO,QAAQ,KAAK,KAAK;AACnD,YAAIA,QAAO,GAAI,QAAO,KAAK,QAAQ,QAAQ;AAAA,MAC5C;AAAA,IACD;AAQA,WAAO,SAAS,OAAO,UAAU,mBAAmB,EAAE,KAAK,EAAE,OAAO,gCAAgC,CAAC;AAAA,EACtG;AAAA,EAEQ,QAAQ,UAAuB;AAEtC,aAAS,QAAQ,OAAO,KAAK,UAAU,OAAO,KAAM,MAAM;AAC1D,WAAO,SAAS,KAAK,EAAE,SAAS,KAAK,CAAC;AAAA,EACvC;AAAA,EAEA,MAAc,OAAO,OAAe;AACnC,UAAM,OAAO,KAAK,UAAU,OAAO;AAkBnC,UAAM,SAAS,MAAM,MAAM,aAAa,oBAAoB;AAAA,MAC3D,QAAQ;AAAA,MACR,MAAM,UAAU;AAAA,QACf;AAAA;AAAA,QAEA,WAAW,KAAK;AAAA,QAChB,eAAe,KAAK;AAAA;AAAA,MAErB,CAAC;AAAA,MACD,SAAS;AAAA,QACR,gBAAgB;AAAA,MACjB;AAAA,IACD,CAAC;AAED,WAAO;AAAA,EACR;AAAA,EAEQ,kBAAkB,YAA2B;AAGpD,WAAO,eAAe,OAAO,MAAO,OAAO,UAAU,IAAI;AAAA,EAC1D;AACD;AAvFuC;AAAhC,IAAM,cAAN","sourcesContent":["import { OAuth2Routes } from 'discord.js';\nimport { stringify } from 'querystring';\nimport { fetch } from 'undici';\nimport { promisify } from 'util';\nimport { Route } from '../../lib/structures/Route';\nimport type { ApiRequest } from '../../lib/structures/api/ApiRequest';\nimport type { ApiResponse } from '../../lib/structures/api/ApiResponse';\nimport { HttpCodes } from '../../lib/structures/http/HttpCodes';\nimport { methods } from '../../lib/structures/http/HttpMethods';\n\nconst sleep = promisify(setTimeout);\n\nexport class PluginRoute extends Route {\n\tpublic constructor(context: Route.LoaderContext) {\n\t\tsuper(context, { route: 'oauth/logout' });\n\t\tthis.enabled = this.container.server.auth !== null;\n\t}\n\n\tpublic override async [methods.POST](request: ApiRequest, response: ApiResponse) {\n\t\tif (!request.auth) return response.status(HttpCodes.Unauthorized).json({ error: 'Unauthorized.' });\n\n\t\tconst result = await this.revoke(request.auth.token);\n\t\tif (result.ok) return this.success(response);\n\n\t\t// RFC 7009 2.2.1. If the server responds with HTTP status code 503, the client must assume the token still\n\t\t// exists and may retry after a reasonable delay.\n\t\t// The server may include a \"Retry-After\" header in the response to indicate how long the service is expected to\n\t\t// be unavailable to the requesting client.\n\t\tif (result.status === HttpCodes.ServiceUnavailable) {\n\t\t\t// RFC 7231 7.1.3. Servers send the \"Retry-After\" header field to indicate how long the user agent ought to\n\t\t\t// wait before making a follow-up request.\n\t\t\t//\n\t\t\t// The value of this field can be either an HTTP-date or a number of seconds to delay after the response is\n\t\t\t// received.\n\t\t\tconst retryAfter = this.processRetryAfter(result.headers.get('Retry-After'));\n\t\t\tif (retryAfter) {\n\t\t\t\tawait sleep(retryAfter);\n\n\t\t\t\tconst result = await this.revoke(request.auth.token);\n\t\t\t\tif (result.ok) return this.success(response);\n\t\t\t}\n\t\t}\n\n\t\t// RFC 7009 2.2. The authorization server responds with HTTP status code 200 if the token has been revoked\n\t\t// successfully or if the client submitted an invalid token.\n\t\t//\n\t\t// Note: invalid tokens do not cause an error response since the client cannot handle such an error in a\n\t\t// reasonable way. Moreover, the purpose of the revocation request, invalidating the particular token, is\n\t\t// already achieved.\n\t\treturn response.status(HttpCodes.InternalServerError).json({ error: 'Unexpected error from server.' });\n\t}\n\n\tprivate success(response: ApiResponse) {\n\t\t// Sending an empty cookie with \"expires\" set to 1970-01-01 makes the browser instantly remove the cookie.\n\t\tresponse.cookies.remove(this.container.server.auth!.cookie);\n\t\treturn response.json({ success: true });\n\t}\n\n\tprivate async revoke(token: string) {\n\t\tconst auth = this.container.server.auth!;\n\n\t\t// RFC 7009 2.1.\n\t\t// The following parameters must be formatted as \"application/x-www-form-urlencoded\" in the HTTP request-body:\n\t\t//\n\t\t// - token: The token the client wants to be revoked.\n\t\t// - token_type_hint: [Optional]: `access_token` (RFC 6749 1.4), `refresh_token` (RFC 6749 1.5)\n\t\t//\n\t\t// The client also includes its authentication credentials, as described in RFC 6749 2.3.\n\t\t//\n\t\t// RFC 6749 2.3.1.\n\t\t// The authorization server MAY include the client credentials in the request - body using the following parameters:\n\t\t//\n\t\t// - client_id: The client identifier issued to the client during the registration process (RFC 6749 2.2)\n\t\t// - client_secret: The client secret.\n\t\t//\n\t\t// RFC 7009 2.2.\n\t\t// The content of the response body is ignored by the client as all necessary information is conveyed in the response code.\n\t\tconst result = await fetch(OAuth2Routes.tokenRevocationURL, {\n\t\t\tmethod: 'POST',\n\t\t\tbody: stringify({\n\t\t\t\ttoken,\n\t\t\t\t/* eslint-disable @typescript-eslint/naming-convention */\n\t\t\t\tclient_id: auth.id,\n\t\t\t\tclient_secret: auth.secret\n\t\t\t\t/* eslint-enable @typescript-eslint/naming-convention */\n\t\t\t}),\n\t\t\theaders: {\n\t\t\t\t'content-type': 'application/x-www-form-urlencoded'\n\t\t\t}\n\t\t});\n\n\t\treturn result;\n\t}\n\n\tprivate processRetryAfter(retryAfter: string | null) {\n\t\t// Discord sends Retry-After in seconds, never an HTTP-date, therefore, we will assume this behaviour.\n\t\t// Either way, if it's not present, we will retry in 5 seconds.\n\t\treturn retryAfter === null ? 5000 : Number(retryAfter) * 1000;\n\t}\n}\n"]}
@@ -0,0 +1,15 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __typeError = (msg) => {
3
+ throw TypeError(msg);
4
+ };
5
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
8
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
9
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
10
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
11
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
12
+
13
+ export { __name, __privateAdd, __privateGet, __privateSet, __publicField };
14
+ //# sourceMappingURL=out.js.map
15
+ //# sourceMappingURL=chunk-JTFKMR4I.mjs.map
@@ -224,10 +224,6 @@ interface ParsedPart {
224
224
  type: TypeState;
225
225
  }
226
226
 
227
- type Methods = 'ACL' | 'BIND' | 'CHECKOUT' | 'CONNECT' | 'COPY' | 'DELETE' | 'GET' | 'HEAD' | 'LINK' | 'LOCK' | 'M-SEARCH' | 'MERGE' | 'MKACTIVITY' | 'MKCALENDAR' | 'MKCOL' | 'MOVE' | 'NOTIFY' | 'OPTIONS' | 'PATCH' | 'POST' | 'PRI' | 'PROPFIND' | 'PROPPATCH' | 'PURGE' | 'PUT' | 'REBIND' | 'REPORT' | 'SEARCH' | 'SOURCE' | 'SUBSCRIBE' | 'TRACE' | 'UNBIND' | 'UNLINK' | 'UNLOCK' | 'UNSUBSCRIBE';
228
- declare const methods: Record<Methods, symbol>;
229
- declare const methodEntries: readonly [Methods, symbol][];
230
-
231
227
  declare enum MimeTypes {
232
228
  ApplicationFormUrlEncoded = "application/x-www-form-urlencoded",
233
229
  ApplicationJson = "application/json",
@@ -354,6 +350,10 @@ declare class ApiResponse<Request extends IncomingMessage = IncomingMessage> ext
354
350
  setContentType(contentType: MimeTypes): this;
355
351
  }
356
352
 
353
+ type Methods = 'ACL' | 'BIND' | 'CHECKOUT' | 'CONNECT' | 'COPY' | 'DELETE' | 'GET' | 'HEAD' | 'LINK' | 'LOCK' | 'M-SEARCH' | 'MERGE' | 'MKACTIVITY' | 'MKCALENDAR' | 'MKCOL' | 'MOVE' | 'NOTIFY' | 'OPTIONS' | 'PATCH' | 'POST' | 'PRI' | 'PROPFIND' | 'PROPPATCH' | 'PURGE' | 'PUT' | 'REBIND' | 'REPORT' | 'SEARCH' | 'SOURCE' | 'SUBSCRIBE' | 'TRACE' | 'UNBIND' | 'UNLINK' | 'UNLOCK' | 'UNSUBSCRIBE';
354
+ declare const methods: Record<Methods, symbol>;
355
+ declare const methodEntries: readonly [Methods, symbol][];
356
+
357
357
  interface MethodCallback {
358
358
  (request: ApiRequest, response: ApiResponse): unknown;
359
359
  }
@@ -383,7 +383,7 @@ interface RouteOptions extends Piece.Options {
383
383
  * ```
384
384
  * @example
385
385
  * ```typescript
386
- * '/guilds/:guild/members/:member/'
386
+ * '/guilds/[guild]/members/[member]'
387
387
  * // request.params -> { guild: '...', member: '...' }
388
388
  * ```
389
389
  */
@@ -440,6 +440,8 @@ declare namespace Route {
440
440
  type Options = RouteOptions;
441
441
  type JSON = Piece.JSON;
442
442
  type LocationJSON = Piece.LocationJSON;
443
+ type Request = ApiRequest;
444
+ type Response = ApiResponse;
443
445
  }
444
446
 
445
447
  /**
@@ -1,4 +1,4 @@
1
- import './chunk-PYETHG4R.mjs';
1
+ import './chunk-JTFKMR4I.mjs';
2
2
  export * from './lib/structures/api/ApiRequest.mjs';
3
3
  export * from './lib/structures/api/ApiResponse.mjs';
4
4
  export * from './lib/structures/api/CookieStore.mjs';
@@ -19,7 +19,7 @@ export { loadMediaParsers } from './mediaParsers/_load.mjs';
19
19
  export { loadMiddlewares } from './middlewares/_load.mjs';
20
20
  export { loadRoutes } from './routes/_load.mjs';
21
21
 
22
- var version = "6.1.2-next.fc6b7cf.0";
22
+ var version = "7.0.0-next.d27dc1c";
23
23
 
24
24
  export { version };
25
25
  //# sourceMappingURL=out.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts"],"names":[],"mappings":";;;AAKA,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AAEd,SAAS,qBAAqB;AAC9B,SAAS,wBAAwB;AACjC,SAAS,uBAAuB;AAChC,SAAS,kBAAkB;AA+BpB,IAAM,UAAkB","sourcesContent":["import type { Server, ServerOptions } from './lib/structures/http/Server';\nimport type { MediaParserStore } from './lib/structures/MediaParserStore';\nimport type { MiddlewareStore } from './lib/structures/MiddlewareStore';\nimport type { RouteStore } from './lib/structures/RouteStore';\n\nexport * from './lib/structures/api/ApiRequest';\nexport * from './lib/structures/api/ApiResponse';\nexport * from './lib/structures/api/CookieStore';\nexport * from './lib/structures/http/Auth';\nexport * from './lib/structures/http/HttpCodes';\nexport * from './lib/structures/http/HttpMethods';\nexport * from './lib/structures/http/Server';\nexport * from './lib/structures/MediaParser';\nexport * from './lib/structures/MediaParserStore';\nexport * from './lib/structures/Middleware';\nexport * from './lib/structures/MiddlewareStore';\nexport * from './lib/structures/Route';\nexport * from './lib/structures/RouteStore';\nexport * from './lib/utils/MimeTypes';\nexport * from './lib/utils/RouteData';\n\nexport { loadListeners } from './listeners/_load';\nexport { loadMediaParsers } from './mediaParsers/_load';\nexport { loadMiddlewares } from './middlewares/_load';\nexport { loadRoutes } from './routes/_load';\n\ndeclare module 'discord.js' {\n\tinterface Client {\n\t\tserver: Server;\n\t}\n\n\tinterface ClientOptions {\n\t\tapi?: ServerOptions;\n\t}\n}\n\ndeclare module '@sapphire/pieces' {\n\tinterface StoreRegistryEntries {\n\t\troutes: RouteStore;\n\t\tmediaParsers: MediaParserStore;\n\t\tmiddlewares: MiddlewareStore;\n\t}\n\n\tinterface Container {\n\t\tserver: Server;\n\t}\n}\n\n/**\n * The [@sapphire/plugin-api](https://github.com/sapphiredev/plugins/blob/main/packages/api) version that you are currently using.\n * An example use of this is showing it of in a bot information command.\n *\n * Note to Sapphire developers: This needs to explicitly be `string` so it is not typed as the string that gets replaced by esbuild\n */\n// eslint-disable-next-line @typescript-eslint/no-inferrable-types\nexport const version: string = '6.1.2-next.fc6b7cf.0';\n"]}
1
+ {"version":3,"sources":["../../src/index.ts"],"names":[],"mappings":";;;AAKA,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AAEd,SAAS,qBAAqB;AAC9B,SAAS,wBAAwB;AACjC,SAAS,uBAAuB;AAChC,SAAS,kBAAkB;AA+BpB,IAAM,UAAkB","sourcesContent":["import type { Server, ServerOptions } from './lib/structures/http/Server';\nimport type { MediaParserStore } from './lib/structures/MediaParserStore';\nimport type { MiddlewareStore } from './lib/structures/MiddlewareStore';\nimport type { RouteStore } from './lib/structures/RouteStore';\n\nexport * from './lib/structures/api/ApiRequest';\nexport * from './lib/structures/api/ApiResponse';\nexport * from './lib/structures/api/CookieStore';\nexport * from './lib/structures/http/Auth';\nexport * from './lib/structures/http/HttpCodes';\nexport * from './lib/structures/http/HttpMethods';\nexport * from './lib/structures/http/Server';\nexport * from './lib/structures/MediaParser';\nexport * from './lib/structures/MediaParserStore';\nexport * from './lib/structures/Middleware';\nexport * from './lib/structures/MiddlewareStore';\nexport * from './lib/structures/Route';\nexport * from './lib/structures/RouteStore';\nexport * from './lib/utils/MimeTypes';\nexport * from './lib/utils/RouteData';\n\nexport { loadListeners } from './listeners/_load';\nexport { loadMediaParsers } from './mediaParsers/_load';\nexport { loadMiddlewares } from './middlewares/_load';\nexport { loadRoutes } from './routes/_load';\n\ndeclare module 'discord.js' {\n\tinterface Client {\n\t\tserver: Server;\n\t}\n\n\tinterface ClientOptions {\n\t\tapi?: ServerOptions;\n\t}\n}\n\ndeclare module '@sapphire/pieces' {\n\tinterface StoreRegistryEntries {\n\t\troutes: RouteStore;\n\t\tmediaParsers: MediaParserStore;\n\t\tmiddlewares: MiddlewareStore;\n\t}\n\n\tinterface Container {\n\t\tserver: Server;\n\t}\n}\n\n/**\n * The [@sapphire/plugin-api](https://github.com/sapphiredev/plugins/blob/main/packages/api) version that you are currently using.\n * An example use of this is showing it of in a bot information command.\n *\n * Note to Sapphire developers: This needs to explicitly be `string` so it is not typed as the string that gets replaced by esbuild\n */\n// eslint-disable-next-line @typescript-eslint/no-inferrable-types\nexport const version: string = '7.0.0-next.d27dc1c';\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../../chunk-PYETHG4R.mjs';
1
+ import { __name } from '../../chunk-JTFKMR4I.mjs';
2
2
  import { Piece } from '@sapphire/pieces';
3
3
  import { createBrotliDecompress, createGunzip, createInflate } from 'zlib';
4
4
 
@@ -21,11 +21,9 @@ var _MediaParser = class _MediaParser extends Piece {
21
21
  */
22
22
  async readString(request) {
23
23
  const stream = this.contentStream(request);
24
- if (stream === null)
25
- return "";
24
+ if (stream === null) return "";
26
25
  let body = "";
27
- for await (const chunk of stream)
28
- body += chunk;
26
+ for await (const chunk of stream) body += chunk;
29
27
  return body;
30
28
  }
31
29
  /**
@@ -35,11 +33,9 @@ var _MediaParser = class _MediaParser extends Piece {
35
33
  */
36
34
  async readBuffer(request) {
37
35
  const stream = this.contentStream(request);
38
- if (stream === null)
39
- return Buffer.alloc(0);
36
+ if (stream === null) return Buffer.alloc(0);
40
37
  const bodies = [];
41
- for await (const chunk of stream)
42
- bodies.push(chunk);
38
+ for await (const chunk of stream) bodies.push(chunk);
43
39
  return Buffer.concat(bodies);
44
40
  }
45
41
  /**