@mx-space/api-client 1.0.0 → 1.0.2
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/.eslintcache +1 -1
- package/LICENSE +661 -0
- package/controllers/recently.ts +24 -3
- package/dist/index.cjs +18 -0
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -1
- package/dist/index.min.cjs +1 -1
- package/dist/index.min.cjs.map +1 -1
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/dist/index.umd.js +18 -0
- package/dist/index.umd.js.map +1 -1
- package/dist/index.umd.min.js +1 -1
- package/dist/index.umd.min.js.map +1 -1
- package/esm/adaptors/axios.d.ts +4 -0
- package/esm/adaptors/axios.js +37 -0
- package/esm/adaptors/axios.js.map +1 -0
- package/esm/adaptors/ky.d.ts +23 -0
- package/esm/adaptors/ky.js +62 -0
- package/esm/adaptors/ky.js.map +1 -0
- package/esm/adaptors/umi-request.d.ts +4 -0
- package/esm/adaptors/umi-request.js +31 -0
- package/esm/adaptors/umi-request.js.map +1 -0
- package/esm/controllers/aggregate.d.ts +64 -0
- package/esm/controllers/aggregate.js +42 -0
- package/esm/controllers/aggregate.js.map +1 -0
- package/esm/controllers/base.d.ts +43 -0
- package/esm/controllers/base.js +27 -0
- package/esm/controllers/base.js.map +1 -0
- package/esm/controllers/category.d.ts +114 -0
- package/esm/controllers/category.js +68 -0
- package/esm/controllers/category.js.map +1 -0
- package/esm/controllers/comment.d.ts +81 -0
- package/esm/controllers/comment.js +47 -0
- package/esm/controllers/comment.js.map +1 -0
- package/esm/controllers/index.d.ts +18 -0
- package/esm/controllers/index.js +55 -0
- package/esm/controllers/index.js.map +1 -0
- package/esm/controllers/link.d.ts +20 -0
- package/esm/controllers/link.js +21 -0
- package/esm/controllers/link.js.map +1 -0
- package/esm/controllers/note.d.ts +123 -0
- package/esm/controllers/note.js +68 -0
- package/esm/controllers/note.js.map +1 -0
- package/esm/controllers/page.d.ts +59 -0
- package/esm/controllers/page.js +42 -0
- package/esm/controllers/page.js.map +1 -0
- package/esm/controllers/post.d.ts +72 -0
- package/esm/controllers/post.js +52 -0
- package/esm/controllers/post.js.map +1 -0
- package/esm/controllers/project.d.ts +15 -0
- package/esm/controllers/project.js +12 -0
- package/esm/controllers/project.js.map +1 -0
- package/esm/controllers/recently.d.ts +110 -0
- package/esm/controllers/recently.js +49 -0
- package/esm/controllers/recently.js.map +1 -0
- package/esm/controllers/say.d.ts +37 -0
- package/esm/controllers/say.js +21 -0
- package/esm/controllers/say.js.map +1 -0
- package/esm/controllers/search.d.ts +247 -0
- package/esm/controllers/search.js +28 -0
- package/esm/controllers/search.js.map +1 -0
- package/esm/controllers/severless.d.ts +24 -0
- package/esm/controllers/severless.js +16 -0
- package/esm/controllers/severless.js.map +1 -0
- package/esm/controllers/snippet.d.ts +24 -0
- package/esm/controllers/snippet.js +19 -0
- package/esm/controllers/snippet.js.map +1 -0
- package/esm/controllers/topic.d.ts +26 -0
- package/esm/controllers/topic.js +18 -0
- package/esm/controllers/topic.js.map +1 -0
- package/esm/controllers/user.d.ts +70 -0
- package/esm/controllers/user.js +40 -0
- package/esm/controllers/user.js.map +1 -0
- package/esm/core/attach-request.d.ts +2 -0
- package/esm/core/attach-request.js +36 -0
- package/esm/core/attach-request.js.map +1 -0
- package/esm/core/client.d.ts +29 -0
- package/esm/core/client.js +186 -0
- package/esm/core/client.js.map +1 -0
- package/esm/core/error.d.ts +6 -0
- package/esm/core/error.js +9 -0
- package/esm/core/error.js.map +1 -0
- package/esm/core/index.d.ts +2 -0
- package/esm/core/index.js +3 -0
- package/esm/core/index.js.map +1 -0
- package/esm/dtos/comment.d.ts +6 -0
- package/esm/dtos/comment.js +3 -0
- package/esm/dtos/comment.js.map +1 -0
- package/esm/index.d.ts +7 -0
- package/esm/index.js +8 -0
- package/esm/index.js.map +1 -0
- package/esm/interfaces/adapter.d.ts +14 -0
- package/esm/interfaces/adapter.js +2 -0
- package/esm/interfaces/adapter.js.map +1 -0
- package/esm/interfaces/client.d.ts +13 -0
- package/esm/interfaces/client.js +2 -0
- package/esm/interfaces/client.js.map +1 -0
- package/esm/interfaces/controller.d.ts +4 -0
- package/esm/interfaces/controller.js +2 -0
- package/esm/interfaces/controller.js.map +1 -0
- package/esm/interfaces/instance.d.ts +7 -0
- package/esm/interfaces/instance.js +2 -0
- package/esm/interfaces/instance.js.map +1 -0
- package/esm/interfaces/options.d.ts +1 -0
- package/esm/interfaces/options.js +2 -0
- package/esm/interfaces/options.js.map +1 -0
- package/esm/interfaces/params.d.ts +4 -0
- package/esm/interfaces/params.js +2 -0
- package/esm/interfaces/params.js.map +1 -0
- package/esm/interfaces/request.d.ts +43 -0
- package/esm/interfaces/request.js +2 -0
- package/esm/interfaces/request.js.map +1 -0
- package/esm/interfaces/types.d.ts +2 -0
- package/esm/interfaces/types.js +2 -0
- package/esm/interfaces/types.js.map +1 -0
- package/esm/models/aggregate.d.ts +53 -0
- package/esm/models/aggregate.js +6 -0
- package/esm/models/aggregate.js.map +1 -0
- package/esm/models/base.d.ts +41 -0
- package/esm/models/base.js +2 -0
- package/esm/models/base.js.map +1 -0
- package/esm/models/category.d.ts +22 -0
- package/esm/models/category.js +6 -0
- package/esm/models/category.js.map +1 -0
- package/esm/models/comment.d.ts +37 -0
- package/esm/models/comment.js +13 -0
- package/esm/models/comment.js.map +1 -0
- package/esm/models/index.d.ts +14 -0
- package/esm/models/index.js +15 -0
- package/esm/models/index.js.map +1 -0
- package/esm/models/link.d.ts +22 -0
- package/esm/models/link.js +14 -0
- package/esm/models/link.js.map +1 -0
- package/esm/models/note.d.ts +38 -0
- package/esm/models/note.js +2 -0
- package/esm/models/note.js.map +1 -0
- package/esm/models/page.d.ts +14 -0
- package/esm/models/page.js +7 -0
- package/esm/models/page.js.map +1 -0
- package/esm/models/post.d.ts +17 -0
- package/esm/models/post.js +2 -0
- package/esm/models/post.js.map +1 -0
- package/esm/models/project.d.ts +11 -0
- package/esm/models/project.js +2 -0
- package/esm/models/project.js.map +1 -0
- package/esm/models/recently.d.ts +20 -0
- package/esm/models/recently.js +7 -0
- package/esm/models/recently.js.map +1 -0
- package/esm/models/say.d.ts +6 -0
- package/esm/models/say.js +2 -0
- package/esm/models/say.js.map +1 -0
- package/esm/models/setting.d.ts +66 -0
- package/esm/models/setting.js +2 -0
- package/esm/models/setting.js.map +1 -0
- package/esm/models/snippet.d.ts +18 -0
- package/esm/models/snippet.js +8 -0
- package/esm/models/snippet.js.map +1 -0
- package/esm/models/topic.d.ts +8 -0
- package/esm/models/topic.js +2 -0
- package/esm/models/topic.js.map +1 -0
- package/esm/models/user.d.ts +21 -0
- package/esm/models/user.js +2 -0
- package/esm/models/user.js.map +1 -0
- package/esm/utils/auto-bind.d.ts +4 -0
- package/esm/utils/auto-bind.js +36 -0
- package/esm/utils/auto-bind.js.map +1 -0
- package/esm/utils/camelcase-keys.d.ts +6 -0
- package/esm/utils/camelcase-keys.js +23 -0
- package/esm/utils/camelcase-keys.js.map +1 -0
- package/esm/utils/index.d.ts +5 -0
- package/esm/utils/index.js +43 -0
- package/esm/utils/index.js.map +1 -0
- package/esm/utils/path.d.ts +1 -0
- package/esm/utils/path.js +7 -0
- package/esm/utils/path.js.map +1 -0
- package/esm/vitest.config.d.ts +2 -0
- package/esm/vitest.config.js +12 -0
- package/esm/vitest.config.js.map +1 -0
- package/lib/adaptors/axios.d.ts +4 -0
- package/lib/adaptors/axios.js +43 -0
- package/lib/adaptors/axios.js.map +1 -0
- package/lib/adaptors/ky.d.ts +23 -0
- package/lib/adaptors/ky.js +69 -0
- package/lib/adaptors/ky.js.map +1 -0
- package/lib/adaptors/umi-request.d.ts +4 -0
- package/lib/adaptors/umi-request.js +34 -0
- package/lib/adaptors/umi-request.js.map +1 -0
- package/lib/controllers/aggregate.d.ts +64 -0
- package/lib/controllers/aggregate.js +46 -0
- package/lib/controllers/aggregate.js.map +1 -0
- package/lib/controllers/base.d.ts +43 -0
- package/lib/controllers/base.js +31 -0
- package/lib/controllers/base.js.map +1 -0
- package/lib/controllers/category.d.ts +114 -0
- package/lib/controllers/category.js +72 -0
- package/lib/controllers/category.js.map +1 -0
- package/lib/controllers/comment.d.ts +81 -0
- package/lib/controllers/comment.js +51 -0
- package/lib/controllers/comment.js.map +1 -0
- package/lib/controllers/index.d.ts +18 -0
- package/lib/controllers/index.js +72 -0
- package/lib/controllers/index.js.map +1 -0
- package/lib/controllers/link.d.ts +20 -0
- package/lib/controllers/link.js +25 -0
- package/lib/controllers/link.js.map +1 -0
- package/lib/controllers/note.d.ts +123 -0
- package/lib/controllers/note.js +72 -0
- package/lib/controllers/note.js.map +1 -0
- package/lib/controllers/page.d.ts +59 -0
- package/lib/controllers/page.js +46 -0
- package/lib/controllers/page.js.map +1 -0
- package/lib/controllers/post.d.ts +72 -0
- package/lib/controllers/post.js +56 -0
- package/lib/controllers/post.js.map +1 -0
- package/lib/controllers/project.d.ts +15 -0
- package/lib/controllers/project.js +16 -0
- package/lib/controllers/project.js.map +1 -0
- package/lib/controllers/recently.d.ts +110 -0
- package/lib/controllers/recently.js +53 -0
- package/lib/controllers/recently.js.map +1 -0
- package/lib/controllers/say.d.ts +37 -0
- package/lib/controllers/say.js +25 -0
- package/lib/controllers/say.js.map +1 -0
- package/lib/controllers/search.d.ts +247 -0
- package/lib/controllers/search.js +32 -0
- package/lib/controllers/search.js.map +1 -0
- package/lib/controllers/severless.d.ts +24 -0
- package/lib/controllers/severless.js +20 -0
- package/lib/controllers/severless.js.map +1 -0
- package/lib/controllers/snippet.d.ts +24 -0
- package/lib/controllers/snippet.js +23 -0
- package/lib/controllers/snippet.js.map +1 -0
- package/lib/controllers/topic.d.ts +26 -0
- package/lib/controllers/topic.js +22 -0
- package/lib/controllers/topic.js.map +1 -0
- package/lib/controllers/user.d.ts +70 -0
- package/lib/controllers/user.js +44 -0
- package/lib/controllers/user.js.map +1 -0
- package/lib/core/attach-request.d.ts +2 -0
- package/lib/core/attach-request.js +40 -0
- package/lib/core/attach-request.js.map +1 -0
- package/lib/core/client.d.ts +29 -0
- package/lib/core/client.js +190 -0
- package/lib/core/client.js.map +1 -0
- package/lib/core/error.d.ts +6 -0
- package/lib/core/error.js +13 -0
- package/lib/core/error.js.map +1 -0
- package/lib/core/index.d.ts +2 -0
- package/lib/core/index.js +19 -0
- package/lib/core/index.js.map +1 -0
- package/lib/dtos/comment.d.ts +6 -0
- package/lib/dtos/comment.js +7 -0
- package/lib/dtos/comment.js.map +1 -0
- package/lib/index.d.ts +7 -0
- package/lib/index.js +28 -0
- package/lib/index.js.map +1 -0
- package/lib/interfaces/adapter.d.ts +14 -0
- package/lib/interfaces/adapter.js +3 -0
- package/lib/interfaces/adapter.js.map +1 -0
- package/lib/interfaces/client.d.ts +13 -0
- package/lib/interfaces/client.js +3 -0
- package/lib/interfaces/client.js.map +1 -0
- package/lib/interfaces/controller.d.ts +4 -0
- package/lib/interfaces/controller.js +3 -0
- package/lib/interfaces/controller.js.map +1 -0
- package/lib/interfaces/instance.d.ts +7 -0
- package/lib/interfaces/instance.js +3 -0
- package/lib/interfaces/instance.js.map +1 -0
- package/lib/interfaces/options.d.ts +1 -0
- package/lib/interfaces/options.js +3 -0
- package/lib/interfaces/options.js.map +1 -0
- package/lib/interfaces/params.d.ts +4 -0
- package/lib/interfaces/params.js +3 -0
- package/lib/interfaces/params.js.map +1 -0
- package/lib/interfaces/request.d.ts +43 -0
- package/lib/interfaces/request.js +3 -0
- package/lib/interfaces/request.js.map +1 -0
- package/lib/interfaces/types.d.ts +2 -0
- package/lib/interfaces/types.js +3 -0
- package/lib/interfaces/types.js.map +1 -0
- package/lib/models/aggregate.d.ts +53 -0
- package/lib/models/aggregate.js +9 -0
- package/lib/models/aggregate.js.map +1 -0
- package/lib/models/base.d.ts +41 -0
- package/lib/models/base.js +3 -0
- package/lib/models/base.js.map +1 -0
- package/lib/models/category.d.ts +22 -0
- package/lib/models/category.js +9 -0
- package/lib/models/category.js.map +1 -0
- package/lib/models/comment.d.ts +37 -0
- package/lib/models/comment.js +16 -0
- package/lib/models/comment.js.map +1 -0
- package/lib/models/index.d.ts +14 -0
- package/lib/models/index.js +31 -0
- package/lib/models/index.js.map +1 -0
- package/lib/models/link.d.ts +22 -0
- package/lib/models/link.js +17 -0
- package/lib/models/link.js.map +1 -0
- package/lib/models/note.d.ts +38 -0
- package/lib/models/note.js +3 -0
- package/lib/models/note.js.map +1 -0
- package/lib/models/page.d.ts +14 -0
- package/lib/models/page.js +10 -0
- package/lib/models/page.js.map +1 -0
- package/lib/models/post.d.ts +17 -0
- package/lib/models/post.js +3 -0
- package/lib/models/post.js.map +1 -0
- package/lib/models/project.d.ts +11 -0
- package/lib/models/project.js +3 -0
- package/lib/models/project.js.map +1 -0
- package/lib/models/recently.d.ts +20 -0
- package/lib/models/recently.js +10 -0
- package/lib/models/recently.js.map +1 -0
- package/lib/models/say.d.ts +6 -0
- package/lib/models/say.js +3 -0
- package/lib/models/say.js.map +1 -0
- package/lib/models/setting.d.ts +66 -0
- package/lib/models/setting.js +3 -0
- package/lib/models/setting.js.map +1 -0
- package/lib/models/snippet.d.ts +18 -0
- package/lib/models/snippet.js +11 -0
- package/lib/models/snippet.js.map +1 -0
- package/lib/models/topic.d.ts +8 -0
- package/lib/models/topic.js +3 -0
- package/lib/models/topic.js.map +1 -0
- package/lib/models/user.d.ts +21 -0
- package/lib/models/user.js +3 -0
- package/lib/models/user.js.map +1 -0
- package/lib/utils/auto-bind.d.ts +4 -0
- package/lib/utils/auto-bind.js +40 -0
- package/lib/utils/auto-bind.js.map +1 -0
- package/lib/utils/camelcase-keys.d.ts +6 -0
- package/lib/utils/camelcase-keys.js +28 -0
- package/lib/utils/camelcase-keys.js.map +1 -0
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.js +50 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/path.d.ts +1 -0
- package/lib/utils/path.js +11 -0
- package/lib/utils/path.js.map +1 -0
- package/lib/vitest.config.d.ts +2 -0
- package/lib/vitest.config.js +17 -0
- package/lib/vitest.config.js.map +1 -0
- package/package.json +26 -12
- package/types/adaptors/axios.d.ts +4 -0
- package/types/adaptors/ky.d.ts +23 -0
- package/types/adaptors/umi-request.d.ts +4 -0
- package/types/controllers/aggregate.d.ts +64 -0
- package/types/controllers/base.d.ts +43 -0
- package/types/controllers/category.d.ts +114 -0
- package/types/controllers/comment.d.ts +81 -0
- package/types/controllers/index.d.ts +18 -0
- package/types/controllers/link.d.ts +20 -0
- package/types/controllers/note.d.ts +123 -0
- package/types/controllers/page.d.ts +59 -0
- package/types/controllers/post.d.ts +72 -0
- package/types/controllers/project.d.ts +15 -0
- package/types/controllers/recently.d.ts +110 -0
- package/types/controllers/say.d.ts +37 -0
- package/types/controllers/search.d.ts +247 -0
- package/types/controllers/severless.d.ts +24 -0
- package/types/controllers/snippet.d.ts +24 -0
- package/types/controllers/topic.d.ts +26 -0
- package/types/controllers/user.d.ts +70 -0
- package/types/core/attach-request.d.ts +2 -0
- package/types/core/client.d.ts +29 -0
- package/types/core/error.d.ts +6 -0
- package/types/core/index.d.ts +2 -0
- package/types/dtos/comment.d.ts +6 -0
- package/types/index.d.ts +7 -0
- package/types/interfaces/adapter.d.ts +14 -0
- package/types/interfaces/client.d.ts +13 -0
- package/types/interfaces/controller.d.ts +4 -0
- package/types/interfaces/instance.d.ts +7 -0
- package/types/interfaces/options.d.ts +1 -0
- package/types/interfaces/params.d.ts +4 -0
- package/types/interfaces/request.d.ts +43 -0
- package/types/interfaces/types.d.ts +2 -0
- package/types/models/aggregate.d.ts +53 -0
- package/types/models/base.d.ts +41 -0
- package/types/models/category.d.ts +22 -0
- package/types/models/comment.d.ts +37 -0
- package/types/models/index.d.ts +14 -0
- package/types/models/link.d.ts +22 -0
- package/types/models/note.d.ts +38 -0
- package/types/models/page.d.ts +14 -0
- package/types/models/post.d.ts +17 -0
- package/types/models/project.d.ts +11 -0
- package/types/models/recently.d.ts +20 -0
- package/types/models/say.d.ts +6 -0
- package/types/models/setting.d.ts +66 -0
- package/types/models/snippet.d.ts +18 -0
- package/types/models/topic.d.ts +8 -0
- package/types/models/user.d.ts +21 -0
- package/types/utils/auto-bind.d.ts +4 -0
- package/types/utils/camelcase-keys.d.ts +6 -0
- package/types/utils/index.d.ts +5 -0
- package/types/utils/path.d.ts +1 -0
- package/types/vitest.config.d.ts +2 -0
- package/__tests__/adaptors/axios.spec.ts +0 -7
- package/__tests__/adaptors/ky.spec.ts +0 -9
- package/__tests__/adaptors/umi-request.spec.ts +0 -7
- package/__tests__/contronllers/aggregate.test.ts +0 -389
- package/__tests__/contronllers/category.test.ts +0 -284
- package/__tests__/contronllers/comment.test.ts +0 -113
- package/__tests__/contronllers/link.test.ts +0 -95
- package/__tests__/contronllers/note.test.ts +0 -120
- package/__tests__/contronllers/page.test.ts +0 -49
- package/__tests__/contronllers/post.test.ts +0 -77
- package/__tests__/contronllers/recently.test.ts +0 -49
- package/__tests__/contronllers/say.test.ts +0 -106
- package/__tests__/contronllers/search.test.ts +0 -81
- package/__tests__/contronllers/serverless.test.ts +0 -19
- package/__tests__/contronllers/snippet.test.ts +0 -38
- package/__tests__/contronllers/topic.test.ts +0 -17
- package/__tests__/contronllers/user.test.ts +0 -59
- package/__tests__/core/client.test.ts +0 -293
- package/__tests__/helpers/adaptor-test.ts +0 -108
- package/__tests__/helpers/e2e-mock-server.ts +0 -22
- package/__tests__/helpers/global-fetch.ts +0 -39
- package/__tests__/helpers/instance.ts +0 -11
- package/__tests__/helpers/response.ts +0 -76
- package/__tests__/mock/algolia.json +0 -446
- package/__tests__/utils/auto-bind.spec.ts +0 -27
- package/__tests__/utils/camelcase-keys.spec.ts +0 -86
- package/__tests__/utils/index.test.ts +0 -33
- package/__tests__/utils/path.spec.ts +0 -8
- package/adaptors/axios.ts +0 -44
- package/adaptors/ky.ts +0 -76
- package/adaptors/umi-request.ts +0 -38
- package/core/attach-request.ts +0 -43
- package/core/client.ts +0 -252
- package/core/error.ts +0 -10
- package/core/index.ts +0 -2
- package/coverage/lcov-report/__tests__/helpers/adaptor-test.ts.html +0 -405
- package/coverage/lcov-report/__tests__/helpers/e2e-mock-server.ts.html +0 -150
- package/coverage/lcov-report/__tests__/helpers/index.html +0 -236
- package/coverage/lcov-report/__tests__/helpers/instance.ts.html +0 -120
- package/coverage/lcov-report/__tests__/helpers/response.ts.html +0 -231
- package/rollup.config.js +0 -150
- package/utils/auto-bind.ts +0 -48
- package/utils/camelcase-keys.ts +0 -26
- package/utils/index.ts +0 -53
- package/utils/path.ts +0 -6
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
import { IRequestAdapter } from '../interfaces/adapter';
|
|
2
|
+
import { IController } from '../interfaces/controller';
|
|
3
|
+
import { IRequestHandler, RequestProxyResult } from '../interfaces/request';
|
|
4
|
+
import { PaginateResult } from '../models/base';
|
|
5
|
+
import { NoteModel } from '../models/note';
|
|
6
|
+
import { PostModel } from '../models/post';
|
|
7
|
+
import { PageModel } from '..';
|
|
8
|
+
import { HTTPClient } from '../core';
|
|
9
|
+
declare module '../core/client' {
|
|
10
|
+
interface HTTPClient<T extends IRequestAdapter = IRequestAdapter, ResponseWrapper = unknown> {
|
|
11
|
+
search: SearchController<ResponseWrapper>;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export type SearchType = 'post' | 'note';
|
|
15
|
+
export type SearchOption = {
|
|
16
|
+
orderBy?: string;
|
|
17
|
+
order?: number;
|
|
18
|
+
rawAlgolia?: boolean;
|
|
19
|
+
};
|
|
20
|
+
export declare class SearchController<ResponseWrapper> implements IController {
|
|
21
|
+
private readonly client;
|
|
22
|
+
base: string;
|
|
23
|
+
name: string;
|
|
24
|
+
constructor(client: HTTPClient);
|
|
25
|
+
get proxy(): IRequestHandler<ResponseWrapper>;
|
|
26
|
+
search(type: 'note', keyword: string, options?: Omit<SearchOption, 'rawAlgolia'>): Promise<RequestProxyResult<PaginateResult<Pick<NoteModel, 'modified' | 'id' | 'title' | 'created' | 'nid'>>, ResponseWrapper>>;
|
|
27
|
+
search(type: 'post', keyword: string, options?: Omit<SearchOption, 'rawAlgolia'>): Promise<RequestProxyResult<PaginateResult<Pick<PostModel, 'modified' | 'id' | 'title' | 'created' | 'slug' | 'category'>>, ResponseWrapper>>;
|
|
28
|
+
/**
|
|
29
|
+
* 从 algolya 搜索
|
|
30
|
+
* https://www.algolia.com/doc/api-reference/api-methods/search/
|
|
31
|
+
* @param keyword
|
|
32
|
+
* @param options
|
|
33
|
+
* @returns
|
|
34
|
+
*/
|
|
35
|
+
searchByAlgolia(keyword: string, options?: SearchOption): RequestProxyResult<RequestProxyResult<PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
36
|
+
type: 'post';
|
|
37
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
38
|
+
type: 'note';
|
|
39
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
40
|
+
type: 'page';
|
|
41
|
+
})> & {
|
|
42
|
+
/**
|
|
43
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
44
|
+
*/
|
|
45
|
+
raw?: any;
|
|
46
|
+
}, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
47
|
+
[key: string]: any;
|
|
48
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
49
|
+
type: 'post';
|
|
50
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
51
|
+
type: 'note';
|
|
52
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
53
|
+
type: 'page';
|
|
54
|
+
})> & {
|
|
55
|
+
/**
|
|
56
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
57
|
+
*/
|
|
58
|
+
raw?: any;
|
|
59
|
+
};
|
|
60
|
+
} : ResponseWrapper extends {
|
|
61
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
62
|
+
type: 'post';
|
|
63
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
64
|
+
type: 'note';
|
|
65
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
66
|
+
type: 'page';
|
|
67
|
+
})> & {
|
|
68
|
+
/**
|
|
69
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
70
|
+
*/
|
|
71
|
+
raw?: any;
|
|
72
|
+
};
|
|
73
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
74
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
75
|
+
type: 'post';
|
|
76
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
77
|
+
type: 'note';
|
|
78
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
79
|
+
type: 'page';
|
|
80
|
+
})> & {
|
|
81
|
+
/**
|
|
82
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
83
|
+
*/
|
|
84
|
+
raw?: any;
|
|
85
|
+
};
|
|
86
|
+
}>, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
87
|
+
[key: string]: any;
|
|
88
|
+
data: RequestProxyResult<PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
89
|
+
type: 'post';
|
|
90
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
91
|
+
type: 'note';
|
|
92
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
93
|
+
type: 'page';
|
|
94
|
+
})> & {
|
|
95
|
+
/**
|
|
96
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
97
|
+
*/
|
|
98
|
+
raw?: any;
|
|
99
|
+
}, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
100
|
+
[key: string]: any;
|
|
101
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
102
|
+
type: 'post';
|
|
103
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
104
|
+
type: 'note';
|
|
105
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
106
|
+
type: 'page';
|
|
107
|
+
})> & {
|
|
108
|
+
/**
|
|
109
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
110
|
+
*/
|
|
111
|
+
raw?: any;
|
|
112
|
+
};
|
|
113
|
+
} : ResponseWrapper extends {
|
|
114
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
115
|
+
type: 'post';
|
|
116
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
117
|
+
type: 'note';
|
|
118
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
119
|
+
type: 'page';
|
|
120
|
+
})> & {
|
|
121
|
+
/**
|
|
122
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
123
|
+
*/
|
|
124
|
+
raw?: any;
|
|
125
|
+
};
|
|
126
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
127
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
128
|
+
type: 'post';
|
|
129
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
130
|
+
type: 'note';
|
|
131
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
132
|
+
type: 'page';
|
|
133
|
+
})> & {
|
|
134
|
+
/**
|
|
135
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
136
|
+
*/
|
|
137
|
+
raw?: any;
|
|
138
|
+
};
|
|
139
|
+
}>;
|
|
140
|
+
} : ResponseWrapper extends {
|
|
141
|
+
data: RequestProxyResult<PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
142
|
+
type: 'post';
|
|
143
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
144
|
+
type: 'note';
|
|
145
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
146
|
+
type: 'page';
|
|
147
|
+
})> & {
|
|
148
|
+
/**
|
|
149
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
150
|
+
*/
|
|
151
|
+
raw?: any;
|
|
152
|
+
}, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
153
|
+
[key: string]: any;
|
|
154
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
155
|
+
type: 'post';
|
|
156
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
157
|
+
type: 'note';
|
|
158
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
159
|
+
type: 'page';
|
|
160
|
+
})> & {
|
|
161
|
+
/**
|
|
162
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
163
|
+
*/
|
|
164
|
+
raw?: any;
|
|
165
|
+
};
|
|
166
|
+
} : ResponseWrapper extends {
|
|
167
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
168
|
+
type: 'post';
|
|
169
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
170
|
+
type: 'note';
|
|
171
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
172
|
+
type: 'page';
|
|
173
|
+
})> & {
|
|
174
|
+
/**
|
|
175
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
176
|
+
*/
|
|
177
|
+
raw?: any;
|
|
178
|
+
};
|
|
179
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
180
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
181
|
+
type: 'post';
|
|
182
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
183
|
+
type: 'note';
|
|
184
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
185
|
+
type: 'page';
|
|
186
|
+
})> & {
|
|
187
|
+
/**
|
|
188
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
189
|
+
*/
|
|
190
|
+
raw?: any;
|
|
191
|
+
};
|
|
192
|
+
}>;
|
|
193
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
194
|
+
data: RequestProxyResult<PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
195
|
+
type: 'post';
|
|
196
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
197
|
+
type: 'note';
|
|
198
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
199
|
+
type: 'page';
|
|
200
|
+
})> & {
|
|
201
|
+
/**
|
|
202
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
203
|
+
*/
|
|
204
|
+
raw?: any;
|
|
205
|
+
}, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
206
|
+
[key: string]: any;
|
|
207
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
208
|
+
type: 'post';
|
|
209
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
210
|
+
type: 'note';
|
|
211
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
212
|
+
type: 'page';
|
|
213
|
+
})> & {
|
|
214
|
+
/**
|
|
215
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
216
|
+
*/
|
|
217
|
+
raw?: any;
|
|
218
|
+
};
|
|
219
|
+
} : ResponseWrapper extends {
|
|
220
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
221
|
+
type: 'post';
|
|
222
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
223
|
+
type: 'note';
|
|
224
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
225
|
+
type: 'page';
|
|
226
|
+
})> & {
|
|
227
|
+
/**
|
|
228
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
229
|
+
*/
|
|
230
|
+
raw?: any;
|
|
231
|
+
};
|
|
232
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
233
|
+
data: PaginateResult<(Pick<PostModel, "id" | "category" | "created" | "modified" | "title" | "slug"> & {
|
|
234
|
+
type: 'post';
|
|
235
|
+
}) | (Pick<NoteModel, "id" | "created" | "modified" | "title" | "nid"> & {
|
|
236
|
+
type: 'note';
|
|
237
|
+
}) | (Pick<PageModel, "id" | "created" | "modified" | "title" | "slug"> & {
|
|
238
|
+
type: 'page';
|
|
239
|
+
})> & {
|
|
240
|
+
/**
|
|
241
|
+
* @see: algoliasearch <https://www.algolia.com/doc/api-reference/api-methods/search/>
|
|
242
|
+
*/
|
|
243
|
+
raw?: any;
|
|
244
|
+
};
|
|
245
|
+
}>;
|
|
246
|
+
}>;
|
|
247
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SearchController = void 0;
|
|
4
|
+
const auto_bind_1 = require("../utils/auto-bind");
|
|
5
|
+
class SearchController {
|
|
6
|
+
constructor(client) {
|
|
7
|
+
this.client = client;
|
|
8
|
+
this.base = 'search';
|
|
9
|
+
this.name = 'search';
|
|
10
|
+
(0, auto_bind_1.autoBind)(this);
|
|
11
|
+
}
|
|
12
|
+
get proxy() {
|
|
13
|
+
return this.client.proxy(this.base);
|
|
14
|
+
}
|
|
15
|
+
search(type, keyword, options = {}) {
|
|
16
|
+
return this.proxy(type).get({
|
|
17
|
+
params: { keyword, ...options },
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* 从 algolya 搜索
|
|
22
|
+
* https://www.algolia.com/doc/api-reference/api-methods/search/
|
|
23
|
+
* @param keyword
|
|
24
|
+
* @param options
|
|
25
|
+
* @returns
|
|
26
|
+
*/
|
|
27
|
+
searchByAlgolia(keyword, options) {
|
|
28
|
+
return this.proxy('algolia').get({ params: { keyword, ...options } });
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.SearchController = SearchController;
|
|
32
|
+
//# sourceMappingURL=search.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../controllers/search.ts"],"names":[],"mappings":";;;AAMA,iDAA4C;AAqB5C,MAAa,gBAAgB;IAI3B,YAA6B,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;QAH/C,SAAI,GAAG,QAAQ,CAAA;QACf,SAAI,GAAG,QAAQ,CAAA;QAGb,IAAA,oBAAQ,EAAC,IAAI,CAAC,CAAA;IAChB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IA6BD,MAAM,CACJ,IAAgB,EAChB,OAAe,EACf,UAA4C,EAAE;QAE9C,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC;YAC1B,MAAM,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE;SAChC,CAAC,CAAA;IACJ,CAAC;IACD;;;;;;OAMG;IACH,eAAe,CAAC,OAAe,EAAE,OAAsB;QACrD,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,GAAG,CAuB9B,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,EAAE,CAAC,CAAA;IACxC,CAAC;CACF;AAjFD,4CAiFC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { IRequestAdapter } from '../interfaces/adapter';
|
|
2
|
+
import { IController } from '../interfaces/controller';
|
|
3
|
+
import { IRequestHandler } from '../interfaces/request';
|
|
4
|
+
import { HTTPClient } from '../core';
|
|
5
|
+
declare module '../core/client' {
|
|
6
|
+
interface HTTPClient<T extends IRequestAdapter = IRequestAdapter, ResponseWrapper = unknown> {
|
|
7
|
+
serverless: ServerlessController<ResponseWrapper>;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export declare class ServerlessController<ResponseWrapper> implements IController {
|
|
11
|
+
protected client: HTTPClient;
|
|
12
|
+
base: string;
|
|
13
|
+
name: string;
|
|
14
|
+
constructor(client: HTTPClient);
|
|
15
|
+
get proxy(): IRequestHandler<ResponseWrapper>;
|
|
16
|
+
getByReferenceAndName<T = unknown>(reference: string, name: string): import("../interfaces/request").RequestProxyResult<T, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
17
|
+
[key: string]: any;
|
|
18
|
+
data: T;
|
|
19
|
+
} : ResponseWrapper extends {
|
|
20
|
+
data: T;
|
|
21
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
22
|
+
data: T;
|
|
23
|
+
}>;
|
|
24
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ServerlessController = void 0;
|
|
4
|
+
const auto_bind_1 = require("../utils/auto-bind");
|
|
5
|
+
class ServerlessController {
|
|
6
|
+
constructor(client) {
|
|
7
|
+
this.client = client;
|
|
8
|
+
this.base = 'serverless';
|
|
9
|
+
this.name = 'serverless';
|
|
10
|
+
(0, auto_bind_1.autoBind)(this);
|
|
11
|
+
}
|
|
12
|
+
get proxy() {
|
|
13
|
+
return this.client.proxy(this.base);
|
|
14
|
+
}
|
|
15
|
+
getByReferenceAndName(reference, name) {
|
|
16
|
+
return this.proxy(reference)(name).get();
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.ServerlessController = ServerlessController;
|
|
20
|
+
//# sourceMappingURL=severless.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"severless.js","sourceRoot":"","sources":["../../controllers/severless.ts"],"names":[],"mappings":";;;AAGA,iDAA4C;AAa5C,MAAa,oBAAoB;IAI/B,YAAsB,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;QAHxC,SAAI,GAAG,YAAY,CAAA;QACnB,SAAI,GAAG,YAAY,CAAA;QAGjB,IAAA,oBAAQ,EAAC,IAAI,CAAC,CAAA;IAChB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED,qBAAqB,CAAc,SAAiB,EAAE,IAAY;QAChE,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAK,CAAA;IAC7C,CAAC;CACF;AAfD,oDAeC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { IRequestAdapter } from '../interfaces/adapter';
|
|
2
|
+
import { IController } from '../interfaces/controller';
|
|
3
|
+
import { IRequestHandler } from '../interfaces/request';
|
|
4
|
+
import { HTTPClient } from '../core';
|
|
5
|
+
declare module '../core/client' {
|
|
6
|
+
interface HTTPClient<T extends IRequestAdapter = IRequestAdapter, ResponseWrapper = unknown> {
|
|
7
|
+
snippet: SnippetController<ResponseWrapper>;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export declare class SnippetController<ResponseWrapper> implements IController {
|
|
11
|
+
protected client: HTTPClient;
|
|
12
|
+
base: string;
|
|
13
|
+
name: string;
|
|
14
|
+
constructor(client: HTTPClient);
|
|
15
|
+
get proxy(): IRequestHandler<ResponseWrapper>;
|
|
16
|
+
getByReferenceAndName<T = unknown>(reference: string, name: string): import("../interfaces/request").RequestProxyResult<T, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
17
|
+
[key: string]: any;
|
|
18
|
+
data: T;
|
|
19
|
+
} : ResponseWrapper extends {
|
|
20
|
+
data: T;
|
|
21
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
22
|
+
data: T;
|
|
23
|
+
}>;
|
|
24
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SnippetController = void 0;
|
|
4
|
+
const auto_bind_1 = require("../utils/auto-bind");
|
|
5
|
+
class SnippetController {
|
|
6
|
+
constructor(client) {
|
|
7
|
+
this.client = client;
|
|
8
|
+
this.base = 'snippets';
|
|
9
|
+
this.name = 'snippet';
|
|
10
|
+
(0, auto_bind_1.autoBind)(this);
|
|
11
|
+
}
|
|
12
|
+
get proxy() {
|
|
13
|
+
return this.client.proxy(this.base);
|
|
14
|
+
}
|
|
15
|
+
// getById(id: string) {
|
|
16
|
+
// return this.proxy(id).get<Omit<SnippetModel, 'data'>>()
|
|
17
|
+
// }
|
|
18
|
+
getByReferenceAndName(reference, name) {
|
|
19
|
+
return this.proxy(reference)(name).get();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.SnippetController = SnippetController;
|
|
23
|
+
//# sourceMappingURL=snippet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"snippet.js","sourceRoot":"","sources":["../../controllers/snippet.ts"],"names":[],"mappings":";;;AAGA,iDAA4C;AAa5C,MAAa,iBAAiB;IAI5B,YAAsB,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;QAHxC,SAAI,GAAG,UAAU,CAAA;QACjB,SAAI,GAAG,SAAS,CAAA;QAGd,IAAA,oBAAQ,EAAC,IAAI,CAAC,CAAA;IAChB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED,wBAAwB;IACxB,4DAA4D;IAC5D,IAAI;IAEJ,qBAAqB,CAAc,SAAiB,EAAE,IAAY;QAChE,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAK,CAAA;IAC7C,CAAC;CACF;AAnBD,8CAmBC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { IRequestAdapter } from '../interfaces/adapter';
|
|
2
|
+
import { IController } from '../interfaces/controller';
|
|
3
|
+
import { IRequestHandler } from '../interfaces/request';
|
|
4
|
+
import { TopicModel } from '../models/topic';
|
|
5
|
+
import { HTTPClient } from '../core';
|
|
6
|
+
import { BaseCrudController } from './base';
|
|
7
|
+
declare module '../core/client' {
|
|
8
|
+
interface HTTPClient<T extends IRequestAdapter = IRequestAdapter, ResponseWrapper = unknown> {
|
|
9
|
+
topic: TopicController<ResponseWrapper>;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export declare class TopicController<ResponseWrapper> extends BaseCrudController<TopicModel, ResponseWrapper> implements IController {
|
|
13
|
+
protected client: HTTPClient;
|
|
14
|
+
base: string;
|
|
15
|
+
name: string;
|
|
16
|
+
constructor(client: HTTPClient);
|
|
17
|
+
get proxy(): IRequestHandler<ResponseWrapper>;
|
|
18
|
+
getTopicBySlug(slug: string): import("../interfaces/request").RequestProxyResult<TopicModel, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
19
|
+
[key: string]: any;
|
|
20
|
+
data: TopicModel;
|
|
21
|
+
} : ResponseWrapper extends {
|
|
22
|
+
data: TopicModel;
|
|
23
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
24
|
+
data: TopicModel;
|
|
25
|
+
}>;
|
|
26
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TopicController = void 0;
|
|
4
|
+
const auto_bind_1 = require("../utils/auto-bind");
|
|
5
|
+
const base_1 = require("./base");
|
|
6
|
+
class TopicController extends base_1.BaseCrudController {
|
|
7
|
+
constructor(client) {
|
|
8
|
+
super(client);
|
|
9
|
+
this.client = client;
|
|
10
|
+
this.base = 'topics';
|
|
11
|
+
this.name = 'topic';
|
|
12
|
+
(0, auto_bind_1.autoBind)(this);
|
|
13
|
+
}
|
|
14
|
+
get proxy() {
|
|
15
|
+
return this.client.proxy(this.base);
|
|
16
|
+
}
|
|
17
|
+
getTopicBySlug(slug) {
|
|
18
|
+
return this.proxy.slug(slug).get();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.TopicController = TopicController;
|
|
22
|
+
//# sourceMappingURL=topic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"topic.js","sourceRoot":"","sources":["../../controllers/topic.ts"],"names":[],"mappings":";;;AAIA,iDAA4C;AAG5C,iCAA2C;AAW3C,MAAa,eACX,SAAQ,yBAA+C;IAMvD,YAAsB,MAAkB;QACtC,KAAK,CAAC,MAAM,CAAC,CAAA;QADO,WAAM,GAAN,MAAM,CAAY;QAHxC,SAAI,GAAG,QAAQ,CAAA;QACf,SAAI,GAAG,OAAO,CAAA;QAIZ,IAAA,oBAAQ,EAAC,IAAI,CAAC,CAAA;IAChB,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED,cAAc,CAAC,IAAY;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAc,CAAA;IAChD,CAAC;CACF;AAnBD,0CAmBC"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { IRequestAdapter } from '../interfaces/adapter';
|
|
2
|
+
import { IController } from '../interfaces/controller';
|
|
3
|
+
import { IRequestHandler } from '../interfaces/request';
|
|
4
|
+
import { TLogin, UserModel } from '../models/user';
|
|
5
|
+
import { HTTPClient } from '../core';
|
|
6
|
+
declare module '../core/client' {
|
|
7
|
+
interface HTTPClient<T extends IRequestAdapter = IRequestAdapter, ResponseWrapper = unknown> {
|
|
8
|
+
user: UserController<ResponseWrapper>;
|
|
9
|
+
master: UserController<ResponseWrapper>;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export declare class UserController<ResponseWrapper> implements IController {
|
|
13
|
+
private readonly client;
|
|
14
|
+
constructor(client: HTTPClient);
|
|
15
|
+
base: string;
|
|
16
|
+
name: string[];
|
|
17
|
+
get proxy(): IRequestHandler<ResponseWrapper>;
|
|
18
|
+
getMasterInfo(): import("../interfaces/request").RequestProxyResult<UserModel, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
19
|
+
[key: string]: any;
|
|
20
|
+
data: UserModel;
|
|
21
|
+
} : ResponseWrapper extends {
|
|
22
|
+
data: UserModel;
|
|
23
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
24
|
+
data: UserModel;
|
|
25
|
+
}>;
|
|
26
|
+
login(username: string, password: string): import("../interfaces/request").RequestProxyResult<TLogin, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
27
|
+
[key: string]: any;
|
|
28
|
+
data: TLogin;
|
|
29
|
+
} : ResponseWrapper extends {
|
|
30
|
+
data: TLogin;
|
|
31
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
32
|
+
data: TLogin;
|
|
33
|
+
}>;
|
|
34
|
+
loginWithToken(token?: string): import("../interfaces/request").RequestProxyResult<{
|
|
35
|
+
token: string;
|
|
36
|
+
}, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
37
|
+
[key: string]: any;
|
|
38
|
+
data: {
|
|
39
|
+
token: string;
|
|
40
|
+
};
|
|
41
|
+
} : ResponseWrapper extends {
|
|
42
|
+
data: {
|
|
43
|
+
token: string;
|
|
44
|
+
};
|
|
45
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
46
|
+
data: {
|
|
47
|
+
token: string;
|
|
48
|
+
};
|
|
49
|
+
}>;
|
|
50
|
+
checkTokenValid(token: string): import("../interfaces/request").RequestProxyResult<{
|
|
51
|
+
ok: number;
|
|
52
|
+
isGuest: boolean;
|
|
53
|
+
}, ResponseWrapper, ResponseWrapper extends unknown ? {
|
|
54
|
+
[key: string]: any;
|
|
55
|
+
data: {
|
|
56
|
+
ok: number;
|
|
57
|
+
isGuest: boolean;
|
|
58
|
+
};
|
|
59
|
+
} : ResponseWrapper extends {
|
|
60
|
+
data: {
|
|
61
|
+
ok: number;
|
|
62
|
+
isGuest: boolean;
|
|
63
|
+
};
|
|
64
|
+
} ? ResponseWrapper : Omit<ResponseWrapper, "data"> & {
|
|
65
|
+
data: {
|
|
66
|
+
ok: number;
|
|
67
|
+
isGuest: boolean;
|
|
68
|
+
};
|
|
69
|
+
}>;
|
|
70
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserController = void 0;
|
|
4
|
+
const auto_bind_1 = require("../utils/auto-bind");
|
|
5
|
+
class UserController {
|
|
6
|
+
constructor(client) {
|
|
7
|
+
this.client = client;
|
|
8
|
+
this.base = 'master';
|
|
9
|
+
this.name = ['user', 'master'];
|
|
10
|
+
(0, auto_bind_1.autoBind)(this);
|
|
11
|
+
}
|
|
12
|
+
get proxy() {
|
|
13
|
+
return this.client.proxy(this.base);
|
|
14
|
+
}
|
|
15
|
+
getMasterInfo() {
|
|
16
|
+
return this.proxy.get();
|
|
17
|
+
}
|
|
18
|
+
login(username, password) {
|
|
19
|
+
return this.proxy.login.post({
|
|
20
|
+
data: {
|
|
21
|
+
username,
|
|
22
|
+
password,
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
loginWithToken(token) {
|
|
27
|
+
return this.proxy.login.put({
|
|
28
|
+
params: token
|
|
29
|
+
? {
|
|
30
|
+
token: `bearer ${token.replace(/^Bearer\s/i, '')}`,
|
|
31
|
+
}
|
|
32
|
+
: undefined,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
checkTokenValid(token) {
|
|
36
|
+
return this.proxy.check_logged.get({
|
|
37
|
+
params: {
|
|
38
|
+
token: `bearer ${token.replace(/^Bearer\s/i, '')}`,
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
exports.UserController = UserController;
|
|
44
|
+
//# sourceMappingURL=user.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../controllers/user.ts"],"names":[],"mappings":";;;AAIA,iDAA4C;AAc5C,MAAa,cAAc;IACzB,YAA6B,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;QAI/C,SAAI,GAAG,QAAQ,CAAA;QAEf,SAAI,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAA;QALvB,IAAA,oBAAQ,EAAC,IAAI,CAAC,CAAA;IAChB,CAAC;IAMD,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,EAAa,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,QAAgB,EAAE,QAAgB;QACtC,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAS;YACnC,IAAI,EAAE;gBACJ,QAAQ;gBACR,QAAQ;aACT;SACF,CAAC,CAAA;IACJ,CAAC;IAED,cAAc,CAAC,KAAc;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAoB;YAC7C,MAAM,EAAE,KAAK;gBACX,CAAC,CAAC;oBACE,KAAK,EAAE,UAAU,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,EAAE;iBACnD;gBACH,CAAC,CAAC,SAAS;SACd,CAAC,CAAA;IACJ,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAmC;YACnE,MAAM,EAAE;gBACN,KAAK,EAAE,UAAU,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,EAAE;aACnD;SACF,CAAC,CAAA;IACJ,CAAC;CACF;AA3CD,wCA2CC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.attachRequestMethod = void 0;
|
|
4
|
+
function attachRequestMethod(target) {
|
|
5
|
+
Object.defineProperty(target, '$$get', {
|
|
6
|
+
value(url, options) {
|
|
7
|
+
// HINT: method get only accept search params;
|
|
8
|
+
const { params = {}, ...rest } = options;
|
|
9
|
+
const qs = handleSearchParams(params);
|
|
10
|
+
return target.instance.get(`${url}${qs ? `${`?${qs}`}` : ''}`, rest);
|
|
11
|
+
},
|
|
12
|
+
});
|
|
13
|
+
['put', 'post', 'patch', 'delete'].forEach((method) => {
|
|
14
|
+
Object.defineProperty(target, `$$${method}`, {
|
|
15
|
+
value(path, options) {
|
|
16
|
+
return target.instance[method](path, options);
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
exports.attachRequestMethod = attachRequestMethod;
|
|
22
|
+
// FIXME: only support string value
|
|
23
|
+
function handleSearchParams(obj) {
|
|
24
|
+
if (!obj && typeof obj !== 'object') {
|
|
25
|
+
throw new TypeError('params must be object.');
|
|
26
|
+
}
|
|
27
|
+
if (obj instanceof URLSearchParams) {
|
|
28
|
+
return obj.toString();
|
|
29
|
+
}
|
|
30
|
+
const search = new URLSearchParams();
|
|
31
|
+
Object.entries(obj).forEach(([k, v]) => {
|
|
32
|
+
if (typeof v === 'undefined' ||
|
|
33
|
+
Object.prototype.toString.call(v) === '[object Null]') {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
search.set(k, v);
|
|
37
|
+
});
|
|
38
|
+
return search.toString();
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=attach-request.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attach-request.js","sourceRoot":"","sources":["../../core/attach-request.ts"],"names":[],"mappings":";;;AAEA,SAAgB,mBAAmB,CAAiC,MAAS;IAC3E,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,OAAO,EAAE;QACrC,KAAK,CAAC,GAAW,EAAE,OAAa;YAC9B,8CAA8C;YAC9C,MAAM,EAAE,MAAM,GAAG,EAAE,EAAE,GAAG,IAAI,EAAE,GAAG,OAAO,CAAA;YACxC,MAAM,EAAE,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAA;YAErC,OAAO,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,CAAA;QACtE,CAAC;KACF,CAAC,CACD;IAAC,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAW,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;QAChE,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,KAAK,MAAM,EAAE,EAAE;YAC3C,KAAK,CAAC,IAAY,EAAE,OAAa;gBAC/B,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;YAC/C,CAAC;SACF,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC;AAjBD,kDAiBC;AACD,mCAAmC;AACnC,SAAS,kBAAkB,CAAC,GAA6C;IACvE,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;QACnC,MAAM,IAAI,SAAS,CAAC,wBAAwB,CAAC,CAAA;KAC9C;IAED,IAAI,GAAG,YAAY,eAAe,EAAE;QAClC,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAA;KACtB;IACD,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAA;IAEpC,MAAM,CAAC,OAAO,CAAM,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;QAC1C,IACE,OAAO,CAAC,KAAK,WAAW;YACxB,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,eAAe,EACrD;YACA,OAAM;SACP;QACD,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IAClB,CAAC,CAAC,CAAA;IAEF,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAA;AAC1B,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { IAdaptorRequestResponseType, IRequestAdapter } from '../interfaces/adapter';
|
|
2
|
+
import { ClientOptions } from '../interfaces/client';
|
|
3
|
+
import { IController } from '../interfaces/controller';
|
|
4
|
+
import { IRequestHandler } from '../interfaces/request';
|
|
5
|
+
import { Class } from '../interfaces/types';
|
|
6
|
+
export type { HTTPClient };
|
|
7
|
+
declare class HTTPClient<T extends IRequestAdapter = IRequestAdapter, ResponseWrapper = unknown> {
|
|
8
|
+
private readonly _endpoint;
|
|
9
|
+
private _adaptor;
|
|
10
|
+
private options;
|
|
11
|
+
private readonly _proxy;
|
|
12
|
+
constructor(_endpoint: string, _adaptor: T, options?: Omit<ClientOptions, 'controllers'>);
|
|
13
|
+
private initGetClient;
|
|
14
|
+
injectControllers(...Controller: Class<IController>[]): void;
|
|
15
|
+
injectControllers(Controller: Class<IController>[]): void;
|
|
16
|
+
get endpoint(): string;
|
|
17
|
+
get instance(): T;
|
|
18
|
+
request(options: {
|
|
19
|
+
url: string;
|
|
20
|
+
method?: string;
|
|
21
|
+
data?: any;
|
|
22
|
+
params?: any;
|
|
23
|
+
}): Promise<IAdaptorRequestResponseType<any>>;
|
|
24
|
+
get proxy(): IRequestHandler<ResponseWrapper>;
|
|
25
|
+
private buildRoute;
|
|
26
|
+
}
|
|
27
|
+
export declare function createClient<T extends IRequestAdapter>(adapter: T): <ResponseWrapper = T extends {
|
|
28
|
+
responseWrapper: infer Type;
|
|
29
|
+
} ? Type extends undefined ? unknown : Type : unknown>(endpoint: string, options?: ClientOptions) => HTTPClient<T, ResponseWrapper>;
|