@intlayer/backend 5.5.11 → 5.7.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/README.md +3 -0
- package/dist/cjs/controllers/ai.controller.cjs +10 -7
- package/dist/cjs/controllers/ai.controller.cjs.map +1 -1
- package/dist/cjs/controllers/dictionary.controller.cjs +50 -58
- package/dist/cjs/controllers/dictionary.controller.cjs.map +1 -1
- package/dist/cjs/controllers/eventListener.controller.cjs +2 -18
- package/dist/cjs/controllers/eventListener.controller.cjs.map +1 -1
- package/dist/cjs/controllers/newsletter.controller.cjs +38 -3
- package/dist/cjs/controllers/newsletter.controller.cjs.map +1 -1
- package/dist/cjs/controllers/oAuth2.controller.cjs +3 -3
- package/dist/cjs/controllers/oAuth2.controller.cjs.map +1 -1
- package/dist/cjs/controllers/organization.controller.cjs +92 -106
- package/dist/cjs/controllers/organization.controller.cjs.map +1 -1
- package/dist/cjs/controllers/project.controller.cjs +81 -83
- package/dist/cjs/controllers/project.controller.cjs.map +1 -1
- package/dist/cjs/controllers/projectAccessKey.controller.cjs +30 -24
- package/dist/cjs/controllers/projectAccessKey.controller.cjs.map +1 -1
- package/dist/cjs/controllers/search.controller.cjs.map +1 -1
- package/dist/cjs/controllers/stripe.controller.cjs +4 -25
- package/dist/cjs/controllers/stripe.controller.cjs.map +1 -1
- package/dist/cjs/controllers/tag.controller.cjs +27 -16
- package/dist/cjs/controllers/tag.controller.cjs.map +1 -1
- package/dist/cjs/controllers/user.controller.cjs +88 -24
- package/dist/cjs/controllers/user.controller.cjs.map +1 -1
- package/dist/cjs/emails/InviteUserEmail.cjs +30 -12
- package/dist/cjs/emails/InviteUserEmail.cjs.map +1 -1
- package/dist/cjs/emails/OAuthTokenCreatedEmail.cjs +266 -0
- package/dist/cjs/emails/OAuthTokenCreatedEmail.cjs.map +1 -0
- package/dist/cjs/emails/ResetUserPassword.cjs +27 -15
- package/dist/cjs/emails/ResetUserPassword.cjs.map +1 -1
- package/dist/cjs/emails/ValidateUserEmail.cjs +27 -36
- package/dist/cjs/emails/ValidateUserEmail.cjs.map +1 -1
- package/dist/cjs/emails/Welcome.cjs +27 -15
- package/dist/cjs/emails/Welcome.cjs.map +1 -1
- package/dist/cjs/emails/index.cjs +7 -5
- package/dist/cjs/emails/index.cjs.map +1 -1
- package/dist/cjs/export.cjs +2 -5
- package/dist/cjs/export.cjs.map +1 -1
- package/dist/cjs/index.cjs +61 -111
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/middlewares/oAuth2.middleware.cjs +26 -38
- package/dist/cjs/middlewares/oAuth2.middleware.cjs.map +1 -1
- package/dist/cjs/middlewares/request.middleware.cjs.map +1 -1
- package/dist/cjs/middlewares/sessionAuth.middleware.cjs +17 -138
- package/dist/cjs/middlewares/sessionAuth.middleware.cjs.map +1 -1
- package/dist/cjs/models/dictionary.model.cjs.map +1 -1
- package/dist/cjs/models/discussion.model.cjs.map +1 -1
- package/dist/cjs/models/oAuth2.model.cjs +4 -1
- package/dist/cjs/models/oAuth2.model.cjs.map +1 -1
- package/dist/cjs/models/organization.model.cjs +1 -4
- package/dist/cjs/models/organization.model.cjs.map +1 -1
- package/dist/cjs/models/project.model.cjs +4 -1
- package/dist/cjs/models/project.model.cjs.map +1 -1
- package/dist/cjs/models/session.model.cjs +34 -0
- package/dist/cjs/models/session.model.cjs.map +1 -0
- package/dist/cjs/models/tag.model.cjs.map +1 -1
- package/dist/cjs/models/user.model.cjs.map +1 -1
- package/dist/cjs/routes/ai.routes.cjs +3 -1
- package/dist/cjs/routes/ai.routes.cjs.map +1 -1
- package/dist/cjs/routes/dictionary.routes.cjs.map +1 -1
- package/dist/cjs/routes/eventListener.routes.cjs +1 -1
- package/dist/cjs/routes/eventListener.routes.cjs.map +1 -1
- package/dist/cjs/routes/newsletter.routes.cjs.map +1 -1
- package/dist/cjs/routes/organization.routes.cjs +8 -8
- package/dist/cjs/routes/organization.routes.cjs.map +1 -1
- package/dist/cjs/routes/project.routes.cjs +23 -14
- package/dist/cjs/routes/project.routes.cjs.map +1 -1
- package/dist/cjs/routes/search.routes.cjs.map +1 -1
- package/dist/cjs/routes/stripe.routes.cjs.map +1 -1
- package/dist/cjs/routes/tags.routes.cjs +4 -4
- package/dist/cjs/routes/tags.routes.cjs.map +1 -1
- package/dist/cjs/routes/user.routes.cjs +12 -12
- package/dist/cjs/routes/user.routes.cjs.map +1 -1
- package/dist/cjs/schemas/dictionary.schema.cjs +18 -1
- package/dist/cjs/schemas/dictionary.schema.cjs.map +1 -1
- package/dist/cjs/schemas/discussion.schema.cjs +18 -1
- package/dist/cjs/schemas/discussion.schema.cjs.map +1 -1
- package/dist/cjs/schemas/oAuth2.schema.cjs +18 -1
- package/dist/cjs/schemas/oAuth2.schema.cjs.map +1 -1
- package/dist/cjs/schemas/organization.schema.cjs +21 -1
- package/dist/cjs/schemas/organization.schema.cjs.map +1 -1
- package/dist/cjs/schemas/plans.schema.cjs +18 -1
- package/dist/cjs/schemas/plans.schema.cjs.map +1 -1
- package/dist/cjs/schemas/project.schema.cjs +19 -14
- package/dist/cjs/schemas/project.schema.cjs.map +1 -1
- package/dist/cjs/schemas/session.schema.cjs +63 -0
- package/dist/cjs/schemas/session.schema.cjs.map +1 -0
- package/dist/cjs/schemas/tag.schema.cjs +18 -1
- package/dist/cjs/schemas/tag.schema.cjs.map +1 -1
- package/dist/cjs/schemas/user.schema.cjs +18 -48
- package/dist/cjs/schemas/user.schema.cjs.map +1 -1
- package/dist/cjs/services/dictionary.service.cjs +6 -5
- package/dist/cjs/services/dictionary.service.cjs.map +1 -1
- package/dist/cjs/services/email.service.cjs +13 -0
- package/dist/cjs/services/email.service.cjs.map +1 -1
- package/dist/cjs/services/oAuth2.service.cjs +49 -10
- package/dist/cjs/services/oAuth2.service.cjs.map +1 -1
- package/dist/cjs/services/organization.service.cjs +16 -15
- package/dist/cjs/services/organization.service.cjs.map +1 -1
- package/dist/cjs/services/project.service.cjs +1 -1
- package/dist/cjs/services/project.service.cjs.map +1 -1
- package/dist/cjs/services/projectAccessKey.service.cjs +17 -33
- package/dist/cjs/services/projectAccessKey.service.cjs.map +1 -1
- package/dist/cjs/services/subscription.service.cjs +10 -10
- package/dist/cjs/services/subscription.service.cjs.map +1 -1
- package/dist/cjs/services/tag.service.cjs.map +1 -1
- package/dist/cjs/services/user.service.cjs +2 -42
- package/dist/cjs/services/user.service.cjs.map +1 -1
- package/dist/cjs/types/dictionary.types.cjs.map +1 -1
- package/dist/cjs/types/discussion.types.cjs.map +1 -1
- package/dist/cjs/types/oAuth2.types.cjs.map +1 -1
- package/dist/cjs/types/organization.types.cjs.map +1 -1
- package/dist/cjs/types/plan.types.cjs.map +1 -1
- package/dist/cjs/types/project.types.cjs.map +1 -1
- package/dist/cjs/types/session.types.cjs.map +1 -1
- package/dist/cjs/types/tag.types.cjs.map +1 -1
- package/dist/cjs/types/user.types.cjs.map +1 -1
- package/dist/cjs/utils/AI/aiSdk.cjs.map +1 -1
- package/dist/cjs/utils/AI/askDocQuestion/PROMPT.md +7 -1
- package/dist/cjs/utils/AI/askDocQuestion/askDocQuestion.cjs +32 -14
- package/dist/cjs/utils/AI/askDocQuestion/askDocQuestion.cjs.map +1 -1
- package/dist/cjs/utils/AI/askDocQuestion/embeddings.json +88086 -76800
- package/dist/cjs/utils/AI/autocomplete/PROMPT.md +18 -2
- package/dist/cjs/utils/AI/autocomplete/index.cjs +8 -5
- package/dist/cjs/utils/AI/autocomplete/index.cjs.map +1 -1
- package/dist/cjs/utils/access.cjs +2 -0
- package/dist/cjs/utils/access.cjs.map +1 -0
- package/dist/cjs/utils/accessControl.cjs +7 -0
- package/dist/cjs/utils/accessControl.cjs.map +1 -1
- package/dist/cjs/utils/auth/getAuth.cjs +248 -0
- package/dist/cjs/utils/auth/getAuth.cjs.map +1 -0
- package/dist/cjs/utils/cors.cjs +55 -0
- package/dist/cjs/utils/cors.cjs.map +1 -0
- package/dist/cjs/utils/ensureMongoDocumentToObject.cjs.map +1 -1
- package/dist/cjs/utils/errors/ErrorHandler.cjs +2 -2
- package/dist/cjs/utils/errors/ErrorHandler.cjs.map +1 -1
- package/dist/cjs/utils/errors/errorCodes.cjs +114 -153
- package/dist/cjs/utils/errors/errorCodes.cjs.map +1 -1
- package/dist/cjs/utils/filtersAndPagination/getOrganizationFiltersAndPagination.cjs.map +1 -1
- package/dist/cjs/utils/filtersAndPagination/getProjectFiltersAndPagination.cjs.map +1 -1
- package/dist/cjs/utils/filtersAndPagination/getTagFiltersAndPagination.cjs.map +1 -1
- package/dist/cjs/utils/filtersAndPagination/getUserFiltersAndPagination.cjs +1 -1
- package/dist/cjs/utils/filtersAndPagination/getUserFiltersAndPagination.cjs.map +1 -1
- package/dist/cjs/utils/mapper/dictionary.cjs.map +1 -1
- package/dist/cjs/utils/mapper/organization.cjs +10 -8
- package/dist/cjs/utils/mapper/organization.cjs.map +1 -1
- package/dist/cjs/utils/mapper/project.cjs +5 -18
- package/dist/cjs/utils/mapper/project.cjs.map +1 -1
- package/dist/cjs/utils/mapper/tag.cjs +4 -2
- package/dist/cjs/utils/mapper/tag.cjs.map +1 -1
- package/dist/cjs/utils/mapper/user.cjs +6 -3
- package/dist/cjs/utils/mapper/user.cjs.map +1 -1
- package/dist/cjs/utils/mergeFunctionTypes.cjs +17 -0
- package/dist/cjs/utils/mergeFunctionTypes.cjs.map +1 -0
- package/dist/cjs/utils/mongoDB/connectDB.cjs +3 -1
- package/dist/cjs/utils/mongoDB/connectDB.cjs.map +1 -1
- package/dist/cjs/utils/mongoDB/types.cjs +17 -0
- package/dist/cjs/utils/mongoDB/types.cjs.map +1 -0
- package/dist/cjs/utils/oAuth2.cjs.map +1 -1
- package/dist/cjs/utils/permissions.cjs +166 -0
- package/dist/cjs/utils/permissions.cjs.map +1 -0
- package/dist/cjs/utils/rateLimiter.cjs +88 -0
- package/dist/cjs/utils/rateLimiter.cjs.map +1 -0
- package/dist/esm/controllers/ai.controller.mjs +10 -7
- package/dist/esm/controllers/ai.controller.mjs.map +1 -1
- package/dist/esm/controllers/dictionary.controller.mjs +50 -58
- package/dist/esm/controllers/dictionary.controller.mjs.map +1 -1
- package/dist/esm/controllers/eventListener.controller.mjs +2 -8
- package/dist/esm/controllers/eventListener.controller.mjs.map +1 -1
- package/dist/esm/controllers/newsletter.controller.mjs +38 -3
- package/dist/esm/controllers/newsletter.controller.mjs.map +1 -1
- package/dist/esm/controllers/oAuth2.controller.mjs +2 -2
- package/dist/esm/controllers/oAuth2.controller.mjs.map +1 -1
- package/dist/esm/controllers/organization.controller.mjs +95 -106
- package/dist/esm/controllers/organization.controller.mjs.map +1 -1
- package/dist/esm/controllers/project.controller.mjs +81 -83
- package/dist/esm/controllers/project.controller.mjs.map +1 -1
- package/dist/esm/controllers/projectAccessKey.controller.mjs +30 -24
- package/dist/esm/controllers/projectAccessKey.controller.mjs.map +1 -1
- package/dist/esm/controllers/search.controller.mjs.map +1 -1
- package/dist/esm/controllers/stripe.controller.mjs +4 -25
- package/dist/esm/controllers/stripe.controller.mjs.map +1 -1
- package/dist/esm/controllers/tag.controller.mjs +27 -16
- package/dist/esm/controllers/tag.controller.mjs.map +1 -1
- package/dist/esm/controllers/user.controller.mjs +85 -22
- package/dist/esm/controllers/user.controller.mjs.map +1 -1
- package/dist/esm/emails/InviteUserEmail.mjs +32 -14
- package/dist/esm/emails/InviteUserEmail.mjs.map +1 -1
- package/dist/esm/emails/OAuthTokenCreatedEmail.mjs +254 -0
- package/dist/esm/emails/OAuthTokenCreatedEmail.mjs.map +1 -0
- package/dist/esm/emails/ResetUserPassword.mjs +29 -17
- package/dist/esm/emails/ResetUserPassword.mjs.map +1 -1
- package/dist/esm/emails/ValidateUserEmail.mjs +29 -38
- package/dist/esm/emails/ValidateUserEmail.mjs.map +1 -1
- package/dist/esm/emails/Welcome.mjs +29 -17
- package/dist/esm/emails/Welcome.mjs.map +1 -1
- package/dist/esm/emails/index.mjs +3 -2
- package/dist/esm/emails/index.mjs.map +1 -1
- package/dist/esm/export.mjs +1 -3
- package/dist/esm/export.mjs.map +1 -1
- package/dist/esm/index.mjs +60 -111
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/middlewares/oAuth2.middleware.mjs +27 -36
- package/dist/esm/middlewares/oAuth2.middleware.mjs.map +1 -1
- package/dist/esm/middlewares/request.middleware.mjs.map +1 -1
- package/dist/esm/middlewares/sessionAuth.middleware.mjs +16 -127
- package/dist/esm/middlewares/sessionAuth.middleware.mjs.map +1 -1
- package/dist/esm/models/dictionary.model.mjs.map +1 -1
- package/dist/esm/models/discussion.model.mjs.map +1 -1
- package/dist/esm/models/oAuth2.model.mjs +4 -1
- package/dist/esm/models/oAuth2.model.mjs.map +1 -1
- package/dist/esm/models/organization.model.mjs +1 -4
- package/dist/esm/models/organization.model.mjs.map +1 -1
- package/dist/esm/models/project.model.mjs +4 -1
- package/dist/esm/models/project.model.mjs.map +1 -1
- package/dist/esm/models/session.model.mjs +10 -0
- package/dist/esm/models/session.model.mjs.map +1 -0
- package/dist/esm/models/tag.model.mjs.map +1 -1
- package/dist/esm/models/user.model.mjs.map +1 -1
- package/dist/esm/routes/ai.routes.mjs +3 -1
- package/dist/esm/routes/ai.routes.mjs.map +1 -1
- package/dist/esm/routes/dictionary.routes.mjs.map +1 -1
- package/dist/esm/routes/eventListener.routes.mjs +1 -1
- package/dist/esm/routes/eventListener.routes.mjs.map +1 -1
- package/dist/esm/routes/newsletter.routes.mjs.map +1 -1
- package/dist/esm/routes/organization.routes.mjs +8 -8
- package/dist/esm/routes/organization.routes.mjs.map +1 -1
- package/dist/esm/routes/project.routes.mjs +23 -14
- package/dist/esm/routes/project.routes.mjs.map +1 -1
- package/dist/esm/routes/search.routes.mjs.map +1 -1
- package/dist/esm/routes/stripe.routes.mjs.map +1 -1
- package/dist/esm/routes/tags.routes.mjs +4 -4
- package/dist/esm/routes/tags.routes.mjs.map +1 -1
- package/dist/esm/routes/user.routes.mjs +14 -14
- package/dist/esm/routes/user.routes.mjs.map +1 -1
- package/dist/esm/schemas/dictionary.schema.mjs +18 -1
- package/dist/esm/schemas/dictionary.schema.mjs.map +1 -1
- package/dist/esm/schemas/discussion.schema.mjs +18 -1
- package/dist/esm/schemas/discussion.schema.mjs.map +1 -1
- package/dist/esm/schemas/oAuth2.schema.mjs +18 -1
- package/dist/esm/schemas/oAuth2.schema.mjs.map +1 -1
- package/dist/esm/schemas/organization.schema.mjs +21 -1
- package/dist/esm/schemas/organization.schema.mjs.map +1 -1
- package/dist/esm/schemas/plans.schema.mjs +18 -1
- package/dist/esm/schemas/plans.schema.mjs.map +1 -1
- package/dist/esm/schemas/project.schema.mjs +21 -15
- package/dist/esm/schemas/project.schema.mjs.map +1 -1
- package/dist/esm/schemas/session.schema.mjs +39 -0
- package/dist/esm/schemas/session.schema.mjs.map +1 -0
- package/dist/esm/schemas/tag.schema.mjs +21 -4
- package/dist/esm/schemas/tag.schema.mjs.map +1 -1
- package/dist/esm/schemas/user.schema.mjs +18 -48
- package/dist/esm/schemas/user.schema.mjs.map +1 -1
- package/dist/esm/services/dictionary.service.mjs +6 -5
- package/dist/esm/services/dictionary.service.mjs.map +1 -1
- package/dist/esm/services/email.service.mjs +33 -16
- package/dist/esm/services/email.service.mjs.map +1 -1
- package/dist/esm/services/oAuth2.service.mjs +47 -10
- package/dist/esm/services/oAuth2.service.mjs.map +1 -1
- package/dist/esm/services/organization.service.mjs +16 -14
- package/dist/esm/services/organization.service.mjs.map +1 -1
- package/dist/esm/services/project.service.mjs +1 -1
- package/dist/esm/services/project.service.mjs.map +1 -1
- package/dist/esm/services/projectAccessKey.service.mjs +15 -31
- package/dist/esm/services/projectAccessKey.service.mjs.map +1 -1
- package/dist/esm/services/subscription.service.mjs +10 -10
- package/dist/esm/services/subscription.service.mjs.map +1 -1
- package/dist/esm/services/tag.service.mjs.map +1 -1
- package/dist/esm/services/user.service.mjs +2 -40
- package/dist/esm/services/user.service.mjs.map +1 -1
- package/dist/esm/types/user.types.mjs.map +1 -1
- package/dist/esm/utils/AI/aiSdk.mjs.map +1 -1
- package/dist/esm/utils/AI/askDocQuestion/PROMPT.md +7 -1
- package/dist/esm/utils/AI/askDocQuestion/askDocQuestion.mjs +32 -14
- package/dist/esm/utils/AI/askDocQuestion/askDocQuestion.mjs.map +1 -1
- package/dist/esm/utils/AI/askDocQuestion/embeddings.json +88086 -76800
- package/dist/esm/utils/AI/autocomplete/PROMPT.md +18 -2
- package/dist/esm/utils/AI/autocomplete/index.mjs +8 -5
- package/dist/esm/utils/AI/autocomplete/index.mjs.map +1 -1
- package/dist/esm/utils/access.mjs +1 -0
- package/dist/esm/utils/access.mjs.map +1 -0
- package/dist/esm/utils/accessControl.mjs +7 -0
- package/dist/esm/utils/accessControl.mjs.map +1 -1
- package/dist/esm/utils/auth/getAuth.mjs +227 -0
- package/dist/esm/utils/auth/getAuth.mjs.map +1 -0
- package/dist/esm/utils/cors.mjs +31 -0
- package/dist/esm/utils/cors.mjs.map +1 -0
- package/dist/esm/utils/ensureMongoDocumentToObject.mjs.map +1 -1
- package/dist/esm/utils/errors/ErrorHandler.mjs +2 -2
- package/dist/esm/utils/errors/ErrorHandler.mjs.map +1 -1
- package/dist/esm/utils/errors/errorCodes.mjs +114 -153
- package/dist/esm/utils/errors/errorCodes.mjs.map +1 -1
- package/dist/esm/utils/filtersAndPagination/getOrganizationFiltersAndPagination.mjs.map +1 -1
- package/dist/esm/utils/filtersAndPagination/getProjectFiltersAndPagination.mjs.map +1 -1
- package/dist/esm/utils/filtersAndPagination/getTagFiltersAndPagination.mjs.map +1 -1
- package/dist/esm/utils/filtersAndPagination/getUserFiltersAndPagination.mjs +1 -1
- package/dist/esm/utils/filtersAndPagination/getUserFiltersAndPagination.mjs.map +1 -1
- package/dist/esm/utils/mapper/dictionary.mjs.map +1 -1
- package/dist/esm/utils/mapper/organization.mjs +8 -7
- package/dist/esm/utils/mapper/organization.mjs.map +1 -1
- package/dist/esm/utils/mapper/project.mjs +5 -18
- package/dist/esm/utils/mapper/project.mjs.map +1 -1
- package/dist/esm/utils/mapper/tag.mjs +4 -2
- package/dist/esm/utils/mapper/tag.mjs.map +1 -1
- package/dist/esm/utils/mapper/user.mjs +6 -3
- package/dist/esm/utils/mapper/user.mjs.map +1 -1
- package/dist/esm/utils/mergeFunctionTypes.mjs +1 -0
- package/dist/esm/utils/mergeFunctionTypes.mjs.map +1 -0
- package/dist/esm/utils/mongoDB/connectDB.mjs +3 -1
- package/dist/esm/utils/mongoDB/connectDB.mjs.map +1 -1
- package/dist/esm/utils/mongoDB/types.mjs +1 -0
- package/dist/esm/utils/mongoDB/types.mjs.map +1 -0
- package/dist/esm/utils/oAuth2.mjs +3 -3
- package/dist/esm/utils/oAuth2.mjs.map +1 -1
- package/dist/esm/utils/permissions.mjs +138 -0
- package/dist/esm/utils/permissions.mjs.map +1 -0
- package/dist/esm/utils/rateLimiter.mjs +53 -0
- package/dist/esm/utils/rateLimiter.mjs.map +1 -0
- package/dist/types/controllers/ai.controller.d.ts +12 -10
- package/dist/types/controllers/ai.controller.d.ts.map +1 -1
- package/dist/types/controllers/dictionary.controller.d.ts +8 -9
- package/dist/types/controllers/dictionary.controller.d.ts.map +1 -1
- package/dist/types/controllers/eventListener.controller.d.ts +2 -3
- package/dist/types/controllers/eventListener.controller.d.ts.map +1 -1
- package/dist/types/controllers/newsletter.controller.d.ts +5 -6
- package/dist/types/controllers/newsletter.controller.d.ts.map +1 -1
- package/dist/types/controllers/oAuth2.controller.d.ts +3 -3
- package/dist/types/controllers/oAuth2.controller.d.ts.map +1 -1
- package/dist/types/controllers/organization.controller.d.ts +22 -23
- package/dist/types/controllers/organization.controller.d.ts.map +1 -1
- package/dist/types/controllers/project.controller.d.ts +13 -14
- package/dist/types/controllers/project.controller.d.ts.map +1 -1
- package/dist/types/controllers/projectAccessKey.controller.d.ts +5 -6
- package/dist/types/controllers/projectAccessKey.controller.d.ts.map +1 -1
- package/dist/types/controllers/search.controller.d.ts +2 -3
- package/dist/types/controllers/search.controller.d.ts.map +1 -1
- package/dist/types/controllers/stripe.controller.d.ts +5 -6
- package/dist/types/controllers/stripe.controller.d.ts.map +1 -1
- package/dist/types/controllers/tag.controller.d.ts +9 -10
- package/dist/types/controllers/tag.controller.d.ts.map +1 -1
- package/dist/types/controllers/user.controller.d.ts +16 -19
- package/dist/types/controllers/user.controller.d.ts.map +1 -1
- package/dist/types/emails/InviteUserEmail.d.ts.map +1 -1
- package/dist/types/emails/OAuthTokenCreatedEmail.d.ts +21 -0
- package/dist/types/emails/OAuthTokenCreatedEmail.d.ts.map +1 -0
- package/dist/types/emails/ResetUserPassword.d.ts.map +1 -1
- package/dist/types/emails/Welcome.d.ts.map +1 -1
- package/dist/types/emails/index.d.ts +3 -2
- package/dist/types/emails/index.d.ts.map +1 -1
- package/dist/types/export.d.ts +2 -3
- package/dist/types/export.d.ts.map +1 -1
- package/dist/types/index.d.ts +1 -3
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/middlewares/oAuth2.middleware.d.ts +1 -2
- package/dist/types/middlewares/oAuth2.middleware.d.ts.map +1 -1
- package/dist/types/middlewares/request.middleware.d.ts +3 -3
- package/dist/types/middlewares/request.middleware.d.ts.map +1 -1
- package/dist/types/middlewares/sessionAuth.middleware.d.ts +3 -25
- package/dist/types/middlewares/sessionAuth.middleware.d.ts.map +1 -1
- package/dist/types/models/dictionary.model.d.ts +6 -5
- package/dist/types/models/dictionary.model.d.ts.map +1 -1
- package/dist/types/models/discussion.model.d.ts +7 -2
- package/dist/types/models/discussion.model.d.ts.map +1 -1
- package/dist/types/models/oAuth2.model.d.ts +3 -2
- package/dist/types/models/oAuth2.model.d.ts.map +1 -1
- package/dist/types/models/organization.model.d.ts +2 -12
- package/dist/types/models/organization.model.d.ts.map +1 -1
- package/dist/types/models/project.model.d.ts +2 -11
- package/dist/types/models/project.model.d.ts.map +1 -1
- package/dist/types/models/session.model.d.ts +3 -0
- package/dist/types/models/session.model.d.ts.map +1 -0
- package/dist/types/models/tag.model.d.ts.map +1 -1
- package/dist/types/models/user.model.d.ts.map +1 -1
- package/dist/types/routes/ai.routes.d.ts.map +1 -1
- package/dist/types/routes/organization.routes.d.ts +4 -4
- package/dist/types/routes/project.routes.d.ts +4 -4
- package/dist/types/routes/project.routes.d.ts.map +1 -1
- package/dist/types/routes/tags.routes.d.ts +2 -2
- package/dist/types/routes/user.routes.d.ts +6 -7
- package/dist/types/routes/user.routes.d.ts.map +1 -1
- package/dist/types/schemas/dictionary.schema.d.ts +6 -8
- package/dist/types/schemas/dictionary.schema.d.ts.map +1 -1
- package/dist/types/schemas/discussion.schema.d.ts +7 -5
- package/dist/types/schemas/discussion.schema.d.ts.map +1 -1
- package/dist/types/schemas/oAuth2.schema.d.ts +4 -3
- package/dist/types/schemas/oAuth2.schema.d.ts.map +1 -1
- package/dist/types/schemas/organization.schema.d.ts +6 -10
- package/dist/types/schemas/organization.schema.d.ts.map +1 -1
- package/dist/types/schemas/plans.schema.d.ts +6 -8
- package/dist/types/schemas/plans.schema.d.ts.map +1 -1
- package/dist/types/schemas/project.schema.d.ts +5 -17
- package/dist/types/schemas/project.schema.d.ts.map +1 -1
- package/dist/types/schemas/session.schema.d.ts +14 -0
- package/dist/types/schemas/session.schema.d.ts.map +1 -0
- package/dist/types/schemas/tag.schema.d.ts +6 -8
- package/dist/types/schemas/tag.schema.d.ts.map +1 -1
- package/dist/types/schemas/user.schema.d.ts +7 -5
- package/dist/types/schemas/user.schema.d.ts.map +1 -1
- package/dist/types/services/dictionary.service.d.ts +9 -9
- package/dist/types/services/dictionary.service.d.ts.map +1 -1
- package/dist/types/services/email.service.d.ts +4 -0
- package/dist/types/services/email.service.d.ts.map +1 -1
- package/dist/types/services/oAuth2.service.d.ts +23 -14
- package/dist/types/services/oAuth2.service.d.ts.map +1 -1
- package/dist/types/services/organization.service.d.ts +6 -12
- package/dist/types/services/organization.service.d.ts.map +1 -1
- package/dist/types/services/project.service.d.ts +5 -5
- package/dist/types/services/project.service.d.ts.map +1 -1
- package/dist/types/services/projectAccessKey.service.d.ts +5 -5
- package/dist/types/services/projectAccessKey.service.d.ts.map +1 -1
- package/dist/types/services/subscription.service.d.ts +1 -1
- package/dist/types/services/subscription.service.d.ts.map +1 -1
- package/dist/types/services/tag.service.d.ts +6 -6
- package/dist/types/services/tag.service.d.ts.map +1 -1
- package/dist/types/services/user.service.d.ts +7 -21
- package/dist/types/services/user.service.d.ts.map +1 -1
- package/dist/types/types/dictionary.types.d.ts +11 -9
- package/dist/types/types/dictionary.types.d.ts.map +1 -1
- package/dist/types/types/discussion.types.d.ts +5 -2
- package/dist/types/types/discussion.types.d.ts.map +1 -1
- package/dist/types/types/oAuth2.types.d.ts +5 -2
- package/dist/types/types/oAuth2.types.d.ts.map +1 -1
- package/dist/types/types/organization.types.d.ts +11 -8
- package/dist/types/types/organization.types.d.ts.map +1 -1
- package/dist/types/types/plan.types.d.ts +6 -3
- package/dist/types/types/plan.types.d.ts.map +1 -1
- package/dist/types/types/project.types.d.ts +25 -25
- package/dist/types/types/project.types.d.ts.map +1 -1
- package/dist/types/types/session.types.d.ts +31 -17
- package/dist/types/types/session.types.d.ts.map +1 -1
- package/dist/types/types/tag.types.d.ts +8 -6
- package/dist/types/types/tag.types.d.ts.map +1 -1
- package/dist/types/types/user.types.d.ts +14 -21
- package/dist/types/types/user.types.d.ts.map +1 -1
- package/dist/types/utils/AI/aiSdk.d.ts +2 -2
- package/dist/types/utils/AI/aiSdk.d.ts.map +1 -1
- package/dist/types/utils/AI/askDocQuestion/askDocQuestion.d.ts +2 -0
- package/dist/types/utils/AI/askDocQuestion/askDocQuestion.d.ts.map +1 -1
- package/dist/types/utils/AI/autocomplete/index.d.ts +4 -1
- package/dist/types/utils/AI/autocomplete/index.d.ts.map +1 -1
- package/dist/types/utils/access.d.ts +1 -0
- package/dist/types/utils/access.d.ts.map +1 -0
- package/dist/types/utils/accessControl.d.ts +9 -9
- package/dist/types/utils/accessControl.d.ts.map +1 -1
- package/dist/types/utils/auth/getAuth.d.ts +7 -0
- package/dist/types/utils/auth/getAuth.d.ts.map +1 -0
- package/dist/types/utils/cors.d.ts +3 -0
- package/dist/types/utils/cors.d.ts.map +1 -0
- package/dist/types/utils/ensureMongoDocumentToObject.d.ts +2 -2
- package/dist/types/utils/ensureMongoDocumentToObject.d.ts.map +1 -1
- package/dist/types/utils/errors/ErrorHandler.d.ts +1 -1
- package/dist/types/utils/errors/ErrorHandler.d.ts.map +1 -1
- package/dist/types/utils/errors/errorCodes.d.ts +57 -96
- package/dist/types/utils/errors/errorCodes.d.ts.map +1 -1
- package/dist/types/utils/filtersAndPagination/getOrganizationFiltersAndPagination.d.ts +1 -1
- package/dist/types/utils/filtersAndPagination/getOrganizationFiltersAndPagination.d.ts.map +1 -1
- package/dist/types/utils/filtersAndPagination/getProjectFiltersAndPagination.d.ts +1 -1
- package/dist/types/utils/filtersAndPagination/getProjectFiltersAndPagination.d.ts.map +1 -1
- package/dist/types/utils/filtersAndPagination/getTagFiltersAndPagination.d.ts +1 -1
- package/dist/types/utils/filtersAndPagination/getTagFiltersAndPagination.d.ts.map +1 -1
- package/dist/types/utils/filtersAndPagination/getUserFiltersAndPagination.d.ts +1 -1
- package/dist/types/utils/filtersAndPagination/getUserFiltersAndPagination.d.ts.map +1 -1
- package/dist/types/utils/mapper/dictionary.d.ts +1 -1
- package/dist/types/utils/mapper/dictionary.d.ts.map +1 -1
- package/dist/types/utils/mapper/organization.d.ts +3 -2
- package/dist/types/utils/mapper/organization.d.ts.map +1 -1
- package/dist/types/utils/mapper/project.d.ts +4 -5
- package/dist/types/utils/mapper/project.d.ts.map +1 -1
- package/dist/types/utils/mapper/tag.d.ts +1 -1
- package/dist/types/utils/mapper/tag.d.ts.map +1 -1
- package/dist/types/utils/mapper/user.d.ts +2 -2
- package/dist/types/utils/mapper/user.d.ts.map +1 -1
- package/dist/types/utils/mergeFunctionTypes.d.ts +18 -0
- package/dist/types/utils/mergeFunctionTypes.d.ts.map +1 -0
- package/dist/types/utils/mongoDB/connectDB.d.ts +1 -1
- package/dist/types/utils/mongoDB/connectDB.d.ts.map +1 -1
- package/dist/types/utils/mongoDB/types.d.ts +11 -0
- package/dist/types/utils/mongoDB/types.d.ts.map +1 -0
- package/dist/types/utils/permissions.d.ts +115 -0
- package/dist/types/utils/permissions.d.ts.map +1 -0
- package/dist/types/utils/rateLimiter.d.ts +4 -0
- package/dist/types/utils/rateLimiter.d.ts.map +1 -0
- package/package.json +16 -14
- package/dist/cjs/controllers/sessionAuth.controller.cjs +0 -839
- package/dist/cjs/controllers/sessionAuth.controller.cjs.map +0 -1
- package/dist/cjs/routes/sessionAuth.routes.cjs +0 -154
- package/dist/cjs/routes/sessionAuth.routes.cjs.map +0 -1
- package/dist/cjs/services/sessionAuth.service.cjs +0 -385
- package/dist/cjs/services/sessionAuth.service.cjs.map +0 -1
- package/dist/cjs/utils/CSRF.cjs +0 -50
- package/dist/cjs/utils/CSRF.cjs.map +0 -1
- package/dist/cjs/utils/cookies.cjs +0 -59
- package/dist/cjs/utils/cookies.cjs.map +0 -1
- package/dist/esm/controllers/sessionAuth.controller.mjs +0 -790
- package/dist/esm/controllers/sessionAuth.controller.mjs.map +0 -1
- package/dist/esm/routes/sessionAuth.routes.mjs +0 -142
- package/dist/esm/routes/sessionAuth.routes.mjs.map +0 -1
- package/dist/esm/services/sessionAuth.service.mjs +0 -337
- package/dist/esm/services/sessionAuth.service.mjs.map +0 -1
- package/dist/esm/utils/CSRF.mjs +0 -24
- package/dist/esm/utils/CSRF.mjs.map +0 -1
- package/dist/esm/utils/cookies.mjs +0 -32
- package/dist/esm/utils/cookies.mjs.map +0 -1
- package/dist/types/controllers/sessionAuth.controller.d.ts +0 -140
- package/dist/types/controllers/sessionAuth.controller.d.ts.map +0 -1
- package/dist/types/routes/sessionAuth.routes.d.ts +0 -77
- package/dist/types/routes/sessionAuth.routes.d.ts.map +0 -1
- package/dist/types/services/sessionAuth.service.d.ts +0 -141
- package/dist/types/services/sessionAuth.service.d.ts.map +0 -1
- package/dist/types/utils/CSRF.d.ts +0 -3
- package/dist/types/utils/CSRF.d.ts.map +0 -1
- package/dist/types/utils/cookies.d.ts +0 -12
- package/dist/types/utils/cookies.d.ts.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/sessionAuth.service.ts"],"sourcesContent":["import { logger } from '@logger';\nimport type { ResponseWithInformation } from '@middlewares/sessionAuth.middleware';\nimport {\n Cookies,\n getClearCookieOptions,\n getCookieOptions,\n MAX_AGE,\n} from '@utils/cookies';\nimport { ensureMongoDocumentToObject } from '@utils/ensureMongoDocumentToObject';\nimport { GenericError } from '@utils/errors';\nimport { mapUserToAPI } from '@utils/mapper/user';\nimport { compare, genSalt, hash } from 'bcryptjs';\nimport crypto from 'crypto';\nimport type { Response } from 'express';\n// @ts-ignore express-intlayer not build yet\nimport type { Organization } from '@/types/organization.types';\nimport type { Project } from '@/types/project.types';\nimport type {\n EmailPasswordSessionProvider,\n GithubSessionProvider,\n GoogleSessionProvider,\n Session,\n SessionProviders,\n} from '@/types/session.types';\nimport type {\n User,\n UserDocument,\n UserWithPasswordNotHashed,\n} from '@/types/user.types';\nimport { t } from 'express-intlayer';\nimport jwt from 'jsonwebtoken';\nimport type { ObjectId } from 'mongoose';\nimport { v4 as uuidv4 } from 'uuid';\nimport { getUserByEmail, getUserById, updateUserById } from './user.service';\n\n/**\n * Adds a session to a user or updates the existing one.\n * @param user - User object.\n * @returns Updated user object.\n */\nexport const addSession = async (user: User): Promise<UserDocument> => {\n const userSessionToken = uuidv4();\n\n const session: Session = {\n sessionToken: userSessionToken,\n expires: new Date(Date.now() + MAX_AGE),\n };\n\n const updatedUser: UserDocument = await updateUserById(user._id, { session });\n\n return updatedUser;\n};\n\nexport const removeSession = async (user: User): Promise<UserDocument> => {\n const session = undefined;\n\n const updatedUser: UserDocument = await updateUserById(user._id, { session });\n\n return updatedUser;\n};\n\n/**\n * Set user auth locals object\n * @param res - Express response object.\n * @param user - User object.\n */\nexport const setUserAuth = async (res: Response, user: User) => {\n const formattedUser = mapUserToAPI(user);\n\n const userToken = jwt.sign(formattedUser, process.env.JWT_TOKEN_SECRET!, {\n expiresIn: MAX_AGE,\n });\n\n if (!userToken) {\n throw new GenericError('JWT_TOKEN_CREATION_FAILED_USER', { user });\n }\n\n const cookieOptions = getCookieOptions();\n\n res.cookie(Cookies.JWT_USER, userToken, cookieOptions);\n\n const userWithSession: UserDocument = await addSession(user);\n\n const userSessionToken = userWithSession.session?.sessionToken;\n\n res.cookie(Cookies.JWT_AUTH, userSessionToken, cookieOptions);\n\n res.locals.user = user;\n logger.info(\n `User logged in - User: Name: ${user.name}, id: ${String(user._id)}`\n );\n};\n\n/**\n * Clears the JWT auth cookies and user locals object.\n * @param res - Express response object.\n */\nexport const clearUserAuth = async (res: ResponseWithInformation) => {\n const { user } = res.locals;\n const cookiesOptions = getClearCookieOptions();\n\n if (user) {\n await removeSession(user);\n }\n\n res.cookie(Cookies.JWT_AUTH, '', cookiesOptions);\n res.cookie(Cookies.JWT_USER, '', cookiesOptions);\n\n res.locals.user = null;\n res.locals.authType = null;\n};\n\n/**\n *\n * @param res\n * @param organization\n * @returns\n */\nexport const setOrganizationAuth = (\n res: ResponseWithInformation,\n organization: Organization\n) => {\n const organizationData = {\n _id: organization._id,\n name: organization.name,\n };\n\n const organizationToken = jwt.sign(\n organizationData,\n process.env.JWT_TOKEN_SECRET!,\n {\n expiresIn: MAX_AGE,\n }\n );\n\n if (!organizationToken) {\n throw new GenericError('JWT_TOKEN_CREATION_FAILED_ORGANIZATION', {\n organization,\n });\n }\n\n res.cookie(Cookies.JWT_ORGANIZATION, organizationToken, getCookieOptions());\n\n res.locals.organization = organization;\n};\n\n/**\n * Clears the JWT organization cookies and organization locals object.\n * @param res - Express response object.\n */\nexport const clearOrganizationAuth = (res: ResponseWithInformation) => {\n res.locals.organization = null;\n\n res.cookie(Cookies.JWT_ORGANIZATION, '', getClearCookieOptions());\n};\n\n/**\n * Set project auth locals object\n * @param res - Express response object.\n * @param project - Project object.\n */\nexport const setProjectAuth = (\n res: ResponseWithInformation,\n project: Project\n) => {\n const { organization } = res.locals;\n const projectData = {\n _id: project._id,\n name: project.name,\n };\n\n const projectToken = jwt.sign(projectData, process.env.JWT_TOKEN_SECRET!, {\n expiresIn: MAX_AGE,\n });\n\n if (!projectToken) {\n throw new GenericError('JWT_TOKEN_CREATION_FAILED_PROJECT', {\n project,\n });\n }\n\n res.cookie(Cookies.JWT_PROJECT, projectToken, getCookieOptions());\n\n if (!organization) {\n throw new GenericError('ORGANIZATION_NOT_FOUND', {\n project,\n });\n }\n\n if (\n // if the project is not in the organization's projects\n String(organization._id) !== String(project.organizationId)\n ) {\n throw new GenericError('JWT_TOKEN_ORGANIZATION_MISMATCH_PROJECT', {\n project,\n });\n }\n\n res.locals.project = project;\n};\n\n/**\n * Clears the JWT project cookies and project locals object.\n * @param res - Express response object.\n */\nexport const clearProjectAuth = (res: Response) => {\n res.locals.project = null;\n\n res.cookie(Cookies.JWT_PROJECT, '', getClearCookieOptions());\n};\n\n/**\n * Generates a random secret string of a specified length.\n * @param length - The length of the secret.\n * @returns The generated secret string.\n */\nexport const generateSecret = (length: number): string => {\n const characters =\n 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n return Array.from({ length }, () =>\n characters.charAt(Math.floor(Math.random() * characters.length))\n ).join('');\n};\n\n/**\n * Handles a password reset request for a user.\n * @param email - The user's email.\n * @param organization - The organization associated with the user.\n * @returns The user object or null if no user was found.\n */\nexport const requestPasswordReset = async (\n email: string\n): Promise<User | null> => {\n const user = await getUserByEmail(email);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { email });\n }\n\n return updateUserProvider(user._id as unknown as string, 'email', {\n secret: generateSecret(35),\n });\n};\n\n/**\n * Resets a user's password.\n * @param userId - The ID of the user.\n * @param secret - The secret token associated with the user.\n * @param newPassword - The new password to set.\n * @returns The updated user or null if the reset failed.\n */\nexport const resetUserPassword = async (\n userId: string | ObjectId,\n secret: string,\n newPassword: string\n): Promise<User> => {\n const emailAndPasswordProvider = await getUserProvider(userId, 'email');\n\n if (!emailAndPasswordProvider) {\n throw new GenericError('USER_PROVIDER_NOT_FOUND', { userId });\n }\n\n if (!emailAndPasswordProvider.secret) {\n throw new GenericError('USER_PROVIDER_SECRET_NOT_DEFINED', { userId });\n }\n\n if (\n !crypto.timingSafeEqual(\n Buffer.from(emailAndPasswordProvider.secret),\n Buffer.from(secret)\n )\n ) {\n throw new GenericError('USER_PROVIDER_SECRET_NOT_VALID', { userId });\n }\n\n const updatedUser: User = await updateUserProvider(userId, 'email', {\n passwordHash: await hash(newPassword, await genSalt()),\n secret,\n });\n\n return updatedUser;\n};\n\ntype UserProvider<T extends SessionProviders['provider']> = T extends 'email'\n ? EmailPasswordSessionProvider\n : T extends 'google'\n ? GoogleSessionProvider\n : T extends 'github'\n ? GithubSessionProvider\n : SessionProviders;\n\n/**\n * Gets a user's provider.\n * @param userId - The ID of the user.\n * @param provider - The provider to get.\n * @returns The user's provider.\n */\nexport const getUserProvider = async <T extends SessionProviders['provider']>(\n userId: string | ObjectId,\n provider: T,\n providerAccountId?: string\n): Promise<UserProvider<T> | null> => {\n const user = await getUserById(userId);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { userId });\n }\n\n const userProvider = user.provider?.find(\n (providerEl) =>\n (providerEl.provider === provider && !providerAccountId) ||\n (providerAccountId &&\n (providerEl as GithubSessionProvider).providerAccountId ===\n providerAccountId)\n );\n\n return (userProvider as UserProvider<T>) ?? null;\n};\n\n/**\n * Formats the given fields of a user's provider.\n * @param provider - The provider to update.\n * @param user - The user object.\n * @param providerUpdate - The updates to apply to the provider.\n * @returns The updated user provider.\n */\nexport const formatUserProviderUpdate = <\n T extends SessionProviders['provider'],\n>(\n provider: T,\n user: Partial<User>,\n providerUpdate: Partial<UserProvider<T>>\n): User['provider'] => {\n const userProvider: SessionProviders[] = ensureMongoDocumentToObject<\n SessionProviders[]\n >(user.provider ?? []);\n\n const userProviderToUpdate = userProvider?.find(\n (providerEl) => providerEl.provider === provider\n );\n\n let updatedProvider: User['provider'];\n\n if (userProviderToUpdate) {\n const otherProviders =\n user.provider?.filter((p) => p.provider !== provider) ?? [];\n\n updatedProvider = [\n ...otherProviders,\n { ...userProviderToUpdate, ...providerUpdate, provider },\n ];\n } else {\n updatedProvider = [\n ...(user.provider ?? []),\n { ...providerUpdate, provider } as SessionProviders,\n ];\n }\n\n return updatedProvider;\n};\n\n/**\n * Updates the given fields of a user's provider.\n * @param userId - The ID of the user.\n * @param provider - The provider to update.\n * @param providerUpdate - The updates to apply to the provider.\n * @returns The updated user.\n */\nexport const updateUserProvider = async <\n T extends SessionProviders['provider'],\n>(\n userId: string | ObjectId,\n provider: T,\n providerUpdate: Partial<UserProvider<T>>\n): Promise<UserDocument> => {\n const user = await getUserById(userId);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { userId });\n }\n\n const formattedProviderToUpdate = formatUserProviderUpdate(\n provider,\n user,\n providerUpdate\n );\n\n const updatedUser: UserDocument = await updateUserById(userId, {\n provider: formattedProviderToUpdate,\n });\n\n logger.info(\n `User provider updated - User: Name: ${updatedUser.name}, id: ${String(updatedUser._id)} - Provider: ${provider}`\n );\n\n return updatedUser;\n};\n\n/**\n * Updates the given fields of a user's provider.\n * @param userId - The ID of the user.\n * @param provider - The updates to apply to the provider.\n * @returns The updated user.\n */\nexport const addUserProvider = async (\n userId: string | ObjectId,\n provider: SessionProviders\n): Promise<UserDocument> => {\n const user = await getUserById(userId);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { userId });\n }\n\n const existingProvider = await getUserProvider(userId, provider.provider);\n\n if (existingProvider) {\n throw new GenericError('USER_PROVIDER_ALREADY_EXISTS', {\n userId,\n provider,\n });\n }\n\n const updatedProvider = [...(user.provider ?? []), provider];\n\n const updatedUser = await updateUserById(userId, {\n provider: updatedProvider,\n });\n\n logger.info(\n `User provider added - User: Name: ${updatedUser.name}, id: ${String(updatedUser._id)} - Provider: ${provider.provider}`\n );\n\n return updatedUser;\n};\n\n/**\n * Removes a user's provider.\n * @param userId - The ID of the user.\n * @param provider - The provider to remove.\n * @returns The updated user.\n */\nexport const removeUserProvider = async (\n userId: string | ObjectId,\n provider: SessionProviders['provider'],\n providerAccountId?: string\n) => {\n const user = await getUserById(userId);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { userId });\n }\n\n const existingProvider = await getUserProvider(\n userId,\n provider,\n providerAccountId\n );\n\n if (!existingProvider) {\n throw new GenericError('USER_PROVIDER_NOT_FOUND', {\n userId,\n provider,\n });\n }\n\n const updatedProvider = user.provider?.filter(\n (p) =>\n p.provider !== provider &&\n (!providerAccountId ||\n (providerAccountId &&\n (p as GithubSessionProvider).providerAccountId !== providerAccountId))\n );\n\n return await updateUserById(userId, {\n provider: updatedProvider,\n });\n};\n\ntype TestUserPasswordResult = { user: User | null; error?: string };\n\n/**\n * Logs in a user.\n * @param email - The user's email.\n * @param password - The user's password.\n * @returns The user object.\n */\nexport const testUserPassword = async (\n email: string,\n password: string\n): Promise<TestUserPasswordResult> => {\n const user = await getUserByEmail(email);\n\n if (!user) {\n const errorMessages = {\n en: `User not found - ${email}`,\n fr: `Utilisateur non trouvé - ${email}`,\n es: `Usuario no encontrado - ${email}`,\n };\n\n return { user: null, error: t(errorMessages) };\n }\n\n const userEmailPasswordProvider = user.provider?.find(\n (provider) => provider.provider === 'email'\n );\n\n if (!userEmailPasswordProvider?.passwordHash) {\n const errorMessages = {\n en: `User request to login but no password defined: ${user.email}`,\n fr: `Demande de connexion d'utilisateur mais pas de mot de passe défini : ${user.email}`,\n es: `Solicitud de inicio de sesión de usuario pero no se define la contraseña : ${user.email}`,\n };\n\n return { user: null, error: t(errorMessages) };\n }\n\n const isMatch = await compare(\n password,\n userEmailPasswordProvider.passwordHash\n );\n\n if (!isMatch) {\n const errorMessages = {\n en: `Incorrect email or password: ${email}`,\n fr: `Email ou mot de passe incorrect : ${email}`,\n es: `Correo electrónico o contraseña incorrecta : ${email}`,\n };\n\n logger.error(errorMessages.en);\n\n // Await a random time to prevent brute force attacks\n const randomNumber = Math.floor(Math.random() * 1000) + 1000;\n await new Promise((resolve) => setTimeout(resolve, randomNumber));\n\n return { user: null, error: t(errorMessages) };\n }\n\n return { user };\n};\n\n/**\n * Hashes a user's password.\n * @param userWithPasswordNotHashed - The user object with password not hashed.\n * @returns The user object with hashed password.\n */\nexport const hashUserPassword = async (\n userWithPasswordNotHashed: UserWithPasswordNotHashed\n): Promise<Partial<UserDocument>> => {\n const { password, ...user } = userWithPasswordNotHashed;\n\n if (!password) {\n throw new GenericError('USER_PASSWORD_NOT_DEFINED', { user });\n }\n\n const userProvider = formatUserProviderUpdate('email', user, {\n passwordHash: await hash(password, await genSalt()),\n secret: generateSecret(35),\n });\n\n return { ...user, provider: userProvider };\n};\n\n/**\n * Changes a user's password.\n * @param userId - The ID of the user.\n * @param newPassword - The user's new password.\n * @returns The updated user or null if the password change failed.\n */\nexport const changeUserPassword = async (\n userId: string | ObjectId,\n newPassword: string\n) => {\n const user = await getUserById(userId);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { userId });\n }\n\n const updatedUser: User = await updateUserProvider(userId, 'email', {\n passwordHash: await hash(newPassword, await genSalt()),\n });\n\n return updatedUser;\n};\n\n/**\n * Resets a user's password.\n * @param userId - The ID of the user.\n * @param secret - The secret token associated with the user.\n * @param newPassword - The new password to set.\n * @returns The updated user or null if the reset failed.\n */\nexport const resetPassword = async (userId: string, password: string) => {\n const user = await getUserById(userId);\n\n if (!user) {\n throw new GenericError('USER_NOT_FOUND', { userId });\n }\n\n const updatedUser: UserDocument = await updateUserProvider(userId, 'email', {\n passwordHash: await hash(password, await genSalt()),\n });\n\n return updatedUser;\n};\n"],"mappings":"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","names":[]}
|
package/dist/esm/utils/CSRF.mjs
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { doubleCsrf } from "csrf-csrf";
|
|
2
|
-
import { Cookies, getCookieOptions } from "./cookies.mjs";
|
|
3
|
-
const {
|
|
4
|
-
generateCsrfToken,
|
|
5
|
-
// Use this in your routes to provide a CSRF hash + token cookie and token.
|
|
6
|
-
validateRequest,
|
|
7
|
-
// Also a convenience if you plan on making your own middleware.
|
|
8
|
-
doubleCsrfProtection
|
|
9
|
-
// This is the default CSRF protection middleware.
|
|
10
|
-
} = doubleCsrf({
|
|
11
|
-
getSecret: () => process.env.CSRF_SECRET,
|
|
12
|
-
getSessionIdentifier: (req) => {
|
|
13
|
-
return req.sessionID || `${req.ip}-${req.get("User-Agent")}` || "anonymous";
|
|
14
|
-
},
|
|
15
|
-
getCsrfTokenFromRequest: (req) => req.body.csrf_token,
|
|
16
|
-
cookieName: Cookies.XSRF_TOKEN,
|
|
17
|
-
cookieOptions: getCookieOptions()
|
|
18
|
-
});
|
|
19
|
-
export {
|
|
20
|
-
doubleCsrfProtection,
|
|
21
|
-
generateCsrfToken as generateToken,
|
|
22
|
-
validateRequest
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=CSRF.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/utils/CSRF.ts"],"sourcesContent":["import { doubleCsrf } from 'csrf-csrf';\nimport { Cookies, getCookieOptions } from './cookies';\n\nconst {\n generateCsrfToken, // Use this in your routes to provide a CSRF hash + token cookie and token.\n validateRequest, // Also a convenience if you plan on making your own middleware.\n doubleCsrfProtection, // This is the default CSRF protection middleware.\n} = doubleCsrf({\n getSecret: () => process.env.CSRF_SECRET!,\n getSessionIdentifier: (req) => {\n // Use session ID if available, otherwise fallback to IP + User-Agent hash\n return (\n (req as any).sessionID ||\n `${req.ip}-${req.get('User-Agent')}` ||\n 'anonymous'\n );\n },\n getCsrfTokenFromRequest: (req) => req.body.csrf_token,\n cookieName: Cookies.XSRF_TOKEN,\n cookieOptions: getCookieOptions(),\n});\n\nexport {\n doubleCsrfProtection,\n generateCsrfToken as generateToken,\n validateRequest,\n};\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,SAAS,wBAAwB;AAE1C,MAAM;AAAA,EACJ;AAAA;AAAA,EACA;AAAA;AAAA,EACA;AAAA;AACF,IAAI,WAAW;AAAA,EACb,WAAW,MAAM,QAAQ,IAAI;AAAA,EAC7B,sBAAsB,CAAC,QAAQ;AAE7B,WACG,IAAY,aACb,GAAG,IAAI,EAAE,IAAI,IAAI,IAAI,YAAY,CAAC,MAClC;AAAA,EAEJ;AAAA,EACA,yBAAyB,CAAC,QAAQ,IAAI,KAAK;AAAA,EAC3C,YAAY,QAAQ;AAAA,EACpB,eAAe,iBAAiB;AAClC,CAAC;","names":[]}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
const MAX_AGE = 3 * 24 * 60 * 60 * 1e3;
|
|
2
|
-
var Cookies = /* @__PURE__ */ ((Cookies2) => {
|
|
3
|
-
Cookies2["JWT_AUTH"] = "intlayer_auth";
|
|
4
|
-
Cookies2["JWT_USER"] = "intlayer_user";
|
|
5
|
-
Cookies2["JWT_ORGANIZATION"] = "intlayer_organization";
|
|
6
|
-
Cookies2["JWT_PROJECT"] = "intlayer_project";
|
|
7
|
-
Cookies2["XSRF_TOKEN"] = "XSRF-TOKEN";
|
|
8
|
-
return Cookies2;
|
|
9
|
-
})(Cookies || {});
|
|
10
|
-
const getCookieOptions = (overwriteOption = {}) => ({
|
|
11
|
-
maxAge: MAX_AGE,
|
|
12
|
-
path: "/",
|
|
13
|
-
domain: process.env.DOMAIN,
|
|
14
|
-
httpOnly: true,
|
|
15
|
-
secure: process.env.NODE_ENV === "production",
|
|
16
|
-
// Enable for HTTPS in production
|
|
17
|
-
sameSite: "strict",
|
|
18
|
-
priority: "high",
|
|
19
|
-
...overwriteOption
|
|
20
|
-
});
|
|
21
|
-
const getClearCookieOptions = (overwriteOption = {}) => ({
|
|
22
|
-
...getCookieOptions(),
|
|
23
|
-
maxAge: 1,
|
|
24
|
-
...overwriteOption
|
|
25
|
-
});
|
|
26
|
-
export {
|
|
27
|
-
Cookies,
|
|
28
|
-
MAX_AGE,
|
|
29
|
-
getClearCookieOptions,
|
|
30
|
-
getCookieOptions
|
|
31
|
-
};
|
|
32
|
-
//# sourceMappingURL=cookies.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/utils/cookies.ts"],"sourcesContent":["import type { CookieOptions } from 'express';\n\nexport const MAX_AGE = 3 * 24 * 60 * 60 * 1000; // 3 days\n\nexport enum Cookies {\n JWT_AUTH = 'intlayer_auth',\n JWT_USER = 'intlayer_user',\n JWT_ORGANIZATION = 'intlayer_organization',\n JWT_PROJECT = 'intlayer_project',\n XSRF_TOKEN = 'XSRF-TOKEN',\n}\n\nexport const getCookieOptions = (\n overwriteOption: Partial<CookieOptions> = {}\n): CookieOptions => ({\n maxAge: MAX_AGE,\n path: '/',\n domain: process.env.DOMAIN,\n httpOnly: true,\n secure: process.env.NODE_ENV === 'production', // Enable for HTTPS in production\n sameSite: 'strict',\n priority: 'high',\n ...overwriteOption,\n});\n\nexport const getClearCookieOptions = (\n overwriteOption: Partial<CookieOptions> = {}\n): CookieOptions => ({\n ...getCookieOptions(),\n maxAge: 1,\n ...overwriteOption,\n});\n"],"mappings":"AAEO,MAAM,UAAU,IAAI,KAAK,KAAK,KAAK;AAEnC,IAAK,UAAL,kBAAKA,aAAL;AACL,EAAAA,SAAA,cAAW;AACX,EAAAA,SAAA,cAAW;AACX,EAAAA,SAAA,sBAAmB;AACnB,EAAAA,SAAA,iBAAc;AACd,EAAAA,SAAA,gBAAa;AALH,SAAAA;AAAA,GAAA;AAQL,MAAM,mBAAmB,CAC9B,kBAA0C,CAAC,OACxB;AAAA,EACnB,QAAQ;AAAA,EACR,MAAM;AAAA,EACN,QAAQ,QAAQ,IAAI;AAAA,EACpB,UAAU;AAAA,EACV,QAAQ,QAAQ,IAAI,aAAa;AAAA;AAAA,EACjC,UAAU;AAAA,EACV,UAAU;AAAA,EACV,GAAG;AACL;AAEO,MAAM,wBAAwB,CACnC,kBAA0C,CAAC,OACxB;AAAA,EACnB,GAAG,iBAAiB;AAAA,EACpB,QAAQ;AAAA,EACR,GAAG;AACL;","names":["Cookies"]}
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
import type { ResponseWithInformation } from '../middlewares/sessionAuth.middleware';
|
|
2
|
-
import { type ResponseData } from '../utils/responseData';
|
|
3
|
-
import type { NextFunction, Request, Response } from 'express';
|
|
4
|
-
import type { OrganizationAPI } from '../types/organization.types';
|
|
5
|
-
import type { ProjectAPI } from '../types/project.types';
|
|
6
|
-
import type { Session } from '../types/session.types';
|
|
7
|
-
import type { User, UserAPI } from '../types/user.types';
|
|
8
|
-
export type CSRFTokenData = {
|
|
9
|
-
csrf_token: string;
|
|
10
|
-
};
|
|
11
|
-
export type SetCSRFTokenResult = ResponseData<CSRFTokenData>;
|
|
12
|
-
export declare const setCSRFToken: (req: Request, res: Response<SetCSRFTokenResult>, _next: NextFunction) => void;
|
|
13
|
-
export type RegisterBody = {
|
|
14
|
-
email: string;
|
|
15
|
-
password?: string;
|
|
16
|
-
};
|
|
17
|
-
export type RegisterQuery = {
|
|
18
|
-
callBack_url?: string;
|
|
19
|
-
};
|
|
20
|
-
export type RegisterResult = ResponseData<UserAPI>;
|
|
21
|
-
/**
|
|
22
|
-
* Handles user registration.
|
|
23
|
-
*/
|
|
24
|
-
export declare const registerEmailPassword: (req: Request<any, any, RegisterBody, RegisterQuery>, res: ResponseWithInformation<RegisterResult>, _next: NextFunction) => Promise<void>;
|
|
25
|
-
export type LoginBody = {
|
|
26
|
-
email: string;
|
|
27
|
-
password: string;
|
|
28
|
-
};
|
|
29
|
-
export type LoginResult = ResponseData<UserAPI>;
|
|
30
|
-
/**
|
|
31
|
-
* Handles user login.
|
|
32
|
-
*/
|
|
33
|
-
export declare const loginEmailPassword: (req: Request<any, any, LoginBody>, res: ResponseWithInformation<LoginResult>, _next: NextFunction) => Promise<void>;
|
|
34
|
-
export type LogoutResult = ResponseData<undefined>;
|
|
35
|
-
/**
|
|
36
|
-
* Handles user logout and clears cookies.
|
|
37
|
-
*/
|
|
38
|
-
export declare const logOut: (_req: Request, res: ResponseWithInformation<LogoutResult>, _next: NextFunction) => Promise<void>;
|
|
39
|
-
export type UpdatePasswordBody = {
|
|
40
|
-
oldPassword?: string;
|
|
41
|
-
newPassword: string;
|
|
42
|
-
};
|
|
43
|
-
export type UpdatePasswordResult = ResponseData<UserAPI>;
|
|
44
|
-
/**
|
|
45
|
-
* Updates the user's password.
|
|
46
|
-
*/
|
|
47
|
-
export declare const updatePassword: (req: Request<undefined, any, UpdatePasswordBody>, res: ResponseWithInformation<UpdatePasswordResult>, _next: NextFunction) => Promise<void>;
|
|
48
|
-
export declare const sendVerificationUpdate: (user: User) => void;
|
|
49
|
-
type CheckIfUserHasPasswordResultData = {
|
|
50
|
-
hasPassword: boolean;
|
|
51
|
-
};
|
|
52
|
-
export type CheckIfUserHasPasswordResult = ResponseData<CheckIfUserHasPasswordResultData>;
|
|
53
|
-
export declare const checkIfUserHasPassword: (_req: Request, res: ResponseWithInformation<CheckIfUserHasPasswordResult>, _next: NextFunction) => Promise<void>;
|
|
54
|
-
export type ValidEmailParams = {
|
|
55
|
-
secret: string;
|
|
56
|
-
userId: string;
|
|
57
|
-
};
|
|
58
|
-
export type ValidEmailQuery = {
|
|
59
|
-
callBack_url?: string;
|
|
60
|
-
};
|
|
61
|
-
export type ValidEmailResult = ResponseData<UserAPI>;
|
|
62
|
-
/**
|
|
63
|
-
* Validates a user's email based on the provided secret and user ID.
|
|
64
|
-
*/
|
|
65
|
-
export declare const validEmail: (req: Request<ValidEmailParams, any, any, ValidEmailQuery>, res: ResponseWithInformation<ValidEmailResult>, _next: NextFunction) => Promise<void>;
|
|
66
|
-
export type VerifyEmailStatusSSEParams = {
|
|
67
|
-
userId: string;
|
|
68
|
-
};
|
|
69
|
-
/**
|
|
70
|
-
* SSE to check the email verification status
|
|
71
|
-
*/
|
|
72
|
-
export declare const verifyEmailStatusSSE: (req: Request<VerifyEmailStatusSSEParams, any, any>, res: ResponseWithInformation) => Promise<void>;
|
|
73
|
-
export type AskResetPasswordBody = {
|
|
74
|
-
email: string;
|
|
75
|
-
};
|
|
76
|
-
export type AskResetPasswordResult = ResponseData<undefined>;
|
|
77
|
-
/**
|
|
78
|
-
* Requests a password reset for a user.
|
|
79
|
-
*/
|
|
80
|
-
export declare const askResetPassword: (req: Request<undefined, any, AskResetPasswordBody>, res: ResponseWithInformation<AskResetPasswordResult>, _next: NextFunction) => Promise<void>;
|
|
81
|
-
export type DefinePasswordBody = {
|
|
82
|
-
password: string;
|
|
83
|
-
secret: string;
|
|
84
|
-
userId: string;
|
|
85
|
-
};
|
|
86
|
-
export type DefinePasswordResult = ResponseData<UserAPI>;
|
|
87
|
-
/**
|
|
88
|
-
* Resets a user's password based on the provided secret and user ID.
|
|
89
|
-
*/
|
|
90
|
-
export declare const definePassword: (req: Request<undefined, any, DefinePasswordBody>, res: Response<DefinePasswordResult>, _next: NextFunction) => Promise<void>;
|
|
91
|
-
export type CreateSessionBody = {
|
|
92
|
-
sessionToken: string;
|
|
93
|
-
userId: string;
|
|
94
|
-
expires: Date;
|
|
95
|
-
};
|
|
96
|
-
export type CreateSessionResult = ResponseData<Session>;
|
|
97
|
-
export type GetSessionInformationQuery = {
|
|
98
|
-
session_token?: string;
|
|
99
|
-
};
|
|
100
|
-
type SessionInformation = {
|
|
101
|
-
user: UserAPI | null;
|
|
102
|
-
organization: OrganizationAPI | null;
|
|
103
|
-
project: ProjectAPI | null;
|
|
104
|
-
session: Session | null;
|
|
105
|
-
};
|
|
106
|
-
export type GetSessionInformationResult = ResponseData<SessionInformation>;
|
|
107
|
-
/**
|
|
108
|
-
* Gets information about a session for a user.
|
|
109
|
-
*/
|
|
110
|
-
export declare const getSessionInformation: (req: Request<undefined, undefined, undefined, GetSessionInformationQuery>, res: ResponseWithInformation<GetSessionInformationResult>, _next: NextFunction) => Promise<void>;
|
|
111
|
-
export type GithubLoginQueryParams = {
|
|
112
|
-
origin: string;
|
|
113
|
-
};
|
|
114
|
-
export type GithubLoginQueryResult = ResponseData<undefined>;
|
|
115
|
-
export declare const githubLoginQuery: (req: Request<undefined, undefined, undefined, GithubLoginQueryParams>, res: ResponseWithInformation<GithubLoginQueryResult>, _next: NextFunction) => void;
|
|
116
|
-
export type GithubCallbackQuery = {
|
|
117
|
-
code: string;
|
|
118
|
-
redirect_uri: string;
|
|
119
|
-
};
|
|
120
|
-
export type GithubCallbackResult = ResponseData<UserAPI>;
|
|
121
|
-
/**
|
|
122
|
-
* Handles GitHub OAuth callback.
|
|
123
|
-
*/
|
|
124
|
-
export declare const githubCallback: (req: Request<undefined, undefined, undefined, GithubCallbackQuery>, res: ResponseWithInformation<GithubCallbackResult>, _next: NextFunction) => Promise<void>;
|
|
125
|
-
export type GoogleLoginQueryParams = {
|
|
126
|
-
origin: string;
|
|
127
|
-
};
|
|
128
|
-
export type GoogleLoginResult = ResponseData<undefined>;
|
|
129
|
-
export declare const googleLoginQuery: (req: Request<undefined, undefined, undefined, GoogleLoginQueryParams>, res: ResponseWithInformation<GoogleLoginResult>, _next: NextFunction) => void;
|
|
130
|
-
export type GoogleCallbackQuery = {
|
|
131
|
-
code: string;
|
|
132
|
-
state: string;
|
|
133
|
-
};
|
|
134
|
-
export type GoogleCallbackResult = ResponseData<UserAPI>;
|
|
135
|
-
/**
|
|
136
|
-
* Handles Google OAuth 2 callback.
|
|
137
|
-
*/
|
|
138
|
-
export declare const googleCallback: (req: Request<undefined, undefined, undefined, GoogleCallbackQuery>, res: ResponseWithInformation<GoogleCallbackResult>, _next: NextFunction) => Promise<void>;
|
|
139
|
-
export {};
|
|
140
|
-
//# sourceMappingURL=sessionAuth.controller.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sessionAuth.controller.d.ts","sourceRoot":"","sources":["../../../src/controllers/sessionAuth.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
export declare const sessionAuthRouter: Router;
|
|
3
|
-
export declare const sessionAuthRoute = "/api/auth";
|
|
4
|
-
export declare const getSessionAuthRoutes: () => {
|
|
5
|
-
registerEmailPassword: {
|
|
6
|
-
urlModel: string;
|
|
7
|
-
url: string;
|
|
8
|
-
method: "POST";
|
|
9
|
-
};
|
|
10
|
-
loginEmailPassword: {
|
|
11
|
-
urlModel: string;
|
|
12
|
-
url: string;
|
|
13
|
-
method: "POST";
|
|
14
|
-
};
|
|
15
|
-
logOut: {
|
|
16
|
-
urlModel: string;
|
|
17
|
-
url: string;
|
|
18
|
-
method: "POST";
|
|
19
|
-
};
|
|
20
|
-
updatePassword: {
|
|
21
|
-
urlModel: string;
|
|
22
|
-
url: string;
|
|
23
|
-
method: "PUT";
|
|
24
|
-
};
|
|
25
|
-
askResetPassword: {
|
|
26
|
-
urlModel: string;
|
|
27
|
-
url: string;
|
|
28
|
-
method: "POST";
|
|
29
|
-
};
|
|
30
|
-
defineNewPassword: {
|
|
31
|
-
urlModel: string;
|
|
32
|
-
url: string;
|
|
33
|
-
method: "POST";
|
|
34
|
-
};
|
|
35
|
-
checkIfUserHasPassword: {
|
|
36
|
-
urlModel: string;
|
|
37
|
-
url: string;
|
|
38
|
-
method: "GET";
|
|
39
|
-
};
|
|
40
|
-
validEmail: {
|
|
41
|
-
urlModel: string;
|
|
42
|
-
url: ({ userId, secret, callBack_url, }: {
|
|
43
|
-
userId: string;
|
|
44
|
-
secret: string;
|
|
45
|
-
callBack_url?: string;
|
|
46
|
-
}) => string;
|
|
47
|
-
method: "GET";
|
|
48
|
-
};
|
|
49
|
-
verifyEmailStatusSSE: {
|
|
50
|
-
urlModel: string;
|
|
51
|
-
url: ({ userId }: {
|
|
52
|
-
userId: string;
|
|
53
|
-
}) => string;
|
|
54
|
-
method: "GET";
|
|
55
|
-
};
|
|
56
|
-
githubLoginQuery: {
|
|
57
|
-
urlModel: string;
|
|
58
|
-
url: string;
|
|
59
|
-
method: "GET";
|
|
60
|
-
};
|
|
61
|
-
githubCallback: {
|
|
62
|
-
urlModel: string;
|
|
63
|
-
url: string;
|
|
64
|
-
method: "GET";
|
|
65
|
-
};
|
|
66
|
-
googleLoginQuery: {
|
|
67
|
-
urlModel: string;
|
|
68
|
-
url: string;
|
|
69
|
-
method: "GET";
|
|
70
|
-
};
|
|
71
|
-
googleCallback: {
|
|
72
|
-
urlModel: string;
|
|
73
|
-
url: string;
|
|
74
|
-
method: "GET";
|
|
75
|
-
};
|
|
76
|
-
};
|
|
77
|
-
//# sourceMappingURL=sessionAuth.routes.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sessionAuth.routes.d.ts","sourceRoot":"","sources":["../../../src/routes/sessionAuth.routes.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,eAAO,MAAM,iBAAiB,EAAE,MAAiB,CAAC;AAElD,eAAO,MAAM,gBAAgB,cAAc,CAAC;AAI5C,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iDA2CxB;YACD,MAAM,EAAE,MAAM,CAAC;YACf,MAAM,EAAE,MAAM,CAAC;YACf,YAAY,CAAC,EAAE,MAAM,CAAC;SACvB;;;;;0BAQiB;YAAE,MAAM,EAAE,MAAM,CAAA;SAAE;;;;;;;;;;;;;;;;;;;;;;;CAwBrB,CAAC"}
|
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
import type { ResponseWithInformation } from '../middlewares/sessionAuth.middleware';
|
|
2
|
-
import type { Response } from 'express';
|
|
3
|
-
import type { Organization } from '../types/organization.types';
|
|
4
|
-
import type { Project } from '../types/project.types';
|
|
5
|
-
import type { EmailPasswordSessionProvider, GithubSessionProvider, GoogleSessionProvider, SessionProviders } from '../types/session.types';
|
|
6
|
-
import type { User, UserDocument, UserWithPasswordNotHashed } from '../types/user.types';
|
|
7
|
-
import type { ObjectId } from 'mongoose';
|
|
8
|
-
/**
|
|
9
|
-
* Adds a session to a user or updates the existing one.
|
|
10
|
-
* @param user - User object.
|
|
11
|
-
* @returns Updated user object.
|
|
12
|
-
*/
|
|
13
|
-
export declare const addSession: (user: User) => Promise<UserDocument>;
|
|
14
|
-
export declare const removeSession: (user: User) => Promise<UserDocument>;
|
|
15
|
-
/**
|
|
16
|
-
* Set user auth locals object
|
|
17
|
-
* @param res - Express response object.
|
|
18
|
-
* @param user - User object.
|
|
19
|
-
*/
|
|
20
|
-
export declare const setUserAuth: (res: Response, user: User) => Promise<void>;
|
|
21
|
-
/**
|
|
22
|
-
* Clears the JWT auth cookies and user locals object.
|
|
23
|
-
* @param res - Express response object.
|
|
24
|
-
*/
|
|
25
|
-
export declare const clearUserAuth: (res: ResponseWithInformation) => Promise<void>;
|
|
26
|
-
/**
|
|
27
|
-
*
|
|
28
|
-
* @param res
|
|
29
|
-
* @param organization
|
|
30
|
-
* @returns
|
|
31
|
-
*/
|
|
32
|
-
export declare const setOrganizationAuth: (res: ResponseWithInformation, organization: Organization) => void;
|
|
33
|
-
/**
|
|
34
|
-
* Clears the JWT organization cookies and organization locals object.
|
|
35
|
-
* @param res - Express response object.
|
|
36
|
-
*/
|
|
37
|
-
export declare const clearOrganizationAuth: (res: ResponseWithInformation) => void;
|
|
38
|
-
/**
|
|
39
|
-
* Set project auth locals object
|
|
40
|
-
* @param res - Express response object.
|
|
41
|
-
* @param project - Project object.
|
|
42
|
-
*/
|
|
43
|
-
export declare const setProjectAuth: (res: ResponseWithInformation, project: Project) => void;
|
|
44
|
-
/**
|
|
45
|
-
* Clears the JWT project cookies and project locals object.
|
|
46
|
-
* @param res - Express response object.
|
|
47
|
-
*/
|
|
48
|
-
export declare const clearProjectAuth: (res: Response) => void;
|
|
49
|
-
/**
|
|
50
|
-
* Generates a random secret string of a specified length.
|
|
51
|
-
* @param length - The length of the secret.
|
|
52
|
-
* @returns The generated secret string.
|
|
53
|
-
*/
|
|
54
|
-
export declare const generateSecret: (length: number) => string;
|
|
55
|
-
/**
|
|
56
|
-
* Handles a password reset request for a user.
|
|
57
|
-
* @param email - The user's email.
|
|
58
|
-
* @param organization - The organization associated with the user.
|
|
59
|
-
* @returns The user object or null if no user was found.
|
|
60
|
-
*/
|
|
61
|
-
export declare const requestPasswordReset: (email: string) => Promise<User | null>;
|
|
62
|
-
/**
|
|
63
|
-
* Resets a user's password.
|
|
64
|
-
* @param userId - The ID of the user.
|
|
65
|
-
* @param secret - The secret token associated with the user.
|
|
66
|
-
* @param newPassword - The new password to set.
|
|
67
|
-
* @returns The updated user or null if the reset failed.
|
|
68
|
-
*/
|
|
69
|
-
export declare const resetUserPassword: (userId: string | ObjectId, secret: string, newPassword: string) => Promise<User>;
|
|
70
|
-
type UserProvider<T extends SessionProviders['provider']> = T extends 'email' ? EmailPasswordSessionProvider : T extends 'google' ? GoogleSessionProvider : T extends 'github' ? GithubSessionProvider : SessionProviders;
|
|
71
|
-
/**
|
|
72
|
-
* Gets a user's provider.
|
|
73
|
-
* @param userId - The ID of the user.
|
|
74
|
-
* @param provider - The provider to get.
|
|
75
|
-
* @returns The user's provider.
|
|
76
|
-
*/
|
|
77
|
-
export declare const getUserProvider: <T extends SessionProviders["provider"]>(userId: string | ObjectId, provider: T, providerAccountId?: string) => Promise<UserProvider<T> | null>;
|
|
78
|
-
/**
|
|
79
|
-
* Formats the given fields of a user's provider.
|
|
80
|
-
* @param provider - The provider to update.
|
|
81
|
-
* @param user - The user object.
|
|
82
|
-
* @param providerUpdate - The updates to apply to the provider.
|
|
83
|
-
* @returns The updated user provider.
|
|
84
|
-
*/
|
|
85
|
-
export declare const formatUserProviderUpdate: <T extends SessionProviders["provider"]>(provider: T, user: Partial<User>, providerUpdate: Partial<UserProvider<T>>) => User["provider"];
|
|
86
|
-
/**
|
|
87
|
-
* Updates the given fields of a user's provider.
|
|
88
|
-
* @param userId - The ID of the user.
|
|
89
|
-
* @param provider - The provider to update.
|
|
90
|
-
* @param providerUpdate - The updates to apply to the provider.
|
|
91
|
-
* @returns The updated user.
|
|
92
|
-
*/
|
|
93
|
-
export declare const updateUserProvider: <T extends SessionProviders["provider"]>(userId: string | ObjectId, provider: T, providerUpdate: Partial<UserProvider<T>>) => Promise<UserDocument>;
|
|
94
|
-
/**
|
|
95
|
-
* Updates the given fields of a user's provider.
|
|
96
|
-
* @param userId - The ID of the user.
|
|
97
|
-
* @param provider - The updates to apply to the provider.
|
|
98
|
-
* @returns The updated user.
|
|
99
|
-
*/
|
|
100
|
-
export declare const addUserProvider: (userId: string | ObjectId, provider: SessionProviders) => Promise<UserDocument>;
|
|
101
|
-
/**
|
|
102
|
-
* Removes a user's provider.
|
|
103
|
-
* @param userId - The ID of the user.
|
|
104
|
-
* @param provider - The provider to remove.
|
|
105
|
-
* @returns The updated user.
|
|
106
|
-
*/
|
|
107
|
-
export declare const removeUserProvider: (userId: string | ObjectId, provider: SessionProviders["provider"], providerAccountId?: string) => Promise<UserDocument>;
|
|
108
|
-
type TestUserPasswordResult = {
|
|
109
|
-
user: User | null;
|
|
110
|
-
error?: string;
|
|
111
|
-
};
|
|
112
|
-
/**
|
|
113
|
-
* Logs in a user.
|
|
114
|
-
* @param email - The user's email.
|
|
115
|
-
* @param password - The user's password.
|
|
116
|
-
* @returns The user object.
|
|
117
|
-
*/
|
|
118
|
-
export declare const testUserPassword: (email: string, password: string) => Promise<TestUserPasswordResult>;
|
|
119
|
-
/**
|
|
120
|
-
* Hashes a user's password.
|
|
121
|
-
* @param userWithPasswordNotHashed - The user object with password not hashed.
|
|
122
|
-
* @returns The user object with hashed password.
|
|
123
|
-
*/
|
|
124
|
-
export declare const hashUserPassword: (userWithPasswordNotHashed: UserWithPasswordNotHashed) => Promise<Partial<UserDocument>>;
|
|
125
|
-
/**
|
|
126
|
-
* Changes a user's password.
|
|
127
|
-
* @param userId - The ID of the user.
|
|
128
|
-
* @param newPassword - The user's new password.
|
|
129
|
-
* @returns The updated user or null if the password change failed.
|
|
130
|
-
*/
|
|
131
|
-
export declare const changeUserPassword: (userId: string | ObjectId, newPassword: string) => Promise<User>;
|
|
132
|
-
/**
|
|
133
|
-
* Resets a user's password.
|
|
134
|
-
* @param userId - The ID of the user.
|
|
135
|
-
* @param secret - The secret token associated with the user.
|
|
136
|
-
* @param newPassword - The new password to set.
|
|
137
|
-
* @returns The updated user or null if the reset failed.
|
|
138
|
-
*/
|
|
139
|
-
export declare const resetPassword: (userId: string, password: string) => Promise<UserDocument>;
|
|
140
|
-
export {};
|
|
141
|
-
//# sourceMappingURL=sessionAuth.service.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sessionAuth.service.d.ts","sourceRoot":"","sources":["../../../src/services/sessionAuth.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
declare const generateCsrfToken: import("csrf-csrf").CsrfTokenGenerator, validateRequest: import("csrf-csrf").CsrfRequestValidator, doubleCsrfProtection: import("csrf-csrf").DoubleCsrfProtection;
|
|
2
|
-
export { doubleCsrfProtection, generateCsrfToken as generateToken, validateRequest, };
|
|
3
|
-
//# sourceMappingURL=CSRF.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CSRF.d.ts","sourceRoot":"","sources":["../../../src/utils/CSRF.ts"],"names":[],"mappings":"AAGA,QAAA,MACE,iBAAiB,0CACjB,eAAe,4CACf,oBAAoB,0CAcpB,CAAC;AAEH,OAAO,EACL,oBAAoB,EACpB,iBAAiB,IAAI,aAAa,EAClC,eAAe,GAChB,CAAC"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { CookieOptions } from 'express';
|
|
2
|
-
export declare const MAX_AGE: number;
|
|
3
|
-
export declare enum Cookies {
|
|
4
|
-
JWT_AUTH = "intlayer_auth",
|
|
5
|
-
JWT_USER = "intlayer_user",
|
|
6
|
-
JWT_ORGANIZATION = "intlayer_organization",
|
|
7
|
-
JWT_PROJECT = "intlayer_project",
|
|
8
|
-
XSRF_TOKEN = "XSRF-TOKEN"
|
|
9
|
-
}
|
|
10
|
-
export declare const getCookieOptions: (overwriteOption?: Partial<CookieOptions>) => CookieOptions;
|
|
11
|
-
export declare const getClearCookieOptions: (overwriteOption?: Partial<CookieOptions>) => CookieOptions;
|
|
12
|
-
//# sourceMappingURL=cookies.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cookies.d.ts","sourceRoot":"","sources":["../../../src/utils/cookies.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAE7C,eAAO,MAAM,OAAO,QAA0B,CAAC;AAE/C,oBAAY,OAAO;IACjB,QAAQ,kBAAkB;IAC1B,QAAQ,kBAAkB;IAC1B,gBAAgB,0BAA0B;IAC1C,WAAW,qBAAqB;IAChC,UAAU,eAAe;CAC1B;AAED,eAAO,MAAM,gBAAgB,GAC3B,kBAAiB,OAAO,CAAC,aAAa,CAAM,KAC3C,aASD,CAAC;AAEH,eAAO,MAAM,qBAAqB,GAChC,kBAAiB,OAAO,CAAC,aAAa,CAAM,KAC3C,aAID,CAAC"}
|