nitrostack 1.0.83 → 1.0.85
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 +1 -1
- package/README.md +42 -137
- package/assets/gif/nitrocli.gif +0 -0
- package/assets/gif/nitrostudio-chat.gif +0 -0
- package/assets/gif/nitrostudio-main.gif +0 -0
- package/assets/gif/nitrostudio-testing.gif +0 -0
- package/package.json +15 -50
- package/dist/auth/__tests__/api-key.test.d.ts +0 -2
- package/dist/auth/__tests__/api-key.test.d.ts.map +0 -1
- package/dist/auth/__tests__/api-key.test.js +0 -156
- package/dist/auth/__tests__/api-key.test.js.map +0 -1
- package/dist/auth/__tests__/client.test.d.ts +0 -2
- package/dist/auth/__tests__/client.test.d.ts.map +0 -1
- package/dist/auth/__tests__/client.test.js +0 -173
- package/dist/auth/__tests__/client.test.js.map +0 -1
- package/dist/auth/__tests__/middleware.test.d.ts +0 -2
- package/dist/auth/__tests__/middleware.test.d.ts.map +0 -1
- package/dist/auth/__tests__/middleware.test.js +0 -232
- package/dist/auth/__tests__/middleware.test.js.map +0 -1
- package/dist/auth/__tests__/pkce.test.d.ts +0 -2
- package/dist/auth/__tests__/pkce.test.d.ts.map +0 -1
- package/dist/auth/__tests__/pkce.test.js +0 -110
- package/dist/auth/__tests__/pkce.test.js.map +0 -1
- package/dist/auth/__tests__/quick-setup.test.d.ts +0 -2
- package/dist/auth/__tests__/quick-setup.test.d.ts.map +0 -1
- package/dist/auth/__tests__/quick-setup.test.js +0 -95
- package/dist/auth/__tests__/quick-setup.test.js.map +0 -1
- package/dist/auth/__tests__/secure-secret.test.d.ts +0 -2
- package/dist/auth/__tests__/secure-secret.test.d.ts.map +0 -1
- package/dist/auth/__tests__/secure-secret.test.js +0 -104
- package/dist/auth/__tests__/secure-secret.test.js.map +0 -1
- package/dist/auth/__tests__/server-integration.test.d.ts +0 -2
- package/dist/auth/__tests__/server-integration.test.d.ts.map +0 -1
- package/dist/auth/__tests__/server-integration.test.js +0 -156
- package/dist/auth/__tests__/server-integration.test.js.map +0 -1
- package/dist/auth/__tests__/server-metadata.test.d.ts +0 -2
- package/dist/auth/__tests__/server-metadata.test.d.ts.map +0 -1
- package/dist/auth/__tests__/server-metadata.test.js +0 -72
- package/dist/auth/__tests__/server-metadata.test.js.map +0 -1
- package/dist/auth/__tests__/simple-jwt.test.d.ts +0 -2
- package/dist/auth/__tests__/simple-jwt.test.d.ts.map +0 -1
- package/dist/auth/__tests__/simple-jwt.test.js +0 -125
- package/dist/auth/__tests__/simple-jwt.test.js.map +0 -1
- package/dist/auth/__tests__/token-store.test.d.ts +0 -2
- package/dist/auth/__tests__/token-store.test.d.ts.map +0 -1
- package/dist/auth/__tests__/token-store.test.js +0 -167
- package/dist/auth/__tests__/token-store.test.js.map +0 -1
- package/dist/auth/__tests__/token-validation.test.d.ts +0 -2
- package/dist/auth/__tests__/token-validation.test.d.ts.map +0 -1
- package/dist/auth/__tests__/token-validation.test.js +0 -219
- package/dist/auth/__tests__/token-validation.test.js.map +0 -1
- package/dist/auth/api-key.d.ts +0 -118
- package/dist/auth/api-key.d.ts.map +0 -1
- package/dist/auth/api-key.js +0 -168
- package/dist/auth/api-key.js.map +0 -1
- package/dist/auth/client.d.ts +0 -151
- package/dist/auth/client.d.ts.map +0 -1
- package/dist/auth/client.js +0 -330
- package/dist/auth/client.js.map +0 -1
- package/dist/auth/index.d.ts +0 -31
- package/dist/auth/index.d.ts.map +0 -1
- package/dist/auth/index.js +0 -46
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/middleware.d.ts +0 -95
- package/dist/auth/middleware.d.ts.map +0 -1
- package/dist/auth/middleware.js +0 -260
- package/dist/auth/middleware.js.map +0 -1
- package/dist/auth/pkce.d.ts +0 -53
- package/dist/auth/pkce.d.ts.map +0 -1
- package/dist/auth/pkce.js +0 -105
- package/dist/auth/pkce.js.map +0 -1
- package/dist/auth/quick-setup.d.ts +0 -94
- package/dist/auth/quick-setup.d.ts.map +0 -1
- package/dist/auth/quick-setup.js +0 -210
- package/dist/auth/quick-setup.js.map +0 -1
- package/dist/auth/secure-secret.d.ts +0 -136
- package/dist/auth/secure-secret.d.ts.map +0 -1
- package/dist/auth/secure-secret.js +0 -182
- package/dist/auth/secure-secret.js.map +0 -1
- package/dist/auth/server-integration.d.ts +0 -97
- package/dist/auth/server-integration.d.ts.map +0 -1
- package/dist/auth/server-integration.js +0 -182
- package/dist/auth/server-integration.js.map +0 -1
- package/dist/auth/server-metadata.d.ts +0 -51
- package/dist/auth/server-metadata.d.ts.map +0 -1
- package/dist/auth/server-metadata.js +0 -106
- package/dist/auth/server-metadata.js.map +0 -1
- package/dist/auth/simple-jwt.d.ts +0 -174
- package/dist/auth/simple-jwt.d.ts.map +0 -1
- package/dist/auth/simple-jwt.js +0 -162
- package/dist/auth/simple-jwt.js.map +0 -1
- package/dist/auth/token-store.d.ts +0 -104
- package/dist/auth/token-store.d.ts.map +0 -1
- package/dist/auth/token-store.js +0 -205
- package/dist/auth/token-store.js.map +0 -1
- package/dist/auth/token-validation.d.ts +0 -59
- package/dist/auth/token-validation.d.ts.map +0 -1
- package/dist/auth/token-validation.js +0 -241
- package/dist/auth/token-validation.js.map +0 -1
- package/dist/auth/types.d.ts +0 -215
- package/dist/auth/types.d.ts.map +0 -1
- package/dist/auth/types.js +0 -6
- package/dist/auth/types.js.map +0 -1
- package/dist/core/__tests__/app-decorator.test.d.ts +0 -2
- package/dist/core/__tests__/app-decorator.test.d.ts.map +0 -1
- package/dist/core/__tests__/app-decorator.test.js +0 -100
- package/dist/core/__tests__/app-decorator.test.js.map +0 -1
- package/dist/core/__tests__/app-factory.extended.test.d.ts +0 -2
- package/dist/core/__tests__/app-factory.extended.test.d.ts.map +0 -1
- package/dist/core/__tests__/app-factory.extended.test.js +0 -244
- package/dist/core/__tests__/app-factory.extended.test.js.map +0 -1
- package/dist/core/__tests__/builders.test.d.ts +0 -2
- package/dist/core/__tests__/builders.test.d.ts.map +0 -1
- package/dist/core/__tests__/builders.test.js +0 -98
- package/dist/core/__tests__/builders.test.js.map +0 -1
- package/dist/core/__tests__/component.test.d.ts +0 -2
- package/dist/core/__tests__/component.test.d.ts.map +0 -1
- package/dist/core/__tests__/component.test.js +0 -151
- package/dist/core/__tests__/component.test.js.map +0 -1
- package/dist/core/__tests__/config-module.test.d.ts +0 -2
- package/dist/core/__tests__/config-module.test.d.ts.map +0 -1
- package/dist/core/__tests__/config-module.test.js +0 -90
- package/dist/core/__tests__/config-module.test.js.map +0 -1
- package/dist/core/__tests__/core-modules.test.d.ts +0 -2
- package/dist/core/__tests__/core-modules.test.d.ts.map +0 -1
- package/dist/core/__tests__/core-modules.test.js +0 -36
- package/dist/core/__tests__/core-modules.test.js.map +0 -1
- package/dist/core/__tests__/di.test.d.ts +0 -2
- package/dist/core/__tests__/di.test.d.ts.map +0 -1
- package/dist/core/__tests__/di.test.js +0 -101
- package/dist/core/__tests__/di.test.js.map +0 -1
- package/dist/core/__tests__/errors.test.d.ts +0 -2
- package/dist/core/__tests__/errors.test.d.ts.map +0 -1
- package/dist/core/__tests__/errors.test.js +0 -109
- package/dist/core/__tests__/errors.test.js.map +0 -1
- package/dist/core/__tests__/final.blitz.test.d.ts +0 -2
- package/dist/core/__tests__/final.blitz.test.d.ts.map +0 -1
- package/dist/core/__tests__/final.blitz.test.js +0 -327
- package/dist/core/__tests__/final.blitz.test.js.map +0 -1
- package/dist/core/__tests__/jwt-module.test.d.ts +0 -2
- package/dist/core/__tests__/jwt-module.test.d.ts.map +0 -1
- package/dist/core/__tests__/jwt-module.test.js +0 -60
- package/dist/core/__tests__/jwt-module.test.js.map +0 -1
- package/dist/core/__tests__/logger.test.d.ts +0 -2
- package/dist/core/__tests__/logger.test.d.ts.map +0 -1
- package/dist/core/__tests__/logger.test.js +0 -83
- package/dist/core/__tests__/logger.test.js.map +0 -1
- package/dist/core/__tests__/models.test.d.ts +0 -2
- package/dist/core/__tests__/models.test.d.ts.map +0 -1
- package/dist/core/__tests__/models.test.js +0 -142
- package/dist/core/__tests__/models.test.js.map +0 -1
- package/dist/core/__tests__/module.test.d.ts +0 -2
- package/dist/core/__tests__/module.test.d.ts.map +0 -1
- package/dist/core/__tests__/module.test.js +0 -58
- package/dist/core/__tests__/module.test.js.map +0 -1
- package/dist/core/__tests__/oauth-module.test.d.ts +0 -2
- package/dist/core/__tests__/oauth-module.test.d.ts.map +0 -1
- package/dist/core/__tests__/oauth-module.test.js +0 -168
- package/dist/core/__tests__/oauth-module.test.js.map +0 -1
- package/dist/core/__tests__/oauth.extended.test.d.ts +0 -2
- package/dist/core/__tests__/oauth.extended.test.d.ts.map +0 -1
- package/dist/core/__tests__/oauth.extended.test.js +0 -146
- package/dist/core/__tests__/oauth.extended.test.js.map +0 -1
- package/dist/core/__tests__/prompt.test.d.ts +0 -2
- package/dist/core/__tests__/prompt.test.d.ts.map +0 -1
- package/dist/core/__tests__/prompt.test.js +0 -126
- package/dist/core/__tests__/prompt.test.js.map +0 -1
- package/dist/core/__tests__/resource.test.d.ts +0 -2
- package/dist/core/__tests__/resource.test.d.ts.map +0 -1
- package/dist/core/__tests__/resource.test.js +0 -173
- package/dist/core/__tests__/resource.test.js.map +0 -1
- package/dist/core/__tests__/server.extended.test.d.ts +0 -2
- package/dist/core/__tests__/server.extended.test.d.ts.map +0 -1
- package/dist/core/__tests__/server.extended.test.js +0 -242
- package/dist/core/__tests__/server.extended.test.js.map +0 -1
- package/dist/core/__tests__/server.test.d.ts +0 -2
- package/dist/core/__tests__/server.test.d.ts.map +0 -1
- package/dist/core/__tests__/server.test.js +0 -120
- package/dist/core/__tests__/server.test.js.map +0 -1
- package/dist/core/__tests__/transport.http.test.d.ts +0 -2
- package/dist/core/__tests__/transport.http.test.d.ts.map +0 -1
- package/dist/core/__tests__/transport.http.test.js +0 -119
- package/dist/core/__tests__/transport.http.test.js.map +0 -1
- package/dist/core/__tests__/transport.streamable.test.d.ts +0 -2
- package/dist/core/__tests__/transport.streamable.test.d.ts.map +0 -1
- package/dist/core/__tests__/transport.streamable.test.js +0 -168
- package/dist/core/__tests__/transport.streamable.test.js.map +0 -1
- package/dist/core/__tests__/transports.test.d.ts +0 -2
- package/dist/core/__tests__/transports.test.d.ts.map +0 -1
- package/dist/core/__tests__/transports.test.js +0 -12
- package/dist/core/__tests__/transports.test.js.map +0 -1
- package/dist/core/apikey-module.d.ts +0 -69
- package/dist/core/apikey-module.d.ts.map +0 -1
- package/dist/core/apikey-module.js +0 -114
- package/dist/core/apikey-module.js.map +0 -1
- package/dist/core/app-decorator.d.ts +0 -59
- package/dist/core/app-decorator.d.ts.map +0 -1
- package/dist/core/app-decorator.js +0 -322
- package/dist/core/app-decorator.js.map +0 -1
- package/dist/core/builders.d.ts +0 -50
- package/dist/core/builders.d.ts.map +0 -1
- package/dist/core/builders.js +0 -139
- package/dist/core/builders.js.map +0 -1
- package/dist/core/component.d.ts +0 -111
- package/dist/core/component.d.ts.map +0 -1
- package/dist/core/component.js +0 -228
- package/dist/core/component.js.map +0 -1
- package/dist/core/config-module.d.ts +0 -62
- package/dist/core/config-module.d.ts.map +0 -1
- package/dist/core/config-module.js +0 -94
- package/dist/core/config-module.js.map +0 -1
- package/dist/core/decorators/__tests__/decorators.test.d.ts +0 -2
- package/dist/core/decorators/__tests__/decorators.test.d.ts.map +0 -1
- package/dist/core/decorators/__tests__/decorators.test.js +0 -103
- package/dist/core/decorators/__tests__/decorators.test.js.map +0 -1
- package/dist/core/decorators/__tests__/extended-decorators.test.d.ts +0 -2
- package/dist/core/decorators/__tests__/extended-decorators.test.d.ts.map +0 -1
- package/dist/core/decorators/__tests__/extended-decorators.test.js +0 -194
- package/dist/core/decorators/__tests__/extended-decorators.test.js.map +0 -1
- package/dist/core/decorators/__tests__/health-check.test.d.ts +0 -2
- package/dist/core/decorators/__tests__/health-check.test.d.ts.map +0 -1
- package/dist/core/decorators/__tests__/health-check.test.js +0 -119
- package/dist/core/decorators/__tests__/health-check.test.js.map +0 -1
- package/dist/core/decorators/cache.decorator.d.ts +0 -61
- package/dist/core/decorators/cache.decorator.d.ts.map +0 -1
- package/dist/core/decorators/cache.decorator.js +0 -115
- package/dist/core/decorators/cache.decorator.js.map +0 -1
- package/dist/core/decorators/health-check.decorator.d.ts +0 -80
- package/dist/core/decorators/health-check.decorator.d.ts.map +0 -1
- package/dist/core/decorators/health-check.decorator.js +0 -153
- package/dist/core/decorators/health-check.decorator.js.map +0 -1
- package/dist/core/decorators/rate-limit.decorator.d.ts +0 -63
- package/dist/core/decorators/rate-limit.decorator.d.ts.map +0 -1
- package/dist/core/decorators/rate-limit.decorator.js +0 -129
- package/dist/core/decorators/rate-limit.decorator.js.map +0 -1
- package/dist/core/decorators.d.ts +0 -190
- package/dist/core/decorators.d.ts.map +0 -1
- package/dist/core/decorators.js +0 -170
- package/dist/core/decorators.js.map +0 -1
- package/dist/core/di/__tests__/container.test.d.ts +0 -2
- package/dist/core/di/__tests__/container.test.d.ts.map +0 -1
- package/dist/core/di/__tests__/container.test.js +0 -88
- package/dist/core/di/__tests__/container.test.js.map +0 -1
- package/dist/core/di/container.d.ts +0 -64
- package/dist/core/di/container.d.ts.map +0 -1
- package/dist/core/di/container.js +0 -105
- package/dist/core/di/container.js.map +0 -1
- package/dist/core/di/injectable.decorator.d.ts +0 -62
- package/dist/core/di/injectable.decorator.d.ts.map +0 -1
- package/dist/core/di/injectable.decorator.js +0 -66
- package/dist/core/di/injectable.decorator.js.map +0 -1
- package/dist/core/di/metadata-shim.d.ts +0 -31
- package/dist/core/di/metadata-shim.d.ts.map +0 -1
- package/dist/core/di/metadata-shim.js +0 -181
- package/dist/core/di/metadata-shim.js.map +0 -1
- package/dist/core/errors.d.ts +0 -54
- package/dist/core/errors.d.ts.map +0 -1
- package/dist/core/errors.js +0 -87
- package/dist/core/errors.js.map +0 -1
- package/dist/core/events/__tests__/events.test.d.ts +0 -2
- package/dist/core/events/__tests__/events.test.d.ts.map +0 -1
- package/dist/core/events/__tests__/events.test.js +0 -177
- package/dist/core/events/__tests__/events.test.js.map +0 -1
- package/dist/core/events/event-emitter.d.ts +0 -50
- package/dist/core/events/event-emitter.d.ts.map +0 -1
- package/dist/core/events/event-emitter.js +0 -94
- package/dist/core/events/event-emitter.js.map +0 -1
- package/dist/core/events/event.decorator.d.ts +0 -48
- package/dist/core/events/event.decorator.d.ts.map +0 -1
- package/dist/core/events/event.decorator.js +0 -72
- package/dist/core/events/event.decorator.js.map +0 -1
- package/dist/core/events/log-emitter.d.ts +0 -14
- package/dist/core/events/log-emitter.d.ts.map +0 -1
- package/dist/core/events/log-emitter.js +0 -20
- package/dist/core/events/log-emitter.js.map +0 -1
- package/dist/core/filters/__tests__/filters.test.d.ts +0 -2
- package/dist/core/filters/__tests__/filters.test.d.ts.map +0 -1
- package/dist/core/filters/__tests__/filters.test.js +0 -72
- package/dist/core/filters/__tests__/filters.test.js.map +0 -1
- package/dist/core/filters/exception-filter.decorator.d.ts +0 -40
- package/dist/core/filters/exception-filter.decorator.d.ts.map +0 -1
- package/dist/core/filters/exception-filter.decorator.js +0 -54
- package/dist/core/filters/exception-filter.decorator.js.map +0 -1
- package/dist/core/filters/exception-filter.interface.d.ts +0 -39
- package/dist/core/filters/exception-filter.interface.d.ts.map +0 -1
- package/dist/core/filters/exception-filter.interface.js +0 -2
- package/dist/core/filters/exception-filter.interface.js.map +0 -1
- package/dist/core/guards/__tests__/guards.test.d.ts +0 -2
- package/dist/core/guards/__tests__/guards.test.d.ts.map +0 -1
- package/dist/core/guards/__tests__/guards.test.js +0 -55
- package/dist/core/guards/__tests__/guards.test.js.map +0 -1
- package/dist/core/guards/apikey.guard.d.ts +0 -22
- package/dist/core/guards/apikey.guard.d.ts.map +0 -1
- package/dist/core/guards/apikey.guard.js +0 -11
- package/dist/core/guards/apikey.guard.js.map +0 -1
- package/dist/core/guards/guard.interface.d.ts +0 -18
- package/dist/core/guards/guard.interface.d.ts.map +0 -1
- package/dist/core/guards/guard.interface.js +0 -2
- package/dist/core/guards/guard.interface.js.map +0 -1
- package/dist/core/guards/jwt.guard.d.ts +0 -18
- package/dist/core/guards/jwt.guard.d.ts.map +0 -1
- package/dist/core/guards/jwt.guard.js +0 -2
- package/dist/core/guards/jwt.guard.js.map +0 -1
- package/dist/core/guards/oauth.guard.d.ts +0 -35
- package/dist/core/guards/oauth.guard.d.ts.map +0 -1
- package/dist/core/guards/oauth.guard.js +0 -2
- package/dist/core/guards/oauth.guard.js.map +0 -1
- package/dist/core/guards/use-guards.decorator.d.ts +0 -25
- package/dist/core/guards/use-guards.decorator.d.ts.map +0 -1
- package/dist/core/guards/use-guards.decorator.js +0 -32
- package/dist/core/guards/use-guards.decorator.js.map +0 -1
- package/dist/core/health/__tests__/health.test.d.ts +0 -2
- package/dist/core/health/__tests__/health.test.d.ts.map +0 -1
- package/dist/core/health/__tests__/health.test.js +0 -31
- package/dist/core/health/__tests__/health.test.js.map +0 -1
- package/dist/core/health/health-checks.resource.d.ts +0 -14
- package/dist/core/health/health-checks.resource.d.ts.map +0 -1
- package/dist/core/health/health-checks.resource.js +0 -29
- package/dist/core/health/health-checks.resource.js.map +0 -1
- package/dist/core/index.d.ts +0 -57
- package/dist/core/index.d.ts.map +0 -1
- package/dist/core/index.js +0 -59
- package/dist/core/index.js.map +0 -1
- package/dist/core/interceptors/__tests__/interceptors.test.d.ts +0 -2
- package/dist/core/interceptors/__tests__/interceptors.test.d.ts.map +0 -1
- package/dist/core/interceptors/__tests__/interceptors.test.js +0 -52
- package/dist/core/interceptors/__tests__/interceptors.test.js.map +0 -1
- package/dist/core/interceptors/interceptor.decorator.d.ts +0 -37
- package/dist/core/interceptors/interceptor.decorator.d.ts.map +0 -1
- package/dist/core/interceptors/interceptor.decorator.js +0 -51
- package/dist/core/interceptors/interceptor.decorator.js.map +0 -1
- package/dist/core/interceptors/interceptor.interface.d.ts +0 -31
- package/dist/core/interceptors/interceptor.interface.d.ts.map +0 -1
- package/dist/core/interceptors/interceptor.interface.js +0 -2
- package/dist/core/interceptors/interceptor.interface.js.map +0 -1
- package/dist/core/jwt-module.d.ts +0 -51
- package/dist/core/jwt-module.d.ts.map +0 -1
- package/dist/core/jwt-module.js +0 -52
- package/dist/core/jwt-module.js.map +0 -1
- package/dist/core/logger.d.ts +0 -18
- package/dist/core/logger.d.ts.map +0 -1
- package/dist/core/logger.js +0 -53
- package/dist/core/logger.js.map +0 -1
- package/dist/core/middleware/__tests__/middleware.test.d.ts +0 -2
- package/dist/core/middleware/__tests__/middleware.test.d.ts.map +0 -1
- package/dist/core/middleware/__tests__/middleware.test.js +0 -105
- package/dist/core/middleware/__tests__/middleware.test.js.map +0 -1
- package/dist/core/middleware/middleware.decorator.d.ts +0 -39
- package/dist/core/middleware/middleware.decorator.d.ts.map +0 -1
- package/dist/core/middleware/middleware.decorator.js +0 -53
- package/dist/core/middleware/middleware.decorator.js.map +0 -1
- package/dist/core/middleware/middleware.interface.d.ts +0 -29
- package/dist/core/middleware/middleware.interface.d.ts.map +0 -1
- package/dist/core/middleware/middleware.interface.js +0 -2
- package/dist/core/middleware/middleware.interface.js.map +0 -1
- package/dist/core/module.d.ts +0 -93
- package/dist/core/module.d.ts.map +0 -1
- package/dist/core/module.js +0 -87
- package/dist/core/module.js.map +0 -1
- package/dist/core/oauth-module.d.ts +0 -123
- package/dist/core/oauth-module.d.ts.map +0 -1
- package/dist/core/oauth-module.js +0 -324
- package/dist/core/oauth-module.js.map +0 -1
- package/dist/core/pipes/__tests__/pipes.test.d.ts +0 -2
- package/dist/core/pipes/__tests__/pipes.test.d.ts.map +0 -1
- package/dist/core/pipes/__tests__/pipes.test.js +0 -164
- package/dist/core/pipes/__tests__/pipes.test.js.map +0 -1
- package/dist/core/pipes/pipe.decorator.d.ts +0 -64
- package/dist/core/pipes/pipe.decorator.d.ts.map +0 -1
- package/dist/core/pipes/pipe.decorator.js +0 -85
- package/dist/core/pipes/pipe.decorator.js.map +0 -1
- package/dist/core/pipes/pipe.interface.d.ts +0 -41
- package/dist/core/pipes/pipe.interface.d.ts.map +0 -1
- package/dist/core/pipes/pipe.interface.js +0 -2
- package/dist/core/pipes/pipe.interface.js.map +0 -1
- package/dist/core/prompt.d.ts +0 -46
- package/dist/core/prompt.d.ts.map +0 -1
- package/dist/core/prompt.js +0 -76
- package/dist/core/prompt.js.map +0 -1
- package/dist/core/resource.d.ts +0 -47
- package/dist/core/resource.d.ts.map +0 -1
- package/dist/core/resource.js +0 -90
- package/dist/core/resource.js.map +0 -1
- package/dist/core/server.d.ts +0 -129
- package/dist/core/server.d.ts.map +0 -1
- package/dist/core/server.js +0 -617
- package/dist/core/server.js.map +0 -1
- package/dist/core/tool.d.ts +0 -108
- package/dist/core/tool.d.ts.map +0 -1
- package/dist/core/tool.js +0 -241
- package/dist/core/tool.js.map +0 -1
- package/dist/core/transports/__tests__/transports.test.d.ts +0 -2
- package/dist/core/transports/__tests__/transports.test.d.ts.map +0 -1
- package/dist/core/transports/__tests__/transports.test.js +0 -249
- package/dist/core/transports/__tests__/transports.test.js.map +0 -1
- package/dist/core/transports/discovery-http-server.d.ts +0 -19
- package/dist/core/transports/discovery-http-server.d.ts.map +0 -1
- package/dist/core/transports/discovery-http-server.js +0 -54
- package/dist/core/transports/discovery-http-server.js.map +0 -1
- package/dist/core/transports/http-server.d.ts +0 -108
- package/dist/core/transports/http-server.d.ts.map +0 -1
- package/dist/core/transports/http-server.js +0 -293
- package/dist/core/transports/http-server.js.map +0 -1
- package/dist/core/transports/streamable-http.d.ts +0 -177
- package/dist/core/transports/streamable-http.d.ts.map +0 -1
- package/dist/core/transports/streamable-http.js +0 -1287
- package/dist/core/transports/streamable-http.js.map +0 -1
- package/dist/core/types.d.ts +0 -195
- package/dist/core/types.d.ts.map +0 -1
- package/dist/core/types.js +0 -2
- package/dist/core/types.js.map +0 -1
- package/dist/core/widgets/__tests__/registry.test.d.ts +0 -2
- package/dist/core/widgets/__tests__/registry.test.d.ts.map +0 -1
- package/dist/core/widgets/__tests__/registry.test.js +0 -69
- package/dist/core/widgets/__tests__/registry.test.js.map +0 -1
- package/dist/core/widgets/widget-examples.resource.d.ts +0 -17
- package/dist/core/widgets/widget-examples.resource.d.ts.map +0 -1
- package/dist/core/widgets/widget-examples.resource.js +0 -28
- package/dist/core/widgets/widget-examples.resource.js.map +0 -1
- package/dist/core/widgets/widget-registry.d.ts +0 -56
- package/dist/core/widgets/widget-registry.d.ts.map +0 -1
- package/dist/core/widgets/widget-registry.js +0 -75
- package/dist/core/widgets/widget-registry.js.map +0 -1
- package/dist/testing/__tests__/testing.test.d.ts +0 -2
- package/dist/testing/__tests__/testing.test.d.ts.map +0 -1
- package/dist/testing/__tests__/testing.test.js +0 -167
- package/dist/testing/__tests__/testing.test.js.map +0 -1
- package/dist/testing/index.d.ts +0 -103
- package/dist/testing/index.d.ts.map +0 -1
- package/dist/testing/index.js +0 -161
- package/dist/testing/index.js.map +0 -1
- package/dist/ui-next/__tests__/ui-next.test.d.ts +0 -2
- package/dist/ui-next/__tests__/ui-next.test.d.ts.map +0 -1
- package/dist/ui-next/__tests__/ui-next.test.js +0 -74
- package/dist/ui-next/__tests__/ui-next.test.js.map +0 -1
- package/dist/ui-next/index.d.ts +0 -31
- package/dist/ui-next/index.d.ts.map +0 -1
- package/dist/ui-next/index.js +0 -687
- package/dist/ui-next/index.js.map +0 -1
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
-
};
|
|
7
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
-
};
|
|
10
|
-
import { jest, describe, it, expect, beforeEach } from '@jest/globals';
|
|
11
|
-
import 'reflect-metadata';
|
|
12
|
-
// Cache Decorator Tests
|
|
13
|
-
import { Cache, getCacheMetadata, clearCache } from '../cache.decorator.js';
|
|
14
|
-
describe('Cache Decorator', () => {
|
|
15
|
-
beforeEach(async () => {
|
|
16
|
-
await clearCache();
|
|
17
|
-
});
|
|
18
|
-
it('should register cache metadata', () => {
|
|
19
|
-
class TestClass {
|
|
20
|
-
method() { }
|
|
21
|
-
}
|
|
22
|
-
__decorate([
|
|
23
|
-
Cache({ ttl: 60 }),
|
|
24
|
-
__metadata("design:type", Function),
|
|
25
|
-
__metadata("design:paramtypes", []),
|
|
26
|
-
__metadata("design:returntype", void 0)
|
|
27
|
-
], TestClass.prototype, "method", null);
|
|
28
|
-
const instance = new TestClass();
|
|
29
|
-
const metadata = getCacheMetadata(instance, 'method');
|
|
30
|
-
expect(metadata).toEqual(expect.objectContaining({ ttl: 60 }));
|
|
31
|
-
});
|
|
32
|
-
it('should cache method results', async () => {
|
|
33
|
-
const mockMethod = jest.fn((x) => x * 2);
|
|
34
|
-
class TestClass {
|
|
35
|
-
method(x) {
|
|
36
|
-
return mockMethod(x);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
__decorate([
|
|
40
|
-
Cache({ ttl: 100 }),
|
|
41
|
-
__metadata("design:type", Function),
|
|
42
|
-
__metadata("design:paramtypes", [Number]),
|
|
43
|
-
__metadata("design:returntype", void 0)
|
|
44
|
-
], TestClass.prototype, "method", null);
|
|
45
|
-
const instance = new TestClass();
|
|
46
|
-
// First call
|
|
47
|
-
const result1 = await instance.method(2);
|
|
48
|
-
expect(result1).toBe(4);
|
|
49
|
-
expect(mockMethod).toHaveBeenCalledTimes(1);
|
|
50
|
-
// Second call - should be cached
|
|
51
|
-
const result2 = await instance.method(2);
|
|
52
|
-
expect(result2).toBe(4);
|
|
53
|
-
expect(mockMethod).toHaveBeenCalledTimes(1);
|
|
54
|
-
// Different arg - should call method
|
|
55
|
-
const result3 = await instance.method(3);
|
|
56
|
-
expect(result3).toBe(6);
|
|
57
|
-
expect(mockMethod).toHaveBeenCalledTimes(2);
|
|
58
|
-
});
|
|
59
|
-
it('should respect TTL', async () => {
|
|
60
|
-
const mockMethod = jest.fn(() => 'value');
|
|
61
|
-
// Mock Date.now
|
|
62
|
-
const realNow = Date.now;
|
|
63
|
-
let currentTime = 1000;
|
|
64
|
-
Date.now = jest.fn(() => currentTime);
|
|
65
|
-
class TestClass {
|
|
66
|
-
method() { return mockMethod(); }
|
|
67
|
-
}
|
|
68
|
-
__decorate([
|
|
69
|
-
Cache({ ttl: 1 }) // 1 second TTL
|
|
70
|
-
,
|
|
71
|
-
__metadata("design:type", Function),
|
|
72
|
-
__metadata("design:paramtypes", []),
|
|
73
|
-
__metadata("design:returntype", void 0)
|
|
74
|
-
], TestClass.prototype, "method", null);
|
|
75
|
-
const instance = new TestClass();
|
|
76
|
-
await instance.method();
|
|
77
|
-
expect(mockMethod).toHaveBeenCalledTimes(1);
|
|
78
|
-
// Advance time past TTL
|
|
79
|
-
currentTime += 2000;
|
|
80
|
-
await instance.method();
|
|
81
|
-
expect(mockMethod).toHaveBeenCalledTimes(2);
|
|
82
|
-
// Cleanup
|
|
83
|
-
Date.now = realNow;
|
|
84
|
-
});
|
|
85
|
-
it('should generate keys using custom generator', async () => {
|
|
86
|
-
const mockMethod = jest.fn(() => 'k');
|
|
87
|
-
class TestClass {
|
|
88
|
-
method(i) { return mockMethod(); }
|
|
89
|
-
}
|
|
90
|
-
__decorate([
|
|
91
|
-
Cache({ ttl: 10, key: (i) => `key:${i}` }),
|
|
92
|
-
__metadata("design:type", Function),
|
|
93
|
-
__metadata("design:paramtypes", [Number]),
|
|
94
|
-
__metadata("design:returntype", void 0)
|
|
95
|
-
], TestClass.prototype, "method", null);
|
|
96
|
-
const instance = new TestClass();
|
|
97
|
-
await instance.method(1);
|
|
98
|
-
await instance.method(1);
|
|
99
|
-
expect(mockMethod).toHaveBeenCalledTimes(1);
|
|
100
|
-
});
|
|
101
|
-
});
|
|
102
|
-
// RateLimit Decorator Tests
|
|
103
|
-
import { RateLimit, getRateLimitMetadata, resetRateLimit } from '../rate-limit.decorator.js';
|
|
104
|
-
describe('RateLimit Decorator', () => {
|
|
105
|
-
beforeEach(() => {
|
|
106
|
-
// Reset storage manually if needed, but we used different types mostly
|
|
107
|
-
// The implementation uses a defaultStorage that is exported indirectly via resetRateLimit
|
|
108
|
-
});
|
|
109
|
-
it('should register rate limit metadata', () => {
|
|
110
|
-
class TestClass {
|
|
111
|
-
method() { }
|
|
112
|
-
}
|
|
113
|
-
__decorate([
|
|
114
|
-
RateLimit({ requests: 5, window: '1m' }),
|
|
115
|
-
__metadata("design:type", Function),
|
|
116
|
-
__metadata("design:paramtypes", []),
|
|
117
|
-
__metadata("design:returntype", void 0)
|
|
118
|
-
], TestClass.prototype, "method", null);
|
|
119
|
-
const instance = new TestClass();
|
|
120
|
-
const metadata = getRateLimitMetadata(instance, 'method');
|
|
121
|
-
expect(metadata).toEqual(expect.objectContaining({ requests: 5, window: '1m' }));
|
|
122
|
-
});
|
|
123
|
-
it('should enforce limits', async () => {
|
|
124
|
-
class TestClass {
|
|
125
|
-
method() { return 'ok'; }
|
|
126
|
-
}
|
|
127
|
-
__decorate([
|
|
128
|
-
RateLimit({ requests: 2, window: '1m' }),
|
|
129
|
-
__metadata("design:type", Function),
|
|
130
|
-
__metadata("design:paramtypes", []),
|
|
131
|
-
__metadata("design:returntype", void 0)
|
|
132
|
-
], TestClass.prototype, "method", null);
|
|
133
|
-
const instance = new TestClass();
|
|
134
|
-
// Reset purely for test isolation in case of shared state
|
|
135
|
-
await resetRateLimit('TestClass:method:anonymous');
|
|
136
|
-
await expect(instance.method()).resolves.toBe('ok');
|
|
137
|
-
await expect(instance.method()).resolves.toBe('ok');
|
|
138
|
-
await expect(instance.method()).rejects.toThrow(/Rate limit exceeded/);
|
|
139
|
-
});
|
|
140
|
-
it('should parse window strings', () => {
|
|
141
|
-
// Indirectly testing via success
|
|
142
|
-
class TestClass {
|
|
143
|
-
method() { return 'ok'; }
|
|
144
|
-
}
|
|
145
|
-
__decorate([
|
|
146
|
-
RateLimit({ requests: 1, window: '1s' }),
|
|
147
|
-
__metadata("design:type", Function),
|
|
148
|
-
__metadata("design:paramtypes", []),
|
|
149
|
-
__metadata("design:returntype", void 0)
|
|
150
|
-
], TestClass.prototype, "method", null);
|
|
151
|
-
expect(getRateLimitMetadata(new TestClass(), 'method').window).toBe('1s');
|
|
152
|
-
});
|
|
153
|
-
});
|
|
154
|
-
// HealthCheck Decorator Tests
|
|
155
|
-
import { HealthCheck, registerHealthCheck, getAllHealthChecks, getOverallHealth, isHealthCheck } from '../health-check.decorator.js';
|
|
156
|
-
describe('HealthCheck Decorator', () => {
|
|
157
|
-
// Need to clear the global registry? It's not exposed well for clearing.
|
|
158
|
-
// We can just use unique names for tests.
|
|
159
|
-
it('should mark class as health check', () => {
|
|
160
|
-
let MyCheck = class MyCheck {
|
|
161
|
-
check() { return { status: 'up' }; }
|
|
162
|
-
};
|
|
163
|
-
MyCheck = __decorate([
|
|
164
|
-
HealthCheck({ name: 'test-hc' })
|
|
165
|
-
], MyCheck);
|
|
166
|
-
expect(isHealthCheck(MyCheck)).toBe(true);
|
|
167
|
-
});
|
|
168
|
-
it('should register and execute checks', async () => {
|
|
169
|
-
const checker = {
|
|
170
|
-
check: jest.fn().mockResolvedValue({ status: 'up' })
|
|
171
|
-
};
|
|
172
|
-
registerHealthCheck(checker, { name: 'reg-check' });
|
|
173
|
-
const results = await getAllHealthChecks();
|
|
174
|
-
expect(results['reg-check'].status).toBe('up');
|
|
175
|
-
expect(checker.check).toHaveBeenCalled();
|
|
176
|
-
});
|
|
177
|
-
it('should report overall health', async () => {
|
|
178
|
-
// Override with known state
|
|
179
|
-
const good = { check: () => ({ status: 'up' }) };
|
|
180
|
-
const bad = { check: () => ({ status: 'down' }) };
|
|
181
|
-
registerHealthCheck(good, { name: 'good' });
|
|
182
|
-
// At this point, if 'bad' from previous test exists?
|
|
183
|
-
// The registry is global module state.
|
|
184
|
-
// We might need to be careful.
|
|
185
|
-
// registerHealthCheck just sets in map.
|
|
186
|
-
// Let's rely on map overwrite.
|
|
187
|
-
registerHealthCheck(bad, { name: 'bad' });
|
|
188
|
-
const health = await getOverallHealth();
|
|
189
|
-
expect(health.status).toBe('unhealthy');
|
|
190
|
-
expect(health.checks['good'].status).toBe('up');
|
|
191
|
-
expect(health.checks['bad'].status).toBe('down');
|
|
192
|
-
});
|
|
193
|
-
});
|
|
194
|
-
//# sourceMappingURL=extended-decorators.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"extended-decorators.test.js","sourceRoot":"","sources":["../../../../src/core/decorators/__tests__/extended-decorators.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"health-check.test.d.ts","sourceRoot":"","sources":["../../../../src/core/decorators/__tests__/health-check.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
-
};
|
|
7
|
-
import { jest, describe, it, expect, beforeEach } from '@jest/globals';
|
|
8
|
-
import { HealthCheck, registerHealthCheck, getAllHealthChecks, getHealthCheck, getOverallHealth, isHealthCheck, getHealthCheckMetadata } from '../health-check.decorator.js';
|
|
9
|
-
describe('Health Check Decorator', () => {
|
|
10
|
-
describe('@HealthCheck decorator', () => {
|
|
11
|
-
it('should mark class with metadata', () => {
|
|
12
|
-
let TestHealthCheck = class TestHealthCheck {
|
|
13
|
-
};
|
|
14
|
-
TestHealthCheck = __decorate([
|
|
15
|
-
HealthCheck({ name: 'test', description: 'Test check' })
|
|
16
|
-
], TestHealthCheck);
|
|
17
|
-
expect(isHealthCheck(TestHealthCheck)).toBe(true);
|
|
18
|
-
});
|
|
19
|
-
it('should store options in metadata', () => {
|
|
20
|
-
let MyHealthCheck = class MyHealthCheck {
|
|
21
|
-
};
|
|
22
|
-
MyHealthCheck = __decorate([
|
|
23
|
-
HealthCheck({ name: 'my-check', description: 'My description', interval: 30 })
|
|
24
|
-
], MyHealthCheck);
|
|
25
|
-
const metadata = getHealthCheckMetadata(MyHealthCheck);
|
|
26
|
-
expect(metadata).toBeDefined();
|
|
27
|
-
expect(metadata?.name).toBe('my-check');
|
|
28
|
-
expect(metadata?.description).toBe('My description');
|
|
29
|
-
expect(metadata?.interval).toBe(30);
|
|
30
|
-
});
|
|
31
|
-
});
|
|
32
|
-
describe('isHealthCheck', () => {
|
|
33
|
-
it('should return false for non-health-check classes', () => {
|
|
34
|
-
class RegularClass {
|
|
35
|
-
}
|
|
36
|
-
expect(isHealthCheck(RegularClass)).toBe(false);
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
describe('getHealthCheckMetadata', () => {
|
|
40
|
-
it('should return undefined for non-decorated classes', () => {
|
|
41
|
-
class RegularClass {
|
|
42
|
-
}
|
|
43
|
-
expect(getHealthCheckMetadata(RegularClass)).toBeUndefined();
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
describe('registerHealthCheck', () => {
|
|
47
|
-
beforeEach(() => {
|
|
48
|
-
jest.useFakeTimers();
|
|
49
|
-
});
|
|
50
|
-
it('should register a health check', async () => {
|
|
51
|
-
const checker = {
|
|
52
|
-
check: () => ({ status: 'up', message: 'Healthy' })
|
|
53
|
-
};
|
|
54
|
-
registerHealthCheck(checker, { name: 'registered-check' });
|
|
55
|
-
const result = await getHealthCheck('registered-check');
|
|
56
|
-
expect(result).toBeDefined();
|
|
57
|
-
expect(result?.status).toBe('up');
|
|
58
|
-
});
|
|
59
|
-
it('should run periodically if interval is set', () => {
|
|
60
|
-
const checkFn = jest.fn().mockReturnValue({ status: 'up' });
|
|
61
|
-
const checker = { check: checkFn };
|
|
62
|
-
registerHealthCheck(checker, { name: 'periodic-check', interval: 10 });
|
|
63
|
-
// Fast-forward time
|
|
64
|
-
jest.advanceTimersByTime(10000);
|
|
65
|
-
expect(checkFn).toHaveBeenCalled();
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
describe('getHealthCheck', () => {
|
|
69
|
-
it('should return null for unknown check', async () => {
|
|
70
|
-
const result = await getHealthCheck('unknown-check');
|
|
71
|
-
expect(result).toBeNull();
|
|
72
|
-
});
|
|
73
|
-
it('should handle check that throws error', async () => {
|
|
74
|
-
const checker = {
|
|
75
|
-
check: () => { throw new Error('Check failed'); }
|
|
76
|
-
};
|
|
77
|
-
registerHealthCheck(checker, { name: 'failing-check' });
|
|
78
|
-
const result = await getHealthCheck('failing-check');
|
|
79
|
-
expect(result?.status).toBe('down');
|
|
80
|
-
expect(result?.message).toBe('Health check failed');
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
describe('getAllHealthChecks', () => {
|
|
84
|
-
it('should return all registered health checks', async () => {
|
|
85
|
-
const checker1 = {
|
|
86
|
-
check: () => ({ status: 'up' })
|
|
87
|
-
};
|
|
88
|
-
const checker2 = {
|
|
89
|
-
check: () => ({ status: 'degraded' })
|
|
90
|
-
};
|
|
91
|
-
registerHealthCheck(checker1, { name: 'check1' });
|
|
92
|
-
registerHealthCheck(checker2, { name: 'check2' });
|
|
93
|
-
const results = await getAllHealthChecks();
|
|
94
|
-
expect(results['check1']).toBeDefined();
|
|
95
|
-
expect(results['check2']).toBeDefined();
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
describe('getOverallHealth', () => {
|
|
99
|
-
it('should return healthy when all checks are up', async () => {
|
|
100
|
-
const checker = {
|
|
101
|
-
check: () => ({ status: 'up' })
|
|
102
|
-
};
|
|
103
|
-
registerHealthCheck(checker, { name: 'healthy-check' });
|
|
104
|
-
const overall = await getOverallHealth();
|
|
105
|
-
// Note: Other checks may already be registered from previous tests
|
|
106
|
-
expect(['healthy', 'degraded', 'unhealthy']).toContain(overall.status);
|
|
107
|
-
expect(overall.checks).toBeDefined();
|
|
108
|
-
});
|
|
109
|
-
it('should return unhealthy when a check is down', async () => {
|
|
110
|
-
const checker = {
|
|
111
|
-
check: () => ({ status: 'down' })
|
|
112
|
-
};
|
|
113
|
-
registerHealthCheck(checker, { name: 'down-check' });
|
|
114
|
-
const overall = await getOverallHealth();
|
|
115
|
-
expect(overall.status).toBe('unhealthy');
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
//# sourceMappingURL=health-check.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"health-check.test.js","sourceRoot":"","sources":["../../../../src/core/decorators/__tests__/health-check.test.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EACH,WAAW,EACX,mBAAmB,EACnB,kBAAkB,EAClB,cAAc,EACd,gBAAgB,EAChB,aAAa,EACb,sBAAsB,EAGzB,MAAM,8BAA8B,CAAC;AAEtC,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;IACpC,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACpC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YAEvC,IAAM,eAAe,GAArB,MAAM,eAAe;aAAI,CAAA;YAAnB,eAAe;gBADpB,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,CAAC;eACnD,eAAe,CAAI;YAEzB,MAAM,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;YAExC,IAAM,aAAa,GAAnB,MAAM,aAAa;aAAI,CAAA;YAAjB,aAAa;gBADlB,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,gBAAgB,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;eACzE,aAAa,CAAI;YAEvB,MAAM,QAAQ,GAAG,sBAAsB,CAAC,aAAa,CAAC,CAAC;YACvD,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;YAC/B,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACxC,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACrD,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;QAC3B,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;YACxD,MAAM,YAAY;aAAI;YACtB,MAAM,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACpC,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;YACzD,MAAM,YAAY;aAAI;YACtB,MAAM,CAAC,sBAAsB,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC;QACjE,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;QACjC,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,aAAa,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;YAC5C,MAAM,OAAO,GAAyB;gBAClC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;aACtD,CAAC;YAEF,mBAAmB,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAC;YAE3D,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,kBAAkB,CAAC,CAAC;YACxD,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;YAC7B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;YAClD,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;YAC5D,MAAM,OAAO,GAAyB,EAAE,KAAK,EAAE,OAAc,EAAE,CAAC;YAEhE,mBAAmB,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;YAEvE,oBAAoB;YACpB,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;YAEhC,MAAM,CAAC,OAAO,CAAC,CAAC,gBAAgB,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC5B,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;YAClD,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,eAAe,CAAC,CAAC;YACrD,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;YACnD,MAAM,OAAO,GAAyB;gBAClC,KAAK,EAAE,GAAG,EAAE,GAAG,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;aACpD,CAAC;YAEF,mBAAmB,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;YAExD,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,eAAe,CAAC,CAAC;YACrD,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACpC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAChC,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;YACxD,MAAM,QAAQ,GAAyB;gBACnC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;aAClC,CAAC;YACF,MAAM,QAAQ,GAAyB;gBACnC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;aACxC,CAAC;YAEF,mBAAmB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;YAClD,mBAAmB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;YAElD,MAAM,OAAO,GAAG,MAAM,kBAAkB,EAAE,CAAC;YAC3C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;YACxC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5C,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;YAC1D,MAAM,OAAO,GAAyB;gBAClC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;aAClC,CAAC;YAEF,mBAAmB,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;YAExD,MAAM,OAAO,GAAG,MAAM,gBAAgB,EAAE,CAAC;YACzC,mEAAmE;YACnE,MAAM,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YACvE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;YAC1D,MAAM,OAAO,GAAyB;gBAClC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;aACpC,CAAC;YAEF,mBAAmB,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;YAErD,MAAM,OAAO,GAAG,MAAM,gBAAgB,EAAE,CAAC;YACzC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import 'reflect-metadata';
|
|
2
|
-
/**
|
|
3
|
-
* Cache options
|
|
4
|
-
*/
|
|
5
|
-
export interface CacheOptions {
|
|
6
|
-
/** Time to live in seconds */
|
|
7
|
-
ttl: number;
|
|
8
|
-
/** Custom cache key generator */
|
|
9
|
-
key?: (input: unknown, context: unknown) => string;
|
|
10
|
-
/** Cache storage (default: in-memory) */
|
|
11
|
-
storage?: CacheStorage;
|
|
12
|
-
}
|
|
13
|
-
/**
|
|
14
|
-
* Cache storage interface
|
|
15
|
-
*/
|
|
16
|
-
export interface CacheStorage {
|
|
17
|
-
get(key: string): Promise<unknown> | unknown;
|
|
18
|
-
set(key: string, value: unknown, ttl: number): Promise<void> | void;
|
|
19
|
-
delete(key: string): Promise<void> | void;
|
|
20
|
-
clear(): Promise<void> | void;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Default in-memory cache storage
|
|
24
|
-
*/
|
|
25
|
-
export declare class InMemoryCacheStorage implements CacheStorage {
|
|
26
|
-
private cache;
|
|
27
|
-
get(key: string): unknown;
|
|
28
|
-
set(key: string, value: unknown, ttl: number): void;
|
|
29
|
-
delete(key: string): void;
|
|
30
|
-
clear(): void;
|
|
31
|
-
private cleanup;
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Cache decorator - caches tool results for a specified duration
|
|
35
|
-
*
|
|
36
|
-
* @example
|
|
37
|
-
* ```typescript
|
|
38
|
-
* @Tool({ name: 'get_products', ... })
|
|
39
|
-
* @Cache({ ttl: 300 }) // Cache for 5 minutes
|
|
40
|
-
* async getProducts(input: unknown) {
|
|
41
|
-
* return await this.database.query('SELECT * FROM products');
|
|
42
|
-
* }
|
|
43
|
-
*
|
|
44
|
-
* // With custom cache key
|
|
45
|
-
* @Cache({
|
|
46
|
-
* ttl: 300,
|
|
47
|
-
* key: (input) => `products:${(input as {category: string}).category}`
|
|
48
|
-
* })
|
|
49
|
-
* async getProducts(input: unknown) { }
|
|
50
|
-
* ```
|
|
51
|
-
*/
|
|
52
|
-
export declare function Cache(options: CacheOptions): MethodDecorator;
|
|
53
|
-
/**
|
|
54
|
-
* Get cache options from metadata
|
|
55
|
-
*/
|
|
56
|
-
export declare function getCacheMetadata(target: object, propertyKey: string | symbol): CacheOptions | undefined;
|
|
57
|
-
/**
|
|
58
|
-
* Clear cache for a specific key or all keys
|
|
59
|
-
*/
|
|
60
|
-
export declare function clearCache(key?: string): Promise<void>;
|
|
61
|
-
//# sourceMappingURL=cache.decorator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cache.decorator.d.ts","sourceRoot":"","sources":["../../../src/core/decorators/cache.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAI1B;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,8BAA8B;IAC9B,GAAG,EAAE,MAAM,CAAC;IAEZ,iCAAiC;IACjC,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,KAAK,MAAM,CAAC;IAEnD,yCAAyC;IACzC,OAAO,CAAC,EAAE,YAAY,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IAC7C,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IACpE,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC1C,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CAC/B;AAED;;GAEG;AACH,qBAAa,oBAAqB,YAAW,YAAY;IACvD,OAAO,CAAC,KAAK,CAA0D;IAEvE,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAYzB,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI;IAOnD,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAIzB,KAAK,IAAI,IAAI;IAKb,OAAO,CAAC,OAAO;CAQhB;AAKD;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,eAAe,CA4C5D;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,MAAM,GAAG,YAAY,GAAG,SAAS,CAEvG;AAED;;GAEG;AACH,wBAAsB,UAAU,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAM5D"}
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
import 'reflect-metadata';
|
|
2
|
-
const CACHE_KEY = 'nitrostack:cache';
|
|
3
|
-
/**
|
|
4
|
-
* Default in-memory cache storage
|
|
5
|
-
*/
|
|
6
|
-
export class InMemoryCacheStorage {
|
|
7
|
-
cache = new Map();
|
|
8
|
-
get(key) {
|
|
9
|
-
const item = this.cache.get(key);
|
|
10
|
-
if (!item)
|
|
11
|
-
return null;
|
|
12
|
-
if (item.expires < Date.now()) {
|
|
13
|
-
this.cache.delete(key);
|
|
14
|
-
return null;
|
|
15
|
-
}
|
|
16
|
-
return item.value;
|
|
17
|
-
}
|
|
18
|
-
set(key, value, ttl) {
|
|
19
|
-
this.cache.set(key, {
|
|
20
|
-
value,
|
|
21
|
-
expires: Date.now() + (ttl * 1000),
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
delete(key) {
|
|
25
|
-
this.cache.delete(key);
|
|
26
|
-
}
|
|
27
|
-
clear() {
|
|
28
|
-
this.cache.clear();
|
|
29
|
-
}
|
|
30
|
-
// Cleanup expired entries periodically
|
|
31
|
-
cleanup() {
|
|
32
|
-
const now = Date.now();
|
|
33
|
-
for (const [key, item] of this.cache.entries()) {
|
|
34
|
-
if (item.expires < now) {
|
|
35
|
-
this.cache.delete(key);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
// Default cache storage instance
|
|
41
|
-
const defaultStorage = new InMemoryCacheStorage();
|
|
42
|
-
/**
|
|
43
|
-
* Cache decorator - caches tool results for a specified duration
|
|
44
|
-
*
|
|
45
|
-
* @example
|
|
46
|
-
* ```typescript
|
|
47
|
-
* @Tool({ name: 'get_products', ... })
|
|
48
|
-
* @Cache({ ttl: 300 }) // Cache for 5 minutes
|
|
49
|
-
* async getProducts(input: unknown) {
|
|
50
|
-
* return await this.database.query('SELECT * FROM products');
|
|
51
|
-
* }
|
|
52
|
-
*
|
|
53
|
-
* // With custom cache key
|
|
54
|
-
* @Cache({
|
|
55
|
-
* ttl: 300,
|
|
56
|
-
* key: (input) => `products:${(input as {category: string}).category}`
|
|
57
|
-
* })
|
|
58
|
-
* async getProducts(input: unknown) { }
|
|
59
|
-
* ```
|
|
60
|
-
*/
|
|
61
|
-
export function Cache(options) {
|
|
62
|
-
return (target, propertyKey, descriptor) => {
|
|
63
|
-
const originalMethod = descriptor.value;
|
|
64
|
-
descriptor.value = async function (...args) {
|
|
65
|
-
const storage = options.storage || defaultStorage;
|
|
66
|
-
const input = args[0];
|
|
67
|
-
const context = args[1];
|
|
68
|
-
// Generate cache key
|
|
69
|
-
let cacheKey;
|
|
70
|
-
if (options.key) {
|
|
71
|
-
cacheKey = options.key(input, context);
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
cacheKey = `${target.constructor.name}:${String(propertyKey)}:${JSON.stringify(input)}`;
|
|
75
|
-
}
|
|
76
|
-
// Check cache
|
|
77
|
-
const cached = await storage.get(cacheKey);
|
|
78
|
-
if (cached !== null && cached !== undefined) {
|
|
79
|
-
if (context?.logger) {
|
|
80
|
-
context.logger.info(`[Cache] Hit for key: ${cacheKey}`);
|
|
81
|
-
}
|
|
82
|
-
return cached;
|
|
83
|
-
}
|
|
84
|
-
// Execute original method
|
|
85
|
-
const result = await originalMethod.apply(this, args);
|
|
86
|
-
// Store in cache
|
|
87
|
-
await storage.set(cacheKey, result, options.ttl);
|
|
88
|
-
if (context?.logger) {
|
|
89
|
-
context.logger.info(`[Cache] Miss for key: ${cacheKey}, stored for ${options.ttl}s`);
|
|
90
|
-
}
|
|
91
|
-
return result;
|
|
92
|
-
};
|
|
93
|
-
// Store metadata
|
|
94
|
-
Reflect.defineMetadata(CACHE_KEY, options, target, propertyKey);
|
|
95
|
-
return descriptor;
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
/**
|
|
99
|
-
* Get cache options from metadata
|
|
100
|
-
*/
|
|
101
|
-
export function getCacheMetadata(target, propertyKey) {
|
|
102
|
-
return Reflect.getMetadata(CACHE_KEY, target, propertyKey);
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Clear cache for a specific key or all keys
|
|
106
|
-
*/
|
|
107
|
-
export async function clearCache(key) {
|
|
108
|
-
if (key) {
|
|
109
|
-
await defaultStorage.delete(key);
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
await defaultStorage.clear();
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
//# sourceMappingURL=cache.decorator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cache.decorator.js","sourceRoot":"","sources":["../../../src/core/decorators/cache.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAE1B,MAAM,SAAS,GAAG,kBAAkB,CAAC;AA0BrC;;GAEG;AACH,MAAM,OAAO,oBAAoB;IACvB,KAAK,GAAG,IAAI,GAAG,EAA+C,CAAC;IAEvE,GAAG,CAAC,GAAW;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI;YAAE,OAAO,IAAI,CAAC;QAEvB,IAAI,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAc,EAAE,GAAW;QAC1C,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,OAAO,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC;SACnC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED,uCAAuC;IAC/B,OAAO;QACb,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;YAC/C,IAAI,IAAI,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC;gBACvB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAED,iCAAiC;AACjC,MAAM,cAAc,GAAG,IAAI,oBAAoB,EAAE,CAAC;AAElD;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,KAAK,CAAC,OAAqB;IACzC,OAAO,CAAC,MAAc,EAAE,WAA4B,EAAE,UAA8B,EAAE,EAAE;QACtF,MAAM,cAAc,GAAG,UAAU,CAAC,KAAK,CAAC;QAExC,UAAU,CAAC,KAAK,GAAG,KAAK,WAAW,GAAG,IAAe;YACnD,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,cAAc,CAAC;YAClD,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACtB,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAA6D,CAAC;YAEpF,qBAAqB;YACrB,IAAI,QAAgB,CAAC;YACrB,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChB,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YACzC,CAAC;iBAAM,CAAC;gBACN,QAAQ,GAAG,GAAI,MAA4C,CAAC,WAAW,CAAC,IAAI,IAAI,MAAM,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;YACjI,CAAC;YAED,cAAc;YACd,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC3C,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC5C,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;oBACpB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,QAAQ,EAAE,CAAC,CAAC;gBAC1D,CAAC;gBACD,OAAO,MAAM,CAAC;YAChB,CAAC;YAED,0BAA0B;YAC1B,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAEtD,iBAAiB;YACjB,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;YAEjD,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;gBACpB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,QAAQ,gBAAgB,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC;YACvF,CAAC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;QAEF,iBAAiB;QACjB,OAAO,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAEhE,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,MAAc,EAAE,WAA4B;IAC3E,OAAO,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;AAC7D,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,GAAY;IAC3C,IAAI,GAAG,EAAE,CAAC;QACR,MAAM,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC;SAAM,CAAC;QACN,MAAM,cAAc,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;AACH,CAAC"}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import 'reflect-metadata';
|
|
2
|
-
/**
|
|
3
|
-
* Health check result
|
|
4
|
-
*/
|
|
5
|
-
export interface HealthCheckResult {
|
|
6
|
-
status: 'up' | 'down' | 'degraded';
|
|
7
|
-
message?: string;
|
|
8
|
-
details?: unknown;
|
|
9
|
-
timestamp?: number;
|
|
10
|
-
}
|
|
11
|
-
/**
|
|
12
|
-
* Health check interface
|
|
13
|
-
*/
|
|
14
|
-
export interface HealthCheckInterface {
|
|
15
|
-
check(): Promise<HealthCheckResult> | HealthCheckResult;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Health check options
|
|
19
|
-
*/
|
|
20
|
-
export interface HealthCheckOptions {
|
|
21
|
-
/** Health check name/identifier */
|
|
22
|
-
name: string;
|
|
23
|
-
/** Description */
|
|
24
|
-
description?: string;
|
|
25
|
-
/** Interval to run health check (in seconds) */
|
|
26
|
-
interval?: number;
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Health check decorator - marks a class as a health check
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
* ```typescript
|
|
33
|
-
* @HealthCheck({ name: 'database', description: 'Database connectivity' })
|
|
34
|
-
* export class DatabaseHealthCheck implements HealthCheckInterface {
|
|
35
|
-
* constructor(private database: DatabaseService) {}
|
|
36
|
-
*
|
|
37
|
-
* async check(): Promise<HealthCheckResult> {
|
|
38
|
-
* try {
|
|
39
|
-
* await this.database.ping();
|
|
40
|
-
* return { status: 'up', message: 'Database is healthy' };
|
|
41
|
-
* } catch (error) {
|
|
42
|
-
* return {
|
|
43
|
-
* status: 'down',
|
|
44
|
-
* message: 'Database connection failed',
|
|
45
|
-
* details: error.message
|
|
46
|
-
* };
|
|
47
|
-
* }
|
|
48
|
-
* }
|
|
49
|
-
* }
|
|
50
|
-
* ```
|
|
51
|
-
*/
|
|
52
|
-
export declare function HealthCheck(options: HealthCheckOptions): ClassDecorator;
|
|
53
|
-
/**
|
|
54
|
-
* Register a health check
|
|
55
|
-
*/
|
|
56
|
-
export declare function registerHealthCheck(checker: HealthCheckInterface, options: HealthCheckOptions): void;
|
|
57
|
-
/**
|
|
58
|
-
* Get all health check results
|
|
59
|
-
*/
|
|
60
|
-
export declare function getAllHealthChecks(): Promise<Record<string, HealthCheckResult>>;
|
|
61
|
-
/**
|
|
62
|
-
* Get a specific health check result
|
|
63
|
-
*/
|
|
64
|
-
export declare function getHealthCheck(name: string): Promise<HealthCheckResult | null>;
|
|
65
|
-
/**
|
|
66
|
-
* Get overall health status
|
|
67
|
-
*/
|
|
68
|
-
export declare function getOverallHealth(): Promise<{
|
|
69
|
-
status: 'healthy' | 'unhealthy' | 'degraded';
|
|
70
|
-
checks: Record<string, HealthCheckResult>;
|
|
71
|
-
}>;
|
|
72
|
-
/**
|
|
73
|
-
* Check if a class is a health check
|
|
74
|
-
*/
|
|
75
|
-
export declare function isHealthCheck(target: object): boolean;
|
|
76
|
-
/**
|
|
77
|
-
* Get health check options from metadata
|
|
78
|
-
*/
|
|
79
|
-
export declare function getHealthCheckMetadata(target: object): HealthCheckOptions | undefined;
|
|
80
|
-
//# sourceMappingURL=health-check.decorator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"health-check.decorator.d.ts","sourceRoot":"","sources":["../../../src/core/decorators/health-check.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAI1B;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,IAAI,GAAG,MAAM,GAAG,UAAU,CAAC;IACnC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,KAAK,IAAI,OAAO,CAAC,iBAAiB,CAAC,GAAG,iBAAiB,CAAC;CACzD;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,mCAAmC;IACnC,IAAI,EAAE,MAAM,CAAC;IAEb,kBAAkB;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,gDAAgD;IAChD,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AASD;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,kBAAkB,GAAG,cAAc,CAIvE;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,kBAAkB,GAAG,IAAI,CA4BpG;AAED;;GAEG;AACH,wBAAsB,kBAAkB,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAwBrF;AAED;;GAEG;AACH,wBAAsB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC,CAsBpF;AAED;;GAEG;AACH,wBAAsB,gBAAgB,IAAI,OAAO,CAAC;IAChD,MAAM,EAAE,SAAS,GAAG,WAAW,GAAG,UAAU,CAAC;IAC7C,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;CAC3C,CAAC,CAkBD;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAErD;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS,CAErF"}
|