@gravito/radiance 1.0.4 → 1.0.5
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/README.md +30 -7
- package/dist/core/src/Application.d.ts +256 -0
- package/dist/core/src/CommandKernel.d.ts +33 -0
- package/dist/core/src/ConfigManager.d.ts +65 -0
- package/dist/core/src/Container/RequestScopeManager.d.ts +62 -0
- package/dist/core/src/Container/RequestScopeMetrics.d.ts +144 -0
- package/dist/core/src/Container.d.ts +153 -0
- package/dist/core/src/ErrorHandler.d.ts +66 -0
- package/dist/core/src/Event.d.ts +5 -0
- package/dist/core/src/EventManager.d.ts +123 -0
- package/dist/core/src/GlobalErrorHandlers.d.ts +47 -0
- package/dist/core/src/GravitoServer.d.ts +28 -0
- package/dist/core/src/HookManager.d.ts +435 -0
- package/dist/core/src/Listener.d.ts +4 -0
- package/dist/core/src/Logger.d.ts +20 -0
- package/dist/core/src/PlanetCore.d.ts +402 -0
- package/dist/core/src/RequestContext.d.ts +97 -0
- package/dist/core/src/Route.d.ts +36 -0
- package/dist/core/src/Router.d.ts +270 -0
- package/dist/core/src/ServiceProvider.d.ts +178 -0
- package/dist/core/src/adapters/GravitoEngineAdapter.d.ts +27 -0
- package/dist/core/src/adapters/bun/BunContext.d.ts +54 -0
- package/dist/core/src/adapters/bun/BunNativeAdapter.d.ts +66 -0
- package/dist/core/src/adapters/bun/BunRequest.d.ts +31 -0
- package/dist/core/src/adapters/bun/BunWebSocketHandler.d.ts +48 -0
- package/dist/core/src/adapters/bun/RadixNode.d.ts +19 -0
- package/dist/core/src/adapters/bun/RadixRouter.d.ts +32 -0
- package/dist/core/src/adapters/bun/index.d.ts +7 -0
- package/dist/core/src/adapters/bun/types.d.ts +20 -0
- package/dist/core/src/adapters/types.d.ts +235 -0
- package/dist/core/src/binary/BinaryUtils.d.ts +105 -0
- package/dist/core/src/binary/index.d.ts +5 -0
- package/dist/core/src/cli/queue-commands.d.ts +6 -0
- package/dist/core/src/compat/async-local-storage.d.ts +7 -0
- package/dist/core/src/compat/crypto.d.ts +6 -0
- package/dist/core/src/engine/AOTRouter.d.ts +139 -0
- package/dist/core/src/engine/FastContext.d.ts +141 -0
- package/dist/core/src/engine/Gravito.d.ts +131 -0
- package/dist/core/src/engine/MinimalContext.d.ts +102 -0
- package/dist/core/src/engine/analyzer.d.ts +113 -0
- package/dist/core/src/engine/constants.d.ts +23 -0
- package/dist/core/src/engine/index.d.ts +26 -0
- package/dist/core/src/engine/path.d.ts +26 -0
- package/dist/core/src/engine/pool.d.ts +83 -0
- package/dist/core/src/engine/types.d.ts +149 -0
- package/dist/core/src/error-handling/RequestScopeErrorContext.d.ts +126 -0
- package/dist/core/src/events/BackpressureManager.d.ts +215 -0
- package/dist/core/src/events/CircuitBreaker.d.ts +229 -0
- package/dist/core/src/events/DeadLetterQueue.d.ts +219 -0
- package/dist/core/src/events/EventBackend.d.ts +12 -0
- package/dist/core/src/events/EventOptions.d.ts +204 -0
- package/dist/core/src/events/EventPriorityQueue.d.ts +63 -0
- package/dist/core/src/events/FlowControlStrategy.d.ts +109 -0
- package/dist/core/src/events/IdempotencyCache.d.ts +60 -0
- package/dist/core/src/events/MessageQueueBridge.d.ts +184 -0
- package/dist/core/src/events/PriorityEscalationManager.d.ts +82 -0
- package/dist/core/src/events/RetryScheduler.d.ts +104 -0
- package/dist/core/src/events/WorkerPool.d.ts +98 -0
- package/dist/core/src/events/WorkerPoolConfig.d.ts +153 -0
- package/dist/core/src/events/WorkerPoolMetrics.d.ts +65 -0
- package/dist/core/src/events/aggregation/AggregationWindow.d.ts +77 -0
- package/dist/core/src/events/aggregation/DeduplicationManager.d.ts +135 -0
- package/dist/core/src/events/aggregation/EventAggregationManager.d.ts +108 -0
- package/dist/core/src/events/aggregation/EventBatcher.d.ts +99 -0
- package/dist/core/src/events/aggregation/types.d.ts +117 -0
- package/dist/core/src/events/index.d.ts +26 -0
- package/dist/core/src/events/observability/EventMetrics.d.ts +132 -0
- package/dist/core/src/events/observability/EventTracer.d.ts +68 -0
- package/dist/core/src/events/observability/EventTracing.d.ts +161 -0
- package/dist/core/src/events/observability/OTelEventMetrics.d.ts +332 -0
- package/dist/core/src/events/observability/ObservableHookManager.d.ts +108 -0
- package/dist/core/src/events/observability/StreamWorkerMetrics.d.ts +76 -0
- package/dist/core/src/events/observability/index.d.ts +24 -0
- package/dist/core/src/events/observability/metrics-types.d.ts +16 -0
- package/dist/core/src/events/queue-core.d.ts +77 -0
- package/dist/core/src/events/task-executor.d.ts +51 -0
- package/dist/core/src/events/types.d.ts +134 -0
- package/dist/core/src/exceptions/AuthenticationException.d.ts +8 -0
- package/dist/core/src/exceptions/AuthorizationException.d.ts +8 -0
- package/dist/core/src/exceptions/CircularDependencyException.d.ts +9 -0
- package/dist/core/src/exceptions/GravitoException.d.ts +23 -0
- package/dist/core/src/exceptions/HttpException.d.ts +9 -0
- package/dist/core/src/exceptions/ModelNotFoundException.d.ts +10 -0
- package/dist/core/src/exceptions/ValidationException.d.ts +22 -0
- package/dist/core/src/exceptions/index.d.ts +7 -0
- package/dist/core/src/ffi/NativeAccelerator.d.ts +62 -0
- package/dist/core/src/ffi/NativeHasher.d.ts +139 -0
- package/dist/core/src/ffi/cbor-fallback.d.ts +96 -0
- package/dist/core/src/ffi/hash-fallback.d.ts +33 -0
- package/dist/core/src/ffi/index.d.ts +10 -0
- package/dist/core/src/ffi/types.d.ts +135 -0
- package/dist/core/src/health/HealthProvider.d.ts +67 -0
- package/dist/core/src/helpers/Arr.d.ts +19 -0
- package/dist/core/src/helpers/Str.d.ts +38 -0
- package/dist/core/src/helpers/data.d.ts +25 -0
- package/dist/core/src/helpers/errors.d.ts +34 -0
- package/dist/core/src/helpers/response.d.ts +41 -0
- package/dist/core/src/helpers.d.ts +338 -0
- package/dist/core/src/hooks/ActionManager.d.ts +132 -0
- package/dist/core/src/hooks/AsyncDetector.d.ts +84 -0
- package/dist/core/src/hooks/FilterManager.d.ts +71 -0
- package/dist/core/src/hooks/MigrationWarner.d.ts +24 -0
- package/dist/core/src/hooks/dlq-operations.d.ts +60 -0
- package/dist/core/src/hooks/types.d.ts +107 -0
- package/dist/core/src/http/CookieJar.d.ts +51 -0
- package/dist/core/src/http/cookie.d.ts +29 -0
- package/dist/core/src/http/types.d.ts +395 -0
- package/dist/core/src/index.d.ts +565 -0
- package/dist/core/src/observability/QueueDashboard.d.ts +136 -0
- package/dist/core/src/observability/contracts.d.ts +137 -0
- package/dist/core/src/reliability/DeadLetterQueueManager.d.ts +349 -0
- package/dist/core/src/reliability/RetryPolicy.d.ts +217 -0
- package/dist/core/src/reliability/index.d.ts +6 -0
- package/dist/core/src/router/ControllerDispatcher.d.ts +12 -0
- package/dist/core/src/router/RequestValidator.d.ts +20 -0
- package/dist/core/src/runtime/adapter-bun.d.ts +12 -0
- package/dist/core/src/runtime/adapter-deno.d.ts +12 -0
- package/dist/core/src/runtime/adapter-node.d.ts +12 -0
- package/dist/core/src/runtime/adapter-unknown.d.ts +13 -0
- package/dist/core/src/runtime/archive.d.ts +17 -0
- package/dist/core/src/runtime/compression.d.ts +21 -0
- package/dist/core/src/runtime/deep-equals.d.ts +56 -0
- package/dist/core/src/runtime/detection.d.ts +22 -0
- package/dist/core/src/runtime/escape.d.ts +34 -0
- package/dist/core/src/runtime/index.d.ts +44 -0
- package/dist/core/src/runtime/markdown.d.ts +44 -0
- package/dist/core/src/runtime/types.d.ts +436 -0
- package/dist/core/src/runtime-helpers.d.ts +67 -0
- package/dist/core/src/runtime.d.ts +11 -0
- package/dist/core/src/security/Encrypter.d.ts +33 -0
- package/dist/core/src/security/Hasher.d.ts +29 -0
- package/dist/core/src/testing/HttpTester.d.ts +40 -0
- package/dist/core/src/testing/TestResponse.d.ts +78 -0
- package/dist/core/src/testing/index.d.ts +2 -0
- package/dist/core/src/transpiler-utils.d.ts +170 -0
- package/dist/core/src/types/events.d.ts +94 -0
- package/dist/index.js +1 -294
- package/dist/index.js.map +3 -10
- package/dist/radiance/src/BroadcastManager.d.ts +124 -0
- package/dist/radiance/src/OrbitRadiance.d.ts +98 -0
- package/dist/radiance/src/channels/Channel.d.ts +86 -0
- package/dist/radiance/src/drivers/AblyDriver.d.ts +73 -0
- package/dist/radiance/src/drivers/BroadcastDriver.d.ts +50 -0
- package/dist/radiance/src/drivers/PusherDriver.d.ts +95 -0
- package/dist/radiance/src/drivers/RedisDriver.d.ts +83 -0
- package/dist/radiance/src/drivers/WebSocketDriver.d.ts +89 -0
- package/dist/radiance/src/index.d.ts +39 -0
- package/package.json +4 -2
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import type { RequestScopeManager } from './Container/RequestScopeManager';
|
|
2
|
+
/**
|
|
3
|
+
* Factory type for creating service instances
|
|
4
|
+
*/
|
|
5
|
+
export type Factory<T> = (container: Container) => T;
|
|
6
|
+
/**
|
|
7
|
+
* ServiceMap interface for type-safe IoC resolution.
|
|
8
|
+
*
|
|
9
|
+
* Extend this interface via module augmentation to get type inference:
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* declare module '@gravito/core' {
|
|
13
|
+
* interface ServiceMap {
|
|
14
|
+
* logger: Logger
|
|
15
|
+
* db: DatabaseConnection
|
|
16
|
+
* }
|
|
17
|
+
* }
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export type ServiceMap = {};
|
|
21
|
+
/**
|
|
22
|
+
* ServiceKey represents the allowed keys for service resolution.
|
|
23
|
+
* Includes keys from ServiceMap, generic strings, or symbols.
|
|
24
|
+
*/
|
|
25
|
+
export type ServiceKey = keyof ServiceMap | (string & {}) | symbol;
|
|
26
|
+
/**
|
|
27
|
+
* Container - Simple Dependency Injection Container.
|
|
28
|
+
* Manages service bindings and singleton instances.
|
|
29
|
+
* @public
|
|
30
|
+
*/
|
|
31
|
+
export declare class Container {
|
|
32
|
+
private bindings;
|
|
33
|
+
private instances;
|
|
34
|
+
private resolutionStack;
|
|
35
|
+
/**
|
|
36
|
+
* Run a function within a request scope context.
|
|
37
|
+
*
|
|
38
|
+
* All service resolutions within the function will use the provided scope,
|
|
39
|
+
* enabling request-scoped service instances to be properly isolated.
|
|
40
|
+
*
|
|
41
|
+
* @template T - The return type of the function.
|
|
42
|
+
* @param scope - The RequestScopeManager for this request.
|
|
43
|
+
* @param fn - The function to execute within the scope.
|
|
44
|
+
* @returns The result of the function.
|
|
45
|
+
*
|
|
46
|
+
* @example
|
|
47
|
+
* ```typescript
|
|
48
|
+
* const scope = new RequestScopeManager()
|
|
49
|
+
* const result = await Container.runWithScope(scope, async () => {
|
|
50
|
+
* const service = container.make('requestScoped')
|
|
51
|
+
* return service.doSomething()
|
|
52
|
+
* })
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
static runWithScope<T>(scope: RequestScopeManager, fn: () => T | Promise<T>): T | Promise<T>;
|
|
56
|
+
/**
|
|
57
|
+
* Bind a service to the container.
|
|
58
|
+
*
|
|
59
|
+
* A new instance will be created by the factory function every time the
|
|
60
|
+
* service is resolved from the container.
|
|
61
|
+
*
|
|
62
|
+
* @template T - The type of the service being bound.
|
|
63
|
+
* @param key - The unique identifier for the service.
|
|
64
|
+
* @param factory - The factory function that creates the service instance.
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```typescript
|
|
68
|
+
* container.bind('logger', (c) => new ConsoleLogger());
|
|
69
|
+
* ```
|
|
70
|
+
*/
|
|
71
|
+
bind<T>(key: ServiceKey, factory: Factory<T>): void;
|
|
72
|
+
/**
|
|
73
|
+
* Bind a shared service to the container (Singleton).
|
|
74
|
+
*
|
|
75
|
+
* The factory function will be called only once, and the same instance
|
|
76
|
+
* will be returned on every subsequent resolution.
|
|
77
|
+
*
|
|
78
|
+
* @template T - The type of the service being bound.
|
|
79
|
+
* @param key - The unique identifier for the service.
|
|
80
|
+
* @param factory - The factory function that creates the service instance.
|
|
81
|
+
*
|
|
82
|
+
* @example
|
|
83
|
+
* ```typescript
|
|
84
|
+
* container.singleton('db', (c) => new DatabaseConnection());
|
|
85
|
+
* ```
|
|
86
|
+
*/
|
|
87
|
+
singleton<T>(key: ServiceKey, factory: Factory<T>): void;
|
|
88
|
+
/**
|
|
89
|
+
* Bind a request-scoped service to the container.
|
|
90
|
+
*
|
|
91
|
+
* A new instance will be created for each request and cached within that request.
|
|
92
|
+
* The service is automatically cleaned up when the request ends.
|
|
93
|
+
*
|
|
94
|
+
* @template T - The type of the service being bound.
|
|
95
|
+
* @param key - The unique identifier for the service.
|
|
96
|
+
* @param factory - The factory function that creates the service instance.
|
|
97
|
+
*
|
|
98
|
+
* @example
|
|
99
|
+
* ```typescript
|
|
100
|
+
* container.scoped('requestCache', (c) => new RequestProductCache());
|
|
101
|
+
* ```
|
|
102
|
+
*/
|
|
103
|
+
scoped<T>(key: ServiceKey, factory: Factory<T>): void;
|
|
104
|
+
/**
|
|
105
|
+
* Register an existing instance as a shared service.
|
|
106
|
+
*
|
|
107
|
+
* @param key - The unique identifier for the service.
|
|
108
|
+
* @param instance - The instance to register.
|
|
109
|
+
*/
|
|
110
|
+
instance<T>(key: ServiceKey, instance: T): void;
|
|
111
|
+
/**
|
|
112
|
+
* Check if a service is request-scoped.
|
|
113
|
+
*
|
|
114
|
+
* @param key - The service key to check.
|
|
115
|
+
* @returns True if the service is request-scoped.
|
|
116
|
+
*/
|
|
117
|
+
isRequestScoped(key: ServiceKey): boolean;
|
|
118
|
+
/**
|
|
119
|
+
* Resolve a service instance from the container.
|
|
120
|
+
*
|
|
121
|
+
* Automatically handles singleton caching and factory execution.
|
|
122
|
+
*
|
|
123
|
+
* @template T - The expected type of the service.
|
|
124
|
+
* @param key - The unique identifier for the service.
|
|
125
|
+
* @returns The resolved service instance.
|
|
126
|
+
* @throws Error if the service key is not found in the container.
|
|
127
|
+
*
|
|
128
|
+
* @example
|
|
129
|
+
* ```typescript
|
|
130
|
+
* const logger = container.make<Logger>('logger');
|
|
131
|
+
* ```
|
|
132
|
+
*/
|
|
133
|
+
make<K extends keyof ServiceMap>(key: K): ServiceMap[K];
|
|
134
|
+
make<T>(key: ServiceKey): T;
|
|
135
|
+
/**
|
|
136
|
+
* Check if a service is bound or has an instance in the container.
|
|
137
|
+
*
|
|
138
|
+
* @param key - The service key to check.
|
|
139
|
+
* @returns True if the service exists.
|
|
140
|
+
*/
|
|
141
|
+
has(key: ServiceKey): boolean;
|
|
142
|
+
/**
|
|
143
|
+
* Flush all instances and bindings from the container.
|
|
144
|
+
* Resets the container to an empty state.
|
|
145
|
+
*/
|
|
146
|
+
flush(): void;
|
|
147
|
+
/**
|
|
148
|
+
* Forget a specific instance while keeping its binding.
|
|
149
|
+
*
|
|
150
|
+
* @param key - The service key to forget.
|
|
151
|
+
*/
|
|
152
|
+
forget(key: ServiceKey): void;
|
|
153
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview ErrorHandler - Centralized Error Handling for Gravito Framework
|
|
3
|
+
*
|
|
4
|
+
* Extracted from PlanetCore to follow Single Responsibility Principle.
|
|
5
|
+
* Handles HTTP errors, validation errors, and error rendering.
|
|
6
|
+
*
|
|
7
|
+
* @module @gravito/core
|
|
8
|
+
* @since 1.3.0
|
|
9
|
+
*/
|
|
10
|
+
import type { HookManager } from './HookManager';
|
|
11
|
+
import type { GravitoContext } from './http/types';
|
|
12
|
+
import type { Logger } from './Logger';
|
|
13
|
+
/**
|
|
14
|
+
* HTTP Status Code to Error Code mapping
|
|
15
|
+
*/
|
|
16
|
+
export declare function codeFromStatus(status: number): string;
|
|
17
|
+
/**
|
|
18
|
+
* HTTP Status Code to Message mapping
|
|
19
|
+
*/
|
|
20
|
+
export declare function messageFromStatus(status: number): string;
|
|
21
|
+
/**
|
|
22
|
+
* Dependencies injected into ErrorHandler
|
|
23
|
+
* @public
|
|
24
|
+
*/
|
|
25
|
+
export interface ErrorHandlerDeps {
|
|
26
|
+
logger: Logger;
|
|
27
|
+
hooks: HookManager;
|
|
28
|
+
getCore: () => unknown;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* ErrorHandler - Centralized error handling logic
|
|
32
|
+
*
|
|
33
|
+
* @example
|
|
34
|
+
* ```typescript
|
|
35
|
+
* const handler = new ErrorHandler({ logger, hooks, getCore: () => core })
|
|
36
|
+
* adapter.onError(handler.handleError.bind(handler))
|
|
37
|
+
* adapter.onNotFound(handler.handleNotFound.bind(handler))
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
export declare class ErrorHandler {
|
|
41
|
+
private deps;
|
|
42
|
+
constructor(deps: ErrorHandlerDeps);
|
|
43
|
+
/**
|
|
44
|
+
* Handle application errors
|
|
45
|
+
*
|
|
46
|
+
* Integrates RequestScope cleanup to ensure proper resource management
|
|
47
|
+
* even when errors occur during request processing.
|
|
48
|
+
*/
|
|
49
|
+
handleError(err: unknown, c: GravitoContext): Promise<Response>;
|
|
50
|
+
/**
|
|
51
|
+
* Handle 404 Not Found errors
|
|
52
|
+
*/
|
|
53
|
+
handleNotFound(c: GravitoContext): Promise<Response>;
|
|
54
|
+
/**
|
|
55
|
+
* Handle validation error redirect for HTML requests
|
|
56
|
+
*/
|
|
57
|
+
private handleValidationRedirect;
|
|
58
|
+
/**
|
|
59
|
+
* Log error based on context settings
|
|
60
|
+
*/
|
|
61
|
+
private logError;
|
|
62
|
+
/**
|
|
63
|
+
* Render error response (HTML or JSON)
|
|
64
|
+
*/
|
|
65
|
+
private renderErrorResponse;
|
|
66
|
+
}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Event } from './Event';
|
|
2
|
+
import type { Listener } from './Listener';
|
|
3
|
+
import type { PlanetCore } from './PlanetCore';
|
|
4
|
+
/**
|
|
5
|
+
* Listener registration metadata.
|
|
6
|
+
*/
|
|
7
|
+
interface ListenerRegistration<TEvent extends Event = Event> {
|
|
8
|
+
listener: Listener<TEvent> | (new () => Listener<TEvent>);
|
|
9
|
+
queue?: string;
|
|
10
|
+
connection?: string;
|
|
11
|
+
delay?: number;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Event manager.
|
|
15
|
+
*
|
|
16
|
+
* Provides type-safe event dispatching and listener registration.
|
|
17
|
+
* Supports both synchronous listeners and asynchronous (queued) listeners.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```typescript
|
|
21
|
+
* class UserRegistered extends Event {
|
|
22
|
+
* constructor(public user: User) {
|
|
23
|
+
* super()
|
|
24
|
+
* }
|
|
25
|
+
* }
|
|
26
|
+
*
|
|
27
|
+
* class SendWelcomeEmail implements Listener<UserRegistered> {
|
|
28
|
+
* async handle(event: UserRegistered): Promise<void> {
|
|
29
|
+
* // send welcome email
|
|
30
|
+
* }
|
|
31
|
+
* }
|
|
32
|
+
*
|
|
33
|
+
* // Register listener
|
|
34
|
+
* core.events.listen(UserRegistered, SendWelcomeEmail)
|
|
35
|
+
*
|
|
36
|
+
* // Dispatch event
|
|
37
|
+
* await core.events.dispatch(new UserRegistered(user))
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
export declare class EventManager {
|
|
41
|
+
private core;
|
|
42
|
+
/**
|
|
43
|
+
* Listener registry.
|
|
44
|
+
* Key: event class or event name
|
|
45
|
+
* Value: listener registrations
|
|
46
|
+
*/
|
|
47
|
+
private listeners;
|
|
48
|
+
/**
|
|
49
|
+
* Broadcast manager (optional, injected by `orbit-broadcasting`).
|
|
50
|
+
*/
|
|
51
|
+
private broadcastManager;
|
|
52
|
+
/**
|
|
53
|
+
* Queue manager (optional, injected by `orbit-queue`).
|
|
54
|
+
*/
|
|
55
|
+
private queueManager;
|
|
56
|
+
constructor(core: PlanetCore);
|
|
57
|
+
/**
|
|
58
|
+
* Register the broadcast manager (called by `orbit-broadcasting`).
|
|
59
|
+
*/
|
|
60
|
+
setBroadcastManager(manager: EventManager['broadcastManager']): void;
|
|
61
|
+
/**
|
|
62
|
+
* Register the queue manager (called by `orbit-queue`).
|
|
63
|
+
*/
|
|
64
|
+
setQueueManager(manager: EventManager['queueManager']): void;
|
|
65
|
+
/**
|
|
66
|
+
* Register an event listener.
|
|
67
|
+
*
|
|
68
|
+
* @param event - Event class or event name
|
|
69
|
+
* @param listener - Listener instance or listener class
|
|
70
|
+
* @param options - Optional queue options
|
|
71
|
+
*
|
|
72
|
+
* @example
|
|
73
|
+
* ```typescript
|
|
74
|
+
* // Synchronous listener
|
|
75
|
+
* core.events.listen(UserRegistered, SendWelcomeEmail)
|
|
76
|
+
*
|
|
77
|
+
* // Queued listener (async)
|
|
78
|
+
* core.events.listen(UserRegistered, SendWelcomeEmail, {
|
|
79
|
+
* queue: 'emails',
|
|
80
|
+
* delay: 60
|
|
81
|
+
* })
|
|
82
|
+
* ```
|
|
83
|
+
*/
|
|
84
|
+
listen<TEvent extends Event>(event: string | (new (...args: unknown[]) => TEvent), listener: Listener<TEvent> | (new () => Listener<TEvent>), options?: {
|
|
85
|
+
queue?: string;
|
|
86
|
+
connection?: string;
|
|
87
|
+
delay?: number;
|
|
88
|
+
}): void;
|
|
89
|
+
/**
|
|
90
|
+
* Remove an event listener.
|
|
91
|
+
*
|
|
92
|
+
* @param event - Event class or event name
|
|
93
|
+
* @param listener - Listener to remove
|
|
94
|
+
*/
|
|
95
|
+
unlisten<TEvent extends Event>(event: string | (new (...args: unknown[]) => TEvent), listener: Listener<TEvent> | (new () => Listener<TEvent>)): void;
|
|
96
|
+
/**
|
|
97
|
+
* Dispatch an event.
|
|
98
|
+
*
|
|
99
|
+
* Runs all registered listeners. If a listener implements `ShouldQueue` or
|
|
100
|
+
* has queue options, the listener will be pushed to the queue for async execution.
|
|
101
|
+
*
|
|
102
|
+
* @param event - Event instance
|
|
103
|
+
*
|
|
104
|
+
* @example
|
|
105
|
+
* ```typescript
|
|
106
|
+
* await core.events.dispatch(new UserRegistered(user))
|
|
107
|
+
* ```
|
|
108
|
+
*/
|
|
109
|
+
dispatch<TEvent extends Event>(event: TEvent): Promise<void>;
|
|
110
|
+
/**
|
|
111
|
+
* Serialize an event (for queueing).
|
|
112
|
+
*/
|
|
113
|
+
private serializeEvent;
|
|
114
|
+
/**
|
|
115
|
+
* Get all registered listeners.
|
|
116
|
+
*/
|
|
117
|
+
getListeners(event?: string | (new () => Event)): ListenerRegistration[];
|
|
118
|
+
/**
|
|
119
|
+
* Clear all listeners.
|
|
120
|
+
*/
|
|
121
|
+
clear(): void;
|
|
122
|
+
}
|
|
123
|
+
export {};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { Logger } from './Logger';
|
|
2
|
+
import type { PlanetCore } from './PlanetCore';
|
|
3
|
+
/**
|
|
4
|
+
* Type of process-level error
|
|
5
|
+
* @public
|
|
6
|
+
*/
|
|
7
|
+
export type GlobalProcessErrorKind = 'unhandledRejection' | 'uncaughtException';
|
|
8
|
+
/**
|
|
9
|
+
* Context payload for global error handler filters/actions
|
|
10
|
+
* @public
|
|
11
|
+
*/
|
|
12
|
+
export type GlobalProcessErrorHandlerContext = {
|
|
13
|
+
core?: PlanetCore;
|
|
14
|
+
kind: GlobalProcessErrorKind;
|
|
15
|
+
error: unknown;
|
|
16
|
+
isProduction: boolean;
|
|
17
|
+
timestamp: number;
|
|
18
|
+
logLevel?: 'error' | 'warn' | 'info' | 'none';
|
|
19
|
+
logMessage?: string;
|
|
20
|
+
exit?: boolean;
|
|
21
|
+
exitCode?: number;
|
|
22
|
+
gracePeriodMs?: number;
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Error handling strategy
|
|
26
|
+
* @public
|
|
27
|
+
*/
|
|
28
|
+
export type GlobalErrorHandlersMode = 'log' | 'exit' | 'exitInProduction';
|
|
29
|
+
/**
|
|
30
|
+
* Options for registering global handlers
|
|
31
|
+
* @public
|
|
32
|
+
*/
|
|
33
|
+
export type RegisterGlobalErrorHandlersOptions = {
|
|
34
|
+
core?: PlanetCore;
|
|
35
|
+
logger?: Logger;
|
|
36
|
+
mode?: GlobalErrorHandlersMode;
|
|
37
|
+
exitCode?: number;
|
|
38
|
+
gracePeriodMs?: number;
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Register process-level error handlers (`unhandledRejection` / `uncaughtException`).
|
|
42
|
+
*
|
|
43
|
+
* - `mode: "log"`: only log/report
|
|
44
|
+
* - `mode: "exit"`: report then `process.exit(exitCode)`
|
|
45
|
+
* - `mode: "exitInProduction"`: exit only when `NODE_ENV=production` (default)
|
|
46
|
+
*/
|
|
47
|
+
export declare function registerGlobalErrorHandlers(options?: RegisterGlobalErrorHandlersOptions): () => void;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type GravitoConfig, PlanetCore } from './PlanetCore';
|
|
2
|
+
/**
|
|
3
|
+
* Manifest describing a Gravito application structure.
|
|
4
|
+
* @public
|
|
5
|
+
*/
|
|
6
|
+
export interface GravitoManifest {
|
|
7
|
+
name: string;
|
|
8
|
+
version?: string;
|
|
9
|
+
modules: string[];
|
|
10
|
+
config?: GravitoConfig;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Function type for asynchronous module resolution.
|
|
14
|
+
* @public
|
|
15
|
+
*/
|
|
16
|
+
export type ModuleResolver = () => Promise<any>;
|
|
17
|
+
/**
|
|
18
|
+
* Gravito 核心啟動引擎 (已解耦)
|
|
19
|
+
*/
|
|
20
|
+
export declare class GravitoServer {
|
|
21
|
+
/**
|
|
22
|
+
* 一鍵建立並組裝伺服器
|
|
23
|
+
* @param manifest 站點描述清單
|
|
24
|
+
* @param resolvers 模組解析器字典
|
|
25
|
+
* @param baseOrbits 基礎軌道模組 (例如 OrbitMonolith)
|
|
26
|
+
*/
|
|
27
|
+
static create(manifest: GravitoManifest, resolvers: Record<string, ModuleResolver>, baseOrbits?: any[]): Promise<PlanetCore>;
|
|
28
|
+
}
|