{"id":21291880,"url":"https://github.com/idea2app/koagger","last_synced_at":"2026-02-12T08:02:48.799Z","repository":{"id":98205114,"uuid":"353109013","full_name":"idea2app/Koagger","owner":"idea2app","description":"A Koa middleware provides Swagger API document \u0026 Mock API for routing-controllers framework","archived":false,"fork":false,"pushed_at":"2025-03-04T10:40:25.000Z","size":156,"stargazers_count":2,"open_issues_count":0,"forks_count":0,"subscribers_count":3,"default_branch":"main","last_synced_at":"2025-03-04T10:49:29.498Z","etag":null,"topics":["api","koa","middleware","mock","swagger","typescript"],"latest_commit_sha":null,"homepage":"https://idea2app.github.io/Koagger/","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/idea2app.png","metadata":{"files":{"readme":"ReadMe.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null},"funding":{"custom":["https://paypal.me/TechQuery","https://tech-query.me/image/TechQuery-Alipay.jpg"]}},"created_at":"2021-03-30T18:52:17.000Z","updated_at":"2025-03-04T10:39:57.000Z","dependencies_parsed_at":null,"dependency_job_id":"1d026390-2977-4853-a616-d3875ffe22ad","html_url":"https://github.com/idea2app/Koagger","commit_stats":{"total_commits":3,"total_committers":1,"mean_commits":3.0,"dds":0.0,"last_synced_commit":"31461bba99dc39e27acd9a08e2c408cac11a470c"},"previous_names":[],"tags_count":3,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/idea2app%2FKoagger","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/idea2app%2FKoagger/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/idea2app%2FKoagger/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/idea2app%2FKoagger/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/idea2app","download_url":"https://codeload.github.com/idea2app/Koagger/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243762227,"owners_count":20343972,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api","koa","middleware","mock","swagger","typescript"],"created_at":"2024-11-21T13:46:33.923Z","updated_at":"2026-02-12T08:02:43.763Z","avatar_url":"https://github.com/idea2app.png","language":"TypeScript","funding_links":["https://paypal.me/TechQuery","https://tech-query.me/image/TechQuery-Alipay.jpg"],"categories":[],"sub_categories":[],"readme":"# Koagger\n\nA [Koa][1] middleware provides [Swagger][2] API document \u0026 **Mock API** for [routing-controllers][3] framework.\n\n[![NPM Dependency](https://img.shields.io/librariesio/github/idea2app/Koagger.svg)][4]\n[![CI \u0026 CD](https://github.com/idea2app/Koagger/actions/workflows/main.yml/badge.svg)][5]\n\n[![NPM](https://nodei.co/npm/koagger.png?downloads=true\u0026downloadRank=true\u0026stars=true)][6]\n\n## Usage\n\n```shell\nnpm install koagger\n```\n\n`index.ts`\n\n```typescript\nimport Koa from 'koa';\nimport { useKoaServer } from 'routing-controllers';\nimport { createAPI } from 'koagger';\n\nimport controllers from './controller';\n\nconst { PORT = 8080 } = process.env,\n    { swagger, mocker, router } = createAPI({ controllers, mock: true });\n\nconst HOST = `http://localhost:${PORT}`,\n    app = new Koa().use(swagger()).use(mocker());\n\nuseKoaServer(app, router);\n\napp.listen(PORT, () =\u003e\n    console.log(`\nHTTP served at ${HOST}\nSwagger API served at ${HOST}/docs/\nMock API served at ${HOST}/mock/\n`)\n);\n```\n\n## Development\n\n```shell\ngit clone https://github.com/idea2app/Koagger.git ~/Desktop/Koagger\n\ncd ~/Desktop/Koagger\n\npnpm i\n\npnpm dev  # or just press F5 key in VS Code\n```\n\n## Cases\n\n- [NodeTS-LeanCloud][7] scaffold\n- [REST-Node-ts][8] scaffold\n\n[1]: https://koajs.com/\n[2]: https://swagger.io/\n[3]: https://github.com/typestack/routing-controllers\n[4]: https://libraries.io/npm/koagger\n[5]: https://github.com/idea2app/Koagger/actions/workflows/main.yml\n[6]: https://nodei.co/npm/koagger/\n[7]: https://github.com/idea2app/NodeTS-LeanCloud\n[8]: https://github.com/idea2app/REST-Node-ts\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fidea2app%2Fkoagger","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fidea2app%2Fkoagger","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fidea2app%2Fkoagger/lists"}