@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,189 @@
|
|
|
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 mongoose_1 = require("mongoose");
|
|
10
|
+
const ts_rest_helpers_1 = require("../../util/ts-rest-helpers");
|
|
11
|
+
const page_response_1 = require("../../util/page-response");
|
|
12
|
+
const debug_1 = __importDefault(require("debug"));
|
|
13
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest:bookmark');
|
|
14
|
+
const bookmarkToResponse = (bookmark) => {
|
|
15
|
+
const bookmarkObj = typeof bookmark.toObject === 'function' ? bookmark.toObject() : bookmark;
|
|
16
|
+
return {
|
|
17
|
+
_id: (0, ts_rest_helpers_1.toStringId)(bookmarkObj._id),
|
|
18
|
+
page: bookmarkObj.page ? (0, page_response_1.pageToResponse)(bookmarkObj.page) : null,
|
|
19
|
+
user: (0, ts_rest_helpers_1.isPopulatedUser)(bookmarkObj.user) ? (0, ts_rest_helpers_1.toPageUser)(bookmarkObj.user) : (0, ts_rest_helpers_1.toStringId)(bookmarkObj.user),
|
|
20
|
+
createdAt: (0, ts_rest_helpers_1.toISOStringOrNull)(bookmarkObj.createdAt) || new Date().toISOString(),
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
exports.default = (crowi, _app) => {
|
|
24
|
+
const s = (0, express_1.initServer)();
|
|
25
|
+
const router = (0, express_2.Router)();
|
|
26
|
+
const Page = crowi.model('Page');
|
|
27
|
+
const Bookmark = crowi.model('Bookmark');
|
|
28
|
+
const bookmarkRouter = s.router(api_contract_1.apiContract.bookmark, {
|
|
29
|
+
/**
|
|
30
|
+
* GET /api/v2/bookmarks?page_id=xxx
|
|
31
|
+
* Returns the current user's bookmark for a given page (or null).
|
|
32
|
+
* Equivalent to legacy GET /_api/bookmarks.get.
|
|
33
|
+
*/
|
|
34
|
+
getBookmark: async ({ query, req }) => {
|
|
35
|
+
const user = req.user;
|
|
36
|
+
const { page_id } = query;
|
|
37
|
+
debug('getBookmark called with:', { page_id, userId: user._id });
|
|
38
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(page_id)) {
|
|
39
|
+
return ts_rest_helpers_1.invalidPageIdResponse;
|
|
40
|
+
}
|
|
41
|
+
try {
|
|
42
|
+
const pageObjectId = new mongoose_1.Types.ObjectId(page_id);
|
|
43
|
+
const bookmark = (await Bookmark.findByPageIdAndUserId(pageObjectId, user._id));
|
|
44
|
+
return {
|
|
45
|
+
status: 200,
|
|
46
|
+
body: {
|
|
47
|
+
bookmark: bookmark ? bookmarkToResponse(bookmark) : null,
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
catch (err) {
|
|
52
|
+
const error = err;
|
|
53
|
+
debug('Error fetching bookmark:', error.message);
|
|
54
|
+
return {
|
|
55
|
+
status: 500,
|
|
56
|
+
body: { error: { code: 'INTERNAL_ERROR', message: 'Internal server error' } },
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
/**
|
|
61
|
+
* GET /api/v2/bookmarks/me?limit&offset
|
|
62
|
+
* Paginated list of the current user's bookmarks.
|
|
63
|
+
* Equivalent to legacy GET /_api/bookmarks.list (paginate).
|
|
64
|
+
*/
|
|
65
|
+
listMyBookmarks: async ({ query, req }) => {
|
|
66
|
+
const user = req.user;
|
|
67
|
+
const { limit = 50, offset = 0 } = query;
|
|
68
|
+
debug('listMyBookmarks called with:', { limit, offset, userId: user._id });
|
|
69
|
+
try {
|
|
70
|
+
// Bookmark.findByUserId always populates the page (and its revision/author).
|
|
71
|
+
const result = await Bookmark.findByUserId(user._id, { limit, offset });
|
|
72
|
+
const bookmarks = result.data;
|
|
73
|
+
const total = result.meta.total;
|
|
74
|
+
const prev = offset > 0 ? Math.max(0, offset - limit) : null;
|
|
75
|
+
const next = offset + limit < total ? offset + limit : null;
|
|
76
|
+
return {
|
|
77
|
+
status: 200,
|
|
78
|
+
body: {
|
|
79
|
+
bookmarks: bookmarks
|
|
80
|
+
.filter((bookmark) => bookmark.page) // populatePage may filter out inaccessible pages
|
|
81
|
+
.map((bookmark) => bookmarkToResponse(bookmark)),
|
|
82
|
+
pager: { prev, next, offset },
|
|
83
|
+
total,
|
|
84
|
+
},
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
catch (err) {
|
|
88
|
+
const error = err;
|
|
89
|
+
debug('Error listing my bookmarks:', error.message);
|
|
90
|
+
return {
|
|
91
|
+
status: 500,
|
|
92
|
+
body: { error: { code: 'INTERNAL_ERROR', message: 'Internal server error' } },
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
},
|
|
96
|
+
/**
|
|
97
|
+
* POST /api/v2/bookmarks { page_id }
|
|
98
|
+
* Add a bookmark for the current user.
|
|
99
|
+
* If the page is not accessible / does not exist, returns { bookmark: null }
|
|
100
|
+
* to preserve legacy /_api/bookmarks.add behavior.
|
|
101
|
+
*/
|
|
102
|
+
addBookmark: async ({ body: requestBody, req }) => {
|
|
103
|
+
const user = req.user;
|
|
104
|
+
const { page_id } = requestBody;
|
|
105
|
+
debug('addBookmark called with:', { page_id, userId: user._id });
|
|
106
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(page_id)) {
|
|
107
|
+
return ts_rest_helpers_1.invalidPageIdResponse;
|
|
108
|
+
}
|
|
109
|
+
let pageData = null;
|
|
110
|
+
try {
|
|
111
|
+
pageData = (await Page.findPageByIdAndGrantedUser(page_id, user));
|
|
112
|
+
}
|
|
113
|
+
catch (err) {
|
|
114
|
+
const error = err;
|
|
115
|
+
// findPageByIdAndGrantedUser throws on not-found / not-granted.
|
|
116
|
+
// Per the planner spec we collapse both cases into { bookmark: null }
|
|
117
|
+
// so that the new endpoint behaves like the legacy `else` branch
|
|
118
|
+
// (which the legacy controller also intended even though it was
|
|
119
|
+
// unreachable in practice).
|
|
120
|
+
if (error.message === 'Page not found' || error.message === 'Page is not granted for the user') {
|
|
121
|
+
return { status: 200, body: { bookmark: null } };
|
|
122
|
+
}
|
|
123
|
+
debug('Error fetching page for bookmark:', error.message);
|
|
124
|
+
return {
|
|
125
|
+
status: 500,
|
|
126
|
+
body: { error: { code: 'INTERNAL_ERROR', message: 'Internal server error' } },
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
if (!pageData) {
|
|
130
|
+
return { status: 200, body: { bookmark: null } };
|
|
131
|
+
}
|
|
132
|
+
try {
|
|
133
|
+
const created = (await Bookmark.add(pageData, user));
|
|
134
|
+
// Mirror the legacy controller: depopulate before serializing so we
|
|
135
|
+
// do not leak full populated docs that the response schema may not expect.
|
|
136
|
+
// We then re-populate via pageToResponse using the page document we already fetched.
|
|
137
|
+
created.depopulate('page');
|
|
138
|
+
created.depopulate('user');
|
|
139
|
+
// Build a hybrid object: the bookmark with the page populated by pageData.
|
|
140
|
+
const bookmarkObj = created.toObject();
|
|
141
|
+
bookmarkObj.page = pageData;
|
|
142
|
+
return {
|
|
143
|
+
status: 200,
|
|
144
|
+
body: {
|
|
145
|
+
bookmark: bookmarkToResponse(bookmarkObj),
|
|
146
|
+
},
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
catch (err) {
|
|
150
|
+
const error = err;
|
|
151
|
+
debug('Error adding bookmark:', error.message);
|
|
152
|
+
return {
|
|
153
|
+
status: 500,
|
|
154
|
+
body: { error: { code: 'INTERNAL_ERROR', message: 'Internal server error' } },
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
},
|
|
158
|
+
/**
|
|
159
|
+
* DELETE /api/v2/bookmarks { page_id }
|
|
160
|
+
* Remove a bookmark for the current user.
|
|
161
|
+
* Mirrors the legacy controller: deletes by (page, user) directly.
|
|
162
|
+
* Returns { ok: true } even when there was no bookmark to delete
|
|
163
|
+
* (the legacy controller emits ApiResponse.success() unconditionally).
|
|
164
|
+
*/
|
|
165
|
+
removeBookmark: async ({ body: requestBody, req }) => {
|
|
166
|
+
const user = req.user;
|
|
167
|
+
const { page_id } = requestBody;
|
|
168
|
+
debug('removeBookmark called with:', { page_id, userId: user._id });
|
|
169
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(page_id)) {
|
|
170
|
+
return ts_rest_helpers_1.invalidPageIdResponse;
|
|
171
|
+
}
|
|
172
|
+
try {
|
|
173
|
+
await Bookmark.removeBookmark(new mongoose_1.Types.ObjectId(page_id), user);
|
|
174
|
+
return { status: 200, body: { ok: true } };
|
|
175
|
+
}
|
|
176
|
+
catch (err) {
|
|
177
|
+
const error = err;
|
|
178
|
+
debug('Error removing bookmark:', error.message);
|
|
179
|
+
return {
|
|
180
|
+
status: 500,
|
|
181
|
+
body: { error: { code: 'INTERNAL_ERROR', message: 'Internal server error' } },
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
},
|
|
185
|
+
});
|
|
186
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.bookmark, bookmarkRouter, router);
|
|
187
|
+
return router;
|
|
188
|
+
};
|
|
189
|
+
//# sourceMappingURL=bookmark.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bookmark.js","sourceRoot":"","sources":["../../../src/routes/ts-rest/bookmark.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,217 @@
|
|
|
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 mongoose_1 = require("mongoose");
|
|
10
|
+
const ts_rest_helpers_1 = require("../../util/ts-rest-helpers");
|
|
11
|
+
const debug_1 = __importDefault(require("debug"));
|
|
12
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest:comment');
|
|
13
|
+
const COMMENT_POSITION_DEFAULT = -1;
|
|
14
|
+
/**
|
|
15
|
+
* Convert CommentDocument (with optionally populated creator) to API response shape.
|
|
16
|
+
* - creator is serialized to PageUserSchema-compatible object when populated
|
|
17
|
+
* - revision is returned as a string id (UI does not need full revision object)
|
|
18
|
+
*/
|
|
19
|
+
const commentToResponse = (comment) => {
|
|
20
|
+
const obj = comment.toObject(); // eslint-disable-line @typescript-eslint/no-explicit-any
|
|
21
|
+
let creator = null;
|
|
22
|
+
if (obj.creator && typeof obj.creator === 'object' && '_id' in obj.creator && 'username' in obj.creator) {
|
|
23
|
+
creator = (0, ts_rest_helpers_1.toPageUser)(obj.creator);
|
|
24
|
+
}
|
|
25
|
+
else if (obj.creator) {
|
|
26
|
+
creator = obj.creator.toString();
|
|
27
|
+
}
|
|
28
|
+
return {
|
|
29
|
+
_id: comment._id.toString(),
|
|
30
|
+
page: comment.page.toString(),
|
|
31
|
+
creator,
|
|
32
|
+
revision: comment.revision.toString(),
|
|
33
|
+
comment: comment.comment,
|
|
34
|
+
commentPosition: typeof comment.commentPosition === 'number' ? comment.commentPosition : COMMENT_POSITION_DEFAULT,
|
|
35
|
+
createdAt: (0, ts_rest_helpers_1.toISOStringOrNull)(comment.createdAt) ?? new Date(0).toISOString(),
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
exports.default = (crowi, _app) => {
|
|
39
|
+
const s = (0, express_1.initServer)();
|
|
40
|
+
const router = (0, express_2.Router)();
|
|
41
|
+
const Comment = crowi.model('Comment');
|
|
42
|
+
const Page = crowi.model('Page');
|
|
43
|
+
const commentRouter = s.router(api_contract_1.apiContract.comment, {
|
|
44
|
+
/**
|
|
45
|
+
* GET /api/v2/comments
|
|
46
|
+
* List comments by page_id or revision_id (one is required).
|
|
47
|
+
* - Authentication enforced by jwtAuth at router level.
|
|
48
|
+
*/
|
|
49
|
+
listComments: async ({ query, req }) => {
|
|
50
|
+
const user = req.user;
|
|
51
|
+
const { page_id, revision_id } = query;
|
|
52
|
+
debug('listComments called with:', { page_id, revision_id, userId: user._id });
|
|
53
|
+
if (!page_id && !revision_id) {
|
|
54
|
+
return {
|
|
55
|
+
status: 400,
|
|
56
|
+
body: {
|
|
57
|
+
error: {
|
|
58
|
+
code: 'INVALID_REQUEST',
|
|
59
|
+
message: 'page_id or revision_id is required',
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
try {
|
|
65
|
+
let comments;
|
|
66
|
+
if (revision_id) {
|
|
67
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(revision_id)) {
|
|
68
|
+
return {
|
|
69
|
+
status: 400,
|
|
70
|
+
body: { error: { code: 'INVALID_REQUEST', message: 'Invalid revision_id' } },
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
comments = await Comment.getCommentsByRevisionId(new mongoose_1.Types.ObjectId(revision_id));
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(page_id)) {
|
|
77
|
+
return {
|
|
78
|
+
status: 400,
|
|
79
|
+
body: { error: { code: 'INVALID_REQUEST', message: 'Invalid page_id' } },
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
comments = await Comment.getCommentsByPageId(new mongoose_1.Types.ObjectId(page_id));
|
|
83
|
+
}
|
|
84
|
+
return {
|
|
85
|
+
status: 200,
|
|
86
|
+
body: { comments: comments.map(commentToResponse) },
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
catch (err) {
|
|
90
|
+
const error = err;
|
|
91
|
+
debug('Error listing comments:', error.message);
|
|
92
|
+
return {
|
|
93
|
+
status: 400,
|
|
94
|
+
body: { error: { code: 'INVALID_REQUEST', message: error.message || 'Failed to list comments' } },
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
},
|
|
98
|
+
/**
|
|
99
|
+
* POST /api/v2/comments
|
|
100
|
+
* Add a comment to a page revision.
|
|
101
|
+
* - Validates page existence and grant before creating (stricter than the legacy
|
|
102
|
+
* /_api/comments.add which trusted the caller-provided page_id).
|
|
103
|
+
* - Comment.create triggers post-save hooks that update Page.commentCount and
|
|
104
|
+
* Activity entries; we intentionally do not duplicate that work here.
|
|
105
|
+
*/
|
|
106
|
+
addComment: async ({ body, req }) => {
|
|
107
|
+
const user = req.user;
|
|
108
|
+
const { page_id, revision_id, comment, comment_position } = body;
|
|
109
|
+
debug('addComment called with:', { page_id, revision_id, userId: user._id });
|
|
110
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(page_id) || !(0, ts_rest_helpers_1.isValidObjectId)(revision_id)) {
|
|
111
|
+
return {
|
|
112
|
+
status: 400,
|
|
113
|
+
body: { error: { code: 'INVALID_REQUEST', message: 'Invalid page_id or revision_id' } },
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
try {
|
|
117
|
+
const page = (await Page.findPageByIdAndGrantedUser(page_id, user));
|
|
118
|
+
if (!page) {
|
|
119
|
+
return {
|
|
120
|
+
status: 404,
|
|
121
|
+
body: { error: { code: 'PAGE_NOT_FOUND', message: 'Page not found' } },
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
const created = await Comment.create({
|
|
125
|
+
page: new mongoose_1.Types.ObjectId(page_id),
|
|
126
|
+
creator: user._id,
|
|
127
|
+
revision: new mongoose_1.Types.ObjectId(revision_id),
|
|
128
|
+
comment,
|
|
129
|
+
commentPosition: comment_position ?? COMMENT_POSITION_DEFAULT,
|
|
130
|
+
});
|
|
131
|
+
const populated = (await created.populate('creator'));
|
|
132
|
+
return {
|
|
133
|
+
status: 200,
|
|
134
|
+
body: { comment: commentToResponse(populated) },
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
catch (err) {
|
|
138
|
+
const error = err;
|
|
139
|
+
debug('Error adding comment:', error.message);
|
|
140
|
+
if (error.message === 'Page not found' || error.message === 'Page is not granted for the user') {
|
|
141
|
+
// findPageByIdAndGrantedUser hides the distinction; map both to 404.
|
|
142
|
+
return {
|
|
143
|
+
status: 404,
|
|
144
|
+
body: { error: { code: 'PAGE_NOT_FOUND', message: 'Page not found' } },
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
return {
|
|
148
|
+
status: 400,
|
|
149
|
+
body: { error: { code: 'INVALID_REQUEST', message: error.message || 'Failed to add comment' } },
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
},
|
|
153
|
+
/**
|
|
154
|
+
* DELETE /api/v2/comments
|
|
155
|
+
* Delete a comment by id. The legacy controller required the caller to also
|
|
156
|
+
* supply the page_id and verified page-grant via `pageData.isGrantedFor(user)`;
|
|
157
|
+
* we preserve that behavior so nothing is lost.
|
|
158
|
+
*/
|
|
159
|
+
deleteComment: async ({ body, req }) => {
|
|
160
|
+
const user = req.user;
|
|
161
|
+
const { comment_id, page_id } = body;
|
|
162
|
+
debug('deleteComment called with:', { comment_id, page_id, userId: user._id });
|
|
163
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(comment_id) || !(0, ts_rest_helpers_1.isValidObjectId)(page_id)) {
|
|
164
|
+
return {
|
|
165
|
+
status: 400,
|
|
166
|
+
body: { error: { code: 'INVALID_REQUEST', message: 'Invalid comment_id or page_id' } },
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
try {
|
|
170
|
+
const pageData = (await Page.findPageById(page_id));
|
|
171
|
+
if (!pageData) {
|
|
172
|
+
return {
|
|
173
|
+
status: 404,
|
|
174
|
+
body: { error: { code: 'COMMENT_NOT_FOUND', message: 'Comment not found' } },
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
if (!pageData.isGrantedFor(user)) {
|
|
178
|
+
return {
|
|
179
|
+
status: 403,
|
|
180
|
+
body: {
|
|
181
|
+
error: { code: 'PAGE_NOT_GRANTED', message: 'Page is not granted for the user' },
|
|
182
|
+
},
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
const existing = await Comment.findOne({ _id: new mongoose_1.Types.ObjectId(comment_id) }).exec();
|
|
186
|
+
if (!existing) {
|
|
187
|
+
return {
|
|
188
|
+
status: 404,
|
|
189
|
+
body: { error: { code: 'COMMENT_NOT_FOUND', message: 'Comment not found' } },
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
await Comment.removeCommentById(new mongoose_1.Types.ObjectId(comment_id));
|
|
193
|
+
return {
|
|
194
|
+
status: 200,
|
|
195
|
+
body: { ok: true },
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
catch (err) {
|
|
199
|
+
const error = err;
|
|
200
|
+
debug('Error deleting comment:', error.message);
|
|
201
|
+
if (error.message === 'Page not found') {
|
|
202
|
+
return {
|
|
203
|
+
status: 404,
|
|
204
|
+
body: { error: { code: 'COMMENT_NOT_FOUND', message: 'Comment not found' } },
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
return {
|
|
208
|
+
status: 400,
|
|
209
|
+
body: { error: { code: 'INVALID_REQUEST', message: error.message || 'Failed to delete comment' } },
|
|
210
|
+
};
|
|
211
|
+
}
|
|
212
|
+
},
|
|
213
|
+
});
|
|
214
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.comment, commentRouter, router);
|
|
215
|
+
return router;
|
|
216
|
+
};
|
|
217
|
+
//# sourceMappingURL=comment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"comment.js","sourceRoot":"","sources":["../../../src/routes/ts-rest/comment.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import Crowi from '../../crowi';
|
|
2
|
+
import { Express } from 'express';
|
|
3
|
+
/**
|
|
4
|
+
* RFC-0004 Phase 3 — drafts endpoints (`/api/v2/pages/drafts`).
|
|
5
|
+
*
|
|
6
|
+
* A *draft* is a `Page` with `status === 'draft'`: a brand-new page in
|
|
7
|
+
* progress, author-only, that transitions to `published` exactly once
|
|
8
|
+
* on first save (the publish transition itself is owned by the future
|
|
9
|
+
* RFC-0003 save flow — out of scope here).
|
|
10
|
+
*
|
|
11
|
+
* Mounted in the authenticated router, so `jwtAuth` is already applied
|
|
12
|
+
* and `req.user` is a `UserDocument`. CSRF is not needed for ts-rest
|
|
13
|
+
* (token-based auth).
|
|
14
|
+
*
|
|
15
|
+
* Same-path conflict (`docs/rfcs/0004-editor-ux-enhancement.md`
|
|
16
|
+
* §"Same-path conflict"): creating a draft at a path already held by
|
|
17
|
+
* another user's draft returns 409 with that user's identity so the
|
|
18
|
+
* `Creating pages` UI can show the contact-the-owner message. A path
|
|
19
|
+
* held by a *published* page returns a plain 400.
|
|
20
|
+
*/
|
|
21
|
+
declare const _default: (crowi: Crowi, _app: Express) => import("express-serve-static-core").Router;
|
|
22
|
+
export default _default;
|
|
@@ -0,0 +1,200 @@
|
|
|
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 page_1 = require("../../models/page");
|
|
10
|
+
const ts_rest_helpers_1 = require("../../util/ts-rest-helpers");
|
|
11
|
+
const debug_1 = __importDefault(require("debug"));
|
|
12
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest:draft');
|
|
13
|
+
/** MongoDB duplicate-key error code, raised by the unique `Page.path` index. */
|
|
14
|
+
const isDuplicateKeyError = (err) => typeof err === 'object' && err !== null && err.code === 11000;
|
|
15
|
+
/**
|
|
16
|
+
* RFC-0004 Phase 3 — drafts endpoints (`/api/v2/pages/drafts`).
|
|
17
|
+
*
|
|
18
|
+
* A *draft* is a `Page` with `status === 'draft'`: a brand-new page in
|
|
19
|
+
* progress, author-only, that transitions to `published` exactly once
|
|
20
|
+
* on first save (the publish transition itself is owned by the future
|
|
21
|
+
* RFC-0003 save flow — out of scope here).
|
|
22
|
+
*
|
|
23
|
+
* Mounted in the authenticated router, so `jwtAuth` is already applied
|
|
24
|
+
* and `req.user` is a `UserDocument`. CSRF is not needed for ts-rest
|
|
25
|
+
* (token-based auth).
|
|
26
|
+
*
|
|
27
|
+
* Same-path conflict (`docs/rfcs/0004-editor-ux-enhancement.md`
|
|
28
|
+
* §"Same-path conflict"): creating a draft at a path already held by
|
|
29
|
+
* another user's draft returns 409 with that user's identity so the
|
|
30
|
+
* `Creating pages` UI can show the contact-the-owner message. A path
|
|
31
|
+
* held by a *published* page returns a plain 400.
|
|
32
|
+
*/
|
|
33
|
+
exports.default = (crowi, _app) => {
|
|
34
|
+
const s = (0, express_1.initServer)();
|
|
35
|
+
const router = (0, express_2.Router)();
|
|
36
|
+
const Page = crowi.model('Page');
|
|
37
|
+
const Revision = crowi.model('Revision');
|
|
38
|
+
const User = crowi.model('User');
|
|
39
|
+
const draftRouter = s.router(api_contract_1.apiContract.draft, {
|
|
40
|
+
/**
|
|
41
|
+
* POST /api/v2/pages/drafts
|
|
42
|
+
*
|
|
43
|
+
* Create a draft at `path` with the default `GRANT_PUBLIC` grant
|
|
44
|
+
* (RFC-0005 Phase 1). A draft's author-only visibility is enforced
|
|
45
|
+
* entirely by `status: 'draft'` — `findPage*` collapse a non-author
|
|
46
|
+
* by-id / by-path access into not-found, and listing / search /
|
|
47
|
+
* backlink all exclude other users' drafts by status. The grant is
|
|
48
|
+
* deliberately left public so that once publish-on-save flips the
|
|
49
|
+
* status to `published`, the page is immediately visible to other
|
|
50
|
+
* users; a `GRANT_OWNER` draft would stay invisible at the grant
|
|
51
|
+
* layer even after the status flip. (Phase 2 will let the editor
|
|
52
|
+
* pick a non-public grant explicitly.)
|
|
53
|
+
*/
|
|
54
|
+
createDraft: async ({ body, req }) => {
|
|
55
|
+
const user = req.user;
|
|
56
|
+
// The seed revision's `body` is `required` in the Revision schema
|
|
57
|
+
// and Mongoose rejects an empty string. A brand-new draft is
|
|
58
|
+
// conceptually empty, so seed a single newline — it renders to
|
|
59
|
+
// nothing and gives the collab editor an effectively blank doc.
|
|
60
|
+
const initialBody = body.initialBody && body.initialBody.length > 0 ? body.initialBody : '\n';
|
|
61
|
+
const path = Page.normalizePath(body.path);
|
|
62
|
+
debug('createDraft called', { path, userId: user._id.toString() });
|
|
63
|
+
if (!Page.isCreatableName(path)) {
|
|
64
|
+
return {
|
|
65
|
+
status: 400,
|
|
66
|
+
body: { error: 'invalid_path', message: `Cannot create a page at this path (${path}).` },
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
// Resolve a path already occupied by a page into the right
|
|
70
|
+
// response — the caller's own draft → 201 (idempotent, so a
|
|
71
|
+
// double-click resolves to the same draft), another user's draft
|
|
72
|
+
// → 409 with owner info, anything published → 400. `null` means
|
|
73
|
+
// the path is free. The owner is loaded only on the 409 branch.
|
|
74
|
+
const resolveOccupied = async () => {
|
|
75
|
+
const existing = (await Page.findOne({ path }));
|
|
76
|
+
if (!existing)
|
|
77
|
+
return null;
|
|
78
|
+
if (existing.status !== page_1.STATUS_DRAFT) {
|
|
79
|
+
return {
|
|
80
|
+
status: 400,
|
|
81
|
+
body: { error: 'path_taken', message: `A page already exists at ${path}.` },
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
if (existing.isCreator(user)) {
|
|
85
|
+
return { status: 201, body: { pageId: existing._id.toString() } };
|
|
86
|
+
}
|
|
87
|
+
const owner = (await User.findById(existing.creator));
|
|
88
|
+
return {
|
|
89
|
+
status: 409,
|
|
90
|
+
body: {
|
|
91
|
+
error: 'path_taken_by_draft',
|
|
92
|
+
owner: owner
|
|
93
|
+
? { id: owner._id.toString(), username: owner.username, displayName: owner.name }
|
|
94
|
+
: { id: '', username: 'unknown', displayName: 'unknown' },
|
|
95
|
+
message: owner ? `This page is being created by @${owner.username}.` : 'This page is being created by another user.',
|
|
96
|
+
},
|
|
97
|
+
};
|
|
98
|
+
};
|
|
99
|
+
const occupied = await resolveOccupied();
|
|
100
|
+
if (occupied)
|
|
101
|
+
return occupied;
|
|
102
|
+
try {
|
|
103
|
+
const newPage = await Page.create({
|
|
104
|
+
path,
|
|
105
|
+
creator: user,
|
|
106
|
+
lastUpdateUser: user,
|
|
107
|
+
createdAt: Date.now(),
|
|
108
|
+
updatedAt: Date.now(),
|
|
109
|
+
redirectTo: null,
|
|
110
|
+
grant: page_1.GRANT_PUBLIC,
|
|
111
|
+
status: page_1.STATUS_DRAFT,
|
|
112
|
+
grantedUsers: [user],
|
|
113
|
+
});
|
|
114
|
+
// Seed the first revision so the page is loadable / editable
|
|
115
|
+
// immediately. `pushRevision` wires `revision` + bumps the
|
|
116
|
+
// `Page.create` event so backlinks / search run — both already
|
|
117
|
+
// exclude other users' drafts (Phase 2).
|
|
118
|
+
const newRevision = await Revision.prepareRevision(newPage, initialBody, user, { format: 'markdown' });
|
|
119
|
+
await Page.pushRevision(newPage, newRevision, user);
|
|
120
|
+
debug('createDraft created draft page', { pageId: newPage._id.toString(), path });
|
|
121
|
+
return { status: 201, body: { pageId: newPage._id.toString() } };
|
|
122
|
+
}
|
|
123
|
+
catch (err) {
|
|
124
|
+
// A concurrent POST can win the unique-`path`-index race between
|
|
125
|
+
// the pre-check and `create`. Re-resolve so the loser still gets
|
|
126
|
+
// the proper 400 / 409 instead of a misleading `invalid_path`.
|
|
127
|
+
if (isDuplicateKeyError(err)) {
|
|
128
|
+
const raced = await resolveOccupied();
|
|
129
|
+
if (raced)
|
|
130
|
+
return raced;
|
|
131
|
+
}
|
|
132
|
+
debug('createDraft failed:', err.message);
|
|
133
|
+
return {
|
|
134
|
+
status: 400,
|
|
135
|
+
body: { error: 'invalid_path', message: err.message || 'Failed to create draft.' },
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
},
|
|
139
|
+
/**
|
|
140
|
+
* GET /api/v2/pages/drafts
|
|
141
|
+
*
|
|
142
|
+
* List the caller's own drafts, newest first. Powers the
|
|
143
|
+
* `Creating pages` view; never returns another user's drafts.
|
|
144
|
+
*/
|
|
145
|
+
listDrafts: async ({ req }) => {
|
|
146
|
+
const user = req.user;
|
|
147
|
+
debug('listDrafts called', { userId: user._id.toString() });
|
|
148
|
+
const drafts = (await Page.find({ status: page_1.STATUS_DRAFT, creator: user._id })
|
|
149
|
+
.sort({ createdAt: -1 })
|
|
150
|
+
.select('_id path createdAt updatedAt')
|
|
151
|
+
.lean()
|
|
152
|
+
.exec());
|
|
153
|
+
return {
|
|
154
|
+
status: 200,
|
|
155
|
+
body: {
|
|
156
|
+
drafts: drafts.map((d) => ({
|
|
157
|
+
pageId: d._id.toString(),
|
|
158
|
+
path: d.path,
|
|
159
|
+
createdAt: (0, ts_rest_helpers_1.toISOStringOrNull)(d.createdAt) ?? new Date().toISOString(),
|
|
160
|
+
updatedAt: (0, ts_rest_helpers_1.toISOStringOrNull)(d.updatedAt) ?? (0, ts_rest_helpers_1.toISOStringOrNull)(d.createdAt) ?? new Date().toISOString(),
|
|
161
|
+
})),
|
|
162
|
+
},
|
|
163
|
+
};
|
|
164
|
+
},
|
|
165
|
+
/**
|
|
166
|
+
* DELETE /api/v2/pages/drafts/:id
|
|
167
|
+
*
|
|
168
|
+
* Cancel a draft, releasing its path. Only the author may cancel.
|
|
169
|
+
* "No such draft", "not a draft", and "someone else's draft" all
|
|
170
|
+
* collapse to the same 404 so draft existence is never leaked.
|
|
171
|
+
*/
|
|
172
|
+
cancelDraft: async ({ params, req }) => {
|
|
173
|
+
const user = req.user;
|
|
174
|
+
const { id } = params;
|
|
175
|
+
debug('cancelDraft called', { id, userId: user._id.toString() });
|
|
176
|
+
const draftNotFound = {
|
|
177
|
+
status: 404,
|
|
178
|
+
body: { error: 'draft_not_found', message: 'Draft not found.' },
|
|
179
|
+
};
|
|
180
|
+
// A malformed id would make the `_id` query throw a CastError;
|
|
181
|
+
// collapse it into the same 404 as "no such draft".
|
|
182
|
+
if (!(0, ts_rest_helpers_1.isValidObjectId)(id)) {
|
|
183
|
+
return draftNotFound;
|
|
184
|
+
}
|
|
185
|
+
const page = (await Page.findOne({ _id: id, status: page_1.STATUS_DRAFT, creator: user._id }));
|
|
186
|
+
if (!page) {
|
|
187
|
+
return draftNotFound;
|
|
188
|
+
}
|
|
189
|
+
// `removePage` physically deletes the Page and its revisions —
|
|
190
|
+
// the right semantics for "cancel": the path is freed and no
|
|
191
|
+
// /trash redirect stub is left behind (unlike soft delete).
|
|
192
|
+
await Page.removePage(page);
|
|
193
|
+
debug('cancelDraft removed draft', { id, path: page.path });
|
|
194
|
+
return { status: 200, body: { pageId: id } };
|
|
195
|
+
},
|
|
196
|
+
});
|
|
197
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.draft, draftRouter, router);
|
|
198
|
+
return router;
|
|
199
|
+
};
|
|
200
|
+
//# sourceMappingURL=draft.js.map
|