modelence 0.8.0 → 0.9.0-dev.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/app/authConfig.d.ts +68 -0
- package/dist/app/authConfig.d.ts.map +1 -0
- package/dist/app/authConfig.js +8 -0
- package/dist/app/authConfig.js.map +1 -0
- package/dist/app/backendApi.d.ts +29 -0
- package/dist/app/backendApi.d.ts.map +1 -0
- package/dist/app/backendApi.js +69 -0
- package/dist/app/backendApi.js.map +1 -0
- package/dist/app/email.d.ts +3 -0
- package/dist/app/email.d.ts.map +1 -0
- package/dist/app/email.js +8 -0
- package/dist/app/email.js.map +1 -0
- package/dist/app/emailConfig.d.ts +27 -0
- package/dist/app/emailConfig.d.ts.map +1 -0
- package/dist/app/emailConfig.js +8 -0
- package/dist/app/emailConfig.js.map +1 -0
- package/dist/app/index.d.ts +20 -0
- package/dist/app/index.d.ts.map +1 -0
- package/dist/app/index.js +258 -0
- package/dist/app/index.js.map +1 -0
- package/dist/app/loggerProcess.d.ts +5 -0
- package/dist/app/loggerProcess.d.ts.map +1 -0
- package/dist/app/loggerProcess.js +90 -0
- package/dist/app/loggerProcess.js.map +1 -0
- package/dist/app/metrics.d.ts +6 -0
- package/dist/app/metrics.d.ts.map +1 -0
- package/dist/app/metrics.js +92 -0
- package/dist/app/metrics.js.map +1 -0
- package/dist/app/module.d.ts +77 -0
- package/dist/app/module.d.ts.map +1 -0
- package/dist/app/module.js +46 -0
- package/dist/app/module.js.map +1 -0
- package/dist/app/server.d.ts +37 -0
- package/dist/app/server.d.ts.map +1 -0
- package/dist/app/server.js +198 -0
- package/dist/app/server.js.map +1 -0
- package/dist/app/state.d.ts +19 -0
- package/dist/app/state.d.ts.map +1 -0
- package/dist/app/state.js +27 -0
- package/dist/app/state.js.map +1 -0
- package/dist/app/websocketConfig.d.ts +7 -0
- package/dist/app/websocketConfig.d.ts.map +1 -0
- package/dist/app/websocketConfig.js +8 -0
- package/dist/app/websocketConfig.js.map +1 -0
- package/dist/auth/client/index.d.ts +69 -0
- package/dist/auth/client/index.d.ts.map +1 -0
- package/dist/auth/client/index.js +79 -0
- package/dist/auth/client/index.js.map +1 -0
- package/dist/auth/db.d.ts +176 -0
- package/dist/auth/db.d.ts.map +1 -0
- package/dist/auth/db.js +117 -0
- package/dist/auth/db.js.map +1 -0
- package/dist/auth/deleteUser.d.ts +5 -0
- package/dist/auth/deleteUser.d.ts.map +1 -0
- package/dist/auth/deleteUser.js +34 -0
- package/dist/auth/deleteUser.js.map +1 -0
- package/dist/auth/disposableEmails.d.ts +6 -0
- package/dist/auth/disposableEmails.d.ts.map +1 -0
- package/dist/auth/disposableEmails.js +47 -0
- package/dist/auth/disposableEmails.js.map +1 -0
- package/dist/auth/index.d.ts +7 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +33 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/login.d.ts +9 -0
- package/dist/auth/login.d.ts.map +1 -0
- package/dist/auth/login.js +100 -0
- package/dist/auth/login.js.map +1 -0
- package/dist/auth/password.d.ts +14 -0
- package/dist/auth/password.d.ts.map +1 -0
- package/dist/auth/password.js +26 -0
- package/dist/auth/password.js.map +1 -0
- package/dist/auth/profile.d.ts +10 -0
- package/dist/auth/profile.d.ts.map +1 -0
- package/dist/auth/profile.js +13 -0
- package/dist/auth/profile.js.map +1 -0
- package/dist/auth/providers/github.d.ts +3 -0
- package/dist/auth/providers/github.d.ts.map +1 -0
- package/dist/auth/providers/github.js +122 -0
- package/dist/auth/providers/github.js.map +1 -0
- package/dist/auth/providers/google.d.ts +3 -0
- package/dist/auth/providers/google.d.ts.map +1 -0
- package/dist/auth/providers/google.js +108 -0
- package/dist/auth/providers/google.js.map +1 -0
- package/dist/auth/providers/oauth-common.d.ts +13 -0
- package/dist/auth/providers/oauth-common.d.ts.map +1 -0
- package/dist/auth/providers/oauth-common.js +109 -0
- package/dist/auth/providers/oauth-common.js.map +1 -0
- package/dist/auth/resetPassword.d.ts +10 -0
- package/dist/auth/resetPassword.d.ts.map +1 -0
- package/dist/auth/resetPassword.js +108 -0
- package/dist/auth/resetPassword.js.map +1 -0
- package/dist/auth/role.d.ts +8 -0
- package/dist/auth/role.d.ts.map +1 -0
- package/dist/auth/role.js +37 -0
- package/dist/auth/role.js.map +1 -0
- package/dist/auth/session.d.ts +24 -0
- package/dist/auth/session.d.ts.map +1 -0
- package/dist/auth/session.js +84 -0
- package/dist/auth/session.js.map +1 -0
- package/dist/auth/signup.d.ts +3 -0
- package/dist/auth/signup.d.ts.map +1 -0
- package/dist/auth/signup.js +89 -0
- package/dist/auth/signup.js.map +1 -0
- package/dist/auth/templates/emailVerficationTemplate.d.ts +6 -0
- package/dist/auth/templates/emailVerficationTemplate.d.ts.map +1 -0
- package/dist/auth/templates/emailVerficationTemplate.js +9 -0
- package/dist/auth/templates/emailVerficationTemplate.js.map +1 -0
- package/dist/auth/types.d.ts +22 -0
- package/dist/auth/types.d.ts.map +1 -0
- package/dist/auth/types.js +2 -0
- package/dist/auth/types.js.map +1 -0
- package/dist/auth/user.d.ts +5 -0
- package/dist/auth/user.d.ts.map +1 -0
- package/dist/auth/user.js +152 -0
- package/dist/auth/user.js.map +1 -0
- package/dist/auth/validators.d.ts +3 -0
- package/dist/auth/validators.d.ts.map +1 -0
- package/dist/auth/validators.js +8 -0
- package/dist/auth/validators.js.map +1 -0
- package/dist/auth/verification.d.ts +8 -0
- package/dist/auth/verification.d.ts.map +1 -0
- package/dist/auth/verification.js +94 -0
- package/dist/auth/verification.js.map +1 -0
- package/dist/bin/auth.d.ts +4 -0
- package/dist/bin/auth.d.ts.map +1 -0
- package/dist/bin/auth.js +48 -0
- package/dist/bin/auth.js.map +1 -0
- package/dist/bin/build.d.ts +2 -0
- package/dist/bin/build.d.ts.map +1 -0
- package/dist/bin/build.js +78 -0
- package/dist/bin/build.js.map +1 -0
- package/dist/bin/config.d.ts +11 -0
- package/dist/bin/config.d.ts.map +1 -0
- package/dist/bin/config.js +91 -0
- package/dist/bin/config.js.map +1 -0
- package/dist/bin/deploy.d.ts +6 -0
- package/dist/bin/deploy.d.ts.map +1 -0
- package/dist/bin/deploy.js +129 -0
- package/dist/bin/deploy.js.map +1 -0
- package/dist/bin/dev.d.ts +2 -0
- package/dist/bin/dev.d.ts.map +1 -0
- package/dist/bin/dev.js +14 -0
- package/dist/bin/dev.js.map +1 -0
- package/dist/bin/modelence.d.ts +3 -0
- package/dist/bin/modelence.d.ts.map +1 -0
- package/dist/bin/modelence.js +57 -3
- package/dist/bin/modelence.js.map +1 -1
- package/dist/bin/setup.d.ts +5 -0
- package/dist/bin/setup.d.ts.map +1 -0
- package/dist/bin/setup.js +91 -0
- package/dist/bin/setup.js.map +1 -0
- package/dist/bin/start.d.ts +2 -0
- package/dist/bin/start.d.ts.map +1 -0
- package/dist/bin/start.js +15 -0
- package/dist/bin/start.js.map +1 -0
- package/dist/client/AppProvider.d.ts +8 -0
- package/dist/client/AppProvider.d.ts.map +1 -0
- package/dist/client/AppProvider.js +31 -0
- package/dist/client/AppProvider.js.map +1 -0
- package/dist/client/errorHandler.d.ts +4 -0
- package/dist/client/errorHandler.d.ts.map +1 -0
- package/dist/client/errorHandler.js +10 -0
- package/dist/client/errorHandler.js.map +1 -0
- package/dist/client/localStorage.d.ts +3 -0
- package/dist/client/localStorage.d.ts.map +1 -0
- package/dist/client/localStorage.js +14 -0
- package/dist/client/localStorage.js.map +1 -0
- package/dist/client/method.d.ts +6 -0
- package/dist/client/method.d.ts.map +1 -0
- package/dist/client/method.js +52 -0
- package/dist/client/method.js.map +1 -0
- package/dist/client/renderApp.d.ts +9 -0
- package/dist/client/renderApp.d.ts.map +1 -0
- package/dist/client/renderApp.js +28 -0
- package/dist/client/renderApp.js.map +1 -0
- package/dist/client/session.d.ts +34 -0
- package/dist/client/session.d.ts.map +1 -0
- package/dist/client/session.js +83 -0
- package/dist/client/session.js.map +1 -0
- package/dist/client.d.ts +10 -133
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +14 -1
- package/dist/client.js.map +1 -1
- package/dist/config/client.d.ts +10 -0
- package/dist/config/client.d.ts.map +1 -0
- package/dist/config/client.js +14 -0
- package/dist/config/client.js.map +1 -0
- package/dist/config/server.d.ts +48 -0
- package/dist/config/server.d.ts.map +1 -0
- package/dist/config/server.js +85 -0
- package/dist/config/server.js.map +1 -0
- package/dist/config/sync.d.ts +2 -0
- package/dist/config/sync.d.ts.map +1 -0
- package/dist/config/sync.js +32 -0
- package/dist/config/sync.js.map +1 -0
- package/dist/config/types.d.ts +19 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/cron/jobs.d.ts +13 -0
- package/dist/cron/jobs.d.ts.map +1 -0
- package/dist/cron/jobs.js +155 -0
- package/dist/cron/jobs.js.map +1 -0
- package/dist/cron/types.d.ts +29 -0
- package/dist/cron/types.d.ts.map +1 -0
- package/dist/cron/types.js +2 -0
- package/dist/cron/types.js.map +1 -0
- package/dist/data/schemaSerializer.d.ts +37 -0
- package/dist/data/schemaSerializer.d.ts.map +1 -0
- package/dist/data/schemaSerializer.js +104 -0
- package/dist/data/schemaSerializer.js.map +1 -0
- package/dist/{types-WgRbQ-tj.d.ts → data/store.d.ts} +13 -231
- package/dist/data/store.d.ts.map +1 -0
- package/dist/data/store.js +501 -0
- package/dist/data/store.js.map +1 -0
- package/dist/data/types.d.ts +47 -0
- package/dist/data/types.d.ts.map +1 -0
- package/dist/data/types.js +35 -0
- package/dist/data/types.js.map +1 -0
- package/dist/db/client.d.ts +5 -0
- package/dist/db/client.d.ts.map +1 -0
- package/dist/db/client.js +41 -0
- package/dist/db/client.js.map +1 -0
- package/dist/error.d.ts +16 -0
- package/dist/error.d.ts.map +1 -0
- package/dist/error.js +24 -0
- package/dist/error.js.map +1 -0
- package/dist/index.d.ts +6 -31
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/lock/db.d.ts +19 -0
- package/dist/lock/db.d.ts.map +1 -0
- package/dist/lock/db.js +28 -0
- package/dist/lock/db.js.map +1 -0
- package/dist/lock/helpers.d.ts +28 -0
- package/dist/lock/helpers.d.ts.map +1 -0
- package/dist/lock/helpers.js +107 -0
- package/dist/lock/helpers.js.map +1 -0
- package/dist/lock/index.d.ts +4 -0
- package/dist/lock/index.d.ts.map +1 -0
- package/dist/lock/index.js +4 -0
- package/dist/lock/index.js.map +1 -0
- package/dist/lock/module.d.ts +7 -0
- package/dist/lock/module.d.ts.map +1 -0
- package/dist/lock/module.js +9 -0
- package/dist/lock/module.js.map +1 -0
- package/dist/methods/index.d.ts +7 -0
- package/dist/methods/index.d.ts.map +1 -0
- package/dist/methods/index.js +65 -0
- package/dist/methods/index.js.map +1 -0
- package/dist/methods/serialize.d.ts +15 -0
- package/dist/methods/serialize.d.ts.map +1 -0
- package/dist/methods/serialize.js +56 -0
- package/dist/methods/serialize.js.map +1 -0
- package/dist/methods/types.d.ts +37 -0
- package/dist/methods/types.d.ts.map +1 -0
- package/dist/methods/types.js +2 -0
- package/dist/methods/types.js.map +1 -0
- package/dist/migration/db.d.ts +17 -0
- package/dist/migration/db.d.ts.map +1 -0
- package/dist/migration/db.js +13 -0
- package/dist/migration/db.js.map +1 -0
- package/dist/migration/index.d.ts +11 -0
- package/dist/migration/index.d.ts.map +1 -0
- package/dist/migration/index.js +85 -0
- package/dist/migration/index.js.map +1 -0
- package/dist/mongo.d.ts +2 -3
- package/dist/mongo.d.ts.map +1 -0
- package/dist/mongo.js +2 -1
- package/dist/mongo.js.map +1 -1
- package/dist/rate-limit/db.d.ts +29 -0
- package/dist/rate-limit/db.d.ts.map +1 -0
- package/dist/rate-limit/db.js +25 -0
- package/dist/rate-limit/db.js.map +1 -0
- package/dist/rate-limit/index.d.ts +4 -0
- package/dist/rate-limit/index.d.ts.map +1 -0
- package/dist/rate-limit/index.js +6 -0
- package/dist/rate-limit/index.js.map +1 -0
- package/dist/rate-limit/rules.d.ts +22 -0
- package/dist/rate-limit/rules.d.ts.map +1 -0
- package/dist/rate-limit/rules.js +112 -0
- package/dist/rate-limit/rules.js.map +1 -0
- package/dist/rate-limit/types.d.ts +12 -0
- package/dist/rate-limit/types.d.ts.map +1 -0
- package/dist/rate-limit/types.js +2 -0
- package/dist/rate-limit/types.js.map +1 -0
- package/dist/routes/handler.d.ts +4 -0
- package/dist/routes/handler.d.ts.map +1 -0
- package/dist/routes/handler.js +66 -0
- package/dist/routes/handler.js.map +1 -0
- package/dist/routes/types.d.ts +45 -0
- package/dist/routes/types.d.ts.map +1 -0
- package/dist/routes/types.js +2 -0
- package/dist/routes/types.js.map +1 -0
- package/dist/server.d.ts +19 -551
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +15 -18
- package/dist/server.js.map +1 -1
- package/dist/system/index.d.ts +4 -0
- package/dist/system/index.d.ts.map +1 -0
- package/dist/system/index.js +21 -0
- package/dist/system/index.js.map +1 -0
- package/dist/telemetry/index.d.ts +11 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +79 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry.d.ts +2 -11
- package/dist/telemetry.d.ts.map +1 -0
- package/dist/telemetry.js +1 -1
- package/dist/telemetry.js.map +1 -1
- package/dist/time.d.ts +8 -0
- package/dist/time.d.ts.map +1 -0
- package/dist/time.js +13 -0
- package/dist/time.js.map +1 -0
- package/dist/types/email.d.ts +25 -0
- package/dist/types/email.d.ts.map +1 -0
- package/dist/types/email.js +2 -0
- package/dist/types/email.js.map +1 -0
- package/dist/types/index.d.ts +14 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types.d.ts +10 -7
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +1 -1
- package/dist/types.js.map +1 -1
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +15 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/viteServer.d.ts +13 -0
- package/dist/viteServer.d.ts.map +1 -0
- package/dist/viteServer.js +132 -0
- package/dist/viteServer.js.map +1 -0
- package/dist/websocket/client.d.ts +9 -0
- package/dist/websocket/client.d.ts.map +1 -0
- package/dist/websocket/client.js +16 -0
- package/dist/websocket/client.js.map +1 -0
- package/dist/websocket/clientChannel.d.ts +9 -0
- package/dist/websocket/clientChannel.d.ts.map +1 -0
- package/dist/websocket/clientChannel.js +26 -0
- package/dist/websocket/clientChannel.js.map +1 -0
- package/dist/websocket/serverChannel.d.ts +14 -0
- package/dist/websocket/serverChannel.d.ts.map +1 -0
- package/dist/websocket/serverChannel.js +21 -0
- package/dist/websocket/serverChannel.js.map +1 -0
- package/dist/websocket/socketio/client.d.ts +4 -0
- package/dist/websocket/socketio/client.d.ts.map +1 -0
- package/dist/websocket/socketio/client.js +48 -0
- package/dist/websocket/socketio/client.js.map +1 -0
- package/dist/websocket/socketio/server.d.ts +10 -0
- package/dist/websocket/socketio/server.d.ts.map +1 -0
- package/dist/websocket/socketio/server.js +80 -0
- package/dist/websocket/socketio/server.js.map +1 -0
- package/dist/websocket/types.d.ts +45 -0
- package/dist/websocket/types.d.ts.map +1 -0
- package/dist/websocket/types.js +2 -0
- package/dist/websocket/types.js.map +1 -0
- package/package.json +5 -6
- package/dist/chunk-3S2FFBNS.js +0 -2
- package/dist/chunk-3S2FFBNS.js.map +0 -1
- package/dist/chunk-3YAV3UUU.js +0 -3
- package/dist/chunk-3YAV3UUU.js.map +0 -1
- package/dist/chunk-55J6XMHW.js +0 -2
- package/dist/chunk-55J6XMHW.js.map +0 -1
- package/dist/chunk-C3UESBRX.js +0 -2
- package/dist/chunk-C3UESBRX.js.map +0 -1
- package/dist/chunk-DO5TZLF5.js +0 -2
- package/dist/chunk-DO5TZLF5.js.map +0 -1
- package/dist/chunk-PB6WQQ4L.js +0 -3
- package/dist/chunk-PB6WQQ4L.js.map +0 -1
- package/dist/index-CwdohC5n.d.ts +0 -15
- package/dist/package-3YQBVIVQ.js +0 -2
- package/dist/package-3YQBVIVQ.js.map +0 -1
- package/dist/types-Ds1ESQSs.d.ts +0 -106
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"websocketConfig.d.ts","sourceRoot":"","sources":["../../src/app/websocketConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAE5D,MAAM,MAAM,eAAe,GAAG;IAC5B,QAAQ,CAAC,EAAE,uBAAuB,CAAC;CACpC,CAAC;AAIF,wBAAgB,kBAAkB,CAAC,kBAAkB,EAAE,eAAe,QAErE;AAED,wBAAgB,kBAAkB,oBAEjC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
let websocketConfig = Object.freeze({});
|
|
2
|
+
export function setWebsocketConfig(newWebsocketConfig) {
|
|
3
|
+
websocketConfig = Object.freeze(Object.assign({}, websocketConfig, newWebsocketConfig));
|
|
4
|
+
}
|
|
5
|
+
export function getWebsocketConfig() {
|
|
6
|
+
return websocketConfig;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=websocketConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"websocketConfig.js","sourceRoot":"","sources":["../../src/app/websocketConfig.ts"],"names":[],"mappings":"AAMA,IAAI,eAAe,GAAoB,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AAEzD,MAAM,UAAU,kBAAkB,CAAC,kBAAmC;IACpE,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,eAAe,EAAE,kBAAkB,CAAC,CAAC,CAAC;AAC1F,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,OAAO,eAAe,CAAC;AACzB,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
export type UserInfo = {
|
|
2
|
+
id: string;
|
|
3
|
+
handle: string;
|
|
4
|
+
roles: string[];
|
|
5
|
+
hasRole: (role: string) => boolean;
|
|
6
|
+
requireRole: (role: string) => void;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Sign up a new user with an email and password.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```ts
|
|
13
|
+
* await signupWithPassword({ email: 'test@example.com', password: '12345678' });
|
|
14
|
+
* ```
|
|
15
|
+
* @param options.email - The email of the user.
|
|
16
|
+
* @param options.password - The password of the user.
|
|
17
|
+
*/
|
|
18
|
+
export declare function signupWithPassword(options: {
|
|
19
|
+
email: string;
|
|
20
|
+
password: string;
|
|
21
|
+
}): Promise<void>;
|
|
22
|
+
/**
|
|
23
|
+
* Login a user with an email and password.
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```ts
|
|
27
|
+
* await loginWithPassword({ email: 'test@example.com', password: '12345678' });
|
|
28
|
+
* ```
|
|
29
|
+
* @param options.email - The email of the user.
|
|
30
|
+
* @param options.password - The password of the user.
|
|
31
|
+
*/
|
|
32
|
+
export declare function loginWithPassword(options: {
|
|
33
|
+
email: string;
|
|
34
|
+
password: string;
|
|
35
|
+
}): Promise<UserInfo>;
|
|
36
|
+
/**
|
|
37
|
+
* Verify user's email with a verification token.
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* ```ts
|
|
41
|
+
* await verifyEmail({ token: 'verification-token' });
|
|
42
|
+
* ```
|
|
43
|
+
* @param options.token - The email verification token.
|
|
44
|
+
*/
|
|
45
|
+
export declare function verifyEmail(options: {
|
|
46
|
+
token: string;
|
|
47
|
+
}): Promise<void>;
|
|
48
|
+
/**
|
|
49
|
+
* Logout the current user.
|
|
50
|
+
*
|
|
51
|
+
*/
|
|
52
|
+
export declare function logout(): Promise<void>;
|
|
53
|
+
/**
|
|
54
|
+
* Send reset password token.
|
|
55
|
+
* @param options.email - The email of the user.
|
|
56
|
+
*/
|
|
57
|
+
export declare function sendResetPasswordToken(options: {
|
|
58
|
+
email: string;
|
|
59
|
+
}): Promise<void>;
|
|
60
|
+
/**
|
|
61
|
+
* Reset password.
|
|
62
|
+
* @param options.token - The password reset token.
|
|
63
|
+
* @param options.password - The new password.
|
|
64
|
+
*/
|
|
65
|
+
export declare function resetPassword(options: {
|
|
66
|
+
token: string;
|
|
67
|
+
password: string;
|
|
68
|
+
}): Promise<void>;
|
|
69
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/auth/client/index.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACnC,WAAW,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACrC,CAAC;AAEF;;;;;;;;;GASG;AACH,wBAAsB,kBAAkB,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,iBAGpF;AAED;;;;;;;;;GASG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,qBAQnF;AAED;;;;;;;;GAQG;AACH,wBAAsB,WAAW,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,iBAG3D;AAED;;;GAGG;AACH,wBAAsB,MAAM,kBAG3B;AAED;;;GAGG;AACH,wBAAsB,sBAAsB,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,iBAKtE;AAED;;;;GAIG;AACH,wBAAsB,aAAa,CAAC,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,iBAM/E"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { setCurrentUser } from '../../client/session';
|
|
2
|
+
import { callMethod } from '../../client/method';
|
|
3
|
+
/**
|
|
4
|
+
* Sign up a new user with an email and password.
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```ts
|
|
8
|
+
* await signupWithPassword({ email: 'test@example.com', password: '12345678' });
|
|
9
|
+
* ```
|
|
10
|
+
* @param options.email - The email of the user.
|
|
11
|
+
* @param options.password - The password of the user.
|
|
12
|
+
*/
|
|
13
|
+
export async function signupWithPassword(options) {
|
|
14
|
+
const { email, password } = options;
|
|
15
|
+
await callMethod('_system.user.signupWithPassword', { email, password });
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Login a user with an email and password.
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```ts
|
|
22
|
+
* await loginWithPassword({ email: 'test@example.com', password: '12345678' });
|
|
23
|
+
* ```
|
|
24
|
+
* @param options.email - The email of the user.
|
|
25
|
+
* @param options.password - The password of the user.
|
|
26
|
+
*/
|
|
27
|
+
export async function loginWithPassword(options) {
|
|
28
|
+
const { email, password } = options;
|
|
29
|
+
const { user } = await callMethod('_system.user.loginWithPassword', {
|
|
30
|
+
email,
|
|
31
|
+
password,
|
|
32
|
+
});
|
|
33
|
+
setCurrentUser(user);
|
|
34
|
+
return user;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Verify user's email with a verification token.
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* ```ts
|
|
41
|
+
* await verifyEmail({ token: 'verification-token' });
|
|
42
|
+
* ```
|
|
43
|
+
* @param options.token - The email verification token.
|
|
44
|
+
*/
|
|
45
|
+
export async function verifyEmail(options) {
|
|
46
|
+
const { token } = options;
|
|
47
|
+
await callMethod('_system.user.verifyEmail', { token });
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Logout the current user.
|
|
51
|
+
*
|
|
52
|
+
*/
|
|
53
|
+
export async function logout() {
|
|
54
|
+
await callMethod('_system.user.logout');
|
|
55
|
+
setCurrentUser(null);
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Send reset password token.
|
|
59
|
+
* @param options.email - The email of the user.
|
|
60
|
+
*/
|
|
61
|
+
export async function sendResetPasswordToken(options) {
|
|
62
|
+
const { email } = options;
|
|
63
|
+
await callMethod('_system.user.sendResetPasswordToken', {
|
|
64
|
+
email,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Reset password.
|
|
69
|
+
* @param options.token - The password reset token.
|
|
70
|
+
* @param options.password - The new password.
|
|
71
|
+
*/
|
|
72
|
+
export async function resetPassword(options) {
|
|
73
|
+
const { token, password } = options;
|
|
74
|
+
await callMethod('_system.user.resetPassword', {
|
|
75
|
+
token,
|
|
76
|
+
password,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/auth/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAUjD;;;;;;;;;GASG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,OAA4C;IACnF,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IACpC,MAAM,UAAU,CAAC,iCAAiC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC3E,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,OAA4C;IAClF,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IACpC,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,UAAU,CAAqB,gCAAgC,EAAE;QACtF,KAAK;QACL,QAAQ;KACT,CAAC,CAAC;IACH,cAAc,CAAC,IAAI,CAAC,CAAC;IACrB,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,OAA0B;IAC1D,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAC1B,MAAM,UAAU,CAAqB,0BAA0B,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;AAC9E,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,MAAM;IAC1B,MAAM,UAAU,CAAC,qBAAqB,CAAC,CAAC;IACxC,cAAc,CAAC,IAAI,CAAC,CAAC;AACvB,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,OAA0B;IACrE,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAC1B,MAAM,UAAU,CAAC,qCAAqC,EAAE;QACtD,KAAK;KACN,CAAC,CAAC;AACL,CAAC;AAED;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAA4C;IAC9E,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IACpC,MAAM,UAAU,CAAC,4BAA4B,EAAE;QAC7C,KAAK;QACL,QAAQ;KACT,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { Store } from '../data/store';
|
|
2
|
+
/**
|
|
3
|
+
* Database collection for storing user accounts with authentication methods and profile information.
|
|
4
|
+
*
|
|
5
|
+
* This is where **signupWithPassword** automatically creates new users.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```typescript
|
|
9
|
+
* // Find user by email
|
|
10
|
+
* const user = await dbUsers.findOne(
|
|
11
|
+
* { 'emails.address': 'john@example.com' }
|
|
12
|
+
* );
|
|
13
|
+
* ```
|
|
14
|
+
*
|
|
15
|
+
*/
|
|
16
|
+
export declare const usersCollection: Store<{
|
|
17
|
+
handle: import("zod").ZodString;
|
|
18
|
+
emails: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodObject<{
|
|
19
|
+
address: import("zod").ZodString;
|
|
20
|
+
verified: import("zod").ZodBoolean;
|
|
21
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
22
|
+
address: string;
|
|
23
|
+
verified: boolean;
|
|
24
|
+
}, {
|
|
25
|
+
address: string;
|
|
26
|
+
verified: boolean;
|
|
27
|
+
}>, "many">>;
|
|
28
|
+
status: import("zod").ZodOptional<import("zod").ZodEnum<["active", "disabled", "deleted"]>>;
|
|
29
|
+
createdAt: import("zod").ZodDate;
|
|
30
|
+
disabledAt: import("zod").ZodOptional<import("zod").ZodDate>;
|
|
31
|
+
deletedAt: import("zod").ZodOptional<import("zod").ZodDate>;
|
|
32
|
+
roles: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodString, "many">>;
|
|
33
|
+
authMethods: import("zod").ZodObject<{
|
|
34
|
+
password: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
35
|
+
hash: import("zod").ZodString;
|
|
36
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
37
|
+
hash: string;
|
|
38
|
+
}, {
|
|
39
|
+
hash: string;
|
|
40
|
+
}>>;
|
|
41
|
+
google: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
42
|
+
id: import("zod").ZodString;
|
|
43
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
44
|
+
id: string;
|
|
45
|
+
}, {
|
|
46
|
+
id: string;
|
|
47
|
+
}>>;
|
|
48
|
+
github: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
49
|
+
id: import("zod").ZodString;
|
|
50
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
51
|
+
id: string;
|
|
52
|
+
}, {
|
|
53
|
+
id: string;
|
|
54
|
+
}>>;
|
|
55
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
56
|
+
password?: {
|
|
57
|
+
hash: string;
|
|
58
|
+
} | undefined;
|
|
59
|
+
google?: {
|
|
60
|
+
id: string;
|
|
61
|
+
} | undefined;
|
|
62
|
+
github?: {
|
|
63
|
+
id: string;
|
|
64
|
+
} | undefined;
|
|
65
|
+
}, {
|
|
66
|
+
password?: {
|
|
67
|
+
hash: string;
|
|
68
|
+
} | undefined;
|
|
69
|
+
google?: {
|
|
70
|
+
id: string;
|
|
71
|
+
} | undefined;
|
|
72
|
+
github?: {
|
|
73
|
+
id: string;
|
|
74
|
+
} | undefined;
|
|
75
|
+
}>;
|
|
76
|
+
}, Record<string, (this: Pick<import("../types").InferDocumentType<{
|
|
77
|
+
handle: import("zod").ZodString;
|
|
78
|
+
emails: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodObject<{
|
|
79
|
+
address: import("zod").ZodString;
|
|
80
|
+
verified: import("zod").ZodBoolean;
|
|
81
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
82
|
+
address: string;
|
|
83
|
+
verified: boolean;
|
|
84
|
+
}, {
|
|
85
|
+
address: string;
|
|
86
|
+
verified: boolean;
|
|
87
|
+
}>, "many">>;
|
|
88
|
+
status: import("zod").ZodOptional<import("zod").ZodEnum<["active", "disabled", "deleted"]>>;
|
|
89
|
+
createdAt: import("zod").ZodDate;
|
|
90
|
+
disabledAt: import("zod").ZodOptional<import("zod").ZodDate>;
|
|
91
|
+
deletedAt: import("zod").ZodOptional<import("zod").ZodDate>;
|
|
92
|
+
roles: import("zod").ZodOptional<import("zod").ZodArray<import("zod").ZodString, "many">>;
|
|
93
|
+
authMethods: import("zod").ZodObject<{
|
|
94
|
+
password: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
95
|
+
hash: import("zod").ZodString;
|
|
96
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
97
|
+
hash: string;
|
|
98
|
+
}, {
|
|
99
|
+
hash: string;
|
|
100
|
+
}>>;
|
|
101
|
+
google: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
102
|
+
id: import("zod").ZodString;
|
|
103
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
104
|
+
id: string;
|
|
105
|
+
}, {
|
|
106
|
+
id: string;
|
|
107
|
+
}>>;
|
|
108
|
+
github: import("zod").ZodOptional<import("zod").ZodObject<{
|
|
109
|
+
id: import("zod").ZodString;
|
|
110
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
111
|
+
id: string;
|
|
112
|
+
}, {
|
|
113
|
+
id: string;
|
|
114
|
+
}>>;
|
|
115
|
+
}, "strip", import("zod").ZodTypeAny, {
|
|
116
|
+
password?: {
|
|
117
|
+
hash: string;
|
|
118
|
+
} | undefined;
|
|
119
|
+
google?: {
|
|
120
|
+
id: string;
|
|
121
|
+
} | undefined;
|
|
122
|
+
github?: {
|
|
123
|
+
id: string;
|
|
124
|
+
} | undefined;
|
|
125
|
+
}, {
|
|
126
|
+
password?: {
|
|
127
|
+
hash: string;
|
|
128
|
+
} | undefined;
|
|
129
|
+
google?: {
|
|
130
|
+
id: string;
|
|
131
|
+
} | undefined;
|
|
132
|
+
github?: {
|
|
133
|
+
id: string;
|
|
134
|
+
} | undefined;
|
|
135
|
+
}>;
|
|
136
|
+
}>, "handle" | "roles" | "status" | "createdAt" | "emails" | "disabledAt" | "deletedAt" | "authMethods"> & {
|
|
137
|
+
_id: import("bson").ObjectId;
|
|
138
|
+
}, ...args: any[]) => any>>;
|
|
139
|
+
export declare const dbDisposableEmailDomains: Store<{
|
|
140
|
+
domain: import("zod").ZodString;
|
|
141
|
+
addedAt: import("zod").ZodDate;
|
|
142
|
+
}, Record<string, (this: Pick<import("../types").InferDocumentType<{
|
|
143
|
+
domain: import("zod").ZodString;
|
|
144
|
+
addedAt: import("zod").ZodDate;
|
|
145
|
+
}>, "domain" | "addedAt"> & {
|
|
146
|
+
_id: import("bson").ObjectId;
|
|
147
|
+
}, ...args: any[]) => any>>;
|
|
148
|
+
export declare const emailVerificationTokensCollection: Store<{
|
|
149
|
+
userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
|
|
150
|
+
email: import("zod").ZodOptional<import("zod").ZodString>;
|
|
151
|
+
token: import("zod").ZodString;
|
|
152
|
+
createdAt: import("zod").ZodDate;
|
|
153
|
+
expiresAt: import("zod").ZodDate;
|
|
154
|
+
}, Record<string, (this: Pick<import("../types").InferDocumentType<{
|
|
155
|
+
userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
|
|
156
|
+
email: import("zod").ZodOptional<import("zod").ZodString>;
|
|
157
|
+
token: import("zod").ZodString;
|
|
158
|
+
createdAt: import("zod").ZodDate;
|
|
159
|
+
expiresAt: import("zod").ZodDate;
|
|
160
|
+
}>, "email" | "token" | "createdAt" | "expiresAt" | "userId"> & {
|
|
161
|
+
_id: import("bson").ObjectId;
|
|
162
|
+
}, ...args: any[]) => any>>;
|
|
163
|
+
export declare const resetPasswordTokensCollection: Store<{
|
|
164
|
+
userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
|
|
165
|
+
token: import("zod").ZodString;
|
|
166
|
+
createdAt: import("zod").ZodDate;
|
|
167
|
+
expiresAt: import("zod").ZodDate;
|
|
168
|
+
}, Record<string, (this: Pick<import("../types").InferDocumentType<{
|
|
169
|
+
userId: import("zod").ZodType<import("bson").ObjectId, import("zod").ZodTypeDef, import("bson").ObjectId>;
|
|
170
|
+
token: import("zod").ZodString;
|
|
171
|
+
createdAt: import("zod").ZodDate;
|
|
172
|
+
expiresAt: import("zod").ZodDate;
|
|
173
|
+
}>, "token" | "createdAt" | "expiresAt" | "userId"> & {
|
|
174
|
+
_id: import("bson").ObjectId;
|
|
175
|
+
}, ...args: any[]) => any>>;
|
|
176
|
+
//# sourceMappingURL=db.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/auth/db.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAoD1B,CAAC;AAEH,eAAO,MAAM,wBAAwB;;;;;;;;2BAWnC,CAAC;AAEH,eAAO,MAAM,iCAAiC;;;;;;;;;;;;;;2BAkB5C,CAAC;AAEH,eAAO,MAAM,6BAA6B;;;;;;;;;;;;2BAiBxC,CAAC"}
|
package/dist/auth/db.js
ADDED
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { schema } from '../data/types';
|
|
2
|
+
import { Store } from '../data/store';
|
|
3
|
+
/**
|
|
4
|
+
* Database collection for storing user accounts with authentication methods and profile information.
|
|
5
|
+
*
|
|
6
|
+
* This is where **signupWithPassword** automatically creates new users.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```typescript
|
|
10
|
+
* // Find user by email
|
|
11
|
+
* const user = await dbUsers.findOne(
|
|
12
|
+
* { 'emails.address': 'john@example.com' }
|
|
13
|
+
* );
|
|
14
|
+
* ```
|
|
15
|
+
*
|
|
16
|
+
*/
|
|
17
|
+
export const usersCollection = new Store('_modelenceUsers', {
|
|
18
|
+
schema: {
|
|
19
|
+
handle: schema.string(),
|
|
20
|
+
emails: schema
|
|
21
|
+
.array(schema.object({
|
|
22
|
+
address: schema.string(),
|
|
23
|
+
verified: schema.boolean(),
|
|
24
|
+
}))
|
|
25
|
+
.optional(),
|
|
26
|
+
status: schema.enum(['active', 'disabled', 'deleted']).optional(),
|
|
27
|
+
createdAt: schema.date(),
|
|
28
|
+
disabledAt: schema.date().optional(),
|
|
29
|
+
deletedAt: schema.date().optional(),
|
|
30
|
+
roles: schema.array(schema.string()).optional(),
|
|
31
|
+
authMethods: schema.object({
|
|
32
|
+
password: schema
|
|
33
|
+
.object({
|
|
34
|
+
hash: schema.string(),
|
|
35
|
+
})
|
|
36
|
+
.optional(),
|
|
37
|
+
google: schema
|
|
38
|
+
.object({
|
|
39
|
+
id: schema.string(),
|
|
40
|
+
})
|
|
41
|
+
.optional(),
|
|
42
|
+
github: schema
|
|
43
|
+
.object({
|
|
44
|
+
id: schema.string(),
|
|
45
|
+
})
|
|
46
|
+
.optional(),
|
|
47
|
+
}),
|
|
48
|
+
},
|
|
49
|
+
indexes: [
|
|
50
|
+
{
|
|
51
|
+
key: { handle: 1 },
|
|
52
|
+
unique: true,
|
|
53
|
+
collation: { locale: 'en', strength: 2 }, // Case-insensitive
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
key: { 'emails.address': 1, status: 1 },
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
key: { 'authMethods.google.id': 1, status: 1 },
|
|
60
|
+
sparse: true,
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
key: { 'authMethods.github.id': 1, status: 1 },
|
|
64
|
+
sparse: true,
|
|
65
|
+
},
|
|
66
|
+
],
|
|
67
|
+
});
|
|
68
|
+
export const dbDisposableEmailDomains = new Store('_modelenceDisposableEmailDomains', {
|
|
69
|
+
schema: {
|
|
70
|
+
domain: schema.string(),
|
|
71
|
+
addedAt: schema.date(),
|
|
72
|
+
},
|
|
73
|
+
indexes: [
|
|
74
|
+
{
|
|
75
|
+
key: { domain: 1 },
|
|
76
|
+
unique: true,
|
|
77
|
+
},
|
|
78
|
+
],
|
|
79
|
+
});
|
|
80
|
+
export const emailVerificationTokensCollection = new Store('_modelenceEmailVerificationTokens', {
|
|
81
|
+
schema: {
|
|
82
|
+
userId: schema.objectId(),
|
|
83
|
+
email: schema.string().optional(),
|
|
84
|
+
token: schema.string(),
|
|
85
|
+
createdAt: schema.date(),
|
|
86
|
+
expiresAt: schema.date(),
|
|
87
|
+
},
|
|
88
|
+
indexes: [
|
|
89
|
+
{
|
|
90
|
+
key: { token: 1 },
|
|
91
|
+
unique: true,
|
|
92
|
+
},
|
|
93
|
+
{
|
|
94
|
+
key: { expiresAt: 1 },
|
|
95
|
+
expireAfterSeconds: 0,
|
|
96
|
+
},
|
|
97
|
+
],
|
|
98
|
+
});
|
|
99
|
+
export const resetPasswordTokensCollection = new Store('_modelenceResetPasswordTokens', {
|
|
100
|
+
schema: {
|
|
101
|
+
userId: schema.objectId(),
|
|
102
|
+
token: schema.string(),
|
|
103
|
+
createdAt: schema.date(),
|
|
104
|
+
expiresAt: schema.date(),
|
|
105
|
+
},
|
|
106
|
+
indexes: [
|
|
107
|
+
{
|
|
108
|
+
key: { token: 1 },
|
|
109
|
+
unique: true,
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
key: { expiresAt: 1 },
|
|
113
|
+
expireAfterSeconds: 0,
|
|
114
|
+
},
|
|
115
|
+
],
|
|
116
|
+
});
|
|
117
|
+
//# sourceMappingURL=db.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/auth/db.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ObjectId } from 'mongodb';
|
|
2
|
+
export declare function clearTokens(userId: ObjectId): Promise<void>;
|
|
3
|
+
export declare function disableUser(userId: ObjectId): Promise<void>;
|
|
4
|
+
export declare function deleteUser(userId: ObjectId): Promise<void>;
|
|
5
|
+
//# sourceMappingURL=deleteUser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteUser.d.ts","sourceRoot":"","sources":["../../src/auth/deleteUser.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAQnC,wBAAsB,WAAW,CAAC,MAAM,EAAE,QAAQ,iBAQjD;AAED,wBAAsB,WAAW,CAAC,MAAM,EAAE,QAAQ,iBASjD;AAED,wBAAsB,UAAU,CAAC,MAAM,EAAE,QAAQ,iBAiBhD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { randomUUID } from 'crypto';
|
|
2
|
+
import { usersCollection, emailVerificationTokensCollection, resetPasswordTokensCollection, } from './db';
|
|
3
|
+
export async function clearTokens(userId) {
|
|
4
|
+
await emailVerificationTokensCollection.deleteMany({
|
|
5
|
+
userId,
|
|
6
|
+
});
|
|
7
|
+
await resetPasswordTokensCollection.deleteMany({
|
|
8
|
+
userId,
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
export async function disableUser(userId) {
|
|
12
|
+
await clearTokens(userId);
|
|
13
|
+
await usersCollection.updateOne(userId, {
|
|
14
|
+
$set: {
|
|
15
|
+
status: 'disabled',
|
|
16
|
+
disabledAt: new Date(),
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
export async function deleteUser(userId) {
|
|
21
|
+
await clearTokens(userId);
|
|
22
|
+
await usersCollection.updateOne({
|
|
23
|
+
_id: userId,
|
|
24
|
+
}, {
|
|
25
|
+
$set: {
|
|
26
|
+
handle: `deleted-${userId}-${randomUUID()}`,
|
|
27
|
+
status: 'deleted',
|
|
28
|
+
deletedAt: new Date(),
|
|
29
|
+
authMethods: {},
|
|
30
|
+
emails: [],
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=deleteUser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteUser.js","sourceRoot":"","sources":["../../src/auth/deleteUser.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EACL,eAAe,EACf,iCAAiC,EACjC,6BAA6B,GAC9B,MAAM,MAAM,CAAC;AAEd,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,MAAgB;IAChD,MAAM,iCAAiC,CAAC,UAAU,CAAC;QACjD,MAAM;KACP,CAAC,CAAC;IAEH,MAAM,6BAA6B,CAAC,UAAU,CAAC;QAC7C,MAAM;KACP,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,MAAgB;IAChD,MAAM,WAAW,CAAC,MAAM,CAAC,CAAC;IAE1B,MAAM,eAAe,CAAC,SAAS,CAAC,MAAM,EAAE;QACtC,IAAI,EAAE;YACJ,MAAM,EAAE,UAAU;YAClB,UAAU,EAAE,IAAI,IAAI,EAAE;SACvB;KACF,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,MAAgB;IAC/C,MAAM,WAAW,CAAC,MAAM,CAAC,CAAC;IAE1B,MAAM,eAAe,CAAC,SAAS,CAC7B;QACE,GAAG,EAAE,MAAM;KACZ,EACD;QACE,IAAI,EAAE;YACJ,MAAM,EAAE,WAAW,MAAM,IAAI,UAAU,EAAE,EAAE;YAC3C,MAAM,EAAE,SAAS;YACjB,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,WAAW,EAAE,EAAE;YACf,MAAM,EAAE,EAAE;SACX;KACF,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"disposableEmails.d.ts","sourceRoot":"","sources":["../../src/auth/disposableEmails.ts"],"names":[],"mappings":"AAGA,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CASvE;AAED,eAAO,MAAM,6BAA6B;;;CA6CzC,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { time } from '../time';
|
|
2
|
+
import { dbDisposableEmailDomains } from './db';
|
|
3
|
+
export async function isDisposableEmail(email) {
|
|
4
|
+
const emailParts = email.toLowerCase().trim().split('@');
|
|
5
|
+
if (emailParts.length !== 2) {
|
|
6
|
+
return false;
|
|
7
|
+
}
|
|
8
|
+
const domain = emailParts[1];
|
|
9
|
+
const result = await dbDisposableEmailDomains.findOne({ domain });
|
|
10
|
+
return Boolean(result);
|
|
11
|
+
}
|
|
12
|
+
export const updateDisposableEmailListCron = {
|
|
13
|
+
interval: time.days(1),
|
|
14
|
+
async handler() {
|
|
15
|
+
const response = await fetch('https://disposable.github.io/disposable-email-domains/domains.txt');
|
|
16
|
+
if (!response.ok) {
|
|
17
|
+
throw new Error(`HTTP ${response.status}: ${response.statusText}`);
|
|
18
|
+
}
|
|
19
|
+
const domainsText = await response.text();
|
|
20
|
+
const domains = domainsText
|
|
21
|
+
.split('\n')
|
|
22
|
+
.map((domain) => domain.trim().toLowerCase())
|
|
23
|
+
.filter((domain) => domain.length > 0);
|
|
24
|
+
const now = new Date();
|
|
25
|
+
// Insert domains in batches to avoid overwhelming the database
|
|
26
|
+
const batchSize = 500;
|
|
27
|
+
for (let i = 0; i < domains.length; i += batchSize) {
|
|
28
|
+
const batch = domains.slice(i, i + batchSize);
|
|
29
|
+
try {
|
|
30
|
+
await dbDisposableEmailDomains.insertMany(batch.map((domain) => ({
|
|
31
|
+
domain,
|
|
32
|
+
addedAt: now,
|
|
33
|
+
})));
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
// MongoDB throws BulkWriteError when some documents are duplicates
|
|
37
|
+
if (error &&
|
|
38
|
+
typeof error === 'object' &&
|
|
39
|
+
'name' in error &&
|
|
40
|
+
error.name === 'MongoBulkWriteError') {
|
|
41
|
+
// console.warn(`Error inserting batch starting at index ${i}:`, error.message);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=disposableEmails.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"disposableEmails.js","sourceRoot":"","sources":["../../src/auth/disposableEmails.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAC/B,OAAO,EAAE,wBAAwB,EAAE,MAAM,MAAM,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,KAAa;IACnD,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACzD,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;IAC7B,MAAM,MAAM,GAAG,MAAM,wBAAwB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAClE,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC;AACzB,CAAC;AAED,MAAM,CAAC,MAAM,6BAA6B,GAAG;IAC3C,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACtB,KAAK,CAAC,OAAO;QACX,MAAM,QAAQ,GAAG,MAAM,KAAK,CAC1B,mEAAmE,CACpE,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,QAAQ,QAAQ,CAAC,MAAM,KAAK,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;QACrE,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAE1C,MAAM,OAAO,GAAG,WAAW;aACxB,KAAK,CAAC,IAAI,CAAC;aACX,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;aAC5C,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEzC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QAEvB,+DAA+D;QAC/D,MAAM,SAAS,GAAG,GAAG,CAAC;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC;YACnD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC;YAE9C,IAAI,CAAC;gBACH,MAAM,wBAAwB,CAAC,UAAU,CACvC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACrB,MAAM;oBACN,OAAO,EAAE,GAAG;iBACb,CAAC,CAAC,CACJ,CAAC;YACJ,CAAC;YAAC,OAAO,KAAc,EAAE,CAAC;gBACxB,mEAAmE;gBACnE,IACE,KAAK;oBACL,OAAO,KAAK,KAAK,QAAQ;oBACzB,MAAM,IAAI,KAAK;oBACf,KAAK,CAAC,IAAI,KAAK,qBAAqB,EACpC,CAAC;oBACD,gFAAgF;gBAClF,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAElD,wBAAsB,YAAY,CAChC,SAAS,EAAE,MAAM,GAAG,IAAI,GACvB,OAAO,CAAC;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,IAAI,EAAE,QAAQ,GAAG,IAAI,CAAC;IAAC,KAAK,EAAE,IAAI,EAAE,CAAA;CAAE,CAAC,CA8BrE"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { ObjectId } from 'mongodb';
|
|
2
|
+
import { obtainSession } from './session';
|
|
3
|
+
import { usersCollection } from './db';
|
|
4
|
+
import { getDefaultAuthenticatedRoles, getUnauthenticatedRoles } from './role';
|
|
5
|
+
export async function authenticate(authToken) {
|
|
6
|
+
const session = await obtainSession(authToken);
|
|
7
|
+
const userDoc = session.userId
|
|
8
|
+
? await usersCollection.findOne({
|
|
9
|
+
_id: new ObjectId(session.userId),
|
|
10
|
+
status: { $nin: ['deleted', 'disabled'] },
|
|
11
|
+
})
|
|
12
|
+
: null;
|
|
13
|
+
const user = userDoc
|
|
14
|
+
? {
|
|
15
|
+
id: userDoc._id.toString(),
|
|
16
|
+
handle: userDoc.handle,
|
|
17
|
+
roles: userDoc.roles || [],
|
|
18
|
+
hasRole: (role) => (userDoc.roles || []).includes(role),
|
|
19
|
+
requireRole: (role) => {
|
|
20
|
+
if (!(userDoc.roles || []).includes(role)) {
|
|
21
|
+
throw new Error(`Access denied - role '${role}' required`);
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
}
|
|
25
|
+
: null;
|
|
26
|
+
const roles = user ? getDefaultAuthenticatedRoles() : getUnauthenticatedRoles();
|
|
27
|
+
return {
|
|
28
|
+
user,
|
|
29
|
+
session,
|
|
30
|
+
roles,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvC,OAAO,EAAE,4BAA4B,EAAE,uBAAuB,EAAE,MAAM,QAAQ,CAAC;AAG/E,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,SAAwB;IAExB,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,SAAS,CAAC,CAAC;IAE/C,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM;QAC5B,CAAC,CAAC,MAAM,eAAe,CAAC,OAAO,CAAC;YAC5B,GAAG,EAAE,IAAI,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC;YACjC,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,SAAS,EAAE,UAAU,CAAC,EAAE;SAC1C,CAAC;QACJ,CAAC,CAAC,IAAI,CAAC;IACT,MAAM,IAAI,GAAG,OAAO;QAClB,CAAC,CAAC;YACE,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE;YAC1B,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,EAAE;YAC1B,OAAO,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;YAC/D,WAAW,EAAE,CAAC,IAAY,EAAE,EAAE;gBAC5B,IAAI,CAAC,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC1C,MAAM,IAAI,KAAK,CAAC,yBAAyB,IAAI,YAAY,CAAC,CAAC;gBAC7D,CAAC;YACH,CAAC;SACF;QACH,CAAC,CAAC,IAAI,CAAC;IAET,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,4BAA4B,EAAE,CAAC,CAAC,CAAC,uBAAuB,EAAE,CAAC;IAEhF,OAAO;QACL,IAAI;QACJ,OAAO;QACP,KAAK;KACN,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Args, Context } from '../methods/types';
|
|
2
|
+
export declare function handleLoginWithPassword(args: Args, { user, session, connectionInfo }: Context): Promise<{
|
|
3
|
+
user: {
|
|
4
|
+
id: import("bson").ObjectId;
|
|
5
|
+
handle: string;
|
|
6
|
+
};
|
|
7
|
+
}>;
|
|
8
|
+
export declare function handleLogout(args: Args, { session }: Context): Promise<void>;
|
|
9
|
+
//# sourceMappingURL=login.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../src/auth/login.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAUjD,wBAAsB,uBAAuB,CAC3C,IAAI,EAAE,IAAI,EACV,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,OAAO;;;;;GA8F3C;AAED,wBAAsB,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,EAAE,OAAO,iBAMlE"}
|