modelence 0.9.0-dev.0 → 0.9.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/bin/modelence.js +3 -57
- package/dist/bin/modelence.js.map +1 -1
- package/dist/chunk-3S2FFBNS.js +2 -0
- package/dist/chunk-3S2FFBNS.js.map +1 -0
- package/dist/chunk-55J6XMHW.js +2 -0
- package/dist/chunk-55J6XMHW.js.map +1 -0
- package/dist/chunk-C3UESBRX.js +2 -0
- package/dist/chunk-C3UESBRX.js.map +1 -0
- package/dist/chunk-DO5TZLF5.js +2 -0
- package/dist/chunk-DO5TZLF5.js.map +1 -0
- package/dist/chunk-PB6WQQ4L.js +3 -0
- package/dist/chunk-PB6WQQ4L.js.map +1 -0
- package/dist/chunk-YOLALUSB.js +3 -0
- package/dist/chunk-YOLALUSB.js.map +1 -0
- package/dist/client.d.ts +133 -10
- package/dist/client.js +1 -14
- package/dist/client.js.map +1 -1
- package/dist/index-CwdohC5n.d.ts +15 -0
- package/dist/index.d.ts +31 -6
- package/dist/index.js +1 -2
- package/dist/index.js.map +1 -1
- package/dist/mongo.d.ts +3 -2
- package/dist/mongo.js +1 -2
- package/dist/mongo.js.map +1 -1
- package/dist/package-FGEKA4ES.js +2 -0
- package/dist/package-FGEKA4ES.js.map +1 -0
- package/dist/server.d.ts +537 -19
- package/dist/server.js +18 -15
- package/dist/server.js.map +1 -1
- package/dist/telemetry.d.ts +11 -2
- package/dist/telemetry.js +1 -1
- package/dist/telemetry.js.map +1 -1
- package/dist/types-BOFsm7A2.d.ts +155 -0
- package/dist/{data/store.d.ts → types-SXHKNPNY.d.ts} +196 -14
- package/dist/types.d.ts +7 -10
- package/dist/types.js +1 -1
- package/dist/types.js.map +1 -1
- package/package.json +6 -5
- package/dist/app/authConfig.d.ts +0 -68
- package/dist/app/authConfig.d.ts.map +0 -1
- package/dist/app/authConfig.js +0 -8
- package/dist/app/authConfig.js.map +0 -1
- package/dist/app/backendApi.d.ts +0 -29
- package/dist/app/backendApi.d.ts.map +0 -1
- package/dist/app/backendApi.js +0 -69
- package/dist/app/backendApi.js.map +0 -1
- package/dist/app/email.d.ts +0 -3
- package/dist/app/email.d.ts.map +0 -1
- package/dist/app/email.js +0 -8
- package/dist/app/email.js.map +0 -1
- package/dist/app/emailConfig.d.ts +0 -27
- package/dist/app/emailConfig.d.ts.map +0 -1
- package/dist/app/emailConfig.js +0 -8
- package/dist/app/emailConfig.js.map +0 -1
- package/dist/app/index.d.ts +0 -20
- package/dist/app/index.d.ts.map +0 -1
- package/dist/app/index.js +0 -258
- package/dist/app/index.js.map +0 -1
- package/dist/app/loggerProcess.d.ts +0 -5
- package/dist/app/loggerProcess.d.ts.map +0 -1
- package/dist/app/loggerProcess.js +0 -90
- package/dist/app/loggerProcess.js.map +0 -1
- package/dist/app/metrics.d.ts +0 -6
- package/dist/app/metrics.d.ts.map +0 -1
- package/dist/app/metrics.js +0 -92
- package/dist/app/metrics.js.map +0 -1
- package/dist/app/module.d.ts +0 -77
- package/dist/app/module.d.ts.map +0 -1
- package/dist/app/module.js +0 -46
- package/dist/app/module.js.map +0 -1
- package/dist/app/server.d.ts +0 -37
- package/dist/app/server.d.ts.map +0 -1
- package/dist/app/server.js +0 -198
- package/dist/app/server.js.map +0 -1
- package/dist/app/state.d.ts +0 -19
- package/dist/app/state.d.ts.map +0 -1
- package/dist/app/state.js +0 -27
- package/dist/app/state.js.map +0 -1
- package/dist/app/websocketConfig.d.ts +0 -7
- package/dist/app/websocketConfig.d.ts.map +0 -1
- package/dist/app/websocketConfig.js +0 -8
- package/dist/app/websocketConfig.js.map +0 -1
- package/dist/auth/client/index.d.ts +0 -69
- package/dist/auth/client/index.d.ts.map +0 -1
- package/dist/auth/client/index.js +0 -79
- package/dist/auth/client/index.js.map +0 -1
- package/dist/auth/db.d.ts +0 -176
- package/dist/auth/db.d.ts.map +0 -1
- package/dist/auth/db.js +0 -117
- package/dist/auth/db.js.map +0 -1
- package/dist/auth/deleteUser.d.ts +0 -5
- package/dist/auth/deleteUser.d.ts.map +0 -1
- package/dist/auth/deleteUser.js +0 -34
- package/dist/auth/deleteUser.js.map +0 -1
- package/dist/auth/disposableEmails.d.ts +0 -6
- package/dist/auth/disposableEmails.d.ts.map +0 -1
- package/dist/auth/disposableEmails.js +0 -47
- package/dist/auth/disposableEmails.js.map +0 -1
- package/dist/auth/index.d.ts +0 -7
- package/dist/auth/index.d.ts.map +0 -1
- package/dist/auth/index.js +0 -33
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/login.d.ts +0 -9
- package/dist/auth/login.d.ts.map +0 -1
- package/dist/auth/login.js +0 -100
- package/dist/auth/login.js.map +0 -1
- package/dist/auth/password.d.ts +0 -14
- package/dist/auth/password.d.ts.map +0 -1
- package/dist/auth/password.js +0 -26
- package/dist/auth/password.js.map +0 -1
- package/dist/auth/profile.d.ts +0 -10
- package/dist/auth/profile.d.ts.map +0 -1
- package/dist/auth/profile.js +0 -13
- package/dist/auth/profile.js.map +0 -1
- package/dist/auth/providers/github.d.ts +0 -3
- package/dist/auth/providers/github.d.ts.map +0 -1
- package/dist/auth/providers/github.js +0 -122
- package/dist/auth/providers/github.js.map +0 -1
- package/dist/auth/providers/google.d.ts +0 -3
- package/dist/auth/providers/google.d.ts.map +0 -1
- package/dist/auth/providers/google.js +0 -108
- package/dist/auth/providers/google.js.map +0 -1
- package/dist/auth/providers/oauth-common.d.ts +0 -13
- package/dist/auth/providers/oauth-common.d.ts.map +0 -1
- package/dist/auth/providers/oauth-common.js +0 -109
- package/dist/auth/providers/oauth-common.js.map +0 -1
- package/dist/auth/resetPassword.d.ts +0 -10
- package/dist/auth/resetPassword.d.ts.map +0 -1
- package/dist/auth/resetPassword.js +0 -108
- package/dist/auth/resetPassword.js.map +0 -1
- package/dist/auth/role.d.ts +0 -8
- package/dist/auth/role.d.ts.map +0 -1
- package/dist/auth/role.js +0 -37
- package/dist/auth/role.js.map +0 -1
- package/dist/auth/session.d.ts +0 -24
- package/dist/auth/session.d.ts.map +0 -1
- package/dist/auth/session.js +0 -84
- package/dist/auth/session.js.map +0 -1
- package/dist/auth/signup.d.ts +0 -3
- package/dist/auth/signup.d.ts.map +0 -1
- package/dist/auth/signup.js +0 -89
- package/dist/auth/signup.js.map +0 -1
- package/dist/auth/templates/emailVerficationTemplate.d.ts +0 -6
- package/dist/auth/templates/emailVerficationTemplate.d.ts.map +0 -1
- package/dist/auth/templates/emailVerficationTemplate.js +0 -9
- package/dist/auth/templates/emailVerficationTemplate.js.map +0 -1
- package/dist/auth/types.d.ts +0 -22
- package/dist/auth/types.d.ts.map +0 -1
- package/dist/auth/types.js +0 -2
- package/dist/auth/types.js.map +0 -1
- package/dist/auth/user.d.ts +0 -5
- package/dist/auth/user.d.ts.map +0 -1
- package/dist/auth/user.js +0 -152
- package/dist/auth/user.js.map +0 -1
- package/dist/auth/validators.d.ts +0 -3
- package/dist/auth/validators.d.ts.map +0 -1
- package/dist/auth/validators.js +0 -8
- package/dist/auth/validators.js.map +0 -1
- package/dist/auth/verification.d.ts +0 -8
- package/dist/auth/verification.d.ts.map +0 -1
- package/dist/auth/verification.js +0 -94
- package/dist/auth/verification.js.map +0 -1
- package/dist/bin/auth.d.ts +0 -4
- package/dist/bin/auth.d.ts.map +0 -1
- package/dist/bin/auth.js +0 -48
- package/dist/bin/auth.js.map +0 -1
- package/dist/bin/build.d.ts +0 -2
- package/dist/bin/build.d.ts.map +0 -1
- package/dist/bin/build.js +0 -78
- package/dist/bin/build.js.map +0 -1
- package/dist/bin/config.d.ts +0 -11
- package/dist/bin/config.d.ts.map +0 -1
- package/dist/bin/config.js +0 -91
- package/dist/bin/config.js.map +0 -1
- package/dist/bin/deploy.d.ts +0 -6
- package/dist/bin/deploy.d.ts.map +0 -1
- package/dist/bin/deploy.js +0 -129
- package/dist/bin/deploy.js.map +0 -1
- package/dist/bin/dev.d.ts +0 -2
- package/dist/bin/dev.d.ts.map +0 -1
- package/dist/bin/dev.js +0 -14
- package/dist/bin/dev.js.map +0 -1
- package/dist/bin/modelence.d.ts +0 -3
- package/dist/bin/modelence.d.ts.map +0 -1
- package/dist/bin/setup.d.ts +0 -5
- package/dist/bin/setup.d.ts.map +0 -1
- package/dist/bin/setup.js +0 -91
- package/dist/bin/setup.js.map +0 -1
- package/dist/bin/start.d.ts +0 -2
- package/dist/bin/start.d.ts.map +0 -1
- package/dist/bin/start.js +0 -15
- package/dist/bin/start.js.map +0 -1
- package/dist/client/AppProvider.d.ts +0 -8
- package/dist/client/AppProvider.d.ts.map +0 -1
- package/dist/client/AppProvider.js +0 -31
- package/dist/client/AppProvider.js.map +0 -1
- package/dist/client/errorHandler.d.ts +0 -4
- package/dist/client/errorHandler.d.ts.map +0 -1
- package/dist/client/errorHandler.js +0 -10
- package/dist/client/errorHandler.js.map +0 -1
- package/dist/client/localStorage.d.ts +0 -3
- package/dist/client/localStorage.d.ts.map +0 -1
- package/dist/client/localStorage.js +0 -14
- package/dist/client/localStorage.js.map +0 -1
- package/dist/client/method.d.ts +0 -6
- package/dist/client/method.d.ts.map +0 -1
- package/dist/client/method.js +0 -52
- package/dist/client/method.js.map +0 -1
- package/dist/client/renderApp.d.ts +0 -9
- package/dist/client/renderApp.d.ts.map +0 -1
- package/dist/client/renderApp.js +0 -28
- package/dist/client/renderApp.js.map +0 -1
- package/dist/client/session.d.ts +0 -34
- package/dist/client/session.d.ts.map +0 -1
- package/dist/client/session.js +0 -83
- package/dist/client/session.js.map +0 -1
- package/dist/client.d.ts.map +0 -1
- package/dist/config/client.d.ts +0 -10
- package/dist/config/client.d.ts.map +0 -1
- package/dist/config/client.js +0 -14
- package/dist/config/client.js.map +0 -1
- package/dist/config/server.d.ts +0 -48
- package/dist/config/server.d.ts.map +0 -1
- package/dist/config/server.js +0 -85
- package/dist/config/server.js.map +0 -1
- package/dist/config/sync.d.ts +0 -2
- package/dist/config/sync.d.ts.map +0 -1
- package/dist/config/sync.js +0 -32
- package/dist/config/sync.js.map +0 -1
- package/dist/config/types.d.ts +0 -19
- package/dist/config/types.d.ts.map +0 -1
- package/dist/config/types.js +0 -2
- package/dist/config/types.js.map +0 -1
- package/dist/cron/jobs.d.ts +0 -13
- package/dist/cron/jobs.d.ts.map +0 -1
- package/dist/cron/jobs.js +0 -155
- package/dist/cron/jobs.js.map +0 -1
- package/dist/cron/types.d.ts +0 -29
- package/dist/cron/types.d.ts.map +0 -1
- package/dist/cron/types.js +0 -2
- package/dist/cron/types.js.map +0 -1
- package/dist/data/schemaSerializer.d.ts +0 -37
- package/dist/data/schemaSerializer.d.ts.map +0 -1
- package/dist/data/schemaSerializer.js +0 -104
- package/dist/data/schemaSerializer.js.map +0 -1
- package/dist/data/store.d.ts.map +0 -1
- package/dist/data/store.js +0 -501
- package/dist/data/store.js.map +0 -1
- package/dist/data/types.d.ts +0 -47
- package/dist/data/types.d.ts.map +0 -1
- package/dist/data/types.js +0 -35
- package/dist/data/types.js.map +0 -1
- package/dist/db/client.d.ts +0 -5
- package/dist/db/client.d.ts.map +0 -1
- package/dist/db/client.js +0 -41
- package/dist/db/client.js.map +0 -1
- package/dist/error.d.ts +0 -16
- package/dist/error.d.ts.map +0 -1
- package/dist/error.js +0 -24
- package/dist/error.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/lock/db.d.ts +0 -19
- package/dist/lock/db.d.ts.map +0 -1
- package/dist/lock/db.js +0 -28
- package/dist/lock/db.js.map +0 -1
- package/dist/lock/helpers.d.ts +0 -28
- package/dist/lock/helpers.d.ts.map +0 -1
- package/dist/lock/helpers.js +0 -107
- package/dist/lock/helpers.js.map +0 -1
- package/dist/lock/index.d.ts +0 -4
- package/dist/lock/index.d.ts.map +0 -1
- package/dist/lock/index.js +0 -4
- package/dist/lock/index.js.map +0 -1
- package/dist/lock/module.d.ts +0 -7
- package/dist/lock/module.d.ts.map +0 -1
- package/dist/lock/module.js +0 -9
- package/dist/lock/module.js.map +0 -1
- package/dist/methods/index.d.ts +0 -7
- package/dist/methods/index.d.ts.map +0 -1
- package/dist/methods/index.js +0 -65
- package/dist/methods/index.js.map +0 -1
- package/dist/methods/serialize.d.ts +0 -15
- package/dist/methods/serialize.d.ts.map +0 -1
- package/dist/methods/serialize.js +0 -56
- package/dist/methods/serialize.js.map +0 -1
- package/dist/methods/types.d.ts +0 -37
- package/dist/methods/types.d.ts.map +0 -1
- package/dist/methods/types.js +0 -2
- package/dist/methods/types.js.map +0 -1
- package/dist/migration/db.d.ts +0 -17
- package/dist/migration/db.d.ts.map +0 -1
- package/dist/migration/db.js +0 -13
- package/dist/migration/db.js.map +0 -1
- package/dist/migration/index.d.ts +0 -11
- package/dist/migration/index.d.ts.map +0 -1
- package/dist/migration/index.js +0 -85
- package/dist/migration/index.js.map +0 -1
- package/dist/mongo.d.ts.map +0 -1
- package/dist/rate-limit/db.d.ts +0 -29
- package/dist/rate-limit/db.d.ts.map +0 -1
- package/dist/rate-limit/db.js +0 -25
- package/dist/rate-limit/db.js.map +0 -1
- package/dist/rate-limit/index.d.ts +0 -4
- package/dist/rate-limit/index.d.ts.map +0 -1
- package/dist/rate-limit/index.js +0 -6
- package/dist/rate-limit/index.js.map +0 -1
- package/dist/rate-limit/rules.d.ts +0 -22
- package/dist/rate-limit/rules.d.ts.map +0 -1
- package/dist/rate-limit/rules.js +0 -112
- package/dist/rate-limit/rules.js.map +0 -1
- package/dist/rate-limit/types.d.ts +0 -12
- package/dist/rate-limit/types.d.ts.map +0 -1
- package/dist/rate-limit/types.js +0 -2
- package/dist/rate-limit/types.js.map +0 -1
- package/dist/routes/handler.d.ts +0 -4
- package/dist/routes/handler.d.ts.map +0 -1
- package/dist/routes/handler.js +0 -66
- package/dist/routes/handler.js.map +0 -1
- package/dist/routes/types.d.ts +0 -45
- package/dist/routes/types.d.ts.map +0 -1
- package/dist/routes/types.js +0 -2
- package/dist/routes/types.js.map +0 -1
- package/dist/server.d.ts.map +0 -1
- package/dist/system/index.d.ts +0 -4
- package/dist/system/index.d.ts.map +0 -1
- package/dist/system/index.js +0 -21
- package/dist/system/index.js.map +0 -1
- package/dist/telemetry/index.d.ts +0 -11
- package/dist/telemetry/index.d.ts.map +0 -1
- package/dist/telemetry/index.js +0 -79
- package/dist/telemetry/index.js.map +0 -1
- package/dist/telemetry.d.ts.map +0 -1
- package/dist/time.d.ts +0 -8
- package/dist/time.d.ts.map +0 -1
- package/dist/time.js +0 -13
- package/dist/time.js.map +0 -1
- package/dist/types/email.d.ts +0 -25
- package/dist/types/email.d.ts.map +0 -1
- package/dist/types/email.js +0 -2
- package/dist/types/email.js.map +0 -1
- package/dist/types/index.d.ts +0 -14
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -2
- package/dist/types/index.js.map +0 -1
- package/dist/types.d.ts.map +0 -1
- package/dist/utils/index.d.ts +0 -4
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js +0 -15
- package/dist/utils/index.js.map +0 -1
- package/dist/viteServer.d.ts +0 -13
- package/dist/viteServer.d.ts.map +0 -1
- package/dist/viteServer.js +0 -132
- package/dist/viteServer.js.map +0 -1
- package/dist/websocket/client.d.ts +0 -9
- package/dist/websocket/client.d.ts.map +0 -1
- package/dist/websocket/client.js +0 -16
- package/dist/websocket/client.js.map +0 -1
- package/dist/websocket/clientChannel.d.ts +0 -9
- package/dist/websocket/clientChannel.d.ts.map +0 -1
- package/dist/websocket/clientChannel.js +0 -26
- package/dist/websocket/clientChannel.js.map +0 -1
- package/dist/websocket/serverChannel.d.ts +0 -14
- package/dist/websocket/serverChannel.d.ts.map +0 -1
- package/dist/websocket/serverChannel.js +0 -21
- package/dist/websocket/serverChannel.js.map +0 -1
- package/dist/websocket/socketio/client.d.ts +0 -4
- package/dist/websocket/socketio/client.d.ts.map +0 -1
- package/dist/websocket/socketio/client.js +0 -48
- package/dist/websocket/socketio/client.js.map +0 -1
- package/dist/websocket/socketio/server.d.ts +0 -10
- package/dist/websocket/socketio/server.d.ts.map +0 -1
- package/dist/websocket/socketio/server.js +0 -80
- package/dist/websocket/socketio/server.js.map +0 -1
- package/dist/websocket/types.d.ts +0 -45
- package/dist/websocket/types.d.ts.map +0 -1
- package/dist/websocket/types.js +0 -2
- package/dist/websocket/types.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.d.ts","sourceRoot":"","sources":["../../src/auth/session.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGtC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,eAAO,MAAM,kBAAkB;;;;;;;;;;;;2BAS7B,CAAC;AAEH,wBAAsB,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,CAY9E;AAED,wBAAsB,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,iBAOvE;AAED,wBAAsB,gBAAgB,CAAC,SAAS,EAAE,MAAM,iBAOvD;AAED,wBAAsB,aAAa,CAAC,MAAM,GAAE,QAAQ,GAAG,IAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAmBpF;;AAiBD,wBAmBG"}
|
package/dist/auth/session.js
DELETED
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { randomBytes } from 'crypto';
|
|
2
|
-
import { Module } from '../app/module';
|
|
3
|
-
import { getPublicConfigs } from '../config/server';
|
|
4
|
-
import { Store } from '../data/store';
|
|
5
|
-
import { schema } from '../data/types';
|
|
6
|
-
import { time } from '../time';
|
|
7
|
-
export const sessionsCollection = new Store('_modelenceSessions', {
|
|
8
|
-
schema: {
|
|
9
|
-
authToken: schema.string(),
|
|
10
|
-
createdAt: schema.date(),
|
|
11
|
-
expiresAt: schema.date(),
|
|
12
|
-
userId: schema.userId().nullable(),
|
|
13
|
-
},
|
|
14
|
-
indexes: [{ key: { authToken: 1 }, unique: true }, { key: { expiresAt: 1 } }],
|
|
15
|
-
// TODO: add TTL index on expiresAt
|
|
16
|
-
});
|
|
17
|
-
export async function obtainSession(authToken) {
|
|
18
|
-
const existingSession = authToken ? await sessionsCollection.findOne({ authToken }) : null;
|
|
19
|
-
if (existingSession) {
|
|
20
|
-
return {
|
|
21
|
-
authToken: String(existingSession.authToken),
|
|
22
|
-
expiresAt: new Date(existingSession.expiresAt),
|
|
23
|
-
userId: existingSession.userId ?? null,
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
return await createSession();
|
|
27
|
-
}
|
|
28
|
-
export async function setSessionUser(authToken, userId) {
|
|
29
|
-
await sessionsCollection.updateOne({ authToken }, {
|
|
30
|
-
$set: { userId },
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
export async function clearSessionUser(authToken) {
|
|
34
|
-
await sessionsCollection.updateOne({ authToken }, {
|
|
35
|
-
$set: { userId: null },
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
export async function createSession(userId = null) {
|
|
39
|
-
// TODO: add rate-limiting and captcha handling
|
|
40
|
-
const authToken = randomBytes(32).toString('base64url');
|
|
41
|
-
const now = Date.now();
|
|
42
|
-
const expiresAt = new Date(now + time.days(7));
|
|
43
|
-
await sessionsCollection.insertOne({
|
|
44
|
-
authToken,
|
|
45
|
-
createdAt: new Date(now),
|
|
46
|
-
expiresAt,
|
|
47
|
-
userId,
|
|
48
|
-
});
|
|
49
|
-
return {
|
|
50
|
-
authToken,
|
|
51
|
-
expiresAt,
|
|
52
|
-
userId,
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
async function processSessionHeartbeat(session) {
|
|
56
|
-
const now = Date.now();
|
|
57
|
-
const newExpiresAt = new Date(now + time.days(7));
|
|
58
|
-
await sessionsCollection.updateOne({ authToken: session.authToken }, {
|
|
59
|
-
$set: {
|
|
60
|
-
lastActiveDate: new Date(now),
|
|
61
|
-
expiresAt: newExpiresAt,
|
|
62
|
-
},
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
export default new Module('_system.session', {
|
|
66
|
-
stores: [sessionsCollection],
|
|
67
|
-
mutations: {
|
|
68
|
-
init: async function (args, { session, user }) {
|
|
69
|
-
// TODO: mark or track app load somewhere
|
|
70
|
-
return {
|
|
71
|
-
session,
|
|
72
|
-
user,
|
|
73
|
-
configs: getPublicConfigs(),
|
|
74
|
-
};
|
|
75
|
-
},
|
|
76
|
-
heartbeat: async function (args, { session }) {
|
|
77
|
-
// Session might not exist if there is no database/authentication setup
|
|
78
|
-
if (session) {
|
|
79
|
-
await processSessionHeartbeat(session);
|
|
80
|
-
}
|
|
81
|
-
},
|
|
82
|
-
},
|
|
83
|
-
});
|
|
84
|
-
//# sourceMappingURL=session.js.map
|
package/dist/auth/session.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/auth/session.ts"],"names":[],"mappings":"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"}
|
package/dist/auth/signup.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"signup.d.ts","sourceRoot":"","sources":["../../src/auth/signup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AASjD,wBAAsB,wBAAwB,CAC5C,IAAI,EAAE,IAAI,EACV,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,OAAO,oCAwG3C"}
|
package/dist/auth/signup.js
DELETED
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import { usersCollection } from './db';
|
|
2
|
-
import { isDisposableEmail } from './disposableEmails';
|
|
3
|
-
import { consumeRateLimit } from '../rate-limit/rules';
|
|
4
|
-
import { sendVerificationEmail } from './verification';
|
|
5
|
-
import { validateEmail, validatePassword } from './validators';
|
|
6
|
-
import { getAuthConfig } from '../app/authConfig';
|
|
7
|
-
import { hashPassword } from './password';
|
|
8
|
-
export async function handleSignupWithPassword(args, { user, session, connectionInfo }) {
|
|
9
|
-
try {
|
|
10
|
-
const email = validateEmail(args.email);
|
|
11
|
-
const password = validatePassword(args.password);
|
|
12
|
-
const ip = connectionInfo?.ip;
|
|
13
|
-
if (ip) {
|
|
14
|
-
await consumeRateLimit({
|
|
15
|
-
bucket: 'signupAttempt',
|
|
16
|
-
type: 'ip',
|
|
17
|
-
value: ip,
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
if (await isDisposableEmail(email)) {
|
|
21
|
-
throw new Error('Please use a permanent email address');
|
|
22
|
-
}
|
|
23
|
-
// TODO: captcha check
|
|
24
|
-
if (user) {
|
|
25
|
-
// TODO: handle cases where a user is already logged in
|
|
26
|
-
}
|
|
27
|
-
const existingUser = await usersCollection.findOne({ 'emails.address': email }, { collation: { locale: 'en', strength: 2 } });
|
|
28
|
-
if (existingUser) {
|
|
29
|
-
const existingEmail = existingUser.emails?.find((e) => e.address === email);
|
|
30
|
-
if (existingUser.status === 'disabled') {
|
|
31
|
-
throw new Error(`User is marked for deletion, please contact support if you want to restore the account.`);
|
|
32
|
-
}
|
|
33
|
-
throw new Error(`User with email already exists: ${existingEmail?.address}`);
|
|
34
|
-
}
|
|
35
|
-
if (ip) {
|
|
36
|
-
await consumeRateLimit({
|
|
37
|
-
bucket: 'signup',
|
|
38
|
-
type: 'ip',
|
|
39
|
-
value: ip,
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
// Hash password with native crypto scrypt (salt is automatically generated)
|
|
43
|
-
const hash = await hashPassword(password);
|
|
44
|
-
const result = await usersCollection.insertOne({
|
|
45
|
-
handle: email,
|
|
46
|
-
status: 'active',
|
|
47
|
-
emails: [
|
|
48
|
-
{
|
|
49
|
-
address: email,
|
|
50
|
-
verified: false,
|
|
51
|
-
},
|
|
52
|
-
],
|
|
53
|
-
createdAt: new Date(),
|
|
54
|
-
authMethods: {
|
|
55
|
-
password: {
|
|
56
|
-
hash,
|
|
57
|
-
},
|
|
58
|
-
},
|
|
59
|
-
});
|
|
60
|
-
const userDocument = await usersCollection.findOne({ _id: result.insertedId }, { readPreference: 'primary' });
|
|
61
|
-
if (!userDocument) {
|
|
62
|
-
throw new Error('User not found');
|
|
63
|
-
}
|
|
64
|
-
await sendVerificationEmail({
|
|
65
|
-
userId: result?.insertedId,
|
|
66
|
-
email,
|
|
67
|
-
baseUrl: connectionInfo?.baseUrl,
|
|
68
|
-
});
|
|
69
|
-
getAuthConfig().onAfterSignup?.({
|
|
70
|
-
user: userDocument,
|
|
71
|
-
session,
|
|
72
|
-
connectionInfo,
|
|
73
|
-
});
|
|
74
|
-
getAuthConfig().signup?.onSuccess?.(userDocument);
|
|
75
|
-
return result.insertedId;
|
|
76
|
-
}
|
|
77
|
-
catch (error) {
|
|
78
|
-
if (error instanceof Error) {
|
|
79
|
-
getAuthConfig().onSignupError?.({
|
|
80
|
-
error,
|
|
81
|
-
session,
|
|
82
|
-
connectionInfo,
|
|
83
|
-
});
|
|
84
|
-
getAuthConfig().signup?.onError?.(error);
|
|
85
|
-
}
|
|
86
|
-
throw error;
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
//# sourceMappingURL=signup.js.map
|
package/dist/auth/signup.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"signup.js","sourceRoot":"","sources":["../../src/auth/signup.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"emailVerficationTemplate.d.ts","sourceRoot":"","sources":["../../../src/auth/templates/emailVerficationTemplate.ts"],"names":[],"mappings":"AAAA,wBAAgB,yBAAyB,CAAC,EACxC,IAAI,EACJ,KAAK,EACL,eAAe,GAChB,EAAE;IACD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,eAAe,EAAE,MAAM,CAAC;CACzB,UAOA"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export function emailVerificationTemplate({ name, email, verificationUrl, }) {
|
|
2
|
-
return `
|
|
3
|
-
<p>Hi${name ? ` ${name}` : ''},</p>
|
|
4
|
-
<p>Please verify your email address ${email} by clicking the link below:</p>
|
|
5
|
-
<p><a href="${verificationUrl}">${verificationUrl}</a></p>
|
|
6
|
-
<p>If you did not request this, please ignore this email.</p>
|
|
7
|
-
`;
|
|
8
|
-
}
|
|
9
|
-
//# sourceMappingURL=emailVerficationTemplate.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"emailVerficationTemplate.js","sourceRoot":"","sources":["../../../src/auth/templates/emailVerficationTemplate.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,yBAAyB,CAAC,EACxC,IAAI,EACJ,KAAK,EACL,eAAe,GAKhB;IACC,OAAO;WACE,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE;0CACS,KAAK;kBAC7B,eAAe,KAAK,eAAe;;GAElD,CAAC;AACJ,CAAC"}
|
package/dist/auth/types.d.ts
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Document, ObjectId } from 'mongodb';
|
|
2
|
-
export type User = Document;
|
|
3
|
-
export type UserInfo = {
|
|
4
|
-
id: string;
|
|
5
|
-
handle: string;
|
|
6
|
-
roles: string[];
|
|
7
|
-
hasRole: (role: string) => boolean;
|
|
8
|
-
requireRole: (role: string) => void;
|
|
9
|
-
};
|
|
10
|
-
export type Role = string;
|
|
11
|
-
export type DefaultRoles = Record<'authenticated' | 'unauthenticated', Role | null>;
|
|
12
|
-
export type Session = {
|
|
13
|
-
authToken: string;
|
|
14
|
-
expiresAt: Date;
|
|
15
|
-
userId: ObjectId | null;
|
|
16
|
-
};
|
|
17
|
-
export type Permission = string;
|
|
18
|
-
export type RoleDefinition = {
|
|
19
|
-
description?: string;
|
|
20
|
-
permissions: Permission[];
|
|
21
|
-
};
|
|
22
|
-
//# sourceMappingURL=types.d.ts.map
|
package/dist/auth/types.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/auth/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE7C,MAAM,MAAM,IAAI,GAAG,QAAQ,CAAC;AAE5B,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,MAAM,MAAM,IAAI,GAAG,MAAM,CAAC;AAE1B,MAAM,MAAM,YAAY,GAAG,MAAM,CAAC,eAAe,GAAG,iBAAiB,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AAEpF,MAAM,MAAM,OAAO,GAAG;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,IAAI,CAAC;IAChB,MAAM,EAAE,QAAQ,GAAG,IAAI,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC;AAEhC,MAAM,MAAM,cAAc,GAAG;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,UAAU,EAAE,CAAC;CAC3B,CAAC"}
|
package/dist/auth/types.js
DELETED
package/dist/auth/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/auth/types.ts"],"names":[],"mappings":""}
|
package/dist/auth/user.d.ts
DELETED
package/dist/auth/user.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../src/auth/user.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAevC,wBAAsB,eAAe,qCAkBpC;;AAED,wBA6HG"}
|
package/dist/auth/user.js
DELETED
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
import { randomBytes } from 'crypto';
|
|
2
|
-
import { Module } from '../app/module';
|
|
3
|
-
import { time } from '../time';
|
|
4
|
-
import { dbDisposableEmailDomains, emailVerificationTokensCollection, resetPasswordTokensCollection, usersCollection, } from './db';
|
|
5
|
-
import { updateDisposableEmailListCron } from './disposableEmails';
|
|
6
|
-
import { handleLoginWithPassword, handleLogout } from './login';
|
|
7
|
-
import { getOwnProfile } from './profile';
|
|
8
|
-
import { handleSignupWithPassword } from './signup';
|
|
9
|
-
import { handleVerifyEmail } from './verification';
|
|
10
|
-
import { handleResetPassword, handleSendResetPasswordToken } from './resetPassword';
|
|
11
|
-
export async function createGuestUser() {
|
|
12
|
-
// TODO: add rate-limiting and captcha handling
|
|
13
|
-
const guestId = randomBytes(9)
|
|
14
|
-
.toString('base64')
|
|
15
|
-
.replace(/[+/]/g, (c) => (c === '+' ? 'a' : 'b'));
|
|
16
|
-
const handle = `guest_${guestId}`;
|
|
17
|
-
// TODO: re-try on handle collision
|
|
18
|
-
const result = await usersCollection.insertOne({
|
|
19
|
-
handle,
|
|
20
|
-
status: 'active',
|
|
21
|
-
createdAt: new Date(),
|
|
22
|
-
authMethods: {},
|
|
23
|
-
});
|
|
24
|
-
return result.insertedId;
|
|
25
|
-
}
|
|
26
|
-
export default new Module('_system.user', {
|
|
27
|
-
stores: [
|
|
28
|
-
usersCollection,
|
|
29
|
-
dbDisposableEmailDomains,
|
|
30
|
-
emailVerificationTokensCollection,
|
|
31
|
-
resetPasswordTokensCollection,
|
|
32
|
-
],
|
|
33
|
-
queries: {
|
|
34
|
-
getOwnProfile,
|
|
35
|
-
},
|
|
36
|
-
mutations: {
|
|
37
|
-
signupWithPassword: handleSignupWithPassword,
|
|
38
|
-
loginWithPassword: handleLoginWithPassword,
|
|
39
|
-
logout: handleLogout,
|
|
40
|
-
sendResetPasswordToken: handleSendResetPasswordToken,
|
|
41
|
-
resetPassword: handleResetPassword,
|
|
42
|
-
},
|
|
43
|
-
cronJobs: {
|
|
44
|
-
updateDisposableEmailList: updateDisposableEmailListCron,
|
|
45
|
-
},
|
|
46
|
-
rateLimits: [
|
|
47
|
-
{
|
|
48
|
-
bucket: 'signup',
|
|
49
|
-
type: 'ip',
|
|
50
|
-
window: time.minutes(15),
|
|
51
|
-
limit: 20,
|
|
52
|
-
},
|
|
53
|
-
{
|
|
54
|
-
bucket: 'signup',
|
|
55
|
-
type: 'ip',
|
|
56
|
-
window: time.days(1),
|
|
57
|
-
limit: 200,
|
|
58
|
-
},
|
|
59
|
-
{
|
|
60
|
-
bucket: 'signupAttempt',
|
|
61
|
-
type: 'ip',
|
|
62
|
-
window: time.minutes(15),
|
|
63
|
-
limit: 50,
|
|
64
|
-
},
|
|
65
|
-
{
|
|
66
|
-
bucket: 'signupAttempt',
|
|
67
|
-
type: 'ip',
|
|
68
|
-
window: time.days(1),
|
|
69
|
-
limit: 500,
|
|
70
|
-
},
|
|
71
|
-
{
|
|
72
|
-
bucket: 'signin',
|
|
73
|
-
type: 'ip',
|
|
74
|
-
window: time.minutes(15),
|
|
75
|
-
limit: 50,
|
|
76
|
-
},
|
|
77
|
-
{
|
|
78
|
-
bucket: 'signin',
|
|
79
|
-
type: 'ip',
|
|
80
|
-
window: time.days(1),
|
|
81
|
-
limit: 500,
|
|
82
|
-
},
|
|
83
|
-
{
|
|
84
|
-
bucket: 'verification',
|
|
85
|
-
type: 'user',
|
|
86
|
-
window: time.minutes(15),
|
|
87
|
-
limit: 3,
|
|
88
|
-
},
|
|
89
|
-
{
|
|
90
|
-
bucket: 'verification',
|
|
91
|
-
type: 'user',
|
|
92
|
-
window: time.days(1),
|
|
93
|
-
limit: 10,
|
|
94
|
-
},
|
|
95
|
-
],
|
|
96
|
-
configSchema: {
|
|
97
|
-
'auth.email.enabled': {
|
|
98
|
-
type: 'boolean',
|
|
99
|
-
isPublic: true,
|
|
100
|
-
default: true,
|
|
101
|
-
},
|
|
102
|
-
'auth.email.from': {
|
|
103
|
-
type: 'string',
|
|
104
|
-
isPublic: false,
|
|
105
|
-
default: '',
|
|
106
|
-
},
|
|
107
|
-
'auth.email.verification': {
|
|
108
|
-
type: 'boolean',
|
|
109
|
-
isPublic: true,
|
|
110
|
-
default: false,
|
|
111
|
-
},
|
|
112
|
-
'auth.google.enabled': {
|
|
113
|
-
type: 'boolean',
|
|
114
|
-
isPublic: true,
|
|
115
|
-
default: false,
|
|
116
|
-
},
|
|
117
|
-
'auth.google.clientId': {
|
|
118
|
-
type: 'string',
|
|
119
|
-
isPublic: false,
|
|
120
|
-
default: '',
|
|
121
|
-
},
|
|
122
|
-
'auth.google.clientSecret': {
|
|
123
|
-
type: 'secret',
|
|
124
|
-
isPublic: false,
|
|
125
|
-
default: '',
|
|
126
|
-
},
|
|
127
|
-
'auth.github.enabled': {
|
|
128
|
-
type: 'boolean',
|
|
129
|
-
isPublic: true,
|
|
130
|
-
default: false,
|
|
131
|
-
},
|
|
132
|
-
'auth.github.clientId': {
|
|
133
|
-
type: 'string',
|
|
134
|
-
isPublic: false,
|
|
135
|
-
default: '',
|
|
136
|
-
},
|
|
137
|
-
'auth.github.clientSecret': {
|
|
138
|
-
type: 'secret',
|
|
139
|
-
isPublic: false,
|
|
140
|
-
default: '',
|
|
141
|
-
},
|
|
142
|
-
},
|
|
143
|
-
routes: [
|
|
144
|
-
{
|
|
145
|
-
path: '/api/_internal/auth/verify-email',
|
|
146
|
-
handlers: {
|
|
147
|
-
get: handleVerifyEmail,
|
|
148
|
-
},
|
|
149
|
-
},
|
|
150
|
-
],
|
|
151
|
-
});
|
|
152
|
-
//# sourceMappingURL=user.js.map
|
package/dist/auth/user.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/auth/user.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validators.d.ts","sourceRoot":"","sources":["../../src/auth/validators.ts"],"names":[],"mappings":"AAEA,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,UAE7C;AAED,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,UAE1C"}
|
package/dist/auth/validators.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
export function validatePassword(value) {
|
|
3
|
-
return z.string().min(8, { message: 'Password must contain at least 8 characters' }).parse(value);
|
|
4
|
-
}
|
|
5
|
-
export function validateEmail(value) {
|
|
6
|
-
return z.string().email({ message: 'Invalid email address' }).parse(value);
|
|
7
|
-
}
|
|
8
|
-
//# sourceMappingURL=validators.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../src/auth/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,MAAM,UAAU,gBAAgB,CAAC,KAAa;IAC5C,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,6CAA6C,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACpG,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,KAAa;IACzC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,uBAAuB,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC7E,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { ObjectId, RouteParams, RouteResponse } from '../server';
|
|
2
|
-
export declare function handleVerifyEmail(params: RouteParams): Promise<RouteResponse>;
|
|
3
|
-
export declare function sendVerificationEmail({ userId, email, baseUrl, }: {
|
|
4
|
-
userId: ObjectId;
|
|
5
|
-
email: string;
|
|
6
|
-
baseUrl?: string;
|
|
7
|
-
}): Promise<void>;
|
|
8
|
-
//# sourceMappingURL=verification.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"verification.d.ts","sourceRoot":"","sources":["../../src/auth/verification.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAOhE,wBAAsB,iBAAiB,CAAC,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,aAAa,CAAC,CAoEnF;AAED,wBAAsB,qBAAqB,CAAC,EAC1C,MAAM,EACN,KAAK,EACL,OAAwC,GACzC,EAAE;IACD,MAAM,EAAE,QAAQ,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,iBAgCA"}
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
2
|
-
import { usersCollection, emailVerificationTokensCollection } from './db';
|
|
3
|
-
import { getEmailConfig } from '../app/emailConfig';
|
|
4
|
-
import { randomBytes } from 'crypto';
|
|
5
|
-
import { time } from '../time';
|
|
6
|
-
import { htmlToText } from '../utils';
|
|
7
|
-
import { emailVerificationTemplate } from './templates/emailVerficationTemplate';
|
|
8
|
-
export async function handleVerifyEmail(params) {
|
|
9
|
-
const baseUrl = process.env.MODELENCE_SITE_URL;
|
|
10
|
-
const emailVerifiedRedirectUrl = getEmailConfig().emailVerifiedRedirectUrl || baseUrl || '/';
|
|
11
|
-
try {
|
|
12
|
-
const token = z.string().parse(params.query.token);
|
|
13
|
-
// Find token in database
|
|
14
|
-
const tokenDoc = await emailVerificationTokensCollection.findOne({
|
|
15
|
-
token,
|
|
16
|
-
expiresAt: { $gt: new Date() },
|
|
17
|
-
});
|
|
18
|
-
if (!tokenDoc) {
|
|
19
|
-
throw new Error('Invalid or expired verification token');
|
|
20
|
-
}
|
|
21
|
-
// Find user by token's userId
|
|
22
|
-
const userDoc = await usersCollection.findOne({ _id: tokenDoc.userId });
|
|
23
|
-
if (!userDoc) {
|
|
24
|
-
throw new Error('User not found');
|
|
25
|
-
}
|
|
26
|
-
const email = tokenDoc.email;
|
|
27
|
-
if (!email) {
|
|
28
|
-
throw new Error('Email not found in token');
|
|
29
|
-
}
|
|
30
|
-
// Mark the specific email as verified atomically
|
|
31
|
-
const updateResult = await usersCollection.updateOne({
|
|
32
|
-
_id: tokenDoc.userId,
|
|
33
|
-
'emails.address': email,
|
|
34
|
-
'emails.verified': { $ne: true },
|
|
35
|
-
}, { $set: { 'emails.$.verified': true } });
|
|
36
|
-
if (updateResult.matchedCount === 0) {
|
|
37
|
-
// Check if email exists but is already verified
|
|
38
|
-
const existingUser = await usersCollection.findOne({
|
|
39
|
-
_id: tokenDoc.userId,
|
|
40
|
-
'emails.address': email,
|
|
41
|
-
});
|
|
42
|
-
if (existingUser) {
|
|
43
|
-
throw new Error('Email is already verified');
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
throw new Error('Email address not found for this user');
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
// Delete the used token
|
|
50
|
-
await emailVerificationTokensCollection.deleteOne({ _id: tokenDoc._id });
|
|
51
|
-
}
|
|
52
|
-
catch (error) {
|
|
53
|
-
if (error instanceof Error) {
|
|
54
|
-
console.error('Error verifying email:', error);
|
|
55
|
-
return {
|
|
56
|
-
status: 301,
|
|
57
|
-
redirect: `${emailVerifiedRedirectUrl}?status=error&message=${encodeURIComponent(error.message)}`,
|
|
58
|
-
};
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return {
|
|
62
|
-
status: 301,
|
|
63
|
-
redirect: `${emailVerifiedRedirectUrl}?status=verified`,
|
|
64
|
-
};
|
|
65
|
-
}
|
|
66
|
-
export async function sendVerificationEmail({ userId, email, baseUrl = process.env.MODELENCE_SITE_URL, }) {
|
|
67
|
-
if (getEmailConfig().provider) {
|
|
68
|
-
const emailProvider = getEmailConfig().provider;
|
|
69
|
-
// Generate verification token
|
|
70
|
-
const verificationToken = randomBytes(32).toString('hex');
|
|
71
|
-
const expiresAt = new Date(Date.now() + time.hours(24));
|
|
72
|
-
// Store token in database
|
|
73
|
-
await emailVerificationTokensCollection.insertOne({
|
|
74
|
-
userId,
|
|
75
|
-
email,
|
|
76
|
-
token: verificationToken,
|
|
77
|
-
createdAt: new Date(),
|
|
78
|
-
expiresAt,
|
|
79
|
-
});
|
|
80
|
-
const verificationUrl = `${baseUrl}/api/_internal/auth/verify-email?token=${verificationToken}`;
|
|
81
|
-
const template = getEmailConfig()?.verification?.template || emailVerificationTemplate;
|
|
82
|
-
// TODO: we should have also the name on this step
|
|
83
|
-
const htmlTemplate = template({ name: '', email, verificationUrl });
|
|
84
|
-
const textContent = htmlToText(htmlTemplate);
|
|
85
|
-
await emailProvider?.sendEmail({
|
|
86
|
-
to: email,
|
|
87
|
-
from: getEmailConfig()?.from || 'noreply@modelence.com',
|
|
88
|
-
subject: getEmailConfig()?.verification?.subject || 'Verify your email address',
|
|
89
|
-
text: textContent,
|
|
90
|
-
html: htmlTemplate,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
//# sourceMappingURL=verification.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"verification.js","sourceRoot":"","sources":["../../src/auth/verification.ts"],"names":[],"mappings":"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"}
|
package/dist/bin/auth.d.ts
DELETED
package/dist/bin/auth.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/bin/auth.ts"],"names":[],"mappings":"AAIA,wBAAsB,eAAe,CAAC,IAAI,EAAE,MAAM;;GAuBjD"}
|
package/dist/bin/auth.js
DELETED
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import open from 'open';
|
|
2
|
-
import { writeFileSync } from 'fs';
|
|
3
|
-
import { join } from 'path';
|
|
4
|
-
export async function authenticateCli(host) {
|
|
5
|
-
// TODO: check if a token already exists in .modelence/auth.json
|
|
6
|
-
const response = await fetch(`${host}/api/cli/auth`, {
|
|
7
|
-
method: 'POST',
|
|
8
|
-
});
|
|
9
|
-
if (!response.ok) {
|
|
10
|
-
throw new Error('Failed to create CLI authentication code');
|
|
11
|
-
}
|
|
12
|
-
const { code, verificationUrl } = await response.json();
|
|
13
|
-
console.log(`Please visit ${verificationUrl} to authenticate`);
|
|
14
|
-
console.log(`Code: ${code}`);
|
|
15
|
-
await open(verificationUrl);
|
|
16
|
-
const token = await waitForAuth(host, code);
|
|
17
|
-
writeFileSync(join(process.cwd(), '.modelence', 'auth.json'), JSON.stringify({ token }));
|
|
18
|
-
return { token };
|
|
19
|
-
}
|
|
20
|
-
async function waitForAuth(host, code) {
|
|
21
|
-
const pollInterval = 5 * 1000; // 5 seconds
|
|
22
|
-
const pollTimeout = 10 * 60 * 1000; // 10 minutes
|
|
23
|
-
const pollExpireTs = Date.now() + pollTimeout;
|
|
24
|
-
while (Date.now() < pollExpireTs) {
|
|
25
|
-
try {
|
|
26
|
-
const token = await pollForToken(host, code);
|
|
27
|
-
if (token) {
|
|
28
|
-
return token;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
catch (error) {
|
|
32
|
-
console.error('Error polling for CLI token:', error);
|
|
33
|
-
}
|
|
34
|
-
await new Promise((resolve) => setTimeout(resolve, pollInterval));
|
|
35
|
-
}
|
|
36
|
-
throw new Error('Unable to authenticate CLI - timed out. Please try again.');
|
|
37
|
-
}
|
|
38
|
-
async function pollForToken(host, code) {
|
|
39
|
-
const response = await fetch(`${host}/api/cli/token?code=${code}`, {
|
|
40
|
-
method: 'GET',
|
|
41
|
-
});
|
|
42
|
-
if (!response.ok) {
|
|
43
|
-
throw new Error(`CLI token polling failed: ${response.statusText}`);
|
|
44
|
-
}
|
|
45
|
-
const { token } = await response.json();
|
|
46
|
-
return token;
|
|
47
|
-
}
|
|
48
|
-
//# sourceMappingURL=auth.js.map
|
package/dist/bin/auth.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/bin/auth.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAE5B,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,IAAY;IAChD,gEAAgE;IAEhE,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,eAAe,EAAE;QACnD,MAAM,EAAE,MAAM;KACf,CAAC,CAAC;IAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;IAExD,OAAO,CAAC,GAAG,CAAC,gBAAgB,eAAe,kBAAkB,CAAC,CAAC;IAC/D,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;IAE7B,MAAM,IAAI,CAAC,eAAe,CAAC,CAAC;IAE5B,MAAM,KAAK,GAAG,MAAM,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAE5C,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,YAAY,EAAE,WAAW,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IAEzF,OAAO,EAAE,KAAK,EAAE,CAAC;AACnB,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,IAAY,EAAE,IAAY;IACnD,MAAM,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,YAAY;IAC3C,MAAM,WAAW,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,aAAa;IACjD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,WAAW,CAAC;IAC9C,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,YAAY,EAAE,CAAC;QACjC,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,MAAM,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC7C,IAAI,KAAK,EAAE,CAAC;gBACV,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,8BAA8B,EAAE,KAAK,CAAC,CAAC;QACvD,CAAC;QACD,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC;AAC/E,CAAC;AAED,KAAK,UAAU,YAAY,CAAC,IAAY,EAAE,IAAY;IACpD,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,uBAAuB,IAAI,EAAE,EAAE;QACjE,MAAM,EAAE,KAAK;KACd,CAAC,CAAC;IAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,6BAA6B,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;IACxC,OAAO,KAAK,CAAC;AACf,CAAC"}
|
package/dist/bin/build.d.ts
DELETED
package/dist/bin/build.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/bin/build.ts"],"names":[],"mappings":"AAiEA,wBAAsB,KAAK,kBAuB1B"}
|