@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,95 @@
|
|
|
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 admin_config_1 = require("../../../util/admin-config");
|
|
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:admin:auth');
|
|
13
|
+
const KEY_REQUIRE_THIRD_PARTY_AUTH = 'auth:requireThirdPartyAuth';
|
|
14
|
+
const KEY_DISABLE_PASSWORD_AUTH = 'auth:disablePasswordAuth';
|
|
15
|
+
const readAuthSettings = (crowi) => {
|
|
16
|
+
const ns = (0, admin_config_1.getCrowiConfigNamespace)(crowi);
|
|
17
|
+
return {
|
|
18
|
+
requireThirdPartyAuth: (0, admin_config_1.coerceBoolean)(ns[KEY_REQUIRE_THIRD_PARTY_AUTH]),
|
|
19
|
+
disablePasswordAuth: (0, admin_config_1.coerceBoolean)(ns[KEY_DISABLE_PASSWORD_AUTH]),
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
exports.default = (crowi, _app) => {
|
|
23
|
+
const s = (0, express_1.initServer)();
|
|
24
|
+
const router = (0, express_2.Router)();
|
|
25
|
+
const authRouter = s.router(api_contract_1.apiContract.admin.auth, {
|
|
26
|
+
/**
|
|
27
|
+
* GET /api/v2/admin/auth
|
|
28
|
+
* Returns the two `auth:*` config values currently in effect.
|
|
29
|
+
* Authorization (jwt + admin) is handled by the surrounding adminRouter
|
|
30
|
+
* middleware; missing/forbidden auth never reaches this handler.
|
|
31
|
+
*/
|
|
32
|
+
getAuthSettings: async () => {
|
|
33
|
+
try {
|
|
34
|
+
const settings = readAuthSettings(crowi);
|
|
35
|
+
return { status: 200, body: settings };
|
|
36
|
+
}
|
|
37
|
+
catch (err) {
|
|
38
|
+
const error = err;
|
|
39
|
+
debug('Error reading auth settings:', error.message);
|
|
40
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
/**
|
|
44
|
+
* PUT /api/v2/admin/auth
|
|
45
|
+
* Persists the two `auth:*` keys via configService.saveConfig('crowi', ...).
|
|
46
|
+
*
|
|
47
|
+
* Self-lockout guard: if the requester sets `disablePasswordAuth: true`
|
|
48
|
+
* but their own account is not connected to a valid third-party identity
|
|
49
|
+
* (Google / GitHub), reject with 422. Mirrors the legacy guard in
|
|
50
|
+
* controllers/admin.ts:postSettings — it intentionally checks only the
|
|
51
|
+
* acting admin, not other admins, matching the previous behaviour.
|
|
52
|
+
*
|
|
53
|
+
* - We only write the two auth keys we own; saveConfig merges into the
|
|
54
|
+
* existing 'crowi' namespace so unrelated keys (app:*, security:*,
|
|
55
|
+
* mail:*) are untouched.
|
|
56
|
+
* - Returns the post-save settings so the UI doesn't need a follow-up GET.
|
|
57
|
+
*/
|
|
58
|
+
updateAuthSettings: async ({ body, req }) => {
|
|
59
|
+
// jwtAdminRequired guarantees req.user is populated; the augmentation
|
|
60
|
+
// declares it optional so we re-narrow here.
|
|
61
|
+
const user = req.user;
|
|
62
|
+
if (body.disablePasswordAuth && !user.hasValidThirdPartyId()) {
|
|
63
|
+
return {
|
|
64
|
+
status: 422,
|
|
65
|
+
body: {
|
|
66
|
+
error: {
|
|
67
|
+
code: 'PASSWORD_AUTH_REQUIRES_THIRDPARTY',
|
|
68
|
+
// Wire-level fallback; UIs key off `code` and render the
|
|
69
|
+
// localised message via paraglide. Kept non-empty so legacy
|
|
70
|
+
// / scripted callers see a hint without grepping for the code.
|
|
71
|
+
message: 'Disabling password auth requires the acting admin to be connected to a valid third-party identity.',
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
try {
|
|
77
|
+
await crowi.getConfigService().saveConfig('crowi', {
|
|
78
|
+
[KEY_REQUIRE_THIRD_PARTY_AUTH]: body.requireThirdPartyAuth,
|
|
79
|
+
[KEY_DISABLE_PASSWORD_AUTH]: body.disablePasswordAuth,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
catch (err) {
|
|
83
|
+
const error = err;
|
|
84
|
+
debug('Error saving auth settings:', error.message);
|
|
85
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
86
|
+
}
|
|
87
|
+
// Re-read from the in-memory cache (saveConfig updates it) so the
|
|
88
|
+
// response reflects the new values without a Mongo round-trip.
|
|
89
|
+
return { status: 200, body: readAuthSettings(crowi) };
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.admin.auth, authRouter, router);
|
|
93
|
+
return router;
|
|
94
|
+
};
|
|
95
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../../src/routes/ts-rest/admin/auth.ts"],"names":[],"mappings":";;;;;AAAA,8CAAsE;AACtE,sDAAqE;AAErE,qCAA0C;AAE1C,wDAA+E;AAC/E,8DAAuE;AACvE,kDAA0B;AAE1B,MAAM,KAAK,GAAG,IAAA,eAAK,EAAC,iCAAiC,CAAC,CAAC;AAEvD,MAAM,4BAA4B,GAAG,4BAA4B,CAAC;AAClE,MAAM,yBAAyB,GAAG,0BAA0B,CAAC;AAE7D,MAAM,gBAAgB,GAAG,CAAC,KAAY,EAAgB,EAAE;IACtD,MAAM,EAAE,GAAG,IAAA,sCAAuB,EAAC,KAAK,CAAC,CAAC;IAC1C,OAAO;QACL,qBAAqB,EAAE,IAAA,4BAAa,EAAC,EAAE,CAAC,4BAA4B,CAAC,CAAC;QACtE,mBAAmB,EAAE,IAAA,4BAAa,EAAC,EAAE,CAAC,yBAAyB,CAAC,CAAC;KAClE,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,CAAC,KAAY,EAAE,IAAa,EAAE,EAAE;IAC7C,MAAM,CAAC,GAAG,IAAA,oBAAU,GAAE,CAAC;IACvB,MAAM,MAAM,GAAG,IAAA,gBAAM,GAAE,CAAC;IAExB,MAAM,UAAU,GAAG,CAAC,CAAC,MAAM,CAAC,0BAAW,CAAC,KAAK,CAAC,IAAI,EAAE;QAClD;;;;;WAKG;QACH,eAAe,EAAE,KAAK,IAAI,EAAE;YAC1B,IAAI,CAAC;gBACH,MAAM,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACzC,OAAO,EAAE,MAAM,EAAE,GAAY,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;YAClD,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,KAAK,GAAG,GAAY,CAAC;gBAC3B,KAAK,CAAC,8BAA8B,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;gBACrD,OAAO,6CAA2B,CAAC;YACrC,CAAC;QACH,CAAC;QAED;;;;;;;;;;;;;;WAcG;QACH,kBAAkB,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE;YAC1C,sEAAsE;YACtE,6CAA6C;YAC7C,MAAM,IAAI,GAAG,GAAG,CAAC,IAAoB,CAAC;YAEtC,IAAI,IAAI,CAAC,mBAAmB,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;gBAC7D,OAAO;oBACL,MAAM,EAAE,GAAY;oBACpB,IAAI,EAAE;wBACJ,KAAK,EAAE;4BACL,IAAI,EAAE,mCAA4C;4BAClD,yDAAyD;4BACzD,4DAA4D;4BAC5D,+DAA+D;4BAC/D,OAAO,EAAE,oGAAoG;yBAC9G;qBACF;iBACF,CAAC;YACJ,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,gBAAgB,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE;oBACjD,CAAC,4BAA4B,CAAC,EAAE,IAAI,CAAC,qBAAqB;oBAC1D,CAAC,yBAAyB,CAAC,EAAE,IAAI,CAAC,mBAAmB;iBACtD,CAAC,CAAC;YACL,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,KAAK,GAAG,GAAY,CAAC;gBAC3B,KAAK,CAAC,6BAA6B,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;gBACpD,OAAO,6CAA2B,CAAC;YACrC,CAAC;YAED,kEAAkE;YAClE,+DAA+D;YAC/D,OAAO,EAAE,MAAM,EAAE,GAAY,EAAE,IAAI,EAAE,gBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC;QACjE,CAAC;KACF,CAAC,CAAC;IAEH,IAAA,gCAAsB,EAAC,0BAAW,CAAC,KAAK,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IAEnE,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import Crowi from '../../../crowi';
|
|
2
|
+
import { Express } from 'express';
|
|
3
|
+
/**
|
|
4
|
+
* Aggregate router for all admin-only ts-rest endpoints. Mounted under the
|
|
5
|
+
* adminRouter in `routes/ts-rest/index.ts` which already applies
|
|
6
|
+
* `jwtAdminRequired` (JWT + admin permission). Individual sub-routers should
|
|
7
|
+
* therefore not re-implement authorization.
|
|
8
|
+
*/
|
|
9
|
+
declare const _default: (crowi: Crowi, app: Express) => import("express-serve-static-core").Router;
|
|
10
|
+
export default _default;
|
|
@@ -0,0 +1,35 @@
|
|
|
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 mail_1 = __importDefault(require("./mail"));
|
|
10
|
+
const plugins_1 = __importDefault(require("./plugins"));
|
|
11
|
+
const search_1 = __importDefault(require("./search"));
|
|
12
|
+
const security_1 = __importDefault(require("./security"));
|
|
13
|
+
const share_1 = __importDefault(require("./share"));
|
|
14
|
+
const storage_1 = __importDefault(require("./storage"));
|
|
15
|
+
const users_1 = __importDefault(require("./users"));
|
|
16
|
+
/**
|
|
17
|
+
* Aggregate router for all admin-only ts-rest endpoints. Mounted under the
|
|
18
|
+
* adminRouter in `routes/ts-rest/index.ts` which already applies
|
|
19
|
+
* `jwtAdminRequired` (JWT + admin permission). Individual sub-routers should
|
|
20
|
+
* therefore not re-implement authorization.
|
|
21
|
+
*/
|
|
22
|
+
exports.default = (crowi, app) => {
|
|
23
|
+
const router = (0, express_1.Router)();
|
|
24
|
+
router.use((0, app_1.default)(crowi, app));
|
|
25
|
+
router.use((0, auth_1.default)(crowi, app));
|
|
26
|
+
router.use((0, security_1.default)(crowi, app));
|
|
27
|
+
router.use((0, mail_1.default)(crowi, app));
|
|
28
|
+
router.use((0, share_1.default)(crowi, app));
|
|
29
|
+
router.use((0, storage_1.default)(crowi, app));
|
|
30
|
+
router.use((0, search_1.default)(crowi, app));
|
|
31
|
+
router.use((0, users_1.default)(crowi, app));
|
|
32
|
+
router.use((0, plugins_1.default)(crowi, app));
|
|
33
|
+
return router;
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/routes/ts-rest/admin/index.ts"],"names":[],"mappings":";;;;;AACA,qCAA0C;AAC1C,gDAA8B;AAC9B,kDAAgC;AAChC,kDAAgC;AAChC,wDAAsC;AACtC,sDAAoC;AACpC,0DAAwC;AACxC,oDAAkC;AAClC,wDAAsC;AACtC,oDAAkC;AAElC;;;;;GAKG;AACH,kBAAe,CAAC,KAAY,EAAE,GAAY,EAAE,EAAE;IAC5C,MAAM,MAAM,GAAG,IAAA,gBAAM,GAAE,CAAC;IAExB,MAAM,CAAC,GAAG,CAAC,IAAA,aAAS,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IAClC,MAAM,CAAC,GAAG,CAAC,IAAA,cAAU,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACnC,MAAM,CAAC,GAAG,CAAC,IAAA,kBAAc,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACvC,MAAM,CAAC,GAAG,CAAC,IAAA,cAAU,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACnC,MAAM,CAAC,GAAG,CAAC,IAAA,eAAW,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACpC,MAAM,CAAC,GAAG,CAAC,IAAA,iBAAa,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACtC,MAAM,CAAC,GAAG,CAAC,IAAA,gBAAY,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACrC,MAAM,CAAC,GAAG,CAAC,IAAA,eAAW,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IACpC,MAAM,CAAC,GAAG,CAAC,IAAA,iBAAa,EAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;IAEtC,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1,156 @@
|
|
|
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 admin_config_1 = require("../../../util/admin-config");
|
|
10
|
+
const debug_1 = __importDefault(require("debug"));
|
|
11
|
+
const debug = (0, debug_1.default)('crowi:routes:ts-rest:admin:mail');
|
|
12
|
+
const KEY_FROM = 'mail:from';
|
|
13
|
+
const KEY_SMTP_HOST = 'mail:smtpHost';
|
|
14
|
+
const KEY_SMTP_PORT = 'mail:smtpPort';
|
|
15
|
+
const KEY_SMTP_USER = 'mail:smtpUser';
|
|
16
|
+
const KEY_SMTP_PASSWORD = 'mail:smtpPassword';
|
|
17
|
+
const KEY_AWS_REGION = 'mail:aws:region';
|
|
18
|
+
const KEY_AWS_ACCESS_KEY = 'mail:aws:accessKeyId';
|
|
19
|
+
const KEY_AWS_SECRET = 'mail:aws:secretAccessKey';
|
|
20
|
+
exports.default = (crowi, _app) => {
|
|
21
|
+
const s = (0, express_1.initServer)();
|
|
22
|
+
const router = (0, express_2.Router)();
|
|
23
|
+
const router_ = s.router(api_contract_1.apiContract.admin.mail, {
|
|
24
|
+
getMailSettings: async () => {
|
|
25
|
+
const ns = (0, admin_config_1.getCrowiConfigNamespace)(crowi);
|
|
26
|
+
const smtpPassword = (0, admin_config_1.coerceString)(ns[KEY_SMTP_PASSWORD]);
|
|
27
|
+
const awsSecret = (0, admin_config_1.coerceString)(ns[KEY_AWS_SECRET]);
|
|
28
|
+
return {
|
|
29
|
+
status: 200,
|
|
30
|
+
body: {
|
|
31
|
+
from: (0, admin_config_1.coerceString)(ns[KEY_FROM]),
|
|
32
|
+
smtpHost: (0, admin_config_1.coerceString)(ns[KEY_SMTP_HOST]),
|
|
33
|
+
smtpPort: (0, admin_config_1.coerceNumber)(ns[KEY_SMTP_PORT]),
|
|
34
|
+
smtpUser: (0, admin_config_1.coerceString)(ns[KEY_SMTP_USER]),
|
|
35
|
+
smtpPassword: { hasValue: smtpPassword.length > 0 },
|
|
36
|
+
aws: {
|
|
37
|
+
region: (0, admin_config_1.coerceString)(ns[KEY_AWS_REGION]),
|
|
38
|
+
accessKeyId: (0, admin_config_1.coerceString)(ns[KEY_AWS_ACCESS_KEY]),
|
|
39
|
+
secretAccessKey: { hasValue: awsSecret.length > 0 },
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
},
|
|
44
|
+
/**
|
|
45
|
+
* Partial update. `smtpPassword` and `aws.secretAccessKey` follow the same
|
|
46
|
+
* three-state semantics admin/app uses:
|
|
47
|
+
* - omitted → not added to the payload, value stays untouched.
|
|
48
|
+
* - empty '' → forwarded as '' to clear the row.
|
|
49
|
+
* - non-empty → forwarded; auto-encryption kicks in via `isSensitiveConfig`.
|
|
50
|
+
*
|
|
51
|
+
* After persisting we re-run `crowi.setupMailer()` so the in-memory mailer
|
|
52
|
+
* reflects the new values without a server restart.
|
|
53
|
+
*/
|
|
54
|
+
updateMailSettings: async ({ body }) => {
|
|
55
|
+
const updates = {};
|
|
56
|
+
if (body.from !== undefined)
|
|
57
|
+
updates[KEY_FROM] = body.from;
|
|
58
|
+
if (body.smtpHost !== undefined)
|
|
59
|
+
updates[KEY_SMTP_HOST] = body.smtpHost;
|
|
60
|
+
if (body.smtpPort !== undefined)
|
|
61
|
+
updates[KEY_SMTP_PORT] = body.smtpPort;
|
|
62
|
+
if (body.smtpUser !== undefined)
|
|
63
|
+
updates[KEY_SMTP_USER] = body.smtpUser;
|
|
64
|
+
if (body.smtpPassword !== undefined)
|
|
65
|
+
updates[KEY_SMTP_PASSWORD] = body.smtpPassword;
|
|
66
|
+
if (body.aws) {
|
|
67
|
+
const { region, accessKeyId, secretAccessKey } = body.aws;
|
|
68
|
+
if (region !== undefined)
|
|
69
|
+
updates[KEY_AWS_REGION] = region;
|
|
70
|
+
if (accessKeyId !== undefined)
|
|
71
|
+
updates[KEY_AWS_ACCESS_KEY] = accessKeyId;
|
|
72
|
+
if (secretAccessKey !== undefined)
|
|
73
|
+
updates[KEY_AWS_SECRET] = secretAccessKey;
|
|
74
|
+
}
|
|
75
|
+
if (Object.keys(updates).length > 0) {
|
|
76
|
+
debug('updateMailSettings keys=%o', Object.keys(updates));
|
|
77
|
+
await crowi.getConfigService().saveConfig('crowi', updates);
|
|
78
|
+
crowi.setupMailer();
|
|
79
|
+
}
|
|
80
|
+
return { status: 200, body: { ok: true } };
|
|
81
|
+
},
|
|
82
|
+
/**
|
|
83
|
+
* Send a test mail to the calling admin's email. Mirrors the legacy
|
|
84
|
+
* `validateMailSetting` controller: builds an SMTP transport from the
|
|
85
|
+
* supplied option (or current saved values) and dispatches a fixed-text
|
|
86
|
+
* mail. Network errors surface as 502.
|
|
87
|
+
*/
|
|
88
|
+
sendTestMail: async ({ body, req }) => {
|
|
89
|
+
const user = req.user;
|
|
90
|
+
if (!user || !user.email) {
|
|
91
|
+
return {
|
|
92
|
+
status: 502,
|
|
93
|
+
body: { error: { code: 'MAIL_TEST_FAILED', message: 'No email address on the calling user' } },
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
const ns = (0, admin_config_1.getCrowiConfigNamespace)(crowi);
|
|
97
|
+
const host = body?.smtpHost ?? (0, admin_config_1.coerceString)(ns[KEY_SMTP_HOST]);
|
|
98
|
+
const port = body?.smtpPort ?? (0, admin_config_1.coerceNumber)(ns[KEY_SMTP_PORT]);
|
|
99
|
+
const smtpUser = body?.smtpUser ?? (0, admin_config_1.coerceString)(ns[KEY_SMTP_USER]);
|
|
100
|
+
const smtpPassword = body?.smtpPassword ?? (0, admin_config_1.coerceString)(ns[KEY_SMTP_PASSWORD]);
|
|
101
|
+
if (!host || !port) {
|
|
102
|
+
return {
|
|
103
|
+
status: 502,
|
|
104
|
+
body: { error: { code: 'MAIL_TEST_FAILED', message: 'SMTP host / port is not configured' } },
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
const option = {
|
|
108
|
+
host,
|
|
109
|
+
port,
|
|
110
|
+
};
|
|
111
|
+
if (smtpUser && smtpPassword) {
|
|
112
|
+
option.auth = { user: smtpUser, pass: smtpPassword };
|
|
113
|
+
}
|
|
114
|
+
if (port === 465) {
|
|
115
|
+
option.secure = true;
|
|
116
|
+
}
|
|
117
|
+
const mailer = crowi.mailer;
|
|
118
|
+
if (!mailer || typeof mailer.createSMTPClient !== 'function') {
|
|
119
|
+
return {
|
|
120
|
+
status: 502,
|
|
121
|
+
body: { error: { code: 'MAIL_TEST_FAILED', message: 'Mailer is not initialized' } },
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
const smtpClient = mailer.createSMTPClient(option);
|
|
125
|
+
try {
|
|
126
|
+
await new Promise((resolve, reject) => {
|
|
127
|
+
smtpClient.sendMail({
|
|
128
|
+
to: user.email,
|
|
129
|
+
// ASCII-only: this is an SMTP smoke test that has to land
|
|
130
|
+
// in the recipient's inbox even when the configured
|
|
131
|
+
// transport's character-encoding settings are wrong.
|
|
132
|
+
subject: 'Crowi: SMTP test mail',
|
|
133
|
+
text: 'This is a test message dispatched from the Crowi admin SMTP settings page.',
|
|
134
|
+
}, (err) => {
|
|
135
|
+
if (err)
|
|
136
|
+
reject(err);
|
|
137
|
+
else
|
|
138
|
+
resolve();
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
catch (err) {
|
|
143
|
+
const error = err;
|
|
144
|
+
debug('sendTestMail failed: %s', error.message);
|
|
145
|
+
return {
|
|
146
|
+
status: 502,
|
|
147
|
+
body: { error: { code: 'MAIL_TEST_FAILED', message: error.message } },
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
return { status: 200, body: { ok: true, to: user.email } };
|
|
151
|
+
},
|
|
152
|
+
});
|
|
153
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.admin.mail, router_, router);
|
|
154
|
+
return router;
|
|
155
|
+
};
|
|
156
|
+
//# sourceMappingURL=mail.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mail.js","sourceRoot":"","sources":["../../../../src/routes/ts-rest/admin/mail.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,317 @@
|
|
|
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 express_2 = require("express");
|
|
8
|
+
const api_contract_1 = require("@crowi/api-contract");
|
|
9
|
+
const schema_serializer_1 = require("../../../plugin/schema-serializer");
|
|
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:admin:plugins');
|
|
13
|
+
exports.default = (crowi, _app) => {
|
|
14
|
+
const s = (0, express_1.initServer)();
|
|
15
|
+
const router = (0, express_2.Router)();
|
|
16
|
+
const pluginsRouter = s.router(api_contract_1.apiContract.admin.plugins, {
|
|
17
|
+
/**
|
|
18
|
+
* GET /api/v2/admin/plugins
|
|
19
|
+
*
|
|
20
|
+
* Lists every plugin currently loaded by the PluginManager along
|
|
21
|
+
* with its declared registry slots. The admin "Plugins" page
|
|
22
|
+
* renders this as a table.
|
|
23
|
+
*/
|
|
24
|
+
listPlugins: async () => {
|
|
25
|
+
const manager = crowi.pluginManager;
|
|
26
|
+
if (!manager) {
|
|
27
|
+
return { status: 200, body: { plugins: [] } };
|
|
28
|
+
}
|
|
29
|
+
const all = manager.getLoadedPlugins();
|
|
30
|
+
const plugins = all.map((p) => toPluginInfo(p, all));
|
|
31
|
+
return { status: 200, body: { plugins } };
|
|
32
|
+
},
|
|
33
|
+
/**
|
|
34
|
+
* GET /api/v2/admin/plugins/:name/config
|
|
35
|
+
*
|
|
36
|
+
* Get the form schema + current values for a single plugin.
|
|
37
|
+
* Sensitive fields are masked to `{ hasValue: boolean }` before
|
|
38
|
+
* returning so plaintext secrets never reach the browser.
|
|
39
|
+
*/
|
|
40
|
+
getPluginConfig: async ({ query }) => {
|
|
41
|
+
const manager = crowi.pluginManager;
|
|
42
|
+
const plugin = manager?.getLoadedPlugin(query.name);
|
|
43
|
+
if (!plugin) {
|
|
44
|
+
return pluginNotFound(query.name);
|
|
45
|
+
}
|
|
46
|
+
if (!plugin.configSchema) {
|
|
47
|
+
// Plugin has no configurable values; return an empty form.
|
|
48
|
+
return {
|
|
49
|
+
status: 200,
|
|
50
|
+
body: { name: plugin.name, fields: [], values: {} },
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
const fields = (0, schema_serializer_1.serializeConfigSchema)(plugin.configSchema);
|
|
54
|
+
const ns = readPluginNamespace(crowi, plugin.name);
|
|
55
|
+
const values = {};
|
|
56
|
+
for (const field of fields) {
|
|
57
|
+
if (field.kind === 'secret') {
|
|
58
|
+
const raw = ns[field.name];
|
|
59
|
+
values[field.name] = { hasValue: typeof raw === 'string' && raw.length > 0 };
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
values[field.name] = ns[field.name] ?? field.defaultValue ?? null;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return {
|
|
66
|
+
status: 200,
|
|
67
|
+
body: { name: plugin.name, fields, values },
|
|
68
|
+
};
|
|
69
|
+
},
|
|
70
|
+
/**
|
|
71
|
+
* PUT /api/v2/admin/plugins/:name/config
|
|
72
|
+
*
|
|
73
|
+
* Validate the request body through the plugin's Zod schema and
|
|
74
|
+
* persist each field into `plugin:<name>:*` config rows. Sensitive
|
|
75
|
+
* fields follow the three-state convention used by /admin/app and
|
|
76
|
+
* /admin/mail:
|
|
77
|
+
* - undefined / missing → leave value untouched
|
|
78
|
+
* - empty string → clear the saved value
|
|
79
|
+
* - non-empty string → replace and re-encrypt
|
|
80
|
+
*/
|
|
81
|
+
updatePluginConfig: async ({ query, body }) => {
|
|
82
|
+
const manager = crowi.pluginManager;
|
|
83
|
+
const plugin = manager?.getLoadedPlugin(query.name);
|
|
84
|
+
if (!plugin) {
|
|
85
|
+
return pluginNotFound(query.name);
|
|
86
|
+
}
|
|
87
|
+
if (!plugin.configSchema) {
|
|
88
|
+
return {
|
|
89
|
+
status: 422,
|
|
90
|
+
body: {
|
|
91
|
+
error: {
|
|
92
|
+
code: 'PLUGIN_CONFIG_VALIDATION_FAILED',
|
|
93
|
+
message: 'Plugin does not declare any configurable values',
|
|
94
|
+
issues: [],
|
|
95
|
+
},
|
|
96
|
+
},
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
const fields = (0, schema_serializer_1.serializeConfigSchema)(plugin.configSchema);
|
|
100
|
+
const fieldsByName = new Map(fields.map((f) => [f.name, f]));
|
|
101
|
+
// Build a candidate object using new values + existing values
|
|
102
|
+
// for fields the operator did not touch (so secret-untouched
|
|
103
|
+
// doesn't overwrite the saved secret).
|
|
104
|
+
const existing = readPluginNamespace(crowi, plugin.name);
|
|
105
|
+
const merged = { ...existing };
|
|
106
|
+
const toWrite = {};
|
|
107
|
+
for (const [key, value] of Object.entries(body.values)) {
|
|
108
|
+
const field = fieldsByName.get(key);
|
|
109
|
+
if (!field) {
|
|
110
|
+
// Ignore unknown keys. The Zod parse below would also catch
|
|
111
|
+
// them via `.strict()`, but we strip first so users get
|
|
112
|
+
// friendlier per-field errors instead of a global one.
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
115
|
+
if (field.kind === 'secret' && value === undefined) {
|
|
116
|
+
// explicitly leave untouched
|
|
117
|
+
continue;
|
|
118
|
+
}
|
|
119
|
+
merged[key] = value;
|
|
120
|
+
toWrite[key] = value;
|
|
121
|
+
}
|
|
122
|
+
const parsed = plugin.configSchema.safeParse(merged);
|
|
123
|
+
if (!parsed.success) {
|
|
124
|
+
return {
|
|
125
|
+
status: 422,
|
|
126
|
+
body: {
|
|
127
|
+
error: {
|
|
128
|
+
code: 'PLUGIN_CONFIG_VALIDATION_FAILED',
|
|
129
|
+
message: 'Plugin config failed validation',
|
|
130
|
+
issues: parsed.error.issues.map((i) => ({
|
|
131
|
+
path: i.path.map((p) => (typeof p === 'symbol' ? String(p) : p)),
|
|
132
|
+
message: i.message,
|
|
133
|
+
})),
|
|
134
|
+
},
|
|
135
|
+
},
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
const configService = crowi.getConfigService();
|
|
139
|
+
const writes = {};
|
|
140
|
+
for (const [key, value] of Object.entries(toWrite)) {
|
|
141
|
+
writes[`plugin:${plugin.name}:${key}`] = value;
|
|
142
|
+
}
|
|
143
|
+
try {
|
|
144
|
+
if (Object.keys(writes).length > 0) {
|
|
145
|
+
await configService.saveConfig('crowi', writes);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
catch (err) {
|
|
149
|
+
const error = err;
|
|
150
|
+
debug('Error saving plugin config:', error.message);
|
|
151
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
152
|
+
}
|
|
153
|
+
let hotReloaded = false;
|
|
154
|
+
let reconfigureFailed = false;
|
|
155
|
+
const pluginManager = crowi.pluginManager;
|
|
156
|
+
if (pluginManager && Object.keys(writes).length > 0) {
|
|
157
|
+
const result = await pluginManager.reconfigureAffected([`plugin:${plugin.name}`]);
|
|
158
|
+
hotReloaded = result.attempted > 0 && result.succeeded === result.attempted;
|
|
159
|
+
reconfigureFailed = result.attempted > result.succeeded;
|
|
160
|
+
}
|
|
161
|
+
return { status: 200, body: { ok: true, hotReloaded, reconfigureFailed } };
|
|
162
|
+
},
|
|
163
|
+
/**
|
|
164
|
+
* POST /api/v2/admin/plugins/render-cache/clear-all
|
|
165
|
+
*
|
|
166
|
+
* Drops every PluginRenderCache document. Surfaced by the
|
|
167
|
+
* "Clear all render cache" button in the admin UI. The next
|
|
168
|
+
* render of any embed-bearing page repopulates the cache.
|
|
169
|
+
*/
|
|
170
|
+
clearRenderCacheAll: async () => {
|
|
171
|
+
const renderer = crowi.renderer;
|
|
172
|
+
if (!renderer) {
|
|
173
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
174
|
+
}
|
|
175
|
+
try {
|
|
176
|
+
const removedCount = await renderer.cache.invalidateAll();
|
|
177
|
+
return {
|
|
178
|
+
status: 200,
|
|
179
|
+
body: {
|
|
180
|
+
ok: true,
|
|
181
|
+
clearedAt: new Date().toISOString(),
|
|
182
|
+
removedCount,
|
|
183
|
+
},
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
catch (err) {
|
|
187
|
+
debug('clearRenderCacheAll failed:', err.message);
|
|
188
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
189
|
+
}
|
|
190
|
+
},
|
|
191
|
+
/**
|
|
192
|
+
* POST /api/v2/admin/plugins/render-cache/clear-plugin?name=…
|
|
193
|
+
*
|
|
194
|
+
* Drops PluginRenderCache documents whose `pluginName` matches.
|
|
195
|
+
* Returns 404 when the named plugin is not loaded; that prevents
|
|
196
|
+
* typos from silently succeeding ("nothing matched, but ok").
|
|
197
|
+
*/
|
|
198
|
+
clearRenderCachePlugin: async ({ query }) => {
|
|
199
|
+
const renderer = crowi.renderer;
|
|
200
|
+
const manager = crowi.pluginManager;
|
|
201
|
+
if (!renderer) {
|
|
202
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
203
|
+
}
|
|
204
|
+
if (manager && !manager.getLoadedPlugin(query.name)) {
|
|
205
|
+
return pluginNotFound(query.name);
|
|
206
|
+
}
|
|
207
|
+
try {
|
|
208
|
+
const removedCount = await renderer.cache.invalidatePlugin(query.name);
|
|
209
|
+
return {
|
|
210
|
+
status: 200,
|
|
211
|
+
body: {
|
|
212
|
+
ok: true,
|
|
213
|
+
clearedAt: new Date().toISOString(),
|
|
214
|
+
removedCount,
|
|
215
|
+
},
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
catch (err) {
|
|
219
|
+
debug('clearRenderCachePlugin failed:', err.message);
|
|
220
|
+
return ts_rest_helpers_1.internalServerErrorResponse;
|
|
221
|
+
}
|
|
222
|
+
},
|
|
223
|
+
});
|
|
224
|
+
(0, express_1.createExpressEndpoints)(api_contract_1.apiContract.admin.plugins, pluginsRouter, router);
|
|
225
|
+
return router;
|
|
226
|
+
};
|
|
227
|
+
const toPluginInfo = (plugin, all) => ({
|
|
228
|
+
name: plugin.name,
|
|
229
|
+
version: plugin.version,
|
|
230
|
+
requires: plugin.requires,
|
|
231
|
+
hasConfig: !!plugin.configSchema,
|
|
232
|
+
registers: collectRegistrySlots(plugin),
|
|
233
|
+
adminPlacement: resolvePlacement(plugin),
|
|
234
|
+
supportsHotReload: hasReconfigureOrDependent(plugin, all),
|
|
235
|
+
});
|
|
236
|
+
/**
|
|
237
|
+
* A plugin "supports hot reload" if changing its config can be applied
|
|
238
|
+
* live. That is true when the plugin itself implements `reconfigure`
|
|
239
|
+
* OR when a plugin that requires it does — config-only base plugins
|
|
240
|
+
* (e.g. `@crowi/plugin-aws`) flow through this transitively because
|
|
241
|
+
* the dependents fan-out fires their reconfigure.
|
|
242
|
+
*/
|
|
243
|
+
function hasReconfigureOrDependent(plugin, all) {
|
|
244
|
+
if (plugin.reconfigure)
|
|
245
|
+
return true;
|
|
246
|
+
for (const other of all) {
|
|
247
|
+
if (other.requires?.includes(plugin.name) && other.reconfigure)
|
|
248
|
+
return true;
|
|
249
|
+
}
|
|
250
|
+
return false;
|
|
251
|
+
}
|
|
252
|
+
function collectRegistrySlots(plugin) {
|
|
253
|
+
const slots = [];
|
|
254
|
+
if (plugin.registerStorage)
|
|
255
|
+
slots.push('storage');
|
|
256
|
+
if (plugin.registerSearch)
|
|
257
|
+
slots.push('search');
|
|
258
|
+
if (plugin.registerAuth)
|
|
259
|
+
slots.push('auth');
|
|
260
|
+
if (plugin.registerNotifier)
|
|
261
|
+
slots.push('notifier');
|
|
262
|
+
return slots;
|
|
263
|
+
}
|
|
264
|
+
/**
|
|
265
|
+
* Compute the effective sidebar placement for a plugin. The plugin's
|
|
266
|
+
* own `adminPlacement` wins where it sets a field; missing fields
|
|
267
|
+
* fall back to derived defaults:
|
|
268
|
+
* - section: derived from register* hooks (storage / search / auth /
|
|
269
|
+
* notification → matching section). Plugins with no register*
|
|
270
|
+
* hook need to declare `section: 'shared'` themselves to appear
|
|
271
|
+
* under the "shared services" section; if they didn't declare it
|
|
272
|
+
* either, fall through to `'settings'`.
|
|
273
|
+
* - label: defaults to the plugin's npm name.
|
|
274
|
+
* - icon: optional, no default.
|
|
275
|
+
*/
|
|
276
|
+
function resolvePlacement(plugin) {
|
|
277
|
+
const declared = plugin.adminPlacement;
|
|
278
|
+
const derivedSection = deriveSectionFromHooks(plugin);
|
|
279
|
+
return {
|
|
280
|
+
section: declared?.section ?? derivedSection ?? 'settings',
|
|
281
|
+
label: declared?.label ?? plugin.name,
|
|
282
|
+
icon: declared?.icon,
|
|
283
|
+
};
|
|
284
|
+
}
|
|
285
|
+
function deriveSectionFromHooks(plugin) {
|
|
286
|
+
if (plugin.registerStorage)
|
|
287
|
+
return 'storage';
|
|
288
|
+
if (plugin.registerAuth)
|
|
289
|
+
return 'auth';
|
|
290
|
+
if (plugin.registerNotifier)
|
|
291
|
+
return 'notification';
|
|
292
|
+
// search has no top-level section in the to-be sidebar; surface
|
|
293
|
+
// search-only plugins under "settings" by default.
|
|
294
|
+
return undefined;
|
|
295
|
+
}
|
|
296
|
+
function readPluginNamespace(crowi, pluginName) {
|
|
297
|
+
const all = crowi.getConfig();
|
|
298
|
+
const crowiNs = (all && typeof all === 'object' ? all.crowi : undefined) ?? {};
|
|
299
|
+
const prefix = `plugin:${pluginName}:`;
|
|
300
|
+
const out = {};
|
|
301
|
+
for (const [key, value] of Object.entries(crowiNs)) {
|
|
302
|
+
if (key.startsWith(prefix)) {
|
|
303
|
+
out[key.slice(prefix.length)] = value;
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
return out;
|
|
307
|
+
}
|
|
308
|
+
const pluginNotFound = (name) => ({
|
|
309
|
+
status: 404,
|
|
310
|
+
body: {
|
|
311
|
+
error: {
|
|
312
|
+
code: 'PLUGIN_NOT_FOUND',
|
|
313
|
+
message: `Plugin '${name}' is not loaded`,
|
|
314
|
+
},
|
|
315
|
+
},
|
|
316
|
+
});
|
|
317
|
+
//# sourceMappingURL=plugins.js.map
|