@crowi/api 2.0.0-alpha.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/LICENSE +21 -0
- package/dist/app.d.ts +8 -0
- package/dist/app.js +65 -0
- package/dist/app.js.map +1 -0
- package/dist/collab/attach.d.ts +33 -0
- package/dist/collab/attach.js +341 -0
- package/dist/collab/attach.js.map +1 -0
- package/dist/collab/extension-redis.d.ts +25 -0
- package/dist/collab/extension-redis.js +133 -0
- package/dist/collab/extension-redis.js.map +1 -0
- package/dist/common/functions/path2name.d.ts +1 -0
- package/dist/common/functions/path2name.js +22 -0
- package/dist/common/functions/path2name.js.map +1 -0
- package/dist/common/functions/renderIcon.d.ts +1 -0
- package/dist/common/functions/renderIcon.js +9 -0
- package/dist/common/functions/renderIcon.js.map +1 -0
- package/dist/controllers/admin.d.ts +3 -0
- package/dist/controllers/admin.js +474 -0
- package/dist/controllers/admin.js.map +1 -0
- package/dist/controllers/attachment.d.ts +4 -0
- package/dist/controllers/attachment.js +200 -0
- package/dist/controllers/attachment.js.map +1 -0
- package/dist/controllers/backlink.d.ts +3 -0
- package/dist/controllers/backlink.js +42 -0
- package/dist/controllers/backlink.js.map +1 -0
- package/dist/controllers/bookmark.d.ts +3 -0
- package/dist/controllers/bookmark.js +100 -0
- package/dist/controllers/bookmark.js.map +1 -0
- package/dist/controllers/comment.d.ts +3 -0
- package/dist/controllers/comment.js +111 -0
- package/dist/controllers/comment.js.map +1 -0
- package/dist/controllers/index.d.ts +25 -0
- package/dist/controllers/index.js +44 -0
- package/dist/controllers/index.js.map +1 -0
- package/dist/controllers/installer.d.ts +3 -0
- package/dist/controllers/installer.js +48 -0
- package/dist/controllers/installer.js.map +1 -0
- package/dist/controllers/login.d.ts +4 -0
- package/dist/controllers/login.js +438 -0
- package/dist/controllers/login.js.map +1 -0
- package/dist/controllers/logout.d.ts +5 -0
- package/dist/controllers/logout.js +11 -0
- package/dist/controllers/logout.js.map +1 -0
- package/dist/controllers/me.d.ts +4 -0
- package/dist/controllers/me.js +369 -0
- package/dist/controllers/me.js.map +1 -0
- package/dist/controllers/notification.d.ts +3 -0
- package/dist/controllers/notification.js +88 -0
- package/dist/controllers/notification.js.map +1 -0
- package/dist/controllers/page.d.ts +3 -0
- package/dist/controllers/page.js +881 -0
- package/dist/controllers/page.js.map +1 -0
- package/dist/controllers/revision.d.ts +3 -0
- package/dist/controllers/revision.js +91 -0
- package/dist/controllers/revision.js.map +1 -0
- package/dist/controllers/search.d.ts +3 -0
- package/dist/controllers/search.js +93 -0
- package/dist/controllers/search.js.map +1 -0
- package/dist/controllers/share.d.ts +3 -0
- package/dist/controllers/share.js +207 -0
- package/dist/controllers/share.js.map +1 -0
- package/dist/controllers/shareAccess.d.ts +3 -0
- package/dist/controllers/shareAccess.js +28 -0
- package/dist/controllers/shareAccess.js.map +1 -0
- package/dist/controllers/slack.d.ts +3 -0
- package/dist/controllers/slack.js +87 -0
- package/dist/controllers/slack.js.map +1 -0
- package/dist/controllers/tokenAuth.d.ts +10 -0
- package/dist/controllers/tokenAuth.js +292 -0
- package/dist/controllers/tokenAuth.js.map +1 -0
- package/dist/controllers/user.d.ts +3 -0
- package/dist/controllers/user.js +67 -0
- package/dist/controllers/user.js.map +1 -0
- package/dist/controllers/version.d.ts +4 -0
- package/dist/controllers/version.js +19 -0
- package/dist/controllers/version.js.map +1 -0
- package/dist/crowi/express-init.d.ts +4 -0
- package/dist/crowi/express-init.js +101 -0
- package/dist/crowi/express-init.js.map +1 -0
- package/dist/crowi/index.d.ts +245 -0
- package/dist/crowi/index.js +726 -0
- package/dist/crowi/index.js.map +1 -0
- package/dist/events/activity.d.ts +7 -0
- package/dist/events/activity.js +15 -0
- package/dist/events/activity.js.map +1 -0
- package/dist/events/bookmark.d.ts +8 -0
- package/dist/events/bookmark.js +16 -0
- package/dist/events/bookmark.js.map +1 -0
- package/dist/events/comment.d.ts +6 -0
- package/dist/events/comment.js +14 -0
- package/dist/events/comment.js.map +1 -0
- package/dist/events/config.d.ts +6 -0
- package/dist/events/config.js +12 -0
- package/dist/events/config.js.map +1 -0
- package/dist/events/index.d.ts +17 -0
- package/dist/events/index.js +22 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/mention-dispatch.d.ts +44 -0
- package/dist/events/mention-dispatch.js +151 -0
- package/dist/events/mention-dispatch.js.map +1 -0
- package/dist/events/notification.d.ts +7 -0
- package/dist/events/notification.js +15 -0
- package/dist/events/notification.js.map +1 -0
- package/dist/events/page.d.ts +44 -0
- package/dist/events/page.js +134 -0
- package/dist/events/page.js.map +1 -0
- package/dist/events/render-cache.d.ts +24 -0
- package/dist/events/render-cache.js +63 -0
- package/dist/events/render-cache.js.map +1 -0
- package/dist/events/user.d.ts +9 -0
- package/dist/events/user.js +39 -0
- package/dist/events/user.js.map +1 -0
- package/dist/form/admin/app.d.ts +2 -0
- package/dist/form/admin/app.js +9 -0
- package/dist/form/admin/app.js.map +1 -0
- package/dist/form/admin/auth.d.ts +2 -0
- package/dist/form/admin/auth.js +9 -0
- package/dist/form/admin/auth.js.map +1 -0
- package/dist/form/admin/aws.d.ts +2 -0
- package/dist/form/admin/aws.js +13 -0
- package/dist/form/admin/aws.js.map +1 -0
- package/dist/form/admin/github.d.ts +2 -0
- package/dist/form/admin/github.js +15 -0
- package/dist/form/admin/github.js.map +1 -0
- package/dist/form/admin/google.d.ts +2 -0
- package/dist/form/admin/google.js +13 -0
- package/dist/form/admin/google.js.map +1 -0
- package/dist/form/admin/mail.d.ts +2 -0
- package/dist/form/admin/mail.js +13 -0
- package/dist/form/admin/mail.js.map +1 -0
- package/dist/form/admin/sec.d.ts +2 -0
- package/dist/form/admin/sec.js +10 -0
- package/dist/form/admin/sec.js.map +1 -0
- package/dist/form/admin/slackSetting.d.ts +2 -0
- package/dist/form/admin/slackSetting.js +13 -0
- package/dist/form/admin/slackSetting.js.map +1 -0
- package/dist/form/admin/userEdit.d.ts +2 -0
- package/dist/form/admin/userEdit.js +9 -0
- package/dist/form/admin/userEdit.js.map +1 -0
- package/dist/form/admin/userInvite.d.ts +2 -0
- package/dist/form/admin/userInvite.js +9 -0
- package/dist/form/admin/userInvite.js.map +1 -0
- package/dist/form/comment.d.ts +2 -0
- package/dist/form/comment.js +9 -0
- package/dist/form/comment.js.map +1 -0
- package/dist/form/index.d.ts +25 -0
- package/dist/form/index.js +48 -0
- package/dist/form/index.js.map +1 -0
- package/dist/form/invited.d.ts +2 -0
- package/dist/form/invited.js +13 -0
- package/dist/form/invited.js.map +1 -0
- package/dist/form/login.d.ts +2 -0
- package/dist/form/login.js +11 -0
- package/dist/form/login.js.map +1 -0
- package/dist/form/me/apiToken.d.ts +2 -0
- package/dist/form/me/apiToken.js +9 -0
- package/dist/form/me/apiToken.js.map +1 -0
- package/dist/form/me/password.d.ts +2 -0
- package/dist/form/me/password.js +11 -0
- package/dist/form/me/password.js.map +1 -0
- package/dist/form/me/user.d.ts +2 -0
- package/dist/form/me/user.js +9 -0
- package/dist/form/me/user.js.map +1 -0
- package/dist/form/register.d.ts +2 -0
- package/dist/form/register.js +13 -0
- package/dist/form/register.js.map +1 -0
- package/dist/form/revision.d.ts +2 -0
- package/dist/form/revision.js +13 -0
- package/dist/form/revision.js.map +1 -0
- package/dist/hono/app.d.ts +19 -0
- package/dist/hono/app.js +21 -0
- package/dist/hono/app.js.map +1 -0
- package/dist/hono/handlers/_helpers/errors.d.ts +61 -0
- package/dist/hono/handlers/_helpers/errors.js +51 -0
- package/dist/hono/handlers/_helpers/errors.js.map +1 -0
- package/dist/hono/handlers/_helpers/user-shape.d.ts +46 -0
- package/dist/hono/handlers/_helpers/user-shape.js +23 -0
- package/dist/hono/handlers/_helpers/user-shape.js.map +1 -0
- package/dist/hono/handlers/access-token.d.ts +221 -0
- package/dist/hono/handlers/access-token.js +113 -0
- package/dist/hono/handlers/access-token.js.map +1 -0
- package/dist/hono/handlers/activation.d.ts +117 -0
- package/dist/hono/handlers/activation.js +77 -0
- package/dist/hono/handlers/activation.js.map +1 -0
- package/dist/hono/handlers/admin/app.d.ts +123 -0
- package/dist/hono/handlers/admin/app.js +76 -0
- package/dist/hono/handlers/admin/app.js.map +1 -0
- package/dist/hono/handlers/admin/auth.d.ts +127 -0
- package/dist/hono/handlers/admin/auth.js +91 -0
- package/dist/hono/handlers/admin/auth.js.map +1 -0
- package/dist/hono/handlers/admin/mail.d.ts +168 -0
- package/dist/hono/handlers/admin/mail.js +76 -0
- package/dist/hono/handlers/admin/mail.js.map +1 -0
- package/dist/hono/handlers/admin/plugins.d.ts +409 -0
- package/dist/hono/handlers/admin/plugins.js +257 -0
- package/dist/hono/handlers/admin/plugins.js.map +1 -0
- package/dist/hono/handlers/admin/search.d.ts +57 -0
- package/dist/hono/handlers/admin/search.js +55 -0
- package/dist/hono/handlers/admin/search.js.map +1 -0
- package/dist/hono/handlers/admin/security.d.ts +112 -0
- package/dist/hono/handlers/admin/security.js +71 -0
- package/dist/hono/handlers/admin/security.js.map +1 -0
- package/dist/hono/handlers/admin/share.d.ts +106 -0
- package/dist/hono/handlers/admin/share.js +55 -0
- package/dist/hono/handlers/admin/share.js.map +1 -0
- package/dist/hono/handlers/admin/storage.d.ts +55 -0
- package/dist/hono/handlers/admin/storage.js +40 -0
- package/dist/hono/handlers/admin/storage.js.map +1 -0
- package/dist/hono/handlers/admin/users.d.ts +1230 -0
- package/dist/hono/handlers/admin/users.js +316 -0
- package/dist/hono/handlers/admin/users.js.map +1 -0
- package/dist/hono/handlers/adminCrypto.d.ts +110 -0
- package/dist/hono/handlers/adminCrypto.js +151 -0
- package/dist/hono/handlers/adminCrypto.js.map +1 -0
- package/dist/hono/handlers/app.d.ts +26 -0
- package/dist/hono/handlers/app.js +34 -0
- package/dist/hono/handlers/app.js.map +1 -0
- package/dist/hono/handlers/attachment-stream.d.ts +4 -0
- package/dist/hono/handlers/attachment-stream.js +211 -0
- package/dist/hono/handlers/attachment-stream.js.map +1 -0
- package/dist/hono/handlers/attachment.d.ts +687 -0
- package/dist/hono/handlers/attachment.js +566 -0
- package/dist/hono/handlers/attachment.js.map +1 -0
- package/dist/hono/handlers/autocomplete.d.ts +160 -0
- package/dist/hono/handlers/autocomplete.js +181 -0
- package/dist/hono/handlers/autocomplete.js.map +1 -0
- package/dist/hono/handlers/backlink.d.ts +78 -0
- package/dist/hono/handlers/backlink.js +93 -0
- package/dist/hono/handlers/backlink.js.map +1 -0
- package/dist/hono/handlers/bookmark.d.ts +558 -0
- package/dist/hono/handlers/bookmark.js +166 -0
- package/dist/hono/handlers/bookmark.js.map +1 -0
- package/dist/hono/handlers/comment.d.ts +231 -0
- package/dist/hono/handlers/comment.js +191 -0
- package/dist/hono/handlers/comment.js.map +1 -0
- package/dist/hono/handlers/draft.d.ts +136 -0
- package/dist/hono/handlers/draft.js +191 -0
- package/dist/hono/handlers/draft.js.map +1 -0
- package/dist/hono/handlers/emailChange.d.ts +124 -0
- package/dist/hono/handlers/emailChange.js +79 -0
- package/dist/hono/handlers/emailChange.js.map +1 -0
- package/dist/hono/handlers/installer.d.ts +94 -0
- package/dist/hono/handlers/installer.js +93 -0
- package/dist/hono/handlers/installer.js.map +1 -0
- package/dist/hono/handlers/inviteAccept.d.ts +180 -0
- package/dist/hono/handlers/inviteAccept.js +94 -0
- package/dist/hono/handlers/inviteAccept.js.map +1 -0
- package/dist/hono/handlers/me.d.ts +401 -0
- package/dist/hono/handlers/me.js +390 -0
- package/dist/hono/handlers/me.js.map +1 -0
- package/dist/hono/handlers/notification.d.ts +274 -0
- package/dist/hono/handlers/notification.js +224 -0
- package/dist/hono/handlers/notification.js.map +1 -0
- package/dist/hono/handlers/oauth.d.ts +299 -0
- package/dist/hono/handlers/oauth.js +443 -0
- package/dist/hono/handlers/oauth.js.map +1 -0
- package/dist/hono/handlers/page-collab.d.ts +79 -0
- package/dist/hono/handlers/page-collab.js +98 -0
- package/dist/hono/handlers/page-collab.js.map +1 -0
- package/dist/hono/handlers/page-preview.d.ts +48 -0
- package/dist/hono/handlers/page-preview.js +83 -0
- package/dist/hono/handlers/page-preview.js.map +1 -0
- package/dist/hono/handlers/page.d.ts +2059 -0
- package/dist/hono/handlers/page.js +793 -0
- package/dist/hono/handlers/page.js.map +1 -0
- package/dist/hono/handlers/passwordReset.d.ts +181 -0
- package/dist/hono/handlers/passwordReset.js +101 -0
- package/dist/hono/handlers/passwordReset.js.map +1 -0
- package/dist/hono/handlers/presence.d.ts +178 -0
- package/dist/hono/handlers/presence.js +163 -0
- package/dist/hono/handlers/presence.js.map +1 -0
- package/dist/hono/handlers/revision.d.ts +345 -0
- package/dist/hono/handlers/revision.js +202 -0
- package/dist/hono/handlers/revision.js.map +1 -0
- package/dist/hono/handlers/search.d.ts +208 -0
- package/dist/hono/handlers/search.js +152 -0
- package/dist/hono/handlers/search.js.map +1 -0
- package/dist/hono/handlers/tokenAuth.d.ts +369 -0
- package/dist/hono/handlers/tokenAuth.js +240 -0
- package/dist/hono/handlers/tokenAuth.js.map +1 -0
- package/dist/hono/handlers/user.d.ts +710 -0
- package/dist/hono/handlers/user.js +212 -0
- package/dist/hono/handlers/user.js.map +1 -0
- package/dist/hono/index.d.ts +289 -0
- package/dist/hono/index.js +240 -0
- package/dist/hono/index.js.map +1 -0
- package/dist/hono/middleware/admin.d.ts +5 -0
- package/dist/hono/middleware/admin.js +34 -0
- package/dist/hono/middleware/admin.js.map +1 -0
- package/dist/hono/middleware/auth.d.ts +54 -0
- package/dist/hono/middleware/auth.js +142 -0
- package/dist/hono/middleware/auth.js.map +1 -0
- package/dist/hono/middleware/cors.d.ts +3 -0
- package/dist/hono/middleware/cors.js +86 -0
- package/dist/hono/middleware/cors.js.map +1 -0
- package/dist/hono/middleware/default-hook.d.ts +8 -0
- package/dist/hono/middleware/default-hook.js +17 -0
- package/dist/hono/middleware/default-hook.js.map +1 -0
- package/dist/hono/middleware/error-handler.d.ts +2 -0
- package/dist/hono/middleware/error-handler.js +20 -0
- package/dist/hono/middleware/error-handler.js.map +1 -0
- package/dist/hono/middleware/rate-limit.d.ts +57 -0
- package/dist/hono/middleware/rate-limit.js +42 -0
- package/dist/hono/middleware/rate-limit.js.map +1 -0
- package/dist/hono/middleware/require-scope.d.ts +50 -0
- package/dist/hono/middleware/require-scope.js +64 -0
- package/dist/hono/middleware/require-scope.js.map +1 -0
- package/dist/hono/path-rewrite.d.ts +15 -0
- package/dist/hono/path-rewrite.js +59 -0
- package/dist/hono/path-rewrite.js.map +1 -0
- package/dist/mail/i18n/en.d.ts +2 -0
- package/dist/mail/i18n/en.js +66 -0
- package/dist/mail/i18n/en.js.map +1 -0
- package/dist/mail/i18n/index.d.ts +46 -0
- package/dist/mail/i18n/index.js +31 -0
- package/dist/mail/i18n/index.js.map +1 -0
- package/dist/mail/i18n/ja.d.ts +2 -0
- package/dist/mail/i18n/ja.js +66 -0
- package/dist/mail/i18n/ja.js.map +1 -0
- package/dist/mcp/attach.d.ts +25 -0
- package/dist/mcp/attach.js +104 -0
- package/dist/mcp/attach.js.map +1 -0
- package/dist/mcp/dispatch.d.ts +59 -0
- package/dist/mcp/dispatch.js +70 -0
- package/dist/mcp/dispatch.js.map +1 -0
- package/dist/mcp/result.d.ts +40 -0
- package/dist/mcp/result.js +78 -0
- package/dist/mcp/result.js.map +1 -0
- package/dist/mcp/server.d.ts +67 -0
- package/dist/mcp/server.js +113 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/page.d.ts +2 -0
- package/dist/mcp/tools/page.js +256 -0
- package/dist/mcp/tools/page.js.map +1 -0
- package/dist/mcp/tools/search.d.ts +2 -0
- package/dist/mcp/tools/search.js +36 -0
- package/dist/mcp/tools/search.js.map +1 -0
- package/dist/middlewares/accessTokenParser.d.ts +4 -0
- package/dist/middlewares/accessTokenParser.js +29 -0
- package/dist/middlewares/accessTokenParser.js.map +1 -0
- package/dist/middlewares/adminRequired.d.ts +10 -0
- package/dist/middlewares/adminRequired.js +35 -0
- package/dist/middlewares/adminRequired.js.map +1 -0
- package/dist/middlewares/applicationInstalled.d.ts +3 -0
- package/dist/middlewares/applicationInstalled.js +20 -0
- package/dist/middlewares/applicationInstalled.js.map +1 -0
- package/dist/middlewares/applicationNotInstalled.d.ts +3 -0
- package/dist/middlewares/applicationNotInstalled.js +13 -0
- package/dist/middlewares/applicationNotInstalled.js.map +1 -0
- package/dist/middlewares/basicAuth.d.ts +4 -0
- package/dist/middlewares/basicAuth.js +23 -0
- package/dist/middlewares/basicAuth.js.map +1 -0
- package/dist/middlewares/csrfVerify.d.ts +4 -0
- package/dist/middlewares/csrfVerify.js +24 -0
- package/dist/middlewares/csrfVerify.js.map +1 -0
- package/dist/middlewares/encodeSpace.d.ts +3 -0
- package/dist/middlewares/encodeSpace.js +14 -0
- package/dist/middlewares/encodeSpace.js.map +1 -0
- package/dist/middlewares/fileAccessRightOrLoginRequired.d.ts +4 -0
- package/dist/middlewares/fileAccessRightOrLoginRequired.js +29 -0
- package/dist/middlewares/fileAccessRightOrLoginRequired.js.map +1 -0
- package/dist/middlewares/index.d.ts +16 -0
- package/dist/middlewares/index.js +30 -0
- package/dist/middlewares/index.js.map +1 -0
- package/dist/middlewares/jwtAdminRequired.d.ts +8 -0
- package/dist/middlewares/jwtAdminRequired.js +35 -0
- package/dist/middlewares/jwtAdminRequired.js.map +1 -0
- package/dist/middlewares/jwtAuth.d.ts +4 -0
- package/dist/middlewares/jwtAuth.js +104 -0
- package/dist/middlewares/jwtAuth.js.map +1 -0
- package/dist/middlewares/loginChecker.d.ts +4 -0
- package/dist/middlewares/loginChecker.js +32 -0
- package/dist/middlewares/loginChecker.js.map +1 -0
- package/dist/middlewares/loginRequired.d.ts +4 -0
- package/dist/middlewares/loginRequired.js +88 -0
- package/dist/middlewares/loginRequired.js.map +1 -0
- package/dist/migration/cli-api.d.ts +83 -0
- package/dist/migration/cli-api.js +128 -0
- package/dist/migration/cli-api.js.map +1 -0
- package/dist/migration/migrations/index.d.ts +12 -0
- package/dist/migration/migrations/index.js +24 -0
- package/dist/migration/migrations/index.js.map +1 -0
- package/dist/migration/migrations/page-status-default.d.ts +25 -0
- package/dist/migration/migrations/page-status-default.js +79 -0
- package/dist/migration/migrations/page-status-default.js.map +1 -0
- package/dist/migration/migrations/revisions-schema-unify.d.ts +33 -0
- package/dist/migration/migrations/revisions-schema-unify.js +88 -0
- package/dist/migration/migrations/revisions-schema-unify.js.map +1 -0
- package/dist/migration/migrations/user-unique-prepare.d.ts +1 -0
- package/dist/migration/migrations/user-unique-prepare.js +214 -0
- package/dist/migration/migrations/user-unique-prepare.js.map +1 -0
- package/dist/migration/migrations/wikilink-format.d.ts +97 -0
- package/dist/migration/migrations/wikilink-format.js +418 -0
- package/dist/migration/migrations/wikilink-format.js.map +1 -0
- package/dist/migration/rebuild-api.d.ts +50 -0
- package/dist/migration/rebuild-api.js +45 -0
- package/dist/migration/rebuild-api.js.map +1 -0
- package/dist/migration/rebuild-runner.d.ts +64 -0
- package/dist/migration/rebuild-runner.js +42 -0
- package/dist/migration/rebuild-runner.js.map +1 -0
- package/dist/migration/rebuilds/index.d.ts +26 -0
- package/dist/migration/rebuilds/index.js +69 -0
- package/dist/migration/rebuilds/index.js.map +1 -0
- package/dist/migration/registry.d.ts +15 -0
- package/dist/migration/registry.js +96 -0
- package/dist/migration/registry.js.map +1 -0
- package/dist/migration/run-boot-migrations.d.ts +31 -0
- package/dist/migration/run-boot-migrations.js +95 -0
- package/dist/migration/run-boot-migrations.js.map +1 -0
- package/dist/migration/runner.d.ts +120 -0
- package/dist/migration/runner.js +276 -0
- package/dist/migration/runner.js.map +1 -0
- package/dist/migration/types.d.ts +153 -0
- package/dist/migration/types.js +13 -0
- package/dist/migration/types.js.map +1 -0
- package/dist/models/activity.d.ts +34 -0
- package/dist/models/activity.js +263 -0
- package/dist/models/activity.js.map +1 -0
- package/dist/models/attachment.d.ts +25 -0
- package/dist/models/attachment.js +82 -0
- package/dist/models/attachment.js.map +1 -0
- package/dist/models/backlink.d.ts +19 -0
- package/dist/models/backlink.js +138 -0
- package/dist/models/backlink.js.map +1 -0
- package/dist/models/bookmark.d.ts +28 -0
- package/dist/models/bookmark.js +136 -0
- package/dist/models/bookmark.js.map +1 -0
- package/dist/models/comment.d.ts +21 -0
- package/dist/models/comment.js +87 -0
- package/dist/models/comment.js.map +1 -0
- package/dist/models/config-sensitive.d.ts +21 -0
- package/dist/models/config-sensitive.js +71 -0
- package/dist/models/config-sensitive.js.map +1 -0
- package/dist/models/config.d.ts +34 -0
- package/dist/models/config.js +161 -0
- package/dist/models/config.js.map +1 -0
- package/dist/models/index.d.ts +30 -0
- package/dist/models/index.js +55 -0
- package/dist/models/index.js.map +1 -0
- package/dist/models/migration-application.d.ts +54 -0
- package/dist/models/migration-application.js +36 -0
- package/dist/models/migration-application.js.map +1 -0
- package/dist/models/notification.d.ts +28 -0
- package/dist/models/notification.js +285 -0
- package/dist/models/notification.js.map +1 -0
- package/dist/models/oauth-authorization-code.d.ts +34 -0
- package/dist/models/oauth-authorization-code.js +100 -0
- package/dist/models/oauth-authorization-code.js.map +1 -0
- package/dist/models/oauth-client.d.ts +36 -0
- package/dist/models/oauth-client.js +56 -0
- package/dist/models/oauth-client.js.map +1 -0
- package/dist/models/oauth-device-code.d.ts +55 -0
- package/dist/models/oauth-device-code.js +158 -0
- package/dist/models/oauth-device-code.js.map +1 -0
- package/dist/models/oauth-refresh-token.d.ts +31 -0
- package/dist/models/oauth-refresh-token.js +118 -0
- package/dist/models/oauth-refresh-token.js.map +1 -0
- package/dist/models/page-yjs-update.d.ts +35 -0
- package/dist/models/page-yjs-update.js +33 -0
- package/dist/models/page-yjs-update.js.map +1 -0
- package/dist/models/page.d.ts +200 -0
- package/dist/models/page.js +1117 -0
- package/dist/models/page.js.map +1 -0
- package/dist/models/personal-access-token.d.ts +30 -0
- package/dist/models/personal-access-token.js +107 -0
- package/dist/models/personal-access-token.js.map +1 -0
- package/dist/models/plugin-render-cache.d.ts +40 -0
- package/dist/models/plugin-render-cache.js +39 -0
- package/dist/models/plugin-render-cache.js.map +1 -0
- package/dist/models/revision.d.ts +145 -0
- package/dist/models/revision.js +241 -0
- package/dist/models/revision.js.map +1 -0
- package/dist/models/share.d.ts +38 -0
- package/dist/models/share.js +137 -0
- package/dist/models/share.js.map +1 -0
- package/dist/models/shareAccess.d.ts +20 -0
- package/dist/models/shareAccess.js +45 -0
- package/dist/models/shareAccess.js.map +1 -0
- package/dist/models/tracking.d.ts +14 -0
- package/dist/models/tracking.js +14 -0
- package/dist/models/tracking.js.map +1 -0
- package/dist/models/updatePost.d.ts +25 -0
- package/dist/models/updatePost.js +87 -0
- package/dist/models/updatePost.js.map +1 -0
- package/dist/models/user.d.ts +144 -0
- package/dist/models/user.js +681 -0
- package/dist/models/user.js.map +1 -0
- package/dist/models/watcher.d.ts +23 -0
- package/dist/models/watcher.js +75 -0
- package/dist/models/watcher.js.map +1 -0
- package/dist/notifications/attach.d.ts +63 -0
- package/dist/notifications/attach.js +426 -0
- package/dist/notifications/attach.js.map +1 -0
- package/dist/notifications/channel.d.ts +13 -0
- package/dist/notifications/channel.js +18 -0
- package/dist/notifications/channel.js.map +1 -0
- package/dist/plugin/index.d.ts +2 -0
- package/dist/plugin/index.js +6 -0
- package/dist/plugin/index.js.map +1 -0
- package/dist/plugin/plugin-context.d.ts +22 -0
- package/dist/plugin/plugin-context.js +126 -0
- package/dist/plugin/plugin-context.js.map +1 -0
- package/dist/plugin/plugin-manager.d.ts +164 -0
- package/dist/plugin/plugin-manager.js +328 -0
- package/dist/plugin/plugin-manager.js.map +1 -0
- package/dist/plugin/plugin-namespace.d.ts +28 -0
- package/dist/plugin/plugin-namespace.js +53 -0
- package/dist/plugin/plugin-namespace.js.map +1 -0
- package/dist/plugin/registries.d.ts +38 -0
- package/dist/plugin/registries.js +71 -0
- package/dist/plugin/registries.js.map +1 -0
- package/dist/plugin/schema-serializer.d.ts +34 -0
- package/dist/plugin/schema-serializer.js +122 -0
- package/dist/plugin/schema-serializer.js.map +1 -0
- package/dist/plugin/topo-sort.d.ts +15 -0
- package/dist/plugin/topo-sort.js +59 -0
- package/dist/plugin/topo-sort.js.map +1 -0
- package/dist/presence/attach.d.ts +36 -0
- package/dist/presence/attach.js +399 -0
- package/dist/presence/attach.js.map +1 -0
- package/dist/renderer/__fixtures__/echo-embed.d.ts +27 -0
- package/dist/renderer/__fixtures__/echo-embed.js +24 -0
- package/dist/renderer/__fixtures__/echo-embed.js.map +1 -0
- package/dist/renderer/cache/index.d.ts +60 -0
- package/dist/renderer/cache/index.js +219 -0
- package/dist/renderer/cache/index.js.map +1 -0
- package/dist/renderer/cache/mongodb-cache.d.ts +82 -0
- package/dist/renderer/cache/mongodb-cache.js +180 -0
- package/dist/renderer/cache/mongodb-cache.js.map +1 -0
- package/dist/renderer/cache/reservation.d.ts +20 -0
- package/dist/renderer/cache/reservation.js +115 -0
- package/dist/renderer/cache/reservation.js.map +1 -0
- package/dist/renderer/core/_mdast-walk.d.ts +35 -0
- package/dist/renderer/core/_mdast-walk.js +45 -0
- package/dist/renderer/core/_mdast-walk.js.map +1 -0
- package/dist/renderer/core/code-block-dispatch.d.ts +31 -0
- package/dist/renderer/core/code-block-dispatch.js +166 -0
- package/dist/renderer/core/code-block-dispatch.js.map +1 -0
- package/dist/renderer/core/code-blocks.d.ts +12 -0
- package/dist/renderer/core/code-blocks.js +32 -0
- package/dist/renderer/core/code-blocks.js.map +1 -0
- package/dist/renderer/core/embed-tags.d.ts +14 -0
- package/dist/renderer/core/embed-tags.js +154 -0
- package/dist/renderer/core/embed-tags.js.map +1 -0
- package/dist/renderer/core/headings.d.ts +16 -0
- package/dist/renderer/core/headings.js +31 -0
- package/dist/renderer/core/headings.js.map +1 -0
- package/dist/renderer/core/index.d.ts +65 -0
- package/dist/renderer/core/index.js +83 -0
- package/dist/renderer/core/index.js.map +1 -0
- package/dist/renderer/core/mention-resolve.d.ts +39 -0
- package/dist/renderer/core/mention-resolve.js +75 -0
- package/dist/renderer/core/mention-resolve.js.map +1 -0
- package/dist/renderer/core/mentions.d.ts +2 -0
- package/dist/renderer/core/mentions.js +83 -0
- package/dist/renderer/core/mentions.js.map +1 -0
- package/dist/renderer/core/syntax-highlight.d.ts +21 -0
- package/dist/renderer/core/syntax-highlight.js +64 -0
- package/dist/renderer/core/syntax-highlight.js.map +1 -0
- package/dist/renderer/core/url-inline-expand.d.ts +9 -0
- package/dist/renderer/core/url-inline-expand.js +157 -0
- package/dist/renderer/core/url-inline-expand.js.map +1 -0
- package/dist/renderer/core/wikilinks.d.ts +2 -0
- package/dist/renderer/core/wikilinks.js +118 -0
- package/dist/renderer/core/wikilinks.js.map +1 -0
- package/dist/renderer/index.d.ts +67 -0
- package/dist/renderer/index.js +99 -0
- package/dist/renderer/index.js.map +1 -0
- package/dist/renderer/pipeline.d.ts +134 -0
- package/dist/renderer/pipeline.js +203 -0
- package/dist/renderer/pipeline.js.map +1 -0
- package/dist/renderer/registry.d.ts +83 -0
- package/dist/renderer/registry.js +130 -0
- package/dist/renderer/registry.js.map +1 -0
- package/dist/renderer/serialize.d.ts +27 -0
- package/dist/renderer/serialize.js +46 -0
- package/dist/renderer/serialize.js.map +1 -0
- package/dist/renderer/version.d.ts +30 -0
- package/dist/renderer/version.js +34 -0
- package/dist/renderer/version.js.map +1 -0
- package/dist/routes/admin.d.ts +4 -0
- package/dist/routes/admin.js +17 -0
- package/dist/routes/admin.js.map +1 -0
- package/dist/routes/api/admin.d.ts +4 -0
- package/dist/routes/api/admin.js +37 -0
- package/dist/routes/api/admin.js.map +1 -0
- package/dist/routes/api/attachment.d.ts +4 -0
- package/dist/routes/api/attachment.js +19 -0
- package/dist/routes/api/attachment.js.map +1 -0
- package/dist/routes/api/bookmark.d.ts +4 -0
- package/dist/routes/api/bookmark.js +15 -0
- package/dist/routes/api/bookmark.js.map +1 -0
- package/dist/routes/api/comment.d.ts +4 -0
- package/dist/routes/api/comment.js +14 -0
- package/dist/routes/api/comment.js.map +1 -0
- package/dist/routes/api/index.d.ts +4 -0
- package/dist/routes/api/index.js +36 -0
- package/dist/routes/api/index.js.map +1 -0
- package/dist/routes/api/like.d.ts +4 -0
- package/dist/routes/api/like.js +13 -0
- package/dist/routes/api/like.js.map +1 -0
- package/dist/routes/api/notification.d.ts +4 -0
- package/dist/routes/api/notification.js +15 -0
- package/dist/routes/api/notification.js.map +1 -0
- package/dist/routes/api/page.d.ts +4 -0
- package/dist/routes/api/page.js +24 -0
- package/dist/routes/api/page.js.map +1 -0
- package/dist/routes/api/revision.d.ts +4 -0
- package/dist/routes/api/revision.js +14 -0
- package/dist/routes/api/revision.js.map +1 -0
- package/dist/routes/api/share.d.ts +4 -0
- package/dist/routes/api/share.js +16 -0
- package/dist/routes/api/share.js.map +1 -0
- package/dist/routes/api/version.d.ts +4 -0
- package/dist/routes/api/version.js +10 -0
- package/dist/routes/api/version.js.map +1 -0
- package/dist/routes/index.d.ts +4 -0
- package/dist/routes/index.js +71 -0
- package/dist/routes/index.js.map +1 -0
- package/dist/routes/login.d.ts +4 -0
- package/dist/routes/login.js +18 -0
- package/dist/routes/login.js.map +1 -0
- package/dist/routes/me.d.ts +4 -0
- package/dist/routes/me.js +24 -0
- package/dist/routes/me.js.map +1 -0
- package/dist/routes/ts-rest/admin/app.d.ts +4 -0
- package/dist/routes/ts-rest/admin/app.js +67 -0
- package/dist/routes/ts-rest/admin/app.js.map +1 -0
- package/dist/routes/ts-rest/admin/auth.d.ts +4 -0
- package/dist/routes/ts-rest/admin/auth.js +95 -0
- package/dist/routes/ts-rest/admin/auth.js.map +1 -0
- package/dist/routes/ts-rest/admin/index.d.ts +10 -0
- package/dist/routes/ts-rest/admin/index.js +35 -0
- package/dist/routes/ts-rest/admin/index.js.map +1 -0
- package/dist/routes/ts-rest/admin/mail.d.ts +4 -0
- package/dist/routes/ts-rest/admin/mail.js +156 -0
- package/dist/routes/ts-rest/admin/mail.js.map +1 -0
- package/dist/routes/ts-rest/admin/plugins.d.ts +4 -0
- package/dist/routes/ts-rest/admin/plugins.js +317 -0
- package/dist/routes/ts-rest/admin/plugins.js.map +1 -0
- package/dist/routes/ts-rest/admin/search.d.ts +4 -0
- package/dist/routes/ts-rest/admin/search.js +67 -0
- package/dist/routes/ts-rest/admin/search.js.map +1 -0
- package/dist/routes/ts-rest/admin/security.d.ts +4 -0
- package/dist/routes/ts-rest/admin/security.js +114 -0
- package/dist/routes/ts-rest/admin/security.js.map +1 -0
- package/dist/routes/ts-rest/admin/share.d.ts +4 -0
- package/dist/routes/ts-rest/admin/share.js +69 -0
- package/dist/routes/ts-rest/admin/share.js.map +1 -0
- package/dist/routes/ts-rest/admin/storage.d.ts +4 -0
- package/dist/routes/ts-rest/admin/storage.js +59 -0
- package/dist/routes/ts-rest/admin/storage.js.map +1 -0
- package/dist/routes/ts-rest/admin/users.d.ts +4 -0
- package/dist/routes/ts-rest/admin/users.js +215 -0
- package/dist/routes/ts-rest/admin/users.js.map +1 -0
- package/dist/routes/ts-rest/adminCrypto.d.ts +4 -0
- package/dist/routes/ts-rest/adminCrypto.js +111 -0
- package/dist/routes/ts-rest/adminCrypto.js.map +1 -0
- package/dist/routes/ts-rest/app.d.ts +4 -0
- package/dist/routes/ts-rest/app.js +23 -0
- package/dist/routes/ts-rest/app.js.map +1 -0
- package/dist/routes/ts-rest/attachment.d.ts +4 -0
- package/dist/routes/ts-rest/attachment.js +830 -0
- package/dist/routes/ts-rest/attachment.js.map +1 -0
- package/dist/routes/ts-rest/auth.d.ts +4 -0
- package/dist/routes/ts-rest/auth.js +70 -0
- package/dist/routes/ts-rest/auth.js.map +1 -0
- package/dist/routes/ts-rest/autocomplete.d.ts +30 -0
- package/dist/routes/ts-rest/autocomplete.js +189 -0
- package/dist/routes/ts-rest/autocomplete.js.map +1 -0
- package/dist/routes/ts-rest/backlink.d.ts +4 -0
- package/dist/routes/ts-rest/backlink.js +106 -0
- package/dist/routes/ts-rest/backlink.js.map +1 -0
- package/dist/routes/ts-rest/bookmark.d.ts +4 -0
- package/dist/routes/ts-rest/bookmark.js +189 -0
- package/dist/routes/ts-rest/bookmark.js.map +1 -0
- package/dist/routes/ts-rest/comment.d.ts +4 -0
- package/dist/routes/ts-rest/comment.js +217 -0
- package/dist/routes/ts-rest/comment.js.map +1 -0
- package/dist/routes/ts-rest/draft.d.ts +22 -0
- package/dist/routes/ts-rest/draft.js +200 -0
- package/dist/routes/ts-rest/draft.js.map +1 -0
- package/dist/routes/ts-rest/index.d.ts +4 -0
- package/dist/routes/ts-rest/index.js +103 -0
- package/dist/routes/ts-rest/index.js.map +1 -0
- package/dist/routes/ts-rest/installer.d.ts +4 -0
- package/dist/routes/ts-rest/installer.js +77 -0
- package/dist/routes/ts-rest/installer.js.map +1 -0
- package/dist/routes/ts-rest/me.d.ts +4 -0
- package/dist/routes/ts-rest/me.js +410 -0
- package/dist/routes/ts-rest/me.js.map +1 -0
- package/dist/routes/ts-rest/notification.d.ts +4 -0
- package/dist/routes/ts-rest/notification.js +241 -0
- package/dist/routes/ts-rest/notification.js.map +1 -0
- package/dist/routes/ts-rest/page-collab.d.ts +29 -0
- package/dist/routes/ts-rest/page-collab.js +90 -0
- package/dist/routes/ts-rest/page-collab.js.map +1 -0
- package/dist/routes/ts-rest/page-preview.d.ts +26 -0
- package/dist/routes/ts-rest/page-preview.js +80 -0
- package/dist/routes/ts-rest/page-preview.js.map +1 -0
- package/dist/routes/ts-rest/page.d.ts +4 -0
- package/dist/routes/ts-rest/page.js +676 -0
- package/dist/routes/ts-rest/page.js.map +1 -0
- package/dist/routes/ts-rest/presence.d.ts +30 -0
- package/dist/routes/ts-rest/presence.js +155 -0
- package/dist/routes/ts-rest/presence.js.map +1 -0
- package/dist/routes/ts-rest/revision.d.ts +4 -0
- package/dist/routes/ts-rest/revision.js +240 -0
- package/dist/routes/ts-rest/revision.js.map +1 -0
- package/dist/routes/ts-rest/search.d.ts +4 -0
- package/dist/routes/ts-rest/search.js +121 -0
- package/dist/routes/ts-rest/search.js.map +1 -0
- package/dist/routes/ts-rest/tokenAuth.d.ts +4 -0
- package/dist/routes/ts-rest/tokenAuth.js +94 -0
- package/dist/routes/ts-rest/tokenAuth.js.map +1 -0
- package/dist/routes/ts-rest/user.d.ts +4 -0
- package/dist/routes/ts-rest/user.js +307 -0
- package/dist/routes/ts-rest/user.js.map +1 -0
- package/dist/service/config.d.ts +50 -0
- package/dist/service/config.js +202 -0
- package/dist/service/config.js.map +1 -0
- package/dist/service/lru.d.ts +11 -0
- package/dist/service/lru.js +47 -0
- package/dist/service/lru.js.map +1 -0
- package/dist/service/mail.d.ts +107 -0
- package/dist/service/mail.js +220 -0
- package/dist/service/mail.js.map +1 -0
- package/dist/service/notification.d.ts +9 -0
- package/dist/service/notification.js +19 -0
- package/dist/service/notification.js.map +1 -0
- package/dist/service/presence.d.ts +219 -0
- package/dist/service/presence.js +602 -0
- package/dist/service/presence.js.map +1 -0
- package/dist/types/error.d.ts +13 -0
- package/dist/types/error.js +13 -0
- package/dist/types/error.js.map +1 -0
- package/dist/types/express.d.ts +34 -0
- package/dist/types/express.js +50 -0
- package/dist/types/express.js.map +1 -0
- package/dist/types/mongoose-extensions.d.ts +8 -0
- package/dist/types/mongoose-extensions.js +24 -0
- package/dist/types/mongoose-extensions.js.map +1 -0
- package/dist/util/accessTokenParser.d.ts +1 -0
- package/dist/util/accessTokenParser.js +34 -0
- package/dist/util/accessTokenParser.js.map +1 -0
- package/dist/util/activityDefine.d.ts +15 -0
- package/dist/util/activityDefine.js +52 -0
- package/dist/util/activityDefine.js.map +1 -0
- package/dist/util/admin-config.d.ts +57 -0
- package/dist/util/admin-config.js +99 -0
- package/dist/util/admin-config.js.map +1 -0
- package/dist/util/admin-pager.d.ts +24 -0
- package/dist/util/admin-pager.js +73 -0
- package/dist/util/admin-pager.js.map +1 -0
- package/dist/util/apiPaginate.d.ts +11 -0
- package/dist/util/apiPaginate.js +33 -0
- package/dist/util/apiPaginate.js.map +1 -0
- package/dist/util/apiResponse.d.ts +9 -0
- package/dist/util/apiResponse.js +23 -0
- package/dist/util/apiResponse.js.map +1 -0
- package/dist/util/auth.d.ts +11 -0
- package/dist/util/auth.js +48 -0
- package/dist/util/auth.js.map +1 -0
- package/dist/util/auto-watch.d.ts +35 -0
- package/dist/util/auto-watch.js +24 -0
- package/dist/util/auto-watch.js.map +1 -0
- package/dist/util/autocomplete-match.d.ts +44 -0
- package/dist/util/autocomplete-match.js +80 -0
- package/dist/util/autocomplete-match.js.map +1 -0
- package/dist/util/aws-config-migration.d.ts +11 -0
- package/dist/util/aws-config-migration.js +68 -0
- package/dist/util/aws-config-migration.js.map +1 -0
- package/dist/util/boot-reporter.d.ts +130 -0
- package/dist/util/boot-reporter.js +242 -0
- package/dist/util/boot-reporter.js.map +1 -0
- package/dist/util/collab-cap.d.ts +39 -0
- package/dist/util/collab-cap.js +90 -0
- package/dist/util/collab-cap.js.map +1 -0
- package/dist/util/crypto.d.ts +39 -0
- package/dist/util/crypto.js +105 -0
- package/dist/util/crypto.js.map +1 -0
- package/dist/util/dedup-users.d.ts +96 -0
- package/dist/util/dedup-users.js +149 -0
- package/dist/util/dedup-users.js.map +1 -0
- package/dist/util/editor-cap-counter.d.ts +90 -0
- package/dist/util/editor-cap-counter.js +175 -0
- package/dist/util/editor-cap-counter.js.map +1 -0
- package/dist/util/fileUploader.d.ts +55 -0
- package/dist/util/fileUploader.js +70 -0
- package/dist/util/fileUploader.js.map +1 -0
- package/dist/util/formUtil.d.ts +2 -0
- package/dist/util/formUtil.js +15 -0
- package/dist/util/formUtil.js.map +1 -0
- package/dist/util/githubAuth.d.ts +2 -0
- package/dist/util/githubAuth.js +82 -0
- package/dist/util/githubAuth.js.map +1 -0
- package/dist/util/googleAuth.d.ts +2 -0
- package/dist/util/googleAuth.js +85 -0
- package/dist/util/googleAuth.js.map +1 -0
- package/dist/util/jwt.d.ts +50 -0
- package/dist/util/jwt.js +127 -0
- package/dist/util/jwt.js.map +1 -0
- package/dist/util/linkDetector.d.ts +3 -0
- package/dist/util/linkDetector.js +91 -0
- package/dist/util/linkDetector.js.map +1 -0
- package/dist/util/mail-token.d.ts +24 -0
- package/dist/util/mail-token.js +117 -0
- package/dist/util/mail-token.js.map +1 -0
- package/dist/util/mailer.d.ts +7 -0
- package/dist/util/mailer.js +98 -0
- package/dist/util/mailer.js.map +1 -0
- package/dist/util/map-duplicate-key-error.d.ts +26 -0
- package/dist/util/map-duplicate-key-error.js +41 -0
- package/dist/util/map-duplicate-key-error.js.map +1 -0
- package/dist/util/mongoose-paginate.d.ts +10 -0
- package/dist/util/mongoose-paginate.js +23 -0
- package/dist/util/mongoose-paginate.js.map +1 -0
- package/dist/util/notifications-token.d.ts +35 -0
- package/dist/util/notifications-token.js +140 -0
- package/dist/util/notifications-token.js.map +1 -0
- package/dist/util/oauth-client-seed.d.ts +2 -0
- package/dist/util/oauth-client-seed.js +48 -0
- package/dist/util/oauth-client-seed.js.map +1 -0
- package/dist/util/oauth-redirect-uri.d.ts +2 -0
- package/dist/util/oauth-redirect-uri.js +55 -0
- package/dist/util/oauth-redirect-uri.js.map +1 -0
- package/dist/util/page-response.d.ts +113 -0
- package/dist/util/page-response.js +154 -0
- package/dist/util/page-response.js.map +1 -0
- package/dist/util/page-search-index.d.ts +19 -0
- package/dist/util/page-search-index.js +91 -0
- package/dist/util/page-search-index.js.map +1 -0
- package/dist/util/page-status-migration.d.ts +23 -0
- package/dist/util/page-status-migration.js +48 -0
- package/dist/util/page-status-migration.js.map +1 -0
- package/dist/util/path.d.ts +2 -0
- package/dist/util/path.js +12 -0
- package/dist/util/path.js.map +1 -0
- package/dist/util/pkce.d.ts +13 -0
- package/dist/util/pkce.js +30 -0
- package/dist/util/pkce.js.map +1 -0
- package/dist/util/presence-token.d.ts +21 -0
- package/dist/util/presence-token.js +120 -0
- package/dist/util/presence-token.js.map +1 -0
- package/dist/util/rate-limit.d.ts +67 -0
- package/dist/util/rate-limit.js +87 -0
- package/dist/util/rate-limit.js.map +1 -0
- package/dist/util/rebuild-backlink.d.ts +25 -0
- package/dist/util/rebuild-backlink.js +7 -0
- package/dist/util/rebuild-backlink.js.map +1 -0
- package/dist/util/rebuild-renderer.d.ts +31 -0
- package/dist/util/rebuild-renderer.js +7 -0
- package/dist/util/rebuild-renderer.js.map +1 -0
- package/dist/util/redis-opts.d.ts +17 -0
- package/dist/util/redis-opts.js +40 -0
- package/dist/util/redis-opts.js.map +1 -0
- package/dist/util/regex.d.ts +2 -0
- package/dist/util/regex.js +8 -0
- package/dist/util/regex.js.map +1 -0
- package/dist/util/search-rebuild.d.ts +18 -0
- package/dist/util/search-rebuild.js +28 -0
- package/dist/util/search-rebuild.js.map +1 -0
- package/dist/util/ssr.d.ts +3 -0
- package/dist/util/ssr.js +9 -0
- package/dist/util/ssr.js.map +1 -0
- package/dist/util/storage-copy.d.ts +40 -0
- package/dist/util/storage-copy.js +123 -0
- package/dist/util/storage-copy.js.map +1 -0
- package/dist/util/ts-rest-helpers.d.ts +110 -0
- package/dist/util/ts-rest-helpers.js +110 -0
- package/dist/util/ts-rest-helpers.js.map +1 -0
- package/dist/util/url.d.ts +1 -0
- package/dist/util/url.js +11 -0
- package/dist/util/url.js.map +1 -0
- package/dist/util/user-code.d.ts +10 -0
- package/dist/util/user-code.js +55 -0
- package/dist/util/user-code.js.map +1 -0
- package/dist/util/view.d.ts +10 -0
- package/dist/util/view.js +99 -0
- package/dist/util/view.js.map +1 -0
- package/dist/util/watcher-backfill.d.ts +30 -0
- package/dist/util/watcher-backfill.js +43 -0
- package/dist/util/watcher-backfill.js.map +1 -0
- package/dist/util/ws-token.d.ts +24 -0
- package/dist/util/ws-token.js +134 -0
- package/dist/util/ws-token.js.map +1 -0
- package/package.json +106 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"draft.js","sourceRoot":"","sources":["../../../src/routes/ts-rest/draft.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const express_1 = require("express");
|
|
7
|
+
const app_1 = __importDefault(require("./app"));
|
|
8
|
+
const auth_1 = __importDefault(require("./auth"));
|
|
9
|
+
const installer_1 = __importDefault(require("./installer"));
|
|
10
|
+
const tokenAuth_1 = __importDefault(require("./tokenAuth"));
|
|
11
|
+
const me_1 = __importDefault(require("./me"));
|
|
12
|
+
const page_1 = __importDefault(require("./page"));
|
|
13
|
+
const page_preview_1 = __importDefault(require("./page-preview"));
|
|
14
|
+
const page_collab_1 = __importDefault(require("./page-collab"));
|
|
15
|
+
const presence_1 = __importDefault(require("./presence"));
|
|
16
|
+
const user_1 = __importDefault(require("./user"));
|
|
17
|
+
const comment_1 = __importDefault(require("./comment"));
|
|
18
|
+
const bookmark_1 = __importDefault(require("./bookmark"));
|
|
19
|
+
const revision_1 = __importDefault(require("./revision"));
|
|
20
|
+
const notification_1 = __importDefault(require("./notification"));
|
|
21
|
+
const backlink_1 = __importDefault(require("./backlink"));
|
|
22
|
+
const draft_1 = __importDefault(require("./draft"));
|
|
23
|
+
const autocomplete_1 = __importDefault(require("./autocomplete"));
|
|
24
|
+
const attachment_1 = __importDefault(require("./attachment"));
|
|
25
|
+
const search_1 = __importDefault(require("./search"));
|
|
26
|
+
const adminCrypto_1 = __importDefault(require("./adminCrypto"));
|
|
27
|
+
const admin_1 = __importDefault(require("./admin"));
|
|
28
|
+
const jwtAuth_1 = __importDefault(require("../../middlewares/jwtAuth"));
|
|
29
|
+
const jwtAdminRequired_1 = __importDefault(require("../../middlewares/jwtAdminRequired"));
|
|
30
|
+
const debug_1 = __importDefault(require("debug"));
|
|
31
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest');
|
|
32
|
+
exports.default = (crowi, app) => {
|
|
33
|
+
debug('Mounting ts-rest routes...');
|
|
34
|
+
// ========================================
|
|
35
|
+
// Authentication Layer Structure
|
|
36
|
+
// ========================================
|
|
37
|
+
// 1. Public routes (no authentication required)
|
|
38
|
+
// 2. Authenticated routes (JWT authentication required)
|
|
39
|
+
// 3. Admin routes (JWT authentication + admin permission required)
|
|
40
|
+
// ========================================
|
|
41
|
+
// Public Router - No authentication required
|
|
42
|
+
const publicRouter = (0, express_1.Router)();
|
|
43
|
+
const appRouter = (0, app_1.default)(crowi, app);
|
|
44
|
+
const authRouter = (0, auth_1.default)(crowi, app); // Legacy - to be removed
|
|
45
|
+
const installerRouter = (0, installer_1.default)(crowi, app);
|
|
46
|
+
const tokenAuthRouter = (0, tokenAuth_1.default)(crowi, app);
|
|
47
|
+
debug('Mounting public routes (no auth required)');
|
|
48
|
+
publicRouter.use(appRouter);
|
|
49
|
+
publicRouter.use(authRouter);
|
|
50
|
+
publicRouter.use(installerRouter);
|
|
51
|
+
publicRouter.use(tokenAuthRouter);
|
|
52
|
+
// Authenticated Router - JWT authentication required
|
|
53
|
+
const authenticatedRouter = (0, express_1.Router)();
|
|
54
|
+
authenticatedRouter.use((0, jwtAuth_1.default)(crowi)); // Apply JWT auth to all routes
|
|
55
|
+
const meRouter = (0, me_1.default)(crowi, app);
|
|
56
|
+
const pageRouter = (0, page_1.default)(crowi, app);
|
|
57
|
+
const pagePreviewRouter = (0, page_preview_1.default)(crowi, app);
|
|
58
|
+
const pageCollabRouter = (0, page_collab_1.default)(crowi, app);
|
|
59
|
+
const presenceRouter = (0, presence_1.default)(crowi, app);
|
|
60
|
+
const userRouter = (0, user_1.default)(crowi, app);
|
|
61
|
+
const commentRouter = (0, comment_1.default)(crowi, app);
|
|
62
|
+
const bookmarkRouter = (0, bookmark_1.default)(crowi, app);
|
|
63
|
+
const revisionRouter = (0, revision_1.default)(crowi, app);
|
|
64
|
+
const notificationRouter = (0, notification_1.default)(crowi, app);
|
|
65
|
+
const backlinkRouter = (0, backlink_1.default)(crowi, app);
|
|
66
|
+
const draftRouter = (0, draft_1.default)(crowi, app);
|
|
67
|
+
const autocompleteRouter = (0, autocomplete_1.default)(crowi, app);
|
|
68
|
+
const attachmentRouter = (0, attachment_1.default)(crowi, app);
|
|
69
|
+
const searchRouter = (0, search_1.default)(crowi, app);
|
|
70
|
+
debug('Mounting authenticated routes (JWT required)');
|
|
71
|
+
authenticatedRouter.use(meRouter);
|
|
72
|
+
// Draft + autocomplete routes mount before pageRouter so the exact
|
|
73
|
+
// `/pages/drafts` and `/pages/autocomplete` paths are matched ahead
|
|
74
|
+
// of any broad `/pages/*` pattern.
|
|
75
|
+
authenticatedRouter.use(draftRouter);
|
|
76
|
+
authenticatedRouter.use(autocompleteRouter);
|
|
77
|
+
authenticatedRouter.use(pageRouter);
|
|
78
|
+
authenticatedRouter.use(pagePreviewRouter);
|
|
79
|
+
authenticatedRouter.use(pageCollabRouter);
|
|
80
|
+
authenticatedRouter.use(presenceRouter);
|
|
81
|
+
authenticatedRouter.use(userRouter);
|
|
82
|
+
authenticatedRouter.use(commentRouter);
|
|
83
|
+
authenticatedRouter.use(bookmarkRouter);
|
|
84
|
+
authenticatedRouter.use(revisionRouter);
|
|
85
|
+
authenticatedRouter.use(notificationRouter);
|
|
86
|
+
authenticatedRouter.use(backlinkRouter);
|
|
87
|
+
authenticatedRouter.use(attachmentRouter);
|
|
88
|
+
authenticatedRouter.use(searchRouter);
|
|
89
|
+
// Admin Router - JWT authentication + admin permission required
|
|
90
|
+
const adminRouter = (0, express_1.Router)();
|
|
91
|
+
adminRouter.use((0, jwtAdminRequired_1.default)(crowi)); // Apply JWT auth + admin check
|
|
92
|
+
const adminCryptoRouter = (0, adminCrypto_1.default)(crowi, app);
|
|
93
|
+
const adminSubRouter = (0, admin_1.default)(crowi, app);
|
|
94
|
+
debug('Mounting admin routes (JWT + admin required)');
|
|
95
|
+
adminRouter.use(adminCryptoRouter);
|
|
96
|
+
adminRouter.use(adminSubRouter);
|
|
97
|
+
// Mount all routers under /api/v2
|
|
98
|
+
app.use('/api/v2', publicRouter);
|
|
99
|
+
app.use('/api/v2', authenticatedRouter);
|
|
100
|
+
app.use('/api/v2', adminRouter);
|
|
101
|
+
debug('All ts-rest routes mounted successfully');
|
|
102
|
+
};
|
|
103
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/routes/ts-rest/index.ts"],"names":[],"mappings":";;;;;AACA,qCAA0C;AAC1C,gDAA8B;AAC9B,kDAAgC;AAChC,4DAA0C;AAC1C,4DAA0C;AAC1C,8CAA4B;AAC5B,kDAAgC;AAChC,kEAA+C;AAC/C,gEAA6C;AAC7C,0DAAwC;AACxC,kDAAgC;AAChC,wDAAsC;AACtC,0DAAwC;AACxC,0DAAwC;AACxC,kEAAgD;AAChD,0DAAwC;AACxC,oDAAkC;AAClC,kEAAgD;AAChD,8DAA4C;AAC5C,sDAAoC;AACpC,gEAA8C;AAC9C,oDAAkC;AAClC,wEAAgD;AAChD,0FAAkE;AAClE,kDAA0B;AAE1B,MAAM,KAAK,GAAG,IAAA,eAAK,EAAC,sBAAsB,CAAC,CAAC;AAE5C,kBAAe,CAAC,KAAY,EAAE,GAAY,EAAE,EAAE;IAC5C,KAAK,CAAC,4BAA4B,CAAC,CAAC;IAEpC,2CAA2C;IAC3C,iCAAiC;IACjC,2CAA2C;IAC3C,gDAAgD;IAChD,wDAAwD;IACxD,mEAAmE;IACnE,2CAA2C;IAE3C,6CAA6C;IAC7C,MAAM,YAAY,GAAG,IAAA,gBAAM,GAAE,CAAC;IAC9B,MAAM,SAAS,GAAG,IAAA,aAAS,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACxC,MAAM,UAAU,GAAG,IAAA,cAAU,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,yBAAyB;IACpE,MAAM,eAAe,GAAG,IAAA,mBAAe,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACpD,MAAM,eAAe,GAAG,IAAA,mBAAe,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAEpD,KAAK,CAAC,2CAA2C,CAAC,CAAC;IACnD,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAC5B,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAC7B,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAClC,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAElC,qDAAqD;IACrD,MAAM,mBAAmB,GAAG,IAAA,gBAAM,GAAE,CAAC;IACrC,mBAAmB,CAAC,GAAG,CAAC,IAAA,iBAAO,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,+BAA+B;IAExE,MAAM,QAAQ,GAAG,IAAA,YAAQ,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACtC,MAAM,UAAU,GAAG,IAAA,cAAU,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC1C,MAAM,iBAAiB,GAAG,IAAA,sBAAiB,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACxD,MAAM,gBAAgB,GAAG,IAAA,qBAAgB,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACtD,MAAM,cAAc,GAAG,IAAA,kBAAc,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAClD,MAAM,UAAU,GAAG,IAAA,cAAU,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC1C,MAAM,aAAa,GAAG,IAAA,iBAAa,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAChD,MAAM,cAAc,GAAG,IAAA,kBAAc,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAClD,MAAM,cAAc,GAAG,IAAA,kBAAc,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAClD,MAAM,kBAAkB,GAAG,IAAA,sBAAkB,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC1D,MAAM,cAAc,GAAG,IAAA,kBAAc,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAClD,MAAM,WAAW,GAAG,IAAA,eAAW,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC5C,MAAM,kBAAkB,GAAG,IAAA,sBAAkB,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC1D,MAAM,gBAAgB,GAAG,IAAA,oBAAgB,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACtD,MAAM,YAAY,GAAG,IAAA,gBAAY,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAE9C,KAAK,CAAC,8CAA8C,CAAC,CAAC;IACtD,mBAAmB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAClC,mEAAmE;IACnE,oEAAoE;IACpE,mCAAmC;IACnC,mBAAmB,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACrC,mBAAmB,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;IAC5C,mBAAmB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpC,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IAC3C,mBAAmB,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;IAC1C,mBAAmB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACxC,mBAAmB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpC,mBAAmB,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IACvC,mBAAmB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACxC,mBAAmB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACxC,mBAAmB,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;IAC5C,mBAAmB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACxC,mBAAmB,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;IAC1C,mBAAmB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAEtC,gEAAgE;IAChE,MAAM,WAAW,GAAG,IAAA,gBAAM,GAAE,CAAC;IAC7B,WAAW,CAAC,GAAG,CAAC,IAAA,0BAAgB,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,+BAA+B;IAEzE,MAAM,iBAAiB,GAAG,IAAA,qBAAiB,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACxD,MAAM,cAAc,GAAG,IAAA,eAAW,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAE/C,KAAK,CAAC,8CAA8C,CAAC,CAAC;IACtD,WAAW,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IACnC,WAAW,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IAEhC,kCAAkC;IAClC,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IACjC,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;IACxC,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IAEhC,KAAK,CAAC,yCAAyC,CAAC,CAAC;AACnD,CAAC,CAAC"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const express_1 = require("@ts-rest/express");
|
|
7
|
+
const api_contract_1 = require("@crowi/api-contract");
|
|
8
|
+
const express_2 = require("express");
|
|
9
|
+
const debug_1 = __importDefault(require("debug"));
|
|
10
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest:installer');
|
|
11
|
+
/**
|
|
12
|
+
* The ConfigService keeps a boot-time snapshot of all Config docs in memory,
|
|
13
|
+
* but `Config.applicationInstall()` writes new docs without refreshing it —
|
|
14
|
+
* so `req.config.crowi` is unreliable as an installed-state oracle. Always
|
|
15
|
+
* count from the DB instead, and refresh the cache after a successful install
|
|
16
|
+
* so other request paths see the new values without a server restart.
|
|
17
|
+
*/
|
|
18
|
+
const isAppInstalled = async (Config) => {
|
|
19
|
+
const count = await Config.countDocuments({ ns: 'crowi' }).exec();
|
|
20
|
+
return count > 0;
|
|
21
|
+
};
|
|
22
|
+
exports.default = (crowi, _app) => {
|
|
23
|
+
const s = (0, express_1.initServer)();
|
|
24
|
+
const router = (0, express_2.Router)();
|
|
25
|
+
const Config = crowi.model('Config');
|
|
26
|
+
const User = crowi.model('User');
|
|
27
|
+
const installerRouter = s.router(api_contract_1.apiContract.installer, {
|
|
28
|
+
getStatus: async () => {
|
|
29
|
+
const installed = await isAppInstalled(Config);
|
|
30
|
+
return {
|
|
31
|
+
status: 200,
|
|
32
|
+
body: { status: installed ? 'already_installed' : 'installer_required' },
|
|
33
|
+
};
|
|
34
|
+
},
|
|
35
|
+
createAdmin: async ({ body }) => {
|
|
36
|
+
if (await isAppInstalled(Config)) {
|
|
37
|
+
return {
|
|
38
|
+
status: 400,
|
|
39
|
+
body: { status: 'error', message: 'Application is already installed' },
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
const { name, username, email, password } = body.registerForm;
|
|
43
|
+
try {
|
|
44
|
+
const userData = await new Promise((resolve, reject) => {
|
|
45
|
+
// Seed admin language defaults to English; the legacy flow sniffed
|
|
46
|
+
// i18next from the request, but we don't have that on this pipeline.
|
|
47
|
+
User.createUserByEmailAndPassword(name, username, email, password, 'en', (err, user) => {
|
|
48
|
+
if (err)
|
|
49
|
+
return reject(err);
|
|
50
|
+
resolve(user);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
await new Promise((resolve, reject) => {
|
|
54
|
+
userData.makeAdmin((err) => {
|
|
55
|
+
if (err)
|
|
56
|
+
return reject(err);
|
|
57
|
+
resolve();
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
await Config.applicationInstall();
|
|
61
|
+
await crowi.getConfigService().load();
|
|
62
|
+
return { status: 200, body: { status: 'ok', message: 'Admin created successfully' } };
|
|
63
|
+
}
|
|
64
|
+
catch (err) {
|
|
65
|
+
const message = err.message;
|
|
66
|
+
debug('Error creating admin:', message);
|
|
67
|
+
return {
|
|
68
|
+
status: 200,
|
|
69
|
+
body: { status: 'error', errors: [`管理ユーザーの作成に失敗しました。${message}`] },
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.installer, installerRouter, router);
|
|
75
|
+
return router;
|
|
76
|
+
};
|
|
77
|
+
//# sourceMappingURL=installer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"installer.js","sourceRoot":"","sources":["../../../src/routes/ts-rest/installer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,410 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const express_1 = require("@ts-rest/express");
|
|
7
|
+
const api_contract_1 = require("@crowi/api-contract");
|
|
8
|
+
const express_2 = require("express");
|
|
9
|
+
const multer_1 = __importDefault(require("multer"));
|
|
10
|
+
const fs_1 = __importDefault(require("fs"));
|
|
11
|
+
const fileUploader_1 = __importDefault(require("../../util/fileUploader"));
|
|
12
|
+
const debug_1 = __importDefault(require("debug"));
|
|
13
|
+
const page_response_1 = require("../../util/page-response");
|
|
14
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest:me');
|
|
15
|
+
exports.default = (crowi, _app) => {
|
|
16
|
+
const s = (0, express_1.initServer)();
|
|
17
|
+
const router = (0, express_2.Router)();
|
|
18
|
+
const User = crowi.model('User');
|
|
19
|
+
// Configure multer for file uploads
|
|
20
|
+
const upload = (0, multer_1.default)({ dest: crowi.tmpDir });
|
|
21
|
+
// Helper function to convert user document to profile response
|
|
22
|
+
const userToProfileResponse = (user, hasPassword) => ({
|
|
23
|
+
id: user._id.toString(),
|
|
24
|
+
username: user.username,
|
|
25
|
+
name: user.name,
|
|
26
|
+
email: user.email,
|
|
27
|
+
lang: user.lang,
|
|
28
|
+
image: user.image,
|
|
29
|
+
introduction: user.introduction || undefined,
|
|
30
|
+
googleId: user.googleId,
|
|
31
|
+
githubId: user.githubId,
|
|
32
|
+
hasPassword,
|
|
33
|
+
createdAt: user.createdAt.toISOString(),
|
|
34
|
+
});
|
|
35
|
+
const meRouter = s.router(api_contract_1.apiContract.me, {
|
|
36
|
+
getProfile: async ({ req }) => {
|
|
37
|
+
const user = req.user;
|
|
38
|
+
// Check if user has password set
|
|
39
|
+
const userWithSecrets = await user.populateSecrets();
|
|
40
|
+
const hasPassword = userWithSecrets.isPasswordSet();
|
|
41
|
+
return {
|
|
42
|
+
status: 200,
|
|
43
|
+
body: userToProfileResponse(user, hasPassword),
|
|
44
|
+
};
|
|
45
|
+
},
|
|
46
|
+
updateProfile: async ({ body, req }) => {
|
|
47
|
+
const user = req.user;
|
|
48
|
+
const { name, email, lang } = body.userForm;
|
|
49
|
+
// Check if email is valid (whitelist check)
|
|
50
|
+
if (!User.isEmailValid(email)) {
|
|
51
|
+
return {
|
|
52
|
+
status: 400,
|
|
53
|
+
body: {
|
|
54
|
+
status: 'error',
|
|
55
|
+
message: "You can't update to that email address",
|
|
56
|
+
errors: ["You can't update to that email address"],
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
// Check for duplicate email
|
|
61
|
+
const existingUser = await User.findOne({ email });
|
|
62
|
+
if (existingUser && !existingUser._id.equals(user._id)) {
|
|
63
|
+
debug('Email address was duplicated');
|
|
64
|
+
return {
|
|
65
|
+
status: 400,
|
|
66
|
+
body: {
|
|
67
|
+
status: 'error',
|
|
68
|
+
message: 'It can not be changed to that mail address',
|
|
69
|
+
errors: ['It can not be changed to that mail address'],
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
try {
|
|
74
|
+
// Update user fields
|
|
75
|
+
user.name = name;
|
|
76
|
+
user.email = email;
|
|
77
|
+
user.lang = lang;
|
|
78
|
+
await user.save();
|
|
79
|
+
// Check if user has password set
|
|
80
|
+
const userWithSecrets = await user.populateSecrets();
|
|
81
|
+
const hasPassword = userWithSecrets.isPasswordSet();
|
|
82
|
+
return {
|
|
83
|
+
status: 200,
|
|
84
|
+
body: userToProfileResponse(user, hasPassword),
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
catch (err) {
|
|
88
|
+
const error = err;
|
|
89
|
+
const errorMessages = [];
|
|
90
|
+
if (error.errors) {
|
|
91
|
+
Object.keys(error.errors).forEach((e) => {
|
|
92
|
+
errorMessages.push(error.errors[e].message);
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
errorMessages.push('Failed to update profile');
|
|
97
|
+
}
|
|
98
|
+
return {
|
|
99
|
+
status: 400,
|
|
100
|
+
body: {
|
|
101
|
+
status: 'error',
|
|
102
|
+
message: errorMessages[0],
|
|
103
|
+
errors: errorMessages,
|
|
104
|
+
},
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
uploadPicture: async ({ req, res }) => {
|
|
109
|
+
return new Promise((resolve) => {
|
|
110
|
+
const user = req.user;
|
|
111
|
+
const fileUploader = (0, fileUploader_1.default)(crowi);
|
|
112
|
+
// Handle file upload with multer
|
|
113
|
+
upload.single('file')(req, res, async (err) => {
|
|
114
|
+
if (err) {
|
|
115
|
+
debug('Multer error:', err);
|
|
116
|
+
return resolve({
|
|
117
|
+
status: 400,
|
|
118
|
+
body: {
|
|
119
|
+
status: 'error',
|
|
120
|
+
message: 'File upload error.',
|
|
121
|
+
errors: ['File upload error.'],
|
|
122
|
+
},
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
const tmpFile = req.file || null;
|
|
126
|
+
if (!tmpFile) {
|
|
127
|
+
return resolve({
|
|
128
|
+
status: 400,
|
|
129
|
+
body: {
|
|
130
|
+
status: 'error',
|
|
131
|
+
message: 'No file provided.',
|
|
132
|
+
errors: ['No file provided.'],
|
|
133
|
+
},
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
const tmpPath = tmpFile.path;
|
|
137
|
+
const name = tmpFile.filename + tmpFile.originalname;
|
|
138
|
+
const ext = name.match(/(.*)(?:\.([^.]+$))/)?.[2] || '';
|
|
139
|
+
const filePath = User.createUserPictureFilePath(user, ext);
|
|
140
|
+
const acceptableFileType = /image\/.+/;
|
|
141
|
+
if (!tmpFile.mimetype.match(acceptableFileType)) {
|
|
142
|
+
// Clean up temp file
|
|
143
|
+
fs_1.default.unlink(tmpPath, () => { });
|
|
144
|
+
return resolve({
|
|
145
|
+
status: 400,
|
|
146
|
+
body: {
|
|
147
|
+
status: 'error',
|
|
148
|
+
message: 'File type error. Only image files is allowed to set as user picture.',
|
|
149
|
+
errors: ['File type error. Only image files is allowed to set as user picture.'],
|
|
150
|
+
},
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
const tmpFileStream = fs_1.default.createReadStream(tmpPath, {
|
|
154
|
+
flags: 'r',
|
|
155
|
+
mode: 0o666,
|
|
156
|
+
autoClose: true,
|
|
157
|
+
});
|
|
158
|
+
try {
|
|
159
|
+
await fileUploader.uploadFile(filePath, tmpFile.mimetype, tmpFileStream, {});
|
|
160
|
+
const imageUrl = await fileUploader.generateUrl(filePath);
|
|
161
|
+
// Update user image
|
|
162
|
+
await new Promise((resolveUpdate, rejectUpdate) => {
|
|
163
|
+
user.updateImage(imageUrl, (updateErr) => {
|
|
164
|
+
if (updateErr) {
|
|
165
|
+
rejectUpdate(updateErr);
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
resolveUpdate();
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
// Clean up temp file
|
|
173
|
+
fs_1.default.unlink(tmpPath, (unlinkErr) => {
|
|
174
|
+
if (unlinkErr) {
|
|
175
|
+
debug('Error while deleting tmp file.', unlinkErr);
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
return resolve({
|
|
179
|
+
status: 200,
|
|
180
|
+
body: {
|
|
181
|
+
status: true,
|
|
182
|
+
url: imageUrl,
|
|
183
|
+
message: '',
|
|
184
|
+
},
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
catch (uploadErr) {
|
|
188
|
+
debug('Uploading error', uploadErr);
|
|
189
|
+
// Clean up temp file
|
|
190
|
+
fs_1.default.unlink(tmpPath, () => { });
|
|
191
|
+
return resolve({
|
|
192
|
+
status: 400,
|
|
193
|
+
body: {
|
|
194
|
+
status: 'error',
|
|
195
|
+
message: 'Error while uploading file',
|
|
196
|
+
errors: ['Error while uploading file'],
|
|
197
|
+
},
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
});
|
|
201
|
+
});
|
|
202
|
+
},
|
|
203
|
+
deletePicture: async ({ req }) => {
|
|
204
|
+
return new Promise((resolve) => {
|
|
205
|
+
const user = req.user;
|
|
206
|
+
// Delete user image
|
|
207
|
+
// TODO: Also delete from S3/storage
|
|
208
|
+
user.deleteImage((err) => {
|
|
209
|
+
if (err) {
|
|
210
|
+
debug('Error deleting image:', err);
|
|
211
|
+
return resolve({
|
|
212
|
+
status: 400,
|
|
213
|
+
body: {
|
|
214
|
+
status: 'error',
|
|
215
|
+
message: 'Failed to delete profile picture',
|
|
216
|
+
errors: ['Failed to delete profile picture'],
|
|
217
|
+
},
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
return resolve({
|
|
221
|
+
status: 200,
|
|
222
|
+
body: {
|
|
223
|
+
status: 'ok',
|
|
224
|
+
message: 'Deleted profile picture',
|
|
225
|
+
},
|
|
226
|
+
});
|
|
227
|
+
});
|
|
228
|
+
});
|
|
229
|
+
},
|
|
230
|
+
updatePassword: async ({ body, req }) => {
|
|
231
|
+
const user = req.user;
|
|
232
|
+
const { oldPassword, newPassword, newPasswordConfirm } = body;
|
|
233
|
+
// Check if email is set (required for password setting)
|
|
234
|
+
if (!user.isEmailSet()) {
|
|
235
|
+
return {
|
|
236
|
+
status: 400,
|
|
237
|
+
body: {
|
|
238
|
+
status: 'error',
|
|
239
|
+
message: 'Email must be set before setting password',
|
|
240
|
+
errors: ['Email must be set before setting password'],
|
|
241
|
+
},
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
// Get user with password field populated for validation
|
|
245
|
+
const userWithSecrets = await user.populateSecrets();
|
|
246
|
+
const hasPassword = userWithSecrets.isPasswordSet();
|
|
247
|
+
// If password is already set, validate old password
|
|
248
|
+
if (hasPassword) {
|
|
249
|
+
if (!oldPassword) {
|
|
250
|
+
return {
|
|
251
|
+
status: 400,
|
|
252
|
+
body: {
|
|
253
|
+
status: 'error',
|
|
254
|
+
message: 'Current password is required',
|
|
255
|
+
errors: ['Current password is required'],
|
|
256
|
+
},
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
// Validate old password (using legacy 6-character minimum for backward compatibility)
|
|
260
|
+
if (oldPassword.length < 6) {
|
|
261
|
+
return {
|
|
262
|
+
status: 400,
|
|
263
|
+
body: {
|
|
264
|
+
status: 'error',
|
|
265
|
+
message: 'Current password must be at least 6 characters',
|
|
266
|
+
errors: ['Current password must be at least 6 characters'],
|
|
267
|
+
},
|
|
268
|
+
};
|
|
269
|
+
}
|
|
270
|
+
if (!userWithSecrets.isPasswordValid(oldPassword)) {
|
|
271
|
+
return {
|
|
272
|
+
status: 400,
|
|
273
|
+
body: {
|
|
274
|
+
status: 'error',
|
|
275
|
+
message: 'Wrong current password',
|
|
276
|
+
errors: ['Wrong current password'],
|
|
277
|
+
},
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
// Update password
|
|
282
|
+
return new Promise((resolve) => {
|
|
283
|
+
userWithSecrets.updatePassword(newPassword, (err) => {
|
|
284
|
+
if (err) {
|
|
285
|
+
debug('Error updating password:', err);
|
|
286
|
+
const error = err;
|
|
287
|
+
const errorMessages = [];
|
|
288
|
+
if (error.errors) {
|
|
289
|
+
Object.keys(error.errors).forEach((e) => {
|
|
290
|
+
errorMessages.push(error.errors[e].message);
|
|
291
|
+
});
|
|
292
|
+
}
|
|
293
|
+
else {
|
|
294
|
+
errorMessages.push('Failed to update password');
|
|
295
|
+
}
|
|
296
|
+
return resolve({
|
|
297
|
+
status: 400,
|
|
298
|
+
body: {
|
|
299
|
+
status: 'error',
|
|
300
|
+
message: errorMessages[0] || 'Failed to update password',
|
|
301
|
+
errors: errorMessages,
|
|
302
|
+
},
|
|
303
|
+
});
|
|
304
|
+
}
|
|
305
|
+
return resolve({
|
|
306
|
+
status: 200,
|
|
307
|
+
body: {
|
|
308
|
+
status: 'ok',
|
|
309
|
+
message: 'Password updated',
|
|
310
|
+
},
|
|
311
|
+
});
|
|
312
|
+
});
|
|
313
|
+
});
|
|
314
|
+
},
|
|
315
|
+
getApiToken: async ({ req }) => {
|
|
316
|
+
const user = req.user;
|
|
317
|
+
try {
|
|
318
|
+
// apiToken is select: false, so we need to populate it explicitly
|
|
319
|
+
const userWithSecrets = await user.populateSecrets();
|
|
320
|
+
const apiToken = userWithSecrets.apiToken;
|
|
321
|
+
// If no API token exists yet, generate one
|
|
322
|
+
if (!apiToken) {
|
|
323
|
+
const updatedUser = await userWithSecrets.updateApiToken();
|
|
324
|
+
return {
|
|
325
|
+
status: 200,
|
|
326
|
+
body: {
|
|
327
|
+
status: 'ok',
|
|
328
|
+
apiToken: updatedUser.apiToken,
|
|
329
|
+
},
|
|
330
|
+
};
|
|
331
|
+
}
|
|
332
|
+
return {
|
|
333
|
+
status: 200,
|
|
334
|
+
body: {
|
|
335
|
+
status: 'ok',
|
|
336
|
+
apiToken,
|
|
337
|
+
},
|
|
338
|
+
};
|
|
339
|
+
}
|
|
340
|
+
catch (err) {
|
|
341
|
+
debug('Error getting API token:', err);
|
|
342
|
+
return {
|
|
343
|
+
status: 500,
|
|
344
|
+
body: {
|
|
345
|
+
status: 'error',
|
|
346
|
+
message: 'Failed to get API token',
|
|
347
|
+
},
|
|
348
|
+
};
|
|
349
|
+
}
|
|
350
|
+
},
|
|
351
|
+
resetApiToken: async ({ req }) => {
|
|
352
|
+
const user = req.user;
|
|
353
|
+
try {
|
|
354
|
+
// apiToken is select: false, so we need to populate it explicitly
|
|
355
|
+
const userWithSecrets = await user.populateSecrets();
|
|
356
|
+
const updatedUser = await userWithSecrets.updateApiToken();
|
|
357
|
+
return {
|
|
358
|
+
status: 200,
|
|
359
|
+
body: {
|
|
360
|
+
status: 'ok',
|
|
361
|
+
apiToken: updatedUser.apiToken,
|
|
362
|
+
},
|
|
363
|
+
};
|
|
364
|
+
}
|
|
365
|
+
catch (err) {
|
|
366
|
+
debug('Error resetting API token:', err);
|
|
367
|
+
return {
|
|
368
|
+
status: 500,
|
|
369
|
+
body: {
|
|
370
|
+
status: 'error',
|
|
371
|
+
message: 'Failed to update API token',
|
|
372
|
+
},
|
|
373
|
+
};
|
|
374
|
+
}
|
|
375
|
+
},
|
|
376
|
+
recentlyViewedPages: async ({ req }) => {
|
|
377
|
+
const user = req.user;
|
|
378
|
+
const Page = crowi.model('Page');
|
|
379
|
+
try {
|
|
380
|
+
// Read 6 to absorb at most one root-portal entry; the dropdown
|
|
381
|
+
// shows 5.
|
|
382
|
+
const ids = (await crowi.lru.get(user._id.toString(), 6)) ?? [];
|
|
383
|
+
if (ids.length === 0) {
|
|
384
|
+
return { status: 200, body: { pages: [] } };
|
|
385
|
+
}
|
|
386
|
+
const found = (await Page.findPagesByIds(ids));
|
|
387
|
+
const byId = new Map();
|
|
388
|
+
for (const p of found)
|
|
389
|
+
byId.set(p._id.toString(), p);
|
|
390
|
+
const ordered = [];
|
|
391
|
+
for (const id of ids) {
|
|
392
|
+
const p = byId.get(id);
|
|
393
|
+
if (!p || p.path === '/')
|
|
394
|
+
continue;
|
|
395
|
+
ordered.push(p);
|
|
396
|
+
if (ordered.length >= 5)
|
|
397
|
+
break;
|
|
398
|
+
}
|
|
399
|
+
return { status: 200, body: { pages: ordered.map((p) => (0, page_response_1.pageToResponse)(p)) } };
|
|
400
|
+
}
|
|
401
|
+
catch (err) {
|
|
402
|
+
debug('recentlyViewedPages: lru / populate failed: %s', err.message);
|
|
403
|
+
return { status: 200, body: { pages: [] } };
|
|
404
|
+
}
|
|
405
|
+
},
|
|
406
|
+
});
|
|
407
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.me, meRouter, router);
|
|
408
|
+
return router;
|
|
409
|
+
};
|
|
410
|
+
//# sourceMappingURL=me.js.map
|